@charset "utf-8";

/* スクロール遅延回避 */
.ie * {
	border-radius: 0 !important;
}

html {
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
}
aside {
	display: block;
}
img, iframe {
	border: 0;
	vertical-align: bottom;
}
svg:not(:root) {
  overflow: hidden;
}
hr {
  margin-top: 20px;
  margin-bottom: 20px;
  border: 0;
  border-top: 1px solid #eee;
  height: 0;
}
*, *:before, *:after {
  box-sizing: border-box;
}

body {
	margin: 0;
	background: #fafafa;
	color: #333;
	font-size: 14px;
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.42857143;
}
h1, h2, h3, ul, ol, li {
	margin: 0;
	padding: 0;
	font-size: 100%;
	font-weight: 400;
	list-style: none;
}
a {
	background: transparent;
	color: #004d79;
	text-decoration: none;
}
a:hover {
	color: #004d79;
	text-decoration: underline;
}
a:active,
a:hover {
  outline: 0;
}

b {
	font-weight: 400;
}
.text-center {
  text-align: center;
}
.hide {
  display: none !important;
}
.show {
  display: block !important;
}
.clearfix:before,
.clearfix:after,
.container:before,
.container:after {
  display: table;
  content: " ";
}
.clearfix:after,
.container:after {
  clear: both;
}
.container {
  margin-right: auto;
  margin-left: auto;
}
.pompass {
	max-width: 100% !important;
}

body #smartphone {
	display: none;
	padding: 5px 0;
}
body #smartphone .smartphonelink {
	display: inline-block;
	padding: 5px 20px;
	font-size: 12px;
}

#top {
	background: #fff;
	box-shadow: rgba(0,0,0, .15) 0 0 2px;
}
#top-logo {
	float: left;
}
#top-logo a {
	display: block;
	padding: 10px 0;
	outline: none;
}
#top-logo a:hover {
	animation: logo 0.8s linear 0s 1;
}
@keyframes logo {
	0%   { transform: scale(1.0, 1.0) translate(0%, 0%); }
	15%  { transform: scale(0.9, 0.9) translate(0%, 5%); }
	30%  { transform: scale(1.3, 0.8) translate(0%, 10%); }
	50%  { transform: scale(0.8, 1.3) translate(0%, -10%); }
	70%  { transform: scale(1.1, 0.9) translate(0%, 5%); }
	100% { transform: scale(1.0, 1.0) translate(0%, 0%); }
}
#top img {
	height: 20px;
}
#top-nav {
	padding: 5px 0;
	text-align: right;
}
#top-nav li {
	display: inline-block;
}
#top-nav li:after {
	content: '';
	display: inline-block;
	margin: 0 1em;
	height: 1em;
	width: 1px;
	background: #ddd;
	vertical-align: middle;
}
#top-nav li:last-child {
	padding-right: 0;
}
#top-nav li:last-child:after {
	display: none;
}
#top-nav a {
	display: inline-block;
	padding: 5px 0;
	color: #777;
	font-size: 13px;
	line-height: 20px;
}

