html {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}


picture,img{
  display: block;
  width: 100%;
}

/* reset */
#main.main_content{
  max-width: 1440px;
  padding: 0 0;
}

.pc-only{
  display: none;
}
.sp-only {
  display: block;
}
@media (min-width: 769px) {
  .pc-only {
    display: block;
  }
  .sp-only {
    display: none;
  }
}

/* font */
body{
  font-family: "Noto Sans JP", sans-serif;
}

.jakarta {
  font-family: "Plus Jakarta Sans", serif;
  font-weight: 700;
  font-style: normal;
}

/* color */
:root{
  --color-green: #0093A3;
  --color-gray: #666666;
  --color-yellow: #F9F815;
  --color-white: #FFFFFF;
}

#enethos{
  color: #333333;
  position: relative;
}

#enethos::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 32px;
  background-image: linear-gradient(to right, #89cc8f, #dde717 24.6%, #fbfa16 43.3%, #84cc6b 71.9%, #2fb9b7 86.2%, #1db6c6);
  z-index: -1;
}

#enethos .enethos-wrapper{
  max-width: 1440px;
  width: 100%;
  margin: 0 auto;
}

@media screen and (min-width: 769px) and (max-width: 1280px) {
  #enethos::after {
    bottom: 0.78vw;
    height: 2.5vw;
  }
}

@media screen and (max-width: 768px) {
  #enethos::after {
    bottom: 0;
    height: 5.3333vw;
  }

}

/* kv */
#enethos .l-kv{
  width: 100%;
}

#enethos .l-kv h1{
  width: 100%;
}

/* lead */
#enethos .enethos-wrapper .l-lead {
  position: relative;
  background-color: transparent;
  padding: 70px 0 180px;
  box-sizing: border-box;
}

#enethos .enethos-wrapper .l-lead::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 540px;
  opacity: 0.16;
  background-image: linear-gradient(to right, #89cc8f, #dde717 24.6%, #fbfa16 43.3%, #84cc6b 71.9%, #2fb9b7 86.2%, #1db6c6);
  z-index: -1;
}

#enethos .enethos-wrapper .l-lead h2 {
  color: var(--color-green);
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.6;
}

#enethos .enethos-wrapper .l-lead ul {
  display: flex;
  max-width: 988px;
  width: 100%;
  margin: 53px auto 0;
  gap: 40px;
}

#enethos .enethos-wrapper .l-lead ul li {
  width: 316px;
  background-color: var(--color-white);
  color: var(--color-green);
  border-radius: 100vh;
  box-shadow: 0 0 8px rgba(0, 0, 0, .06);
  padding: 50px 0;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.58;
  text-align: center;
}

#enethos .enethos-wrapper .l-lead::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: auto;
  aspect-ratio: 144 / 10;
  background: url('../img/bg-lead.svg') no-repeat;
  background-size: 100% auto;
}

@media screen and (min-width: 769px) and (max-width: 1280px) {

  #enethos .enethos-wrapper .l-lead {
    padding: 5.469vw 0 14vw;
  }

  #enethos .enethos-wrapper .l-lead::before {
    height: 42vw;
  }
  
  #enethos .enethos-wrapper .l-lead h2 {
    font-size: 2.5vw;
  }
  
  #enethos .enethos-wrapper .l-lead ul {
    max-width: unset;
    width: 95%;
    margin: 4.14vw auto 0;
    gap: 2.125vw;
  }
  
  #enethos .enethos-wrapper .l-lead ul li {
    width: 31.8%;
    padding: 3.9vw 0;
    font-size: 2vw;
  }
  
  #enethos .enethos-wrapper .l-lead::after {
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: auto;
    aspect-ratio: 144 / 10;
    background: url('../img/bg-lead.svg') no-repeat;
    background-size: 100% auto;
  }

}

@media screen and (max-width: 768px) {
  #enethos .enethos-wrapper .l-lead {
    padding: 9vw 0 20.8vw;
  }

  #enethos .enethos-wrapper .l-lead::before {
    height: 125vw;
  }

  #enethos .enethos-wrapper .l-lead h2 {
    font-size: 5.333vw;
  }
  
  #enethos .enethos-wrapper .l-lead ul {
    flex-direction: column;
    width: 87.2%;
    margin: 5.333vw auto 0;
    gap: 2.6667vw;
  }
  
  #enethos .enethos-wrapper .l-lead ul li {
    width: 100%;
    border-radius: 100vh;
    box-shadow: 0 0 2.133vw rgba(0, 0, 0, .06);
    padding: 4vw 0;
    font-size: 4.8vw;
    height: 22.133vw;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  
}

/* about */
#enethos .enethos-wrapper .l-about{
  position: relative;
  width: 100%;
  background-color: var(--color-white);
  padding-top: 33px;
  text-align: center;
}

#enethos .enethos-wrapper .l-about .l-about-catch{
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding: 0 38px;
  width: 600px;
  margin: 0 auto;
  text-align: center;
  position: relative;
}

