/*========================
ローディング
========================*/
#loaded {
	display: none;
	overflow: hidden;
}

#loader-bg {
	display: none;
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	bottom: 0;
	right: 0;
	background: #FFF;
	z-index: 1000;
	overflow: hidden;
}

#loader {
	display: none;
	position: fixed;
	top: 50%;
	left: 50%;
	width: 70%;
	transform: translate(-50%, -50%);
	text-align: center;
	color: #fff;
	z-index: 100;
}

#loader img {
	position: absolute;
	top: 50%;
	left: 50%;
	display: block;
	transform: translate(-50%, -50%);
	position: 0;
	width: 90%;
	max-width: 3.00rem;
	opacity: 0.6;
}

@media screen and (max-width: 499px) {
	#loader img {
		top: 50%;
	}
}

.load_obi {
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: #FFF;
	position: absolute;
	opacity: 0.7;
	z-index: 1;
	animation: load_obi 1.4s 1 ease-in-out forwards;
}

@keyframes load_obi {
	0% {
		transform: translateX(0)
	}

	100% {
		transform: translateX(100%)
	}
}

/*============================
共通
============================*/
.sec_title {
	font-size: 0.45rem;
	font-weight: 700;
	color: #bf0000;
	text-align: center;
	letter-spacing: 0.20em;
	margin-bottom: 0.40rem;
}

@media screen and (max-width: 640px) {
	.sec_title {
		font-size: 0.24rem;
		letter-spacing: 0.10em;
		margin-bottom: 0.30rem;
	}
}

.sec_title span {
	display: block;
	font-size: 0.16rem;
	font-family: 'Poppins', sans-serif;
	font-weight: 400;
	color: #111;
	letter-spacing: 0.20em;
	padding-bottom: 0.15rem;
}

@media screen and (max-width: 640px) {
	.sec_title span {
		font-size: 0.13rem;
		letter-spacing: 0.10em;
		padding-bottom: 0.10rem;
	}
}

/*============================
mv下のカテゴリリンク
============================*/
#category_icon_wrap {
	background-color: #fef8ec;
}

#category_icon_wrap .pickup_tit {
	padding: 0.80rem 0 0.10rem;
	text-align: center;
	font-size: 0.36rem;
	font-family: "Inter", sans-serif;
	font-weight: 700;
	color: #b82603;
}
@media screen and (max-width: 640px) {
	#category_icon_wrap .pickup_tit {
		padding: 0.40rem 0 0;
		font-size: 0.30rem;
	}
}

#category_icon_wrap .area_tit {
	font-size: 0.22rem;
	font-weight: 700;
	text-align: center;
	padding-top: 0.20rem;
}
@media screen and (max-width: 640px) {
	#category_icon_wrap .area_tit {
		font-size: 0.20rem;
		padding-top: 0.30rem;
		padding-bottom: 0.10rem;
	}
}

#category_icon_wrap .area_tit a {
	color: #b82603;
	text-decoration: none;
}

#category_icon_wrap .area_tit a:hover {
	opacity: 0.6;
}

#category_icon_wrap .area_tit a span {
	border-bottom: 2px solid #b82603;
}

#category_icon_wrap .area_tit a span::before {
	content: "";
	display: inline-block;
	width: 0;
  height: 0;
  border-style: solid;
  border-top: 6px solid transparent;
  border-bottom: 6px solid transparent;
  border-left: 8px solid #b82603;
  border-right: 0;
	position: relative;
	margin-right: 0.10rem;
	top: -0.02rem;
}

#category_icon_wrap .list {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 0 0.20rem;
	padding-bottom: 0.20rem;
}

@media screen and (max-width: 640px) {
	#category_icon_wrap .list {
		justify-content: center;
		padding: 0.20rem 0 0;
	}
}

#category_icon_wrap .list:last-child {
	padding-bottom: 0.80rem;
}

#category_icon_wrap .list .detail {
	width: calc(20% - 0.20rem);
	margin: 0.40rem 0 0;
}

@media screen and (max-width: 640px) {
	#category_icon_wrap .list .detail {
		width: 45.5%;
		margin: 0 0 0.20rem;
	}
}

