@charset "UTF-8";

@import url('https://fonts.googleapis.com/css?family=Rubik:400,500');

/* * * * * * * * * * * * * * * * * *
 base.css
* * * * * * * * * * * * * * * * * */

/* reset, common
--------------------------------- */
* {
	margin:0; padding:0; list-style:none;
	outline: none;
}

body{
	margin: 0;
	padding: 0;
	line-height: 1.6;
	font-size: 14px;
	color: #333;
	font-family: "Rubik", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HiraKakuProN-W3", "HiraKakuPro-W3", 'ヒラギノ角ゴ ProN W3', 'ヒラギノ角ゴ Pro W3', "Meiryo UI", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	width: 100%;
	background: #FFF;
	letter-spacing: 0.5px;
	overflow-x: hidden;
}

h1,h2,h3,h4,h5,h6{
	font-size:100%;
	font-weight:normal;
}

img {
	border:none;
	vertical-align: bottom;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
	max-width: 100%;
	height: auto;
}

a {
	color: #333;
	outline : none ;
	text-decoration: none;
}
a:hover{
	text-decoration: underline;
}

/* fonts */
.f_min {
font-family:"ヒラギノ明朝 Pro W6", "Hiragino Mincho Pro", "HGS明朝E", "ＭＳ Ｐ明朝", serif;
}
.font_s { font-size: 90%; }
.font_big { font-size: 130%; }

/* color */
.red {color: #FF0000;}
.color_theme {color: #4FC2F9;}

/* float */
.l {float: left;}
.r {float: right;}

.tac {text-align: center;}
.tar {text-align: right;}

/* clearfix */
.clearfix:after {
	content : "." ;
	display : block ;
	height : 0 ;
	clear : both ;
	visibility : hidden ;
}
.clearfix { display : inline-block ; }
/* Hides from IE-Mac \*/
*html .clearfix { height : 1% ; }
.clearfix { display : block ; }
/* End hide from IE-mac */

.none {display: none!important;}

.inWrap li,
.txt_indent {
	text-indent: -1em;
	padding-left: 1em;
}

/* opacity */
a:hover img {
	filter: alpha(opacity=50);
	-moz-opacity:0.50;
	opacity:0.50;
}

/* margin */
.mb10 {margin-bottom: 10px;}
.mb20 {margin-bottom: 20px;}
.mb30 {margin-bottom: 30px;}
.mb40 {margin-bottom: 40px;}
.mt10 {margin-top: 10px;}
.mt20 {margin-top: 20px;}
.mt30 {margin-top: 30px;}
.mt40 {margin-top: 40px;}

/* parts */
label {
	cursor: pointer;
	user-select: none;
	-moz-user-select: none;
	-webkit-user-select: none;
}

input, select, button {
	font-family: "Rubik", "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HiraKakuProN-W3", "HiraKakuPro-W3", 'ヒラギノ角ゴ ProN W3', 'ヒラギノ角ゴ Pro W3', "Meiryo UI", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.noPC {
	display: none;
}


/* アニメーション */
a, a:before, a:after, a p,
a img,
p.btnBox input,
#shareList, .shareList, button,
#header, #header h1, nav.nav {
	-webkit-transition: all .3s ease;
	-moz-transition: all .3s ease;
	-o-transition: all .3s ease;
	-ms-transition: all .3s ease;
	transition: all .3s ease;
}

/* display */
.table {display: table;width: 100%;}
.table_c {display: table-cell;}


#wrap, .inner {
	min-width: 700px;
}

/*クリック防止*/
.replace_img_tag,
.txts .image{
	position: relative;
}
.imgcover{
	width: 100%;
	height: 100%;
	background: url(/img/common/cover.png) center center;
	z-index: 9997;
	position: absolute;
	top: 0;
	left: 0;
	display: block;
}
#clickwindow{
	width: 100%;
	height: 100%;
	background: url(/img/common/cover.png) center center;
	z-index: 9998;
	position: fixed;
	top: 0;
	left: 0;
	display: block;
}


