@charset "utf-8";

@media (max-width: 640px) {
	
body{
	padding-bottom:40px;
}
header.sp_only {
    border-bottom: solid 5px #E36B6F!important;
}

#m_contents { width:100%; margin:10px auto; }


#return_top { text-align:center; margin:10px; }
#return_top a { background: url("//image.stworld.jp/images/common/tri01.gif") no-repeat scroll left 5px rgba(0, 0, 0, 0); line-height: 1em; padding-left: 10px; }

.rankblock .sp{
	display:block;
}
.rankblock .pc {
    display: none;
}
img {
	max-width:100%;
	height:auto;
}

.clearfix {
}
.clearfix:after {
	display: block;
	font-size: 0;
	content: " ";
	clear: both;
	height: 0;
	min-height: 0px;
}
#main {
	font-size: 12px;
	line-height: 1.5;
	min-width: 100%;
	background-image: url(../images/bg_body.png);
	background-repeat: repeat;
	width: 100%;
	padding-bottom: 10px;
	margin-top: -10px;
}
#main.rankblockwrap {
	font-size: 12px;
	line-height: 1.5;
	min-width: 100%;
	background-image: url(../images/bg_body.png);
	background-repeat: repeat;
	width: 100%;
	padding-bottom: 10px;
	margin-top: -10px;
}
.rankblock .mainboxwrap {
    background-image: url(../images/bg_01.png);
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    margin-bottom: 20px;
    height: auto;
    min-width: 100%;
    padding: 20px 0 20px 0;
}
.rankblock .mainbox {
    width: 94%;
    min-height: 150px;
    margin-right: auto;
    margin-left: auto;
    position: relative;
    height: auto;
    background-image: url(../images/bg_02.png);
    background-size: 280px 100%;
    background-repeat: no-repeat;
    background-position: center 0;
}
.rankblock .mainbox .block01 {
    width: 100%;
    margin-right: auto;
    margin-left: auto;
    padding-top: 0;
}
.rankblock .mainbox .titlewrap {
    margin-bottom: 0px;
    padding-bottom: 0px;
}
.rankblock .mainbox .titlewrap .pt01 {
    float: none;
    display: block;
    width: 64px;
    margin: 0 auto 0;
    padding: 15px 0 0;
}
.rankblock .mainbox .titlewrap .pt02 {
    background-image: none;
    float: none;
    display: block;
    width: 80%;
    margin: 5px auto 0;
    text-align: center;
}
.rankblock .mainbox .titlewrap .pt03 {
    background: none;
}
.rankblock .mainbox .titlewrap .pt04 {
    font-size: 18px;
    font-weight: bold;
    padding-top: 7px;
    padding-bottom: 3px;
    padding-left: 0;
    color: #3F1F00;
}
.rankblock .mainbox .title01 {
	margin-left: 0;
	padding-top: 0;
}
.rankblock .mainbox .txt01 {
	font-size: 15px;
	color: #FFF;
	position: absolute;
	right: 0px;
	bottom: 60px;
	text-shadow:2px 2px 4px #000;
	display:none;
}

.rankblock .contblock01 {
	width: 94%;
	margin-right: auto;
	margin-left: auto;
}

.rankblock .titlewrap01 {
	background-image: url(../images/spbg_title_01.png);
	background-repeat: repeat-x;
	background-position: left top;
	margin-bottom: 25px;
	text-align: center;
	margin-right: auto;
	margin-left: auto;
	display: block;
	background-size: cover;
	margin-top: -5px;
	padding-top: 12px;
	padding-bottom: 10px;
}
#wrapper .rankblock h3.title01 {
    float: left;
    width: auto;
    height: auto;
    font-size: 22px;
    font-weight: bold;
    padding-left: 10px;
    line-height: 1;
    text-shadow: none;
    color: #402000;
}
.rankblock .title02 .fs01{
	font-size:12px;
	vertical-align: middle;
}
.rankblock .boxwrap01 {
    background-image: none;
    background-repeat: no-repeat;
    background-position: center top;
    padding-top: 0;
    position: relative;
    z-index: 10;
}
.rankblock .sp .txt01 {
	margin-bottom: 15px;
}

