/* ╔══════════════════════════════════════════════╗
   ║  WorkFileSync 控制台 — CRT 琥珀监控台 · 双主题  ║
   ║  暗色=机房 CRT（默认） / 亮色=暖纸·琥珀墨水     ║
   ╚══════════════════════════════════════════════╝ */

@font-face { font-family:'Archivo'; font-weight:400; font-display:swap; src:url('fonts/archivo-400.woff2') format('woff2'); }
@font-face { font-family:'Archivo'; font-weight:600; font-display:swap; src:url('fonts/archivo-600.woff2') format('woff2'); }
@font-face { font-family:'Archivo'; font-weight:700; font-display:swap; src:url('fonts/archivo-700.woff2') format('woff2'); }
@font-face { font-family:'JetBrains Mono'; font-weight:400; font-display:swap; src:url('fonts/jbmono-400.woff2') format('woff2'); }
@font-face { font-family:'JetBrains Mono'; font-weight:700; font-display:swap; src:url('fonts/jbmono-700.woff2') format('woff2'); }

/* ───────── 设计令牌：暗色（默认 / data-theme 未设或 =dark）───────── */
:root {
  /* 基础面 */
  --bg:#0d0f12; --bg-grid:#1a1f28; --panel:#16191e; --panel-2:#1b1f27;
  --line:#272d36; --line-2:#333b46;
  --ink:#e7e9ec; --muted:#828b97; --faint:#5a626d;
  /* 强调 */
  --amber:#ffb000; --amber-2:#ffd166; --amber-dim:#9a6c00; --on-amber:#1a1205;
  --red:#ff453a; --green:#3ddc84; --cyan:#54d6e0;
  /* 语义表面 */
  --input-bg:#0f1217; --btn-bg:#1c2128; --thead-bg:#13161b; --subrow-bg:#101318;
  --toast-bg:#1b1f26; --track-off:#2a2f38; --track-knob:#9aa3af;
  --scrollbar:#2b3038; --scrollbar-hover:#3a414c;
  --tip-bg:#0a0c0f; --tip-ink:#e7e9ec;
  /* 渐变端点 */
  --side-1:#13161b; --side-2:#0f1216;
  --login-1:#15191f; --login-2:#0a0c0f;
  --card-1:#16191e; --card-2:#121419;
  /* 叠加 / 信号底色 */
  --hover:rgba(255,255,255,.04); --amber-soft:rgba(255,176,0,.10); --amber-hover:rgba(255,176,0,.04);
  --sel:rgba(255,176,0,.28); --scanline:rgba(255,255,255,.025); --inset-hi:rgba(255,255,255,.03);
  --green-soft:rgba(61,220,132,.12); --green-line:rgba(61,220,132,.30);
  --red-soft:rgba(255,69,58,.12); --red-line:rgba(255,69,58,.35);
  --cyan-soft:rgba(84,214,224,.10); --cyan-line:rgba(84,214,224,.25);
  /* 辉光（亮色置 transparent 自动消隐） */
  --glow:rgba(255,176,0,.30); --glow-strong:rgba(255,176,0,.50); --glow-green:rgba(61,220,132,.30);
  --amber-line:rgba(255,176,0,.45);
  /* 阴影 / 遮罩 */
  --shadow:rgba(0,0,0,.6); --shadow-soft:rgba(0,0,0,.5); --overlay:rgba(5,7,10,.66);
  /* 排版 */
  --font-ui:'Archivo','Microsoft YaHei','PingFang SC',system-ui,sans-serif;
  --font-mono:'JetBrains Mono','Cascadia Code',Consolas,monospace;
  --radius:8px;
}

