/* ─────────────────────────────────────────
   Card
   ───────────────────────────────────────── */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
}

/* ─────────────────────────────────────────
   Search Input
   ───────────────────────────────────────── */
.input-wrap {
  position: relative;
}

.search-input {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  padding-right: 44px; /* Room for spinner */
  font-family: inherit;
  font-size: var(--text-base);
  line-height: 1.5;
  color: var(--color-text);
  background: var(--color-surface);
  border: 2px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  -webkit-appearance: none;
  appearance: none;
}

.search-input::placeholder {
  color: var(--color-text-muted);
}

.search-input:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-light);
}

.search-input::-webkit-search-cancel-button {
  display: none;
}

/* ─────────────────────────────────────────
   Spinner (functional, not decorative)
   ───────────────────────────────────────── */
.spinner {
  position: absolute;
  right: var(--space-3);
  top: 50%;
  transform: translateY(-50%);
  width: 20px;
  height: 20px;
  border: 2px solid var(--color-border);
  border-top-color: var(--color-accent);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
}

.spinner--inline {
  position: static;
  right: auto;
  top: auto;
  display: block;
  margin: 0 auto;
  transform: none;
  animation: spin-inline 0.8s linear infinite;
}

@keyframes spin {
  to { transform: translateY(-50%) rotate(360deg); }
}

@keyframes spin-inline {
  to { transform: rotate(360deg); }
}

@media (prefers-reduced-motion: reduce) {
  .spinner {
    animation: none;
  }

  .spinner--inline {
    animation: none;
  }
}

/* ─────────────────────────────────────────
   Messages
   ───────────────────────────────────────── */
.status-message {
  margin-top: var(--space-4);
  font-size: var(--text-sm);
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
}

.status-message:empty {
  display: none;
}

.status-message.info {
  color: var(--color-text-muted);
  background: transparent;
  padding-left: 0;
  padding-right: 0;
}

.status-message.error {
  color: var(--color-error);
  background: var(--color-error-bg);
}

/* ─────────────────────────────────────────
   Results Count
   ───────────────────────────────────────── */
.count {
  margin: var(--space-4) 0 var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

/* ─────────────────────────────────────────
   Results Table
   ───────────────────────────────────────── */
.results-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-sm);
}

.results-table th,
.results-table td {
  text-align: left;
  padding: var(--space-3) var(--space-2);
  border-bottom: 1px solid var(--color-border);
  vertical-align: top;
}

.results-table th {
  font-weight: 600;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  border-bottom: 2px solid var(--color-border-strong);
  white-space: nowrap;
}

/* Search result row links — fill cell, inherit text color, no underline */
tr[data-ndc] td,
tr[data-rxcui] td {
  padding: 0;
}

tr[data-ndc] a,
tr[data-rxcui] a {
  display: block;
  padding: var(--space-2) var(--space-3);
  color: inherit;
  text-decoration: none;
}

tr[data-ndc]:active,
tr[data-rxcui]:active {
  background: var(--color-accent-light);
}

/* NDC column - monospace for readability (scoped to search result tables) */
tr[data-ndc] td:first-child,
tr[data-rxcui] td:first-child {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  white-space: nowrap;
  color: var(--color-text-muted);
}

/* Name cell — stacked primary name + strength/form details */
tr[data-ndc] .name-cell a,
tr[data-rxcui] .name-cell a {
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.name-primary {
  font-weight: 500;
}

.name-details {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}


/* ─────────────────────────────────────────
   Load More Button
   ───────────────────────────────────────── */
.load-more {
  display: block;
  margin: var(--space-4) auto;
  padding: var(--space-2) var(--space-6);
  font-family: inherit;
  font-size: var(--text-sm);
  color: var(--color-accent);
  background: var(--color-surface);
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-md);
  cursor: pointer;
}

.load-more:active:not(:disabled) {
  background: var(--color-accent-light);
}

.load-more:disabled {
  color: var(--color-text-muted);
  border-color: var(--color-border);
  cursor: not-allowed;
}

@media (min-width: 640px) {
  .card {
    padding: var(--space-6);
  }

  .results-table,
  .detail-table,
  .detail-ndc-table {
    font-size: var(--text-base);
  }

  .results-table th,
  .results-table td,
  .detail-table th,
  .detail-table td {
    padding: var(--space-3) var(--space-4);
  }

  tr[data-ndc] a,
  tr[data-rxcui] a {
    padding: var(--space-3) var(--space-4);
  }

  tr[data-ndc] td:first-child,
  tr[data-rxcui] td:first-child {
    font-size: var(--text-sm);
  }
}

@media (hover: hover) and (pointer: fine) {
  tr[data-ndc]:hover,
  tr[data-rxcui]:hover {
    background: var(--color-accent-light);
  }

  .load-more:hover:not(:disabled) {
    background: var(--color-accent-light);
  }
}
