@charset "UTF-8";



	
/* pagetitle-service
------------------------------  */
#pagetitle-service {
	padding-top: 8vw;
	padding-bottom: 3vw;
	overflow: hidden;
}
	#pagetitle-service h1 {
		font-size: 2.6vw;
		line-height: 1.3em;
		text-align: center;
	}

	#pagetitle-service .swiper-container {
		width: 100%;
		position: relative;
	}
		#pagetitle-service .swiper-container .swiper-slide .pht {
			padding: 0 2vw;
			opacity: 0.5;
			transition: 0.3s;
			-webkit-transition: 0.3s;
		}
		#pagetitle-service .swiper-container .swiper-slide.swiper-slide-active .pht {
			opacity: 1;
		}

		#pagetitle-service .swiper-container .swiper-slide .text {
			display: none;
			margin-top: 1vw;
			text-align: center;
			opacity: 0;
			transition: 0.3s;
			-webkit-transition: 0.3s;
		}
		#pagetitle-service .swiper-container .swiper-slide.swiper-slide-active .text {
			display: block;
			opacity: 1;
		}
			#pagetitle-service .swiper-container .swiper-slide .text h2 {
				font-size: 2.4vw;
				font-weight: 700;
				line-height: 1.3em;
				margin-bottom: 1vw;
			}

			.jp #pagetitle-service .swiper-container .swiper-slide .text p.txt-18 {
				text-align: left;
			}

			#pagetitle-service .swiper-container .swiper-slide .text a.link-txt {
				display: block;
				text-decoration: underline;
				margin-top: 0.5vw;
			}
			#pagetitle-service .swiper-container .swiper-slide .text a.link-txt:hover {
				text-decoration: none;
			}

		#pagetitle-service .swiper-container .swiper-button-prev {
			display: block;
			width: 25%;
			height: 3vw;
			aspect-ratio: 1 / 1;
			background: url("../img/common/btn_prev_red.svg") no-repeat right center / auto 100%;
			margin: 0;
			padding-top: 0.5vw;
			padding-right: 4vw;
			font-size: 1.2vw;
			color: #AB3535;
			line-height: 3vw;
			white-space: nowrap;
			text-align: right;
			position: absolute;
			top: auto;
			top: 34vw;
			left: 0;
			transition: 0.3s;
			-webkit-transition: 0.3s;
			z-index: 2;
		}
		#pagetitle-service .swiper-container .swiper-button-prev:before {
			content: "Previous";
			font-size: 1.0vw;
			line-height: 1;
			position: absolute;
			top: 0.4vw;
			right: 4vw;
		}
		.jp #pagetitle-service .swiper-container .swiper-button-prev:before {
			content: "戻る";
			top: 0.3vw;
		}

		#pagetitle-service .swiper-container .swiper-button-next {
			display: block;
			width: 25%;
			height: 3vw;
			aspect-ratio: 1 / 1;
			background: url("../img/common/btn_next_red.svg") no-repeat left center / auto 100%;
			margin: 0;
			padding-top: 0.5vw;
			padding-left: 4vw;
			font-size: 1.2vw;
			color: #AB3535;
			line-height: 3vw;
			white-space: nowrap;
			position: absolute;
			top: 34vw;
			right: 0;
			transition: 0.3s;
			-webkit-transition: 0.3s;
			z-index: 2;
		}
		#pagetitle-service .swiper-container .swiper-button-next:before {
			content: "Next";
			font-size: 1.0vw;
			line-height: 1;
			position: absolute;
			top: 0.4vw;
			left: 4vw;
		}
		.jp #pagetitle-service .swiper-container .swiper-button-next:before {
			content: "次へ";
			top: 0.3vw;
		}

		#pagetitle-service .swiper-container .swiper-button-next:after,
		#pagetitle-service .swiper-container .swiper-button-prev:after {
			display: none;
		}
		#pagetitle-service .swiper-container .swiper-button-prev:hover,
		#pagetitle-service .swiper-container .swiper-button-next:hover {
			opacity: 0.7;
		}


		#pagetitle-service .swiper-container .swiper-slide .text .list  {
			margin-top: 4vw;
		}
			#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox  {
				display: block;
				background: #fff;
				padding: 2vw;
				border-radius: 1.5vw;
				margin-bottom: 2vw;
				box-shadow: 0 0.5vw 1.5vw 0 rgba(0, 0, 0, 0.12);
			}
				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox .pht  {
					border-radius: 1vw;
					padding: 0;
				}

				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox h3  {
					margin-top: 1.2vw;
					margin-bottom: 0.5vw;
					line-height: 1.3em;
					text-align: left;
				}

				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox .txt-16  {
					text-align: left;
				}

				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox .txt-12  {
					text-align: left;
				}
				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox .remarks  {
					text-align: left;
					margin-bottom: 0.3vw;
				}

				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox .c-red  {
					text-align: left;
					text-decoration: underline;
				}
				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox:hover .c-red  {
					text-decoration: none;
				}
