/* claim.css - 证券索赔筛选页专属样式（继承 tokens.css / base.css） */

.hidden { display: none !important; }

.eyebrow { color: var(--cyan); font-size: var(--font-sm); letter-spacing: .08em; font-weight: 700; }
h2 { font-size: var(--font-xl); line-height: 1.3; }
h3 { font-size: 16px; }
p, .notice, .footer-note { color: var(--muted); line-height: 1.7; }

/* 主容器 */
.app { width: min(100% - 32px, 1480px); margin: 0 auto; padding: var(--space-4) 0 var(--space-8); }

/* 区块标题 */
.section-title {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  margin: var(--space-5) 0 var(--space-3);
}
.section-title h2 { font-size: var(--font-lg); }
.section-title p { font-size: var(--font-sm); margin-top: 3px; }

/* 查询区 */
.query-grid { display: grid; grid-template-columns: .92fr 1.08fr; gap: var(--space-4); }
.panel, .chart-card, .table-panel, .kpi {
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-sm);
}
.intro, .form-card { padding: var(--space-5); }
.intro h2 { margin-top: var(--space-2); font-size: var(--font-xl); }
.intro p { margin-top: var(--space-2); font-size: var(--font-sm); }
.form-card h3 { margin-bottom: var(--space-3); font-size: 16px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: var(--space-2); margin-top: var(--space-1); }

/* 表单元素 */
.field { margin-top: var(--space-4); }
label { display: block; margin-bottom: 6px; color: var(--text); font-weight: 600; font-size: var(--font-sm); }
.app input, .app select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: var(--space-2) var(--space-3);
  background: rgba(3,9,22,.5);
  color: var(--text);
  outline: none;
  font-size: var(--font-sm);
  transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
}
.app input:focus, .app select:focus { border-color: rgba(24,225,255,.6); box-shadow: 0 0 0 2px rgba(24,225,255,.12); }
.app input::placeholder { color: var(--muted); opacity: .6; }
.app input::file-selector-button {
  border: none;
  margin-right: var(--space-2);
  border-radius: 6px;
  padding: 6px 10px;
  background: rgba(24,225,255,.12);
  color: var(--text-accent);
  cursor: pointer;
  font-size: var(--font-sm);
}

/* 按钮 */
.button-row { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-top: var(--space-3); }
.app button {
  border: 0;
  border-radius: 8px;
  padding: var(--space-2) var(--space-3);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
  font-size: var(--font-sm);
}
.app button:hover { transform: translateY(-1px); }
.app button:disabled { opacity: .5; cursor: wait; transform: none; }
.primary { background: linear-gradient(135deg, var(--blue), var(--cyan)); color: #031022; box-shadow: 0 2px 8px rgba(24,225,255,.2); }
.primary:hover { box-shadow: 0 4px 12px rgba(24,225,255,.35); }
.secondary { background: rgba(255,255,255,.08); border: 1px solid var(--line); color: var(--text); }
.secondary:hover { background: rgba(255,255,255,.14); }

/* 案件信息 / 提示 */
.case-info {
  margin-top: var(--space-3);
  padding: var(--space-2) var(--space-3);
  border-radius: 8px;
  border: 1px solid rgba(24,225,255,.15);
  background: rgba(24,225,255,.06);
  color: var(--text-accent);
  font-size: var(--font-sm);
  line-height: 1.6;
}
.notice {
  margin-top: var(--space-3);
  border: 1px solid rgba(246,200,95,.18);
  border-radius: 8px;
  padding: var(--space-2) var(--space-3);
  background: rgba(246,200,95,.05);
  font-size: var(--font-sm);
  color: var(--gold);
  line-height: 1.6;
}

/* KPI */
section { margin-top: var(--space-6); }
.data-source-badges { display: flex; gap: var(--space-2); margin-top: var(--space-2); }
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 4px;
  font-size: var(--font-sm);
}
.badge-purple { background: rgba(168,85,247,.2); color: #a855f7; }
.badge-orange { background: rgba(59,130,246,.2); color: #3b82f6; }
.badge-blue { background: rgba(34,197,94,.2); color: #22c55e; }
.kpis { display: grid; grid-template-columns: repeat(6, 1fr); gap: var(--space-2); }
.kpi {
  padding: 14px 12px;
  min-height: 0;
  border-radius: 14px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.08);
  border-left: 3px solid var(--cyan);
  transition: border-color .2s;
}
.kpi:nth-child(1) { border-left-color: var(--cyan); }
.kpi:nth-child(2) { border-left-color: var(--color-purple); }
.kpi:nth-child(3) { border-left-color: var(--color-orange); }
.kpi:nth-child(4) { border-left-color: var(--color-indigo); }
.kpi:nth-child(5) { border-left-color: var(--green); }
.kpi:nth-child(6) { border-left-color: var(--red); }
.kpi:hover { border-color: rgba(24,225,255,.25); }
.kpi span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  margin-bottom: 4px;
}
.kpi small {
  display: block;
  color: var(--muted);
  font-size: var(--font-xs);
  margin-top: 4px;
}
.kpi strong {
  display: block;
  font-size: 20px;
  font-weight: 700;
  color: var(--text);
  line-height: 1.2;
  word-break: break-word;
}

/* 图表 */
.charts { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-3); }
.chart-card { padding: var(--space-4); min-height: 320px; }
.chart-card h3 { font-size: 16px; margin-bottom: 4px; }
.sub { margin-top: 4px; margin-bottom: var(--space-4); font-size: var(--font-sm); color: var(--muted); }
.bars { margin-top: var(--space-4); display: grid; gap: var(--space-2); }
.bar-row { display: grid; grid-template-columns: 110px 1fr 82px; gap: var(--space-2); align-items: center; font-size: var(--font-sm); }
.name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--text); }
.bar-track { height: 10px; border-radius: 999px; background: rgba(255,255,255,.09); overflow: hidden; }
.bar-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, var(--blue), var(--cyan)); box-shadow: 0 0 12px rgba(24,225,255,.26); transition: width .8s; }
.bar-value { color: var(--gold); text-align: right; }

