
/* ----------------------------------------------------------------
	Global 
-----------------------------------------------------------------*/

/* title */
.el_ttl_gl {
	font-size: 36px;
	padding-bottom: 1em; 
	margin-left: -2px;
}
.el_ttl_gl:before {
	width: 50px;
	height: 1px;
	background: #e03819;
	left: 0;
	bottom: 0;
}
.el_ttl_lsz {
	font-size: 30px;
}
.el_ttl_msz {
	font-size: 26px;
}
@media screen and (max-width :767px) {
	.el_ttl_gl {
		font-size: 31px;
	}
	.el_ttl_lsz {
		font-size: 28px;
	}
	.el_ttl_msz {
		font-size: 23px;
	}
}

/* iframe */
.el_umekomi_wrap iframe {
	max-width: 100%;
}



/* ----------------------------------------------------------------
	Header
-----------------------------------------------------------------*/

.gl_h {
	position: fixed;
	width: 100%;
	background: #fff;
	top: 0;
	z-index: 100;
	transform: translateY(-100%);
	transition: transform 0.6s ease, opacity 0.6s ease;
}
.gl_h.is-visible {
	transform: translateY(0);
}
.gl_h_in {
	display: flex;
	align-items: flex-end;
	min-height: 76px;
}
.gl_h_inlogo {
	width: 425px;
	padding: 0 20px 15px;
}
.gl_hin_nav {
	width: calc( 100% - 425px);
	padding: 0 20px 15px;
	text-align: center;
}
.navbar-nav li { 
	display: inline-block;
	padding: 0 1em;
	margin: .25em 0;
	vertical-align: bottom;
}
.navbar-nav li a { 
	text-decoration: none;
}

@media (max-width: 1024px) {
	.gl_h_in {
		align-items: center;
	}
	.gl_h_inlogo {
		width: 280px;
	}
	.gl_hin_nav {
		width: calc( 100% - 280px);
	}
	ul.navbar-nav li a { 
		font-size: .9em;
	}
}
@media screen and (max-width :767px) {
	#top-head { 
		position: fixed !important;
		z-index: 999;
	}
	.gl_h_in {
		min-height: 60px;
		box-shadow: 4px 0 6px 1px rgba(0, 0, 0, 0.10);
	}
	.gl_h_inlogo {
		width: 260px;
		padding: 0 0 0 10px;
	}
	
	/* sp nav */
	
	.gl_h_spmenu {
		position: fixed;
		top: 60px;
		right: -280px;
		width: 280px;
		height: 100vh;
		background: rgba(255, 255, 255, 0.95);
		z-index: 999;
		transition: right 0.3s ease-in-out;
	}
	body.open .gl_h_spmenu {
	  right: 0;
	}
	.gl_h_spmenu li {
		text-align: center;
	}
	.gl_h_spmenu a {
		display: block;
		color: #1a1a1a;
		text-decoration: none;
		padding: .8em 1.5em;
		border-bottom: 1px solid #8f8f8f;
	}
	
	/* Toggle Button */
	#nav-toggle {
		position: absolute;
		width: 60px;
		height: 60px;
		right: 0;
		top: 0;
		padding: 0 15px;
/* 		margin-right: 10px; */
		cursor: pointer;
		z-index: 101;
	}
	#nav-toggle div { position: relative; }
	#nav-toggle span {
		display: block;
		position: absolute;
		height: 1px;
		width: 35px;
		background: #261e1c;
		right: 0;
		-webkit-transition: .35s ease-in-out;
		-moz-transition: .35s ease-in-out;
		transition: .35s ease-in-out;
		text-align: center !important;
	}
	#nav-toggle span:nth-child(1) { top: 17px; }
	#nav-toggle span:nth-child(2) { top: 28px; }
	#nav-toggle span:nth-child(3) { top: 40px; }
	
	body #nav-toggle, body .container h1 {
		-webkit-transition: 0.4s;
		-moz-transition: 0.4s;
		-o-transition: 0.4s;
		-ms-transition: 0.4s;
		transition: 0.4s;
	}
	
	/* open */
	.open .nav_overlay {
		position: fixed;
		display: block;
		background: rgba(0, 0, 0, 0.55) none repeat scroll 0 0;
		height: 100vh;
		width: 100%;

		top: 60px;
		left: 0;
		z-index: 998;
	}
	.open #nav-toggle span:nth-child(1) {
		top: 30px;
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	.open #nav-toggle span:nth-child(2) { 
		display: none;
	}
	.open #nav-toggle span:nth-child(3) {
		top: 30px;
		-webkit-transform: rotate(45deg);
		-moz-transform: rotate(45deg);
		transform: rotate(45deg);
	}
}