@media screen and (max-width: 767px) {
	#pagetitle-service {
		padding-top: 18vw;
		padding-bottom: 10vw;
	}
		#pagetitle-service h1 {
			font-size: 7.0vw;
		}

		#pagetitle-service .swiper-container .swiper-slide .pht {
			padding: 0 3vw;
		}

		#pagetitle-service .swiper-container .swiper-slide .text {
			display: none;
			margin-top: 3vw;
		}
		#pagetitle-service .swiper-container .swiper-slide.swiper-slide-active .text {
			display: block;
		}
			#pagetitle-service .swiper-container .swiper-slide .text h2 {
				font-size: 5.6vw;
				margin-bottom: 2vw;
			}
	
			#pagetitle-service .swiper-container .swiper-slide .text .txt-18 {
				text-align: left;
			}

		#pagetitle-service .swiper-container .swiper-button-prev {
			width: 6vw;
			height: 6vw;
			padding-top: 0;
			padding-right: 0;
			line-height: 1;
			top: 69vw;
			left: -3%;
			border-radius: 50%;
			overflow: hidden;
		}

		#pagetitle-service .swiper-container .swiper-button-next {
			width: 6vw;
			height: 6vw;
			padding-top: 0;
			padding-left: 0;
			line-height: 1;
			top: 69vw;
			right: -3%;
			border-radius: 50%;
			overflow: hidden;
		}
		#pagetitle-service .swiper-container .swiper-button-prev:before,
		#pagetitle-service .swiper-container .swiper-button-next:before {
			display: none;
		}


		#pagetitle-service .swiper-container .swiper-slide .text .list  {
			margin-top: 10vw;
		}
			#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox  {
				padding: 5.5vw;
				border-radius: 3vw;
				margin-bottom: 8vw;
				box-shadow: 0 1vw 3vw 0 rgba(0, 0, 0, 0.15);
			}
				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox .pht  {
					border-radius: 1vw;
					padding: 0;
				}

				#pagetitle-service .swiper-container .swiper-slide .text .list a.linkbox h3  {
					margin-top: 3vw;
					margin-bottom: 1vw;
				}
}



	
/* service
------------------------------  */
#service .search {
	margin-bottom: 3vw;
}
	#service .search .btn-list a {
		display: flex;
		justify-content: flex-start;
		align-items: center;
		width: 48%;
		height: 4vw;
		border-radius: 2vw;
		background: #fff url("../img/common/icon_plus_red.svg") no-repeat right 1vw center / 1.5vw;
		border: solid 1px #AB3535;
		margin-right: 4%;
		margin-bottom: 4%;
		padding: 0 1.5vw;
		font-weight: 700;
		line-height: 1;
		color: #AB3535;
	}
	#service .search .btn-list a:hover {
		background: #AB3535 url("../img/common/icon_plus_white.svg") no-repeat right 1vw center / 1.5vw;
		color: #fff;
	}
	#service .search .btn-list a:nth-child(2n),
	#service .search .btn-list a:nth-last-child(1) {
		margin-right: 0;
	}

	#service .search .filter {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
		margin-top: 0.5vw;
	}
		#service .search .filter .head {
			width: 15%;
			font-weight: 500;
			line-height: 1;
		}

		#service .search .filter .f-list {
			width: 85%;
			font-weight: 500;
		}
			#service .search .filter .f-list .f-btn {
				display: block;
				line-height: 1;
				background: url("../img/common/icon_check_black.svg") no-repeat right top 60% / 1vw;
				margin-right: 1vw;
				margin-bottom: 1vw;
				padding-right: 1.5vw;
			}
				#service .search .filter .f-list .f-btn span {
					display: inline-block;
					text-decoration: underline;
				}


	#service .results .h2-tit {
		margin-bottom: 0.2vw;
	}
	#service .results .number {
		text-align: center;
		line-height: 1;
		margin-bottom: 2.5vw;
	}

	#service .results .r-list {
		border-radius: 1vw;
		overflow: hidden;
		padding: 2vw 0;
		box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.35);
	}
		#service .results .r-list .scorll-area {
			height: 60vw;
			overflow-y: scroll;
			padding: 0 2vw;
		}
		#service .results .r-list .scorll-area::-webkit-scrollbar {
			width: 10px;
			height: 10px;
		}
		#service .results .r-list .scorll-area::-webkit-scrollbar-track {
			background: #fff;
		}
		#service .results .r-list .scorll-area::-webkit-scrollbar-thumb {
			background: #D1D1D1;
			border-radius: 5px;
		}
			#service .results .r-list .scorll-area .item {
				border-bottom: solid 1px #ddd;
				margin-bottom: 2vw;
				padding-bottom: 2vw;
			}
			#service .results .r-list .scorll-area .item:nth-last-child(1) {
				margin-bottom: 0;
			}
				#service .results .r-list .scorll-area .item a .pht {
					width: 48%;
					border-radius: 1.5vw;
				}
					#service .results .r-list .scorll-area .item a .pht img {
						width: 100%;
						height: 100%;
						object-fit: cover;
					}

				#service .results .r-list .scorll-area .item a .text {
					width: 48%;
				}
					#service .results .r-list .scorll-area .item a .text .cat {
						margin-bottom: 0.2vw;
					}

					#service .results .r-list .scorll-area .item a .text h3 {
						font-size: 1.6vw;
						line-height: 1.5em;
						margin-bottom: 0.4vw;
					}

					#service .results .r-list .scorll-area .item a .text .txt-14 {
						line-height: 1.5em;
						margin-bottom: 0.4vw;
					}

					#service .results .r-list .scorll-area .item a .text ul.icon li {
						width: 2vw;
						margin-top: 1vw;
						margin-right: 0.5vw;
					}
					#service .results .r-list .scorll-area .item a .text ul.icon li:nth-last-child(1) {
						margin-right: 0;
					}

	#service .results .r-list .more-btn {
		width: 100%;
		padding-top: 2vw;
	}
		#service .results .r-list .more-btn a {
			display: block;
			text-align: center;
			color: #9B9B9B;
			font-weight: 700;
			line-height: 1;
			padding: 0.5vw 0;
		}

	#service .results ul.icon-list {
		  display: flex;
		  justify-content: space-between;
		  align-items: center;
		margin-top: 3vw;
	}
		#service .results ul.icon-list li {
			display: flex;
			justify-content: flex-start;
			align-items: center;
			white-space: nowrap;
		}
			#service .results ul.icon-list li img {
				width: 1.6vw;
			}
			#service .results ul.icon-list li span {
				width: 86%;
				font-size: 1.1vw;
				padding-left: 0.5vw;
				line-height: 1.3em;
			}
