@charset "UTF-8";

/***** 共通設定 *****/

*, *::before, *::after {
	box-sizing: border-box;
}
:root {
	--color_bbred: #c60000;
	--color_danger: #c60000;
	--color_accent: #0078e3;
	--color_success: #00be9c;
	--color_blue: #1d3994;
	--color_pink: #f5696c;
	--color_link: #2984d6;

	--color_font_basic: #45454a;
	--color_gray_7: #73737a;
	--color_gray_c: #c6c6cf;
	--color_blog: #e64d3b;

	--hover_opacity: 0.7;
	--hover_transition: 0.3s;
}
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	-webkit-font-smoothing: antialiased;
	margin: 0;
	padding: 0;
	border: 0;
}
html {
	-webkit-text-size-adjust: 100%;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
body {
	line-height: 1.5;
	font-size: 14px;
	word-wrap: break-word;
}
body, button, input, select, textarea {
	color: var(--color_font_basic);
	font-family: "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}
ul {
	list-style-type: none;
}
table {
	border-collapse: collapse;
}
img {
	vertical-align: bottom;
}
body > div {
	background-color:#eee;
	position: relative;
}
body > div > section {
	margin: 0 0 20px;
	background-color:#fff;
	box-shadow: 0 1px 1px 1px rgba(0, 0, 0, .1);
}
strong {
	color:#c60000;
}

/* 基本テキストリンク */
a {color:#1d3994;}

/* アプリでは非表示 */
body.in_app .app_display_none {
	display: none;
}


.fc-bbred {
	color: var(--color_bbred);
}
.fc-danger {
	color: var(--color_danger);
}
.fc-accent {
	color: var(--color_accent);
}
.fc-sucsess {
	color: var(--color_success);
}
.fc-info {
	color: var(--color_info);
}
.fc-warning {
	color: var(--color_warning);
}
.fc-blue {
	color: var(--color_blue);
}
.fc-pink {
	color: var(--color_pink);
}


/***** ヘッダー *****/

header {
	height: 49px;
	border-bottom: 1px solid #c60000;
	box-shadow: 0 1px 1px 1px rgba(0, 0, 0, .1);
	position: relative;
	width: 100%;
	background: #fff;
}
header h1 {
	padding-top: 10px;
}
header h1 a {
	text-indent: -9999px;
	width: 180px;
	height: 30px;
	display: block;
	background-size: 180px 30px;
	margin: 0 auto;
}
body header h1 a {
	background-image: url(/sp/img/header/logo_sp@3x.png);
}
body.in_app.is_ios header h1 a {
	background-image: url(/sp/img/header/logo_sp_ios@2x.png);
	background-size: 180px 30px;
	width: 180px;
	height: 30px;
}
header div a {
	display:block;
	width: 48px;
	height: 48px;
	font-size: 10px;
	color: #444;
	text-align: center;
	position: absolute;
	top: 0;
	padding-top: 31px;
	text-decoration: none;
}
header #btn_menu a {
	right: 0;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2028%2028%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%3E%3Cg%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22m3.5%2014h21%22%2F%3E%3Cpath%20d%3D%22m3.5%206.22h21%22%2F%3E%3Cpath%20d%3D%22m3.5%2021.78h21%22%2F%3E%3C%2Fg%3E%3Cpath%20d%3D%22m0%200h28v28h-28z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E') center 5px no-repeat;
	background-size: 28px 28px;
}
html.menu header #btn_menu a {
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2028%2028%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%3E%3Cpath%20d%3D%22m0%200h28v28h-28z%22%2F%3E%3Cg%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22m21%207-14%2014%22%2F%3E%3Cpath%20d%3D%22m7%207%2014%2014%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E') center 5px no-repeat;
	background-size: 28px 28px;
}
header #btn_search a {
	left: 0;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2028%2028%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%3E%3Cpath%20d%3D%22m0%200h28v28h-28z%22%2F%3E%3Ccircle%20cx%3D%2213.3%22%20cy%3D%2213.3%22%20r%3D%229.8%22%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3Cpath%20d%3D%22m24.5%2024.5-4.2-4.2%22%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3Cpath%20d%3D%22m0%200h28v28h-28z%22%2F%3E%3Cg%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22m9.1%209.1h8.4%22%2F%3E%3Cpath%20d%3D%22m9.1%2013.3h5.6%22%2F%3E%3Cpath%20d%3D%22m9.1%2017.5h2.8%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E') center 5px no-repeat;
	background-size: 28px 28px;
}
html.filter_menu header #btn_search a {
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2028%2028%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%3E%3Cpath%20d%3D%22m0%200h28v28h-28z%22%2F%3E%3Cg%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%3E%3Cpath%20d%3D%22m21%207-14%2014%22%2F%3E%3Cpath%20d%3D%22m7%207%2014%2014%22%2F%3E%3C%2Fg%3E%3C%2Fg%3E%3C%2Fsvg%3E') center 5px no-repeat;
	background-size: 28px 28px;
}
header #btn_top a {
	left: 0;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2028%2028%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%3E%3Cpath%20d%3D%22m14%203.13-11.67%2012.97h4.67v8.4h14v-8.4h4.67z%22%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%222%22%2F%3E%3Cpath%20d%3D%22m0%200h28v28h-28z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E') center 5px no-repeat;
	background-size: 28px 28px;
}
/***** ログインボタン *****/

