﻿@import url('https://fonts.googleapis.com/css2?family=Kosugi+Maru&family=Otomanopee+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Mochiy+Pop+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Kosugi&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Fuzzy+Bubbles:wght@400;700&display=swap');
#info_contact .con_box:before {
    content: "";
    display: block;
    background: url(Dup/img/clover3.png) no-repeat 50% 0;
    width: 100px;
    height: 100px;
    top: -25px;
    left: 0;
    right: 0;
    margin: auto;
    position: absolute;
    background-size: contain;
    z-index: 2;
}




#intro_wrap, #contents3 .con_box, #info_contact .con_img {
    border-radius: 30px;
}
.clover-r {
    width: 140px;
    right: -9px;
    top: -10px;
}
.clover-l {
    left: -16px;
    bottom: -6px;
    width: 171px;
}
#contents1 .con_box:before {
    content: "";
    display: block;
    width: 100px;
    height: 100px;
    position: absolute;
    background: url(Dup/img/clover1.png) no-repeat 0 0;
    top: -100px;
    right: 0;
    background-size: contain;
}
body {
 font-family: 'Kosugi', sans-serif;   
background-image: url("https://www.transparenttextures.com/patterns/rice-paper-2.png");
background-color: #ffffff;
background-image: url("https://www.transparenttextures.com/patterns/lined-paper-2.png");
}
#intro .num, #contents1 .num, #contents2 .num {
    font-family: 'Fuzzy Bubbles', cursive;
    font-size: 28px;
}
#contents1 .con_img, #contents2 .con_img {
    border: 6px solid #fff;border-radius: 34px;
}
#contents1 .num {
    left: 66px;
    top: -58px;
    transform: none;

}
#contents2 .num {
    transform: inherit;
    top: -54px;
    left: 0;
}

.cms_title p {
    font-family: 'Fuzzy Bubbles', cursive;
}
.hannari {
    font-family: 'Kosugi Maru', sans-serif;
}
.cms_title  {
    position: relative;
}



/*--------hati---------*/
.hatiAnim {
    width: 140px;
    bottom: -27px;
    right: 4%;
}
.hatiAnim .muki {
animation: muki 60s infinite;
}
.hatiAnim img {
    animation-name: hurueru;
    animation-duration: 7s;
    animation-fill-mode: forwards;
    transition-timing-function: ease-in-out;
    -webkit-animation: hurueru 7s ease-in-out infinite alternate;
    animation: hurueru 7s ease-in-out infinite alternate;
}
.hatiAnim.trans {
    animation-name: hatiAnim;
    animation-duration: 50s;
    animation-timing-function: ease-in;
    animation-fill-mode: forwards;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    animation-delay: 0s;
    z-index: 1;
    animation: hatiAnim 60s infinite;
}
@keyframes muki {
  0% {
  transform: scaleX(1);
  } 
  49% {
  transform: scaleX(1);
  } 
   50% {
  transform: scaleX(-1);
  } 
   99% {
  transform: scaleX(-1);
  } 
   100% {
  transform: scaleX(1);
  } 
}
@keyframes hatiAnim {
	/*0% {right: 4%;transform: translate(-0%,-0%);}*/
	/*100% {right: 87%;transform: translate(0,-0%);}*/
	
	0% {
	 right: 4%;
	}
		50% {
	 right: 87%;
	}
		0% {
	 right: 4%;
	}
}

