/*==============================================
Font
==============================================*/
body {
	line-height:1;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
	-webkit-text-size-adjust: 100%;
}

h1,h2,h3,h4,h5,h6,p,li,th,td,dt,dd,a {
	color:#333;
	font-size:14px;
	line-height:20px;
	letter-spacing:1.8px;
}

a{
	outline:none;
	text-decoration: none;
	color: #666666;
}
a:hover{
	color: #dddddd;
}

span {
}



/*==============================================
all
==============================================*/
html{
}
body{
	text-align: center;
}

.switch {
    visibility: hidden;
}

ul.bxslider {
  padding: 0;
  margin: 0;
}

.bx-pager-item {
}

/*==============================================
main
==============================================*/
#main{
	padding:15px 15px 0px 15px;
}

.sp { display:block }
.pc { display:none }


/*==============================================
sns
==============================================*/
#sns{
	height:25px ;
	width:100% ;
	position: relative;
}
#sns .facebookicon,
#sns .twittericon{
	position: absolute ;
	top: 0px;
}
#sns .facebookicon{
	right: 35px ;
}
#sns .facebookicon img {
	width:25px;
}
#sns .twittericon{
	right: 0px ;
}
#sns .twittericon img {
	width:25px;
}
#sns a:hover {
	opacity:0.5;
}


/*==============================================
header
==============================================*/
#header{
	width:100% ;
	height:97px;
	padding-bottom: 30px;
}
#header h1 a{
	width:100px;
	height:97px;
	text-indent:-9999px;
	white-space:nowrap;
	overflow:hidden;
	display: block;
	margin:0 auto;
	background:url(../images/logo.jpg) no-repeat 0 0;
	background-size:100px 97px;
}




/*==============================================
headline
==============================================*/
#headline{
	position: relative;
	width: 100%;
	/* ソート機能追加時
	height: 80px;
	*/
	height:70px;
	margin-bottom: 10px
}
#headline a {
	display:inline-block;
}
#headline p.about a,
#headline p.ensen a,
#headline p.group a{
	line-height: 20px;
	text-decoration: none;
}
#headline p.topic a ,
#headline p.about a {
	position: absolute;
}
#headline .asita > p.about a{
	top: 0px;
	left: 0px;
	font-size:8px;
	line-height:10px;
	width:120px;
	padding:4px 0;
	border-bottom:#bababa solid 1px;
	text-align:left;
}
#headline .group > p.about a{
	top: 0px;
	right: 0px;
	font-size:8px;
	line-height:10px;
	width:120px;
	padding:4px 0;
	border-bottom:#bababa solid 1px;
	text-align:right;
	top:10px;

}
#headline p.topic a {
	top:45px;
	display:block;
	width:100%;
	font-size: 8px;
	line-height:10px;
	padding:4px 0;
	border:#ccc solid 1px;
	margin:0 auto 40px auto;
}
#headline p.topic a:hover {
	border:#ddd solid 1px;
}

#headline .sort {
	width:300px;
	height:30px;
	padding-top:45px;
	margin:0 auto;
}
#headline .sort p.ensen a,
#headline .sort p.group a{
	float:right;
	font-size:12px;
	line-height:30px;
	letter-spacing: 1px;
	width: 130px;
	height: 30px;
	margin:0 10px;
}

#headline p.ensen a{
	background-color: #fff200;
}
#headline p.ensen a:hover {
	background-color: #fff988;
}
#headline p.group a{
	background-color: #00aeef;
}
#headline p.group a:hover{
	background-color: #5bd2ff;
}


/*170403追記*/


/*=============================================
contents
==============================================*/
#contents {
	margin-bottom:25px;
}
#contents ul{
	width: 100%;
	overflow: hidden;
}
/*------------------------------------------------------
#contents ul#Container .mix{
	display: none;
}
------------------------------------------------------*/
#contents ul li{
	display:block;
	width: 100%;
	position:relative;
}
#contents ul li a {
	display:block;
	width: 100%;
	line-height:0px;
}
#contents ul li a img{
	width: 100%;
}

