@charset "utf-8";

body{
  font-family: "Noto Sans JP", sans-serif;
  /* 14-18 */
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.814rem + 0.26vw, 1.125rem);
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.7;
  font-feature-settings: "palt" 1;
  color: #333;
  background-color: #f8f8f8;
}

a{
  text-decoration: none;
  color: #222;
  transition: 0.8s cubic-bezier(.15,1,.2,1);
}
img,svg {
  width: 100%;
  height: auto;
  vertical-align: middle;
  box-sizing: border-box;
}

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

.marker{
  padding-inline: 0.2em;
  background: linear-gradient(transparent 65%, #eced6e 35%);
}
.ttl-jp-2l{
  font-size: 1.25rem;
  font-size: clamp(1.563rem, 1.25rem + 1.33vw, 2.5rem);
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.3;
}
.ttl-jp-l{
  font-size: 1.146rem;
  font-size: clamp(1.25rem, 1.146rem + 0.44vw, 1.563rem);
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.3;
}
.ttl-jp-m{
  font-size: 1.1rem;
  font-size: clamp(1.125rem, 1.1rem + 0.13vw, 1.25rem);
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.35;
  font-weight: 500;
}
.ttl-lower{
  font-size: 1.188rem;
  font-size: clamp(1.25rem, 1.188rem + 0.31vw, 1.563rem);
  font-weight: 500;
  letter-spacing: 0.1em;
  line-height: 1.3;
  text-align: center;
  padding-bottom: 1em;
}

.txt-jp-l{
  font-size: 1.146rem;
  font-size: clamp(1.25rem, 1.146rem + 0.44vw, 1.563rem);
  line-height: 1.48;
}
.txt-jp-m{
  font-size: 0.939rem;
  font-size: clamp(1rem, 0.939rem + 0.26vw, 1.25rem);
}
.txt-jp-s{
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.845rem + 0.13vw, 1rem);
}

.ttl-en-2l{
  font-size: 2.25rem;
  font-size: clamp(2.5rem, 2.25rem + 1.25vw, 3.75rem);
  font-family:  '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
}
.ttl-en-m{
  font-size: 0.939rem;
  font-size: clamp(1rem, 0.939rem + 0.26vw, 1.25rem);
  font-family:  '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
}
.txt-en-2l{
  font-size: 2.917rem;
  font-size: clamp(3.125rem, 2.917rem + 0.89vw, 3.75rem);
  font-family:  '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
  line-height: 1;
}
.txt-en-l{
  font-size: 1.042rem;
  font-size:clamp(1.25rem, 1.042rem + 0.89vw, 1.875rem);
  font-family:  '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
  line-height: 1;
}

.txt-en-m{
  font-size: 0.939rem;
  font-size: clamp(1rem, 0.939rem + 0.26vw, 1.25rem);
  font-family:  '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
}
.txt-en-s{
  font-size: 0.875rem;
  font-size: clamp(0.875rem, 0.845rem + 0.13vw, 1rem);
  font-family:  '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
}

.txt-light{
  font-weight: 300;
}
.txt-regular{
  font-weight: 400;
}
.txt-medium{
  font-weight: 500;
}
.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;
}
.small{
  font-size: 0.7em;
}
.round{
  border-radius: 10px;
}

.wrap-l{
  width: min(90%,79em);
  margin: 0 auto;
}
.wrap-m{
  width: min(80%,61.1em);
  margin: 0 auto;
}
.wrap-s{
  width: min(60%,30.1em);
  margin: 0 auto;
}

@media (max-width: 1023px){
  .wrap-m{
    width: min(80%,42em);
  }
}
@media (max-width: 767px){
  .wrap-l{
    width: min(92%,79em);
    margin: 0 auto;
  }
  .wrap-m{
    width: min(92%,32em);
  }
  .wrap-s{
    width: min(80%,22.1em);
    margin: 0 auto;
  }
}

.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);
}
.p2{
  padding: 2em;
}
.p1{
  padding: 1em;
}
.p-half{
  padding: 0.5em;
}
.mb2{
  margin-bottom: 2em;
}
.mb1{
  margin-bottom: 1em;
}
.mt2{
  margin-top: 2em;
}
.mt1{
  margin-top: 1em;
}
.pi1{
  padding-inline: 1em;
}
.g2{
  gap:2em;
}
.g1{
  gap:1em;
}
.gg2{
  grid-gap:2em;
}
.gg1{
  grid-gap:1em;
}

.txt-white, .txt-white a{
  color: #fff;
}
.txt-orange, .txt-orange a{
  color: #ed966e;
}
.txt-beige, .txt-beige a{
  color: #8b7965;
}
.txt-blue{
  color: #6e92ed;
}
.bg-white{
  background-color: #fff;
}
.bg-gray{
  background-color: #f8f8f8;
}
.bg-green{
  background-color: #55bdb2;
}
.bg-orange{
  background-color: #ed966e;
}
.bg-orange-gradiate{
  background: linear-gradient(90deg, #edbf6e,#ed966e);
}
.bg-blue{
  background-color: #6e80ed;
}
.bg-beige{
  background-color: #f4f0e9;
}

.border-bottom-pink{
  border-bottom: 2px solid #f29ea0;
  padding-bottom: 0.3em;
  margin-bottom: 0.8em;
}

.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;
}

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

/* --------------- btn --------------- */
.btn{
  display: block;
  padding: 0.6em 2em;
  width: fit-content;
  border-radius: 50px;
  margin: 0 auto;
}
.btn:hover{
  cursor: pointer;
  opacity:0.8;
}
