/* 首页科研风密集看板 — 仅作用于 .sci-dash */
.sci-dash {
  margin: -1rem -1.5rem;
  padding: 1rem 1.5rem 1.5rem;
  background: var(--sci-bg);
  color: var(--sci-text);
  font-family: var(--sci-font-family);
  min-height: calc(100vh - 8rem);
}

.sci-dash .sci-grid-kpi {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 10px;
}

@media (max-width: 1024px) {
  .sci-dash .sci-grid-kpi { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 640px) {
  .sci-dash .sci-grid-kpi { grid-template-columns: 1fr; }
}

.sci-dash .sci-grid-2 {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}

@media (max-width: 1024px) {
  .sci-dash .sci-grid-2 { grid-template-columns: 1fr; }
}

.sci-dash .sci-card {
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 4px;
  padding: 12px 14px;
}

.sci-dash .sci-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.sci-dash .sci-title {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sci-muted);
}

.sci-dash .sci-badge {
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--sci-muted);
  border: 1px solid var(--sci-border);
  padding: 2px 6px;
  border-radius: 3px;
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}

.sci-dash .sci-kpi-label {
  font-size: 13px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--sci-muted);
  margin-bottom: 4px;
}

.sci-dash .sci-kpi-value {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  font-size: 1.85rem;
  font-weight: 700;
  line-height: 1.1;
}

.sci-dash .sci-kpi-sub {
  margin-top: 6px;
  font-size: 14px;
  color: var(--sci-muted);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.sci-dash .sci-kpi-sub .delta {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  font-size: 14px;
}

.sci-dash .val-blue { color: var(--sci-blue); }
.sci-dash .val-green { color: var(--sci-green); }
.sci-dash .val-yellow { color: var(--sci-yellow); }
.sci-dash .val-red { color: var(--sci-red); }
.sci-dash .val-purple { color: var(--sci-purple); }

.sci-dash .delta-up { color: var(--sci-green); }
.sci-dash .delta-down { color: var(--sci-red); }

.sci-dash .sci-quick {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}

.sci-dash .sci-quick a {
  font-size: 14px;
  color: var(--sci-blue);
  text-decoration: none;
  border: 1px solid var(--sci-border);
  padding: 3px 8px;
  border-radius: 3px;
}

.sci-dash .sci-quick a:hover {
  background: var(--sci-raised);
}

.sci-dash .sci-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.sci-dash .sci-table th {
  text-align: left;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sci-muted);
  padding: 6px 8px;
  border-bottom: 1px solid var(--sci-border);
  font-weight: 600;
}

.sci-dash .sci-table td {
  padding: 7px 8px;
  border-bottom: 1px solid var(--sci-border);
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}

.sci-dash .sci-table tbody tr:hover {
  background: var(--sci-raised);
}

.sci-dash .sci-table .name-cell {
  font-family: inherit;
  color: var(--sci-text);
}

.sci-dash .status-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  margin-right: 5px;
  vertical-align: middle;
}

.sci-dash .status-normal .status-dot { background: var(--sci-green); }
.sci-dash .status-attention .status-dot { background: var(--sci-yellow); }
.sci-dash .status-overdue .status-dot { background: var(--sci-red); }

.sci-dash .status-normal { color: var(--sci-green); }
.sci-dash .status-attention { color: var(--sci-yellow); }
.sci-dash .status-overdue { color: var(--sci-red); }

.sci-dash .cost-row {
  margin-bottom: 10px;
}

.sci-dash .cost-row:last-child { margin-bottom: 0; }

.sci-dash .cost-meta {
  display: flex;
  justify-content: space-between;
  font-size: 14px;
  margin-bottom: 4px;
}

.sci-dash .cost-meta span:first-child {
  color: var(--sci-text);
  font-size: 13px;
}

.sci-dash .cost-meta span:last-child {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  color: var(--sci-muted);
}

.sci-dash .cost-bar {
  height: 8px;
  background: var(--sci-raised);
  border: 1px solid var(--sci-border);
  border-radius: 2px;
  overflow: hidden;
}

.sci-dash .cost-bar-fill {
  height: 100%;
  border-radius: 1px;
}

.sci-dash .sci-mini-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 10px;
}

.sci-dash .sci-mini {
  border: 1px solid var(--sci-border);
  background: var(--sci-raised);
  padding: 8px;
  border-radius: 3px;
}

.sci-dash .sci-mini .label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--sci-muted);
}

.sci-dash .sci-mini .num {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  font-size: 1.1rem;
  font-weight: 700;
  margin-top: 2px;
}

.sci-dash canvas { max-height: 220px; }

.sci-dash .sci-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 8px;
  font-size: 14px;
  color: var(--sci-muted);
}

.sci-dash .sci-legend i {
  display: inline-block;
  width: 10px;
  height: 10px;
  margin-right: 4px;
  vertical-align: -1px;
}

/* 订单列表等子页：工具栏、按钮、模态框 */
.sci-dash .sci-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.sci-dash .sci-toolbar form {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.sci-dash .sci-input,
.sci-dash .sci-select {
  border: 1px solid var(--sci-border);
  border-radius: 3px;
  padding: 6px 10px;
  font-size: 14px;
  background: var(--sci-surface);
  color: var(--sci-text);
}

.sci-dash .sci-btn {
  font-size: 13px;
  letter-spacing: 0.03em;
  padding: 6px 12px;
  border-radius: 3px;
  border: 1px solid var(--sci-border);
  background: var(--sci-surface);
  color: var(--sci-text);
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}

.sci-dash .sci-btn:hover {
  background: var(--sci-raised);
}

.sci-dash .sci-btn-primary {
  background: var(--sci-blue);
  border-color: var(--sci-blue);
  color: #fff;
}

.sci-dash .sci-btn-primary:hover {
  filter: brightness(0.95);
}

.sci-dash .sci-btn-danger {
  border-color: var(--sci-red);
  color: var(--sci-red);
  background: var(--sci-surface);
}

.sci-dash .sci-btn-danger:hover {
  background: #fff5f5;
}

.sci-dash .sci-btn-link {
  border: none;
  background: none;
  color: var(--sci-blue);
  padding: 0 4px;
}

.sci-dash .sci-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
}

.sci-dash .sci-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 50;
  background: rgba(31, 35, 40, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.sci-dash .sci-modal-backdrop.hidden {
  display: none;
}

.sci-dash .sci-modal {
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 4px;
  width: 100%;
  max-width: 28rem;
  padding: 14px 16px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

.sci-dash .sci-modal-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 12px;
}

.sci-dash .sci-modal-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--sci-text);
}

.sci-dash .sci-modal-sub {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
  font-size: 13px;
  color: var(--sci-blue);
  margin-top: 2px;
}

.sci-dash .sci-modal-close {
  border: none;
  background: none;
  font-size: 1.25rem;
  line-height: 1;
  color: var(--sci-muted);
  cursor: pointer;
}

.sci-dash .sci-modal-hint {
  font-size: 13px;
  color: var(--sci-yellow);
  margin-bottom: 10px;
  padding: 8px;
  border: 1px solid var(--sci-border);
  background: var(--sci-raised);
  border-radius: 3px;
}

.sci-dash .sci-modal textarea {
  width: 100%;
  border: 1px solid var(--sci-border);
  border-radius: 3px;
  padding: 8px 10px;
  font-size: 14px;
  min-height: 4.5rem;
  resize: vertical;
  font-family: inherit;
}

.sci-dash .sci-modal-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}

.sci-dash .order-status-quoting .status-dot,
.sci-dash .order-status-confirmed .status-dot { background: var(--sci-blue); }
.sci-dash .order-status-in_production .status-dot,
.sci-dash .order-status-ready_to_ship .status-dot,
.sci-dash .order-status-partially_shipped .status-dot { background: var(--sci-yellow); }
.sci-dash .order-status-completed .status-dot { background: var(--sci-green); }
.sci-dash .order-status-cancelled .status-dot { background: var(--sci-red); }

.sci-dash .order-status-quoting,
.sci-dash .order-status-confirmed { color: var(--sci-blue); }
.sci-dash .order-status-in_production,
.sci-dash .order-status-ready_to_ship,
.sci-dash .order-status-partially_shipped { color: var(--sci-yellow); }
.sci-dash .order-status-completed { color: var(--sci-green); }
.sci-dash .order-status-cancelled { color: var(--sci-red); }

.sci-dash .task-status-pending_schedule .status-dot,
.sci-dash .task-status-scheduled .status-dot { background: var(--sci-blue); }
.sci-dash .task-status-in_progress .status-dot,
.sci-dash .task-status-in_qc .status-dot,
.sci-dash .task-status-pending_stock_in .status-dot { background: var(--sci-yellow); }
.sci-dash .task-status-completed .status-dot { background: var(--sci-green); }
.sci-dash .task-status-cancelled .status-dot,
.sci-dash .task-status-paused .status-dot { background: var(--sci-red); }

.sci-dash .task-status-pending_schedule,
.sci-dash .task-status-scheduled { color: var(--sci-blue); }
.sci-dash .task-status-in_progress,
.sci-dash .task-status-in_qc,
.sci-dash .task-status-pending_stock_in { color: var(--sci-yellow); }
.sci-dash .task-status-completed { color: var(--sci-green); }
.sci-dash .task-status-cancelled,
.sci-dash .task-status-paused { color: var(--sci-red); }

/* ── 全局应用壳（base.html）──────────────────────── */
.sci-app {
  min-height: 100vh;
  display: flex;
  background: var(--sci-bg);
  color: var(--sci-text);
  font-family: var(--sci-font-family);
}

.sci-app * { box-sizing: border-box; }

.sci-app-sidebar {
  width: 14rem;
  flex-shrink: 0;
  background: var(--sci-surface);
  border-right: 1px solid var(--sci-border);
  display: flex;
  flex-direction: column;
  box-shadow: 2px 0 12px rgba(31, 35, 40, 0.04);
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 40;
  transform: translateX(-100%);
  transition: transform 0.2s;
}

@media (min-width: 1024px) {
  .sci-app-sidebar { position: static; transform: none; }
}

.sci-app-sidebar.open { transform: translateX(0); }

.sci-app-sidebar-head {
  padding: 1rem;
  border-bottom: 1px solid var(--sci-border);
  display: flex;
  justify-content: space-between;
  gap: 0.5rem;
}

