/* =====================================================================
   临检云 LIS — 设计系统 (Clinical Precision)
   一套面向临床实验室信息系统的统一视觉语言
   ===================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Sora:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  /* 纸面与表面 */
  --paper:#e9ece8;
  --surface:#ffffff;
  --surface-2:#f6f8f5;
  --surface-3:#eef1ed;

  /* 墨色文字 */
  --ink:#101d1c;
  --ink-2:#3f4b48;
  --ink-3:#697571;
  --muted:#9aa39e;

  /* 线条 */
  --line:#e0e5df;
  --line-2:#eceee9;

  /* 主色：医疗石青 */
  --teal:#0b6b66;
  --teal-deep:#063d3b;
  --teal-darker:#052a29;
  --teal-bright:#13b8a6;
  --teal-soft:#d6ece9;

  /* 语义色 */
  --crit:#c8214b;       /* 危急值 / 失控 */
  --crit-soft:#fbe2e9;
  --warn:#c97a14;       /* 预警 */
  --warn-soft:#fbecd6;
  --ok:#1f8f5f;         /* 正常 / 通过 */
  --ok-soft:#dcf0e5;
  --info:#1f6fb2;       /* 信息 */
  --info-soft:#dceaf6;
  --grape:#6b4fa0;      /* 辅助强调 */
  --grape-soft:#e8e2f4;

  /* 字体 */
  --f-display:'Sora','PingFang SC','Microsoft YaHei',sans-serif;
  --f-body:'IBM Plex Sans','PingFang SC','Microsoft YaHei',sans-serif;
  --f-mono:'IBM Plex Mono','PingFang SC',monospace;

  /* 尺寸 */
  --sidebar-w:262px;
  --topbar-h:62px;
  --radius:13px;
  --radius-sm:9px;
  --shadow-sm:0 1px 2px rgba(16,29,28,.05),0 1px 3px rgba(16,29,28,.04);
  --shadow:0 4px 18px -6px rgba(16,29,28,.14),0 2px 6px -2px rgba(16,29,28,.07);
  --shadow-lg:0 24px 60px -18px rgba(6,40,40,.34);
}

*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--paper);
  font-size:14px;
  line-height:1.5;
  letter-spacing:.005em;
}
::selection{background:var(--teal-bright);color:#042b29}

/* 细滚动条 */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:#c7cec8;border-radius:8px;border:3px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:#aab2ac;background-clip:padding-box}
::-webkit-scrollbar-track{background:transparent}

a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}

/* =====================================================================
   布局骨架
   ===================================================================== */
.app{display:flex;min-height:100vh}

