@charset "utf-8";

/* ============ Foundation Reset (2025) ============ */
/* 目的：
   - 余白・装飾のゼロベース
   - 一貫した box-sizing
   - メディア要素のレスポンシブ化
   - a を inline-block 既定化
   - アクセシビリティの最小下支え
*/

/* 1) Box sizing 一括 */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* 2) HTML 基本 */
html {
  font-size: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}
body {
  margin: 0;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* 3) 要素のデフォルト余白・見出し等 */
:where(h1, h2, h3, h4, h5, h6, p, blockquote, figure, dl, dd) {
  margin: 0;
}
:where(ul, ol) {
  margin: 0;
  padding: 0;
  list-style: none;
}
:where(hr) {
  margin: 0;
  border: 0;
  height: 1px;
  background: #e5e7eb;
}

h1 {font-size: 2em;}

h2 {font-size: 1.5em;}

h3 {font-size: 1.17em;}

h4 {font-size: 1em;}

h5 {font-size: 0.83em;}

h6 {font-size: 0.67em;}

/* セクショニング要素の display */
:where(article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary) {
  display: block;
}

/* 4) リンク */
a {
  display: inline-block; /* ← 要望どおり既定で inline-block */
  color: inherit;
  text-decoration: none;
  backface-visibility: hidden;
}
a:focus {
  outline: none;
}
a:focus-visible {
  outline: 2px solid #2563eb;
  outline-offset: 2px;
}

/* 5) メディア */
img,
svg,
video,
canvas,
audio,
iframe,
embed,
object {
  display: block;
  max-width: 100%;
}
img {
  display: inline-block;
  height: auto;
}

/* 6) フォーム */
button,
input,
select,
textarea {
  font: inherit;
  color: inherit;
  margin: 0;
}
button,
[type='button'],
[type='submit'],
[type='reset'] {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}
[disabled] {
  cursor: default;
}
textarea {
  resize: vertical;
}
/* iOS のインプットズーム軽減用 */
input,
select,
textarea {
  font-size: 16px;
}

/* 7) テーブル */
table {
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
}
th,
td {
  padding: 0;
  list-style: none;
}