@media screen and (max-width: 767px) {
	#service .search {
		margin-bottom: 8vw;
	}
		#service .search .btn-list a {
			height: 12vw;
			border-radius: 6vw;
			background: #fff url("../img/common/icon_plus_red.svg") no-repeat right 3vw center / 5vw;
			padding: 0 4vw;
			font-size: 3.4vw;
		}
		#service .search .btn-list a:hover {
			background: #AB3535 url("../img/common/icon_plus_white.svg") no-repeat right 3vw center / 5vw;
		}

		#service .search .filter {
			margin-top: 3vw;
		}
			#service .search .filter .head {
				width: 22%;
				padding-top: 0.7vw;
			}

			#service .search .filter .f-list {
				width: 78%;
			}
				#service .search .filter .f-list .f-btn {
					background: url("../img/common/icon_check_black.svg") no-repeat right top 60% / 4vw;
					margin-right: 3vw;
					margin-bottom: 3vw;
					font-size: 3.2vw;
					padding: 1vw 5.2vw 1vw 0;
				}


		#service .results .h2-tit {
			margin-bottom: 1vw;
		}
		#service .results .number {
			margin-bottom: 6.5vw;
		}

		#service .results .r-list {
			border-radius: 3vw;
			padding: 5vw 0;
		}
			#service .results .r-list .scorll-area {
				height: 150vw;
				padding: 0 5vw;
			}
			#service .results .r-list .scorll-area::-webkit-scrollbar {
				width: 6px;
				height: 6px;
			}
			#service .results .r-list .scorll-area::-webkit-scrollbar-thumb {
				border-radius: 3px;
			}
				#service .results .r-list .scorll-area .item {
					margin-bottom: 6vw;
					padding-bottom: 6vw;
				}
					#service .results .r-list .scorll-area .item a .pht {
						height: 100%;
						aspect-ratio: 1 / 1;
					}
						#service .results .r-list .scorll-area .item a .pht img {
							width: 100%;
							height: 100%;
							object-fit: cover;
						}

					#service .results .r-list .scorll-area .item a .text .cat {
						font-size: 3.0vw;
						margin-bottom: 0.2vw;
					}

					#service .results .r-list .scorll-area .item a .text h3 {
						font-size: 4.0vw;
						line-height: 1.3em;
						margin-bottom: 2vw;
					}

					#service .results .r-list .scorll-area .item a .text .txt-18 {
						font-size: 3.6vw;
					}

					#service .results .r-list .scorll-area .item a .text .info {
						font-size: 2.8vw;
						line-height: 1.5em;
					}

					#service .results .r-list .scorll-area .item a .text ul.icon li {
						width: 6vw;
						margin-top: 2vw;
						margin-right: 1vw;
					}

		#service .results .r-list .more-btn {
			padding-top: 6vw;
		}


	#service .results ul.icon-list {
		margin-top: 10vw;
	}
		#service .results ul.icon-list li img {
			width: 4.5vw;
		}
		#service .results ul.icon-list li span {
			width: 80%;
			font-size: 2.1vw;
			padding-left: 1vw;
		}
}



	
/* animatedModal
------------------------------  */
.animatedModal {
	background: rgba(0,0,0,0.5) !important;
}
	.animatedModal .close {
		width: 50px;
		position: fixed;
		top: 30px;
		left: 0;
		cursor: pointer;
		margin-left: -webkit-calc(100% - 80px);
		margin-left: calc(100% - 80px);
		transition: all 0.2s;
	}
	.animatedModal .close:hover {
		transform: rotate(90deg);
	}

	.animatedModal .modal-content {
		display: flex;
		justify-content: center;
		align-items: center;
		width: 100%;
		height: 100vh;
	}
		.animatedModal .modal-content .cont {
			width: 30vw;
			background: #fff;
			padding: 3vw 4vw;
			max-height: 80vh;
			overflow-y: scroll;
		}
		.animatedModal .modal-content .cont::-webkit-scrollbar {
			width: 4px;
			height: 4px;
		}
		.animatedModal .modal-content .cont::-webkit-scrollbar-track {
			background: #fff;
		}
		.animatedModal .modal-content .cont::-webkit-scrollbar-thumb {
			background: #D1D1D1;
			border-radius: 1.5px;
		}
			.animatedModal .modal-content .cont h2 {
				font-size: 1.8vw;
				font-weight: 700;
				line-height: 1;
				margin-bottom: 1.5vw;
			}

			.animatedModal .modal-content .cont h3 {
				font-size: 1.3vw;
				font-weight: 700;
				line-height: 1;
				margin-top: 2vw;
				margin-bottom: 0.5vw;
			}

			.animatedModal .modal-content .cont ul.check-list li {
				border-top: solid 1px #ddd;
				font-size: 1.15vw;
				font-weight: 500;
			}
			.animatedModal .modal-content .cont ul.check-list li:nth-last-child(1) {
				border-bottom: solid 1px #ddd;
			}
				.animatedModal .modal-content .cont ul.check-list li label {
					width: 100%;
					display: flex;
					align-items: center;
					position: relative;
					cursor: pointer;
					padding: 0.5vw 0.5vw 0.5vw 1.5vw;
				}

				.animatedModal .modal-content .cont ul.check-list li label:after {
					content: "";
					width: 1vw;
					height: 1vw;
					background: url("../img/common/icon_plus_gray.svg") no-repeat center / 100%;
					position: absolute;
					top: 50%;
					left: 0;
					margin-top: -0.44vw;
				}
				.animatedModal .modal-content .cont ul.check-list li label:has(:checked):after {
					content: "";
					background: url("../img/common/icon_check_red.svg") no-repeat center / 100%;
				}

				.animatedModal .modal-content .cont ul.check-list li input {
					display: none;
				}

			.animatedModal .modal-content .cont .search-btn {
				width: 60%;
				margin: 2.5vw auto 0 auto;
			}
				.animatedModal .modal-content .cont .search-btn button {
					width: 100%;
					background: #222222;
					border: none;
					border-radius: 1.8vw;
					height: 3.6vw;
					font-size: 1.3vw;
					font-weight: 700;
					color: #fff;
					line-height: 1;
					cursor: pointer;
					transition: 0.3s;
					-webkit-transition: 0.3s;
				}
				.animatedModal .modal-content .cont .search-btn button:hover {
					background: #AB3535;
				}
