/* ============================================================
   灵活用工平台 · 调度沙盘原型  —— 设计系统（亮色版）
   方向：派单调度台  /  工装橙 + 在途青 + 浅色控制台
   ============================================================ */

:root{
  /* —— 色板 —— */
  --ink:        #16202E;   /* 文字主色 / 深色设备拟物 */
  --ink-soft:   #243349;
  --signal:     #F2611B;   /* 工装橙 hi-vis：品牌 / 主操作 / 激活 */
  --signal-700: #D24A0E;
  --signal-tint:#FFF1E8;
  --track:      #0AA89E;   /* 在途 / 进行中 */
  --track-700:  #07857D;
  --track-tint: #E2F6F4;
  --ok:         #1B9E6B;
  --ok-tint:    #E6F4EE;
  --warn:       #B97708;
  --warn-tint:  #FBF1DC;
  --danger:     #DC3A3F;
  --danger-tint:#FBE7E7;

  --surface:    #EEF1F6;   /* app 浅底 */
  --surface-2:  #F5F7FA;
  --card:       #FFFFFF;
  --line:       #E2E7EF;
  --line-soft:  #EDF1F6;
  --text:       #16202E;
  --muted:      #58637A;
  --muted-2:    #8A94A6;

  /* —— 字体 —— */
  --sans: -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Segoe UI", Roboto, "Helvetica Neue", sans-serif;
  --mono: ui-monospace, "Cascadia Code", "SFMono-Regular", "JetBrains Mono", Consolas, "Liberation Mono", monospace;

  /* —— 圆角 / 阴影 —— */
  --r:    14px;
  --r-sm: 10px;
  --r-lg: 20px;
  --pill: 999px;
  --sh-1: 0 1px 2px rgba(16,32,52,.05), 0 2px 8px rgba(16,32,52,.05);
  --sh-2: 0 8px 24px rgba(16,32,52,.10), 0 2px 6px rgba(16,32,52,.06);
  --sh-3: 0 22px 60px rgba(16,32,52,.18);
}