#gnav {
	position: relative;
	z-index: 5;
	-webkit-transform: translate3d(0,0,0);
		transform: translate3d(0,0,0);
	transition: all 0.3s ease;
	transition-property: box-shadow, font-size, padding;
}
#gnav.gnav-fixed {
	position: fixed;
	top: 0;
	padding-bottom: 4px;
}
#gnav.gnav-fixed > div:last-child,
#gnav.gnav-fixed .gnav-pulldown {
	box-shadow: 0 1px 0 rgba(12,13,14,0.1),0 1px 3px rgba(12,13,14,0.1),0 4px 20px rgba(12,13,14,0.035),0 1px 1px rgba(12,13,14,0.025);
}
#gnav.gnav-fixed > :nth-child(2),
#gnav.gnav-fixed .gnav-pulldown {
	border-bottom: 0;
}
#gnav.gnav-fixed {
	font-size: 12px;
}
#gnav ul {
	margin: 0;
	padding: 0;
	list-style: none;
}
.gnav-scroll,
.gnav-pulldown {
	overflow: hidden;
	height: 2.7em;
}
.gnav-scroll:first-child {
	background: #347baa;
}
.gnav-scroll:nth-child(2),
.gnav-pulldown {
	background: #fff;
	border-bottom: solid 1px #ddd;
}
.gnav-scroll-mask {
	height: 5em;
	width: 100%;
	overflow-x: auto;
	-webkit-overflow-scrolling: touch;
}
.gnav-scroll ul {
	display: inline-table;
	margin: 0 auto;
	max-width: 100%;
}
.gnav-scroll li {
	display: table-cell;
}
.gnav-scroll a {
	display: inline-block;
	font-weight: bold;
	white-space: nowrap;
}
.gnav-scroll a:hover {
	text-decoration: none;
}
.gnav-pulldown {
	display: none;
	position: absolute;
	top: 2.7em;
	left: 0;
	width: 100%;
	z-index: 100;
}
.gnav-pulldown ul {
	position: relative;
}
#gnav-parent > li > a {
	padding: 0 1em;
	color: #fff;
	height: 2.7em;
	border-right: solid 1px rgba(0,0,0,.15);
	box-shadow: 1px 0 0 rgba(255,255,255,.08);
	line-height: 2.7;
	text-shadow: 0 1px 0 rgba(0,0,0,.29)
}
#gnav-parent:before {
	content: '';
	display: inline-block;
	height: 2.7em;
	border-right: solid 1px rgba(0,0,0,.15);
	box-shadow: 1px 0 0 rgba(255,255,255,.08);
	vertical-align: middle;
}
#gnav-parent > li > a:hover {
	border-right: solid 1px rgba(0,0,0,.19);
	background: #438eb9;
	box-shadow: none;
}
#gnav-parent > li.active > a {
	border: 0;
	border-left: solid 1px rgba(0,0,0,.1);
	background: #1e5f93;
	color: #fff;
}
#gnav-child,
.gnav-pulldown ul {
	border-left: solid 1px #e7e7e7;
}
#gnav-child li,
.gnav-pulldown li {
	border-right: solid 1px #e7e7e7;
}
#gnav-child a,
.gnav-pulldown a {
	position: relative;
	overflow: hidden;
	height: 2.7em;
	padding: 0 1em;
	background: #fff;
	color: #3c6e8a;
	line-height: 2.7;
	text-decoration: none;
	font-weight: bold;
	-webkit-transform: translateZ(0);
	transform: translateZ(0);
}
#gnav-child a:before,
.gnav-pulldown a:before {
	content: '';
	position: absolute;
	left: .6em;
	right: .6em;
	bottom: 0;
	background: #ffb253;
	height: .29em;
	-webkit-transform: translateY(.29em);
	-webkit-transition: transform .3s ease-out;
	transform: translateY(.29em);
	transition: transform .3s ease-out;
}
#gnav-child a:hover:before,
#gnav-child .active a:before,
.gnav-pulldown a:hover:before {
	-webkit-transform: translateY(0);
	transform: translateY(0);
}
#gnav-child a:hover,
#gnav-child .active a,
.gnav-pulldown a:hover {
	color: #333;
}


#body {
	position: relative;
}
#main {
	float: left;
	width: 100%;
	margin-right: -313px;
}
#main-inner {
	margin-right: 313px;
	border-top: 0;
}

#cat-title {
  display: none;
  margin: 0;
  padding: 15px 15px 8px;
  font-size: 14px;
  font-weight: bold;
}

#error {
	position: relative;
	margin: 10px 0;
	padding: 1em 1em 1em 44px;
	border-radius: 3px;
	border: 1px solid #ECE9CE;
	background: #FFF9E9;
	color: #775C17;
}
#error svg {
	position: absolute;
	top: 50%;
	left: 1em;
	margin-top: -10px;
	width: 20px;
	height: 20px;
}
#error path {
	fill: #ddbb46;
}

