/* ── Component Detail – Page-specific CSS ──────────────────────────
   Mouser-style 3-column product card, collapsible sections,
   specifications table, documents list, equivalents, comparison modal.
   ──────────────────────────────────────────────────────────────────── */

/* ══════════════════════════════════════════════════════════════════
   PRODUCT CARD — 3-column desktop layout
   ══════════════════════════════════════════════════════════════════ */
.product-card {
  display: grid;
  grid-template-columns: 190px 1fr 220px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: var(--space-xl);
}

/* Column 1: Image */
.product-col-image {
  padding: var(--space-lg);
  border-right: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-sm);
  background: var(--color-surface);
}
.product-card-mpn {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  font-family: var(--font-mono);
  text-align: center;
  width: 100%;
  padding-bottom: var(--space-md);
  border-bottom: 1px solid var(--color-border);
  margin-bottom: var(--space-xs);
  overflow-wrap: break-word;
}
.product-mfr-logo {
  font-size: var(--font-size-md);
  color: var(--color-accent);
  font-weight: var(--font-weight-semi);
}
.product-image-box {
  width: 150px;
  height: 110px;
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--color-text-muted);
}
.product-image-note {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
  text-align: center;
  font-style: italic;
}

/* Column 2: Details */
.product-col-details {
  padding: var(--space-md) var(--space-lg);
  border-right: 1px solid var(--color-border);
}
.detail-row {
  padding: 5px 0;
  border-bottom: 1px solid var(--color-border);
  font-size: var(--font-size-sm);
}
.detail-row:last-child { border-bottom: none; }
.detail-row-label {
  font-weight: var(--font-weight-semi);
  color: var(--color-text-muted);
  font-size: var(--font-size-xs);
  margin-bottom: 1px;
}
.detail-row-value {
  font-size: var(--font-size-sm);
  word-break: break-word;
}
.detail-row-value a { color: var(--color-accent); }

/* Column 3: Status & Actions */
.product-col-status {
  padding: 0;
  display: flex;
  flex-direction: column;
}
.status-header {
  padding: var(--space-md) var(--space-lg);
  background: var(--color-badge-success-bg);
  font-weight: var(--font-weight-semi);
  font-size: var(--font-size-md);
  color: var(--color-badge-success-text);
  display: flex;
  align-items: center;
  gap: var(--space-sm);
}
.status-header.inactive {
  background: var(--color-badge-warning-bg);
  color: var(--color-badge-warning-text);
}
.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: currentColor;
}
.status-body {
  padding: var(--space-lg);
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}
.status-row {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.status-row-label {
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-semi);
  color: var(--color-text-muted);
  text-transform: uppercase;
  letter-spacing: 0.03em;
}
.status-row-value {
  font-size: var(--font-size-sm);
}
.status-actions {
  margin-top: auto;
  padding-top: var(--space-md);
  border-top: 1px solid var(--color-border);
  display: flex;
  gap: var(--space-sm);
}
.action-btn {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  padding: var(--space-sm) var(--space-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text-muted);
  background: var(--color-bg);
  cursor: pointer;
  font-family: inherit;
  font-size: var(--font-size-sm);
  flex: 1;
  justify-content: center;
}
.action-btn:hover { color: var(--color-accent); border-color: var(--color-accent); }
.action-btn.danger:hover { color: var(--color-danger); border-color: var(--color-danger); }

/* ══════════════════════════════════════════════════════════════════
   Collapsible sections
   ══════════════════════════════════════════════════════════════════ */
.product-section {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-lg);
  overflow: hidden;
}
.product-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-md) var(--space-lg);
  background: var(--color-surface);
  cursor: pointer;
  user-select: none;
  transition: background var(--transition-fast);
}
.product-section-header:hover { background: var(--color-surface-hover); }
.product-section-title { font-size: var(--font-size-md); font-weight: var(--font-weight-semi); margin: 0; }
.product-section-toggle { color: var(--color-accent); font-size: 1.1rem; transition: transform var(--transition-base); line-height: 1; }
.product-section.collapsed .product-section-toggle { transform: rotate(180deg); }
.product-section.collapsed .product-section-body { display: none; }
.product-section-body { border-top: 1px solid var(--color-border); }

/* Specs table */
.specs-table { width: 100%; border-collapse: collapse; }
.specs-table tr { border-bottom: 1px solid var(--color-border); transition: background var(--transition-fast); }
.specs-table tr:last-child { border-bottom: none; }
.specs-table tr:hover { background: var(--color-surface-hover); }
.specs-table td { padding: var(--space-sm) var(--space-lg); font-size: var(--font-size-sm); vertical-align: top; }
.specs-table .spec-attr { width: 220px; font-weight: var(--font-weight-semi); color: var(--color-text-muted); }
.specs-table .spec-val a { color: var(--color-accent); }

