* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: "SF Pro Display", "PingFang SC", "Microsoft YaHei", sans-serif;
  background: #f5f6f8;
  color: #18181b;
}
.hidden { display: none !important; }


.login-wrap {
  position: relative;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  overflow: hidden;
  background:
    linear-gradient(135deg, rgba(15, 23, 42, .76), rgba(15, 23, 42, .52)),
    url('./login-bg.jpg') center/cover no-repeat,
    linear-gradient(135deg, #18181b 0%, #134e4a 55%, #18181b 100%);
}
.login-wrap::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top right, rgba(96, 165, 250, .18), transparent 30%),
    radial-gradient(circle at left bottom, rgba(16, 185, 129, .14), transparent 28%);
  pointer-events: none;
}
.login-card {
  position: relative;
  z-index: 1;
  width: 390px;
  max-width: calc(100vw - 32px);
  background: rgba(255, 255, 255, .94);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(255, 255, 255, .68);
  border-radius: 20px;
  padding: 26px;
  box-shadow: 0 28px 60px rgba(15, 23, 42, .28);
}
.login-card h1 { margin: 0 0 8px; font-size: 26px; }
.login-card p { margin: 0 0 16px; color: #52525b; }
.login-card input {
  width: 100%;
  margin-bottom: 10px;
  padding: 11px 12px;
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  background: #fafafa;
}
.login-card button {
  width: 100%;
  padding: 11px;
  border: none;
  border-radius: 12px;
  background: #10b981;
  color: #052e16;
  font-weight: 700;
  cursor: pointer;
}
.login-card .hint { margin-top: 10px; color: #52525b; font-size: 12px; line-height: 1.6; }

.app { display: flex; min-height: 100vh; }
.sidebar {
  width: 260px;
  background: #09090b;
  color: #a1a1aa;
  padding: 18px 12px;
  display: flex;
  flex-direction: column;
  border-right: 1px solid #27272a;
}
.brand-block { display: flex; align-items: center; gap: 10px; padding: 8px 10px 14px; }
.brand-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: #34d399;
  color: #052e16;
  display: grid;
  place-items: center;
  font-weight: 800;
}
.brand { color: #fff; font-size: 20px; font-weight: 700; letter-spacing: .2px; }

.nav-btn {
  border: none;
  background: transparent;
  color: #a1a1aa;
  text-align: left;
  padding: 11px 14px;
  border-radius: 12px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 9px;
  font-weight: 500;
}
.nav-ico { width: 16px; text-align: center; color: #a1a1aa; }
.nav-btn .dot {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #3f3f46;
}
.nav-btn:hover { background: #18181b; color: #e4e4e7; }
.nav-btn:hover .nav-ico { color: #e4e4e7; }
.nav-btn.active {
  background: #27272a;
  color: #fff;
  box-shadow: inset 0 0 0 1px #3f3f46;
}
.nav-btn.active .dot { background: #34d399; }
.nav-btn.active .nav-ico { color: #34d399; }
.sidebar-footer { margin-top: auto; padding-top: 12px; border-top: 1px solid #27272a; }
.logout-btn { color: #fca5a5; }

.main { flex: 1; min-width: 0; padding: 16px 18px; }
.topbar {
  height: 66px;
  background: rgba(255, 255, 255, .88);
  backdrop-filter: blur(8px);
  border: 1px solid #e4e4e7;
  border-radius: 16px;
  padding: 0 14px;
  margin-bottom: 14px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}
.top-left { display: flex; align-items: center; flex: 1; min-width: 240px; max-width: 520px; }
.search-wrap { width: 100%; }
.search-input {
  width: 100%;
  border: none;
  outline: none;
  border-radius: 999px;
  background: #f4f4f5;
  padding: 10px 14px;
  color: #18181b;
}
.top-right { display: flex; align-items: center; gap: 8px; }
.icon-btn {
  background: #fff;
  border: 1px solid #e4e4e7;
  border-radius: 999px;
  width: 36px;
  height: 36px;
  padding: 0;
}
.avatar {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  background: #e4e4e7;
  color: #27272a;
  display: grid;
  place-items: center;
  font-weight: 700;
}
.topbar input {
  padding: 8px 10px;
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  min-width: 220px;
}
.role {
  display: inline-block;
  background: #f4f4f5;
  color: #52525b;
  border-radius: 999px;
  padding: 3px 9px;
  font-size: 12px;
}

.page {
  display: none;
  background: #fff;
  border: 1px solid #e4e4e7;
  border-radius: 18px;
  padding: 18px;
  box-shadow: 0 8px 20px rgba(0,0,0,.04);
}
.page.active { display: block; }
.page { animation: fadein .16s ease; }
@keyframes fadein { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }
.page h2 { margin: 0; font-size: 24px; letter-spacing: -.3px; }
.page-head { display: flex; justify-content: space-between; align-items: center; gap: 12px; }
.sub { margin: 6px 0 0; color: #52525b; font-size: 14px; }

.actions { display: flex; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.actions input, .actions select {
  padding: 9px 10px;
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  background: #fff;
}
button {
  border: none;
  border-radius: 11px;
  padding: 9px 12px;
  background: #10b981;
  color: #052e16;
  font-weight: 700;
  cursor: pointer;
}
button:hover { filter: brightness(1.03); }
button.danger { background: #ef4444; color: #fff; }
.ghost-btn, .ghost {
  background: #fff;
  color: #27272a;
  border: 1px solid #e4e4e7;
}

#page-case table td {
  vertical-align: top;
}

.case-list-summary {
  margin-bottom: 14px;
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: #fff;
  padding: 12px 14px;
}

.case-list-summary-head {
  margin-bottom: 12px;
}

.case-list-summary-title {
  color: #18181b;
  font-size: 14px;
  font-weight: 700;
}

.case-list-summary-desc {
  margin-top: 4px;
  color: #52525b;
  font-size: 12px;
}

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

.case-list-summary-card {
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  background: #fff;
  padding: 10px 12px;
}

.case-list-summary-card.info {
  background: #eff6ff;
  border-color: #bfdbfe;
}

.case-list-summary-card.warn {
  background: #fffbeb;
  border-color: #fde68a;
}

.case-list-summary-card.success {
  background: #ecfdf5;
  border-color: #bbf7d0;
}

.case-list-summary-card.ghost {
  background: #f8fafc;
  border-color: #e2e8f0;
}

.case-list-summary-label {
  color: #52525b;
  font-size: 12px;
}

.case-list-summary-value {
  margin-top: 6px;
  color: #18181b;
  font-size: 22px;
  font-weight: 800;
  line-height: 1.2;
}

.case-list-summary-note {
  margin-top: 6px;
  color: #475569;
  font-size: 12px;
  line-height: 1.5;
}

.case-list-cell {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.case-list-main {
  color: #18181b;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.5;
}

.case-list-sub {
  color: #52525b;
  font-size: 12px;
  line-height: 1.5;
}

.case-list-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 2px;
}

.case-list-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: 3px 8px;
  font-size: 12px;
  font-weight: 700;
  border: 1px solid transparent;
}

.case-list-tag.info {
  background: #dbeafe;
  border-color: #bfdbfe;
  color: #1d4ed8;
}

.case-list-tag.warn {
  background: #fef3c7;
  border-color: #fde68a;
  color: #92400e;
}

.case-list-tag.danger {
  background: #fee2e2;
  border-color: #fecaca;
  color: #991b1b;
}

.case-list-tag.success {
  background: #dcfce7;
  border-color: #bbf7d0;
  color: #166534;
}

.case-list-tag.ghost {
  background: #f8fafc;
  border-color: #e2e8f0;
  color: #475569;
}

.case-list-note {
  margin-top: 4px;
  color: #475569;
  font-size: 12px;
  line-height: 1.6;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  word-break: break-word;
}

table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  background: #fff;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid #ececf0;
}
.table-card { border-radius: 14px; overflow: hidden; }
thead tr { background: #fafafa; }
th, td {
  border-bottom: 1px solid #ececf0;
  text-align: left;
  padding: 11px 12px;
  font-size: 14px;
}
tbody tr:hover { background: #fafafa; }
tbody tr:last-child td { border-bottom: none; }

.cards {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
}
.card {
  background: #fff;
  border: 1px solid #e4e4e7;
  border-radius: 16px;
  padding: 16px;
}
.card .label { color: #52525b; font-size: 13px; }
.card .value { font-size: 28px; font-weight: 800; margin-top: 8px; letter-spacing: -.3px; }

.dash-panels {
  margin-top: 14px;
  display: grid;
  grid-template-columns: 2fr 1fr;
  gap: 12px;
}
.panel-chart, .panel-alert {
  border: 1px solid #e4e4e7;
  border-radius: 16px;
  padding: 14px;
  background: #fff;
}
.panel-title {
  font-weight: 700;
  color: #27272a;
  margin-bottom: 10px;
}
.chart-bars {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: 8px;
  align-items: end;
  height: 160px;
  background: linear-gradient(to top, #f4f4f5, #fff);
  border-radius: 12px;
  padding: 10px;
}
.chart-bars span {
  display: block;
  border-radius: 8px;
  background: linear-gradient(to top, #10b981, #34d399);
}
.panel-alert {
  background: linear-gradient(150deg, #18181b, #09090b);
  color: #e4e4e7;
}
.panel-alert .panel-title { color: #fff; }
.panel-alert p { color: #a1a1aa; margin: 0 0 12px; font-size: 14px; }
.panel-alert button {
  width: 100%;
  background: #34d399;
  color: #052e16;
}

.todo-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.todo-item {
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  padding: 12px;
  background: #fafafa;
  cursor: pointer;
}

.todo-item:hover {
  background: #f4f4f5;
}

.todo-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.todo-title {
  font-weight: 700;
  color: #18181b;
}

.todo-meta {
  margin-top: 6px;
  color: #52525b;
  font-size: 13px;
}

.todo-badge {
  border-radius: 999px;
  padding: 4px 10px;
  background: #dcfce7;
  color: #166534;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.todo-badge.success {
  background: #dcfce7;
  color: #166534;
}

.todo-badge.warn {
  background: #fef3c7;
  color: #92400e;
}

.todo-badge.info {
  background: #dbeafe;
  color: #1d4ed8;
}

.todo-badge.danger {
  background: #fee2e2;
  color: #991b1b;
}

.case-workspace-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 14px;
}

.case-summary-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 12px;
  margin-bottom: 14px;
}

.case-summary-card {
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  padding: 12px;
  background: #fff;
}

.case-summary-card.warn {
  background: #fffbeb;
  border-color: #fcd34d;
}

.case-summary-card.info {
  background: #eff6ff;
  border-color: #93c5fd;
}

.case-summary-card.danger {
  background: #fef2f2;
  border-color: #fca5a5;
}

.case-summary-card.success {
  background: #ecfdf5;
  border-color: #86efac;
}

.case-summary-label {
  color: #52525b;
  font-size: 12px;
}

.case-summary-value {
  margin-top: 8px;
  font-size: 24px;
  line-height: 1.2;
  font-weight: 800;
  color: #18181b;
  word-break: break-word;
}

.case-summary-desc {
  margin-top: 8px;
  color: #475569;
  font-size: 12px;
  line-height: 1.6;
}

.case-quick-actions {
  margin-bottom: 14px;
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: #fff;
  padding: 12px 14px;
}

.case-quick-actions-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.case-quick-actions-title {
  font-size: 14px;
  font-weight: 700;
  color: #18181b;
}

.case-quick-actions-desc {
  margin-top: 4px;
  color: #52525b;
  font-size: 13px;
  line-height: 1.6;
}

.case-quick-actions-list {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.case-section-nav {
  position: sticky;
  top: 12px;
  z-index: 20;
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-bottom: 14px;
  padding: 10px 12px;
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: rgba(255, 255, 255, .94);
  backdrop-filter: blur(8px);
}

.case-section-btn {
  border: 1px solid #d4d4d8;
  background: #fff;
  color: #334155;
  border-radius: 999px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
}

.case-section-btn.active {
  background: #ecfdf5;
  border-color: #10b981;
  color: #047857;
}

.case-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.case-workspace-back {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.case-workspace-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.case-workspace-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(320px, 0.95fr);
  gap: 16px;
  align-items: start;
}

.case-workspace-main,
.case-workspace-side {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.case-workspace-side {
  position: sticky;
  top: 12px;
  align-self: start;
}

.case-workspace-block {
  max-height: none;
  min-height: 120px;
}

.case-overview-layout {
  display: grid;
  gap: 14px;
}

.case-overview-section {
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: #fff;
  padding: 12px;
}

.case-overview-title {
  font-size: 14px;
  font-weight: 700;
  color: #18181b;
  margin-bottom: 10px;
}

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

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

.case-kv-item {
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  padding: 10px 12px;
  background: #fff;
}

.case-kv-item-wide {
  grid-column: span 2;
}

.case-kv-label {
  color: #52525b;
  font-size: 12px;
  margin-bottom: 4px;
}

.case-kv-value {
  color: #18181b;
  font-size: 14px;
  font-weight: 600;
  word-break: break-all;
}

.case-kv-value-emphasis {
  color: #047857;
}

.case-inline-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.case-inline-row {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}

.case-inline-form input,
.case-inline-form select,
.case-inline-form textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #d4d4d8;
  border-radius: 10px;
  background: #fff;
  font: inherit;
}

.case-inline-form textarea {
  min-height: 88px;
  resize: vertical;
}

.case-step-overview {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.case-step-summary-card {
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: #fff;
  padding: 12px;
}

.case-step-summary-card.info {
  background: #eff6ff;
  border-color: #93c5fd;
}

.case-step-summary-card.warn {
  background: #fffbeb;
  border-color: #fcd34d;
}

.case-step-summary-card.success {
  background: #ecfdf5;
  border-color: #86efac;
}

.case-step-summary-label {
  color: #52525b;
  font-size: 12px;
}

.case-step-summary-value {
  margin-top: 8px;
  color: #18181b;
  font-size: 20px;
  font-weight: 800;
  line-height: 1.3;
  word-break: break-word;
}

.case-step-summary-desc {
  margin-top: 8px;
  color: #475569;
  font-size: 12px;
  line-height: 1.6;
}

.case-step-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: #ffffff;
  padding: 12px;
}

.case-step-group.info {
  border-color: #93c5fd;
  background: #f8fbff;
}

.case-step-group.warn {
  border-color: #fcd34d;
  background: #fffbeb;
}

.case-step-group.success {
  border-color: #86efac;
  background: #f4fff8;
}

.case-step-group + .case-step-group {
  margin-top: 14px;
}

.case-step-group-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 4px 2px;
}

.case-step-group-title {
  font-size: 15px;
  font-weight: 700;
  color: #18181b;
}

.case-step-group-desc {
  margin-top: 4px;
  color: #52525b;
  font-size: 12px;
  line-height: 1.5;
}

.case-step-group-badge {
  white-space: nowrap;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
}

.case-step-group-badge.info {
  background: #dbeafe;
  color: #1d4ed8;
}

.case-step-group-badge.warn {
  background: #fef3c7;
  color: #92400e;
}

.case-step-group-badge.success {
  background: #dcfce7;
  color: #166534;
}

.case-step-group-list {
  display: grid;
  gap: 10px;
}

.case-step-card,
.case-material-card {
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  background: #fff;
  padding: 12px;
}

.case-step-card.info {
  border-color: #bfdbfe;
}

.case-step-card.warn {
  border-color: #fde68a;
}

.case-step-card.success {
  border-color: #bbf7d0;
}

.case-step-card-highlight {
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.12);
}

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

.case-card-title {
  font-weight: 700;
  color: #18181b;
}

.case-card-meta {
  color: #475569;
  font-size: 13px;
  line-height: 1.6;
}

.case-card-actions {
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.case-material-overview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.case-material-summary-card {
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: #ffffff;
  padding: 12px;
}

.case-material-summary-card.warn {
  background: #fffbeb;
  border-color: #fcd34d;
}

.case-material-summary-card.info {
  background: #eff6ff;
  border-color: #93c5fd;
}

.case-material-summary-card.danger {
  background: #fef2f2;
  border-color: #fca5a5;
}

.case-material-summary-card.success {
  background: #ecfdf5;
  border-color: #86efac;
}

.case-material-summary-value {
  font-size: 24px;
  font-weight: 800;
  color: #18181b;
}

.case-material-summary-label {
  margin-top: 4px;
  font-size: 13px;
  font-weight: 700;
  color: #18181b;
}

.case-material-summary-desc {
  margin-top: 6px;
  font-size: 12px;
  line-height: 1.5;
  color: #52525b;
}

.case-material-group {
  display: flex;
  flex-direction: column;
  gap: 10px;
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  padding: 12px;
  background: #ffffff;
}

.case-material-group.warn {
  border-color: #fcd34d;
  background: #fffbeb;
}

.case-material-group.info {
  border-color: #93c5fd;
  background: #f8fbff;
}

.case-material-group.danger {
  border-color: #fca5a5;
  background: #fff7f7;
}

.case-material-group.success {
  border-color: #86efac;
  background: #f4fff8;
}

.case-material-group + .case-material-group {
  margin-top: 14px;
}

.case-material-group-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  padding: 4px 2px;
}

.case-material-group-title {
  font-size: 15px;
  font-weight: 700;
  color: #18181b;
}

.case-material-group-desc {
  margin-top: 4px;
  color: #52525b;
  font-size: 12px;
  line-height: 1.5;
}

.case-material-group-badge {
  white-space: nowrap;
  border-radius: 999px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 700;
}

.case-material-group-badge.success {
  background: #dcfce7;
  color: #166534;
}

.case-material-group-badge.warn {
  background: #fef3c7;
  color: #92400e;
}

.case-material-group-badge.info {
  background: #dbeafe;
  color: #1d4ed8;
}

.case-material-group-badge.danger {
  background: #fee2e2;
  color: #991b1b;
}

.case-material-group-list {
  display: grid;
  gap: 10px;
}

.case-log-overview {
  margin-bottom: 12px;
  color: #52525b;
  font-size: 13px;
}

.case-log-timeline {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.case-log-item {
  display: grid;
  grid-template-columns: 22px minmax(0, 1fr);
  gap: 10px;
  align-items: stretch;
}

.case-log-axis {
  position: relative;
  display: flex;
  justify-content: center;
}

.case-log-axis::before {
  content: '';
  position: absolute;
  top: 0;
  bottom: -12px;
  left: 50%;
  width: 2px;
  transform: translateX(-50%);
  background: #e4e4e7;
}

.case-log-item:last-child .case-log-axis::before {
  bottom: 50%;
}

.case-log-dot {
  position: relative;
  z-index: 1;
  width: 12px;
  height: 12px;
  margin-top: 18px;
  border-radius: 999px;
  border: 2px solid #ffffff;
  box-shadow: 0 0 0 2px #e4e4e7;
  background: #93c5fd;
}

.case-log-dot.info {
  background: #60a5fa;
}

.case-log-dot.warn {
  background: #f59e0b;
}

.case-log-dot.danger {
  background: #ef4444;
}

.case-log-dot.success {
  background: #22c55e;
}

.case-log-card {
  border: 1px solid #e4e4e7;
  border-radius: 14px;
  background: #ffffff;
  padding: 12px 14px;
}

.case-log-card.info {
  background: #f8fbff;
  border-color: #bfdbfe;
}

.case-log-card.warn {
  background: #fffbeb;
  border-color: #fde68a;
}

.case-log-card.danger {
  background: #fff7f7;
  border-color: #fecaca;
}

.case-log-card.success {
  background: #f4fff8;
  border-color: #bbf7d0;
}

.case-log-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.case-log-head-main {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.case-log-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 44px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

.case-log-tag.info {
  background: #dbeafe;
  color: #1d4ed8;
}

.case-log-tag.warn {
  background: #fef3c7;
  color: #92400e;
}

.case-log-tag.danger {
  background: #fee2e2;
  color: #991b1b;
}

.case-log-tag.success {
  background: #dcfce7;
  color: #166534;
}

.case-log-title {
  color: #18181b;
  font-size: 14px;
  font-weight: 700;
}

.case-log-time {
  color: #52525b;
  font-size: 12px;
  white-space: nowrap;
}

.case-log-desc,
.case-log-transition,
.case-log-meta,
.case-log-remark {
  margin-top: 8px;
  color: #475569;
  font-size: 13px;
  line-height: 1.6;
}

.case-log-transition {
  color: #18181b;
  font-weight: 600;
}

.case-log-remark {
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(255, 255, 255, .72);
  border: 1px dashed #d4d4d8;
  white-space: pre-wrap;
  word-break: break-word;
}

.perm-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.perm-item {
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  padding: 10px;
  background: #fafafa;
  display: flex;
  align-items: center;
  gap: 8px;
}
.perm-item code { color: #52525b; font-size: 12px; }
.perm-node { display: flex; flex-direction: column; gap: 8px; }
.perm-children { display: flex; flex-direction: column; gap: 8px; margin-left: 18px; padding-left: 12px; border-left: 2px solid #e4e4e7; }
.perm-item-root { background: #f5f7ff; }
.perm-item-child { background: #fafafa; }
.perm-badge { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; padding: 2px 8px; border-radius: 999px; background: #eef2ff; color: #4338ca; font-size: 12px; }
.perm-badge-warn { background: #fff7ed; color: #c2410c; }

pre {
  background: #18181b;
  color: #dbeafe;
  border-radius: 12px;
  padding: 12px;
  overflow: auto;
}

.modal-mask {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, .5);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 999;
}
.modal {
  width: 430px;
  background: #fff;
  border-radius: 16px;
  padding: 16px;
  box-shadow: 0 24px 60px rgba(0, 0, 0, .3);
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: calc(100vh - 32px);
  overflow-y: auto;
}
.modal-wide {
  width: min(1100px, calc(100vw - 36px));
}
.modal h3 { margin: 0; }
.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  position: sticky;
  top: 0;
  background: #fff;
  padding-bottom: 6px;
  z-index: 2;
}
.modal-close {
  background: #fff;
  color: #27272a;
  border: 1px solid #e4e4e7;
  padding: 8px 12px;
}
.modal input, .modal select {
  padding: 10px;
  border: 1px solid #e4e4e7;
  border-radius: 10px;
}
.modal textarea {
  padding: 10px;
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  min-height: 92px;
  resize: vertical;
}
.rt-toolbar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.rt-toolbar .ghost-btn {
  padding: 6px 10px;
  border-radius: 8px;
  font-weight: 600;
}
.rt-preview-wrap {
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  background: #fafafa;
  overflow: hidden;
}
.rt-preview-title {
  padding: 8px 10px;
  border-bottom: 1px solid #e4e4e7;
  color: #475569;
  font-size: 12px;
  font-weight: 600;
}
.rt-preview {
  padding: 10px;
  max-height: 180px;
  overflow: auto;
  color: #18181b;
  line-height: 1.6;
  font-size: 13px;
}
.rt-preview h2, .rt-preview h3 { margin: 8px 0; }
.rt-preview p, .rt-preview ul, .rt-preview ol, .rt-preview blockquote { margin: 6px 0; }
.rt-preview blockquote {
  border-left: 3px solid #10b981;
  background: #ecfdf5;
  padding: 6px 10px;
  border-radius: 6px;
}
.sku-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: #334155;
  font-size: 13px;
}
.sku-rows {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.sku-row {
  display: grid;
  grid-template-columns: 1fr 120px 68px;
  gap: 8px;
}
.sku-row input {
  width: 100%;
}
.material-template-rows {
  display: grid;
  gap: 10px;
  margin-bottom: 10px;
}

.material-template-empty {
  border: 1px dashed #cbd5e1;
  border-radius: 12px;
  padding: 14px;
  background: #f8fafc;
  color: #52525b;
  font-size: 13px;
}

.material-template-row {
  display: grid;
  grid-template-columns: minmax(140px, 1.1fr) 120px 100px minmax(220px, 1.6fr) auto;
  gap: 8px;
  align-items: center;
}

.material-template-row input,
.material-template-row select {
  width: 100%;
  padding: 10px;
  border: 1px solid #d4d4d8;
  border-radius: 10px;
  background: #fff;
  font: inherit;
}
.modal-actions { display: flex; gap: 8px; justify-content: flex-end; }
.banner-preview {
  width: 100%;
  max-height: 190px;
  object-fit: contain;
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  background: #fafafa;
}
.detail-title {
  margin-top: 4px;
  font-weight: 600;
  color: #18181b;
}
.detail-tools {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.detail-tools select {
  padding: 8px 10px;
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  min-width: 140px;
}
.detail-block {
  max-height: 180px;
  overflow: auto;
  border: 1px solid #e4e4e7;
  border-radius: 10px;
  padding: 10px;
  background: #fafafa;
  color: #334155;
  font-size: 13px;
  line-height: 1.5;
}

#page-case-detail .detail-block,
#page-case-detail .case-workspace-block {
  max-height: none;
  overflow: visible;
}
.detail-line {
  padding: 6px 0;
  border-bottom: 1px dashed #d4d4d8;
}
.detail-line:last-child { border-bottom: none; }
.detail-empty { color: #52525b; }
.file-preview-body {
  min-height: 360px;
  max-height: calc(100vh - 180px);
  overflow: auto;
  border: 1px solid #e4e4e7;
  border-radius: 12px;
  background: #f8fafc;
  padding: 12px;
}
.file-preview-frame {
  width: 100%;
  min-height: 72vh;
  border: none;
  border-radius: 10px;
  background: #fff;
}
.file-preview-image {
  display: block;
  max-width: 100%;
  max-height: 72vh;
  margin: 0 auto;
  border-radius: 10px;
  background: #fff;
}
.pager {
  margin-top: 10px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  color: #334155;
  font-size: 13px;
}
.pager button {
  border-radius: 999px;
  padding: 6px 12px;
}
.sortable {
  cursor: pointer;
  user-select: none;
}
.quick-filters {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.quick-filter {
  border-radius: 999px;
  padding: 6px 14px;
  border: 1px solid #e4e4e7;
  background: #fff;
  color: #334155;
  cursor: pointer;
}
.quick-filter.active {
  background: #10b981;
  border-color: #10b981;
  color: #fff;
}
.hint-text {
  margin-top: 8px;
  color: #52525b;
  font-size: 13px;
}

.notify-layout {
  display: grid;
  gap: 14px;
}

.notify-card {
  border: 1px solid #e4e4e7;
  border-radius: 16px;
  padding: 14px;
  background: #fafafa;
}

.panel-tip {
  margin: -2px 0 12px;
  color: #52525b;
  font-size: 13px;
  line-height: 1.6;
}

.notify-grid {
  display: grid;
  gap: 12px;
}

.notify-grid.two-col {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.notify-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.notify-field span {
  font-size: 13px;
  font-weight: 600;
  color: #334155;
}

.notify-field input,
.notify-field textarea {
  width: 100%;
  padding: 10px;
  border: 1px solid #d4d4d8;
  border-radius: 10px;
  background: #fff;
  font: inherit;
}

.notify-field textarea {
  min-height: 120px;
  resize: vertical;
}

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

@media (max-width: 1080px) {
  .case-list-summary-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .case-summary-strip { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .case-overview-grid { grid-template-columns: 1fr; }
  .case-quick-actions-head { flex-direction: column; }
  .case-quick-actions-list { justify-content: flex-start; }
  .case-step-overview { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .case-material-overview { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .app { flex-direction: column; }
  .sidebar { width: 100%; flex-direction: row; overflow-x: auto; }
  .cards { grid-template-columns: repeat(2, 1fr); }
  .dash-panels { grid-template-columns: 1fr; }
  .case-workspace-head { flex-direction: column; }
  .case-section-nav { position: static; top: auto; }
  .case-workspace-grid { grid-template-columns: 1fr; }
  .case-workspace-side { position: static; top: auto; }
  .case-kv-grid { grid-template-columns: 1fr; }
  .perm-list { grid-template-columns: 1fr; }
  .notify-grid.two-col { grid-template-columns: 1fr; }
  .notify-span-2 { grid-column: auto; }
  .topbar { height: auto; padding: 10px; flex-direction: column; align-items: stretch; }
  .top-right { flex-wrap: wrap; }
  .topbar input { min-width: 0; width: 100%; }
  .modal { width: calc(100vw - 22px); }
}

@media (max-width: 640px) {
  .case-list-summary-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .case-summary-strip { grid-template-columns: 1fr; }
  .case-kv-item-wide { grid-column: auto; }
  .case-step-overview { grid-template-columns: 1fr; }
  .case-material-overview { grid-template-columns: 1fr; }
  .case-step-group-head { flex-direction: column; }
  .case-material-group-head { flex-direction: column; }
  .case-log-item { grid-template-columns: 18px minmax(0, 1fr); gap: 8px; }
  .case-log-head { flex-direction: column; }
  .case-log-time { white-space: normal; }
}


