*{
	margin: 0;
	padding: 0;
}
html{ font-size: 62.5%; }
body {
	background: #fff;
	text-align: left;
	line-height: 1.6;
	font-family: Helvetica,Arial,’Hiragino Kaku Gothic Pro’,'ヒラギノ角ゴ Pro W3','Droid Sans',sans-serif;
	font-weight: 400;
	color: #452d1e;
	user-select:none;
	-webkit-user-select: none;
	-webkit-touch-callout:none;
	margin: 0;
}
a{ color: #3cacca; }
img{
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}
ul, ol{ margin-left: 20px; }
table{
	width: 100%;
	background: #fff;
	border-collapse: collapse;
}
th, td{ border: 1px solid #ddd; }
th{ background: #efefef; }
th a{ color: #fff; }

.inner, .inner800{ margin: auto; }

@media (min-width: 751px){
	body{ font-size: 1.8rem; }
	a:hover img, #logo a:hover,
	.refine_btn:hover, .more a:hover{
		opacity: .8;
		-webkit-transition: .3s;
		transition: .3s;
	}
	th, td{
		padding: 15px;
		font-size: 1.6rem;
	}
	p{ margin: 2.4rem 0;}
	.inner{ width: 1000px; }
	.inner800{ width: 800px; }
}
@media (max-width: 750px){
	body{ font-size: 4.2vw; }
	p{ margin: 20px 0; }
	th, td{
		padding: 5px;
		line-height: 1.4;
		font-size: .9em;
	}
	.inner, .inner800{ padding: 0 5vw; }
}

/* ------------------------------------------------
 header
------------------------------------------------ */
header{
	padding: 10px 0;
	box-sizing: border-box;
}
#logo a{
	display: block;
	width: 225px;
	height: 40px;
	background: url(images/logo.png) 0 0 no-repeat;
	text-indent: 200%;
	white-space: nowrap;
	overflow: hidden;
}
@media (min-width: 751px){
	header{
		padding: 10px 0;
		height: 60px;
	}
}

/* ------------------------------------------------
 main
------------------------------------------------ */
h4:before{
	content: "■";
	margin-right: 5px;
	color: #ffc81b;
}
@media (min-width: 751px){
	main{ padding-bottom: 40px; }
	.eyecatch{
		background: url(images/eyecatch_bg.jpg) center 0 no-repeat;
		background-size: cover;
	}
	.eyecatch .inner{
		position: relative;
		height: 400px;
	}
	.eyecatch h1{
		position: absolute;
		top: 50%;
		left: 0;
		-webkit-transform: translateY(-50%);
		transform: translateY(-50%);
	}
	section{
		position: relative;
		padding: 50px 0;
	}
	h2{
		margin-bottom: 40px;
		font-size: 3.6rem;
	}
	h3{ font-size: 2.4rem; }
	h3 span{
		display: inline-block;
		margin-bottom: 40px;
		border-bottom: 5px solid #ffc81b;
		font-size: 3rem;
	}
	h4{
		margin: 30px 0 0;
		font-size: 2rem;
	}
}
@media (max-width: 750px){
	.eyecatch .inner{
		padding: 0;
		height: 40vh;
	}
	section{ padding: 30px 0; }
	h2{
		margin-bottom: 30px;
		line-height: 1.4;
		font-size: 1.4em;
	}
	h3{
		line-height: 1.4;
		font-size: 1.2em;
	}
	h3 span{
		display: inline-block;
		margin-bottom: 30px;
		border-bottom: 3px solid #ffc81b;
	}
    h4{
    	margin: 20px 0;
    	font-size: 1.2em;
    }
}


/* ------------------------------------------------
 index
------------------------------------------------ */
.onayami .flx{ justify-content: space-between; }
.onayami li{ text-align: center; }
.onayami figcaption{
	margin-top: 10px;
	line-height: 1.4;
}
.idx_cnt h2{
	position: relative;
	z-index: 0;
}
.idx_cnt h2:before{
	position: absolute;
	content: "";
	left: 0;
	background: #ffc81b;
	z-index: -1;
}
.idx_cnt h2 span{
	font-weight: normal;
	font-style: italic;
}
.comment{
	position: relative;
	background: #fffae7;
	border: 1px solid #ffc81b;
	border-radius: 5px;
}
.box_careful{
	position: relative;
	background: #f5fcfb;
	border: 1px solid #80e0e4;
	border-radius: 5px;
	box-shadow: 1px 1px 0 #fff inset, -1px -1px 0 #fff inset;
}
.box_careful .arrow{
	position: relative;
	border-bottom: 1px solid #80e0e4;
}
.box_careful .arrow:after{
	position: absolute;
	content: "";
	left: 50%;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}
.ng{ position: relative; }
.ng:before{
	position: absolute;
	content: "×";
	top: 0;
	line-height: .6;
	color: #d43b29;
}
#ranking h2{ background: #ffc81b; }
@media (min-width: 751px){
	.onayami li{ flex-basis: 220px; }
	.onayami figcaption{ font-size: 2.4rem; }
	.idx_cnt h2{ font-size: 3.4rem; }
	.idx_cnt h2:before{
	    top: 38%;
		width: 36px;
		height: 36px;
	}
	.idx_cnt h2 span{ font-size: 6rem; }
	.comment{
		margin-bottom: 50px;
		padding: 1px 20px 0 200px;
	}
	.comment .image{
		position: absolute;
		left: 0;
		bottom: 0;
		width: 180px;
	}
	.box_careful{
		margin-bottom: 60px;
		padding: 10px 20px 0;
	}
	.box_careful h3{
		position: absolute;
		display: inline-block;
		top: -2.8rem;
		padding-right: 10px;
		background: -webkit-linear-gradient(#fff 50%, #f5fcfb 50%);
		background: linear-gradient(#fff 50%, #f5fcfb 50%);
	}
	.box_careful .arrow:after{
		top: -7px;
		border: 25px solid transparent;
		border-top: 20px solid #9d7c6b;
	}
	.ng{ padding-left: 120px; }
	.ng:before{
		left: 60px;
		font-size: 10rem;
	}
	#ranking h2{
		padding: 20px 0;
		font-size: 2.4rem;
	}
}
@media (max-width: 750px){
	.onayami .flx{ flex-wrap: wrap; }
	.onayami li{
		flex-basis: 48%;
		margin: 0 4% 20px 0;
	}
	.onayami li:nth-of-type(even){ margin-right: 0; }
	.onayami figcaption{ font-size: 4.6vw; }
	.idx_cnt h2:before{
		width: 24px;
		height: 24px;
		top: 24%;
	}
	.idx_cnt h2 span{ font-size: 1.8em; }
	.comment{
		margin: 50px 0 30px;
		padding: 0 15px;
	}
	.comment .image{
		margin: -50px auto -10px;
		width: 50%;
	}
	.box_careful{
		margin-bottom: 30px;
		padding: 20px 15px 0;
	}
	.box_careful .arrow:after{
		top: -5px;
		border: 25px solid transparent;
		border-top: 15px solid #9d7c6b;
	}
	.ng{ padding-top: 4.5em; }
	.ng:before{
		left: 50%;
		font-size: 7em;
		-webkit-transform: translateX(-50%);
		transform: translateX(-50%);
	}
	#ranking h2{ padding: 15px 5px; }
}

/* ------------------------------------------------
 store_box
------------------------------------------------ */
.store_box{
	background: #fff;
	border: 5px solid;
}
#ranking section:nth-of-type(1){ border-color: #ffc81b; }
#ranking section:nth-of-type(2){ border-color: #ccc; }
#ranking section:nth-of-type(3){ border-color: #9d7c6b; }
.store_box h3 a{
	position: relative;
	display: block;
	text-decoration: none;
	color: #452d1e;
}
.store_box h3 a:before{
	position: absolute;
	content: "";
	left: 0;
	background: url(images/sprite.png) 0 0 no-repeat;
}
.store_box h3 a:after{
	position: absolute;
	content: "";
	right: 0;
}
.store_box .feature li{ position: relative; }
.store_box .feature li:before{
	position: absolute;
	content: "";
	left: 0;
}
@media (min-width: 751px){
	.store_box{
		margin: 80px 0;
		padding: 30px;
	}
	.store_box .img{
		flex: 0 0 300px;
		padding-right: 40px;
	}
	.store_box .detail{ flex: 0 1 100%; }
	.store_box h3 a{
		padding-left: 50px;
		font-size: 3rem;
	}
	.store_box h3 a:before{
		top: 9px;
		width: 45px;
		height: 30px;
		background-size: 375px auto;
	}
	.store_box:nth-of-type(2) h3 a:before{ background-position: -45px 0; }
	.store_box:nth-of-type(3) h3 a:before{ background-position: -90px 0; }
	.store_box h3 a:after{
		top: 15px;
		border: 8px solid transparent;
		border-left: 12px solid;
	}
	.store_box h3 a:hover{
		background: #fffae7;
		text-decoration: underline;
		-webkit-transition: .3s;
		transition: .3s;
	}
	.store_box .feature li{
		margin: 8px 0;
		padding-left: 20px;
		font-size: 1.6rem;
	}
	.store_box .feature li:before{
		top: 2px;
		width: 6px;
		height: 12px;
		border-bottom: 4px solid #ffc81b;
		border-right: 4px solid #ffc81b;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}
	.store_box .bt_cv a{ margin: 20px auto; }
}
@media (max-width: 750px){
	.store_box{
		margin: 30px 0;
		padding: 20px 15px 0;
	}
	.store_box .flx{ display: block; }
	.store_box .img{
		margin-bottom: 20px;
		text-align: center;
	}
	.store_box h3 a{ padding-left: 36px; }
	.store_box h3 a:before{
		top: 2px;
		width: 30px;
		height: 20px;
		background-size: 250px auto;
	}
	.store_box:nth-of-type(2) h3 a:before{ background-position: -30px 0; }
	.store_box:nth-of-type(3) h3 a:before{ background-position: -60px 0; }
	.store_box h3 a:after{
		top: 8px;
		border: 6px solid transparent;
		border-left: 10px solid;
	}
	.store_box .feature li{
		margin: 5px 0;
		padding-left: 16px;
		font-size: .9em;
	}
	.store_box .feature li:before{
		top: 3px;
		width: 5px;
		height: 9px;
		border-bottom: 3px solid #ffc81b;
		border-right: 3px solid #ffc81b;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);		
	}
}

/* ------------------------------------------------
 btn
------------------------------------------------ */
.bt_cv a{
	position: relative;
	display: block;
	background: #fe941e;
	border-radius: 5px;
	box-sizing: border-box;
	box-shadow: 0 3px 0 #ec9627;
	text-decoration: none;
	text-align: center;
	font-weight: bold;
	color: #fff;
	-webkit-animation: bound .5s ease infinite alternate;
	animation: bound .5s ease infinite alternate;
}
.bt_cv a:after{
	position: absolute;
	content: "";
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
@-webkit-keyframes bound{
	50%{ -webkit-transform: translateY(0); }
	75%{ -webkit-transform: translateY(5px); }
}
@keyframes bound{
	50%{ transform: translateY(0); }
	75%{ transform: translateY(5px); }
}
@media (min-width: 751px){
	.bt_cv a{
		margin: 50px auto;
		padding: 25px; 20px 20px;
		width: 600px;
		height: 80px;
		font-size: 2.4rem;
	}
	.bt_cv a:hover{
		top: 2px;
		box-shadow: 0 1px 0 #ec9627;
		-webkit-animation: none;
		animation: none;
	}
	.bt_cv a:after{
		right: 20px;
		border: 10px solid transparent;
		border-left: 14px solid;
	}
}
@media (max-width: 750px){
	.bt_cv a{
		margin: 30px auto;
		padding: 15px 20px;
		line-height: 1.4;
		font-size: 2rem;
	}
	.bt_cv a:after{
		right: 8px;
		border: 7px solid transparent;
		border-left: 10px solid;
	}
}

/* ------------------------------------------------
 search
------------------------------------------------ */
#refine{ border: 5px solid #9d7c6b; }
#refine .flx{ flex-wrap: wrap; }
#refine h4:before{ content: ""; }
#refine label{ position: relative; }
#refine label:before, #refine label.checked:after{
	position: absolute;
	content: "";
	border-radius: 100%;
}
#refine label:before{
	left: 0;
	border: 1px solid #ccc;
}
#refine label:after{ background: #ffc81b; }
#refine input[type=radio]{ display: none; }
.refine_btn, .more a{
	background: #9d7c6b;
	border: 0;
	border-radius: 5px;
	text-align: center;
	color: #fff;
}
.refine_btn{
	font-family: Helvetica,Arial,’Hiragino Kaku Gothic Pro’,'ヒラギノ角ゴ Pro W3','Droid Sans',sans-serif;
	-webkit-appearance: none;
}
@media (min-width: 751px){
	#refine, #column{ margin: 80px 0; }
	#refine{ padding: 40px 70px; }
	#refine section{
		display: flex;
		align-items: center;
		padding: 15px 0;
		border-bottom: 1px solid rgba(157, 124, 107, .3);
	}
	#refine h4{
		position: relative;
		flex: 0 0 80px;
		margin-top: -2px;
		margin-right: 40px;
		padding: 7px 10px;
		height: 40px;
		background: #9d7c6b;
		box-sizing: border-box;
		font-weight: normal;
		font-size: 1.8rem;
		color: #fff;
	}
	#refine h4:after{
		position: absolute;
		content: "";
		top: 0;
		right: -35px;
		border: 20px solid transparent;
		border-left: 15px solid #9d7c6b;
	}
	#refine label{
		margin-right: 10px;
		padding: 5px 5px 5px 24px;
		font-size: 1.6rem;
	}
	#refine label:before{
		top: 8px;
		width: 16px;
		height: 16px;
	}
	#refine label.checked:after{
		top: 11px;
		left: 3px;
		width: 12px;
		height: 12px;
	}
	.refine_btn{
		display: block;
		margin: 30px auto 0;
		width: 480px;
		height: 80px;
		font-size: 2rem;
		cursor: pointer;
	}
}
@media (max-width: 750px){
	#refine{ margin: 30px 0; }
	#refine{ padding: 20px 10px; }
	#refine section{ padding: 0; }
	#refine h4{
		padding: 4px 10px 2px;
		background: #9d7c6b;
		font-weight: normal;
		font-size: 1em;
		color: #fff;
	}
	#refine label{
		margin: 0 2% 5px 0;
		padding: 8px 8px 8px 20px;
		width: 49%;
		border: 1px solid #ccc;
		border-radius: 3px;
		box-sizing: border-box;
		font-size: 4vw;
	}
	#refine label:nth-of-type(even){ margin-right: 0; }
	#refine label:before{
		top: .8em;
		left: 3px;
		width: 12px;
		height: 12px;
	}
	#refine label.checked:after{
		top: 1em;
		left: 6px;
		width: 8px;
		height: 8px;
	}
	.refine_btn{
		display: block;
		padding: 15px 10px;
		width: 100%;
		font-size: 1em;
		cursor: pointer;
	}
}

