/* ==========================================================================
   記事詳細ページ（interview / tip）
   URL: /articles/{slug}
   テンプレ: page-templates/single-article.php
   ========================================================================== */

.article-detail {
  --article-detail-max: 860px;
  --article-detail-gutter: clamp(var(--space-4), 4vw, var(--space-10));
  color: var(--color-text-primary);
  background: var(--color-base-1);
}

.article-detail .container {
  max-width: var(--article-detail-max);
  margin-inline: auto;
  padding-inline: var(--article-detail-gutter);
}

/* --------------------------------------------------------------------------
   ヒーロー（インタビュー専用: 画像背景 + 左上プレート + 左下H1 + 外部メタ1行）
   -------------------------------------------------------------------------- */
.article-detail__hero-wrap {
  position: relative;
}

.article-detail__hero {
  position: relative;
  isolation: isolate;
  color: var(--color-text-inverse);
  overflow: hidden;
  min-height: 520px;
}

.article-detail__hero-bg {
  position: absolute;
  inset: 0;
  z-index: -1;
}

.article-detail__hero-img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  /* 既定は右寄り・中央。記事ごとに --hero-img-pos をインラインで上書き可能（ACF: hero_focus）。 */
  object-position: var(--hero-img-pos, 70% center);
}

.article-detail__hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(
      90deg,
      rgba(0, 0, 0, 0.45) 0%,
      rgba(0, 0, 0, 0.2) 45%,
      rgba(0, 0, 0, 0) 70%
    ),
    linear-gradient(
      180deg,
      rgba(0, 0, 0, 0.1) 0%,
      rgba(0, 0, 0, 0.35) 70%,
      rgba(0, 0, 0, 0.65) 100%
    );
}

/* ヒーロー内の .container は本文用の 860px 制約を上書きして 1200px 相当に */
.article-detail .article-detail__hero-inner {
  position: relative;
  max-width: 1200px;
  padding-block: var(--space-8);
  width: 100%;
  min-height: inherit;
}

/* 左上: 名前プレート（半透明ダーク・1行表示） */
.article-detail__hero-nameplate {
  display: inline-flex;
  align-items: baseline;
  flex-wrap: nowrap;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-4);
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  border-radius: var(--radius-sm);
  color: var(--color-text-inverse);
  white-space: nowrap;
  max-width: 100%;
  overflow: hidden;
}

/* INTERVIEW #010（小・通常ウェイト） */
.article-detail__hero-plate-label {
  display: inline-flex;
  align-items: baseline;
  gap: 0.3em;
  font-size: var(--font-size-xs);
  letter-spacing: 0.12em;
  opacity: 0.95;
}

.article-detail__hero-plate-type {
  color: var(--color-text-inverse);
}

.article-detail__hero-plate-no {
  color: var(--color-text-inverse);
  letter-spacing: 0.05em;
}

/* 対象者｜肩書（中サイズ） */
.article-detail__hero-plate-person {
  display: inline-flex;
  align-items: baseline;
  gap: 0.35em;
  font-size: var(--font-size-base);
  line-height: 1.3;
}

/* 対象者名のみ太字 */
.article-detail__hero-name {
  font-weight: var(--font-weight-bold);
}

.article-detail__hero-plate-sep {
  opacity: 0.6;
}

.article-detail__hero-role {
  opacity: 0.95;
}

/* H1: モバイル既定は通常フロー（ヒーロー外・白地ダーク文字） */
.article-detail__hero-title-box {
  padding-block: var(--space-6) var(--space-4);
}

.article-detail__hero-title {
  margin: 0;
  font-size: clamp(1.5rem, 5vw, 1.75rem);
  font-weight: 900;
  line-height: 1.5;
  letter-spacing: 0.01em;
  color: var(--color-text-primary);
}

