/*--------------
common
--------------*/
html {
  font-size:0.624vw;
}

@media print,screen and (max-width:1024px) {
  html {
    font-size:1.02vw;
  }
}

@media print,screen and (max-width: 768px) {
  html {
    font-size:1.44444vw;
  }
}

@media print,screen and (max-width: 521px) {
  html {
    font-size:2.666vw;
  }
}


*,
*::before,
*::after{
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

:root{
  --c-black:#000000;
  --c-white:#fefefe;
  --c-blue:#2e3192;
  --c-orange:#ffa324;
  --c-green:#4d9c44;
  --c-gray:#dddddd;
  --gradation:linear-gradient(0deg,rgba(255, 148, 70, 1) 0%, rgba(255, 211, 156, 1) 36%, rgba(255, 255, 255, 1) 83%);
  --gradation-rgb:rgb(255,251,224);
  --bg:#f0f9f6;
  --font-20:2rem;
  --font-exTxt:min(1.83rem,4vw);
  --title214:min(2.14rem,4.6vw);
  --translate:translate(0, -6px);
  --transition:all .5s cubic-bezier(0.43, 0.05, 0.17, 1);
  --opacity:.6;
  --section-margin:13rem;
  --border-radius:min(2rem,4vw);
  --bg-padding:min(6rem,5vw);
  --font-jp:"Libertinus Serif","Noto Serif JP","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
}

body {
  font-size: 1.24rem;
  font-family: "Libertinus Serif","Noto Serif JP","YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  line-height: 1.75;
  letter-spacing: .14em;
  font-feature-settings:"palt";
  font-weight: 400;
  color: var(--color-black);
  position: relative;
  /**/
}

@keyframes opacityAnimation {
  0% {
    opacity: 0;
    filter: blur(2rem);
  }
  100% {
    opacity: 1;
    filter: blur(0rem);
  }
}

body.page-id-18{
  animation: none;
  opacity: 1;
  filter: blur(0);
}

a {
  text-decoration: none;
  color: var(--color-black);
  transition: var(--transition);
  font-weight: 500;
}

li{
  list-style: none;
}

img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

table {
  clear: both;
  border-collapse: collapse;
  width: 100%;
  text-align: center;
}

td,th{
  padding: min(1rem, 1.6vw);
  border: solid 1px var(--color-gray);
  line-height: 1.75;
}

.title-svg{
  fill: var(--c-blue);
}

.contents{
  margin: auto;
  width: min(88rem,86%);
}

.contents-title{
  position: relative;
  margin-bottom: min(6rem, 6vw);
  text-align: center;
}

.contents-title_inner{
  position: relative;
}
.contents-title_inner::before{
  content: "";
  position: absolute;
  background: #c8c8c8;
  width: 100%;
  height: min(6px, .8vw);
  left: 0;
  bottom: -2vw;
}

.contents-title_inner svg,.contents-title_inner img{
  height: min(6rem, 9vw);
  overflow: visible;
}

.deco-item{
  position: absolute;
}

/*---link---*/
.linkBox {
  display: flex;
  align-items: center;
  justify-content: center;
  height: min(8rem, 16vw);
  width: min(27rem, 52vw);
  border-radius: 50%;
  font-size: var(--font-exTxt);
  font-weight: 700;
  border: 2px solid currentColor;
  color: var(--c-blue);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  letter-spacing: .02em;
  -webkit-font-smoothing: antialiased;
  transition: var(--transition);
  gap: min(.83rem,2vw);
}

.linkBox-arrow{
  width: min(2rem,3.24vw);
  transition: var(--c-blue);
  transition: var(--transition);
}
.linkBox-arrow svg{
  fill: var(--c-blue);
}

/*---arrow---*/
.arrow{
  vertical-align: middle;
  color: var(--color-white);
  line-height: 1;
  width: .6rem;
  height: .6rem;
  border: 0.1em solid currentColor;
  border-left: 0;
  border-bottom: 0;
  box-sizing: border-box;
}

.arrow-icon{
  background: var(--c-blue);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: min(3rem, 6vw);
  height: min(3rem, 6vw);
  transition: var(--transition);
}

.important-text{
  color: #ea0000;
  font-weight: 500;
}


/*----- not found -----*/
.notFound{
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: min(20vh, 38vw) 0 min(12rem, 14vw);
  position: relative;
  z-index: 1;
}

.notFound>.deco-item.-item-cloud1{
  width: min(32rem, 36vw);
  top: min(16rem, 22vw);
  left: min(19rem, 4vw);
  z-index: -1;
}
.notFound>.deco-item.-item-cloud2{
  width: min(23rem, 29vw);
  right: min(24rem, 3vw);
  top: min(17rem, 25vw);
  z-index: -1;
}

.notFont-wrapper{
  padding: 0 10vw 0;
}

.notFont-wrapper h2{
  font-size: min(6.24rem, 10vw);
  font-weight: 600;
  line-height: 1.2;
  letter-spacing: .02em;
  padding-bottom: 16px;
  text-transform: uppercase;
}

.notFont-wrapper p{
  font-size: min(1.6rem, 3.24vw);
  padding-bottom: 40px;
}

.notFont-wrapper .linkBox{
  width: min(23rem, 54vw);
  margin: 0 auto;
}

.notFont-wrapper .linkBox p{
  padding-bottom: 0;
}

.notFont-wrapper .notFound-image{
  width: min(22rem, 32vw);
  display: block;
  margin: 0 auto min(3rem, 6vw);
}


@media print, screen and (min-width: 769px) {
  body {
    font-size: 1.4rem;
  }

  .contents{
    width: 88rem;
  }

  .contents-title_inner::before{
    bottom: -2rem;
  }

  /*---link---*/
  .linkBox:hover{
    color: var(--c-white);
    background: var(--c-blue);
  }

  .linkBox:hover .linkBox-arrow{
    transform:translateX(.5rem);
  }
  .linkBox:hover .linkBox-arrow svg{
    fill: var(--c-white);
  }
}

@media print, screen and (min-width: 1025px){
  .contents {
    width: 120rem;
  }
}


/*-- scroll animation --*/
.scroll-fadeIn {
  opacity: 0;
}
.scroll-fadeIn.is-active{
  animation: scroll-fadeIn .75s ease .6s normal forwards;
}
@keyframes scroll-fadeIn {
  0%{
    opacity: 0;
    transform: translateY(6%);
  }
  100%{
    opacity: 1;
    transform: translateY(0);
  }
}

.scroll-title{
  translate: 0% 0%;
  opacity: 0;
}

.scroll-title.is-active{
  display: block;
  animation: titleEffectAnimation .75s cubic-bezier(.55,.05,.22,.99) .2s normal forwards;
  opacity: 0;
  translate: 0% 140%;
}

.a-pop{
  animation: scroll-blur 1.5s ease 0s normal forwards;
  opacity: 0;
  filter: blur(.6rem);
}
@keyframes scroll-blur {
  0%{
    opacity: 0;
    filter: blur(.6rem);
  }
  100%{
    opacity: 1;
    filter: blur(0);
  }
}



/*-- animation --*/
.a-cloud{
  animation: cloud 14s ease-in-out infinite alternate;
}
.a-cloud2{
  animation: cloud 12s ease-in-out infinite alternate;
}

@keyframes cloud {
  0% {
    transform: translate(0, 0);
  }
  50% {
    transform: translate(-10%, 0);
  }
  100% {
    transform: translate(0, 0);
  }
}

.parallax-element{
  transform: translateY(0);
  transition: transform .8s ease-out;
}

@keyframes blur {
  0% {
    opacity: 0;
    filter: blur(2rem);
  }
  100% {
    opacity: 1;
    filter: blur(0px);
  }
}



/*----- breadcrumbs/pageTop -----*/
.breadcrumbs {
  text-align: center;
  font-size: min(1.24rem, 2.4vw);
  margin: auto;
  padding: min(1.4rem) min(10rem, 5vw);
  color: var(--c-blue);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.breadcrumbs span {
  padding: 0;
  letter-spacing: .04em;
}

.breadcrumbs a {
  color: var(--c-blue);
  text-decoration: underline;
}

#page-top a{
	display: flex;
	justify-content:center;
	align-items:center;
	width: 50px;
	height: 50px;
	text-align: center;
	text-transform: uppercase;
	text-decoration: none;
	font-size:0.6rem;
}

/*---- page top -----*/
.page-top{
  right: min(12px, 2vw);
  bottom: min(12px, 1vw);
  position: fixed;
  z-index: 4;
  opacity: 0;
  visibility: hidden;
  transition: var(--transition);
}

.page-top.is-show {
  visibility: inherit;
  opacity: 1;
}

.page-top a{
  background: var(--c-blue);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  height: min(7rem, 16vw);
  width: min(7rem, 16vw);
  text-align: center;
  color: var(--color-white);
  line-height: 1.4;
  box-shadow: var(--bs-black);
  letter-spacing: .08em;
  font-size: min(1.2rem, 3vw);
  text-transform: uppercase;
}


/*----- googleMap/youtube -----*/
.youtube{
  position:relative;
  width:100%;
  padding-top:62.25%;
}

.youtube iframe{
  position:absolute;
  top:0;
  right:0;
  width:100%;
  height:100%;
}

/*----- thumbnail -----*/
.thumbnail {
  position: relative;
  display: block;
  overflow: hidden;
  padding-top: 72.25%;
  background: var(--color-white);
}

.thumbnail img {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  width:100%;
  height: 100%;
  object-fit: cover;
  transition: all 0.2s ease;
}

/*--------------
  loading
--------------*/
.c-loader-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background:var(--c-white);
  z-index: 200;
  display: grid;
  place-items: center;
  pointer-events: none;
}

