.lock-scroll {
  overflow: hidden;
  height: 100vh;
  touch-action: none;
}

.loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index:1001;
  background: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 1s cubic-bezier(0.7, 0.05, 0.8, 0.5);

  &.js-loading-end {
    opacity: 0;
  }
}

@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

#loading-logo-g {
  opacity: 0;
  width: 16.302vw;
  height: auto;
  position: absolute;
    top: 50%;
  left: 52%;
  transform: translate(-50%,-50%);
  z-index: 1; /* 下 */
}
#base path {
  fill:#006400; /* 塗りの色 */
}
#mask path {
  fill:none; /* 塗りの色 */
  stroke:#ffffff; /* 線の色 */
  stroke-width:50px; /* 線幅 */
}
.loading-logo-wrap{
  width: 16.302vw;
  height: 16.302vw;
  position: absolute;
    top: 50%;
  left: 52%;
  right: auto;                /* ← 右基準は外す */
  transform: translate(-50%, -50%);  /* 横も中央に */
  z-index: 2; /* 下 */
}
.loading-logo {
  opacity: 0;
  width: 6.458vw;
  height: auto;
  position: absolute;
  top: 55%;
  /* left: 47.5%; */
  left: 38%;
  right: auto;                /* ← 右基準は外す */
  transform: translate(-50%, -50%);  /* 横も中央に */
  z-index: 2; /* 下 */
}

@media screen and (max-width: 768px) {
  #loading-logo-g {
    width: 190px;
    left: 53%;
    top: 51%;
  }
  .loading-logo-wrap{
    width: 190px;
    height: 190px;
  }
  .loading-logo {
    width: 75px;
    top: 60%;
    left: 42%;
    /* top: 51%;
    left: 49%; */
  }
}
@media screen and (max-width: 600px) {
  #loading-logo-g {
    left: 54%;
  }
}
@media screen and (max-width: 500px) {
  #loading-logo-g {
    left: 56%;
  }
  .loading-logo {
    left: 46%;
    /* top: 51%;
    left: 49%; */
  }
}
@media screen and (max-width: 375px){
  .loading-logo {

    left: 45%;
    /* top: 51%;
    left: 49%; */
  }
}

#kv-logo-wh {
  /* opacity: 1; */
  width: min(52.604vw, 1010px);
  height: auto;
  position: absolute;
    top: 50%;
  left: 56%;
  transform: translate(-50%,-50%);
  z-index: 10; /* 下 */
}
#kv-base path {
  fill:#fff; /* 塗りの色 */
}
#kv-mask path {
  fill:none; /* 塗りの色 */
  stroke:#ffffff; /* 線の色 */
  stroke-width:50px; /* 線幅 */
}
.kv .kv__logo img {
  /* opacity: 1; */
  width: min(20.833vw, 400px);
  height: auto;
  position: absolute;
  top: 54%;
  left: 50%;
  transform: translate(-50%,-50%);
  z-index: 11; /* 下 */
}
@media (max-width: 1240px) and (min-width: 769px) {
  .kv .kv__logo img {
    top: 52%;
  }
}
@media screen and (max-width: 768px) {
  #kv-logo-wh {
    width: 339px;
    left: 54%;
    top: 48%;
  }
  .kv .kv__logo img {
    width: 134px;
    top: 50%;
    left: 48%;
  }
}
@media screen and (max-width: 540px) {
  #kv-logo-wh {
    left: 54%;
  }
}
@media screen and (max-width: 500px) {
  #kv-logo-wh {
    left: 58%;
  }
}

.kv {
  opacity: 0;
  transition: opacity 1s ease-out;
}

.kv.show {
  opacity: 1;
}

.kv__logo,
.header,
.kv__copy,
.kv__scroll,
.kv__scroll_text{
  opacity: 0;
  transition: opacity 1s ease-out;
}

.kv__logo.show,
.header.show,
.kv__copy.show,
.kv__scroll.show,
.kv__scroll_text.show{
  opacity: 1;
}


.ecoHead__wrap .arrow {
  position: relative;
  display: inline-block;
  width: 113px;   /* 最終的に100pxまで伸びる */
  height: 59.92px;
  margin-top:38px;
  --line-width: 60px;       /* 初期値 */
  --arrow-opacity: 1;       /* 初期から表示 */
}

/* 横線 */
.ecoHead__wrap .arrow::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: var(--line-width);
  height: 10px;
  background: #00845F;
  transform: translateY(-50%);
}

/* 矢印の先端（→） */
.ecoHead__wrap .arrow::after {
  content: "";
  position: absolute;
  top: 50%;
  /* left: var(--line-width); */
  left: calc(var(--line-width) - 55px); /* ← ここで線と太さ分を調整 */
  width: 59.92px;
  height: 59.92px;
  background-image: url(../img/econowa/arrow_head.svg);
  background-size:100% 100%;
  transform: translateY(-50%) ;
  opacity: var(--arrow-opacity);
}
.ecoHead::before{
  display: none;
}
.ecoHead__wrap{
  display: flex;
  align-items: flex-start;
}
.ecoHead span {
  padding-left: min(11.1111111111vw, 42px);
  line-height: 136px;
}
.ecoHead strong{
  padding-left: min(11.1111111111vw, 42px);
}

