@charset "UTF-8";

body {
	letter-spacing: 2px;
	padding-top: 100px;
}
@media screen and (max-width: 1160px) {
	body {
		letter-spacing: .2vw;
		padding-top: 8vw;
	}
}
@media screen and (max-width: 780px) {
	body {
		letter-spacing: .4vw;
		padding-top: 12vw;
	}
}

.sec_inner {
	margin: 0 auto;
	width: 1120px;
}
.headline_1 {
	font-size: 30px;
}
.headline_2 {
	font-size: 24px;
}
@media screen and (max-width: 1160px) {
	.sec_inner {
		margin: 0 4vw;
		width: auto;
	}
	.headline_1 {
		font-size: 2.8vw;
	}
	.headline_2 {
		font-size: 2.3vw;
	}
}
@media screen and (max-width: 780px) {
	.sec_inner {
		margin: 0 5vw;
		width: auto;
	}
	.headline_1 {
		font-size: 5.2vw;
	}
	.headline_2 {
		font-size: 4.6vw;
	}
}

/** -------------------
	header
------------------- **/
header {
	background-color: #fff;
	box-shadow: 0 0 8px 0 rgba(0, 0, 0, .2);
	position: fixed;
	left: 0;
	top: 0;
	height: 100px;
	width: 100%;
	z-index: 999;
}
header .logo {
	position: absolute;
	left: 40px;
	top: 15px;
	height: 60px;
	width: auto;
}
header .logo img {
	height: 100%;
	width: auto;
}
header .nav {
	align-items: flex-start;
	font-size: 15px;
	line-height: 1.0;
	justify-content: flex-end;
	margin-right: 30px;
	margin-top: 40px;
}
header .nav li {
	position: relative;
	padding: 0 15px 20px;
}
header .nav li a {
	display: block;
}
header .nav li a:hover {
	color: #AABC4A;
}
header .nav li.menu-item-has-children a {
	padding-right: 20px;
	position: relative;
}
header .nav li.menu-item-has-children a::after {
	content: '\f107';
	display: block;
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	position: absolute;
	top: 2px;
	right: 0;
}
header .nav li a span {
	color: #C94C6E;
}
header .nav .sub-menu {
	background-color: #fff;
	box-shadow: 0 0 5px 0 rgba(0, 0, 0, .2);
	display: none;
	position: absolute;
	left: 0px;
	top: 30px;
	white-space: nowrap;
}
header .nav .sub-menu li {
	padding: 0;
}
header .nav .sub-menu li a {
	background-repeat: no-repeat;
	background-position: 15px 50%;
	background-size: 24px;
	display: block;
	padding: 12px 15px;
	padding-left: 50px;
}
header .nav .sub-menu li.red a {
	background-image: url("../img/common/icon_red.svg");
}
header .nav .sub-menu li.white a {
	background-image: url("../img/common/icon_white.svg");
}
header .nav .sub-menu li.lose a {
	background-image: url("../img/common/icon_lose.svg");
}
header .nav .sub-menu li.set a {
	background-image: url("../img/common/icon_set1.svg");
}
header .nav .sub-menu li.set:last-child a {
	background-image: url("../img/common/icon_set2.svg");
}
header .nav .sub-menu li a span {
	font-size: 90%;
}
header .nav li.menu-item-has-children .sub-menu li a::after {
	display: none;
}
header .nav li.user {
	margin-left: 10px;
	padding: 0;
	width: 20px;
}
header .nav li.search {
	margin-left: 12px;
	padding: 0;
	width: 20px;
}
header .nav li.cart {
	margin-left: 12px;
	padding: 0;
	width: 20px;
}
header .menu_btn {
	display: none;
}
@media screen and (max-width: 1160px) {
	header {
		height: 8vw;
	}
	header .logo {
		left: 3vw;
		top: 1vw;
		height: 5vw;
	}
	header .nav {
		font-size: 1.3vw;
		margin-right: 3vw;
		margin-top: 3vw;
	}
	header .nav li {
		padding: 0 1vw 2vw;
	}
	header .nav li.menu-item-has-children a {
		padding-right: 2vw;
	}
	header .nav li.menu-item-has-children a::after {
		top: .2vw;
	}
	header .nav .sub-menu {
		top: 3vw;
	}
	header .nav .sub-menu li a {
		background-position: 1.5vw 50%;
		background-size: 2.4vw;
		padding: 1vw 1.5vw;
		padding-left: 5vw;
	}
	header .nav li.user {
		margin-left: 1vw;
		width: 2vw;
	}
	header .nav li.search {
		margin-left: 1.2vw;
		width: 2vw;
	}
	header .nav li.cart {
		margin-left: 1.2vw;
		width: 2vw;
	}
}
@media screen and (max-width: 780px) {
	header {
		height: 12vw;
	}
	header .logo {
		left: 4vw;
		top: 2vw;
		height: 8vw;
	}
	header .nav {
		background-color: #fff;
		border-bottom: solid 1px #D8D8D8;
		font-size: 3.6vw;
		margin-right: 0;
		margin-top: 0;
		position: fixed;
		top: 12vw;
		transform: translateY(-120vh);
	}
	header .nav li {
		background-color: #F7F7F7;
		border-top: solid 1px #D8D8D8;
		padding: 0;
		width: 100%;
	}
	header .nav li a {
		display: block;
		padding: 5vw 10vw !important;
	}
	header .nav li.has-sub a::after {
		top: .2vw;
	}
	header .nav .sub-menu {
		box-shadow: none;
		display: block;
		position: static;
		top: auto;
	}
	header .nav .sub-menu li {
		background-color: #fff;
	}
	header .nav .sub-menu li a {
		background-position: 12vw 50%;
		background-size: 7vw;
		padding-left: 23vw !important;
	}
	header .nav .sub-menu li.set a {
		padding-bottom: 2.8vw !important;
		padding-top: 2.8vw !important;
	}
	header .nav .sub-menu li.set a span {
		display: block;
		margin-top: 1vw;
	}
	header .nav li.user {
		display: none;
	}
	header .nav li.search {
		display: none;
	}
	header .nav li.cart {
		background-color: transparent;
		border: none;
		margin-left: 0;
		position: absolute;
		right: 16vw;
		top: -9vw;
		width: 6vw;
	}
	header .nav li.cart a {
		padding: 0 !important;
	}
	header .menu_btn {
		cursor: pointer;
		display: block;
		position: absolute;
		right: 6vw;
		top: 2.8vw;
		height: 6vw;
		width: 6vw;
	}
	header .menu_btn span {
		background-color: #2B3848;
		border-radius: 10px;
		display: block;
		position: absolute;
		left: 0;
		height: 2px;
		width: 100%;
	}
	header .menu_btn span:nth-child(1) {
		top: 1vw;
	}
	header .menu_btn span:nth-child(2) {
		top: 3vw;
	}
	header .menu_btn span:nth-child(3) {
		top: 5vw;
	}
	header .menu_btn.active span:nth-child(1) {
		top: 3vw;
	}
	header .menu_btn.active span:nth-child(2) {
		opacity: 0;
	}
	header .menu_btn.active span:nth-child(3) {
		top: 3vw;
	}
}

