/* cxalloy-filler 设计系统 —— 现场仪表盘 · 移动优先 · 单手 · 零字体加载 */
:root{
  --bg:#eaecf0; --surface:#fff; --surface-2:#f5f7f9;
  --ink:#13171e; --ink-2:#586173; --ink-3:#7a838f; --line:#e1e5eb;
  --bar:#141823; --bar-2:#1d2230; --bar-ink:#eef1f6; --bar-ink-2:#9aa3b4;
  --accent:#f59e0b; --accent-d:#9a5d05; --accent-bg:#fff5e3; --accent-ink:#7a4d00;
  --pass:#15803d; --pass-bg:#e7f6ec; --fail:#dc2626; --fail-bg:#fdeaea; --na:#566374; --na-bg:#eef1f5;
  --r:14px; --r-sm:10px; --tap:54px;
  --t-tag:1.05rem; --t-body:.9rem; --t-meta:.78rem; --t-micro:.68rem;
  --font:system-ui,-apple-system,"PingFang SC","Microsoft YaHei",Segoe UI,sans-serif;
  --mono:ui-monospace,"SF Mono","JetBrains Mono",Menlo,Consolas,monospace;
  --shadow:0 1px 2px rgba(16,22,34,.05),0 2px 10px rgba(16,22,34,.05);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html,body{margin:0;padding:0}
body{font-family:var(--font);background:var(--bg);color:var(--ink);font-size:16px;line-height:1.5;
  -webkit-font-smoothing:antialiased;padding-bottom:env(safe-area-inset-bottom)}
a{color:inherit;text-decoration:none}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
svg.ic{display:block;flex:none}

/* 顶栏 */
.topbar{position:sticky;top:0;z-index:50;background:var(--bar);color:var(--bar-ink);
  display:flex;align-items:center;gap:.7rem;padding:.7rem 1rem;padding-top:calc(.7rem + env(safe-area-inset-top));
  box-shadow:0 1px 0 rgba(255,255,255,.05),0 6px 18px rgba(0,0,0,.18)}
.topbar .brand{font-weight:700;letter-spacing:.02em;display:flex;align-items:center;gap:.5rem;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:0 1 auto}
.topbar .brand .dot{width:10px;height:10px;border-radius:3px;background:var(--accent);box-shadow:0 0 0 3px rgba(245,158,11,.25);flex:none}
.topbar .spacer{flex:1;min-width:.5rem}
.topbar a.tb,.topbar .who{color:var(--bar-ink-2);font-size:.85rem;display:flex;align-items:center;gap:.35rem;white-space:nowrap;flex:none}
.topbar a.tb:active{color:var(--bar-ink)}
.topbar .back{display:flex;color:var(--bar-ink);margin-right:.1rem}
.netpill{display:inline-flex;align-items:center;gap:.32rem;font-size:.72rem;font-weight:700;color:var(--bar-ink-2);
  background:rgba(255,255,255,.07);border-radius:99px;padding:.2rem .5rem;cursor:pointer;white-space:nowrap;flex:none}
.netpill .d2{width:7px;height:7px;border-radius:50%;background:#34d399;flex:none}
.netpill.offline{color:#fca5a5;background:rgba(220,38,38,.18)} .netpill.offline .d2{background:#f87171}
.netpill.syncing{color:#fcd34d;background:rgba(245,158,11,.16)} .netpill.syncing .d2{background:var(--accent);animation:pulse 1s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.25}}

.wrap{max-width:760px;margin:0 auto;padding:1rem 1rem calc(8.5rem + env(safe-area-inset-bottom))}
.page-h{display:flex;align-items:baseline;gap:.6rem;margin:.4rem 0 1rem}
.page-h h1{font-size:1.3rem;margin:0;font-weight:700;letter-spacing:-.01em}
.page-h .sub{color:var(--ink-2);font-size:var(--t-meta)}

/* 卡片 */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.card+.card{margin-top:.8rem}
.card-h{padding:.8rem .95rem;border-bottom:1px solid var(--line);font-weight:600;font-size:var(--t-body);display:flex;align-items:center;gap:.5rem;background:var(--surface-2)}
.card-b{padding:1rem}

/* 族 = 一块仪表面板（发丝线行表，非浮卡堆叠）*/
.fam{margin-top:1.2rem;background:var(--surface);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);overflow:hidden}
.fam-h{display:flex;align-items:center;gap:.5rem;margin:0;padding:.6rem .9rem;background:var(--surface-2);border-bottom:1px solid var(--line);
  color:var(--ink-2);font-size:var(--t-micro);font-weight:700;letter-spacing:.1em;text-transform:uppercase}
.fam-h .ct{margin-left:auto;background:var(--bar);color:var(--bar-ink-2);border-radius:99px;padding:.05rem .5rem;font-size:var(--t-micro);font-weight:600}

/* 设备行 */
.eq{display:flex;align-items:center;gap:.7rem;padding:.7rem .9rem;border-bottom:1px solid var(--line);min-height:60px;
  transition:background .15s ease}
.eq:last-child{border-bottom:0}
.eq:active{background:var(--surface-2)}
.led{width:8px;height:8px;border-radius:50%;flex:none;background:var(--ink-3);box-shadow:0 0 0 3px var(--surface-2)}
.eq[data-state="active"] .led{background:var(--accent);box-shadow:0 0 0 3px var(--accent-bg),0 0 7px rgba(245,158,11,.55)}
.eq[data-state="done"] .led{background:var(--pass)}
.eq[data-state="pushed"] .led{background:var(--bar)}
.eq .tag{font-family:var(--mono);font-weight:700;font-size:var(--t-tag);letter-spacing:-.02em}
.eq .meta{color:var(--ink-3);font-size:var(--t-meta);margin-top:.1rem;font-family:var(--mono)}
.eq .phases{margin-left:auto;display:flex;gap:.5rem;padding-top:.45rem}

/* 阶段芯片：可解码（顶部 L1/L2/L3 角标）*/
.ph{position:relative;width:30px;height:28px;border-radius:8px;display:flex;align-items:center;justify-content:center;
  font:700 .6rem/1 var(--mono);font-variant-numeric:tabular-nums;border:1.5px dashed var(--line);color:var(--ink-3);background:var(--surface-2)}
.ph::after{content:attr(data-lvl);position:absolute;top:-8px;left:50%;transform:translateX(-50%);font:600 .5rem/1 var(--mono);color:var(--ink-3)}
.ph.partial{background:var(--accent-bg);border-style:solid;border-color:var(--accent);color:var(--accent-d)}
.ph.done{background:var(--pass-bg);border-style:solid;border-color:var(--pass);color:var(--pass)}
.ph.pushed{background:var(--bar);border-style:solid;border-color:var(--bar);color:var(--bar-ink-2)}

/* 大答案按钮 */
.ans{display:grid;grid-template-columns:1fr 1fr 1fr;gap:.5rem}
.ans button{height:var(--tap);border-radius:var(--r-sm);border:1.5px solid var(--line);background:var(--surface);
  font-size:1.02rem;font-weight:700;color:var(--ink-2);cursor:pointer;transition:transform .06s ease,background .15s ease}
.ans button:active{transform:scale(.97)}
.ans button.yes.on{background:var(--pass-bg);border-color:var(--pass);color:var(--pass)}
.ans button.no.on{background:var(--fail-bg);border-color:var(--fail);color:var(--fail)}
.ans button.na.on{background:var(--na-bg);border-color:var(--na);color:var(--na)}

/* 核对行 */
.line{padding:.85rem .95rem;border-bottom:1px solid var(--line)}
.line:last-child{border-bottom:0}
.line.delta{background:linear-gradient(90deg,var(--accent-bg),transparent 72%)}
.line.delta .n{color:var(--accent-d)}
.line[data-save="err"]{background:var(--fail-bg)}
.line .lh{display:flex;align-items:flex-start;gap:.5rem;margin-bottom:.6rem}
.line .n{font-family:var(--mono);font-size:.78rem;color:var(--ink-3);min-width:1.5rem;padding-top:.1rem;font-weight:700}
.line .lbl{font-weight:600;font-size:var(--t-body);flex:1;line-height:1.35}
.line .note{margin-top:.55rem}
.line input.note-in{width:100%;height:48px;border:1.5px solid var(--line);border-radius:var(--r-sm);padding:0 .7rem;
  font-family:var(--mono);font-size:16px;background:var(--surface-2)}
.line input.note-in:focus{outline:none;border-color:var(--accent);background:#fff}
.tagline{display:flex;gap:.45rem;align-items:center;flex-wrap:wrap;margin-top:.55rem;font-size:var(--t-micro);color:var(--ink-3)}
.line .saveflag{font-size:var(--t-micro);font-weight:700;margin-left:auto;transition:color .2s ease}
.line[data-save="ok"] .saveflag{color:var(--pass)} .line[data-save="ok"] .saveflag::before{content:"已存 ✓"}
.line[data-save="pending"] .saveflag{color:var(--ink-3)} .line[data-save="pending"] .saveflag::before{content:"存…"}
.line[data-save="err"] .saveflag{color:var(--fail)} .line[data-save="err"] .saveflag::before{content:"未存 · 点行重试"}

/* 药丸 */
.pill{display:inline-flex;align-items:center;gap:.3rem;border-radius:99px;padding:.12rem .55rem;font-size:var(--t-micro);font-weight:700;line-height:1.7}
.pill.delta{background:var(--accent-bg);color:var(--accent-ink)}
.pill.common{background:var(--surface-2);color:var(--ink-3)}
.pill.lo{background:var(--fail-bg);color:var(--fail)} .pill.med{background:var(--accent-bg);color:var(--accent-ink)} .pill.hi{background:var(--pass-bg);color:var(--pass)}
.pill.st{background:var(--bar);color:var(--accent)}

/* 按钮 */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;height:var(--tap);padding:0 1.1rem;
  border-radius:var(--r-sm);border:0;font-size:1rem;font-weight:700;cursor:pointer;width:100%;
  transition:transform .06s ease,box-shadow .15s ease,background .15s ease}
.btn.primary{background:var(--accent);color:#231400;box-shadow:0 2px 0 var(--accent-d)}
.btn.primary:active{transform:translateY(1px);box-shadow:0 1px 0 var(--accent-d)}
.btn.dark{background:var(--bar);color:var(--bar-ink)}
.btn.ghost{background:var(--surface);border:1.5px solid var(--line);color:var(--ink)}
.btn.sm{height:46px;font-size:.88rem;width:auto;padding:0 .9rem}
.btn:disabled{opacity:.6;pointer-events:none}
.ans button:focus-visible,.btn:focus-visible,.eq:focus-visible,.line input:focus-visible,a:focus-visible{outline:3px solid var(--accent);outline-offset:2px}

/* 拍照入口：中性面板，橙只留给图标（克制 accent）*/
.shoot{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
  min-height:140px;border:1.5px dashed var(--line);border-radius:var(--r);background:var(--surface);color:var(--ink-2);font-weight:600;cursor:pointer}
.shoot .ic{color:var(--accent)}
.shoot input{position:absolute;inset:0;opacity:0}

/* 底部操作栏（破坏性主操作独占一行）*/
.actionbar{position:fixed;left:0;right:0;bottom:0;z-index:40;background:var(--surface);border-top:1px solid var(--line);
  padding:.7rem 1rem calc(.7rem + env(safe-area-inset-bottom));display:flex;gap:.6rem;box-shadow:0 -6px 18px rgba(16,22,34,.07)}
.actionbar .grow{flex:1}
.actionbar.two-row{flex-direction:column;gap:.5rem}
.actionbar.two-row .ab-sec{display:flex;gap:.5rem}
.actionbar.two-row .ab-sec .btn{flex:1}
@media(min-width:560px){ .actionbar.two-row{flex-direction:row} .actionbar.two-row .ab-sec{flex:1} }

/* 表单 */
label.f{display:block;font-size:var(--t-meta);color:var(--ink-2);font-weight:600;margin:.7rem 0 .3rem}
input.f,select.f{width:100%;height:var(--tap);border:1.5px solid var(--line);border-radius:var(--r-sm);padding:0 .8rem;font-size:16px;background:var(--surface)}
input.f:focus,select.f:focus{outline:none;border-color:var(--accent)}

.flash{background:var(--accent-bg);color:var(--accent-ink);border:1px solid var(--accent);border-radius:var(--r-sm);padding:.6rem .8rem;font-size:.85rem;margin-bottom:.9rem}
.empty{text-align:center;color:var(--ink-3);padding:2.4rem 1rem;font-size:.9rem}
.syncbar{position:sticky;top:0;z-index:30;background:var(--fail);color:#fff;text-align:center;font-size:.8rem;font-weight:700;padding:.45rem;display:none}
.syncbar.show{display:block}
.cxf-toast{position:fixed;left:50%;bottom:calc(5.5rem + env(safe-area-inset-bottom));transform:translateX(-50%) translateY(10px);
  background:var(--bar);color:var(--bar-ink);padding:.7rem 1.1rem;border-radius:99px;font-size:.85rem;font-weight:600;
  box-shadow:0 8px 24px rgba(0,0,0,.28);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;z-index:60;max-width:88%;text-align:center}
.cxf-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* 克制微交互（带 reduced-motion 守卫）*/
@media(prefers-reduced-motion:no-preference){
  .eq{animation:row .28s cubic-bezier(.22,1,.36,1) both}
  .fam .eq:nth-child(2){animation-delay:.03s}.fam .eq:nth-child(3){animation-delay:.06s}
  .fam .eq:nth-child(4){animation-delay:.09s}.fam .eq:nth-child(5){animation-delay:.12s}
}
@keyframes row{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
@media(min-width:820px){ .wrap{padding-top:1.4rem} }
