@charset "utf-8";
/* CSS Document */
/***** 共通 *****/
body{
	font-family: 'Noto Serif JP', serif;
	font-size: 16px;
	letter-spacing: .2rem;
}
h1,h2,h3,h4,h5,h6{
	font-weight: normal;
}
h3.ttl{
	font-size: 24px;
	text-align: center;
}
h3.ttl em{
	border-bottom: #850000 2px solid;
}
img{
	/* width: 100%; */
	width: auto;
	max-width: 100%;
	height: auto;
}

a{
	text-decoration: none;
	color: inherit;
	transition: opacity .25s ease-in-out;
}
a:hover{
	opacity: .65;
}
em{
	font-style: normal;
}
.font_beau{
	font-family: 'Beau Rivage', cursive;
}
section{
	/* max-width: 1200px; */
	margin: 0 auto;
}
.pc{
	display: block;
}
.sp{
	display: none;
}
/***** 共通 end *****/
/***** header *****/
header{
	/* max-width: 1200px; */
	width: 100%;
	display: flex;
	justify-content: center;
    /* align-items: center; */
	/* align-items: end; */
	align-items: flex-end;
	padding: 25px 50px;
	box-sizing: border-box;
	/* position: fixed; */
	background:#fff;
	position: sticky;
	position: -webkit-sticky;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
	z-index: 10;
	border-bottom: solid 1px;
}
/* header h1{
	width: 27.637%;
}
header h1 img{
	width: 100%;
	max-width: inherit;
} */
header .inner{
	white-space: nowrap;
	margin-left: auto;
}
header .inner .iconbox{
	font-size: 0;
	display: inline-block;
	vertical-align: bottom;
}
header .inner .iconbox li{
	display: inline-block;
	vertical-align: bottom;
	margin-right: 15px;
}
header .inner .iconbox li:last-child{
	margin-right: 30px;
}
header .inner .iconbox li.language{
	font-size: 20px;
}
/* header .inner .exerciselink{
	margin-right: 30px;
} */
.aboutlink{
	display: inline-block;
	width: 181px;
	text-align: center;
	color: #fff;
	background: linear-gradient(to bottom, #be3838, #850000);
	margin-right: 30px;
	padding: 5px 0;
	border-radius: 5px
}
.aboutlink span{
	display: block;
	font-size: 14px;
}




header .inner .header_maplink{
	display: none;
}
header .inner .burger img{
	cursor: pointer;
}

/***** バーガーメニュー *****/

.burgerin{
	display: none;
	width: 100%;
	max-width: 450px;
	padding: 50px;
	background: #404040;
	color: #fff;
	box-sizing: border-box;
	position: absolute;
    top: 0;
    right: 0;
	z-index: 2;
}
.burgerin .burgertop{
	display: flex;
	/* justify-content: space-between; */
	justify-content: flex-end;
    flex-wrap: wrap;
}
.burgerin .burgertop img{
	cursor: pointer;
}
.burgerin .menulist{
	/* margin-top: 80px; */
	margin: 25px auto 0;
}
.burgerin .menulist li{
	font-size: 0;
	border-bottom: solid 1px #fff;
	margin-bottom: 10px;
	padding-bottom: 10px;
}
.burgerin .menulist li i{
	float: left;
	/* display: inline-block;
	vertical-align: top; */
	/* margin-right: 40px; */
}
.burgerin .menulist li p{
	/* display: inline-block;
	vertical-align: top; */
	padding-left: 70px;
	font-size: 18px;
}
.burgerin .menulist li p span{
	display: block;
	font-size: 14px;
}

.menubottom{
	margin-top: 30px;
}
.burgerin .menubottom{
	/* display: flex;
	align-items: flex-end; */
	display: block;
}
.burgerin .menuiconbox{
	margin-top: 20px;
	margin-left: auto;
	font-size: 0;
	display: inline-block;
	vertical-align: bottom;
	white-space: nowrap; 
}
.burgerin .menuiconbox li {
    display: inline-block;
    vertical-align: bottom;
    margin-right: 15px;
}
.burgerin .menuiconbox li:last-child {
	margin-right: 0;
}
.burgerin .menuiconbox li.language{
	font-size: 20px;
}
/***** バーガーメニュー end *****/
/***** header end *****/

/***** footer *****/
footer{
	/* max-width: 1200px; */
	margin: 90px auto 0;
	background: #f3f3f3;
	padding: 90px 0 50px;
}
footer .inner{
	max-width: 1000px;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
    flex-wrap: wrap;
}
footer .inner .text{
	width: 31%;
	font-size: 16px;
}
footer .inner .text h3{
	/* font-size: 24px; */
	text-align: left;
}
footer .inner .text .time{
	margin-top: 15px;
}
footer .inner .text .address,footer .inner .text .place,footer .inner .text .exerciselink{
	display: block;
	margin-top: 20px;
}
footer .inner .text .aboutlink{
	margin-top: 20px;
}
footer .inner .map {
	width: 65%;
	height: 0;
	overflow: hidden;
	padding-bottom: 34.5%;
	position: relative;
}
footer .inner .map iframe{
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}
footer .inner .copy{
	font-size: 14px;
	margin-top: 50px;
	margin-left: auto;
}
footer .inner .copy br{
	display: none;
}
footer .inner .copy a{
	border-bottom: dotted 1px;
}
/***** footer end *****/

/***** 下層共通 *****/
.underlayer .mainvisual{
	/* max-width: 1200px; */
	margin: 0 auto;
	position: relative;
	/* overflow: hidden; */
}
.underlayer .mainvisual img{
	width: 100%;
}
.underlayer .mainvisual h2{
	width: 100%;
	max-width: 1000px;
	padding: 10px 10px 10px 100px;
	/* background-image: linear-gradient(90deg, rgba(0, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 100%); */
	background-image: linear-gradient(90deg, rgba(133, 0, 0, 1) 0%, rgba(0, 0, 0, 0) 100%);
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	margin: auto;
	box-sizing: border-box;
}
.underlayer .mainvisual h2 span{
	display: block;
	font-size: 24px;
	color: #fff;
	line-height: 1;
	border-left: solid 3px #ffffff;
	padding-left: 10px;
}
p.nocomments {
	display: none;
	}
/***** EVENT *****/

.eventarea{
	/* max-width: 1200px;
	margin: 0 auto; */
	max-width: inherit;
	background: #dcd8c6;
	padding: 40px 0;
	overflow: hidden;
}
.eventarea h3{
	/* font-size: 24px; */
	/* color: #fff; */
	/* text-align: center; */
}
.eventarea article{
	max-width: 1000px;
	margin: 20px auto 0;
}
.eventarea ul{
	font-size: 0;
	/* text-align: center; */
	margin:0 -2.5%;
}
.eventarea ul li{
	/* width: 300px;
	margin-left: 50px; */
	/* position: relative; */
	/* width: 30%;
	margin-left: 5%; */
	width: 28.572%;
	margin: 0 2.3%;
	display: inline-block;
	text-align: left;
}
/* .eventarea ul li:first-child{
	margin-left: 0;
} */
.eventarea ul li a{
	position: relative;
	display: block;
	transition: all 0.5s 0s ease;
}
.eventarea ul li a::before{
	content: "";
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	background:linear-gradient(transparent,rgba(0,0,0,0.9));
	transform-origin: left bottom;
  	transform: scale(1, 1);
  	transition: transform .5s;
}
.eventarea ul li a:hover{
	opacity: 1;
}
.eventarea ul li a:hover::before{
	/* background:linear-gradient(transparent,transparent); */
	background-position: -100%;
	/* transform-origin: left bottom; */
	transform: scale(1, 0);
}
.eventarea ul li img{
	min-height: 350px;
	object-fit: cover;
}
.eventarea ul li a em{
	position: absolute;
	top: 10px;
	left: -10px;
	background: #949494;
	padding: 5px 20px;
	font-size: 16px;
	color: #fff;
	line-height: 1;
}
.eventarea ul li p{
	font-size: 20px;
	color: #fff;
	position: absolute;
	bottom: 20px;
	left: 0;
	margin: 0 20px;
	text-shadow: 0px 0px 1px #000000, 0px 0px 5px rgba(0,0,0,0.8);
}
.eventarea ul li p span{
	display: block;
	font-size: 16px;
}
.eventarea .articlelinks {
	color: #fff;
    float: right;
    margin-top: 40px;
}
.eventarea .articlelinks a{
	display: block;
	color: #000;
	/* font-size: 12px; */
}
.eventarea .articlelinks a + a{
	margin-top: 20px;
}
/***** カレンダー *****/
/* 土曜日の色を変える */
.eo-fullcalendar .fc-view-container .fc-view table tbody .fc-widget-content .fc-day-grid-container .fc-day-grid .fc-row .fc-content-skeleton table thead .fc-sun {
color: #7f1311;
}
/* 日曜日の色を変える */
.eo-fullcalendar .fc-view-container .fc-view table tbody .fc-widget-content .fc-day-grid-container .fc-day-grid .fc-row .fc-content-skeleton table thead .fc-sat {
color: #356e88;
}
/***** カレンダー end *****/
/***** EVENT end *****/

/***** column下層 *****/
/* .column_layer{
	max-width: 1200px;
	margin: 90px auto 0;
}
.column_layer .ttlarea{
	max-width: 1000px;
	margin: 0 auto;
}
.column_layer .ttlarea .ttl{
	text-align: left;
}
.column_layer .article{
	max-width: 1000px;
	margin: 40px auto 0;
}
.column_layer .article dl{
	max-width: 700px;
	margin: 0 auto;
	padding-top: 20px;
}
.column_layer .article dt{
	font-size: 20px;
	margin-top: 20px;
}
.column_layer .article dd{
	margin-top: 10px;
} */
/***** column下層 end *****/

/***** 第二下層共通 *****/
.underlayer.second .readarea {
    /* background: url(../img/exercise/read_bg.svg) repeat top left; */
    padding: 90px 0;
}
.underlayer.second .readarea article {
    /* max-width: 700px; */
	text-align: center;
    margin: 0 auto;
}
.underlayer.second .readarea article p {
    font-size: 16px;
    line-height: 2;
    margin-top: 50px;
}
.underlayer.second .contin article{
	max-width: 1000px;
	margin: -30px auto 0;
}

/***** 第二下層共通 end *****/


/***** 下層共通 end *****/
@media screen and (max-width:1200px) {
	header h1{
		width: 27.637%;
	}
	header h1 img{
		width: 100%;
		max-width: inherit;
	}
}
@media screen and (max-width:1000px) {
/***** footer *****/
	footer .inner{
		width: 90%;
		max-width: inherit;
	}
/***** footer end *****/

/***** 下層共通 *****/
/***** EVENT *****/
	.eventarea article{
		width: 90%;
		max-width: inherit;
	}
	.worksarea{
		width: 90%;
		max-width: inherit;
	}
	.partnersarea {
		width: 90%;
		max-width: inherit;
	}
/***** EVENT end *****/

/***** column下層 *****/
/* .column_layer{
	width: 90%;
}
.column_layer .article dd{
	font-size: 16px;
} */
/***** column下層 end *****/

/***** 第二下層共通 *****/
.underlayer.second .contin article{
	width: 90%;
	/* margin: 0 auto; */
}
/***** 第二下層共通 end *****/
/***** 下層共通 end *****/
}

/* @media screen and (max-width:768px) {
} */

@media screen and (max-width:750px) {
/***** 共通 *****/
	body{
		font-size: 19px;
	}
	/* h3.ttl{
		font-size: 28px;
	} */
	.pc{
		display: none;
	}
	.sp{
		display: block;
	}
/***** 共通 end *****/
/***** header *****/
	header{
		padding: 25px 5%;
	}
	header h1{
		/* width: 45%; */
		/* width: 40%; */
    	margin-right: 5%;
	}
	/* header h1 img {
		width: auto;
		max-width: 100%;
	} */
	header .inner .iconbox{
		display: none;
	}
	/* header .inner .aboutlink{
		display: none;
	} */
	header .inner .aboutlink{
		width: 160px;
	}
	.aboutlink{
	width: 71%;
    /* font-size: 2.5vw; */
	font-size: 14px;
	margin-right: 15px;
	}
	/* header .inner .header_maplink{
		display: inline-block;
		margin-right: 40px;
	} */

	/* .aboutlink{
		background: #850000;
	} */
	.burgerin .aboutlink{
		width: 181px;
	}
/***** header end *****/
/***** footer *****/
	footer .inner {
		max-width: 1000px;
		margin: 0 auto;
		display: block;
		justify-content: inherit;
		flex-wrap: inherit;
	}
	footer .inner .text {
		width: auto;
		font-size: 17px;
	}
	footer .inner .text .aboutlink{
		display: block;
		margin: 20px auto 0;
	}
	/* footer .inner .text h3 {
		font-size: 28px;
		text-align: left;
	} */
	footer .inner .map {
		width: 100%;
		margin-top: 40px;
		padding-bottom: 100%;
	}
	footer .inner .copy {
		font-size: 14px;
		/* margin: 50px 0 0; */
	}
	footer .inner .copy br {
		display: block;
	}
	footer .inner .copy a{
		display: inline-block;
		margin-bottom: 10px;
	}
/***** footer end *****/
/***** 下層共通 *****/
	.underlayer .mainvisual h2 span{
		font-size: 28px;
	}
/***** EVENT *****/
		/* .eventarea h3 {
		font-size: 28px;
	} */
	.eventarea article {
		width: 90%;
	}
	.eventarea ul{
		margin: 0;
	}
	.eventarea ul li {
		width: auto;
		margin:20px 0 0;
		display: block;
		font-size: 0;
		margin-top: 0;
	}
	.eventarea ul li img{
		/* width: 40%;
		display: inline-block;
		vertical-align: top; */
	}
	.eventarea ul li p {
		/* width: 60%;
		display: inline-block;
		padding-left: 20px; */
		/* font-size: 24px; */
		position: inherit;
		bottom: inherit;
		margin: 0;
		box-sizing: border-box;
		vertical-align: bottom;
		padding: 10px;
		background-image:radial-gradient(closest-side,rgba(0, 0, 0, 0.8), rgba(85, 85, 85, 1))
	}
	.eventarea ul li a::before{
		display: none;
	}
	.eventarea ul li img{
		min-height: 470px;
		/* min-height: inherit; */
		/* object-fit: none; */
	}
	.eventarea ul .slick-disabled{
		display: none !important;
	}
	.eventarea ul .slick-next,.eventarea ul .slick-prev{
		top: 0;
		bottom: 0;
		margin: auto;
		background: none;
	}

	.eventarea ul .slick-next:before,.eventarea ul .slick-prev:before {
		content: '';
		width: 10px;
		height: 10px;
		border: none;
		top: 0;
		background: #fff;
		border-radius: 50%;
		animation:blink 1s ease-in-out infinite alternate;
	}
	@keyframes blink{
		0% {opacity:0;}
		100% {opacity:1;}
	}
	.eventarea .articlelinks a{
		font-size: 14px;
	}
/***** EVENT end *****/
/***** 下層共通 end *****/
}
@media screen and (max-width:530px) {
	.underlayer .mainvisual h2{
		padding-left: 10%;
	}
}
@media screen and (max-width:440px) {
	.burgerin{
		padding: 25px;
	}
	.burgerin .menulist li i{
		width: 18%;
		margin-right: 0;
	}
	.burgerin .menulist li p{
		width: 82%;
	}
	.burgerin .menubottom div{
		width: 50%;
	}
	.burgerin .menuiconbox{
		width: 50%;
		text-align: right;
	}
}