/* ----------------------------------------------------------------
	Footer
-----------------------------------------------------------------*/

.lp_f_wrap {
	background: url(../img/f_back.png) no-repeat center bottom;
}
.f_gl {
	color: #000;
	border-top: 1px solid #b3b3b3;
	padding: 50px 0 30px;
}
.f_gl a {
	color: #000;
}
.f_bg_nav li {
	display: inline-block;
	padding: 0 1em;
}
.f_gl small {
	font-size: 13px;
}
@media screen and (min-width :1320px) {
	.lp_f_wrap {
		background-size: cover;
	}
}
@media screen and (max-width :1319.9999px) {
	.lp_f_wrap {
		background-size: auto;
	}
}

a.f_gl_topback {
	position: fixed;
	width: 82px;
	height: 82px;
	font-size: 16px;
	color: #fff;
	text-decoration: none;
	background: rgba(0, 0, 0, 0.6);
	border-radius: 50%;
	right: 5%;
	bottom: 40px;
}
a.f_gl_topback span {
	display: inline-block;
	padding-top: 15px;
	top: 22px;
}
a.f_gl_topback span::before {
	width: 15px;
	height: 15px;
	border-right: 1px solid #fff;
	border-top: 1px solid #fff;
	transform: rotate( -45deg);
	top: 0;
	left: 0;
	right: 0;
}
@media screen and (max-width :767px) {
	a.f_gl_topback {
		position: fixed;
		width: 60px;
		height: 60px;
		font-size: 13px;
		right: 14px;
		bottom: 18px;
	}
	a.f_gl_topback span {
		padding-top: 13px;
		top: 15px;
	}
	a.f_gl_topback span::before {
		top: 3px;
		width: 12px;
		height: 12px;
	}
}



/* ----------------------------------------------------------------
	contents
-----------------------------------------------------------------*/

.lp_asirai {
	position: fixed;
	right: 5%;
	top: 80px;
	z-index: 101;
}

/* mainvl */