/* Documents */
.docs-list { padding: var(--space-sm) var(--space-lg) var(--space-lg); }
.doc-item { display: flex; align-items: center; gap: var(--space-sm); padding: var(--space-sm) 0; font-size: var(--font-size-sm); }
.doc-item + .doc-item { border-top: 1px solid var(--color-border); }
.doc-icon { color: var(--color-text-muted); flex-shrink: 0; }
.doc-label { color: var(--color-text-muted); font-size: var(--font-size-xs); font-style: italic; margin-left: auto; }

/* ══════════════════════════════════════════════════════════════════
   Equivalents & Alternatives
   ══════════════════════════════════════════════════════════════════ */
.equivalents-section { padding: var(--space-lg); }
.equivalents-section-header { display: flex; align-items: center; justify-content: space-between; gap: 1rem; margin-bottom: var(--space-md); }
.section-title { font-size: 0.75rem; font-weight: var(--font-weight-semi); text-transform: uppercase; letter-spacing: 0.06em; color: var(--color-text-muted); margin: 0; }

.confirmed-links { margin-bottom: var(--space-xl); }
.equiv-card { display: flex; align-items: center; gap: var(--space-md); padding: var(--space-md) var(--space-lg); border: 1px solid var(--color-border); border-radius: var(--radius-lg); margin-bottom: var(--space-sm); transition: background var(--transition-fast), border-color var(--transition-fast); }
.equiv-card:hover { background: var(--color-surface-hover); border-color: var(--color-border-active); }
.equiv-badge { font-size: var(--font-size-xs); font-weight: var(--font-weight-semi); padding: 2px 8px; border-radius: var(--radius-pill); white-space: nowrap; flex-shrink: 0; }
.equiv-badge.equivalent { background: var(--color-badge-success-bg); color: var(--color-badge-success-text); }
.equiv-badge.compatible { background: var(--color-badge-info-bg); color: var(--color-badge-info-text); }
.equiv-badge.supersedes { background: var(--color-badge-warning-bg); color: var(--color-badge-warning-text); }
.equiv-info { flex: 1; min-width: 0; }
.equiv-manufacturer { font-size: var(--font-size-xs); color: var(--color-text-muted); margin-bottom: 1px; }
.equiv-mpn { font-weight: var(--font-weight-medium); color: var(--color-accent); cursor: pointer; }
.equiv-mpn:hover { text-decoration: underline; }
.equiv-match-info { font-size: var(--font-size-xs); color: var(--color-text-muted); margin-top: 2px; }
.equiv-actions { display: flex; align-items: center; gap: var(--space-xs); flex-shrink: 0; }

.suggestions-section { padding: var(--space-lg); padding-top: 0; }
.suggestions-header { display: flex; align-items: baseline; gap: var(--space-sm); margin-bottom: var(--space-sm); }
.suggestions-subtitle { font-size: var(--font-size-xs); color: var(--color-text-muted); font-style: italic; }
.suggestion-card { display: flex; align-items: center; gap: var(--space-md); padding: var(--space-md) var(--space-lg); border: 1px dashed var(--color-border); border-radius: var(--radius-lg); margin-bottom: var(--space-sm); transition: background var(--transition-fast), border-color var(--transition-fast); }
.suggestion-card:hover { background: var(--color-surface-hover); border-color: var(--color-accent); border-style: solid; }
.match-score { display: flex; align-items: center; gap: var(--space-xs); flex-shrink: 0; }
.match-dots { display: flex; gap: 3px; }
.match-dot { width: 8px; height: 8px; border-radius: 50%; background: var(--color-border); }
.match-dot.filled { background: var(--color-success); }
.match-label { font-size: var(--font-size-xs); color: var(--color-text-muted); white-space: nowrap; }

/* ══════════════════════════════════════════════════════════════════
   Comparison Modal
   ══════════════════════════════════════════════════════════════════ */