@media screen and (max-width: 767px) {
	.animatedModal .close {
		width: 40px;
		top: 20px;
		margin-left: -webkit-calc(100% - 60px);
		margin-left: calc(100% - 60px);
	}

	.animatedModal .modal-content {
		height: 100dvh;
	}
		.animatedModal .modal-content .cont {
			width: 80%;
			padding: 8vw 8vw;
			max-height: 70vh;
		}
			.animatedModal .modal-content .cont h2 {
				font-size: 4.8vw;
				margin-bottom: 5vw;
			}

			.animatedModal .modal-content .cont h3 {
				font-size: 4.1vw;
				margin-top: 6vw;
				margin-bottom: 2vw;
			}

			.animatedModal .modal-content .cont ul.check-list li {
				font-size: 4.0vw;
			}
				.animatedModal .modal-content .cont ul.check-list li label {
					padding: 2vw 2vw 2vw 6vw;
				}

				.animatedModal .modal-content .cont ul.check-list li label:after {
					width: 4vw;
					height: 4vw;
					margin-top: -2.2vw;
				}

			.animatedModal .modal-content .cont .search-btn {
				width: 60%;
				margin: 6vw auto 0 auto;
			}
				.animatedModal .modal-content .cont .search-btn button {
					border-radius: 5vw;
					height: 10vw;
					font-size: 3.8vw;
				}
}



	
/* tax-free
------------------------------  */
#tax-free {
	width: 100%;
	background: url("../img/common/bg_slash.svg") no-repeat center bottom / cover;
	position: relative;
}
#tax-free:before {
	content: "";
	width: 100%;
	height: 25%;
	background: #fff;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
}
	#tax-free .box {
		border-radius: 1.5vw;
		background: url("../img/shopping/tax-free_bg.webp") no-repeat center / cover;
		color: #fff;
		text-align: center;
		padding: 5vw 2vw 3vw 2vw;
		position: relative;
		z-index: 2;
	}
		#tax-free .box h2 {
			font-size: 4.0vw;
			font-weight: 700;
			line-height: 1.3em;
		}

		#tax-free .box .txt-18 {
			margin-bottom: 3vw;
		}