/* header
--------------------------------- */
#header {
	position: fixed;
	width: 100%;
	background: #FFF;
	left: 0;
	top: 0;
	height: 80px;
	z-index: 999;
}

#header h1 {
	line-height: 80px;
}
#header h1 img {
	vertical-align: middle;
}

#header div.search {
	font-weight: bold;
}

ul.headBtn {
	position: absolute;
	right: 0;
	top: 0;
	text-align: center;
}
ul.headBtn li {
	width: 85px;
	float: left;
}
ul.headBtn li#share {
	width: 75px;
}

ul.headBtn li a {
	display: block;
	padding-top: 45px;
	box-sizing: border-box;
	height: 75px;
	background-position: center 12px;
	background-repeat: no-repeat;
	background-size: auto 30px;
}
ul.headBtn li#share a {
	background-image: url(../img/common/btn_share.png);
}
ul.headBtn li.login a {
	background-image: url(../img/common/btn_login.png);
}
ul.headBtn li.logout a {
	background-image: url(../img/common/btn_logout.png);
}
ul.headBtn li.signup a {
	background-image: url(../img/common/btn_signup_on.png);
	background-color: #114b60;
	color: #FFF;
}

ul.headBtn li.member a {
	padding-top: 12px;
	color: #32D8CE;
	/* 	color: #FFF; */
}
ul.headBtn li.member a p.img_prof {
	margin-bottom: 3px;
}
ul.headBtn li.member a p.img_prof img {
	width: 55px;
	height: 55px;
	border-radius: 50%;
	filter: alpha(opacity=100);
	-moz-opacity:1.0;
	opacity:1.0;
}
ul.headBtn li.premium a {
	color: #ffbe00;
}


ul.headBtn li a:hover {
	text-decoration: none;
}

#shareList,
.shareList {
	background: url(../img/common/bg_menu2.png) center top repeat #555;
	color: #FFF;
	box-sizing: border-box;
	text-align: center;
	height: 0;
	overflow: hidden;
	filter: alpha(opacity=0);
	-moz-opacity:0;
	opacity:0;
}
#shareList.on,
.shareList.on {
	display: block;
	filter: alpha(opacity=100);
	-moz-opacity:1.0;
	opacity:1.0;
	height: auto;
	padding: 15px 0 20px;
}
#shareList p.ttl_menu,
.shareList p.ttl_menu {
	font-size: 18px;
	letter-spacing: 1px;
	margin-bottom: 5px;
}

#shareList ul li,
.shareList ul li {
	display: inline-block;
	*display: inline;
	*zoom: 1;
	line-height: 44px;
}
#shareList ul li + li:before,
.shareList ul li + li:before {
	content: "";
	display: inline-block;
	*display: inline;
	*zoom: 1;
	width: 1px;
	height: 44px;
	background: rgba(255,255,255,.5);
	margin: 0 40px 0 25px;
	vertical-align: middle;
}

/* PC Only */
@media screen and (min-width: 769px) {
	body.naka #header h1 img {
		width: 130px;
	}

	ul.headBtn li a {
		height: 80px;
	}

	#header div.search {
		position: absolute;
		left: 0;
		top: 30px;
		text-align: left;
	}
	#header div.search input.searchTxt {
		border: 2px solid #000;
		height: 40px;
		width: 220px;
		box-sizing: border-box;
		line-height: 38px;
		padding: 0 0 0 30px;
		background: url(../img/common/btn_search.png) 5px center no-repeat;
		margin: 5px 0 0;
		font-size: 14px;
	}
	ul.headBtn li a:hover {
		filter: alpha(opacity=50);
		-moz-opacity:0.5;
		opacity:0.5;
	}

	#shareList,
	.shareList {
		position: absolute;
		right: 0px;
		top: 75px;
		z-index: 9999;
		width: 240px;
	}

}