#category_icon_wrap .list .detail a {
	display: block;
	color: #111;
	text-decoration: none;
	position: relative;
	height: 100%;
	box-sizing: border-box;
}

#category_icon_wrap .list .detail a:hover {
	opacity: 0.7;
}

#category_icon_wrap .list .detail a:hover::after {
	bottom: -0.06rem;
}

#category_icon_wrap .list .detail a .area_name {
	text-align: center;
	font-size: 0.15rem;
	font-weight: 700;
	padding-bottom: 0.10rem;
}

@media screen and (max-width: 640px) {
	#category_icon_wrap .list .detail a .area_name {
		font-size: 0.15rem;
		padding-bottom: 0;
		padding-top: 0.05rem;
	}
}

#category_icon_wrap .list .detail a .area_name span {
	display: inline-block;
	padding-right: 0.05rem;
	font-size: 0.12rem;
}

@media screen and (max-width: 640px) {
	#category_icon_wrap .list .detail a .area_name span {
		font-size: 0.12rem;
	}
}

#category_icon_wrap .list .detail a .icon_wrap {
	width: 100%;
	height: 2.20rem;
	overflow: hidden;
	margin: auto;
	border: 3px solid #FFF;
}

@media screen and (max-width: 640px) {
	#category_icon_wrap .list .detail a .icon_wrap {
		width: 100%;
		height: 41vw;
		border-radius: 0.06rem;
	}
}

#category_icon_wrap .list .detail a .icon_wrap img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#category_icon_wrap .list .detail a .text {
	font-size: 0.13rem;
	padding: 0.06rem 0.10rem 0;
	line-height: 1.68;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#category_icon_wrap .list .detail a .text {
		display: none;
	}
}

#category_icon_wrap .list .detail a .price {
	font-size: 0.15rem;
	font-weight: 700;
	color: #bf0000;
	padding-top: 0.05rem;
	padding-left: 0.10rem;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#category_icon_wrap .list .detail a .price {
		text-align: center;
		font-size: 0.14rem;
		padding-left: 0;
		padding-top: 0.07rem;
	}
}

#category_icon_wrap .list .detail a .caption {
	font-size: 0.11rem;
	line-height: 1.6;
	padding-top: 0.10rem;
	text-align: justify;
}
@media screen and (max-width: 640px) {
	#category_icon_wrap .list .detail a .caption {
		font-size: 0.10rem;
		letter-spacing: 0;
	}
}

/*============================
about
============================*/
#about {
	padding: 1.00rem 0;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#about {
		padding: 0.50rem 0;
	}
}

#about .text {
	font-size: 0.20rem;
	line-height: 2;
	letter-spacing: 0.10em;
}

@media screen and (max-width: 640px) {
	#about .text {
		font-size: 0.15rem;
		line-height: 1.91;
		letter-spacing: 0.05em;
		text-align: left;
	}
}

/*============================
feature
============================*/
#feature {
	padding: 1.00rem 0;
	background-color: #F1E9E2;
	text-align: center;
	margin-bottom: 1.00rem;
}

@media screen and (max-width: 640px) {
	#feature {
		padding: 0.50rem 0;
		margin-bottom: 0.50rem;
	}
	#feature .sec_title {
		margin-bottom: 0.40rem;
	}
}

#feature .feature_list_wrap {
	padding-top: 0.30rem;
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap {
		padding-top: 0;
	}
}

#feature .feature_list_wrap .list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}
@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list {
		display: block;
	}
}

#feature .feature_list_wrap .list .detail {
	width: 2.00rem;
	position: relative;
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list .detail {
		width: 100%;
		margin-top: 0.30rem;
		display: flex;
		align-items: center;
		flex-wrap: wrap;
		justify-content: space-between;
	}
}

#feature .feature_list_wrap .list .detail .num {
	width: 0.85rem;
	position: absolute;
	left: 50%;
	top: -0.15rem;
	transform: translateX(-50%);
	z-index: 1;
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list .detail .num {
		width: 0.50rem;
		top: -0.05rem;
		left: 0.35rem;
		transform: translateX(0);
	}
}

#feature .feature_list_wrap .list .detail .round_box {
	background-color: #FFF;
	height: 2.00rem;
	border-radius: 2.00rem;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list .detail .round_box {
		width: 1.20rem;
		height: 1.20rem;
	}
}