.section {
	overflow: hidden;
	margin: 10px 0;
	border-radius: 3px;
	background: #fff;
	border: solid 1px;
	border-color: #e6e6e6 #e3e3e3 #d5d5d5;
}
#entries-tabs, #main h2 {
	background: #fafbfc;
}


#entries-tabs li {
	display: inline-block;
}
#entries-tabs li:after {
	content: '';
	display: inline-block;
	width: 1px;
	height: 1em;
	background: #ddd;
	vertical-align: middle;
}
#entries-tabs a {
	position: relative;
	display: inline-block;
	box-sizing: border-box;
	margin: 0 1.07em;
	padding: 0 .5em;
	color: #576b75;
	font-size: 1.07em;
	line-height: 2.7;
	height: 2.6em;
	text-decoration: none;
	transition: color .2s ease-out;
}
#entries-tabs a:focus {
	outline: none;
}
#entries-tabs a:hover, #entries-tabs a.active {
	color: #222;
}
#entries-tabs a.active {
	cursor: default;
}
#entries-tabs a:before {
	content: '';
	position: absolute;
	z-index: 1;
	left: 50%;
	right: 50%;
	bottom: 0;
	background: #4dabff;
	height: .21em;
	transition-property: left, right;
	transition-duration: .2s;
	transition-timing-function: ease-out;
}
#entries-tabs a.active:before {
	transition-delay: .5s;
}
#entries-tabs a:hover:before, #entries-tabs a.active:before {
	left: 0;
	right: 0;
}
#entries-contents {
	border-top: 1px solid #d7d7d7;
	background: #fff;
}
#entries-contents > div {
	display: none;
}
#entries-contents > div.active {
	display: block;
	animation: entriesTabShow .1s linear;
	opacity: 1;
}
@keyframes entriesTabShow {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}
#entries-contents .entries {
	padding: 5px 0 0;
}
.entries-scroll, .entries-loading {
	overflow-x: hidden;
	overflow-y: scroll;
	height: 375px;
	-webkit-overflow-scrolling: touch;
}
.entries-scroll.subcategory {
	overflow-y: visible;
	height: auto;
}
.entries-loading, .entries-loading:before {
	overflow: hidden;
	padding: 0;
}
.entries-loading:before {
	content: '読み込み中... (´・ω・｀)';
	display: block;
	color: #bbb;
	font-size: 32px;
	line-height: 370px;
	text-align: center;
}
.entries-error {
	text-align: center;
}
.entries-error:before {
	content: '';
	display: inline-block;
	height: 100%;
	width: 0;
	vertical-align: middle;
}
.entries-error div {
	display:inline-block;
	vertical-align: middle;
}
.entries-error br {
	display: inline !important;
}
.entries-error a {
	display: inline-block;
	margin-top: 1em;
	border-radius: 3px;
	border: solid 1px #B8C3CE;
	padding: .8em 1em;
	background: #FAFBFC;
}
.entries-error svg {
	margin-right: .5em;
	vertical-align: middle;
	fill: #03334e;
}

.mac .entries-scroll::-webkit-scrollbar {
	-webkit-appearance: none;
	overflow:hidden;
	width: 10px;
	background:#fff;
	border-left: solid 1px #eee;
	padding: 1px;
}
.mac .entries-scroll::-webkit-scrollbar-thumb {
	border-radius: 5px;
	background-color: #888;
}



#main  h2 {
	margin: 0;
	padding: .65em .93em .36em;
	border-top: 1px solid #e7e7e7;
	border-bottom: 1px solid #d7d7d7;
	color: #222;
	font-size: 1.07em;
}
#main  h2:first-child {
	border-top: 0;
}
#content > section:first-of-type h3 {
	border-top: 0;
}
#content .btn {
	margin: 0 10px;
	width: auto;
	border-color: #C0E2F4;
	background: #F4FBFF;
	color: #0072AE;
}
#content .btn:hover {
	background: #DFEEF7;
}
a.p:visited {
	color: #aaa;
}
a.p:hover,
#sub a:hover {
	background-color:#FFFCEA;
	color: #05344e;
	text-decoration: underline;
}