/* ---------- 侧边栏 ---------- */
.sidebar{
  width:var(--sidebar-w);
  flex:0 0 var(--sidebar-w);
  background:
    radial-gradient(120% 60% at 0% 0%, rgba(19,184,166,.12), transparent 60%),
    linear-gradient(178deg,#074240 0%,#063d3b 40%,#052a29 100%);
  color:#cfe3e0;
  position:sticky;top:0;height:100vh;
  display:flex;flex-direction:column;
  border-right:1px solid #052a29;
  z-index:30;
}
.brand{
  display:flex;align-items:center;gap:11px;
  padding:18px 20px 16px;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.brand-mark{
  width:38px;height:38px;border-radius:11px;flex:0 0 38px;
  background:linear-gradient(150deg,var(--teal-bright),#0b8a7e);
  display:grid;place-items:center;
  box-shadow:0 6px 16px -4px rgba(19,184,166,.5), inset 0 1px 0 rgba(255,255,255,.3);
  position:relative;
}
.brand-mark svg{width:21px;height:21px}
.brand-mark::after{content:"";position:absolute;inset:0;border-radius:11px;border:1px solid rgba(255,255,255,.18)}
.brand-text b{
  font-family:var(--f-display);font-weight:700;font-size:16px;color:#fff;
  display:block;letter-spacing:.02em;line-height:1.1;
}
.brand-text span{font-size:10.5px;letter-spacing:.32em;color:#6fb3ad;text-transform:uppercase;font-family:var(--f-mono)}

.nav{flex:1;overflow-y:auto;padding:12px 12px 24px}
.nav::-webkit-scrollbar{width:6px}
.nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.12)}
.nav-group{margin-bottom:4px}
.nav-group-label{
  display:flex;align-items:center;gap:8px;
  padding:11px 12px 7px;font-size:10.5px;font-weight:600;
  letter-spacing:.16em;text-transform:uppercase;color:#5f9d97;
  font-family:var(--f-mono);
}
.nav-group-label .gi{width:13px;height:13px;opacity:.8}
.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:8px 12px;border-radius:9px;margin:1px 0;
  color:#aecdc8;font-size:13px;font-weight:450;
  position:relative;transition:background .14s,color .14s,transform .14s;
}
.nav-item .ni{width:16px;height:16px;flex:0 0 16px;opacity:.78;transition:opacity .14s}
.nav-item:hover{background:rgba(255,255,255,.055);color:#eafffb;transform:translateX(2px)}
.nav-item:hover .ni{opacity:1}
.nav-item.active{
  background:linear-gradient(90deg,rgba(19,184,166,.22),rgba(19,184,166,.04));
  color:#fff;font-weight:500;
}
.nav-item.active .ni{opacity:1;color:var(--teal-bright)}
.nav-item.active::before{
  content:"";position:absolute;left:-12px;top:50%;transform:translateY(-50%);
  width:3px;height:20px;border-radius:0 3px 3px 0;background:var(--teal-bright);
  box-shadow:0 0 12px var(--teal-bright);
}
.nav-item .badge-sm{
  margin-left:auto;font-family:var(--f-mono);font-size:10px;font-weight:600;
  padding:1px 6px;border-radius:20px;background:var(--crit);color:#fff;
  box-shadow:0 0 0 3px rgba(200,33,75,.18);
}
.sidebar-foot{
  padding:12px 16px;border-top:1px solid rgba(255,255,255,.06);
  display:flex;align-items:center;gap:10px;font-size:12px;color:#8fb8b2;
}
.sidebar-foot .avatar{
  width:32px;height:32px;border-radius:9px;flex:0 0 32px;
  background:linear-gradient(140deg,#0e9488,#0b6b66);color:#fff;
  display:grid;place-items:center;font-weight:600;font-family:var(--f-display);font-size:13px;
}
.sidebar-foot b{color:#e6f4f1;font-weight:500;display:block;font-size:12.5px}
.sidebar-foot small{color:#6fa39d;font-size:10.5px}
.sidebar-foot > svg{width:18px;height:18px;flex:0 0 18px;opacity:.6;color:#8fb8b2;cursor:pointer;transition:.15s}
.sidebar-foot > svg:hover{opacity:1;color:var(--teal-bright)}

/* ---------- 主区域 ---------- */
.main{flex:1;min-width:0;display:flex;flex-direction:column;
  background:
    radial-gradient(60% 50% at 100% 0%, rgba(19,184,166,.05), transparent 60%),
    var(--paper);
  background-attachment:fixed;
}
.main::before{
  content:"";position:fixed;inset:0 0 0 var(--sidebar-w);pointer-events:none;z-index:0;
  background-image:radial-gradient(circle, rgba(16,29,28,.045) 1px, transparent 1px);
  background-size:22px 22px;
  mask-image:linear-gradient(180deg,#000,transparent 70%);
  opacity:.6;
}

/* ---------- 顶栏 ---------- */
.topbar{
  height:var(--topbar-h);position:sticky;top:0;z-index:20;
  display:flex;align-items:center;gap:16px;
  padding:0 26px;
  background:rgba(233,236,232,.82);
  backdrop-filter:saturate(1.4) blur(14px);
  border-bottom:1px solid var(--line);
}
.crumbs{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--ink-3);font-family:var(--f-mono)}
.crumbs .sep{opacity:.4}
.crumbs b{color:var(--ink);font-weight:600;font-family:var(--f-body)}
.topbar-spacer{flex:1}
.search{
  display:flex;align-items:center;gap:8px;
  background:var(--surface);border:1px solid var(--line);border-radius:9px;
  padding:7px 12px;width:248px;color:var(--muted);font-size:12.5px;transition:border .15s,box-shadow .15s;
}
.search:focus-within{border-color:var(--teal);box-shadow:0 0 0 3px var(--teal-soft)}
.search input{border:none;outline:none;background:none;flex:1;font-family:var(--f-body);font-size:13px;color:var(--ink)}
.search svg{width:15px;height:15px;flex:0 0 15px}
.search kbd{font-family:var(--f-mono);font-size:10px;border:1px solid var(--line);border-radius:5px;padding:1px 5px;color:var(--muted)}
.topbar-btn{
  width:36px;height:36px;border-radius:9px;border:1px solid var(--line);
  background:var(--surface);display:grid;place-items:center;color:var(--ink-2);
  position:relative;transition:.15s;
}
.topbar-btn:hover{border-color:var(--teal);color:var(--teal);transform:translateY(-1px)}
.topbar-btn svg{width:17px;height:17px}
.topbar-btn .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:50%;background:var(--crit);box-shadow:0 0 0 2px var(--surface)}
.clock{font-family:var(--f-mono);font-size:12.5px;color:var(--ink-2);letter-spacing:.02em}
.clock b{color:var(--ink)}

/* ---------- 内容容器 ---------- */
.content{padding:26px 30px 60px;position:relative;z-index:1;max-width:1480px;width:100%;margin:0 auto}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:22px}
.page-head .eyebrow{
  font-family:var(--f-mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--teal);font-weight:600;margin-bottom:7px;display:flex;align-items:center;gap:8px;
}
.page-head .eyebrow::before{content:"";width:22px;height:1.5px;background:var(--teal)}
.page-head h1{font-family:var(--f-display);font-size:27px;font-weight:600;letter-spacing:-.01em;line-height:1.12}
.page-head p{color:var(--ink-3);font-size:13.5px;margin-top:7px;max-width:620px}
.head-actions{display:flex;gap:10px;align-items:center}

/* =====================================================================
   组件
   ===================================================================== */

/* 按钮 */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 15px;border-radius:9px;border:1px solid var(--line);
  background:var(--surface);color:var(--ink);font-size:13px;font-weight:500;
  transition:.15s;white-space:nowrap;
}
.btn svg{width:15px;height:15px}
.btn:hover{border-color:var(--teal);color:var(--teal);box-shadow:var(--shadow-sm);transform:translateY(-1px)}
.btn.primary{
  background:linear-gradient(160deg,var(--teal),#085551);color:#fff;border-color:transparent;
  box-shadow:0 6px 16px -6px rgba(11,107,102,.6);
}
.btn.primary:hover{filter:brightness(1.08);color:#fff;transform:translateY(-1px)}
.btn.danger{background:var(--crit);color:#fff;border-color:transparent}
.btn.danger:hover{color:#fff;filter:brightness(1.06)}
.btn.ghost{background:transparent;border-color:transparent}
.btn.sm{padding:6px 11px;font-size:12px}
.btn.icon{padding:9px;width:38px;justify-content:center}

/* 卡片 */
.card{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);position:relative;overflow:hidden;
}
.card-pad{padding:18px 20px}
.card-head{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  padding:15px 20px;border-bottom:1px solid var(--line-2);
}
.card-head h3{font-family:var(--f-display);font-size:14.5px;font-weight:600;display:flex;align-items:center;gap:9px}
.card-head h3 svg{width:16px;height:16px;color:var(--teal)}
.card-head .sub{font-size:12px;color:var(--muted);font-weight:400}

/* 网格 */
.grid{display:grid;gap:18px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-12{grid-template-columns:repeat(12,1fr)}
.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}
.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}
.col-9{grid-column:span 9}.col-12{grid-column:span 12}
@media(max-width:1100px){.g-4{grid-template-columns:repeat(2,1fr)}.g-3{grid-template-columns:1fr}}

/* KPI 指标块 */
.kpi{
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:17px 18px;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);
  transition:transform .18s, box-shadow .18s;
}
.kpi:hover{transform:translateY(-3px);box-shadow:var(--shadow)}
.kpi::after{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--teal)}
.kpi.is-crit::after{background:var(--crit)}.kpi.is-warn::after{background:var(--warn)}.kpi.is-ok::after{background:var(--ok)}.kpi.is-info::after{background:var(--info)}
.kpi .k-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:11px}
.kpi .k-label{font-size:12px;color:var(--ink-3);font-weight:500}
.kpi .k-ico{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;background:var(--surface-3);color:var(--teal)}
.kpi .k-ico svg{width:16px;height:16px}
.kpi.is-crit .k-ico{background:var(--crit-soft);color:var(--crit)}
.kpi.is-warn .k-ico{background:var(--warn-soft);color:var(--warn)}
.kpi.is-ok .k-ico{background:var(--ok-soft);color:var(--ok)}
.kpi.is-info .k-ico{background:var(--info-soft);color:var(--info)}
.kpi .k-val{font-family:var(--f-display);font-size:29px;font-weight:600;letter-spacing:-.02em;line-height:1}
.kpi .k-val small{font-size:14px;color:var(--muted);font-weight:400;margin-left:2px}
.kpi .k-foot{margin-top:9px;font-size:11.5px;color:var(--ink-3);display:flex;align-items:center;gap:6px;font-family:var(--f-mono)}
.trend{display:inline-flex;align-items:center;gap:3px;font-weight:600;font-family:var(--f-mono)}
.trend.up{color:var(--ok)}.trend.down{color:var(--crit)}.trend svg{width:12px;height:12px}

/* 状态标签 */
.tag{
  display:inline-flex;align-items:center;gap:5px;
  padding:2.5px 9px;border-radius:20px;font-size:11.5px;font-weight:600;
  font-family:var(--f-mono);line-height:1.5;white-space:nowrap;
}
.tag .d{width:6px;height:6px;border-radius:50%;background:currentColor}
.tag.ok{background:var(--ok-soft);color:#13693f}
.tag.warn{background:var(--warn-soft);color:#9a5a0d}
.tag.crit{background:var(--crit-soft);color:#a01038}
.tag.info{background:var(--info-soft);color:#155488}
.tag.teal{background:var(--teal-soft);color:#06504c}
.tag.grape{background:var(--grape-soft);color:#4f3680}
.tag.muted{background:var(--surface-3);color:var(--ink-3)}
.tag.solid-crit{background:var(--crit);color:#fff}
.pulse .d{animation:pulse 1.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 currentColor;opacity:1}70%{box-shadow:0 0 0 5px transparent;opacity:.7}100%{opacity:1}}

/* 表格 */
.table{width:100%;border-collapse:collapse;font-size:13px}
.table thead th{
  text-align:left;font-size:11px;font-weight:600;color:var(--ink-3);
  text-transform:uppercase;letter-spacing:.08em;font-family:var(--f-mono);
  padding:11px 14px;border-bottom:1px solid var(--line);background:var(--surface-2);
  position:sticky;top:0;
}
.table tbody td{padding:11px 14px;border-bottom:1px solid var(--line-2);color:var(--ink-2);vertical-align:middle}
.table tbody tr{transition:background .12s}
.table tbody tr:hover{background:var(--surface-2)}
.table tbody tr:last-child td{border-bottom:none}
.table .mono{font-family:var(--f-mono);font-size:12.5px;color:var(--ink)}
.table .strong{color:var(--ink);font-weight:600}
.table-wrap{overflow:auto;border-radius:var(--radius)}

/* 进度条 */
.bar{height:7px;border-radius:6px;background:var(--surface-3);overflow:hidden;position:relative}
.bar > i{display:block;height:100%;border-radius:6px;background:linear-gradient(90deg,var(--teal),var(--teal-bright))}
.bar.crit > i{background:linear-gradient(90deg,#c8214b,#e8557d)}
.bar.warn > i{background:linear-gradient(90deg,#c97a14,#e2a64e)}
.bar.ok > i{background:linear-gradient(90deg,#1f8f5f,#3fb87f)}

/* 时间线 */
.timeline{position:relative;padding-left:26px}
.timeline::before{content:"";position:absolute;left:7px;top:4px;bottom:4px;width:2px;background:var(--line)}
.tl-item{position:relative;padding:0 0 20px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{
  content:"";position:absolute;left:-23px;top:3px;width:12px;height:12px;border-radius:50%;
  background:var(--surface);border:2.5px solid var(--teal);box-shadow:0 0 0 3px var(--surface);
}
.tl-item.done::before{background:var(--teal);border-color:var(--teal)}
.tl-item.crit::before{border-color:var(--crit)}
.tl-item.pending::before{border-color:var(--muted)}
.tl-time{font-family:var(--f-mono);font-size:11px;color:var(--muted);letter-spacing:.02em}
.tl-title{font-weight:600;font-size:13.5px;margin:2px 0 3px;color:var(--ink)}
.tl-desc{font-size:12.5px;color:var(--ink-3)}

/* 分段控件 / 标签页 */
.segment{display:inline-flex;background:var(--surface-3);border-radius:9px;padding:3px;gap:2px}
.segment button{
  border:none;background:none;padding:6px 14px;border-radius:7px;font-size:12.5px;
  color:var(--ink-3);font-weight:500;transition:.14s;
}
.segment button.active{background:var(--surface);color:var(--teal);box-shadow:var(--shadow-sm);font-weight:600}

/* 列表项 */
.list-row{display:flex;align-items:center;gap:13px;padding:12px 0;border-bottom:1px solid var(--line-2)}
.list-row:last-child{border-bottom:none}
.list-ico{width:36px;height:36px;border-radius:9px;flex:0 0 36px;display:grid;place-items:center;background:var(--surface-3);color:var(--teal)}
.list-ico svg{width:17px;height:17px}
.list-main{flex:1;min-width:0}
.list-main b{font-size:13.5px;font-weight:600;display:block}
.list-main span{font-size:12px;color:var(--ink-3)}

/* 杂项 */
.muted{color:var(--muted)}
.mono{font-family:var(--f-mono)}
.divider{height:1px;background:var(--line-2);margin:16px 0}
.dl{display:grid;grid-template-columns:auto 1fr;gap:9px 16px;font-size:13px}
.dl dt{color:var(--ink-3)}
.dl dd{color:var(--ink);font-weight:500;text-align:right;font-family:var(--f-mono)}
.flex{display:flex}.between{justify-content:space-between}.center{align-items:center}.gap{gap:10px}.wrap{flex-wrap:wrap}
.stack{display:flex;flex-direction:column;gap:14px}
.scroll-y{overflow-y:auto}

/* 条码视觉 */
.barcode{height:46px;background:repeating-linear-gradient(90deg,var(--ink) 0 2px,transparent 2px 4px,var(--ink) 4px 5px,transparent 5px 9px,var(--ink) 9px 12px,transparent 12px 13px);border-radius:2px}
.qr{width:84px;height:84px;border-radius:8px;background:
  conic-gradient(from 0deg,#101d1c 90deg,transparent 0 180deg,#101d1c 0 270deg,transparent 0),
  #fff;background-size:14px 14px;border:5px solid #fff;box-shadow:inset 0 0 0 1px var(--line)}

/* 进入动画 */
@keyframes rise{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
.rise{animation:rise .5s cubic-bezier(.16,.84,.44,1) both}
.content > *{animation:rise .5s cubic-bezier(.16,.84,.44,1) both}
.content > *:nth-child(1){animation-delay:.02s}
.content > *:nth-child(2){animation-delay:.06s}
.content > *:nth-child(3){animation-delay:.10s}
.content > *:nth-child(4){animation-delay:.14s}
.content > *:nth-child(5){animation-delay:.18s}
.content > *:nth-child(6){animation-delay:.22s}

/* 灯 (TAT 红绿灯) */
.lamp{width:13px;height:13px;border-radius:50%;display:inline-block;position:relative}
.lamp.g{background:var(--ok);box-shadow:0 0 9px var(--ok)}
.lamp.y{background:var(--warn);box-shadow:0 0 9px var(--warn)}
.lamp.r{background:var(--crit);box-shadow:0 0 11px var(--crit);animation:pulse 1.2s infinite}

/* 提示条 */
.banner{display:flex;align-items:center;gap:13px;padding:13px 17px;border-radius:11px;font-size:13px;border:1px solid transparent}
.banner svg{width:19px;height:19px;flex:0 0 19px}
.banner.crit{background:var(--crit-soft);border-color:#f1c4d1;color:#92133a}
.banner.warn{background:var(--warn-soft);border-color:#eed3a8;color:#86510f}
.banner.info{background:var(--info-soft);border-color:#c2dcf0;color:#13507f}
.banner.ok{background:var(--ok-soft);border-color:#bce3cd;color:#136540}
.banner b{font-weight:600}

@media(max-width:1240px){
  .col-3,.col-4{grid-column:span 6}.col-6,.col-7,.col-8,.col-9{grid-column:span 12}
}