.c-loader-text {
  display: inline-flex;
  align-items: center;
  justify-content: start;
  pointer-events: none;
  flex-direction: column;
  gap: min(4rem,8vw);
}

.c-loader-text>span {
  display: block;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background-color: #fff;
}

.c-loader-text>span+span {
  margin-left: 3rem;
}

.c-loader-textLogo{
  width: min(21rem,44vw);
}
.c-loader-textWrap{
  width: min(40rem, 80vw);
}



/*--------------
  header
--------------*/
header{
  position: fixed;
  z-index: 100;
  top: min(2rem, 3vw);
  left: min(6rem, 3vw);
}
header h1{
  width: min(23rem, 33vw);
  z-index: 1;
  position: relative;
}

header h1 img{
  display: block;
  transition: var(--transition);
}

@media screen and (min-width:769px) {
  header h1 a:hover img{
    transform: scale(1.05);
  }

  a:hover .thumbnail img{
    transform: translate(-50%,-50%) scale(1.05);
  }

  .breadcrumbs a:hover{
    opacity: .6;
  }
}

/*----- hamburger -----*/
.fixedBtn{
  cursor: pointer;
  position: fixed;
  top: min(3rem, 3vw);
  right: min(4rem, 3vw);
  z-index: 200;
  transition: ease .5s;
  display: flex;
  align-items: center;
  flex-direction: row-reverse;
  gap: 1rem;
  opacity: 0;
  animation: fallInAnimation2 .85s cubic-bezier(.04,.435,.315,.9) .6s normal forwards;
}