/* ───────── 设计令牌：亮色（暖纸·琥珀墨水）───────── */
:root[data-theme="light"] {
  --bg:#f4f0e6; --bg-grid:#e3d9c4; --panel:#fdfbf6; --panel-2:#f6f1e7;
  --line:#e6ddcb; --line-2:#d8cdb6;
  --ink:#2d2920; --muted:#80755f; --faint:#a99e86;
  --amber:#b06f00; --amber-2:#caa53b; --amber-dim:#e6b85c; --on-amber:#fff8ea;
  --red:#c8332a; --green:#1f9d57; --cyan:#1f8b97;
  --input-bg:#fbf7ee; --btn-bg:#f1ebdd; --thead-bg:#f4eee2; --subrow-bg:#f6f1e6;
  --toast-bg:#fffdf7; --track-off:#d8cdb6; --track-knob:#fbf7ee;
  --scrollbar:#d6ccb6; --scrollbar-hover:#c2b699;
  --tip-bg:#2d2920; --tip-ink:#f4f0e6;
  --side-1:#f0ebdf; --side-2:#ece5d6;
  --login-1:#f4f0e6; --login-2:#e9e1d0;
  --card-1:#fdfbf6; --card-2:#f6f1e7;
  --hover:rgba(0,0,0,.04); --amber-soft:rgba(176,111,0,.12); --amber-hover:rgba(176,111,0,.06);
  --sel:rgba(176,111,0,.18); --scanline:rgba(0,0,0,.015); --inset-hi:rgba(255,255,255,.6);
  --green-soft:rgba(31,157,87,.12); --green-line:rgba(31,157,87,.38);
  --red-soft:rgba(200,51,42,.10); --red-line:rgba(200,51,42,.36);
  --cyan-soft:rgba(31,139,151,.10); --cyan-line:rgba(31,139,151,.32);
  --glow:transparent; --glow-strong:transparent; --glow-green:transparent;
  --amber-line:rgba(176,111,0,.55);
  --shadow:rgba(90,72,30,.20); --shadow-soft:rgba(90,72,30,.15); --overlay:rgba(60,52,32,.32);
}

* { box-sizing:border-box; }
html,body { margin:0; height:100%; }
body {
  font-family:var(--font-ui); color:var(--ink); font-size:14px; line-height:1.5;
  background-color:var(--bg);
  background-image:radial-gradient(circle, var(--bg-grid) 1px, transparent 1.4px);
  background-size:24px 24px;
  transition:background-color .25s ease, color .25s ease;
}
.hidden { display:none !important; }
::selection { background:var(--sel); }
::-webkit-scrollbar { width:10px; height:10px; }
::-webkit-scrollbar-thumb { background:var(--scrollbar); border-radius:6px; }
::-webkit-scrollbar-thumb:hover { background:var(--scrollbar-hover); }
a { color:inherit; text-decoration:none; }
input,button,textarea { font-family:inherit; }

/* ───────── 登录 ───────── */
.login-wrap { position:fixed; inset:0; display:flex; align-items:center; justify-content:center; overflow:hidden;
  background:radial-gradient(ellipse at 50% 30%, var(--login-1) 0%, var(--login-2) 70%); }
.scanlines { position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:repeating-linear-gradient(0deg, var(--scanline) 0 1px, transparent 1px 3px); }
.login-card { position:relative; width:360px; padding:42px 38px;
  background:linear-gradient(180deg,var(--card-1),var(--card-2)); border:1px solid var(--line);
  border-radius:14px; box-shadow:0 30px 80px var(--shadow), inset 0 1px 0 var(--inset-hi);
  display:flex; flex-direction:column; gap:16px; animation:fadeUp .6s ease both; }
.login-card::before { content:''; position:absolute; top:0; left:24px; right:24px; height:1px;
  background:linear-gradient(90deg,transparent,var(--amber),transparent); box-shadow:0 0 14px var(--glow-strong); }
.login-brand { font-weight:700; font-size:23px; letter-spacing:2px; text-align:center; }
.login-brand .amber { color:var(--amber); text-shadow:0 0 22px var(--glow-strong); }
.login-brand .cursor { color:var(--amber); animation:blink 1.1s steps(1) infinite; }
.login-tag { font-family:var(--font-mono); font-size:11.5px; color:var(--muted); text-align:center; margin-top:-8px; letter-spacing:.5px; }
.fld { display:flex; flex-direction:column; gap:7px; }
.fld span { font-family:var(--font-mono); font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:1px; }
.fld input { padding:11px 13px; background:var(--input-bg); border:1px solid var(--line-2); border-radius:7px; color:var(--ink); font-size:14px; outline:none; transition:border-color .15s, box-shadow .15s; }
.fld input:focus { border-color:var(--amber); box-shadow:0 0 0 3px var(--amber-soft); }
#login-btn { margin-top:6px; padding:12px; background:var(--amber); color:var(--on-amber); border:none; border-radius:7px;
  font-weight:700; font-size:14.5px; letter-spacing:1px; cursor:pointer; transition:filter .15s, box-shadow .15s;
  box-shadow:0 6px 22px var(--glow); }
#login-btn:hover { filter:brightness(1.08); box-shadow:0 8px 28px var(--glow-strong); }
#login-btn:disabled { opacity:.6; cursor:not-allowed; }
.error-text { margin:0; min-height:16px; color:var(--red); font-size:12.5px; text-align:center; font-family:var(--font-mono); }