.rankblock .titlewrap02 {
    text-align: center;
    margin-bottom: 15px;
    border-bottom-width: 2px;
    border-bottom-style: solid;
    border-bottom-color: #402000;
    padding-bottom: 5px;
}
.rankblock .titlewrap02 .flag {
    float: left;
    width: 28px;
}
#wrapper .rankblock h3.title03 {
	width: auto;
	height: auto;
	font-size: 18px;
	font-weight: bold;
	padding-left: 10px;
	line-height: 1.5;
	text-shadow: none;
	color: #683905;
	background-image: url(../images/bd_title_01.png);
	background-repeat: no-repeat;
	background-position: left bottom;
	margin-bottom: 15px;
	display: inline-block;
	padding-right: 10px;
}

#wrapper .rankblock h3.title03 span{
	font-weight: bold;
	line-height: 1.5;
	background-image: url(../images/icon_title_01.png);
	background-size: 30px;
	background-repeat: no-repeat;
	background-position: left top;
	display: inline-block;
	padding-left: 34px;
	text-align: left;
	padding-top: 2px;
	padding-bottom: 8px;
}
.rankblock .pagetop {
	z-index:9999!important;
}
.rankblock .pagetop a {
	position: fixed;
	right: 3%;
	bottom: 50px!important;
	width:40px;
	z-index:9999!important;
}
.rankblock .listwrap {
    margin-bottom: 25px;
}
.rankblock .listwrap .listdetail {
    float: left;
    width: 47%;
    margin-bottom: 18px;
    margin-left: 6%;
}
.rankblock .listwrap .listdetail:nth-child(odd) {
    margin-left: 0px;
}
.rankblock .listwrap .listdetail a dl dd span {
    background-image: url(../images/icon_02.png);
    background-repeat: no-repeat;
    background-position: 95% center;
    background-size: 10px;
    text-align: center;
    display: block;
    text-decoration: none;
    color: #FFF;
    font-size: 11px;
    font-weight: bold;
    padding-top: 3px;
    padding-bottom: 2px;
    width: 100%;
}

.rankblock .contblock01.detail {
	width: 100%;
	margin-right: auto;
	margin-left: auto;
}
.rankblock .contblock01.detail .sp .txt01 {
    margin-bottom: 15px;
	width: 94%;
	margin-right: auto;
	margin-left: auto;
}


.rankblock .mainboxwrap.detail {
	background-image: url(../images/bg_03.png);
	background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    margin-bottom: 20px;
    height: auto;
    min-width: 100%;
    padding: 20px 0 20px 0;
}

.rankblock .mainboxwrap.detail_bl {
	background-image: url(../images/bg_bl.png);
	background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
    margin-bottom: 20px;
    height: auto;
    min-width: 100%;
    padding: 20px 0 20px 0;
}

.rankblock .mainboxwrap.detail .pt03 {
	display:none;
}