/* 标签页 */
.tabs { display: flex; gap: var(--space-2); flex-wrap: wrap; margin-bottom: var(--space-2); }
.tab {
  padding: var(--space-2) var(--space-3);
  border: 1px solid var(--line);
  border-radius: 999px;
  color: var(--text);
  background: rgba(255,255,255,.06);
  cursor: pointer;
  font-size: var(--font-sm);
  transition: var(--transition-fast);
}
.tab.active { color: #061426; border-color: transparent; background: linear-gradient(135deg, var(--cyan), var(--gold)); font-weight: 900; }

/* 表格 */
.table-panel { overflow: hidden; }
.table-toolbar { display: grid; grid-template-columns: 1.4fr .75fr .75fr auto auto; gap: var(--space-2); padding: var(--space-3); border-bottom: 1px solid var(--line); background: rgba(255,255,255,.04); }
.table-wrap { overflow: auto; max-height: 620px; }
table { width: 100%; border-collapse: collapse; min-width: 900px; }
th, td { padding: var(--space-3); border-bottom: 1px solid rgba(255,255,255,.08); text-align: left; font-size: var(--font-sm); vertical-align: top; }
th { position: sticky; top: 0; z-index: 1; background: rgba(3,9,22,.9); color: var(--text-dim); white-space: nowrap; }
td { color: var(--text-bright); }
td.money { color: var(--gold); font-weight: 800; white-space: nowrap; }
tr:hover td { background: rgba(24,225,255,.04); }
.empty { text-align: center; padding: 38px; color: var(--muted); }

/* 页脚提示 */
.footer-note { margin-top: var(--space-4); font-size: var(--font-sm); padding: var(--space-3) var(--space-4); border-radius: var(--radius-sm); background: rgba(246,200,95,.07); border: 1px solid rgba(246,200,95,.18); color: var(--gold); line-height: 1.7; }

/* 加载遮罩 */
.loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: var(--space-6);
  background: rgba(3, 9, 22, .82);
  backdrop-filter: blur(16px);
}
.loading-card {
  width: min(520px, 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-md);
  padding: var(--space-8);
  background: linear-gradient(180deg, rgba(255,255,255,.13), rgba(255,255,255,.07));
  box-shadow: var(--shadow-lg);
  text-align: center;
}
.loading-ring {
  width: 64px;
  height: 64px;
  margin: 0 auto var(--space-4);
  border-radius: 50%;
  border: 4px solid rgba(255,255,255,.14);
  border-top-color: var(--cyan);
  border-right-color: var(--blue);
  animation: spin 1s linear infinite;
}
.loading-card h3 { font-size: var(--font-xl); margin-bottom: var(--space-2); color: var(--text); }
.loading-card p { color: var(--muted); line-height: 1.7; font-size: var(--font-sm); }
.loading-progress-bar {
  width: 100%;
  height: 6px;
  background: rgba(255,255,255,.1);
  border-radius: 3px;
  margin: var(--space-4) 0 4px;
  overflow: hidden;
}
.loading-progress-fill {
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--cyan), var(--blue));
  border-radius: 3px;
  transition: width .6s ease;
}
.loading-percent {
  font-size: var(--font-sm);
  color: var(--cyan);
  font-weight: 600;
  margin-bottom: var(--space-3);
}
.loading-steps { display: flex; flex-wrap: wrap; gap: var(--space-2); justify-content: center; margin-top: var(--space-3); }
.loading-steps .step {
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 999px;
  padding: 6px 14px;
  color: var(--muted);
  background: rgba(255,255,255,.04);
  font-size: var(--font-sm);
  transition: all var(--transition-base);
}
.loading-steps .step.active {
  color: #fff;
  background: rgba(24,225,255,.18);
  border-color: var(--cyan);
  box-shadow: 0 0 8px rgba(24,225,255,.3);
}
.loading-steps .step.done {
  color: var(--green);
  background: rgba(32,201,151,.12);
  border-color: var(--green);
}
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes pulse { 0%, 100% { opacity: .54; transform: translateY(0); } 50% { opacity: 1; transform: translateY(-2px); } }

/* 响应式 */
@media (max-width: 1080px) {
  .query-grid, .charts { grid-template-columns: 1fr; }
  .kpis { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 720px) {
  .app { width: min(100% - 24px, 1480px); }
  .section-title { flex-direction: column; align-items: flex-start; }
  .kpis { grid-template-columns: repeat(2, 1fr); }
  .table-toolbar { grid-template-columns: 1fr; }
  .intro h2 { font-size: var(--font-xl); }
  .bar-row { grid-template-columns: 86px 1fr 70px; }
  .loading-card { padding: var(--space-5); }
}