/** -------------------
	main
------------------- **/

/** -- top_slider -- **/
.top_slider {
	margin-bottom: 100px;
	position: relative;
}
.top_slider .swiper-button-prev,
.top_slider .swiper-button-next {
	height: 68px;
	width: 68px;
}
.top_slider .swiper-button-prev {
	background: url("../img/common/slider-arrow-left.svg") no-repeat 0 0 / 100%;
	left: 24vw;
}
.top_slider .swiper-button-next {
	background: url("../img/common/slider-arrow-right.svg") no-repeat 0 0 / 100%;
	right: 24vw;
}
.swiper-button-prev:after,
.swiper-button-next:after {
	display: none;
}
@media screen and (max-width: 1160px) {
	.top_slider {
		margin-bottom: 10vw;
	}
	.top_slider .swiper-button-prev,
	.top_slider .swiper-button-next {
		height: 3.8vw;
		width: 3.8vw;
	}
	.top_slider .swiper-button-prev {
		left: 17.5vw;
	}
	.top_slider .swiper-button-next {
		right: 17.5vw;
	}
}
@media screen and (max-width: 780px) {
	.top_slider {
		margin-bottom: 18vw;
		padding: 0 6vw;
	}
	.top_slider .swiper-button-prev,
	.top_slider .swiper-button-next {
		height: 9vw;
		width: 9vw;
	}
	.top_slider .swiper-button-prev {
		left: 2vw;
	}
	.top_slider .swiper-button-next {
		right: 2vw;
	}
}