#contents ul li.numbers_sub{
	width: 50%;
	float: left;
}
#contents ul li .boxinner {
	margin:10px;
}
#contents ul li.numbers_sub a{
	margin:0px 7px 0px 0px;
}
#contents .numbers a span.mask {
	display:none;
}

/*==============================================
section
==============================================*/
#section {
	background:url(../images/railroad.gif) repeat-x 0 0;
	background-size:9px 4px;
	padding-top:30px;
}
#section ul.top_bnrs li {
	width:250px;
	height:40px;
	margin:0 auto 20px auto;
}
#section p{
	margin-bottom: 30px;
}
#section p img{
	position: relative;
	width: 100%;
	height: 100%;
	margin-top: 15px;
}
#section p.text{
	font-size: 24px;
	text-align: left;
	line-height: 50px;
}

#section p.comments{
	font-size: 12px;
	text-align: left;
	line-height: 50px;
}

/*==============================================
contents page
==============================================*/
#topic {
	padding:60px 0 80px 0;
}

#about a.close ,
#topic a.close {
	display:block;
	position:absolute;
	width:30px;
	height:30px;
	top:20px;
	right:20px;
	z-index:9999;
}
#about a.close:hover ,
#topic a.close:hover {
	opacity:0.5;
}
#about a.close img ,
#topic a.close img {
	width:30px;
	height:30px;
}
#about .about_inner {
	text-align:left;
	padding:50px;
}
#about .about_inner h2 ,
#topic h2 {
	font-size:22px;
	line-height:26px;
	margin-bottom:30px;
}
#topic p {
	text-align:left;
	margin-bottom:30px;
}
#topic p.cap {
	font-size:10px;
	line-height:16px;
}
#topic .topic_map img ,
#topic .outline img {
	width:100%;
}



#page #headline{
	width: 100%;
	height: auto;
	overflow:hidden;
}

#page #headline h2{
	text-align: left;
	font-size: 14px;
	padding-right:60px;
}
#page #headline h2 span{
	font-size: 30px;
	line-height: 30px;
	margin-right: 10px;
}
#page #headline a.g-icon {
	width:50px;
	height:30px;
	position:absolute;
	right:0px;
	bottom:0px;
}
#page #headline a.g-icon img{
	width:50px;
	height:30px;
}
#page #headline a.g-icon:hover img{
	opacity:0.5;
}
#page #contents {
}
#page #contents ul li {
	position: static;
}
#page #contents ul li img{
	width: 100%;
}
#page #section p,
#page #section p a {
	font-size:12px;
	line-height:25px;
}
#page #section p.text a{
	text-decoration:underline;
}
#page #section p.comments a{
	text-decoration:underline;
}
#page #pager {
	overflow:hidden;
	margin-bottom:50px;
	border-top: 1px solid #666666;
	border-bottom: 1px solid #666666;
}
#page #pager .left{
	float: left;
}
#page #pager .right{
	float: right;
}
#page #pager .right a,
#page #pager .left a{
	font-size:10px;
	line-height:20px;
	display: inline-block;
	margin:10px 0px;
}
#page #pager .pager_txt{
	display:none;
}


/*0404追記*/

.group_link{
	margin-top:40px;
	width:100%;
}

.group_link > li{
	float: left;
	display:inline;
	width:230px;
	padding-bottom: 10px;
}


/*.group_link > li > a{
	line-height: 20px;
	border-bottom: #bababa solid 1px;
}*/

.group_link > .li_last{
		padding-bottom: 70px;
}
/*==============================================
footer
==============================================*/
#footer{
	margin: 0px auto 60px auto;
}
#footer ul{
	margin-bottom:20px;
}
#footer ul li a{
	font-size: 10px;
	display:block;
	padding: 5px 0px;
	border-bottom: 1px solid #ffffff;
	background-color:#dddddd;
	color: #000000;
}
#footer p{
	font-size: 8px;
	line-height:10px;
}

