/* ==========================================================================
   THG Brand Book — components.css
   Component styles. Light-theme canonical. All values from tokens.css.
   No weird gradients on do/don't panels — clean borders, clean fills.
   ========================================================================== */


/* ----- Eyebrow (small uppercase label above a heading) ----------------- */
.eyebrow {
  display: inline-block;
  font-family: var(--font-accent);
  font-size: var(--fs-caption);
  line-height: var(--lh-caption);
  letter-spacing: var(--tracking-caption);
  text-transform: uppercase;
  color: var(--color-text-subtle);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-16);
}
.eyebrow--brand { color: var(--color-brand-text); }
.eyebrow--accent { color: var(--color-accent); }
.eyebrow--light { color: var(--c-paper-300); }


/* ----- Button (rounded-rect 12px — matches live site) ------------------ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-8);
  height: var(--button-height-md);
  padding-inline: var(--button-padding-x-md);
  border-radius: var(--button-radius);
  font-family: var(--font-sans);
  font-size: var(--fs-body-s);
  font-weight: var(--button-font-weight);
  letter-spacing: 0;
  cursor: pointer;
  transition:
    background-color var(--duration-fast) var(--ease-standard),
    color var(--duration-fast) var(--ease-standard),
    border-color var(--duration-fast) var(--ease-standard),
    transform var(--duration-fast) var(--ease-standard),
    box-shadow var(--duration-fast) var(--ease-standard);
  white-space: nowrap;
  border: 1px solid transparent;
  text-decoration: none;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; pointer-events: none; transform: none; }

.btn--primary {
  background: var(--color-brand);
  color: var(--color-text-on-brand);
  box-shadow: var(--shadow-soft);
}
.btn--primary:hover { background: var(--color-brand-hover); color: var(--color-text-on-brand); box-shadow: var(--shadow-md); }

.btn--accent {
  background: var(--color-accent-fill);
  color: var(--color-text-on-accent);
  box-shadow: var(--shadow-soft);
}
.btn--accent:hover { background: var(--color-accent-hover); color: var(--color-text-on-accent); box-shadow: var(--shadow-md); }

.btn--secondary {
  background: var(--color-surface);
  color: var(--color-heading);
  border-color: var(--color-border-strong);
}
.btn--secondary:hover { border-color: var(--color-heading); color: var(--color-heading); }

.btn--ghost {
  background: transparent;
  color: var(--color-heading);
}
.btn--ghost:hover { background: var(--color-surface-sunken); }

.btn--dark {
  background: var(--c-midnight-700);
  color: var(--color-text-inverse);
}
.btn--dark:hover { background: var(--c-midnight-800); color: var(--color-text-inverse); }

.btn--danger {
  background: var(--color-danger);
  color: var(--c-paper-white);
}
.btn--danger:hover { background: var(--c-error-500); color: var(--c-paper-white); }

.btn--sm { height: var(--button-height-sm); padding-inline: var(--button-padding-x-sm); font-size: var(--fs-caption); letter-spacing: 0.02em; text-transform: uppercase; }
.btn--lg { height: var(--button-height-lg); padding-inline: var(--button-padding-x-lg); font-size: var(--fs-body); }
.btn--pill { border-radius: var(--button-radius-pill); }


/* ----- Link / inline --------------------------------------------------- */
.link {
  color: var(--color-link);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--duration-fast) var(--ease-standard), color var(--duration-fast) var(--ease-standard);
}
.link:hover {
  color: var(--color-link-hover);
  border-bottom-color: currentColor;
}
.link-arrow {
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
  color: var(--color-link);
  font-weight: var(--fw-medium);
  text-decoration: none;
}
.link-arrow::after { content: "→"; transition: transform var(--duration-base) var(--ease-standard); }
.link-arrow:hover { color: var(--color-link-hover); }
.link-arrow:hover::after { transform: translateX(4px); }


/* ----- Card (white surface, soft shadow, 12px radius — live-site spec) - */
.card {
  background: var(--color-surface);
  border-radius: var(--card-radius);
  padding: var(--card-padding);
  box-shadow: var(--card-shadow);
  transition: box-shadow var(--duration-base) var(--ease-standard), transform var(--duration-base) var(--ease-standard);
}
.card:hover { box-shadow: var(--card-shadow-hover); }
.card--bordered { border: var(--hairline); box-shadow: none; }
.card--quiet { background: transparent; box-shadow: none; padding: 0; }
.card--tinted { background: var(--color-brand-muted); box-shadow: none; }
.card--dark {
  background: var(--c-midnight-700);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-lg);
}
.card--dark .card__title, .card--dark h1, .card--dark h2, .card--dark h3, .card--dark h4 { color: var(--color-text-inverse); }
.card--dark .card__body, .card--dark p { color: var(--c-paper-300); }
.card__title { font-size: var(--fs-heading-m); margin-bottom: var(--space-12); color: var(--color-heading); font-weight: var(--fw-semibold); }
.card__body { color: var(--color-text); font-size: var(--fs-body-s); line-height: var(--lh-body-s); }