.rankblock .mainbox .pt05  {
	padding-bottom: 5px;
	color: #3F1F00;
	text-align: center;
	padding-top:10px;
}
.rankblock .mainbox .pt05 dt {
	font-size: 24px;
	font-weight: bold;
	line-height: 1.1;
}
.rankblock .mainbox .pt05 dd {
	font-size: 12px;
	font-weight: bold;
	line-height: 1.1;
}
.rankblock .detailboxwrap02 {
	background-color: transparent;
	padding: 0px;
	margin-bottom: 20px;
}
.rankblock .detailbox01 {
	background-color: #FFF;
	padding: 3%;
	padding-top:20px;
	margin-bottom: 0px;
	display: block;
	width: 100%;
	box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-webkit-box-sizing: border-box !important;
}
.rankblock .detailbox01 .pt01 {
	width: 100%;
	vertical-align: middle;
	display: block;
	padding-right: 0;
	margin-bottom:15px;
}
.rankblock .detailbox01 .pt02 {
	vertical-align: middle;
	display: block;
}
.rankblock .detailbox01 .pt03 {
	color: #3F1F00;
	font-size: 12px;
}
.rankblock .detailbox01 .pt03 dt {
	font-weight: bold;
}
.rankblock .detailbox01 .pt04 {
	margin-bottom: 12px;
	padding-bottom: 12px;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #402000;
}
.rankblock .detailbox01 .pt05{
	background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #D96C00), color-stop(0.00, #FC7D00));
	background: -webkit-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
	background: -moz-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
	background: -o-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
	background: -ms-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
	background: linear-gradient(top, #FC7D00 0%, #D96C00 100%);
	border-radius:5px;
	margin-bottom:20px;
}
.rankblock .detailbox01 .pt05 a{
	background-image: url(../images/icon_10.png);
	background-repeat: no-repeat;
	background-position: 95% center;
	background-size: 16px;
	display: block;
	height: auto;
	width: 100%;
	color: #FFF;
	text-decoration: none;
	padding-top: 9px;
	padding-bottom: 9px;
}
.rankblock .detailbox01 .pt06 {
	text-align: center;
	vertical-align: middle;
	display: block;
}
.rankblock .detailbox01 .pt07 {
	font-size: 12px;
	display: block;
	padding-top: 0px;
}
.rankblock .detailbox01 .pt08 {
	font-size: 16px;
	display: block;
	font-weight: bold;
	width: 100%;
	margin-right: auto;
	margin-left: auto;
	line-height: 1.3;
}
.rankblock .detailtitle01 {
	background-color: #E7E2A8;
	text-align: center;
	margin-bottom: 3%;
	padding-top: 15px;
	padding-bottom: 15px;
	background-image: url(../images/bg_04.png);
	background-repeat: no-repeat;
	background-position: center center;
	background-size:cover;
}
.rankblock .detailtitle01 h2 {
	font-size: 22px;
	font-weight: bold;
	color: #402000!important;
	line-height: 1;
	padding-top:4px;
}
.rankblock .detailtitle01 h2 span {
	background-image: url(../images/icon_06.png);
	background-repeat: no-repeat;
	background-position: left top;
	padding-left: 25px;
	padding-right:25px;
	background-size:20px;
}
.rankblock .detailboxwrap01 {
	padding-left: 0px;
	position: relative;
	background-color: #EBE4DA;
}

.rankblock .detailboxwrap01 .pt01 {
	background-image: url(../images/icon_03.png);
	background-repeat: no-repeat;
	background-position: right center;
	width: 45px;
	position: absolute;
	left: 0px;
	top: 0px;
	height:42px;
	box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-webkit-box-sizing: border-box !important;
	background-size:12px 100%;
}
.rankblock .detailboxwrap01 .pt01 span{
	display: inline-block;
	background-color: #23458F;
	width: 33px;
	font-size: 10px;
	color: #FFF;
	padding-top: 6px;
	padding-bottom: 6px;
	padding-left: 5px;
	height:42px;
	box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-webkit-box-sizing: border-box !important;
}
.rankblock .detailboxwrap01 .pt02.current {
	background-color: #D5C7B3;
	padding-top: 12px;
    padding-bottom: 12px;
}
.rankblock .detailboxwrap01 .pt02 {
	float: none;
	width: 100%;
	font-size: 12px;
	font-weight: bold;
	color: #83480C;
	text-align: center;
	padding-top: 0;
	padding-bottom: 0;
	height:42px;
	box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-webkit-box-sizing: border-box !important;
}
.rankblock .detailboxwrap01 .pt02 span {
	font-weight: bold;
}
.rankblock .detailboxwrap01 .pt02 a {
	color: #83490D;
	background-color: #EBE4DA;
	display: block;
	padding-top: 12px;
	padding-bottom: 12px;
	position: relative;
	top: 0;
	background-image:none;
}
.rankblock .detailboxwrap01 .pt02 a span {
	background-image: url(../images/icon_09.png);
	background-repeat: no-repeat;
	background-position: right center;
	background-size: 15px;
	padding-right: 20px;
	padding-left: 20px;
	display: inline-block;
	padding-top: 2px;
	padding-bottom: 2px;
}





.rankblock .detailbox02 {
	background-color: #FFF;
	padding: 14px;
	margin-bottom: 12px;
	position: relative;
}
.rankblock .detailboxwrap03 {
	width: 94%;
	margin-right: auto;
	margin-left: auto;
}
#wrapper .rankblock h3.detailtitle02 {
	margin-bottom: 15px;
	padding-bottom: 5px;
	padding-left: 20px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #402000;
	color: #402000;
	width: auto;
	height: auto;
	font-size: 20px;
	font-weight: bold;
	line-height: 1.5;
	text-shadow: none;
	background-image: url(../images/icon_08.png);
	background-repeat: no-repeat;
	background-position: left 8px;
}
#wrapper .rankblock h3.detailtitle02 span {
	color: #402000!important;
	font-weight: bold;
}
.rankblock .dblock01 {
	margin-bottom: 20px;
}
.rankblock .dblock01 .dimg01 {
	float: left;
}
.rankblock .dblock01 .dimg02 {
	float: right;
}
.rankblock .dblock01 .dimg02 li {
	margin-bottom: 12px;
}


