@charset "utf-8";
body {
	font-family: 'Noto Sans Japanese', "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	min-width: 320px;
	font-size: 14px;
	line-height: 1.5;
	background-color: #fff;
}

@media ( min-width: 768px) {
	body {
		font-size: 16px;
	}
}
/*text-----------------------------------------------------------------*/

p {
}
section.tabranking h3 {
	color: #ffffff;
	font-size: 18px;
}
th {
	color: #ffffff;
	font-weight: normal;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
	-ms-interpolation-mode: bicubic;
}
a img, .rsp-img {
	width: 100%;
}
strong {
	color: #508f0d;
}
div.nav-inner a {
	color: #f78b28;
	font-size: 11px;
	text-decoration: none;
}
div.nav-inner a.active {
	color: #fff;
}
.tab_content {
	color: #574738;
}

@media ( min-width: 768px) {
	section.tabranking h3 {
		font-size: 22px;
	}
	div.nav-inner a {
		font-size: 18px;
	}
}
.ranking .text {
	margin: 20px 0px 20px;
	font-weight: normal;
}
.ranking .inner:last-of-type .text {
    margin-bottom: 0;
}
@media (min-width: 768px){
	.ranking {
		margin-bottom: 0px;
	}
	.ranking .contents {
		margin-bottom: 16px;
	}
}
/*ttl-----------------------------------------------------------------*/

.main-visual img {
	display: block;
	width: 100%;
	height: auto;
	margin: 0 auto;
	padding: 0px 10px 0;
}

@media ( min-width: 768px) {
	.main-visual img {
		padding: 20px 20px 0;
	}
}
/*aside-----------------------------------------------------------------*/

.contents+.sns-link {
	padding: 0;
}
.about {
	width: auto;
	padding: 10px;
}

@media ( min-width: 768px) {
	.about {
		padding: 20px 20px 0;
	}
}
.about p {
	text-align: justify;
	font-weight: bold;
}
/*nav-----------------------------------------------------------------*/

#tabnavi {
	margin-top: 0px;
}
.tab_content {
	display: none;
}
#tab1 {
	display: block;
}
div.nav-inner {
	z-index: 3;
	position: relative;
	width: auto;
	height: auto;
}
div.nav-inner ul {
	width: 100%;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: center;
	padding: 0px 8px;
}
div.nav-inner li {
	width: 33.33%;
	padding: 2px;
	height: 40px;
	position: relative;
}
div.nav-inner li a {
	display: block;
	border: solid #f78b28 2px;
	background-color: #fffcf5;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	position: relative;
	padding-bottom: 5px;
	background-image: url(../img/ranking/under_arrow.gif);
	background-size: 10px auto;
	background-position: center 80%;
	background-repeat: no-repeat;
}
div.nav-inner li .active {
	background-color: #508f0d;
	border: none;
	padding-bottom: 0px;
	background-image: none;
}
div.nav-inner li a.active::after {
	display: none;
}
div.nav-inner.fixed {
	position: fixed;
	top: 0;
	width: 100%;
	z-index: 10000;
}

@media ( min-width: 768px) {
	div.nav-inner ul {
		padding: 0 16px;
	}
	div.nav-inner li {
		padding: 4px;
		height: 72px;
	}
	div.nav-inner.fixed {
		width: 100%;
		max-width: 960px;
	}
	div.nav-inner li a {
		border-width: 2px;
		background-size: 20px auto;
	}
}
/*contents-------------------------------------------------------------------*/

.contents {
	width: 100%;
	margin: 0 auto 0;
	font-weight: 700;
}

@media ( min-width: 768px) {
	.contents {
		max-width: 750px;
		margin: 0 auto 0;
	}
}
section.tabranking {
	margin-bottom: 0px;
	padding: 20px 10px 0px;
	position: relative;
	z-index: 2;
	width: auto;
}
section.tabranking h3 {
	width: auto;
	text-align: center;
	background-color: #508f0d;
	padding: 10px;
	box-shadow: 0 0 0 1.5px #508f0d inset, 0 0 0 3px #377238 inset;
}
section.tabranking h3:not(:first-of-type){
	margin-top: 20px;
}

