@charset "utf-8";

@font-face {
	font-family: 'Noto';
	src: url('../fonts/NotoSansCJKjp-Bold.woff') format('woff'),
			 url('../fonts/NotoSansCJKjp-Bold.otf') format('opentype');
	font-weight: 700;
	font-style: normal;
}

@font-face {
	font-family: 'Noto';
	src: url('../fonts/NotoSansCJKjp-Regular.woff') format('woff'),
			 url('../fonts/NotoSansCJKjp-Regular.otf') format('opentype');
	font-weight: 300;
	font-style: normal;
}

@font-face {
	font-family: 'HansSerif';
	src: url('../fonts/SourceHanSerifJP-Bold.woff') format('woff'),
			 url('../fonts/SourceHanSerifJP-Bold.otf') format('opentype');
	font-weight: 700;
	font-style: normal;
}

@font-face {
	font-family: 'HansSerif';
	src: url('../fonts/SourceHanSerifJP-Regular.woff') format('woff'),
			 url('../fonts/SourceHanSerifJP-Regular.otf') format('opentype');
	font-weight: 300;
	font-style: normal;
}



/*//////////////////////////////////////////////////////////

	1: Application all
	2: Flame layout
	3: Decoration
	
//////////////////////////////////////////////////////////*/

/*=========================================================

	Application all

==========================================================*/

html,body{
	margin:0;
	padding:0;
}
html{-webkit-text-size-adjust: 100%;}

body{
	text-align:center;
	font-family: 'Noto';
	line-height:1.5;
	font-size:16px;
	color:#333;
	width:100%;
	background:#fff;
}

a{
	transition: all .5s;
	-webkit-tap-highlight-color: rgba(0,84,122,0.5);
	text-decoration:underline;
	color: #00547A;
}
a:visited{
	color: #00547A;
}
a:hover{
	text-decoration:none;
}

img{
	vertical-align:bottom;
	max-width: 100%;
	height: auto;
	border:0;
}

h1,h2,h3,h4,h5,h6{
	font-weight: 300;
	font-size: 16px;
	padding: 0;
	margin: 0;
}

strong,b{
	font-weight: 700;
}

table{
	width: 100%;
	border-collapse: collapse;
	border: 0;
}
th,td{
	box-sizing: border-box;
	text-align: left;
	vertical-align: top;
	font-weight: 300;
	padding: 0;
	margin: 0;
}

form,p,dl,dd,figure{
	padding: 0;
	margin: 0;
}

ul,ol{
	list-style-position: outside;
	padding: 0;
	margin: 0 0 0 20px;
}

input,select,textarea{
	font-family: 'Noto';
}
button{line-height: 1;}

hr{
	clear: both;
	color: #fff;
	height: 1px;
	padding: 0;
	margin: 0;
	border: 0;
	background: transeparent;
}

address,em{
	font-style: normal;
}



@media screen and (min-width: 737px){ /* PC */
	br.spbr{
		display: none;
	}
}
@media screen and (max-width: 736px){ /* SP */
	br.spbr{
		display: block;
	}
	br.pcbr{
		display: none;
	}
}

::selection {
	color:#fff;
	background: #86d300;
}
::-moz-selection {
	color:#fff;
	background: #86d300;
}





/*=========================================================

	Flame layout

==========================================================*/

#layout{
	position:relative;
	text-align:center;
	width:100%;
}

#header{
	box-sizing: border-box;
	width: 100%;
	border-bottom: 1px solid #ccc;
	background: #fff;
}

#contents{
	text-align:left;
}

#footer{
	width:100%;
	background: #eee;
}

#footer-layout{
	position: relative;
	text-align:left;
	padding: 50px 0;
	margin:0 auto;
}


@media screen and (min-width: 737px){ /* PC */
	#layout{
		padding-top: 71px;
	}
	
	#header{
		position: fixed;
		top: 0;
		left: 0;
		z-index: 9999;
		min-height: 70px;
		padding: 10px 30px;
	}
	
	#contents{
		font-size: 110%;
		width: 930px;
		padding-bottom: 50px;
		margin: 0 auto;
	}
	
	#footer-layout{
		width: 930px;
	}
}

@media screen and (max-width: 736px){ /* SP */
	#contents{
		box-sizing: border-box;
		width: 100%;
		padding: 0 10px;
	}
	
	#footer{
		margin-top: 50px;
	}
	#footer-layout{
		padding: 50px 10px 70px 10px;
	}
}






/*=========================================================

	Decoration

==========================================================*/

/*== Header ==============================================*/

#header h1{
	text-align:left;
}
#header h1 img{
	width: auto;
	height: 50px;
}



/*== contents =============================================*/

ul.nav-banner{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	list-style: none;
	width: 100%;
	padding: 0;
	margin: 0 0 50px 0;
}
ul.nav-banner li{
	width: 455px;
	margin-bottom: 15px
}
ul.nav-banner li a.link-banner{
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	text-decoration: none;
	color: #fff;
	padding: 20px 0;
	border: 3px solid #00547A;
	background: #00547A;
}
ul.nav-banner li a.link-banner:hover{
	color: #00547A;
	background: #fff;
}

ul.nav-banner li:nth-last-child(2) a{
	border: 3px solid #ffa000;
	background: #ffa000;
}
ul.nav-banner li:nth-last-child(2) a:hover{
	color: #ffa000;
	background: #fff;
}

ul.nav-banner li span.wait{
	display: block;
	text-align: center;
	text-decoration: none;
	color: #fff;
	padding: 20px 0;
	border: 3px solid #00547A;
	background: #00547A;
}
ul.nav-banner li:last-child span.wait{
	border: 3px solid #ea5550;
	background: #ea5550;
}