/* ───────── 侧边栏布局 ───────── */
.app-shell { display:grid; grid-template-columns:226px 1fr; min-height:100vh; }
.sidebar { position:sticky; top:0; height:100vh; display:flex; flex-direction:column;
  background:linear-gradient(180deg,var(--side-1),var(--side-2)); border-right:1px solid var(--line); padding:22px 16px; }
.logo { font-weight:700; font-size:17px; letter-spacing:.3px; padding:4px 8px 22px; display:flex; align-items:center; gap:9px; }
.logo-mark { color:var(--amber); text-shadow:0 0 14px var(--glow-strong); font-size:15px; }
.side-nav { display:flex; flex-direction:column; gap:4px; flex:1; }
.side-nav a { display:flex; align-items:center; gap:11px; padding:10px 13px; border-radius:8px; color:var(--muted);
  font-size:14px; font-weight:600; transition:background .14s, color .14s; position:relative; }
.side-nav a .ic { font-size:14px; width:16px; text-align:center; opacity:.85; }
.side-nav a:hover { background:var(--hover); color:var(--ink); }
.side-nav a.active { background:var(--amber-soft); color:var(--amber); }
.side-nav a.active::before { content:''; position:absolute; left:0; top:8px; bottom:8px; width:3px; border-radius:3px;
  background:var(--amber); box-shadow:0 0 10px var(--glow-strong); }
.side-foot { border-top:1px solid var(--line); padding-top:14px; display:flex; flex-direction:column; gap:10px; }
.conn { display:flex; align-items:center; gap:8px; font-family:var(--font-mono); font-size:11.5px; color:var(--muted); padding-left:6px; }
.conn .dot { width:7px; height:7px; border-radius:50%; background:var(--green); box-shadow:0 0 8px var(--glow-green); animation:pulse 2s infinite; }
.ghost-btn { padding:9px; background:transparent; border:1px solid var(--line-2); color:var(--muted); border-radius:7px; cursor:pointer; font-size:13px; transition:all .15s; }
.ghost-btn:hover { border-color:var(--red); color:var(--red); }
/* 主题切换 */
.theme-toggle { display:flex; align-items:center; gap:9px; padding:9px 11px; background:var(--btn-bg);
  border:1px solid var(--line-2); color:var(--muted); border-radius:7px; cursor:pointer; font-size:12.5px;
  font-family:var(--font-mono); transition:border-color .15s, color .15s, background .25s; }
.theme-toggle:hover { border-color:var(--amber); color:var(--amber); }
.theme-toggle .ti { font-size:14px; line-height:1; }
.theme-toggle .tl { flex:1; text-align:left; letter-spacing:.5px; }
.theme-toggle .tk { font-size:10px; color:var(--faint); }

/* ───────── 内容区 ───────── */
.content { padding:30px 34px; max-width:1280px; }
.view { animation:fadeUp .45s ease both; }
.page-head { display:flex; align-items:baseline; gap:14px; margin:0 0 24px; }
.page-head h1 { font-size:23px; font-weight:700; margin:0; letter-spacing:.2px; }
.page-head .sub { font-family:var(--font-mono); font-size:12px; color:var(--faint); }
.crumb { color:var(--muted); cursor:pointer; font-size:14px; font-weight:600; }
.crumb:hover { color:var(--amber); }

/* 统计卡 */
.stat-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(195px,1fr)); gap:15px; }
.stat-card { position:relative; background:var(--panel); border:1px solid var(--line); border-radius:var(--radius);
  padding:17px 19px; overflow:hidden; animation:fadeUp .5s ease both; }
.stat-card::before { content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--amber-line),transparent); }
.stat-card .label { font-family:var(--font-mono); font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.8px; }
.stat-card .num { font-family:var(--font-mono); font-weight:700; font-size:29px; color:var(--amber); margin-top:8px;
  text-shadow:0 0 20px var(--glow); line-height:1; }
.stat-card .num small { font-size:13px; color:var(--muted); font-weight:400; margin-left:5px; text-shadow:none; }
.stat-card .foot { font-size:11.5px; color:var(--faint); margin-top:7px; font-family:var(--font-mono); }
.stat-card.lit .num { color:var(--green); text-shadow:0 0 20px var(--glow-green); }
.stat-card:nth-child(1){animation-delay:.03s}.stat-card:nth-child(2){animation-delay:.06s}.stat-card:nth-child(3){animation-delay:.09s}
.stat-card:nth-child(4){animation-delay:.12s}.stat-card:nth-child(5){animation-delay:.15s}.stat-card:nth-child(6){animation-delay:.18s}.stat-card:nth-child(7){animation-delay:.21s}

