@charset "UTF-8";

/* ==========================================================================
   メディアサイト (記事) スタイル — ミニマル・エディトリアル
   normalize → variables → base → common → ★media (記事系ページでのみ読込)

   設計方針 (de-AI / editorial):
     - 影・グラデーション・塗りピル・装飾枠は使わない
     - 区切りは 1px ヘアライン主体 / 背景は白基調
     - タイポグラフィと余白で構造を出す (見出しは大きく詰める)
     - 画像先行のカード (枠/影なし、hover はタイトル下線 + 画像微ズーム)
     - アクセント色 (blue) はリンク/ホバー/小さなラベルにだけ効かせる

   対象: single / archive / search / home(front-page) / 404
   SP 1 カラム / PC (>=900px) 本文 + サイドバーの 2 カラム
   ========================================================================== */

.media-site {
  /* ブランドカラー — 初心者向け金融/投資メディア (会社員・医療従事者・公務員)
     ・基調 = 爽やかなグリーン: 信頼 / 安心 / 成長。リンク・ラベル・アクセントに使用
     ・差し色 = 親しみのあるオレンジ: 行動喚起 (CTA / 主要ボタン)
     ・グリーン×オレンジで「安心して始められる」トーンを作る */
  --color-accent:      #149a63;        /* フレッシュグリーン (リンク/ラベル/アクセント) */
  --color-accent-rgb:  20, 154, 99;
  --media-accent-deep: #0f7a4e;        /* 濃グリーン (hover) */
  --media-tint:        #ecf7f1;        /* グリーンの淡い面 (帯/タグ等) */

  --media-cta:         #fb6b29;        /* オレンジ (CTA / 主要ボタン) */
  --media-cta-rgb:     251, 107, 41;
  --media-cta-deep:    #e85511;

  /* エディトリアル用ニュートラル */
  --media-head:  #1d2b25;             /* 締まった暖色寄りの濃色 (ほぼ黒・わずかに緑) */
  --media-line:  #e7e7e7;             /* 標準ヘアライン */
  --media-rule:  #1d2b25;             /* 強調ルール (濃い区切り) */
  --media-muted: var(--color-gray-500);
  --media-radius: 0.571rem;           /* ~8px: 角をやや丸めて親しみやすさを補強 */

  /* レイアウト幅 */
  --media-max:  1080px;
  --media-side: 18.5rem;              /* サイドバー列 (~260px) */
  --media-gap:  var(--space-5xl);     /* 本文⇄サイドバーの列間 (~48px) */

  color: var(--color-ink);
  background-color: var(--color-white);
}

/* サイドバーの position: sticky を有効にするための overflow 上書き。
   base.css の html/body { overflow-x: hidden } はスクロールコンテナを生成し、
   子孫の sticky 追従を無効化してしまう。スクロールコンテナを作らない
   `overflow-x: clip` に上書きすれば、横はみ出しは抑えつつ sticky が効く。 */
html:has(.media-site),
.media-site {
  overflow-x: clip;
}


/* ==========================================================================
   ヘッダー (l-siteheader) — 白 + 下ヘアライン、ナビは細字
   ========================================================================== */
.l-siteheader {
  position: sticky;
  top: 0;
  z-index: var(--z-header);
  width: 100%;
  background-color: var(--color-white);
  border-bottom: 1px solid var(--media-line);
}

.l-siteheader__inner {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  max-width: var(--media-max);
  margin-inline: auto;
  padding: var(--space-lg) var(--mobile-gutter);
}

.l-siteheader__logo { display: flex; align-items: center; line-height: 0; }
.l-siteheader__logo img { width: auto; height: 1.857rem; }

.l-siteheader__toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 0.357rem;
  width: 2.428rem;
  height: 2.428rem;
  padding: 0.5rem;
}

.l-siteheader__bar {
  display: block;
  width: 100%;
  height: 1.5px;
  background-color: var(--media-head);
  transition: transform var(--transition-base), opacity var(--transition-base);
}

.is-nav-open .l-siteheader__bar:nth-child(1) { transform: translateY(0.5rem) rotate(45deg); }
.is-nav-open .l-siteheader__bar:nth-child(2) { opacity: 0; }
.is-nav-open .l-siteheader__bar:nth-child(3) { transform: translateY(-0.5rem) rotate(-45deg); }

.l-sitenav {
  display: none;
  width: 100%;
  margin-top: var(--space-md);
  padding-top: var(--space-md);
  border-top: 1px solid var(--media-line);
}

.l-sitenav.is-open { display: block; animation: media-fadein 0.2s ease-out; }

.l-sitenav__list { display: flex; flex-direction: column; }

.l-sitenav__item + .l-sitenav__item { border-top: 1px solid var(--media-line); }

.l-sitenav__link {
  display: block;
  padding: var(--space-md) 0;
  font-size: var(--font-base);
  font-weight: var(--font-weight-medium);
  color: var(--media-head);
}
.l-sitenav__link:hover { color: var(--color-accent); opacity: 1; }


/* ==========================================================================
   本文 + サイドバー (l-media) / トップ (l-mediahome)
   ========================================================================== */
.l-media {
  display: flex;
  flex-direction: column;
  gap: var(--space-5xl);
  width: 100%;
  max-width: var(--media-max);
  margin-inline: auto;
  padding: var(--space-2xl) var(--mobile-gutter) var(--space-7xl);
}

.l-media__main {
  display: flex;
  flex-direction: column;
  gap: var(--space-4xl);
  min-width: 0;
}

.l-media__side {
  display: flex;
  flex-direction: column;
  gap: var(--space-4xl);
}

.l-mediahome {
  display: flex;
  flex-direction: column;
  gap: var(--space-7xl);
  width: 100%;
  max-width: var(--media-max);
  margin-inline: auto;
  padding: var(--space-3xl) var(--mobile-gutter) var(--space-7xl);
}


