@charset "utf-8";

a,
abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
hgroup,
html,
i,
iframe,
img,
input,
ins,
kbd,
label,
legend,
li,
mark,
menu,
nav,
object,
ol,
p,
pre,
q,
samp,
section,
select,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
textarea,
tfoot,
th,
thead,
time,
tr,
ul,
var,
video {
	background: transparent;
	border: 0;
	font-size: 100%;
	font-style: normal;
	font-weight: normal;
	margin: 0;
	outline: 0;
	padding: 0;
	text-decoration: none;
	vertical-align: baseline;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
	display: block;
}

ul,
ol {
	list-style: none;
}

blockquote,
q {
	quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
	content: '';
	content: none;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

a {
	outline: none;
}

img {
	width:100%;
	vertical-align: bottom;
}

body {
	background: #fff;
	font-size: 16px;
    font-family: 'roboto', "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", 'メイリオ' , Meiryo , Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	line-height: 1.5;
	-webkit-text-size-adjust: none;
}


/*---------------------------------------------
CleraFix
---------------------------------------------*/
.clfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}
.clfix {
	min-height: 1px;
}
* html .clfix {
	height: 1px;/*\*//*/height: auto;  overflow: hidden;/**/
}



#wrapper { overflow: hidden; }




.js-banner { display: none; }




