/* ═══════════════════════════════════════════════════════
   Generic pages + post body rich text.
   Handles: about, contact, generic WP pages, single blog post body,
   FAQ sections, rich editor output (.entry-content).
   ═══════════════════════════════════════════════════════ */

/* ─── Entry content — WordPress post/page body ────── */
.entry-content {
  max-width: 65ch;
  margin-inline: auto;
  color: var(--color-text);
}

.entry-content > * + * { margin-top: var(--space-5); }

.entry-content h2 {
  font-family: var(--font-display);
  font-size: var(--text-display-s);
  font-weight: var(--weight-regular);
  line-height: var(--lh-tight);
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
  letter-spacing: var(--tracking-snug);
}

.entry-content h3 {
  font-family: var(--font-body);
  font-size: var(--text-heading-l);
  font-weight: var(--weight-semibold);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}

.entry-content h4 {
  font-family: var(--font-body);
  font-size: var(--text-heading-m);
  font-weight: var(--weight-semibold);
  margin-top: var(--space-6);
  margin-bottom: var(--space-2);
}

.entry-content p {
  font-size: var(--text-body-l);
  line-height: var(--lh-body);
  max-width: 65ch;
  color: var(--color-text);
  margin: 0 0 var(--space-5);
}

.entry-content > p:first-of-type { font-weight: var(--weight-medium); }

.entry-content ul,
.entry-content ol {
  padding-left: var(--space-6);
  margin: 0 0 var(--space-5);
}

.entry-content li {
  font-size: var(--text-body-m);
  line-height: var(--lh-body);
  margin-bottom: var(--space-2);
}

.entry-content blockquote {
  border-left: 3px solid var(--color-brand);
  padding-left: var(--space-6);
  margin: var(--space-10) 0;
  font-family: var(--font-display);
  font-size: var(--text-display-s);
  font-style: italic;
  line-height: var(--lh-subhead);
  color: var(--color-text-secondary);
}

.entry-content img,
.entry-content figure img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  display: block;
  margin: var(--space-8) 0;
}

.entry-content figure { margin: var(--space-8) 0; }

.entry-content figcaption {
  font-size: var(--text-caption);
  color: var(--color-text-secondary);
  text-align: center;
  margin-top: var(--space-2);
}

.entry-content a {
  color: var(--color-text-brand);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.entry-content a:hover { color: var(--color-brand-hover); }

.entry-content hr {
  margin: var(--space-10) 0;
  border: 0;
  border-top: 1px solid var(--color-border-mid);
}

.entry-content .img--wide {
  width: 100vw;
  margin-inline: calc(var(--container-px) * -1);
  max-width: none;
  border-radius: 0;
}

/* ─── Author card ─────────────────────────────────── */
.author-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-5);
  padding: var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  margin-block: var(--space-10);
  max-width: 65ch;
  margin-inline: auto;
}

.author-card__avatar {
  width: 64px;
  height: 64px;
  border-radius: var(--radius-full);
  background: var(--color-brand-subtle);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
  font-size: var(--text-heading-l);
  color: var(--color-brand-hover);
}

.author-card__name {
  font-size: var(--text-body-m);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin: 0;
}

.author-card__role {
  font-size: var(--text-overline);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-secondary);
  margin-top: var(--space-1);
}

.author-card__bio {
  font-size: var(--text-body-s);
  color: var(--color-text-secondary);
  line-height: var(--lh-body);
  margin-top: var(--space-3);
}

/* ─── FAQ (native <details>) ──────────────────────── */
.faq {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.faq__item {
  padding: var(--space-5) var(--space-6);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.faq__item[open] {
  border-color: var(--color-border-mid);
  box-shadow: var(--shadow-sm);
}

.faq__item summary {
  list-style: none;
  cursor: pointer;
  font-family: var(--font-body);
  font-size: var(--text-body-l);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
}

.faq__item summary::-webkit-details-marker { display: none; }

.faq__item summary::after {
  content: "";
  width: 12px;
  height: 12px;
  border-right: 2px solid var(--color-brand);
  border-bottom: 2px solid var(--color-brand);
  transform: rotate(45deg);
  transition: transform var(--duration-base) var(--ease-out);
  flex-shrink: 0;
}

.faq__item[open] summary::after { transform: rotate(-135deg); }

.faq__answer {
  padding-top: var(--space-4);
  color: var(--color-text-secondary);
  font-size: var(--text-body-m);
  line-height: var(--lh-body);
}

/* ─── Contact layout ──────────────────────────────── */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-10);
}