/* ==========================================================================
   フッター (l-sitefooter) — 余白広め・ヘアライン区切り (反転背景は使わない)
   ========================================================================== */
.l-sitefooter {
  width: 100%;
  border-top: 1px solid var(--media-line);
  background-color: var(--color-white);
}

.l-sitefooter__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2xl);
  max-width: var(--media-max);
  margin-inline: auto;
  padding: var(--space-6xl) var(--mobile-gutter);
  text-align: center;
}

.l-sitefooter__logo img { height: 1.857rem; width: auto; }

.l-sitefooter__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-md) var(--space-2xl);
}

.l-sitefooter__link {
  font-size: var(--font-sm);
  color: var(--color-ink);
}
.l-sitefooter__link:hover { color: var(--color-accent); opacity: 1; }

.l-sitefooter__copyright {
  font-size: var(--font-xs);
  letter-spacing: 0.04em;
  color: var(--media-muted);
}


/* ==========================================================================
   タクソノミー — カテゴリ(eyebrow) / タグ(テキストリンク)
   ========================================================================== */
.c-tax {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs) var(--space-lg);
}

.c-tax__link { display: inline-flex; align-items: center; gap: 0.25em; }
.c-tax__link i { font-size: 1.08em; line-height: 1; }

/* カテゴリ: 塗りピルをやめ、字間広めの小ラベル (eyebrow) + フォルダアイコン */
.c-tax--cat .c-tax__link {
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.12em;
  color: var(--color-accent);
}
.c-tax--cat .c-tax__link:hover { opacity: 0.7; }

/* タグ: タグアイコン付きの控えめなテキストリンク */
.c-tax--tag .c-tax__link {
  font-size: var(--font-sm);
  color: var(--media-muted);
}
.c-tax--tag .c-tax__link i { color: var(--color-accent); }
.c-tax--tag .c-tax__link:hover { color: var(--color-accent); opacity: 1; }


/* ==========================================================================
   主要ボタン (c-linkbtn / p-corp__btn) — LP の c-button と同じ立体ピル
   記事下CTA / 404 / お問い合わせ等の主要ボタンは LP とデザインを合わせる。
   角丸ピル + 下に厚みのある影 + 押し込みアニメ。色はブランドのオレンジグラデ。
   ========================================================================== */
.c-linkbtn,
.p-corp__btn {
  display: flex;          /* block レベルにして margin-inline:auto で中央寄せ */
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  width: 100%;
  max-width: 24.286rem;   /* ~340px (LP の c-button と同値) */
  min-height: 4rem;        /* ~56px */
  margin-inline: auto;
  padding: var(--space-lg) var(--space-xl);
  font-family: inherit;
  font-size: var(--font-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  text-align: center;
  border: 0;
  border-radius: var(--border-radius-full);
  background: var(--gradient-orange);
  box-shadow: 0 0.429rem 0 var(--media-cta-deep);
  cursor: pointer;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
/* hover/active は「接地面は固定のまま本体が沈む」LP と同じ物理モデル */
.c-linkbtn:hover,
.p-corp__btn:hover {
  opacity: 1;
  transform: translateY(0.3rem);
  box-shadow: 0 0.129rem 0 var(--media-cta-deep);
}
.c-linkbtn:active,
.p-corp__btn:active {
  transform: translateY(0.358rem);
  box-shadow: 0 0.071rem 0 var(--media-cta-deep);
}


/* ==========================================================================
   BoostUp Form (お問い合わせ等) — メディア体裁ページ用
   フォーム本体 (c-form*) は common.css。送信ボタン (c-form__submit /
   c-button-wrap) は LP では lp-common が担うため、メディアでは media.css で用意。
   ※ media.css は記事系ページでのみ読込まれるため LP とは競合しない。
   ========================================================================== */
/* フォーム全体を読みやすい幅に中央寄せ。
   BoostUp は本文の <form class="c-form"> タグを除去して独自の <form class="buf-form">
   でラップするため、生き残る外側ラッパー (.buf-form / .p-form) を制約して
   入力欄・同意欄・タイトル・送信ボタンの幅を揃える (LP の .l-section 相当)。 */
.p-form-article,
.buf-form,
.p-form {
  width: 100%;
  /* 幅は親 .l-mediapage が制約するため 100% で十分 */
  max-width: 100%;
  margin-inline: auto;
}
/* LP (lp-common.css) の .l-section__inner と同じ縦リズム。
   メディアでは lp-common を読まないため、フォーム内の要素間 (入力欄・
   ポリシー・同意・送信ボタン) が詰まる (ギチギチ) のを防ぐ。 */
.buf-form .l-section__inner,
.p-form .l-section__inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-3xl);
  width: 100%;
}
/* テキスト系（タイトル等）が左に見えないよう、フォーム内の見出しは中央 */
.p-form-article .c-form__title { text-align: center; }

/* 入力欄: BoostUp frontend.css の max-width:480px を解除し、
   フォーム全幅 (.l-mediapage) いっぱいに揃える。 */
.media-site .buf-form__input,
.media-site .buf-form__textarea,
.media-site .buf-form__select {
  max-width: 100%;
}

/* 必須バッジの既定色を赤に統一。
   common.css の既定は --color-accent(メディアは緑) だが、BoostUp の
   リアルタイム判定 (.is-valid=緑 / .is-invalid=赤) の「入力OK緑」と
   見分けがつかず2色に見える。未入力＝赤、入力OK＝緑 と意味を明確化する。 */
.media-site .c-form__required { background-color: #e53935; }

.c-button-wrap {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-md);
  width: 100%;
}

/* 送信ボタン: 主要ボタン (.c-linkbtn) と同じオレンジの立体ピル。
   base.css の input[type="submit"] リセット (0,1,1) を超える詳細度で指定。 */
