/* ============================================================
    THE MEN'S COACH - 共通スタイルシート
    ------------------------------------------------------------
    このCSSは index.html（トップページ）と
    articles/ 配下の各記事ページの両方から読み込まれています。

    構成（上から順番に並んでいます）
    1. 共通変数・リセット
    2. ヘッダー（ロゴ・ナビゲーション）
    3. ヒーローセクション（トップページ最上部）
    4. セクション共通見出し
    5. About セクション（ブランド紹介）
    6. Blog（検証ログ一覧）セクション
    7. Products（商品比較）セクション ※商品カードの追加方法はコメント参照
        ※このカードのスタイルは記事ページ末尾の商品紹介ブロックでも
          共通利用しています（デザインを統一するため）
    8. Contact（SNS導線）セクション
    9. フッター
    10. 記事ページ専用スタイル（articles/*.html）
   ============================================================ */


/* ---------- 1. 共通変数・リセット ---------- */

:root {
  /* カラー定義：白・黒・黄色の3色構成（黄色はCTAと価格ハイライトのみに限定使用） */
  --white: #FFFFFF;
  --ink: #1A1A1A;
  --gray: #767676;
  --gray-light: #B7B7B7;
  --yellow: #FFD400;
  --line: #EAEAEA;
}

* {
  box-sizing: border-box;
}

html {
  /* ページ内リンク（アンカー）をなめらかにスクロール */
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--white);
  color: var(--ink);
  font-family: 'Noto Sans JP', sans-serif;
  line-height: 1.8;
  -webkit-font-smoothing: antialiased;
  font-size: 15px;
}

a {
  color: inherit;
}

::selection {
  background: var(--yellow);
  color: var(--ink);
}

:focus-visible {
  outline: 2px solid var(--ink);
  outline-offset: 3px;
}

img {
  max-width: 100%;
  display: block;
}

.num {
  /* 価格などの数字を等幅風に整列 */
  font-variant-numeric: tabular-nums;
}

.wrap {
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 40px;
}

@media (max-width: 640px) {
  .wrap {
    padding: 0 24px;
  }
}


/* ---------- 2. ヘッダー（ロゴ・ナビゲーション） ---------- */

header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: var(--white);
  border-bottom: 1px solid var(--line);
}

.header-inner {
  max-width: 1120px;
  margin: 0 auto;
  padding: 22px 40px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media (max-width: 640px) {
  .header-inner {
    padding: 18px 24px;
  }
}

/* ロゴ：サイト名「THE MEN'S COACH」。全ページ共通でトップへ戻る導線 */
.logo {
  font-size: 17px;
  font-weight: 700;
  letter-spacing: .03em;
  text-decoration: none;
}

nav ul {
  display: flex;
  gap: 32px;
  list-style: none;
  margin: 0;
  padding: 0;
  font-size: 13.5px;
}

nav a {
  text-decoration: none;
  color: var(--ink);
}

nav a:hover {
  color: var(--gray);
}

@media (max-width: 640px) {
  /* スマホでは省略。必要であれば別途ハンバーガーメニューを追加 */
  nav {
    display: none;
  }
}


/* ---------- 3. ヒーローセクション ---------- */

.hero {
  padding: 100px 0 90px;
  text-align: center;
}

.hero-eyebrow {
  font-size: 12.5px;
  letter-spacing: .16em;
  color: var(--gray);
  margin-bottom: 22px;
}

.hero h1 {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 700;
  line-height: 1.7;
  margin: 0 0 26px;
  letter-spacing: .02em;
}

.hero p {
  max-width: 480px;
  margin: 0 auto 36px;
  color: var(--gray);
  font-size: 14.5px;
}

/* CTAボタンを2種類用意：
   ・btn-primary（黒）＝読み物への導線（SEO記事を読ませて信頼を作る一次導線）
   ・btn-secondary（アウトライン）＝比較検討層向けの二次導線（すぐ価格を見たい人向け） */
.hero-actions {
  display: flex;
  gap: 14px;
  justify-content: center;
  flex-wrap: wrap;
}

.btn {
  display: inline-block;
  font-size: 13.5px;
  font-weight: 500;
  text-decoration: none;
  padding: 15px 36px;
  letter-spacing: .05em;
  border: 1px solid var(--ink);
}

.btn-primary {
  background: var(--ink);
  color: var(--white);
}

.btn-primary:hover {
  background: #333;
}

.btn-secondary {
  background: var(--white);
  color: var(--ink);
}

.btn-secondary:hover {
  background: #F5F5F3;
}


/* ---------- 4. セクション共通見出し ---------- */

.section {
  padding: 84px 0;
  border-top: 1px solid var(--line);
}

.section-heading {
  text-align: center;
  margin-bottom: 60px;
}

.section-heading .eyebrow {
  font-size: 12px;
  letter-spacing: .16em;
  color: var(--gray);
  margin-bottom: 14px;
}

.section-heading h2 {
  font-size: 24px;
  font-weight: 700;
  margin: 0 0 14px;
  letter-spacing: .03em;
}

.section-heading p {
  color: var(--gray);
  font-size: 14px;
  margin: 0;
  max-width: 480px;
  margin-left: auto;
  margin-right: auto;
}


/* ---------- 5. About セクション（ブランド紹介） ---------- */
/* 個人プロフィールではなく「THE MEN'S COACHが何を助けるか」を
   伝えるシンプルな紹介文＋3つの支援領域で構成 */

.about-lead {
  max-width: 620px;
  margin: 0 auto 48px;
  text-align: center;
  font-size: 15px;
  color: var(--ink);
  line-height: 2;
}

.about-pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  max-width: 880px;
  margin: 0 auto;
}

