/* ==========================================================================
   Components - buttons, badges, cards, panels, stats, charts shell
   ========================================================================== */

/* --- Buttons ---------------------------------------------------------- */
.btn {
  --btn-bg: var(--c-ink);
  --btn-fg: var(--c-white);
  display: inline-flex;
  align-items: center;
  gap: var(--sp-3);
  padding: .85em 1.6em;
  font-family: var(--font-sans);
  font-weight: 700;
  font-size: var(--fs-400);
  letter-spacing: .02em;
  text-transform: uppercase;
  color: var(--btn-fg);
  background: var(--btn-bg);
  border-radius: var(--radius-pill);
  transition: transform var(--dur-fast) var(--ease-out), background var(--dur-fast) var(--ease-out), color var(--dur-fast) var(--ease-out), box-shadow var(--dur-fast) var(--ease-out);
}
.btn:hover { color: var(--btn-fg); transform: translateY(-2px); }
.btn:active { transform: translateY(0) scale(.985); transition-timing-function: var(--ease-press); transition-duration: 90ms; }
.btn .btn__peak {
  width: .6em; height: .6em; flex: none;
  background: currentColor;
  clip-path: polygon(0 0, 100% 50%, 0 100%); /* right-pointing */
  transition: transform var(--dur) var(--ease-out);
}
.btn:hover .btn__peak { transform: translateX(3px); }

.btn--green   { --btn-bg: var(--c-green); --btn-fg: var(--c-ink); }
.btn--green:hover { background: var(--c-green-deep); }
.btn--invert  { --btn-bg: var(--c-white); --btn-fg: var(--c-ink); }
.btn--outline {
  --btn-bg: transparent; --btn-fg: currentColor;
  box-shadow: inset 0 0 0 2px currentColor;
}
.btn--outline:hover { --btn-bg: var(--c-green); color: var(--c-ink); box-shadow: inset 0 0 0 2px var(--c-green); }
.btn--lg { font-size: var(--fs-450); padding: .9em 1.7em; }
.btn--sm { font-size: var(--fs-300); padding: .65em 1.2em; }

/* Text link with peak marker - sentence case (friendlier than all-caps). */
.link-peak {
  display: inline-flex; align-items: center; gap: .5em;
  font-family: var(--font-sans); font-weight: var(--weight-semibold);
  letter-spacing: 0;
  font-size: var(--fs-450);
  color: var(--c-green-text);
}
.section--ink .link-peak, .section--black .link-peak { color: var(--c-green); }
.link-peak::after {
  content: ""; width: .52em; height: .52em;
  background: currentColor;
  clip-path: polygon(0 0, 100% 50%, 0 100%); /* right-pointing */
  transition: transform var(--dur) var(--ease-out);
}
.link-peak:hover { color: var(--c-green-text); }
.link-peak:hover::after { transform: translateX(3px); }
.section--ink .link-peak:hover, .section--black .link-peak:hover { color: var(--c-white); }

/* --- Pill badge (POSITION A / OUR PURPOSE style) ---------------------- */
.badge {
  display: inline-block;
  padding: .4em 1.1em;
  font-family: var(--font-sans); font-weight: 700;
  font-size: var(--fs-300); letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--c-white);
  background: var(--c-ink);
  border-radius: var(--radius-pill);
}
.badge--green { background: var(--c-green); color: var(--c-ink); }

/* --- Interaction states (shared) -------------------------------------- *
   Tasteful only: a small lift, a clear keyboard ring, press feedback on touch.
   No glow, no scale-up bounce. */
.sire-card, .lot-card, .news-card, .team-card, .contact-point, .chart-card {
  transition: transform var(--dur) var(--ease-out), box-shadow var(--dur) var(--ease-out);
}
@media (hover: hover) {
  .sire-card:hover, .lot-card:hover, .news-card:hover { transform: translateY(-3px); }
}
/* Keyboard focus: ring the whole card when a link inside is focused. */
.sire-card:focus-within, .lot-card:focus-within, .news-card:focus-within {
  outline: 3px solid var(--c-green); outline-offset: 4px; border-radius: var(--radius-sm);
}
.sire-card a:focus-visible, .lot-card a:focus-visible, .news-card a:focus-visible,
.news-card__link:focus-visible { outline: none; } /* ring lives on the card */
/* Press feedback on touch devices. */
@media (hover: none) {
  .sire-card:active, .lot-card:active, .news-card:active { transform: scale(.99); }
}

