/* ===================================================================
   应用内部 UI（主系统 + 绑定助手共用）
   作用域：.win-body 内
   =================================================================== */

/* ---------- 主系统骨架 ---------- */
.sys{display:flex;height:100%;background:var(--bg-soft);font-size:13px;color:var(--ink)}
.sys-side{
  flex:0 0 196px;background:linear-gradient(180deg,#13314f,#0f2840);color:#cdddf0;
  display:flex;flex-direction:column;overflow:hidden;
}
.sys-side .ss-brand{padding:14px 16px;display:flex;align-items:center;gap:10px;border-bottom:1px solid rgba(255,255,255,.08)}
.sys-side .ss-brand img{width:26px;height:26px}
.sys-side .ss-brand b{font-size:13px;color:#fff;line-height:1.25}
.ss-mode{
  margin:10px 12px;padding:7px 10px;border-radius:7px;font-size:12px;cursor:pointer;
  display:flex;align-items:center;justify-content:space-between;transition:background .12s;
}
.ss-mode.admin{background:rgba(255,77,79,.16);color:#ffb4b5}
.ss-mode.admin:hover{background:rgba(255,77,79,.28)}
.ss-mode.user{background:rgba(45,140,240,.18);color:#bcdcff}
.ss-mode.user:hover{background:rgba(45,140,240,.3)}
.ss-nav{flex:1;overflow-y:auto;padding:4px 0 14px}
.ss-nav::-webkit-scrollbar{width:7px}
.ss-nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16);border-radius:4px}
.ss-group{font-size:11px;color:#6f8aa8;padding:12px 16px 5px;letter-spacing:1px}
.ss-item{
  padding:8px 16px 8px 18px;font-size:12.5px;cursor:pointer;display:flex;align-items:center;gap:9px;
  border-left:3px solid transparent;color:#cdddf0;transition:background .1s;white-space:nowrap;
}
.ss-item:hover{background:rgba(255,255,255,.06)}
.ss-item.active{background:rgba(45,140,240,.22);border-left-color:var(--brand);color:#fff;font-weight:600}
.ss-item .si-dot{width:6px;height:6px;border-radius:50%;background:#4f7aa8;flex:0 0 6px}
.ss-item.active .si-dot{background:var(--brand)}
.ss-item.locked{opacity:.45}

.sys-main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-soft)}
.sys-top{
  height:46px;flex:0 0 46px;background:#fff;border-bottom:1px solid var(--line);
  display:flex;align-items:center;padding:0 18px;gap:14px;
}
.sys-top .st-title{font-size:15px;font-weight:700}
.sys-top .st-spacer{flex:1}
.sys-top .st-chip{font-size:12px;color:var(--ink-2);display:flex;align-items:center;gap:6px}
.sys-top .st-chip .live-dot{width:8px;height:8px;border-radius:50%;background:var(--ok);box-shadow:0 0 0 3px rgba(52,199,89,.18);animation:pulse 1.6s infinite}
@keyframes pulse{50%{box-shadow:0 0 0 6px rgba(52,199,89,.05)}}
.sys-top .st-clock{font-variant-numeric:tabular-nums;font-weight:600;font-size:14px}
.sys-content{flex:1;overflow:auto;padding:18px}
.sys-content::-webkit-scrollbar{width:9px;height:9px}
.sys-content::-webkit-scrollbar-thumb{background:#cfd9e6;border-radius:5px}

/* ---------- 看板 ---------- */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpi{
  background:#fff;border-radius:12px;padding:16px 18px;border:1px solid var(--line);
  position:relative;overflow:hidden;box-shadow:0 2px 10px rgba(20,60,110,.05);
}
.kpi::after{content:"";position:absolute;right:-18px;top:-18px;width:72px;height:72px;border-radius:50%;opacity:.12}
.kpi.c1::after{background:var(--brand)} .kpi.c2::after{background:var(--ok)}
.kpi.c3::after{background:var(--warn)} .kpi.c4::after{background:#7a4dd6}
.kpi .k-label{font-size:12.5px;color:var(--ink-2)}
.kpi .k-num{font-size:30px;font-weight:800;margin-top:6px;line-height:1;font-variant-numeric:tabular-nums}
.kpi.c1 .k-num{color:var(--brand)} .kpi.c2 .k-num{color:var(--ok-dark)}
.kpi.c3 .k-num{color:#d98b00} .kpi.c4 .k-num{color:#7a4dd6}
.kpi .k-foot{font-size:11px;color:#9aa7b6;margin-top:8px}

.panel{background:#fff;border-radius:12px;border:1px solid var(--line);box-shadow:0 2px 10px rgba(20,60,110,.04);margin-bottom:16px}
.panel-h{padding:13px 18px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:10px}
.panel-h b{font-size:14px}
.panel-h .ph-spacer{flex:1}
.panel-b{padding:14px 18px}
.panel-b.flush{padding:0}

/* ---------- 表格 ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl th{background:#f3f7fc;color:var(--ink-2);font-weight:600;text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap;position:sticky;top:0}
.tbl td{padding:9px 12px;border-bottom:1px solid #f0f3f7;white-space:nowrap}
.tbl tr:hover td{background:#f8fbff}
.tbl .num{font-variant-numeric:tabular-nums}
.badge{display:inline-block;padding:2px 9px;border-radius:11px;font-size:11.5px;font-weight:600}
.badge.green{background:#e7f9ee;color:#1f9d57}
.badge.blue{background:#e8f2ff;color:#1769c9}
.badge.gray{background:#eef1f5;color:#7a8696}
.badge.red{background:#ffecec;color:#e23a3a}
.badge.orange{background:#fff3e0;color:#d98b00}
.badge.purple{background:#f1ebff;color:#7a4dd6}
.badge.cyan{background:#e1f5fa;color:#0e8aa6}

/* 看板 15 列：步骤列窄一些，整表横向可滚 */
.dash-tbl th,.dash-tbl td{padding:8px 10px}

/* 步骤进度色块（记录列表内迷你） */
.step-mini{display:inline-flex;gap:3px;vertical-align:middle}
.step-mini i{width:13px;height:10px;border-radius:2px;background:var(--idle);display:inline-block}
.step-mini i.done{background:var(--ok)} .step-mini i.doing{background:var(--warn)} .step-mini i.over{background:var(--danger)}

/* 工具条/按钮 */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
.btn{
  border:1px solid var(--line);background:#fff;color:var(--ink);padding:7px 14px;border-radius:7px;
  font-size:12.5px;cursor:pointer;font-family:inherit;display:inline-flex;align-items:center;gap:6px;transition:.12s;
}
.btn:hover{border-color:var(--brand);color:var(--brand)}
.btn.primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn.primary:hover{background:var(--brand-dark)}
.btn.ok{background:var(--ok-dark);border-color:var(--ok-dark);color:#fff}
.btn.ok:hover{filter:brightness(1.05)}
.input,.select{border:1px solid var(--line);border-radius:7px;padding:7px 11px;font-size:12.5px;font-family:inherit;background:#fff;color:var(--ink)}
.input:focus,.select:focus{outline:none;border-color:var(--brand)}
.field{display:flex;flex-direction:column;gap:5px}
.field label{font-size:12px;color:var(--ink-2)}

/* ---------- 实时监控（核心展示） ---------- */
.monitor{height:100%;display:flex;flex-direction:column;background:#0c2236;color:#e8f1fb;padding:0}
.mon-top{display:flex;align-items:center;gap:16px;padding:14px 22px;background:rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.08)}
.mon-top .mt-big{font-size:17px;font-weight:700}
.mon-top .mt-big b{color:#5ad17e}
.mon-top .mt-spacer{flex:1}
.mon-top .mt-stat{font-size:13px;color:#a9c2dd}
.mon-top .mt-stat b{color:#fff;font-size:16px;margin:0 3px}
.mon-rows{flex:1;display:flex;flex-direction:column;gap:10px;padding:16px 18px;overflow:auto}
.mon-row{
  flex:1;min-height:104px;display:flex;background:rgba(255,255,255,.05);border-radius:12px;overflow:hidden;
  border:1px solid rgba(255,255,255,.07);
}
.mon-info{
  flex:0 0 172px;background:rgba(45,140,240,.14);display:flex;flex-direction:column;
  align-items:center;justify-content:center;gap:4px;padding:10px;border-right:1px solid rgba(255,255,255,.08);
}
.mon-info .mi-group{font-size:11px;color:#8fb4dd;letter-spacing:1px;display:flex;align-items:center;gap:6px}
.mon-info .mi-group .badge{padding:1px 7px;font-size:11px;font-weight:600;letter-spacing:0}
.mon-info .mi-nurse{font-size:22px;font-weight:800;color:#fff;letter-spacing:3px}
.mon-info .mi-endo{font-size:13px;color:#bcdcff;margin-top:2px}
.mon-info .mi-pat{margin-top:2px}
.mon-info .mi-pat .badge{padding:1px 7px;font-size:11px;letter-spacing:0}
.mon-info .mi-time{font-size:11px;color:#7f9bbb;font-variant-numeric:tabular-nums;margin-top:2px}
.mon-steps{flex:1;display:flex;align-items:center;gap:8px;padding:12px 16px;overflow-x:auto}
.mon-step{
  flex:1;min-width:96px;height:74px;border-radius:10px;background:rgba(255,255,255,.06);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;
  border:2px solid transparent;position:relative;transition:.3s;
}
.mon-step .ms-name{font-size:13px;font-weight:600}
.mon-step .ms-time{font-size:14px;font-variant-numeric:tabular-nums;color:#cfe1f4}
.mon-step .ms-state{font-size:10.5px}
.mon-step.idle{color:#8aa0b8}
.mon-step.doing{background:rgba(255,176,46,.22);border-color:var(--warn);color:#ffd591;box-shadow:0 0 22px rgba(255,176,46,.25)}
.mon-step.doing .ms-time{color:#ffd591}
.mon-step.done{background:rgba(52,199,89,.18);border-color:var(--ok);color:#9ff0bb}
.mon-step.done .ms-time{color:#9ff0bb}
.mon-step.over{background:rgba(255,77,79,.2);border-color:var(--danger);color:#ffb4b5;animation:overblink 1s infinite}
@keyframes overblink{50%{border-color:rgba(255,77,79,.4)}}
.mon-arrow{flex:0 0 14px;color:#43617e;font-size:16px;text-align:center}
.mon-foot{padding:8px 22px;font-size:11.5px;color:#6f8aa8;border-top:1px solid rgba(255,255,255,.08);display:flex;gap:18px;align-items:center}
.mon-legend{display:flex;align-items:center;gap:5px}
.mon-legend i{width:11px;height:11px;border-radius:3px;display:inline-block}

/* ---------- 详情 / 表单弹层 ---------- */
.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px 24px}
.detail-grid .dg-item{display:flex;flex-direction:column;gap:3px}
.detail-grid .dg-k{font-size:11.5px;color:var(--ink-2)}
.detail-grid .dg-v{font-size:13.5px;font-weight:600}
.timeline{margin-top:6px}
.tl-step{display:flex;gap:12px;padding:10px 0;border-bottom:1px dashed #eef1f5;align-items:center}
.tl-step .tl-idx{width:24px;height:24px;border-radius:50%;background:var(--ok);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex:0 0 24px}
.tl-step.over .tl-idx{background:var(--danger)}
.tl-step .tl-name{font-weight:600;flex:0 0 90px}
.tl-step .tl-time{color:var(--ink-2);font-size:12px;font-variant-numeric:tabular-nums}
.tl-step .tl-dur{margin-left:auto;font-weight:600}
.tl-step.over .tl-dur{color:var(--danger)}

/* ---------- 内镜回溯：全生命周期时间线 ---------- */
.trace-tl{display:flex;flex-direction:column}
.trace-tl .tr-round{font-size:12px;font-weight:700;color:#7a8696;background:#f3f7fc;padding:7px 12px;border-radius:6px;margin:12px 0 4px;letter-spacing:1px;white-space:nowrap;overflow:hidden}
.trace-tl .tr-round:first-child{margin-top:0}
.trace-tl .tr-ev{display:flex;align-items:center;gap:12px;padding:10px 8px;border-bottom:1px dashed #eef1f5}
.trace-tl .tr-ev:hover{background:#f8fbff}
.trace-tl .tr-time{flex:0 0 96px;font-size:12px;color:var(--ink-2);font-variant-numeric:tabular-nums}
.trace-tl .tr-type{flex:0 0 74px}
.trace-tl .tr-op{flex:0 0 76px;font-size:12.5px;font-weight:600}
.trace-tl .tr-desc{flex:1;font-size:12.5px;color:var(--ink)}
.trace-tl .tr-res{flex:0 0 72px;text-align:right;font-weight:700;font-size:12.5px}

/* 占位/空提示 */
.placeholder{padding:60px 20px;text-align:center;color:#9aa7b6}
.placeholder .ph-ico{font-size:42px;opacity:.4;margin-bottom:12px}

/* ---------- 图表（统计分析） ---------- */
.charts-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.chart-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.chart-card h4{font-size:13px;margin-bottom:14px;color:var(--ink)}
.bars{display:flex;align-items:flex-end;gap:10px;height:150px;padding-top:8px}
.bars .bar-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;justify-content:flex-end}
.bars .bar{width:74%;border-radius:5px 5px 0 0;min-height:3px;transition:height .6s cubic-bezier(.2,.8,.2,1)}
.bars .bar-v{font-size:11px;color:var(--ink-2);font-variant-numeric:tabular-nums}
.bars .bar-x{font-size:10.5px;color:#9aa7b6}
.hbars{display:flex;flex-direction:column;gap:9px}
.hbar{display:flex;align-items:center;gap:8px;font-size:12px}
.hbar .hb-name{flex:0 0 56px;text-align:right;color:var(--ink-2)}
.hbar .hb-track{flex:1;background:#f0f3f7;border-radius:6px;height:16px;overflow:hidden}
.hbar .hb-fill{height:100%;border-radius:6px;transition:width .7s}
.hbar .hb-v{flex:0 0 34px;font-variant-numeric:tabular-nums;font-weight:600}

/* ===================================================================
   AI 患者绑定助手
   =================================================================== */
.binder{height:100%;display:flex;flex-direction:column;background:#f6f9fc;font-size:13px}
.bd-head{display:flex;align-items:center;padding:12px 16px 10px;gap:10px}
.bd-title{font-size:15px;font-weight:700;flex:1}
.bd-head-btns{display:flex;gap:8px}
.bd-mini-btn{border:1px solid var(--line);background:#fff;border-radius:6px;padding:5px 12px;font-size:12px;cursor:pointer;color:var(--ink-2)}
.bd-mini-btn:hover{border-color:var(--brand);color:var(--brand)}
.bd-body{flex:1;overflow:auto;padding:4px 16px 14px}
.bd-field-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.bd-field-row label{flex:0 0 58px;text-align:right;font-size:13px;color:var(--ink-2)}
.bd-field-row .input{flex:1}
.bd-add{flex:0 0 auto}
.bd-cardlist{margin:2px 0 6px 68px;display:flex;flex-direction:column;gap:5px;min-height:6px}
.bd-card-item{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:7px;padding:7px 10px;font-size:12.5px}
.bd-card-sym{font-weight:700;flex:0 0 14px}
.bd-card-no{font-weight:600;font-variant-numeric:tabular-nums}
.bd-card-detail{flex:1;font-size:12px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bd-card-del{cursor:pointer;color:#c4ccd6;font-size:12px}
.bd-card-del:hover{color:var(--danger)}
.bd-tip{font-size:11px;color:#9aa7b6;margin:0 0 12px 68px}
.bd-send{
  width:100%;border:none;border-radius:9px;padding:12px;font-size:15px;font-weight:700;color:#fff;cursor:pointer;
  background:linear-gradient(180deg,#3a98f5,#2d8cf0);box-shadow:0 6px 16px rgba(45,140,240,.3);font-family:inherit;margin-bottom:14px;
}
.bd-send:hover{filter:brightness(1.05)}
.bd-send:disabled{opacity:.7;cursor:default}

.bd-ai-zone{background:#fff;border:1px solid #e3ecf6;border-radius:11px;padding:12px;margin-bottom:14px}
.bd-paste{
  width:100%;border:1px solid #cdeccf;background:#eafbef;color:#1f9d57;border-radius:8px;padding:9px;font-size:13px;
  cursor:pointer;font-family:inherit;font-weight:600;margin-bottom:9px;
}
.bd-paste:hover{background:#defaea}
.bd-ocr{
  width:100%;border:none;border-radius:8px;padding:11px;font-size:14px;cursor:pointer;font-family:inherit;font-weight:700;color:#fff;
  background:linear-gradient(120deg,#6a37c0,#9a4de0 60%,#c44ddc);position:relative;overflow:hidden;
  box-shadow:0 5px 14px rgba(122,55,214,.32);
}
.bd-ocr b{font-weight:600;font-size:12px;opacity:.92}
.bd-ocr:hover{filter:brightness(1.06)}
.bd-ocr .ai-spark{display:inline-block;animation:spark 1.6s infinite}
@keyframes spark{0%,100%{transform:scale(1);opacity:1}50%{transform:scale(1.4) rotate(20deg);opacity:.7}}
.bd-ocr::after{content:"";position:absolute;top:0;left:-60%;width:40%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shine 2.8s infinite}
@keyframes shine{0%{left:-60%}55%,100%{left:130%}}
.bd-ai-cap{font-size:11px;color:#9aa7b6;text-align:center;margin-top:9px}

.bd-records{background:#fff;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.bd-rec-head{display:flex;justify-content:space-between;align-items:center;padding:9px 12px;font-size:12.5px;border-bottom:1px solid var(--line);color:var(--ink-2)}
.bd-rec-head b{color:var(--brand);font-size:14px}
.bd-rec-head a{color:var(--brand);cursor:pointer}
.bd-rec-tbl{width:100%;border-collapse:collapse;font-size:12px}
.bd-rec-tbl th{background:#f6f9fc;color:#9aa7b6;font-weight:600;text-align:left;padding:7px 12px}
.bd-rec-tbl td{padding:7px 12px;border-top:1px solid #f2f5f9;font-variant-numeric:tabular-nums}
.bd-rec-tbl tbody:empty::after{content:"暂无绑定记录";display:block;padding:14px;text-align:center;color:#c4ccd6}

.bd-status{display:flex;align-items:center;justify-content:space-between;padding:7px 16px;background:#eef3f9;border-top:1px solid var(--line);font-size:11.5px}
.bd-st-text{font-weight:600}
.bd-support{color:#9aa7b6}

/* ---------- OCR 全屏框选遮罩 ---------- */
.ocr-overlay{position:absolute;inset:0;z-index:300;cursor:crosshair;background:rgba(8,16,30,.42)}
.ocr-hint{
  position:absolute;top:26px;left:50%;transform:translateX(-50%);color:#fff;font-size:15px;font-weight:600;
  background:rgba(20,30,50,.7);padding:9px 20px;border-radius:22px;letter-spacing:1px;
}
.ocr-hint.busy{background:rgba(106,55,192,.85)}
.his-card{
  position:absolute;right:90px;top:130px;width:360px;background:#fff;border-radius:10px;overflow:hidden;cursor:pointer;
  box-shadow:0 18px 50px rgba(0,0,0,.4);
}
.his-tt{background:#244a73;color:#fff;font-size:13px;font-weight:600;padding:10px 14px}
.his-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px 14px;padding:16px}
.his-grid>div{display:flex;flex-direction:column;gap:3px}
.his-grid span{font-size:11px;color:#9aa7b6}
.his-grid b{font-size:14px;color:#1f2733}
.his-point{font-size:11.5px;color:#6a37c0;text-align:center;padding:0 0 12px;font-weight:600}
.ocr-rect{position:absolute;display:none;border:2px solid #2d8cf0;background:rgba(45,140,240,.14);box-shadow:0 0 0 9999px rgba(8,16,30,.04)}
.ocr-rect.scanning{border-color:#9a4de0;background:rgba(154,77,224,.12)}
.ocr-rect.scanning::before{
  content:"";position:absolute;left:0;right:0;height:3px;background:linear-gradient(90deg,transparent,#c44ddc,transparent);
  box-shadow:0 0 14px 3px rgba(196,77,220,.7);animation:scanline 1.1s linear infinite;
}
@keyframes scanline{0%{top:0}100%{top:100%}}

/* ---------- 登录蒙层 ---------- */
.login-mask{position:absolute;inset:0;background:rgba(8,28,52,.55);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:50}
.login-box{background:#fff;border-radius:14px;padding:26px 28px;width:320px;box-shadow:0 20px 60px rgba(0,0,0,.3)}
.login-box h3{font-size:16px;margin-bottom:4px}
.login-box p{font-size:12px;color:var(--ink-2);margin-bottom:16px}
.login-box .input{width:100%;margin-bottom:12px}
.login-box .btn{width:100%;justify-content:center}
.login-hint{font-size:11px;color:#9aa7b6;margin-top:10px;text-align:center}