.c-form__submit,
button.c-form__submit,
input[type="submit"].c-form__submit {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-sm);
  width: 100%;
  /* フォーム全幅化に合わせ送信ボタンも全幅 (フィールドと比率を揃える) */
  max-width: 100%;
  min-height: 4rem;
  margin-inline: auto;
  padding: var(--space-lg) var(--space-xl);
  font-family: inherit;
  font-size: var(--font-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  text-align: center;
  border: 0;
  border-radius: var(--border-radius-full);
  background: var(--gradient-orange);
  box-shadow: 0 0.429rem 0 var(--media-cta-deep);
  cursor: pointer;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.c-form__submit:hover,
button.c-form__submit:hover,
input[type="submit"].c-form__submit:hover {
  opacity: 1;
  transform: translateY(0.3rem);
  box-shadow: 0 0.129rem 0 var(--media-cta-deep);
}
.c-form__submit:active,
button.c-form__submit:active,
input[type="submit"].c-form__submit:active {
  transform: translateY(0.358rem);
  box-shadow: 0 0.071rem 0 var(--media-cta-deep);
}
/* 必須未入力で無効化されたとき (boostup-form/frontend.js が is-disabled を付与) */
.c-form__submit:disabled,
.c-form__submit.is-disabled,
button.c-form__submit:disabled,
button.c-form__submit.is-disabled,
input[type="submit"].c-form__submit:disabled,
input[type="submit"].c-form__submit.is-disabled {
  background: var(--color-disabled) !important;
  color: var(--color-white) !important;
  box-shadow: none !important;
  transform: none !important;
  cursor: not-allowed;
  pointer-events: none;
}


/* ==========================================================================
   パンくず (p-breadcrumb)
   ========================================================================== */
.p-breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2xs);
  font-size: var(--font-xs);
  color: var(--media-muted);
}

.p-breadcrumb__item { display: inline-flex; align-items: center; }
.p-breadcrumb__item:not(:last-child)::after {
  content: "/";
  margin-left: var(--space-2xs);
  color: var(--color-gray-400);
}
.p-breadcrumb__item a:hover { color: var(--color-accent); opacity: 1; }
.p-breadcrumb__item--current {
  max-width: 16em;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}


/* ==========================================================================
   記事本体 (p-article) — カード化しない。白地 + ヘアライン + タイポ
   ========================================================================== */
.p-article {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xl);
}

.p-article__header {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
}

.p-article__title {
  font-size: var(--font-4xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.45;
  letter-spacing: 0.01em;
  color: var(--media-head);
}

/* 時間: 字間を取ったミュート小文字、中黒で区切る */
.p-article__time {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-xs) var(--space-md);
  font-size: var(--font-xs);
  letter-spacing: 0.04em;
  color: var(--media-muted);
}
.p-article__date,
.p-article__readtime { display: inline-flex; align-items: center; gap: var(--space-2xs); }
.p-article__date + .p-article__date::before,
.p-article__date + .p-article__readtime::before,
.p-article__date-label + *::before { content: none; }
.p-article__date-label {
  padding: 0;
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  color: var(--color-ink);
  background: none;
  border-radius: 0;
}

/* アイキャッチ: 角丸ほぼ無し、影無し、ワイドに */
.p-article__eyecatch {
  margin: var(--space-sm) 0 var(--space-lg);
  border-radius: var(--media-radius);
  overflow: hidden;
}
.p-article__eyecatch img { width: 100%; height: auto; }


/* ==========================================================================
   記事本文タイポグラフィ (p-article__body)
   ========================================================================== */
.p-article__body {
  font-size: var(--font-md);
  line-height: 1.95;
  color: var(--color-ink);
}

.p-article__body > * + * { margin-top: var(--space-xl); }
/* 先頭/末尾要素の余白は相殺し、.p-article の flex gap と二重にしない
   (特に末尾が補足ボックス <div> の場合に margin-bottom がはみ出すのを防ぐ) */
.p-article__body > *:first-child { margin-top: 0; }
.p-article__body > *:last-child { margin-bottom: 0; }

.p-article__body h2 {
  margin-top: var(--space-6xl);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-md);
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  color: var(--media-head);
  border-bottom: 1px solid var(--media-rule);
}

.p-article__body h3 {
  margin-top: var(--space-4xl);
  margin-bottom: var(--space-sm);
  font-size: var(--font-xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  color: var(--media-head);
}

.p-article__body h4 {
  margin-top: var(--space-2xl);
  margin-bottom: var(--space-sm);
  font-size: var(--font-lg);
  color: var(--media-head);
}

.p-article__body p { line-height: 1.95; }

.p-article__body a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 0.18em;
  text-decoration-thickness: 1px;
}
.p-article__body a:hover { opacity: 0.7; }

.p-article__body strong { font-weight: var(--font-weight-bold); }
.p-article__body em { font-style: italic; }

.p-article__body img { border-radius: var(--media-radius); }
.p-article__body figure { margin-inline: 0; }
.p-article__body figcaption {
  margin-top: var(--space-sm);
  font-size: var(--font-xs);
  color: var(--media-muted);
}

.p-article__body ul,
.p-article__body ol { padding-left: var(--space-xl); }
.p-article__body ul { list-style: disc; }
.p-article__body ol { list-style: decimal; }
.p-article__body li { margin-top: var(--space-xs); }
.p-article__body li::marker { color: var(--media-muted); }

/* 引用: 左に細い濃ルール + イタリック寄せ (塗り箱にしない) */
.p-article__body blockquote {
  padding-left: var(--space-xl);
  color: var(--media-muted);
  border-left: 2px solid var(--media-rule);
}
.p-article__body blockquote > * + * { margin-top: var(--space-sm); }

