@charset "utf-8";


/* --------------- base --------------- */
body{
  font-family: "Inter", "Noto Sans JP", sans-serif;
  /* 15-21 */
  font-size: clamp(0.938rem, 0.846rem + 0.39vw, 1.313rem);
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.85;
  font-feature-settings: "palt" 1;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  color: #282828;
}
a{
  text-decoration: none;
  color: #282828;
}
img,svg {
  width: 100%;
  height: auto;
  vertical-align: middle;
  box-sizing: border-box;
}
button{
  display: block;
  letter-spacing: 0.08em;
}
*,
*::before,
*::after {
  box-sizing: boder-box;
}
.block{
  display: block;
}
.ib {
  display: inline-block;
}
.grid{
  display: grid;
}
.grid2{
  display: grid;
  grid-template-columns: repeat(2,1fr);
}
.grid3{
  display: grid;
  grid-template-columns: repeat(3,1fr);
}
.flex{
  display: flex;
}
.flex-wrap{
  flex-wrap: wrap;
}
.flex-center{
  justify-content: center;
}
.flex-between{
  justify-content: space-between;
}
.flex-around{
  justify-content: space-around;
}
.flex-end{
  justify-content: flex-end;
}
.flex-column{
  flex-direction: column;
}
.align-center{
  align-items: center;
}

@media (max-width: 767px){
  .grid2{
    grid-template-columns: repeat(1,1fr);
  }
  .grid3{
    grid-template-columns: repeat(1,1fr);
  }
}


/* position relativeを使ったり、後ろ背景をりz-indexを上に持ってきたりする機会が多いので、その場合はこのクラス使ってもらうと楽です */
.contents-relative{
  position: relative;
  z-index: 1;
}

/* PCで表示させたり逆にSPだけで表示させたり。端末で改行変わる時とか便利です */
.pc-none{
  display: none;
}
.sp-only{
  display: none;
}
@media (max-width: 1023px){
  .pc-none{
    display: inherit;
  }
  .pc-only{
    display: none;
  }
}
@media (max-width: 767px){
  .sp-none{
    display: none;
  }
  .sp-only{
    display: inherit;
  }
}




