﻿/*@import url('https://fonts.googleapis.com/css2?family=Caveat&display=swap');*/
@import url('https://fonts.googleapis.com/css2?family=Kiwi+Maru:wght@300&display=swap');

.font_en {
    /*font-family: 'Caveat',"游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ Pro W3", Hiragino Kaku Gothic Pro," メイリオ", Meiryo, Osaka," ＭＳ Ｐゴシック", MS PGothic," sans-serif";*/
    font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ Pro W3", Hiragino Kaku Gothic Pro," メイリオ", Meiryo, Osaka," ＭＳ Ｐゴシック", MS PGothic," sans-serif";
}

.font_km {
    font-family: 'Kiwi Maru',"游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ Pro W3", Hiragino Kaku Gothic Pro," メイリオ", Meiryo, Osaka," ＭＳ Ｐゴシック", MS PGothic," sans-serif";
}

body{
    overflow-x: hidden;
}
#fakeloader{
	z-index: 9999;
	background-color: #fcf5e7;
    /*background-image: url(./Dup/img/fl_bg.png);*/
    background-position: left bottom;
    background-repeat: repeat-x;
    background-size: auto 70px;
}
#fakeloader .fl{
	position: absolute!important;
	top: 50%!important;
	left: 50%!important;
	transform: translate(-50%,-50%)!important;
	width: 50%!important;
	max-width: 240px;
}
#fakeloader .fl{
	animation-name: loader;
	animation-duration: 5s;
	animation-timing-function: ease;
	animation-iteration-count: infinite;
}
@keyframes loader {
	0% {opacity: 0;}
	50% {opacity: 1;}
	100% {opacity: 0;}
}

#main_img {
    min-height: auto;
}
.scroll_bt {
    bottom: -25px;
}
#video video {
    vertical-align: middle;
}
#video::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    background-image: url(./Dup/img/dott.png);
    background-position: left top;
    background-repeat: repeat;
    background-size: 3px auto;
    z-index: 1;
}
#main_img h2{
    font-size: 18px;
    text-align: left;
    color: #404556;
    font-weight: bold;
    line-height: 2.2;
    text-shadow: none;
}
.txt1 span {
    display: block;
    color: #ffffff;
    background-color: #27C69F;
    margin-bottom: 15px;
    padding: 0 10px;
}
/*
.txt1 span:last-child{
    font-size: 12px;
    background-color: #EDBBD4;
}
*/
.scroll_bt{
    display: none;
}

header{
    position: relative;
    /*background-image: url(./Dup/img/head_bottom.png);*/
    background-position: center bottom 6%;
    background-repeat: no-repeat;
    background-size: 100% auto;
}
header::after {
    position: absolute;
    content: "";
    background-image: url(./Dup/img/head.png);
    background-position: right top;
    background-repeat: repeat-y;
    background-size: 12px;
    top: 0px;
    right: -12px;
    width: 12px;
    height: 100%;
}

#main_menu ul li a {
    font-size: 16px;
    /*font-weight: bold;*/
    color: #42210B;
    margin-bottom: 20px;
}
#main_menu ul li a span{
    display: block;
    font-size: 10px;
    color: #E879A4;
    padding: 0 0 0 5px;
}

.pc_box #logo img {
    width: 90% !important;
}
.pc_box .contact_bt{
    position:relative;
}
.pc_box .contact_bt a{
    color: #ffffff;
    border: 1px solid #27C69F;
    background-color: #27C69F;
    border-radius: 30px;
    padding-top: 10px;
    padding-bottom: 10px;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}
.pc_box .button:hover{
    color: #ffffff;
    border:1px solid #EDBBD4;
    background-color: transparent;
}
.pc_box .button:hover::after {
    box-shadow: inset 0 0 0 15em #EDBBD4;
}
.pc_box .tel_bt{
    display: none;
}