.sci-app-sidebar-head h1 { font-size: 1.15rem; font-weight: 700; }
.sci-app-sidebar-head p { font-size: 0.8rem; color: var(--sci-muted); margin-top: 0.2rem; }

.sci-app-nav { flex: 1; overflow-y: auto; padding: 0.5rem 0; }

.sci-app-nav a {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.55rem 1rem;
  font-size: 0.92rem;
  color: var(--sci-text);
  text-decoration: none;
  border-left: 3px solid transparent;
}

.sci-app-nav a:hover { background: var(--sci-raised); }
.sci-app-nav a.active { background: var(--sci-raised); border-left-color: var(--sci-blue); font-weight: 600; }

.sci-app-nav-icon {
  width: 1.4rem;
  height: 1.4rem;
  border-radius: 3px;
  background: var(--sci-raised);
  border: 1px solid var(--sci-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 700;
}

.sci-app-sidebar-foot {
  padding: 0.75rem 1rem;
  border-top: 1px solid var(--sci-border);
  font-size: 0.92rem;
  color: var(--sci-muted);
}

.sci-app-sidebar-foot button {
  margin-top: 0.35rem;
  border: none;
  background: none;
  color: var(--sci-blue);
  cursor: pointer;
  padding: 0;
}

.sci-app-main { flex: 1; min-width: 0; display: flex; flex-direction: column; }

.sci-app-header {
  background: var(--sci-surface);
  border-bottom: 1px solid var(--sci-border);
  padding: 0.65rem 1rem 0.75rem;
  box-shadow: 0 1px 0 rgba(31, 35, 40, 0.04);
}

.sci-app-header-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.65rem;
}

.sci-app-search { flex: 1; min-width: 12rem; max-width: 24rem; }

.sci-app-content { flex: 1; overflow: auto; padding: 1rem 1.25rem 1.5rem; }

/* ── 手机底部 Tab ── */
.sci-mobile-tab-bar {
  display: none;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 45;
  background: var(--sci-surface);
  border-top: 1px solid var(--sci-border);
  padding-bottom: env(safe-area-inset-bottom, 0);
  box-shadow: 0 -2px 10px rgba(31, 35, 40, 0.06);
}
.sci-mobile-tab-bar-inner {
  display: flex;
  align-items: stretch;
  width: 100%;
  max-width: 100vw;
}
.sci-mobile-tab {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 3px;
  min-height: 56px;
  padding: 6px 4px;
  border: none;
  background: none;
  color: var(--sci-muted);
  text-decoration: none;
  font-size: var(--sci-font-xs);
  cursor: pointer;
  font-family: inherit;
}
.sci-mobile-tab.active {
  color: var(--sci-blue);
  font-weight: 600;
}
.sci-mobile-tab-icon {
  width: 1.45rem;
  height: 1.45rem;
  border-radius: var(--sci-radius-sm);
  background: var(--sci-raised);
  border: 1px solid var(--sci-border);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.65rem;
  font-weight: 700;
  line-height: 1;
}
.sci-mobile-tab.active .sci-mobile-tab-icon {
  background: var(--status-active-bg);
  border-color: var(--sci-blue);
  color: var(--sci-blue);
}
.sci-mobile-tab-label {
  line-height: 1.2;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media (max-width: 1023px) {
  .sci-mobile-tab-bar { display: block; }
  .sci-app-content {
    padding-bottom: calc(4.75rem + env(safe-area-inset-bottom, 0));
  }
  #sidebar-open.lg-hide { display: none !important; }
}

/* ── 登录 / 注册页 ── */
.sci-auth-page,
.sci-auth-page *,
.sci-auth-page *::before,
.sci-auth-page *::after {
  box-sizing: border-box;
}

.sci-auth-page {
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--sci-bg);
  color: var(--sci-text);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
}

.sci-auth-layout {
  display: flex;
  min-height: 100vh;
  min-height: 100dvh;
}

.sci-auth-hero {
  position: relative;
  flex: 1 1 48%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 3rem 2.5rem;
  overflow: hidden;
  color: #fff;
}

.sci-auth-hero-bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 80%, rgba(255, 200, 120, 0.18) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 90% 20%, rgba(130, 80, 223, 0.15) 0%, transparent 55%),
    linear-gradient(145deg, #0a3d6b 0%, #0969da 45%, #0550ae 100%);
}

.sci-auth-hero-inner {
  position: relative;
  max-width: 22rem;
}

.sci-auth-logo {
  width: 3.25rem;
  height: 3.25rem;
  margin-bottom: 1.5rem;
  color: rgba(255, 255, 255, 0.92);
}

.sci-auth-logo svg { width: 100%; height: 100%; }

.sci-auth-hero-title {
  font-size: 1.75rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 0.5rem;
  line-height: 1.25;
}

.sci-auth-hero-tagline {
  font-size: 0.95rem;
  color: rgba(255, 255, 255, 0.72);
  margin: 0 0 2rem;
  line-height: 1.5;
}

.sci-auth-features {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.sci-auth-features li {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  font-size: 0.88rem;
  color: rgba(255, 255, 255, 0.82);
}

.sci-auth-features li::before {
  content: "";
  flex-shrink: 0;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(255, 200, 120, 0.9);
  box-shadow: 0 0 8px rgba(255, 200, 120, 0.5);
}

.sci-auth-main {
  flex: 1 1 52%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 2rem 1.5rem;
  background: var(--sci-bg);
}

.sci-auth-card {
  width: 100%;
  max-width: 24rem;
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 12px;
  padding: 2rem 2rem 1.75rem;
  box-shadow:
    0 1px 2px rgba(31, 35, 40, 0.04),
    0 8px 24px rgba(31, 35, 40, 0.07);
}

.sci-auth-card-head {
  margin-bottom: 1.5rem;
}

.sci-auth-heading {
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 0.35rem;
  text-align: left;
}

.sci-auth-lead {
  font-size: var(--sci-font-sm);
  color: var(--sci-muted);
  line-height: 1.5;
  margin: 0;
  text-align: left;
}

.sci-auth-note {
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
  line-height: 1.45;
  margin: 0 0 var(--sci-space-sm);
}

.sci-auth-error {
  color: var(--sci-red);
  font-size: var(--sci-font-sm);
  margin: 0 0 var(--sci-space-md);
}

.sci-auth-msg {
  font-size: var(--sci-font-sm);
  margin: var(--sci-space-md) 0 0;
}

.sci-auth-alert {
  border-radius: 8px;
  padding: 0.65rem 0.85rem;
  font-size: var(--sci-font-sm);
  line-height: 1.45;
  margin-bottom: 1rem;
}

.sci-auth-alert-error {
  background: #ffebe9;
  color: var(--sci-red);
  border: 1px solid #ffcecb;
}

.sci-auth-alert-success {
  background: #dafbe1;
  color: var(--sci-green);
  border: 1px solid #aceebb;
}

.sci-auth-form .sci-field { margin-bottom: 0; }

.sci-auth-form .sci-field label {
  font-size: var(--sci-font-sm);
  font-weight: 500;
  color: var(--sci-text);
  margin-bottom: 0.4rem;
}

.sci-input-wrap {
  display: flex;
  align-items: center;
  width: 100%;
  min-width: 0;
  border: 1px solid var(--sci-border);
  border-radius: 8px;
  background: var(--sci-surface);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.sci-input-wrap:focus-within {
  border-color: var(--sci-blue);
  box-shadow: 0 0 0 3px rgba(9, 105, 218, 0.14);
}

.sci-input-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 2.5rem;
  color: var(--sci-muted);
  pointer-events: none;
}

.sci-input-icon svg {
  width: 1.1rem;
  height: 1.1rem;
  display: block;
}

.sci-auth-page .sci-input-wrap .sci-input.sci-input-iconed {
  flex: 1;
  min-width: 0;
  width: auto;
  max-width: none;
  border: none;
  border-radius: 0;
  padding: 0.65rem 0.85rem 0.65rem 0;
  font-size: 0.92rem;
  background: transparent;
  box-shadow: none;
}

.sci-auth-page .sci-input-wrap .sci-input.sci-input-iconed::placeholder {
  color: #9ca3af;
}

.sci-auth-page .sci-input-wrap .sci-input.sci-input-iconed:focus {
  outline: none;
  border: none;
  box-shadow: none;
}

.sci-auth-page .sci-input-wrap:focus-within .sci-input-icon {
  color: var(--sci-blue);
}

.sci-auth-page .sci-select:focus,
.sci-auth-page .sci-textarea:focus {
  outline: none;
  border-color: var(--sci-blue);
  box-shadow: 0 0 0 3px rgba(9, 105, 218, 0.14);
}

.sci-auth-submit {
  width: 100%;
  min-height: var(--sci-touch-min);
  margin-top: 0.25rem;
  border-radius: 8px;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  transition: background 0.15s, transform 0.1s;
}

.sci-auth-submit:hover {
  background: #0550ae;
  border-color: #0550ae;
}

.sci-auth-submit:active {
  transform: scale(0.985);
}

.sci-auth-footer {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.35rem 0.5rem;
  font-size: var(--sci-font-sm);
  color: var(--sci-muted);
  margin-top: 1.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--sci-border);
}

.sci-auth-footer-sep { opacity: 0.5; }

.sci-auth-copyright {
  margin: 1.25rem 0 0;
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
  opacity: 0.7;
}

.sci-auth-success-icon {
  width: 3.5rem;
  height: 3.5rem;
  margin: 0 auto var(--sci-space-md);
  border-radius: 50%;
  background: rgba(26, 127, 55, 0.12);
  color: var(--sci-green);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.75rem;
  font-weight: 700;
}

.sci-auth-done { text-align: center; }

@media (max-width: 860px) {
  .sci-auth-layout { flex-direction: column; }

  .sci-auth-hero {
    flex: none;
    padding: 2rem 1.5rem 1.75rem;
    min-height: auto;
  }

  .sci-auth-hero-inner {
    max-width: none;
    text-align: center;
  }

  .sci-auth-logo {
    margin-left: auto;
    margin-right: auto;
    width: 2.5rem;
    height: 2.5rem;
    margin-bottom: 1rem;
  }

  .sci-auth-hero-title { font-size: 1.35rem; }

  .sci-auth-hero-tagline { margin-bottom: 0; }

  .sci-auth-features { display: none; }

  .sci-auth-main {
    flex: 1;
    padding: 1.25rem 1rem 2rem;
    justify-content: flex-start;
  }

  .sci-auth-card {
    padding: 1.5rem 1.25rem 1.25rem;
    border-radius: 10px;
  }
}