@media screen and (max-width: 767px) {
	#tax-free .box {
		border-radius: 3vw;
		padding: 10vw 0 3vw 0;
	}
		#tax-free .box h2 {
			font-size: 9.0vw;
		}

		#tax-free .box .txt-18 {
			font-size: 3.6vw;
			margin-bottom: 6vw;
		}
}



	
/* gift
------------------------------  */
#gift .area .pht {
	width: 65%;
	border-radius: 1.5vw 0 0 1.5vw;
	overflow: hidden;
}

#gift .area .text {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 35%;
	border-radius: 0 1.5vw 1.5vw 0;
	overflow: hidden;
	background: #222;
	color: #fff;
	text-align: center;
}
	#gift .area .text h2 {
		font-size: 1.6vw;
		line-height: 1.3em;
		margin-bottom: 2.5vw;
	}

	#gift .area .text p {
		margin-bottom: 3.5vw;
	}
@media screen and (max-width: 767px) {
	#gift .area {
		border-top: solid 1px #ddd;
		border-bottom: solid 1px #ddd;
		padding: 5vw 0;
	}
		#gift .area .pht {
			width: 45%;
			border-radius: 3vw;
		}
			#gift .area .pht img {
				width: 100%;
				height: 100%;
				object-fit: cover;
			}

		#gift .area .text {
			display: block;
			width: 50%;
			border-radius: 0;
			background: #fff;
			color: #222222;
			text-align: left;
		}
			#gift .area .text h2 {
				font-size: 2.8vw;
				color: #AB3535;
				margin-bottom: 1.5vw;
			}

			#gift .area .text p {
				font-size: 3.4vw;
				font-weight: 700;
				line-height: 1.2em;
				letter-spacing: 0;
				margin-bottom: 5vw;
			}

			#gift .area .text .btn {
				width: 28vw;
				margin: 0;
			}
				#gift .area .text .btn a {
					font-size: 3.2vw;
					height: 10vw;
					line-height: 10vw;
				}
}








