@charset "utf-8";
body{
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
  color: #000;
}

a:hover{
  opacity: 0.7;
}

/* PCのみ表示する要素を表示 */
.pc_block {display: block;}
.sp_block {display: none;}

/* インデント */
.indent{
  text-indent: -1em;
  padding-left: 1em;
}

/* アニメーション */
.fade{
  opacity: 0;
  transition: .5s ease-in-out;
}
.fade.fade--bot{
  transform: translate(0,100px);
}
.fade.fade--top{
  transform: translate(0,-100px);
}
.fade.fade--left{
  transform: translate(-100px,0);
}
.fade.fade--right{
  transform: translate(100px,0);
}
.fade.fadein{
  transform: translate(0,0);
  opacity: 1;
}
/* 子要素を順番にフェードイン */
.fade.fade--list{
  opacity: 1;
}
.fade_child{
  opacity: 0;
  transform: translate(0,100px);
  transition: .5s ease-in-out;
}
.fadein .fade_child{
  transform: translate(0,0);
  opacity: 1;
}
.fade_child:nth-child(1){
  transition-delay: 0.15s;
}
.fade_child:nth-child(2){
  transition-delay: 0.3s;
}
.fade_child:nth-child(3){
  transition-delay: 0.45s;
}
.fade_child:nth-child(4){
  transition-delay: 0.6s;
}
.fade_child:nth-child(5){
  transition-delay: 0.75s;
}
.fade_child:nth-child(6){
  transition-delay: 0.9s;
}
.fade_child:nth-child(7){
  transition-delay: 1.05s;
}
.fade_child:nth-child(8){
  transition-delay: 1.2s;
}
.fade_child:nth-child(9){
  transition-delay: 1.35s;
}
.fade.roll-in {
opacity: 0;
}
.fade.roll-in.roll-in.fadein {
animation: rollFadeIn 1s ease-in-out;
opacity: 1;
}
@keyframes rollFadeIn {
from {
  opacity: 0;
  transform: rotate(-180deg) translate(0);
}
to {
  opacity: 1;
  transform: rotate(0deg) translate(0);
}
}

/*コンポーネント*/
.mt_0{margin-top: 0px;}
.mt_10{margin-top: 10px;}
.mt_20{margin-top: 20px;}
.mt_30{margin-top: 30px;}
.mt_40{margin-top: 40px;}
.mt_50{margin-top: 50px;}
.mt_60{margin-top: 60px;}
.mt_70{margin-top: 70px;}
.mt_80{margin-top: 80px;}
.mt_90{margin-top: 90px;}
.mt_100{margin-top: 100px;}
.mt_110{margin-top: 110px;}

.mb_0{margin-bottom: 0px;}
.mb_10{margin-bottom: 10px;}
.mb_20{margin-bottom: 20px;}
.mb_30{margin-bottom: 30px;}
.mb_40{margin-bottom: 40px;}
.mb_50{margin-bottom: 50px;}
.mb_60{margin-bottom: 60px;}
.mb_70{margin-bottom: 70px;}
.mb_80{margin-bottom: 80px;}
.mb_90{margin-bottom: 90px;}
.mb_100{margin-bottom: 100px;}
.mb_110{margin-bottom: 110px;}

.mv{
  background: #EDF7FE;
  position: relative;
  z-index: 1;
}
.mv_inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 15px solid #EEEE6D;
  border-bottom: 15px solid #EEEE6D;
}
.mv_catch{
  position: relative;
  &::before{
    content: "";
    background: url(../img/cl01.png)no-repeat center/cover;
    width: 170px;
    height: 49px;
    position: absolute;
    top: -30px;
    left: -55px;
    animation: mv_cloud01 3s infinite;
  }
  &::after{
    content: "";
    background: url(../img/cl02.png)no-repeat center/cover;
    width: 196px;
    height: 80px;
    position: absolute;
    bottom: 0;
    right: -90px;
    animation: mv_cloud02 3s infinite;
    z-index: 1;
  }
}
@keyframes mv_cloud01 {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
}
@keyframes mv_cloud02 {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(20px);
  }
}

.mi--01{
  position: relative;
  &::before{
    content: "";
    background: url(../img/bg01.png) no-repeat center/cover;
    width: 273px;
    height: 224px;
    position: absolute;
    top: 0;
    right: -273px;
  }
}
.mi--02{
  position: relative;
  &::before{
    content: "";
    background: url(../img/bg02.png) no-repeat center/cover;
    width: 273px;
    height: 224px;
    position: absolute;
    left: -273px;
    bottom: 0;
  }
}

