/* ==========================================================================
   Layout Containers - コンテナ・グリッド・基本レイアウト
   全ページで共通するレイアウト要素
   ========================================================================== */

@layer layout {

/* =================================
   基本コンテナ
   ================================= */

.container {
  max-width: var(--container-max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
  width: 100%;
  box-sizing: border-box;
}

.container-wide {
  max-width: var(--container-wide-max-width);
  margin: 0 auto;
  padding: 0 var(--container-padding);
  width: 100%;
  box-sizing: border-box;
}

/* メインページの主要セクション */
.main-section {
  padding: var(--section-padding-current, var(--section-padding)) 0;
  scroll-margin-top: var(--scroll-offset);
}

/* =================================
   グリッドシステム
   ================================= */

.grid {
  display: grid;
  gap: var(--grid-gap);
  width: 100%;
}

.grid-2 {
  grid-template-columns: repeat(2, 1fr);
}

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

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

.grid-auto {
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

/* =================================
   フレックスレイアウト
   ================================= */

.flex {
  display: flex;
  gap: var(--spacing-lg);
}

.flex-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.flex-between {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.flex-column {
  display: flex;
  flex-direction: column;
  gap: var(--spacing-lg);
}

.flex-wrap {
  flex-wrap: wrap;
}

/* =================================
   装飾要素（削除済み - 個別セクションで管理）
   ================================= */

/* =================================
   セクションタイトル共通レイアウト
   ================================= */

.section-header {
  text-align: center;
  margin-bottom: var(--spacing-2xl);
  position: relative;
  z-index: 2;
}

.section-content {
  position: relative;
  z-index: 2;
}

.section-content-wide {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--spacing-lg);
  width: 100%;
  /* 自然な日本語改行設定 */
  word-break: auto-phrase;
  overflow-wrap: break-word;
  text-align: center;
  line-height: 1.7;
}

/* =================================
   特殊背景セクション
   ================================= */

.section-bg-light {
  background: var(--gray-light);
  position: relative;
  overflow: hidden;
}

.section-bg-white {
  background: var(--white);
}

.section-bg-primary {
  background: linear-gradient(135deg, var(--primary-blue), var(--primary-teal));
  color: var(--white);
}

/* =================================
   カードレイアウト
   ================================= */

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: var(--spacing-xl);
  margin-top: var(--spacing-xl);
}

.card-flex {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-xl);
  justify-content: center;
}

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

@media (max-width: 1200px) {
  .container-wide {
    padding: 0 var(--spacing-lg);
  }

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

@media (max-width: 992px) {
  .container,
  .container-wide {
    padding: 0 var(--spacing-lg);
  }

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

  .flex {
    flex-direction: column;
    gap: var(--spacing-md);
  }
}

@media (max-width: 768px) {
  .container,
  .container-wide {
    padding: 0 var(--container-padding-mobile);
  }

  .grid-2,
  .grid-3,
  .grid-4 {
    grid-template-columns: 1fr;
    gap: var(--grid-gap-mobile);
  }

  .grid {
    gap: var(--grid-gap-mobile);
  }

  .flex {
    gap: var(--spacing-sm);
  }

  .card-grid {
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
  }
}

@media (max-width: 480px) {
  .section-content-wide {
    padding: 0 var(--spacing-md);
  }

  .card-grid {
    gap: var(--spacing-md);
  }
}

@media (max-width: 360px) {
  .container,
  .container-wide {
    padding: 0 var(--spacing-sm);
  }
}

}