.hati2 {
    right: 7%;
    bottom: 4%;
    width: 141px;
}
.hati2 {
	-webkit-animation-name: sample1;
	animation-name: sample1;
	-webkit-transform-origin: center center;
	transform-origin: center center;
}
.hati2 {
	-webkit-animation-duration: 5s;
	animation-duration: 5s;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
	-webkit-animation-iteration-count: infinite;
	animation-iteration-count: infinite;
}
@-webkit-keyframes sample1 {
	from {
		-webkit-animation-timing-function: linear;
		-webkit-transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1;
	} to {
		-webkit-animation-timing-function: linear;
		-webkit-transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1.0;
	} 3% {
		-webkit-animation-timing-function: linear;
		-webkit-transform: translate(0px,0px) scale(1,1) rotate(-5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 6% {
		-webkit-animation-timing-function: linear;
		-webkit-transform: translate(0px,0px) scale(1,1) rotate(5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 9% {
		-webkit-animation-timing-function: linear;
		-webkit-transform: translate(0px,0px) scale(1,1) rotate(-5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 12% {
		-webkit-animation-timing-function: linear;
		-webkit-transform: translate(0px,0px) scale(1,1) rotate(5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 15% {
		-webkit-animation-timing-function: linear;
		-webkit-transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1;
	} 
}
@keyframes sample1 {
	from {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1;
	} to {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1.0;
	} 3% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(-5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 6% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 9% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(-5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 12% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(5deg) skew(0deg,0deg);
		opacity: 1.0;
	} 15% {
		animation-timing-function: linear;
		transform: translate(0px,0px) scale(1,1) rotate(0deg) skew(0deg,0deg);
		opacity: 1;
	} 
}







.hati4 {
    width: 111px;
  
}
.hati4.trans img {
    animation: 1s ease 1.6s 1 normal none running rotate2; 
}
@keyframes rotate2 {
    0% {
    -webkit-transform: rotateY(0deg);
    -moz-transform: rotateY(0deg);
    -ms-transform: rotateY(0deg);
    -o-transform: rotateY(0deg);
    transform: rotateY(0deg);
    }
    25% {
    -webkit-transform: rotateY(90deg);
    -moz-transform: rotateY(90deg);
    -ms-transform: rotateY(90deg);
    -o-transform: rotateY(90deg);
    transform: rotateY(90deg); 
    }
    50% {
    -webkit-transform: rotateY(180deg);
    -moz-transform: rotateY(180deg);
    -ms-transform: rotateY(180deg);
    -o-transform: rotateY(180deg);
    transform: rotateY(180deg);
    }
    75% {
    -webkit-transform: rotateY(270deg);
    -moz-transform: rotateY(270deg);
    -ms-transform: rotateY(270deg);
    -o-transform: rotateY(270deg);
    transform: rotateY(270deg);  
    }
    100% {
    -webkit-transform: rotateY(360deg);
    -moz-transform: rotateY(360deg);
    -ms-transform: rotateY(360deg);
    -o-transform: rotateY(360deg);
    transform: rotateY(360deg);
    }
}
@keyframes hatiAnim2 {
    	0% {
	 right: 4%;
	}
		50% {
	 right: 76%;
	}
		0% {
	 right: 4%;
	}
}
@keyframes hurueru {
    0% {transform: translate(0px, 0px) rotateZ(0deg)}
    25% {transform: translate(0px, 25px) rotateZ(0deg)}
    50% {transform: translate(0px, 0px) rotateZ(0deg)}
    75% {transform: translate(0px, 25px) rotateZ(-0deg)}
    100% {transform: translate(0px, 0px) rotateZ(0deg)}
}
@keyframes hurueru2 {
    0% {transform: translate(0px, 0px) rotateZ(0deg)}
    25% {transform: translate(0px, 10px) rotateZ(0deg)}
    50% {transform: translate(0px, 0px) rotateZ(0deg)}
    75% {transform: translate(0px, 10px) rotateZ(-0deg)}
    100% {transform: translate(0px, 0px) rotateZ(0deg)}
}
.menu .bg_white {
    border-radius: 50%;
}
/*HEADER*/
header.scr_header {
background-color: #ffffff!important;
}
#pc_nav li a, #footer_nav li a {
color: #572c24;
}
.button_container span {
background: #199f19;color: #199f19;
}
/**/
.eachTextAnime {
    position: relative;
}
.eachTextAnime span {
    transition: transform 0.2s ease-in, opacity 0.1s ease-in;
    margin: 0 0.1em 0 0;
    /*transform: skewX(-10deg) translate3d(0, 1em, 0);*/
    transform: translate3d(0, 1em, 0);
    opacity: 0;
}
.eachTextAnime.appeartext span {
    animation: text_anime_on 1s ease-out forwards;
    /*transform: skewX(-10deg) translate3d(0, 0, 0);*/
     transform: translate3d(0, 0, 0);
    opacity: 1;
    display: inline-block;
}
.eachTextAnime:after {
    position: absolute;
    bottom: -4px;
    left: 0;
    margin: auto;
    width: 0%;
    height: 2px;
    content: '';
    background-color: #febd33;
    transition: all 1.2s;
}
.eachTextAnime.appeartext:after {
width: 100%;
}
.line:before {
    display: none;
}
/*CMS*/
#page_title .page_title_box {
    border-radius: 15px;
}
.top_cms_box {
    padding-top: 55px;
}
.top_cms_box:nth-child(2) {
}
.top_cms_box:first-of-type .cms_title:before {
    content: "";
    display: block;
    width: 59px;
    height: 100px;
    background: url(Dup/img/hati4.png);
    background-repeat: no-repeat;
    background-size: contain;
    left: calc(50% - 120px);
    top: -38px;
    position: absolute;
}
.cms_title {
    text-align: center;
}
.line-l:before {
    display: none;
}
#cms_2-a .cate_title {
        padding-top: .5em;
    padding-bottom: .5em;
    margin-bottom: 2em;
    position: relative;
    border-bottom: solid 2px #e0e0e0;
    display: block;
    text-align: left;
    border-top: 0;
}
#cms_2-a .cate_title:after {
    position: absolute;
    content: " ";
    display: block;
    width: 8%;
    bottom: -2px;
    border-bottom: solid 2px #f9ba37;
    left: 0;
}
#cms_2-a .cate_box img {
    border-radius: 47% 53% 50% 50% / 51% 44% 56% 49%;
}

/*FOOTER*/
footer {
   background: transparent!important;
    border-top: 1px solid #d9d9d9;
}
#footer {
    background-image: url(Dup/img/wood1.png), url(Dup/img/wood2.png);
    background-size: 150px;
    background-repeat: no-repeat;
    background-position: 4% 100%, 96% 100%;
}
/* ----------------------------------------------------------------------------------------------------------------------------------------------*/
/* -------------------------------------------------------↓↓↓↓↓↓↓↓↓↓↓↓↓------------------------------------------------------------------------*/
::-webkit-scrollbar {
width: 9px;
}
::selection {
    background: #73a853;
}
::-webkit-scrollbar-track {
    background: #e8e8e8;
}
::-webkit-scrollbar-thumb {
    background: #f9b11d;
    border-radius: 5px;
}
.button_container span {/*humburger MENU フォント*/
    font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic,"ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic",  sans-serif;
}
.fadein{
     transform: translateY(25px);
     transition: 1.5s;
     transition-property: opacity,transform
}
.fadein.trans{
     opacity: 1;
     transform: none
}
main {
    overflow: hidden;
}
.nav_menu_more:first-of-type a .icon:before  {
    content: "\f086";
}
.more_btn {
    background-color: rgba(213, 228, 210, 0.63);
}
#top_pc_nav li a {
}
#intro .num, #contents1 .num, #contents2 .num, #contents3 .num {/*数字*/
opacity: 1;z-index: 2;
}

.back1:before, .back2:before {
    z-index: -1;
    display: none;
}

footer #logo2 a {
max-width: 173px;
}
@media screen and (max-width: 768px){

   .pager li {
        margin-right: 0!important;
    }
    #footer h2 {
    font-size: 20px;
}
#intro_wrap {
    padding: 7% 4%;
}
.menu a {
    max-width: 108px;
    z-index: 2;
}
#intro .num, #contents1 .num, #contents2 .num {
   font-size: 16px; 
}
#contents1 .num {
    left: 36px;
    top: -28px;
}
#contents2 .num {
    top: -32px;
    left: 35px;
}
#contents3 .num {
    top: -70px;
}
.hatiAnim {
    width: 86px;
    bottom: 3px;
    right: 4%;
}
.hati2 {
    right: 4%;
    bottom: -10%;
    width: 85px;
}
.hati4 {
    width: 65px;
}
.top_cms_box:first-of-type .cms_title:before {
    width: 42px;
    height: 79px;
    left: calc(50% - 89px);
}
#footer {
    background-size: 100px;
    background-position: 2% 100%, 98% 100%;
}
#info_contact .con_box:before {
    width: 76px;
    height: 65px;
    top: -21px;
}
}
@media screen and (max-width: 667px){
.page_title_box h2 {
    font-size: 5vw;
}
#footer h2 {
    font-size: 5vw;
}
.pd_l-r5per {
    padding: 0 3%;
}
#fakeloader .fl {
max-width: 129px;
}
.hatiAnim {
    bottom: -23px;
}
.hatiAnim img {
    animation-name: hurueru2;
}

