/* ============================================================
   风眸 WindEye 原型样式 · 暗色指挥室主题
   全自包含，无外部字体/图标依赖
   ============================================================ */
:root{
  --bg:#070b16; --bg2:#0a1020; --panel:#0e1426; --panel2:#121a30;
  --line:#1d2840; --line2:#28375a;
  --text:#e7eefb; --muted:#8b9ab8; --muted2:#5d6b88;
  --cyan:#00e5ff; --cyan-dim:#0b94a8; --green:#2bd97c; --amber:#ffb020;
  --red:#ff4d5e; --purple:#a371ff; --blue:#4cc3ff;
  /* 严重度色阶 Cat1-5 */
  --c1:#4cc3ff; --c2:#2bd97c; --c3:#ffd23f; --c4:#ff8a3d; --c5:#ff4d5e;
  --glow-cyan:0 0 18px rgba(0,229,255,.35);
  --radius:14px; --radius-sm:9px;
  --mono:'SFMono-Regular',Consolas,'Liberation Mono',Menlo,monospace;
  --sans:-apple-system,BlinkMacSystemFont,'Segoe UI','PingFang SC','Microsoft YaHei',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:var(--sans); color:var(--text); background:var(--bg);
  background-image:
    radial-gradient(1200px 600px at 80% -10%, rgba(0,229,255,.07), transparent 60%),
    radial-gradient(900px 500px at 0% 110%, rgba(163,113,255,.06), transparent 55%);
  font-size:14px; line-height:1.5; overflow:hidden;
}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:6px}
::-webkit-scrollbar-track{background:transparent}
a{color:inherit;text-decoration:none;cursor:pointer}
.hidden{display:none !important}

/* ===== 顶栏 ===== */
.topbar{
  height:62px; display:flex; align-items:center; justify-content:space-between;
  padding:0 22px; border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(14,20,38,.95),rgba(10,16,32,.85));
  backdrop-filter:blur(8px); position:relative; z-index:20;
}
.brand{display:flex;align-items:center;gap:12px}
.brand-mark{filter:drop-shadow(var(--glow-cyan));display:flex}
.brand-mark svg{animation:spin 9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.brand-name{font-size:18px;font-weight:700;letter-spacing:.5px}
.brand-name span{color:var(--cyan);font-weight:600;font-size:13px;letter-spacing:1px}
.brand-sub{font-size:11px;color:var(--muted)}
.badge{font-size:11px;padding:3px 9px;border-radius:20px;font-weight:600;white-space:nowrap}
.badge-neutral{background:rgba(0,229,255,.1);color:var(--cyan);border:1px solid rgba(0,229,255,.3)}
.badge-proto{background:rgba(163,113,255,.13);color:var(--purple);border:1px solid rgba(163,113,255,.35)}
.topbar-right{display:flex;align-items:center;gap:16px}
.farm-pill{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:8px;
  background:var(--panel);padding:7px 13px;border-radius:20px;border:1px solid var(--line)}
.clock{font-family:var(--mono);font-size:13px;color:var(--cyan);letter-spacing:.5px}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.dot-green{background:var(--green);box-shadow:0 0 8px var(--green)}
.dot-amber{background:var(--amber);box-shadow:0 0 8px var(--amber)}
.dot-red{background:var(--red);box-shadow:0 0 8px var(--red)}

/* ===== 主布局 ===== */
.body-grid{display:grid;grid-template-columns:236px 1fr;height:calc(100vh - 62px)}
.sidenav{
  border-right:1px solid var(--line); background:linear-gradient(180deg,var(--bg2),var(--bg));
  padding:14px 12px; display:flex;flex-direction:column;gap:4px; overflow-y:auto;
}
.nav-item{
  display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;
  color:var(--muted);font-size:13.5px;font-weight:500;position:relative;transition:.16s;
}
.nav-item:hover{background:var(--panel);color:var(--text)}
.nav-item.active{background:linear-gradient(90deg,rgba(0,229,255,.16),rgba(0,229,255,.03));
  color:var(--text);box-shadow:inset 2px 0 0 var(--cyan)}
.nav-ico{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2;flex:none}
.nav-item.active .nav-ico{stroke:var(--cyan);filter:drop-shadow(0 0 5px rgba(0,229,255,.6))}
.nav-item svg path[fill]:not([fill="none"]),.nav-item svg circle[fill]:not([fill="none"]){fill:currentColor;stroke:none}
.nav-star .star-tag{margin-left:auto;font-size:9.5px;background:var(--cyan);color:#04222a;
  padding:1px 6px;border-radius:8px;font-weight:800;font-style:normal;letter-spacing:.5px;box-shadow:var(--glow-cyan)}
.nav-reserved .reserve-tag{margin-left:auto;font-size:9.5px;background:rgba(139,154,184,.18);
  color:var(--muted);padding:1px 6px;border-radius:8px;font-style:normal;border:1px dashed var(--line2)}
.nav-reserved{opacity:.85}
.nav-foot{margin-top:auto;padding-top:14px}
.pillars{background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:11px;margin-bottom:10px}
.pillars-title{font-size:10.5px;color:var(--muted2);text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.pill{font-size:11px;padding:4px 8px;border-radius:7px;margin-bottom:5px;font-weight:600}
.pill.A{background:rgba(0,229,255,.1);color:var(--cyan);border-left:2px solid var(--cyan)}
.pill.B{background:rgba(43,217,124,.1);color:var(--green);border-left:2px solid var(--green)}
.pill.C{background:rgba(255,176,32,.1);color:var(--amber);border-left:2px solid var(--amber)}
.pill.D{background:rgba(163,113,255,.1);color:var(--purple);border-left:2px solid var(--purple)}
.ver{font-family:var(--mono);font-size:10.5px;color:var(--muted2);text-align:center}

/* ===== 内容区 ===== */
.content{overflow-y:auto;padding:22px 26px 40px}
.view{animation:fade .35s ease}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px;flex-wrap:wrap;gap:12px}
.page-title{font-size:21px;font-weight:700;display:flex;align-items:center;gap:10px}
.page-title .kicker{font-size:11px;font-weight:600;color:var(--cyan);background:rgba(0,229,255,.1);
  padding:3px 9px;border-radius:7px;letter-spacing:.5px}
.page-sub{font-size:12.5px;color:var(--muted);margin-top:4px}

/* ===== 卡片/面板 ===== */
.panel{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);
  border-radius:var(--radius);padding:16px}