.rankblock .dblock02 {
	float: none;
	width: 100%;
	margin-bottom:38px;
}
.rankblock .dblock02 img{
	width:100%;
}
.rankblock .dblock03 {
	float: none;
	width: 100%;
}
.rankblock .detailtitle03   {
	margin-bottom: 12px;
	padding-bottom: 5px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #402000;
	color: #402000;
	font-size: 16px;
	font-weight: bold;
}
.rankblock .detailtitle03 span   {
	font-weight: bold;
}
.rankblock .detailtxt01 {
	font-size: 12px;
	color: #3F1F00;
	margin-bottom: 12px;
}
.rankblock .dblock04 {
	background-color: #F3F3E9;
	padding: 12px;
}
.rankblock .detailtxt02 {
	font-size: 11px;
	color: #FFF;
	background-color: #402000;
	display: inline-block;
	margin-bottom: 5px;
	padding-top: 5px;
	padding-right: 9px;
	padding-bottom: 3px;
	padding-left: 9px;
}
.rankblock .detailtxt03 {
	font-size: 12px;
	color: #402000;
}
.rankblock .detailtxt03 dt   {
	font-weight: bold;
}
.rankblock .detailtxt03.pt01  {
	margin-bottom: 7px;
	padding-bottom: 7px;
	border-bottom-width: 1px;
	border-bottom-style: dotted;
	border-bottom-color: #402000;
}

.rankblock .dtable01 table {
	width: 100%;
}
.rankblock .dtable01 table th {
	color: #402000;
	background-color: #F3F3E9;
	border: 1px solid #402000;
	text-align: left;
	width: 50%;
	padding: 5px;
	font-size:11px;
}
.rankblock .dtable01 table td {
	color: #402000;
	border: 1px solid #402000;
	text-align: left;
	padding: 5px;
	font-size:11px;
}