#feature .feature_list_wrap .list .detail .round_box .icon_wrap {
	width: 0.90rem;
	margin: auto;
	padding: 0.30rem 0 0.15rem;
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list .detail .round_box .icon_wrap {
		width: 0.70rem;
		padding: 0.25rem 0 0.10rem;
	}
}

#feature .feature_list_wrap .list .detail .title {
	font-size: 0.20rem;
	font-weight: 700;
	color: #111;
	line-height: 1.47;
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list .detail .title {
		font-size: 0.16rem;
		color: #bf0000;
		line-height: 1.47;
		text-align: left;
	}
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list .detail .txt_box {
		width: calc(100% - 1.40rem);
	}
}

#feature .feature_list_wrap .list .detail .text {
	font-size: 0.15rem;
	text-align: center;
	line-height: 1.86;
	padding-top: 0.15rem;
}

@media screen and (max-width: 640px) {
	#feature .feature_list_wrap .list .detail .text {
		font-size: 0.13rem;
		padding: 0.07rem 0 0;
		line-height: 1.55;
		text-align: justify;
	}
}


/*============================
返礼品ボックス
============================*/
.henrei_box {
	padding-bottom: 1.60rem;
}

@media screen and (max-width: 640px) {
	.henrei_box {
		padding-bottom: 0.80rem;
	}
}

/* タイトルの帯 */
.henrei_box::before {
	content: "";
	width: 100%;
	height: 2.50rem;
	background-color: #bf0000;
	position: absolute;
	left: 0;
	top: 0.25rem;
	z-index: -1;
}

@media screen and (max-width: 640px) {
	.henrei_box::before {
		height: 3.00rem;
		top: 0;
	}
}

/* 背景画像 */
.henrei_box::after {
	content: "";
	width: 100%;
	height: 7.30rem;
	background-position: center bottom;
	background-size: cover;
	position: absolute;
	top: 0.30rem;
	left: 0;
	z-index: -2;
}

.henrei_box .in {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	align-items: flex-start;
}

.henrei_box .in .num {
	position: absolute;
	top: 0.55rem;
	right: 0;
	font-family: 'Poppins', sans-serif;
	color: #FFF;
	font-size: 0.14rem;
	letter-spacing: 0.10em;
	z-index: 1;
	writing-mode: vertical-rl;
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .num {
		top: 0.25rem;
		right: 0.10rem;
		font-size: 0.10rem;
	}
}

.henrei_box .in .textbox {
	width: 100%;
	max-width: 4.10rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox {
		max-width: 100%;
	}
}