.lp_mainvl {
	position: relative;
	text-align: center;
	background: url(../img/mv_img.jpg) no-repeat center top;
	min-height: 900px;
}
.lp_mainvl h1 {
	position: absolute;
	width: 100%;
	max-width: 825px;
	top: 53.5%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.lp_mainvl_menu {
	padding: 20px 20px 0;
}
.lp_mainvl_menu li {
	display: inline-block;
	margin: 0 1em;
}
.lp_mainvl_menu li a {
	color: #fff;
	text-decoration: none;
}
.lp_mainvl_menu li a:hover {
	border-bottom: 1px solid #fff;
}

@media screen and (min-width :1320px) {
	.lp_mainvl {
		background-size: cover;
	}
}
@media screen and (max-width :1319.9999px) {
	.container.boxm {
		background-size: auto;
	}
}
@media screen and (max-width :1000px) {
	.lp_mainvl h1 {
		width: 86%;
	}
}
@media screen and (max-width :767px) {
	.lp_mainvl {
		min-height: 600px;
	}
}


/* about */

.lp_about_txt {
	width: 50%;
	padding-left: 28px;
}
.lp_about_img {
	width: 50%;
	padding-right: 28px;
}

@media screen and (max-width :767px) {
	.lp_about_txt {
		width: 100%;
		padding-left: 10px;
		padding-right: 10px;
	}
	.lp_about_img {
		width: 80%;
		padding-right: 0;
	}
}


/* gaiyou */

.lp_gaiyou table,
.lp_gaiyou table td,
.lp_gaiyou table th {
	background: none;
	border-top: none;
	border-bottom: none;
}
.lp_gaiyou table th {
	min-width: 8em;
	padding-left: 0;
}

@media screen and (max-width :767px) {
	.lp_gaiyou table th {
		padding-bottom: 0;
	}
	.lp_gaiyou table td {
		padding-top: 5px;
		padding-left: 0;
		padding-right: 0;
	}
}

.lp_gaiyou_event {
	padding: 50px 40px;
	background: #fff;
}
.lp_gaiyou_event::before {
	width: 150px;
	height: 150px;
	border-left: 1px solid #261e1c;
	border-top: 1px solid #261e1c;
	top: 0;
	left: 0;
}
.lp_gaiyou_event::after {
	width: 150px;
	height: 150px;
	border-right: 1px solid #261e1c;
	border-bottom: 1px solid #261e1c;
	bottom: 0;
	right: 0;	
}
@media screen and (max-width :767px) {
	.lp_gaiyou_event {
		padding: 40px 30px;
		background: #fff;
	}
	.lp_gaiyou_event::before {
		width: 100px;
		height: 100px;
	}
	.lp_gaiyou_event::after {
		width: 100px;
		height: 100px;
	}
}

/* news */

.lp_news li {
	border-bottom: 1px solid #b3b3b3;
}
.lp_news_day {
	width: 150px;
	color: #231815;
	padding: 17px 20px 17px 0;
}
.lp_news_cont {
	width: calc( 100% - 150px);
	padding: 15px 30px 7px 20px;	
}
@media screen and (max-width :860px) {
	.lp_news_day {
		width: 100%;
		padding: 17px 15px 7px 0;
	}
	.lp_news_cont {
		width: 100%;
		padding: 0 15px 7px 0;	
	}
	.lp_news_cont p {
		line-height: 1.5;	
	}
}

/* tenji */

.lp_tenji {
	border-bottom: 1px solid #b3b3b3;
	overflow: hidden;
}

.lp_tenji_mttl {
	position: relative;
	text-align: center;
	background: url(../img/tenji_ttl_img.jpg) no-repeat center top;
	min-height: 500px;
	color: #fff;
	font-size: 36px;
	margin-bottom: 50px;
}
.lp_tenji_mttl span {
	position: absolute;
	max-width: 825px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
@media screen and (min-width :1320px) {
	.lp_tenji_mttl {
		background-size: cover;
	}
}
@media screen and (max-width :1319.9999px) {
	.lp_tenji_mttl {
		background-size: auto;
	}
}
@media screen and (max-width :767px) {
	.lp_tenji_mttl {
		min-height: 360px;
		font-size: 32px;
	}
}

/* tenji chapter */

.lp_tcap {
	position: relative;
	max-width: 1060px;
	margin: 0 auto;
	display: flex;
}

/* tenji chapter header */

.lp_tcap_h {
	position: relative;
}
.lp_tcap_hbg {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 50vw;
	height: 440px;
	mix-blend-mode: multiply;
	z-index: 1;
	opacity: 0;
	transform: translateX(-500px);
	transition: all 2s ease;
}
.lp_tcap_hbg__1 {background: rgba(225, 56, 26, 1);}
.lp_tcap_hbg__2 {background: #f8d700; width: 55vw;}
.lp_tcap_hbg__3 {background: #00a7ea; width: 47vw;}
.lp_tcap_h.animate .lp_tcap_hbg { opacity: 1; transform: translateX(0); }

.lp_tcap_hintxt {
	position: relative;
	display: flex;
	max-width: 1060px;
	margin: 0 auto;
	z-index: 2;
	color: #fff;
}
.lp_tcap_hintxt_in {
	position: relative;
	flex: 0 0 50%;
	padding: 0;
	height: 440px;
	opacity: 0;
	transform: translateX(-500px);
	transition: all 2s ease;
}
.lp_tcap_h.animate .lp_tcap_hintxt_in { opacity: 1; transform: translateX(0);}

.lp_tcap_hintxt_in h2 {	
	font-size: 40px;
	margin: 25px 40px 20px 10px;
}
.lp_tcap_hintxt_in h3 {
	font-size: 26px;
	margin-left: 10px;
}
.lp_tcap_hintxt_in img {
	position: absolute;
	bottom: 0;
	left: 10px;
}

.lp_tcap_hinimg {
	position: relative;
	display: flex;
	max-width: 1060px;
	margin: 0 auto;
	z-index: 0;
}
.lp_tcap_hinimg_in {
	position: absolute;
	width: 62.3%;
	flex: 0 0 58%;
	margin-left: 0;
	z-index: 0;
	right: 0;
	bottom: -120px;
	opacity: 0;
	transform: translateX(500px);
	transition: all 1s ease;
}
.lp_tcap_h.animate .lp_tcap_hinimg_in { opacity: 1; transform: translateX(0); }

.lp_tcap_read {
	padding-top: 180px;
}
.lp_tcap_readin {
	width: 60%;
}

/* tenji chapter header #cap2 */

#cap2 .lp_tcap_hbg {
	left: auto;
	right: 0;
	transform: translateX(500px);
}
#cap2 .lp_tcap_h.animate .lp_tcap_hbg { transform: translateX(0); opacity: 1;}

#cap2 .lp_tcap_hintxt {
	flex-direction: row-reverse;
	text-align: right;
}
#cap2 .lp_tcap_hintxt_in {
	transform: translateX(500px);
}
#cap2 .lp_tcap_h.animate .lp_tcap_hintxt_in { transform: translateX(0); opacity: 1;}

#cap2 .lp_tcap_hintxt_in h2 {	
	text-align: left;
	margin: 25px 0 20px 48px;
}
#cap2 .lp_tcap_hintxt_in h3 {
	text-align: left;
	margin-left: 48px;
}
#cap2 .lp_tcap_hintxt_in img {
	position: absolute;
	bottom: 0;
	left: inherit;
	right: 0;
}
#cap2 .lp_tcap_hinimg_in {
	width: 50%;
	text-align: right;
	right: auto;
	left: 0;
	bottom: -320px;
	transform: translateX(-500px);
}
#cap2 .lp_tcap_h.animate .lp_tcap_hinimg_in { transform: translateX(0); opacity: 1; }