.panel-h{font-size:13px;font-weight:700;color:var(--text);margin-bottom:13px;display:flex;
  align-items:center;justify-content:space-between;gap:8px}
.panel-h .sub{font-size:11px;color:var(--muted);font-weight:400}
.grid{display:grid;gap:14px}
.g-4{grid-template-columns:repeat(4,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-2-1{grid-template-columns:2fr 1fr}
.g-1-2{grid-template-columns:1fr 2fr}
@media(max-width:1180px){.g-4{grid-template-columns:repeat(2,1fr)}}

/* KPI 卡 */
.kpi{background:linear-gradient(150deg,var(--panel2),var(--bg2));border:1px solid var(--line);
  border-radius:var(--radius);padding:15px 16px;position:relative;overflow:hidden}
.kpi::after{content:'';position:absolute;right:-20px;top:-20px;width:80px;height:80px;
  border-radius:50%;background:radial-gradient(circle,rgba(0,229,255,.12),transparent 70%)}
.kpi .k-label{font-size:11.5px;color:var(--muted);margin-bottom:7px;display:flex;align-items:center;gap:6px}
.kpi .k-val{font-size:27px;font-weight:800;font-family:var(--mono);letter-spacing:-.5px}
.kpi .k-val small{font-size:13px;color:var(--muted);font-weight:500;margin-left:3px}
.kpi .k-foot{font-size:11px;margin-top:6px;color:var(--muted)}
.up{color:var(--green)} .down{color:var(--red)}
.k-cyan .k-val{color:var(--cyan)} .k-green .k-val{color:var(--green)}
.k-amber .k-val{color:var(--amber)} .k-red .k-val{color:var(--red)} .k-purple .k-val{color:var(--purple)}

/* 严重度徽标 */
.cat{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;
  padding:2px 8px;border-radius:7px;font-family:var(--mono);white-space:nowrap}
.cat::before{content:'';width:7px;height:7px;border-radius:50%;background:currentColor}
.cat-1{color:var(--c1);background:rgba(76,195,255,.13)}
.cat-2{color:var(--c2);background:rgba(43,217,124,.13)}
.cat-3{color:var(--c3);background:rgba(255,210,63,.14)}
.cat-4{color:var(--c4);background:rgba(255,138,61,.14)}
.cat-5{color:var(--c5);background:rgba(255,77,94,.15);animation:catpulse 1.6s infinite}
@keyframes catpulse{0%,100%{box-shadow:0 0 0 0 rgba(255,77,94,.4)}50%{box-shadow:0 0 0 5px rgba(255,77,94,0)}}

/* 表格 */
.tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.tbl th{text-align:left;color:var(--muted2);font-weight:600;font-size:11px;text-transform:uppercase;
  letter-spacing:.5px;padding:9px 11px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--panel)}
.tbl td{padding:10px 11px;border-bottom:1px solid rgba(29,40,64,.55)}
.tbl tbody tr{transition:.13s;cursor:pointer}
.tbl tbody tr:hover{background:rgba(0,229,255,.05)}
.tbl .mono{font-family:var(--mono);color:var(--cyan);font-size:12px}
.tbl tr.sel{background:rgba(0,229,255,.09);box-shadow:inset 2px 0 0 var(--cyan)}

/* 按钮 */
.btn{font-family:var(--sans);font-size:13px;font-weight:600;border:1px solid var(--line2);
  background:var(--panel2);color:var(--text);padding:9px 16px;border-radius:9px;cursor:pointer;transition:.15s;
  display:inline-flex;align-items:center;gap:8px}
.btn:hover{border-color:var(--cyan);color:var(--cyan)}
.btn-primary{background:linear-gradient(135deg,var(--cyan),#0098c7);color:#04222a;border:none;box-shadow:var(--glow-cyan)}
.btn-primary:hover{filter:brightness(1.1);color:#04222a}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;filter:grayscale(.5);box-shadow:none}
.btn-ghost{background:transparent}
.btn-sm{padding:6px 11px;font-size:12px}

.chip{font-size:11px;padding:3px 9px;border-radius:7px;background:var(--panel2);border:1px solid var(--line);color:var(--muted)}
.chip.on{background:rgba(0,229,255,.12);color:var(--cyan);border-color:rgba(0,229,255,.35)}
.tag{font-size:10.5px;padding:2px 7px;border-radius:6px;font-weight:600}
.tag-green{background:rgba(43,217,124,.13);color:var(--green)}
.tag-amber{background:rgba(255,176,32,.13);color:var(--amber)}
.tag-blue{background:rgba(76,195,255,.13);color:var(--blue)}
.tag-muted{background:var(--panel2);color:var(--muted)}

/* 状态条 */
.bar{height:7px;border-radius:5px;background:var(--panel2);overflow:hidden;position:relative}
.bar > i{display:block;height:100%;border-radius:5px;background:linear-gradient(90deg,var(--cyan),var(--green))}

/* ===================== AI 检测驾驶舱 ===================== */
.cockpit{display:grid;grid-template-columns:170px 1fr 290px;gap:14px;height:calc(100vh - 200px);min-height:520px}
.ck-frames{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:12px;overflow-y:auto}
.ck-frames .fh{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}
.frame-thumb{position:relative;border:1px solid var(--line);border-radius:8px;overflow:hidden;margin-bottom:8px;cursor:pointer;aspect-ratio:4/3;transition:.15s}
.frame-thumb canvas{width:100%;height:100%;display:block}
.frame-thumb .fn{position:absolute;left:5px;bottom:4px;font-family:var(--mono);font-size:9.5px;
  color:#cfe;background:rgba(0,0,0,.55);padding:1px 5px;border-radius:4px}
.frame-thumb.cur{border-color:var(--cyan);box-shadow:var(--glow-cyan)}
.frame-thumb .vote{position:absolute;right:4px;top:4px;font-family:var(--mono);font-size:9px;
  padding:1px 5px;border-radius:4px;background:rgba(0,0,0,.6);color:var(--green)}

.ck-stage{background:radial-gradient(120% 120% at 50% 0%,#0c1530,#070b16);
  border:1px solid var(--line2);border-radius:var(--radius);position:relative;overflow:hidden;display:flex;flex-direction:column}
.ck-canvas-wrap{flex:1;position:relative;display:flex;align-items:center;justify-content:center;padding:10px}
#ckCanvas{max-width:100%;max-height:100%;border-radius:9px;background:#0a0f1d}
.ck-overlay-svg{position:absolute;inset:10px;pointer-events:none}
.scanline{position:absolute;left:0;right:0;height:3px;
  background:linear-gradient(90deg,transparent,var(--cyan),transparent);
  box-shadow:0 0 16px 3px rgba(0,229,255,.6);opacity:0;top:0}
.ck-toolbar{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line);
  background:rgba(10,16,32,.7);position:relative;z-index:3}
.ck-toolbar .spacer{flex:1}
.stage-stepper{display:flex;gap:0;padding:9px 14px;border-top:1px solid var(--line);background:rgba(10,16,32,.7);z-index:3}
.step{flex:1;text-align:center;font-size:10px;color:var(--muted2);position:relative;padding-top:16px}
.step::before{content:'';position:absolute;top:3px;left:50%;transform:translateX(-50%);width:9px;height:9px;
  border-radius:50%;background:var(--panel2);border:2px solid var(--line2);transition:.2s}
.step::after{content:'';position:absolute;top:7px;left:50%;width:100%;height:2px;background:var(--line);z-index:-1}
.step:last-child::after{display:none}
.step.done::before{background:var(--green);border-color:var(--green);box-shadow:0 0 8px var(--green)}
.step.active::before{background:var(--cyan);border-color:var(--cyan);box-shadow:var(--glow-cyan);animation:catpulse 1.2s infinite}
.step.active{color:var(--cyan)}.step.done{color:var(--green)}

/* 右侧仪表盘 */
.ck-side{display:flex;flex-direction:column;gap:12px;overflow-y:auto}
.gauge-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:14px}
.metrics{display:grid;grid-template-columns:1fr 1fr;gap:9px}
.metric{background:var(--bg2);border:1px solid var(--line);border-radius:9px;padding:9px 11px}
.metric .ml{font-size:10px;color:var(--muted);margin-bottom:3px}
.metric .mv{font-family:var(--mono);font-size:17px;font-weight:700;color:var(--cyan)}
.metric .mv.green{color:var(--green)} .metric .mv.amber{color:var(--amber)} .metric .mv.white{color:var(--text)}
.model-row{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;padding:6px 0;border-bottom:1px dashed var(--line)}
.model-row:last-child{border:none}.model-row .mlbl{color:var(--muted)}
.model-row .mtag{font-family:var(--mono);font-size:11px;color:var(--text)}
.led{width:7px;height:7px;border-radius:50%;display:inline-block;margin-right:5px;background:var(--muted2)}
.led.on{background:var(--green);box-shadow:0 0 7px var(--green);animation:blink 1.1s infinite}
@keyframes blink{50%{opacity:.4}}

/* 差异化 A：时序证据链面板 */
.evidence{background:linear-gradient(135deg,rgba(0,229,255,.07),var(--panel));border:1px solid rgba(0,229,255,.25);border-radius:var(--radius);padding:14px}
.evidence .eh{font-size:12px;font-weight:700;color:var(--cyan);display:flex;align-items:center;gap:7px;margin-bottom:10px}
.evidence .erow{display:flex;align-items:center;justify-content:space-between;font-size:11.5px;padding:5px 0}
.evidence .erow b{font-family:var(--mono);color:var(--text)}
.vote-track{display:flex;gap:3px;margin:7px 0}
.vote-cell{flex:1;height:18px;border-radius:4px;background:var(--panel2);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;font-family:var(--mono);font-size:9px;color:var(--muted2);transition:.25s}
.vote-cell.hit{background:rgba(43,217,124,.2);border-color:var(--green);color:var(--green)}
.vote-cell.miss{background:rgba(255,77,94,.13);border-color:rgba(255,77,94,.4);color:var(--red)}

/* 价值结算条 */
.value-bar{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);
  border:1px solid var(--line2);border-radius:11px;overflow:hidden;margin-top:14px}
.value-cell{background:linear-gradient(180deg,var(--panel2),var(--bg2));padding:12px 14px;text-align:center}
.value-cell .vl{font-size:10.5px;color:var(--muted);margin-bottom:5px}
.value-cell .vv{font-family:var(--mono);font-size:20px;font-weight:800;color:var(--cyan)}
.value-cell .vv.green{color:var(--green)}.value-cell .vv.amber{color:var(--amber)}

/* 可解释分级面板 */
.explain-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.explain-row .el{width:84px;font-size:11.5px;color:var(--muted)}
.explain-row .ebar{flex:1;height:9px;background:var(--panel2);border-radius:5px;overflow:hidden}
.explain-row .ebar > i{display:block;height:100%;border-radius:5px}
.explain-row .ev{width:64px;text-align:right;font-family:var(--mono);font-size:11.5px;color:var(--text)}
.formula{font-family:var(--mono);font-size:12px;color:var(--muted);background:var(--bg2);
  border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin-top:6px;line-height:1.8}
.formula b{color:var(--cyan)}

/* 证据链 */
.chain{display:flex;flex-direction:column;gap:0}
.chain-item{display:flex;gap:12px;padding:10px 0;position:relative}
.chain-item::before{content:'';position:absolute;left:7px;top:22px;bottom:-10px;width:2px;background:var(--line)}
.chain-item:last-child::before{display:none}
.chain-dot{width:16px;height:16px;border-radius:50%;background:var(--panel2);border:2px solid var(--cyan);
  flex:none;margin-top:2px;box-shadow:0 0 6px rgba(0,229,255,.4)}
.chain-body .ct{font-size:12.5px;font-weight:600}
.chain-body .cm{font-size:11px;color:var(--muted);font-family:var(--mono)}

/* 叶片示意 / 资产 */
.blade-map{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:16px}
.point-pin{cursor:pointer;transition:.15s}
.point-pin:hover circle{r:7}
.legend{display:flex;gap:14px;flex-wrap:wrap;font-size:11.5px;color:var(--muted);margin-top:10px}
.legend span{display:flex;align-items:center;gap:6px}

/* 进展/趋势 */
.predict-box{background:linear-gradient(135deg,rgba(43,217,124,.08),var(--panel));
  border:1px solid rgba(43,217,124,.25);border-radius:var(--radius);padding:15px}
.predict-box .ph{font-size:12px;font-weight:700;color:var(--green);margin-bottom:8px;display:flex;align-items:center;gap:7px}
.big-num{font-family:var(--mono);font-size:30px;font-weight:800}
.big-num.green{color:var(--green)}.big-num.amber{color:var(--amber)}.big-num.red{color:var(--red)}

/* 维保排程 */
.gantt{position:relative}
.gantt-row{display:flex;align-items:center;gap:10px;margin-bottom:9px}
.gantt-row .gl{width:120px;font-size:11.5px;color:var(--muted)}
.gantt-track{flex:1;height:26px;background:var(--bg2);border-radius:7px;position:relative;border:1px solid var(--line)}
.gantt-bar{position:absolute;height:100%;border-radius:7px;display:flex;align-items:center;
  padding:0 8px;font-size:10.5px;font-family:var(--mono);color:#04222a;font-weight:700}
.opt-vs{display:grid;grid-template-columns:1fr auto 1fr;gap:14px;align-items:center}
.vs-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);padding:15px;text-align:center}
.vs-card.win{border-color:var(--green);box-shadow:0 0 16px rgba(43,217,124,.18)}
.vs-arrow{font-size:22px;color:var(--cyan)}

/* 振动预留 */
.reserve-banner{background:repeating-linear-gradient(45deg,rgba(139,154,184,.06),rgba(139,154,184,.06) 12px,transparent 12px,transparent 24px);
  border:1px dashed var(--line2);border-radius:var(--radius);padding:16px;display:flex;align-items:center;gap:14px;margin-bottom:18px}
.reserve-banner .rb-ico{width:42px;height:42px;flex:none;border-radius:11px;background:rgba(163,113,255,.12);
  display:flex;align-items:center;justify-content:center;border:1px solid rgba(163,113,255,.3)}
.reserve-banner .rb-t{font-size:14px;font-weight:700;color:var(--purple)}
.reserve-banner .rb-s{font-size:12px;color:var(--muted);margin-top:3px}

/* 通用 */
.row{display:flex;align-items:center;gap:10px}
.between{justify-content:space-between}
.wrap{flex-wrap:wrap}
.mt{margin-top:14px}.mt-s{margin-top:8px}.mb{margin-bottom:14px}
.muted{color:var(--muted)}.small{font-size:11.5px}.center{text-align:center}
.mono{font-family:var(--mono)}
.flash{animation:flash .6s}
@keyframes flash{0%{background:rgba(0,229,255,.25)}100%{background:transparent}}
.spin-i{display:inline-block;width:13px;height:13px;border:2px solid var(--line2);border-top-color:var(--cyan);
  border-radius:50%;animation:spin .8s linear infinite}
.divider{height:1px;background:var(--line);margin:14px 0}

/* ===== 驾驶舱 v0.2 增强：网格背景 + 速度档 ===== */
.ck-grid-bg{position:absolute;inset:0;z-index:0;opacity:.45;pointer-events:none;
  background-image:linear-gradient(rgba(14,28,51,.5) 1px,transparent 1px),linear-gradient(90deg,rgba(14,28,51,.5) 1px,transparent 1px);
  background-size:26px 26px;animation:gridmove 6s linear infinite}
@keyframes gridmove{to{background-position:26px 26px}}
.ck-canvas-wrap{position:relative;z-index:1}
.speed-ctl{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:4px}
.spd{font-family:var(--mono);font-size:11px;padding:3px 7px;border-radius:6px;border:1px solid var(--line2);
  background:var(--panel2);color:var(--muted);cursor:pointer;transition:.13s}
.spd.on{background:rgba(0,229,255,.15);color:var(--cyan);border-color:var(--cyan)}

/* ===== 滑块 ===== */
.rng{-webkit-appearance:none;appearance:none;width:100%;height:5px;border-radius:5px;background:var(--panel2);outline:none;margin:8px 0;cursor:pointer}
.rng::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;border-radius:50%;background:var(--cyan);cursor:pointer;box-shadow:var(--glow-cyan)}
.rng::-moz-range-thumb{width:16px;height:16px;border:none;border-radius:50%;background:var(--cyan);cursor:pointer}

/* ===== 时序证据链页 ===== */
.ev-judge{display:flex;align-items:center;gap:8px;font-size:12.5px;padding:6px 0}
.sr-wrap{position:relative;width:100%;max-width:460px;border-radius:9px;overflow:hidden;border:1px solid var(--line2)}
.sr-wrap>canvas{display:block;width:100%;height:auto}
.sr-top{position:absolute;inset:0}
.sr-top canvas{display:block;width:100%;height:auto}
.sr-divider{position:absolute;top:0;bottom:0;width:2px;background:var(--cyan);box-shadow:var(--glow-cyan);left:50%}
.sr-lbl{position:absolute;bottom:8px;font-size:10.5px;font-family:var(--mono);padding:2px 7px;border-radius:5px;background:rgba(0,0,0,.62)}
.sr-lbl.left{left:8px;color:var(--c4)}.sr-lbl.right{right:8px;color:var(--green)}
.blade3d{width:150px;height:150px;flex:none;display:flex;align-items:center;justify-content:center}
.track-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:4px}
.trk{position:relative;flex:none;border-radius:7px;overflow:hidden;border:1px solid var(--line2)}
.trk canvas{display:block}
.trk-box{position:absolute;width:24px;height:24px;border:2px solid var(--green);border-radius:3px;box-shadow:0 0 6px var(--green)}
.trk-id{position:absolute;top:2px;left:2px;font-size:8px;font-family:var(--mono);color:var(--green);background:rgba(0,0,0,.6);padding:0 3px;border-radius:3px}