.henrei_box .in .textbox .henrei_title_wrap {
	margin-top: 0.25rem;
	height: 2.50rem;
	position: relative;
	color: #FFF;
	margin-bottom: 0.35rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap {
		margin-top: 0;
		height: auto;
		margin-bottom: 0.20rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	width: 100%;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box {
		position: relative;
		top: auto;
		left: auto;
		transform: none;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title {
	font-size: 0.38rem;
	font-weight: 700;
	margin-bottom: 0.20rem;
	line-height: 1.33;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title {
		font-size: 0.24rem;
		padding-top: 0.30rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title.small_title {
	font-size: 0.30rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title.small_title {
		font-size: 0.24rem;
		padding-top: 0.30rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title.x-small_title {
	font-size: 0.24rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title.x-small_title {
		font-size: 0.20rem;
		padding-top: 0.30rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title span {
	font-size: 0.20rem;
	display: block;
	padding-bottom: 0.05rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_title span {
		font-size: 0.16rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee {
	display: flex;
	flex-wrap: wrap;
	line-height: 1.45;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee {
		padding-bottom: 0.30rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee .henrei_fee_title {
	width: 0.85rem;
	font-size: 0.16rem;
	letter-spacing: 0.05em;
	font-weight: 700;
	padding-top: 0.08rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee .henrei_fee_title {
		width: calc(100% - 0.20rem);
		font-size: 0.15rem;
		padding-top: 0;
		padding-bottom: 0.10rem;
		border-bottom: 1px solid #FFF;
		margin-bottom: 0.05rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee .henrei_fee_text {
	width: calc(100% - 0.85rem);
	border-left: 1px solid #FFF;
	box-sizing: border-box;
	padding-left: 0.15rem;
	font-size: 0.16rem;
	letter-spacing: 0.05em;
	font-weight: 700;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee .henrei_fee_text {
		width: 100%;
		border-left: 0;
		padding-left: 0;
		font-size: 0.14rem;
	}
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee .henrei_fee_text .text {
	text-align: left;
	padding-right: 0.20rem;
}

.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee .henrei_fee_text .fee span {
	font-size: 0.24rem;
	font-family: 'Poppins', sans-serif;
	font-weight: 500;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .henrei_title_wrap .henrei_title_box .henrei_fee .henrei_fee_text .fee span {
		font-size: 0.20rem;
	}
}

.henrei_box .in .textbox .sub_title {
	font-size: 0.24rem;
	font-weight: 700;
	line-height: 1.66;
	padding-bottom: 0.10rem;
	letter-spacing: 0.075em;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .sub_title {
		font-size: 0.20rem;
	}
}

.henrei_box .in .textbox .caption {
	font-size: 0.16rem;
	line-height: 1.87;
	letter-spacing: 0.05em;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .caption {
		font-size: 0.15rem;
	}
}

.henrei_box .in .textbox .spec_wrap {
	padding-top: 0.25rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .spec_wrap {
		padding-top: 0.30rem;
	}
}

.henrei_box .in .textbox .spec_wrap table {
	width: 100%;
	font-size: 0.145rem;
	letter-spacing: 0.075em;
	line-height: 1.75;
	border-collapse: collapse;
	border-top: 1px solid #111;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .spec_wrap table {
		font-size: 0.14rem;
	}
}

.henrei_box .in .textbox .spec_wrap table th {
	text-align: left;
	vertical-align: top;
	padding: 0.10rem;
	width: 0.70rem;
	border-bottom: 1px solid #111;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .spec_wrap table th {
		padding: 0.10rem;
		padding-left: 0;
		width: 0.70rem;
	}
}

.henrei_box .in .textbox .spec_wrap table td {
	padding: 0.10rem;
	border-bottom: 1px solid #111;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .spec_wrap table td {
		padding: 0.10rem;
		padding-right: 0;
	}
}

/* メイン購入ボタン */
.henrei_box .in .textbox .buy_btn {
	padding-top: 0.25rem;
}

.henrei_box .in .textbox .buy_btn a {
	width: 100%;
	max-width: 3.60rem;
	display: block;
	background-color: #bd0000;
	line-height: 0;
	padding: 0.30rem 0;
	text-align: center;
	font-size: 0.20rem;
	font-weight: 700;
	color: #fff;
	border-radius: 0.06rem;
	box-shadow: 0 2px 0 #bd000039;
	text-decoration: none;
}

.henrei_box .in .textbox .buy_btn a:hover {
	opacity: 0.6;
}

.henrei_box .in .textbox .buy_btn a span::after {
	content: "";
	width: 0.18rem;
	height: 0.18rem;
	background-image: url(../common/img/icon_newwin_white.svg);
	background-position: right center;
	background-repeat: no-repeat;
	background-size: contain;
	margin-left: 0.06rem;
	display: inline-block;
}

.henrei_box .in .textbox .buy_btn .caption {
	max-width: 3.60rem;
	font-size: 0.13rem;
	font-weight: 500;
	padding-top: 0.03rem;
	text-align: center;
}
@media screen and (max-width: 640px) {
	.henrei_box .in .textbox .buy_btn .caption {
		max-width: 100%;
		font-size: 0.12rem;
		padding-top: 0.06rem;
	}
}

/* 写真 */
.henrei_box .in .main_ph_wrap {
	width: 100%;
	max-width: 7.48rem;
	border-radius: 0.10rem;
	overflow: hidden;
	box-shadow: 0 0 6px rgba(0, 0, 0, 0.2);
	max-height: 7.5rem;
	min-height: 6.5rem;
	height: 50vw;
	position: relative;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .main_ph_wrap {
		border-radius: 0;
		margin: 0 -0.20rem;
		width: calc(100% + 0.40rem);
		height: auto;
		max-height: auto;
		min-height: auto;
	}
}

.henrei_box .in .main_ph_wrap img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.henrei_box .in .main_ph_wrap .ph_caption {
	position: absolute;
	font-size: 0.12rem;
	color: #FFF;
	bottom: 0.15rem;
	right: 0.15rem;
}

/* サブ返礼品 */
.henrei_box .in .sub_item_box {
	width: 100%;
	max-width: 7.30rem;
	margin-top: 0.55rem;
	background-color: #F1E9E2;
	border-radius: 0.10rem;
	box-sizing: border-box;
}

.henrei_box .in .sub_item_box .sub_title {
	font-size: 0.20rem;
	font-weight: 700;
	padding: 0.30rem 0.30rem 0.20rem;
	border-bottom: 1px solid #bf0000;
	position: relative;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .sub_item_box .sub_title {
		font-size: 0.17rem;
		text-align: center;
		font-weight: 700;
		padding: 0.20rem;
		line-height: 1.45;
	}
}

.henrei_box .in .sub_item_box .sub_title::before {
	content: "";
	width: 1.50rem;
	height: 0.80rem;
	background-image: url(../../img/reccomend_icon.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	top: -0.40rem;
	left: -0.30rem;
	transform: rotate(-5deg);
	z-index: 1;
}
@media screen and (max-width: 640px) {
	.henrei_box .in .sub_item_box .sub_title::before {
		content: "";
		width: 1.20rem;
		height: 0.60rem;
		background-image: url(../../img/reccomend_icon.svg);
		background-position: center;
		background-repeat: no-repeat;
		background-size: contain;
		position: absolute;
		top: -0.30rem;
		left: -0.20rem;
		transform: rotate(-5deg);
		z-index: 1;
	}
}

.henrei_box .in .sub_item_box .flexbox {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	padding: 0.30rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .sub_item_box .flexbox {
		display: block;
		padding: 0.20rem;
	}
}

.henrei_box .in .sub_item_box .ph_wrap {
	width: 45%;
	overflow: hidden;
	height: fit-content;
	border-radius: 0.06rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .sub_item_box .ph_wrap {
		width: 100%;
		height: fit-content;
	}
}

.henrei_box .in .sub_item_box .ph_wrap img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.henrei_box .in .sub_item_box .textbox {
	width: 52%;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .sub_item_box .textbox {
		width: 100%;
		padding-top: 0.15rem;
	}
}

.henrei_box .in .sub_item_box .textbox .text {
	font-size: 0.15rem;
	line-height: 1.85;
}

.henrei_box .in .sub_item_box .textbox .spec_wrap {
	padding-top: 0.15rem;
}

.henrei_box .in .sub_item_box .textbox .spec_wrap table {
	font-size: 0.14rem;
}

.henrei_box .in .sub_item_box .textbox .buy_btn {
	padding-top: 0.20rem;
}

.henrei_box .in .sub_item_box .textbox .buy_btn a {
	padding: 0.25rem 0;
	font-size: 0.16rem;
}

.henrei_box .in .sub_item_box .textbox .buy_btn a span::after {
	width: 0.12rem;
	height: 0.12rem;
}


/* スペックとリンク */
.henrei_box .in .spec_box {
	width: 100%;
	max-width: 6.50rem;
	padding-top: 0.55rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box {
		padding-top: 0.30rem;
	}
}

.henrei_box .in .spec_box table {
	width: 100%;
	font-size: 0.16rem;
	letter-spacing: 0.075em;
	line-height: 1.75;
	border-collapse: collapse;
	border-top: 1px solid #111;
	margin-bottom: 0.55rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box table {
		font-size: 0.14rem;
		margin-bottom: 0.30rem;
	}
}

.henrei_box .in .spec_box table th {
	text-align: left;
	vertical-align: top;
	padding: 0.15rem;
	width: 1.40rem;
	border-bottom: 1px solid #111;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box table th {
		padding: 0.10rem;
		padding-left: 0;
		width: 0.70rem;
	}
}

.henrei_box .in .spec_box table td {
	padding: 0.15rem;
	border-bottom: 1px solid #111;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box table td {
		padding: 0.10rem;
		padding-right: 0;
	}
}

.henrei_box .in .spec_box .kifu_title {
	background-color: #b82603;
	font-size: 0.20rem;
	font-weight: 700;
	color: #FFF;
	letter-spacing: 0.075em;
	padding: 0.14rem 0.15rem 0.17rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box .kifu_title {
		font-size: 0.18rem;
		padding: 0.10rem 0.13rem 0.13rem;
	}
}

.henrei_box .in .spec_box .kifu_link_wrap .list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.henrei_box .in .spec_box .kifu_link_wrap .list .link {
	width: 48%;
	padding-top: 0.20rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box .kifu_link_wrap .list .link {
		width: 49%;
		padding-top: 0.15rem;
	}

	.henrei_box .in .spec_box .kifu_link_wrap .list .link.sp_full {
		width: 100%;
	}
}

.henrei_box .in .spec_box .kifu_link_wrap .list .link a {
	display: block;
	background-color: #00aa00;
	font-size: 0.18rem;
	font-weight: 700;
	color: #FFF;
	text-align: center;
	border-radius: 0.05rem;
	box-shadow: 0 3px rgba(0, 170, 0, 0.3);
	text-decoration: none;
	line-height: 0;
	padding: 0.29rem 0 0.31rem;
}

.henrei_box .in .spec_box .kifu_link_wrap .list .link a.line2 {
	line-height: 1.35;
	padding: 0.14rem 0 0.16rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box .kifu_link_wrap .list .link a {
		font-size: 0.13rem;
		padding: 0.19rem 0 0.21rem;
		letter-spacing: 0;
		position: relative;
	}
	.henrei_box .in .spec_box .kifu_link_wrap .list .link a.line2 {
		line-height: 1.35;
		padding: 0.08rem 0 0.10rem;
	}
	.henrei_box .in .spec_box .kifu_link_wrap .list .link a.line2 em {
		font-size: 0.11rem;
	}
}

.henrei_box .in .spec_box .kifu_link_wrap .list .link a span::after {
	content: "";
	width: 0.18rem;
	height: 0.18rem;
	background-image: url(../common/img/icon_newwin_white.svg);
	background-position: right center;
	background-repeat: no-repeat;
	background-size: contain;
	margin-left: 0.06rem;
	display: inline-block;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .spec_box .kifu_link_wrap .list .link a span::after {
		width: 0.14rem;
		height: 0.12rem;
		margin-left: 0.04rem;
	}
	.henrei_box .in .spec_box .kifu_link_wrap .list .link a.line2 span::after {
		position: absolute;
		right: 0.10rem;
		top:50%;
		transform: translateY(-50%);
	}
}

/* 街の情報 */
.henrei_box .in .town_info_wrap {
	width: 100%;
	max-width: 4.20rem;
	padding-top: 0.55rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .town_info_wrap {
		max-width: 100%;
		padding-top: 0.40rem;
	}
}

.henrei_box .in .town_info_wrap .ph_wrap {
	height: 2.75rem;
	overflow: hidden;
	border: 5px solid #FFF;
	box-sizing: border-box;
	box-shadow: 0 2px 6px rgba(0, 0, 0, 0.3);
	overflow: hidden;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .town_info_wrap .ph_wrap {
		height: 55vw;
	}
}

.henrei_box .in .town_info_wrap .ph_wrap img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.henrei_box .in .town_info_wrap .title {
	text-align: center;
	font-size: 0.20rem;
	font-weight: 700;
	letter-spacing: 0.075em;
	padding: 0.20rem 0 0.10rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .town_info_wrap .title {
		font-size: 0.16rem;
	}
}

.henrei_box .in .town_info_wrap .text {
	font-size: 0.15rem;
	line-height: 1.85;
	letter-spacing: 0.05em;
	padding-bottom: 0.15rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .town_info_wrap .text {
		font-size: 0.14rem;
		line-height: 1.71;
	}
}

.henrei_box .in .town_info_wrap .more_btn {
	max-width: 3.00rem;
	margin: auto;
}
@media screen and (max-width: 640px) {
	.henrei_box .in .town_info_wrap .more_btn {
		padding-bottom: 0.15rem;
	}
}

.henrei_box .in .town_info_wrap .more_btn a {
	width: 100%;
	display: block;
	background-color: #bd0000;
	line-height: 0;
	padding: 0.22rem 0 0.24rem;
	text-align: center;
	font-size: 0.16rem;
	font-weight: 700;
	color: #fff;
	border-radius: 0.06rem;
	box-shadow: 0 2px 0 #bd000039;
	text-decoration: none;
}

.henrei_box .in .town_info_wrap .more_btn a:hover {
	opacity: 0.7;
}

.henrei_box .in .town_info_wrap .more_btn a span::after {
	content: "";
	width: 0.12rem;
	height: 0.12rem;
	background-image: url(../common/img/icon_newwin_white.svg);
	background-position: right center;
	background-repeat: no-repeat;
	background-size: contain;
	margin-left: 0.06rem;
	display: inline-block;
}

.henrei_box .in .town_info_wrap .more_btn .caption {
	font-size: 0.13rem;
	font-weight: 500;
	text-align: center;
	padding-top: 0.06rem;
}
@media screen and (max-width: 640px) {
	.henrei_box .in .town_info_wrap .more_btn .caption {
		font-size: 0.12rem;
		padding-top: 0.08rem;
	}
}

/* お問い合わせ */
.henrei_box .in .contact_wrap {
	text-align: center;
	width: 100%;
	max-width: 7.00rem;
	margin: 0.30rem auto 0;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .contact_wrap {
		margin: 0.10rem auto 0;
	}
}

.henrei_box .in .contact_wrap .title {
	padding: 0.10rem 0 0.12rem;
	border-top: 1px solid #111;
	border-bottom: 1px solid #111;
	font-size: 0.18rem;
	font-weight: 700;
	margin-bottom: 0.10rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .contact_wrap .title {
		font-size: 0.16rem;
	}
}

.henrei_box .in .contact_wrap .text {
	padding-bottom: 0.10rem;
	font-size: 0.14rem;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .contact_wrap .text {
		padding-bottom: 0.10rem;
		line-height: 1.55;
	}
}

.henrei_box .in .contact_wrap .tel {
	font-family: 'Poppins', sans-serif;
	font-size: 0.20rem;
	letter-spacing: 0.10em;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .contact_wrap .tel {
		font-weight: 600;
	}
}

.henrei_box .in .contact_wrap .tel a {
	color: #111;
	text-decoration: none;
}

@media screen and (max-width: 640px) {
	.henrei_box .in .contact_wrap .tel a {
		text-decoration: underline;
	}
}


/* 返礼品ごと */
#henrei01::after {
	background-image: url(../img/henrei/01/bg.jpg);
}

#henrei02::after {
	background-image: url(../img/henrei/02/bg.jpg);
}

#henrei03::after {
	background-image: url(../img/henrei/03/bg.jpg);
}

#henrei04::after {
	background-image: url(../img/henrei/04/bg.jpg);
}

#henrei05::after {
	background-image: url(../img/henrei/05/bg.jpg);
}

#henrei06::after {
	background-image: url(../img/henrei/06/bg.jpg);
}

#henrei07::after {
	background-image: url(../img/henrei/07/bg.jpg);
}

/*=======================
寄附金控除について
=======================*/
#donation {
	padding: 1.00rem 0;
	background-color: #F1E9E2;
}

@media screen and (max-width: 640px) {
	#donation {
		padding: 0.50rem 0 0.20rem;
	}
}

#donation .list {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

#donation .list .detail {
	width: 47.5%;
	background-color: #FFF;
	overflow: hidden;
	list-style: none;
	border: 1px solid #bf0000;
}

@media screen and (max-width: 640px) {
	#donation .list .detail {
		width: 100%;
		margin-bottom: 0.30rem;
	}
}

#donation .list .detail .title {
	text-align: center;
	font-size: 0.24rem;
	font-weight: 700;
	color: #FFF;
	letter-spacing: 0.05em;
	padding: 0.25rem 0;
	background-color: #bf0000;
}