#cap2 .lp_tcap_read {
	padding-top: 120px;
}
#cap2 .lp_tcap_readin {
	width: 45%;
	margin-left: 55%;
}

@media screen and (max-width :1080px) {
	/* tenji chapter header */
	.lp_tcap_read {
		padding-left: 40px;
	}
	/* tenji chapter header #cap2 */
	#cap2 .lp_tcap_read {
		padding-right: 30px;
	}
}
@media screen and (max-width :767px) {
	/* tenji chapter header */
	.lp_tcap_hbg {
		width: 80vw;
		height: 360px;
		transition: all 1.5s ease;
	}
	.lp_tcap_hbg__2 {width: 80vw;}
	.lp_tcap_hbg__3 {width: 80vw;}
	
	.lp_tcap_hintxt_in {
		flex: 0 0 80%;
		height: 360px;
		transition: all 1.5s ease;
	}
	
	.lp_tcap_hintxt_in h2 {	
		font-size: 34px;
		margin: 25px 20px 20px 15px;
	}
	.lp_tcap_hintxt_in h3 {
		font-size: 23px;
		margin-left: 15px;
	}
	.lp_tcap_hintxt_in img {
		width: 80px;
	}
	
	.lp_tcap_hinimg_in {
		position: relative;
		width: 95%;
		flex: 0 0 95%;
		margin-left: inherit;
		margin-right: 0;
		bottom: 30px;
		opacity: 1;
		transform: translateX(50px);
	}
	.lp_tcap_h.animate .lp_tcap_hinimg_in { opacity: 1; transform: translateX(0); }
	
	.lp_tcap_read {
		padding-top: 30px;
		padding-left: 0;
	}
	.lp_tcap_readin {
		width: 100%;
		padding: 0 25px;
	}
	
	/* tenji chapter header #cap2 */
	
	#cap2 .lp_tcap_hintxt_in h2 {	
		margin: 25px 0 20px 30px;
	}
	#cap2 .lp_tcap_hintxt_in h3 {
		margin-left: 30px;
	}
	#cap2 .lp_tcap_hintxt_in img {
		position: absolute;
		bottom: 0;
		left: inherit;
		right: 0;
	}
	#cap2 .lp_tcap_hinimg_in {
		width: 70%;
		flex: 0 0 70%;
		text-align: left;
		margin-right: inherit;
		margin-left: 0;
		bottom: 30px;
		opacity: 1;
		transform: translateX(-50px);
	}
	#cap2 .lp_tcap_h.animate .lp_tcap_hinimg_in { opacity: 1; transform: translateX(0); }
	
	#cap2 .lp_tcap_read {
		padding-top: 30px;
		padding-right: 0;
	}
	#cap2 .lp_tcap_readin {
		width: 100%;
		margin-left: 0;
	}
	
}


/* tenji chapter naiyou */

