@charset "UTF-8";
/*
Author: 株式会社メックコミュニケーションズ
Author URI: http://www.mec-com.co.jp
*/


/*  CSS Index
--------------------------------------------------------------
ヘッダーのロゴは縦の長さで横幅を自動調整します。
比率に注意してください。
--------------------------------------------------------------
@media print, screen and (min-width: 768px) {pc/print}
@media screen and (max-width: 767px) {sp}
1 : base
 	  : body(pc=min-width:1200px || sp=min-width:375px)
 	  : frame(pc=max-width:1080px || sp=max-width:480px)
 	  : clearfix
 	  : accordion
 	  : pc/sp
2 : header
 	  : header_copy
 	  : header_wrap
 	  : globalnav_btn
 	  : pc
 	 	  : header_logo
 	 	  : header_toi
 	 	  : globalnav
 	 	  : accordion
 	 	  : header_banner
 	  : sp
 	 	  : header_logo
 	 	  : header_toi
 	 	  : globalnav_btn
 	 	  : globalnav
 	 	  : accordionopen
 	 	  : accordion
 	 	  : btn toi
 	 	  : header_banner
4 : main
 	  : localnav(pc only)
 	  : path(pc only)
 	  : layout(pc only)
 	  : single
 	  : sidebar
 	  : pager
5 : footer
 	  : footer_toi
 	  : footer_nav
 	  : footer_data
 	  : pagetop
 	  : copyright
 	  : poweredby
6 : print
-----------------------------------------------------------------------------------------*/