#enethos .enethos-wrapper .l-about .l-about-catch::before{
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 18px;
  height: 36px;
  background: url(../img/ico-about.svg) no-repeat;
  background-size: 100% auto;
}

#enethos .enethos-wrapper .l-about .l-about-catch::after{
  position: absolute;
  right: 0;
  bottom: 0;
  content: '';
  width: 18px;
  height: 36px;
  background: url(../img/ico-about.svg) no-repeat;
  background-size: 100% auto;
  transform: scale(-1, 1);
}


#enethos .enethos-wrapper .l-about .l-about-intro{
  color: var(--color-green);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-align: center;
  position: relative;
  margin: 40px auto 15px;
}

#enethos .enethos-wrapper .l-about .l-about-intro .dot-text{
  position: relative;
}

#enethos .enethos-wrapper .l-about .l-about-intro .dot-text::before{
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 6px;
    height: 6px;
    background: url('../img/2507/ico-circle.svg') no-repeat;
    background-size: 100% auto;
}

#enethos .enethos-wrapper .l-about h2{
  color: var(--color-green);
  display: inline;
  text-align: center;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.08em;
  background: linear-gradient(transparent 70%, #F9F815 30%);
}

#enethos .enethos-wrapper .l-about .l-about-inner{
  max-width: 1100px;
  width: 90%;
  display: flex;
  /* gap: 5.5%; */
  margin: 73px auto 0;
}

#enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail-wrapper{
  width: 55.45%;
}

#enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail{
  font-size: 20px;
  line-height: 2;
  text-align: left;
}

#enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail span{
  font-size: 70%;
}

#enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail-notice{
  display: flex;
  flex-direction: column;
  gap: 11px;
  font-size: 12px;
  font-weight: 500;
  margin-top: 29px;
  text-align: left;
}

#enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail-notice li{
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.5em;
}

#enethos .enethos-wrapper .l-about .l-about-inner picture{
  width: 44.5%;
  margin-top: 7px;
}

#enethos .enethos-wrapper .l-about .l-about-outline{
  max-width: 1100px;
  width: 95%;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 52px auto 0;
  position: relative;
  background-color: transparent;
  padding: 60px 0 0;
  text-align: left;
}

#enethos .enethos-wrapper .l-about .l-about-outline-catch{
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  line-height: 1.458;
  letter-spacing: 0.04em;
}

#enethos .enethos-wrapper .l-about .l-about-outline-title{
  color: var(--color-green);
  font-size: 30px;
  font-weight: 700;
  line-height: 1.2667;
  letter-spacing: 0.04em;
  margin-top: 6px;
  padding: 0 68px 7px;
  position: relative;
}

#enethos .enethos-wrapper .l-about .l-about-outline-title::before{
  position: absolute;
  left: 0;
  bottom: 0;
  content: '';
  width: 18px;
  height: 36px;
  background: url(../img/ico-about.svg) no-repeat;
  background-size: 100% auto;
}

#enethos .enethos-wrapper .l-about .l-about-outline-title::after{
  position: absolute;
  right: 0;
  bottom: 0;
  content: '';
  width: 18px;
  height: 36px;
  background: url(../img/ico-about.svg) no-repeat;
  background-size: 100% auto;
  transform: scale(-1, 1);
}

#enethos .enethos-wrapper .l-about .l-about-outline .l-about-outline-img-wrapper{
  background: url('../img/2507/bg-enethos.png') repeat-y;
  background-size: contain;
  border-radius: 20px;
  padding: 40px 56px;
  max-width: 1100px;
  width: 100%;
  margin: 20px auto 0;
}

#enethos .enethos-wrapper .l-about .l-about-outline .l-about-outline-img{
  position: relative;
  margin: 21px auto 0;
  display: flex;
  justify-content: center;
}

#enethos .enethos-wrapper .l-about .l-about-outline picture{
  width: 100%;
  height: auto;
}

#enethos .enethos-wrapper .l-about .l-about-outline ul{
  width: 89.8%;
  margin-top: 24px;
}

#enethos .enethos-wrapper .l-about .l-about-outline ul li{
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.5em;
  font-size: 14px;
}

#enethos .enethos-wrapper .l-about .l-about-outline ul li::before{
  content: "※";
}

#enethos .enethos-wrapper .l-about .l-about-footer{
  max-width: 1100px;
  width: 95%;
  margin: 36px auto 0;
  font-size: 14px;
  text-align: left;
}

#enethos .enethos-wrapper .l-about .l-about-footer h3{
  font-weight: 700;
}

#enethos .enethos-wrapper .l-about .l-about-footer ul{
  width: 89.8%;
}

#enethos .enethos-wrapper .l-about .l-about-footer ul li{
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.5em;
  line-height: 1.43;
  margin-top: 6px;
}

#enethos .enethos-wrapper .l-about .l-about-footer ul li::before{
  content: "・";
}