/** -- pickup -- **/
.pickup {
	margin-bottom: 120px;
	padding-top: 160px;
}
.pickup .headline_1 {
	margin-bottom: 40px;
	text-align: center;
}
.pickup article {
	background-color: #fff;
	border-radius: 8px;
	box-shadow: 0 0 10px 0 rgba(0, 0, 0, .2);
	padding: 40px 40px 70px;
	position: relative;
}
.pickup article + article {
	margin-top: 50px;
}
.pickup article .image {
	position: relative;
	height: 440px;
	width: 440px;
}
.pickup article .image img {
	object-fit: contain;
	height: 100%;
	width: 100%;
}
.pickup article .image p.white {
	color: #AABC4A;
	font-size: 15px;
	position: absolute;
	left: 0;
	top: 0;
}
.pickup article .text {
	margin-left: 20px;
	width: calc(100% - 440px - 20px);
}
.pickup article .text .headline_2 {
	margin-bottom: 20px;
}
.pickup article .text .headline_2 span {
	display: block;
	font-size: 14px;
}
.pickup article .text .exp {
	font-size: 15px;
	margin-bottom: 20px;
}
.pickup article .text .one_word {
	background: url("../img/common/one_word_bg.png") no-repeat center / cover;
	margin-bottom: 25px;
	padding: 30px 20px;
	padding-left: 90px;
	position: relative;
	height: 170px;
}
.pickup article .text .one_word figure {
	position: absolute;
	left: 20px;
	top: 30px;
	width: 60px;
}
.pickup article .text .one_word h4 {
	font-size: 15px;
	font-weight: 700;
}
.pickup article .text .one_word p {
	font-size: 14px;
}
.pickup ul.medal {
	display: table;
	margin-left: auto;
}
.pickup ul.medal li {
	background: url("../img/common/icon_medal.svg") no-repeat 0 50% / 16px;
	font-size: 12px;
	line-height: 1.0;
	padding: 5px 0;
	padding-left: 22px;
}
.pickup ul.medal li + li {
	margin-top: 5px;
}
.pickup ul.medal li span {
	border-right: solid 1px #707070;
	font-weight: 700;
	margin-right: 10px;
	padding-right: 10px;
}
.pickup .price {
	margin-right: 220px;
	margin-top: 40px;
	text-align: right;
}
.pickup .price .yen {
	font-size: 12px;
	margin-right: 2px;
}
.pickup .price .tax {
	font-size: 12px;
	margin-left: 5px;
}
.pickup .button {
	background-color: #C94C6E;
	border: solid 1px #C94C6E;
	border-radius: 4px;
	box-sizing: border-box;
	color: #fff;
	cursor: pointer;
	padding: 10px;
	position: absolute;
	bottom: 60px;
	right: 40px;
	width: 200px;
}
.pickup .button:hover {
	background-color: #fff;
	color: #C94C6E;
}
.pickup .button span {
	background: url("../img/common/glass2-white.svg") no-repeat 0 0 / 24px;
	display: table;
	margin: 0 auto;
	padding-left: 30px;
}
.pickup .button:hover span {
	background-image: url("../img/common/glass2.svg");
}
@media screen and (max-width: 1160px) {
	.pickup {
		margin-bottom: 12vw;
		padding-top: 14vw;
	}
	.pickup .headline_1 {
		margin-bottom: 4vw;
	}
	.pickup article {
		padding: 3vw 3vw 6vw;
	}
	.pickup article + article {
		margin-top: 4vw;
	}
	.pickup article .image {
		height: 38vw;
		width: 38vw;
	}
	.pickup article .image p.red,
	.pickup article .image p.lose,
	.pickup article .image p.white {
		font-size: 1.3vw;
	}
	.pickup article .text {
		margin-left: 1vw;
		width: calc(100% - 38vw - 1vw);
	}
	.pickup article .text .headline_2 {
		margin-bottom: 1vw;
	}
	.pickup article .text .headline_2 span {
		font-size: 1.2vw;
	}
	.pickup article .text .exp {
		font-size: 1.3vw;
		margin-bottom: 2vw;
	}
	.pickup article .text .one_word {
		margin-bottom: 2vw;
		padding: 2vw 2vw;
		padding-left: 8.6vw;
		height: auto;
	}
	.pickup article .text .one_word figure {
		left: 2vw;
		top: 2vw;
		width: 6vw;
	}
	.pickup article .text .one_word h4 {
		font-size: 1.3vw;
	}
	.pickup article .text .one_word p {
		font-size: 1.2vw;
	}
	.pickup ul.medal li {
		background-size: 1.6vw;
		font-size: 1.1vw;
		padding: .5vw 0;
		padding-left: 2vw;
	}
	.pickup ul.medal li + li {
		margin-top: .5vw;
	}
	.pickup ul.medal li span {
		margin-right: .8vw;
		padding-right: .8vw;
	}
	.pickup .price {
		margin-right: 22vw;
		margin-top: 3vw;
	}
	.pickup .price .yen {
		font-size: 1.1vw;
		margin-right: .2vw;
	}
	.pickup .price .tax {
		font-size: 1.1vw;
		margin-left: .4vw;
	}
	.pickup .button {
		padding: 1vw;
		bottom: 5vw;
		right: 3vw;
		width: 20vw;
	}
	.pickup .button span {
		background-size: 2.1vw;
		padding-left: 3vw;
	}
}
@media screen and (max-width: 780px) {
	.pickup {
		margin-bottom: 18vw;
		padding-top: 20vw;
	}
	.pickup .headline_1 {
		margin-bottom: 5vw;
	}
	.pickup article {
		border-radius: 8px;
		box-shadow: 0 0 1vw 0 rgba(0, 0, 0, .1);
		padding: 8vw 5vw 8vw;
	}
	.pickup article + article {
		margin-top: 8vw;
	}
	.pickup article .image {
		margin-top: 10vw;
		height: 40vw;
		width: 40vw;
	}
	.pickup article .image p.white {
		font-size: 3.6vw;
		position: absolute;
		left: 0;
		top: -10vw;
	}
	.pickup article .text {
		margin-left: 0;
		margin-top: 8vw;
		width: 100%;
	}
	.pickup article .text .headline_2 {
		margin-bottom: 0;
		position: absolute;
		left: 42vw;
		top: 30vw;
	}
	.pickup article .text .headline_2 span {
		font-size: 3.2vw;
		left: 0;
	}
	.pickup article .text .exp {
		font-size: 3.2vw;
		margin-bottom: 4vw;
	}
	.pickup article .text .one_word {
		margin-bottom: 5vw;
		padding: 6vw 3vw 4vw;
		height: auto;
	}
	.pickup article .text .one_word figure {
		left: 3vw;
		top: 4vw;
		width: 10vw;
	}
	.pickup article .text .one_word h4 {
		font-size: 3.4vw;
		margin-bottom: 6vw;
		padding-left: 18vw;
	}
	.pickup article .text .one_word p {
		font-size: 3vw;
	}
	.pickup ul.medal {
		margin-left: 0;
	}
	.pickup ul.medal li {
		background-size: 4vw;
		font-size: 2.8vw;
		letter-spacing: 0;
		padding: 1vw 0;
		padding-left: 5vw;
	}
	.pickup ul.medal li + li {
		margin-top: 1vw;
	}
	.pickup ul.medal li span {
		margin-right: 2vw;
		padding-right: 2vw;
	}
	.pickup .price {
		letter-spacing: .2vw;
		margin-right: 45vw;
		margin-top: 8vw;
	}
	.pickup .price .yen {
		font-size: 2.8vw;
		margin-right: .3vw;
	}
	.pickup .price .tax {
		font-size: 2.8vw;
		margin-left: .3vw;
	}
	.pickup .button {
		padding: 2vw;
		bottom: 6vw;
		right: 5vw;
		width: 40vw;
	}
	.pickup .button span {
		background-size: 4.6vw;
		padding-left: 7vw;
	}
}