.p-article__body pre {
  padding: var(--space-lg);
  overflow-x: auto;
  font-size: var(--font-sm);
  line-height: 1.7;
  color: var(--color-white);
  background-color: var(--media-head);
  border-radius: var(--media-radius);
}
.p-article__body code {
  padding: 0.1em 0.4em;
  font-size: 0.92em;
  background-color: var(--color-gray-100);
  border-radius: var(--media-radius);
}
.p-article__body pre code { padding: 0; background: none; }

.p-article__body table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--font-base);
}
.p-article__body th,
.p-article__body td {
  padding: var(--space-sm) var(--space-md);
  text-align: left;
  border-bottom: 1px solid var(--media-line);
}
.p-article__body th { font-weight: var(--font-weight-bold); color: var(--media-head); }

.p-article__body hr {
  margin-block: var(--space-3xl);
  border: 0;
  border-top: 1px solid var(--media-line);
}

/* 記事内マルチページ送り */
.p-article__pagelinks {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-md);
  margin-top: var(--space-3xl);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--media-line);
}
.p-article__pagelinks-label {
  font-size: var(--font-xs);
  letter-spacing: 0.08em;
  color: var(--media-muted);
}
.p-article__pagelinks a span,
.p-article__pagelinks > span > span {
  display: inline-flex;
  min-width: 1.8rem;
  justify-content: center;
  font-size: var(--font-sm);
  font-weight: var(--font-weight-bold);
}
.p-article__pagelinks a span { color: var(--color-accent); }
.p-article__pagelinks > span > span { color: var(--media-head); text-decoration: underline; }

/* タグ (記事下) — 間隔は .p-article の flex gap が担当。ここは罫線区切りのみ */
.p-article__tags {
  padding-top: var(--space-lg);
  border-top: 1px solid var(--media-line);
}


/* ==========================================================================
   記事本文 内のリッチ要素 (執筆フォーマット準拠)
   本文先頭のタグ行 / 記事内の目次 <nav> / 補足ボックス <div> / データ表
   ※ 記事は class 無しの素の HTML で入稿される前提のため、要素セレクタで装飾する
   ========================================================================== */

/* --- 本文先頭のタグ行 <p><span>#…</span> …</p> をチップ化 --- */
.p-article__body > p:first-child:has(span) {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs) var(--space-sm);
  margin-bottom: var(--space-2xl);
}
.p-article__body > p:first-child:has(span) span {
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  color: var(--media-accent-deep);
  background-color: var(--media-tint);
  padding: 0.214rem var(--space-md);
  border-radius: var(--border-radius-full);
}

/* --- 記事内の目次 <nav> (記事側で手書き) — 淡グリーンのパネル + ゼロ埋め番号 --- */
.p-article__body nav {
  margin-block: var(--space-2xl);
  padding: var(--space-xl) var(--space-2xl);
  background-color: var(--media-tint);
  border-radius: var(--media-radius);
}
.p-article__body nav > p {
  margin-bottom: var(--space-md);
  font-size: var(--font-base);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.04em;
  color: var(--media-head);
}
.p-article__body nav ol {
  margin-top: 0;
  padding-left: 0;
  list-style: none;
  counter-reset: toc;
}
.p-article__body nav li {
  display: flex;
  align-items: baseline;       /* 番号とテキストのベースラインを揃える (ズレ防止) */
  gap: var(--space-md);
  counter-increment: toc;
  margin-top: var(--space-sm);
  line-height: 1.6;
}
.p-article__body nav li::before {
  content: counter(toc, decimal-leading-zero);
  flex-shrink: 0;
  min-width: 1.4rem;
  font-family: var(--ff-en);
  font-size: var(--font-base);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
}
.p-article__body nav a {
  font-size: var(--font-base);
  color: var(--color-ink);
  text-decoration: none;
}
.p-article__body nav a:hover { color: var(--color-accent); opacity: 1; }

/* --- 補足ボックス (.point: ここがポイント / リスク / 免責 / シミュレーション 等) ---
   <div class="point">…</div> を共通の「ノート」枠に。先頭 <strong> はリード見出し扱い。 */
.p-article__body .point {
  margin-block: var(--space-xl);
  padding: var(--space-lg) var(--space-xl);
  font-size: var(--font-base);
  line-height: 1.85;
  color: var(--color-ink);
  background-color: var(--color-gray-100);
  border-left: 3px solid var(--color-accent);
  border-radius: 0 var(--media-radius) var(--media-radius) 0;
}
.p-article__body .point > * + * { margin-top: var(--space-sm); }
.p-article__body .point > strong:first-child {
  display: block;
  margin-bottom: var(--space-2xs);
  font-size: var(--font-md);
  font-weight: var(--font-weight-bold);
  color: var(--media-accent-deep);
}
/* リード <strong> 直後の <br> は不要 (strong を block 化したため) */
.p-article__body .point > strong:first-child + br { display: none; }
/* FAQ の質問 (<p><strong>Q…</strong></p>) は行内強調のまま、回答とリズムを付ける */
.p-article__body .point > p > strong { color: var(--media-head); }

/* --- データ表 — ヘッダーに淡い面。PC は幅100%、狭い画面のみ横スクロール --- */
.p-article__body thead th {
  background-color: var(--media-tint);
  color: var(--media-head);
}
@media (max-width: 600px) {
  .p-article__body table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }
}


/* ==========================================================================
   SNS シェア (p-share) — モノクロのアウトライン円、hover で反転
   ========================================================================== */
.p-share {
  display: flex;
  align-items: center;
  gap: var(--space-lg);
  flex-wrap: wrap;
  /* 上下対称の独立した帯にして中身を罫線間で中央に置く */
  padding-block: var(--space-lg);
  border-top: 1px solid var(--media-line);
  border-bottom: 1px solid var(--media-line);
}

.p-share__title {
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.12em;
  color: var(--media-muted);
}

.p-share__list { display: flex; flex-wrap: wrap; gap: var(--space-sm); }