@media screen and (min-width: 769px) and (max-width: 1280px) {
  #enethos .enethos-wrapper .l-about{
    padding-top: 2.58vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-catch{
    font-size: 2.1875vw;
    padding: 0 2.968vw;
    width: 46.875vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-catch::before{
    width: 1.4vw;
    height: 2.8125vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-catch::after{
    width: 1.4vw;
    height: 2.8125vw;
  }
  
  
  #enethos .enethos-wrapper .l-about .l-about-intro{
    font-size: 2.8125vw;
    margin: 3.125vw auto 1.17svw;
  }
  
  #enethos .enethos-wrapper .l-about h2{
    font-size: 2.8125vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-inner{
    max-width: unset;
    gap: 5.5%;
    margin: 5.7vw auto 0;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail{
    font-size: 1.5625vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-inner picture{
    width: 44.5%;
    margin-top: 0.5469vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline{
    margin: 4vw auto 0;
    padding: 4.6875vw 0 0;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline::before{
    height: 27.89vw;
    border-radius: 1.5625vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline ul{
    margin-top: 1.875vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline ul li{
    font-size: 1vw;
  }

  #enethos .enethos-wrapper .l-about .l-about-footer{
    max-width: unset;
    margin: 2.344vw auto 0;
    font-size: 1vw;
  }

  #enethos .enethos-wrapper .l-about .l-about-footer ul{
    width: 100%;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-footer ul li{
    margin-top: 0.46875vw;
  }
}

@media screen and (max-width: 768px) {
  #enethos .enethos-wrapper .l-about{
    padding-top: 7.4667vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-catch{
    font-size: 4.2667vw;
    padding: 0 5.333vw;
    width: 91vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-catch::before{
    width: 2.66667vw;
    height: 5.3333vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-catch::after{
    width: 2.66667vw;
    height: 5.3333vw;
  }
  
  
  #enethos .enethos-wrapper .l-about .l-about-intro{
    font-size: 6.4vw;
    margin: 5.333vw auto 5.3333vw;
    line-height: 1.79;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-intro .dot-text::before{
        width: 1.067vw;
        height: 1.067vw;
  }
  
  #enethos .enethos-wrapper .l-about h2{
    display: inline;
    text-align: center;
    font-size: 6.4vw;
    line-height: 1.6667;
    background: linear-gradient(transparent 70%, #F9F815 30%);
  }
  
  #enethos .enethos-wrapper .l-about .l-about-inner{
    max-width: unset;
    width: 87.2%;
    flex-direction: column;
    gap: 7.466vw;
    margin: 8.8vw auto 0;
  }

  #enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail-wrapper{
    width: 100%;
  }

  #enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail{
    font-size: 4.2667vw;
    line-height: 2;
  }

  #enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail span{
    font-size: 100%;
  }

  #enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail-notice{
    gap: 1.6vw;
    font-size: 3.2vw;
    font-weight: 400;
    margin-top: 4.2667vw;
  }

  #enethos .enethos-wrapper .l-about .l-about-inner .l-about-detail-notice li{
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 0.5em;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-inner picture{
    width: 100%;
    margin-top: 0;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline{
    max-width: unset;
    width: 87.2%;
    margin: 0 auto 0;
    padding: 10.133vw 0 0;
  }

  #enethos .enethos-wrapper .l-about .l-about-outline-catch{
    font-size: 4.2667vw;
    line-height: 1.5625;
  }

  #enethos .enethos-wrapper .l-about .l-about-outline-title{
    font-size: 5.33vw;
    line-height: 1.6;
    letter-spacing: 0.08em;
    margin-top: 6px;
    padding: 0 0 7px;
  }

  #enethos .enethos-wrapper .l-about .l-about-outline-title::before{
    left: -1em;
    width: 11px;
    height: 22px;
  }

  #enethos .enethos-wrapper .l-about .l-about-outline-title::after{
    right: -1em;
    width: 11px;
    height: 22px;
  }

  #enethos .enethos-wrapper .l-about .l-about-outline .l-about-outline-img-wrapper{
    border-radius: 2.133vw;
    padding: 7.4667vw 8vw 8vw;
    max-width: unset;
    margin: 4.533vw auto 0;
  }

  #enethos .enethos-wrapper .l-about .l-about-outline .l-about-outline-img{
    width: 91%;
    margin: 0 auto 0;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline picture{
    width: 89.8%;
    height: auto;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline ul{
    width: 71.73vw;
    margin-top: 3.2vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline ul li{
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 0.5em;
    font-size: 3.2vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-outline ul li::before{
    content: "※";
  }
  
  #enethos .enethos-wrapper .l-about .l-about-footer{
    max-width: unset;
    width: 87.2%;
    margin: 4.2667vw auto 0;
    font-size: 3.2vw;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-footer h3{
    font-weight: 700;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-footer ul{
    width: 100%;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-footer ul li{
    display: grid;
    grid-template-columns: auto 1fr;
    column-gap: 0.5em;
    line-height: 1.43;
    margin-top: 6px;
  }
  
  #enethos .enethos-wrapper .l-about .l-about-footer ul li::before{
    content: "・";
  }
}

/* register */
#enethos .enethos-wrapper .l-register {
  max-width: 1100px;
  width: 95%;
  margin: 86px auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* #enethos .enethos-wrapper .l-register .l-register-catch{
  color: var(--color-green);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: 0.08em;
  width: 315px;
  margin: 0 auto;
  padding: 0 38px;
  position: relative;
} */

/* #enethos .enethos-wrapper .l-register .l-register-catch::before{
  position: absolute;
  left: 0;
  bottom: 5px;
  content: '';
  width: 18px;
  height: 36px;
  background: url(../img/ico-register.svg) no-repeat;
  background-size: 100% auto;
} */

/* #enethos .enethos-wrapper .l-register .l-register-catch::after{
  position: absolute;
  right: 0;
  bottom: 5px;
  content: '';
  width: 18px;
  height: 36px;
  background: url(../img/ico-register.svg) no-repeat;
  background-size: 100% auto;
  transform: scale(-1, 1);
} */

#enethos .enethos-wrapper .l-register h2{
  color: var(--color-green);
  text-align: center;
  font-size: 36px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.08em;
}

#enethos .enethos-wrapper .l-register .l-register-sub{
  border: 1px solid var(--color-green);
  border-radius: 20px;
  padding: 30px 0;
  text-align: center;
  width: 100%;
  font-size: 28px;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 23px auto 0;
}