nav.entry {
	padding: 10px 0;
}
nav.entry ul {
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
	padding: 0 10px;
	overflow: hidden;
	display: flex;
	gap: 10px;
}
nav.entry ul li {
	width: 50%;
}

/***** 会員情報 *****/

section.member_status {
	padding: 8px 5px;
	overflow: hidden;
	text-align: center;
	line-height: 1.2;
	margin-bottom: 10px;
}
section.member_status h3 {
	font-size: 12px;
	color: #c60000;
	display: inline;
}
section.member_status h3 span {
	font-size:11px;
	color:#444;
	font-weight: normal;
}
section.member_status p {
	font-size: 12px;
	color: #444;
	display: inline;
}
section.member_status p span {
	color:#c60000;
	font-size:12px;
	font-weight: bold;
}
section.member_status p a {
	font-size: 12px;
	background: #c60000;
	border-radius: 4px;
	color: #fff;
	padding: 1px 7px;
	margin-left: 2px;
	text-decoration: none;
	font-weight: 700;
}

/***** スライドバナー *****/

#slide_bnr {
	background: #eee;
	padding: 0 0 5px 0;
	text-align: center;
	width:100%;
	overflow:hidden;
}
#slide_bnr ul.banner {
	margin:0;
	padding:0;
	white-space:nowrap;
}
#slide_bnr ul.banner li {
	list-style-type:none;
	margin:0 /*.1em*/;
	padding:0;
	display:inline;
}
#slide_bnr ul.banner li img {
	width: 100%;
	height: auto;
}
#slide_bnr ul.indicator {
	margin:0;
	padding:0;
	white-space:nowrap;
	text-align:center;
}
#slide_bnr ul.indicator li {
	list-style-type:none;
	display:inline-block;
	width: 5px;
	height: 5px;
	background: #555;
	margin: 0 3px;
	padding:0;
	overflow:hidden;
	text-indent:2em;
}
#slide_bnr ul.indicator li.selected {
	background: #c60000;
}
#slide_bnr .remaining_time_wrap {
	position: absolute;
    bottom: -16px;
    left: 6px;
    color: #fff;
    border: 1px solid #fff;
    padding: 4px 6px;
    line-height: 1;
    background: rgba(0,0,0,0.9);
    font-size: 12px;
    border-radius: 3px;
    font-weight: bold;
}
#slide_bnr .remaining_time_wrap .remaining_time {
	font-size: 16px;
	color: #ffe040;
	margin-left: 1px;
	font-weight: bold;
	animation: remainTimer 2s linear infinite;

}
@keyframes remainTimer {
	0% {
		opacity: 1;
	}
	50% {
		opacity: .5;
	}
	100% {
		opacity: 1;
	}
}
#slide_bnr .remaining_time_wrap .remaining_time::before {
	content: "hours";
	position: absolute;
	font-size: 10px;
	bottom: 4px;
	left: 28px;
	transform: scale(.8);
	font-weight: normal;
}
#slide_bnr .remaining_time_wrap .remaining_time::after {
	content: "minutes";
	position: absolute;
	font-size: 10px;
	bottom: 4px;
	right: 1px;
	transform: scale(.8);
	font-weight: normal;
}