/* --------------- type --------------- */
/* font-size */
/* 今回から文字や余白サイズは数字で管理しようかと思います。以前のようなS,M,L等だと追加で文字サイズが必要になった場合詰むのと、デザインから実装する際の確認が手間なので。数字は悪手だと思って避けてましたが、ルール破綻よりはマシだと思うのでこうします。 */
/* 文字サイズ選定基準は明確にはありませんが、本文14~18px、24~40pxを基準に決めていくことが多いです。SPのジャンプ率は、PCフルHDより小さく設定します。 */
.txt-35-90{
  font-size: clamp(2.188rem, 1.353rem + 3.56vw, 5.625rem);
  letter-spacing: 0.08em;
  /* レタースペーシングはサイズごとに設定しないと、bodyや親要素の数値基準になってしまうので、それそれに記載 */
  line-height: 1.2;
  /* 基本、文字サイズが大きいほど行間を狭くしています。ただし、狭すぎると詰まった印象になるので和文は1.35より下は原則作りません。 */
}
.txt-33-80{
  font-size: clamp(2.063rem, 1.35rem + 3.04vw, 5rem);
  letter-spacing: 0.08em;
  line-height: 1.45;
}
.txt-30-65{
  font-size: clamp(1.875rem, 1.344rem + 2.27vw, 4.063rem);
  letter-spacing: 0.08em;
  line-height: 1.45;
}
.txt-28-60{
  font-size: clamp(1.75rem, 1.265rem + 2.07vw, 3.75rem);
  letter-spacing: 0.08em;
  line-height: 1.45;
}
.txt-23-60{
  /* デザインデータ右側見出し上の数字用 */
  font-size: clamp(1.438rem, 0.876rem + 2.39vw, 3.75rem);
  letter-spacing: 0.08em;
  line-height: 1.45;
}
.txt-27-55{
  font-size: clamp(1.688rem, 1.263rem + 1.81vw, 3.438rem);
  letter-spacing: 0.08em;
  line-height: 1.45;
}
.txt-25-50{
  font-size: clamp(1.563rem, 1.183rem + 1.62vw, 3.125rem);
  letter-spacing: 0.08em;
  line-height: 1.45;
}
.txt-23-45{
  font-size: clamp(1.438rem, 1.104rem + 1.42vw, 2.813rem);
  letter-spacing: 0.08em;
  line-height: 1.45;
}
.txt-21-35{
  font-size: clamp(1.313rem, 1.1rem + 0.91vw, 2.188rem);
  letter-spacing: 0.08em;
  line-height: 1.55;
}
.txt-20-32{
  font-size: clamp(1.25rem, 1.068rem + 0.78vw, 2rem);
  letter-spacing: 0.085em;
  line-height: 2;
}
.txt-19-30{
  font-size: clamp(1.188rem, 1.021rem + 0.71vw, 1.875rem);
  letter-spacing: 0.1em;
  line-height: 1.78;
}
.txt-18-27{
  font-size: clamp(1.125rem, 0.988rem + 0.58vw, 1.688rem);
  letter-spacing: 0.08em;
  line-height: 1.55;
}
.txt-16-23{
  font-size: clamp(1rem, 0.894rem + 0.45vw, 1.438rem);
  letter-spacing: 0.08em;
}
.txt-13-23{
  /* アンカーリンクボタン用 */
  font-size: clamp(0.813rem, 0.661rem + 0.65vw, 1.438rem);
  letter-spacing: 0.08em;
  line-height: 1.55;
}
.txt-15-21{
  font-size: clamp(0.938rem, 0.846rem + 0.39vw, 1.313rem);
  letter-spacing: 0.08em;
  line-height: 1.8;
}
.txt-13-17{
  font-size: clamp(0.813rem, 0.752rem + 0.26vw, 1.063rem);
  letter-spacing: 0.08em;
}
.txt-12-15{
  font-size: clamp(0.75rem, 0.704rem + 0.19vw, 0.938rem);
  letter-spacing: 0.08em;
}
.txt-10-12{
  font-size: clamp(0.625rem, 0.595rem + 0.13vw, 0.75rem);
  letter-spacing: 0.08em;
}

.txt-10-18{
  font-size: clamp(0.625rem, 0.443rem + 0.91vw, 1.125rem);
  letter-spacing: 0.08em;
}

/* 今回はほぼSemiBoldとMediumです。一見すると見分けがつきにくいところがあるので注意してください。 */
.txt-regular{
  font-weight: 400;
}
.txt-medium{
  font-weight: 500;
}
.txt-semibold{
  font-weight: 600;
}
.txt-bold{
  font-weight: 700;
}

.txt-center{
  text-align: center;
}
.txt-left{
  text-align: left;
}
.txt-right{
  text-align: right;
}
/* 箱組の文字は、基本justifyを設定 */
.txt-just{
  text-align: justify;
}
.mi-auto{
  margin-inline: auto;
}

/* 言葉ではなく情報部分、例えばtableのコンテンツ等は行間を狭めにする */
.lh-info{
  line-height: 1.55;
}
/* 欧文見出しはこの字間 */
.ls-en{
  letter-spacing: 0.04em;
}



/* --------------- wrap --------------- */

/* コンテンツ幅も数値class名で管理します */
.wrap-1200{
  width: min(78%,57.14em);
  margin: 0 auto;
}
.wrap-1080{
  width: min(74%,51.42em);
  margin: 0 auto;
}
.wrap-1000{
  width: min(72%,47.61em);
  margin: 0 auto;
}
.wrap-920{
  width: min(70%,43.8em);
  margin: 0 auto;
}

@media (max-width: 1023px){
}
@media (max-width: 767px){
  .wrap-1200,
  .wrap-1080,
  .wrap-1000{
    width: min(90%,32em);
  }
}




