/* =============================================================
   2026国家标准社区健康体检系统（AI增强版）— 设计系统「数智穹顶」
   深空蓝黑 · 电光青 · 琥珀预警 · 玻璃拟态卡片 · 辉光数据
   ============================================================= */
@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700&family=Noto+Sans+SC:wght@400;500;700&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root{
  --void:#070d18;            /* 页面底 */
  --deep:#0b1424;            /* 深层 */
  --panel:#101b30;           /* 卡片底 */
  --panel-2:#15233c;         /* 卡片亮层 */
  --line:#1f3252;            /* 描边 */
  --line-glow:#2a4a78;
  --txt:#dce7f7;             /* 主文字 */
  --txt-2:#8fa3c4;           /* 次级 */
  --txt-3:#5a6e92;           /* 弱 */
  --cyan:#3ee6c4;            /* 电光青（AI 主色） */
  --cyan-deep:#16957d;
  --cyan-soft:rgba(62,230,196,.12);
  --blue:#4da3ff;            /* 数据蓝 */
  --blue-soft:rgba(77,163,255,.12);
  --amber:#ffb547;           /* 琥珀预警 */
  --amber-soft:rgba(255,181,71,.13);
  --red:#ff6b6b;             /* 危急 */
  --red-soft:rgba(255,107,107,.13);
  --violet:#9d8cff;          /* 少量点缀（模型/算法） */
  --violet-soft:rgba(157,140,255,.12);
  --glow:0 0 18px rgba(62,230,196,.25);
  --disp:'Outfit','Noto Sans SC',sans-serif;
  --sans:'Noto Sans SC',sans-serif;
  --mono:'JetBrains Mono',monospace;
}

*{margin:0;padding:0;box-sizing:border-box}
html{font-size:14px}
body{
  font-family:var(--sans);color:var(--txt);background:var(--void);min-height:100vh;display:flex;
  background-image:
    radial-gradient(ellipse 900px 500px at 75% -10%,rgba(62,230,196,.07),transparent 60%),
    radial-gradient(ellipse 700px 450px at 10% 110%,rgba(77,163,255,.06),transparent 60%),
    radial-gradient(circle,rgba(143,163,196,.05) 1px,transparent 1px);
  background-size:auto,auto,26px 26px;
}
::selection{background:var(--cyan);color:#06231d}
a{color:var(--blue);text-decoration:none}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:9px}
::-webkit-scrollbar-track{background:transparent}