#enethos .enethos-wrapper .l-register .l-register-sub span{
  color: var(--color-green);
  background: linear-gradient(transparent 70%, #F9F815 30%);
}

#enethos .enethos-wrapper .l-register .l-register-attention{
  max-width: 1100px;
  width: 100%;
  font-size: 14px;
  margin: 36px auto 0;
}

#enethos .enethos-wrapper .l-register .l-register-attention p{
  font-weight: 700;
}

#enethos .enethos-wrapper .l-register .l-register-attention ul{
  display: flex;
  flex-direction: column;
}

#enethos .enethos-wrapper .l-register .l-register-attention li{
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.5em;
  line-height: 1.5;
  margin-top: 10px;
}

#enethos .enethos-wrapper .l-register .l-register-attention li:before{
  content: '・';
}

#enethos .enethos-wrapper .l-register .l-register-benefits{
  margin: 68px auto 0;
  padding: 42px 0 53px;
  max-width: 1100px;
  width: 100%;
  background: url('../img/2507/bg-enethos.png') repeat-y;
  background-size: contain;
  border-radius: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#enethos .enethos-wrapper .l-register .l-register-benefits h3{
  color: var(--color-green);
  font-size: 30px;
  font-weight: 700;
  letter-spacing: 0.04em;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-read{
  margin: 16px auto 0;
  font-size: 16px;
  line-height: 1.75;
  letter-spacing: 0.04em;
  text-align: center;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-wrapper{
  display: flex;
  max-width: 630px;
  width: 100%;
  gap: 50px;
  margin: 40px auto 0;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner{
  width: 53.33%;
}

#enethos .enethos-wrapper .l-register .l-register-benefits figure{
  width: calc(53.33% - 50px);
}

#enethos .enethos-wrapper .l-register .l-register-benefits figure figcaption{
  text-align: center;
  font-size: 12px;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dl{
  position: relative;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0.04em;
  display: flex;
  flex-wrap: nowrap;
  padding: 18px 0;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dl::after{
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 3px;
  background: linear-gradient(to right, #0093A3 3px, transparent 3px) repeat-x;
    background-size: 9px 3px;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dt{
  color: var(--color-green);
  width: 62.5%;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dt span{
  color: #333;
  font-size: 12px;
  font-weight: 400;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dd{
  text-align: right;
  width: 37.5%;
}

#enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner > p{
  margin-top: 10px;
  font-size: 12px;
  line-height: 1.25;
} 


@media screen and (min-width: 769px) and (max-width: 1280px) {
  #enethos .enethos-wrapper .l-register {
    max-width: unset;
    margin: 6.72vw auto 0;
  }
  
  #enethos .enethos-wrapper .l-register .l-register-catch{
    font-size: 2.8vw;
    width: 24.6vw;
    padding: 0 2.968vw;
  }
  
  #enethos .enethos-wrapper .l-register .l-register-catch::before{
    bottom: 0.39vw;
    width: 1.4vw;
    height: 2.8125vw;
  }
  
  #enethos .enethos-wrapper .l-register .l-register-catch::after{
    bottom: 0.39vw;
    width: 1.4vw;
    height: 2.8125vw;
  }
  
  #enethos .enethos-wrapper .l-register h2{
    font-size: 4vw;
    margin: 1.172vw auto 0;
    padding: 0 0.39vw 0 0.78vw;
  }
  
  #enethos .enethos-wrapper .l-register .l-register-notice{
    font-size: 1.56vw;
    margin-top: 1.95vw;
  }
}