/* --------------- space --------------- */
/* セクション余白も数値class名で管理します */
/* 375px~1920px */
/* 128-320 */
.space-128-320{
  padding-top: 8rem;
  padding-top: clamp(8rem, 5.087rem + 12.43vw, 20rem);
}
.space-128-320-bottom{
  padding-bottom: 8rem;
  padding-bottom: clamp(8rem, 5.087rem + 12.43vw, 20rem);
}
/* 112-280 */
.space-112-280{
  padding-top: 7rem;
  padding-top: clamp(7rem, 4.451rem + 10.87vw, 17.5rem);
}
.space-112-280-bottom{
  padding-bottom: 7rem;
  padding-bottom: clamp(7rem, 4.451rem + 10.87vw, 17.5rem);
}
/* 96-240 */
.space-96-240{
  padding-top: 6rem;
  padding-top: clamp(6rem, 3.816rem + 9.32vw, 15rem);
}
.space-96-240-bottom{
  padding-bottom: 6rem;
  padding-bottom: clamp(6rem, 3.816rem + 9.32vw, 15rem);
}
/* 80-200 */
.space-80-200{
  padding-top: 5rem;
  padding-top: clamp(5rem, 3.18rem + 7.77vw, 12.5rem);
}
.space-80-200-bottom{
  padding-bottom: 5rem;
  padding-bottom: clamp(5rem, 3.18rem + 7.77vw, 12.5rem);
}
/* 64-160 */
.space-64-160{
  padding-top: 4rem;
  padding-top: clamp(4rem, 2.544rem + 6.21vw, 10rem);
}
.space-64-160-bottom{
  padding-bottom: 4rem;
  padding-bottom: clamp(4rem, 2.544rem + 6.21vw, 10rem);
}
/* 48-120 */
.space-48-120{
  padding-top: 3rem;
  padding-top: clamp(3rem, 1.908rem + 4.66vw, 7.5rem);
}
.space-48-120-bottom{
  padding-bottom: 3rem;
  padding-bottom: clamp(3rem, 1.908rem + 4.66vw, 7.5rem);
}
/* 40-100 */
.space-40-100{
  padding-top: 2.5rem;
  padding-top: clamp(2.5rem, 1.59rem + 3.88vw, 6.25rem);
}
.space-40-100-bottom{
  padding-bottom: 2.5rem;
  padding-bottom: clamp(2.5rem, 1.59rem + 3.88vw, 6.25rem);
}
/* 34-80 */
.space-34-80{
  padding-top: 2.125rem;
  padding-top: clamp(2.125rem, 1.427rem + 2.98vw, 5rem);
}
.space-34-80-bottom{
  padding-bottom: 2.125rem;
  padding-bottom: clamp(2.125rem, 1.427rem + 2.98vw, 5rem);
}
/* 1 */
.space-1{
  padding-top: 1px;
}