/*==============================================
mv_pop
==============================================*/
#mv_pop{
	width: 100%;
	height: 100%;
	top:0;
	left:0;
  position: fixed;
  z-index: 1991;
	opacity: 0;
	display:none;
}
#mv_pop .bg{
	position:absolute;
	width: 100%;
	height: 100%;
	background:#000;
	opacity: 0.8;
}
#mv_pop #mv_popBox{
	position:absolute;
	width:1000px;
	height:563px;
    top: 50%;
    left: 50%;
    margin-top: -282px;
    margin-left: -500px;
	display:none;
}
#mv_pop .close_wrap2{
	position:absolute;
	float:right;
	width:30px;
	right:15px;
	top:-40px;
}
#mv_pop .close_wrap2 a img{
	width:100%;
	height:auto;
}




@media screen and (min-width: 768px) {

/*==============================================
main
==============================================*/
#main{
	padding:0px;
	width:1000px;
	margin: 30px auto 0px auto;
}
.sp { display:none }
.pc { display:block }
/*==============================================
sns
==============================================*/
#sns{
	height:50px ;
}
#sns .facebookicon{
	right: 65px ;
}
#sns .facebookicon img {
	width:50px;
}
#sns .twittericon{
	right: 0px ;
}
#sns .twittericon img {
	width:50px;
}

/*==============================================
header
==============================================*/
#header{
	height:194px;
	padding-bottom: 60px;
}
#header h1 a{
	width:200px;
	height:194px;
	background:url(../images/logo.jpg) no-repeat 0 0;
	background-size:200px 194px;
}
#header h1 a:hover{
	background:url(../images/logo_hover.gif) no-repeat 0 0;
	background-size:200px 194px;
}


/*==============================================
headline
==============================================*/
#headline{
	height: 32px;
	margin-bottom: 20px
}
#headline p.about a,
#headline p.ensen a,
#headline p.group a{
	line-height: 32px;
}
#headline p.about a{
	font-size:14px;
	line-height:30px;
	border-bottom:#000000 solid 1px;
	padding:0 0;
}
#headline p.about a:hover {
	border-bottom:#dddddd solid 1px;
}
#headline p.topic a br ,
#headline p.about a br {
	display:none;
}

#headline .sort {
	position:absolute;
	padding-top:0px;
	right:0px;
}
#headline .sort p.ensen a,
#headline .sort p.group a{
	cursor:pointer;
	font-size:14px;
	line-height:32px;
	width: 110px;
	height: 32px;
	margin:0 0 0 10px;
}
#headline p.topic a {
	top:0px;
	right:0px;
	/* ソート機能追加時
	right:344px;
	*/
	font-size: 14px;
	line-height:30px;
	padding:0 0;
	width:310px;
	border:#000 solid 1px;
}



/*170404追記*/
#headline > ul {
	position: relative;
}

#headline > ul > .group {


}

#headline > ul > .group a{
	left: 270px;
	width: 158px;
	padding-left: 5px;
	top:10px;}

#headline > ul > .asita a{
	width:240px;
}

#headline .asita > p.about a{
	top: 5px;
	left: 0px;
	font-size:14px;
	line-height:10px;
	width:240px;
	padding:4px 0;
	border-bottom:#bababa solid 1px;
	text-align:left;
}
#headline .group > p.about a{
	top: 5px;
	right: 0px;
	font-size:14px;
	line-height:10px;
	width:160px;
	padding:4px 0;
	border-bottom:#bababa solid 1px;
	text-align:right;
}

/*==============================================
contents
==============================================*/
#contents ul{
	width: 1035px;
	overflow: hidden;
}
#contents ul li.numbers_main{
	width: 655px;
	height: 655px;
	float: left;
	margin:0px 35px 0px 0px;
}
#contents ul li.numbers_sub{
	width: 310px;
	margin:0px 35px 35px 0px;
}
#contents ul li.numbers_sub a,
#contents ul li .boxinner {
	margin:0px;
}
#contents .numbers a span.mask{
	display:block;
	width:100%;
	height:100%;
	position:absolute;
	top:0;
	left:0;
	opacity:0;
	-webkit-transition:all 0.2s ease;
	transition:all 0.2s ease;
}
#contents .numbers.type_ensen a span.mask{
	background-color:rgba(255,244,51,1);
}
#contents .numbers.type_group a span.mask{
	background-color:rgba(0,174,239,1);
}
#contents .numbers a:hover span.mask {
	opacity:1;
}