/* ------------------------------------------------
 postlist
------------------------------------------------ */
.postlist li a{
	position: relative;
	align-items: center;
	background: #f5fcfb;
	text-decoration: none;
	color: #452d1e;
}
.postlist li a:after, .more a:after{
	position: absolute;
	content: "";
	top: 50%;
	-webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.more a{
	position: relative;
	display: block;
	text-decoration: none;
}
@media (min-width: 751px){
    .postlist{ margin: 30px 0; }
	.postlist li{ margin: 10px 0; }
	.postlist li a{ height: 100px; }
	.postlist li a:after{
		right: 20px;
		border: 8px solid transparent;
		border-left: 12px solid #452d1e;
	}
	.postlist li .thumb{ flex: 0 0 150px; }
	.postlist li .thumb img{
		width: 150px;
		height: 100px;
		object-fit: cover;
	}
	.postlist li .txt{ padding: 10px 50px 10px 15px; }
	.more a{
		margin: auto;
		padding: 23px 40px 0;
		width: 600px;
		height: 80px;
		box-sizing: border-box;
		font-size: 2rem;
	}
	.more a:after{
		right: 20px;
		border: 8px solid transparent;
		border-left: 12px solid #fff;
	}
}
@media (max-width: 750px){
	#column{ margin: 50px 0; }
    .postlist{ margin: 0 0 30px; }
	.postlist li{ margin: 0 0 10px; }
	.postlist li a{
		padding: 10px;
		height: 100px;
	}
	.postlist li a:after{
		right: 0px;
		border: 6px solid transparent;
		border-left: 9px solid #452d1e;
	}
	.postlist li .thumb{ flex: 0 0 100px; }
	.postlist li .thumb img{
		width: 100px;
		height: 67px;
		object-fit: cover;
	}
	.postlist li .txt{
		padding: 0 20px 0 10px;
		line-height: 1.4;
		font-size: .8em;
	}
	.more a{
		margin: auto;
		padding: 15px 20px;
		box-sizing: border-box;
	}
	.more a:after{
		right: 8px;
		border: 6px solid transparent;
		border-left: 9px solid #fff;
	}
}

/* ------------------------------------------------
 footer
------------------------------------------------ */
footer{
    background: #fffae7;
    text-align: center;
    font-size: 1.2rem;
}
footer a{
	text-decoration: none;
	color: #452d1e;
}
@media (min-width: 751px){
	footer{ padding: 40px 0; }
}
@media (max-width: 750px){
	footer{ padding: 20px 0; }
}

/* ------------------------------------------------
 styles
------------------------------------------------ */
h3.list span, h3.list_ylw span{
	display: inline-block;
	text-align: center;
	background: #80e0e4;
	border-bottom: 0;
	border-radius: 100%;
	vertical-align: middle;
	font-weight: normal;
	color: #fff;
}
h3.list_ylw span{ background: #ffc81b; }

table.hikaku{ table-layout: fixed; }
table.hikaku thead th{
	background: #999;
	color: #fff;
}
table.hikaku tbody th{ background: none; }
table.hikaku tbody tr:nth-of-type(even){ background: #efefef; }
table.hikaku td{
	position: relative;
	padding-top: 50px;
}
table.hikaku td:before{
	position: absolute;
	top: 0;
	left: 50%;
	line-height: 1;
	-webkit-transform: translateX(-50%);
	transform: translateX(-50%);
}
table.hikaku td.maru2:before{
	content: "◎";
	top: 10px;
	color: #F44336;
}
table.hikaku td.maru:before{
	content: "○";
	color: #EF9A9A;
}
table.hikaku td.sankaku:before{
	content: "△";
	top: 20px;
	color: #FFC107;
}
table.hikaku td.batsu:before{
	content: "×";
	color: #BBDEFB;
}
table.hikaku th.no1{ background: #eab820; }
table.hikaku td.no1{ background: #fffde7; }
table.hikaku tbody tr:nth-of-type(even) td.no1{ background: #f4ee98; }

.li_n{ list-style: none; }
.flx{ display: flex; }

.bg_bl{ background: #f5fcfb; }
.box_point{
	background: #fffae7;
	box-shadow: 0 1px 0 rgba(0, 0, 0, .1);
}

.alignleft{ text-align: left; }
.aligncenter{ text-align: center; }
.alignright{ text-align: right; }
img.alignleft{ float: left; }
img.aligncenter{
	display: block;
	margin: auto;
}
img.alignright{ float: right; }
.cl_b{ clear: both; }
.marker{
	background: -webkit-linear-gradient(transparent 50%, #ffc81b 50%);
	background: linear-gradient(transparent 50%, #ffc81b 50%);
}
.red{ color: #d43b29; }

.mr15{ margin-right: 15px; }
.mb20{ margin-bottom: 20px; }
.ml0{ margin-left: 0; }
.ml15{ margin-left: 15px; }

@media (min-width: 751px){
	.pc{ display: block; }
	.sp{ display: none; }
	h3.list span, h3.list_ylw span{
    	margin-right: 10px;
		margin-bottom: 0;
		width: 56px;
		height: 56px;
		font-size: 3.6rem;
	}
	table.hikaku td.maru2:before{ font-size: 4.2rem; }
	table.hikaku td.maru:before, table.hikaku td.batsu:before{ font-size: 6.4rem; }
	table.hikaku td.sankaku:before{ font-size: 3.6rem; }
	img.aligncenter{ margin: 50px auto; }
	.pc_alc{ text-align: center; }
	.box_point{
		margin: 50px 0;
		padding: 30px;
		border-top: 10px solid #ffc81b;
	}
}
@media (max-width: 750px){
	.pc{ display: none; }
	.sp{ display: block; }
	h3.list, h3.list_ylw{
		position: relative;
		padding-left: 40px;
	}
	h3.list span, h3.list_ylw span{
		position: absolute;
		top: -4px;
		left: 0;
		padding-top: .3em;
		width: 36px;
		height: 36px;
		box-sizing: border-box;
		line-height: 1;
		font-size: 1.2em;
	}
	table.hikaku td.maru2:before{ font-size: 4.2rem; }
	table.hikaku td.maru:before, table.hikaku td.batsu:before{ font-size: 6.4rem; }
	table.hikaku td.sankaku:before{ font-size: 3.6rem; }
	img.aligncenter{ margin: 30px 0; }
	.box_point{
		margin: 30px 0;
		padding: 20px 15px;
		border-top: 5px solid #ffc81b;
	}
}

/* ------------------------------------------------
 chat content style
------------------------------------------------ */
.chat-wrap{
	margin: 20px 0;
	padding: 10px;
}
.chat-r, .chat-l{
	clear: both;
	overflow: hidden;
	margin-bottom: 10px;
}
.chat-r img{ float: right; width:80px; }
.chat-l img{ float: left; width:80px; }
.chat-name{ margin-top: -10px; }
.chat-r .chat-name{
	margin-right: 95px;
	text-align: right;
}
.chat-message + .chat-message {
margin-top: 10px;
}
.chat-l .chat-name { margin-left: 95px; }
.chat-message {
	position: relative;
	padding: 10px 15px;
	border-radius: 20px;
}
.chat-r .chat-message {
	margin-right: 95px;
	background-color: #ededed;
}
.chat-l .chat-message {
	margin-left: 95px;
	background-color: #ededed;
}
.chat-message:before {
	position: absolute;
	content: "";
	top: 10px;
	width: 0;
	height: 0;
	border: 15px solid transparent;
	border-top: 15px solid;
}
.chat-r .chat-message:before {
	right: -10px;
	border-top-color: #ededed;
}
.chat-l .chat-message:before {
	left: -10px;
	border-top-color: #ededed;
}