/* PC: H1をヒーロー内左下に絶対配置（白抜き + text-shadow / 1行表示・右端まで） */
@media (min-width: 769px) {
  .article-detail__hero-title-box {
    position: absolute;
    left: 0;
    right: 0;
    bottom: var(--space-10);
    z-index: 2;
    padding-block: 0;
    pointer-events: none;
  }
  .article-detail__hero-title-box > .container {
    max-width: 1200px;
    pointer-events: auto;
  }
  .article-detail__hero-title {
    color: var(--color-text-inverse);
    font-size: clamp(1.75rem, 3.2vw, 2.5rem);
    line-height: 1.4;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  /* PC のみ プレートの対象者｜肩書を1段階大きく（INTERVIEW #010 は据え置き） */
  .article-detail__hero-plate-person {
    font-size: var(--font-size-lg);
  }
}

/* メタ1行（常にヒーロー外・本文幅で右寄せ） */
.article-detail__hero-meta {
  padding-block: var(--space-3) var(--space-6);
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
}

.article-detail__hero-meta .container {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  gap: var(--space-4);
}

.article-detail__hero-meta-item {
  display: inline-flex;
  align-items: center;
  gap: 0.4em;
}

/* 絵文字をモノクロ寄せ（彩度を抜いて落ち着かせる） */
.article-detail__hero-meta-icon {
  display: inline-flex;
  align-items: center;
  font-size: 1em;
  filter: grayscale(1);
  opacity: 0.75;
}

/* モバイル調整 */
@media (max-width: 768px) {
  .article-detail__hero {
    min-height: 360px;
  }
  .article-detail__hero-img {
    object-position: var(--hero-img-pos, 65% center);
  }
  .article-detail__hero-overlay {
    background:
      linear-gradient(
        180deg,
        rgba(0, 0, 0, 0.2) 0%,
        rgba(0, 0, 0, 0.4) 60%,
        rgba(0, 0, 0, 0.6) 100%
      );
  }
  .article-detail .article-detail__hero-inner {
    padding-block: var(--space-5);
  }
  .article-detail__hero-name {
    font-size: var(--font-size-base);
  }

  /* スマホ: ネームプレートのはみ出しテキストを左スライドして停止 */
  .article-detail__hero-nameplate {
    max-width: 100%;
    overflow: hidden;
  }
  .article-detail__hero-nameplate.is-marquee {
    display: block;
    padding-inline: 0;
  }
  .article-detail__hero-nameplate__track {
    display: inline-flex;
    align-items: baseline;
    gap: var(--space-3);
    padding-inline: var(--space-4);
    white-space: nowrap;
    /* 1s 待機後にスライド開始 → 最後の文字が見えたところで停止 */
    animation: iv-marquee-once var(--iv-marquee-duration, 6s) linear 1s 1 forwards;
  }
  @keyframes iv-marquee-once {
    from { transform: translateX(0); }
    to   { transform: translateX(calc(-1 * var(--iv-scroll-amount, 0px))); }
  }
}

/* コラム・Tips 用のチップ（ヘッダー内で使用） */
.article-detail__chip {
  display: inline-flex;
  align-items: center;
  padding: 0.25rem 0.75rem;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.08em;
  color: var(--color-text-inverse);
  background: var(--color-main);
  border-radius: var(--radius-full);
}

.article-detail__chip--interview {
  background: var(--color-main);
}

.article-detail__chip--tip {
  background: var(--color-accent-2);
}

/* --------------------------------------------------------------------------
   ヘッダー（コラム・Tips用 シンプル版） / アイキャッチ / 本文 / タグ
   -------------------------------------------------------------------------- */
.article-detail__header {
  padding-block: var(--space-10) var(--space-6);
  text-align: center;
}

/* 記事種別バッジとカテゴリバッジの並び（コラム・Tips ヘッダ冒頭）。
   中央揃えのまま inline-flex で横並びにする。カテゴリが無い記事でも
   .article-detail__type 単独レイアウトが崩れないよう margin-bottom を保持。 */
.article-detail__badges {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}

.article-detail__type {
  display: inline-block;
  padding: 2px var(--space-3);
  border-radius: var(--radius-full);
  background: var(--color-main);
  color: var(--color-text-inverse);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.04em;
}

.article-detail__type--tip {
  background: var(--color-accent-2);
}

/* コラム・Tips のカテゴリバッジ。記事種別バッジの右隣に並ぶアウトライン型。
   クリックでカテゴリ一覧へ遷移できるリンクにしている。 */
.article-detail__category {
  display: inline-block;
  padding: 2px var(--space-3);
  border: 1px solid var(--color-accent-2);
  border-radius: var(--radius-full);
  background: color-mix(in srgb, var(--color-accent-2) 6%, var(--color-base-1));
  color: var(--color-accent-2);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.04em;
  text-decoration: none;
  transition: background var(--transition-fast), color var(--transition-fast);
}

.article-detail__category:hover,
.article-detail__category:focus-visible {
  background: var(--color-accent-2);
  color: var(--color-text-inverse);
}

.article-detail__title {
  margin: 0 0 var(--space-4);
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  font-weight: 900;
  line-height: 1.4;
  letter-spacing: 0.01em;
}

.article-detail__meta {
  display: inline-flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
  line-height: 1.5;
}

.article-detail__date {
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.article-detail__read-min {
  display: inline-flex;
  align-items: center;
  gap: 0.35em;
  color: var(--color-text-secondary);
  font-size: var(--font-size-sm);
}

.article-detail__read-min-icon {
  font-size: 1em;
  line-height: 1;
}

.article-detail__eyecatch {
  max-width: 1000px;
  margin: 0 auto var(--space-10);
  padding-inline: var(--article-detail-gutter);
}

.article-detail__eyecatch-img,
.article-detail__eyecatch img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
  object-fit: cover;
}

.article-detail__content {
  padding-bottom: var(--space-12);
  font-size: var(--font-size-base);
  line-height: 1.95;
}

.article-detail__content .container > *:first-child {
  margin-top: 0;
}

.article-detail__tags {
  padding-bottom: var(--space-10);
}

.article-detail__tags .container {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}

/* 見出し「関連する記事を探す」（H4）: 行全幅・タグより上に出す */
.article-detail__tags-heading {
  width: 100%;
  margin: 0 0 var(--space-2);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-secondary);
  letter-spacing: 0.02em;
}

