
@charset "UTF-8";
/* CSS Document */

/* reset */
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
}
sup {
    vertical-align: super;
    font-size: 50%;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
img { line-height: 0;}
small { font-size: 80%;}
/* base */
body {
	-webkit-text-size-adjust: auto;
	margin: 0;
	padding: 0;
	color: #333333; 
	font-size: 16px; 
	font-family: "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ＭＳ Ｐゴシック", "MS PGothic",Osaka, sans-serif; 
	min-width: 100%;
	height: 100%;
}

p, li, dt, dd { line-height: 150%;}

/* Link */
a, a:visited {
	color: #336699;
	text-decoration: none;
}
a:hover { color: #5990c8;}

/*clearfix*/

.clearfix:after {
	content: ".";
	display: block;
	height: 0;
	clear: both;
	visibility: hidden;
}

.clearfix {
	display: inline-table; 
}

/* Hides from IE-mac \*/
* html .clearfix {
	height: 1%;
}

.clearfix {
	display: block;
}
/* End hide from IE-mac */
.dis_n {display: none;}

/* breadcrumb */
ol.breadc { margin: 0 0 16px 0;}

ol.breadc li {
	display: inline;
	margin: 0;
	font-size: 85%;
}
ol.breadc li:after {
	content: "＞";
	padding: 0 8px;
}
ol.breadc li:last-child:after { content:"";}

/* margin */
.mt8 { margin-top: 8px !important;}
.mt16 { margin-top: 16px !important;}
.mt24 { margin-top: 24px !important;}
.mb8 { margin-bottom: 8px !important;}
.mb16 { margin-bottom: 16px !important;}
.mb24 { margin-bottom: 24px !important;}
/* header & footer & gnavi common media queries */
@media screen and (min-width: 769px) {
	img{
		max-width: 100%;
		height: auto;
		width /***/:auto;　
	}
	.pc_n { display: none !important;}
	
	/* header */
	header {
		width: 100%;
		background: url(../img/header_top.jpg) top repeat-x;
		height: 84px;
	}
	h1 {
		margin: 0 auto;
		width: 1280px;
		padding-top: 20px;
	}
	/* grobal navi */
	nav {
		height: 48px;
		border-bottom: 3px solid #b4d2e6;
	}
	#gnavi {
		max-width: 1280px;
		width: 100%;
		min-width: 769px;
		margin: 0 auto;
	}
	#gnavi dl {
		width: 14%;
		float: left;
		position: relative;
	}
	#gnavi dl dt {
		width: 14%;
		height: 48px;
		font-size: calc(12px + 0.2vw);
		overflow: hidden;
		display: table-cell;
		vertical-align: middle;
		text-align: center;
		position: relative;
		cursor: pointer;
	}
	.big_m, #gnavi dl dt.big_m:hover {width: 16% !important;}
	#gnavi dl dt:hover {
		width: 14%;
		height: 48px;
		line-height: 48px;
		background-color: #f4f8fb !important;
		border-bottom: 3px solid #506e9b !important;
		cursor: pointer;
		color: #506e9b;
	}
	#gnavi dl dt a {
		text-decoration: none;
		color: #333333;
		display: block;
		height: 48px;
		width: auto;
		line-height: 48px;
	}
	#gnavi dl dt a:hover { color: #506e9b !important;}
	#gnavi dl dd {
		position: absolute;
		width: 300px;
		top: 51px;
		display: none;
		z-index: 100;
		margin: 0;
	}
	dd.big_p {width: 420px !important;}
	#gnavi dl ul li {
		list-style-type: none;
		font-weight: normal;
		border-bottom: 1px solid #dae9f3;
		border-top: 1px solid #FFFFFF;
		background: #f4f8fb;
	}
	#gnavi ul li a {
		display: block;
		color: #333333;
		text-decoration: none;
		padding: 10px 15px;
		text-align: left;
	}
	#gnavi ul li a:hover {
		background-color: #f4f8fb;
		color: #333333;
	}
	.last_p {
		top: 60px;
		right: 0;
	}
	/* article */
	article {
		margin: 32px auto;
		padding: 0 16px;
		overflow: hidden;
		max-width: 1280px;
		width: 100%;
		min-width: 769px;
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
	}
	/* caption */
	h2.cap {
		font-size: 100%;
		border-left: 8px solid #506e9b;
		padding: 8px 0 8px 16px;
		color: #506e9b;
		margin: 0 0 32px 0;
		line-height: 150%;
	}
	h2.cap span {
		font-family: 'EB Garamond', serif;
		font-size: 200%;
		padding: 0 16px 0 0;
		letter-spacing: 0.05em;
	}
	
	/* footer */
	footer {
		background: #87a5a7;
		height: 210px;
		margin-top: 72px;
		overflow: hidden;
	}
	.sns_area {	background: #5f878a;}
	footer dl {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
		width: 1280px;
		height: 80px;
		margin: 0 auto;
		padding: 16px;
		overflow: hidden;
	}
	
	footer dt, footer dd {
		float: left;
		margin: 0 24px;
		display: table-cell;
		vertical-align: middle;
		line-height: 0;
	}
	
	footer ul {
		height: 20px;
		font-size: 90%;
		margin: 40px 0;
		text-align: center;
	}
	footer ul li {
		display: inline-block;
		margin-left: 24px;
	}
	footer ul li:first-child { margin-left: 0 !important;}

	footer ul li a, footer ul li a:visited { color: #ffffff;}
	footer ul li a:hover { color: #4e7577; text-decoration: underline;}
	
	footer p {
		clear: both;
		color: #ffffff;
		font-size: 85%;
		margin: 16px 0;
		text-align: center;
	}
	.pagetop {
		display: none;
		position: fixed;
		line-height: 90%;
		bottom: 5%;
		right: 10%;
	}
	.pagetop a {
		display: block;
		background-color: #506e9b;
		text-align: center;
		color: #ffffff;
		font-size: 120%;
		text-decoration: none;
		padding: 18px 10px;
		-webkit-border-radius: 50%;
		-moz-border-radius: 50%;
		border-radius: 50%;
	}
	.pagetop a span { font-size: 60%;}
	.pagetop a:hover {
		display: block;
		background-color: #506e9b;
		text-align: center;
		color: #fff;
		font-size: 120%;
		text-decoration: none;
		padding: 18px 10px;
		filter: alpha(opacity=50);
		-moz-opacity: 0.5;
		opacity: 0.5;
	}
}

@media screen and (max-width: 768px) and (min-width: 641px)  {
	img{
		max-width: 100%;
		height: auto;
		width /***/:auto;　
	}
	.tb_n { display: none !important;}
	header {
		width: 100%;
		background: url(../img/header_top.jpg) top left no-repeat;
		background-color: #ffffff;
		height: 84px;
		position: fixed;
		z-index: 9;
		-moz-box-shadow: 0px 2px 6px 0px rgba(0,0,0,0.2);
		-webkit-box-shadow: 0px 2px 6px 0px rgba(0,0,0,0.2);
		box-shadow: 0px 2px 6px 0px rgba(0,0,0,0.2);
	}
	#wrap { padding: 84px 0 0 0;}
	/* article */
	article {
		width: 98%;
		margin: 32px auto;
		overflow: hidden;
	}
	h1 {
		margin: 0 auto;
		width: 100%;
		padding: 20px 0 0 16px;
	}
	/* hamburger menu & navi */
	.h_btn { margin: 13px 16px 10px;}
	/* accordion menu */
	.accordion dt {
		display:block;
		width: 100%;
		height: 40px;
		line-height: 40px;
		text-align:center;
		border-top: 1px solid #706f6f;
		border-bottom: 1px solid #222222;
		cursor:pointer;
		position: relative;
	}
	.ar_b:after {
		position: absolute;
		top: 35%;
		right: 15px;
		margin-top: -14px;
		content: '>';
		font-size: 14px;
		font-weight: bold;
		-moz-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
		-moz-transition: all, 0.25s, linear;
		-o-transition: all, 0.25s, linear;
		-webkit-transition: all, 0.25s, linear;
		transition: all, 0.25s, linear;
	}
	.ar_b.open:after {
		-moz-transform: translate(0, 50%);
		-ms-transform: translate(0, 50%);
		-webkit-transform: translate(0, 50%);
		transform: translate(0, 50%);
		-moz-transform: rotate(-90deg);
		-ms-transform: rotate(-90deg);
		-webkit-transform: rotate(-90deg);
		transform: rotate(-90deg);
	}
	.accordion dt a {
		color: #ffffff !important;
		display: block;
		width: 100%;
		height: 40px;
	}
	.accordion dd {
		background: #dfdfdf;
		color: #444444;
		width: 100%;
		height: auto;
		/*display: none;*/
		border-bottom: 1px solid #222222;
	}
	.accordion dd ul li {
		padding: 8px 8px 8px 16px;
		font-size: 85%;
		line-height: 140%;
		border-bottom: 1px dotted #ACACAC;
	}
	.accordion dd ul li:last-child { border-bottom: none !important;}
	
	/* caption */
	h2.cap {
		font-size: 100%;
		border-left: 8px solid #506e9b;
		padding: 8px 0 8px 16px;
		color: #506e9b;
		margin: 0 0 24px 0;
	}
	h2.cap span {
		font-family: 'EB Garamond', serif;
		font-size: 200%;
		padding: 0 16px 0 0;
		letter-spacing: 0.05em;
		line-height: 150%;
	}
	/* breadcrumb */
	ol.breadc { margin: 0 0 16px 16px;}
	/* footer */
	footer {
		background: #87a5a7;
		height: 210px;
		margin-top: 72px;
		overflow: hidden;
	}
	.sns_area {	background: #5f878a;}
	footer dl {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
		width: 100%;
		height: 80px;
		margin: 0 auto;
		padding: 16px;
		overflow: hidden;
	}
	
	footer dt, footer dd {
		float: left;
		margin: 0 24px;
		display: table-cell;
		vertical-align: middle;
		line-height: 0;
	}
	
	footer ul {
		height: 20px;
		font-size: 90%;
		margin: 40px 0;
		text-align: center;
	}
	footer ul li {
		display: inline-block;
		margin-left: 16px;
	}
	footer ul li:first-child { margin-left: 0 !important;}
	footer ul li a { color: #ffffff;}
	footer ul li a:hover { color: #4e7577; text-decoration: underline;}
	footer p {
		clear: both;
		color: #ffffff;
		font-size: 75%;
		margin: 16px 0;
		text-align: center;
	}
}

@media screen and (max-width: 640px) and (min-width: 0px) {
	img{
		max-width: 100%;
		height: auto;
		width /***/:auto;　
	}
	.sp_n { display: none !important;}
	header {
		width: 100%;
		background: url(../img/header_top.jpg) top repeat-x;
		background-color: #ffffff;
		height: 64px;
		position: fixed;
		z-index: 9;
		-moz-box-shadow: 0px 2px 6px 0px rgba(0,0,0,0.2);
		-webkit-box-shadow: 0px 2px 6px 0px rgba(0,0,0,0.2);
		box-shadow: 0px 2px 6px 0px rgba(0,0,0,0.2);
	}
	#wrap {padding: 64px 0 0 0; overflow: hidden;}
	h1 {
		margin: 0 auto;
		width: 100%;
		padding: 10px 0 0 16px;
	}
	/* hamburger menu & navi */
	.h_btn {margin: 6px 6px 0;}
	/* accordion menu */
	.accordion dt {
		display:block;
		width: 100%;
		height: 40px;
		line-height: 40px;
		text-align:center;
		border-top: 1px solid #706f6f;
		border-bottom: 1px solid #222222;
		cursor: pointer;
		position: relative;
	}
	.ar_b:after {
		display: inline-block;
		position: absolute;
		top: 35%;
		right: 15px;
		margin-top: -14px;
		content: '>';
		font-size: 14px;
		font-weight: bold;
		-moz-transform: rotate(90deg);
		-ms-transform: rotate(90deg);
		-webkit-transform: rotate(90deg);
		transform: rotate(90deg);
		-moz-transition: all, 0.25s, linear;
		-o-transition: all, 0.25s, linear;
		-webkit-transition: all, 0.25s, linear;
		transition: all, 0.25s, linear;
	}
 
	.ar_b.open:after {
		-moz-transform: translate(0, 50%);
		-ms-transform: translate(0, 50%);
		-webkit-transform: translate(0, 50%);
		transform: translate(0, 50%);
		-moz-transform: rotate(-90deg);
		-ms-transform: rotate(-90deg);
		-webkit-transform: rotate(-90deg);
		transform: rotate(-90deg);
	}
	
	.accordion dt a {
		color: #ffffff !important;
		display: block;
		width: 100%;
		height: 40px;
	}
	.accordion dd {
		background: #dfdfdf;
		color: #444444;
		width: 100%;
		height: auto;
		/*display: none;*/
		border-bottom: 1px solid #222222;
	}
	.accordion dd ul li {
		padding: 8px 8px 8px 16px;
		font-size: 85%;
		line-height: 140%;
		border-bottom: 1px dotted #ACACAC;
	}
	/* article */
	article {
		width: 95%;
		margin: 32px auto;
		overflow: hidden;
	}
	/* caption */
	h2.cap {
		font-size: 100%;
		border-left: 8px solid #506e9b;
		padding: 8px 0 8px 16px;
		color: #506e9b;
		margin: 0 0 32px 0;
		line-height: 150%;
	}
	h2.cap span {
		font-family: 'EB Garamond', serif;
		font-size: 200%;
		padding: 0 16px 0 0;
		letter-spacing: 0.05em;
	}
	/* footer */
	footer {
		background: #87a5a7;
		/* height: 260px; */
		margin-top: 72px;
		overflow: hidden;
	}
	.sns_area {	background: #5f878a;}
	footer dl {
		-webkit-box-sizing: border-box;
		-moz-box-sizing: border-box;
		-o-box-sizing: border-box;
		-ms-box-sizing: border-box;
		box-sizing: border-box;
		width: 100%;
		height: 120px;
		margin: 0 auto;
		padding: 16px;
		overflow: hidden;
	}
	
	footer dt, footer dd { line-height: 0;}
	footer dd {
		height: 50px;
		padding: 0 8px 0 0;
		display: table-cell;
		vertical-align: middle;
	}
	
	footer ul {
		/* height: 20px; */
		font-size: 90%;
		margin: 16px 0 0 0;
		/* text-align: center; */
		clear: both;
	}
	footer ul li {
		/* display: inline-block; */
		margin: 16px 0 0;
		margin-left: 24px;
	}
	footer ul li:first-child {/* margin-left: 0 !important; */}
	footer ul li a { color: #ffffff;}
	footer ul li a:hover { color: #4e7577; text-decoration: underline;}
	footer p {
		clear: both;
		color: #ffffff;
		font-size: 85%;
		line-height: 140%;
		margin: 24px 0 8px 0;
		text-align: center;
	}
}