.sci-link { color: var(--sci-blue); text-decoration: none; }
.sci-link:hover { text-decoration: underline; }
.sci-breadcrumb-sep { color: var(--sci-muted); margin: 0 0.25rem; }

.sci-page-title { font-size: 1.35rem; font-weight: 600; margin-top: 0.35rem; }

.sci-msg {
  border-radius: 3px;
  padding: 0.55rem 0.85rem;
  font-size: 0.92rem;
  margin-bottom: 0.5rem;
  border: 1px solid var(--sci-border);
}

.sci-msg-success { background: #dafbe1; color: var(--sci-green); border-color: #aceebb; }
.sci-msg-error { background: #ffebe9; color: var(--sci-red); border-color: #ffcecb; }
.sci-msg-info { background: #ddf4ff; color: var(--sci-blue); border-color: #b6e3ff; }
.sci-msg-warn {
  background: #fff8c5;
  color: var(--sci-yellow);
  border-color: #d4a72c;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.5rem;
}

.sci-input, .sci-select, .sci-textarea,
.sci-app-search input {
  width: 100%;
  border: 1px solid var(--sci-border);
  border-radius: 3px;
  padding: 6px 10px;
  font-size: 14px;
  background: var(--sci-surface);
  color: var(--sci-text);
}

.sci-textarea { min-height: 4.5rem; resize: vertical; font-family: inherit; }

.sci-btn {
  font-size: 13px;
  padding: 6px 12px;
  border-radius: 3px;
  border: 1px solid var(--sci-border);
  background: var(--sci-surface);
  color: var(--sci-text);
  cursor: pointer;
  text-decoration: none;
  display: inline-block;
}

.sci-btn:hover { background: var(--sci-raised); }
.sci-btn-primary { background: var(--sci-blue); border-color: var(--sci-blue); color: #fff; }
.sci-btn-danger { border-color: var(--sci-red); color: var(--sci-red); }
.sci-btn-link { border: none; background: none; color: var(--sci-blue); padding: 0 4px; }

.sci-card {
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  padding: 14px 16px;
  margin-bottom: 10px;
  box-shadow: 0 1px 3px rgba(31, 35, 40, 0.06);
}

.sci-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

.sci-title {
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sci-muted);
}

.sci-badge {
  font-size: 13px;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--sci-muted);
  border: 1px solid var(--sci-border);
  padding: 2px 6px;
  border-radius: 3px;
}

.sci-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}

.sci-table th {
  text-align: left;
  font-size: 13px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sci-muted);
  padding: 6px 8px;
  border-bottom: 1px solid var(--sci-border);
}

.sci-table td {
  padding: 7px 8px;
  border-bottom: 1px solid var(--sci-border);
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}

.sci-table tbody tr:hover { background: var(--sci-raised); }
.sci-table .text-right { text-align: right; }

.sci-toolbar {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.sci-toolbar form { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }

.sci-grid-2, .sci-grid-3 { display: grid; gap: 10px; margin-bottom: 10px; }
.sci-grid-2 { grid-template-columns: 1.35fr 1fr; }
.sci-grid-3 { grid-template-columns: 2fr 1fr; }

@media (max-width: 1024px) {
  .sci-grid-2, .sci-grid-3 { grid-template-columns: 1fr; }
}

.sci-actions { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.sci-tabs { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 10px; }

.sci-tabs a {
  font-size: 13px;
  padding: 5px 10px;
  border: 1px solid var(--sci-border);
  border-radius: 3px;
  text-decoration: none;
  color: var(--sci-text);
  background: var(--sci-surface);
}

.sci-tabs a.active, .sci-tabs a:hover { background: var(--sci-raised); }

.sci-field { margin-bottom: 0.85rem; }

.sci-field label {
  display: block;
  font-size: 13px;
  font-weight: 600;
  color: var(--sci-muted);
  margin-bottom: 0.3rem;
}

.sci-field .error { color: var(--sci-red); font-size: 14px; margin-top: 0.25rem; }

.sci-pagination { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; font-size: 13px; }

.sci-pagination a, .sci-pagination span {
  padding: 4px 8px;
  border: 1px solid var(--sci-border);
  border-radius: 3px;
  text-decoration: none;
  color: var(--sci-text);
}

.sci-pagination .current { background: var(--sci-raised); font-weight: 600; }

.sci-notif-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.1rem;
  height: 1.1rem;
  padding: 0 0.25rem;
  margin-left: 0.25rem;
  font-size: 0.65rem;
  font-weight: 700;
  color: #fff;
  background: var(--sci-red);
  border-radius: 999px;
}

.sci-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(31, 35, 40, 0.35);
  z-index: 30;
  display: none;
}

.sci-backdrop.show { display: block; }
.sci-hidden { display: none !important; }

.val-blue { color: var(--sci-blue); }
.val-green { color: var(--sci-green); }
.val-yellow { color: var(--sci-yellow); }
.val-red { color: var(--sci-red); }

.hidden { display: none !important; }

/* ── 全局链接规范 ── */
.sci-app a:not([class]) { color: inherit; text-decoration: none; }
.sci-dash a:not([class]) { color: inherit; text-decoration: none; }

.sci-link-weak {
  color: var(--sci-muted);
  text-decoration: none;
  font-size: 14px;
}
.sci-link-weak:hover { color: var(--sci-text); }

.sci-text-blue { color: var(--sci-blue); }

.sci-label {
  font-size: 13px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--sci-muted);
}

.sci-num {
  font-family: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}
.sci-num-blue { color: var(--sci-blue); }
.sci-num-green { color: var(--sci-green); }
.sci-num-red { color: var(--sci-red); }

/* 导入导出工具栏 */
.impex-toolbar { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }

.impex-export-wrap { position: relative; display: inline-block; }

.impex-export-menu {
  display: none;
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  min-width: 12rem;
  z-index: 20;
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  box-shadow: 0 4px 12px rgba(31, 35, 40, 0.12);
  padding: 4px 0;
}

.impex-export-menu.is-open { display: block; }

.impex-export-menu a {
  display: block;
  padding: 6px 12px;
  font-size: 13px;
  color: var(--sci-text);
  text-decoration: none;
}

.impex-export-menu a:hover { background: var(--sci-raised); }

.sci-table .name-cell { font-family: inherit; }
.sci-table tr.row-low { background: #fff8c5; }

/* 可点击的设置/导航卡片 */
a.sci-card {
  text-decoration: none;
  color: inherit;
  display: block;
  transition: border-color 0.15s, box-shadow 0.15s;
}
a.sci-card:hover {
  border-color: var(--sci-blue);
  box-shadow: 0 2px 8px rgba(9, 105, 218, 0.1);
}

/* ── AI 智能录单 ── */
#ai-chat-root {
  display: flex;
  gap: 10px;
  min-height: calc(100vh - 10rem);
}

#ai-session-sidebar {
  width: 14rem;
  flex-shrink: 0;
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(31, 35, 40, 0.06);
}

#ai-session-sidebar.collapsed { width: 0; border: none; box-shadow: none; }

#ai-session-sidebar-head {
  padding: 10px 12px;
  border-bottom: 1px solid var(--sci-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: var(--sci-raised);
}

#ai-session-list {
  flex: 1;
  overflow-y: auto;
  list-style: none;
  margin: 0;
  padding: 6px;
}

.ai-session-item {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  padding: 8px 10px;
  margin-bottom: 2px;
  cursor: pointer;
  border-radius: 4px;
  font-size: 13px;
  color: var(--sci-text);
  border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s;
}

.ai-session-item:hover { background: var(--sci-raised); }

.ai-session-item.active {
  background: rgba(9, 105, 218, 0.08);
  border-color: rgba(9, 105, 218, 0.25);
  font-weight: 600;
}

.ai-session-main {
  flex: 1;
  min-width: 0;
  border: none;
  background: none;
  text-align: left;
  padding: 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
}

.ai-session-item .title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.35;
}

.ai-session-item .meta {
  font-size: 14px;
  color: var(--sci-muted);
  margin-top: 3px;
  font-weight: 400;
}

.ai-session-item .del-btn {
  border: none;
  background: none;
  color: var(--sci-muted);
  cursor: pointer;
  padding: 0 2px;
  font-size: 15px;
  line-height: 1;
  opacity: 0;
  transition: opacity 0.15s, color 0.15s;
}

.ai-session-item:hover .del-btn { opacity: 1; }
.ai-session-item .del-btn:hover { color: var(--sci-red); }

.ai-layout-main {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

#ai-chat-messages {
  flex: 1;
  overflow-y: auto;
  min-height: 280px;
  max-height: 50vh;
}

#ai-preview-panel {
  background: #fff8c5;
  border: 1px solid #d4a72c;
  border-radius: 4px;
  padding: 12px;
  font-size: 14px;
}

#ai-attachment-strip { display: flex; flex-wrap: wrap; gap: 8px; }

#ai-endpoint-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  background: rgba(31, 35, 40, 0.45);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

#ai-endpoint-modal.hidden { display: none; }

#ai-endpoint-modal .sci-card {
  width: 100%;
  max-width: 32rem;
  max-height: 90vh;
  overflow-y: auto;
}

.ai-msg-system { font-size: 14px; color: var(--sci-muted); margin-bottom: 8px; }

.ai-msg-user {
  font-size: 14px;
  margin: 8px 0 8px 2rem;
  padding: 10px 12px;
  background: #ddf4ff;
  border: 1px solid #b6e3ff;
  border-radius: 4px;
  color: var(--sci-text);
}

.ai-msg-assistant {
  font-size: 14px;
  margin: 8px 0;
  padding: 10px 12px;
  background: var(--sci-raised);
  border: 1px solid var(--sci-border);
  border-radius: 4px;
  color: var(--sci-text);
}

.ai-msg-error {
  font-size: 14px;
  margin: 8px 0;
  padding: 10px 12px;
  background: #ffebe9;
  border: 1px solid #ffcecb;
  border-radius: 4px;
  color: var(--sci-red);
}

.ai-attach-thumb {
  position: relative;
  width: 5rem;
  height: 5rem;
  border: 1px solid var(--sci-border);
  border-radius: 4px;
  overflow: hidden;
  background: var(--sci-raised);
}