@media screen and (max-width: 640px) {
	#donation .list .detail .title {
		font-size: 0.18rem;
		padding: 0.20rem 0;
	}
}

#donation .list .detail .ph_wrap {
	padding: 0.50rem;
}

@media screen and (max-width: 640px) {
	#donation .list .detail .ph_wrap {
		padding: 0.30rem 0.20rem;
	}
}

#donation .list .detail .text {
	padding: 0 0.40rem 0.30rem;
	font-size: 0.16rem;
	line-height: 2;
}

@media screen and (max-width: 640px) {
	#donation .list .detail .text {
		padding: 0 0.20rem 0.20rem;
		font-size: 0.14rem;
		line-height: 1.85;
	}
}

#donation .list .detail .caption {
	border-top: 1px solid #CCC;
	margin: 0 0.40rem;
	padding: 0.20rem 0;
}

@media screen and (max-width: 640px) {
	#donation .list .detail .caption {
		margin: 0 0.20rem;
	}
}

#donation .list .detail .caption .caption_text {
	font-size: 0.14rem;
	line-height: 1.85;
	text-indent: -0.14rem;
	padding-left: 0.14rem;
	padding-bottom: 0.14rem;
}

@media screen and (max-width: 640px) {
	#donation .list .detail .caption .caption_text {
		font-size: 0.13rem;
		line-height: 1.75;
		text-indent: -0.13rem;
		padding-left: 0.13rem;
		padding-bottom: 0.13rem;
	}
}