/* 面板 */
.panel { background:var(--panel); border:1px solid var(--line); border-radius:var(--radius); margin-top:20px; overflow:hidden; animation:fadeUp .5s ease both; }
.panel-head { padding:14px 18px; border-bottom:1px solid var(--line); display:flex; align-items:center; gap:12px; font-weight:600; font-size:14.5px; }
.panel-head .tag { font-family:var(--font-mono); font-size:11px; color:var(--muted); }
.panel-head .spacer { flex:1; }
.panel-body { padding:18px; }

/* 表格 */
table { width:100%; border-collapse:collapse; font-size:13.5px; }
thead th { text-align:left; padding:11px 16px; font-family:var(--font-mono); font-size:11px; text-transform:uppercase; letter-spacing:.6px;
  color:var(--muted); background:var(--thead-bg); border-bottom:1px solid var(--line); white-space:nowrap; }
tbody td { padding:11px 16px; border-bottom:1px solid var(--line); vertical-align:middle; }
tbody tr:last-child td { border-bottom:none; }
tbody tr { transition:background .12s; }
tbody tr:hover { background:var(--amber-hover); }
.mono { font-family:var(--font-mono); font-size:12.5px; color:var(--muted); }
.amber { color:var(--amber); }
.path-cell { max-width:360px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.empty { text-align:center; color:var(--faint); padding:44px; font-family:var(--font-mono); font-size:13px; }
.loading { text-align:center; color:var(--muted); padding:54px; font-family:var(--font-mono); }
.loading::after { content:'_'; animation:blink 1s steps(1) infinite; }

/* 徽标 */
.badge { display:inline-block; padding:3px 9px; border-radius:20px; font-size:11.5px; font-family:var(--font-mono); border:1px solid transparent; }
.badge.on { background:var(--green-soft); color:var(--green); border-color:var(--green-line); }
.badge.off { background:var(--red-soft); color:var(--red); border-color:var(--red-line); }
.badge.dev { background:var(--cyan-soft); color:var(--cyan); border-color:var(--cyan-line); }

/* 按钮 */
.btn { padding:7px 13px; border-radius:7px; border:1px solid var(--line-2); background:var(--btn-bg); color:var(--ink); cursor:pointer; font-size:13px; transition:all .14s; }
.btn:hover { border-color:var(--amber); color:var(--amber); }
.btn.primary { background:var(--amber); color:var(--on-amber); border-color:var(--amber); font-weight:700; }
.btn.primary:hover { filter:brightness(1.08); color:var(--on-amber); }
.btn.danger { color:var(--red); border-color:var(--red-line); }
.btn.danger:hover { background:var(--red-soft); border-color:var(--red); color:var(--red); }
.btn.sm { padding:5px 10px; font-size:12px; }
.btn:disabled { opacity:.5; cursor:not-allowed; }
.row-actions { display:flex; gap:6px; flex-wrap:wrap; }

/* 工具条 / 搜索 / 分页 */
.toolbar { display:flex; gap:10px; align-items:center; margin-bottom:16px; flex-wrap:wrap; }
.search { padding:9px 13px; background:var(--input-bg); border:1px solid var(--line-2); border-radius:7px; color:var(--ink); width:300px; font-size:13.5px; outline:none; }
.search:focus { border-color:var(--amber); }
.pager { display:flex; gap:12px; align-items:center; justify-content:flex-end; margin-top:14px; color:var(--muted); font-family:var(--font-mono); font-size:12.5px; }

/* 信息网格 */
.info-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:16px 26px; }
.info-grid .k { font-family:var(--font-mono); font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.6px; }
.info-grid .v { font-size:14px; margin-top:5px; word-break:break-all; }
.info-grid .v.big { font-family:var(--font-mono); font-size:18px; color:var(--amber); }

/* 表单 */
.form-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:16px 22px; }
.field { display:flex; flex-direction:column; gap:7px; }
.field.full { grid-column:1/-1; }
.field label { font-family:var(--font-mono); font-size:11px; color:var(--muted); text-transform:uppercase; letter-spacing:.5px; }
.field input, .field textarea { padding:9px 12px; background:var(--input-bg); border:1px solid var(--line-2); border-radius:7px; color:var(--ink); font-size:13.5px; outline:none; }
.field input:focus, .field textarea:focus { border-color:var(--amber); }
.field textarea { resize:vertical; min-height:72px; font-family:var(--font-mono); font-size:12.5px; }