.p-share__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.857rem;
  height: 2.857rem;
  color: var(--media-head);
  background-color: transparent;
  border: 1px solid var(--media-line);
  border-radius: var(--border-radius-full);
  transition: color var(--transition-base), background-color var(--transition-base), border-color var(--transition-base);
}
.p-share__link:hover {
  opacity: 1;
  color: var(--color-white);
  background-color: var(--media-head);
  border-color: var(--media-head);
}
.p-share__link i { font-size: 1.286rem; line-height: 1; }

.p-share__copied {
  position: absolute;
  bottom: calc(100% + 0.5rem);
  left: 50%;
  transform: translateX(-50%) translateY(4px);
  padding: var(--space-2xs) var(--space-sm);
  font-size: var(--font-xs);
  white-space: nowrap;
  color: var(--color-white);
  background-color: var(--media-head);
  border-radius: var(--media-radius);
  opacity: 0;
  pointer-events: none;
  transition: opacity var(--transition-base), transform var(--transition-base);
}
.p-share__link--copy.is-copied .p-share__copied {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}


/* ==========================================================================
   著者欄 (p-author) — ヘアライン上下ルール、横並び
   ========================================================================== */
.p-author {
  display: flex;
  flex-direction: column;
  gap: var(--space-lg);
  /* 上罫線は p-share の border-bottom が担うため持たない。
     上は l-media__main の gap で分離し、下だけ罫線で締める */
  padding: 0 0 var(--space-2xl);
  border-bottom: 1px solid var(--media-line);
}

.p-author__head { display: flex; align-items: center; gap: var(--space-lg); }

.p-author__avatar {
  flex-shrink: 0;
  width: 4rem;
  height: 4rem;
  margin: 0;
  border-radius: var(--border-radius-full);
  overflow: hidden;
  background-color: var(--color-gray-100);
}
.p-author__avatar-img { width: 100%; height: 100%; object-fit: cover; }

.p-author__role {
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.1em;
  color: var(--media-muted);
}
.p-author__name {
  font-size: var(--font-lg);
  font-weight: var(--font-weight-bold);
  color: var(--media-head);
}
.p-author__bio {
  font-size: var(--font-sm);
  line-height: 1.85;
  color: var(--color-ink);
}

.p-author__socials { display: flex; gap: var(--space-md); }
.p-author__social-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.285rem;
  height: 2.285rem;
  color: var(--media-muted);
  border: 1px solid var(--media-line);
  border-radius: var(--border-radius-full);
  transition: color var(--transition-base), border-color var(--transition-base);
}
.p-author__social-link:hover { color: var(--media-head); border-color: var(--media-head); opacity: 1; }
.p-author__social-link i { font-size: 1.143rem; line-height: 1; }


/* ==========================================================================
   関連記事 (p-related) — カードは p-cards を流用
   ========================================================================== */
.p-related { display: flex; flex-direction: column; gap: var(--space-xl); }


/* ==========================================================================
   記事下 CTA (p-cta) — 薄いグリーン地 + LPアイキャッチのサムネイル
   ========================================================================== */
.p-cta {
  padding: var(--space-4xl) var(--space-2xl) var(--space-5xl);
  text-align: center;
  color: var(--color-ink);
  background-color: var(--media-tint);                       /* 薄いグリーン */
  border: 1px solid rgba(var(--color-accent-rgb), 0.2);
  border-radius: var(--media-radius);
}
.p-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
}
/* 誘導先LPのアイキャッチをサムネイル表示 */
.p-cta__thumb {
  display: block;
  width: 100%;
  max-width: 24rem;
  margin-bottom: var(--space-xs);
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-radius: var(--media-radius);
  background-color: var(--color-white);
}
.p-cta__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--easeOutCubic);
}
.p-cta__thumb:hover { opacity: 1; }
.p-cta__thumb:hover img { transform: scale(1.04); }
.p-cta__heading {
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  color: var(--media-head);
}
.p-cta__text {
  font-size: var(--font-base);
  line-height: 1.8;
  color: var(--media-muted);
}
.p-cta__inner .c-linkbtn { margin-top: var(--space-xs); }


/* ==========================================================================
   前後記事ナビ (p-postnav)
   ========================================================================== */
.p-postnav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--media-line);
}
.p-postnav__link {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
  padding: var(--space-lg) 0;
}
.p-postnav__link--next { text-align: right; align-items: flex-end; }
.p-postnav__link--prev + .p-postnav__link--next { border-left: 1px solid var(--media-line); padding-left: var(--space-lg); }
.p-postnav__link--prev { padding-right: var(--space-lg); }
.p-postnav__dir {
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.08em;
  color: var(--media-muted);
}
.p-postnav__link:hover .p-postnav__title { color: var(--color-accent); }
.p-postnav__title {
  font-size: var(--font-sm);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  color: var(--media-head);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}


/* ==========================================================================
   記事カード (p-cards / p-card) — 画像先行・枠/影なし
   ========================================================================== */
.p-cards {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2xl) var(--space-lg);
}

.p-card__link { display: flex; flex-direction: column; gap: var(--space-md); }
.p-card__link:hover { opacity: 1; }

.p-card__thumb {
  margin: 0;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background-color: var(--color-gray-100);
  border-radius: var(--media-radius);
}
.p-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--duration-slow) var(--easeOutCubic);
}
.p-card__link:hover .p-card__img { transform: scale(1.04); }

.p-card__body { display: flex; flex-direction: column; gap: var(--space-xs); }

.p-card__cat {
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.12em;
  color: var(--color-accent);
}