@media (min-width: 1024px) {
  .contact-layout {
    grid-template-columns: 5fr 7fr;
    gap: var(--space-16);
    align-items: start;
  }
}

.contact-info {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.contact-channel {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: inherit;
  transition:
    border-color var(--duration-fast) var(--ease-out),
    box-shadow var(--duration-fast) var(--ease-out);
}

.contact-channel:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
  color: inherit;
}

.contact-channel__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  background: var(--color-brand-subtle);
  color: var(--color-brand-hover);
  border-radius: var(--radius-md);
}

.contact-channel__icon svg {
  width: 20px;
  height: 20px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.contact-channel__label {
  font-size: var(--text-overline);
  font-weight: var(--weight-semibold);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
  color: var(--color-text-secondary);
}

.contact-channel__value {
  font-size: var(--text-body-m);
  font-weight: var(--weight-medium);
  color: var(--color-text);
  margin-top: var(--space-1);
  display: block;
}

/* Form grid helpers */
.form-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
}

@media (min-width: 768px) {
  .form-grid--two { grid-template-columns: repeat(2, 1fr); }
}

/* ─── About — value cards ─────────────────────────── */
.about-values {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .about-values { grid-template-columns: repeat(3, 1fr); }
}

.value-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  padding: var(--space-8);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}

.value-card__number {
  font-family: var(--font-display);
  font-size: var(--text-display-s);
  font-weight: var(--weight-regular);
  color: var(--color-brand);
  line-height: 1;
}

.value-card__heading {
  font-family: var(--font-body);
  font-size: var(--text-heading-s);
  font-weight: var(--weight-semibold);
  color: var(--color-text);
  margin: 0;
}

.value-card__body {
  font-size: var(--text-body-s);
  color: var(--color-text-secondary);
  line-height: var(--lh-body);
}

/* Stats inline row */
.stats-inline {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .stats-inline { grid-template-columns: repeat(4, 1fr); }
}

.stats-inline .stat {
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  text-align: left;
  padding: var(--space-5) 0;
  border-top: 1px solid var(--color-border);
}

.stats-inline .stat__value {
  font-family: var(--font-display);
  font-size: var(--text-display-m);
  font-weight: var(--weight-regular);
  color: var(--color-brand);
  line-height: 1;
}

.stats-inline .stat__label {
  font-size: var(--text-overline);
  font-weight: var(--weight-semibold);
  color: var(--color-text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--tracking-widest);
}

/* ─── 404 ─────────────────────────────────────────── */
.error-404 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-6);
  padding-block: var(--space-20);
  text-align: center;
  max-width: 640px;
  margin-inline: auto;
}

.error-404__code {
  font-family: var(--font-display);
  font-size: clamp(6rem, 18vw, 12rem);
  font-weight: var(--weight-regular);
  color: var(--color-brand);
  line-height: 1;
  letter-spacing: var(--tracking-tight);
}

.error-404__heading {
  font-family: var(--font-display);
  font-size: var(--text-display-m);
  font-weight: var(--weight-regular);
  color: var(--color-text);
  margin: 0;
}

.error-404__body {
  font-size: var(--text-body-l);
  color: var(--color-text-secondary);
  max-width: 52ch;
}

/* ─── Post archive grid (blog) ────────────────────── */
.posts-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
}

@media (min-width: 768px) {
  .posts-grid { grid-template-columns: repeat(2, 1fr); gap: var(--space-8); }
}

@media (min-width: 1280px) {
  .posts-grid { grid-template-columns: repeat(3, 1fr); }
}