/** -- item_list -- **/
.item_list {
	margin-bottom: 160px;
}
.item_list .headline_1 {
	margin-bottom: 50px;
	text-align: center;
}
.item_list .tab {
	margin: 0 -5px 50px;
}
.item_list .tab li {
	border-bottom: solid 4px #D8D8D8;
	color: #D8D8D8;
	cursor: pointer;
	font-size: 20px;
	margin: 0 5px;
	padding-bottom: 5px;
	text-align: center;
	width: calc(16.6666% - 10px);
}
.item_list .tab li.active {
	border-color: #C94C6E;
	color: #191919;
}
/** list **/
.item_list .list {
	display: none;
	margin: 0 -15px;
}
.item_list .list.active {
	display: block;
}
.item_list .list article {
	margin: 0 15px 80px;
	padding-bottom: 70px;
	position: relative;
	width: calc(25% - 30px);
}
.item_list .list article .thumb {
	margin-bottom: 20px;
}
.item_list .list article .cat {
	color: #7E7E7E;
	font-size: 12px;
	margin-bottom: 5px;
}
.item_list .list article .name {
	font-size: 14px;
	margin-bottom: 5px;
}
.item_list .list article .price del {
	display: inline-block;
	margin-right: 10px;
}
.item_list .list article .price ins {
	text-decoration: none;
}
.item_list .list article .price .woocommerce-Price-currencySymbol {
	font-size: 12px;
	margin-right: 2px;
}
.item_list .list article .price .tax {
	font-size: 12px;
	margin-left: 5px;
}
.item_list .list article .button {
	background: url("../img/common/cart-white.svg") no-repeat 25px 50% / 24px;
	background-color: #C94C6E;
	border: solid 1px #C94C6E;
	border-radius: 4px;
	box-sizing: border-box;
	color: #fff;
	cursor: pointer;
	padding: 10px;
	padding-left: 40px;
	position: absolute;
	bottom: 0;
	right: 40px;
	text-align: center;
	width: 200px;
}
.item_list .list article .button:hover {
	background-image: url("../img/common/cart-pink.svg");
	background-color: #fff;
	color: #C94C6E;
}
.item_list .list .btn {
	background-color: #191919;
	border: solid 1px #191919;
	border-radius: 4px;
	box-sizing: border-box;
	color: #fff;
	display: block;
	font-size: 18px;
	margin: 0 auto;
	padding: 10px 0 14px;
	text-align: center;
	width: 300px;
}
.item_list .list .btn:hover {
	background-color: #fff;
	color: #191919;
}
@media screen and (max-width: 1160px) {
	.item_list {
		margin-bottom: 14vw;
	}
	.item_list .headline_1 {
		margin-bottom: 4vw;
	}
	.item_list .tab {
		margin: 0 -.5vw 5vw;
	}
	.item_list .tab li {
		border-bottom: solid 3px #D8D8D8;
		font-size: 1.8vw;
		margin: 0 .5vw;
		padding-bottom: .5vw;
		width: calc(16.6666% - 1vw);
	}
	/** list **/
	.item_list .list {
		margin: 0 -1.5vw;
	}
	.item_list .list article {
		margin: 0 1.5vw 8vw;
		padding-bottom: 7vw;
		width: calc(25% - 3vw);
	}
	.item_list .list article .thumb {
		margin-bottom: 2vw;
	}
	.item_list .list article .cat {
		font-size: 1.1vw;
		margin-bottom: .5vw;
	}
	.item_list .list article .name {
		font-size: 1.3vw;
		letter-spacing: .1vw;
		margin-bottom: .5vw;
	}
	.item_list .list article .price del {
		margin-right: 1vw;
	}
	.item_list .list article .price .woocommerce-Price-currencySymbol {
		font-size: 1.1vw;
		margin-right: .2vw;
	}
	.item_list .list article .price .tax {
		font-size: 1.1vw;
		margin-left: .4vw;
	}
	.item_list .list article .button {
		background-size: 2.3vw;
		padding: 1vw;
		padding-left: 3vw;
		right: 2vw;
		width: 18vw;
	}
	.item_list .list .btn {
		font-size: 1.6vw;
		padding: 1vw 0 1.2vw;
		width: 26vw;
	}
}
@media screen and (max-width: 780px) {
	.item_list {
		margin-bottom: 160px;
	}
	.item_list .headline_1 {
		margin-bottom: 6vw;
	}
	.item_list .tab {
		margin: 0 -5px 50px;
	}
	.item_list .tab li {
		border-bottom: solid 2px #D8D8D8;
		font-size: 4vw;
		margin: 0 1vw 6vw;
		padding-bottom: 1vw;
		width: calc(33.3333% - 2vw);
	}
	/** list **/
	.item_list .list {
		margin: 0 -3vw;
	}
	.item_list .list article {
		margin: 0 3vw 14vw;
		padding-bottom: 16vw;
		position: relative;
		width: calc(50% - 6vw);
	}
	.item_list .list article .thumb {
		margin-bottom: 5vw;
	}
	.item_list .list article .cat {
		font-size: 3vw;
		margin-bottom: 1vw;
	}
	.item_list .list article .name {
		font-size: 3.4vw;
		letter-spacing: .2vw;
		margin-bottom: 1vw;
	}
	.item_list .list article .price del {
		margin-right: 2vw;
	}
	.item_list .list article .price {
		letter-spacing: .2vw;
	}
	.item_list .list article .price .woocommerce-Price-currencySymbol {
		font-size: 2.8vw;
		margin-right: .2vw;
	}
	.item_list .list article .price .tax {
		font-size: 2.8vw;
		margin-left: .4vw;
	}
	.item_list .list article .button {
		background-position: 5vw 50%;
		background-size: 5vw;
		padding: 2vw;
		padding-left: 9vw;
		left: 50%;
		right: auto;
		transform: translateX(-50%);
		width: 40vw;
	}
	.item_list .list .btn {
		font-size: 4vw;
		padding: 2vw 0;
		width: 58vw;
	}
}