/* ---------- 侧边栏 ---------- */
.sidebar{
  width:226px;flex:0 0 226px;background:linear-gradient(180deg,#0c1626,#091020);
  border-right:1px solid var(--line);min-height:100vh;display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;overflow-y:auto;
}
.brand{display:flex;align-items:center;gap:11px;padding:20px 18px 16px;border-bottom:1px solid var(--line)}
.brand .orb{
  width:38px;height:38px;flex:0 0 38px;border-radius:11px;position:relative;
  background:linear-gradient(135deg,var(--cyan-deep),var(--cyan));
  display:flex;align-items:center;justify-content:center;box-shadow:var(--glow);
}
.brand .orb svg{width:20px;height:20px;stroke:#06231d;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.brand b{font-family:var(--disp);font-size:14.5px;font-weight:600;display:block;line-height:1.3;letter-spacing:.3px}
.brand small{font-size:10px;color:var(--cyan);letter-spacing:1.5px;font-family:var(--mono)}
.nav-group{padding:12px 10px 4px}
.nav-group h6{font-size:10px;color:var(--txt-3);font-weight:500;letter-spacing:2.5px;padding:6px 10px}
.nav-item{
  display:flex;align-items:center;gap:9px;padding:8px 10px;border-radius:8px;
  color:var(--txt-2);font-size:13px;cursor:pointer;transition:.15s;margin-bottom:1px;position:relative;
}
.nav-item svg{width:16px;height:16px;flex:0 0 16px;stroke:currentColor;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.nav-item:hover{background:var(--panel-2);color:var(--txt)}
.nav-item.active{background:var(--cyan-soft);color:var(--cyan);font-weight:500}
.nav-item.active::before{content:'';position:absolute;left:-10px;top:20%;bottom:20%;width:3px;border-radius:3px;background:var(--cyan);box-shadow:var(--glow)}
.nav-item .ai-dot{
  margin-left:auto;font-size:8.5px;font-family:var(--mono);color:var(--cyan);
  border:1px solid rgba(62,230,196,.4);border-radius:4px;padding:0 4px;letter-spacing:.5px;
}
.sidebar-foot{
  margin-top:auto;padding:14px 16px;border-top:1px solid var(--line);
  display:flex;align-items:center;gap:10px;font-size:11px;color:var(--txt-3);
}
.sidebar-foot .avatar{
  width:30px;height:30px;border-radius:50%;background:var(--panel-2);color:var(--cyan);
  display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;flex:0 0 30px;
  border:1px solid var(--line-glow);
}
.sidebar-foot b{color:var(--txt);font-weight:500;display:block;font-size:12px}
.sidebar-foot > svg{width:16px;height:16px;flex:0 0 16px;stroke:var(--txt-3);fill:none;stroke-width:1.8;cursor:pointer}
.sidebar-foot > svg:hover{stroke:var(--cyan)}

/* ---------- 主区域 ---------- */
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{
  height:52px;background:rgba(7,13,24,.8);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);display:flex;align-items:center;
  padding:0 24px;gap:14px;position:sticky;top:0;z-index:50;
}
.topbar .crumb{font-size:12.5px;color:var(--txt-3)}
.topbar .crumb b{color:var(--txt);font-weight:500}
.topbar .spacer{flex:1}
.topbar .clock{font-family:var(--mono);font-size:12px;color:var(--cyan);background:var(--cyan-soft);padding:4px 10px;border-radius:6px;border:1px solid rgba(62,230,196,.25)}
.topbar .org{font-size:12px;color:var(--txt-2);display:flex;align-items:center;gap:6px}
.topbar .org::before{content:'';width:7px;height:7px;border-radius:50%;background:var(--cyan);box-shadow:0 0 8px var(--cyan)}

.content{padding:22px 26px 40px;max-width:1500px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.page-head h1{font-family:var(--disp);font-size:23px;font-weight:600;letter-spacing:.5px}
.page-head h1 .ai-chip{
  display:inline-flex;align-items:center;gap:5px;vertical-align:4px;margin-left:10px;
  font-size:10px;font-weight:500;font-family:var(--mono);letter-spacing:1px;
  color:#06231d;background:linear-gradient(90deg,var(--cyan),#7df0d8);
  border-radius:5px;padding:2px 8px;box-shadow:var(--glow);
}
.page-head p{font-size:12.5px;color:var(--txt-3);margin-top:5px}
.page-actions{display:flex;gap:8px;flex-wrap:wrap}

/* ---------- 按钮 ---------- */
.btn{
  display:inline-flex;align-items:center;gap:6px;padding:7px 15px;border-radius:8px;
  font-size:12.5px;font-weight:500;font-family:var(--sans);cursor:pointer;
  border:1px solid var(--line-glow);background:var(--panel);color:var(--txt-2);transition:.15s;
}
.btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.btn:hover{border-color:var(--cyan);color:var(--cyan)}
.btn.primary{
  background:linear-gradient(90deg,var(--cyan-deep),var(--cyan));border:none;color:#06231d;font-weight:700;
}
.btn.primary:hover{box-shadow:var(--glow);color:#031a15}
.btn.danger{background:var(--red-soft);border-color:rgba(255,107,107,.4);color:var(--red)}
.btn.sm{padding:4px 10px;font-size:11.5px;border-radius:6px}

/* ---------- 卡片 ---------- */
.card{
  background:linear-gradient(180deg,var(--panel),rgba(16,27,48,.7));
  border:1px solid var(--line);border-radius:14px;margin-bottom:18px;overflow:hidden;
  backdrop-filter:blur(6px);
}
.card.glow{border-color:rgba(62,230,196,.35);box-shadow:0 0 30px rgba(62,230,196,.08)}
.card-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:14px 18px;border-bottom:1px solid var(--line);
}
.card-head h3{font-family:var(--disp);font-size:14.5px;font-weight:600;display:flex;align-items:center;gap:8px}
.card-head h3::before{content:'';width:8px;height:8px;border-radius:2px;background:var(--cyan);box-shadow:0 0 8px var(--cyan);transform:rotate(45deg)}
.card-head .sub{font-size:11.5px;color:var(--txt-3);font-weight:400}
.card-body{padding:18px}
.card-body.flush{padding:0}

/* ---------- KPI ---------- */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:18px}
.kpi{
  background:linear-gradient(160deg,var(--panel-2),var(--panel));border:1px solid var(--line);
  border-radius:14px;padding:16px 18px;position:relative;overflow:hidden;
}
.kpi::before{
  content:'';position:absolute;right:-30px;top:-30px;width:90px;height:90px;border-radius:50%;
  background:radial-gradient(circle,var(--cyan-soft),transparent 70%);
}
.kpi.red::before{background:radial-gradient(circle,var(--red-soft),transparent 70%)}
.kpi.amber::before{background:radial-gradient(circle,var(--amber-soft),transparent 70%)}
.kpi.blue::before{background:radial-gradient(circle,var(--blue-soft),transparent 70%)}
.kpi .label{font-size:11.5px;color:var(--txt-3);margin-bottom:7px;letter-spacing:.5px}
.kpi .num{font-family:var(--mono);font-size:27px;font-weight:700;letter-spacing:-.5px;color:var(--cyan)}
.kpi.red .num{color:var(--red)}
.kpi.amber .num{color:var(--amber)}
.kpi.blue .num{color:var(--blue)}
.kpi.plain .num{color:var(--txt)}
.kpi .num small{font-size:12px;color:var(--txt-3);font-weight:400;margin-left:3px}
.kpi .delta{font-size:11px;margin-top:5px;color:var(--txt-3)}

/* ---------- 表格 ---------- */
.table-wrap{overflow-x:auto}
table.data{width:100%;border-collapse:collapse;font-size:12.5px}
table.data th{
  text-align:left;padding:10px 14px;background:rgba(21,35,60,.6);color:var(--txt-3);
  font-weight:500;font-size:11px;letter-spacing:1px;border-bottom:1px solid var(--line);white-space:nowrap;
}
table.data td{padding:10px 14px;border-bottom:1px solid rgba(31,50,82,.5);vertical-align:middle}
table.data tr:last-child td{border-bottom:none}
table.data tr:hover td{background:rgba(21,35,60,.45)}
table.data .mono{font-family:var(--mono);font-size:12px}
table.data .name{font-weight:500;color:var(--txt)}

/* ---------- 标签 ---------- */
.pill{
  display:inline-flex;align-items:center;gap:5px;padding:2px 9px;border-radius:99px;
  font-size:11px;font-weight:500;white-space:nowrap;
}
.pill::before{content:'';width:6px;height:6px;border-radius:50%;background:currentColor;box-shadow:0 0 6px currentColor}
.pill.cyan{background:var(--cyan-soft);color:var(--cyan)}
.pill.blue{background:var(--blue-soft);color:var(--blue)}
.pill.green{background:rgba(98,222,141,.12);color:#62de8d}
.pill.red{background:var(--red-soft);color:var(--red)}
.pill.amber{background:var(--amber-soft);color:var(--amber)}
.pill.violet{background:var(--violet-soft);color:var(--violet)}
.pill.gray{background:rgba(90,110,146,.15);color:var(--txt-3)}
.pill.plain::before{display:none}

/* ---------- AI 标识（合规：人机协同） ---------- */
.ai-mark{
  display:inline-flex;align-items:center;gap:6px;font-size:10.5px;color:var(--cyan);
  border:1px dashed rgba(62,230,196,.45);border-radius:6px;padding:3px 9px;font-family:var(--mono);
  letter-spacing:.5px;background:rgba(62,230,196,.05);
}
.ai-mark::before{content:'◈';font-size:11px}
.confidence{display:inline-flex;align-items:center;gap:7px;font-size:11px;color:var(--txt-2)}
.confidence .cbar{width:64px;height:5px;border-radius:99px;background:var(--panel-2);overflow:hidden}
.confidence .cbar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--cyan-deep),var(--cyan))}
.confidence b{font-family:var(--mono);color:var(--cyan);font-weight:500}