@media screen and (max-width: 768px) {
  #enethos .enethos-wrapper .l-register {
    max-width: unset;
    width: 87.2%;
    margin: 10.6667vw auto 0;
    text-align: center;
  }
  
  #enethos .enethos-wrapper .l-register .l-register-catch{
    font-size: 7.46667vw;
    width: 66vw;
    padding: 0 8.8vw;
  }
  
  #enethos .enethos-wrapper .l-register .l-register-catch::before{
    bottom: 1.333vw;
    width: 3.7333vw;
    height: 7.46667vw;
  }
  
  #enethos .enethos-wrapper .l-register .l-register-catch::after{
    bottom: 1.333vw;
    width: 3.7333vw;
    height: 7.46667vw;
  }
  
  #enethos .enethos-wrapper .l-register h2{
    font-size: 6.4vw;
    line-height: 1.5833;
    margin: 14.4vw auto 0;
  }

  #enethos .enethos-wrapper .l-register h2 .small{
    font-size: 0.8em;
  }

  #enethos .enethos-wrapper .l-register .l-register-sub{
    border-radius: 2.133vw;
    padding: 5.8667vw 0;
    font-size: 5.333vw;
    line-height: 1.6;
    margin: 4.8vw auto 0;
  }

  #enethos .enethos-wrapper .l-register .l-register-sub span{
    color: var(--color-green);
    background: linear-gradient(transparent 70%, #F9F815 30%);
  }

  #enethos .enethos-wrapper .l-register .l-register-attention{
    max-width: unset;
    text-align: left;
    font-size: 3.2vw;
    margin: 4.2667vw auto 0;
  }

  #enethos .enethos-wrapper .l-register .l-register-attention li{
    margin-top: 1.333vw;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits{
    margin: 10.133vw auto 0;
    padding: 9.0667vw 0 9.0667vw;
    max-width: unset;
    width: 100%;
    border-radius: 2.133vw;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits h3{
    font-size: 5.333vw;
    letter-spacing: 0.08em;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-read{
    margin: 2.133vw auto 0;
    font-size: 4.2667vw;
    line-height: 1.5625;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-wrapper{
    flex-direction: column;
    max-width: unset;
    width: 88.99%;
    gap: 7.4667vw;
    margin: 3.2vw auto 0;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner{
    width: 100%;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits figure{
    width: 100%;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits figure figcaption{
    text-align: center;
    font-size: 3.2vw;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dl{
    font-size: 4.8vw;
    padding: 4.2667vw 0;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dl::after{
    content: '';
    position: absolute;
    bottom: 0;
    left: 0;
    height: 3px;
    background: linear-gradient(to right, #0093A3 3px, transparent 3px) repeat-x;
      background-size: 9px 3px;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dt{
    color: var(--color-green);
    width: 62.5%;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dt span{
    color: #333;
    font-size: 12px;
    font-weight: 400;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner dd{
    text-align: right;
    width: 37.5%;
  }

  #enethos .enethos-wrapper .l-register .l-register-benefits .l-register-benefits-inner > p{
    margin-top: 1em;
    font-size: 3.2vw;
  } 
}


/* l-purchase */
#enethos .enethos-wrapper .l-purchase{
  max-width: 1100px;
  width: 95%;
  padding: 104px 0 0;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#enethos .enethos-wrapper .l-purchase h2{
  color: var(--color-green);
  font-size: 36px;
  font-weight: 700;
  letter-spacing: 0.08em;
}

#enethos .enethos-wrapper .l-purchase .l-purchase-sub{
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.08em;
  margin: 8px auto 0;
}

#enethos .enethos-wrapper .l-purchase .l-purchase-wrapper{
  width: 100%;
  padding: 50px 0 20px;
  background: url('../img/2507/bg-enethos.png') repeat-y;
  background-size: contain;
  border-radius: 20px;
  margin: 10px auto 0;
}

#enethos .enethos-wrapper .l-purchase .l-purchase-wrapper > img{
  width: 43.9%;
  margin: 0 auto;
}

#enethos .enethos-wrapper .l-purchase .l-purchase-notice{
  margin: 10px 0 0;
  width: 100%;
}

#enethos .enethos-wrapper .l-purchase .l-purchase-notice li{
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 0.5em;
  font-size: 14px;
  line-height: 1.429;
  margin-top: 8px;
}

#enethos .enethos-wrapper .l-purchase .l-purchase-notice li:before{
  content: '・';
}

@media screen and (max-width: 768px) {
  #enethos .enethos-wrapper .l-purchase{
    max-width: unset;
    width: 87.2%;
    padding: 26.667vw 0 0;
  }

  #enethos .enethos-wrapper .l-purchase h2{
    font-size: 6.4vw;
  }

  #enethos .enethos-wrapper .l-purchase .l-purchase-sub{
    font-size: 3.733vw;
    margin: 1.6vw auto 0;
  }

  #enethos .enethos-wrapper .l-purchase .l-purchase-wrapper{
    padding: 8.533vw 0 0.8vw;
    border-radius: 2.133vw;
    margin: 1.6vw auto 0;
  }

  #enethos .enethos-wrapper .l-purchase .l-purchase-wrapper > img{
    width: 91.13%;
    margin: 0 auto;
  }

  #enethos .enethos-wrapper .l-purchase .l-purchase-notice{
    margin: 4.633vw 0 0;
  }

  #enethos .enethos-wrapper .l-purchase .l-purchase-notice li{
    font-size: 3.2vw;
    line-height: 1.667;
    margin-top: 2.133vw;
  }
}