/** -- save -- **/
.save {
	margin-bottom: 120px;
	padding-bottom: 150px;
	padding-top: 100px;
	position: relative;
	text-align: center;
	z-index: 1;
}
.save::before {
	background-color: #F8F8F4;
	content: '';
	display: block;
	position: absolute;
	left: 0;
	top: 0;
	height: calc(100% - 140px);
	width: 100%;
	z-index: -1;
}
.save::after {
	background: url("../img/top/save_bottom.png") no-repeat 50% 0 / 100%;
	content: '';
	display: block;
	position: absolute;
	bottom: 0;
	height: 150px;
	width: 100%;
}
.save .inner {
	padding-bottom: 100px;
	position: relative;
	width: 50%;
}
.save .inner .deco {
	position: absolute;
	right: -90%;
	top: -250px;
	width: 390px;
}
.save h2 {
	color: #C94C6E;
	font-size: 40px;
	margin-bottom: 20px;
}
.save p {
	font-size: 15px;
}
.save p.free {
	border-bottom: solid 2px #C94C6E;
	color: #C94C6E;
	display: table;
	font-size: 20px;
	letter-spacing: 4px;
	margin: 0 auto;
	margin-top: 20px;
}
.save .swiper-wrapper {
	transition-timing-function: linear;
}
@media screen and (max-width: 1160px) {
	.save {
		margin-bottom: 10vw;
		padding-bottom: 10vw;
		padding-top: 8vw;
	}
	.save::before {
		height: calc(100% - 9vw);
	}
	.save::after {
		background-size: auto 100%;
		height: 10vw;
	}
	.save .inner {
		padding-bottom: 8vw;
	}
	.save .inner .deco {
		top: -20vw;
		width: 32vw;
	}
	.save h2 {
		font-size: 3.6vw;
		margin-bottom: 2vw;
	}
	.save p {
		font-size: 1.3vw;
	}
	.save p.free {
		font-size: 1.8vw;
		letter-spacing: .4vw;
		margin-top: 2vw;
	}
}
@media screen and (max-width: 780px) {
	.save {
		margin-bottom: 12vw;
		padding-bottom: 18vw;
		padding-top: 12vw;
	}
	.save::before {
		height: calc(100% - 11vw);
	}
	.save::after {
		background-image: url("../img/top/save_bottom-sp.png");
		height: 12vw;
	}
	.save .inner {
		padding-bottom: 12vw;
		width: 100%;
	}
	.save .inner .deco {
		right: 8vw;
		top: -18vw;
		width: 43vw;
	}
	.save h2 {
		font-size: 6vw;
		margin-bottom: 5vw;
	}
	.save p {
		font-size: 15px;
	}
	.save p.free {
		font-size: 4.2vw;
		letter-spacing: .6vw;
		margin-top: 5vw;
	}
}