@media (max-width: 720px) {
  .about-pillars {
    grid-template-columns: 1fr;
    gap: 28px;
  }
}

.pillar {
  text-align: center;
}

.pillar-num {
  font-size: 12px;
  color: var(--gray-light);
  letter-spacing: .1em;
  margin-bottom: 10px;
}

.pillar h3 {
  font-size: 15.5px;
  font-weight: 700;
  margin: 0 0 10px;
}

.pillar p {
  font-size: 13px;
  color: var(--gray);
  margin: 0;
  line-height: 1.9;
}


/* ---------- 6. Blog（検証ログ一覧）セクション ---------- */
/* ここが「記事一覧 → 個別記事へのクリック導線」の起点になるセクション */

.article-list {
  max-width: 760px;
  margin: 0 auto;
}

.article-item {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 20px;
  padding: 22px 0;
  border-bottom: 1px solid var(--line);
}

.article-date {
  font-size: 12px;
  color: var(--gray-light);
  flex-shrink: 0;
  width: 84px;
}

.article-title {
  font-size: 15px;
  font-weight: 500;
  flex-grow: 1;
}

/* 記事タイトルのリンク：ここをクリックすると個別記事（例: articles/mote-hada.html）に遷移する */
.article-title a {
  text-decoration: none;
}

.article-title a:hover {
  color: var(--gray);
  text-decoration: underline;
  text-decoration-color: var(--yellow);
  text-decoration-thickness: 2px;
}

.article-cat {
  font-size: 11.5px;
  color: var(--gray);
  flex-shrink: 0;
  width: 90px;
  text-align: right;
}

@media (max-width: 560px) {
  .article-item {
    flex-wrap: wrap;
  }

  .article-cat {
    width: auto;
    text-align: left;
  }
}

.section-more {
  text-align: center;
  margin-top: 40px;
}

.section-more a {
  font-size: 13px;
  text-decoration: none;
  border-bottom: 1px solid var(--ink);
  padding-bottom: 2px;
}

.section-more a:hover {
  color: var(--gray);
  border-color: var(--gray);
}


/* ---------- 7. Products（商品比較）セクション ---------- */
/* =================================================================
    商品カード：この1ブロックが「商品1件分」の完全な単位です。
    追加する場合は index.html 側の
    <!-- PRODUCT CARD START --> 〜 <!-- PRODUCT CARD END -->
    をまるごとコピーし、カテゴリ／商品名／説明／価格／リンク先を書き換えるだけ。
    グリッドは PC4列・タブレット2列・スマホ1列の固定列なので、
    カードを増やしても自動で次の行に折り返されます。

    ★ このカード自体のデザイン（.product-card 以下）は、
      articles/*.html の記事末尾「商品紹介ブロック」でも
      そのまま再利用しています。トップページと記事ページで
      商品カードの見た目を統一するためです。
   ================================================================= */

.cat-line {
  text-align: center;
  font-size: 13px;
  color: var(--gray);
  margin-bottom: 56px;
  display: flex;
  justify-content: center;
  gap: 22px;
  flex-wrap: wrap;
}

.cat-line a {
  text-decoration: none;
  color: var(--gray);
  padding-bottom: 3px;
}

.cat-line a.active {
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
}

.cat-line a:hover {
  color: var(--ink);
}

.product-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 40px 28px;
}

@media (max-width: 900px) {
  .product-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 36px 20px;
  }
}

@media (max-width: 480px) {
  .product-grid {
    grid-template-columns: 1fr;
  }
}

.product-card {
  display: flex;
  flex-direction: column;
}