/* l-qa */
#enethos .enethos-wrapper .l-qa{
  max-width: 1100px;
  width: 95%;
  margin: 162px auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#enethos .enethos-wrapper .l-qa h2{
  color: var(--color-green);
  font-size: 36px;
  font-weight: 600;
  letter-spacing: 0.08em;
}

#enethos .enethos-wrapper .l-qa .accordion{
  width: 100%;
  margin: 36px auto 0;
  border-bottom: 1px solid #E6E6E6;
}

#enethos .enethos-wrapper .l-qa .accordion h3{
  width: 100%;
  border-top: 1px solid #E6E6E6;
  padding: 32px 0 20px;
  position: relative;
}

#enethos .enethos-wrapper .l-qa .accordion h3::before{
  content: 'Q';
  position: absolute;
  top: 40px;
  bottom: 0;
  margin: 0 0 0;
  color: var(--color-green);
  font-family: "Plus Jakarta Sans", serif;
  font-size: 26px;
  font-weight: 600;
}

#enethos .enethos-wrapper .l-qa .accordion h3 button{
  width: 100%;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  padding: 0;
  margin: 0;
  border: none;
  text-align: left;
  position: relative;
}

#enethos .enethos-wrapper .l-qa .accordion h3 button::before{
  content: '';
  position: absolute;
  right: 14px;
  top: 18px;
  background: #333;
  border-radius: 2px;
  width: 20px;
  height: 2px;
  transition: background 0.4s;
}

#enethos .enethos-wrapper .l-qa .accordion h3 button::after{
  content: '';
  position: absolute;
  right: 23px;
  top: 9px;
  width: 2px;
  height: 20px;
  background: #333;
  border-radius: 2px;
  transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
  transform: rotate(0deg);
}

#enethos .enethos-wrapper .l-qa .accordion h3 .toggle-title[aria-expanded="true"]::after {
  transform: rotate(-90deg);
}

#enethos .enethos-wrapper .l-qa .accordion h3 button span{
  color: #333;
  display: block;
  max-width: 994px;
  width: 90%;
  padding-left: 46px;
  font-size: 26px;
  font-weight: 700;
  line-height: 1.577;
  letter-spacing: 0.04em;
  text-align: left;
}

#enethos .enethos-wrapper .l-qa .accordion .toggle-body{
  position: relative;
  padding: 10px 0 40px;
  width: 90%;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transition: max-height 0.8s cubic-bezier(0.4,0,0.2,1), opacity 0.8s cubic-bezier(0.4,0,0.2,1), padding 0.8s cubic-bezier(0.4,0,0.2,1);
}

#enethos .enethos-wrapper .l-qa .accordion .toggle-body::before{
  content: 'A';
  position: absolute;
  top: 3px;
  margin: 0 0 0 3px;
  color: var(--color-green);
  font-family: "Plus Jakarta Sans", serif;
  font-size: 26px;
  font-weight: 600;
  line-height: 2.077;
}

#enethos .enethos-wrapper .l-qa .accordion .toggle-body span{
  font-size: 20px;
  line-height: 2;
  padding-left: 46px;
  display: block;
}

#enethos .enethos-wrapper .l-qa .accordion .toggle-body span a{
  text-decoration: underline;
}

#enethos .enethos-wrapper .l-qa .accordion .toggle-body[aria-hidden="false"] {
  max-height: 300px;
  opacity: 1;
  transition: max-height 0.8s cubic-bezier(0.4,0,0.2,1), opacity 0.8s cubic-bezier(0.4,0,0.2,1), padding 0.8s cubic-bezier(0.4,0,0.2,1);
}

.toggle-body[aria-hidden="true"] {
  max-height: 0;
  opacity: 0;
  padding: 0 0 0 0;
  transition: max-height 0.8s cubic-bezier(0.4,0,0.2,1), opacity 0.8s cubic-bezier(0.4,0,0.2,1), padding 0.8s cubic-bezier(0.4,0,0.2,1);
}

@media screen and (min-width: 769px) and (max-width: 1280px) {
  #enethos .enethos-wrapper .l-qa .accordion .toggle-body[aria-hidden="false"] {
    max-height: 500px;
    opacity: 1;
    transition: max-height 0.8s cubic-bezier(0.4,0,0.2,1), opacity 0.8s cubic-bezier(0.4,0,0.2,1), padding 0.8s cubic-bezier(0.4,0,0.2,1);
  }
}