.openBtn{
  width: min(72px, 15vw);
  height: min(72px, 15vw);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: transform .5s cubic-bezier(.215,.61,.355,1);
  gap: min(5.4px, 1.4vw);
  background: var(--opacity-white);
  border-radius: 50%;
  box-shadow: var(--bs-black);
}

.openBtn span{
  background-color: var(--c-blue);
  border-radius: 50%;
  height: min(6px, 1.4vw);
  width: min(6px, 1.4vw);
  transition: transform .3s cubic-bezier(.215,.61,.355,1);
  position: relative;
}

.openBtn.active span:nth-of-type(1){
  transform: translateX(200%);
}
.openBtn.active span:nth-of-type(3){
  transform: translateX(-200%);
}

.openBtn::before{
  position: absolute;
  content: "menu";
  bottom: 12%;
  left: 50%;
  transform: translateX(-50%);
  font-size: min(12px, 2.6vw);
  letter-spacing: 0;
  text-transform: uppercase;
  font-weight: 700;
  color: var(--c-blue);
  transition: transform .5s cubic-bezier(.215,.61,.355,1);
}
.openBtn.active::before{
  content: "close";
}

#js-g-nav{
  transition: all .5s cubic-bezier(0.43, 0.05, 0.17, 1);
  -webkit-transition: all .5s cubic-bezier(0.43, 0.05, 0.17, 1);
  opacity: 0;
  visibility: hidden;
}

#js-g-nav.panelactive{
  opacity: 1;
  visibility: inherit;
}

.g-nav{
  position: fixed;
  z-index: 100;
  top: 0;
  right: 0;
  width: 100%;
  height: 100svh;
  color: var(--color-black);
  background: rgba(0, 149, 110, .9);
  background-size: cover;
  backdrop-filter: blur(3px);
  visibility: hidden;
}

.g-nav a{
  color: var(--color-white);
}

.g-nav_container{
  display: flex;
  flex-direction: row-reverse;
  height: 100svh;
}

.g-nav_images{
  overflow: hidden;
}

picture._images__image{
  display: block;
  height: 100%;
}

._images__image img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

a.g-nav_logo{
  display: block;
  width: min(36rem, 62vw);
  margin: min(3rem, 5vw);
}

.g-nav_mainMenu_acc,.g-nav_mainMenu_list{
  width: calc(100% / 2);
}

.g-nav_menu{
  padding: 10rem;
  overflow-y: auto;
}

.g-nav_mainMenu{
  display: flex;
  justify-content: space-between;
  gap: 8rem;
}