.ai-attach-thumb img { width: 100%; height: 100%; object-fit: cover; }

.ai-attach-thumb--pending {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  text-align: center;
  padding: 4px;
}

.ai-attach-remove {
  position: absolute;
  top: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  border: none;
  font-size: 13px;
  padding: 0 4px;
  cursor: pointer;
  line-height: 1.4;
}

#ai-endpoint-list { list-style: none; padding: 0; margin: 0; }

.ai-endpoint-empty { padding: 10px; font-size: 14px; color: var(--sci-muted); }

.ai-endpoint-item {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
  padding: 10px;
  border-bottom: 1px solid var(--sci-border);
}

.ai-endpoint-info { min-width: 0; flex: 1; }
.ai-endpoint-info .name { font-weight: 600; font-size: 14px; }
.ai-endpoint-info .detail {
  font-size: 14px;
  color: var(--sci-muted);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.ai-endpoint-actions { display: flex; gap: 4px; flex-shrink: 0; }

#ai-model-bar label { font-size: 13px; color: var(--sci-muted); margin-right: 6px; }

.ai-preview-json {
  margin-top: 6px;
  font-size: 14px;
  background: var(--sci-surface);
  padding: 8px;
  border: 1px solid var(--sci-border);
  border-radius: 4px;
  overflow-x: auto;
}

.ai-msg-img {
  margin-top: 8px;
  max-height: 10rem;
  border-radius: 4px;
  border: 1px solid var(--sci-border);
}

#ai-session-toggle { display: none; }

@media (max-width: 900px) {
  #ai-session-toggle { display: inline-block; }
  #ai-session-sidebar {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    z-index: 35;
    border-radius: 0;
  }
}

/* ── v3 表格横向滚动 ── */
.sci-table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  margin-bottom: 0.5rem;
}

.sci-dash .sci-table,
.sci-table {
  min-width: 600px;
}

nav[aria-label="面包屑"] {
  font-size: 0.88rem;
}

/* 新手引导 — 见 components.css .sci-onboarding-strip */

/* ── 空状态引导卡片 ── */
.sci-empty-guide {
  text-align: center;
  padding: 2.5rem 1.5rem;
  color: var(--sci-muted);
}
.sci-empty-guide-icon { font-size: 2.5rem; margin-bottom: 0.75rem; }
.sci-empty-guide h4 { font-size: 1rem; font-weight: 600; color: var(--sci-text); margin: 0 0 0.4rem; }
.sci-empty-guide p { font-size: 0.85rem; max-width: 28rem; margin: 0 auto 1rem; line-height: 1.55; }
.sci-empty-guide-actions { display: flex; gap: 0.5rem; justify-content: center; flex-wrap: wrap; }