.compare-backdrop { display: none; position: fixed; inset: 0; background: var(--color-overlay); z-index: 1000; align-items: center; justify-content: center; padding: var(--space-lg); }
.compare-backdrop.show { display: flex; }
.compare-modal { background: var(--color-bg); border: 1px solid var(--color-border); border-radius: var(--radius-xl); width: 100%; max-width: 780px; max-height: 85vh; display: flex; flex-direction: column; overflow: hidden; box-shadow: var(--shadow-lg); }
.compare-header { display: flex; align-items: center; justify-content: space-between; padding: var(--space-lg) var(--space-xl); border-bottom: 1px solid var(--color-border); flex-shrink: 0; }
.compare-header h2 { font-size: var(--font-size-2xl); font-weight: var(--font-weight-bold); margin: 0; letter-spacing: -0.02em; }
.compare-close { background: none; border: none; color: var(--color-text-muted); font-size: 1.4rem; cursor: pointer; padding: 0 var(--space-xs); border-radius: var(--radius-sm); }
.compare-close:hover { background: var(--color-surface-hover); color: var(--color-text); }
.compare-body { flex: 1; overflow-y: auto; padding: var(--space-xl); }
.compare-parts-header { display: grid; grid-template-columns: 160px 1fr 1fr; gap: 0; margin-bottom: var(--space-sm); border-bottom: 2px solid var(--color-border); padding-bottom: var(--space-sm); }
.compare-col-label { font-size: var(--font-size-xs); text-transform: uppercase; letter-spacing: 0.05em; color: var(--color-text-muted); font-weight: var(--font-weight-semi); padding: 0 var(--space-sm); }
.compare-col-part { padding: 0 var(--space-sm); }
.compare-part-manufacturer { font-size: var(--font-size-xs); color: var(--color-text-muted); }
.compare-part-mpn { font-weight: var(--font-weight-semi); font-size: var(--font-size-md); }
.compare-row { display: grid; grid-template-columns: 160px 1fr 1fr; gap: 0; border-bottom: 1px solid var(--color-border); transition: background var(--transition-fast); }
.compare-row:last-child { border-bottom: none; }
.compare-row > div { padding: var(--space-sm); }
.compare-param-name { font-size: var(--font-size-sm); color: var(--color-text-muted); font-weight: var(--font-weight-medium); display: flex; align-items: center; gap: var(--space-xs); }
.compare-param-value { font-size: var(--font-size-sm); }
.compare-row.match { background: rgba(26, 127, 55, 0.06); }
.compare-row.diff { background: rgba(154, 103, 0, 0.06); }
.compare-row.diff .compare-param-value { font-weight: var(--font-weight-semi); }
.compare-row.missing { background: rgba(101, 109, 118, 0.06); }
.compare-row.missing .compare-param-value.empty { color: var(--color-text-muted); font-style: italic; }
.key-param-indicator { display: inline-flex; align-items: center; justify-content: center; width: 14px; height: 14px; font-size: 9px; font-weight: var(--font-weight-bold); border-radius: 3px; flex-shrink: 0; }
.key-param-indicator.is-key { background: var(--color-badge-warning-bg); color: var(--color-badge-warning-text); }
.compare-legend { display: flex; gap: var(--space-lg); margin-top: var(--space-lg); padding-top: var(--space-md); border-top: 1px solid var(--color-border); }
.legend-item { display: flex; align-items: center; gap: var(--space-xs); font-size: var(--font-size-xs); color: var(--color-text-muted); }
.legend-dot { width: 12px; height: 12px; border-radius: 3px; flex-shrink: 0; }
.legend-dot.match { background: rgba(26, 127, 55, 0.2); }
.legend-dot.diff { background: rgba(154, 103, 0, 0.2); }
.legend-dot.missing { background: rgba(101, 109, 118, 0.15); }
.compare-footer { display: flex; align-items: center; justify-content: flex-end; gap: var(--space-sm); padding: var(--space-lg) var(--space-xl); border-top: 1px solid var(--color-border); flex-shrink: 0; }
.compare-summary { display: flex; gap: var(--space-lg); padding: var(--space-md) var(--space-lg); background: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-lg); margin-bottom: var(--space-lg); }
.summary-stat { display: flex; align-items: center; gap: var(--space-xs); font-size: var(--font-size-sm); }
.summary-stat .num { font-weight: var(--font-weight-bold); font-size: var(--font-size-lg); }
.summary-stat.match-stat .num { color: var(--color-success); }
.summary-stat.diff-stat .num { color: var(--color-badge-warning-text); }
.summary-stat.missing-stat .num { color: var(--color-text-muted); }

/* ── Responsive ────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .product-card { grid-template-columns: 1fr; }
  .product-col-image { border-right: none; border-bottom: 1px solid var(--color-border); }
  .product-col-details { border-right: none; border-bottom: 1px solid var(--color-border); }
  .compare-parts-header,
  .compare-row { grid-template-columns: 100px 1fr 1fr; }
}