.rankblock .dtable02 table {
	width: 100%;
}
.rankblock .dtable02 table th {
	color: #402000;
	background-color: #F3F3E9;
	border: 1px solid #402000;
	text-align: left;
	padding: 5px;
	font-size: 11px;
}
.rankblock .dtable02 table td {
	color: #402000;
	border: 1px solid #402000;
	text-align: center;
	padding: 5px;
	font-size: 11px;
}
.rankblock .dtable03 table {
	width: 100%;
	border-top: 1px solid #402000;
}
.rankblock .dtable03 table th {
	color: #402000;
	background-color: #F3F3E9;
	text-align: center;
	padding: 5px;
	display: block;
	width: 100%;
	font-size: 11px;
	border-top-width: 1px;
	border-right-width: 1px;
	border-bottom-width: 1px;
	border-left-width: 1px;
	border-top-style: none;
	border-right-style: solid;
	border-bottom-style: solid;
	border-left-style: solid;
	border-top-color: #402000;
	border-right-color: #402000;
	border-bottom-color: #402000;
	border-left-color: #402000;
	box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-webkit-box-sizing: border-box !important;
}
.rankblock .dtable03 table td {
	color: #402000;
	text-align: center;
	padding: 5px;
	font-size: 11px;
	display: block;
	width: 100%;
	border-top-width: 1px;
	border-right-width: 1px;
	border-bottom-width: 1px;
	border-left-width: 1px;
	border-top-style: none;
	border-right-style: solid;
	border-bottom-style: solid;
	border-left-style: solid;
	border-top-color: #402000;
	border-right-color: #402000;
	border-bottom-color: #402000;
	border-left-color: #402000;
	box-sizing: border-box !important;
	-moz-box-sizing: border-box !important;
	-webkit-box-sizing: border-box !important;
}
.rankblock .dfs01 {
	font-size: 14px;
	font-weight: bold;
}
.rankblock .dfs02 {
	font-size: 11px;
	text-align: center!important;
	padding-top: 7px!important;
	padding-bottom: 7px!important;
}
.rankblock .dbtn01 {
	position: relative;
	top: 0;
	right: 0;
	margin-top: 15px;
	text-align: center;
	margin-bottom: 5px;
}
.rankblock .dbtn01 a {
	font-size: 14px;
	font-weight: bold;
	color: #FFF;
	background-image: url(../images/icon_01.png);
	background-repeat: no-repeat;
	background-position: 96% center;
	text-align: center;
	display: inline-block;
	background: -webkit-gradient(linear, left top, left bottom, color-stop(1.00, #D96C00), color-stop(0.00, #FC7D00));
background: -webkit-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
background: -moz-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
background: -o-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
background: -ms-linear-gradient(top, #FC7D00 0%, #D96C00 100%);
background: linear-gradient(top, #FC7D00 0%, #D96C00 100%);
	border-radius:5px;
	text-decoration: none;
}
.rankblock .dbtn01 a span{
	background-image: url(../images/icon_01.png);
	background-repeat: no-repeat;
	background-position: 95% 14px;
	display: block;
	padding-top: 10px;
	padding-right: 25px;
	padding-bottom: 10px;
	padding-left: 15px;
	font-weight: bold;
}

.spcontnav{
	width: 94%;
	margin-right: auto;
	margin-bottom: 20px;
	margin-left: auto;
}
.spcontnav .acctitle{
	font-size: 14px;
	font-weight: bold;
	color: #FFF;
	background-color: #F97C00;
	padding-top: 10px;
	padding-bottom: 10px;
	text-align: center;
	background-image: url(../images/icon_12.png);
	background-repeat: no-repeat;
	background-position: 94% center;
	background-size:14px;
}
.spcontnav .acctitle.open{
	background-image: url(../images/icon_11.png);
}
.spcontnav .acccont{
	display:none;
}
.spcontnav .list01 li a{
	font-size: 14px;
	font-weight: bold;
	color: #402000;
	text-decoration: none;
	background-color: #FFF;
	text-align: center;
	display: block;
	padding-top: 10px;
	padding-bottom: 10px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #F0F0E1;
}

#anc01 , #anc02 , #anc03 , #anc04 , #anc05 , #anc06 , #anc07 , #anc08 , #anc09 , #anc10 , #anc11 , #anc12 , #anc13 , #anc14 {
	margin-top:-60px;
	padding-top:60px;
}

}