.p-card__title {
  font-size: var(--font-md);
  font-weight: var(--font-weight-bold);
  line-height: 1.6;
  color: var(--media-head);
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.p-card__link:hover .p-card__title { text-decoration: underline; text-underline-offset: 0.16em; }

.p-card__date {
  font-size: var(--font-xs);
  letter-spacing: 0.04em;
  color: var(--media-muted);
}


/* ==========================================================================
   一覧見出し / 空表示 (p-archive)
   ========================================================================== */
.p-archive__head {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  margin-bottom: var(--space-3xl);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--media-rule);
}
.p-archive__kicker {
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.12em;
  color: var(--color-accent);
}
.p-archive__title {
  font-size: var(--font-4xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  color: var(--media-head);
}
.p-archive__desc {
  font-size: var(--font-sm);
  line-height: 1.8;
  color: var(--media-muted);
}

.p-archive__empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-6xl) var(--space-lg);
  text-align: center;
  color: var(--media-muted);
}

.p-archive__searchform,
.p-notfound__search {
  display: flex;
  gap: var(--space-sm);
  width: 100%;
  max-width: 22rem;
}
.p-archive__searchform input,
.p-notfound__search input {
  flex: 1;
  min-width: 0;
  padding: var(--space-sm) 0;
  font-size: 16px;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--media-line);
}
.p-archive__searchform input:focus,
.p-notfound__search input:focus { outline: none; border-bottom-color: var(--media-head); }
.p-archive__searchform button,
.p-notfound__search button {
  flex-shrink: 0;
  padding: var(--space-sm) var(--space-xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-white);
  background-color: var(--media-cta);
  border-radius: var(--media-radius);
}


/* ==========================================================================
   ページネーション (p-pagination) — 箱なし、現在地は下線
   ========================================================================== */
.p-pagination { margin-top: var(--space-5xl); }
.p-pagination__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: var(--space-lg);
}
.p-pagination__item .page-numbers {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.4rem;
  font-family: var(--ff-en);
  font-size: var(--font-base);
  font-weight: var(--font-weight-bold);
  color: var(--media-muted);
  transition: color var(--transition-base);
}
.p-pagination__item a.page-numbers:hover { color: var(--media-head); opacity: 1; }
.p-pagination__item .page-numbers.current {
  color: var(--color-accent);
  border-bottom: 2px solid var(--color-accent);
}
.p-pagination__item .page-numbers.dots { color: var(--color-gray-400); }

/* 前後ページ: 円に矢印 (hover で塗り) */
.p-pagination__item .prev.page-numbers,
.p-pagination__item .next.page-numbers {
  width: 2.571rem;
  height: 2.571rem;
  color: var(--color-accent);
  border: 1.5px solid var(--color-accent);
  border-radius: var(--border-radius-full);
  transition: color var(--transition-base), background-color var(--transition-base);
}
.p-pagination__item .prev.page-numbers:hover,
.p-pagination__item .next.page-numbers:hover {
  color: var(--color-white);
  background-color: var(--color-accent);
  opacity: 1;
}
.p-pagination__item .prev.page-numbers i,
.p-pagination__item .next.page-numbers i { font-size: 1.143rem; }


/* ==========================================================================
   目次 (p-toc) — 上下ヘアライン、塗り箱にしない
   ========================================================================== */
.p-toc {
  padding: var(--space-xl) var(--space-2xl);
  background-color: var(--media-tint);
  border-radius: var(--media-radius);
}
.p-toc__title {
  margin-bottom: var(--space-md);
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.12em;
  color: var(--media-muted);
}
.p-toc__list {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  counter-reset: toc;
}
.p-toc__item--h2 { counter-increment: toc; }
.p-toc__item--h2 > .p-toc__link::before {
  content: counter(toc, decimal-leading-zero);
  margin-right: var(--space-sm);
  font-family: var(--ff-en);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
}
.p-toc__item--h3 { padding-left: var(--space-2xl); }
.p-toc__item--h3 > .p-toc__link::before { content: "— "; color: var(--color-gray-400); }
.p-toc__link {
  font-size: var(--font-base);
  line-height: 1.7;
  color: var(--color-ink);
}
.p-toc__link:hover { color: var(--color-accent); opacity: 1; }


/* ==========================================================================
   人気記事ランキング (p-rank) — 大きめの英数番号 + ヘアライン
   ========================================================================== */
.p-rank { display: flex; flex-direction: column; }

.p-rank__item + .p-rank__item { border-top: 1px solid var(--media-line); }

.p-rank__link {
  display: grid;
  grid-template-columns: 4.285rem 1fr; /* サムネ(番号バッジ付き) / タイトル */
  align-items: center;
  gap: var(--space-md);
  padding: var(--space-md) 0;
}
.p-rank__link:hover { opacity: 1; }
.p-rank__link:hover .p-rank__title { color: var(--color-accent); }

.p-rank__thumb {
  position: relative;
  width: 4.285rem;   /* ~60px */
  height: 4.285rem;
  overflow: hidden;
  border-radius: var(--media-radius);
  background-color: var(--color-gray-100);
}
.p-rank__thumb img { width: 100%; height: 100%; object-fit: cover; }

/* 番号バッジ — サムネ左上に重ねる */
.p-rank__num {
  position: absolute;
  top: 0;
  left: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.571rem;  /* ~22px */
  height: 1.571rem;
  padding-inline: 0.25rem;
  font-family: var(--ff-en);
  font-size: var(--font-xs);
  font-weight: var(--font-weight-bold);
  line-height: 1;
  color: var(--color-white);
  background-color: var(--media-head);
  border-radius: 0 0 var(--media-radius) 0;
}
.p-rank__item:nth-child(1) .p-rank__num { background-color: var(--media-cta); }
.p-rank__item:nth-child(2) .p-rank__num,
.p-rank__item:nth-child(3) .p-rank__num { background-color: var(--color-accent); }