/* ----- Input / Textarea / Select -------------------------------------- */
.field { display: block; }
.field + .field { margin-top: var(--space-16); }
.field__label {
  display: block;
  font-family: var(--font-accent);
  font-size: var(--fs-caption);
  letter-spacing: var(--tracking-caption);
  text-transform: uppercase;
  color: var(--color-text-subtle);
  font-weight: var(--fw-semibold);
  margin-bottom: var(--space-8);
}
.field__input,
.field__select,
.field__textarea {
  width: 100%;
  height: var(--input-height);
  padding-inline: var(--input-padding-x);
  background: var(--color-surface);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--input-radius);
  color: var(--color-heading);
  font-size: var(--fs-body);
  transition: border-color var(--duration-fast) var(--ease-standard), box-shadow var(--duration-fast) var(--ease-standard);
}
.field__textarea {
  height: auto;
  min-height: 120px;
  padding-block: var(--space-12);
  resize: vertical;
  line-height: 1.55;
}
.field__input:hover,
.field__select:hover,
.field__textarea:hover { border-color: var(--color-text-muted); }
.field__input:focus-visible,
.field__select:focus-visible,
.field__textarea:focus-visible {
  border-color: var(--color-focus-ring);
  outline: none;
  box-shadow: 0 0 0 3px rgba(17, 96, 50, 0.18);
}
.field__help {
  display: block;
  margin-top: var(--space-8);
  font-size: var(--fs-body-s);
  color: var(--color-text-subtle);
}
.field--error .field__input,
.field--error .field__select,
.field--error .field__textarea { border-color: var(--color-danger); }
.field--error .field__help { color: var(--color-danger); }


/* ----- Tag / Chip ----------------------------------------------------- */
.chip {
  display: inline-flex;
  align-items: center;
  gap: var(--space-4);
  padding: 6px 14px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  font-family: var(--font-sans);
  font-size: var(--fs-caption);
  letter-spacing: 0.04em;
  color: var(--color-heading);
  white-space: nowrap;
  font-weight: var(--fw-medium);
}
.chip--brand { color: var(--color-brand-text); border-color: var(--c-signal-green-200); background: var(--c-signal-green-50); }
.chip--accent { color: var(--color-accent); border-color: var(--c-signal-blue-200); background: var(--c-signal-blue-50); }
.chip--banned { color: var(--color-danger); border-color: var(--c-error-200); background: var(--c-error-50); text-decoration: line-through; text-decoration-color: var(--color-danger); text-decoration-thickness: 1px; }


/* ----- Stat ----------------------------------------------------------- */
.stat__label {
  font-family: var(--font-accent);
  font-size: var(--fs-caption);
  letter-spacing: var(--tracking-caption);
  text-transform: uppercase;
  color: var(--color-text-subtle);
  margin-bottom: var(--space-8);
  display: block;
  font-weight: var(--fw-semibold);
}
.stat__number {
  font-size: var(--fs-display-l);
  line-height: var(--lh-display-l);
  font-weight: var(--fw-bold);
  color: var(--color-heading);
  letter-spacing: -0.02em;
  display: block;
}
.stat__number--brand { color: var(--color-brand-text); }
.stat__caption {
  font-size: var(--fs-body-s);
  color: var(--color-text-muted);
  margin-top: var(--space-4);
}


/* ----- Pull-quote ----------------------------------------------------- */
.pullquote {
  font-family: var(--font-display);
  font-size: var(--fs-display-m);
  line-height: var(--lh-display-m);
  font-weight: var(--fw-medium);
  letter-spacing: var(--tracking-heading);
  color: var(--color-heading);
  border-left: 3px solid var(--color-brand);
  padding-left: var(--space-32);
  margin-block: var(--space-32);
  max-width: 38ch;
}
.pullquote cite {
  display: block;
  margin-top: var(--space-12);
  font-family: var(--font-accent);
  font-size: var(--fs-caption);
  letter-spacing: var(--tracking-caption);
  text-transform: uppercase;
  color: var(--color-text-subtle);
  font-style: normal;
  font-weight: var(--fw-semibold);
}


/* ----- Accordion ------------------------------------------------------ */
.accordion {
  border-top: var(--hairline);
}
.accordion summary {
  list-style: none;
  cursor: pointer;
  padding-block: var(--space-16);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-16);
  font-size: var(--fs-heading-s);
  font-weight: var(--fw-semibold);
  color: var(--color-heading);
}
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary::after {
  content: "+";
  font-family: var(--font-sans);
  font-size: 1.5rem;
  line-height: 1;
  color: var(--color-text-subtle);
  transition: transform var(--duration-base) var(--ease-standard);
}
.accordion[open] summary::after { content: "−"; }
.accordion summary:hover { color: var(--color-brand-text); }
.accordion__panel {
  padding-bottom: var(--space-32);
  color: var(--color-text);
}
