    :root {
      --bg: #f7f7f7;
      --surface: #ffffff;
      --surface-soft: #f7f7f7;
      --surface-strong: #eef0f3;
      --ink: #0a0b0d;
      --muted: #5b616e;
      --muted-soft: #7c828a;
      --line: #dee1e6;
      --green: #0052ff;
      --green-soft: #eef3ff;
      --teal: #0f766e;
      --amber: #a15c13;
      --amber-soft: #fff4df;
      --red: #b42318;
      --red-soft: #fff0ed;
      --violet: #5f4bb6;
      --blue: #0052ff;
      --success: #05b169;
      --shadow: 0 4px 12px rgba(0, 0, 0, 0.04);
      --mono: "SFMono-Regular", "Roboto Mono", "JetBrains Mono", ui-monospace, monospace;
      font-family: Inter, -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
    }

    * { box-sizing: border-box; }

    body {
      margin: 0;
      background: var(--bg);
      color: var(--ink);
      letter-spacing: 0;
    }

    button, input, select, textarea {
      font: inherit;
    }

    .app {
      min-height: 100vh;
      display: grid;
      grid-template-columns: 236px minmax(0, 1fr);
    }

    .sidebar {
      background: #0a0b0d;
      color: #ffffff;
      padding: 20px 14px;
      display: flex;
      flex-direction: column;
      gap: 18px;
    }

    .brand {
      padding: 10px 10px 14px;
      border-bottom: 1px solid #16181c;
    }

    .brand strong {
      display: block;
      font-size: 18px;
      line-height: 1.3;
    }

    .brand span {
      color: #a8acb3;
      font-size: 12px;
      display: block;
      margin-top: 6px;
    }

    .nav {
      display: grid;
      gap: 6px;
    }

    .nav button {
      width: 100%;
      border: 0;
      background: transparent;
      color: #a8acb3;
      display: flex;
      align-items: center;
      gap: 10px;
      padding: 11px 12px;
      border-radius: 999px;
      cursor: pointer;
      text-align: left;
    }

    .nav button:hover,
    .nav button.active {
      background: #16181c;
      color: #ffffff;
    }

    .nav svg {
      width: 18px;
      height: 18px;
      stroke-width: 2;
      flex: 0 0 auto;
    }

    .sidebar-footer {
      margin-top: auto;
      padding: 12px;
      border: 1px solid rgba(255, 255, 255, 0.13);
      border-radius: 16px;
      color: #a8acb3;
      font-size: 12px;
      line-height: 1.5;
    }

    main {
      min-width: 0;
      display: flex;
      flex-direction: column;
    }

    .topbar {
      min-height: 70px;
      background: rgba(255, 255, 255, 0.94);
      backdrop-filter: blur(16px);
      border-bottom: 1px solid var(--line);
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: 14px 28px;
      position: sticky;
      top: 0;
      z-index: 10;
    }

    .title-block h1 {
      margin: 0;
      font-size: 22px;
      line-height: 1.25;
    }

    .title-block p {
      margin: 5px 0 0;
      color: var(--muted);
      font-size: 13px;
    }

    .top-actions {
      display: flex;
      align-items: center;
      gap: 10px;
      flex-wrap: wrap;
      justify-content: flex-end;
    }

    .btn {
      border: 1px solid var(--line);
      background: var(--surface-strong);
      color: var(--ink);
      min-height: 40px;
      padding: 0 16px;
      border-radius: 999px;
      display: inline-flex;
      align-items: center;
      gap: 8px;
      cursor: pointer;
      white-space: nowrap;
    }

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

    .btn.ghost {
      background: transparent;
    }

    .btn svg {
      width: 16px;
      height: 16px;
    }

    .content {
      padding: 24px 28px 34px;
      display: grid;
      gap: 18px;
    }

    .view { display: none; }
    .view.active { display: grid; gap: 18px; }

    .toolbar,
    .panel,
    .table-wrap,
    .detail-layout > section,
    .form-panel {
      background: var(--surface);
      border: 1px solid var(--line);
      border-radius: 16px;
      box-shadow: var(--shadow);
    }

    .toolbar {
      padding: 14px;
      display: flex;
      gap: 10px;
      align-items: center;
      flex-wrap: wrap;
    }

    .segmented {
      display: inline-grid;
      grid-auto-flow: column;
      border: 1px solid var(--line);
      border-radius: 999px;
      overflow: hidden;
      background: var(--surface-strong);
    }

    .segmented button {
      min-height: 34px;
      border: 0;
      border-right: 1px solid var(--line);
      background: transparent;
      padding: 0 12px;
      cursor: pointer;
      color: var(--muted);
    }

    .segmented button:last-child { border-right: 0; }
    .segmented button.active { background: var(--green-soft); color: var(--green); }

    .field {
      display: grid;
      gap: 6px;
      min-width: 180px;
    }

    .field label {
      color: var(--muted);
      font-size: 12px;
    }

    input, select, textarea {
      border: 1px solid var(--line);
      border-radius: 12px;
      min-height: 44px;
      padding: 10px 14px;
      background: #fff;
      color: var(--ink);
      outline: 0;
      width: 100%;
    }

    table input,
    table select {
      min-height: 34px;
      max-width: 150px;
      border-radius: 8px;
      padding: 7px 10px;
      font-size: 13px;
    }

    textarea {
      min-height: 86px;
      resize: vertical;
    }

    input:focus, select:focus, textarea:focus {
      border-color: var(--green);
      box-shadow: 0 0 0 3px rgba(31, 122, 77, 0.14);
    }

    .calc-output {
      min-height: 44px;
      border: 1px solid var(--line);
      border-radius: 12px;
      padding: 10px 14px;
      background: var(--surface-strong);
      color: var(--ink);
      display: flex;
      align-items: center;
      font-weight: 700;
    }

    .metric-grid {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 14px;
    }

    .metric {
      background: var(--surface);
      border: 1px solid var(--line);
      border-radius: 16px;
      padding: 16px;
      box-shadow: var(--shadow);
      min-height: 118px;
      display: grid;
      align-content: space-between;
      gap: 10px;
    }

    .metric span {
      color: var(--muted);
      font-size: 13px;
    }

    .metric strong {
      font-size: 26px;
      line-height: 1;
      font-family: var(--mono);
    }

    .trend {
      color: var(--blue);
      font-size: 12px;
    }

    .panel {
      padding: 18px;
      display: grid;
      gap: 14px;
    }

    .panel h2 {
      margin: 0;
      font-size: 16px;
    }

    .split {
      display: grid;
      grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
      gap: 18px;
    }

    .status-stack {
      display: grid;
      gap: 10px;
    }

    .status-row {
      display: grid;
      grid-template-columns: 90px minmax(0, 1fr) 42px;
      align-items: center;
      gap: 12px;
      min-height: 32px;
      font-size: 13px;
    }

    .bar {
      height: 10px;
      background: #eef1ec;
      border-radius: 999px;
      overflow: hidden;
    }

    .bar i {
      display: block;
      height: 100%;
      background: var(--green);
      border-radius: inherit;
    }

    .bar.amber i { background: var(--amber); }
    .bar.blue i { background: var(--blue); }
    .bar.violet i { background: var(--violet); }

    .table-wrap {
      overflow-x: auto;
      overflow-y: hidden;
    }

    .order-workspace {
      display: grid;
      grid-template-columns: minmax(320px, 420px) minmax(0, 1fr);
      gap: 18px;
      align-items: start;
    }

    .compact-form {
      position: sticky;
      top: 92px;
    }

    .board-summary {
      display: grid;
      grid-template-columns: repeat(4, minmax(0, 1fr));
      gap: 10px;
    }

    .summary-tile {
      border: 1px solid var(--line);
      background: var(--surface-soft);
      border-radius: 16px;
      padding: 10px;
      min-height: 72px;
    }

    .summary-tile span {
      display: block;
      color: var(--muted);
      font-size: 12px;
      margin-bottom: 8px;
    }

    .summary-tile strong {
      font-size: 20px;
      font-family: var(--mono);
    }

    .kanban {
      display: grid;
      grid-template-columns: repeat(3, minmax(250px, 1fr));
      gap: 12px;
      overflow-x: auto;
      padding-bottom: 4px;
    }

    .lane {
      background: var(--surface-soft);
      border: 1px solid var(--line);
      border-radius: 16px;
      min-height: 430px;
      display: grid;
      grid-template-rows: auto 1fr;
    }

    .lane header {
      padding: 12px;
      display: flex;
      align-items: center;
      justify-content: space-between;
      border-bottom: 1px solid var(--line);
    }

    .lane h3 {
      margin: 0;
      font-size: 14px;
      display: flex;
      align-items: center;
      gap: 8px;
    }

    .lane-count {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: 999px;
      min-width: 28px;
      height: 24px;
      display: inline-grid;
      place-items: center;
      font-size: 12px;
      color: var(--muted);
    }

    .lane-body {
      padding: 10px;
      display: grid;
      gap: 10px;
      align-content: start;
    }

    .order-card {
      background: #fff;
      border: 1px solid var(--line);
      border-radius: 16px;
      padding: 14px;
      display: grid;
      gap: 10px;
      box-shadow: 0 6px 18px rgba(39, 47, 42, 0.06);
    }

    .order-card.alert {
      border-color: #e0b56e;
      box-shadow: 0 0 0 3px rgba(161, 92, 19, 0.08);
    }

    .card-head {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      gap: 10px;
    }

    .card-head strong {
      font-size: 14px;
      display: block;
    }

    .card-head span {
      color: var(--muted);
      font-size: 12px;
      margin-top: 3px;
      display: block;
    }

    .card-money {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 8px;
    }

    .card-money div {
      background: var(--surface-soft);
      border: 1px solid var(--line);
      border-radius: 12px;
      padding: 8px;
    }

    .card-money span {
      display: block;
      color: var(--muted);
      font-size: 11px;
      margin-bottom: 5px;
    }

    .card-money strong {
      font-size: 13px;
      font-family: var(--mono);
    }

    .card-flags {
      display: flex;
      gap: 6px;
      flex-wrap: wrap;
    }

    .card-actions {
      display: grid;
      grid-template-columns: 1fr 36px 36px;
      gap: 8px;
    }

    .icon-btn {
      width: 36px;
      height: 36px;
      border: 1px solid var(--line);
      background: var(--surface-strong);
      border-radius: 999px;
      display: inline-grid;
      place-items: center;
      cursor: pointer;
    }

    .icon-btn svg {
      width: 16px;
      height: 16px;
    }

    .toast {
      position: fixed;
      right: 24px;
      bottom: 24px;
      z-index: 40;
      background: #1f2a24;
      color: #fff;
      border-radius: 8px;
      padding: 12px 14px;
      box-shadow: var(--shadow);
      font-size: 13px;
      opacity: 0;
      transform: translateY(8px);
      pointer-events: none;
      transition: opacity .2s ease, transform .2s ease;
    }

    .toast.show {
      opacity: 1;
      transform: translateY(0);
    }

    .back-row {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      flex-wrap: wrap;
    }

    .modal-backdrop {
      position: fixed;
      inset: 0;
      background: rgba(20, 28, 23, 0.48);
      z-index: 30;
      display: none;
      align-items: center;
      justify-content: center;
      padding: 20px;
    }

    .modal-backdrop.show {
      display: flex;
    }

    .modal {
      width: min(560px, 100%);
      background: #fff;
      border-radius: 16px;
      box-shadow: 0 24px 70px rgba(20, 28, 23, 0.28);
      border: 1px solid var(--line);
      overflow: hidden;
    }

    .modal.wide {
      width: min(980px, 100%);
    }

    .modal header {
      padding: 16px 18px;
      border-bottom: 1px solid var(--line);
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 12px;
    }

    .modal h2 {
      margin: 0;
      font-size: 16px;
    }

    .modal-body {
      padding: 18px;
      display: grid;
      gap: 14px;
    }

    .modal-footer {
      padding: 14px 18px;
      border-top: 1px solid var(--line);
      display: flex;
      gap: 10px;
      justify-content: flex-end;
      flex-wrap: wrap;
    }

    .fake-preview {
      min-height: 150px;
      border: 1px dashed #b9c2ba;
      border-radius: 16px;
      background:
        linear-gradient(135deg, rgba(31, 122, 77, 0.08), rgba(47, 111, 159, 0.08)),
        var(--surface-soft);
      display: grid;
      place-items: center;
      color: var(--muted);
      text-align: center;
      padding: 16px;
    }

    .promo-preview {
      background: #f8fafc;
      border: 1px solid var(--line);
      border-radius: 16px;
      padding: 14px;
      overflow: auto;
    }

    .promo-preview svg {
      display: block;
      width: 100%;
      height: auto;
      border-radius: 12px;
    }

    .promo-spec {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 10px;
    }

    .promo-spec div {
      border: 1px solid var(--line);
      background: var(--surface-soft);
      border-radius: 10px;
      padding: 10px;
      font-size: 12px;
      color: var(--muted);
    }

    .promo-spec strong {
      display: block;
      color: var(--ink);
      font-size: 14px;
      margin-bottom: 4px;
    }

    table {
      border-collapse: collapse;
      width: 100%;
      min-width: 980px;
      font-size: 13px;
    }

    th, td {
      border-bottom: 1px solid var(--line);
      padding: 12px 14px;
      text-align: left;
      vertical-align: middle;
      white-space: nowrap;
    }

    th {
      color: var(--muted);
      font-weight: 600;
      background: var(--surface-soft);
    }

    .order-table td:nth-child(1),
    .order-table td:nth-child(4),
    .order-table td:nth-child(5),
    .order-table td:nth-child(6),
    .order-table td:nth-child(10),
    .order-table td:nth-child(11) {
      font-family: var(--mono);
    }

    .table-actions {
      display: inline-flex;
      gap: 8px;
      align-items: center;
    }

    .text-link {
      border: 0;
      background: transparent;
      color: var(--blue);
      cursor: pointer;
      padding: 0;
      font-weight: 600;
    }

    .filter-grid {
      display: grid;
      grid-template-columns: repeat(5, minmax(150px, 1fr));
      gap: 12px;
      width: 100%;
    }

    tr:last-child td {
      border-bottom: 0;
    }

    .tag {
      display: inline-flex;
      align-items: center;
      justify-content: center;
      min-height: 24px;
      padding: 0 8px;
      border-radius: 999px;
      font-size: 12px;
      border: 1px solid transparent;
    }

    .tag.green { background: #ecfdf5; color: #047857; }
    .tag.amber { background: var(--amber-soft); color: var(--amber); }
    .tag.red { background: var(--red-soft); color: var(--red); }
    .tag.gray { background: #eff1ed; color: var(--muted); }
    .tag.teal { background: #e3f5f2; color: var(--teal); }
    .tag.violet { background: #efedfb; color: var(--violet); }

    .detail-layout {
      display: grid;
      grid-template-columns: minmax(0, 1.15fr) minmax(320px, 0.85fr);
      gap: 18px;
    }

    .detail-layout > section {
      padding: 18px;
      display: grid;
      gap: 16px;
      align-content: start;
    }

    .kv {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 12px;
    }

    .kv div {
      border: 1px solid var(--line);
      border-radius: 12px;
      padding: 10px;
      min-height: 64px;
      background: var(--surface-soft);
    }

    .kv span {
      display: block;
      color: var(--muted);
      font-size: 12px;
      margin-bottom: 7px;
    }

    .kv strong {
      font-size: 15px;
      font-family: var(--mono);
    }

    .timeline {
      display: grid;
      gap: 12px;
      position: relative;
    }

    .step {
      display: grid;
      grid-template-columns: 26px minmax(0, 1fr);
      gap: 10px;
      align-items: start;
    }

    .dot {
      width: 18px;
      height: 18px;
      border-radius: 50%;
      background: var(--green);
      margin-top: 2px;
      box-shadow: 0 0 0 4px var(--green-soft);
    }

    .dot.pending {
      background: var(--amber);
      box-shadow: 0 0 0 4px var(--amber-soft);
    }

    .step strong {
      display: block;
      font-size: 13px;
    }

    .step span {
      color: var(--muted);
      font-size: 12px;
    }

    .form-grid {
      display: grid;
      grid-template-columns: repeat(2, minmax(0, 1fr));
      gap: 14px;
    }

    .form-panel {
      padding: 18px;
      display: grid;
      gap: 14px;
    }

    .span-2 { grid-column: span 2; }

    .upload-zone {
      min-height: 112px;
      border: 1px dashed #b9c2ba;
      border-radius: 8px;
      background: var(--surface-soft);
      display: grid;
      place-items: center;
      color: var(--muted);
      text-align: center;
      padding: 16px;
      font-size: 13px;
      cursor: pointer;
    }

    .finance-grid {
      display: grid;
      grid-template-columns: repeat(3, minmax(0, 1fr));
      gap: 14px;
    }

    .mini-chart {
      height: 170px;
      display: grid;
      grid-template-columns: repeat(7, 1fr);
      gap: 10px;
      align-items: end;
      border: 1px solid var(--line);
      border-radius: 8px;
      padding: 14px;
      background: var(--surface-soft);
    }

    .mini-chart i {
      display: block;
      min-height: 20px;
      background: linear-gradient(180deg, #1f7a4d, #56a377);
      border-radius: 5px 5px 0 0;
    }

    .hint {
      color: var(--muted);
      font-size: 12px;
      line-height: 1.55;
    }

    .mobile-nav {
      display: none;
    }

    @media (max-width: 1020px) {
      .app { grid-template-columns: 1fr; }
      .sidebar { display: none; }
      .mobile-nav {
        display: flex;
        gap: 8px;
        padding: 10px 14px;
        overflow-x: auto;
        background: #1f2a24;
      }
      .mobile-nav button {
        border: 0;
        color: #dce7df;
        background: rgba(255, 255, 255, 0.08);
        min-height: 36px;
        border-radius: 6px;
        padding: 0 12px;
        white-space: nowrap;
      }
      .mobile-nav button.active {
        background: #fff;
        color: #1f2a24;
      }
      .topbar {
        position: static;
        align-items: flex-start;
        gap: 12px;
        flex-direction: column;
        padding: 18px;
      }
      .content { padding: 18px; }
      .metric-grid,
      .finance-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
      }
      .split,
      .detail-layout,
      .order-workspace {
        grid-template-columns: 1fr;
      }
      .compact-form { position: static; }
      .kanban { grid-template-columns: repeat(3, minmax(270px, 1fr)); }
      .filter-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    }

    @media (max-width: 640px) {
      .metric-grid,
      .finance-grid,
      .form-grid,
      .kv,
      .board-summary {
        grid-template-columns: 1fr;
      }
      .span-2 { grid-column: auto; }
      .toolbar { align-items: stretch; }
      .toolbar > * { width: 100%; }
      .segmented { grid-auto-flow: row; }
      .segmented button { border-right: 0; border-bottom: 1px solid var(--line); }
      .segmented button:last-child { border-bottom: 0; }
      .kanban {
        grid-template-columns: 1fr;
        overflow-x: visible;
      }
      .lane {
        min-height: auto;
      }
      .card-actions {
        grid-template-columns: 1fr 40px 40px;
      }
      .filter-grid { grid-template-columns: 1fr; }
      .top-actions {
        width: 100%;
        justify-content: flex-start;
      }
      .promo-spec { grid-template-columns: 1fr; }
    }

/* P1B 补丁 — SPA shell helpers */
.metrics-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 16px; }
.metric-card  { background: var(--surface); padding: 16px; border-radius: 12px; border: 1px solid var(--line); }
.metric-card .label { color: var(--muted); font-size: 13px; }
.metric-card .value { font-size: 28px; font-weight: 600; margin-top: 8px; }
.status-row   { display: flex; align-items: center; gap: 12px; padding: 8px 0; }
.empty-panel  { text-align: center; padding: 64px; color: var(--muted); }
.empty-panel h2 { margin: 0 0 8px; font-size: 18px; }
.loading      { padding: 32px; color: var(--muted); }
.error-panel  { color: var(--red); padding: 16px; border: 1px solid var(--red); border-radius: 8px; margin: 16px 0; }
.modal-backdrop { display: none; position: fixed; inset: 0; background: rgba(0,0,0,.4); align-items: center; justify-content: center; z-index: 100; }
.modal-backdrop.open { display: flex; }
.modal        { background: var(--surface); width: min(640px, 92vw); border-radius: 16px; max-height: 85vh; overflow: auto; }
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--line); }
.modal-body   { padding: 20px; }
.modal-footer { padding: 16px 20px; border-top: 1px solid var(--line); display: flex; justify-content: flex-end; gap: 8px; }
.toast        { position: fixed; bottom: 24px; left: 50%; transform: translateX(-50%); background: var(--ink); color: #fff; padding: 12px 20px; border-radius: 999px; opacity: 0; pointer-events: none; transition: opacity .2s; z-index: 200; }
.toast.visible { opacity: 1; pointer-events: auto; }
.toast.error  { background: var(--red); }
.tag.green    { background: #e8f6ee; color: var(--success); }
.tag.amber    { background: var(--amber-soft); color: var(--amber); }
.tag.blue     { background: var(--green-soft); color: var(--blue); }
.tag.violet   { background: #efe9fb; color: var(--violet); }
.tag.red      { background: var(--red-soft); color: var(--red); }

/* P1B 补丁 — in-progress board */
.in-progress-grid { display: grid; grid-template-columns: 320px 1fr; gap: 18px; align-items: start; }
@media (max-width: 1024px) { .in-progress-grid { grid-template-columns: 1fr; } }

.compact-form .field { margin-bottom: 12px; }
.compact-form label  { display: block; font-size: 13px; color: var(--muted); margin-bottom: 4px; }
.compact-form input, .compact-form textarea { width: 100%; padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px; font: inherit; }
.compact-form .calc-output { background: var(--surface-soft); padding: 8px 10px; border-radius: 8px; color: var(--ink); font-variant-numeric: tabular-nums; }
.compact-form .form-actions { margin-top: 12px; }
.compact-form .form-error { color: var(--red); font-size: 13px; margin: 8px 0 0; }

/* 表单字段错误：input 红边 + 下方红字提示 */
.compact-form input.has-error,
.compact-form textarea.has-error,
.profile-form input.has-error,
.profile-form textarea.has-error,
.address-form input.has-error,
.address-form textarea.has-error,
.address-form select.has-error {
  border-color: var(--red, #d33) !important;
}
.field-error { color: var(--red, #d33); font-size: 12px; margin: 4px 0 0; line-height: 1.4; }

/* 上传位"点选粘贴"功能 — orderDetail / userDetail 共用 */
.paste-tip {
  font-size: 12px;
  color: var(--muted);
  font-weight: 400;
}
.paste-target {
  position: relative;
  cursor: pointer;
  transition: box-shadow .15s ease, border-color .15s ease;
}
.paste-target:hover { box-shadow: 0 0 0 2px var(--accent, #1d8aff)33; }
.paste-target:focus-visible { outline: none; box-shadow: 0 0 0 2px var(--accent, #1d8aff); }
.paste-active { box-shadow: 0 0 0 2px var(--accent, #1d8aff) !important; }
.paste-active::after {
  content: '📋 已选中 — Ctrl+V 粘贴图片';
  position: absolute;
  top: 6px; right: 6px;
  background: var(--accent, #1d8aff);
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 12px;
  z-index: 1;
  pointer-events: none;
}

/* 敏感操作按钮（如"导出完整字段"）：红边 + 红字 + hover 红底白字 */
.btn.warn {
  border-color: var(--red);
  color: var(--red);
  background: var(--surface, #fff);
}
.btn.warn:hover { background: var(--red); color: #fff; }

.lanes-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; }
@media (max-width: 1280px) { .lanes-grid { grid-template-columns: 1fr; } }
.lane { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; padding: 14px; }
.lane > header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.lane > header h3 { margin: 0; font-size: 15px; display: flex; gap: 8px; align-items: center; }
.lane-count { background: var(--surface-soft); border-radius: 999px; padding: 2px 10px; font-size: 12px; color: var(--muted); }
.lane-body { display: flex; flex-direction: column; gap: 10px; max-height: 70vh; overflow: auto; }
.lane-empty { padding: 24px; text-align: center; color: var(--muted); font-size: 13px; }

.order-card { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 12px; padding: 12px; display: flex; flex-direction: column; gap: 8px; }
.order-card header { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.order-card .order-id { font-family: var(--mono); font-size: 11px; color: var(--muted-soft); }
.order-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 4px; font-size: 13px; }
.order-meta.secondary { color: var(--muted); font-size: 12px; }
.order-meta .muted { color: var(--muted); margin-right: 4px; }
.order-amount { font-size: 13px; }
.order-amount .big { font-size: 18px; font-weight: 600; font-variant-numeric: tabular-nums; }
.order-amount .muted { margin-left: 6px; color: var(--muted); }
.order-actions { display: flex; flex-wrap: wrap; gap: 6px; }
.order-actions .btn { font-size: 12px; padding: 6px 10px; min-height: auto; }

/* P1B 补丁 — orders list & detail */
.filters-panel { padding: 12px 16px; }
.filters-row { display: flex; flex-wrap: wrap; gap: 12px; align-items: end; }
.filter { display: flex; flex-direction: column; gap: 4px; min-width: 120px; }
.filter > span { font-size: 12px; color: var(--muted); }
.filter input, .filter select { padding: 6px 10px; border: 1px solid var(--line); border-radius: 8px; font: inherit; min-height: 32px; }
.filter.actions { flex-direction: row; gap: 8px; }

.table-wrap { background: var(--surface); border: 1px solid var(--line); border-radius: 14px; overflow: auto; }
.orders-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.orders-table th, .orders-table td { padding: 10px 12px; border-bottom: 1px solid var(--line); text-align: left; }
.orders-table th { background: var(--surface-soft); font-weight: 600; color: var(--muted); font-size: 12px; text-transform: none; }
.orders-table tr:hover { background: var(--surface-soft); }
.orders-table .num { font-variant-numeric: tabular-nums; text-align: right; }
.orders-table .order-id { font-family: var(--mono); font-size: 11px; color: var(--muted-soft); }
.orders-table .empty-row { text-align: center; color: var(--muted); padding: 32px; }

.pager { display: flex; justify-content: space-between; align-items: center; padding: 8px 12px; }
.pager-info { color: var(--muted); font-size: 13px; }
.pager-controls { display: flex; gap: 6px; align-items: center; }
.pager-controls select { padding: 4px 8px; border: 1px solid var(--line); border-radius: 6px; font: inherit; }

.detail-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 18px; align-items: start; }
@media (max-width: 1024px) { .detail-grid { grid-template-columns: 1fr; } }
.detail-grid .panel { padding: 16px; }
.detail-table { width: 100%; }
.detail-table th { width: 100px; text-align: left; color: var(--muted); padding: 6px 0; font-weight: 500; }
.detail-table td { padding: 6px 0; }

.timeline { list-style: none; margin: 0; padding: 0; }
.timeline li { display: flex; gap: 10px; padding: 6px 0; }
.timeline .dot { width: 10px; height: 10px; border-radius: 50%; background: var(--blue); margin-top: 6px; flex-shrink: 0; }
.timeline strong { display: block; font-size: 13px; }
.timeline time { color: var(--muted); font-size: 12px; }

.attachments-panel { grid-column: 1 / -1; }
.attach-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
@media (max-width: 768px) { .attach-grid { grid-template-columns: 1fr; } }
.attach-slot { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 12px; padding: 12px; }
.attach-slot header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.attach-slot h4 { margin: 0; font-size: 14px; }
.attach-slot img { width: 100%; max-height: 320px; object-fit: contain; border: 1px solid var(--line); border-radius: 8px; background: #fff; }
.attach-slot .attach-empty { padding: 40px; text-align: center; color: var(--muted); border: 1px dashed var(--line); border-radius: 8px; }
.attach-slot footer { margin-top: 8px; display: flex; gap: 6px; }

.actions-panel { grid-column: 1 / -1; }
.actions-row { display: flex; gap: 8px; flex-wrap: wrap; }
.panel-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.panel-header h3 { margin: 0; font-size: 15px; }

.panel-header { padding: 0 0 8px; border-bottom: 1px solid var(--line); margin: 0 -16px 12px; padding: 0 16px 8px; }

/* P1B 补丁 — users list & detail */
.users-table .stars { color: #d28a00; letter-spacing: 1px; }
.users-table .muted { color: var(--muted); }

.profile-form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.profile-form .field { display: flex; flex-direction: column; gap: 4px; }
.profile-form .field.span-2 { grid-column: 1 / -1; }
.profile-form label { font-size: 12px; color: var(--muted); }
.profile-form input, .profile-form textarea { padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px; font: inherit; }
.profile-form input[disabled] { background: var(--surface-soft); color: var(--muted); }
.profile-form .form-actions { grid-column: 1 / -1; display: flex; justify-content: flex-end; }
.profile-form .form-error { grid-column: 1 / -1; color: var(--red); font-size: 13px; margin: 0; }

/* P2B 补丁 — sidebar footer with multiple buttons */
.sidebar-footer { display: flex; flex-direction: column; gap: 8px; align-items: stretch; }
.sidebar-footer button { width: 100%; }

.stats-grid { display: grid; gap: 16px; }
.stats-row { background: var(--surface-soft); border: 1px solid var(--line); border-radius: 10px; padding: 12px; }
.stats-row h4 { margin: 0 0 8px; font-size: 14px; display: flex; gap: 8px; align-items: center; }
.stats-row > div { display: flex; justify-content: space-between; padding: 3px 0; font-size: 13px; }
.stats-row strong { font-variant-numeric: tabular-nums; }

.id-photos-panel { grid-column: 1 / -1; }
.history-panel   { grid-column: 1 / -1; }
.history-panel .table-wrap { margin: 0 -16px; border-radius: 0; border-left: 0; border-right: 0; }
.btn.active-reveal { border-color: var(--amber); color: var(--amber); position: relative; }
.btn.active-reveal::after { content: '·已显示'; margin-left: 6px; font-size: 11px; opacity: .7; }

/* P2B 补丁 — settings sub-tabs */
.subtabs { display: flex; gap: 4px; margin-bottom: 16px; border-bottom: 1px solid var(--line); }
.subtabs button { background: none; border: 0; padding: 10px 16px; cursor: pointer; color: var(--muted); font: inherit; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.subtabs button:hover { color: var(--ink); }
.subtabs button.active { color: var(--ink); border-bottom-color: var(--blue); }

.address-form { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.address-form .field { display: flex; flex-direction: column; gap: 4px; }
.address-form .field.span-2 { grid-column: 1 / -1; }
.address-form label { font-size: 12px; color: var(--muted); }
.address-form input, .address-form select, .address-form textarea {
  padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px; font: inherit;
}
.address-form input[disabled], .address-form select[disabled] { background: var(--surface-soft); color: var(--muted); }
.address-form .form-error { grid-column: 1 / -1; color: var(--red); font-size: 13px; margin: 0; }

.starlevels-table input[type="number"] { padding: 6px 8px; border: 1px solid var(--line); border-radius: 6px; }
.starlevels-table .stars { letter-spacing: 1px; }

/* P4B — finance series axis (date labels under .mini-chart bars) */
.series-axis { display: flex; justify-content: space-between; font-size: 11px; color: var(--muted); padding: 4px 8px 0; }
.series-axis span:nth-child(n+10) { display: none; }

/* P2B 补丁 — accounts + oplog */
.accounts-table .role-admin { color: var(--violet); font-weight: 500; }
.oplog-detail {
  font-family: var(--mono);
  font-size: 11px;
  max-width: 360px;
  max-height: 1.3em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  cursor: pointer;
  color: var(--muted-soft);
}
.oplog-detail.expanded {
  max-height: none;
  white-space: pre-wrap;
  word-break: break-all;
  color: var(--ink);
}
.oplog-detail:empty::before { content: '—'; color: var(--muted); }

/* 顶部 "+ 新建" 按钮在桌面上点击时给表单一次性高亮反馈 */
@keyframes pulseFlash {
  0%   { box-shadow: 0 0 0 0 var(--accent, #1d8aff); }
  60%  { box-shadow: 0 0 0 6px transparent; }
  100% { box-shadow: 0 0 0 0 transparent; }
}
.pulse-flash { animation: pulseFlash 0.6s ease-out 1; border-radius: 12px; }

/* QQ 号可点击复制（format.js qqLink 渲染）— 全局 click delegation 在 app.js */
.qq-copy {
  cursor: pointer;
  text-decoration: underline;
  text-decoration-style: dotted;
  text-decoration-color: rgba(0, 0, 0, 0.3);
  text-underline-offset: 2px;
}
.qq-copy:hover {
  text-decoration-color: var(--accent, #1d8aff);
  color: var(--accent, #1d8aff);
}

/* ──────────────────────────────────────────────────────────────
   Phase 3：v2 进行中订单看板 + 弹窗 + 多图截图
   ────────────────────────────────────────────────────────────── */

/* v2 顶层容器：单列（metric + board），不再 sidebar 表单 */
.in-progress-v2 { display: grid; gap: 18px; }

/* 指标卡（看板顶部 4 个） */
.in-progress-v2 .metric-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.in-progress-v2 .metric {
  background: var(--surface-soft); border: 1px solid var(--line); border-radius: 12px;
  padding: 12px 14px; display: flex; flex-direction: column; gap: 6px;
}
.in-progress-v2 .metric span { color: var(--muted); font-size: 12px; }
.in-progress-v2 .metric strong { font-size: 22px; font-family: var(--mono); line-height: 1; }
@media (max-width: 1024px) {
  .in-progress-v2 .metric-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* 看板：自适应卡片网格 */
.order-board-panel { padding: 14px 16px; }
.order-board {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  align-items: start;
}

/* v2 卡片 — 用 .order-card.v2 区别于旧 .order-card */
.order-card.v2 {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
  display: flex; flex-direction: column; gap: 10px;
  box-shadow: 0 4px 14px rgba(39, 47, 42, 0.055);
}
.order-card.v2 .card-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 8px; padding-bottom: 8px; border-bottom: 1px solid var(--line);
}
.order-card.v2 .card-id { display: block; font-size: 13px; font-family: var(--mono); }
.order-card.v2 .card-sub { display: block; margin-top: 3px; color: var(--muted); font-size: 11px; }

/* 卡片字段网格：单列堆叠（match 原型） */
.order-card.v2 .card-grid {
  display: grid; grid-template-columns: 1fr; gap: 7px;
}

/* 三种 cell：只读 / 可编辑 / 截图 — 共享外观 */
.order-card.v2 .info-cell,
.order-card.v2 .edit-cell,
.order-card.v2 .shot-cell {
  background: var(--surface-soft);
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 8px 9px;
  min-height: 52px;
  display: grid; gap: 4px; align-content: start;
}
.order-card.v2 .info-cell > span,
.order-card.v2 .edit-cell > label,
.order-card.v2 .shot-cell > span:first-child {
  color: var(--muted); font-size: 11px;
}
.order-card.v2 .info-cell > strong {
  font-size: 13px; font-family: var(--mono); line-height: 1.3;
  word-break: break-word;
}
.order-card.v2 .info-cell .note { font-family: inherit; font-weight: 500; }

/* inline 编辑 — input + 确认按钮 */
.order-card.v2 .edit-row {
  display: grid; grid-template-columns: minmax(0, 1fr) auto;
  gap: 6px; align-items: center;
}
.order-card.v2 .edit-row input {
  min-height: 30px; border-radius: 8px;
  padding: 6px 8px; font-size: 12px;
  border: 1px solid var(--line); background: #fff;
}
.order-card.v2 .edit-row input:focus {
  outline: none; border-color: var(--blue);
  box-shadow: 0 0 0 3px rgba(0, 82, 255, 0.12);
}

/* 截图 cell — 按钮 + 状态 tag */
.order-card.v2 .shot-cell > .btn { justify-self: start; }

/* 卡片操作行（放行 + 取消） */
.order-card.v2 .card-actions {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.order-card.v2 .card-actions .btn {
  font-size: 13px; padding: 8px 12px; min-height: 36px;
}

/* btn.small：原型用的小号按钮 */
.btn.small { min-height: 30px; padding: 4px 10px; font-size: 12px; }
.btn.danger {
  color: var(--red);
  background: var(--red-soft);
  border: 1px solid #ffd5cc;
}
.btn.danger:hover { background: var(--red); color: #fff; border-color: var(--red); }

/* 创建订单表单（modal 内） */
.create-form { display: grid; gap: 14px; }
.create-form .field { display: flex; flex-direction: column; gap: 4px; }
.create-form label { font-size: 12px; color: var(--muted); }
.create-form label .muted { color: var(--muted-soft); font-weight: 400; margin-left: 4px; }
.create-form input,
.create-form textarea {
  padding: 8px 10px; border: 1px solid var(--line); border-radius: 8px;
  font: inherit; background: #fff;
}
.create-form textarea { resize: vertical; min-height: 60px; }
.create-form .shots-hint { margin: 4px 0 0; font-size: 12px; }
.create-form .form-error { color: var(--red); font-size: 13px; margin: 0; }

/* 截图弹窗内容 */
.shots-modal-body { display: grid; gap: 12px; }
.shots-count {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 13px;
}
.shots-count strong { font-family: var(--mono); }
.shots-empty {
  border: 1px dashed var(--line); border-radius: 10px;
  padding: 24px; text-align: center; color: var(--muted); font-size: 13px;
}
.shot-thumb-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.shot-thumb {
  position: relative;
  margin: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: 6px;
  display: flex; flex-direction: column; gap: 4px;
}
.shot-thumb img {
  width: 100%; height: 120px; object-fit: contain;
  background: var(--surface-soft); border-radius: 6px;
}
.shot-thumb figcaption { font-size: 11px; }
.shot-thumb .shot-del,
.shot-thumb .detail-shot-del {
  align-self: flex-end;
}
.shots-upload {
  display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center;
  border: 1px dashed var(--line); border-radius: 10px; padding: 10px;
  background: var(--surface-soft);
}
.upload-area input[type=file] {
  display: block; padding: 2px 0; font-size: 13px;
  border: none; background: transparent;
}
.upload-area span { display: block; color: var(--muted); font-size: 12px; margin-top: 4px; }
.shot-err { margin: 0; color: var(--red); font-size: 13px; }

/* 放行二次确认 — summary 网格 */
.release-confirm-body { display: grid; gap: 12px; }
.summary-grid {
  display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px;
}
.summary-grid .summary-item {
  border: 1px solid var(--line); border-radius: 12px;
  background: var(--surface-soft); padding: 10px;
  display: grid; gap: 6px; min-height: 68px;
}
.summary-grid .summary-item.span-2 { grid-column: 1 / -1; }
.summary-grid .summary-item > span { color: var(--muted); font-size: 12px; }
.summary-grid .summary-item > strong {
  font-family: var(--mono); font-size: 15px; line-height: 1.35;
  word-break: break-word;
}
/* 高亮字段：买家账号 / USDT 金额 / RMB 金额 — 蓝色边框 + 大字号 + 加粗 */
.summary-grid .summary-item.highlight {
  background: #eef3ff;
  border-color: var(--blue);
  border-width: 2px;
}
.summary-grid .summary-item.highlight > strong {
  color: var(--blue);
  font-size: 20px;
  font-weight: 800;
}
.summary-grid .summary-item .mono { font-family: var(--mono); }

/* warn-box（取消/放行警告条） */
.warn-box {
  border: 1px solid #fed7aa;
  background: #fff7ed;
  color: #9a3412;
  border-radius: 12px;
  padding: 12px;
  font-size: 14px;
  line-height: 1.55;
}

/* 取消确认 mini-table */
.confirm-mini { width: 100%; border-collapse: collapse; font-size: 13px; }
.confirm-mini th {
  width: 90px; text-align: left; color: var(--muted); padding: 6px 0; font-weight: 500;
}
.confirm-mini td { padding: 6px 0; }

/* 单列响应式 */
@media (max-width: 760px) {
  .summary-grid { grid-template-columns: 1fr; }
  .summary-grid .summary-item.span-2 { grid-column: auto; }
  .order-card.v2 .card-actions { grid-template-columns: 1fr; }
}