.p-rank__body {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
  min-width: 0;
}
.p-rank__title {
  font-size: var(--font-sm);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  color: var(--media-head);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.p-rank__meta {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2xs) var(--space-sm);
  font-size: var(--font-xs);
}
.p-rank__cat { font-weight: var(--font-weight-bold); color: var(--color-accent); }
.p-rank__date { font-family: var(--ff-en); letter-spacing: 0.02em; color: var(--media-muted); }


/* ==========================================================================
   サイドバー ウィジェット (p-widget) / カテゴリー一覧 (p-catlist)
   ========================================================================== */
.p-widget { display: flex; flex-direction: column; }
.p-widget__title {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-xs);
  margin-bottom: var(--space-lg);
  padding-bottom: var(--space-sm);
  font-size: var(--font-md);
  font-weight: var(--font-weight-bold);
  color: var(--media-head);
  border-bottom: 1px solid var(--media-line);
}
.p-widget__title::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -1px;
  width: 2.5rem;
  height: 2px;
  background-color: var(--color-accent);
}
.p-widget__title i { font-size: 1.15em; color: var(--color-accent); }

.p-catlist { display: flex; flex-direction: column; }
.p-catlist__link {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  padding: var(--space-sm) var(--space-md);
  font-size: var(--font-sm);
  color: var(--color-ink);
  border-radius: var(--media-radius);
  transition: background-color var(--transition-base), color var(--transition-base);
}
.p-catlist__link:hover { background-color: var(--media-tint); color: var(--media-accent-deep); opacity: 1; }
.p-catlist__icon { flex-shrink: 0; font-size: 1.071rem; color: var(--color-accent); }
.p-catlist__name { flex: 1; }
.p-catlist__count {
  flex-shrink: 0;
  min-width: 1.7rem;
  padding: 0.05rem 0.45rem;
  font-family: var(--ff-en);
  font-size: var(--font-xs);
  text-align: center;
  color: var(--media-muted);
  background-color: var(--color-gray-100);
  border-radius: var(--border-radius-full);
}
.p-catlist__link:hover .p-catlist__count { color: var(--color-white); background-color: var(--color-accent); }
.p-catlist__arrow { flex-shrink: 0; font-size: 1.143rem; color: var(--color-gray-400); }
.p-catlist__link:hover .p-catlist__arrow { color: var(--color-accent); }


/* ==========================================================================
   トップ — ヒーロー (p-hero)
   ========================================================================== */
.p-hero {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xl);
  padding-bottom: var(--space-3xl);
  border-bottom: 1px solid var(--media-rule);
}
.p-hero__intro { display: flex; flex-direction: column; gap: var(--space-sm); }
.p-hero__title {
  font-size: var(--font-5xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.3;
  letter-spacing: 0.01em;
  color: var(--media-head);
}
.p-hero__lead {
  font-size: var(--font-base);
  line-height: 1.8;
  color: var(--media-muted);
}
.p-hero__posts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2xl) var(--space-lg);
}


/* ==========================================================================
   トップ — セクション (p-sectiontitle / p-homesection / p-catnav / p-homecat)
   ========================================================================== */
.p-sectiontitle {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-xl);
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  color: var(--media-head);
}
.p-sectiontitle i { font-size: 1.1em; color: var(--color-accent); }

.p-homesection { display: flex; flex-direction: column; }

.p-catnav { display: flex; flex-wrap: wrap; gap: var(--space-sm); }
.p-catnav__link {
  display: inline-block;
  padding: var(--space-sm) var(--space-lg);
  font-size: var(--font-sm);
  font-weight: var(--font-weight-bold);
  color: var(--media-accent-deep);
  background-color: var(--media-tint);
  border: 1px solid transparent;
  border-radius: var(--border-radius-full);
  transition: color var(--transition-base), background-color var(--transition-base);
}
.p-catnav__link:hover { color: var(--color-white); background-color: var(--color-accent); opacity: 1; }
/* タグから探す: # 付きのチップ (カテゴリと同じピル) */
.p-catnav__hash { margin-right: 0.05em; opacity: 0.7; }

/* トップの「よく読まれている記事」: 横幅100% + サムネイル大きめ */
.p-homesection--rank .p-rank { max-width: none; }
.p-homesection--rank .p-rank__link {
  grid-template-columns: 7.5rem 1fr;
  gap: var(--space-lg);
}
.p-homesection--rank .p-rank__thumb { width: 7.5rem; height: 7.5rem; }
.p-homesection--rank .p-rank__num {
  min-width: 1.857rem;
  height: 1.857rem;
  font-size: var(--font-sm);
}
.p-homesection--rank .p-rank__title {
  font-size: var(--font-md);
  -webkit-line-clamp: 2;
}

.p-homecat { display: flex; flex-direction: column; }
.p-homecat__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--space-md);
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--media-rule);
}
.p-homecat__title {
  font-size: var(--font-xl);
  font-weight: var(--font-weight-bold);
  color: var(--media-head);
}
.p-homecat__more {
  display: inline-flex;
  align-items: center;
  gap: var(--space-xs);
  flex-shrink: 0;
  font-size: var(--font-sm);
  font-weight: var(--font-weight-bold);
  color: var(--color-accent);
}
/* 円に矢印。hover で塗り + わずかに右へ */
.p-homecat__more-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.857rem;
  height: 1.857rem;
  font-size: 1rem;
  color: var(--color-accent);
  border: 1.5px solid var(--color-accent);
  border-radius: var(--border-radius-full);
  transition: color var(--transition-base), background-color var(--transition-base), transform var(--transition-base);
}
.p-homecat__more:hover { opacity: 1; }
.p-homecat__more:hover .p-homecat__more-icon {
  color: var(--color-white);
  background-color: var(--color-accent);
  transform: translateX(2px);
}


/* ==========================================================================
   404 (p-notfound)
   ========================================================================== */