/*==============================================
section
==============================================*/
#section {
	background:url(../images/railroad.gif) repeat-x 0 0;
	background-size:18px 8px;
}
#section ul.top_bnrs {
	width:870px;
	overflow:hidden;
	margin:0 auto 40px auto;
}
#section ul.top_bnrs li {
	float:left;
	margin:10px 20px;
}
#section p img{
	padding-top: 40px;
}
#section p.text{
	font-size: 18px;
}

#section p.comments{
	font-size: 12px !important;
	line-height: 20px !important;
}

/*==============================================
contents page
==============================================*/
#about #main{
	width:800px;
}
#about a.close {
	top:40px;
	right:40px;
}
#about .about_inner {
	padding:100px;
}
#about .about_inner h2 ,
#topic h2 {
	font-size:30px;
	line-height:35px;
	margin-bottom:30px;
}
#about .about_inner p ,
#topic p {
	font-size:18px;
	line-height:36px;
}
#topic .outline {
	width:1000px;
	height:540px;
	background-image:url(../images/topiclist_pc.png);
}
#topic .outline img {
	display:none;
}

#page #headline h2{
	font-size: 30px;
	line-height: 60px;
	padding-right:110px
}
#page #headline h2 span{
	font-size: 60px;
	line-height:60px;
}
#page #headline a.g-icon,
#page #headline a.g-icon img{
	width:100px;
	height:60px;
}
#page #contents .mainimage{
	width:1000px;
	margin-bottom:35px;
}
#page #contents .subimage{
	display: inline;
	width: 310px;
	float: left;
	margin:0px 35px 0px 0px;
}
#page #contents .one_item {
	width: 1000px;
	background:url(../images/one_item_bg.png) no-repeat 0 0;
}
#page #contents .one_item .subimage{
	display: block;
	width: 310px;
	float: none;
	margin:0px auto;
}


/*bxslider*/
#page div.bx-wrapper {
	position:relative;
}
#page a.bx-prev,
#page a.bx-next {
	display:block;
	text-indent:-9999px;
	white-space:nowrap;
	position:absolute;
	width:32px;
	height:32px;
	top:100px;
	z-index:9999;
}
#page a.bx-prev {
	left:-50px;
	background:url(../images/slider_pager_icon.png) no-repeat 0 0;
	background-size:64px 32px;
}
#page a.bx-next {
	right:-50px;
	background:url(../images/slider_pager_icon.png) no-repeat -32px 0;
	background-size:64px 32px;
}
#page #section p,
#page #section p a {
	font-size:18px;
	line-height:40px;
}

#page #pager {
	height:80px;
	border-top: 1px solid #000000;
	border-bottom: 1px solid #000000;
}
#page #pager .right a,
#page #pager .left a{
	font-size:18px;
	line-height:32px;
	margin:24px 0px;
}
#page #pager .pager_txt{
	display:inline-block;
	border-left: 1px solid #666666;
	padding-left: 10px;
	margin-left:10px;
}
#page #pager a:hover .pager_txt{
	border-left: 1px solid #dddddd;
}


/*0404追記*/

.group_link{
	margin-top:40px;
	width:600px;
}

.group_link > li{
	float: left;
	display:inline;
	width:200px;
	padding-bottom: 10px;
}


.group_link > li > a{
	line-height: 20px;
	border-bottom: #bababa solid 1px;
}


/*==============================================
footer
==============================================*/
#footer{
	width: 1000px;
}

#footer ul{
	border-top: none;
	float: left;
}

#footer ul li{
	float: left;
	border-bottom: none;
	padding: 0px;
}
#footer ul li a{
	background-color:transparent;
	border-bottom: none;
	padding: 0px ;
	margin-right:30px;
	font-size: 12px;
}
#footer ul li a:hover {
	color:#dddddd;
}
#footer p{
	float: right;
	font-size: 12px;
}

/*==============================================
mv_pop
==============================================*/
#mv_pop .close_wrap2{
	position:absolute;
	float:right;
	width:60px;
	right:0px;
	top:-80px;
}
}