/* --- Cards / panels --------------------------------------------------- */
.card {
  position: relative;
  background: var(--c-white);
  border-radius: var(--radius);
  padding: clamp(1.5rem, 1rem + 1.5vw, 2.5rem);
  box-shadow: var(--shadow-sm);
  height: 100%;
}
.section--ink .card, .section--black .card {
  background: rgba(255,255,255,.04);
  box-shadow: none;
  border: 1px solid var(--c-border-dark);
  color: var(--c-text-invert);
}
.card__title { font-family: var(--font-sans); font-weight: 700; font-size: var(--fs-600); margin-bottom: var(--sp-3); }
.card__num {
  font-family: var(--font-display);
  font-size: var(--fs-700);
  color: var(--c-green-text);
  line-height: 1;
  margin-bottom: var(--sp-3);
}

/* Panel with top green rule (deck "WHOLESALE/RETAIL" style) */
.panel {
  background: var(--c-grey-50);
  border-radius: var(--radius);
  padding: clamp(1.25rem, 1rem + 1vw, 2rem);
}
.panel__rule { width: 56px; height: 4px; background: var(--c-green); margin-bottom: var(--sp-4); }

/* Pillar item (icon-ish peak + title + copy) */
.pillar { display: grid; gap: var(--sp-3); }
.pillar__badge { justify-self: start; }

/* --- Stat callouts ---------------------------------------------------- */
.stat { display: grid; gap: var(--sp-1); }
.stat__value {
  font-family: var(--font-display);
  font-weight: var(--weight-heading);
  font-size: var(--fs-800);
  line-height: 1;
  letter-spacing: var(--tracking-display);
  color: var(--c-ink);
}
.section--ink .stat__value, .section--black .stat__value, .section--green .stat__value { color: inherit; }
.stat__value .unit { font-size: .5em; }
.stat__label {
  font-family: var(--font-sans); font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  font-size: var(--fs-300); color: var(--c-text-muted);
}
.section--ink .stat__label, .section--black .stat__label { color: rgba(255,255,255,.7); }
/* Stats render on dark sections - use the bright signal green there, and the
   AA text-green only when a stat sits on a light surface. */
.stat--green .stat__value { color: var(--c-green); }
.section--alt .stat--green .stat__value,
.stat-section:not(.section--ink):not(.section--black):not(.section--green) .stat--green .stat__value { color: var(--c-green-text); }

/* --- Quote / statement band ------------------------------------------- */
.statement {
  font-family: var(--font-display);
  font-weight: var(--weight-heading);
  font-size: var(--fs-800);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-display);
  max-width: 30ch;
}
.statement--lg { font-size: var(--fs-900); }
.statement .accent { color: var(--c-green); }

/* --- Divider peak row ------------------------------------------------- */
.peak-rule {
  display: flex; align-items: center; gap: var(--sp-3);
  color: var(--c-green);
}
.peak-rule::before, .peak-rule::after {
  content: ""; height: 2px; flex: 1; background: currentColor; opacity: .4;
}
.peak-rule__mark { width: 14px; height: 14px; background: currentColor; clip-path: polygon(50% 0, 100% 100%, 0 100%); flex: none; }

/* --- Tag list --------------------------------------------------------- */
.tags { display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.tag {
  font-size: var(--fs-300); font-weight: 600;
  padding: .35em .9em; border-radius: var(--radius-pill);
  background: var(--c-grey-100); color: var(--c-grey-600);
}

/* --- Bullet list with peak markers ------------------------------------ */
.peak-list { display: grid; gap: var(--sp-3); }
.peak-list li { position: relative; padding-left: 1.8em; }
.peak-list li::before {
  content: ""; position: absolute; left: 0; top: .45em;
  width: .7em; height: .7em; background: var(--c-green);
  clip-path: polygon(50% 0, 100% 100%, 0 100%);
}
