@charset "UTF-8";

:root {
	--base-color:#7c1109;
	--sub-color:#9e1b0d;
	--opa-color:#f7f6f5;
	--gry-color:#2d2d2d;
	--cv-color:#9e1b0d;
}

/*-- Anchor -------------------------------------------------------------*/
a         { resize: none; }
a:link    { color:#333333; text-decoration: underline; }
a:visited { color:#333333; text-decoration: underline; }
a:hover   { color:var(--base-color); text-decoration: underline; }
a:active  { color:#333333; text-decoration: underline; }

.u_no_link a         { resize: none; }
.u_no_link a:link    { color:#333333; text-decoration: none; }
.u_no_link a:visited { color:#333333; text-decoration: none; }
.u_no_link a:hover   { color:var(--base-color); text-decoration: underline; }
.u_no_link a:active  { color:#333333; text-decoration: none; }

footer a         { resize: none; }
footer a:link    { color:#fff; text-decoration: none; }
footer a:visited { color:#fff; text-decoration: none; }
footer a:hover   { color:#fff; text-decoration: underline; }
footer a:active  { color:#fff; 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: 599px) {
	.pc { display: none; }
}
@media screen and (min-width: 600px) {
	.sp { display: none; }
	.alC_pc { text-align: center; }
}
@media screen and (max-width: 767px) {
	.pc_mini { display: none; }
}
@media screen and (min-width: 768px) {
	.sp_mini { display: none; }
}
@media screen and (max-width: 1089px) {
	.pc_tab { display: none; }
}
@media screen and (min-width: 1090px) {
	.sp_tab { display: none; }
}
@media screen and (max-width: 899px) {
	.pc_tab_mini { display: none; }
}
@media screen and (min-width: 900px) {
	.sp_tab_mini { display: none; }
}

@media screen and (max-width: 1099px) {
	.pc_only { display: none; }
	.sp_only { position: relative; width: 100%; height: 100vh; }
	.sp_only p { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); font-size: 0.9rem; margin:0 auto 0px; text-align: center; width: 90%; }
}
@media screen and (min-width: 1100px) {
	.sp_only { display: none; }
}

/*-- imaga -------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.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%;}
	
	.img_y_R02 { margin:0 25% 4%; width:50%;}
}
@media screen and (min-width: 600px) {
	.img_t_R { float:right; margin:0 0 40px 40px; width:20%; position: relative; z-index: 1; }
	.img_t_L { float:left; margin:0 40px 40px 0; width:30%; position: relative; z-index: 1;}
	.img_y_R { float:right; margin:0 0 40px 40px; width:30%; position: relative; z-index: 1;}
	.img_y_L { float:left; margin:0 40px 40px 0; width:30%; position: relative; z-index: 1;}
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.img_t_R { float:right; margin:0 0 40px 40px; width:40%;}
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	.img_t_R { float:right; margin:0 0 40px 40px; width:35%;}
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	.img_t_R { float:right; margin:0 0 40px 40px; width:30%;}
}

/*-- header -------------------------------------------------------------*/
@media screen and (max-width: 1089px) {
	header .in { margin: 0 0 0 2%; }
	header .in .h_flex { display: flex; justify-content: space-between; align-items: center; }	
	header .in .h_flex .h_flex_L { width: 70%; }
	header .in .h_flex .h_flex_L .h_logo a { display: flex; justify-content: flex-start; align-items: center; margin: 10px 0; }
	header .in .h_flex .h_flex_L .h_logo a img { max-width: 200px; margin-right: 20px; }
	header .in .h_flex .h_flex_L .h_logo h1 { color: #333; font-weight: 500; }
	header .in .h_flex .h_flex_L .h_logo h1 .oswald { font-size: 1.0em;}
	header .in .h_flex .h_flex_L .h_logo a { resize: none; }
	header .in .h_flex .h_flex_L .h_logo a:link    { color:var(--gry-color); text-decoration: none; }
	header .in .h_flex .h_flex_L .h_logo a:visited { color:var(--gry-color); text-decoration: none; }
	header .in .h_flex .h_flex_L .h_logo a:hover   { color:var(--base-color); text-decoration: none; }
	header .in .h_flex .h_flex_L .h_logo a:active  { color:var(--gry-color); text-decoration: none; }
	
	header .in .h_flex .h_flex_R .h_menu { position: fixed; top: 1.5%; right: 2%; z-index: 9999; }
}
@media screen and (max-width: 599px) {
	header .in .h_flex .h_flex_L .h_logo a { display: flex; justify-content: flex-start; align-items: flex-start; flex-direction: column; margin: 0; }
	header .in .h_flex .h_flex_L .h_logo a h1 { order: 1; font-size: 0.8em; }
	header .in .h_flex .h_flex_L .h_logo a img { order: 2; width: 180px; }
}
@media screen and (min-width: 1090px) {
	header .in { margin: 0 0 0 1%; }
	header .in .h_flex { display: flex; justify-content: space-between; align-items: center; }	
	
	header .in .h_flex .h_flex_L { width: 30%; }
	header .in .h_flex .h_flex_L .h_logo a { display: flex; justify-content: flex-start; align-items: center; margin: 10px 0; }
	header .in .h_flex .h_flex_L .h_logo a img { max-width: 200px; margin-right: 20px; }
	header .in .h_flex .h_flex_L .h_logo h1 { color: #333; font-weight: 500; }
	header .in .h_flex .h_flex_L .h_logo h1 .oswald { font-size: 1.05em;}
	header .in .h_flex .h_flex_L .h_logo a { resize: none; }
	header .in .h_flex .h_flex_L .h_logo a:link    { color:var(--gry-color); text-decoration: none; }
	header .in .h_flex .h_flex_L .h_logo a:visited { color:var(--gry-color); text-decoration: none; }
	header .in .h_flex .h_flex_L .h_logo a:hover   { color:var(--base-color); text-decoration: none; }
	header .in .h_flex .h_flex_L .h_logo a:active  { color:var(--gry-color); text-decoration: none; }
		
	.h_flex_R { width:66%; margin-right: 1%; }
	.h_flex_R .h_nav { display: flex; justify-content: flex-end; align-items: center; }
	.h_flex_R .h_nav li { margin-left: 4%; text-align: center; line-height: 1.4; font-weight: bold; font-size: 0.9em; }
	
	.h_flex_R .h_nav li a         { resize: none; display: block; }
	.h_flex_R .h_nav li a:link    { color:var(--gry-color); text-decoration: none; }
	.h_flex_R .h_nav li a:visited { color:var(--gry-color); text-decoration: none; }
	.h_flex_R .h_nav li a:hover   { color:var(--base-color); text-decoration: none; }
	.h_flex_R .h_nav li a:active  { color:var(--gry-color); text-decoration: none; }
	
	.h_flex_R .h_nav li.h_contact_btn_fix { background:var(--cv-color); width: 150px; height: 35px; line-height: 35px; }
	.h_flex_R .h_nav li.h_contact_btn_fix a { color: #fff; font-size:0.8em; }
	.h_flex_R .h_nav li.h_contact_btn_fix a:link    { color:#fff; text-decoration: none; }
	.h_flex_R .h_nav li.h_contact_btn_fix a:visited { color:#fff; text-decoration: none; }
	.h_flex_R .h_nav li.h_contact_btn_fix a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
	.h_flex_R .h_nav li.h_contact_btn_fix a:active  { color:#fff; text-decoration: none; }
	.h_flex_R .h_nav li.h_contact_btn_fix .fa-envelope { font-size: 1.4em; margin-right: 10px; }
	
	.h_flex_R .h_nav li.navbar { position: relative; }
	.h_flex_R .h_nav li.navbar a:hover { text-decoration: none; }
	.h_flex_R .h_nav li.navbar a::after { position: absolute; bottom: -2px; left: 5%; content: ''; width: 90%; height: 2px; background: var(--base-color); transform: scale(0, 1); transform-origin: left top; transition: transform .3s; z-index: 1; }
	.h_flex_R .h_nav li.navbar a:hover::after { transform: scale(1, 1); }
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	header .in .h_flex .h_flex_L { width: 40%; }
	header .in .h_flex .h_flex_R { width: 56%; }
	
	header .in .h_flex .h_flex_L .h_logo a img { max-width: 180px; }
	
	.h_flex_R .h_nav li { margin-left: 3.0%; font-size: 0.9em; }
}
@media screen and (min-width: 1190px) and (max-width: 1289px) {
	header .in .h_flex .h_flex_L { width: 40%; }
	header .in .h_flex .h_flex_R { width: 56%; }
	
	header .in .h_flex .h_flex_L .h_logo a img { max-width: 180px; }
	
	.h_flex_R .h_nav li { margin-left: 3.0%; font-size: 0.9em; }
}
@media screen and (min-width: 1290px) and (max-width: 1389px) {
	header .in .h_flex .h_flex_L { width: 40%; }
	header .in .h_flex .h_flex_R { width: 56%; }
	
	header .in .h_flex .h_flex_L .h_logo a img { max-width: 190px; }
	
	.h_flex_R .h_nav li { margin-left: 3.5%; }
}
@media screen and (min-width: 1390px) and (max-width: 1489px) {
	header .in .h_flex .h_flex_L { width: 40%; }
	header .in .h_flex .h_flex_R { width: 56%; }
	
	header .in .h_flex .h_flex_L .h_logo a img { max-width: 190px; }
}

/*-- is-fix  -------------------------------------------------------------*/
header.is-fix { position: fixed; left: 0; top: 0; width: 100%; z-index: 999; background: #fff; }
@media screen and (max-width: 889px) {
	header.is-fix { box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.25); }
	header.is-fix .in-head-flex { width: 100%; margin: 0 auto; padding: 0.5% 1%; }
	header.is-fix .in-head-flex .hL .logo-mark { width: 120px; }
}
@media screen and (min-width:600px) and (max-width: 1089px) {
}
@media screen and (min-width: 900px) {
	header.is-fix { box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.25); padding: 0px 0; }
	header.is-fix .in { margin: 0 0 0 0.5%; }
	header.is-fix .in .h_flex .h_flex_L .h_logo h1 { font-size: 0.9em; }
	header.is-fix .in .h_flex .h_flex_L .h_logo a img { max-width: 150px; }
	
	header.is-fix .in .h_flex .h_nav li.navbar { font-size: 0.8em; }
	header.is-fix .in .h_flex .h_nav li.navbar a         { resize: none; display: block; }
	header.is-fix .in .h_flex .h_nav li.navbar a:link    { color:#333; text-decoration: none; }
	header.is-fix .in .h_flex .h_nav li.navbar a:visited { color:#333; text-decoration: none; }
	header.is-fix .in .h_flex .h_nav li.navbar a:hover   { color:var(--base-color); text-decoration: none; }
	header.is-fix .in .h_flex .h_nav li.navbar a:active  { color:#333; text-decoration: none; }	
	
	header.is-fix .h_flex_R {margin-right: 0%; }
	header.is-fix .h_flex_R .h_nav li.h_contact_btn_fix { width: 150px; height: 35px; line-height: 35px; }
	header.is-fix .h_flex_R .h_nav li.h_contact_btn_fix a { font-size:0.7em; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
}
/*-- SP menu-trgger -------------------------------------------------------------*/
@media screen and (max-width: 1089px) {
	.menu-trigger,.menu-trigger span { display: inline-block; transition: all .4s; box-sizing: border-box; }
	.menu-trigger { width: 45px; height: 20px; display: flex; justify-content: space-between; align-items:flex-start; flex-direction: column; }
	.menu-trigger:hover{ cursor:pointer; }
	.menu-trigger span { left: 4.2px; width: 100%; height: 1px; background-color: #000; border-radius: 2px; }
	.menu-trigger span:nth-of-type(1) { position: relative; left: 0px; top: 2px;}
	.menu-trigger span:nth-of-type(2) { width: 75%; }
	.menu-trigger span:nth-of-type(3) { }
	
	.h_menu .active span { background-color: #333 !important; } /* 色を変える */
	.h_menu .active span:nth-of-type(3) { bottom: 15px; }
	.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);
	}
	header nav#overlay{ display: none; width: 80%; margin: 0 0 0 10%; padding: 4%; height: calc(100% - 0px); text-align: center; position: fixed; top: 0px; right: 0px; z-index: 999; background:var(--opa-color); box-sizing: border-box; box-shadow: -4px 0px 16px -6px rgba(0,0,0,0.6); padding-top: 15%;}
	header nav#overlay .in { overflow: auto; height: 100%; -webkit-overflow-scrolling: touch; }
	header nav#overlay ul { border-top: 1px dotted #fff; padding-top: 10px; }
	header nav#overlay ul li { font-size: 0.9rem; margin-bottom: 10px; padding-bottom: 10px; border-bottom: 1px dotted #ccc; text-align: left; }
	header nav#overlay ul li.subMenu { padding-left: 1em; }
	header nav#overlay ul li a         { resize: none; display: block; }
	header nav#overlay ul li a:link    { color:#333; text-decoration: none; }
	header nav#overlay ul li a:visited { color:#333; text-decoration: none; }
	header nav#overlay ul li a:hover   { color:#333; text-decoration: none; opacity: 0.7; }
	header nav#overlay ul li a:active  { color:#333; text-decoration: none; }
	header nav#overlay ul li a:before { content: "├"; margin-right: 10px; color: #ccc; }
}
@media screen and (max-width: 599px) {
	.menu-trigger span:nth-of-type(1) { position: relative; left: 0px; top: -1px;}
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	header nav#overlay{ display: none; width: 50%; }
	.menu-trigger { margin-right: 4%; }
	.menu-trigger span:nth-of-type(1) { position: relative; left: 0px; top: 0px;}
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	header nav#overlay{ display: none; width: 50%; }
	.menu-trigger { margin-right: 4%; }
	.menu-trigger span:nth-of-type(1) { position: relative; left: 0px; top: 2px;}
}
@media screen and (min-width: 1090px) {
	header nav#overlay { display: none; }
}
/*-- コンテンツ -------------------------------------------------------------*/
@media screen and (max-width: 899px) {
}
@media screen and (min-width: 900px) {
}
@media screen and (min-width: 900px) and (max-width: 1089px)  {
}
@media screen and (min-width: 1090px) and (max-width: 1189px)  {
}
@media screen and (min-width: 1190px) and (max-width: 1289px)  {
}
@media screen and (min-width: 1290px) and (max-width: 1389px)  {
}
@media screen and (min-width: 1390px) and (max-width: 1489px)  {
}
@media screen and (min-width: 1490px) {
}

/*-- footer fix bnr  -------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	#contact-fixed { position: fixed; z-index: 888; bottom: 1%; left: 2%; right: 0%; margin: 0 auto; width: 100%; display: flex; justify-content: flex-start; }
	#contact-fixed p { margin-bottom: 0px; }
	.f_cv { display: flex; justify-content: flex-start; align-items: center; width: 100%; }
	.f_cv_tel { background:var(--base-color); width: 18%; height: 60px; border-radius: 4px; text-align: center; color: #fff; font-size: 0.7rem; display: flex; flex-direction: column; align-items: center; justify-content: center; margin-right: 1%;  }
	.f_cv_tel .fa-phone { font-size: 1.5rem; margin-bottom: 5px; }
	
	.f_cv_form { background:var(--cv-color); width: 60%; height: 60px; border-radius: 4px; text-align: center; color: #fff; font-size: 1.0rem; display: flex; align-items: center; justify-content: center; margin-right: 4%;  }
	.f_cv_form .fa-envelope { margin-right: 10px; }
	
	#contact-fixed .pagetop { width: 40px; height: 40px; line-height: 40px; opacity:0.8; z-index: 999; text-align: center; margin-bottom: 0px; border-radius: 50%; background:#dedede; }
	.f_cv_form a         { resize: none; }
	.f_cv_form a:link    { color:#fff; text-decoration: none; }
	.f_cv_form a:visited { color:#fff; text-decoration: none; }
	.f_cv_form a:hover   { color:#fff; text-decoration: none; }
	.f_cv_form a:active  { color:#fff; text-decoration: none; }
}
@media screen and (min-width: 600px) {
	#contact-fixed { display:none; }
}

/*-- #contact-section -------------------------------------------------------------*/
#contact-section { background: var(--opa-color);}
@media screen and (max-width: 599px) {
	#contact-section { padding:6%; position: relative; }
	#contact-section .ovry { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: #fff; opacity: 0.6; }
	#contact-section .in { padding: 4%; background: #fff; border-radius: 6px; position: relative; z-index: 1; }
	#contact-section p {  }
	.contact-list { }
	.contact-list li { width: 90%; margin:0 5% 20px;}
	.contact-list li:last-child { margin-right: 0px; }
	.contact-list li:nth-child(1) p { margin-bottom: 0; font-size: 0.7rem; }
	.contact-list li:nth-child(1) p.roboto { font-size: 2.2rem;line-height: 1.2; }
		.contact-list li:nth-child(1) p.roboto a         { resize: none; }
		.contact-list li:nth-child(1) p.roboto a:link    { color:#000; text-decoration: none; }
		.contact-list li:nth-child(1) p.roboto a:visited { color:#000; text-decoration: none; }
		.contact-list li:nth-child(1) p.roboto a:hover   { color:#000; text-decoration: none; }
		.contact-list li:nth-child(1) p.roboto a:active  { color:#000; text-decoration: none; }
	.contact-list li:nth-child(1) p.roboto a:before { content: "\f095"; font-family: "Font AweSome 5 Free"; font-weight: 900; margin-right: 10px; transform: rotate(-270deg); display: inline-block;} 
	.contact-list li:nth-child(1) p.xsmall { font-size: 0.8rem; }
	
	.contact-list li:nth-child(2) { background: var(--cv-color); border: var(--cv-color) 1px solid; height: 50px; line-height: 50px; color: #fff; text-align: center; font-size: 1.0rem; border-radius: 6px; }
	.contact-list li:nth-child(2):hover { line-height: 47px; }
		.contact-list li:nth-child(2) a         { resize: none; display: block; }
		.contact-list li:nth-child(2) a:link    { color:#fff; text-decoration: none; }
		.contact-list li:nth-child(2) a:visited { color:#fff; text-decoration: none; }
		.contact-list li:nth-child(2) a:hover   { color:var(--cv-color); text-decoration: none; background:#fff; border-radius: 6px; }
		.contact-list li:nth-child(2) a:active  { color:var(--cv-color); text-decoration: none; }
	.contact-list li:nth-child(2) a:before { content: "\f0e0"; font-family: "Font AweSome 5 Free"; font-weight: 900; margin-right: 10px;} 
	.contact-list li:nth-child(2):hover a:before { content: "\f2b6"; font-family: "Font AweSome 5 Free"; font-weight: 900; margin-right: 10px;}  
}
@media screen and (min-width: 600px) {	
	#contact-section { padding: 5vh 4%; position: relative; }
	#contact-section .ovry { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: var(--base-color); opacity: 0.8; }
	#contact-section .in { max-width: 1000px; margin: 0 auto; width: 100%; padding: 20px 40px; background: #fff; border-radius: 6px; position: relative; z-index: 1;}
	.contact-list { display: flex; justify-content: center; align-items: center; }
	.contact-list li { width: 36%; margin-right: 3.5%;}
	.contact-list li:last-child { margin-right: 0px; }
	.contact-list li:nth-child(1) p { margin-bottom: 0; color:#000; font-size: 0.9rem; }
	.contact-list li:nth-child(1) p.roboto { font-size: 2.4rem;line-height: 1.2; }
		.contact-list li:nth-child(1) p.roboto a         { resize: none; }
		.contact-list li:nth-child(1) p.roboto a:link    { color:#000; text-decoration: none; }
		.contact-list li:nth-child(1) p.roboto a:visited { color:#000; text-decoration: none; }
		.contact-list li:nth-child(1) p.roboto a:hover   { color:#000; text-decoration: none; }
		.contact-list li:nth-child(1) p.roboto a:active  { color:#000; text-decoration: none; }
	.contact-list li:nth-child(1) p.roboto a:before { content: "\f095"; font-family: "Font AweSome 5 Free"; font-weight: 900; margin-right: 10px; transform: rotate(-270deg); display: inline-block;} 
	.contact-list li:nth-child(1) p.xsmall { font-size: 0.8rem; }
	
	.contact-list li:nth-child(2) { background: var(--cv-color); border: var(--cv-color) 1px solid; height: 50px; line-height: 50px; color: #fff; text-align: center; font-size: 1.0rem; border-radius: 6px; }
	.contact-list li:nth-child(2):hover { line-height: 47px; }
		.contact-list li:nth-child(2) a         { resize: none; display: block; }
		.contact-list li:nth-child(2) a:link    { color:#fff; text-decoration: none; }
		.contact-list li:nth-child(2) a:visited { color:#fff; text-decoration: none; }
		.contact-list li:nth-child(2) a:hover   { color:var(--cv-color); text-decoration: none; background:#fff; border-radius: 6px; }
		.contact-list li:nth-child(2) a:active  { color:var(--cv-color); text-decoration: none; }
	.contact-list li:nth-child(2) a:before { content: "\f0e0"; font-family: "Font AweSome 5 Free"; font-weight: 900; margin-right: 10px;} 
	.contact-list li:nth-child(2):hover a:before { content: "\f2b6"; font-family: "Font AweSome 5 Free"; font-weight: 900; margin-right: 10px;}  
}
@media screen and (min-width: 600px) and (max-width: 899px)  {	
	.contact-list li { width: 40%; margin-right: 2%;}
	.contact-list li:nth-child(1) p { margin-bottom: 0; font-size: 0.7rem; }
	.contact-list li:nth-child(1) p.roboto { font-size: 2.0rem; }	
	.contact-list li:nth-child(2) { height: 50px; line-height: 50px; font-size: 1.0rem; }
	.contact-list li:nth-child(2):hover { line-height: 47px; }
}
@media screen and (min-width: 900px) and (max-width: 1089px)  {	
	.contact-list li { width: 32%; margin-right: 2%;}
	.contact-list li:nth-child(1) p { margin-bottom: 0; font-size: 0.7rem; }
	.contact-list li:nth-child(1) p.roboto { font-size: 2.0rem; }	
	.contact-list li:nth-child(2) { height: 50px; line-height: 50px; font-size: 1.0rem; }
	.contact-list li:nth-child(2):hover { line-height: 47px; }
}


/*-- footer ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	footer { padding: 2vh 2% 0; position: relative; z-index: 10; }
	footer .in { }
	footer .in .fLogo { width: 180px; margin:0 auto 20px;  }
	footer .f-flex { display: flex; flex-direction: column; }
	footer .f-flex-R { order: 1; margin-bottom: 40px; border-bottom: 1px solid #312f2f; }
	footer .f-flex-L { order: 2; }
	footer .f-flex-L p { text-align: center; font-size: 0.8rem; color: #333; }
	footer .in p.xlarge { font-size: 0.9rem; }
	footer .f-flex-L ul li { text-align: center; margin-bottom: 10px; font-size: 0.8rem; }
	
	footer .f-flex-R { padding: 6%; }	
	footer .f-flex-R .f_menu ul { display: flex; justify-content: space-between; flex-wrap: wrap; }
	footer .f-flex-R .f_menu ul li { width: 44%; font-size: 0.8rem; margin-bottom: 10px; text-align: left; padding-left: 1em; text-indent: -1.8em; }
	footer .f-flex-R .f_menu ul li:before { content: "├"; margin-right: 10px; color: #333; opacity: 0.7;}
	footer .fa-external-link-alt { display: inline; }
}
@media screen and (min-width: 600px) {	
	footer { padding: 2vh 2% 0; position: relative; z-index: 10; }
	footer .in { color:#333; padding:30px 2%; padding-bottom: 0vh; }
	footer .in .fLogo { width: 300px; margin-bottom: 20px;  }
	footer .in .f_mark { display: flex; justify-content: flex-start; margin-bottom: 20px; }
	footer .in .f_mark li { width: 100px; margin-right: 10px; background: #fff; padding: 5px; border: 1px solid #dedede; }
	footer .in p { font-size: 0.9rem;  }
	footer .in p.xlarge { font-size: 1.0rem; }
	
	footer .f-flex { display: flex; justify-content: space-between;  }
	footer .f-flex-L { width: 30%; }
	footer .f-flex-L ul li { font-size: 0.9rem; margin-bottom: 5px; }
	footer .f-flex-L .xsmall { font-size: 0.7em; }
	
	footer .f-flex-R { display: flex; justify-content: flex-end; flex-wrap: wrap; width: 70%; }
	
	footer .f-flex-R .f_menu { margin-left: 60px; margin-bottom: 40px; }
	footer .f-flex-R .f_menu h4 { font-size: 0.95rem; word-break: keep-all; margin-bottom: 10px; }
	footer .f-flex-R .f_menu li { font-size: 0.85rem; word-break: keep-all; margin-bottom: 10px; }
	footer .f-flex-R .f_menu li.subMenu { padding-left: 1em; }
	footer .f-flex-R .f_menu li:before { content: "├"; margin-right: 10px; opacity: 0.5; }
}
@media screen and (min-width: 600px) and (max-width: 899px) {	
	footer .f-flex-L { width: 60%; }
	footer .f-flex-R { width: 36%; }
	footer .in .fLogo { width: 240px; margin-bottom: 20px;  }
	footer .in p { font-size: 0.9rem; }
	
	footer .f-flex-L ul li { font-size: 0.8rem; margin-bottom: 5px; }
	footer .f-flex-R .f_menu { margin-left: 6%; margin-bottom: 40px; }
	footer .f-flex-R .f_menu:nth-child(1) { margin-left: 0px;}
}

footer .in a         { resize: none; position: relative;}
footer .in a:link    { color:#333; text-decoration: none; }
footer .in a:visited { color:#333; text-decoration: none; }
footer .in a:hover   { color:var(--base-color); text-decoration: none; }
footer .in a:active  { color:#333; text-decoration: none; }

@media screen and (min-width: 1490px) {	
	footer .in .in-in-f-flex { display: flex; justify-content: flex-start; padding-left: 0.75em; }
}

/*-- copyright ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	#copyright { text-align:center; margin-bottom:0px; padding:1px 0; color:#fff; font-size:12px; }
}
@media screen and (min-width: 600px) {
	#copyright { text-align:center; margin-bottom:0px; padding:1px 0; color:#fff; font-size:12px; }
}
/*-- pagetop ------------------------------------------------------------*/
#pagetop { background: var(--base-color); opacity: 0.5; }
#pagetop a         { color:#fff; display: block; resize: none; }
#pagetop a:link    { color:#fff; text-decoration: none; }
#pagetop a:visited { color:#fff; text-decoration: none; }
#pagetop a:hover   { color:#999; text-decoration: none; }
#pagetop a:active  { color:#fff; text-decoration: none; }
@media screen and (max-width: 599px) {
	#pagetop { width: 40px; height: 40px; line-height: 40px; position:fixed; right:2%; bottom:2%; opacity:0.8; z-index: 999; text-align: center; margin-bottom: 0px; border-radius: 50%; }
}
@media screen and (min-width: 600px) and (max-width: 1079px) {
	#pagetop { width: 50px; height: 50px; line-height: 50px; position:fixed; right:20px; bottom:20px; opacity:0.8; z-index: 999; text-align: center; margin-bottom: 0px; border-radius: 50%; }
}
@media screen and (min-width: 1080px) {
	#pagetop { width: 50px; height: 50px; line-height: 50px; position:fixed; right:20px; bottom:20px; opacity:0.8; z-index: 999; text-align: center; margin-bottom: 0px; border-radius: 50%; }
}

/*-- ロゴマーク　パララックス -------------------------------------------------------------*/
#wrapper { position: relative; overflow: hidden;}
.logomark { position: absolute; z-index: -1; width: 50vw; opacity: 0.05;　pointer-events: none; will-change: transform; }
.logomark img { width: 100%; height: auto; display: block; }

/* 配置（好みに応じて調整できます） */
.logomark01 { top: 1200px; left: -10vw; }
.logomark02 { top: 2000px; right: -10vw; }
.logomark03 { top: 2800px; left: -10vw; }

/*-- box LINK ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.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; } 

	.r_box_btn a { color:#000; width:200px; height:35px; line-height:35px; border:#000 1px solid; border-radius: 50px; display:block; text-align:center; margin:0 0; background:#fff; font-size: 1.1em; font-weight: 900; position: relative; } 
	.r_box_btn a:link    { color:#000; text-decoration: none; }
	.r_box_btn a:visited { color:#000; text-decoration: none; }
	.r_box_btn a:hover   { color:#fff; text-decoration: none; background:#000; }
	.r_box_btn a:active  { color:#000; text-decoration: none; }
	.r_box_btn a:after { content: ""; width: 10px; height: 10px; border-radius: 5px; background: var(--sub-color); position: absolute; top: 50%; right: 15px; transform: translateY(-50%); }
}
@media screen and (min-width: 600px) {
	.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; }

	.r_box_btn a { color:#000; width:250px; height:50px; line-height:50px; border:#000 1px solid; border-radius: 50px; display:block; text-align:center; margin:0 0; background:#fff; font-size: 1.2em; font-weight: 900; position: relative; } 
	.r_box_btn a:link    { color:#000; text-decoration: none; }
	.r_box_btn a:visited { color:#000; text-decoration: none; }
	.r_box_btn a:hover   { color:#fff; text-decoration: none; background:#000; }
	.r_box_btn a:active  { color:#000; text-decoration: none; }
	.r_box_btn a:after { content: ""; width: 10px; height: 10px; border-radius: 5px; background: var(--sub-color); position: absolute; top: 50%; right: 15px; transform: translateY(-50%); }
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.r_box_btn a { color:#000; width:200px; height:45px; line-height:45px; font-size: 1.1em; } 
}
/*-- 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 {padding-left: 1em; margin-bottom: 20px; }
ol li { margin-bottom: 10px;}

/*-- 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投稿　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) }
}
	
/*-- text-shadow ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.tShadow {
		text-shadow: 2px 2px 2px rgba(0,0,0,0.1), -2px -2px 2px rgba(0,0,0,0.1), -2px 2px 2px rgba(0,0,0,0.1), 2px -2px 2px rgba(0,0,0,0.1), 2px 0px 2px rgba(0,0,0,0.1), -2px -0px 2px rgba(0,0,0,0.1), 0px 2px 2px rgba(0,0,0,0.1), 0px -2px 2px rgba(0,0,0,0.1);
	}
	.tShadow-wh {
		text-shadow: 2px 2px 2px #fff, -2px -2px 2px #fff, -2px 2px 2px #fff, 2px -2px 2px #fff, 2px 0px 2px #fff, -2px -0px 2px #fff, 0px 2px 2px #fff, 0px -2px 2px #fff;
	}
}
@media screen and (min-width: 600px) {
	.tShadow {
		text-shadow: 3px 3px 3px rgba(0,0,0,0.1), -3px -3px 3px rgba(0,0,0,0.1), -3px 3px 3px rgba(0,0,0,0.1), 3px -3px 3px rgba(0,0,0,0.1), 3px 0px 3px rgba(0,0,0,0.1), -3px -0px 3px rgba(0,0,0,0.1), 0px 3px 3px rgba(0,0,0,0.1), 0px -3px 3px rgba(0,0,0,0.1);
	}
	.tShadow-wh {
		text-shadow: 3px 3px 3px #fff, -3px -3px 3px #fff, -3px 3px 3px #fff, 3px -3px 3px #fff, 3px 0px 3px #fff, -3px -0px 3px #fff, 0px 3px 3px #fff, 0px -3px 3px #fff;
	}	
}

/*-- 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;}

.marker { background:linear-gradient(transparent 60%, #ff6 60%); }

.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; font-weight:bold; }
.oswald { font-family: "Oswald", sans-serif; }
.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 */




