img{ border:none; vertical-align:bottom;}
.clear{ clear:both; height:0;}
.center{ text-align:center;}
ul{ list-style:none; margin:0; padding:0;}
p{ margin:0; line-height: 1.8;}
body{ margin:0 auto; padding:0; font-family: "Noto Sans Japanese"; color:#414A5A;}
a{ color:#414A5A;}

/* IE8+, Chrome */
a{ outline: 0;}

/* Firefox */
a::-moz-focus-inner,
a::-moz-focus-inner { border: 0;}

#container{ width: 100%; margin: 0 auto; position: relative;}
#contents{ padding-top: 115px;}
#main{ width: 100%; background: url("../img/common/bg_orange.jpg") repeat center top; padding-bottom: 100px;}
#main .bgR{ width: 100%; background-image: url("../img/common/bg_arch.png"),url("../img/common/sub_illust.png"); background-repeat: no-repeat,no-repeat; background-position: center top,left top; background-size: auto,auto;}
#main .mainV{ width: 1155px; margin: 0 auto 60px;}
#main .mainV::after{ display: block; content: ""; clear: both;}
#main .moveTxt{ float: left; text-align: center; padding-top: 330px;}
#main .moveTxt h1{ font-size: 24px;}
#main .moveTxt h1 span{ font-size: 50px; display: block; margin: 15px 0 40px;}
#main .moveTxt p.catch{ font-size: 18px; line-height: 30pt;}
#main .moveTxt p.fadeIn span{ opacity:0;}
#main .mainIllust{ float: right;}
#main .mainIllust img{ animation-name: fadein; animation-duration: 2s; /*animation-iteration-count: infinite;*/}
@keyframes fadein {
from {
    opacity: 0;
    transform: translateY(40px);
}
to {
    opacity: 1;
    transform: translateY(0);
}
}


#about-us{ width: 100%; background: url("../img/common/img_aboutus.png") no-repeat center top; padding-top: 90px;}
#about-us .auWrap{ width: 1000px; margin: 0 auto;}
#about-us h2{ font-size: 24px; text-align: center; margin: 0; position: relative;}
#about-us h2 span{ font-size: 30px; display: block; margin: 15px 0 40px;}
#about-us h2::after{ content: ''; display: inline-block; background: url("../img/common/mini_flower.png") no-repeat center bottom; background-size: contain; width: 100px; height: 52px; margin-bottom: 40px;}
#about-us h3{ font-size: 24px; margin: 0 0 40px; text-align: center;}
#about-us p{ text-align: center; font-size: 16px; line-height: 22pt;}
#about-us p.usTxt{ margin: 0 0 90px;}
#about-us ul{ width: 800px; margin: 45px auto 0;}
#about-us ul::after{ display: block; content: ""; clear: both;}
#about-us li{ width: 200px; float: left; color: #EC7978; font-size: 18px; line-height: 20pt; text-align: center;}
#about-us li img{ width: 140px; margin: 0 auto 10px; display: block;}
#about-us li span{ font-size: 12px; display: inline-block; vertical-align: top;}

#plan{ width: 100%; background: url("../img/common/bg_blue.jpg") repeat center top; padding: 100px 0;}
#plan .plan{ width: 1000px; margin: 0 auto 70px; padding-bottom: 70px; background: url("../img/common/dotted_line.png") repeat-x left bottom;}
#plan h2{ font-size: 24px; text-align: center; margin: 0; position: relative;}
#plan h2 span{ display: block; margin: 15px 0 40px;}
#plan h2::after{ content: ''; display: inline-block; background: url("../img/common/mini_flower.png") no-repeat center bottom; background-size: contain; width: 100px; height: 52px; margin-bottom: 40px;}
#plan h3{ font-size: 24px; margin: 0; text-align: center;}
#plan .plan ul::after{ display: block; content: ""; clear: both;}
#plan .plan li{ width: 475px; float: left; margin-right: 50px; margin-top: 50px;}
#plan .plan li:nth-child(even){ margin-right: 0;}
#plan .plan li img{ width: 475px;}
#plan .plan li .planWrap{ background: #fff; padding: 25px; border-radius: 0 0 6px 6px;}
#plan .plan li h4{ margin: 0 0 20px; font-size: 24px;}
#plan .plan li span.icon{ background: #FEEDE5; padding: 3px 10px;  margin-right: 10px; font-size: 14px; display: inline-block;}
#plan .plan li p.amount{ font-size: 16px; margin-top: 20px;}
#plan .plan li p.amount span{ font-size: 24px;}
#plan .plan li p.p-ex{ font-size: 14px; color: #8D929C;}

#plan .price{ width: 1000px; margin: 0 auto; padding-bottom: 100px;}
#plan .priceList{ width: 780px; margin: 50px auto 0;}
#plan .priceList::after{ display: block; content: ""; clear: both;}
#plan .priceList h4{  margin: 0 0 20px; padding-left: 30px; background: url("../img/common/icon_flower.png") no-repeat left center; background-size: 20px auto; color: #EC7978; font-size: 18px;}
#plan .priceList dd{ margin:0 auto; padding:0;}
#plan .priceList .l_pl{ width: 340px; float: left;}
#plan .priceList .r_pl{ width: 340px; float: right;}
#plan .priceList table{ width: 100%; border-top: #C9D6D6 solid 1px;}
#plan .priceList table th{ border-bottom: #C9D6D6 solid 1px; text-align: left; padding: 10px 10px 10px;}
#plan .priceList table td{ border-bottom: #C9D6D6 solid 1px; padding: 10px 10px 10px;}
#plan .priceList table tr td:last-child{ text-align: right;}
#plan .priceList p{ font-size: 14px; color: #8D929C; margin-top: 10px;}

#plan .petCemeteryWrap{ width: 1000px; margin: 0 auto 70px; padding-bottom: 70px; background: url("../img/common/dotted_line.png") repeat-x left bottom;}
#plan .petCemetery{ width: 910px; padding: 35px 45px; margin: 40px 0 0; background: #fff; border-radius: 6px;}
#plan .petCemetery p.pc_ttl{ font-size: 24px; background: url("../img/common/dotted_line.png") repeat-x left bottom; padding-bottom: 10px; margin-bottom: 40px;}
#plan .petCemetery ul::after{ display: block; content: ""; clear: both;}
#plan .petCemetery li{ float: left; padding-left: 30px; background: url("../img/common/icon_flower.png") no-repeat left center; background-size: 20px auto; color: #EC7978; font-size: 18px; margin-right: 52px;}
#plan .petCemetery li:last-child{ margin-right: 0;}

#plan .example{}
#plan .example p{ color: #EC7978; font-size: 18px; text-align: center; margin: 40px 0 50px;}
#plan .example ul{ width: 970px; margin: 0 auto;}
/*#plan .example li{ float: left; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; justify-content: space-between; align-items: center; font-size: 18px;}*/
#plan .example li{ display: inline-block; vertical-align: middle; font-size: 18px; margin-right: 20px;}
#plan .example li:first-child,#plan .example li:nth-child(4){ margin-right: 10px;}
#plan .example li:last-child{ margin-right: 0;}
#plan .example li img.exImg01{ width: 140px;}
#plan .example li img.exImg02{ width: 30px;}
#plan .example li span{ font-size: 24px;}

#flow{ width: 100%; background: url("../img/common/bg_orange.jpg") repeat center top; padding: 100px 0;}
#flow h2{ font-size: 24px; text-align: center; margin: 0 0 40px; position: relative;}
#flow h2 span{ display: block; margin: 15px 0 40px;}
#flow h2::after{ content: ''; display: inline-block; background: url("../img/common/mini_flower.png") no-repeat center bottom; background-size: contain; width: 100px; height: 52px; margin-bottom: 40px;}
#flow .flow{ width: 1000px; margin: 0 auto;}
#flow .flow ul::after{ display: block; content: ""; clear: both;}
#flow .flow li{ float: left; /*display: inline-block;*/ vertical-align: middle; font-size: 16px; margin-right: 40px; background: #fff; border-radius: 6px; text-align: center; width: 220px; height: 250px; position: relative; box-sizing: border-box;}
#flow .flow li::after{ content: ""; position: absolute; top: 49%; right: -25px; background: url("../img/common/arrow_right.png") no-repeat left center; background-size: contain; width: 8px; height: 12px;}
#flow .flow li:last-child::after{ content: none;}
#flow .flow li img{ width: 80px; margin-top: -40px;}
#flow .flow li:last-child{ width: 160px; margin-right: 0;}
#flow .flow li:nth-child(3){ width: 280px;}
#flow .flow li p{ margin-top: 20px; line-height: 19pt;}
#flow .flow li p span{ font-size: 12px;}
#flow .flow li p.f24{ font-size: 24px;}

#flow .area{ width: 1000px; margin: 80px auto 0; display: flex;}
#flow .areaImg{ width: 370px;}
#flow .areaImg img{ width: 370px;}
#flow .areaTxt{ width: 630px; padding: 30px 50px; background: #fff; box-sizing: border-box; align-items: center;}
#flow .areaTxt h4{ font-size: 24px; background: url("../img/common/dotted_line.png") repeat-x left bottom; padding-bottom: 10px; margin: 0 0 40px;}
#flow .areaTxt ul::after{ display: block; content: ""; clear: both;}
#flow .areaTxt li{ float: left; font-size: 18px; width: 130px; margin-bottom: 10px;}
#flow .areaTxt li:last-child{ margin-bottom: 0;}

#thoughts{ width: 100%; background-image: url("../img/common/img_thought"),url("../img/common/bg_blue.jpg"); background-repeat: no-repeat,repeat; background-position: right top,center top; background-size: auto,auto;}
#thoughts .thoughtsWrap{ width: 1000px; margin: 0 auto; padding: 100px 0;}
#thoughts h2{ font-size: 30px; margin: 0 0 60px;}
#thoughts p{ line-height: 27pt;}
#thoughts .bnr_caldog{ text-align: center; margin: 80px 0 0; display: block;}
#thoughts .bnr_caldog a:hover img{ opacity:0.7; filter:alpha(opacity=70); transition: all  0.3s ease;}

footer{ width: 1000px; margin: 0 auto; padding: 80px 0; text-align: center;}
footer .footLogo{ text-align: center;}
footer .footLogo img{ width: 300px;}
footer p.fLead{ font-size: 18px; margin: 50px 0;}
footer .contact::after{ display: block; content: ""; clear: both;}
footer .contact p{ color: #EC7978; font-size: 18px; margin-bottom: 10px;}
footer .contact a{ display: block; border-radius: 50px; height: 90px; box-sizing: border-box; text-decoration: none;}
footer .contact a:hover{ opacity:0.7; filter:alpha(opacity=70); transition: all  0.3s ease;}
footer .tel{ width: 475px; /*float: left;*/ margin: 0 auto;}
footer .tel a.btnTel{ font-size: 40px; background: url("../img/common/icon_tel.png") no-repeat 70px center #FEEDE6; background-size: 20px auto; padding-left: 40px; line-height: 84px;}
footer .mail{ width: 475px; float: right;}
footer .mail a.btnMail{ font-size: 30px; background: url("../img/common/icon_mail.png") no-repeat 70px center #FEEDE6; background-size: 25px auto; padding-left: 45px; line-height: 80px;}
footer p.add{ margin-top: 40px;}
footer .photo{ margin: 20px 0;}
footer .photo img{ width: 120px;}
#container .copy{ width: 100%; text-align: center; background: url("../img/common/bg_orange.jpg") repeat center top; padding: 30px 0; font-size: 12px;}
#container .copy a{ text-decoration: none;}

#container p.cau{ margin: 40px 0 0; font-size: 14px; color: #8D929C; line-height: 19pt; text-align: left;}

.site-header{
    background: rgba(255,255,255,1);
    padding: 36px 0;
    position: fixed;
    justify-content: space-between;
    transition: .5s;
    width: 100%;
	z-index: 100;
}
.site-header.transform{
    background: rgba(255,255,255,0.9);
    padding: 15px 0;
}
.site-logo{
    width: 1210px;
	margin: 0 auto;
	text-align: center;
}
.site-logo img{
    width: 260px;
	margin: 0 auto;
}

.gnav{ width: 1210px; height: 30px; margin: 0 auto;}
.gnav ul{ width: 100%; margin: -20px auto 0;}
.gnav ul::after{ display: block; content: ""; clear: both;}
.gnav ul li{ float: left; margin-right: 28px; vertical-align:middle;/*width: calc( ( 100% - 260px ) / 5);*/}
.gnav ul li:first-child{ margin-right: 48px;}
.gnav ul li:nth-child(2){ margin-right: 48px;}
.gnav ul li:nth-child(3){ margin-right: 0;}
.gnav ul li:nth-child(4){ margin-left: 340px;}
.gnav ul li:last-child{ margin-right: 0;}
.gnav ul li a{ background: url("../img/common/arrow_under.png") no-repeat left center; background-size: 12px auto; padding-left: 20px; text-decoration: none;}

/* page top
------------------------------------------------*/
#page-top{ width:90px; height:90px; display:none; position:fixed; right:40px; bottom: 35px; z-index:200;}
#page-top p{ margin:0; padding:0;}
#page-top p img{ width:90px; opacity:0.8; filter:alpha(opacity=80);}
#page-top p:hover img{ opacity:0.6; filter:alpha(opacity=60);}
#move-page-top{ text-decoration:none; display:block; cursor:pointer;}

.fadein { opacity : 0; transform : translate(0, 50px); transition : all 500ms;}
.fadein.scrollin { opacity : 1; transform : translate(0, 0);}

.pc{ display:inline !important;}
.sp{ display:none !important;}



@media screen and (max-width: 768px){
html {-webkit-text-size-adjust:none; margin:0 auto; padding:0;}
body{ margin:0 auto; padding:0; font-family: "Noto Sans Japanese"; color:#414A5A;}
img{ width:100%; height:auto; vertical-align:bottom;}
a img:hover{ opacity:1; filter:alpha(opacity=100); transition: all 0;}
.clear{ clear:both; height:0;}
.center{ text-align:center;}
ul{ list-style:none; margin:0; padding:0;}
p{ margin:0;}

#container{ width: 100%; margin: 0 auto; position: relative;}
#contents{ padding-top: 20%;}
#main{ width: 100%; background: url("../img/common/bg_orange.jpg") repeat center top; padding-bottom: 15%;}
#main .bgR{ width: 100%; background-image: url("../img/common/bg_arch.png"),url("none"); background-repeat: no-repeat; background-position: center top; background-size: 100%;}
#main .mainV{ width: auto; margin: 0 auto 10%;}
#main .mainV::after{ display: block; content: ""; clear: both;}
#main .moveTxt{ float: none; text-align: center; padding-top: 0;}
#main .moveTxt h1{ font-size: 18px;}
#main .moveTxt h1 span{ font-size: 24px; display: block; margin: 5px 0 20px;}
#main .moveTxt p.catch{ font-size: 16px; line-height: 20pt;}
#main .moveTxt p.fadeIn span{ opacity:0;}
#main .mainIllust{ float: none;}
#main .mainIllust img{ animation-name: fadein; animation-duration: 2s; /*animation-iteration-count: infinite;*/}


#about-us{ width: 100%; background: url("../img/common/img_aboutus_sp.png") no-repeat center top; background-size: 100%; padding-top: 70%;}
#about-us .auWrap{ width: auto; margin: 0 5%;}
#about-us h2{ font-size: 16px; text-align: center; margin: 0; position: relative;}
#about-us h2 span{ font-size: 20px; display: block; margin: 15px 0 20px;}
#about-us h2::after{ content: ''; display: inline-block; background: url("../img/common/mini_flower.png") no-repeat center bottom; background-size: contain; width: 80px; height: 41px; margin-bottom: 20px;}
#about-us h3{ font-size: 16px; margin: 0 0 40px; text-align: center;}
#about-us p{ text-align: left; font-size: 14px; line-height: 16pt;}
#about-us p.usTxt{ margin: 0 0 10%;}
#about-us ul{ width: auto; margin: 0 auto;}
#about-us ul::after{ display: block; content: ""; clear: both;}
#about-us li{ width: 50%; float: left; color: #EC7978; font-size: 13px; line-height: 18pt; text-align: center; margin-top: 10%;}
#about-us li img{ width: 85%; margin: 0 auto 10px; display: block;}
#about-us li span{ font-size: 10px; display: inline-block; vertical-align: top;}

#plan{ width: 100%; background: url("../img/common/bg_blue.jpg") repeat center top; padding: 15% 0;}
#plan .plan{ width: auto; margin: 0 5% 10%; padding-bottom: 10%; background: url("../img/common/dotted_line_sp.png") repeat-x left bottom; background-size: 30%;}
#plan h2{ font-size: 16px; text-align: center; margin: 0; position: relative;}
#plan h2 span{ display: block; margin: 15px 0 20px;}
#plan h2::after{ content: ''; display: inline-block; background: url("../img/common/mini_flower.png") no-repeat center bottom; background-size: contain; width: 80px; height: 41px; margin-bottom: 20px;}
#plan h3{ font-size: 16px; margin: 0; text-align: center;}
#plan .plan ul::after{ display: block; content: ""; clear: both;}
#plan .plan li{ width: auto; float: none; margin-right: 0; margin-top: 5%;}
#plan .plan li:nth-child(even){ margin-right: 0;}
#plan .plan li img{ width: 100%;}
#plan .plan li .planWrap{ background: #fff; padding: 5%; border-radius: 0 0 6px 6px;}
#plan .plan li h4{ margin: 0; font-size: 16px;}
#plan .plan li span.icon{ background: #FEEDE5; padding: 3px 10px; margin-right: 10px; margin-top: 10px; font-size: 12px; display: inline-block;}
#plan .plan li p.amount{ font-size: 14px; margin-top: 10px;}
#plan .plan li p.amount span{ font-size: 18px;}
#plan .plan li p.p-ex{ font-size: 12px; color: #8D929C;}

#plan .price{ width: auto; margin: 0 5%; padding-bottom: 0;}
#plan .price h3{ margin-bottom: 5%;}
#plan .priceList{ width: auto; margin: 3% auto 0;}
#plan .priceList::after{ display: block; content: ""; clear: both;}
#plan .priceList dl.acm{ margin:0; padding:0;}
#plan .priceList dl.acm dt{ margin:0; padding:0;}
#plan .priceList dl.acm dt a{ display:block; color:#EC7978; font-size:14px; padding: 5% 5% 5% 13%; margin:0; text-decoration:none; width: auto; border-radius: 6px; background: url("../img/common/icon_flower.png") no-repeat 5% center #fff; background-size: 16px auto;}
#plan .priceList dl.acm dt a:hover { text-decoration:none !important;}
#plan .priceList h4{ margin: 0 0 20px; padding-left: 30px; background: url("../img/common/icon_flower.png") no-repeat left center; background-size: 20px auto; color: #EC7978; font-size: 16px;}
#plan .priceList a.menuitem{ display:block; position:relative; width:100%; padding:0; margin:0 0 0; text-decoration:none;}
#plan .priceList a.menuitem:hover{ text-decoration:none;}
#plan .priceList a.menuitem:hover img{ opacity:1.0; filter:alpha(opacity=100);}
#plan .priceList a.menuitem .statusicon{ position:absolute; top: 47%; right:14px; border:none; width:12px;}
#plan .priceList dd.submenu{ width:100%; margin: -6px 0 0; padding: 0 5% 5%; background: #fff; box-sizing: border-box; border-radius: 0 0 6px 6px;}
#plan .priceList .l_pl{ width: auto; float: none; margin-bottom: 3%;}
#plan .priceList .r_pl{ width: auto; float: none;}
#plan .priceList table{ width: 100%; border-top: #C9D6D6 solid 1px; font-size: 12px;}
#plan .priceList table th{ border-bottom: #C9D6D6 solid 1px; text-align: left; padding: 10px;}
#plan .priceList table td{ border-bottom: #C9D6D6 solid 1px; padding: 10px;}
#plan .priceList table tr td:last-child{ text-align: right;}
#plan .priceList p{ font-size: 12px; color: #8D929C; margin-top: 10px;}

#plan .petCemeteryWrap{ width: auto; margin: 0 auto 10%; padding-bottom: 10%; background: url("../img/common/dotted_line_sp.png") repeat-x left bottom; background-size: 30%;}
#plan .petCemetery{ width: auto; padding: 5%; margin: 10% 0 0; background: #fff; border-radius: 6px;}
#plan .petCemetery p.pc_ttl{ font-size: 16px; background: url("../img/common/dotted_line_sp.png") repeat-x left bottom; background-size: 30%; padding-bottom: 10px; margin-bottom: 0;}
#plan .petCemetery ul::after{ display: block; content: ""; clear: both;}
#plan .petCemetery li{ float: none; padding-left: 30px; background: url("../img/common/icon_flower.png") no-repeat left center; background-size: 16px auto; color: #EC7978; font-size: 14px; margin-right: 0; margin-top: 5%;}
#plan .petCemetery li:last-child{ margin-right: 0;}

#plan .example{ margin: 0 5%;}
#plan .example p{ color: #EC7978; font-size: 14px; text-align: center; margin: 5% 0 10%;}
#plan .example ul{ width: auto; margin: 0 auto;}
/*#plan .example li{ float: left; -ms-flex-wrap: wrap; -webkit-flex-wrap: wrap; flex-wrap: wrap; justify-content: space-between; align-items: center; font-size: 18px;}*/
#plan .example li{ display: inline-block; vertical-align: middle; font-size: 14px; margin-right: 3%; width: 43%; text-align: center;}
#plan .example li p{ font-size: 13px; color:#414A5A;}
#plan .example li:first-child,#plan .example li:nth-child(4){ margin-right: 0;}
#plan .example li:first-child{ vertical-align: top;}
#plan .example li:nth-child(2),#plan .example li:nth-child(5){ display: none;}
#plan .example li:nth-child(3){ width: 10%; margin-right: 0;}
#plan .example li:nth-child(6){ width: 100%; margin-right: 0; border-top: #C9D7D7 solid 1px; margin-top: 8%; padding-top: 8%;}
#plan .example li:nth-child(6) img{ margin-right: 5%;}
#plan .example li:last-child{ display: none; margin-right: 0;}
#plan .example li img.exImg01{ width: 100%; margin-bottom: 4%;}
#plan .example li img.exImg02{ width: 20px; vertical-align: text-top;}
#plan .example li span{ font-size: 18px;}

#flow{ width: 100%; background: url("../img/common/bg_orange.jpg") repeat center top; padding: 15% 0;}
#flow h2{ font-size: 16px; text-align: center; margin: 0 0 20px; position: relative;}
#flow h2 span{ display: block; margin: 15px 0 20px;}
#flow h2::after{ content: ''; display: inline-block; background: url("../img/common/mini_flower.png") no-repeat center bottom; background-size: contain; width: 80px; height: 41px; margin-bottom: 20px;}
#flow .flow{ width: auto; margin: 0 5%;}
#flow .flow ul::after{ display: block; content: ""; clear: both;}
#flow .flow li{ float: none; /*display: inline-block;*/ vertical-align: middle; font-size: 14px; margin-right: 0; background: #fff; border-radius: 6px; text-align: center; width: auto; height: auto; position: relative; box-sizing: border-box; margin-top: 23%; padding-bottom: 30px;}
#flow .flow li:first-child{ margin-top: 10%;}
#flow .flow li:nth-child(2){}
#flow .flow li:nth-child(3){ width: auto;}
#flow .flow li:last-child{ width: auto; margin-right: 0;}
#flow .flow li:last-child::after{ content: none;}
#flow .flow li::after{ content: ""; position: absolute; top: 110%; right: 47%; background: url("../img/common/arrow_flow_sp.png") no-repeat center bottom; background-size: contain; width: 20px; height: 13px;}
#flow .flow li img{ width: 60px; margin-top: -30px;}
#flow .flow li p{ margin-top: 0; line-height: 19pt; text-align: left; padding-left: 25%;}
#flow .flow li p.flow_sp01{ background: url("../img/common/flow_icon01_sp.png") no-repeat 5% center; background-size: 15%;}
#flow .flow li p.flow_sp02{ background: url("../img/common/flow_icon02_sp.png") no-repeat 5% center; background-size: 15%;}
#flow .flow li p.flow_sp03{ background: url("../img/common/flow_icon03_sp.png") no-repeat 5% center; background-size: 15%;}
#flow .flow li p.flow_sp04{ background: url("../img/common/flow_icon04_sp.png") no-repeat 5% center; background-size: 15%;}
#flow .flow li p span{ font-size: 12px;}
#flow .flow li p.f24{ font-size: 14px; line-height: 300%;}

#flow .area{ width: auto; margin: 15% 5% 0; display: block;}
#flow .areaImg{ width: auto;}
#flow .areaImg img{ width: 100%;}
#flow .areaTxt{ width: auto; padding: 5%; background: #fff; box-sizing: border-box; align-items: center;}
#flow .areaTxt h4{ font-size: 16px; background: url("../img/common/dotted_line.png") repeat-x left bottom; background-size: 30%; padding-bottom: 10px; margin-bottom: 5%;}
#flow .areaTxt ul::after{ display: block; content: ""; clear: both;}
#flow .areaTxt li{ float: left; font-size: 11px; width: 33.3333%; margin-bottom: 3%;}
#flow .areaTxt li:last-child{ margin-bottom: 0;}

#thoughts{ width: 100%; background-image: url("../img/common/img_thought"),url("../img/common/bg_blue.jpg"); background-repeat: no-repeat,repeat; background-position: center top,center top; background-size: 70%,auto;}
#thoughts .thoughtsWrap{ width: auto; margin: 0 5%; padding: 50% 0 15%;}
#thoughts h2{ font-size: 20px; margin: 0 0 10%; text-align: center;}
#thoughts p{ line-height: 18pt; font-size: 14px;}
#thoughts .bnr_caldog{ text-align: center; margin: 15% 0 0; display: block;}
#thoughts .bnr_caldog a:hover img{ opacity:1; filter:alpha(opacity=100); transition: all  0.3s ease;}

footer{ width: auto; margin: 0 5%; padding: 15% 0; text-align: center;}
footer .footLogo{ text-align: center; width: 60%; margin: 0 auto;}
footer .footLogo img{ width: 100%;}
footer p.fLead{ font-size: 14px; margin: 10% 0 5%;}
footer .contact::after{ display: block; content: ""; clear: both;}
footer .contact p{ color: #EC7978; font-size: 14px; margin-bottom: 2%;}
footer .contact a{ display: block; border-radius: 50px; height: auto; box-sizing: border-box; text-decoration: none;}
footer .contact a:hover{ opacity:1; filter:alpha(opacity=100); transition: all  0.3s ease;}
footer .tel{ width: auto; float: none; margin-bottom: 5%;}
footer .tel a.btnTel{ font-size: 20px; background: url("../img/common/icon_tel.png") no-repeat 10% center #FEEDE6; background-size: 20px auto; padding: 4%; line-height: 150%;}
footer .mail{ width: auto; float: none;}
footer .mail a.btnMail{ font-size: 18px; background: url("../img/common/icon_mail.png") no-repeat 10% center #FEEDE6; background-size: 25px auto; padding: 5%; line-height: 150%;}
footer p.add{ margin-top: 10%; font-size: 14px;}
footer .photo{ margin: 5% 0;}
footer .photo img{ width: 120px;}
footer p.name{ font-size: 14px;}
#container .copy{ width: auto; text-align: center; background: url("../img/common/bg_orange.jpg") repeat center top; padding: 5%; font-size: 10px;}

#container p.cau{ margin: 8% 0 0; font-size: 12px; color: #8D929C; line-height: 16pt; text-align: left;}
	
	
/*menu*/
.menu{
    height: 20px;
    position: absolute;
    right: 20px;
    top: 18px;
    width: 30px;
    z-index: 99;
	display: block;
}
.menu__line{
    background: #EC7978;
    display: block;
    height: 2px;
    position: absolute;
    transition:transform .3s;
    width: 100%;
}
.menu__line--center{
    top: 9px;
}
.menu__line--bottom{
    bottom: 0;
}
.menu__line--top.active{
    top: 8px;
    transform: rotate(45deg);
	background: #EC7978;
}
.menu__line--center.active{
    transform:scaleX(0);
	background: #EC7978;
}
.menu__line--bottom.active{
    bottom: 10px;
    transform: rotate(135deg);
	background: #EC7978;
}
	
/*gnav*/
.gnav{
    background: rgba(255,255,255,0.9);
    display: none;
    height: 100%;
    position: fixed;
    width: 100%;
    z-index: 98;
	top: 0;
}
.gnav__wrap{
    align-items:center;
    display: flex;
    height: 100%;
    position: absolute;
    width: 100%;
}
.gnav__menu{
    position: absolute;
    left: 50%;
	top: 20%;
    transform: translateX(-50%);
    width: 80%;
}
.gnav__menu__item{
    margin: 0 auto;
    opacity: 0;
}
.gnav__menu__item a{
     color:#414A5A;
    font-size: 16px;
    font-weight: bold;
    text-decoration: none;
    transition: .5s;
}
.gnav__menu__item a:hover{
     color:#414A5A;
}
	
.gnav ul{ width: 90%; height: auto; margin: 0 auto;}
.gnav ul::after{ display: block; content: ""; clear: both;}
.gnav ul li{ float: none; margin: 0 0 10%; vertical-align:middle;}
.gnav ul li:first-child{ margin-right: 0;}
.gnav ul li:nth-child(2){ margin-right: 0;}
.gnav ul li:nth-child(3){ margin-right: 0;}
.gnav ul li:nth-child(4){ margin-left: 0;}
.gnav ul li:last-child{ margin-right: 0;}
	
.site-header{
    background: rgba(255,255,255,1);
    padding: 15px 0;
    position: fixed;
    justify-content: space-between;
    transition: .5s;
    width: 100%;
	z-index: 100;
}
.site-header.transform{
    background: rgba(255,255,255,0.9);
    padding: 15px 0;
}
.site-logo{
    width: auto;
	margin: 0 auto;
	text-align: center;
}
.site-logo img{
    width: 45%;
	margin: 0 auto;
	vertical-align: middle;
}
	
/* page top
------------------------------------------------*/
#page-top{ width:40px; height:40px; display:none; position:fixed; right:5px; bottom:7%; z-index: 11;}
#page-top p{ margin:0; padding:0;}
#page-top p img{ width:100%; opacity:0.8; filter:alpha(opacity=80);}
#page-top p:hover img{ opacity:0.6; filter:alpha(opacity=60);}
#move-page-top{ text-decoration:none; display:block; cursor:pointer;}


.pc{ display:none !important;}
.sp{ display:inline !important;}

}