.lp_tcap_wd_wrap::before {
	width: 100%;
	height: 300px;
	background: #f3f2e8;
	left: 0;
	top: 0;
	z-index: -1;
}
.lp_tcap_wd {
	justify-content: space-around;
	flex-wrap: nowrap;
}
.lp_tcap_sakuhin {
/* 	max-height: 300px; */
	overflow: hidden;
}
.lp_tcap_sakuhin img {
	max-height: 100%;
	transition: transform 0.3s ease;
}
.lp_tcap_sakuhin img:hover {
	transform: scale(1.1);
}
@media screen and (max-width :1319.9999px) {
	.lp_tcap_wd_wrap::before {
		display: none;
	}
}
@media screen and (max-width :767px) {
	.lp_tcap_wd {
		justify-content: center;
		flex-wrap: wrap;
	}
	.lp_tcap_wd figure {
		width: 60%;
	}
	.lp_tcap_wd figure img {
		width: 100%;
	}
}
@media screen and (max-width :560px) {
	.lp_tcap_wd figure {
		width: 80%;
	}
}

/* tenji chapter 1 */

.lp_tcap1_i1::before {
	width: 80px;
	height: 80px;
	background: #e03819;
	right: -87%;
	bottom: -80px;
	z-index: -1;
}
.lp_tcap1_i2::before {
	width: 180px;
	height: 180px;
	background: #e03819;
	left: -1260px;
	right: 0;
	bottom: -100px;
	z-index: -1;
}
@media screen and (max-width :767px) {
	.lp_tcap1_i1::before {
		width: 70px;
		height: 70px;
		right: -40px;
		bottom: -60px;
	}
	.lp_tcap1_i2::before {
		width: 120px;
		height: 120px;
		left: -50px;
		right: inherit;
		bottom: -120px;
	}
}

/* tenji chapter 2 */

.lp_tcap2_i1::before {
	width: 80px;
	height: 80px;
	background: #f8d700;
	right: 30px;
	bottom: -150px;
	z-index: -1;
}

.lp_tcap2_subimage01 {
	width: 57%;
	margin-left: -60px;
	padding-top: 30px;
	margin-bottom: 30px;
}
.lp_tcap2_subimage02 {
	width: 43%;
	padding-top: 30px;
	margin-bottom: 80px;
	padding-left: 20px;
}

.lp_tcap_profimg {
	width: 160px;
}
.lp_tcap_proftxt {
	width: calc( 100% - 190px);
	margin-left: 30px;
}
.lp_tcap_profmain dt {
	float: left;
	margin-right: 1em;
}
@media screen and (max-width :767px) {
	.lp_tcap2_i1::before {
		right: 25px;
		bottom: -200px;
	}
	.lp_tcap2_subimage01 {
		width: 70%;
		margin-left: -25px;
		padding-top: 0;
	}
	.lp_tcap2_subimage02 {
		width: 60%;
		margin-left: 27%;
		padding-top: 0;
		margin-bottom: 60px;
		padding-left: 20px;
	}
	.lp_tcap_profimg {
		width: 140px;
	}
	.lp_tcap_proftxt {
		width: 100%;
		margin-left: 0;
	}
}

/* tenji chapter 3 */

.lp_tcap3_i1::before {
	width: 200px;
	height: 200px;
	background: #00a7ea;
	mix-blend-mode: multiply;
	right: -92%;
	top: -160px;
}

.lp_tcap_3kikaku {
	padding: 50px 40px;
}
.lp_tcap_3kikaku::before {
	width: 150px;
	height: 150px;
	border-left: 1px solid #261e1c;
	border-top: 1px solid #261e1c;
	top: 0;
	left: -60px;	
}
.lp_tcap_3kikaku::after {
	width: 150px;
	height: 150px;
	border-right: 1px solid #261e1c;
	border-bottom: 1px solid #261e1c;
	bottom: 0;
	right: -60px;	
}
@media screen and (max-width :1080px) {
	.lp_tcap_3kikaku::before {
		left: -20px;	
	}
	.lp_tcap_3kikaku::after {
		right: -20px;	
	}
}
@media screen and (max-width :767px) {
	.lp_tcap_3kikaku {
		padding: 50px 20px;
	}
	.lp_tcap_3kikaku::before {
		width: 100px;
		height: 100px;
		left: -10px;	
	}
	.lp_tcap_3kikaku::after {
		width: 100px;
		height: 100px;
		right: -10px;	
	}
}



/* access */

.lp_access {
	border-bottom: 1px solid #b3b3b3
}
.lp_access_ttl {
	width: 17%;
	margin-right: 5%;
}
.lp_access_map {
	width: 78%;
}
@media screen and (max-width :767px) {
	.lp_access_ttl {
		width: 100%;
		margin-right: 0;
	}
	.lp_access_map {
		width: 100%;
	}
}