.txt3{
    width: 100%;
    max-width: 880px;
    margin-left: auto;
    margin-right: auto;
}
.txt2_sub{
    color: #eb6d7b;
}
.contents2_bnr{
    background-color: #eb6d7b;
    color: #ffffff;
    text-align: center;
    padding: 10px 10px;
    font-weight: bold;
    font-size: 16px;
    margin-top: 10px;
    border-radius: 10px;
}
.contents2_bnr span{
    display: inline-block;
    font-size: 13px;
    font-weight: normal;
    padding: 3px 20px;
    color: #eb6d7b;
    background-color: #ffffff;
    line-height: 1;
    border-radius: 15px;
    margin-bottom: 5px;
}

#contents3{
    border-top: double 6px #EDBBD4;
    border-bottom: double 6px #EDBBD4;
    background: rgba(237,187,212,0.2);
}
#contents2 figure,#contents3 figure{
    position: relative;
}
#contents2 figure::after,#contents3 figure::after{
    background-image: url(./Dup/img/img_frame_w.png);
    content: "";
    display: block;
    background-repeat: no-repeat;
    position: absolute;
    background-size: 100% 100%;
    width: 102%;
    height: 102%;
    top: 50%;
    left: 50%;
    -ms-transform: translate(-50%,-50%);
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    z-index: 1;
}
#contents3 figure::after{
    background-image: url(./Dup/img/img_frame.png);
}

#top_cms{
    background-image: url(./Dup/img/point9.png);
    background-repeat: no-repeat;
    background-position: top 3% right 5%;
    background-size: 160px auto;
}
#top_cms .more a{
    color: #ffffff;
    border-color: #27C69F;
    background-color: #27C69F;
    z-index: 1;
    font-size: 15px;
    line-height: 1;
    border-radius: 30px;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}
#top_cms .more a:hover{
    color: #ffffff;
    background-color: transparent;
    border-color: #EDBBD4;
}
#top_cms .more a:hover::after {
    box-shadow: inset 0 0 0 15em #EDBBD4;
}
.cms_title h2{
    color: #42210B;
    font-family: 'Kiwi Maru';
    font-weight: bold;
}
.cms_title p{
    color: #eb6d7b;
    line-height: 1.0;
}

#map{
    /*
    padding: 5px;
    border: 1px solid #9b9a9a;
    */
}

.footer_wrap{
    background-color: #F5F2F1;
    border-top: solid 8px #ECE9E7;
}
.footer_wrap .logo .width_200-max{
        max-width: 250px;
}
.foot_tel_bt .button{
    color: #ffffff;
    border-color: #EDBBD4;
    background-color: #EDBBD4;
    z-index: 1;
    border-radius: 30px;
    padding-top: 10px;
    padding-bottom: 10px;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}
.foot_tel_bt .button:hover{
    color: #ffffff;
    background-color: transparent;
    border-color: #27C69F;
}
.foot_tel_bt .button:hover::after {
    box-shadow: inset 0 0 0 15em #27C69F;
}
.footer_cms{
    font-size: 13px;
    color: #694d29;
}

#page-top .txt_color1{
    color: #42210B;
}

#page_title .page_box{
    text-align: center;
    padding-left: 0;
    background-image: url(./Dup/img/point1.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: auto 100%;
}
#page_title .page_box h2 {
    text-shadow: none;
    font-weight: bold;
    font-family: 'Kiwi Maru';
    color: #42210B;
    letter-spacing: 2px;
}
#page_title .page_box p {
    text-shadow: none;
    font-size: 12px;
    color: #E879A4;
}
#page_title .page_box::before{
    display: none;
}

.cate_list li a{
    color: #ffffff;
    background-color: #EDBBD4;
    border: 1px solid #EDBBD4;
    border-radius: 30px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    padding: 10px;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}
.cate_list li a:hover{
    background-color: #27C69F;
    border: 1px solid #27C69F;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}

#page8 .mail_contact_link div{
    padding: 0 10px;
    font-size: 16px;
}
#page8 .mail_contact_link div:first-child a{
    background-color: #7ac0cc;
    color: #ffffff;
    text-align: center;
    padding: 20px 10px;
    border-radius: 10px;
}
#page8 .mail_contact_link div:last-child a{
    background-color: #E879A4;
    color: #ffffff;
    text-align: center;
    padding: 10px 10px;
    border-radius: 40px;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
    font-size: 20px;
}