/*base
-----------------------------------------------------------------------------------------*/
*{
	margin: 0; 
	padding: 0; 
	list-style-type: none; 
	font-weight: normal;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
html{
	height:100%;
	font-size:10px;
}
body{
	font-family: "HummingStd-L", Meiryo, "メイリオ", "Lucida Grande", Verdana, "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ＭＳ Ｐゴシック", sans-serif;
	color:#000;
	text-align:center;
	font-size:1.8rem;
	line-height:1.5;
	height:100%;
	min-width:1200px;
	-webkit-text-size-adjust:none;
}
ruby{
	ruby-position:under; 
}
ruby rt{
	margin:5px 0;
	letter-spacing:1px;
}
@media screen and (max-width: 767px) {body{min-width:375px;}}
img{
	border-width: 0px;
	vertical-align: bottom;
	max-width: 100%;
	height: auto;
	width /***/:auto;
}
* html img{
	border-width: 0px;
	vertical-align: top;
	padding:-1px;
}
*:first-child+html img {
	border-width: 0px;
	vertical-align: middle;
	padding:-1px;
}
h1,h2,h3,h4,h5,h6,p,li,dl,dt,dd,input,table,figure,ol,.dot{
	font-size:1.8rem;
	line-height:1.5;
	margin:0;
}
@media screen and (max-width: 767px) {h1,h2,h3,h4,h5,h6,p,li,dt,dd,input,table,figure,ol,.dot{font-size:1.6rem;}}
ul{
	font-size:0;
}
span{
	font-weight:inherit;
	display:inline-block;
}
em{
	font-weight:bold;
	font-style:inherit;
	color:#CC0000;
}
strong{
	font-weight:bold;
}
a{
	color:inherit;
	font-weight:inherit;
	text-decoration: none;
	outline:none;
}
a:hover {
	text-decoration: none;
	outline:none;
}
a:link,a:visited,a:hover,a:active {
	outline:none;
}
hr{
	border-bottom:1px solid rgba(0,0,0,0);
	border-top:1px solid rgba(0,0,0,0);
	margin:50px 0;
}
@media screen and (max-width: 767px) {hr{margin:30px 0;}}
#wrapper{
	width:100%;
	overflow:hidden;
}
/*-------------------------frame*/
.frame{
	max-width:1080px;
	margin:0 auto;
	text-align:left;
	position:relative;
}
.frame::after {
	display: block;
	clear: both;
	content: "";
}
@media screen and (max-width: 767px) {.frame{max-width:480px;padding-right:20px;padding-left:20px;}}
/*-------------------------clearfix*/
.clearfix::after{
	display: block;
	clear: both;
	content: "";
}
/*-------------------------accordion*/
.accordion{
	display:none;
}
.accordionopen{
	cursor:pointer;
}
/*-------------------------pc/sp*/
@media screen and (max-width: 767px) {#wrapper .pc{display:none;}}
@media print, screen and (min-width: 768px) {#wrapper .sp{display:none;}}



/*header
-----------------------------------------------------------------------------------------*/
header{
	position:relative;
	left:0;
	z-index:1000;
	width:100%;
	text-align:left;
	max-width:100%;
	min-width:1200px;
	background:#F5F5F5;
}
header p{
	font-size:18px;
}
#wrapper.scroll header{
	position:fixed;
	box-shadow: 0 0 5px rgba(0,0,0,0.3);
}
@media screen and (max-width: 767px) {
	header,#wrapper.scroll header{min-width:375px;height:auto;overflow:auto;top:0;}
}
/*-------------------------header_copy*/
.header_copy{
	font-size:14px;
	line-height:40px;
	padding:0 10px;
	background:#E6E6E6;
}
.header_copy::after{
	display: block;
	clear: both;
	content: "";
}
#wrapper.scroll .header_copy{
	display:none;
}
@media screen and (max-width: 767px) {
	.header_copy{font-size:10px;line-height:20px;padding:0 5px;}
}
/*-------------------------header_wrap*/
.header_wrap{
	position:relative;
}
/*-------------------------globalnav_btn*/
.globalnav_btn{
	position:absolute;
	right:0;
	top:0;
	width:65px;
	height:65px;
	z-index:1000;
	font-size:10px;
	letter-spacing:1px;
	text-align:center;
	padding-top:38px;
	color:#000;
	font-weight:bold;
}
.globalnav_btn::before,
.globalnav_btn::after{
	content:"";
	display:block;
	width:35px;
	height:3px;
	position: absolute;
	left: 15px;
	top:20px;
	background:#000;
	transition: all .4s;
	box-sizing: border-box;
}
.globalnav_btn::after{
	top:30px;
}
.globalnav_btn.open::before{
	-webkit-transform: translateY(10px) rotate(-45deg);
	transform: translateY(10px) rotate(-45deg);
}
.globalnav_btn.open{
	text-indent:-9999em;
}
.globalnav_btn.open::after{
	-webkit-transform: translateY(0) rotate(45deg);
	transform: translateY(0) rotate(45deg);
}
/*----------------------------------------------------------------------------------------pc*/
@media print, screen and (min-width: 768px) {
#wrapper.scroll header{
	top:-70px;
	transition: 0.5s;
	transform: translateY(70px);
}
/*-------------------------globalnav_btn(pc)*/
.globalnav_btn{
	display:none;
}
/*-------------------------header_logo(pc)*/
.header_logo{
	float:left;
	padding:10px;
}
.header_logo img{
	max-height:80px;
}
.header_logo a:hover{
	opacity:0.6;
}
#wrapper.scroll .header_logo{
	display:none;
}
/*-------------------------header_toi(pc)*/
.header_toi{
	padding:10px;
	text-align:right;
}
.header_toi a.toi{
	width:180px;
	font-size:inherit;
	padding-top:0;
	padding-bottom:0;
	line-height:80px;
	margin:0 0 0 auto;
	background-position:left 15px center;
}
#wrapper.scroll .header_toi{
	display:none;
}
/*-------------------------globalnav(pc)*/
.globalnav{
	display:block;
}
.globalnav nav > ul{
	text-align:center;
}
.globalnav nav > ul > li{
	flex:1 0 auto;
	position:relative;
}
.globalnav nav > ul > li > a{
	font-size:18px;
	line-height:20px;
	font-weight:bold;
	letter-spacing:1px;
	display:block;
	padding:25px 0;
}
/*accordion(pc)*/
.globalnav nav .accordion{
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	max-height:0;
	min-width:200px;
	overflow:hidden;
	position:absolute;
	width:100%;
	display:block;
    left: 50%;
    transform: translateX(-50%);
}
.globalnav nav > ul > li:hover .accordion{
	max-height:500px;
}
.globalnav nav .accordion li + li{
	border-top:1px solid #FFF;
}
.globalnav nav .accordion li a{
	display:block;
	color:#000;
	padding:10px 5px;
}
.globalnav nav .accordion li a:hover{
	background:#999;
}
/*-------------------------header_banner(pc)*/
.header_banner{
	position:absolute;
	top:0;
	right:190px;
	padding:10px;
}
#wrapper.scroll .header_banner{
	display:none;
}
}
/*----------------------------------------------------------------------------------------sp*/
@media screen and (max-width: 767px) {
header .frame{padding:0;}
/*-------------------------header_logo(sp)*/
.header_logo{
	padding:5px;
}
.header_logo img{
	max-height:55px;
}
/*-------------------------header_toi(sp)*/
.header_toi{
	padding:5px;
	position:absolute;
	top:0;
	right:65px;
}
.header_toi a.toi{
	width:55px;
	padding:0;
	line-height:55px;
	margin:0;
	text-indent:-999em;
	background-position:center;
}
#wrapper.scroll .header_toi{
	padding:5px;
}
/*-------------------------globalnav_btn(sp)*/
#wrapper.scroll .globalnav_btn{top:0;}
/*-------------------------globalnav(sp)*/
.globalnav{
	background:#F5F5F5;
	padding:5px 20px;
	height:calc(100vh - 85px);
	overflow:auto;
}
#wrapper.scroll .globalnav{height:calc(100vh - 65px);}
.globalnav nav > ul{
	margin-bottom:10px;
}
.globalnav nav > ul > li{
	border-bottom:1px solid #000;
	position:relative;
}
.globalnav nav > ul > li:last-child{
	border-bottom:none;
}
.globalnav nav ul li a{
	display:block;
	text-align:center;
	font-size:18px;
	line-height:30px;
	padding:10px 0;
}
.globalnav nav ul li a.current{
	background-color:rgba(0,0,0,0.1);
}
/*accordionopen(sp)*/
.globalnav nav .accordionopen{
	width:50px;
	line-height:50px;
	text-align:center;
	position:absolute;
	right:0;
	top:0;
	background:rgba(0,0,0,0.1);
}
.globalnav nav .accordionopen::before{
	content:"+";
	display:block;
}
.globalnav nav .accordionopen.open::before,
.globalnav nav ul li a.current + p.accordionopen::before{
	content:"-";
}
/*accordion(sp)*/
.globalnav nav .accordion{
	display:none;
}
.globalnav nav .accordion li a{
	border-top:1px dashed #999;
}
#wrapper .globalnav nav ul li a.current + p + ul{
	display:block;
}
/*btn toi(sp)*/
.globalnav nav ul li a.btn.toi{
	width:100%;
}
/*-------------------------header_banner(sp)*/
.header_banner{
}
}




