/*
 * WFP Editorial Module
 * Article layout, bylines, single post, author pages.
 */

/* =============================================================================
   SINGLE ARTICLE LAYOUT
   ============================================================================= */

.wfp-article {
  max-width: var(--wfp-prose-width);
  margin-left: auto;
  margin-right: auto;
}

.wfp-article__header {
  margin-bottom: var(--space-l);
}

.wfp-article__kicker {
  display: inline-block;
  font-size: var(--wfp-kicker-size);
  font-weight: var(--wfp-kicker-weight);
  color: var(--wfp-kicker-color);
  text-transform: uppercase;
  letter-spacing: var(--wfp-kicker-spacing);
  text-decoration: none;
  margin-bottom: var(--space-xs);
  line-height: 1;
}

.wfp-article__title {
  font-size: var(--step-4);
  font-weight: 800;
  line-height: 1.1;
  letter-spacing: -0.025em;
  color: var(--contrast);
  margin: 0 0 var(--space-xs);
}

.wfp-article__deck {
  font-size: var(--step-1);
  color: var(--contrast-2);
  line-height: 1.4;
  margin: 0 0 var(--space-s);
  font-weight: 400;
}

/* =============================================================================
   BYLINE
   ============================================================================= */

.wfp-byline {
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  font-size: var(--wfp-byline-size);
  color: var(--wfp-byline-color);
  padding: var(--space-xs) 0;
  border-top: var(--border);
  border-bottom: var(--border);
  flex-wrap: wrap;
}

.wfp-byline__avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  object-fit: cover;
  background: var(--base-2);
  flex-shrink: 0;
}

.wfp-byline__info {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.wfp-byline__author {
  font-weight: 700;
  color: var(--contrast);
  text-decoration: none;
  line-height: 1.2;
}

.wfp-byline__author:hover {
  color: var(--accent);
}

.wfp-byline__titles {
  font-size: var(--step--2);
  color: var(--contrast-3);
  line-height: 1.2;
}

.wfp-byline__meta {
  margin-left: auto;
  text-align: right;
  flex-shrink: 0;
  font-size: var(--step--2);
}

.wfp-byline__date {
  color: var(--contrast-3);
  white-space: nowrap;
}

/* Multiple contributors */
.wfp-byline__contributors {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
}

.wfp-byline__contributor {
  display: flex;
  align-items: center;
  gap: var(--space-2xs);
}

/* =============================================================================
   FEATURED IMAGE
   ============================================================================= */

.wfp-article__featured-image {
  margin-bottom: var(--space-l);
  border-radius: var(--radius);
  overflow: hidden;
}

.wfp-article__featured-image img {
  width: 100%;
  height: auto;
  display: block;
}

.wfp-article__caption {
  font-size: var(--step--2);
  color: var(--contrast-3);
  margin-top: var(--space-2xs);
  line-height: 1.4;
}

.wfp-article__photo-credit {
  font-size: var(--step--2);
  color: var(--contrast-3);
  margin-top: var(--space-3xs);
  font-style: italic;
}

/* =============================================================================
   ARTICLE BODY / PROSE
   ============================================================================= */

.wfp-article__body {
  font-size: var(--step-0);
  line-height: 1.75;
  color: var(--contrast);
}

.wfp-article__body > * + * {
  margin-top: var(--space-s);
}

.wfp-article__body h2 {
  font-size: var(--step-3);
  margin-top: var(--space-xl);
}

.wfp-article__body h3 {
  font-size: var(--step-2);
  margin-top: var(--space-l);
}

/* Pull quote */
.wfp-pull-quote {
  font-size: var(--step-2);
  font-weight: 700;
  color: var(--contrast);
  border-left: 4px solid var(--accent);
  padding: var(--space-xs) var(--space-m);
  margin: var(--space-l) 0;
  line-height: 1.3;
  font-style: italic;
}

/* =============================================================================
   ARTICLE FOOTER
   ============================================================================= */

.wfp-article__footer {
  margin-top: var(--space-2xl);
  padding-top: var(--space-l);
  border-top: var(--border);
}

.wfp-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2xs);
  margin-bottom: var(--space-m);
}

.wfp-tag {
  display: inline-block;
  padding: 0.25em 0.7em;
  background: var(--base-2);
  border: var(--border);
  border-radius: var(--radius-full);
  font-size: var(--step--2);
  color: var(--contrast-2);
  text-decoration: none;
  transition: background var(--transition-2), color var(--transition-2);
}

.wfp-tag:hover {
  background: var(--accent);
  color: var(--base-3);
  border-color: var(--accent);
}

/* =============================================================================
   AUTHOR BIO BOX
   ============================================================================= */

.wfp-author-box {
  display: flex;
  gap: var(--space-m);
  background: var(--base-2);
  border: var(--border);
  border-radius: var(--radius);
  padding: var(--space-m);
  margin-top: var(--space-2xl);
}

.wfp-author-box__avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--base-3);
}

.wfp-author-box__name {
  font-size: var(--step-1);
  font-weight: 700;
  margin: 0 0 var(--space-3xs);
}

.wfp-author-box__name a {
  color: inherit;
  text-decoration: none;
}

.wfp-author-box__name a:hover {
  color: var(--accent);
}

.wfp-author-box__title {
  font-size: var(--step--1);
  color: var(--accent);
  font-weight: 600;
  margin-bottom: var(--space-xs);
}

.wfp-author-box__bio {
  font-size: var(--step--1);
  color: var(--contrast-2);
  line-height: 1.6;
  margin: 0;
}

@media (max-width: 560px) {
  .wfp-author-box {
    flex-direction: column;
  }
}

/* =============================================================================
   RELATED STORIES
   ============================================================================= */

.wfp-related-stories {
  margin-top: var(--space-2xl);
}