#donation .list .detail .caption02 {
	border-top: 1px solid #CCC;
	margin: 0 0.40rem;
}

@media screen and (max-width: 640px) {
	#donation .list .detail .caption02 {
		margin: 0 0.20rem;
	}
}

#donation .list .detail .caption02 .text {
	padding: 0.20rem 0 0.50rem;
}

@media screen and (max-width: 640px) {
	#donation .list .detail .caption02 .text {
		padding: 0.20rem 0 0.20rem;
	}
}

#donation .more_btn {
	width: 100%;
	max-width: 4.00rem;
	margin: 0.30rem auto 0;
}
@media screen and (max-width: 640px) {
	#donation .more_btn {
		margin: 0.10rem auto 0;
		padding: 0 0.10rem 0.30rem;
		box-sizing: border-box;
	}
}

#donation .more_btn a {
	width: 100%;
	display: block;
	background-color: #bd0000;
	line-height: 0;
	padding: 0.30rem 0;
	text-align: center;
	font-size: 0.20rem;
	font-weight: 700;
	color: #fff;
	border-radius: 0.06rem;
	box-shadow: 0 2px 0 #bd000039;
	text-decoration: none;
}
@media screen and (max-width: 640px) {
	#donation .more_btn a {
		padding: 0.22rem 0 0.24rem;
		font-size: 0.16rem;
	}
}