*{ box-sizing:border-box; }
html,body{ margin:0; height:100%; }
body{
  font-family:var(--sans); font-size:15px; color:var(--text);
  background:
    radial-gradient(1100px 520px at 84% -10%, #FFEFE4 0%, transparent 55%),
    linear-gradient(180deg, #F3F5F9 0%, #E8ECF3 100%);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }
::selection{ background:var(--signal); color:#fff; }

.mono{ font-family:var(--mono); font-variant-numeric:tabular-nums; }
.eyebrow{ font-family:var(--mono); font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted-2); }

/* ============================================================
   App Shell  —— 左侧全局导航 + 中央舞台
   ============================================================ */
.app{ display:grid; grid-template-columns:300px 1fr; height:100vh; min-height:0; }

/* —— 左侧「纵观全局」导航（亮色） —— */
.rail{
  background:#FFFFFF; color:var(--text); display:flex; flex-direction:column; min-height:0;
  border-right:1px solid var(--line);
}
.rail__brand{ display:flex; align-items:center; gap:12px; padding:22px 20px 16px; }
.rail__logo{
  width:40px; height:40px; border-radius:12px; flex:none; position:relative;
  background:linear-gradient(140deg,var(--signal),#ff8a4d); box-shadow:0 6px 16px rgba(242,97,27,.4);
}
.rail__logo::after{
  content:""; position:absolute; inset:0; border-radius:12px;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.9) 0 2.5px, transparent 3px),
    radial-gradient(circle at 70% 64%, rgba(255,255,255,.9) 0 2.5px, transparent 3px);
}
.rail__logo i{ position:absolute; left:13px; right:13px; top:19px; height:2px; background:rgba(255,255,255,.9); transform:rotate(34deg); transform-origin:left; }
.rail__name{ font-weight:700; font-size:16.5px; color:var(--text); letter-spacing:.01em; }
.rail__name small{ display:block; font-size:11px; font-weight:600; letter-spacing:.22em; color:var(--muted-2); margin-top:3px; font-family:var(--mono); }

.rail__home{
  margin:6px 14px 14px; padding:13px 14px; border-radius:12px; cursor:pointer;
  display:flex; align-items:center; gap:10px; font-size:15px; font-weight:700; color:#fff;
  background:linear-gradient(135deg,var(--signal),#ff8546); box-shadow:0 10px 22px rgba(242,97,27,.3);
}
.rail__home span{ color:#fff; }
.rail__home .dot{ margin-left:auto; font-family:var(--mono); font-size:10.5px; color:#fff; opacity:.9; letter-spacing:.1em; }

.rail__scroll{ overflow:auto; flex:1; padding:4px 10px 24px; min-height:0; }
.rail__scroll::-webkit-scrollbar{ width:8px; }
.rail__scroll::-webkit-scrollbar-thumb{ background:#D7DDE7; border-radius:99px; }

.navgroup{ margin:14px 8px 4px; }
.navgroup__h{
  display:flex; align-items:center; gap:8px; padding:5px 8px; margin-bottom:4px;
  font-family:var(--mono); font-size:11.5px; letter-spacing:.14em; text-transform:uppercase; color:var(--muted-2);
}
.navgroup__h b{ color:var(--text); font-weight:700; letter-spacing:.01em; text-transform:none; font-family:var(--sans); font-size:14px; }
.navgroup__tag{ margin-left:auto; font-size:11px; padding:2px 9px; border-radius:99px; border:1px solid var(--line); color:var(--muted); background:var(--surface-2); }
.navgroup__tag.is-ent{ color:var(--signal-700); border-color:#FAD7C5; background:#FFF4EE; }
.navgroup__tag.is-wk{ color:var(--track-700); border-color:#BCE7E3; background:#E9F8F6; }

.navlink{
  display:flex; align-items:center; gap:10px; padding:10px 11px; margin:2px 0;
  border-radius:10px; font-size:14.5px; color:#3B4659; cursor:pointer; position:relative;
  transition:background .12s, color .12s;
}
.navlink:hover{ background:#F2F5F9; color:var(--text); }
.navlink.active{ background:var(--signal-tint); color:var(--signal-700); font-weight:600; }
.navlink.active::before{
  content:""; position:absolute; left:-10px; top:8px; bottom:8px; width:3px;
  border-radius:0 3px 3px 0; background:var(--signal);
}
.navlink .ic{ width:18px; text-align:center; opacity:.95; font-size:14.5px; }
.navlink .n{ margin-left:auto; font-family:var(--mono); font-size:11px; color:var(--muted-2); }

/* —— 中央舞台 —— */
.stage{ display:flex; flex-direction:column; min-width:0; min-height:0; background:transparent; }
.stage__bar{
  height:60px; flex:none; display:flex; align-items:center; gap:14px; padding:0 26px;
  color:var(--text); border-bottom:1px solid var(--line); background:rgba(255,255,255,.55);
}
.crumb{ display:flex; align-items:center; gap:9px; font-size:14.5px; color:var(--muted); }
.crumb b{ color:var(--text); font-weight:700; }
.crumb .sep{ color:var(--muted-2); }
.stage__role{
  margin-left:auto; display:flex; align-items:center; gap:8px;
  font-family:var(--mono); font-size:12.5px; letter-spacing:.04em; color:var(--muted);
  padding:6px 13px; border:1px solid var(--line); border-radius:99px; background:#fff;
}
.stage__role b{ color:var(--text); }
.stage__role .rdot{ width:8px; height:8px; border-radius:50%; background:var(--track); box-shadow:0 0 0 3px rgba(10,168,158,.18); }
.stage__scroll{ flex:1; overflow:auto; min-height:0; display:flex; justify-content:center; padding:30px; }
.stage__scroll::-webkit-scrollbar{ width:11px; }
.stage__scroll::-webkit-scrollbar-thumb{ background:#CFD6E1; border-radius:99px; }

/* ============================================================
   纵观全局 · 调度沙盘（亮色）
   ============================================================ */
.board{ width:min(1200px,100%); color:var(--text); }
.board__hero{ display:flex; align-items:flex-end; gap:24px; margin-bottom:6px; flex-wrap:wrap; }
.board__title{ font-size:36px; font-weight:780; letter-spacing:-.02em; color:var(--text); line-height:1.08; }
.board__title span{ color:var(--signal-700); }
.board__sub{ color:var(--muted); font-size:16px; max-width:580px; margin-top:12px; line-height:1.65; }
.board__metrics{ margin-left:auto; display:flex; gap:10px; }
.bmetric{ background:#fff; border:1px solid var(--line); border-radius:13px; padding:12px 16px; min-width:100px; box-shadow:var(--sh-1); }
.bmetric b{ display:block; font-family:var(--mono); font-size:24px; color:var(--text); font-variant-numeric:tabular-nums; }
.bmetric small{ color:var(--muted); font-size:12.5px; }
.bmetric b i{ font-size:13px; color:var(--track-700); font-style:normal; margin-left:3px; }

/* 履约时间轴 —— 全景顶部主轴（签名元素的横版） */
.spine{
  margin:26px 0 30px; padding:20px 24px; border-radius:18px;
  background:#fff; border:1px solid var(--line); box-shadow:var(--sh-1); position:relative; overflow:hidden;
}
.spine::before{ content:""; position:absolute; inset:0 0 auto 0; height:4px; background:linear-gradient(90deg,var(--track),var(--signal)); }
.spine__h{ display:flex; align-items:center; gap:10px; margin-bottom:18px; }
.spine__h b{ color:var(--text); font-size:15px; font-weight:700; }
.spine__h .eyebrow{ color:var(--muted-2); }
.spine__flow{ display:flex; align-items:flex-start; gap:0; }
.snode{ flex:1; position:relative; text-align:center; min-width:0; }
.snode__dot{
  width:34px; height:34px; border-radius:50%; margin:0 auto 10px; position:relative; z-index:2;
  display:grid; place-items:center; font-family:var(--mono); font-size:14px; font-weight:700;
  background:#fff; color:var(--muted-2); border:2px solid var(--line);
}
.snode.done .snode__dot{ background:var(--track); color:#fff; border-color:var(--track); box-shadow:0 0 0 4px rgba(10,168,158,.14); }
.snode.now  .snode__dot{ background:var(--signal); color:#fff; border-color:var(--signal); box-shadow:0 0 0 5px rgba(242,97,27,.16); animation:pulse 2s infinite; }
.snode::before{ content:""; position:absolute; top:17px; left:-50%; width:100%; height:3px; background:var(--line); z-index:1; }
.snode:first-child::before{ display:none; }
.snode.done::before, .snode.now::before{ background:var(--track); }
.snode__t{ font-size:13px; color:var(--muted); line-height:1.3; }
.snode.now .snode__t{ color:var(--signal-700); font-weight:700; }
@keyframes pulse{ 0%,100%{ box-shadow:0 0 0 5px rgba(242,97,27,.16);} 50%{ box-shadow:0 0 0 9px rgba(242,97,27,.04);} }

/* 三大端分区 */
.zones{ display:grid; grid-template-columns:repeat(2,1fr); gap:18px; }
.zone{ background:#fff; border:1px solid var(--line); border-radius:18px; overflow:hidden; box-shadow:var(--sh-1); }
.zone--wide{ grid-column:1 / -1; }
.zone__h{ display:flex; align-items:center; gap:12px; padding:16px 20px; border-bottom:1px solid var(--line-soft); }
.zone__ic{ width:34px; height:34px; border-radius:9px; display:grid; place-items:center; font-size:17px; flex:none; }
.zone__ic.m{ background:var(--signal-tint); color:var(--signal-700); }
.zone__ic.a{ background:var(--track-tint); color:var(--track-700); }
.zone__ic.p{ background:#EAEEFF; color:#4C63D8; }
.zone__h b{ color:var(--text); font-size:16px; }
.zone__h small{ color:var(--muted); font-size:13px; display:block; margin-top:2px; }
.zone__h .zcount{ margin-left:auto; font-family:var(--mono); font-size:12.5px; color:var(--muted-2); }
.zone__body{ padding:16px; display:grid; gap:16px; }
.subzone__h{ display:flex; align-items:center; gap:8px; margin:2px 4px 10px; font-size:14px; color:var(--text); font-weight:700; }
.subzone__h .pill-mini{ font-family:var(--mono); font-size:10.5px; padding:2px 9px; border-radius:99px; border:1px solid var(--line); color:var(--muted); background:var(--surface-2); }
.cards{ display:grid; grid-template-columns:repeat(auto-fill,minmax(172px,1fr)); gap:11px; }

.scard{
  background:#fff; border:1px solid var(--line); border-radius:13px; padding:14px; cursor:pointer; position:relative;
  transition:transform .12s, border-color .12s, box-shadow .12s; box-shadow:var(--sh-1); overflow:hidden;
}
.scard:hover{ transform:translateY(-3px); border-color:var(--signal); box-shadow:var(--sh-2); }
.scard__top{ display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.scard__ic{ width:28px; height:28px; border-radius:8px; display:grid; place-items:center; font-size:14px; background:var(--surface-2); color:var(--muted); }
.scard__no{ margin-left:auto; font-family:var(--mono); font-size:11px; color:var(--muted-2); }
.scard__t{ font-size:14.5px; color:var(--text); font-weight:700; line-height:1.35; }
.scard__d{ font-size:12.5px; color:var(--muted); margin-top:5px; line-height:1.45; min-height:34px; }
.scard__go{ margin-top:10px; font-family:var(--mono); font-size:11px; color:var(--signal-700); letter-spacing:.06em; font-weight:600; opacity:0; transition:opacity .12s; }
.scard:hover .scard__go{ opacity:1; }

/* ============================================================
   设备外壳 —— 手机壳 / 桌面壳
   ============================================================ */
.device{ display:flex; gap:34px; align-items:flex-start; flex-wrap:wrap; justify-content:center; }
.device__aside{ width:252px; flex:none; color:var(--text); padding-top:10px; }
.device__aside .eyebrow{ margin-bottom:12px; color:var(--muted-2); }
.device__aside h2{ font-size:23px; color:var(--text); margin:0 0 10px; font-weight:760; }
.device__aside p{ font-size:14.5px; color:var(--muted); line-height:1.7; }
.aside-flow{ margin-top:20px; border-left:2px solid var(--line); padding-left:0; }
.aside-step{ position:relative; padding:0 0 15px 18px; }
.aside-step::before{ content:""; position:absolute; left:-5px; top:4px; width:8px; height:8px; border-radius:50%; background:#CDD5E1; }
.aside-step.on::before{ background:var(--signal); box-shadow:0 0 0 3px rgba(242,97,27,.18); }
.aside-step b{ font-size:14px; color:var(--text); display:block; }
.aside-step span{ font-size:12.5px; color:var(--muted); }

/* —— 手机壳（深色边框=真机拟物，保留） —— */
.phone{
  width:386px; flex:none; background:#0c1118; border-radius:48px; padding:13px;
  box-shadow:var(--sh-3), inset 0 0 0 2px #2a3342; position:relative;
}
.phone__screen{
  background:var(--surface); border-radius:37px; overflow:hidden; height:792px;
  display:flex; flex-direction:column; position:relative;
}
.phone__status{
  height:44px; flex:none; display:flex; align-items:center; padding:0 24px 0 30px; gap:6px;
  font-family:var(--mono); font-size:14px; font-weight:700; color:#fff; position:relative; z-index:5;
}
.phone__status .time{ font-variant-numeric:tabular-nums; }
.phone__status .sig{ margin-left:auto; letter-spacing:.05em; font-size:12.5px; opacity:.92; }
.phone__notch{ position:absolute; top:15px; left:50%; transform:translateX(-50%); width:122px; height:27px; background:#0c1118; border-radius:0 0 16px 16px; z-index:6; }

/* app 顶栏（壳内） */
.mbar{ flex:none; padding:7px 16px 12px; color:#fff; position:relative; z-index:4; }
.mbar__row{ display:flex; align-items:center; gap:10px; min-height:36px; }
.mbar__back{ width:32px; height:32px; border-radius:10px; display:grid; place-items:center; background:rgba(255,255,255,.18); font-size:17px; }
.mbar__title{ font-size:19px; font-weight:700; letter-spacing:.01em; }
.mbar__title small{ display:block; font-size:12px; font-weight:500; opacity:.82; margin-top:2px; }
.mbar__act{ margin-left:auto; display:flex; gap:8px; }
.mbar__ic{ width:34px; height:34px; border-radius:10px; display:grid; place-items:center; background:rgba(255,255,255,.18); font-size:15px; position:relative; }
.mbar__ic .badge{ position:absolute; top:-3px; right:-3px; min-width:16px; height:16px; padding:0 3px; border-radius:99px; background:var(--signal); color:#fff; font-size:9.5px; font-family:var(--mono); display:grid; place-items:center; border:1.5px solid #fff; }

/* 顶栏配色随角色 */
.mhead{ position:absolute; top:0; left:0; right:0; height:158px; z-index:1; }
.mhead.enterprise{ background:linear-gradient(150deg,#1c3157 0%,#2a4a7a 100%); }
.mhead.worker{ background:linear-gradient(150deg,#0c6b52,#0aa89e); }
.mhead.platform{ background:linear-gradient(150deg,#b8531c,#f2611b); }

.mbody{ flex:1; overflow:auto; position:relative; z-index:3; padding:4px 15px 22px; }
.mbody::-webkit-scrollbar{ width:0; }
.mbody--flush{ padding:0; }

/* 底部 Tab */
.tabbar{
  flex:none; height:64px; background:#fff; border-top:1px solid var(--line);
  display:flex; padding:6px 6px env(safe-area-inset-bottom); position:relative; z-index:4;
}
.tabbar__i{ flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px; color:var(--muted-2); font-size:11.5px; }
.tabbar__i .ti{ font-size:20px; line-height:1; }
.tabbar__i.on{ color:var(--signal-700); font-weight:600; }
.tabbar__fab{ flex:1; display:flex; align-items:center; justify-content:center; }
.tabbar__fab b{
  width:50px; height:50px; border-radius:50%; margin-top:-24px; display:grid; place-items:center;
  background:linear-gradient(140deg,var(--signal),#ff8546); color:#fff; font-size:24px; font-weight:300;
  box-shadow:0 8px 18px rgba(242,97,27,.4); border:3px solid #fff;
}

/* —— 桌面壳（PC 后台） —— */
.desktop{ width:min(1200px,100%); }
.win{ background:var(--surface-2); border-radius:14px; overflow:hidden; box-shadow:var(--sh-3); border:1px solid #d7dde7; }
.win__bar{ height:44px; background:#1a2436; display:flex; align-items:center; gap:8px; padding:0 16px; border-bottom:1px solid #0f1726; }
.win__dots{ display:flex; gap:7px; }
.win__dots i{ width:12px; height:12px; border-radius:50%; }
.win__dots i:nth-child(1){ background:#ff5f57; } .win__dots i:nth-child(2){ background:#febc2e; } .win__dots i:nth-child(3){ background:#28c840; }
.win__url{ margin-left:14px; flex:1; max-width:540px; height:26px; border-radius:7px; background:#0f1726; display:flex; align-items:center; padding:0 12px; font-family:var(--mono); font-size:12px; color:#9aa7bd; gap:7px; }
.win__url .lock{ color:var(--track); }
.win__chrome{ margin-left:auto; font-family:var(--mono); font-size:11.5px; color:#7886a0; }
/* 自适应高度：固定高度会被 grid 内容撑破 + 被 .win overflow:hidden 裁掉底部，改 min-height 让窗口随内容增高、整页由外层滚动 */
.pc{ display:grid; grid-template-columns:224px 1fr; min-height:700px; background:var(--surface); }
.pc__side{ background:#16202E; color:#c2cbdb; display:flex; flex-direction:column; padding:14px 0; overflow:auto; }
.pc__brand{ display:flex; align-items:center; gap:9px; padding:6px 16px 16px; }
.pc__brand .l{ width:32px; height:32px; border-radius:9px; background:linear-gradient(140deg,var(--signal),#ff8a4d); flex:none; box-shadow:0 4px 10px rgba(242,97,27,.4); }
.pc__brand b{ color:#fff; font-size:14.5px; } .pc__brand small{ display:block; font-family:var(--mono); font-size:9.5px; letter-spacing:.16em; color:#7886a0; }
.pc__navh{ font-family:var(--mono); font-size:10.5px; letter-spacing:.14em; color:#6f7c95; padding:16px 18px 6px; text-transform:uppercase; }
.pc__nav{ display:flex; align-items:center; gap:11px; padding:10px 18px; font-size:14.5px; color:#c2cbdb; cursor:pointer; border-left:3px solid transparent; }
.pc__nav:hover{ background:#1d2940; color:#fff; }
.pc__nav.on{ background:#202d46; color:#fff; border-left-color:var(--signal); }
.pc__nav .ic{ width:17px; text-align:center; opacity:.85; }
.pc__nav .n{ margin-left:auto; font-family:var(--mono); font-size:10.5px; padding:1px 7px; border-radius:99px; background:#2a3850; color:#9aa6be; }
.pc__main{ display:flex; flex-direction:column; min-width:0; }
.pc__top{ height:58px; flex:none; background:#fff; border-bottom:1px solid var(--line); display:flex; align-items:center; padding:0 24px; gap:14px; }
.pc__top h3{ margin:0; font-size:18px; font-weight:700; }
.pc__top .sub{ font-size:13px; color:var(--muted); }
.pc__search{ margin-left:auto; height:36px; width:260px; border:1px solid var(--line); border-radius:9px; background:var(--surface-2); display:flex; align-items:center; padding:0 12px; gap:8px; color:var(--muted-2); font-size:13px; }
.pc__user{ width:36px; height:36px; border-radius:50%; background:linear-gradient(140deg,#2a4a7a,#1c3157); color:#fff; display:grid; place-items:center; font-size:14px; font-weight:600; }
.pc__content{ flex:1; overflow:auto; padding:24px; background:var(--surface); }
.pc__content::-webkit-scrollbar{ width:10px; } .pc__content::-webkit-scrollbar-thumb{ background:#cdd5e0; border-radius:99px; }

/* ============================================================
   通用组件
   ============================================================ */
.sec{ margin:16px 0; }
.sec__h{ display:flex; align-items:center; gap:8px; margin:0 2px 11px; }
.sec__h b{ font-size:16px; font-weight:700; color:var(--text); }
.sec__h .more{ margin-left:auto; font-size:13px; color:var(--signal-700); font-weight:600; }
.sec__h .cnt{ font-family:var(--mono); font-size:12px; color:var(--muted-2); }

.card{ background:var(--card); border:1px solid var(--line); border-radius:var(--r); box-shadow:var(--sh-1); }
.card--pad{ padding:15px; }
.card + .card{ margin-top:11px; }

/* 状态药丸 */
.pill{ display:inline-flex; align-items:center; gap:5px; height:23px; padding:0 10px; border-radius:99px; font-size:12.5px; font-weight:600; line-height:1; white-space:nowrap; }
.pill .pd{ width:6px; height:6px; border-radius:50%; background:currentColor; }
.pill--ok{ color:var(--ok); background:var(--ok-tint); }
.pill--warn{ color:var(--warn); background:var(--warn-tint); }
.pill--danger{ color:var(--danger); background:var(--danger-tint); }
.pill--track{ color:var(--track-700); background:var(--track-tint); }
.pill--signal{ color:var(--signal-700); background:var(--signal-tint); }
.pill--muted{ color:var(--muted); background:#ECEFF4; }
.pill--ink{ color:#fff; background:var(--ink); }

.tag{ display:inline-flex; align-items:center; height:26px; padding:0 11px; border-radius:8px; font-size:13px; background:var(--surface-2); border:1px solid var(--line); color:var(--muted); }
.tag--on{ background:var(--signal-tint); border-color:#FAD0BC; color:var(--signal-700); font-weight:600; }
.tagrow{ display:flex; flex-wrap:wrap; gap:7px; }

/* 按钮 */
.btn{ display:inline-flex; align-items:center; justify-content:center; gap:6px; height:42px; padding:0 17px; border-radius:11px; font-size:15px; font-weight:600; border:1px solid transparent; background:var(--surface-2); color:var(--text); }
.btn--primary{ background:linear-gradient(135deg,var(--signal),#ff8546); color:#fff; box-shadow:0 6px 14px rgba(242,97,27,.28); }
.btn--dark{ background:var(--ink); color:#fff; }
.btn--ghost{ background:#fff; border-color:var(--line); color:var(--text); }
.btn--track{ background:var(--track); color:#fff; }
.btn--danger{ background:#fff; border-color:#f1bdbe; color:var(--danger); }
.btn--sm{ height:34px; padding:0 13px; font-size:13.5px; border-radius:9px; }
.btn--block{ width:100%; }
.btn:active{ transform:translateY(1px); }
.btnrow{ display:flex; gap:10px; }

/* 履约轨道（紧凑横版，签名元素） */
.track{ display:flex; align-items:flex-start; padding:4px 2px; }
.track__n{ flex:1; text-align:center; position:relative; min-width:0; }
.track__dot{ width:27px; height:27px; border-radius:50%; margin:0 auto 7px; display:grid; place-items:center; font-family:var(--mono); font-size:12.5px; font-weight:700; background:#fff; color:var(--muted-2); border:2px solid var(--line); position:relative; z-index:2; }
.track__n.done .track__dot{ background:var(--track); border-color:var(--track); color:#fff; }
.track__n.now .track__dot{ background:var(--signal); border-color:var(--signal); color:#fff; box-shadow:0 0 0 4px rgba(242,97,27,.14); }
.track__n::before{ content:""; position:absolute; top:12.5px; left:-50%; width:100%; height:2.5px; background:var(--line); z-index:1; }
.track__n:first-child::before{ display:none; }
.track__n.done::before, .track__n.now::before{ background:var(--track); }
.track__t{ font-size:11.5px; color:var(--muted); line-height:1.25; }
.track__n.now .track__t{ color:var(--signal-700); font-weight:600; }

/* 键值 / 资料行 */
.kv{ display:flex; justify-content:space-between; align-items:baseline; padding:9px 0; border-bottom:1px solid var(--line-soft); font-size:14px; }
.kv:last-child{ border-bottom:0; }
.kv .k{ color:var(--muted); }
.kv .v{ font-weight:600; color:var(--text); }

/* 列表行 */
.row{ display:flex; align-items:center; gap:12px; padding:14px 15px; }
.row + .row{ border-top:1px solid var(--line-soft); }
.row__main{ min-width:0; flex:1; }
.row__t{ font-size:15px; font-weight:600; color:var(--text); display:flex; align-items:center; gap:7px; }
.row__s{ font-size:13px; color:var(--muted); margin-top:4px; display:flex; align-items:center; gap:6px; flex-wrap:wrap; }
.row__r{ text-align:right; flex:none; }
.row__r .price{ font-family:var(--mono); font-weight:700; color:var(--signal-700); font-size:16px; }
.row__chev{ color:var(--muted-2); font-size:18px; flex:none; }

/* 头像 */
.av{ width:44px; height:44px; border-radius:12px; flex:none; display:grid; place-items:center; font-weight:600; color:#fff; font-size:16px; background:linear-gradient(140deg,#3a557f,#26405f); position:relative; }
.av--sm{ width:34px; height:34px; border-radius:9px; font-size:13px; }
.av--lg{ width:58px; height:58px; border-radius:16px; font-size:21px; }
.av .ondot{ position:absolute; right:-2px; bottom:-2px; width:13px; height:13px; border-radius:50%; background:var(--ok); border:2.5px solid #fff; }

/* 统计卡 */
.stats{ display:grid; grid-template-columns:repeat(var(--n,3),1fr); gap:11px; }
.stat{ background:var(--card); border:1px solid var(--line); border-radius:12px; padding:13px; box-shadow:var(--sh-1); }
.stat b{ font-family:var(--mono); font-size:23px; font-variant-numeric:tabular-nums; display:block; line-height:1.1; }
.stat small{ font-size:12.5px; color:var(--muted); }
.stat .delta{ font-family:var(--mono); font-size:12px; }
.stat .delta.up{ color:var(--ok); } .stat .delta.down{ color:var(--danger); }

/* 表单字段 */
.field{ margin-bottom:14px; }
.field__l{ font-size:13.5px; color:var(--muted); margin-bottom:7px; display:flex; gap:5px; }
.field__l .req{ color:var(--danger); }
.input, .select, .textarea{ width:100%; border:1px solid var(--line); border-radius:11px; background:#fff; padding:12px 14px; font-size:15px; color:var(--text); font-family:inherit; }
.input::placeholder{ color:var(--muted-2); }
.textarea{ min-height:88px; resize:vertical; }
.faux-input{ width:100%; border:1px solid var(--line); border-radius:11px; background:#fff; padding:12px 14px; font-size:15px; color:var(--text); display:flex; align-items:center; }
.faux-input .ph{ color:var(--muted-2); } .faux-input .chev{ margin-left:auto; color:var(--muted-2); }

/* 照片墙 */
.photos{ display:grid; grid-template-columns:repeat(4,1fr); gap:7px; }
.photo{ aspect-ratio:1; border-radius:10px; background:linear-gradient(140deg,#41597d,#2c4564); position:relative; overflow:hidden; display:grid; place-items:center; color:#9fb0cb; font-size:20px; }
.photo .tstamp{ position:absolute; left:4px; bottom:4px; font-family:var(--mono); font-size:8.5px; color:#e6ecf6; background:rgba(0,0,0,.42); padding:1px 4px; border-radius:4px; }
.photo--add{ background:var(--surface-2); border:1.5px dashed var(--line); color:var(--muted-2); }

/* 信息流 / 跟进时间线 */
.feed{ position:relative; padding-left:6px; }
.feed__i{ position:relative; padding:0 0 17px 22px; border-left:2px solid var(--line); margin-left:6px; }
.feed__i:last-child{ border-left-color:transparent; padding-bottom:2px; }
.feed__i::before{ content:""; position:absolute; left:-7px; top:2px; width:12px; height:12px; border-radius:50%; background:#fff; border:2.5px solid var(--track); }
.feed__i.signal::before{ border-color:var(--signal); }
.feed__i.now::before{ border-color:var(--signal); box-shadow:0 0 0 3px rgba(242,97,27,.14); }
.feed__i.muted::before{ border-color:var(--muted-2); background:var(--muted-2); }
.feed__time{ font-family:var(--mono); font-size:12px; color:var(--muted-2); }
.feed__t{ font-size:14.5px; font-weight:600; color:var(--text); margin:3px 0; }
.feed__d{ font-size:13.5px; color:var(--muted); line-height:1.5; }

/* 横幅 / 提示 */
.banner{ border-radius:var(--r); padding:14px 15px; display:flex; gap:11px; align-items:flex-start; font-size:14px; line-height:1.55; }
.banner .bic{ font-size:18px; flex:none; }
.banner--info{ background:var(--track-tint); color:var(--track-700); }
.banner--warn{ background:var(--warn-tint); color:#8a5d06; }
.banner--signal{ background:var(--signal-tint); color:var(--signal-700); }
.banner b{ color:inherit; }

/* hero 卡（壳内顶部，叠在彩色 head 上） */
.hero{ color:#fff; padding:8px 2px 14px; }
.hero__row{ display:flex; align-items:center; gap:12px; }
.hero__hi{ font-size:14.5px; opacity:.9; } .hero__hi b{ font-weight:700; }
.hero__stat{ display:flex; gap:20px; margin-top:15px; }
.hero__stat div b{ font-family:var(--mono); font-size:22px; display:block; }
.hero__stat div small{ font-size:12px; opacity:.85; }

/* 数据表（PC） */
.table{ width:100%; border-collapse:collapse; font-size:14px; background:#fff; }
.table th{ text-align:left; padding:12px 15px; font-size:12px; letter-spacing:.02em; color:var(--muted); font-weight:600; background:var(--surface-2); border-bottom:1px solid var(--line); white-space:nowrap; }
.table td{ padding:13px 15px; border-bottom:1px solid var(--line-soft); color:var(--text); }
.table tbody tr:hover{ background:var(--surface-2); }
.table .mono{ font-weight:600; }
.table .num{ text-align:right; font-family:var(--mono); font-variant-numeric:tabular-nums; }
.tablewrap{ background:#fff; border:1px solid var(--line); border-radius:var(--r); overflow:hidden; box-shadow:var(--sh-1); }
.tablewrap__h{ display:flex; align-items:center; gap:10px; padding:14px 17px; border-bottom:1px solid var(--line); }
.tablewrap__h b{ font-size:15px; } .tablewrap__h .more{ margin-left:auto; }

/* PC 卡片网格 */
.pcgrid{ display:grid; gap:16px; }
.pcgrid--4{ grid-template-columns:repeat(4,1fr); }
.pcgrid--3{ grid-template-columns:repeat(3,1fr); }
.pcgrid--2{ grid-template-columns:repeat(2,1fr); }
.pccard{ background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:17px; box-shadow:var(--sh-1); }
.pccard__h{ display:flex; align-items:center; gap:9px; margin-bottom:13px; }
.pccard__h b{ font-size:15.5px; } .pccard__h .more{ margin-left:auto; font-size:13px; color:var(--signal-700); }
.kpi b{ font-family:var(--mono); font-size:30px; font-variant-numeric:tabular-nums; display:block; line-height:1.05; }
.kpi small{ color:var(--muted); font-size:13.5px; }
.kpi .ic{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; font-size:20px; float:right; }

/* 进度条 */
.bar{ height:9px; border-radius:99px; background:var(--surface-2); overflow:hidden; }
.bar > i{ display:block; height:100%; border-radius:99px; background:linear-gradient(90deg,var(--signal),#ff8546); }
.bar.track > i{ background:var(--track); }
.bar.ok > i{ background:var(--ok); }

/* 二维码（分销） */
.qr{ width:156px; height:156px; border-radius:14px; background:#fff; padding:10px; box-shadow:var(--sh-1); margin:0 auto;
  background-image:
    linear-gradient(45deg,#16202E 25%,transparent 25%,transparent 75%,#16202E 75%),
    linear-gradient(45deg,#16202E 25%,transparent 25%,transparent 75%,#16202E 75%);
  background-size:17px 17px; background-position:0 0,8.5px 8.5px; background-color:#fff; border:9px solid #fff;
}

/* 空状态 */
.empty{ text-align:center; padding:42px 20px; color:var(--muted-2); }
.empty .ei{ font-size:36px; opacity:.55; } .empty p{ margin:11px 0 0; font-size:14px; }

/* toast */
.toast-wrap{ position:fixed; left:50%; bottom:42px; transform:translateX(-50%); z-index:9999; display:flex; flex-direction:column; gap:8px; align-items:center; }
.toast{ background:var(--ink); color:#fff; padding:13px 20px; border-radius:12px; font-size:14.5px; box-shadow:var(--sh-3); display:flex; align-items:center; gap:9px; animation:toastin .25s ease; max-width:80vw; }
.toast .ti{ font-size:17px; } .toast.ok .ti{ color:#4ade80; } .toast.warn .ti{ color:#fbbf24; }
@keyframes toastin{ from{ opacity:0; transform:translateY(10px); } to{ opacity:1; transform:translateY(0); } }

.spacer{ height:8px; } .grow{ flex:1; }
.muted{ color:var(--muted); } .small{ font-size:13px; }
.divider{ height:1px; background:var(--line-soft); margin:13px 0; }

@media (max-width:1180px){
  .app{ grid-template-columns:256px 1fr; }
  .zones{ grid-template-columns:1fr; }
}
@media (max-width:880px){
  .app{ grid-template-columns:1fr; }
  .rail{ display:none; }
  .device{ gap:18px; } .device__aside{ display:none; }
}
@media (prefers-reduced-motion:reduce){ *{ animation:none!important; transition:none!important; } }
