/* ============================================================
   bloom-region-cards.css — field-guide region card chrome.
   Classes prefixed brc- to avoid colliding with site styles.
   Mounts inside any container; the card scales to the parent
   width and the SVG scene keeps its 4:3 aspect.
   ============================================================ */

.brc-card {
  --brc-paper: #f6efdf;
  --brc-ink:   #2a2620;
  --brc-muted: #8a8472;
  --brc-accent: #2a2620;
  background: var(--brc-paper);
  color: var(--brc-ink);
  font-family: "JetBrains Mono", ui-monospace, monospace;
  border: 1px solid #d8cdaf;
  border-radius: 2px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow:
    0 1px 0 rgba(0,0,0,0.04),
    0 18px 32px -22px rgba(60,40,15,0.25);
  position: relative;
  width: 100%;
}
/* Paper fiber texture */
.brc-card::before {
  content: "";
  position: absolute; inset: 0;
  pointer-events: none;
  background-image:
    repeating-linear-gradient(91deg, rgba(140,110,60,0.025) 0 1px, transparent 1px 3px),
    repeating-linear-gradient(1deg,  rgba(140,110,60,0.025) 0 1px, transparent 1px 4px);
  z-index: 2;
}
/* Inner hairline second-frame */
.brc-card::after {
  content: "";
  position: absolute;
  inset: 6px;
  border: 1px solid color-mix(in oklab, var(--brc-accent) 35%, transparent);
  pointer-events: none;
  z-index: 3;
}

.brc-scene-wrap {
  position: relative;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  margin: 12px 12px 0;
  border: 1px solid color-mix(in oklab, var(--brc-accent) 45%, transparent);
}
.brc-scene-wrap svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  display: block;
}

.brc-chrome {
  padding: 14px 14px 14px;
  color: var(--brc-ink);
  font-size: 9.5px;
  letter-spacing: 0.10em;
  position: relative;
  z-index: 1;
}
.brc-chrome-top {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 800;
  letter-spacing: 0.18em;
  font-size: 10px;
  white-space: nowrap;
}
.brc-chrome-top .brc-idx {
  color: var(--brc-accent);
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}
.brc-chrome-top .brc-rule {
  flex: 1;
  height: 1px;
  background: color-mix(in oklab, var(--brc-accent) 35%, transparent);
}
.brc-chrome-top .brc-name { color: var(--brc-ink); flex-shrink: 0; }

.brc-chrome-mid {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-top: 8px;
  color: var(--brc-muted);
  font-size: 9px;
  letter-spacing: 0.16em;
  white-space: nowrap;
}
.brc-chrome-mid .brc-tag {
  overflow: hidden; text-overflow: ellipsis; min-width: 0;
}
.brc-chrome-mid .brc-coords {
  color: var(--brc-accent);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  flex-shrink: 0;
}

.brc-chrome-bot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  gap: 10px;
}
.brc-palette {
  display: flex;
  gap: 4px;
}
.brc-swatch {
  width: 14px; height: 14px;
  border: 1px solid rgba(0,0,0,0.10);
  box-shadow: 0 0 0 1px var(--brc-paper) inset;
}
.brc-cat {
  font-size: 8.5px;
  letter-spacing: 0.14em;
  color: var(--brc-muted);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
}
.brc-cat strong {
  color: var(--brc-accent);
  font-weight: 700;
}

.brc-specimen {
  display: flex;
  align-items: stretch;
  gap: 12px;
  margin: 8px 14px 14px;
  padding-top: 12px;
  border-top: 1px dashed color-mix(in oklab, var(--brc-accent) 40%, transparent);
  position: relative;
  z-index: 1;
}
.brc-specimen-art {
  width: 64px; height: 64px;
  flex-shrink: 0;
  background: color-mix(in oklab, var(--brc-paper) 80%, white);
  border: 1px solid color-mix(in oklab, var(--brc-accent) 35%, transparent);
  position: relative;
}
.brc-specimen-art svg { width: 100%; height: 100%; display: block; }
.brc-specimen-art::after {
  content: "";
  position: absolute; top: 2px; left: 2px; width: 6px; height: 6px;
  border-top: 1px solid var(--brc-accent);
  border-left: 1px solid var(--brc-accent);
  opacity: 0.7;
}
.brc-specimen-info {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 2px;
}
.brc-specimen-info .brc-lbl {
  font-size: 7.5px;
  letter-spacing: 0.28em;
  color: var(--brc-muted);
  font-weight: 700;
  margin-bottom: 2px;
}
.brc-specimen-info .brc-common {
  font-size: 9.5px;
  font-weight: 800;
  letter-spacing: 0.14em;
  color: var(--brc-accent);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.brc-specimen-info .brc-latin {
  font-size: 9px;
  font-style: italic;
  color: var(--brc-ink);
  opacity: 0.75;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-top: 1px;
}
.brc-specimen-info .brc-bloom {
  font-size: 8px;
  letter-spacing: 0.20em;
  color: var(--brc-muted);
  margin-top: 5px;
  display: flex;
  gap: 6px;
  align-items: center;
  white-space: nowrap;
}
.brc-specimen-info .brc-bloom .brc-pip {
  width: 5px; height: 5px;
  background: var(--brc-accent);
  border-radius: 50%;
  flex-shrink: 0;
}
.brc-specimen-info .brc-bloom strong {
  color: var(--brc-accent);
  font-weight: 700;
}