/** -- banner -- **/
.banner {
	margin-bottom: 120px;
}
.banner a {
	display: block;
}
@media screen and (max-width: 1160px) {
	
}
@media screen and (max-width: 780px) {
	.banner {
		margin-bottom: 10vw;
	}
}

/** -- page_link -- **/
.page_link {
	margin-bottom: 120px;
}
.page_link .inner {
	justify-content: space-between;
}
.page_link .box {
	position: relative;
	width: 530px;
}
.page_link .box a {
	position: absolute;
	height: 100%;
	width: 100%;
	z-index: 1;
}
.page_link .box p {
	color: #fff;
	font-size: 28px;
	left: 0;
	top: 50%;
	text-align: center;
	transform: translateY(-50%);
	position: absolute;
	width: 100%;
}
.page_link .box p span {
	display: block;
	margin-bottom: 10px;
	font-size: 16px;
}
@media screen and (max-width: 1160px) {
	.page_link {
		margin-bottom: 12vw;
	}
	.page_link .box {
		width: 45vw;
	}
	.page_link .box p {
		font-size: 2.6vw;
	}
	.page_link .box p span {
		margin-bottom: 1vw;
		font-size: 1.5vw;
	}
}
@media screen and (max-width: 780px) {
	.page_link {
		margin-bottom: 14vw;
	}
	.page_link .box {
		width: 100%;
	}
	.page_link .box + .box {
		margin-top: 8vw;
	}
	.page_link .box p {
		font-size: 5.6vw;
	}
	.page_link .box p span {
		margin-bottom: 2vw;
		font-size: 3.6vw;
	}
}