/* 横向条形图（类型分布） */
.bars { display:flex; flex-direction:column; gap:11px; }
.bar-row { display:grid; grid-template-columns:130px 1fr 150px; align-items:center; gap:14px; }
.bar-label { font-family:var(--font-mono); font-size:12.5px; color:var(--ink); overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.bar-track { height:20px; background:var(--input-bg); border-radius:4px; overflow:hidden; border:1px solid var(--line); }
.bar-fill { height:100%; background:linear-gradient(90deg,var(--amber-dim),var(--amber)); border-radius:3px; animation:barGrow .7s cubic-bezier(.2,.7,.3,1) both; box-shadow:0 0 14px var(--glow); }
.bar-meta { font-family:var(--font-mono); font-size:12px; color:var(--muted); text-align:right; }
.bar-meta b { color:var(--amber); font-weight:700; }

/* 趋势柱状 */
.trend { display:flex; align-items:flex-end; gap:3px; height:140px; padding:8px 0; border-bottom:1px solid var(--line); }
.trend-bar { flex:1; min-width:4px; background:linear-gradient(180deg,var(--amber),var(--amber-dim)); border-radius:3px 3px 0 0; position:relative; animation:growY .6s ease both; opacity:.85; transition:opacity .12s; }
.trend-bar:hover { opacity:1; box-shadow:0 0 12px var(--glow-strong); }
.trend-bar:hover::after { content:attr(data-tip); position:absolute; bottom:100%; left:50%; transform:translateX(-50%); margin-bottom:6px; background:var(--tip-bg); border:1px solid var(--line-2); color:var(--tip-ink); font-family:var(--font-mono); font-size:11px; padding:4px 8px; border-radius:5px; white-space:nowrap; z-index:5; }
.trend-axis { display:flex; justify-content:space-between; font-family:var(--font-mono); font-size:10.5px; color:var(--faint); margin-top:7px; }

/* 进度条（分块会话） */
.progress { height:8px; background:var(--input-bg); border-radius:5px; overflow:hidden; border:1px solid var(--line); min-width:110px; }
.progress-fill { height:100%; background:linear-gradient(90deg,var(--amber-dim),var(--amber)); animation:barGrow .6s ease both; }

/* 行内展开（版本历史） */
.subrow td { background:var(--subrow-bg); padding:0 16px; }
.versions { padding:6px 0 12px; }
.versions table { font-size:12.5px; }
.versions thead th { background:transparent; }

/* 内联开关 */
.switch { display:inline-flex; align-items:center; gap:7px; cursor:pointer; user-select:none; }
.switch .track { width:38px; height:20px; border-radius:20px; background:var(--track-off); position:relative; transition:background .18s; }
.switch .track::after { content:''; position:absolute; top:2px; left:2px; width:16px; height:16px; border-radius:50%; background:var(--track-knob); transition:transform .18s, background .18s; }
.switch.on .track { background:var(--green-line); }
.switch.on .track::after { transform:translateX(18px); background:var(--green); }

/* modal */
.modal-overlay { position:fixed; inset:0; background:var(--overlay); backdrop-filter:blur(2px); display:flex; align-items:center; justify-content:center; z-index:60; animation:fadeIn .15s ease; }
.modal { width:380px; background:var(--panel); border:1px solid var(--line-2); border-radius:12px; padding:24px; box-shadow:0 30px 80px var(--shadow); animation:fadeUp .25s ease; }
.modal h3 { margin:0 0 16px; font-size:16px; }
.modal .actions { display:flex; gap:10px; justify-content:flex-end; margin-top:20px; }

/* toast */
.toast { position:fixed; bottom:26px; left:50%; transform:translateX(-50%); background:var(--toast-bg); border:1px solid var(--line-2); color:var(--ink); padding:11px 20px; border-radius:9px; font-size:13.5px; box-shadow:0 12px 36px var(--shadow-soft); z-index:80; font-family:var(--font-mono); }
.toast.ok { border-color:var(--green-line); }
.toast.ok::before { content:'✓ '; color:var(--green); }
.toast.err { border-color:var(--red-line); }
.toast.err::before { content:'✕ '; color:var(--red); }

/* 动画 */
@keyframes fadeUp { from { opacity:0; transform:translateY(12px); } to { opacity:1; transform:none; } }
@keyframes fadeIn { from { opacity:0; } to { opacity:1; } }
@keyframes barGrow { from { width:0 !important; } }
@keyframes growY { from { height:0; } }
@keyframes blink { 50% { opacity:0; } }
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:.4; } }
@media (max-width:760px){ .app-shell{ grid-template-columns:1fr; } .sidebar{ position:static; height:auto; flex-direction:row; flex-wrap:wrap; } .side-nav{ flex-direction:row; } .side-foot{ border:none; } }
