/* =============================================
   identify.css  v1
   Shared layout for identify.html + identify-chart.html.
   Load order: main.css → species.css → identify.css
   Tokens, fonts, and global components
   (np-cta, char-sign, info-card, matrix, chip,
   dividers, species-banner) all come from main.css.
   This file owns identify-funnel structure only.
   ============================================= */

/* ── Station signs (char-sign is scoped to
      body#species-page in main.css; mirror it here) ── */
body#identify-page .char-sign {
  font-family: 'National Park', Arial, sans-serif;
  font-weight: 500;
  font-size: 36px;
  line-height: 40px;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: #f8f4ea;
  background: #3f2805;
  padding: 10px 22px;
  display: inline-block;
}
body#identify-page .char-sign-row {
  text-align: center;
  margin: 20px 0 12px;
}
@media (max-width: 560px) {
  body#identify-page .char-sign { font-size: 20px; line-height: 24px; }
}

/* ── Section shell ───────────────────────────── */
.id-section {
  max-width: 1200px;
  margin: 0 auto;
  padding: 10px 20px 30px;
}

.id-section .sp-heading { margin-top: 18px; }

/* Light prose on the dark body */
.id-lead {
  max-width: 780px;
  margin: 14px auto 6px;
  text-align: center;
  color: var(--sp-light, #e8dfc8);
  font-family: 'Raleway', sans-serif;
  font-size: 1.05rem;
  line-height: 1.7;
}

.id-lead strong { color: var(--sp-gold, #d3a90f); }

.id-note {
  max-width: 720px;
  margin: 10px auto 0;
  text-align: center;
  color: var(--sp-muted, #c8b898);
  font-family: 'Raleway', sans-serif;
  font-size: 0.92rem;
  line-height: 1.6;
}

/* list-block ink fix: species.css scopes dark text to
   .sp-section; mirror for .id-section */
.id-section .list-block p,
.id-section .list-block li,
.id-section .list-block strong {
  color: var(--sp-body-ink, #2d2d2b);
}

/* ── Gate / habitat cards (3-across) ─────────── */
.id-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  max-width: 1100px;
  margin: 22px auto 0;
}

.id-card {
  background: var(--sp-parchment, #f7f2e4);
  border-radius: 12px;
  padding: 20px 22px 18px;
  color: var(--sp-body-ink, #2d2d2b);
  font-family: 'Raleway', sans-serif;
}

.id-card h3 {
  font-family: 'National Park', Arial, sans-serif;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 1.05rem;
  color: var(--sp-label, #7A463A);
  margin: 0 0 8px;
}

.id-card p {
  font-size: 0.92rem;
  line-height: 1.6;
  margin: 0 0 8px;
}

.id-card .id-card-verdict {
  font-weight: 600;
  color: #1e4e03;
}

.id-card a { color: var(--sp-label, #7A463A); }

.id-card-grid--four {
  grid-template-columns: repeat(4, 1fr);
  max-width: 1200px;
}

/* ── One-glance key ──────────────────────────── */
.id-key-step {
  background: var(--sp-parchment, #f7f2e4);
  border-left: 8px solid var(--sp-accent, #d37e0f);
  border-radius: 10px;
  max-width: 980px;
  margin: 20px auto;
  padding: 22px 28px 24px;
  color: var(--sp-body-ink, #2d2d2b);
  font-family: 'Raleway', sans-serif;
}

.id-key-stepnum {
  display: inline-block;
  font-family: 'National Park', Arial, sans-serif;
  font-weight: 700;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: var(--sp-bg, #1b1606);
  color: var(--sp-gold, #d3a90f);
  border-radius: 4px;
  padding: 4px 12px;
  margin-bottom: 8px;
}

.id-key-q {
  font-family: 'National Park', Arial, sans-serif;
  font-size: 1.5rem;
  line-height: 1.25;
  margin: 4px 0 14px;
  color: #1b1606;
}

.id-key-branches {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.id-key-branch {
  background: #fffdf4;
  border: 1px solid var(--sp-panel-border, #ddd5c2);
  border-radius: 8px;
  padding: 12px;
}

.id-key-branch img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 6px;
}

.id-key-cue {
  font-weight: 600;
  font-size: 0.95rem;
  margin: 10px 0 2px;
  color: #1b1606;
}

.id-key-verdict {
  font-size: 0.92rem;
  line-height: 1.5;
  margin: 0;
}

.id-key-verdict strong { color: var(--sp-label, #7A463A); }

/* ── Trait stations (4-across squares) ───────── */
.id-station-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  margin: 20px auto 4px;
}

.id-station-grid figure {
  margin: 0;
  background: var(--sp-parchment, #f7f2e4);
  border-radius: 10px;
  padding: 10px 10px 8px;
}

.id-station-grid img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 6px;
}

.id-station-grid figcaption {
  font-family: 'Raleway', sans-serif;
  font-size: 0.85rem;
  line-height: 1.45;
  text-align: center;
  color: var(--sp-body-ink, #2d2d2b);
  padding-top: 8px;
}

.id-station-grid figcaption strong {
  display: block;
  color: var(--sp-label, #7A463A);
}

/* Two-across variant (Western vs Eastern station) */
.id-station-grid.id-station-grid--pair {
  grid-template-columns: repeat(2, 1fr);
  max-width: 820px;
}

/* ── Wide banner images ──────────────────────── */
.id-banner-fig {
  margin: 22px auto 0;
  max-width: 1100px;
}

.id-banner-fig img {
  display: block;
  width: 100%;
  border-radius: 8px;
}

.id-banner-fig figcaption {
  font-family: 'Raleway', sans-serif;
  font-size: 0.88rem;
  text-align: center;
  color: var(--sp-muted, #c8b898);
  padding-top: 8px;
}

/* ── Range map callout panel ─────────────────── */
.id-range-callout {
  max-width: 820px;
  margin: 22px auto 6px;
  background: var(--sp-bg, #1b1606);
  border: 3px solid var(--sp-accent, #d37e0f);
  border-radius: 16px;
  padding: 36px 44px 32px;
  text-align: center;
  box-shadow: 0 4px 32px rgba(211, 126, 15, 0.18);
}

.id-range-callout-icon {
  font-size: 2.2rem;
  line-height: 1;
  margin-bottom: 12px;
}

.id-range-callout-heading {
  font-family: 'National Park', Arial, sans-serif;
  font-size: clamp(1.6rem, 3vw, 2.4rem);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--sp-accent, #d37e0f);
  margin: 0 0 16px;
}

.id-range-callout-body {
  font-family: 'Raleway', sans-serif;
  font-size: 1.05rem;
  line-height: 1.75;
  color: var(--sp-light, #e8dfc8);
  max-width: 640px;
  margin: 0 auto 12px;
}

.id-range-callout-hint {
  font-family: 'Raleway', sans-serif;
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--sp-muted, #c8b898);
  max-width: 580px;
  margin: 0 auto 22px;
  font-style: italic;
}

@media (max-width: 600px) {
  .id-range-callout { padding: 24px 20px 22px; }
}

/* ── CTA row ─────────────────────────────────── */
.id-cta-row {
  text-align: center;
  margin: 26px auto 6px;
}

/* ── Photo credits ───────────────────────────── */
sup.id-ref {
  font-size: 0.62em;
  color: var(--sp-accent, #d37e0f);
  font-weight: 700;
}

.id-credits {
  max-width: 900px;
  margin: 10px auto 0;
  color: var(--sp-muted, #c8b898);
  font-family: 'Raleway', sans-serif;
  font-size: 0.85rem;
  line-height: 1.6;
}

.id-credits h2 {
  font-family: 'National Park', Arial, sans-serif;
  font-size: 1rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--sp-muted, #c8b898);
  margin-bottom: 8px;
}

.id-credits ol {
  margin: 0;
  padding-left: 22px;
}

.id-credits a { color: var(--sp-muted, #c8b898); }

/* ── Species doorway cards ───────────────────────
      Mirrors the body#species-page card-banner rules
      in species.css for the identify page. ── */
body#identify-page .species-banner {
  --species-card-gap: 24px;
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--species-card-gap);
  align-items: start;
  justify-items: center;
  width: min(90vw, 1280px);
  margin: 24px auto 40px;
  padding: 0;
}

body#identify-page .species-card {
  width: 100%;
  max-width: 260px;
  text-align: center;
}

body#identify-page .species-card .glass-frame2 {
  display: block !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  margin: 0 !important;
  padding: 10px !important;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.22) !important;
  box-shadow: 0 4px 14px rgba(255, 255, 255, 0.18);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

body#identify-page .species-card .glass-frame2 img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  height: auto;
  object-fit: cover;
  border-radius: 8px;
  margin: 0;
}

body#identify-page .species-card-label {
  margin-top: 10px;
  text-align: center;
}

body#identify-page .species-name {
  display: block;
  font-family: 'National Park', Arial, sans-serif;
  font-weight: 700;
  font-size: clamp(0.9rem, 1.2vw, 1.05rem);
  line-height: 1.2;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: rgba(245, 232, 198, 0.96);
  text-shadow: 0 2px 8px rgba(0,0,0,0.85);
}

body#identify-page .species-status {
  display: block;
  margin-top: 3px;
  font-family: 'Raleway', Arial, sans-serif;
  font-size: 0.74rem;
  line-height: 1.2;
  letter-spacing: 0.09em;
  text-transform: uppercase;
  text-shadow: 0 2px 6px rgba(0,0,0,0.85);
}

body#identify-page .native-status     { color: #c7e489; }
body#identify-page .introduced-status { color: #e8a87c; }

@media (max-width: 900px) {
  body#identify-page .species-banner {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: min(92vw, 620px);
  }
}

/* ── Responsive ──────────────────────────────── */
@media (max-width: 980px) {
  .id-card-grid { grid-template-columns: 1fr; max-width: 560px; }
  .id-station-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 560px) {
  .id-key-branches { grid-template-columns: 1fr; }
  .id-key-q { font-size: 1.25rem; }
  .id-station-grid.id-station-grid--pair { grid-template-columns: 1fr; }
}