/* 相談詳細ページの「おすすめタグ」と同じビジュアルで揃える */
.article-detail__tags .tag-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 12px;
  border-radius: var(--radius-full);
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-bold);
  background: var(--color-thread-detail-pill-hash-bg);
  color: var(--color-thread-detail-muted);
  text-decoration: none;
  transition:
    background-color var(--transition-fast),
    color var(--transition-fast);
}

.article-detail__tags .tag-badge:hover {
  background: var(--color-border);
  color: var(--color-text-primary);
}

/* 記事末尾アクション（リアクション3種 + ブックマーク）。share の直前に配置 */
.article-detail__actions {
  padding-block: var(--space-8) var(--space-4);
}

.article-detail__actions .article-react-bar {
  margin: 0 auto;
}

.article-detail__share {
  padding-block: var(--space-6) var(--space-12);
  border-top: 1px solid var(--color-border-light);
}

/* ==========================================================================
   SNSシェア共通ブロック（.sns-share）
   他のポストタイプからも呼び出せる汎用コンポーネント
   ========================================================================== */
.sns-share {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin: 0;
  padding: 0;
}

.sns-share--inline {
  justify-content: flex-start;
  flex-wrap: wrap;
}

.sns-share--center {
  justify-content: center;
  flex-wrap: wrap;
}

.sns-share__label {
  font-size: var(--font-size-sm);
  color: var(--color-text-secondary);
  font-weight: var(--font-weight-medium);
}

.sns-share__list {
  display: flex;
  gap: var(--space-2);
  margin: 0;
  padding: 0;
  list-style: none;
}

.sns-share__item {
  margin: 0;
  padding: 0;
}

.sns-share__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  border: 0;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-text-primary);
  text-decoration: none;
  cursor: pointer;
  transition:
    transform var(--transition-fast),
    opacity var(--transition-fast);
}