/*main
-----------------------------------------------------------------------------------------*/
main{
	display:block;
	padding-top:60px;
	padding-bottom:60px;	
}
@media screen and (max-width: 767px) {
	main{padding-top:30px;padding-bottom:30px;}
}
/*-------------------------localnav(pc)*/
.localnav{
	background:#000;
	color:#FFF;
}
.localnav ul{
	font-size:0;
}
.localnav  ul li{
	display:inline-block;
}
.localnav  ul li a{
	font-size:16px;
	line-height:20px;
	padding:20px;
	display:block;
}
.localnav  ul li a.current,
.localnav  ul li a:hover{
	background-color:rgba(255,255,255,0.3);
}
@media screen and (max-width: 767px) {
	.localnav{display:none;}
}
/*-------------------------path(pc only)*/
.path{
	padding:6px 10px;
	height:0;
	position:absolute;
	z-index:10;
}
.path p{
	font-size:1.3rem;
	text-align:left;
	color:#555;
}
.path p strong{
	font-weight:normal;
}
.path p a:hover{
	text-decoration:underline;
}
@media screen and (max-width: 767px) {
	.path{display:none;}
}
/*-------------------------layout(pc only)*/
@media print, screen and (min-width: 768px) {
	.mainarea{width:720px;float:left;}
	.sidebar{width:280px;float:right;}
}
/*-------------------------single*/
.single .data{
	text-align:right;
	font-size:1.4rem;
	line-height:50px;
	margin:0 0 30px 0;	
	color:#666;
}
.single img{
	display:block;
	margin:30px auto;
}
.single h1{
	font-size:3rem;
	font-weight:bold;
	padding:0.8em 0;
	border-top:2px solid #000;
	border-bottom:2px solid #000;
}
.single h2{
	background:#000;
	color:#FFF;
	font-size:2.2rem;
	font-weight:bold;
	padding:8px 15px;
	margin:50px 0 -20px 0;
}
.single h3{
	font-size:2.2rem;
	font-weight:bold;
	margin:50px 0 -20px 0;
}
.single h4{
	font-size:1.8rem;
	font-weight:bold;
	padding-bottom:5px;
	border-bottom:2px solid #000;
	margin:50px 0 -20px 0;
}
.single p{
	line-height:1.66;
}
.single figure,
.single p,
.single dl,
.single ul,
.single ol,
.single table{
	margin-top:30px;
}
.single a{
	text-decoration:underline;
	color:#0052B5;
}
.single a:hover{
	text-decoration:none;
}
@media screen and (max-width: 767px) {
	.single{margin:20px 0;}
	.single .data{font-size:12px;line-height:30px;margin-bottom:-15px;}
	.single img{margin:15px auto;}
	.single h1{font-size:20px;padding:0.4em 0;}
	.single h2{font-size:18px;margin:30px 0 -20px 0;padding:2px 6px;}
	.single h3{font-size:18px;margin:30px 0 -20px 0;}
	.single h4{font-size:16px;margin:30px 0 -20px 0;}
}
/*-------------------------sidebar*/
.sidebar h2{
	font-size:1.6rem;
	border-top:2px solid #000;
	font-weight:bold;
	padding:10px;
}
.sidebar nav{
	margin-bottom:-1px;
}
.sidebar li a{
	border-bottom:1px solid rgba(0,0,0,0.3);
	display:block;
	padding:12px 10px;
}
.sidebar li a:hover{
	background:rgba(0,0,0,0.1);
}
@media print, screen and (min-width: 768px) {
	.sidebar li a{font-size:1.6rem;}
}
@media screen and (max-width: 767px) {
	.sidebar{margin-top:30px;padding:30px 0;position:relative;}
	.sidebar nav{background:#FFF;}
	.sidebar::after{content:"";display:block;position:absolute;width:100vw;min-width:1200px;top:0;height:100%;z-index:-1;left:50%;margin-left:-50vw;height:100%;background:rgba(255,255,255,1);}
	.sidebar li a{font-size:14px;}
}
/*-------------------------pager*/
.pager{
	margin-top:30px;
	text-align:center;
}
.pager li{
	display:inline-block;
}
.pager li a,
.pager li span{
	display:block;
	color:#000;
	background:rgba(0,0,0,0.1);
	width:40px;
	font-size:16px;
	line-height:40px;
	text-align:center;
	margin:2px;
	text-decoration:none;
}
.pager li span{
	color:#FFF;
	background:#000;
}
.pager li span.dots{
	background:none;
	color:#4D4D4D;
	width:auto;
	padding:0;
}
.pager li a:hover{
	background-color:#CCCCCC;
}


/*footer
-----------------------------------------------------------------------------------------*/
footer{
	position:relative;
}
/*-------------------------footer_toi*/
.footer_toi{
	background:#F1F1F1;
	color:#000;
}
@media print, screen and (min-width: 768px) {
.footer_toi .bg{
	background:url(images/footer_toi_bg.jpg) right no-repeat;
	background-size:contain;
}
}

/*-------------------------footer_nav*/
.footer_nav{
	background:#000;
	color:#FFF;
}
.footer_nav li{
	display:inline-block;
	font-size:16px;
}
.footer_nav li a{
	display:block;
	padding:15px;
}
.footer_nav li a:hover{
	background-color:rgba(255,255,255,0.2);
}
/*-------------------------footer_data*/
.footer_data{
}
/*-------------------------pagetop*/
.pagetop a{
	position:fixed;
	bottom:10px;
	right: 10px;
	width:100px;
	height:100px;
	z-index:20;
	background:rgba(0,0,0,0.2);
	border-radius:20px;
}
.pagetop a:hover{
	background-color:#000;
}
@media screen and (max-width: 767px) {
	.pagetop a{bottom:0;right: 0;width:60px;height:60px;border-radius:0;}
}
/*-------------------------copyright*/
.copyright{
	display:block;
	font-size:12px;
	padding:20px;
}
.copyright a:hover{
	text-decoration:underline;
}
@media print, screen and (min-width: 768px) {
	.copyright{letter-spacing:1px;}
}
@media screen and (max-width: 767px) {
	.copyright{font-size:10px;padding:0;}
}
/*-------------------------poweredby*/
.poweredby{
	font-size:12px;
}
.poweredby a:hover{
	text-decoration:underline;
}
@media print, screen and (min-width: 768px) {
	.poweredby{position:absolute;left:20px;bottom:20px;letter-spacing:1px;}
}
@media screen and (max-width: 767px) {
	.poweredby{font-size:10px;padding:10px 0 15px 0;}
}

/*print
-----------------------------------------------------------------------------------------*/
@media print{
	#wrapper.scroll{padding-top:0;}
	#wrapper header{display:none;}
}