/** -- blog_list -- **/
.blog_list {
	margin-bottom: 120px;
}
.blog_list .headline_1 {
	margin-bottom: 50px;
	text-align: center;
}
.blog_list .list {
	margin: 0 -15px;
}
.blog_list article {
	border-radius: 4px;
	box-shadow: 0 0 5px 0 rgba(0, 0, 0, .2);
	margin: 0 15px;
	overflow: hidden;
	width: calc(33.3333% - 30px);
}
.blog_list article .text {
	padding: 25px 30px;
}
.blog_list article h3 {
	font-size: 16px;
	letter-spacing: 1px;
	margin-bottom: 20px;
}
.blog_list article .date {
	font-size: 12px;
	margin-bottom: 5px;
}
.blog_list article ul li {
	color: #7E7E7E;
	font-size: 12px;
	margin-right: 10px;
}
@media screen and (max-width: 1160px) {
	.blog_list {
		margin-bottom: 12vw;
	}
	.blog_list .headline_1 {
		margin-bottom: 4vw;
	}
	.blog_list .list {
		margin: 0 -1.2vw;
	}
	.blog_list article {
		margin: 0 1.2vw;
		width: calc(33.3333% - 2.4vw);
	}
	.blog_list article .text {
		padding: 2vw;
	}
	.blog_list article h3 {
		font-size: 1.4vw;
		letter-spacing: 0;
		margin-bottom: 2vw;
	}
	.blog_list article .date {
		font-size: 1.1vw;
		margin-bottom: .5vw;
	}
	.blog_list article ul li {
		font-size: 1vw;
		margin-right: .6vw;
	}
}
@media screen and (max-width: 780px) {
	.blog_list {
		margin-bottom: 12vw;
	}
	.blog_list .headline_1 {
		margin-bottom: 5vw;
	}
	.blog_list .list {
		margin: 0;
	}
	.blog_list article {
		border-radius: 4px;
		box-shadow: 0 0 5px 0 rgba(0, 0, 0, .2);
		margin: 0 0;
		width: 100%;
	}
	.blog_list article .text {
		padding: 25px 30px;
	}
	.blog_list article h3 {
		font-size: 16px;
		letter-spacing: 1px;
		margin-bottom: 20px;
	}
	.blog_list article .date {
		font-size: 12px;
		margin-bottom: 5px;
	}
	.blog_list article ul li {
		color: #7E7E7E;
		font-size: 12px;
		margin-right: 10px;
	}
}

