@charset "utf-8";


/* --------------- base --------------- */
body{
  
  /* 14-17 */
  font-size: 0.829rem;
  font-size: clamp(0.875rem, 0.829rem + 0.19vw, 1.063rem);
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.7;
  font-feature-settings: "palt" 1;
  color: #333;
}


a{
  text-decoration: none;
  transition: 0.8s cubic-bezier(.15,1,.2,1);
}
.link-hover{
  text-decoration:underline;
}
.link-hover:hover{
  color: #a40000;
}
img,svg {
  width: 100%;
  height: auto;
  vertical-align: middle;
  box-sizing: border-box;
}
button{
  display: block;
  letter-spacing: 0.05em;
}

main{
  position: relative;
  z-index: 1;
  flex: 1;
}
*,
*::before,
*::after {
  box-sizing: boder-box;
}
.block{
  display: block;
}
.none{
  display: none;
}
.ib {
  display: inline-block;
}
.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 --------------- */

/* 和文タイトル */
/* 30~40 */
.ttl-jp-3l{
  font-size: 2.723rem;
  font-size: clamp(2.813rem, 2.737rem + 0.32vw, 3.125rem);
  letter-spacing: 0.12em;
  line-height: 1.4;
}
/* 30~40 */
.ttl-jp-2l{
  font-size: 1.723rem;
  font-size: clamp(1.875rem, 1.723rem + 0.65vw, 2.5rem);
  letter-spacing: 0.12em;
  line-height: 1.2;
}
/* 25~30 */
.ttl-jp-l{
  font-size: 1.487rem;
  font-size: clamp(1.563rem, 1.487rem + 0.32vw, 1.875rem);
  letter-spacing: 0.12em;
  line-height: 1.6;
}
.ttl-jp-m{
  font-size: 0.939rem;
  font-size: clamp(1rem, 0.939rem + 0.26vw, 1.25rem);
  letter-spacing: 0.1em;
  line-height: 1.6;
}
.ttl-lower{
  font-size: 1.487rem;
  font-size: clamp(1.563rem, 1.487rem + 0.32vw, 1.875rem);
  letter-spacing: 0.1em;
  line-height: 1.3;
  font-weight: 600;
  border:1px solid#fff;
  padding: 1.2em 3em;
  width: fit-content;
}

.txt-jp-l{
  font-size: 1.189rem;
  font-size: clamp(1.25rem, 1.189rem + 0.26vw, 1.5rem);
  line-height: 1.4;
}
.txt-jp-m{
  font-size: 0.939rem;
  font-size: clamp(1rem, 0.939rem + 0.26vw, 1.25rem);
}
.txt-jp-s{
  font-size: 0.564rem;
  font-size: clamp(0.625rem, 0.564rem + 0.26vw, 0.875rem);
}

/* 欧文タイトル */
.ttl-en-2l{
  font-size: 1.022rem;
  font-size: clamp(1.25rem, 1.022rem + 0.97vw, 2.188rem);
}
.ttl-en-m{
  font-size: 0.939rem;
  font-size: clamp(1rem, 0.939rem + 0.26vw, 1.25rem);
}
.txt-en-3l{
  font-size: 1.626rem;
  font-size: clamp(3.75rem, 1.626rem + 9.06vw, 12.5rem);
}
.txt-en-2l{
  font-size: 1.723rem;
  font-size: clamp(1.875rem, 1.723rem + 0.65vw, 2.5rem);
}
.txt-en-l{
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.784rem + 0.39vw, 1.25rem);
}

.txt-en-m{
  font-size: 0.939rem;
  font-size: clamp(1rem, 0.939rem + 0.26vw, 1.25rem);
  line-height: 1.4;
}
.txt-en-s{
  font-size: 0.564rem;
  font-size: clamp(0.625rem, 0.564rem + 0.26vw, 0.875rem);
}

/* 文字周り調整 */
.txt-regular{
  font-weight: 400;
}
.txt-medium{
  font-weight: 600;
}
.txt-bold{
  font-weight: 700;
}
.txt-center{
  text-align: center;
}
.txt-left{
  text-align: left;
}
.txt-right{
  text-align: right;
}
.txt-just{
  text-align: justify;
}
.lh-info{
  line-height: 1.6;
}
.en-upper{
  text-transform: uppercase;
}
.en-normal{
  text-transform: none;
}
.big{
  font-size: 2em;
}
.small{
  font-size: 0.5em;
}

/* --------------- wrap --------------- */
.maw200{
  width: min(100%,15em);
  margin-inline:auto;
}
.maw400{
  width: min(100%,30em);
  margin-inline:auto;
}
.maw600{
  width: min(100%,38em);
  margin-inline:auto;
}
.maw700{
  width: min(100%,43em);
  margin-inline:auto;
}
.wrap-m{
  width: min(80%,61.1em);
  margin: 0 auto;
}
.wrap-l{
  width: min(90%,70.8em);
  margin: 0 auto;
}