@media screen and (max-width: 768px) {
  #enethos .enethos-wrapper .l-qa{
    max-width: unset;
    width: 87.2%;
    margin: 18.133vw auto 0;
  }

  #enethos .enethos-wrapper .l-qa h2{
    font-size: 6.4vw;
  }

  #enethos .enethos-wrapper .l-qa .accordion{
    margin: 4.8vw auto 0;
  }

  #enethos .enethos-wrapper .l-qa .accordion h3{
    padding: 8vw 0 8vw;
  }

  #enethos .enethos-wrapper .l-qa .accordion h3::before{
    top: 5.6667vw;
    font-size: 5.8667vw;
    line-height: 1.818;
  }

  #enethos .enethos-wrapper .l-qa .accordion h3 button::before{
    right: 0;
    top: 3vw;
    bottom: 0;
    width: 4.2667vw;
    height: 2px;
  }

  #enethos .enethos-wrapper .l-qa .accordion h3 button::after{
    right: calc(2.4667vw - 2px);
    top: 1.15vw;
    height: 4.2667vw;
  }

  #enethos .enethos-wrapper .l-qa .accordion h3 button span{
    width: 88%;
    display: block;
    padding-left: 9.133vw;
    font-size: 4.26667vw;
    line-height: 1.577;
  }

  #enethos .enethos-wrapper .l-qa .accordion .toggle-body{
    position: relative;
    padding: 2.6667vwvw 0 8vw;
    width: 90%;
  }

  #enethos .enethos-wrapper .l-qa .accordion .toggle-body::before{
    top: 0;
    margin: 0 0 0 1px;
    font-size: 5.8667vw;
    line-height: 2.4545;
  }

  #enethos .enethos-wrapper .l-qa .accordion .toggle-body span{
    font-size: 4.2667vw;
    padding-left: 9.133vw;
  }

  #enethos .enethos-wrapper .l-qa .accordion .toggle-body span a{
    font-size: 4.2667vw;
    text-decoration: underline;
  }

  #enethos .enethos-wrapper .l-qa .accordion .toggle-body[aria-hidden="false"] {
    max-height: 700px;
  }
}
 
/* footer */
#enethos .enethos-wrapper .l-footer{
  max-width: 1440px;
  width: 100%;
  margin: 75px auto 0;
  padding: 120px 0 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
}

#enethos .enethos-wrapper .l-footer::before{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 1500px;
  opacity: 0.16;
  background-image: linear-gradient(to right, #89cc8f, #dde717 24.6%, #fbfa16 43.3%, #84cc6b 71.9%, #2fb9b7 86.2%, #1db6c6);
  z-index: -1;
}

#enethos .enethos-wrapper .l-footer::after{
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  aspect-ratio: 144 / 10;
  background: url('../img/2507/bg-footer.png') no-repeat;
  background-size: 100% auto;
}

#enethos .enethos-wrapper .l-footer .footer-register{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  max-width: 560px;
  width: 50%;
  height: 80px;
  margin: 0 auto;
  color: #fff;
  background: var(--color-green);
  border-radius: 100vh;
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.04em;
  box-shadow: 0 3px 6px rgba(0, 0, 0, 0.16);
}

#enethos .enethos-wrapper .l-footer .footer-register span{
  width: 19px;
  height: 15px;
  background: url('../img/2507/ico-blank.svg') no-repeat;
  background-size: 100% auto;
}
#enethos .enethos-wrapper .l-footer .l-footer-contact{
  max-width: 1100px;
  width: 100%;
  margin: 80px auto 0;
  display: flex;
  flex-direction: column;
  align-items: center;
}

#enethos .enethos-wrapper .l-footer .l-footer-contact h4{
  color: var(--color-green);
  font-size: 20px;
  font-weight: 700;
  line-height: 2;
  margin: 0 auto;
}

#enethos .enethos-wrapper .l-footer .l-footer-contact-wrapper{
  display: flex;
  width: 100%;
  border: 1px solid var(--color-green);
  background: #fff;
  padding: 30px 59px;
}

#enethos .enethos-wrapper .l-footer .l-footer-contact-inner{
  width: 50%;
}

#enethos .enethos-wrapper .l-footer h5{
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 0.04em;
  position: relative;
  padding-left: 19px;
}

#enethos .enethos-wrapper .l-footer h5::before{
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  margin: auto 0;
  background: var(--color-green);
  border-radius: 100vh;
  width: 14px;
  height: 14px;
}

#enethos .enethos-wrapper .l-footer .l-footer-contact-title{
  color: var(--color-green);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 16px 0 0;
  padding-left: 20px;
}

#enethos .enethos-wrapper .l-footer .l-footer-contact-tel{
  font-size: 20px;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 10px 0 0;
  padding-left: 20px;
}

#enethos .enethos-wrapper .l-footer .l-footer-contact-tel span{
  font-size: 16px;
}