/* ── 订单流程条 ── */
.sci-progress-bar {
  display: flex;
  align-items: flex-start;
  gap: 0;
  padding: 1rem 1rem 0.75rem;
  background: var(--sci-surface, #fff);
  border: 1px solid var(--sci-border, #e5e1d9);
  border-radius: 6px;
  margin-bottom: 1rem;
  overflow-x: auto;
}
.sci-progress-step { flex: 1; text-align: center; min-width: 5rem; position: relative; }
.sci-progress-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  margin: 0 auto 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  background: #e5e1d9;
}
.sci-progress-done .sci-progress-dot { background: #1a7f37; color: #fff; }
.sci-progress-current .sci-progress-dot {
  background: #0969da;
  color: #fff;
  box-shadow: 0 0 0 4px rgba(9,105,218,.15);
}
.sci-progress-cancelled .sci-progress-dot { background: #cf222e; color: #fff; }
.sci-progress-pending .sci-progress-dot { background: #f3f1ec; border: 2px dashed #c5bfb6; }
.sci-progress-label { font-size: 0.78rem; font-weight: 600; color: var(--sci-text, #1f2328); margin-bottom: 2px; }
.sci-progress-sub { font-size: 0.72rem; color: var(--sci-muted, #656d76); }
.sci-progress-done .sci-progress-label { color: #1a7f37; }
.sci-progress-current .sci-progress-label { color: #0969da; }
.sci-progress-cancelled .sci-progress-label { color: #cf222e; }
.sci-progress-line {
  flex: 0 0 2rem;
  height: 2px;
  background: #e5e1d9;
  margin-top: 13px;
}
.sci-progress-line-done { background: #1a7f37; }

/* ── 订单链路追踪时间线 ── */
.sci-trail { padding: 0; }
.sci-trail-item {
  display: flex;
  gap: 0.75rem;
  padding: 0.55rem 0;
  border-bottom: 1px solid var(--sci-border, #e5e1d9);
  font-size: 0.82rem;
}
.sci-trail-item:last-child { border-bottom: none; }
.sci-trail-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #0969da;
  flex-shrink: 0;
  margin-top: 4px;
}
.sci-trail-type { color: var(--sci-muted); width: 5rem; flex-shrink: 0; }
.sci-trail-ref { font-weight: 600; color: var(--sci-blue, #0969da); flex: 1; }
.sci-trail-date { color: var(--sci-muted); flex-shrink: 0; }
.sci-trail-status { flex-shrink: 0; }

/* ── 财务可视化图表区 ── */
.sci-finance-charts {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-bottom: 10px;
}
.sci-finance-charts-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1100px) { .sci-finance-charts-3 { grid-template-columns: 1fr 1fr; } }
@media (max-width: 900px) { .sci-finance-charts, .sci-finance-charts-3 { grid-template-columns: 1fr; } }
.sci-chart-empty {
  text-align: center;
  color: var(--sci-muted, #656d76);
  font-size: 0.85rem;
  padding: 2rem 1rem;
}
.sci-trail-horizontal {
  display: flex;
  gap: 0;
  overflow-x: auto;
  padding: 0.5rem 0 1rem;
}
.sci-trail-h-item {
  flex: 1;
  min-width: 7rem;
  text-align: center;
  position: relative;
  padding: 0 0.5rem;
}
.sci-trail-h-item::after {
  content: '';
  position: absolute;
  top: 14px;
  right: -50%;
  width: 100%;
  height: 2px;
  background: var(--sci-border, #e5e1d9);
  z-index: 0;
}
.sci-trail-h-item:last-child::after { display: none; }
.sci-trail-h-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: #0969da;
  color: #fff;
  font-size: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto 6px;
  position: relative;
  z-index: 1;
}
.sci-trail-h-type { font-size: 0.72rem; color: var(--sci-muted); }
.sci-trail-h-ref { font-size: 0.78rem; font-weight: 600; display: block; margin: 2px 0; }
.sci-trail-h-date { font-size: 0.7rem; color: var(--sci-muted); }
.ai-query-result {
  margin-top: 8px;
  padding: 10px;
  background: var(--sci-raised, #f3f1ec);
  border: 1px solid var(--sci-border, #e5e1d9);
  border-radius: 4px;
  font-size: 0.85rem;
}
.ai-query-table { width: 100%; border-collapse: collapse; margin-top: 6px; font-size: 0.8rem; }
.ai-query-table th, .ai-query-table td { padding: 4px 6px; border-bottom: 1px solid var(--sci-border); text-align: left; }
.ai-query-cards { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 6px; }
.ai-query-card {
  flex: 1;
  min-width: 6rem;
  padding: 8px;
  background: #fff;
  border: 1px solid var(--sci-border);
  border-radius: 4px;
  text-align: center;
}
.ai-query-card .num { font-size: 1.1rem; font-weight: 700; color: #0969da; }
.ai-query-card .lbl { font-size: 0.72rem; color: var(--sci-muted); }

.val-muted { color: var(--sci-muted, #656d76); }
.order-no { font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 1.1rem; font-weight: 700; }
.sci-meta { font-size: 0.82rem; color: var(--sci-muted, #656d76); }

.sci-breadcrumb {
  color: var(--sci-muted);
}

/* ── 跟单工作台 ── */
.sci-workbench {
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  padding: 14px 16px;
  margin-bottom: 12px;
}
.sci-workbench-head {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
}
.sci-workbench-title {
  font-size: 1rem;
  font-weight: 700;
  margin: 0 0 4px;
  color: var(--sci-text);
}
.sci-workbench-sub {
  font-size: 0.82rem;
  color: var(--sci-muted);
  margin: 0;
}
.sci-workbench-head-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.sci-workbench-section {
  margin-bottom: var(--sci-space-md);
}

.sci-workbench-alerts .sci-wb-alert-btn {
  cursor: pointer;
  text-align: left;
  font-family: inherit;
  width: 100%;
}

.sci-wb-filter .sci-filter-field-search {
  flex: 1.5 1 10rem;
  max-width: 14rem;
}

.sci-wb-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sci-space-sm);
  padding: 0.55rem 0.75rem;
  background: var(--sci-raised);
  border: 1px solid var(--sci-border);
  border-bottom: none;
  border-radius: var(--sci-radius-lg) var(--sci-radius-lg) 0 0;
}

.sci-wb-dense-list {
  border: 1px solid var(--sci-border);
  border-radius: 0 0 var(--sci-radius-lg) var(--sci-radius-lg);
  background: var(--sci-surface);
  overflow: hidden;
}

.sci-wb-dense-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--sci-space-md);
  padding: 0.75rem 0.85rem;
  border-bottom: 1px solid var(--sci-border);
  font-size: var(--sci-font-md);
}

.sci-wb-dense-item:last-child { border-bottom: none; }

.sci-wb-dense-item.is-urgent {
  background: var(--status-danger-bg);
  border-left: 3px solid var(--status-danger);
  padding-left: calc(0.85rem - 3px);
}

.sci-wb-dense-main {
  flex: 1;
  min-width: 0;
}

.sci-wb-dense-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 0.35rem 0.5rem;
  margin-bottom: 0.2rem;
}

.sci-wb-dense-no {
  font-family: var(--sci-font-mono);
  font-weight: 600;
  font-size: var(--sci-font-md);
  color: var(--sci-blue);
  text-decoration: none;
}

.sci-wb-dense-no:hover { text-decoration: underline; }

.sci-wb-dense-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}

.sci-wb-dense-customer {
  margin: 0 0 0.2rem;
  font-weight: 600;
  color: var(--sci-text);
}

.sci-wb-dense-product {
  margin: 0 0 0.35rem;
  font-size: var(--sci-font-sm);
  color: var(--sci-text-secondary);
}

.sci-wb-dense-qty {
  font-family: var(--sci-font-mono);
  color: var(--sci-muted);
}

.sci-wb-dense-hint {
  margin: 0.35rem 0 0;
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
}

.sci-wb-dense-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.45rem;
  flex-shrink: 0;
}

.sci-wb-dense-deadline {
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
  white-space: nowrap;
}

.sci-wb-dense-deadline.is-danger {
  color: var(--status-danger);
  font-weight: 600;
}

.sci-wb-dense-deadline.is-warning {
  color: var(--status-warning);
  font-weight: 600;
}

.sci-wb-dense-cta {
  white-space: nowrap;
  font-size: var(--sci-font-xs) !important;
  padding: 0.35rem 0.65rem !important;
  min-height: auto !important;
}

.sci-wb-empty-filter {
  padding: 1.25rem;
  text-align: center;
  font-size: var(--sci-font-sm);
  color: var(--sci-muted);
  border: 1px solid var(--sci-border);
  border-top: none;
  border-radius: 0 0 var(--sci-radius-lg) var(--sci-radius-lg);
  background: var(--sci-surface);
}

.sci-wb-more {
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
  margin: 0.5rem 0 0;
  text-align: center;
}

.sci-wb-empty .sci-empty-guide { padding: 1.5rem 1rem; }

.sci-analytics-fold {
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  background: var(--sci-surface);
  margin-bottom: 10px;
}
.sci-analytics-fold-summary {
  cursor: pointer;
  padding: 10px 14px;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--sci-muted);
  list-style: none;
  user-select: none;
}
.sci-analytics-fold-summary::-webkit-details-marker { display: none; }
.sci-analytics-fold-summary::before {
  content: "▸ ";
  display: inline-block;
  transition: transform 0.15s;
}
.sci-analytics-fold[open] .sci-analytics-fold-summary::before {
  transform: rotate(90deg);
}
.sci-analytics-body {
  padding: 0 10px 10px;
  border-top: 1px solid var(--sci-border);
}

/* ── 订单详情：下一步横幅 + 锚点高亮 ── */
.sci-next-action {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  margin-bottom: 12px;
  background: linear-gradient(135deg, #eef5ff 0%, #f8fbff 100%);
  border: 1px solid #0969da;
  border-radius: 6px;
}
.sci-next-action-icon {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #0969da;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  flex-shrink: 0;
}
.sci-next-action-body { flex: 1; min-width: 10rem; }
.sci-next-action-label {
  font-size: 0.72rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #0969da;
  margin: 0 0 2px;
}
.sci-next-action-title {
  font-size: 0.95rem;
  font-weight: 700;
  margin: 0 0 2px;
  color: var(--sci-text);
}
.sci-next-action-hint {
  font-size: 0.8rem;
  color: var(--sci-muted);
  margin: 0;
}
.sci-next-action-cta { white-space: nowrap; }
.sci-action-target {
  scroll-margin-top: 5rem;
}
.sci-action-highlight {
  outline: 2px solid #0969da;
  outline-offset: 2px;
  box-shadow: 0 0 0 4px rgba(9, 105, 218, 0.12);
  border-radius: 6px;
}

/* ── 订单列表：迷你进度 + 待办列 ── */
.sci-mini-progress {
  display: flex;
  align-items: center;
  gap: 3px;
  min-width: 4.5rem;
}
.sci-mini-progress-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  background: #e5e1d9;
  border: 1px solid #c5bfb6;
}
.sci-mini-progress-dot.is-done {
  background: #1a7f37;
  border-color: #1a7f37;
}
.sci-mini-progress-dot.is-current {
  background: #0969da;
  border-color: #0969da;
  box-shadow: 0 0 0 2px rgba(9, 105, 218, 0.2);
}
.sci-mini-progress-dot.is-cancelled {
  background: #cf222e;
  border-color: #cf222e;
}
.sci-list-action {
  display: inline-block;
  font-size: 0.78rem;
  font-weight: 600;
  text-decoration: none;
  padding: 3px 8px;
  border-radius: 4px;
  border: 1px solid var(--sci-border);
  background: #fff;
  color: var(--sci-blue);
  white-space: nowrap;
}
.sci-list-action:hover {
  background: #eef5ff;
  border-color: #0969da;
}
.sci-list-action-confirm { color: #9a6700; border-color: #d4a72c; }
.sci-list-action-ship { color: #1a7f37; border-color: #1a7f37; }
.sci-list-action-receipt { color: #cf222e; border-color: #cf222e; }

/* ── 列表页双轨 + 通用卡片 ── */
.sci-list-page .sci-list-cards {
  display: flex;
  flex-direction: column;
  gap: var(--sci-space-sm);
  padding: var(--sci-space-sm) 0;
}
.sci-list-card {
  padding: var(--sci-space-md) var(--sci-space-lg);
  border: 1px solid var(--sci-border);
  border-radius: var(--sci-radius-lg);
  background: var(--sci-surface);
}
.sci-list-card.is-urgent {
  border-color: var(--sci-red);
  background: #fff8f8;
}
.sci-list-card.is-low {
  border-color: var(--sci-yellow);
  background: #fff8c5;
}
.sci-list-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--sci-space-sm);
  margin-bottom: 4px;
}
.sci-list-card-title {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: var(--sci-font-lg);
  font-weight: 700;
  color: var(--sci-blue);
  text-decoration: none;
}
a.sci-list-card-title:hover { text-decoration: underline; }
.sci-list-card-sub {
  font-size: var(--sci-font-md);
  font-weight: 600;
  margin: 0 0 var(--sci-space-sm);
}
.sci-list-card-hint {
  font-size: var(--sci-font-sm);
  color: var(--sci-muted);
  margin: 0 0 var(--sci-space-sm);
}
.sci-list-card-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sci-space-sm);
  margin-bottom: var(--sci-space-sm);
}
.sci-list-card-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sci-space-sm);
}
.sci-list-card-foot-left { font-weight: 600; color: var(--sci-blue); }
.sci-list-card-cta {
  flex: 1;
  text-align: center;
  max-width: 12rem;
  min-height: var(--sci-touch-min);
  line-height: 2.4;
}

/* 兼容旧类名 */
.sci-order-cards { display: flex; flex-direction: column; gap: var(--sci-space-sm); }
.sci-order-card { padding: var(--sci-space-md); border: 1px solid var(--sci-border); border-radius: var(--sci-radius-lg); background: #fff; }
.sci-order-card.is-urgent { border-color: var(--sci-red); background: #fff8f8; }
.sci-order-card-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 4px; }
.sci-order-card-customer { font-weight: 600; margin: 0 0 8px; font-size: 0.88rem; }
.sci-order-card-row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.sci-order-card-deadline { font-size: 0.75rem; color: var(--sci-muted); }
.sci-order-card-foot { display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.sci-order-card-cta { flex: 1; text-align: center; min-height: var(--sci-touch-min) !important; max-width: 12rem; }

/* ── 筛选条 / 表单栅格（替代 Tailwind） ── */
.sci-filter-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: var(--sci-space-sm);
  margin-bottom: var(--sci-space-md);
  font-size: var(--sci-font-sm);
}
.sci-filter-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 8rem;
}
.sci-filter-field label {
  font-size: var(--sci-font-xs);
  font-weight: 600;
  color: var(--sci-muted);
}
.sci-form-page { max-width: 48rem; }
.sci-form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sci-space-md);
}
.sci-form-grid .sci-field { margin-bottom: 0; }
@media (min-width: 768px) {
  .sci-form-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sci-form-grid .sci-field-full { grid-column: 1 / -1; }
}
.sci-form-stack { display: flex; flex-direction: column; gap: var(--sci-space-md); }
.sci-form-stack > label {
  font-size: 13px;
  font-weight: 600;
  color: var(--sci-muted);
}
.sci-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--sci-space-sm);
  margin-top: var(--sci-space-lg);
}
.sci-form-line-cards {
  display: flex;
  flex-direction: column;
  gap: var(--sci-space-md);
}
.sci-form-line-card {
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  padding: var(--sci-space-md);
  background: var(--sci-raised);
}
.sci-form-line-card-head {
  font-weight: 600;
  font-size: var(--sci-font-sm);
  margin-bottom: var(--sci-space-sm);
  color: var(--sci-text);
}
.sci-form-line-fields {
  display: flex;
  flex-direction: column;
  gap: var(--sci-space-sm);
}
.sci-form-line-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sci-space-sm);
}
@media (min-width: 768px) {
  .sci-form-line-row { grid-template-columns: 1fr 1fr; }
}
.sci-form-line-meta {
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
}
.sci-form-line-value {
  font-size: var(--sci-font-md);
  font-weight: 600;
}
.sci-form-delete {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--sci-font-sm);
  color: var(--sci-muted);
}
.sci-layout-2col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sci-space-lg);
}
@media (min-width: 1024px) {
  .sci-layout-2col { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
.sci-layout-3col {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sci-space-lg);
}
@media (min-width: 1024px) {
  .sci-layout-3col { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
.sci-kpi-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--sci-space-sm);
}
@media (min-width: 768px) {
  .sci-kpi-strip { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
.sci-chart-canvas { max-height: 16rem; margin-bottom: var(--sci-space-lg); }

/* ── 甘特图 ── */
.sci-gantt-axis {
  display: flex;
  justify-content: space-between;
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
  margin-bottom: var(--sci-space-sm);
  padding-left: 11rem;
}
.sci-gantt-row {
  display: grid;
  grid-template-columns: 10rem 1fr;
  gap: var(--sci-space-sm);
  align-items: center;
  margin-bottom: var(--sci-space-sm);
}
.sci-gantt-label {
  display: flex;
  flex-direction: column;
  gap: 2px;
  font-size: var(--sci-font-sm);
  min-width: 0;
}
.sci-gantt-label .sci-meta {
  font-size: var(--sci-font-xs);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sci-gantt-bar-wrap {
  background: var(--sci-raised);
  border: 1px solid var(--sci-border);
  border-radius: var(--sci-radius-sm);
  height: 1.35rem;
  position: relative;
  overflow: hidden;
}
.sci-gantt-bar {
  position: absolute;
  top: 0;
  height: 100%;
  border-radius: 2px;
  min-width: 4px;
  transition: opacity 0.15s;
}
.sci-gantt-bar-wrap:hover .sci-gantt-bar { opacity: 0.85; }
.sci-gantt-dates {
  grid-column: 1 / -1;
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
  margin: 0;
  padding-left: 0.15rem;
}

/* ── 报表中心卡片 ── */
a.sci-report-card {
  display: block;
  text-decoration: none;
  color: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
}
a.sci-report-card:hover {
  border-color: var(--sci-blue);
  box-shadow: 0 2px 8px rgba(9, 105, 218, 0.12);
}
a.sci-report-card .sci-kpi-value {
  font-size: 1.25rem;
  line-height: 1.2;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sci-card-section-title {
  font-size: var(--sci-font-md);
  font-weight: 700;
  margin: 0 0 var(--sci-space-md);
}
.sci-stack-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: var(--sci-font-sm);
}
.sci-stack-list li {
  padding: var(--sci-space-sm) 0;
  border-bottom: 1px solid var(--sci-border);
}
.sci-stack-list li:last-child { border-bottom: none; }

.sci-mobile-only { display: none; }
.sci-desktop-only { display: block; }

@media (max-width: 768px) {
  .sci-mobile-only { display: block; }
  .sci-desktop-only { display: none !important; }

  .sci-next-action { flex-direction: column; align-items: stretch; }
  .sci-next-action-cta { width: 100%; text-align: center; min-height: 44px; }
  .sci-workbench-head { flex-direction: column; }
  .sci-workbench-head-actions { width: 100%; }
  .sci-workbench-head-actions .sci-btn {
    flex: 1;
    text-align: center;
    min-height: 44px;
  }
  .sci-wb-filter .sci-filter-field {
    flex: 1 1 100%;
    max-width: none;
  }

  .sci-wb-list-head {
    border-radius: var(--sci-radius-lg);
    border-bottom: 1px solid var(--sci-border);
  }

  .sci-wb-mobile-product {
    font-size: 0.82rem;
    color: var(--sci-text-secondary);
    margin: 0 0 6px;
  }

  .sci-wb-mobile-deadline.is-danger { color: var(--status-danger); font-weight: 600; }
  .sci-wb-mobile-deadline.is-warning { color: var(--status-warning); font-weight: 600; }

  .sci-form-actions { flex-direction: column; }
  .sci-form-actions .sci-btn {
    width: 100%;
    text-align: center;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .sci-input, .sci-select, .sci-textarea { min-height: 44px; font-size: 16px; }
  .sci-textarea { min-height: 5rem; }

  .sci-gantt-row { grid-template-columns: 1fr; }
  .sci-gantt-axis { padding-left: 0; }

  .sci-wb-mobile-feed { display: flex; flex-direction: column; gap: 10px; }
  .sci-wb-mobile-card {
    display: block;
    text-decoration: none;
    color: inherit;
    padding: 14px;
    border: 1px solid var(--sci-border);
    border-radius: 8px;
    background: #fff;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
  }
  .sci-wb-mobile-card.is-urgent {
    border-color: #cf222e;
    background: #fff8f8;
  }
  .sci-wb-mobile-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 6px;
    font-size: 0.72rem;
  }
  .sci-wb-mobile-tag {
    padding: 2px 6px;
    border: 1px solid var(--sci-border);
    border-radius: 3px;
    color: var(--sci-muted);
  }
  .sci-wb-mobile-order {
    font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
    font-size: 1rem;
    font-weight: 700;
    color: var(--sci-blue);
    margin: 0 0 4px;
  }
  .sci-wb-mobile-customer {
    font-weight: 600;
    margin: 0 0 4px;
    font-size: 0.9rem;
  }
  .sci-wb-mobile-hint {
    font-size: 0.8rem;
    color: var(--sci-muted);
    margin: 0 0 12px;
    line-height: 1.45;
  }
  .sci-wb-mobile-cta {
    display: block;
    width: 100%;
    text-align: center;
    min-height: 48px !important;
    line-height: 2.2;
    box-sizing: border-box;
  }
  .sci-wb-mobile-more {
    text-align: center;
    font-size: 0.8rem;
    color: var(--sci-muted);
    margin: 4px 0 0;
  }

  .sci-order-cards { display: flex; flex-direction: column; gap: 10px; }
  .sci-order-card {
    padding: 12px 14px;
    border: 1px solid var(--sci-border);
    border-radius: 8px;
    background: #fff;
  }
  .sci-order-card.is-urgent { border-color: #cf222e; background: #fff8f8; }
  .sci-order-card-head {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
  }
  .sci-order-card-customer {
    font-size: 0.88rem;
    font-weight: 600;
    margin: 0 0 8px;
  }
  .sci-order-card-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 8px;
    margin-bottom: 10px;
  }
  .sci-order-card-deadline { font-size: 0.75rem; color: var(--sci-muted); }
  .sci-order-card-foot {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
  }
  .sci-order-card-cta {
    flex: 1;
    text-align: center;
    min-height: 44px !important;
    max-width: 12rem;
  }

  .sci-analytics-fold { display: none; }
  .sci-dash .sci-grid-kpi { grid-template-columns: 1fr 1fr; }
}

/* ── v3 移动端优化（列表页密度见 components.css）── */
@media (max-width: 640px) {
  .sci-dash .sci-toolbar:not(.sci-list-toolbar) {
    flex-direction: column;
    align-items: stretch;
  }

  .sci-dash .sci-toolbar:not(.sci-list-toolbar) form {
    width: 100%;
  }

  .sci-dash .sci-toolbar:not(.sci-list-toolbar) form input,
  .sci-dash .sci-toolbar:not(.sci-list-toolbar) form select {
    flex: 1;
    min-width: 0;
  }

  .sci-dash .sci-toolbar:not(.sci-list-toolbar) .sci-actions {
    width: 100%;
    flex-direction: column;
    gap: 4px;
  }

  .sci-dash .sci-toolbar:not(.sci-list-toolbar) > .sci-btn,
  .sci-dash .sci-toolbar:not(.sci-list-toolbar) .sci-actions .sci-btn {
    flex: 1;
    padding: 10px 12px;
    min-height: 44px;
    text-align: center;
  }

  .sci-card {
    padding: 10px 12px;
  }

  .sci-table th,
  .sci-table td {
    padding: 6px;
  }

  .sci-app-header-row {
    flex-wrap: wrap;
  }

  .sci-app-search {
    min-width: 0;
    flex: 1;
    order: 0;
    max-width: none;
  }

  .sci-app-sidebar {
    width: 100vw;
    max-width: 100vw;
  }

  #ai-chat-root {
    flex-direction: column;
  }

  #ai-session-sidebar {
    width: 100%;
    max-height: 40vh;
    position: relative;
    left: auto;
    top: auto;
    bottom: auto;
  }

  #ai-chat-form textarea {
    min-height: 60px;
  }

  #ai-chat-form .sci-actions {
    flex-direction: row;
    justify-content: flex-end;
    width: auto;
  }

  .impex-toolbar {
    width: 100%;
  }

  .impex-toolbar .sci-btn {
    flex: 1;
  }
}

/* ── 今日必须处理 / 系统任务卡片 ── */
.sci-role-tag {
  display: inline-block;
  margin-right: 0.5rem;
  padding: 0.1rem 0.45rem;
  font-size: 0.72rem;
  font-weight: 600;
  color: #1e40af;
  background: #eff6ff;
  border-radius: 999px;
}
.sci-task-section { margin-bottom: 1rem; }
.sci-task-section-title {
  font-size: 0.88rem;
  font-weight: 600;
  margin: 0 0 0.65rem;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}
.sci-task-section-title.is-danger { color: #b91c1c; }
.sci-task-section-title.is-warning { color: #b45309; }
.sci-task-card-list {
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.sci-task-card {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem 1rem;
  padding: 0.85rem 1rem;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 0.65rem;
}
.sci-task-card.is-urgent {
  border-color: #fecaca;
  background: #fffbfb;
}
.sci-task-card-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem;
}
.sci-task-card-type {
  font-size: 0.72rem;
  font-weight: 600;
  color: #64748b;
  text-transform: uppercase;
  letter-spacing: 0.02em;
}
.sci-task-card-order {
  font-size: 0.92rem;
  font-weight: 600;
  color: #0f172a;
  text-decoration: none;
}
a.sci-task-card-order:hover { color: #2563eb; }
.sci-task-card-customer,
.sci-task-card-reason,
.sci-task-card-suggestion {
  margin: 0.2rem 0 0;
  font-size: 0.82rem;
  color: #475569;
}
.sci-task-card-suggestion { color: #1d4ed8; }
.sci-task-card-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.45rem;
  min-width: 8rem;
}
.sci-task-card-deadline {
  font-size: 0.75rem;
  font-weight: 600;
  color: #64748b;
}
.sci-task-card-deadline.is-danger { color: #b91c1c; }
.sci-task-card-deadline.is-warning { color: #b45309; }
.sci-task-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  justify-content: flex-end;
}
.sci-btn-ghost {
  background: transparent;
  border: 1px solid #e2e8f0;
  color: #64748b;
}
.sci-btn-ghost:hover { background: #f8fafc; }
.sci-task-confirm-form,
.sci-task-dismiss-form { display: inline; margin: 0; }

/* ── 订单作战室 ── */
.sci-war-room-banner {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem 1.5rem;
  padding: 1.1rem 1.25rem;
  margin-bottom: 1rem;
  border-radius: 8px;
  border: 1px solid var(--sci-border);
  background: var(--sci-surface);
  border-left-width: 5px;
}
.sci-war-room-banner-danger { border-left-color: #dc2626; }
.sci-war-room-banner-warning { border-left-color: #d97706; }
.sci-war-room-banner-success { border-left-color: #16a34a; }
.sci-war-room-banner-main { flex: 1; min-width: 14rem; }
.sci-war-room-banner-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 0.5rem;
}
.sci-war-room-order {
  margin: 0;
  font-size: 1.35rem;
  font-weight: 700;
  color: #0969da;
  font-family: ui-monospace, monospace;
}
.sci-war-room-customer {
  margin: 0.15rem 0 0;
  font-size: 0.92rem;
  color: var(--sci-muted);
}
.sci-war-room-banner-score {
  text-align: center;
  flex-shrink: 0;
}
.sci-war-room-score {
  display: block;
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
  font-family: ui-monospace, monospace;
}
.sci-war-room-level {
  display: block;
  font-size: 0.78rem;
  font-weight: 600;
  margin-top: 0.25rem;
}
.sci-war-room-headline {
  margin: 0 0 0.5rem;
  font-size: 1rem;
  font-weight: 600;
}
.sci-war-room-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 0.75rem;
  align-items: center;
  font-size: 0.82rem;
}
.sci-war-room-deadline {
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--sci-raised);
}
.sci-war-room-deadline.is-danger {
  color: #cf222e;
  background: rgba(248, 81, 73, 0.12);
}
.sci-war-room-deadline.is-warning {
  color: #9a6700;
  background: rgba(210, 153, 34, 0.12);
}
.sci-war-room-predictions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  margin-top: 0.5rem;
  font-size: 0.8rem;
  color: var(--sci-muted);
}
.sci-war-room-banner-actions {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.5rem;
  flex-shrink: 0;
}
.sci-btn-lg {
  padding: 0.55rem 1.25rem;
  font-size: 0.92rem;
}
.sci-war-room-cancel-fold summary {
  list-style: none;
  cursor: pointer;
}
.sci-war-room-cancel-fold summary::-webkit-details-marker { display: none; }
.sci-war-room-cancel-form {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 0.5rem;
  align-items: center;
}
.sci-war-room-todos {
  margin-bottom: 1rem;
  padding: 0.85rem 1rem;
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  background: var(--sci-surface);
}
.sci-war-room-todos-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}
.sci-war-room-todos-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
}
.sci-war-room-todo-group { margin-bottom: 0.65rem; }
.sci-war-room-todo-group:last-child { margin-bottom: 0; }
.sci-war-room-todo-group-label {
  margin: 0 0 0.35rem;
  font-size: 0.75rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sci-muted);
}
.sci-war-room-todo-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.sci-war-room-todo-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.5rem 0;
  border-top: 1px solid var(--sci-border);
}
.sci-war-room-todo-item:first-child { border-top: none; }
.sci-war-room-todo-object { font-size: 0.9rem; }
.sci-war-room-todo-type {
  display: block;
  font-size: 0.75rem;
  color: var(--sci-muted);
  margin-top: 0.1rem;
}
.sci-war-room-todo-actions {
  display: flex;
  gap: 0.35rem;
  flex-shrink: 0;
}
.sci-war-room-fold {
  margin-bottom: 0.75rem;
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  background: var(--sci-bg);
}
.sci-war-room-fold-summary {
  padding: 0.65rem 1rem;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--sci-muted);
  cursor: pointer;
  list-style: none;
}
.sci-war-room-fold-summary::-webkit-details-marker { display: none; }
.sci-war-room-fold-body {
  padding: 0 1rem 1rem;
}
.sci-war-room-trail { margin-bottom: 0.75rem; }

