/* ==========================================================
   layout.css  -  グリッド / コンテナ / 2カラムレイアウト
   StoryCrafters テーマ レイアウトシステム
========================================================== */

/* ----------------------------------------------------------
   コンテナ
   min() で小さい画面でも左右にパディングを確保
---------------------------------------------------------- */
.container {
  width: min(var(--content-width), 100% - 48px);
  margin-inline: auto;
}

.container--narrow {
  max-width: 780px;
  margin-inline: auto;
}

/* ----------------------------------------------------------
   ページコンテンツエリア
   ヘッダーの高さ分だけ上部をオフセット
   フッターとの間に十分な余白を確保
---------------------------------------------------------- */
.page-content {
  padding-top: var(--header-height);
  padding-bottom: 96px;
  min-height: calc(100vh - var(--header-height));
}

/* ----------------------------------------------------------
   セクション余白
---------------------------------------------------------- */
.section {
  padding-block: 80px;
}

.section--lg {
  padding-block: 120px;
}

.section--sm {
  padding-block: 48px;
}

/* ----------------------------------------------------------
   記事詳細 2カラムレイアウト
   メインカラム + 右サイドバー
---------------------------------------------------------- */
.content-columns {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 56px;
  align-items: start;
}

/* ----------------------------------------------------------
   グリッドシステム
---------------------------------------------------------- */
.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

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

/* 記事カードグリッド（3列デフォルト） */
.post-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 28px;
}

.post-grid--4col {
  grid-template-columns: repeat(4, 1fr);
}

/* ----------------------------------------------------------
   フレックスユーティリティ
---------------------------------------------------------- */
.flex          { display: flex; }
.flex-wrap     { flex-wrap: wrap; }
.flex-center   { display: flex; align-items: center; justify-content: center; }
.flex-between  { display: flex; align-items: center; justify-content: space-between; }
.gap-8         { gap: 8px; }
.gap-16        { gap: 16px; }
.gap-24        { gap: 24px; }
.gap-32        { gap: 32px; }

/* ----------------------------------------------------------
   フッターグリッド
   4カラム：ブランド・メニュー・テーマ・運営者
---------------------------------------------------------- */
.footer-grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 2fr;
  gap: 48px;
  padding-block: 64px;
  border-bottom: var(--border-gold);
}

/* ----------------------------------------------------------
   CTAグリッド（動的カラム）
   表示されるカード数に応じて 1 / 2 / 3 カラムへ自動調整
---------------------------------------------------------- */
.cta-grid {
  display: grid;
  gap: 28px;
  align-items: stretch;
}

.cta-grid--cols-3 {
  grid-template-columns: 1fr 1fr 1fr;
}

.cta-grid--cols-2 {
  grid-template-columns: 1fr 1fr;
}

.cta-grid--cols-1 {
  grid-template-columns: 1fr;
  max-width: 720px;
  margin: 0 auto;
}

/* ----------------------------------------------------------
   テーマカードグリッド（3カラム）
---------------------------------------------------------- */
.theme-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

/* ----------------------------------------------------------
   ステップリスト（横並び）
---------------------------------------------------------- */
.steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  position: relative;
}