#enethos .enethos-wrapper .l-footer .l-footer-contact-hours{
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.04em;
  margin: 10px 0 0;
  padding-left: 20px;
}

#enethos .enethos-wrapper .l-footer .footer-contact span{
  width: 19px;
  height: 15px;
  background: url('../img/2507/ico-blank-g.svg') no-repeat;
  background-size: 100% auto;
}

#enethos .enethos-wrapper .l-footer .footer-solaelu{
  max-width: 542px;
  width: 50%;
  margin: 100px auto 0;
}

#enethos .enethos-wrapper .l-footer .l-footer-sdgs-title{
  margin: 90px auto 0;
  color: var(--color-blue);
  font-size: 32px;
  font-weight: 700;
}

#enethos .enethos-wrapper .l-footer .l-footer-sdgs-wrapper{
  max-width: 1100px;
  width: 95%;
  background-color: #fff;
  border-radius: 20px;
  padding: 50px 0;
  margin: 78px auto 0;
}

#enethos .enethos-wrapper .l-footer .l-footer-sdgs-inner{
  width: 56.4%;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}

#enethos .enethos-wrapper .l-footer .l-footer-sdgs-inner .l-footer-sdgs-img01{
  width: 65.645%;
}

#enethos .enethos-wrapper .l-footer .l-footer-sdgs-inner .l-footer-sdgs-img02{
  width: 28.548%;
}

@media screen and (min-width: 769px) and (max-width: 1280px) {
  #enethos .enethos-wrapper .l-footer .l-footer-contact{
    max-width: unset;
    width: 95%;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-wrapper{
    padding: 30px 5px;
  }

}

@media screen and (max-width: 768px) {
  #enethos .enethos-wrapper .l-footer{
    max-width: unset;
    width: 100%;
    margin: 14.667vw auto 0;
    padding: 21.333vw 0 17vw;
  }

  #enethos .enethos-wrapper .l-footer::before{
    height: 250vw;
  }

  #enethos .enethos-wrapper .l-footer .footer-register{
    gap: 4.8vw;
    max-width: unset;
    width: 87.2%;
    height: 19.2vw;
    font-size: 4.2667vw;
  }

  #enethos .enethos-wrapper .l-footer .footer-register span{
    width: 5.0667vw;
    height: 4vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-title{
    margin: 9.333vw auto 0;
    font-size: 4.2667vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact{
    max-width: unset;
    width: 87.2%;
    margin: 9.6vw auto 0;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact h4{
    font-size: 4.2667vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-wrapper{
    flex-direction: column;
    gap: 4.2667vw;
    padding: 5.3333vw 3.75vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-inner{
    width: 100%;
  }

  #enethos .enethos-wrapper .l-footer h5{
    font-size: 3.733vw;
    padding-left: 3.5vw;
  }

  #enethos .enethos-wrapper .l-footer h5::before{
    width: 3.2vw;
    height: 3.2vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-title{
    font-size: 4.2667vw;
    margin: 3.2vw 0 0;
    padding-left: 3.6vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-tel{
    font-size: 4.2667vw;
    margin: 2.6667vw 0 0;
    padding-left: 3.6vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-tel span{
    font-size: 3.2vw;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-contact-hours{
    font-size: 3.2vw;
    margin: 2.6667vw 0 0;
    padding-left: 3.6vw;
  }

  #enethos .enethos-wrapper .l-footer .footer-solaelu{
    max-width: unset;
    width: 87.2%;
    margin: 17vw auto 0;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-sdgs-wrapper{
    max-width: unset;
    width: 93.6%;
    border-radius: 5.333vw;
    padding: 8.5333vw 0;
    margin: 9.6vw auto 0;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-sdgs-inner{
    width: 86.6%;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-sdgs-inner .l-footer-sdgs-img01{
    width: 65.645%;
  }

  #enethos .enethos-wrapper .l-footer .l-footer-sdgs-inner .l-footer-sdgs-img02{
    width: 28.548%;
  }
}

/* btn-register */
.l-btn-register{
  position: fixed;
  bottom: 20px;
  right: 20px;
  /* padding-block: 16px; */
  z-index: 10;
  width: 240px;
  height: auto;
  aspect-ratio: 1 / 1;
}

@media screen and (min-width: 769px) and (max-width: 1280px) {
  .l-btn-register{
    bottom: 1.5625vw;
    right: 1.5625vw;
    width: 18.75vw;
    height: auto;
  }
}

@media screen and (max-width: 768px) {
  .l-btn-register{
    bottom: 2.1333vw;
    right: 2.1333vw;
    width: 38.4vw;
    height: auto;
  }
}

@media (min-width: 769px) {
  a[href^="tel:"] {
      pointer-events: none;
      cursor: default;
      text-decoration: none!important;
  }
}

/* link-external */

.link-external{
  position: relative;
  padding-right: 20px;
}

.link-external::after{
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto 0;
  width: 16px;
  height: 16px;
  background: url('../../../common/img/blank_icon.svg') no-repeat;
  background-size: 100% auto;;
}