#pickup br, #pickup object,
#new br, #new object {
	display: none;
}
.p {
	position: relative;
	display: block;
	overflow: hidden;
	padding: .4em 14px;
	border-bottom: 1px dotted #E1E1E1;
	background: #fff;
	white-space: nowrap;
	text-overflow: ellipsis;
}
#pickup-entries ul {
	border-top: 1px dotted #E1E1E1;
}
#pickup-entries ul .p:last-of-type {
	border-bottom-width: 1px;
}
#pickup-entries .p:last-of-type {
	border-bottom-width: 0;
}
.p-rank {
	padding-left: 40px;
}
.p-date {
	padding-right: 60px;
}
#new div > .p:last-of-type, #hotentry-inner > .p:last-of-type, li:last-child .p {
	border-bottom: 0;
}
a.p.titlelink {
	color: #E61E1E;
}
a.p i {
	display: none;
}
b {
	overflow: hidden;
	display: block;
	white-space: nowrap;
	text-overflow: ellipsis;
}
b.bracket {
	text-indent: -.5em;
}

.rank {
	position: absolute;
	top: 50%;
	left: 15px;
	display: inline-block;
	margin-top: -8px;
	height: 16px;
	width: 16px;
	border-radius: 2px;
	background: #aaa;
	color: #fff;
	font-size: 10px;
	font-weight: bold;
	line-height: 18px;
	text-align: center;
	vertical-align: top;
}
.rank1 {
	background: #fffa90;
	background: #f1c40f;
}
.rank2 {
	background: #f6f6f6;
	background: #95a5a6;
}
.rank3 {
	background: #FFDA91;
	background: #e67e22;
}
.date {
	position: absolute;
	top: 50%;
	right: 15px;
	margin-top: -10px;
	height: 20px;
	color: #999;
	font-size: 11px;
	line-height: 20px;
}


.site-divider {
	padding: 1.1em .93em 1.1em;
	border-top: solid 1px #ddd;
	color: #222;
	font-size: 1.07em;
}

#site-footer {
	padding: 10px;
	border-top: 1px solid #e1e1e1;
	font-size: 16px;
	text-align: center;
}
#site-footer.entries-loading {
	height: 45px;
}
#site-footer.entries-loading:before {
	color: #555;
	font-size: 15px;
	line-height:25px;
}
.load-more-btn {
	display: block;
	padding: 10px 0;
	font-weight: bold;
}
.load-retry-message {
	padding: 10px 0 0;
	line-height: 1.5;
}


#content .pager {
	margin: 0 0 30px;
	padding: 20px 0 0;
	border-top: solid 1px #eee;
	text-align: center;
}
#content .pager a {
	margin-bottom: 7px;
	padding-right: 9px;
	padding-left: 9px;
}



#sub {
	float: right;
	width: 300px;
}

#sub aside {
  margin: 20px 0;
  background: transparent;
  border: 0;
}
#sub aside:first-child {
	margin-top: 10px;
}
#sub aside:last-child {
  margin-bottom: 0;
}
#sub aside > div {
	height: 250px;
}
#sub h2 {
  overflow: hidden;
  position: relative;
  margin: 0 0 3px;
  padding-bottom: 5px;
  color: #222;
  font-size: 15px;
}
#sub h2 small {
	float: right;
	margin-top: 5px;
	color: #999;
	font-size: 11px;
}
#sub h2::before, #sub h2::after{
  content: "";
  position: absolute;
  bottom: 0;
}
#sub h2:before{
  border-bottom: 2px solid #325A8C;
  width: 100%;
}
#sub h2:after{
  border-bottom: 2px solid #D8D8D8;
  width: 100%;
}