@media ( min-width: 768px) {
	section.tabranking {
		padding: 20px 20px 0px;
	}
	section.tabranking h3 {
		padding: 15px;
		box-shadow: 0 0 0 2px #508f0d inset, 0 0 0 4px #377238 inset;
	}
	section.tabranking h3:not(:first-of-type){
		margin-top: 40px;
	}

}
.best5 {
	margin-bottom: 20px;
	padding-bottom: 30px;
	border-bottom: solid #91b459 2px;
	text-align: center;
}
.best5 dl {
	padding-bottom: 5px;
}
.best5 dt {
	background-color: transparent!important;
	background-image: url(../img/ranking/rank_2nd.gif);
	background-size: 100% auto;
	background-position: top;
	height: 65px;
	width: 165px;
	margin: auto auto 5px;
	text-indent: -9999px;
}
.best5 dt.rank-1st {
	background-position: top;
}
.best5 dt.rank-2nd {
	background-position: 0 -65px;
}
.best5 dt.rank-3rd {
	background-position: 0 -134px;
}
.best5 dt.rank-4th {
	background-position: 0 -199px;
}
.best5 dt.rank-5th {
	background-position: 0 -268px;
}
.best5 dd:nth-child(2) {
	font-size: 1.3rem;
	line-height: 1.4rem;
}

@media ( min-width: 768px) {
	.best5 dl {
		padding-bottom: 10px;
	}
	.best5 dd {
		font-size: 1.25rem;
		line-height: 1.8rem;
	}
	.best5 dd:nth-child(2) {
		font-size: 2rem;
		line-height: 2.25rem;
	}
}
.about-table, .total-rank20, .total-rank5 {
	border-spacing: 2px;
	border-collapse: inherit;
}
.total-rank5 {
	width: 100%;
}
.total-rank5 th {
	width: 100%;
	padding: 1px;
	background-color: #91b458;
}
.total-rank5 td {
	padding: 10px 5px;
	background-color: #fdf1d5;
}
.total-rank5 td:nth-child(2n) {
	background-color: #fcf9eb;
}
.total-rank20 {
	width: 100%;
	text-align: center;
}
.total-rank20 tr {
	background-color: #fcf9eb;
}
.total-rank20 tr:nth-child(2n) {
	background-color: #fdf1d5;
}
.total-rank20 th {
	background-color: #91b458;
	padding: 1px 0;
}
.total-rank20 td {
	padding: 10px 0;
}
.rank-1st {
	background-color: #ff8a00!important;
	color: #ffffff!important;
}
.rank-2nd {
	background-color: #ff9c00!important;
	color: #ffffff!important;
}
.rank-3rd {
	background-color: #ffb129!important;
	color: #ffffff!important;
}

@media ( min-width: 768px) {
	.best5 dt {
		height: 98px;
		width: 254px;
	}
	.best5 dt.rank-1st {
		background-position: top;
	}
	.best5 dt.rank-2nd {
		background-position: 0 -102px;
	}
	.best5 dt.rank-3rd {
		background-position: 0 -206px;
	}
	.best5 dt.rank-4th {
		background-position: 0 -309px;
	}
	.best5 dt.rank-5th {
		background-position: 0 -412px;
	}
	.total-rank5 th {
		padding: 2px;
	}
	.total-rank5 td {
		padding: 10px;
	}
	.total-rank5 td:first-child {
		padding: 0 20px;
	}
}
.about-table {
	width: 100%;
}
.about-table th {
	padding: 5px;
	background-color: #91b458;
}
.about-table td {
	padding: 5px;
	background-color: #fdf1d5;
}
.stripe td:nth-child(2n) {
	background-color: #fcf9eb;
}