/* intro */
.intro{
  position: relative;
  &::before{
    content: "";
    background: url(../img/bg04.png) no-repeat center/cover;
    width: 100%;
    height: 292px;
    position: absolute;
    top: 100px;
    left: 0;
  }
}
.intro_box{
  position: relative;
  z-index: 2;
  margin-top: -100px;
  &::before{
    content: "";
    background: #FFF;
    width: 872px;
    height: 436px;  
    border-radius: 436px 436px 0 0;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
  }
}
.ib_inner{
  max-width: 850px;
  width: 100%;
  margin: auto;
  position: relative;
  padding-top: 100px;
  display: flex;
  flex-direction: column;
  align-items: center;
  &::before{
    content: "";
    background: url(../img/cl03.png) no-repeat center/cover;
    width: 209px;
    height: 69px;
    position: absolute;
    bottom: 200px;
    left: -180px;
    animation: ib_cloud01 3s infinite;
  }
  &::after{
    content: "";
    background: url(../img/cl04.png) no-repeat center/cover;
    width: 210px;
    height: 68px;
    position: absolute;
    bottom: 120px;
    right: -180px;
    animation: ib_cloud02 3s infinite;
  }
}
@keyframes ib_cloud01 {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(-20px);
  }
}
@keyframes ib_cloud02 {
  0%, 100% {
    transform: translateY(0);
  }
  50% {
    transform: translateY(20px);
  }
}
.intro_para{
  text-align: center;
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.9px;
  font-size: 1.8rem;
  margin-top: 40px;
}
.intro_video{
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 40px;
}
.iv_txt{
  font-weight: 700;
  line-height: 200%;
  font-size: 2rem;
  letter-spacing: 1px;
  color: #E50000;
  text-align: center;
}
.intro_video iframe{
  border: 2px solid #E50000;
  padding: 2px;
  margin-top: 10px;
}

/* mido */
.mido{
  background: linear-gradient(180deg, #A2CDE7 0%, #C3E8FF 100%);
  position: relative;
  &::after{
    content: "";
    background: url(../img/bg04.png)no-repeat center/cover;
    width: 100%;
    height: 292px;
    position: absolute;
    bottom: 0;
    left: 0;
  }
}
.mido_list{
  max-width: 1024px;
  width: 100%;
  margin: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 95px;
  position: relative;
  z-index: 2;
}
.mido_list--box{
  max-width: 1024px;
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 16px;
  border: 4px solid #2BAC66;
  background: #FFF;
  padding: 40px 30px 40px 70px;
  position: relative;
}
.mlb--left{
  max-width: 470px;
  width: 100%;
}
.mlb_title{
  font-weight: 900;
  line-height: 175%;
  letter-spacing: 1.6px;
  font-size: 3.2rem;
  color: #2BAC66;
  span{
    background: linear-gradient(transparent 0%, transparent 50%, #EEEE6D 50%, #EEEE6D 100%);
  }
}
.mlb_para{
  max-width: 421px;
  width: 100%;
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.8px;
  margin-top: 30px;
}
.more_btn{
  max-width: 342px;
  width: 100%;
  min-height: 59px;
  display: flex;
  align-items: center;
  gap: 30px;
  border-radius: 81px;
  background: #2BAC66;
  color: #fff;
  font-weight: 700;
  margin-top: 30px;
  padding-left: 40px;
  position: relative;
  &::after{
    content: "";
    background: url(../img/arrow_02.svg) no-repeat center/cover;
    width: 11px;
    height: 15px;
    position: absolute;
    right: 25px;
    top: 50%;
    transform: translateY(-50%);
  }
}
.img_box{
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
}
.mido_img{
  position: absolute;
  top: -65px;
  left: 50px;
}
.mido_list--box:nth-child(2){
  border: 4px solid #188CB5;
  .mlb_title{
    color: #188CB5;
  }
  .more_btn{
    background: #188CB5;
  }
}
.mido_list--box:nth-child(3){
  border: 4px solid #CA7D39;
  .mlb_title{
    color: #CA7D39;
  }
  .more_btn{
    background: #CA7D39;
  }
}
.mido_list--box:nth-child(4){
  border: 4px solid #706BB2;
  .mlb_title{
    color: #706BB2;
  }
  .more_btn{
    background: #706BB2;
  }
}

/* art */
.art{
  margin-top: -20px;
}
.mou_block{
  display: flex;
  justify-content: center;
  position: relative;
  z-index: 1;
}
.damu_block{
  display: flex;
  justify-content: center;
  background: #DBF1D1;
}
.river_block{
  display: flex;
  justify-content: center;
  background: #DBF1D1;
  figure{
    max-width: 412px;
    width: 100%;
  }
  &::before{
    content: "";
    width: 100%;
    height: 100px;
    background-color: #A2CDE7;
    clip-path: polygon(100% 100%, 100% 0, 0 100%);
    position: relative;
    right: -1px;
  }
  &::after{
    content: "";
    width: 100%;
    height: 100px;
    background-color: #A2CDE7;
    clip-path: polygon(0 0, 100% 100%, 0 100%);
  }
}

/* footer */
.ft_c{
  font-weight: 900;
  line-height: 200%;
  letter-spacing: 1.6px;
  color: #2BAC66;
  text-align: center;
  font-size: 3.2rem;
  margin-top: 40px;
}
.btn_box{
  max-width: 1280px;
  width: 100%;
  margin: auto;
  display: flex;
  justify-content: center;
  position: relative;
  padding-bottom: 85px;
}
.btn_a{
  border-radius: 16px;
  font-weight: 900;
  background: #D41D1D;
  box-shadow: 4px 4px 4px 0 rgba(0, 0, 0, 0.25);
  color: #fff;
  position: relative;
  max-width: 310px;
  width: 100%;
  min-height: 72px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  &::after{
    content: "";
    background: url(../img/arrow.svg) no-repeat center/cover;
    width: 23px;
    height: 24px;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 30px;
  }
}
.btn_box--list{
  max-width: 656px;
  width: 100%;
  display: flex;
  gap: 54px;
  margin-top: 40px;
}
.btn_link--txt{
  font-weight: 700;
  line-height: 200%;
  letter-spacing: 0.9px;
  font-size: 1.8rem;
}
.btn_link{
  max-width: 301px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
.tree01{
  position: absolute;
  left: 0;
  bottom: 0;
}
.tree02{
  position: absolute;
  right: 0;
  bottom: 0;
}
.cp{
  background: #EEEE6D;
  padding: 10px 0;
  display: flex;
  justify-content: center;
  small{
    color: #000;
  }
}


/* ------------------
Backtop
------------------ */
#backtop {
  position: fixed;
  display: block;
  width: 50px;
  height: 50px;
  right: 3%;
  bottom: 50px;
  border-radius: 50%;
  background: rgba(50,50,50,0.9);
  opacity: 0;
  visibility: hidden;
  transition: 0.5s;
  z-index: -10;
}
#backtop::after {
  content: "";
  position: absolute;
  width: 12px;
  height: 12px;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateY(-25%) rotate(-45deg);
  top: 50%;
  left: 0;
  right: 0;
  margin: auto;
}
#backtop.active {
  opacity: 0.6;
  visibility: visible;
  z-index: 50;
}