/* main
--------------------------------- */
#main {
	padding-bottom: 85px;
}
.inner {
	position: relative;
	width: 1024px;
	margin-left: auto;
	margin-right: auto;
}

li {
	box-sizing: border-box;
}

/* contents */
p.btn {
	text-align: center;
	padding-top: 30px;
}
.btn a,
button.btn {
	text-align: center;
	display: inline-block;
	*display: inline;
	*zoom: 1;
	width: 440px;
	max-width: 100%;
	box-sizing: border-box;
	height: 52px;
	line-height: 52px;
	padding: 0 50px;
	background: url(../img/common/arrow_btn.png) right 15px top 50% no-repeat #32D8CE;
	background-size: 11px auto;
	color: #FFF;
	font-size: 20px;
	letter-spacing: 2px;
}
button.btn {
	border: 0;
	cursor: pointer;
}
.btn a:hover,
button.btn:hover {
	text-decoration: none;
	filter: alpha(opacity=70);
	-moz-opacity:0.7;
	opacity:0.7;
}

span.fav {
	color: #ff82a0;
	display: inline-block;
	*display: inline;
	*zoom: 1;
	padding-left: 25px;
	background: url(../img/common/icon_fav.png) left center no-repeat;
	background-size: 22px auto;
}



/* side */
#side .box + .box {
	margin-top: 30px;
}

ul.bnr li + li {
	margin-top: 15px;
}

p.ttl_side {
	text-align: center;
	font-weight: bold;
	margin-bottom: 10px;
	font-size: 21px;
}
p.ttl_side:before,
.btn_fav:before {
	content: "";
	display: inline-block;
	*display: inline;
	*zoom: 1;
	vertical-align: text-top;
	margin-right: 5px;
	width: 26px;
	height: 20px;
	background-size: 100% 100%;
	background-position: 0 0;
	background-repeat: no-repeat;
}

#ranking p.ttl_side:before {
	background-image: url(../img/common/icon_ttl_rank.png);
}
#twiBox p.ttl_side:before {
	background-image: url(../img/common/icon_ttl_twi.png);
}
.fav p.ttl_side:before,
.btn_fav:before {
	background-image: url(../img/common/icon_ttl_fav.png);
}
.recommend p.ttl_side:before {
	background-image: url(../img/common/icon_ttl_recommend.png);
}

.boxIn {
	border: 1px solid #e3e3e3;
	background: #FFF;
}

#ranking ul.tabNav {
	border-bottom: 1px solid #e3e3e3;
}
#ranking ul.tabNav li {
	width: 50%;
	float: left;
	text-align: center;
}
#ranking ul.tabNav li a {
	display: block;
	line-height: 40px;
	background: #ECF8F8;
	border-bottom: 3px solid transparent;
	font-weight: 500;
	font-size: 16px;
}
#ranking ul.tabNav li a:hover {
	text-decoration: none;
}
#ranking ul.tabNav li a:after {
	font-weight: 400;
}
#ranking ul.tabNav li.active a {
	background: #FFF;
	color: #32D8CE;
	border-bottom-color: #32D8CE;
}

ul.rankList li + li {
	border-top: 1px solid #e3e3e3;
}

ul.rankList li a {
	display: block;
	padding: 15px;
	position: relative;
}
ul.rankList li a:hover {
	text-decoration: none;
}
ul.rankList li a p.thum {
	width: 35%;
	float: left;
	overflow: hidden;
}
ul.rankList li a p.thum img {
	width: 100%;
}
ul.rankList li a:hover p.thum img {
	-webkit-transform: scale(1.1);
	-moz-transform: scale(1.1);
	-o-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
	filter: alpha(opacity=100);
	-moz-opacity:1.0;
	opacity:1.0;
}