/* ===== 巡检报告页 ===== */
.report-doc{background:linear-gradient(180deg,#0f1730,#0b1020);border:1px solid var(--line2);border-radius:14px;padding:26px 30px;max-width:940px}
.rpt-head{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--cyan);padding-bottom:14px;margin-bottom:6px}
.rpt-title{font-size:22px;font-weight:800}
.rpt-sub{font-size:12.5px;color:var(--muted);margin-top:5px}
.rpt-logo{text-align:right;font-weight:800;color:var(--cyan)}
.rpt-no{font-size:10.5px;color:var(--muted);font-weight:400;font-family:var(--mono);margin-top:4px}
.rpt-sec{font-size:14px;font-weight:700;color:var(--cyan);margin:18px 0 10px;padding-left:10px;border-left:3px solid var(--cyan)}
.rpt-sub2{font-size:12px;color:var(--muted);margin-bottom:8px;font-weight:600}
.rpt-tbl{width:100%;border-collapse:collapse;font-size:12.5px}
.rpt-tbl td,.rpt-tbl th{border:1px solid var(--line);padding:8px 11px;text-align:left}
.rpt-tbl th{background:var(--panel2);color:var(--muted);font-weight:600}
.rpt-foot{font-size:11px;color:var(--muted2);text-align:center;margin-top:22px;padding-top:14px;border-top:1px solid var(--line)}

@media print{
  .topbar,.sidenav,.page-head{display:none !important}
  body,.content,.view{overflow:visible !important;height:auto !important}
  .report-doc{border:none;max-width:none;border-radius:0}
  @page{margin:1.2cm}
}
