/* ================================================================
   AILANG Parse — Shared Components
   Reusable UI patterns: callouts, tables, badges
   Used by: multiple docs pages
   ================================================================ */

/* ---- Callout ---- */
.dp-callout {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 16px 20px;
  border-radius: var(--radius-sm);
  background: var(--dp-blue-faded);
  border: 1px solid var(--dp-blue-border);
  margin-bottom: 20px;
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
}
.dp-callout svg {
  width: 18px; height: 18px; min-width: 18px;
  margin-top: 1px;
  stroke: var(--dp-blue); fill: none;
  stroke-width: 2; stroke-linecap: round; stroke-linejoin: round;
}
.dp-callout--warn,
.dp-callout--warning {
  background: rgba(245, 158, 11, 0.06);
  border-color: rgba(245, 158, 11, 0.2);
}
.dp-callout--warn svg,
.dp-callout--warning svg { stroke: #f59e0b; }
.dp-callout--contact {
  background: rgba(139, 92, 246, 0.06);
  border-color: rgba(139, 92, 246, 0.2);
}
.dp-callout--contact svg { stroke: #8b5cf6; }

/* ---- Config table ---- */
.dp-config-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  margin-bottom: 20px;
}
.dp-config-table th {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  text-align: left;
  padding: 10px 14px;
  border-bottom: 2px solid var(--border);
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  background: var(--dp-blue-faded);
}
.dp-config-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--text-secondary);
  vertical-align: top;
}
.dp-config-table td:first-child {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--dp-blue);
  font-weight: 500;
  white-space: nowrap;
}

/* ---- Comparison table ---- */
.dp-compare-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  margin-bottom: 20px;
}
.dp-compare-table th {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  text-align: left;
  padding: 10px 14px;
  border-bottom: 2px solid var(--border);
  color: var(--text-primary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  background: var(--dp-blue-faded);
}
.dp-compare-table td {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  color: var(--text-secondary);
  vertical-align: top;
}
.dp-compare-table td:first-child {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--dp-blue);
  font-weight: 500;
  white-space: nowrap;
}
.dp-compare-table .dp-preserved,
.dp-compare-table .dp-lost {
  display: inline;
  padding: 0;
  border-radius: 0;
  border: none;
  background: none;
  font-family: inherit;
  font-size: inherit;
}
.dp-compare-table .dp-preserved {
  color: var(--success);
  font-weight: 600;
}
.dp-compare-table .dp-lost {
  color: #ef4444;
  font-weight: 500;
}

/* ---- Preserved / Lost badges ---- */
.dp-preserved {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(34, 197, 94, 0.1);
  color: #16a34a;
  border: 1px solid rgba(34, 197, 94, 0.2);
}
.dp-lost {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(239, 68, 68, 0.1);
  color: #dc2626;
  border: 1px solid rgba(239, 68, 68, 0.2);
}