/* ── 异常中心 ── */
.sci-exception-center {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.sci-exception-zone {
  border-left: 4px solid #cf222e;
  padding-left: 0.85rem;
}

.sci-exception-filters {
  margin-bottom: 0.5rem;
}

.sci-exception-section {
  margin-bottom: 1rem;
}

.sci-exception-section-title {
  margin: 0 0 0.55rem;
  font-size: 0.88rem;
  font-weight: 600;
}

.sci-exception-section-title.is-danger { color: #cf222e; }
.sci-exception-section-title.is-warning { color: #9a6700; }

.sci-order-risk-card.is-full {
  padding: 1rem 1.1rem;
}

.sci-order-risk-source {
  font-size: 0.68rem;
  padding: 1px 6px;
  border-radius: 3px;
  background: var(--sci-raised);
  color: var(--sci-muted);
}

.sci-order-risk-executions {
  list-style: none;
  margin: 0.45rem 0 0;
  padding: 0;
}

.sci-order-risk-exec-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.35rem 0.65rem;
  padding: 0.3rem 0;
  font-size: 0.82rem;
  border-top: 1px dashed var(--sci-border);
}

.sci-order-risk-exec-row:first-child { border-top: none; }

.sci-order-risk-exec-label {
  font-weight: 600;
}

.sci-order-risk-exec-type {
  color: var(--sci-muted);
  font-size: 0.75rem;
}

.sci-order-risk-exec-actions {
  margin-left: auto;
}

/* ── 执行模块卡（采购 / 生产 / 供应商） ── */
.sci-module-section {
  margin-bottom: 1.25rem;
}

.sci-module-section-secondary .sci-module-section-title {
  color: var(--sci-muted);
  font-size: 0.82rem;
}

.sci-module-section-head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-bottom: 0.65rem;
}

.sci-module-section-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
}

