/* ========================================
   base.css - 全ページ共通の土台
   リセット・CSS変数・フォント・レイアウトユーティリティ
   ======================================== */

/* ----- CSS変数（デザイントークン） ----- */
:root {
  /* カラー */
  --color-white: #ffffff;
  --color-primary: #004599;
  --color-text: #191919;
  --color-text-gray: #666666;
  --color-accent: #3da2ff;
  --color-light-blue: #c5dff7;
  /* グラデーション用 */
  --gradient-blue: linear-gradient(203deg, #3da2ff 14.94%, #004599 85.727%);
  --gradient-blue-reverse: linear-gradient(189deg, rgba(255,255,255,0.5) 2.7%, rgba(255,255,255,0.8) 80.68%);
  /* フォント */
  --font-ja: "Noto Sans JP", sans-serif;
  --font-en: "Lato", "Inter", sans-serif;
  /* 余白・ブレークポイント */
  --container-padding: 20px;
  --breakpoint-tablet: 768px;
  --breakpoint-pc: 1024px;
}

/* ----- フォント読み込み ----- */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Lato:wght@400;700&family=Inter:wght@400;700&display=swap");

/* ----- 軽量リセット ----- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: var(--font-ja);
  color: var(--color-text);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: middle;
}

a {
  color: inherit;
  text-decoration: none;
}

ul, ol {
  margin: 0;
  padding: 0;
  list-style: none;
}

/* ----- レイアウトユーティリティ（全ページで使用） ----- */
.l-container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--container-padding);
  padding-right: var(--container-padding);
}

@media (min-width: 1024px) {
  .l-container {
    max-width: 1080px;
    padding-left: 40px;
    padding-right: 40px;
  }
}