.thumb {
  aspect-ratio: 1 / 1;
  background: #F4F4F2;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--gray-light);
  font-size: 12px;
  letter-spacing: .08em;
}

.cat-tag {
  font-size: 11px;
  color: var(--gray);
  letter-spacing: .06em;
  margin-bottom: 6px;
}

.product-card h3 {
  font-size: 14.5px;
  font-weight: 500;
  margin: 0 0 10px;
  line-height: 1.6;
}

.price-rows {
  margin-bottom: 14px;
}

.price-row {
  display: flex;
  justify-content: space-between;
  font-size: 12.5px;
  color: var(--gray);
  padding: 4px 0;
}

.price-row .amt.best {
  color: var(--ink);
  font-weight: 700;
}

.price-row .amt.best::after {
  content: '';
  display: block;
  height: 2px;
  background: var(--yellow);
  margin-top: 2px;
}

/* 商品詳細への導線：リンク文言に商品名を含めることでSEO・アクセシビリティ両方に配慮 */
.card-link {
  font-size: 12.5px;
  text-decoration: none;
  color: var(--ink);
  border-bottom: 1px solid var(--ink);
  padding-bottom: 2px;
  align-self: flex-start;
}

.card-link:hover {
  color: var(--gray);
  border-color: var(--gray);
}

.grid-note {
  font-size: 12px;
  color: var(--gray);
  margin-top: 44px;
  text-align: center;
}

/* 記事ページ末尾で商品カードを1枚だけ中央に表示するためのラッパー。
   .product-card 自体のデザインはトップページと完全に共通。 */
.article-product-wrap {
  max-width: 300px;
  margin: 0 auto 40px;
}


/* ---------- 8. Contact セクション（SNS導線） ---------- */
/* ブログ記事や商品比較で興味を持った読者を、SNSでフォローに繋げるための最終導線 */

.contact-lead {
  text-align: center;
  max-width: 480px;
  margin: 0 auto 36px;
  color: var(--gray);
  font-size: 14px;
}

.sns-row {
  display: flex;
  justify-content: center;
  gap: 16px;
  flex-wrap: wrap;
}

.sns-link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  text-decoration: none;
  color: var(--ink);
  border: 1px solid var(--ink);
  padding: 12px 28px;
  font-size: 13.5px;
  letter-spacing: .04em;
}

.sns-link:hover {
  background: var(--ink);
  color: var(--white);
}


/* ---------- 9. フッター ---------- */

footer {
  border-top: 1px solid var(--line);
  padding: 48px 0;
}

.footer-inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  align-items: center;
}

.footer-inner .logo {
  font-size: 14px;
}

footer nav ul {
  gap: 26px;
}

.footer-sns {
  display: flex;
  gap: 18px;
  font-size: 12.5px;
  margin-top: 18px;
}

.footer-sns a {
  text-decoration: none;
  color: var(--gray);
}

.footer-sns a:hover {
  color: var(--ink);
}

.disclosure {
  font-size: 11.5px;
  color: var(--gray-light);
  margin-top: 26px;
  line-height: 1.9;
}


/* ---------- 10. 記事ページ専用スタイル（articles/*.html） ---------- */

/* パンくず：記事ページからトップに戻るための導線 */
.breadcrumb {
  font-size: 12.5px;
  color: var(--gray);
  padding: 28px 0 0;
}

.breadcrumb a {
  text-decoration: none;
}

.breadcrumb a:hover {
  text-decoration: underline;
}

.article-header {
  padding: 24px 0 48px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 48px;
}

.article-header .cat-tag {
  margin-bottom: 14px;
}

.article-header h1 {
  font-size: clamp(24px, 3.6vw, 34px);
  font-weight: 700;
  line-height: 1.6;
  margin: 0 0 16px;
}

.article-header .meta {
  font-size: 12.5px;
  color: var(--gray-light);
}

.article-body {
  max-width: 680px;
  margin: 0 auto 64px;
  font-size: 15px;
}

.article-body h2 {
  font-size: 19px;
  font-weight: 700;
  margin: 48px 0 18px;
}

.article-body p {
  margin: 0 0 22px;
  color: #333;
}

.article-body .lead-text {
  font-size: 16px;
  color: var(--ink);
}

/* 記事内の体験談ボックス：本文と視覚的に区別してユーザーの共感を誘う仕掛け */
.experience-box {
  background: #F9F9F7;
  border-left: 3px solid var(--yellow);
  padding: 22px 26px;
  margin: 0 0 28px;
  font-size: 14px;
  color: #333;
}

.experience-box .label {
  font-size: 11.5px;
  letter-spacing: .08em;
  color: var(--gray);
  margin-bottom: 8px;
}