.sci-module-exec-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  margin-bottom: 0.55rem;
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 6px;
}

.sci-module-exec-card.is-urgent {
  border-color: #f85149;
  background: linear-gradient(90deg, rgba(248, 81, 73, 0.05) 0%, var(--sci-surface) 30%);
}

.sci-module-exec-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 0.6rem;
  margin-bottom: 0.3rem;
}

.sci-module-exec-type {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sci-muted);
  border: 1px solid var(--sci-border);
  padding: 1px 5px;
  border-radius: 3px;
}

.sci-module-exec-title {
  font-size: 1rem;
  font-weight: 700;
}

.sci-module-exec-detail {
  font-size: 0.85rem;
  color: var(--sci-muted);
}

.sci-module-exec-impact {
  margin: 0.25rem 0;
  font-size: 0.82rem;
}

.sci-module-exec-impact-label {
  color: var(--sci-muted);
}

.sci-module-exec-meta {
  margin: 0.2rem 0 0;
  font-size: 0.8rem;
  color: var(--sci-muted);
}

.sci-module-exec-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.4rem;
  flex-shrink: 0;
}

.sci-module-exec-deadline {
  font-size: 0.78rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--sci-raised);
}

.sci-module-exec-deadline.is-danger {
  color: #cf222e;
  background: rgba(248, 81, 73, 0.12);
}

.sci-module-exec-deadline.is-warning {
  color: #9a6700;
  background: rgba(210, 153, 34, 0.12);
}

.sci-module-exec-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  justify-content: flex-end;
}

.sci-module-order-group {
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  margin-bottom: 0.65rem;
  overflow: hidden;
  background: var(--sci-surface);
}

.sci-module-order-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.65rem 0.85rem;
  background: var(--sci-raised);
  border-bottom: 1px solid var(--sci-border);
}

.sci-module-order-no {
  font-weight: 700;
  font-size: 0.95rem;
  text-decoration: none;
}

.sci-module-order-customer {
  display: block;
  font-size: 0.8rem;
  color: var(--sci-muted);
}

.sci-module-order-meta {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.sci-module-pr-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sci-module-pr-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.55rem 0.85rem;
  border-top: 1px solid var(--sci-border);
}

.sci-module-pr-row:first-child { border-top: none; }

.sci-module-pr-main {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem 0.55rem;
}

.sci-inv-impact-cell {
  font-size: 0.78rem;
  line-height: 1.45;
  text-align: right;
}

@media (max-width: 640px) {
  .sci-module-exec-card,
  .sci-module-pr-row {
    flex-direction: column;
    align-items: flex-start;
  }
  .sci-module-exec-side { align-items: flex-start; }
}