.sns-share__btn img {
  width: 100%;
  height: 100%;
  display: block;
  pointer-events: none;
  border-radius: var(--radius-full);
}

.sns-share__btn:hover {
  transform: translateY(-1px);
  opacity: 0.85;
}

.sns-share__btn:focus-visible {
  outline: 2px solid var(--color-main);
  outline-offset: 3px;
}

/* URL コピーだけは PNG ではなく SVG アイコン + 白枠線の独自 UI を維持する */
.sns-share__btn--copy {
  background: var(--color-base-1);
  color: var(--color-text-primary);
  border: 1px solid var(--color-border);
}

.sns-share__btn--copy:hover {
  background: var(--color-surface-muted);
  opacity: 1;
}

/* ==========================================================================
   下部CTA（動画背景・白半透明マスク）
   → components/bottom-cta.css に分離（記事詳細・体験談詳細・ランキング末尾で共用）。
   ========================================================================== */

/* ==========================================================================
   関連セクション3本（.article-related）
   ========================================================================== */
.article-related {
  padding-block: var(--space-12);
  background: var(--color-base-1);
}

.article-related--interview {
  background: var(--color-base-2);
}

.article-related--thread {
  background: var(--color-base-1);
}

.article-related--tip {
  background: var(--color-surface-muted);
}

.article-related .container {
  max-width: var(--container-max);
  margin-inline: auto;
  padding-inline: var(--article-detail-gutter);
}

.article-related__heading {
  margin: 0 0 var(--space-6);
  font-size: var(--font-size-xl);
  font-weight: 900;
  color: var(--color-text-primary);
  text-align: left;
  position: relative;
  padding-left: var(--space-4);
}

.article-related__heading::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 4px;
  height: 1.25em;
  background: var(--color-main);
  border-radius: var(--radius-sm);
}

.article-related__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: var(--space-6);
}

/* 関連内の記事カード基礎（他所に article-card が無い場合の最小セット） */
.article-related .article-card {
  display: flex;
  flex-direction: column;
  background: var(--color-base-1);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: box-shadow var(--transition-fast), transform var(--transition-fast);
}

.article-related .article-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-2px);
}

.article-related .article-card__thumb {
  display: block;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-border-light);
}

.article-related .article-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.article-related .article-card__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
}

.article-related .article-card__type {
  align-self: flex-start;
  padding: 2px var(--space-2);
  border-radius: var(--radius-sm);
  background: var(--color-main);
  color: var(--color-text-inverse);
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-bold);
}

.article-related .article-card__type--tip {
  background: var(--color-accent-2);
}

.article-related .article-card__subject {
  margin: 0;
  font-size: var(--font-size-xs);
  font-weight: var(--font-weight-normal);
  color: var(--color-text-secondary);
  line-height: 1.4;
}

.article-related .article-card__title {
  margin: 0;
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
}

.article-related .article-card__title a {
  color: inherit;
  text-decoration: none;
}

.article-related .article-card__title a:hover {
  color: var(--color-main);
}

.article-related .article-card__date {
  font-size: var(--font-size-xs);
  color: var(--color-text-muted);
}

/* --------------------------------------------------------------------------
   関連する悩み・体験談: thread-card は category.css の .category-ranking-grid /
   .thread-card--home-rail スタイルをそのまま利用するため、ここでは何も上書きしない。
   -------------------------------------------------------------------------- */

/* --------------------------------------------------------------------------
   レスポンシブ
   -------------------------------------------------------------------------- */
@media (max-width: 768px) {
  .article-detail__header {
    padding-block: var(--space-8) var(--space-4);
  }

  .article-detail__eyecatch {
    margin-bottom: var(--space-8);
    border-radius: 0;
    padding-inline: 0;
  }

  .article-detail__eyecatch-img,
  .article-detail__eyecatch img {
    border-radius: 0;
  }

  .sns-share--inline {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-3);
  }

  .article-related__grid {
    grid-template-columns: 1fr;
  }
}