.hatiAnim.trans {
    animation-name: hatiAnim2;
}
#contents1 .num {
    left: 19px;
    top: -26px;
}
#contents2 .num {
    top: -28px;
    left: 17px;
}
.hati2 {
    right: 4%;
    bottom: -4.5%;
    width: 85px;
}
.cms_2-a .cate_box {
	padding: 0 10px;
}
.cms_2-a .swiper-button-prev {
    left: -5px;
}
.cms_2-a .swiper-button-next {
    right: -5px;
}
#cms_2-a .cate_box {
    margin-top: 20px;
    padding-bottom: 10px;
}
}
/* ----------------------------------------------------------------------------------------------------------------------------------------------*/
/* ----------------------------------------------------------------------------------------------------------------------------------------------*/

@media all and (-ms-high-contrast: none) {
#contents1 figure:before, #contents2 figure:before {
   display: none;
}
#cms_2-b .cate_title::before {
    padding: 6px 4px 2px 4px;
}
}





/* ------------video----------------------------------------------------------*/
.video_wrap {
	position: relative;
	overflow: hidden;
	width: 100%;
	height: 100vh;
}
video {
	min-width: 100%;
	min-height: 100vh;
	z-index: 1;
	position: absolute;
	top: 50%;
	left: 50%;
	-webkit-transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
	transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px){
	.video_wrap {
	position: static;
	overflow: hidden;
	width: 100%;
	height: auto;
	min-width: 100%;
}
video {   
	min-width: auto;
	min-height: auto;
	width: 100%;
	z-index: 1;
	position: static;
	top: 0%;
	left: 0%;
	-webkit-transform: translate(0%, 0%); 
	-ms-transform: translate(0%, 0%);
	transform: translate(0%, 0%); 
vertical-align: bottom;
}
}
/* ------------------------------------------------------------------------------- */    
@media screen and (max-width: 768px){

    .clover-r {
    width: 75px;
    right: -7px;
    top: -7px;
    }
    .clover-l {
    left: -12px;
    bottom: -7px;
    width: 96px;
    }
}