.g-nav_mainMenu li._mainMenu-item{
  border-bottom: solid 1px var(--color-white);
  padding: min(2rem,4vw) 0;
  cursor: pointer;
}

@media screen and (min-width:769px) {
  a.g-nav_cardLink:hover .cardLink-title::before{
    transform: scale(1.1);
  }

  .g-nav_mainMenu_acc .title:hover .hoverRoll-item1{
    animation: hover-text-out 1s cubic-bezier(0.23, 1, 0.32, 1) forwards;
  }
  .g-nav_mainMenu_acc .title:hover .hoverRoll-item2{
    animation: hover-text-in 1s cubic-bezier(0.23, 1, 0.32, 1) forwards;
  }

  a.g-nav_logo:hover,
  ._mainMenu_menuList li a:hover,
  .g-nav_subMenu>.-nav_sns li a:hover{
    opacity: var(--opacity);
  }

  .-nav_sns li a:hover img{
    transform: scale(1.05);
  }
}

/*--------------
  contact
--------------*/
.footer-contact{
  background: linear-gradient(0deg,rgba(255, 211, 156, 1) 0%, rgba(254, 254, 254, 1) 50%);
  position: relative;
  overflow: hidden;
  padding: 12vw 0 18vw;
  z-index: 1;
}

.footer-logo{
  width: min(36rem, 48vw);
  margin: 0 auto min(4vw, 4rem);
}
.footer-logo img{
  transition: var(--transition);
}

.footer-information{
  width: 86%;
  margin: 0 auto;
  text-align: center;
}

.footer-information_address{
  font-size: min(2.4rem, 3.6vw);
  letter-spacing: .06em;
}
.footer-information_address a{
  text-decoration: underline;
  font-weight: 600;
  font-size: min(90%);
}

.contact-link{
  position: relative;
  display: block;
  z-index: 1;
  width: min(40rem, 56vw);
  margin: min(4vw, 4rem) auto 0;
  padding: 10.4vw 11vw;
}
.contact-link::before{
  position: absolute;
  content: "";
  background: url(img/btnBg-contact.svg) no-repeat center;
  background-size: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%,-50%);
  width: 100%;
  height: 100%;
  z-index: -1;
}

.footer-contact .deco-item.-item-cloud1{
  top: 11vw;
  right: min(24rem, 4vw);
  width: 19vw;
}
.footer-contact .deco-item.-item-cloud2{
  width: 74vw;
  top: 3vw;
  left: -35vw;
  z-index: -1;
}
.footer-contact .deco-item.-item-cloud3{
  width: 39vw;
  top: 50vw;
  right: -17vw;
}

/*--------------
  footer
--------------*/
.footer{
  color: var(--c-white);
  background: var(--c-blue);
  position: relative;
  z-index: 1;
  padding: min(2rem, 13vw) 0px min(3rem, 4vw);
}
.footer::before{
  position: absolute;
  content: "";
  background: url(img/footer-bg.webp) no-repeat center;
  background-size: 100%;
  top: -12vw;
  left: 0;
  width: 100%;
  height: 16vw;
}

.footer>.contents{
  text-align: center;
}

.footer>.contents small{
  letter-spacing: .1em;
  padding-top: min(2vw, 6rem);
  display: block;
}

@media screen and (min-width:769px) {
  /*--------------
    contact
  --------------*/
  .footer-contact{
    padding: 8vw 0 15vw;
  }

  .footer-contact .deco-item.-item-cloud1{
    top: 8vw;
    right: min(24rem, 9vw);
    width: 19vw;
  }
  .footer-contact .deco-item.-item-cloud2{
    width: 62vw;
    left: -32vw;
  }
  .footer-contact .deco-item.-item-cloud3{
    width: 34vw;
    top: 36vw;
    right: -12vw;
  }

  .contact-link{
    width: min(40rem, 36vw);
    padding: min(6.4vw, 7rem) min(8vw, 7rem);
  }

  .footer-logo a:hover img,
  .contact-link:hover{
    transform: scale(1.05);
  }

  /*--------------
    footer
  --------------*/
  .footer::before{
    width: 100%;
    height: 14vw;
    top: -11vw;
  }

  .footer-information_address a:hover{
    opacity: .6;
  }
}

@media screen and (min-width:1025px) {
  .footer-contact .deco-item.-item-cloud1{
    top: 11vw;
    right: min(26rem, 15vw);
    width: 17vw;
  }
  .footer-contact .deco-item.-item-cloud2{
    width: 62vw;
    top: 5vw;
    left: -32vw;
  }
  .footer-contact .deco-item.-item-cloud3 {
    width: 34vw;
    top: 28vw;
  }
}

