@charset "utf-8";


/* --------------- base --------------- */
body{
  
  /* 14-17 */
  font-family: "Zen Maru Gothic", sans-serif;
  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;
  margin-top: -2em;
}
*,
*::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){
  .sp-none{
    display: none;
  }
  .sp-only{
    display: inherit;
  }
}


/* --------------- type --------------- */

/* 和文タイトル */
/* 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;
  font-weight: 600;
}
.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;
  font-weight: 600;
}
.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;
  margin-inline: auto;
}
.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;
}


.g3{
  gap:3em;
}
.g2{
  gap:2em;
}
.g1{
  gap: 1em;
}
.g-half{
  gap:0.5em;
}
.gg10{
  grid-gap:10%;
}
.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;
}
.pb1{
  padding-bottom: 1em;
}
@media (max-width: 767px){
  .gg10{
    grid-gap: 2em;
  }
}

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

.txt-white, .txt-white a{
  color: #fff;
}
.txt-orange, .txt-orange a{
  color: #DC4F26;
}
.txt-red, .txt-red a{
  color: #a40000;
}
.txt-green, .txt-green a{
  color: #387039;
}
.bg-black{
  background-color: #333;
}
.bg-white{
  background-color: #fff;
}
.bg-gray{
  background-color: #EFEFEF;
}
.bg-orange{
  background-color: #DC4F26;
}
.bg-pink{
  background-color: #FFF5F0;
}
.bg-green{
  background-color: #98BF3A;
}
.bg-green2{
  background-color: #F6FFF0;
}
.bg-green3{
  background-color: #387039;
}
.bg-blue{
  background-color: #76D4E2;
}
.bg-blue2{
  background-color: #EAF9F7;
}
.underline-gray{
  border-bottom:1px solid #C6C6C6;
}
.underline-black{
  border-bottom:1px solid #333;
  padding-bottom: 0.5em;
}
.underline-block-black{
  border-bottom:1px solid #888;
  border-top:1px solid #888;
  padding: 1rem 2.5rem;
  margin-top: 1em;
}
.border-gray{
  border:1px solid #ccc;
}
.border-l-red{
  padding-left:0.5em;
  border-left:4px solid #a40000
}
.hr-black{
  border:none;
  background-color: #231815;
  height: 1px;
  margin: 1em 0;
}

/* --------------- 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-start{
  justify-content: flex-start;
}
.flex-end{
  justify-content: flex-end;
}
.flex-column{
  flex-direction: column;
}
.align-center{
  align-items: center;
}
.align-start{
  align-items: start;
}
.list-disc{
  list-style: disc;
  line-height: 2.2;
}
.list-disc li{
  margin-left: 1em;
  font-size: 1.1em;
}
.list-disc li::marker{
  color: #a40000;
}

.list-leaf li{
  position: relative;
  margin-left:2em;
  text-indent: -0.72em;
}
.list-leaf li+li{
  margin-top: 1em;
}
.list-leaf li::before{
  display: inline-block;
  content:'';
  background-image: url(../image/common/list-icon.png);
  background-size: cover;
  width: 1.2em;
  height: 1.2em;
  margin-bottom: -0.15em;
  margin-left:-1em;
  margin-right: 0.5em;
}
@media (max-width: 1023px){
   .grid3{
    grid-template-columns: repeat(2,1fr);
  }
}
@media (max-width: 767px){
  .grid2{
    grid-template-columns: repeat(1,1fr);
  }
  .grid3{
    grid-template-columns: repeat(1,1fr);
  }
}

/* --------------- logo --------------- */
.logo{
  width: 5em;
  margin-inline: auto;
}

/* --------------- ttl-icon --------------- */
.ttl-icon{
  width: min(20%,5em);
  margin-inline: auto;
}
/* --------------- bg-icon --------------- */
.bg-icon01{
  position: fixed;
  top:23%;
  left:-2em;
  width: 14em;
  z-index:1;
}
.bg-icon02{
  position: fixed;
  bottom:2%;
  right:-3em;
  width: 12em;
  z-index:1;
}
@media (max-width: 767px){
  .bg-icon01{

    display: none;
  }
  .bg-icon02{
    display: none;

  }
}

/* --------------- btn --------------- */
.btn-more{
  display: inline-block;
  width: 14em;
  padding: 0.5em 1.2em;
  transition: 0.3s ease-out;
  border-radius: 50px;
}

/* --------------- pan --------------- */
.pan{
  padding-left: 6.5em;
  padding-top: 2em;
  align-items: center;
  font-weight: 600;
}
.pan li {
  margin: 0;
}
.pan a:hover{
  color: #a40000;
}
@media (max-width: 767px){
  .pan{
    padding-left: 15px;
  }
}

/* --------------- categoly --------------- */
.post-categoly{
  border-radius: 50px;
}
/* --------------- number--------------- */

.cont-number{
  grid-template-columns: 4em 1fr;
}
.cont-number figure{
  width: 100%;
}
@media (max-width: 767px) {
  .number-desc {
    display: flex;
    flex-direction: column;
  }

  .number-desc:nth-of-type(odd) {
    flex-direction: column-reverse; 
  }
  .number-desc+.number-desc{
    margin-top: 2em;
  }
}
/* --------------- company-data--------------- */
.company-data{
  margin-inline: auto;
}
.company-data th{
  padding-right: 3em;
  border-bottom: 1px solid #4890E8;
  padding: 1em 1.5em 1em 0;
}
.company-data td{
  border-bottom: 1px solid #ccc;
  padding: 1em 0 1em 1.5em;
}
@media (max-width: 767px){
  .company-data th{
    padding-right: 1.5em;
    padding: 1em 1.5em 1em 0;
    width: 6em;
  }
}
/* --------------- lower-catch --------------- */
.lower-catch{
  grid-template-columns: 1fr 30%;
  padding: 2em 5%;
}
.lower-catch p+p{
  margin-top: 1.5em;
}
@media (max-width: 767px){
  .lower-catch{
  grid-template-columns: repeat(1,1fr);
}
}