@media (max-width: 1023px){
  .wrap-m,.wrap-l{
    width: min(90%,48em);
  }
}
@media (max-width: 767px){
  .wrap-m,.wrap-l{
    width: min(100%,39em);
    padding-inline: 15px;
  }
}


/* --------------- space --------------- */
/* 375px~1920px */
/* 112-280 */
.space-3l{
  padding-top: 7rem;
  padding-top: clamp(7rem, 4.451rem + 10.87vw, 17.5rem);
}
.space-3l-bottom{
  padding-bottom: 7rem;
  padding-bottom: clamp(7rem, 4.451rem + 10.87vw, 17.5rem);
}
/* 96-240 */
.space-2l{
  padding-top: 6rem;
  padding-top: clamp(6rem, 3.816rem + 9.32vw, 15rem);
}
.space-2l-bottom{
  padding-bottom: 6rem;
  padding-bottom: clamp(6rem, 3.816rem + 9.32vw, 15rem);
}
/* 80-200 */
.space-l{
  padding-top: 5rem;
  padding-top: clamp(5rem, 3.18rem + 7.77vw, 12.5rem);
}
.space-l-bottom{
  padding-bottom: 5rem;
  padding-bottom: clamp(5rem, 3.18rem + 7.77vw, 12.5rem);
}
/* 64-160 */
.space-m{
  padding-top: 4rem;
  padding-top: clamp(4rem, 2.544rem + 6.21vw, 10rem);
}
.space-m-bottom{
  padding-bottom: 4rem;
  padding-bottom: clamp(4rem, 2.544rem + 6.21vw, 10rem);
}
/* 48-120 */
.space-s{
  padding-top: 3rem;
  padding-top: clamp(3rem, 1.908rem + 4.66vw, 7.5rem);
}
.space-s-bottom{
  padding-bottom: 3rem;
  padding-bottom: clamp(3rem, 1.908rem + 4.66vw, 7.5rem);
}
/* 40-100 */
.space-2s{
  padding-top: 2.5rem;
  padding-top: clamp(2.5rem, 1.59rem + 3.88vw, 6.25rem);
}
.space-2s-bottom{
  padding-bottom: 2.5rem;
  padding-bottom: clamp(2.5rem, 1.59rem + 3.88vw, 6.25rem);
}
/* 34-80 */
.space-3s{
  padding-top: 2.125rem;
  padding-top: clamp(2.125rem, 1.427rem + 2.98vw, 5rem);
}
.space-3s-bottom{
  padding-bottom: 2.125rem;
  padding-bottom: clamp(2.125rem, 1.427rem + 2.98vw, 5rem);
}

.fit{
  width: fit-content;
}
.mb2{
  margin-bottom: 2em;
}
.mb1{
  margin-bottom: 1em;
}
.mb-half{
  margin-bottom: 0.5em;
}

.mt2{
  margin-top: 2em;
}
.mt1{
  margin-top: 1em;
}
.mt-half{
  margin-top: 0.5em;
}

.g2{
  gap:2em;
}
.g1{
  gap: 1em;
}
.g-half{
  gap:0.5em;
}
.gg3{
  grid-gap: 3em;
}
.gg2{
  grid-gap:2em;
}
.gg1{
  grid-gap:1em;
}
.p2{
  padding: 2em;
}
.p1{
  padding: 1em;
}
.p-half{
  padding: 0.5em;
}
.pi2{
  padding-inline: 2em;
}
.pi1{
  padding-inline: 1em;
}
.pi-half{
  padding-inline: 0.5em;
}


/* --------------- color --------------- */

.txt-white, .txt-white a{
  color: #fff;
}
.bg-black{
  background-color: #000;
}
.bg-white{
  background-color: #fff;
}
.bg-gray{
  background-color: #F5F4EA;
}
.bg-green{
  background-color: #2C7D3A;
}
.bg-blue{
  background-color: #069DE6;
}
.bg-red{
  background-color: #E83E69;
}
.border-b-green::after {
  position: absolute;
  bottom:-0.5em;
  left:50%;
  translate:-50% 0;
  content: '';
  width: 3em;
  background-color: #2C7D3A;
  height: 3px;
}
.shadow-white{
  text-shadow: 1px 1px 3px rgba(255,255,255,0.9);
}

/* --------------- layout --------------- */
.relative{
  position: relative;
}
.middle{
  max-inline-size: max-content;
  margin-inline: auto;
}
.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;
}
.align-start{
  align-items: start;
}


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