#sub ul {
	margin: 0;
	padding: 0;
	font-size: 12px;
	list-style: none;
}
#sub li {
	position: relative;
	margin: 0;
	padding: 0;
}
#sub li a {
	position: relative;
	display: block;
	overflow: hidden;
	padding: .5em 0;
	border-bottom: 1px solid #e7e7e7;
	background: transparent;
	white-space: nowrap;
	text-overflow: ellipsis;
	z-index: 2;
}
#sub.multiline li a {
	white-space: normal;
}
#sub li b {
	white-space: normal;
	word-break: break-all;
}
#sub li a.has-img {
	padding-right: 70px;
	min-height: 73px;
}
#sub li span {
	position: absolute;
	top: 6px;
	right: 0;
	display: block;
	height: 60px;
	width: 60px;
	background: #eee;
	text-align: center;
}
#sub li span:before {
	content: '';
	display: inline-block;
	height: 100%;
	width: 0;
	vertical-align: middle;
}
#sub li span img {
	max-width: 100%;
	max-height: 100%;
	vertical-align: middle;
}
#affix-ad.affix {
	top: 0;
}


.container {
	max-width: 1043px;
	width: auto;
}

@media (max-width: 1099px) {
	body {
		font-size: 13pt;
	}
	.container {
		max-width: none;
	}
	#top {
		padding: 0 14px;
	}
	#main {
		float: none;
		margin-right: 0;
	}
	#main-inner {
		margin-right: 0;
	}
	#sub {
		display: none;
	}
	.section {
		border-radius: 0;
		border-right: 0;
		border-left: 0;
	}
	a.p:hover {
		background-color: #f9f9f9;
	}
}

@media (max-width: 999px) {
	#top nav {
		display: none;
	}
}

@media (max-width:899px) {
	a.p {
		padding-right: 14px;
	}
	a.p, b {
		white-space: normal;
		word-break: break-all;
	}
	.date {
		position: static;
		display: inline;
	}
	.date:before {
		content: '　';
	}
	.entries-scroll {
		overflow-y: visible;
		height: auto;
	}
	.entries-scroll li:nth-child(n+11) {
		display: none;
	}
	a.p:hover {
		background-color: transparent;
	}
}


@media (max-width: 799px) {
	body {
		font-size: 12pt;
	}
	.entries-loading:before {
		font-size: 25px;
		line-height: 300px;
	}
}

@media (min-width:768px) and (max-width:899px) {
	#gnav1 a {
		padding: 13px 10px;
		font-size: 13px;
	}
}

@media (max-width:767px){
	.container {
		padding: 0;
	}
	#top {
		position: relative;
		margin: 0;
		min-height: 0;
	}
	#top .navbar-header {
		margin: 0;
		padding: 0;
	}
	#top .navbar-brand {
		padding: 15px 20px;
		height: 45px;
	}
	#top h1.navbar-text {
		position: absolute;
		right: 5px;
		bottom: 12px;
		margin: 0;
		padding: 0;
		color: #666;
		font-size: 9px;
		line-height: 1;
	}
	#gnav {
		position: static;
	}


	#content {
		margin-left: 0;
	}
	#content h2 {
		margin: 0;
		font-size: 14px;
	}
	#content h3 {
		font-size: 14px;
	}
	#content .pager {
		margin: 0 0 50px;
	}
}

@media (max-width:479px){
	#top .navbar-brand {
		padding-left: 10px;
		height: 45px;
	}
	#top .navbar-text {
		padding-left: 5px;
		padding-right: 5px;
	}
	#cat-title {
		margin-left: 10px;
		margin-right: 10px;
	}
	#gnav1 {
		padding: 7px 10px 0;
	}
	#content {
		padding: 10px 0;
	}
	#content h2, #content h3 {
		padding-left: 10px;
		padding-right: 10px;
	}
	#hotentry-inner a.p, #topsite a, #topentry li a {
		padding-left: 10px;
		padding-right: 10px;
	}
	#content footer {
		padding-right: 10px;
		padding-left: 10px;
	}
}

@media (min-height:550px) {
  #copy {
    display: none;
  }
}