ul.rankList li a .detail {
	width: 62%;
	float: right;
	padding-top: 15px;
}
ul.rankList li a .detail p.num {
	position: absolute;
	right: 0;
	top: 0;
}
ul.rankList li a .detail p.num span {
	position: relative;
	display: block;
	width: 85px;
	text-align: center;
	color: #FFF;
	background: #12191F;
	height: 22px;
	line-height: 22px;
	padding-left: 14px;
}
ul.rankList li:nth-child(-n+3) a .detail p.num span {
	background: #FF82A0;
}
ul.rankList li a .detail p.num span:before {
	content: "";
	display: inline-block;
	*display: inline;
	*zoom: 1;
	width: 0;
	height: 0;
	border-top: 11px solid transparent;
	border-right: 7px solid transparent;
	border-bottom: 11px solid #FFF;
	border-left: 7px solid #FFF;
	position: absolute;
	left: 0;
	top: 0;
}

ul.rankList li a .detail p.ttl {
	font-weight: bold;
	color: #32D8CE;
	font-size: 15px;
}
ul.rankList li a .detail p.txt {
	margin: 5px 0;
	line-height: 17px;
	height: 34px;
	overflow: hidden;
}
ul.rankList li a:hover .detail p.txt {
	color: #32D8CE;
}

ul.rankList li a .detail p.data {
	font-size: 13px;
	line-height: 1;
}
ul.rankList li a .detail p.data span.date {
	color: #AAA;
	margin-right: 10px;
}
ul.rankList li a .detail p.data span.fav {
	background-size: 13px auto;
	padding-left: 15px;
}

#twiBox iframe {
	vertical-align: bottom;
}

p.btn_follow {
	padding: 15px 15px 0;
}
p.btn_follow a {
	background-color: #1DA1F3;
	background-size: 8px auto;
	font-size: 16px;
	letter-spacing: 1px;
}
p.btn_follow a:before {
	content: "";
	display: inline-block;
	*display: inline;
	*zoom: 1;
	width: 18px;
	height: 18px;
	background: url(../img/common/btn_sns_tw_on.png) 0 0 no-repeat;
	background-size: 100% 100%;
	vertical-align: middle;
	margin-right: 5px;
}

ul.favList {
	margin: 0 -1px -1px;
}
ul.favList li {
	width: 33.333333%;
	float: left;
	padding: 0 1px 2px;
	position: relative;
}
ul.favList li a {
	display: block;
	overflow: hidden;
}
ul.favList li a:hover img {
	-webkit-transform: scale(1.1);
	-moz-transform: scale(1.1);
	-o-transform: scale(1.1);
	-ms-transform: scale(1.1);
	transform: scale(1.1);
	filter: alpha(opacity=100);
	-moz-opacity:1.0;
	opacity:1.0;
}
ul.favList li p.data {
	position: absolute;
	right: 5px;
	bottom: 5px;
	font-size: 12px;
	text-shadow: 0 0 2px #FFF,0 0 2px #FFF,0 0 2px #FFF,0 0 2px #FFF,0 0 2px #FFF,0 0 2px #FFF,0 0 2px #FFF,0 0 2px #FFF;
	line-height: 1.2;
}
ul.favList li p.data span.fav {
	background-size: 13px auto;
	padding-left: 15px;
}

/* PC Only */
@media screen and (min-width: 769px) {

	#contents {
		width: 680px;
		float: left;
	}

	#side {
		width: 315px;
		float: right;
	}

}

/* footer
--------------------------------- */
#footer {
	text-align: center;
	background:#CFD9DB;
}

dl.staff {
	width: 235px;
	height: 272px;
	background: url(../img/common/bg_staff.png) center top no-repeat;
	text-align: center;
	box-sizing: border-box;
	color: #FFF;
	padding-left: 15px;
	padding-right: 15px;
}
dl.staff dt {
	font-weight: 500;
	padding-bottom: 10px;
	border-bottom: 1px solid #88a5b0;
}
dl.staff dd {
	border-bottom: 1px solid #88a5b0;
	padding: 3px 0;
}