/** -- faq -- **/
.faq {
	background: url("../img/common/faq_bg.jpg") no-repeat center / cover;
	padding: 60px 0;
}
.faq .sec_inner {
	background-color: #fff;
	padding: 50px 70px;
	width: 940px;
}
.faq .headline_1 {
	margin-bottom: 50px;
	text-align: center;
}
.faq dl {
	border-top: solid 1px #D3D3D3;
}
.faq dl:last-child {
	border-bottom: solid 1px #D3D3D3;
}
.faq dt,
.faq dd {
	font-size: 14px;
	padding: 25px 0;
	padding-left: 80px;
	position: relative;
}
.faq dt {
	background-color: #fff;
	cursor: pointer;
}
.faq dd {
	background-color: #F8F8F4;
	display: none;
}
.faq dt::before,
.faq dd::before {
	display: block;
	font-family: 'Manrope', sans-serif;
	font-size: 24px;
	position: absolute;
	left: 30px;
	top: 50%;
	transform: translateY(-50%);
}
.faq dt::before {
	content: 'Q.';
}
.faq dd::before {
	content: 'A.';
}
.faq dt::after {
	background: url("../img/common/icon_plus.svg") no-repeat center / 100%;
	content: '';
	display: block;
	position: absolute;
	right: 30px;
	top: 50%;
	transform: translateY(-50%);
	transition: ease .3s;
	height: 15px;
	width: 15px;
}
.faq dt.active::after {
	background: url("../img/common/icon_minus.svg") no-repeat center / 100%;
	transform: translateY(-50%) rotate(360deg);
}
@media screen and (max-width: 1160px) {
	.faq {
		padding: 6vw 0;
	}
	.faq .sec_inner {
		padding: 4vw;
		width: auto;
	}
	.faq .headline_1 {
		margin-bottom: 4vw;
	}
	.faq dt,
	.faq dd {
		font-size: 1.3vw;
		padding: 2.5vw 0;
		padding-left: 8vw;
	}
	.faq dt::before,
	.faq dd::before {
		font-size: 2.3vw;
		left: 4vw;
	}
	.faq dt::after {
		right: 3vw;
		height: 1.5vw;
		width: 1.5vw;
	}
}
@media screen and (max-width: 780px) {
	.faq {
		background: url("../img/common/faq_bg-sp.jpg") no-repeat center / cover;
		padding: 12vw 0;
	}
	.faq .sec_inner {
		background-color: #fff;
		padding: 8vw 4vw;
		width: auto;
	}
	.faq .headline_1 {
		margin-bottom: 6vw;
		text-align: center;
	}
	.faq dl {
		border-top: solid 1px #D3D3D3;
	}
	.faq dl:last-child {
		border-bottom: solid 1px #D3D3D3;
	}
	.faq dt,
	.faq dd {
		font-size: 3.2vw;
		padding: 3vw;
		padding-left: 10vw;
	}
	.faq dt::before,
	.faq dd::before {
		font-size: 5vw;
		left: 3vw;
	}
	.faq dt::after {
		right: 4vw;
		height: 3vw;
		width: 3vw;
	}
}

/** -------------------
	footer
------------------- **/
/** -- sns -- **/
footer .sns {
	padding: 60px 0 30px;
}
footer .sns .inner {
	justify-content: center;
}
footer .sns a {
	color: #AABC4A;
	font-size: 48px;
	margin: 0 15px;
}
/** -- bottom -- **/
footer .bottom {
	background-color: #D6DBBC;
	padding: 40px 60px 60px;
}
footer .bottom .inner {
	position: relative;
}
footer .bottom .copyright {
	font-size: 15px;
	letter-spacing: 0;
	position: absolute;
	bottom: 0;
	left: 0;
}
footer .bottom ul {
	justify-content: flex-end;
}
footer .bottom li {
	margin-left: 25px;
}
footer .bottom li a:hover {
	color: #AABC4A;
}
footer .bottom .menu_2 {
	margin-top: 20px;
}
footer .bottom .menu_2 li {
	font-size: 15px;
}
@media screen and (max-width: 1160px) {
	/** -- sns -- **/
	footer .sns {
		padding: 6vw 0 2vw;
	}
	footer .sns a {
		font-size: 4.2vw;
		margin: 0 1.5vw;
	}
	/** -- bottom -- **/
	footer .bottom {
		padding: 4vw 3vw 6vw;
	}
	footer .bottom .copyright {
		font-size: 1.3vw;
	}
	footer .bottom li {
		margin-left: 2.5vw;
	}
	footer .bottom .menu_2 {
		margin-top: 1.5vw;
	}
	footer .bottom .menu_2 li {
		font-size: 1.3vw;
	}
}
@media screen and (max-width: 780px) {
	/** -- sns -- **/
	footer .sns {
		padding: 10vw 0 4vw;
	}
	footer .sns a {
		font-size: 8vw;
		margin: 0 3vw;
	}
	/** -- bottom -- **/
	footer .bottom {
		padding: 8vw 6vw 10vw;
	}
	footer .bottom .copyright {
		font-size: 3.2vw;
		left: 50%;
	}
	footer .bottom ul {
		justify-content: flex-start;
	}
	footer .bottom li {
		margin-bottom: 2vw;
		margin-left: 0;
		width: 50%;
	}
	footer .bottom .menu_2 {
		margin-top: 6vw;
	}
	footer .bottom .menu_2 li {
		font-size: 3.2vw;
		margin-bottom: 0;
		margin-top: 1.5vw;
		width: 100%;
	}
}