ul.nav-banner li.seminar{
	font-size: 80%;
}
ul.nav-banner li.seminar em{
	font-size: 125%;
}

ul.nav-banner li.movie-banner{
	display: flex;
	justify-content: space-between;
}
ul.nav-banner li.movie-banner a{
	width: calc(50% - 10px);
}

h2.pagetitle{
	font-family: 'HansSerif';
	font-size:230%;
	color: #fff;
	padding:50px 0;
	margin-bottom:50px;
	background: #00547A;
}
h2.pagetitle span{
	display: block;
	text-align: left;
	width: 930px;
	margin: 0 auto;
}
h2.pagetitle em{
	display: block;
	font-size: 50%;
}

h2.pagetitle.pets{
	background: #ffa000;
}

.section{
	width: 930px;
	margin-top: 70px;
}
.section:first-child{margin-top: 0;}

.sectiontitle{
	font-family: 'HansSerif';
	font-size:150%;
	padding-bottom: 20px;
	margin-bottom: 30px;
	border-bottom: 1px solid #ddd;
}
.sectiontitle::before{
	margin-right: 5px;
}



/*== footer ===============================================*/

.pagetop{
	position: absolute;
	bottom: 40px;
	right: 0;
	line-height: 1;
	width: 42px;
	height: 42px;
}
.pagetop a{
	transition: all .3s;
	text-decoration: none;
	position: relative;
	display: block;
	text-align: center;
	width: 42px;
	height: 42px;
	border-radius: 23px;
	border: 2px solid #ff8c00;
	background: #ff8c00;
}
.pagetop a::before{
	position: absolute;
	top: 7px;
	left: 0;
	right: 0;
	font-size: 150%;
	color: #fff;
	margin: auto;
}
.pagetop a:hover{background: #fff;}
.pagetop a:hover::before{color: #ff8c00;}
.pagetop a span{
	visibility: hidden;
}


dl.link dt{
	font-weight: 700;
}
dl.link ul{
	list-style: none;
	padding: 0;
	margin: 0;
}
dl.link ul li{
	display: inline-block;
	margin-right: 20px;
}

p.address{
	padding-top: 30px;
	margin-top: 30px;
	border-top: 1px solid #ccc;
}


#copyright{
	color: #fff;
	padding: 10px 0;
	background: #333;
}



@media screen and (min-width: 737px){ /* PC */
	.menu-trigger{display: none;}
	
	#header h1{
		float: left;
	}
	
	#header ul{
		float: right;
		list-style: none;
		line-height: 50px;
		padding: 0;
		margin: 0;
	}
	#header ul li{
		float: left;
		margin-left: 20px;
	}
	#header ul li:first-child{
		margin: 0;
	}
	#header ul li a{
		text-decoration: none;
		font-weight: 700;
		font-size: 95%;
		color: #111;
	}
	#header ul li a:hover{color: #00547A;}
}

@media screen and (max-width: 736px){ /* SP */
	#header h1{
		text-align: center;
		padding: 10px 0;
	}
	#header h1 img{
		width: 80%;
		height: auto;
	}
	
	#navigation-area{
		position: fixed;
		z-index: 999;
		bottom: 0;
		right: 0;
		width: 100%;
		height: 60px;
	}
	
	.menu-trigger,
	.menu-trigger span {
		display: inline-block;
		transition: all .3s;
		box-sizing: border-box;
	}
	.menu-trigger{
		position: absolute;
		display: block;
		bottom: 0;
		left: calc(100% - 60px);
		width: 60px;
		height: 60px;
		background: #333;
	}
	.menu-trigger.active{
		left: 0;
		background: #c00;
	}
	
	.menu-trigger span {
		position: absolute;
		left: 15px;
		width: 30px;
		height: 2px;
		background-color: #fff;
		border-radius: 2px;
	}
	.menu-trigger span:nth-of-type(1) {
		top: 19px;
	}
	.menu-trigger span:nth-of-type(2) {
		top: 29px;
	}
	.menu-trigger span:nth-of-type(3) {
		top: 40px;
	}
	
	.menu-trigger.active span:nth-of-type(1) {
		-webkit-transform: translateY(10px) rotate(-315deg);
		transform: translateY(10px) rotate(-315deg);
	}
	.menu-trigger.active span:nth-of-type(2) {
		opacity: 0;
	}
	.menu-trigger.active span:nth-of-type(3) {
		-webkit-transform: translateY(-11px) rotate(315deg);
		transform: translateY(-11px) rotate(315deg);
	}
	
	ul#navigation{
		transition: all .3s;
		position: absolute;
		bottom: 0;
		left: 100%;
		/*transform: translateX(100%);*/
		box-sizing: border-box;
		list-style: none;
		text-align: right;
		width: calc(100% - 60px);
		padding: 0 10px;
		margin: 0;
		background: #333;
	}
	ul#navigation.active{
		left: 60px;
		/*transform: translateX(0);*/
	}
	
	ul#navigation li::before{
		display: none;
	}
	ul#navigation a{
		display: block;
		color: #fff;
		padding: 10px;
	}
	
	ul.nav-banner li{
		width: 100%;
		margin-bottom: 10px;
	}
	ul.nav-banner li a{
		overflow: hidden;
		color: #fff;
	}
	
	h2.pagetitle{
		font-size:150%;
		color: #fff;
		padding:50px 0;
		margin-bottom:50px;
	}
	h2.pagetitle span{
		text-align: center;
		width: 100%;
	}
	
	.section{
		width: 100%;
	}
	
	.pagetop{
		bottom: 10px;
		left: 10px;
		right: auto;
	}
	
	#copyright{
		text-align: left;
		padding: 10px 70px 10px 10px
	}
}