.p-notfound {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
  padding: var(--space-7xl) var(--space-lg);
  text-align: center;
}
.p-notfound__code {
  font-family: var(--ff-en);
  font-size: var(--font-5xl);
  font-weight: var(--font-weight-black);
  letter-spacing: 0.05em;
  color: var(--media-head);
  line-height: 1;
}
.p-notfound__title {
  font-size: var(--font-xl);
  font-weight: var(--font-weight-bold);
  color: var(--media-head);
}
.p-notfound__text { font-size: var(--font-sm); color: var(--media-muted); }
.p-notfound__search { margin-block: var(--space-md); }


/* ==========================================================================
   固定ページ (page.php / メディア体裁) — 運営会社情報 / ポリシー 等
   ========================================================================== */
.l-mediapage {
  width: 100%;
  max-width: 760px;
  margin-inline: auto;
  padding: var(--space-6xl) var(--mobile-gutter) var(--space-7xl);
}

/* 運営会社情報 (p-corp) */
.p-corp { color: var(--color-ink); }

.p-corp__head {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
  padding-bottom: var(--space-xl);
  border-bottom: 1px solid var(--media-head);
}
.p-corp__eyebrow {
  font-family: var(--ff-en);
  font-size: var(--font-sm);
  font-weight: var(--font-weight-bold);
  letter-spacing: 0.14em;
  color: var(--color-accent);
}
.p-corp__title {
  font-size: var(--font-4xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.4;
  color: var(--media-head);
}
.p-corp__lead {
  margin-top: var(--space-xs);
  font-size: var(--font-base);
  line-height: 1.9;
}

.p-corp__section { margin-top: var(--space-6xl); }
.p-corp__heading {
  margin-bottom: var(--space-xl);
  padding-bottom: var(--space-sm);
  font-size: var(--font-2xl);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  color: var(--media-head);
  border-bottom: 1px solid var(--media-rule);
}
.p-corp__subheading {
  margin-top: var(--space-2xl);
  margin-bottom: var(--space-sm);
  font-size: var(--font-md);
  font-weight: var(--font-weight-bold);
  line-height: 1.5;
  color: var(--media-head);
}

/* 会社概要テーブル */
.p-corp__table { margin: 0; border-top: 1px solid var(--media-line); }
.p-corp__row {
  display: grid;
  grid-template-columns: 9rem 1fr;
  gap: var(--space-md);
  padding: var(--space-lg) var(--space-xs);
  border-bottom: 1px solid var(--media-line);
}
.p-corp__row dt {
  font-size: var(--font-sm);
  font-weight: var(--font-weight-bold);
  color: var(--media-head);
}
.p-corp__row dd { margin: 0; font-size: var(--font-base); line-height: 1.8; }
.p-corp__row dd a {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}

/* 本文・リスト */
.p-corp__text { font-size: var(--font-base); line-height: 1.9; }
.p-corp__text + .p-corp__text { margin-top: var(--space-md); }
/* 本文中リンクは緑＋下線。ただしボタン (.p-corp__btn) は除外 (白文字を維持) */
.p-corp a:not(.p-corp__btn) {
  color: var(--color-accent);
  text-decoration: underline;
  text-underline-offset: 0.15em;
}
.p-corp__list {
  margin-top: var(--space-md);
  padding-left: var(--space-lg);
  list-style: disc;
}
.p-corp__list--num { list-style: decimal; }
.p-corp__list li { margin-top: var(--space-xs); line-height: 1.8; }
.p-corp__list li::marker { color: var(--color-accent); }

/* お問い合わせボタン本体は LP と同じ立体ピル (.c-linkbtn と共通定義) */
.p-corp__btnwrap { margin-top: var(--space-xl); }

@media (max-width: 600px) {
  .p-corp__row {
    grid-template-columns: 1fr;
    gap: var(--space-2xs);
    padding: var(--space-md) var(--space-xs);
  }
}


/* ==========================================================================
   アニメーション
   ========================================================================== */
@keyframes media-fadein {
  from { opacity: 0; transform: translateY(-4px); }
  to   { opacity: 1; transform: translateY(0); }
}


/* ==========================================================================
   レスポンシブ
   ========================================================================== */

/* タブレット以上: カード 3 カラム / ヒーロー記事も 3 カラム */
@media (min-width: 600px) {
  .p-cards { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}

/* PC: ヘッダー横一列 / 本文 + サイドバー 2 カラム */
@media (min-width: 900px) {
  .l-siteheader__inner { flex-wrap: nowrap; gap: var(--space-3xl); }
  .l-siteheader__toggle { display: none; }

  .l-sitenav {
    display: flex !important;
    align-items: center;
    gap: var(--space-2xl);
    flex: 1;
    width: auto;
    margin-top: 0;
    padding-top: 0;
    border-top: 0;
  }
  .l-sitenav__list { flex: 1; flex-direction: row; flex-wrap: wrap; gap: var(--space-xl); }
  .l-sitenav__item + .l-sitenav__item { border-top: 0; }
  .l-sitenav__link {
    padding: 0;
    font-size: var(--font-sm);
    letter-spacing: 0.02em;
  }

  .l-media {
    display: grid;
    grid-template-columns: minmax(0, 1fr) var(--media-side);
    gap: var(--media-gap);
    align-items: start;
  }
  .l-media__side {
    position: sticky;
    top: 5rem;            /* sticky ヘッダー分のオフセット */
    align-self: start;    /* grid 子の stretch を防ぎ sticky の可動域を確保 */
    max-height: calc(100vh - 6rem);
    overflow-y: auto;     /* サイドバーが長い場合は内部スクロールしつつ追従 */
    padding-left: var(--space-2xl);
    border-left: 1px solid var(--media-line);
    scrollbar-width: thin;
  }

  /* ヒーロー: イントロを横並びにして誌面らしく */
  .p-hero__title { font-size: clamp(2.286rem, 3.4vw, 2.857rem); }
}