/* ---------- 表单 ---------- */
.form-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px 18px}
.field label{display:block;font-size:12px;color:var(--txt-2);margin-bottom:6px;font-weight:500}
.field label .req{color:var(--red);margin-left:2px}
.field input,.field select,.field textarea{
  width:100%;padding:8px 11px;border:1px solid var(--line-glow);border-radius:8px;
  background:var(--deep);font-family:var(--sans);font-size:13px;color:var(--txt);outline:none;transition:.15s;
}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--cyan);box-shadow:0 0 0 3px rgba(62,230,196,.12)}
.field .hint{font-size:11px;color:var(--txt-3);margin-top:4px}
.field .hint.warn{color:var(--amber)}
.field .hint.error{color:var(--red)}
.field input.error{border-color:var(--red);background:rgba(255,107,107,.06)}
.field .unit-input{position:relative}
.field .unit-input span{position:absolute;right:11px;top:50%;transform:translateY(-50%);font-size:11.5px;color:var(--txt-3);font-family:var(--mono)}

/* ---------- 提示条 ---------- */
.notice{
  display:flex;gap:10px;padding:11px 14px;border-radius:10px;font-size:12.5px;
  margin-bottom:14px;line-height:1.7;align-items:flex-start;border:1px solid transparent;
}
.notice svg{width:16px;height:16px;flex:0 0 16px;margin-top:2px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.notice.info{background:var(--blue-soft);color:var(--blue);border-color:rgba(77,163,255,.25)}
.notice.ai{background:var(--cyan-soft);color:var(--cyan);border-color:rgba(62,230,196,.3)}
.notice.warn{background:var(--amber-soft);color:var(--amber);border-color:rgba(255,181,71,.25)}
.notice.danger{background:var(--red-soft);color:var(--red);border-color:rgba(255,107,107,.3)}
.notice b{font-weight:700}

/* ---------- 语音波形 ---------- */
.wave{display:flex;align-items:center;gap:2.5px;height:34px}
.wave i{display:block;width:3px;border-radius:3px;background:var(--cyan);animation:wv 1.1s ease-in-out infinite}
@keyframes wv{0%,100%{transform:scaleY(.35)}50%{transform:scaleY(1)}}
.wave i:nth-child(2n){animation-delay:.15s;height:70%}
.wave i:nth-child(3n){animation-delay:.3s;height:90%}
.wave i:nth-child(4n){animation-delay:.45s;height:55%}
.wave i:nth-child(5n){animation-delay:.08s;height:100%}
.wave i{height:60%}
.wave.still i{animation:none;opacity:.35}

/* ---------- 进度环（SVG 配套类） ---------- */
.ring-wrap{display:flex;align-items:center;gap:14px}
.ring-wrap .lbl b{display:block;font-size:13px}
.ring-wrap .lbl small{font-size:11px;color:var(--txt-3)}

/* ---------- 进度条 ---------- */
.bar{height:7px;background:var(--panel-2);border-radius:99px;overflow:hidden}
.bar i{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,var(--cyan-deep),var(--cyan))}
.bar i.blue{background:linear-gradient(90deg,#2a6cc0,var(--blue))}
.bar i.red{background:linear-gradient(90deg,#c04848,var(--red))}
.bar i.amber{background:linear-gradient(90deg,#c08a2e,var(--amber))}

/* ---------- 对话气泡（外呼/语音） ---------- */
.chat{display:flex;flex-direction:column;gap:10px}
.bubble{max-width:78%;padding:10px 14px;border-radius:13px;font-size:12.5px;line-height:1.7;position:relative}
.bubble.ai{align-self:flex-start;background:var(--panel-2);border:1px solid var(--line);border-bottom-left-radius:4px}
.bubble.ai .who{color:var(--cyan)}
.bubble.user{align-self:flex-end;background:rgba(77,163,255,.14);border:1px solid rgba(77,163,255,.3);border-bottom-right-radius:4px}
.bubble.user .who{color:var(--blue)}
.bubble .who{display:block;font-size:10.5px;font-family:var(--mono);margin-bottom:4px;letter-spacing:.5px}

/* ---------- 风险等级 ---------- */
.risk-band{display:flex;border-radius:10px;overflow:hidden;height:34px;font-size:11px;font-weight:700}
.risk-band span{flex:1;display:flex;align-items:center;justify-content:center;color:#0a1220;letter-spacing:2px}
.risk-band .lo{background:#62de8d}
.risk-band .mid{background:var(--amber)}
.risk-band .hi{background:var(--red)}

/* ---------- 时间线 ---------- */
.timeline{position:relative;padding-left:22px}
.timeline::before{content:'';position:absolute;left:6px;top:4px;bottom:4px;width:1px;background:var(--line-glow)}
.tl-item{position:relative;padding-bottom:16px;font-size:12.5px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{
  content:'';position:absolute;left:-20px;top:4px;width:9px;height:9px;border-radius:50%;
  background:var(--panel);border:2px solid var(--cyan);box-shadow:0 0 8px rgba(62,230,196,.5);
}
.tl-item.warn::before{border-color:var(--amber);box-shadow:0 0 8px rgba(255,181,71,.5)}
.tl-item.danger::before{border-color:var(--red);box-shadow:0 0 8px rgba(255,107,107,.5)}
.tl-item b{display:block;font-weight:500}
.tl-item small{color:var(--txt-3);font-size:11px;font-family:var(--mono)}
.tl-item p{color:var(--txt-2);margin-top:3px;line-height:1.7}

/* ---------- 布局 ---------- */
.cols{display:grid;gap:18px}
.cols.c2{grid-template-columns:1fr 1fr}
.cols.c21{grid-template-columns:2fr 1fr}
.cols.c12{grid-template-columns:1fr 2fr}
.cols.c3{grid-template-columns:repeat(3,1fr)}
@media(max-width:1100px){.cols.c2,.cols.c21,.cols.c12,.cols.c3{grid-template-columns:1fr}}

/* ---------- 工具 ---------- */
.muted{color:var(--txt-3)}
.mono{font-family:var(--mono)}
.tr{text-align:right}.tc{text-align:center}
.mt0{margin-top:0}.mb0{margin-bottom:0}
.flex{display:flex;align-items:center;gap:10px}
.flex .grow{flex:1}
.chart-note{font-size:11px;color:var(--txt-3);margin-top:8px}
svg.chart text{font-family:var(--mono)}
.legend{display:flex;gap:16px;flex-wrap:wrap;font-size:11.5px;color:var(--txt-2)}
.legend i{display:inline-block;width:10px;height:10px;border-radius:3px;margin-right:5px;vertical-align:-1px}

/* ---------- 合规页脚（每页必带：人机协同标注） ---------- */
.compliance-foot{
  margin-top:6px;padding:12px 16px;border:1px dashed var(--line-glow);border-radius:10px;
  font-size:11px;color:var(--txt-3);line-height:1.8;display:flex;gap:10px;align-items:flex-start;
}
.compliance-foot::before{content:'◈';color:var(--cyan);font-size:13px;margin-top:1px}