.txtbnr01 { padding: 15px 20px 0; margin: 0 auto; font-size: 12px; }
.txtbnr01 li { margin: 0 0 15px; }
.txtbnr01 li a { position: relative; display: inline-block; padding: 0 0 0 20px; color: #333; }
.txtbnr01 li a::before {
	position: absolute;
	content: "";
	vertical-align: middle;
	left: 0;
	bottom: 0;
	top: 50%;
	width: 6px;
	height: 6px;
	margin-top: -3px;
	border-top: 1.5px solid #007ABD;
	border-right: 1.5px solid #007ABD;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}
.txtbnr01 li:not(:first-child) { display: none; }


.main_slider { padding: 25px 0; background: #F5F5F5; clear: both; position: relative; z-index: 0;}

.swiper-container {
	width: 100%;
	height: 100%;
}
#main_slider { padding: 0 0 15px; }
#main_slider .swiper-wrapper { width: 70%; }
#main_slider_thumbs .swiper-wrapper { width: 12%; }
.swiper-slide {
	text-align: center;
	/* Center slide text vertically */
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	-webkit-justify-content: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	-webkit-align-items: center;
	align-items: center;
}
#main_slider .swiper-pagination { bottom: 15px; left: 70%; width: 15%; padding: 15px 0; background-color: rgba(51,51,51,0.6);font-size: 12px; color: #fff; }

#main_slider_thumbs .swiper-slide { border: 2px solid #F5F5F5; }
#main_slider_thumbs .swiper-slide-active { border: 2px solid #333; }






.tilebnr01 { padding: 32px 0; margin: 0 auto; }
.tilebnr01 ul li { margin: 0 30px 0 0; float: left; }
.tilebnr01 ul li:nth-child(3n) { margin: 0; }


h2.ttl01 { font-family: 'Roboto', sans-serif; font-weight: 700; font-style: italic; font-size: 34px; color: #333; line-height: 1; margin: 0 0 30px; }
h2.ttl01 small {
	font-family: 'Quicksand',"游ゴシック体", "Yu Gothic", YuGothic, "ヒラギノ角ゴシック Pro", "Hiragino Kaku Gothic Pro", 'メイリオ' , Meiryo , Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 16px; font-style: normal; border-left: 2px solid #333; margin-left: 15px; padding-left: 15px; line-height: 1; vertical-align: middle; font-weight: bold;
}


.search_contents { background: #333; padding: 40px 20px 30px; color: #fff; }
.inner { margin: 0; }
.search_contents h2.ttl01 { color: #fff; }
.search_contents h2.ttl01 small { border-left: 2px solid #fff; }
.search_contents h3 { font-size: 20px; margin: 0 0 20px; line-height: 1.0; }

.search_contents a { color: #fff; }

.search_contents .keywordssearch { position: relative; }
.search_contents .keywordssearch input { vertical-align: middle; font-size: 11px; padding: 10px 10px; min-height: 26px; width: 90%; border: 1px solid #ccc; background: #fff; 	
	-webkit-appearance: none; border-radius: 0; }
.search_contents .keywordssearch button { position: absolute; bottom: 0; right: 0; width: 48px; height: 48px; padding: 0; background: #fff; border: 1px solid #ccc; cursor: pointer; -webkit-appearance: none; border-radius: 0; }
.search_contents .keywordssearch button img, .search_contents .keywordssearch button svg { width: 24px; }
.search_contents .keywordssearch button svg { margin-top: 4px; }

.search_contents ul.locsearch { margin: 0 -20px 40px; }
.search_contents ul.locsearch li a { display: block; padding: 20px 30px; background: #666; }
.search_contents ul.locsearch li ul {  }
.search_contents ul.locsearch li ul li a { padding: 20px 60px; background: #999; }
.search_contents ul.locsearch li a#area_search { position: relative; }
.search_contents ul.locsearch li a#area_search::before {
	position: absolute;
	content: "";
	vertical-align: middle;
	right: 25px;
	bottom: 0;
	top: 0;
	margin: auto;
	width: 6px;
	height: 6px;
	border-top: 1.5px solid #fff;
	border-right: 1.5px solid #fff;
	-webkit-transform: rotate(135deg);
	transform: rotate(135deg);
}
.search_contents ul.locsearch li a#area_search.area_search_on::before {
	position: absolute;
	content: "";
	vertical-align: middle;
	right: 25px;
	bottom: 0;
	top: 0;
	margin: auto;
	width: 6px;
	height: 6px;
	border-top: 1.5px solid #fff;
	border-right: 1.5px solid #fff;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

.search_contents ul.targetsearch { margin-bottom: 25px; }
.search_contents ul.targetsearch li { margin: 0 15px 15px 0; float: left; width: -webkit-calc(50% - 7.5px); width: calc(50% - 7.5px); }
.search_contents ul.targetsearch li:nth-child(2n) { margin: 0 0 15px; }
.search_contents ul.targetsearch li a { display: block; background: #fff; color: #333; text-align: center; border-radius: 3px; padding: 10px 0; }
.search_contents ul.targetsearch li img, .search_contents ul.targetsearch li svg { height: 48px; width: auto; display: block; margin: 0 auto 5px; }


#searchmodal { display: none; }
.modalbox { display: none; background: #fff; }
.modalbox .modalboxttl { padding: 30px 0 25px; text-align: center; color: #333; }
.modalbox dl { border-top: 1px solid #E0E0E0; }
.modalbox dl dt { background: #F5F5F5; color: #666; border-bottom: 1px solid #E0E0E0; font-size: 12px; line-height: 1.0; padding: 10px 20px; }
.modalbox dl dd { border-bottom: 1px solid #E0E0E0; }
.modalbox dl dd a { display: block; padding: 20px; color: #333; }
.modalbox dl.modalbox_area { margin-bottom: -1px;  font-size: 14px; }
.modalbox dl.modalbox_area dd { width: 50%; border-right: 1px solid #E0E0E0; float: left; }
.modalbox dl.modalbox_area_pickup { border-top: 1px solid #E0E0E0;  font-size: 14px; }
.modalbox dl.modalbox_area_pickup dd { position: relative; }
.modalbox dl.modalbox_area_pickup dd a { padding: 20px;  }
.modalbox dl.modalbox_area_pickup dd span.area_pickup_title {
    line-height: 1.0;
    color: #999;
    font-size: 12px;
    display: table-cell;
    width: 100%;
    font-weight: bold;
}
.modalbox dl.modalbox_area_pickup dd span.area_pickup_place {
    display: table-cell;
    text-align: right;
    white-space: nowrap;
    line-height: 1.0;
    color: #999;
    font-size: 12px;
    display: table-cell;
    width: 100%;
}
/*.modalbox dl.modalbox_area_pickup dd span { position: absolute; top: 50%; margin-top: -6px; line-height: 1.0; right: 20px; color: #999; font-size: 12px; }*/
.modalbox .modalclose { padding: 30px 20px; }
.modalbox .modalclose a { display: block; border: 1px solid #333; color: #333; border-radius: 2px; text-align: center; padding: 20px 0; line-height: 1.0; }
.modaal-close { color: #333; top: 0; right: 0; position: absolute; width: 45px; height: 45px; }
.modaal-close:focus, .modaal-close:hover { background: none; }
.modaal-close::before, .modaal-close::after { background: #333 !important; width: 3px; top: 13px; left: 20px; height: 17px; }
.modaal-inner-wrapper { padding: 60px 10px; }

.whatsnew_contents { background: #F5F5F5; padding: 40px 20px 15px; }
.whatsnew_contents h3 { font-size: 20px; margin: 0 0 20px; }

.more a { font-size: 16px; color: #007abd; line-height: 1; text-decoration: none; display: inline-block; padding: 0 12px 0 0; position: relative; }
.more a::before {
	position: absolute;
	content: "";
	vertical-align: middle;
	right: 3px;
	bottom: 0;
	top: 0;
	margin: auto;
	width: 6px;
	height: 6px;
	border-top: 1.5px solid #007abd;
	border-right: 1.5px solid #007abd;
	-webkit-transform: rotate(45deg);
	transform: rotate(45deg);
}

.whatsnew_contents ul li { margin: 0 0 15px; position: relative; }
.whatsnew_contents ul li a { display: block; color: #333; text-decoration: none; padding: 20px; background: #fff; box-shadow: 0 2px 7px rgba(0,0,0,0.06); }
.whatsnew_contents ul li .ss_date { padding: 0 0 20px; color: #999; font-size: 12px; line-height: 1.0; }
.whatsnew_contents ul li .ss_new { position: absolute; background: #BD0000; display: block; font-size: 12px; color: #fff; top: 16px; right: 20px; width: 42px; text-align: center; padding: 2px 0; font-family: 'Roboto', sans-serif; font-weight: 400; }
.whatsnew_contents ul li .ss_loc { background: url(../img/icon_pin_sp.png) no-repeat 0; margin: 0 0 15px; padding: 0 0 0 20px; font-size: 12px; line-height: 1.5; min-height: 16px; background-size: 16px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.whatsnew_contents ul li .ss_ttl { font-size: 16px; margin: 0; font-weight: bold; }
.whatsnew_contents .more { clear: both; text-align: right; padding: 15px 0 30px; }

.ss_box { margin: 0 auto; padding: 40px 20px 0; color: #333; clear: both; }
.ss_box ul { list-style: none; margin: 0; padding: 0; }
.ss_box ul li { margin: 0 0 25px; }
.ss_box ul li a { color: #333; text-decoration: none; }
.ss_box ul li p { margin: 0; }
.ss_box ul li .ss_date, .ss_box ul li .ss_genre { color: #999; font-size: 12px; margin: 0 0 5px; line-height: 1.5; }
.ss_box ul li .ss_pr { position: absolute; top: 0; right: 0; color: #999; font-size: 12px; }
.ss_box ul li .ss_img { margin: 0 0 15px; }
.ss_box ul li .ss_img img { width: 100%; }
.ss_box ul li:nth-child(n+2) .ss_img img { max-height: 150px; }
.ss_box ul li .ss_img a { display: block; position: relative; }
.ss_box ul li .ss_ttl { font-size: 16px; margin: 0 0 24px; font-weight: bold; word-break: break-all; }
.ss_box ul li .ss_ttl a { font-weight: bold; }
.ss_box ul li .ss_subttl { font-size: 12px; line-height: 1.0; color: #999; }
.ss_box ul li .ss_txt { font-size: 16px; }
.ss_box .more { clear: both; text-align: right; margin: 30px 0; }

.article_contents ul li:nth-child(n+2) { width: 47%; float: left; }
.article_contents ul li:nth-child(3), .article_contents ul li:nth-child(5) { float: right; } 
.article_contents ul li:nth-child(4), .article_contents ul li:nth-child(5) { margin: 0; } 
.article_contents ul li .ss_ttl { height: 48px; overflow: hidden; }
.article_contents ul li .ss_subttl { overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.article_contents ul li .ss_ttl { margin: 0 0 10px; }
.article_contents ul li { position: relative; }

.news_contents { background: #F5F5F5; }
.news_contents ul li:first-child .ss_ttl { margin: 0; }
.news_contents ul li:not(:first-child) { margin: 0 0 15px; }
.news_contents ul li:not(:first-child) .ss_date { float: right; width: 55%; }
.news_contents ul li:not(:first-child) .ss_img { float: left; width: 40%; margin: 0; }
.news_contents ul li:not(:first-child) .ss_ttl { float: right; width: 55%; margin: 0; }
.news_contents ul li:last-child { margin: 0; }

.pickup_contents ul li { width: 47%; float: left; }
.pickup_contents ul li:nth-child(2n) { float: right; } 
.pickup_contents ul li .ss_ttl { margin: 0; }
.pickup_contents ul li .ss_img a img { height: auto; } 


.review_contents { margin: 0 auto; padding: 40px 20px 30px; color: #333; clear: both; }
.review_contents ul { list-style: none; margin: 0; padding: 0; }
.review_contents ul li { margin: 0 0 15px; position: relative; }
.review_contents ul li a { display: block; color: #333; height: 120px; overflow: hidden; text-decoration: none; padding: 0; background: #fff; box-shadow: 0 2px 7px rgba(0,0,0,0.06); }
.review_contents ul li .ss_img { width: 120px; height: 120px; overflow: hidden; float: left; }
.review_contents ul li .ss_img img { width: 100%; }
.review_contents ul li .ss_star { position: absolute; top: 0; right: 10px; }
.review_contents ul li .ss_star img { margin: 0; width: 13px; }
.review_contents ul li .ss_ttl { font-size: 16px; margin: 0 15px 5px 135px; font-weight: bold; overflow: hidden; height: 50px; }
.review_contents ul li .ss_txt { font-size: 13px; margin: 0 15px 16px 135px; line-height: 1.0; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.review_contents ul li .ss_loc { background: url(../img/icon_pin_sp.png) no-repeat 0 center; padding: 3px 0 3px 20px; font-size: 12px; line-height: 1.5; min-height: 16px; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; position: absolute; bottom: 15px; left: 135px; width: 50%; width: -webkit-calc(100% - 170px); width: calc(100% - 170px); background-size: 16px; }
.review_contents ul li .ss_date { margin: 15px 15px 5px 135px; font-size: 12px; line-height: 1.0; color: #999; }
.review_contents .more { clear: both; text-align: right; margin: 0; padding: 15px 0 0; }

.prbox { background: #333; color: #fff; padding: 40px 20px; margin: 0 20px; font-size: 12px; }
.prbox .inner { position: relative; }
.prbox .inner .preboxbtn { padding: 0 0 0; font-size: 16px; }
.prbox .preboxbtn a { display: block; background: #007ABD; color: #fff; line-height: 1.0; padding: 20px 0; border-radius: 3px; text-align: center; }

.rankingentry { margin: 0; border: 20px solid #F5F5F5; border-bottom-width: 30px; border-top: none; }

.rankingentry .ss_theme { line-height: 1.0; margin: 0 0 15px; }
.rankingentry .ss_ttl { font-size: 20px; font-weight: bold; padding: 0 0 25px; line-height: 1.5; }
.kuchikomi { margin-bottom: 30px; }
.kuchikomi .ss_ttl { font-size: 20px; font-weight: bold; padding: 0 0 25px; line-height: 1.5; }
.rankingentry .ss_date { font-size: 12px; line-height: 1.0; padding: 0 0 15px; }
.rankingentry .preboxbtn a { line-height: 1.5; }


.ranking_contents { background: #F5F5F5; }
.ranking_contents h3 { font-size: 20px; margin: 0 0 20px; }
.ranking_contents ul li { margin: 0 0 15px; position: relative; }
.ranking_contents ul li a { display: block; color: #333; text-decoration: none; padding: 0; background: #fff; box-shadow: 0 2px 7px rgba(0,0,0,0.06); }
.ranking_contents ul li::before { font-family: 'Roboto', sans-serif; font-weight: 700; font-style: italic; color: #E0E0E0; position: absolute; right: 15px; top: 10px; font-size: 42px; }
.ranking_contents ul li:nth-child(1)::before { content: "1"; }
.ranking_contents ul li:nth-child(2)::before { content: "2"; }
.ranking_contents ul li:nth-child(3)::before { content: "3"; }
.ranking_contents ul li .ss_logo { margin: 0 15px 0 0; width: 127px; height: 84px; overflow: hidden; text-align: center; float: left; position: relative; }
.ranking_contents ul li .ss_logo::before { position: absolute; content: ""; left: 0; top: 15px; height: 54px; width: 126px; border-right: 1px solid #E0E0E0; }
.ranking_contents ul li .ss_logo span { display: block; width: 96px; height: 54px; overflow: hidden; margin: 15px 0 0 15px; }
.ranking_contents ul li .ss_logo img { max-width: 96px; max-height: 54px; }
.ranking_contents ul li .ss_name { font-size: 12px; padding: 0 54px 0 141px; overflow: hidden; position: absolute; bottom: 33px; left: 0; }
.ranking_contents ul li .ss_area { font-size: 12px; color: #999; line-height: 1.0; position: absolute; left: 141px; bottom: 15px; }
.ranking_contents .more { clear: both; text-align: right; margin: 15px 0 30px; }




.foot_slider { margin:0 ; padding: 0 0 15px; background: #F5F5F5; clear: both; }
#foot_slider .swiper-wrapper { width: 50%; }
.foot_slider .swiper-container {
	width: 100%;
	height: 100%;
	padding: 25px 0 25px;
}
.foot_slider .swiper-container li { background: none; text-align: left; width: 160px; }
.foot_slider .swiper-container li p { margin: 15px 0 0; }
.foot_slider .swiper-container li img { display: block; width: 160px; height: 72px; }
.foot_slider .swiper-container li a { font-size: 12px; color: #333; }
.foot_slider .swiper-pagination { bottom: 0px; }



.top_footmenu { padding: 30px 20px 5px; background: #333; }
.top_footmenu ul { margin: 0 auto; text-align: center; }
.top_footmenu ul li { display: inline-block; margin: 0 15px 25px 0; padding: 0 15px 0 0; border-right: 1px solid #fff; }
.top_footmenu ul li:last-child { border-right: none; }
.top_footmenu ul li a { display: block; color: #fff; font-size: 10px; padding: 4px 0 4px 30px; }
.top_footmenu ul li.tfm_pre a { background: url(../img/icon_premiam_sp.png) no-repeat 0 center; background-size: auto 25px; }
.top_footmenu ul li.tfm_app a { background: url(../img/icon_app_sp.png) no-repeat 0 center; background-size: auto 25px; }
.top_footmenu ul li.tfm_mail a { background: url(../img/icon_mailmaga_sp.png) no-repeat 0 center; background-size: auto 25px; }
.top_footmenu ul li.tfm_fb a { background: url(../img/icon_fb_sp.png) no-repeat 0 center; background-size: auto 25px; }
.top_footmenu ul li.tfm_tw a { background: url(../img/icon_tw_sp.png) no-repeat 0 center; background-size: auto 25px; }

.top_footmenu02 { padding: 30px 20px 30px; background: #424242; text-align: center; }
.top_footmenu02 ul li { display: inline-block; margin: 0 10px 10px 0; padding: 0 10px 0 0; border-right: 1px solid #fff; }
.top_footmenu02 ul li:last-child { border-right: none; }
.top_footmenu02 ul li a { display: block; color: #fff; font-size: 10px; padding: 2px 0; }


#ss_jackbanner { display: none; }
.ss_jackbannerbody { background: #fff; overflow: hidden; }
.modal_jbclose { margin: 15px 0 15px 15px; text-align: center; width: -webkit-calc(50% - 22.5px); width: calc(50% - 22.5px); float: left; }
.modal_jbclose a { display: block; padding: 15px 0; background: #E5E5E5; color: #333; border-radius: 2px; }
.modal_jblink { margin: 15px; text-align: center; width: -webkit-calc(50% - 22.5px); width: calc(50% - 22.5px); float: right; }
.modal_jblink a { display: block; padding: 15px 0; background: #007ABD; color: #fff; border-radius: 2px; }
.modal_startopen { display: none; }

.tilebnr { position: fixed; z-index: 100; bottom: 0px; left: 0px; width: 100%; }
.tilebnr li:not(:first-child) { display: none; }


.beyond { background: #424242; padding: 0 20px 30px; }
.beyond .inbox { display: table; margin: 0 auto; }
.beyond img { width: 56px; margin: 0 16px 0 0; }
.beyond a { color: #fff; font-size: 12px; line-height: 1.2; }
.beyond a span { line-height: 1.2; display: table-cell; vertical-align: middle; }

.footer__copy { padding-bottom: 20%;}