/* 上部にもどる */
#to_top a {
	display: block;
	visibility: hidden;
	opacity: 0;
	position:fixed;
	width:48px;
	height:48px;
	bottom: 8px;
	right: 8px;
	background-color:#fff;
	border-radius: 8px;
	text-indent: 100%;
	white-space: nowrap;
	overflow: hidden;
	z-index:99999;
	transition: opacity 0.5s, visibility 0.5s;
	border: 2px solid #ccc;
}
#to_top a:after {
	content:"";
	display:block;
	position:absolute;
	top: calc(50% - 15px);
	left: calc(50% - 15px);
	width: 30px;
	height: 30px;
	transform:rotate(-90deg);
	background: url(data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2040%2040%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cg%20fill%3D%22none%22%3E%3Cpath%20d%3D%22m13.83%2034.17%2014.17-14.17-14.17-14.17%22%20stroke%3D%22%23999%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20stroke-width%3D%224%22%2F%3E%3Cpath%20d%3D%22m0%200h40v40h-40z%22%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E);
}
#to_top a.is-show {
	visibility: visible;
	opacity: 0.8;
	transition: opacity 0.5s, visibility 0.5s;
}
/***** スライドメニュー *****/
body > div {
	right: 0;
	transition: right .3s;
}
nav.drawer > ul {
	position: absolute;
	top: 0;
	width: 264px;
	background-color: #333;
	z-index: 99999;
}
nav.drawer > ul h3 {
	background: #222;
	color: #888;
	font-size: 12px;
	font-weight: normal;
	height: 22px;
	line-height: 22px;
	padding-left: 10px;
}
nav.drawer > ul a.common_button {
	margin: 15px 10px;
}
nav.drawer > ul a.common_button.more_search {
	margin: 30px 10px;
}
nav.drawer li.item:not(:last-child) {
	border-bottom: 1px solid #444;
}
nav.drawer li.item[data-type="area"]:last-child {
	border-bottom: 1px solid #444;
}
nav.drawer li.item a {
	padding: 12px 10px;
	font-size: 15px;
	line-height: 24px;
	color: #eee;
	text-decoration: none;
	display: block;
	position:relative;
}
nav.drawer li.item a:before {
	content: "";
	display: inline-block;
	width: 24px;
	height: 24px;
	vertical-align: middle;
	margin-right: 8px;
	color: #ccc;
	font-size: 24px;
	font-family: 'bb_font' !important;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	margin-top: -2px;
}
nav.drawer li.item a.totop:before { content: "\e90d"; }
nav.drawer li.item a.free { color:#ffca45; }
nav.drawer li.item a.free:before { content: "\e90b";color:#ffca45; }
nav.drawer li.item a.point:before { content: "\e914"; }
nav.drawer li.item a.mailbox:before { content: "\e911"; }
nav.drawer li.item a.member:before { content: "\e909"; }
nav.drawer li.item a.mail_fw:before { content: "\e90c"; }
nav.drawer li.item a.favorite_list:before { content: "\e917"; }
nav.drawer li.item a.chat_history:before { content: "\e910"; }
nav.drawer li.item a.search:before { content: "\e916"; }
nav.drawer li.item a.howto:before { content: "\e960"; }
nav.drawer li.item a.news:before { content: "\e90f"; }
nav.drawer li.item a.newgirl:before { content: "\e912"; }
nav.drawer li.item a.manual:before { content: "\e95a"; }
nav.drawer li.item a.faq:before { content: "\e95e"; }
nav.drawer li.item a.inquiry:before { content: "\e918"; }
nav.drawer li.item a.app:before { content: "\e905"; }
nav.drawer li.item a.blog:before { content: "\e908"; }
nav.drawer li.item a.maintenance:before { content: "\e94d"; }
nav.drawer li.item a.sitemap:before { content: "\e958"; }
nav.drawer li.item a.rule:before,
nav.drawer li.item a.syotori:before,
nav.drawer li.item a.privacy:before { content: "\e913"; }
nav.drawer li.item a.twitter:before {
	content: "";
	
	background-image: url('data:image/svg+xml;charset=utf8,%3Csvg%20viewBox%3D%220%200%2024%2024%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22m13.65%2010.7%206.6-7.7h-1.5l-5.7%206.7-4.6-6.7h-5.2l6.8%2010-6.8%208h1.5l6-7%204.8%207h5.2zm-2%202.4-.7-1-5.6-7.9h2.4l4.5%206.4.7%201%205.8%208.3h-2.4z%22%20fill%3D%22%23ccc%22%2F%3E%3Cpath%20d%3D%22m0%200h24v24h-24z%22%20fill%3D%22none%22%2F%3E%3C%2Fsvg%3E');
}
nav.drawer li.item a.recruit:before { content: "\e906"; }
nav.drawer li.item a.pcview:before { content: "\e95d"; }
nav.drawer > ul > li {
	position: relative;
}
nav.drawer > ul .app_ver {
	position: absolute;
	bottom: -56px;
	left: 14px;
	border-bottom: none;
	color: #888;
	font-size: 12px;
}
nav.drawer > ul li.item a.logout {
	font-size: 12px;
	color: #888;
	width: 106px;
	margin: 10px;
	padding: 2px 6px;
	background: #383838;
	float: right;
	border-radius: 3px;
}
nav.drawer > ul li.item a.logout:before {
	content: "\e915";
	color: #888;
	font-size: 20px;
}

/* サイドメニュー */
#side_menu {
	display: none;
}
#side_menu > ul {
	right: -264px;
}
html.menu {
	overflow-x: hidden;
}
html.menu body {
	overflow: hidden;
}
html.menu body > div {
	right: 264px;
}
html.menu #side_menu_overlay {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	z-index: 99998;
}
html.menu #to_top a {
	right: 270px;
}