#page9 h3{
    font-weight: bold;
}
#page9 p{
    line-height: 1.8;
}

#page10 ul li{
    margin-bottom: 20px;
}
#page10 ul li .button2 {
    color: #42210B;
    background-color: #fcf5e7;
    border-radius: 30px;
    border: solid 3px #FDE4BC;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}
#page10 ul li .button2:hover{
    color: #ffffff;
    background-color: #EDBBD4;
    border: 3px solid #EDBBD4;
}

.cms_2-c{
    padding: 15px;
    background-color: #fdfaf3;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);  
}
#cms_2-c .cate_box{
    padding: 15px;
    background-color: #fdfaf3;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);  
}
.cms_1-a .cate_box{
    padding: 15px;
    background-color: #fdfaf3;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}
.cms_2-ax .cate_box{
    padding: 15px;
    background-color: #fdfaf3;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}
.cms_5-c .cate_box{
    padding: 15px;
    background-color: #fdfaf3;
    box-shadow: 4px 4px 0 rgba(0,0,0,0.1);
}


/* 公開後修正 */
#contents2{
    display: none;
}

@media screen and (min-width:769px){

}

@media screen and (max-width: 768px){
    /*
    .txt1 span:last-child{
        display: none;
    }
    */
	.pc_box #logo img {
		width: 100% !important;
	}
	.hamburger.active .hamburger__icon:before,
	.hamburger.active .hamburger__icon:after{
		/*background-color: #ffffff!important;*/
	}
	.fat-nav.active,.fat-nav.active ul{
		background-color: #fcf5e7;
		background-image: url(./Dup/img/h_bg.png);;
	}
	.fat-nav li a{
		color: #42210B;
		font-size: 14px;
		/*font-weight: bold;*/
	}
	.fat-nav li a.border_color1{
		border-color: #42210B;
		font-size: 20px;;
	}
    footer .link_box ul{
        max-width: 400px;
        margin: 0 auto;
    }
	footer .logo img {
		max-width: 200px;
	}
    #top_cms {
        background-position: top 1% right 2%;
        background-size: 120px auto;
    }
}

@media screen and (max-width: 667px){
    #main_img h2 {
        font-size: 14px;
        margin: 20px auto;
    }
    .txt1 {
        position: relative;
        max-width: 100%;
        right: 0;
        margin: 0 auto;
    }
    #top_cms {
        background-position: top 10px right 0;
        background-size: 100px auto;
    }
    .cms_2-c{
        padding: 5px;
    }
    #cms_2-c .cate_box{
        padding: 5px;
    }
    .cms_1-a .cate_box{
        padding: 5px;
    }
    .cms_2-ax .cate_box{
        padding: 5px;
    }
    .cms_5-c .cate_box{
        padding: 5px;
    }
}

@media all and (-ms-high-contrast:none){
    body,html{
        overflow-x: hidden;
    }
    .pc_box .contact_bt a {
        padding-top: 13px;
        padding-bottom: 7px;
    }
    .contents2_bnr span{
        padding:5px 20px 0px;
    }
    #top_cms .more a{
        padding: 13px 0 7px;
    }
    .foot_tel_bt .button{
        padding-top: 13px;
        padding-bottom: 7px; 
    }
    .cate_list li a{
        padding:13px 0 7px;
    }
    #page8 .mail_contact_link div:first-child a,
    #page8 .mail_contact_link div:last-child a{
        padding:13px 10px 7px;
    }
}

/* アニメーション */
.fadein{
     opacity: 0;
     transform: translateY(20px);
     transition: 1.5s;
     transition-property: opacity,transform
}
.fadein.fadetrans{
     opacity: 1;
     transform: none
}
.fadein2{
     opacity: 0;
     transform: translateX(20px);
     transition: 1.5s;
     transition-property: opacity,transform
}
.fadein2.fadetrans{
     opacity: 1;
     transform: none
}
.fadein3{
     opacity: 0;
     transform: translateX(-20px);
     transition: 1.5s;
     transition-property: opacity,transform
}
.fadein3.fadetrans{
     opacity: 1;
     transform: none
}