#footer nav.nav {
	background:#CFD9DB;
}

#footer p.logo {
	padding: 45px 0 40px;
}

ul.footLink li a {
	color: #114B60;
}

#footer p.copy {
	color: #114B60;
	padding: 25px 0;
	font-size: 13px;
	letter-spacing: 1px;
}

.popBox {
	text-align: center;
}
.popBox p {
	color: #465A65;
	padding: 50px 0 30px;
	font-size: 20px;
	font-family: "游ゴシック", "Yu Gothic", "游ゴシック体", "YuGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HiraKakuProN-W3", "HiraKakuPro-W3", 'ヒラギノ角ゴ ProN W3', 'ヒラギノ角ゴ Pro W3', "Meiryo UI", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-weight: bold;
}

.popBox .box {
	padding: 0 30px;
}

.popBox a {
	display: table;
	width: 340px;
}
.popBox a:hover {
	text-decoration: none;
}
.popBox a span {
	display: table-cell;
	vertical-align: middle;
	color: #FFF;
	font-size: 14px;
	background: #4FC2F8;
	height: 60px;
}


/* PC Only */
@media screen and (min-width: 769px) {

	dl.staff {
		background-size: 100% 100%;
		padding-top: 45px;
		position: absolute;
		left: 80px;
		bottom: 30px;
	}
	dl.staff dt {
		font-size: 20px;
	}
	dl.staff dd {
		font-size: 13px;
	}

	.foot_btm {
		padding-left: 360px;
		height: 320px;
		text-align: left;
	}
	#footer .foot_btm p.logo {
		padding-top: 60px;
		padding-bottom: 30px;
		width: 334px;
	}

	ul.navBtn li {
		display: inline-block;
		*display: inline;
		*zoom: 1;
		font-weight: 500;
	}
	ul.navBtn li + li {
		margin-left: 25px;
	}
	ul.navBtn li a {
		color: #114B60;
		display: inline-block;
		*display: inline;
		*zoom: 1;
	}
	ul.navBtn li.signup a {
		padding-left: 25px;
		background: url(../img/common/icon_foot_signup.png) left center no-repeat;
	}
	ul.navBtn li.login a {
		padding-left: 25px;
		background: url(../img/common/icon_foot_login.png) left center no-repeat;
	}
	ul.navBtn li.share a {
		padding-right: 60px;
		background: url(../img/common/icon_foot_share.png) right center no-repeat;
	}
	ul.navBtn li.sitetop a {
		padding-left: 15px;
		background: url(../img/common/arrow_foot.png) left center no-repeat;
	}
	#footer p.copy {
		font-size: 12px;
	}

	ul.footLink {
		margin-top: 30px;
		margin-bottom: -5px;
	}
	ul.footLink li {
		display: inline-block;
		*display: inline;
		*zoom: 1;
		color: #114B60;
		font-size: 12.5px;
	}
	ul.footLink li + li {
		padding-left: 3px;
	}
	ul.footLink li + li:before {
		content: "|";
		margin-right: 8px;
		color: #114B60;
	}

	#footer .shareList {
		right: auto;
		left: 570px;
		top: 230px;
	}

}


/* scrollup */
#topcontrol {
	z-index: 20;
}
p#scrollup {
	text-indent: -9999px;
	width: 60px;
	height: 60px;
	background: #4FC2F9;
	position: relative;
}
	p#scrollup:before,
	p#scrollup:after {
		content: "";
		display: block;
		width: 0;
		height: 0;
		border: 12px solid transparent;
		border-bottom: 12px solid #FFF;
		position: absolute;
		left: 50%;
		top: 50%;
		margin: -17px 0 0 -12px;
	}
	p#scrollup:after {
		border-bottom: 12px solid #4FC2F9;
		margin-top: -14px;
	}