/* 8) 非表示・アクセシビリティ */
[hidden] {
  display: none !important;
}
.visually-hidden {
  position: absolute !important;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

/* 9) 低速環境・reduce motion */
@media (prefers-reduced-motion: reduce) {
  * {
    animation: none !important;
    transition: none !important;
    scroll-behavior: auto !important;
  }
}

/* ============ Utilities ============ */

/* Clearfix（近代版） */
.cf::after {
  content: '';
  display: block;
  clear: both;
}

/* テキストアライン */
.align-left {
  text-align: left;
}
.align-center {
  text-align: center;
}
.align-right {
  text-align: right;
}

/* フロート（必要なら） */
.fl-left {
  float: left;
}
.fl-right {
  float: right;
}
.clear {
  clear: both;
}

/* 画像の半透明ホバー（旧 .alpha の置換） */
.alpha:hover {
  opacity: 0.7;
}

/* ============ Spacing Utilities（整理版） ============
   旧 .mt-10 などを整理。値の重複や綴りミスを修正。
   - PC: 指定値そのまま
   - SP(<=767px): 値を約 50〜60% にスケール
   必要なクラスだけ抜粋してもOK。全量そのまま使ってもOK。
*/

/* ---- margin ---- */
.mt-0 {
  margin-top: 0;
}
.mt-5 {
  margin-top: 5px;
}
.mt-10 {
  margin-top: 10px;
}
.mt-15 {
  margin-top: 15px;
}
.mt-20 {
  margin-top: 20px;
}
.mt-25 {
  margin-top: 25px;
}
.mt-30 {
  margin-top: 30px;
}
.mt-35 {
  margin-top: 35px;
}
.mt-40 {
  margin-top: 40px;
}
.mt-45 {
  margin-top: 45px;
}
.mt-50 {
  margin-top: 50px;
}
.mt-60 {
  margin-top: 60px;
}
.mt-70 {
  margin-top: 70px;
}
.mt-80 {
  margin-top: 80px;
}
.mt-90 {
  margin-top: 90px;
}
.mt-100 {
  margin-top: 100px;
}
.mt-120 {
  margin-top: 120px;
}

.mr-0 {
  margin-right: 0;
}
.mr-5 {
  margin-right: 5px;
}
.mr-10 {
  margin-right: 10px;
}
.mr-15 {
  margin-right: 15px;
}
.mr-20 {
  margin-right: 20px;
}
.mr-25 {
  margin-right: 25px;
}
.mr-30 {
  margin-right: 30px;
}
.mr-35 {
  margin-right: 35px;
}
.mr-40 {
  margin-right: 40px;
}
.mr-45 {
  margin-right: 45px;
}
.mr-50 {
  margin-right: 50px;
}
.mr-60 {
  margin-right: 60px;
}
.mr-70 {
  margin-right: 70px;
}
.mr-80 {
  margin-right: 80px;
}
.mr-90 {
  margin-right: 90px;
}
.mr-100 {
  margin-right: 100px;
}
.mr-120 {
  margin-right: 120px;
}

.ml-0 {
  margin-left: 0;
}
.ml-5 {
  margin-left: 5px;
}
.ml-10 {
  margin-left: 10px;
}
.ml-15 {
  margin-left: 15px;
}
.ml-20 {
  margin-left: 20px;
}
.ml-25 {
  margin-left: 25px;
}
.ml-30 {
  margin-left: 30px;
}
.ml-35 {
  margin-left: 35px;
}
.ml-40 {
  margin-left: 40px;
}
.ml-45 {
  margin-left: 45px;
}
.ml-50 {
  margin-left: 50px;
}
.ml-60 {
  margin-left: 60px;
}
.ml-70 {
  margin-left: 70px;
}
.ml-80 {
  margin-left: 80px;
}
.ml-90 {
  margin-left: 90px;
}
.ml-100 {
  margin-left: 100px;
}
.ml-120 {
  margin-left: 120px;
}

.mb-0 {
  margin-bottom: 0;
}
.mb-5 {
  margin-bottom: 5px;
}
.mb-10 {
  margin-bottom: 10px;
}
.mb-15 {
  margin-bottom: 15px;
}
.mb-20 {
  margin-bottom: 20px;
}
.mb-25 {
  margin-bottom: 25px;
}
.mb-30 {
  margin-bottom: 30px;
}
.mb-35 {
  margin-bottom: 35px;
}
.mb-40 {
  margin-bottom: 40px;
}
.mb-45 {
  margin-bottom: 45px;
}
.mb-50 {
  margin-bottom: 50px;
}
.mb-60 {
  margin-bottom: 60px;
}
.mb-70 {
  margin-bottom: 70px;
}
.mb-80 {
  margin-bottom: 80px;
}
.mb-90 {
  margin-bottom: 90px;
}
.mb-100 {
  margin-bottom: 100px;
}
.mb-120 {
  margin-bottom: 120px;
}

/* ---- padding ---- */
.pt-0 {
  padding-top: 0;
}
.pt-5 {
  padding-top: 5px;
}
.pt-10 {
  padding-top: 10px;
}
.pt-15 {
  padding-top: 15px;
}
.pt-20 {
  padding-top: 20px;
}
.pt-25 {
  padding-top: 25px;
}
.pt-30 {
  padding-top: 30px;
}
.pt-35 {
  padding-top: 35px;
}
.pt-40 {
  padding-top: 40px;
}
.pt-45 {
  padding-top: 45px;
}
.pt-50 {
  padding-top: 50px;
}
.pt-60 {
  padding-top: 60px;
}
.pt-70 {
  padding-top: 70px;
}
.pt-80 {
  padding-top: 80px;
}
.pt-90 {
  padding-top: 90px;
}
.pt-100 {
  padding-top: 100px;
}
.pt-120 {
  padding-top: 120px;
}

.pr-0 {
  padding-right: 0;
}
.pr-5 {
  padding-right: 5px;
}
.pr-10 {
  padding-right: 10px;
}
.pr-15 {
  padding-right: 15px;
}
.pr-20 {
  padding-right: 20px;
}
.pr-25 {
  padding-right: 25px;
}
.pr-30 {
  padding-right: 30px;
}
.pr-35 {
  padding-right: 35px;
}
.pr-40 {
  padding-right: 40px;
}
.pr-45 {
  padding-right: 45px;
}
.pr-50 {
  padding-right: 50px;
}
.pr-60 {
  padding-right: 60px;
}
.pr-70 {
  padding-right: 70px;
}
.pr-80 {
  padding-right: 80px;
}
.pr-90 {
  padding-right: 90px;
}
.pr-100 {
  padding-right: 100px;
}
.pr-120 {
  padding-right: 120px;
}

.pl-0 {
  padding-left: 0;
}
.pl-5 {
  padding-left: 5px;
}
.pl-10 {
  padding-left: 10px;
}
.pl-15 {
  padding-left: 15px;
}
.pl-20 {
  padding-left: 20px;
}
.pl-25 {
  padding-left: 25px;
}
.pl-30 {
  padding-left: 30px;
}
.pl-35 {
  padding-left: 35px;
}
.pl-40 {
  padding-left: 40px;
}
.pl-45 {
  padding-left: 45px;
}
.pl-50 {
  padding-left: 50px;
}
.pl-60 {
  padding-left: 60px;
}
.pl-70 {
  padding-left: 70px;
}
.pl-80 {
  padding-left: 80px;
}
.pl-90 {
  padding-left: 90px;
}
.pl-100 {
  padding-left: 100px;
}
.pl-120 {
  padding-left: 120px;
}

.pb-0 {
  padding-bottom: 0;
}
.pb-5 {
  padding-bottom: 5px;
}
.pb-10 {
  padding-bottom: 10px;
}
.pb-15 {
  padding-bottom: 15px;
}
.pb-20 {
  padding-bottom: 20px;
}
.pb-25 {
  padding-bottom: 25px;
}
.pb-30 {
  padding-bottom: 30px;
}
.pb-35 {
  padding-bottom: 35px;
}
.pb-40 {
  padding-bottom: 40px;
}
.pb-45 {
  padding-bottom: 45px;
}
.pb-50 {
  padding-bottom: 50px;
}
.pb-60 {
  padding-bottom: 60px;
}
.pb-70 {
  padding-bottom: 70px;
}
.pb-80 {
  padding-bottom: 80px;
}
.pb-90 {
  padding-bottom: 90px;
}
.pb-100 {
  padding-bottom: 100px;
}
.pb-120 {
  padding-bottom: 120px;
}

/* ---- SP 縮尺 ---- */
@media (max-width: 767px) {
  /* margin - 上 */
  .mt-10 {
    margin-top: 5px;
  }
  .mt-15 {
    margin-top: 8px;
  }
  .mt-20 {
    margin-top: 10px;
  }
  .mt-25 {
    margin-top: 12px;
  }
  .mt-30 {
    margin-top: 15px;
  }
  .mt-35 {
    margin-top: 18px;
  }
  .mt-40 {
    margin-top: 20px;
  }
  .mt-45 {
    margin-top: 22px;
  }
  .mt-50 {
    margin-top: 25px;
  }
  .mt-60 {
    margin-top: 30px;
  }
  .mt-70 {
    margin-top: 35px;
  }
  .mt-80 {
    margin-top: 40px;
  }
  .mt-90 {
    margin-top: 45px;
  }
  .mt-100 {
    margin-top: 50px;
  }
  .mt-120 {
    margin-top: 60px;
  }

  /* 右 */
  .mr-10 {
    margin-right: 5px;
  }
  .mr-15 {
    margin-right: 8px;
  }
  .mr-20 {
    margin-right: 10px;
  }
  .mr-25 {
    margin-right: 12px;
  }
  .mr-30 {
    margin-right: 15px;
  }
  .mr-35 {
    margin-right: 18px;
  }
  .mr-40 {
    margin-right: 20px;
  }
  .mr-45 {
    margin-right: 22px;
  }
  .mr-50 {
    margin-right: 25px;
  }
  .mr-60 {
    margin-right: 30px;
  }
  .mr-70 {
    margin-right: 35px;
  }
  .mr-80 {
    margin-right: 40px;
  }
  .mr-90 {
    margin-right: 45px;
  }
  .mr-100 {
    margin-right: 50px;
  }
  .mr-120 {
    margin-right: 60px;
  }

  /* 左 */
  .ml-10 {
    margin-left: 5px;
  }
  .ml-15 {
    margin-left: 8px;
  }
  .ml-20 {
    margin-left: 10px;
  }
  .ml-25 {
    margin-left: 12px;
  }
  .ml-30 {
    margin-left: 15px;
  }
  .ml-35 {
    margin-left: 18px;
  }
  .ml-40 {
    margin-left: 20px;
  }
  .ml-45 {
    margin-left: 22px;
  }
  .ml-50 {
    margin-left: 25px;
  }
  .ml-60 {
    margin-left: 30px;
  }
  .ml-70 {
    margin-left: 35px;
  }
  .ml-80 {
    margin-left: 40px;
  }
  .ml-90 {
    margin-left: 45px;
  }
  .ml-100 {
    margin-left: 50px;
  }
  .ml-120 {
    margin-left: 60px;
  }

  /* 下 */
  .mb-10 {
    margin-bottom: 5px;
  }
  .mb-15 {
    margin-bottom: 8px;
  }
  .mb-20 {
    margin-bottom: 10px;
  }
  .mb-25 {
    margin-bottom: 12px;
  }
  .mb-30 {
    margin-bottom: 15px;
  }
  .mb-35 {
    margin-bottom: 18px;
  }
  .mb-40 {
    margin-bottom: 20px;
  }
  .mb-45 {
    margin-bottom: 22px;
  }
  .mb-50 {
    margin-bottom: 25px;
  }
  .mb-60 {
    margin-bottom: 30px;
  }
  .mb-70 {
    margin-bottom: 35px;
  }
  .mb-80 {
    margin-bottom: 40px;
  }
  .mb-90 {
    margin-bottom: 45px;
  }
  .mb-100 {
    margin-bottom: 50px;
  }
  .mb-120 {
    margin-bottom: 60px;
  }

  /* padding 上下左右（代表値のみ縮小） */
  .pt-10 {
    padding-top: 5px;
  }
  .pt-15 {
    padding-top: 8px;
  }
  .pt-20 {
    padding-top: 10px;
  }
  .pt-25 {
    padding-top: 12px;
  }
  .pt-30 {
    padding-top: 15px;
  }
  .pt-35 {
    padding-top: 18px;
  }
  .pt-40 {
    padding-top: 20px;
  }
  .pt-45 {
    padding-top: 22px;
  }
  .pt-50 {
    padding-top: 25px;
  }
  .pt-60 {
    padding-top: 30px;
  }
  .pt-70 {
    padding-top: 35px;
  }
  .pt-80 {
    padding-top: 40px;
  }
  .pt-90 {
    padding-top: 45px;
  }
  .pt-100 {
    padding-top: 50px;
  }
  .pt-120 {
    padding-top: 60px;
  }

  .pr-10 {
    padding-right: 5px;
  }
  .pr-15 {
    padding-right: 8px;
  }
  .pr-20 {
    padding-right: 10px;
  }
  .pr-25 {
    padding-right: 12px;
  }
  .pr-30 {
    padding-right: 15px;
  }
  .pr-35 {
    padding-right: 18px;
  }
  .pr-40 {
    padding-right: 20px;
  }
  .pr-45 {
    padding-right: 22px;
  }
  .pr-50 {
    padding-right: 25px;
  }
  .pr-60 {
    padding-right: 30px;
  }
  .pr-70 {
    padding-right: 35px;
  }
  .pr-80 {
    padding-right: 40px;
  }
  .pr-90 {
    padding-right: 45px;
  }
  .pr-100 {
    padding-right: 50px;
  }
  .pr-120 {
    padding-right: 60px;
  }

  .pl-10 {
    padding-left: 5px;
  }
  .pl-15 {
    padding-left: 8px;
  }
  .pl-20 {
    padding-left: 10px;
  }
  .pl-25 {
    padding-left: 12px;
  }
  .pl-30 {
    padding-left: 15px;
  }
  .pl-35 {
    padding-left: 18px;
  }
  .pl-40 {
    padding-left: 20px;
  }
  .pl-45 {
    padding-left: 22px;
  }
  .pl-50 {
    padding-left: 25px;
  }
  .pl-60 {
    padding-left: 30px;
  }
  .pl-70 {
    padding-left: 35px;
  }
  .pl-80 {
    padding-left: 40px;
  }
  .pl-90 {
    padding-left: 45px;
  }
  .pl-100 {
    padding-left: 50px;
  }
  .pl-120 {
    padding-left: 60px;
  }

  .pb-10 {
    padding-bottom: 5px;
  }
  .pb-15 {
    padding-bottom: 8px;
  }
  .pb-20 {
    padding-bottom: 10px;
  }
  .pb-25 {
    padding-bottom: 12px;
  }
  .pb-30 {
    padding-bottom: 15px;
  }
  .pb-35 {
    padding-bottom: 18px;
  }
  .pb-40 {
    padding-bottom: 20px;
  }
  .pb-45 {
    padding-bottom: 22px;
  }
  .pb-50 {
    padding-bottom: 25px;
  }
  .pb-60 {
    padding-bottom: 30px;
  }
  .pb-70 {
    padding-bottom: 35px;
  }
  .pb-80 {
    padding-bottom: 40px;
  }
  .pb-90 {
    padding-bottom: 45px;
  }
  .pb-100 {
    padding-bottom: 50px;
  }
  .pb-120 {
    padding-bottom: 60px;
  }
}