@media screen and (max-width: 1279px) {
/* 推奨動作環境1280pxに固定 */
  body {
    width: 1280px;
  }
}

@media screen and (min-width: 768px) {
/* PCの場合はtelリンクを無効 */
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
  }
}

/* iPad調整用 */
@media screen and (orientation: portrait) and (min-width: 768px){}

@media screen and (max-width: 767px){
  body {
    width: 100%;
  }

  /* スマホのみ表示する要素を表示 */
	.sp_block {display: block;}
	.pc_block {display: none;}
	
  /* mv */
  .mv_inner{
    flex-direction: column;
  }
  .mi--01 {
    width: 100%;
    &::before {
      background: url(../img/bg01_sp.png) no-repeat center/cover;
      width: 80px;
      height: 66px;
      right: auto;
      left: 0;
      top: auto;
      bottom: -66px;
    }
    img{
      width: 100%;
    }
  }
  .mi--02 {
    width: 100%;
    &::before {
      background: url(../img/bg02_sp.png) no-repeat center / cover;
      width: 80px;
      height: 66px;
      left: auto;
      bottom: auto;
      right: 0;
      top: -66px;
    }
    img{
      width: 100%;
    }
  }
  .mv_catch{
    padding: 15px 5%;
    &::before{
      width: 87px;
      height: 25px;
      top: -15px;
      left: 5%;
    }
    &::after{
      width: 106px;
      height: 44px;
      right: 5%;
      bottom: -10px;
      z-index: 1;
    }
  }

  /* intro */
  .intro{
    &::before{
      top: 0;
    }
  }
  .intro_box{
    margin-top: -50px;
    &::before{
      width: 100%;
      height: 100%;
    }
  }
  .ib_inner{
    padding: 50px 5% 0;
    &::before{
      display: none;
    }
    &::after{
      display: none;
    }
  }
  .intro_video{
    iframe{
      width: 100%;
      height: 195px;
    }
  }
  .comp_logo{
    max-width: 200px;
    margin-top: 20px;
  }

  /* art */
  .art {
    margin-top: 20px;
  }
  .river_block{
    display: none;
  }

  /* mido */
  .mido_list{
    padding: 60px 5% 40px;
    gap: 70px;
  }
  .mido_list--box{
    padding: 40px 5%;
    flex-direction: column-reverse;
    gap: 15px;
  }
  .mido_img{
    left: 5px;
    top: -50px;
  }
  .more_btn{
    padding-left: 15px;
    &::after{
      right: 10px;
    }
  }
  .mlb_title{
    font-size: 2.4rem;
  }
  .mlb_para{
    margin-top: 15px;
  }
  .mido_img{
    max-width: 102px;
  }

  /* footer */
  .ft_c{
    font-size: 2.4rem;
    padding:  0 5%;
    margin-top: 0;
  }
  .btn_box{
    padding: 0 5% 165px;
  }
  .btn_box--list{
    flex-direction: column;
    align-items: center;
    gap: 20px;
  }
  .tree01,.tree02{
    max-width: 120px;
  }
}

/* 印刷用設定 */
@media print {
  body {
    width:1280px!important;
    zoom: 0.68;
    -webkit-print-color-adjust: exact;
  }

  #backtop{
    display: none;
  }

  .mv_inner {
    min-height: 640px;
    height: 640px;
  }
  .mi--01, .mi--02 {
    height: 100%;
    img {
      height: 100%;
      object-fit: cover;
    }
  }
}
@page {
  size: A4;margin: 5px;
}