.ecoSec04 .ecoHead__wrap .arrow::before {
  background: #fff;
}
.ecoSec04 .ecoHead__wrap .arrow::after{
  width: 59.92px;
  height: 59.92px;
  background-image: url(../img/econowa/arrow_head_w.svg);
  background-size:100% 100%;
}
@media screen and (max-width: 768px) {
  .ecoHead__wrap .arrow {
    position: relative;
    display: inline-block;
    width: 6.827vw;   /* 最終的に100pxまで伸びる */
    height: 6.461vw;
    margin-top:4.107vw;
    --line-width: 6.827vw;       /* 初期値 */
    --arrow-opacity: 1;       /* 初期から表示 */
  }

  /* 横線 */
  .ecoHead__wrap .arrow::before {
    content: "";
    position: absolute;
    top: 50%;
    left: 0;
    width: var(--line-width);
    height: 1.067vw;
    background: #00845F;
    transform: translateY(-50%);
  }

  /* 矢印の先端（→） */
  .ecoHead__wrap .arrow::after {
    content: "";
    position: absolute;
    top: 50%;
    /* left: var(--line-width); */
    left: calc(var(--line-width) - (6.461vw - 6px)); /* ← ここで線と太さ分を調整 */
    width: 6.461vw;
    height: 6.461vw;
    transform: translateY(-50%);
    opacity: var(--arrow-opacity);
  }
  .ecoSec04 .ecoHead__wrap .arrow::after {
    width: 6.461vw;
    height: 6.461vw;
    background-image: url(../img/econowa/arrow_head_w.svg);
    background-size: 100% 100%;
  }
  .ecoHead::before{
    display: none;
  }
  .ecoHead__wrap{
    display: flex;
    align-items: flex-start;
  }
  .ecoHead span {
    padding-left:  8.533vw;
    padding-left:4.533vw;
    line-height: 1.2274;
  }
  .ecoSec05 .ecoHead span {
    line-height: 1.090909;
    margin-top:3px;
  }
  .ecoHead strong{
    padding-left: 8.533vw;
    padding-left:4.533vw;
  }
}

#sec-logo-wh {
  width: min(37.292vw, 716px);
  height: auto;
  position: absolute;
top: 0;
right: 50px;
  z-index: 2; /* 下 */
}
#sec-logo-base path {
  fill:#fff; /* 塗りの色 */
}
#sec-logo-mask path {
  fill:none; /* 塗りの色 */
  stroke:#ffffff; /* 線の色 */
  stroke-width:120px; /* 線幅 */
}
.ecoSec04::before{
  display: none;
}
@media screen and (max-width: 768px) {

  #sec-logo-wh {
  display: none;
  }
}

.kv__scroll_text{
  position: absolute;
  bottom: min(2.5185185185vw, 34px);
  right: min(4.4444444444vw, 60px);
  width: min(10.8888888889vw, 147px);
  height: min(10.8888888889vw, 147px);
  pointer-events: none;
  z-index: 3;
}
@media only screen and (max-width: 768px){
  .kv__scroll_text{
    bottom: 8.8vw;
    right: 8.8vw;
    width: 28.8vw;
    height: 28.8vw;
  }

}
.swiper-set .swiper-button-prev{
  background-image: url(../img/econowa/sec05_prev_g.svg);
  background-color: #fff;
}
.swiper-set .swiper-button-next{
  background-image: url(../img/econowa/sec05_next_g.svg);
  background-color: #fff;
}
.swiper-set .swiper-button-prev:hover{
  background-image: url(../img/econowa/sec05_prev_w.svg);
  background-color: #00845f;
}
.swiper-set .swiper-button-next:hover{
  background-image: url(../img/econowa/sec05_next_w.svg);
  background-color: #00845f;
}
.ecoSec08 .ecoSec08__data a{
  background-color:unset;
  border:solid 1.5px #00845F;
  color:#00845F;
}
.ecoSec08 .ecoSec08__data a:hover{
  background-color:#00845F;
  color:#fff;
  opacity: 1;
}

.kv .kv__copy{
  position:fixed;
}

@media only screen and (min-width: 1000px){

  .ecoSec06 .ecoSec06__slider{
    width: 100%;
    margin-left: 0;
    padding-left: min(3.7037037037vw, 50px);
    padding-right: min(3.7037037037vw, 50px);
  }
  .ecoSec06 .swiper-set{
    right:0;
  }
  .ecoSec06 .swiper-slide{
    width:409px;
  }
}
@media only screen and (min-width: 1340px){
  .ecoSec06 .ecoSec06__slider{
    width: calc(100vw - (100vw - 1240px)/2);
    margin-left: calc((100vw - 1240px)/2);
    padding-left: 0;
    padding-right: 0;
  }
  .ecoSec06 .swiper-slide{
    width:409px;
  }
  .ecoSec06 .swiper-set{
    right:calc((100vw - 1240px)/2);
  }
}
@media only screen and (max-width: 768px) {
  .gloNav {
    transition: all .3s ease-in-out;
  }
}
.ecoSec04 .ecoSec04__main .ecoSec04__mainItem p,
.ecoSec08 .ecoSec08__data p{
  font-weight:500;
}