/* フィルタメニュー */
#side_filter_menu {
	display: none;
}
#side_filter_menu > ul {
	left: -264px;
}
html.filter_menu {
	overflow-x: hidden;
}
html.filter_menu body {
	overflow: hidden;
}
html.filter_menu body > div {
	right: -264px;
}
html.filter_menu #side_filter_menu_overlay {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	z-index: 99998;
}
html.filter_menu #to_top a {
	right: -258px;
}

nav.drawer#side_filter_menu > ul li.item {
	padding: 0 10px 0 40px;
	height: 48px;
	font-size: 15px;
	line-height: 48px;
	color: #eee;
	position: relative;
}
nav.drawer#side_filter_menu > ul li.item::before {
	content: "";
	top: 50%;
	left: 10px;
	width: 20px;
	height: 20px;
	transform: translateY(-50%);
	border: 2px solid #555;
	border-radius: 10px;
	display: block;
	position: absolute;
}
nav.drawer#side_filter_menu > ul li.item::after {
	content: "";
	top: calc(50% - 6px);
	left: 17px;
	width: 6px;
	height: 10px;
	border-bottom: 2px solid #555;
	border-right: 2px solid #555;
	transform: rotate(45deg);
	display: block;
	position: absolute;
}
nav.drawer#side_filter_menu > ul li.item.selected::before {
	border-color: #f5696c;
}
nav.drawer#side_filter_menu > ul li.item.selected::after {
	border-color: #f5696c;
}

/***** PC版QR *****/

#qr_for_pc {
	display:none;
	position:absolute;
	right:20px;
	top:-30px;
	z-index:9999;
	padding:1em;
	font-size:12px;
	line-height:1.6;
	color:#666;
	background-color:#fff;
	overflow:hidden;
}
#qr_for_pc h3 {
	margin:0 0 10px;
}
#qr_for_pc img {
	display:block;
	float:left;
}
#qr_for_pc p {
	float:left;
	margin:0 0 0 15px;
	width:200px;
}
#qr_for_pc b {
	color:#dc143c;
	background-color:transparent;
}
#qr_for_pc div[title] {
	position:absolute;
	right:6px;
	top:6px;
	line-height:24px;
	width:24px;
	color:#fff;
	background-color:#666;
	border-radius:6px;
	cursor:pointer;
	font-size:16px;
	text-align:center;
}


/* フッター */
footer {
	color: #aaa;
	background-color: #444;
	font-size: 12px;
	text-align: center;
	margin-top: 5px;
	content-visibility: auto;
    contain-intrinsic-size: 287px;
}
footer a {
	color:#aaa;
	background-color:transparent;
	text-decoration:none;
}
footer a img[src*="btn_share"] {
	border-radius: 2px;
}
footer .disp_mode {
	padding:.8em;
	border-bottom: 1px solid #aaa;
}
footer .disp_mode a {
	color:#aaa;
}
footer nav h1 {
	padding:5px 0px 4px 0px;
	color:#b5a642;
	background-color:transparent;
	font-size: 12px;
	line-height: 2;
	text-align: left;
	text-indent: 2.5em;
}
footer nav ul {
	overflow:hidden;
}
footer nav ul li {
	float:left;
	width: 50%;
	text-align: left;
}
footer nav ul li a {
	display: block;
	line-height: 3em;
	text-indent: 4em;
}
	footer nav ul li a:link {color:#aaa;}
	footer nav ul li a:visited {color:#aaa;}
	
footer > ul {
	padding:1em;
}
footer > ul li {
	display:inline;
	margin-left:2em;
}
footer > ul li:first-child {
	margin-left:0;
}
footer .copy_right {
	color:#b5a642;
	background-color:transparent;
	font-size:12px;
	line-height:5em;
}
footer .copy_right a:link {color:#b5a642;}
footer .copy_right a:visited {color:#b5a642;}