#donation .more_btn a:hover {
	opacity: 0.6;
}

#donation .more_btn a span::after {
	content: "";
	width: 0.18rem;
	height: 0.18rem;
	background-image: url(../common/img/icon_newwin_white.svg);
	background-position: right center;
	background-repeat: no-repeat;
	background-size: contain;
	margin-left: 0.06rem;
	display: inline-block;
}
@media screen and (max-width: 640px) {
	#donation .more_btn a span::after {
		height: 0.13rem;
	}
}

/*========================
フッター
========================*/
footer {
	padding: 0.50rem 0;
	text-align: center;
}

@media screen and (max-width: 640px) {
	footer {
		padding: 0.30rem 0;
	}
}

footer .logo {
	width: 100%;
	max-width: 5.10rem;
	margin: auto;
	padding-bottom: 0.20rem;
}

@media screen and (max-width: 640px) {
	footer .logo {
		max-width: 2.60rem;
	}
}

footer .copyright {
	text-align: center;
	font-size: 0.13rem;
	letter-spacing: .05em;
	font-family: 'Poppins', sans-serif
}

@media screen and (max-width: 640px) {
	footer .copyright {
		font-size: 0.10rem;
	}
}

footer .corpname {
	text-align: center;
	font-size: 0.13rem;
	letter-spacing: .05em;
	font-family: 'Poppins', sans-serif;
	padding-top: 0.10rem;
}
@media screen and (max-width: 640px) {
	footer .corpname {
		font-size: 0.10rem;
	}
}