@charset "UTF-8";
/* color */
:root {
	--base-color:#003366;
	--sc-color:#107cc1;
	--sub-color:#e4007f;
	--opa-color:#a5d1ee;
	--gry-color:#f4f4f4;
}

.grad { background: linear-gradient(64deg, #07913a 50%, #d8de00 100%); }
/*-- Anchor -------------------------------------------------------------*/
a         { resize: none; }
a:link    { color:var(--base-color); text-decoration: underline; }
a:visited { color:var(--base-color); text-decoration: underline; }
a:hover   { color:#333; text-decoration: none; }
a:active  { color:var(--base-color); text-decoration: underline; }

.tag a         { resize: none; }
.tag a:link    { color:#333; }
.tag a:visited { color:#333; }
.tag a:hover   { color:var(--base-color); text-decoration: underline; }
.tag a:active  { color:#333; }

footer a         { resize: none; }
footer a:link    { color:#fff; text-decoration: none; }
footer a:visited { color:#fff; text-decoration: none; }
footer a:hover   { color:#FFE300; text-decoration: none; }
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: 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%;}
}
@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 {  width:45%;}
	.img_y_R { width: 45%; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	.img_t_R { width:40%;}
	.img_y_R { width:40%; }
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	.img_t_R { width:35%;}
	.img_y_R { width:35%; }
}

#wrapper { overflow-x: hidden; }
/*-- header -------------------------------------------------------------*/
@media screen and (max-width: 1089px) {
	header .h1_out h1 { font-size: 10px; color: #000; line-height: 1.5; width: 98%; margin: 0 auto; padding: 0 1%;  }
	header .in-head-flex { display: flex; justify-content: space-between; align-items: center; width: 98%; margin: 0 auto 10px; padding: 0 1%; }
	header .in-head-flex .hL { width: 40%; }	
	header .in-head-flex .hL .logo-inFlex { display: flex; justify-content: flex-start; align-items: center;  }
	header .in-head-flex .hL .logo-mark { max-width: 200px; }
	header .in-head-flex .hR ul { display: flex; justify-content: flex-end; align-items: center; }
	header .in-head-flex .hR ul li { margin-right: 20%; font-size: 0.9rem; list-style: none; word-break: keep-all; }
	header .in-head-flex .hR ul li:nth-child(1) { margin-left: 0; }
	header .in-head-flex .hR ul li.search { position: relative; }
	header .in-head-flex .hR ul li.search input[type=text]{ border: 1px solid var(--base-color); padding: 0px 10px; height: 30px; line-height: 30px; font-size: 0.9rem; }
	header .in-head-flex .hR ul li.search input[type=image]{ background:var(--base-color); display: flex; justify-content: center; align-items: center; width: 20px; height: 20px; position: absolute; top: 0; right: 0; padding: 6px; }
	header .in-head-flex .hR ul li.search input[type=text]::placeholder { font-size: 0.7rem; }	
	header .in-head-flex .hR ul li .searchBtn { width: 40px; height: 40px; background: var(--base-color); display: flex; justify-content: center; align-items: center; }
	header .in-head-flex .hR ul li .searchBtn a { display: flex; justify-content: center; align-items: center;} 
	header .in-head-flex .hR ul li .searchBtn a img { width: 50%; }
	
	header .in-head-flex .hR ul li.h_contact a { width: 40px; height: 40px; background: var(--base-color); display: flex; justify-content: center; align-items: center; }
	header .in-head-flex .hR ul li.h_contact a:link    { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li.h_contact a:visited { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li.h_contact a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
	header .in-head-flex .hR ul li.h_contact a:active  { color:#fff; text-decoration: none; }	
}
@media screen and (max-width: 899px) {
	header .in-head-flex .hR ul li .searchBtn_pc { display: none; }
}
@media screen and (max-width: 599px) {
	header .h1_out h1 { margin-bottom: 5px; }
	header .in-head-flex .hL { width: 50%; }	
	header .in-head-flex .hR ul li { margin-right: 10%; }
	header .in-head-flex .hR ul li .searchBtn { width: 30px; height: 30px; } 
	header .in-head-flex .hR ul li.h_menu { margin-right: 4%; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	header .in-head-flex .hR ul li.search .searchBtn { display: none; }
}
@media screen and (min-width: 600px) and (max-width: 1089px) {
	header .h1_out h1 { font-size: 11px; } 
	header .in-head-flex .hL .logo-mark { max-width: 270px; }
	header .in-head-flex .hR ul li.sns { width: 40px; }
}
@media screen and (min-width: 1090px) {
	header { max-width: 1400px; margin: 0 auto; }
	header .h1_out { }
	header .h1_out h1 { font-size: 12px; color: #000; line-height: 1.5; width: 98%; margin: 0 auto 5px; padding: 0 1%;  }
	
	header .in-head-flex { display: flex; justify-content: space-between; align-items: center; width: 98%; margin: 0 auto 10px; padding: 0 1%; }
	
	header .in-head-flex .hL { width: 30%; }	
	header .in-head-flex .hL .logo-inFlex { display: flex; justify-content: flex-start; align-items: center;  }
	header .in-head-flex .hL .logo-mark { max-width: 300px; }
	
	header .in-head-flex .hR { width: 70%; }

	header .in-head-flex .hR ul { display: flex; justify-content: flex-end; align-items: center; }
	header .in-head-flex .hR ul li { margin-left: 4%; font-size: 0.9rem; list-style: none; word-break: keep-all; }
	header .in-head-flex .hR ul li:nth-child(1) { margin-left: 0; }
	
	header .in-head-flex .hR ul li.h_contact a { color:#fff; text-decoration: none; display: block; background:var(--base-color); padding: 5px 40px; font-size: 0.9rem; border-radius: 50px; }
	header .in-head-flex .hR ul li.h_contact a:link    { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li.h_contact a:visited { color:#fff; text-decoration: none; }
	header .in-head-flex .hR ul li.h_contact a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
	header .in-head-flex .hR ul li.h_contact a:active  { color:#fff; text-decoration: none; }	
	
	header .in-head-flex .hR ul li.search { position: relative; margin-left: 2%; }
	header .in-head-flex .hR ul li.search input[type=text]{ border: 1px solid var(--base-color); padding: 0px 10px; height: 30px; line-height: 30px; font-size: 0.9rem; }
	header .in-head-flex .hR ul li.search input[type=image]{ background:var(--base-color); display: flex; justify-content: center; align-items: center; width: 20px; height: 20px; position: absolute; top: 0; right: 0; padding: 6px; }
	header .in-head-flex .hR ul li.search input[type=text]::placeholder { font-size: 0.7rem; }
	header .in-head-flex .hR ul li.search .searchBtn { display: none; }	
	header .in-head-flex .hR ul li.h_menu { display: none; }
} 
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	header .in-head-flex .hL .logo-mark { max-width: 280px; }
	header .in-head-flex .hR ul li.sns { width: 25px; }
}
@media screen and (min-width: 1190px) and (max-width: 1289px) {
	header .in-head-flex .hL .logo-mark { max-width: 290px; }
	header .in-head-flex .hR ul li.sns { width: 25px; }
}
/*-- is-fix  -------------------------------------------------------------*/
header.is-fix { position: fixed; left: 0; top: 0; width: 100%; z-index: 9999; background: #fff; }
@media screen and (max-width: 1089px) {
	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 .h1_out { display: none; }
	header.is-fix .in-head-flex .hL .logo-mark { width: 120px; }
}
@media screen and (min-width:600px) and (max-width: 1089px) {
	header.is-fix .in-head-flex .hR ul li.search input[type=text]{ height: 25px; line-height: 25px; font-size: 0.8rem; }
	header.is-fix .in-head-flex .hR ul li.search input[type=image]{ width: 14px; height: 14px; }
}
@media screen and (min-width: 1090px) {
	header.is-fix { box-shadow: 0px 3px 6px 0px rgba(0, 0, 0, 0.25); max-width: 100%; }
	header.is-fix .h1_out { display: none; }
	header.is-fix .in-head-flex { max-width: 100%; width: 100%; padding: 0px; margin-bottom: 0px; }
	header.is-fix .in-head-flex .hL { margin: 5px 0 5px 1%; }
	header.is-fix .in-head-flex .hL .logo-mark { width: 200px; }
		
	header.is-fix .in-head-flex .hR { margin-right: 1%; }
	header.is-fix .in-head-flex .hR ul li { font-size: 0.7rem; margin-left: 2%; }
	header.is-fix .in-head-flex .hR ul li.h_contact a { padding: 3px 30px; font-size: 0.8rem; }
}

/*-- megaMenu  -------------------------------------------------------------*/
@media screen and (min-width: 1090px) {
	header .in-head-flex .hR ul li .parent { font-weight: bold; }
	header .in-head-flex .hR > ul > li.mTxt { font-size: 1.1rem; position: relative; font-weight: bold; }
	header .in-head-flex .hR > ul > li.mTxt a         { resize: none; display: block; word-break: keep-all; }
	header .in-head-flex .hR > ul > li.mTxt a:link    { color:var(--base-color); text-decoration: none; }
	header .in-head-flex .hR > ul > li.mTxt a:visited { color:var(--base-color); text-decoration: none; }
	header .in-head-flex .hR > ul > li.mTxt a:hover   { color:var(--base-color); text-decoration: none; opacity: 0.7; }
	header .in-head-flex .hR > ul > li.mTxt a:active  { color:var(--base-color); text-decoration: none; }
		
	header .in-head-flex .hR > ul > li .menu { display: none; transition: all .2s ease-in; max-height: 0; opacity: 0; min-width: 350px; text-align: left; position: absolute; top: 100%; left: 0%; /*transform: translateX(-50%);*/ z-index: 10; background-color: #fff; border: 1px solid #ccc; }
	header .in-head-flex .hR > ul > li:hover .menu { display:block; }
	header .in-head-flex .hR > ul > li:last-child .menu { position: absolute; top: 100%; left: inherit; right: 0; transform: translateX(0); }
	header .in-head-flex .hR > ul > li:first-child .menu { position: absolute; top: 100%; left: 0; transform: translateX(0); }
	
	header .in-head-flex .hR > ul > li:hover > .menu { max-height: 9999px; opacity: 1; z-index: 100; }
	header .in-head-flex .hR > ul > li:hover > .menu.menu02 { min-width: 240px; }
	header .in-head-flex .hR > ul > li:hover > .menu.menu03 { min-width: 240px; }
	
	header .in-head-flex .hR > ul > li .menu > .menu_inner { padding:20px; font-weight: normal; }
	header .in-head-flex .hR > ul > li .menu > .menu_inner p:last-child { margin-bottom: 0px; }
	header .in-head-flex .hR > ul > li .menu > .menu_inner p a { word-break: keep-all; /*font-size: 0.85rem;*/ display: block; transition: all .2s ease-in; padding-left: 1em; text-indent: -1.5em; }
	header .in-head-flex .hR > ul > li .menu > .menu_inner p a:before { content: "├"; margin-right: 10px; color: #ccc; }
	
	header .in-head-flex .hR > ul .menu .menu_inner p a         { resize: none; display: block; color:#000; }
	header .in-head-flex .hR > ul .menu .menu_inner p a:link    { color:#000; text-decoration: none; }
	header .in-head-flex .hR > ul .menu .menu_inner p a:visited { color:#000; text-decoration: none; }
	header .in-head-flex .hR > ul .menu .menu_inner p a:hover   { color:var(--base-color); text-decoration: none; opacity: 1.0; background: #f4f4f4; }
	header .in-head-flex .hR > ul .menu .menu_inner p a:active  { color:#fff; text-decoration: none; }
	
	header.is-fix .in-head-flex .hR > ul > li.mTxt { font-size: 0.95rem; }
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	header .in-head-flex .hR > ul > li.mTxt { font-size: 1.0rem; }
	header .in-head-flex .hR > ul > li .menu > .menu_inner p { font-size: 0.75rem; }
	
	header.is-fix .in-head-flex .hR > ul > li.mTxt { font-size: 0.85rem; }
}
@media screen and (min-width: 1190px) and (max-width: 1289px) {
	header .in-head-flex .hR > ul > li.mTxt { font-size: 1.05rem; }
	header .in-head-flex .hR > ul > li .menu > .menu_inner p { font-size: 0.80rem; } 
	
	header.is-fix .in-head-flex .hR > ul > li.mTxt { font-size: 0.9rem; }
}

/*-- SP menu-trgger -------------------------------------------------------------*/
.sp-toggle { color: #fff; }
@media screen and (max-width: 1089px) {
	header .in-head-flex .hR ul li.h_menu { display: block; position: relative; z-index: 9999; }
	.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: var(--base-color); border-radius: 2px; }
	.menu-trigger span:nth-of-type(1) { }
	.menu-trigger span:nth-of-type(2) { width: 75%; }
	.menu-trigger span:nth-of-type(3) { }
	
	.h_menu .active span { background-color: #fff !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(--base-color); box-sizing: border-box; box-shadow: -4px 0px 16px -6px rgba(0,0,0,0.6);}
	header nav#overlay .in { overflow: auto; height: 100%; -webkit-overflow-scrolling: touch; }
	header nav#overlay ul { display: flex; justify-content: flex-start; flex-wrap: wrap; }
	header nav#overlay ul.scroll-menu { overflow-y: scroll; height: 80vh; margin-top: 5vh; }
	header nav#overlay ul li { margin-right: 6%; font-size: 0.9rem; margin-bottom: 40px; text-align: left; }
	header nav#overlay ul li a         { resize: none; display: block; }
	header nav#overlay ul li a:link    { color:#fff; text-decoration: none; }
	header nav#overlay ul li a:visited { color:#fff; text-decoration: none; }
	header nav#overlay ul li a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
	header nav#overlay ul li a:active  { color:#fff; text-decoration: none; }
	
	header nav#overlay ul li .menu { margin: 10px 0 0 10px; }
	header nav#overlay ul li .menu .menu_inner p:last-child { text-align: left; }
	header nav#overlay ul li .menu .menu_inner p:last-child { margin-bottom: 0px; text-align: left; }
	header nav#overlay ul li .menu .menu_inner p a { word-break: keep-all; font-size: 0.85rem; display: block; transition: all .2s ease-in; padding-left: 1em; text-indent: -1.5em; }
	header nav#overlay ul li .menu .menu_inner p a:before { content: "├"; margin-right: 10px; color: #ccc; }
	
	header nav#overlay ul .menu .menu_inner p a         { resize: none; display: block; }
	header nav#overlay ul .menu .menu_inner p a:link    { color:#fff; text-decoration: none; }
	header nav#overlay ul .menu .menu_inner p a:visited { color:#fff; text-decoration: none; }
	header nav#overlay ul .menu .menu_inner p a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
	header nav#overlay ul .menu .menu_inner p a:active  { color:#fff; text-decoration: none; }
}
@media screen and (max-width: 599px) {
	header nav#overlay ul.scroll-menu { flex-direction: column; }
	header nav#overlay ul .sp-toggle { position: relative; }
	header nav#overlay ul .sp-toggle:after { content: "\f067"; font-family: "Font Awesome 5 Free"; font-weight: 900; position: absolute; top: 50%; right: 0; transform: translateY(-50%); opacity: 0.7; }
	header nav#overlay ul .sp-toggle.active:after { content: "\f068"; }
	header nav#overlay ul.scroll-menu { margin-top: 10vh; }
	header nav#overlay ul li { margin-bottom: 20px; }
	header nav#overlay ul li .sp-toggle { color: #fff; }
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	header nav#overlay{ width: 40%; }
	.menu-trigger { margin-right: 4%; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	header nav#overlay{ width: 40%; }
	.menu-trigger { margin-right: 4%; }
}

@media screen and (min-width: 1090px) {
	header nav#overlay { display: none; }
	header.is-fix .in-head-flex .hR ul li.h_menu { display: block; position: relative; z-index: 9999; }
	.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: var(--base-color); border-radius: 2px; }
	.menu-trigger span:nth-of-type(1) { }
	.menu-trigger span:nth-of-type(2) { width: 75%; }
	.menu-trigger span:nth-of-type(3) { }
	
	.h_menu .active span { background-color: #fff !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.is-fix nav#overlay{ display: none; width: 60%; 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(--base-color); box-sizing: border-box; box-shadow: -4px 0px 16px -6px rgba(0,0,0,0.6);}
	header.is-fix nav#overlay .in { overflow: auto; height: 100%; -webkit-overflow-scrolling: touch; }
	header.is-fix nav#overlay ul { display: flex; justify-content: flex-end; flex-wrap: wrap; }
	header.is-fix nav#overlay ul li { margin-right: 6%; font-size: 0.9rem; margin-bottom: 40px; text-align: left; }
	header.is-fix nav#overlay ul li a         { resize: none; display: block; }
	header.is-fix nav#overlay ul li a:link    { color:#fff; text-decoration: none; }
	header.is-fix nav#overlay ul li a:visited { color:#fff; text-decoration: none; }
	header.is-fix nav#overlay ul li a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
	header.is-fix nav#overlay ul li a:active  { color:#fff; text-decoration: none; }
	
	header.is-fix nav#overlay ul li .menu { margin: 10px 0 0 10px; }
	header.is-fix nav#overlay ul li .menu .menu_inner p:last-child { text-align: left; }
	header.is-fix nav#overlay ul li .menu .menu_inner p:last-child { margin-bottom: 0px; text-align: left; }
	header.is-fix nav#overlay ul li .menu .menu_inner p a { word-break: keep-all; font-size: 0.85rem; display: block; transition: all .2s ease-in; padding-left: 1em; text-indent: -1.5em; }
	header.is-fix nav#overlay ul li .menu .menu_inner p a:before { content: "├"; margin-right: 10px; color: #ccc; }
	
	header.is-fix nav#overlay ul .menu .menu_inner p a         { resize: none; display: block; }
	header.is-fix nav#overlay ul .menu .menu_inner p a:link    { color:#fff; text-decoration: none; }
	header.is-fix nav#overlay ul .menu .menu_inner p a:visited { color:#fff; text-decoration: none; }
	header.is-fix nav#overlay ul .menu .menu_inner p a:hover   { color:#fff; text-decoration: none; opacity: 0.7; }
	header.is-fix nav#overlay ul .menu .menu_inner p a:active  { color:#fff; text-decoration: none; }
}
@media screen and (min-width: 1090px) and (max-width: 1289px) {
	header.is-fix nav#overlay{ width: 70%; }
}
@media screen and (min-width: 1290px) and (max-width: 1489px) {
	header.is-fix nav#overlay{ width: 70%; }
}
/*-- コンテンツ -------------------------------------------------------------*/
@media screen and (max-width: 1089px) {
	.cubeTtl { background:var(--base-color) url("../img/common/ttlBg.png") center right no-repeat; background-size: 60%; color: #fff; padding: 10px 0 10px 15px; margin-bottom: 20px; font-size: 1.3rem; border-left: 8px solid var(--sub-color); }
	.ttl01 { text-align: center; margin-bottom: 20px; font-weight: bold; font-size: 1.5rem; line-height: 1.5; color: #333; }	
	.ttl01 span.xsmall { color: #333; font-size: 0.8em; }
	.ttl02 { color: var(--base-color); margin-bottom: 20px; font-size: 1.0rem; font-weight: bold; text-align: center; }
	.subttl01 { text-align: center; color: #333; margin-bottom: 10px; font-weight: bold; line-height: 1.5; margin-bottom: 5px; }
	.ttlBar { width: 5%; height: 5px; margin: 0 auto 20px;}
	.mark { width: 30px; margin: 0 auto 10px; }	
	.lead { margin-bottom: 20px; }
	.movie_icon { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 30px;}
	.nayami { width: 120px; margin: 0 auto 20px;}
}
@media screen and (min-width: 600px) and (max-width: 1089px) {
	section .in { margin: 0 2%; }
	.cubeTtl { font-size: 1.8rem; background-size: 40%; }
	.ttl01 { font-size: 2.0rem; }
	.ttl02 { font-size: 1.1rem; color: var(--base-color); }
	.mark { width: 40px; margin: 0 auto 20px; }	
	.movie_icon { width: 40px;}
	.nayami { width: 150px; margin: 0 auto 20px;}
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	.cubeTtl { font-size: 1.9rem; }
	.ttl01 { font-size: 1.8rem; }
	.ttl02 { font-size: 1.2rem; }
}
@media screen and (min-width: 1090px) {
	section .in { max-width: 1400px; width: 96%; margin: 0 auto 10vh; }
	.cubeTtl { background:var(--base-color) url("../img/common/ttlBg.png") center right no-repeat; color: #fff; padding: 10px 0 10px 20px; font-size:2.4rem; font-weight: bold; margin-bottom: 40px; border-left: 10px solid var(--sub-color); }
	.ttl01 { color: var(--base-color); padding-bottom: 5px; margin-bottom: 40px; border-bottom: 1px solid var(--base-color); font-size: 2.1rem; line-height: 1.5; background-size: 40px; letter-spacing: 0.1em;  }		
	.ttl02 { color: var(--sub-color); margin-bottom: 20px; font-size: 1.5rem; font-weight: bold; text-align: center; }
	.ttlBar { width: 5%; height: 5px; margin: 0 auto 40px;}
	.subttl01 { text-align: center; color: #333; margin-bottom: 10px; font-weight: bold; line-height: 1.0; margin-bottom: 5px; }
	.mark { width: 60px; margin: 0 auto 20px; }	
	.lead { margin-bottom: 40px; }
	.lead_alC { text-align: center; }
	.movie_icon { position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); width: 50px;}
	.nayami { width: 180px; margin: 0 auto 20px;}
	
	.spotTtl { text-align: center; margin-bottom: 20px; }
	.spotTtl span { background: #ef5555; color: #fff; font-weight: bold; padding: 5px 20px; }
	
	.in-900 { max-width: 900px; margin: 0 auto; }
	.in-700 { max-width: 700px; margin: 0 auto; }
}
@media screen and (min-width: 1090px) and (max-width: 1189px) {
	.cubeTtl { font-size: 2.0rem; }
	.ttl01 { font-size: 1.8rem; }
	.ttl02 { font-size: 1.2rem; }
}
@media screen and (min-width: 1190px) and (max-width: 1289px) {
	.cubeTtl { font-size: 2.1rem; }
	.ttl01 { font-size: 1.9rem; }
	.ttl02 { font-size: 1.3rem; }
}
@media screen and (min-width: 1290px) and (max-width: 1389px) {
	.cubeTtl { font-size: 2.2rem; }
	.ttl01 { font-size: 2.0rem; }
	.ttl02 { font-size: 1.4rem; }
}
@media screen and (min-width: 1390px) and (max-width: 1489px) {
	.cubeTtl { font-size: 2.3rem; }
}


/*-- floeList -------------------------------------------------------------*/
@media screen and (max-width: 889px) {
	.flowList { }
	.flowList li { border-bottom: 1px solid #dedede; position: relative; padding-bottom: 20px; margin-bottom: 20px; }
	.flowList li:after { 
		content: ""; position: absolute; bottom: -10px; left: 50%; transform: translateX(-50%); 
		width:0; height:0; border-style:solid; border-width: 10px 25px 0 25px; border-color: #dedede transparent transparent transparent;
	}
	.flowList li .step { font-family:'Roboto Condensed', sans-serif; font-weight:bold; font-size: 0.7rem; text-align: center; background: #fff; padding: 2px 0; margin-bottom: 10px; }
	.flowList li .step span { font-size: 1.5em; }
	.flowList li h4 { text-align: center; color: #fff; background:var(--base-color); margin-bottom: 10px; display: flex; justify-content: center; align-items: center; padding: 5px 0; }
	.flowList li p { font-size: 0.9rem; margin-bottom: 0px; }
	.flowList li div { width: 60%; margin: 0 auto; }
	.flowList li:last-child { border-bottom: none; }
	.flowList li:last-child:after { display: none; }
}
@media screen and (min-width: 900px) {
	.flowList { display: flex; justify-content: space-between; }
	.flowList li {width: 16%; padding: 0 2%; border-right: 1px solid #dedede; position: relative; }
	.flowList li:after { 
		content: ""; position: absolute; top: 50%; right: -10px; transform: translateY(-50%); 
		width:0; height:0; border-style:solid; border-width: 25px 0 25px 10px; border-color: transparent transparent transparent #dedede;
	}
	.flowList li .step { font-family:'Roboto Condensed', sans-serif; font-weight:bold; font-size: 0.8rem; text-align: center; background: #fff; padding: 2px 0; margin-bottom: 10px; }
	.flowList li .step span { font-size: 1.5em; }
	.flowList li h4 { text-align: center; color: #fff; background:var(--base-color); margin-bottom: 10px; display: flex; justify-content: center; align-items: center; padding: 5px 0; }
	.flowList li p { font-size: 0.9rem; margin-bottom: 0px; }
	.flowList li div { width: 60%; margin: 0 auto 10px; }
	.flowList li:last-child { border-right: none; }
	.flowList li:last-child:after { display: none; }
	
	.flowList li .memo { display: block; margin-top: 20px;  }
	.flowList li .memo li { font-size: 0.8rem; border-right: none; border-bottom: 1px dotted #dedede; padding: 5px; margin-bottom: 5px; width: 100%; padding-left: 1em; text-indent: -1.5em; }
	.flowList li .memo li:after { display: none; }
	.flowList li .memo li:before { content: "\f00c"; font-family: "Font Awesome 5 Free"; font-weight: 900; color:var(--base-color); margin-right: 5px; }
}

/*-- faq -------------------------------------------------------------*/
@media screen and (max-width: 899px) {
	.faqDl { margin-bottom: 40px; }
	.faqDl dt { margin-bottom: 10px; font-weight: bold; font-size: 1.0em;  }
	.faqDl dt:before { content: "Q."; color:var(--base-color); margin-right: 10px; font-family:'Roboto Condensed', sans-serif; font-weight:bold; font-size: 1.1em; }
	.faqDl dd { font-size: 0.9em; background: #f4f4f4; padding: 4%; border-radius: 6px;}
}
@media screen and (min-width: 900px) {
	.faqDl { margin-bottom: 40px; }
	.faqDl dt { margin-bottom: 10px; font-weight: bold; font-size: 1.1em;  }
	.faqDl dt:before { content: "Q."; color:var(--base-color); margin-right: 10px; font-family:'Roboto Condensed', sans-serif; font-weight:bold; font-size: 1.1em; }
	.faqDl dd { font-size: 0.9em; background: #f4f4f4; padding: 20px; border-radius: 6px; }
}
.faqDl ul { padding-left: 1em; }
/*-- contact section  -------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.contactSec { background:var(--base-color); margin-top: 40px; padding-top: 0; }
	.contactSec .in { margin-bottom: 0px; padding: 5vh 0; }
	.contactBox h2 { text-align: center; font-size: 1.0rem; margin-bottom: 10px; }
	.contactBox dl { display: flex; justify-content: center; align-items: center; margin-bottom: 20px; } 
	.contactBox dl dt { font-size: 0.8rem; font-weight: bold; background:var(--base-color); border: 1px solid var(--base-color); color: #fff; padding: 2px 20px; }
	.contactBox dl dd { font-size: 0.8rem; font-weight: bold; background:#fff; border: 1px solid var(--base-color); color: var(--base-color); padding: 2px 20px; }
	
	.contactFlex { display: flex; flex-direction: column; justify-content: center; align-items: center; }
	.contactFlex li { width: 100%; }
	.contactFlex li:nth-child(1) { color: #fff; margin-bottom: 20px; font-size: 1.2rem; font-weight: bold; text-align: center; }
	
	.contactFlex li:nth-child(3) { display: flex; justify-content: center; }
	.contactFlex li:nth-child(3) p { color: #fff; line-height: 1.0; background: url("../img/common/icon-tel.png") 0 0px no-repeat; background-size: 30px; padding-left: 35px; margin-bottom: 0px; margin-right: 0px; }
	.contactFlex li:nth-child(3) p .xlarge { font-size: 1.5rem; }
	.contactFlex li:nth-child(3) p .xsmall { display: block; font-size: 0.7rem; font-weight: normal; }
	.contactFlex li:nth-child(3) p .xsmall .roboto { font-size: 0.8rem; margin-right: 5px; }
	
	.contactFlex li:nth-child(2) { text-align: center; margin-bottom: 10px; }
	.contactFlex li:nth-child(2) p {  }
	.contactFlex li:nth-child(2) p a { background: var(--sub-color); text-align: center; border-radius: 20px; font-size:1.1rem; border: 1px solid var(--sub-color); font-weight: bold; padding: 5px 25px;  }
	.contactFlex li:nth-child(2) p a:link    { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:visited { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:hover   { color:#cc0066; text-decoration: none; background: #fff; }
	.contactFlex li:nth-child(2) p a:active  { color:#fff; text-decoration: none; }
	
}
@media screen and (min-width: 600px) {
	.contactSec { background:var(--base-color); margin-top: 100px; padding-top: 0; }
	.contactSec .in { margin-bottom: 0px; padding: 5vh 0; }
	.contactBox { padding: 20px; max-width: 1000px; border: 1px solid var(--base-color); margin: 0 auto; }
	.contactBox h2 { text-align: center; font-size: 1.2rem; margin-bottom: 10px; font-weight: bold; }
	.contactBox dl { display: flex; justify-content: center; align-items: center; margin-bottom: 20px; } 
	.contactBox dl dt { font-size: 1.0rem; font-weight: bold; background:var(--base-color); border: 1px solid var(--base-color); color: #fff; padding: 2px 20px; }
	.contactBox dl dd { font-size: 1.0rem; font-weight: bold; background:#fff; border: 1px solid var(--base-color); color: var(--base-color); padding: 2px 20px; }
	.contactFlex { display: flex; justify-content: center; align-items: center; }
	
	.contactFlex li:nth-child(1) { color: #fff; margin-right: 60px; font-size: 1.5rem; font-weight: bold; }
	
	.contactFlex li:nth-child(3) p { color: #fff; line-height: 1.0; background: url("../img/common/icon-tel.png") 0 0px no-repeat; background-size: 40px; padding-left: 45px; margin-bottom: 0px; margin-right: 0px; }
	.contactFlex li:nth-child(3) p .xlarge { font-size: 1.8rem; }
	.contactFlex li:nth-child(3) p .xsmall { display: block; font-size: 0.7rem; font-weight: normal; }
	.contactFlex li:nth-child(3) p .xsmall .roboto { font-size: 0.9rem; margin-right: 5px; }
	
	.contactFlex li:nth-child(2) { margin-right: 40px; }
	.contactFlex li:nth-child(2) p { margin-bottom: 0px;}
	.contactFlex li:nth-child(2) p a { margin-bottom: 0px; background: #cc0066; height: 40px; line-height: 40px; min-width: 240px; text-align: center; border-radius: 20px; font-size:1.1rem; border: 1px solid var(--sub-color); resize: none; display: block; margin-right: 20px; font-weight: bold; }
	.contactFlex li:nth-child(2) p a:link    { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:visited { color:#fff; text-decoration: none; }
	.contactFlex li:nth-child(2) p a:hover   { color:#cc0066; text-decoration: none; background: #fff; }
	.contactFlex li:nth-child(2) p a:active  { color:#fff; text-decoration: none; }
	
}
@media screen and (min-width: 600px) and (max-width: 899px)  {	
	.contactFlex li:nth-child(3) p { background-size: 30px; padding-left: 35px; margin-right: 10px; font-size: 1.6rem; }
	.contactFlex li:nth-child(3) p .xlarge { font-size: 1.6rem; }
	.contactFlex li:nth-child(3) p .xsmall { display: block; font-size: 0.6rem; font-weight: normal; }
	.contactFlex li:nth-child(3) p .xsmall .roboto { font-size: 0.8rem; margin-right: 5px; }
	.contactFlex li:nth-child(2) p a { height: 30px; line-height: 30px; min-width: 180px; font-size:0.9rem; margin-right: 10px;}
}
@media screen and (min-width: 900px) and (max-width: 1089px)  {	
	.contactBox { max-width: 820px; width: 100%; margin: 0 auto; }
	.contactFlex li:nth-child(3) p .xlarge { font-size: 1.7rem; }
	.contactFlex li:nth-child(3) p { background-size: 35px; padding-left: 40px; }
}

/*-- footer fix bnr  -------------------------------------------------------------*/
@media screen and (max-width: 1079px) {
	#contact-fixed ul { position: fixed; z-index: 888; bottom: 0; left: 0.5%; right: 0.5%; margin: 0 auto; width: 99%; display: flex; justify-content: center;}
	#contact-fixed ul li { width: 33%; }
}
@media screen and (min-width: 900px) and (max-width: 1079px) {
	#contact-fixed { display: none; }
}
/*-- 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: 599px) {
	footer {  }
	footer .in { color:#000; padding: 6% 4%; display: flex; flex-direction: column; }
	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 #dedede; }
	footer .f-flex-L { order: 2; }
	footer .f-flex-L p { text-align: center; font-size: 0.9rem; color: #000; }
	footer .in .f_mark { display: flex; justify-content: center; width: 80%; margin: 0 auto 40px; }
	footer .in .f_mark li { width: 32%; margin-right: 10px; background: #fff; padding: 5px; border: 1px solid #dedede; }
	footer .f-flex-L p.xsmall { text-align: left; }
	
	footer .f-flex-R { display: none; }	
	footer .f-flex-R .f_menu { width: 48%; margin-bottom: 20px; }
	footer .f-flex-R .f_menu h4 { font-size: 0.8rem; word-break: keep-all; margin-bottom: 10px; }
	footer .f-flex-R .f_menu li { font-size: 0.7rem; word-break: keep-all; margin-bottom: 10px; }
	footer .f-flex-R .f_menu li:before { content: "├"; margin-right: 10px;}
}
@media screen and (min-width: 600px) {	
	footer { padding: 2vh 0 0; margin: 0 2%; position: relative; z-index: 10; border-top: 1px solid #dedede; }
	footer .in { color:#000; padding:30px 2%; padding-bottom: 5vh; }
	footer .in .fLogo { width: 240px; 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: 40px; 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:before { content: "├"; margin-right: 10px; opacity: 0.5; }
}

footer .in a         { resize: none; position: relative;}
footer .in a:link    { color:#000; text-decoration: none; }
footer .in a:visited { color:#000; text-decoration: none; }
footer .in a:hover   { color:var(--opa-color); text-decoration: none; }
footer .in a:active  { color:#000; 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; }
}

@media screen and (min-width: 600px) and (max-width: 899px) {
	footer .in .fLogo { width: 180px; margin-bottom: 20px;  }
	footer .f-flex-R { display: flex; flex-direction: column; justify-content: flex-end; flex-wrap: wrap; width: 40%; }
}
@media screen and (min-width: 900px) and (max-width: 1089px) {
	footer .f-flex-L { width: 25%; }
}
@media screen and (min-width: 1090px) and (max-width: 1289px) {	
	footer .f-flex-L { width: 25%; }
}

/*-- copyright ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	#copyright { text-align:center; margin-bottom:0px; padding:1px 0; color:#000; font-size:12px; }
}
@media screen and (min-width: 600px) {
	#copyright { text-align:center; margin-bottom:0px; padding:1px 0; color:#000; font-size:12px; }
}
/*-- pagetop ------------------------------------------------------------*/
#pagetop { background: var(--opa-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%; }
}

/*-- box LINK ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.box_link_btn a { color:var(--base-color); width:80%; height:30px; line-height:30px; border:var(--base-color) 1px solid; display:block; text-align:center; margin:0 10%; background:#fff; font-size: 12px; position: relative; transition: .3s; }
	.box_link_btn a:link    { color:var(--base-color); text-decoration: none; }
	.box_link_btn a:visited { color:var(--base-color); text-decoration: none; }
	.box_link_btn a:hover   { color:#fff; text-decoration: none; background: var(--base-color); letter-spacing: 0.1em; }
	.box_link_btn a:active  { color:#000; text-decoration: none; }
	.box_link_btn a:after { content: ""; position: absolute; top: 50%; right: 0px; z-index: 1; transform: translateY(-50%); width: 20px; height: 1px; background: var(--base-color); }
	.box_link_btn a:hover:after { content: ""; position: absolute; top: 50%; right: 0px; z-index: 1; transform: translateY(-50%); width: 25px; height: 1px; background: #fff; }
}
@media screen and (min-width: 600px) {
	.box_link_btn a { color:var(--base-color); width:300px; height:35px; line-height:35px; border:var(--base-color) 1px solid; display:block; text-align:center; margin:0 auto; background:#fff; font-size: 13px; position: relative; transition: .3s; }
	.box_link_btn a:link    { color:var(--base-color); text-decoration: none; }
	.box_link_btn a:visited { color:var(--base-color); text-decoration: none; }
	.box_link_btn a:hover   { color:#fff; text-decoration: none; background: var(--base-color); letter-spacing: 0.1em; }
	.box_link_btn a:active  { color:var(--base-color); text-decoration: none; }
	.box_link_btn a:after { content: ""; position: absolute; top: 50%; right: 0px; z-index: 1; transform: translateY(-50%); width: 20px; height: 1px; background: var(--base-color); }
	.box_link_btn a:hover:after { content: ""; position: absolute; top: 50%; right: 0px; z-index: 1; transform: translateY(-50%); width: 25px; height: 1px; background: #fff; }
	
	.box_link_btn_L a { margin: 0 0;}
	
	.box_link_btn_300 a { width: 300px; margin: 0 auto;}
	.box_link_btn_80 a { width: 80%; margin: 0 auto;}
	.box_link_btn_200 a { width: 200px; margin: 0 auto; height:30px; line-height: 30px; font-size: 0.8rem; }
}
@media screen and (min-width: 600px) and (max-width: 899px) {
	.box_link_btn a { width: 60%;}
}
	
.fa-window-restore { opacity: 0.5; }
/*-- text-shadow ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.tShadow {
		text-shadow: 2px 2px 2px rgba(0,0,0,0.7), -2px -2px 2px rgba(0,0,0,0.7), -2px 2px 2px rgba(0,0,0,0.7), 2px -2px 2px rgba(0,0,0,0.7), 2px 0px 2px rgba(0,0,0,0.7), -2px -0px 2px rgba(0,0,0,0.7), 0px 2px 2px rgba(0,0,0,0.7), 0px -2px 2px rgba(0,0,0,0.7);
	}
	.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.7), -3px -3px 3px rgba(0,0,0,0.7), -3px 3px 3px rgba(0,0,0,0.7), 3px -3px 3px rgba(0,0,0,0.7), 3px 0px 3px rgba(0,0,0,0.7), -3px -0px 3px rgba(0,0,0,0.7), 0px 3px 3px rgba(0,0,0,0.7), 0px -3px 3px rgba(0,0,0,0.7);
	}
	.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;
	}	
}

/*-- 背景固定　パララックス -------------------------------------------------------------*/

@media screen and (max-width: 899px){
	.parallax_content { height: 100px; overflow: hidden; position: relative; background: none; padding: 10vh 0;  }	
	.parallax_content::before {
		position: absolute;
		top: 0;
		left: 0;
		content:"";
		display: flex;
		height: 100%;
		padding: 100%;
		justify-content: center;
		align-items: center;
		background-image: url("../img/common/palabg_sp.jpg") ;
		background-attachment: fixed;
		background-size: cover;
		background-repeat: no-repeat;
	}
}
@media screen and (max-width: 599px){
	.parallax_content { height: 100px; overflow: hidden; }	
}
@media screen and (min-width: 900px) and (max-width: 1079px) {
	.parallax_content { height: 150px; overflow: hidden; position: relative; background: none; padding: 10vh 0;  }	
	.parallax_content::before {
		position: absolute;
		top: 0;
		left: 0;
		content:"";
		display: flex;
		height: 100%;
		padding: 100%;
		justify-content: center;
		align-items: center;
		background-image: url("../img/common/palabg_tab.jpg") ;
		background-attachment: fixed;
		background-size: cover;
		background-repeat: no-repeat;
	}
}
@media screen and (min-width: 1080px) {
	.parallax_content { height: 250px; overflow: hidden; position: relative; background: none; padding: 10vh 0; }	
	.parallax_content::before {
		position: absolute;
		top: 0;
		left: 0;
		content:"";
		display: flex;
		height: 100%;
		padding: 100%;
		justify-content: center;
		align-items: center;
		background-image: url("../img/common/palabg.jpg") ;
		background-attachment: fixed;
		background-size: cover;
		background-repeat: no-repeat;
	}
}
@media screen and (min-width: 1080px) and (min-width: 1289px) {
	.parallax_content { height: 200px; }
}
@media screen and (max-width: 599px) {		
	.inCopy { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 2; width: 100%; }
	.inCopy h4 { color: #333; text-align: center; margin-bottom: 10px; font-size: 0.9rem; font-weight: bold; }
	.inCopy p { color: #333; text-align: center; margin-bottom: 0; font-size: 0.7rem;  }
}
@media screen and (min-width: 600px) {	
	.inCopy { position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%); z-index: 2; }
	.inCopy h4 { color: #333; text-align: center; margin-bottom: 10px; font-size: 1.0rem; font-weight: bold; }
	.inCopy p { color: #333; text-align: center; margin-bottom: 0; font-size: 1.0rem;  }
	.inCopy .box_link_btn a { width: 300px; margin: 0 auto; border: 1px solid #333; }
}
@media screen and (min-width: 600px) and (max-width: 899px)  {
	.inCopy { width: 100%; }
	.inCopy h4 { font-size: 1.0rem; }
	.inCopy p { font-size: 0.75rem;  }
}
@media screen and (min-width: 900px) and (max-width: 1079px)  {
	.inCopy h4 { font-size: 1.1rem; }
	.inCopy p { font-size: 0.8rem;  }
}
@media screen and (min-width: 1080px) and (max-width: 1179px)  {
	.inCopy h4 { font-size: 1.15rem; }
	.inCopy p { font-size: 0.85rem;  }
}
@media screen and (min-width: 1180px) and (max-width: 1279px)  {
	.inCopy h4 { font-size: 1.2rem; }
	.inCopy p { font-size: 0.9rem;  }
}
@media screen and (min-width: 1280px) and (max-width: 1379px)  {
	.inCopy h4 { font-size: 1.25rem; }
	.inCopy p { font-size: 0.95rem;  }
}
@media screen and (min-width: 1380px) {
}

/*-- sp tbl overscroll ------------------------------------------------------------*/
@media screen and (max-width: 599px) {
	.scroll { overflow-y: scroll; padding: 0 4% 4%; margin-bottom: 60px; max-height: 80vh; }
	.scroll::-webkit-scrollbar { width: 6px; }
	.scroll::-webkit-scrollbar-track { margin: 0 2px; background: #ccc; border-radius: 5px; }
	.scroll::-webkit-scrollbar-thumb { border-radius: 5px; background: #666; }
}
@media screen and (min-width: 600px) {
	.scroll { overflow-y: scroll; padding: 0 4% 4%; margin-bottom: 60px; max-height: 80vh; }
	.scroll::-webkit-scrollbar { width: 10px; }
	.scroll::-webkit-scrollbar-track { margin: 0 2px; background: #ccc; border-radius: 5px; }
	.scroll::-webkit-scrollbar-thumb { border-radius: 5px; background: #666; }
	
	.scroll-x { overflow-x: scroll; }
}
/*-- 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;}

.list_C { width: fit-content; margin: 0 auto; }

/*-- ol number list ------------------------------------------------------------*/
ol.nrml { counter-reset: item; list-style-type: none; padding-left: 0; }
ol.nrml li{ text-indent: -1.3em; padding-left: 1.3em; }
ol.nrml li:before { counter-increment: item; content: counter(item)'.'; padding-right: .5em; font-weight: bold; color: #000;}

ol.maru { list-style-type: none; counter-reset: number; }
ol.maru li { position: relative;}
ol.maru li::before { content: counter(number); counter-increment: number; padding: 0 0.2em; }
ol.maru li::after { content: ''; position: absolute; display: block; top: 50%; left: 0; transform: translateY(-50%); width: 1em; height: 1em; border: 1px solid #000; border-radius: 50%;}

/*-- arrow list ------------------------------------------------------------*/
.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:"Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:var(--sub-color); }

.arrow_list_w { margin-bottom:40px; }
.arrow_list_w li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; border-bottom:1px dotted #DEDEDE; }
.arrow_list_w li:before { content:"»"; margin-right:10px; color:var(--base-color); }
.arrow_list_w li span { margin-right: 1em; font-size: 0.9em; }
@media screen and (max-width: 599px) {
	.arrow_list_w li a { display: block; text-indent:0em; padding-left:0em; }
}

.arrow_list_down { margin-bottom:20px; }
.arrow_list_down li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; border-bottom:1px dotted #DEDEDE; }
.arrow_list_down li:before { content:"\f107"; font-family:"Font Awesome 5 Free"; font-weight: bold; margin-right:10px; color:var(--base-color); }

.dot_list { margin-bottom:20px; }
.dot_list li { padding:5px 0; text-indent:-1.0em; padding-left:1.0em; }
.dot_list li:before { content:"●"; margin-right:10px; color:var(--base-color); }

.check_list { margin-bottom:20px; }
.check_list li { padding:5px 0; text-indent:-1.5em; padding-left:2.0em; }
.check_list li:before { content:"\f00c"; font-family:"Font Awesome 5 Free"; font-weight: 900; margin-right:10px; color:var(--sub-color); }


.bkCheck_list { margin-bottom: 0px; }
.bkCheck_list li { padding-left: 2.0em; }
.bkCheck_list li:before { content:"\f00c"; font-family:"Font Awesome 5 Free"; font-weight: 900; margin-right:10px; color:#000; }

/*-- スマホメニュー開閉背景の色 ------------------------------------------------------------*/
.mm-menu { background:#54A583 !important; color:rgba(0, 0, 0, 0.7)  !important; }

/*--wordpress投稿　段落 ------------------------------------------------------------*/
.single_section h1 { font-size:2.4em; color:#333; font-weight:bold; margin-bottom:20px; }
.single_section h2 { font-size:2.1em; color:#333; font-weight:bold; border-left:6px solid #50A8ED; padding-left:2%; margin-bottom:20px; }
.single_section h3 { font-size:1.8em; color:#50A8ED; font-weight:bold; padding:2% 0; border-bottom:#333333 1px solid; margin-bottom:20px; }
.single_section h4 { font-size:1.2em; color:var(--sub-color); font-weight:bold; margin-bottom:10px; }
.single_section h5 { font-size:1.1em; color:var(--base-color); font-weight:bold; margin-bottom:10px; }
.single_section p { line-height:1.7 !important; font-size:1.0em !important; margin-bottom:40px !important; }
.single_section p.xsmall { font-size: 0.8em !important; }
.single_section img { margin-bottom:10px !important; }
.single_section strong { font-size: 1.1em; color:var(--base-color); }

/*--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 ページャーカラー ------------------------------------------------------------*/
#pager a:hover { background: #ccc !important; }
#pager .pages, #pager .current, #pager .extend, #pager a { color: #333 !important; background: #fff !important; }
#pager a { color: #333 !important;  }
#pager .pages, #pager .current { background: #dedede !important;}
#pager a.page { border: 1px solid #dedede; }

/*-- 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: #ef5555; }
.blk {color:#000;}
.endi { color: var(--base-color);}

.under {text-decoration:underline; border-color:#666;}

.marker { background:linear-gradient(transparent 60%, #ffff00 60%); }

.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; }
.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; }
}

/* モーダル全体のスタイル */
.video-modal {
    display: none; /* 初期は非表示 */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.8); /* 背景を半透明に */
    justify-content: center; /* 横方向中央 */
    align-items: center;     /* 縦方向中央 */
    z-index: 9999;
}

/* 表示時にFlexを有効化 */
.video-modal.show {
    display: flex;
}

/* モーダルの中身（動画コンテナ） */
.video-content {
    position: relative;
    max-width: 80%;
    width: 900px;
    /*background: #000;
    padding: 10px;*/
    box-sizing: border-box;
    border-radius: 8px;
}

/* 動画を100%幅で表示 */
.video-content video {
    width: 100%;
    height: auto;
    border-radius: 4px;
}

/* 閉じるボタン */
.close-modal {
    position: absolute;
    top: -40px;
    right: 0;
    font-size: 32px;
    color: #fff;
    cursor: pointer;
    font-weight: bold;
    line-height: 1;
    transition: 0.3s;
}

.close-modal:hover {
    color: #f00;
}

/* スマホ対応 */
@media screen and (max-width: 768px) {
    .video-content {
        width: 90%;
        max-width: 90%;
    }
}

