@charset "UTF-8";

/*-- Anchor -------------------------------------------------------------*/
a         { resize: none; }
a:link    { color:#000; text-decoration: none; }
a:visited { color:#000; text-decoration: none; }
a:hover   { color:#000; text-decoration: none; opacity: 0.7; }
a:active  { color:#000; text-decoration: none; }

.u_link a         { resize: none; }
.u_link a:link    { color:#03C; text-decoration: none; }
.u_link a:visited { color:#639; text-decoration: none; }
.u_link a:hover   { color:#03C; text-decoration: underline; }
.u_link a:active  { color:#03C; text-decoration: none; }

.h_contact a         { resize: none; }
.h_contact a:link    { color:#fff; text-decoration: none; }
.h_contact a:visited { color:#fff; text-decoration: none; }
.h_contact a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
.h_contact a:active  { color:#fff; text-decoration: none; }

footer a         { resize: none; }
footer a:link    { color:#000; text-decoration: none; }
footer a:visited { color:#000; text-decoration: none; }
footer a:hover   { color:#000; text-decoration: none; opacity: 0.7; }
footer a:active  { color:#000; text-decoration: none; }

em { color: #C00;}

/*-- リスト全体をリンク　hover透過　グループリンク
-------------------------------------------------------------*/
.g_box { position:relative; }
.g_box:hover { cursor:pointer; opacity:0.7; }
.g_link { margin-bottom:0px; }
.g_link a {position:absolute; text-indent:-9999px; top:0px; left:0px; width:100%; height:100%; }

@media screen and (max-width: 767px) {
	.pc { display: none; }
}
@media screen and (min-width: 768px) {
	.sp { display: none; }
	.alC_pc { text-align: center; }
}
@media screen and (max-width: 960px) {
	.pc_tab { display: none; }
	.sp_tab { display: block; }
}
@media screen and (min-width: 961px) {
	.pc_tab { display: block; }
	.sp_tab { display: none; }
}
/*-- imaga -------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	.img_t_R { float:right; margin:0 0 2% 4%; width:45%;}
	.img_t_L { float:left; margin:0 4% 2% 0; width:45%;}
	.img_y_R { margin:0 10% 4%; width:80%;}
	.img_y_L { margin:0 10% 4%; width:80%;}
}
@media screen and (min-width: 768px) {
	.img_t_R { float:right; margin:0 0 20px 20px; width:240px;}
	.img_t_L { float:left; margin:0 20px 20px 0; width:240px;}
	.img_y_R { float:right; margin:0 0 20px 20px; width:300px;}
	.img_y_L { float:left; margin:0 20px 20px 0; width:300px;}
}

/*-- header -------------------------------------------------------------*/
header { position: relative; }
@media screen and (max-width: 767px) {
	h1 { font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; font-weight:bold; font-size: 1.4rem; text-align: center; margin-bottom: 10px; }
	.headline { padding: 50px 0; margin-bottom: 15px; 
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ededed+1,ededed+28,f6f6f6+47,ffffff+100 */
background: rgb(237,237,237); /* Old browsers */
background: -moz-linear-gradient(45deg,  rgba(237,237,237,1) 1%, rgba(237,237,237,1) 28%, rgba(246,246,246,1) 47%, rgba(255,255,255,1) 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(45deg,  rgba(237,237,237,1) 1%,rgba(237,237,237,1) 28%,rgba(246,246,246,1) 47%,rgba(255,255,255,1) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(45deg,  rgba(237,237,237,1) 1%,rgba(237,237,237,1) 28%,rgba(246,246,246,1) 47%,rgba(255,255,255,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ededed', endColorstr='#ffffff',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */	
	}
	h2 { text-align: center; font-size: 1.5rem; font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; }
	h2 span { display: block; font-size: 0.6em; }
	
	.index-h2 { margin-bottom: 20px; }
	.headline p { margin-bottom: 0px; font-size: 0.9rem; font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif }
	#content { margin: 0 4%;}
	
	header .f_logo { width: 50px; margin: 5px auto 0; }
}
@media screen and (min-width: 768px) {
	h1 { font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; font-weight:bold; font-size: 2.0rem; line-height: 1.2; text-align: center; margin-bottom: 10px }
	.headline { padding: 120px 0; margin-bottom: 80px;
/* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#ededed+1,ededed+28,f6f6f6+47,ffffff+100 */
background: rgb(237,237,237); /* Old browsers */
background: -moz-linear-gradient(45deg,  rgba(237,237,237,1) 1%, rgba(237,237,237,1) 28%, rgba(246,246,246,1) 47%, rgba(255,255,255,1) 100%); /* FF3.6-15 */
background: -webkit-linear-gradient(45deg,  rgba(237,237,237,1) 1%,rgba(237,237,237,1) 28%,rgba(246,246,246,1) 47%,rgba(255,255,255,1) 100%); /* Chrome10-25,Safari5.1-6 */
background: linear-gradient(45deg,  rgba(237,237,237,1) 1%,rgba(237,237,237,1) 28%,rgba(246,246,246,1) 47%,rgba(255,255,255,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#ededed', endColorstr='#ffffff',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
	}
	h2 { text-align: center; font-size: 3.3rem; font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; }
	h2 span { display: block; font-size: 0.5em; }
	
	.index-h2 { margin-bottom: 40px; }
	.headline p { margin-bottom: 0px;font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif}
	
	header .f_logo { width: 80px; margin: 5px auto 10px; }
}
@media screen and (min-width: 768px) and (max-width: 960px)  {
	h2 { padding: 30px 0; }
}
@media screen and (min-width: 961px) and (max-width: 1024px)  {

} 
@media screen and (min-width: 1025px) and (max-width: 1319px)  {

}
@media screen and (min-width: 1320px) {

}

/*-- SP menu-trgger -------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	.menu-trigger,.menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box; }
	.menu-trigger { position: fixed; top: 1%; left: 4%; width: 40px; height: 33px; z-index: 9999; border-radius: 2px; }
	.menu-trigger:hover{ /*background: rgba(255, 255, 255,0.6);*/ cursor:pointer; }
	.menu-trigger span { position: absolute; z-index: 9999; left: 4.2px; width: 100%; height: 1px; background-color: #000; border-radius: 2px; }
	.h_menu .active span { background-color: #fff !important; } /* 色を変える */
	.menu-trigger span:nth-of-type(1) { top: 7px; }
	.menu-trigger span:nth-of-type(2) { top: 16.5px; width: 75%; }
	.menu-trigger span:nth-of-type(3) { bottom: 6px; }
	.menu-trigger.active span:nth-of-type(1) {
	 -webkit-transform: translateY(20px) rotate(-45deg);
	 transform: translateY(8px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) { opacity: 0; }
	.menu-trigger.active span:nth-of-type(3) {
	 -webkit-transform: translateY(-20px) rotate(45deg);
	 transform: translateY(-8px) rotate(45deg);
	}
	#overlay{ display: none; width: 82%; margin: 0 10% 0 0%; padding: 15% 4% 4%; height: calc(100% - 0px); text-align: center;
		position: fixed; top: 0px; left: 0px; z-index: 999; background: #000; box-sizing: border-box;
		box-shadow: -4px 0px 16px -6px rgba(0,0,0,0.6);
	}
	#overlay .in { overflow: auto; height: 100%;
		-webkit-overflow-scrolling: touch;
	}	
	#overlay .h_nav li { text-align: left; margin-bottom: 5px; padding-bottom: 5px; border-bottom: 1px dotted #fff; font-size: 0.8rem; }
	#overlay .h_nav li a         { resize: none; display: block; font-family:'Roboto Condensed', sans-serif; font-weight:bold; }
	#overlay .h_nav li a:link    { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:visited { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:hover   { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:active  { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:before { content:"\f0da"; font-family:FontAwesome; margin-right:10px; opacity: 0.7; }
	#overlay .h_nav li a span { font-family:'Roboto Condensed', sans-serif; font-weight:bold; color: rgba(255,255,255,0.5); font-size: 0.7rem; float: right; }
	
	.h_contact { position: fixed; top: 1%; right: 1%; width: 35px; height: 35px; border-radius: 50%; z-index: 9999; background: #000; text-align: center; line-height: 35px;}
}
@media screen and (min-width: 768px) {
	.menu-trigger,.menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box; }
	.menu-trigger { position: fixed; top: 1%; left: 1%; width: 50px; height: 33px; z-index: 9999; }
	.menu-trigger:hover{ /*background: rgba(255, 255, 255,0.6);*/ cursor:pointer; }
	.menu-trigger span { position: absolute; z-index: 9999; left: 0px; width: 100%; height: 1px; background-color: #000; border-radius: 2px; }
	.h_menu .active span { background-color: #fff !important; } /* 色を変える */
	.menu-trigger span:nth-of-type(1) { top: 7px; }
	.active span:nth-of-type(1) { top: 9px; }
	.menu-trigger span:nth-of-type(2) { top: 16.5px; width: 75%; }
	.menu-trigger span:nth-of-type(3) { bottom: 6px; }
	.menu-trigger.active span:nth-of-type(1) {
	 -webkit-transform: translateY(20px) rotate(-45deg);
	 transform: translateY(8px) rotate(-45deg);
	}
	.menu-trigger.active span:nth-of-type(2) { opacity: 0; }
	.menu-trigger.active span:nth-of-type(3) {
	 -webkit-transform: translateY(-20px) rotate(45deg);
	 transform: translateY(-8px) rotate(45deg);
	}
	#overlay{ display: none; width: 40%; margin: 0 10% 0 0%; padding: 6% 4% 4%; height: calc(100% - 0px); text-align: center;
		position: fixed; top: 0px; left: 0px; z-index: 999; background: #000; box-sizing: border-box;
		box-shadow: -4px 0px 16px -6px rgba(0,0,0,0.6);
	}
	#overlay .in { overflow: auto; height: 100%;
		-webkit-overflow-scrolling: touch;
	}	
	#overlay .h_nav li { text-align: left; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px dotted #fff; font-size: 0.9rem; }
	#overlay .h_nav li a         { resize: none; display: block; /*font-family:'Roboto Condensed', sans-serif; font-weight:bold;*/ font-family:'Roboto Condensed', sans-serif; }
	#overlay .h_nav li a:link    { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:visited { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:hover   { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:active  { color:#fff; text-decoration: none; }
	#overlay .h_nav li a:before { content:"\f0da"; font-family:FontAwesome; margin-right:10px; opacity: 0.7; }
	#overlay .h_nav li a span { font-family:'Roboto Condensed', sans-serif; font-weight:bold; color: rgba(255,255,255,0.5); font-size: 0.7rem; float: right; }
	
	.h_contact { position: fixed; top: 1%; right: 1%; width: 40px; height: 40px; border-radius: 50%; z-index: 9999; background: #000; text-align: center; line-height: 40px;}
}

/*-- コンテンツ -------------------------------------------------------------*/
.sp-search-wrap { display: none; }
@media screen and (max-width: 767px) {
	.proList { display: flex; justify-content: center; flex-wrap: wrap;}
	.proList li { width: 50%; margin-bottom: 20px;}
	.proList li div { margin-bottom: 10px; }
	.proList li h4 { font-family:'Roboto Condensed', sans-serif; font-weight:normal; margin:0 10px; font-size: 0.8rem; }
	.proList li h3 { margin-bottom: 0px; margin:0 10px; font-size: 0.9rem;}
	.proList li h5 { font-size: 0.7rem; margin:0 10px 20px;}
	.proList li h5 span { font-family:'Roboto Condensed', sans-serif; font-weight:normal; font-size: 1.2em; }
	
	.proList li table { width: 96%; margin: 0 2%;  border-top: 1px dotted #dedede; }
	.proList li table th { width: 20%; padding: 5px 0; border-bottom: 1px dotted #dedede; font-size: 0.7rem;  }
	.proList li table td { width: 80%; padding: 5px 0 5px 10px; border-bottom: 1px dotted #dedede; font-size: 0.7rem; }
	
	.tbl01 { width: 100%; border-top: 1px dotted #dedede; }
	.tbl01 th { padding: 10px; border-bottom: 1px dotted #dedede; text-align: center; background: #f4f4f4; display: block; }
	.tbl01 td { padding: 10px; border-bottom: 1px solid #dedede; display: block; }
	
	.sohL { width: 90%; margin: 0 auto 20px;}
	.sOverHead table { width: 96%; margin: 0 2% 20px;  border-top: 1px dotted #dedede; }
	.sOverHead table th { width: 20%; padding: 5px 0; border-bottom: 1px dotted #dedede; font-size: 0.7rem;  }
	.sOverHead table td { width: 80%; padding: 5px 0 5px 10px; border-bottom: 1px dotted #dedede; font-size: 0.7rem; }
	.sohL .eyecatch img { width: 100%; height: 250px; object-fit: cover; }
	
	.sOverHead .sohR p { font-size: 0.7rem; }
	
	.proList li div.eyecatch img { width: 100%; height: 175px; object-fit: cover; }
	
	.eyecatch { margin: 0 0 20px; }
	.subnails { display: flex; justify-content: flex-start; flex-wrap: wrap; }	
	.subnails li { width: 15%; margin-right: 2%; margin-bottom: 10px; }
	.subnails li:nth-child(6n) { margin-right: 0px; }
	.subnails li img { width: 100%; height: 40px; object-fit: cover; }
}
@media screen and (min-width: 768px) {
	.proList { display: flex; justify-content: center; flex-wrap: wrap;}
	.proList li { width: 20%; margin:0 20px 40px;}
	.proList li div { margin-bottom: 20px; }
	.proList li h4 { font-family:'Roboto Condensed', sans-serif; font-weight:normal; margin:0 10px; font-size: 0.9rem; }
	.proList li h3 { margin-bottom: 0px; margin:0 10px;}
	.proList li h5 { font-size: 0.7rem; margin:0 10px 20px; }
	.proList li h5 span { font-family:'Roboto Condensed', sans-serif; font-weight:normal; font-size: 1.5em; }
	.proList li table { width: 100%; border-top: 1px dotted #dedede; }
	.proList li table th { width: 20%; padding: 5px 0; border-bottom: 1px dotted #dedede; font-size: 0.7rem; }
	.proList li table td { width: 80%; padding: 5px 0 5px 10px; border-bottom: 1px dotted #dedede; font-size: 0.7rem; }
	
	.tbl01 { width: 100%; margin-bottom: 20px; }
	.tbl01 th { padding: 20px; border-bottom: 3px solid #dedede; }
	.tbl01 td { padding: 20px; border-bottom: 3px solid #dedede; }
	
	.sOverHead { display: flex; justify-content:space-between; }
	.sohL { width: 48%; }
	.sohR { width: 48%; }
	
	.sOverHead table { width: 100%; border-top: 1px dotted #dedede; margin-bottom: 20px; }
	.sOverHead table th { width: 20%; padding: 5px 0; border-bottom: 1px dotted #dedede; font-size: 0.8rem; }
	.sOverHead table td { width: 80%; padding: 5px 0 5px 10px; border-bottom: 1px dotted #dedede; font-size: 0.8rem; }
	
	.sOverHead .sohR p { font-size: 0.8rem; }
	
	.eyecatch { margin: 0 0 20px; }
	.subnails { display: flex; justify-content: flex-start; flex-wrap: wrap; }
}
@media screen and (min-width: 768px) and (max-width: 960px)  {
	.sohL .eyecatch img { width: 100%; height: 360px; object-fit: cover; }
	.sohL { width: 40%; }
	.sohR { width: 56%; }
	.proList li div.eyecatch img { width: 100%; height: 210px; object-fit: cover; }
	
	.subnails li { width: 15%; margin-right: 2%; margin-bottom: 10px; }
	.subnails li:nth-child(6n) { margin-right: 0px; }
	.subnails li img { width: 100%; height: 65px; object-fit: cover; }
}
@media screen and (min-width: 961px) and (max-width: 1024px)  {
	.sohL .eyecatch img { width: 100%; height: 400px; object-fit: cover; }
	.proList li div.eyecatch img { width: 100%; height: 240px; object-fit: cover; }
	
	.subnails li { width: 15%; margin-right: 2%; margin-bottom: 10px; }
	.subnails li:nth-child(6n) { margin-right: 0px; }
	.subnails li img { width: 100%; height: 70px; object-fit: cover; }
}
@media screen and (min-width: 1025px) and (max-width: 1259px)  {
	.sohL .eyecatch img { width: 100%; height: 450px; object-fit: cover; }
	.proList li div img { width: 100%; height: 270px; object-fit: cover; }
	
	.subnails li { width: 15%; margin-right: 2%; margin-bottom: 10px; }
	.subnails li:nth-child(6n) { margin-right: 0px; }
	.subnails li img { width: 100%; height: 70px; object-fit: cover; }
}
@media screen and (min-width: 1260px) and (max-width: 1479px)  {
	.sohL .eyecatch img { width: 100%; height: 450px; object-fit: cover; }
	.proList li div.eyecatch img { width: 100%; height: 300px; object-fit: cover; }
	
	.subnails li { width: 15%; margin-right: 2%; margin-bottom: 10px; }
	.subnails li:nth-child(6n) { margin-right: 0px; }
	.subnails li img { width: 100%; height: 75px; object-fit: cover; }
}
@media screen and (min-width: 1480px) {
	.sohL .eyecatch  img { width: 100%; height: 450px; object-fit: cover; }
	.proList li div.eyecatch img { width: 100%; height: 360px; object-fit: cover; }
	.subnails li { width: 15%; margin-right: 2%; margin-bottom: 10px; }
	.subnails li:nth-child(6n) { margin-right: 0px; }
	.subnails li img { width: 100%; height: 75px; object-fit: cover; }
}

.lb-nav a.lb-prev { opacity: 1.0; }
.lb-nav a.lb-next { opacity: 1.0; }

/*-- footer fix bnr  -------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	#contact-fixed ul { position: fixed; z-index: 888; bottom: 0; width: 100%; display: flex; justify-content: center;}
	#contact-fixed ul li { width: 50%; }
}
/*-- pc
@media screen and (min-width: 768px) {
	#contact-fixed { position: fixed; z-index: 888; bottom: 0; left: 0; background: rgba(148,75,67,0.7); padding: 1%; width: 100%; }
	#contact-fixed ul { display: flex; justify-content: center;}
	#contact-fixed ul li { margin-right: 1%; }
	#contact-fixed ul li:last-child { margin-right: 0px;}
}
@media screen and (min-width: 768px) and (max-width: 960px)  {
	#contact-fixed .in { margin:0 1%; }
}
@media screen and (min-width: 961px) and (max-width: 1259px)  {
	#contact-fixed .in { margin:0 1%; }
}
@media screen and (min-width: 1260px) and (max-width: 1319px)  {
	#contact-fixed .in { margin:0 2%; }
}
@media screen and (min-width: 1320px) {
	#contact-fixed .in { width: 1260px; margin: 0 auto;}
}
-- */
/*-- footer ------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	footer { margin-top: 20px; }
	footer .in { color:#000; padding:4%; }
	footer .in .f_logo { text-align: center; font-size: 1.2rem; font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; font-weight:bold; width: 50px; margin:0 auto 5px; }
	footer .in .f_text { text-align: center; font-size: 0.8rem; }
}
@media screen and (min-width: 768px) {	
	footer { background:#fff; margin-top: 80px; }
	footer .in { color:#000; padding:30px 0; }
	footer .in .f_logo { text-align: center; font-size: 1.8rem; font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; font-weight:bold; width: 80px; margin:0 auto 10px; }
	footer .in .f_text { text-align: center; font-size: 0.8rem; }
}
@media screen and (min-width: 768px) and (max-width: 960px)  {
	footer .in { margin:0 2%; }
}
@media screen and (min-width: 961px) and (max-width: 1024px)  {
	footer .in { margin:0 2%; }
}
@media screen and (min-width: 1025px) and (max-width: 1319px)  {
	footer .in { margin:0 2%; }
}
@media screen and (min-width: 1320px) {
}
/*-- copyright ------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	#copyright { font-family:'Roboto Condensed', sans-serif; font-weight:bold; text-align:center; color:#000; font-size:12px; }
}
@media screen and (min-width: 768px) {
	#copyright { font-family:'Roboto Condensed', sans-serif; font-weight:bold;  text-align:center; color:#000; font-size:12px; }
}
/*-- pagetop ------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	#pagetop { width: 40px; height: 40px; position:fixed; right:5px; bottom:50px; opacity:0.8; z-index: 999;}
}
@media screen and (min-width: 768px) and (max-width: 1023px) {
	#pagetop { width: 50px; height: 50px; position:fixed; right:20px; bottom:20px; opacity:0.8; z-index: 999;}
}
@media screen and (min-width: 1024px) {
	#pagetop { width: 70px; height: 70px; position:fixed; right:20px; bottom:20px; opacity:0.8; z-index: 999; }
}

/*-- animation ------------------------------------------------------------*/
.fadeUps { opacity: 0; }
.fadeUps {
	animation-name: fadeUpAnime;/*アニメーションの定義名*/
	animation-duration:1s;/*アニメーション変化時間 ※デフォルト*/
	animation-fill-mode:forwards;/*アニメーションの開始と終了時の状態を指定*/
}

.fadeUp { opacity: 0; }
.fadeUp.add-show {
	animation-name: fadeUpAnime;/*アニメーションの定義名*/
	animation-duration:1s;/*アニメーション変化時間 ※デフォルト*/
	animation-fill-mode:forwards;/*アニメーションの開始と終了時の状態を指定*/
}

.proList li:nth-child(1) .fadeUp,.proList li:nth-child(2) .fadeUp,.proList li:nth-child(3) .fadeUp,.proList li:nth-child(1) .fadeUp {
	opacity: 0;
	animation-name: fadeUpAnime;/*アニメーションの定義名*/
	animation-duration:1s;/*アニメーション変化時間 ※デフォルト*/
	animation-fill-mode:forwards;/*アニメーションの開始と終了時の状態を指定*/	
}
/*アニメーションの開始から終了までを指定する*/
@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}

/*アニメーションを遅らせる*/
.delay-time01 { animation-delay: 0.1s; }
.delay-time02 { animation-delay: 0.2s; }
.delay-time03 { animation-delay: 0.3s; }
.delay-time04 { animation-delay: 0.4s; }
.delay-time05 { animation-delay: 0.5s; }
.delay-time06 { animation-delay: 0.6s; }
.delay-time07 { animation-delay: 0.7s; }
.delay-time08 { animation-delay: 0.8s; }
.delay-time09 { animation-delay: 0.9s; }
.delay-time10 { animation-delay: 1.0s; }
.delay-time20 { animation-delay: 2.0s; }

/*-- box LINK ------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	.box_link_btn a { color:#000; width:80%; height:30px; line-height:30px; border:#000 1px solid; border-radius: 15px; display:block; text-align:center; margin:0 10%; background:#fff; font-size: 13px;}
	.box_link_btn a:link    { color:#000; text-decoration: none; }
	.box_link_btn a:visited { color:#000; text-decoration: none; }
	.box_link_btn a:hover   { color:#fff; text-decoration: none; background:#000; }
	.box_link_btn a:active  { color:#000; text-decoration: none; } 
	
	.box_link_btn_sq a { color:#000; width:80%; height:30px; line-height:30px; border:#000 1px solid; display:block; text-align:center; margin:0 10%; background:#fff; font-size: 13px;}
	.box_link_btn_sq a:link    { color:#000; text-decoration: none; }
	.box_link_btn_sq a:visited { color:#000; text-decoration: none; }
	.box_link_btn_sq a:hover   { color:#fff;    text-decoration: none; background:#000; }
	.box_link_btn_sq a:active  { color:#000; text-decoration: none; }

	.box_link_btn_og a { color:#FF6600; width:80%; height:30px; line-height:30px; border:#FF6600 1px solid; border-radius: 15px; display:block; text-align:center; margin:0 10%; background:#fff; font-size: 13px;}
	.box_link_btn_og a:link    { color:#FF6600; text-decoration: none; }
	.box_link_btn_og a:visited { color:#FF6600; text-decoration: none; }
	.box_link_btn_og a:hover   { color:#fff; text-decoration: none; background:#FF6600; }
	.box_link_btn_og a:active  { color:#FF6600; text-decoration: none; } 
}
@media screen and (min-width: 768px) {
	.box_link_btn a { color:#000; width:40%; height:40px; line-height:40px; border:#000 1px solid; border-radius: 20px; display:block; text-align:center; margin:0 30%; background:#fff; font-size: 15px;}
	.box_link_btn a:link    { color:#000; text-decoration: none; }
	.box_link_btn a:visited { color:#000; text-decoration: none; }
	.box_link_btn a:hover   { color:#fff; text-decoration: none; background:#000; }
	.box_link_btn a:active  { color:#000; text-decoration: none; }
	
	.sOverHead .sohR a { color:#000; width:80%; height:40px; line-height:40px; border:#000 1px solid; border-radius: 20px; display:block; text-align:center; margin:0 10%; background:#fff; font-size: 0.8rem;}
	.sOverHead .sohR a:link    { color:#000; text-decoration: none; }
	.sOverHead .sohR a:visited { color:#000; text-decoration: none; }
	.sOverHead .sohR a:hover   { color:#fff; text-decoration: none; background:#000; }
	.sOverHead .sohR a:active  { color:#000; text-decoration: none; }
	
	.box_link_btn_sq a { color:#000; width:40%; height:40px; line-height:40px; border:#000 1px solid; display:block; text-align:center; margin:0 30%; background:#fff; font-size: 15px;}
	.box_link_btn_sq a:link    { color:#000; text-decoration: none; }
	.box_link_btn_sq a:visited { color:#000; text-decoration: none; }
	.box_link_btn_sq a:hover   { color:#fff; text-decoration: none; background:#000; }
	.box_link_btn_sq a:active  { color:#000; text-decoration: none; } 
	
	.box_link_btn_og a { color:#FF6600; width:40%; height:40px; line-height:40px; border:#FF6600 1px solid; border-radius: 20px; display:block; text-align:center; margin:0 30%; background:#fff; font-size: 15px;}
	.box_link_btn_og a:link    { color:#FF6600; text-decoration: none; }
	.box_link_btn_og a:visited { color:#FF6600; text-decoration: none; }
	.box_link_btn_og a:hover   { color:#fff; text-decoration: none; background:#FF6600; }
	.box_link_btn_og a:active  { color:#FF6600; text-decoration: none; }
}

@media screen and (min-width: 768px) {
	.flatbtn a {
		width: 200px;
		height: 35px;
		line-height: 35px;
		color: #fff;
		border: #ffa23e 1px solid;
		display: block;
		text-align: center;
		background: #ffa23e;
		border-bottom: #e68822 3px solid;
		border-radius: 4px;
	}
	.flatbtn a:hover {
		color:#ffa23e;
		background:#fff;
		text-decoration:none;
	}
}
@media screen and (min-width: 768px) and (max-width: 960px) {
	.flatbtn a {
		width: 160px;
		height: 30px;
		line-height: 30px;
	}
}

/*-- sp tbl overscroll ------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	.scroll { overflow: auto; white-space: nowrap;}
	.scroll::-webkit-scrollbar { height: 10px; }
	.scroll::-webkit-scrollbar-track { margin: 0 2px; background: #ccc; border-radius: 5px; }
	.scroll::-webkit-scrollbar-thumb { border-radius: 5px; background: #666; }
}

/*-- list indent ------------------------------------------------------------*/
ol.indent { list-style-position: inside;}
ol.indent li { padding-left: 1em; text-indent: -1em;}
ul.indent { list-style-position: inside;}
ul.indent li { padding-left: 1em; text-indent: -1em;}

/*-- ol number list ------------------------------------------------------------*/
ol { counter-reset:number; list-style:none; margin:0; padding:0;}
ol li{ margin-bottom:10px; text-indent:-1.0em; padding-left:1.0em; border-bottom:#DEDEDE 1px dotted; padding-bottom:10px; }
ol li:before{ counter-increment: number; content: counter(number); margin-right:0.5em; color:#000; font-family:'Roboto Condensed', sans-serif; font-weight:bold;　font-size:1.1em; }

/*-- arrow list ------------------------------------------------------------*/
.arrow_list_w { margin-bottom:20px; }
.arrow_list_w li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; }
.arrow_list_w li:before { content:"\f101"; font-family:FontAwesome; margin-right:10px; color:#67A64F; }

.arrow_list_s { margin-bottom:20px; }
.arrow_list_s li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; }
.arrow_list_s li:before { content:"\f105"; font-family:FontAwesome; margin-right:10px; color:#67A64F; }

.arrow_list_t { margin-bottom:20px; }
.arrow_list_t li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; border-bottom:1px dotted #DEDEDE; }
.arrow_list_t li:before { content:"\f0da"; font-family:FontAwesome; margin-right:10px; color:#67A64F; }

.circle_list { margin:0 2% 0px; }
.circle_list li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list li:before { content:"\f10c"; font-family:FontAwesome; margin-right:10px; color:#D91061; font-weight:bold; font-size:1.0em; }

.circle_list02 { margin:0 2% 0px; }
.circle_list02 li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list02 li:before { content:"\f10c"; font-family:FontAwesome; margin-right:10px; color:#3da678; }

.circle_list03 { margin:0 2% 0px; }
.circle_list03 li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list03 li:before { content:"\f10c"; font-family:FontAwesome; margin-right:10px; color:#cd9054; }

.circle_list04 { margin:0 2% 0px; }
.circle_list04 li { text-indent:-1.0em; padding:0 0 0 1.0em !important; border:none !important; margin-bottom:5px !important; font-size:0.9em; }
.circle_list04 li:before { content:"\f10c"; font-family:FontAwesome; margin-right:10px; color:#64a8dd; }

/*-- スマホメニュー開閉背景の色 ------------------------------------------------------------*/
.mm-menu { background:#54A583 !important; color:rgba(0, 0, 0, 0.7)  !important; }

/*--wordpress投稿　段落 ------------------------------------------------------------*/
@media screen and (max-width: 767px) {
	.single_section h1 { font-size: 1.3rem; font-weight: bold; color: #F08200;  padding-bottom: 10px; border-bottom: 1px solid #f08200; margin-bottom: 10px; }
	.single_section h2 { font-size: 1.2rem; margin-bottom: 15px; background: #f4f4f4; padding: 10px; }
	.single_section h3 { font-size: 1.2rem; margin-bottom: 10px;  color:#f08200; font-weight: bold; }
	.single_section h4 { font-size: 1.2rem; font-weight: bold; padding-bottom: 10px; border-bottom: 1px solid #000; margin-bottom: 10px; }
	.single_section h5 { font-size: 1.1rem; font-weight: bold; }
	.single_section h6 { font-size: 1.0rem; font-weight: bold; }
}
@media screen and (min-width: 768px) {
	.single_section h1 { font-weight: bold; margin-bottom: 20px; padding-bottom: 10px; border-bottom: 1px solid #f08200; color: #F08200; }
	.single_section h2 { background: #f4f4f4; padding: 5px 10px; margin-bottom: 20px; }
	.single_section h3 { color:#f08200; font-weight: bold; }
	.single_section h4 { font-weight: bold; padding-bottom: 10px; border-bottom: 1px solid #000; margin-bottom: 10px; }
	.single_section h5 { font-weight: bold; }
	.single_section h6 { font-weight: bold; }
}
@media screen and (min-width: 768px) and (max-width: 960px) {
	.single_section h1 { font-size: 1.5rem; }
	.single_section h2 { font-size: 1.4rem; }
	.single_section h3 { font-size: 1.3rem; }
	.single_section h4 { font-size: 1.2rem; }
	.single_section h5 { font-size: 1.2rem; }
	.single_section h6 { font-size: 1.1rem; }
}
@media screen and (min-width: 961px) and (max-width: 1024px) {
	.single_section h1 { font-size: 1.6rem; }
	.single_section h2 { font-size: 1.3rem; }
	.single_section h3 { font-size: 1.2rem; }
	.single_section h4 { font-size: 1.2rem; }
	.single_section h5 { font-size: 1.2rem; }
	.single_section h6 { font-size: 1.1rem; }
}
@media screen and (min-width: 1025px) and (max-width: 1259px) {
	.single_section h1 { font-size: 1.7rem; }
	.single_section h2 { font-size: 1.4rem; }
	.single_section h3 { font-size: 1.3rem; }
	.single_section h4 { font-size: 1.2rem; }
	.single_section h5 { font-size: 1.2rem; }
	.single_section h6 { font-size: 1.1rem; }
}
@media screen and (min-width: 1260px) and (max-width: 1319px) {
	.single_section h1 { font-size: 1.8rem; }
	.single_section h2 { font-size: 1.5rem; }
	.single_section h3 { font-size: 1.4rem; }
	.single_section h4 { font-size: 1.3rem; }
	.single_section h6 { font-size: 1.2rem; }
}
@media screen and (min-width: 1320px) {
	.single_section h1 { font-size: 1.9rem; }
	.single_section h2 { font-size: 1.6rem; }
	.single_section h3 { font-size: 1.5rem; }
	.single_section h4 { font-size: 1.3rem; }
	.single_section h5 { font-size: 1.3rem; }
	.single_section h6 { font-size: 1.2rem; }
}


/*--wordpress投稿　AUTO SITEMAP ------------------------------------------------------------*/
#sitemap_list { margin-bottom:20px; }
#sitemap_list li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; border-bottom:#DEDEDE 1px dotted; }
#sitemap_list li:before { content:"\f0da"; font-family:FontAwesome; margin-right:10px; color:#d91061; }

/*-- wordpress 画像 ------------------------------------------------------------*/
.aligncenter { display: block; margin: 0 auto;}
.alignright { float: right; }
.alignleft { float: left; }

/*-- wordpress ページャーカラー ------------------------------------------------------------*/
/*-- wordpress ページャーカラー ------------------------------------------------------------*/
#pager { width: 90%; margin: 40px 5%; overflow: hidden; display: flex; justify-content: center; }
#pager:before, #pager:after { content: ''; display: block; overflow: hidden; }
#pager a {
	-webkit-transition: all 0.6s ease;
	-moz-transition: all 0.6s ease;
	-ms-transition: all 0.6s ease;
	-o-transition: all 0.6s ease;
	transition: all 0.6s ease;
}
#pager a:hover { background: #999;}
#pager .pages, #pager .current, #pager .extend, #pager a { float: left; display: block; text-decoration: none; line-height: 20px; color: #333; background: #dedede; }
#pager a { color: #333; }
#pager .pages, #pager .current { background: #333; }
#pager .pages a, #pager .current { color: #fff; }
#pager .pages { display: none; }
@media screen and (max-width: 1024px) {
	#pager .pages, #pager .current, #pager .extend, #pager a { margin: 0 0 0 5px; padding: 4px 10px; }
}
@media screen and (min-width: 1025px) {
	#pager .pages, #pager .current, #pager .extend, #pager a { margin: 0 0 0 3px; padding: 6px 12px; }
}

/*-- animation ------------------------------------------------------------*/
/* 点滅 */
.flash1{ animation: Flash1 1.0s infinite; }
@keyframes Flash1{ 50%{ opacity: 0.5; }}
/* 揺れる */
.fluffy { width: 100%; height: auto; animation: fluffy1 3s ease infinite; }
@keyframes fluffy1 {
  0% { transform:translateY(0) }
  5% { transform:translateY(0) }
  10% { transform:translateY(0) }
  20% { transform:translateY(-15px) }
  25% { transform:translateY(0) }
  30% { transform:translateY(-15px) }
  50% { transform:translateY(0) }
  100% { transform:translateY(0) }
}
	
/*-- Adjustment ------------------------------------------------------------*/
.mt5  { margin-top:  5px !important; }
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt20 { margin-top: 20px !important; }
.mt25 { margin-top: 25px !important; }
.mt30 { margin-top: 30px !important; }
.mt40 { margin-top: 40px !important; }

.mr5  { margin-right:  5px !important; }
.mr10 { margin-right: 10px !important; }
.mr15 { margin-right: 15px !important; }
.mr20 { margin-right: 20px !important; }
.mr25 { margin-right: 25px !important; }
.mr30 { margin-right: 30px !important; }
.mr40 { margin-right: 40px !important; }

.mb5  { margin-bottom:  5px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 { margin-bottom: 20px !important; }
.mb25 { margin-bottom: 25px !important; }
.mb30 { margin-bottom: 30px !important; }
.mb40 { margin-bottom: 40px !important; }

.ml5  { margin-left:  5px !important; }
.ml10 { margin-left: 10px !important; }
.ml15 { margin-left: 15px !important; }
.ml20 { margin-left: 20px !important; }
.ml25 { margin-left: 25px !important; }
.ml30 { margin-left: 30px !important; }
.ml40 { margin-left: 40px !important; }

.pg5  { padding:  5px !important; }
.pg10 { padding: 10px !important; }
.pg15 { padding: 15px !important; }
.pg20 { padding: 20px !important; }
.pg25 { padding: 25px !important; }
.pg30 { padding: 30px !important; }
.pg35 { padding: 35px !important; }
.pg40 { padding: 40px !important; }

.mg0  { margin: 0  !important; }
.pg0  { padding: 0 !important; }

.ofh  { overflow: hidden; }
.fltR { float: right; }
.fltL { float: left; }
.clr  { clear: both; }

.posRe { position: relative; }
.posAb { position: absolute; }

.alJ { text-align: justify; }
.alC { text-align: center; }
.alR { text-align: right; }
.alL { text-align: left; }

.xlarge { font-size: 1.2em; }
.large  { font-size: 1.1em; }

.xsmall { font-size: 0.8em; }
.small  { font-size: 0.9em; }

.bold { font-weight: bold; }
.red  { color: #C00; }
.blk {color:#000;}

.under {text-decoration:underline; border-color:#666;}

.border-dotted { display: block; clear: both; height: 1px; border: none; border-bottom: dotted 1px #ddd !important; }
.border-solid  { display: block; clear: both; height: 1px; border: none; border-bottom: solid 1px #ddd  !important; }

.trans-ease { -webkit-transition: all 0.6s ease; -moz-transition: all 0.6s ease; -ms-transition: all 0.6s ease; -o-transition: all 0.6s ease; transition: all 0.6s ease; }

.link-hover { -webkit-transition: all 0.6s ease; -moz-transition: all 0.6s ease; -ms-transition: all 0.6s ease; -o-transition: all 0.6s ease; transition: all 0.6s ease; }
.link-hover:hover { opacity: 0.7; filter: alpha(opacity=70); }

.roboto { font-family:'Roboto Condensed', sans-serif; }
.roboto-b { font-family:'Roboto Condensed', sans-serif; font-weight:bold; }
.g_font { font-family: "Rounded Mplus 1c"; font-weight:300; }
.gothic { font-family: 'Noto Sans Japanese','Hiragino Kaku Gothic ProN','メイリオ', serif; }
.min { font-family: 'Noto Serif JP','游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro', serif; }
.youtube { position: relative; width: 100%; padding-top: 56.25%; }
.youtube iframe { position: absolute; top: 0; right: 0; width: 100% !important; height: 100% !important;}

/*-- clearfix ------------------------------------------------------------*/
.cf:after { visibility: hidden; display: block; font-size: 0; content: " "; clear: both; height: 0; }
/* *html .cf { zoom: 1; } */
*:first-child+html .cf { zoom: 1; } /* IE7 */

/*-- loading ------------------------------------------------------------*/
#loading{ position: absolute; left: 45%; top: 40%; }
#loader-bg { position: fixed; width: 100%; height: 100%; top: 0px; left: 0px; background: #fff; z-index: 8888; }
body{ background-color: #fff; }
@media screen and (max-width: 767px) { 
	#loading{ position: absolute; left: 45%; top: 40%; }
	#loading img { width:40px; }
}
@media screen and (min-width: 768px) and (max-width: 960px) {
	#loading{ position: absolute; left: 45%; top: 40%;}
	#loading img { width:50px; }
}
@media screen and (min-width: 961px) {
	#loading{ position: absolute; left: 48%; top: 40%;}
	#loading img { width:60px; }
}
.spinner { margin: 100px auto; width: 50px; height: 40px; text-align: center; font-size: 10px;
}
.spinner > div {
  background-color: #975048; /* 色を変える */
  height: 100%; width: 6px; display: inline-block; z-index: 9999
  -webkit-animation: sk-stretchdelay 1.2s infinite ease-in-out;
  animation: sk-stretchdelay 1.2s infinite ease-in-out;
}
.spinner .rect2 {
  -webkit-animation-delay: -1.1s;
  animation-delay: -1.1s;
}
.spinner .rect3 {
  -webkit-animation-delay: -1.0s;
  animation-delay: -1.0s;
}
.spinner .rect4 {
  -webkit-animation-delay: -0.9s;
  animation-delay: -0.9s;
}
.spinner .rect5 {
  -webkit-animation-delay: -0.8s;
  animation-delay: -0.8s;
}

@-webkit-keyframes sk-stretchdelay {
  0%, 40%, 100% { -webkit-transform: scaleY(0.4) }  
  20% { -webkit-transform: scaleY(1.0) }
}
@keyframes sk-stretchdelay {
  0%, 40%, 100% { 
    transform: scaleY(0.4);
    -webkit-transform: scaleY(0.4);
  }  20% { 
    transform: scaleY(1.0);
    -webkit-transform: scaleY(1.0);
  }
}