.sci-order-war-room .sci-order-health {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 1.5rem;
  padding: 1rem 1.15rem;
  margin-bottom: 1rem;
  border-radius: 0.65rem;
  border: 1px solid #e2e8f0;
  background: #fff;
}
.sci-order-health-success { border-left: 4px solid #16a34a; }
.sci-order-health-warning { border-left: 4px solid #d97706; }
.sci-order-health-danger { border-left: 4px solid #dc2626; }
.sci-order-health-main {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem 2rem;
  align-items: flex-start;
}
.sci-order-health-score-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 4.5rem;
}
.sci-order-health-score {
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  font-family: "Roboto Mono", monospace;
}
.sci-order-health-level { font-size: 0.82rem; font-weight: 600; margin-top: 0.25rem; }
.sci-order-health-line {
  margin: 0.15rem 0;
  font-size: 0.82rem;
  color: #475569;
}
.sci-order-health-line span { color: #94a3b8; margin-right: 0.35rem; }
.sci-order-health-factors {
  list-style: none;
  margin: 0;
  padding: 0;
  flex: 1;
  min-width: 12rem;
}
.sci-order-health-factor {
  font-size: 0.82rem;
  padding: 0.25rem 0;
}
.sci-order-health-factor.is-danger { color: #b91c1c; }
.sci-order-health-factor.is-warning { color: #b45309; }
.sci-order-health-action { margin-left: 0.5rem; font-size: 0.78rem; }
.sci-status-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0.5rem;
  margin-bottom: 1rem;
}
@media (max-width: 900px) {
  .sci-status-grid { grid-template-columns: repeat(3, 1fr); }
}
.sci-status-grid-cell {
  padding: 0.65rem 0.5rem;
  text-align: center;
  border-radius: 0.5rem;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  font-size: 0.78rem;
}
.sci-status-grid-cell.is-done { background: #f0fdf4; border-color: #bbf7d0; }
.sci-status-grid-cell.is-active { background: #eff6ff; border-color: #bfdbfe; }
.sci-status-grid-cell.is-blocked { background: #fef2f2; border-color: #fecaca; }
.sci-status-grid-icon { display: block; font-size: 1rem; margin-bottom: 0.2rem; }
.sci-status-grid-label { display: block; font-weight: 600; }
.sci-status-grid-note { display: block; color: #64748b; margin-top: 0.15rem; }
.sci-payment-summary { font-size: 0.88rem; }
.sci-payment-row {
  display: flex;
  justify-content: space-between;
  padding: 0.35rem 0;
  border-bottom: 1px solid #f1f5f9;
}
.sci-payment-progress { margin-top: 0.65rem; }
.sci-search-health {
  font-size: 0.72rem;
  font-weight: 600;
  margin-left: 0.35rem;
  padding: 0.1rem 0.35rem;
  border-radius: 999px;
}
.sci-search-health.is-danger { background: #fee2e2; color: #b91c1c; }
.sci-search-health.is-warning { background: #fef3c7; color: #b45309; }
.sci-search-health.is-success { background: #dcfce7; color: #15803d; }

/* +上传 下拉 */
.sci-create-menu { position: relative; }
.sci-create-dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 0.35rem);
  min-width: 11rem;
  background: #fff;
  border: 1px solid var(--sci-border, #e2e8f0);
  border-radius: 0.5rem;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  z-index: 50;
  padding: 0.35rem 0;
}
.sci-create-item {
  display: block;
  padding: 0.5rem 0.85rem;
  font-size: 0.82rem;
  color: #0f172a;
  text-decoration: none;
}
.sci-create-item:hover { background: #f1f5f9; }

/* 侧边栏专家模式 */
.sci-nav-expert { margin: 0.15rem 0 0.35rem 1rem; }
.sci-nav-expert-summary {
  font-size: 0.72rem;
  color: #64748b;
  cursor: pointer;
  padding: 0.25rem 0;
  list-style: none;
}
.sci-nav-expert-summary::-webkit-details-marker { display: none; }
.sci-nav-expert-link {
  display: block;
  padding: 0.35rem 0.75rem 0.35rem 1.5rem;
  font-size: 0.78rem;
  color: #475569;
  text-decoration: none;
}
.sci-nav-expert-link:hover,
.sci-nav-expert-link.active { color: #2563eb; background: #f8fafc; }

/* 延期归因 */
.sci-delay-report .sci-table td { font-size: 0.82rem; }

/* +上传 下拉 */
.sci-create-menu { position: relative; }
.sci-create-dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 4px);
  min-width: 10rem;
  background: #fff;
  border: 1px solid var(--sci-border, #e2e8f0);
  border-radius: 0.5rem;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.12);
  z-index: 50;
  padding: 0.35rem 0;
}
.sci-create-item {
  display: block;
  padding: 0.45rem 0.85rem;
  font-size: 0.82rem;
  color: #0f172a;
  text-decoration: none;
}
.sci-create-item:hover { background: #f1f5f9; }

/* 侧边栏专家模式 */
.sci-nav-expert { margin: 0.15rem 0 0.35rem 1rem; }
.sci-nav-expert-summary {
  font-size: 0.72rem;
  color: #64748b;
  cursor: pointer;
  list-style: none;
}
.sci-nav-expert-summary::-webkit-details-marker { display: none; }
.sci-nav-expert-link {
  display: block;
  padding: 0.35rem 0.75rem;
  font-size: 0.78rem;
  color: #475569;
  text-decoration: none;
}
.sci-nav-expert-link:hover, .sci-nav-expert-link.active { color: #2563eb; background: #f8fafc; }

/* ── 首页三屏瀑布（决策 / 执行 / 经营） ─────────────────────── */
.sci-home-layout {
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}

/* 桌面首页：经营 KPI 置顶，待办区不再左侧红条强调 */
.sci-dash-desktop .sci-zone-analytics {
  opacity: 1;
  order: -1;
}

.sci-home-analytics-head {
  margin-bottom: 0.75rem;
}

.sci-home-analytics-title {
  margin: 0;
  font-size: 1.15rem;
  font-weight: 700;
  color: var(--sci-text);
}

.sci-dash-desktop .sci-zone-danger {
  border-left: none;
  padding-left: 0;
}

.sci-zone-danger {
  border-left: 4px solid #cf222e;
  padding-left: 0.85rem;
}

.sci-zone-work {
  padding-left: 0.25rem;
}

.sci-zone-analytics {
  opacity: 0.92;
}

.sci-home-danger-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 0.85rem;
}

.sci-home-danger-title {
  font-size: 1.35rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 0 0 0.35rem;
  color: var(--sci-text);
}

.sci-home-danger-icon {
  color: #cf222e;
  margin-right: 0.15rem;
}

.sci-home-danger-sub {
  margin: 0;
  font-size: 0.88rem;
  color: var(--sci-muted);
}

.sci-home-danger-actions {
  display: flex;
  gap: 0.5rem;
  flex-shrink: 0;
}

.sci-order-risk-list {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}

.sci-order-risk-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.85rem 1rem;
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 6px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.sci-order-risk-card.is-must,
.sci-order-risk-card.is-urgent {
  border-color: #f85149;
  background: linear-gradient(90deg, rgba(248, 81, 73, 0.06) 0%, var(--sci-surface) 28%);
}

.sci-order-risk-head {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.45rem 0.65rem;
  margin-bottom: 0.35rem;
}

.sci-order-risk-dot {
  color: #cf222e;
  font-size: 0.75rem;
}

.sci-order-risk-order {
  font-size: 1.05rem;
  font-weight: 700;
  color: #0969da;
  text-decoration: none;
}

.sci-order-risk-order:hover { text-decoration: underline; }

.sci-order-risk-customer {
  font-size: 0.88rem;
  color: var(--sci-muted);
}

.sci-order-risk-health {
  font-size: 0.78rem;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 3px;
  border: 1px solid var(--sci-border);
}

.sci-order-risk-headline {
  margin: 0 0 0.25rem;
  font-size: 0.92rem;
  font-weight: 500;
}

.sci-order-risk-meta {
  margin: 0;
  font-size: 0.82rem;
}

.sci-order-risk-subtasks {
  margin: 0.35rem 0 0;
  padding-left: 1.1rem;
  font-size: 0.8rem;
  color: var(--sci-muted);
}

.sci-order-risk-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.45rem;
  flex-shrink: 0;
}

.sci-order-risk-deadline {
  font-size: 0.78rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  background: var(--sci-raised);
}

.sci-order-risk-deadline.is-danger {
  color: #cf222e;
  background: rgba(248, 81, 73, 0.12);
}

.sci-order-risk-deadline.is-warning {
  color: #9a6700;
  background: rgba(210, 153, 34, 0.12);
}

.sci-order-risk-amount {
  font-size: 0.82rem;
  color: var(--sci-muted);
  font-family: ui-monospace, monospace;
}

.sci-order-risk-actions {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.sci-home-danger-more {
  margin: 0.65rem 0 0;
  font-size: 0.82rem;
  color: var(--sci-muted);
}

.sci-home-work-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 0.65rem;
}

.sci-home-work-title {
  margin: 0;
  font-size: 0.95rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--sci-muted);
}

.sci-home-work-list {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.sci-home-work-card {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 0.7rem 0.85rem;
  background: var(--sci-surface);
  border: 1px solid var(--sci-border);
  border-radius: 4px;
}

.sci-home-work-object {
  display: flex;
  align-items: center;
  gap: 0.45rem;
}

.sci-home-work-type {
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--sci-muted);
  border: 1px solid var(--sci-border);
  padding: 1px 5px;
  border-radius: 3px;
}

.sci-home-work-label {
  font-size: 0.92rem;
}

.sci-home-work-detail,
.sci-home-work-impact,
.sci-home-work-status {
  margin: 0.2rem 0 0;
  font-size: 0.8rem;
  color: var(--sci-muted);
}

.sci-home-work-impact-label {
  color: var(--sci-muted);
}

.sci-home-work-side {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.35rem;
  flex-shrink: 0;
}

.sci-home-work-deadline {
  font-size: 0.75rem;
  font-weight: 600;
}

.sci-home-work-deadline.is-danger { color: #cf222e; }
.sci-home-work-deadline.is-warning { color: #9a6700; }

.sci-btn-sm {
  padding: 0.28rem 0.65rem;
  font-size: 0.78rem;
}

.sci-card-muted {
  background: var(--sci-bg);
  border-color: var(--sci-border);
}

.sci-card-muted .sci-kpi-value {
  font-size: 1.35rem;
}

.sci-grid-kpi-compact {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 900px) {
  .sci-grid-kpi-compact { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 640px) {
  .sci-order-risk-card,
  .sci-home-work-card {
    flex-direction: column;
  }
  .sci-order-risk-side,
  .sci-home-work-side {
    align-items: flex-start;
    width: 100%;
  }
  .sci-order-risk-actions { justify-content: flex-start; }
  .sci-home-danger-head { flex-direction: column; }
  .sci-home-danger-actions { width: 100%; }
}

/* ── PWA / 移动端增强 ── */
.sci-list-card-unread {
  border-left: 3px solid var(--sci-blue);
  background: var(--status-active-bg);
}
.sci-list-card-actions { margin-top: 0.65rem; }
.sci-btn-sm { padding: 0.35rem 0.75rem; font-size: var(--sci-font-xs); }
.sci-btn-block { width: 100%; justify-content: center; text-align: center; }

@media (max-width: 1023px) {
  .sci-mobile-sticky-actions {
    position: fixed;
    left: 0;
    right: 0;
    bottom: calc(3.5rem + env(safe-area-inset-bottom, 0));
    z-index: 44;
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 0.65rem 0.75rem;
    background: var(--sci-surface);
    border-top: 1px solid var(--sci-border);
    box-shadow: 0 -4px 16px rgba(15, 23, 42, 0.08);
  }
  .sci-mobile-sticky-actions form { margin: 0; }
  .sci-task-detail-page .sci-toolbar .sci-actions { display: none; }
  .sci-form-actions-sticky {
    position: sticky;
    bottom: calc(3.5rem + env(safe-area-inset-bottom, 0));
    z-index: 2;
    background: var(--sci-surface);
    padding-top: 0.75rem;
    margin-top: 0.5rem;
    border-top: 1px solid var(--sci-border);
  }
  .sci-form-line-card-highlight {
    outline: 2px solid var(--sci-blue);
    box-shadow: 0 0 0 3px var(--status-active-bg);
  }
  .sci-order-war-room .sci-table-wrap,
  .sci-order-war-room .sci-data-table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .sci-order-war-room .sci-trail-horizontal {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 0.35rem;
  }
  .sci-war-room-banner-actions {
    flex-direction: column;
    align-items: stretch;
  }
  .sci-war-room-banner-actions .sci-btn,
  .sci-war-room-banner-actions form { width: 100%; }
}

/* ── 质检照片 ── */
.sci-qc-photos { margin-top: 0.75rem; }
.sci-qc-photo-actions { margin-bottom: 0.75rem; }
.sci-qc-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(7.5rem, 1fr));
  gap: 0.65rem;
}
.sci-qc-photo-item {
  margin: 0;
  border: 1px solid var(--sci-border);
  border-radius: var(--sci-radius-md);
  overflow: hidden;
  background: var(--sci-raised);
}
.sci-qc-photo-item img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}
.sci-qc-photo-item figcaption {
  padding: 0.35rem 0.45rem;
  font-size: var(--sci-font-xs);
  color: var(--sci-muted);
  line-height: 1.35;
}
.sci-qc-photo-delete {
  padding: 0 0.45rem 0.45rem;
}