/* 文字周りのmtやpt。スマホでは余白が同じ値だと大きく開いて見えるので、少しだけ小さくなるよう調整しています。ある程度準備しておきますが、デザインを忠実に再現することが前提なので汎用クラスでこと足りない場合は個別でCSSを書いてください。 */
/* margin-top */
.mt3{
  margin-top: 3em;
}
.mt2_5{
  margin-top: 2.5em;
}
.mt2{
  margin-top: 2em;
}
.mt1_5{
  margin-top: 1.5em;
}
.mt1{
  margin-top: 1em;
}
.mt0_5{
  margin-top: 0.5em;
}
.mt-2{
  margin-top: -2em;
}
@media (max-width: 767px){
  .mt3{
    margin-top: 1.9em;
  }
  .mt2_5{
    margin-top: 1.7em;
  }
  .mt2{
    margin-top: 1.3em;
  }
  .mt1_5{
    margin-top: 1em;
  }
  .mt1{
    margin-top: 0.8em;
  }
  .mt0_5{
    margin-top: 0.4em;
  }
}
/* margin-bottom */
.mb3{
  margin-bottom: 3em;
}
.mb2_5{
  margin-bottom: 2.5em;
}
.mb2{
  margin-bottom: 2em;
}
.mb1_5{
  margin-bottom: 1.5em;
}
.mb1{
  margin-bottom: 1em;
}
.mb0_5{
  margin-bottom: 0.5em;
}
.mb-2{
  margin-bottom: -2em;
}
@media (max-width: 767px){
  .mb3{
    margin-bottom: 1.9em;
  }
  .mb2_5{
    margin-bottom: 1.7em;
  }
  .mb2{
    margin-bottom: 1.3em;
  }
  .mb1_5{
    margin-bottom: 1em;
  }
  .mb1{
    margin-bottom: 0.8em;
  }
  .mb0_5{
    margin-bottom: 0.4em;
  }
}
/* 全方位paddinfg */
.p2{
  padding: 2em;
}
.p1_5{
  padding: 1.5em;
}
.p1{
  padding: 1em;
}
.p0_5{
  padding: 0.5em;
}
@media (max-width: 767px){
  .p2{
    padding: 1.3em;
  }
  .p1_5{
    padding: 1em;
  }
  .p1{
    padding: 0.8em;
  }
  .p0_5{
    padding: 0.4em;
  }
}
/* padding-bottom */
.pb2{
  padding-bottom: 2em;
}
/* gap */
.g2{
  gap: 2em;
}
.g1_5{
  gap: 1.5em;
}
.g1{
  gap: 1em;
}
.g0_5{
  gap: 0.5em;
}
@media (max-width: 767px){
  .g2{
    gap: 1.3em;
  }
  .g1_5{
    gap: 1em;
  }
  .g1{
    gap: 0.8em;
  }
  .g0_5{
    gap: 0.4em;
  }
}
/* grid-gap */
.gg2{
  grid-gap: 2em;
}
.gg1_5{
  grid-gap: 1.5em;
}
.gg1{
  grid-gap: 1em;
}
.gg0_5{
  grid-gap: 0.5em;
}
@media (max-width: 767px){
  .gg2{
    grid-gap: 1.3em;
  }
  .gg1_5{
    grid-gap: 1em;
  }
  .gg1{
    grid-gap: 0.8em;
  }
  .gg0_5{
    grid-gap: 0.4em;
  }
}
/* padding-inline */
.pi2{
  padding-inline: 2em;
}
.pi1_5{
  padding-inline: 1.5em;
}
.pi1{
  padding-inline: 1em;
}
.pi0_5{
  padding-inline: 0.5em;
}
@media (max-width: 767px){
  .pi2{
    padding-inline: 1.3em;
  }
  .pi1_5{
    padding-inline: 1em;
  }
  .pi1{
    padding-inline: 0.8em;
  }
  .pi0_5{
    padding-inline: 0.4em;
  }
}



/* --------------- color --------------- */
/* 背景色 */
.bg-black{
  background-color: #282828;
}
.bg-white{
  background-color: #fff;
}
.bg-gray01{
  background-color: #f4f5f5;
}
.bg-gray02{
  background-color: #d4d9dc;
}
.bg-blue{
  background-color: #0068b7;
}
.bg-red{
  background-color: #e60012;
}
.bg-green{
  background-color: #3c796c;
}
.bg-lightblue{
  background-color: #dbe7ef;
}

/* border色 */
.border-green{
  border: 2px solid #3C796C;
}
.border-block-blue{
  border-top: 2px solid #0068B7;
  border-bottom: 2px solid #0068B7;
  padding-block: 1em;
}
.border-left-green{
  border-left:5px solid #3C796C;
  padding-left: 1em;
}
.border-left-red{
  border-left:5px solid #E60012;
  padding-left: 1em;
}
.border-bottom-white{
  border-bottom: 2px solid #fff;
  padding-bottom: 0.4em;
}
.border-bottom-white01{
  border-bottom: 1px solid #fff;
  padding-bottom: 0.4em;
}
.border-bottom-black{
  border-bottom: 2px solid #282828;
  padding-bottom: 0.4em;
}

/* 文字色 */
.txt-black, .txt-black a{
  color: #282828;
}
.txt-white, .txt-white a{
  color: #fff;
}
.txt-blue, .txt-blue a{
  color: #0068b7;
}
.txt-red, .txt-red a{
  color: #e60012;
}
.txt-green, .txt-green a{
  color: #3c796c;
}

.pic-480{
  width: min(80%,480px);
  margin-inline: auto;
}
.pic-480 img{
  border-radius: 20px;
}

.round{
  border-radius: 20px;
}
@media (max-width: 767px){
  .round{
    display:block;
    width: 80%;
    margin-inline: auto;
  }
}

.fit{
  width: fit-content;
  padding-inline:1em;
}
