@charset "utf-8";
@import url('https://use.fontawesome.com/releases/v6.5.1/css/all.css');
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Klee+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;500;600;700;800&display=swap');
* {
	margin:0;
	padding:0;
	list-style:none;
	font-weight:normal;
	box-sizing: border-box;
}
img {
	vertical-align: top;
	max-width: 100%;
	height: auto;
}
a {
	text-decoration: none;
}
a img {
	border:none;
}

:root {
	--blue: #657aa3;
	--gradtop: #9ad6ed;
	--gradbottom: #f0f0f0;
	--orange: #ed6e34;
	--icon: 'Font Awesome 5 Free';
	--campaign: #c02c7c;
	--serif: 'Noto Serif JP', serif;
	--yellow: #f6d34d;
	--pink: #e65668;
	--purple: #c02c7c;
}

/* COMMON */
body {
	background: url(img/bg_body.jpg) no-repeat center fixed;
	background-size: cover;
}
.icon-times:before {
    font-family: "Font Awesome 5 Free";
    content: "\f00d";
    font-weight: 900;
    margin: 0 0.5rem 0 0;
}

html{
	font-size: 16px;
}
body{
	font-family: arial, 'Noto Sans JP', sans-serif;
	line-height: 1;
	position: relative;
	z-index: 0;
}
.common__center {
	text-align: center;
}
.common__label {
	margin: 0 0 1rem;
	/*color: var(--blue);*/
	font-family: var(--serif);
	font-size: 1.1rem;
	letter-spacing: 0.2rem;
	text-align: center;
	line-height: 1.2;
	opacity: 0.4;
}
.common__heading {
	margin: 0 0 3rem;
	/*color: var(--blue);*/
	font-family: var(--serif);
	font-size: 3.0rem;
	font-weight: 400;
	letter-spacing: 0.1rem;
	line-height: 1.5;
	text-align: center;
}
.common__heading small {
	display: block;
	font-size: 2rem;
	font-weight: 400;
}
.common__heading small strong {
	font-size: 2.4rem;
}
.common__heading * {
	font-weight: 600;
}
.common__midheading {
	margin: 0 0 2rem;
	font-family: var(--serif);
	font-size: 1.6rem;
	font-weight: 600;
	letter-spacing: 0.1rem;
	line-height: 1.5;
}
.common__midheading.margin {
	margin-top: 3rem;
}
.common__midheading small {
	display: block;
	font-size: 1.4rem;
	font-weight: bold;
}
.common__minheading {
	margin: 0 0 1rem;
	font-size: 1.4rem;
	font-weight: 600;
	letter-spacing: 0.1rem;
}
.common__minheading small {
	display: block;
	font-size: 0.8rem;
	font-weight: bold;
}
.common__insert {
	height: calc(100vh + 18rem);
}
.common__insert img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: 50% 100%;
}

.title {
	display: flex;
	flex-direction: column;
	/*background: url(img/bg_title.jpg) 25% 25% no-repeat;
	background-size: cover;*/
	height: 100vh;
	position: relative;
	overflow: hidden;
}
.title::before {
	content: "";
	background: url(img/bg_title.jpg) bottom -85vw center no-repeat;
	background-size: 100vw auto;
	width: 300vw;
	height: 300vw;
	border-radius: 50%;
	position: absolute;
	bottom: 8rem;
	left: -100vw;
}
.title__heading {
	margin: auto 14vw 6rem;
	color: #fff;
	font-family: var(--serif);
	letter-spacing: 2px;
	line-height: 1.2;
	text-shadow: 0 0 1rem #000;
	position: relative;
}
.title__heading small {
	display: block;
	margin: 0 0 1rem;
	font-size: 2.4rem;
	font-weight: 600;
	position: relative;
	z-index: 0;
}
.title__heading h1 {
	font-size: 3.8rem;
	font-weight: 600;
}
.introduce {
	/*background: url(img/bg_introduce.png) left 50vw top 6rem no-repeat;
	background-size: auto calc(100% - 6rem);*/
	padding: 6rem 14vw;
}
.introduce__label {
	display: inline-block;
	background: #fff;
	margin: 0 0 1rem;
	padding: 0.5rem 2rem;
	font-size: 1.6rem;
	font-weight: 400;
	border-radius: 2rem;
	opacity: 1;
}
.introduce__wrap {
	display: flex;
	align-items: center;
	gap: 2rem;
	background: rgba(255,255,255,0.2);
	margin: 2rem 0 0 0;
	padding: 3rem;
	border-radius: 2rem;
}
.introduce__image {
	width: calc(40% - 2rem);
}
.introduce__comment {
	width: 60%;
	font-size: 1.2rem;
	line-height: 1.8;
}
.check {
	background: #fff;
	margin: 6rem 0 0;
	border: var(--pink) solid 5px;
	border-radius: 2rem;
	overflow: hidden;
}
.check__title {
	background: var(--pink);
	padding: 1rem 0;
}
.check .common__heading,
.check .common__label {
	color: #fff;
}
.check .common__heading {
	margin: 0;
}
.check__list {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem 0;
	margin: 3rem 3rem 0;
}
.check__list li {
	display: flex;
	align-items: center;
	gap: 0 0.5rem;
	width: 50%;
	font-size: 1.2rem;
	font-weight: 700;
}
.check__list li::before {
	content: "";
	background: #fff;
	width: 1rem;
	height: 1rem;
	border: #856744 solid 1px;
	border-radius: 5px;
}
.check__list li span {
	width: calc(100% - 1.5rem);
}
.check p {
	margin: 3rem;
	line-height: 1.8;
}
.prohibit {
	background: rgba(255, 255, 255, 0.2);
	padding: 6rem 14vw;
}
.prohibit p {
	line-height: 1.8;
}
.prohibit__inner {
	display: flex;
	margin: 3rem 0 0;
	gap: 0 2rem;
	position: relative;
}
.prohibit__col {
	width: calc(60% - 2rem);
	padding: 2rem 0;
}
.prohibit__obj {
	width: 16%;
	position: absolute;
	right: -2rem;
	bottom: -1rem;
}
.prohibit__image {
	width: 40%;
}
.prohibit__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 2rem;
	border: #fff solid 2px;
}
.prohibit p + .common__midheading {
	margin-top: 2rem;
}
.prohibit .common__midheading::before {
	content: "\f14a";
	display: inline-block;
	margin: 0 0.5rem 0 0;
	color: #6bb82d;
	font-family: var(--icon);
	font-weight: 400;
}
.difference {
	/*background:url(img/img_difference.png) no-repeat;
	background-size: 100% auto;*/
	margin: -18rem 0 0;
	padding: 0 14vw 6rem;
}
.difference .common__heading {
	color: #fff;
	text-shadow: 0 0 1rem #000;
}
.difference p {
	color: #fff;
	text-shadow: 0 0 1rem #000;
	line-height: 1.8;
}
.difference__comparison {
	background: url(img/ils_difference.png) no-repeat right 0;
	background-size: 30% auto;
	padding: 6rem 0 0;
}
.difference__comparison .common__heading {
	text-align: left;
}
.difference__table {
	border-spacing: 5px;
	margin: 0 -4vw;
}
.difference__table th {
	background: #fff;
	padding: 1rem;
	font-size: 1.1rem;
	text-align: left;
}
.difference__table td {
	background: #fff;
	width: 40%;
	padding: 1rem;
	vertical-align: top;
}
.difference__table td:nth-of-type(1) {
	width: 20%;
}
.difference__table td ul li {
	padding: 0 0 0 1rem;
	line-height: 1.25;
}
.difference__table td ul li::before {
	content: "・";
	display: inline-block;
	width: 1rem;
	margin: 0 0 0 -1rem;
}
.difference__table td ul li + li {
	margin-top: 0.5rem;
}
.difference__table td dl dt {
	font-size: 1.1rem;
	font-weight: bold;
}
.difference__table td dl dd {
	margin: 0.5rem 0 0 1rem;
	line-height: 1.25;
}
.difference__table td dl dd + dt {
	margin-top: 1rem;
}

.method {
	background: rgba(255, 255, 255, 0.2);
	padding: 6rem 14vw 12rem;
}
.method p {
	line-height: 1.8;
}
.method__list {
	display: flex;
	margin: 3rem -4vw 0;
	padding: 2rem 0 0;
	gap: 2rem;
	position: relative;
	z-index: 0;
}
.method__list::before {
	content: "";
	background: var(--pink);
	height: 13.5rem;
	position: absolute;
	z-index: -1;
	top: 0;
	right: -10vw;
	left: -10vw;
}
.method__list li {
	width: calc((100% - 4rem) / 3);
}
.method__list__label {
	margin: 0 0 1rem;
	color: #fff;
	font-size: 2rem;
	text-align: center;
}
.method__list li .common__minheading {
	color: #fff;
	font-family: var(--serif);
	line-height: 1.25;
	text-align: center;
}
.method__list__inner {
	background: #fff;
	padding: 2rem;
	position: relative;
}
.method__list__inner p {
	margin: 1rem 0 0;
	line-height: 1.8;
}
.method__list__obj {
	width: 6vw;
	height: 6vw;
	border-radius: 50%;
	border: #e3d288 solid 2px;
	position: absolute;
	top: -2vw;
	right: -2vw;
	overflow: hidden;
}
.method__list__obj a {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: #000;
	height: 6vw;
	padding: 1rem;
	color: #fff;
	font-size: 0.8rem;
	line-height: 1.2;
	text-align: center;
}
.method__list__obj a::after {
	content: "\f0a9";
	font-family: var(--icon);
	font-weight: 900;
	margin: 0.5rem 0 0;
}
.method__list__obj img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.method__select {
	margin: 6rem 0 0;
}
.method__select .common__midheading {
	background: linear-gradient(90deg, transparent, #fff, transparent);
	padding: 1rem;
}
.method__select__inner {
	display: flex;
	align-items: center;
	gap: 0 2rem;
	margin: -5.6rem 0 0;
}
.method__select__image {
	width: 30%;
	order: 2;
}
.method__select__list {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 2rem 1rem;
	width: calc(70% - 2rem);
	color: #fff;
	text-shadow: 0 0 1rem #000;
}
.method__select__list dt {
	width: 50%;
	line-height: 1.8;
}
.method__select__list dd {
	display: flex;
	align-items: center;
	width: calc(50% - 1rem);
	gap: 0 1rem;
}
.method__select__list dd::before {
	content: "";
	background: #fff;
	width: 50%;
	height: 2px;
}
.method__result {
	background: #fff;
	margin: 6rem 0 0;
	border: var(--pink) solid 5px;
	border-radius: 2rem;
	overflow: hidden;
}
.result__title {
	background: var(--pink);
	padding: 1rem 0;
	text-align: center;
}
.result__title .common__midheading,
.result__title .common__label {
	color: #fff;
}
.result__title .common__midheading {
	margin: 0;
}
.method__result__inner {
	padding: 3rem;
}
.method__result__list {
	display: flex;
	gap: 0 2rem;
	margin: 3rem 3rem 0;
}
.ba-container {
	position: relative;
	width: 100%;
	/*height: 600px;*/
	margin: 0 auto 1rem;
	overflow: hidden;
	user-select: none;
}
.ba-container figure {
	margin: 0;
}
.ba-container figcaption {
	position: absolute;
	right: 0.5rem;
	bottom: 0.5rem;
	color: #fff;
}
.ba-container img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.ba-overlay {
	position: absolute;
	width: 50%;
	height: 100%;
	overflow: hidden;
	top: 0;
	left: 0;
}
.ba-slider {
	position: absolute;
	top: 0;
	left: 50%;
	width: 2px;
	height: 100%;
	background: #fff;
	/*cursor: ew-resize;*/
	z-index: 10;
	transform: translateX(-50%);
}
.ba-slider::before {
	content: "\f337";
	background: #fff;
	width: 4rem;
	height: 4rem;
	margin: auto;
	font-family: var(--icon);
	font-size: 2rem;
	font-weight: 900;
	text-align: center;
	line-height: 4rem;
	border-radius: 50%;
	position: absolute;
	top: 0;
	bottom: 0;
	left: calc(-2rem + 1px);
	cursor: pointer;
}

/*===============================================
モーダルウィンドウ部分
===============================================*/
.modal {
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	position: fixed;
	width: 100vw;
	height: 100vh;
	top: 0;
	right: 0;
	z-index: 100;
	display: none;
}
.modal__close {
	width: 40px;
	margin-left: auto;
}
.modal__close a {
	background: #fff;
	height: 40px;
	display: block;
	text-align: center;
}
.modal__close a i {
	line-height: 40px;
}
.modal__inner {
	background: rgba(255, 255, 255, 0.8);
	margin: 0 14vw;
	padding: 3rem;
	/*opacity: 0;*/
}
.modal .common__label {
	line-height: 1;
}
.modal .common__midheading {
	line-height: 1;
	text-align: center;
}
.modal__wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 0 2rem;
}
.modal__wrap figure {
	height: calc(100vh - 80px - 6rem - 2.1rem - 3.6rem - 0rem);
	margin: 0;
}
.modal__wrap figure img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

.btn__toitems {
	display: none;
}
.btn__toitems a {
	display: block;
	background: #000203;
	width: 50vw;
	margin: 0 auto;
	padding: 2rem 0;
	color: #fff;
	font-size: 1.6rem;
	text-decoration: none;
	text-align: center;
	border: #000203 solid 1px;
	border-radius: 3rem;
	position: fixed;
	right: 0;
	bottom: 1rem;
	left: 0;
	z-index: 99;
}
.btn__toitems a::after {
	content: "\f0a9";
	font-family: var(--icon);
	font-weight: 900;
	position: absolute;
	right: 3rem;
}

.items {
	padding: 6rem 10vw;
}
.items__data {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--campaign);
	width: 100%;
	padding: 0.5rem 0;
	position: fixed;
	top: 0;
	left: 0;
	color: #fff;
	z-index: 99;
}
.items__data dt {
	padding: 0 1rem 0 0;
	border-right: #fff solid 1px;
}
.items__data dd:not(.items__data__label) {
	margin: 0 1rem;
}
.items__data__label {
	background: #fff;
	padding: 0.5rem 1rem;
	color: var(--campaign);
	font-weight: bold;
	text-align: center;
	border-radius: 3rem;
}
.items__heading {
	background: linear-gradient(90deg, transparent, #db780c, transparent);
	margin: 0 0 3rem;
	padding: 1rem;
    color: #fff;
	font-family: var(--serif);
	font-size: 2.4rem;
	font-weight: 400;
	letter-spacing: 0.1rem;
	line-height: 1.5;
	text-align: center;
	border-radius: 1rem;
}
.items__heading:nth-of-type(2) {
	background: linear-gradient(90deg, transparent, #a45c8e, transparent);
}
.items__heading:nth-of-type(3) {
	background: linear-gradient(90deg, transparent, #cec7c7, transparent);
	color: #1a1a1a;
}
.items__heading:nth-of-type(4) {
	background: linear-gradient(90deg, transparent, #92a8ce, transparent);
}
.itemList + .items__heading {
	margin-top: 6rem;
}
.itemList {
	margin: 3rem auto 0;
}
.itemList > li {
	margin: 0 auto;
}
.itemList > li:nth-of-type(n+2) {
	margin-top: 3rem;
	padding-top: 3rem;
	border-top: var(--campaign) solid 1px;
}
.itemList__inner{
	display: flex;
	align-items: center;
}
.itemList__itemImg {
	background: #fff;
	width: 40%;
	height: 35vw;
	margin: 0 0 0 auto;
	border-radius: 1rem;
	overflow: hidden;
}
.itemList__itemImg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.itemList__col {
	width: 60%;
	padding: 3rem;
}
.itemList__label {
	display: inline-block;
	background: var(--blue);
	margin: 0 0 1rem;
	padding: 0.5rem 2rem;
	border-radius: 2rem;
	color: #fff;
}
.itemList__title {
	font-size: 1.8rem;
	font-weight: 700;
}
.itemList__point {
	margin: 2rem 0;
	padding: 0 0 0 25%;
	position: relative;
}
.itemList__point dt {
	display: inline-block;
	background: #c81939;
	margin: 0 0 1rem;
	padding: 0.5rem 2rem;
	color: #fff;
	position: absolute;
	top: 0;
	left: 0;
	clip-path: polygon(0 0, 90% 0, 100% 50%, 90% 100%, 0 100%, 10% 50%);
}
.itemList__point dd {
	padding: 0.5rem 0 0.5rem 1.5rem;
}
.itemList__point dd::before {
	content: "・";
	display: inline-block;
	width: 1.5rem;
	margin: 0 0 0 -1.5rem;
}

.itemList__comment {
	margin: 2rem 0;
	line-height: 1.8;
}
.itemList__size {
	margin: 0 0 1rem;
}
.itemList__price {
	display: flex;
	align-items: flex-end;
	font-size: 1.2rem;
	line-height: 1.0;
}
.itemList__price strong {
	margin: 0 0.5rem 0 1rem;
	color: #e60012;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1.0;
}
.itemList__submit {
	max-width: 320px;
	margin: 3rem 0 0;
}
.itemList__submit a {
	display: block;
	background: #000203;
	padding: 1rem 0;
	color: #fff;
	font-size: 1.4rem;
	text-decoration: none;
	text-align: center;
	border-radius: 3rem;
	position: relative;
}
.itemList__submit a::after {
	content: "\f0a9";
	font-family: var(--icon);
	font-weight: 900;
	position: absolute;
	right: 1rem;
	z-index: 99;
}

@media screen and (min-width: 981px){
	
	.sp__only {
		display: none;
	}
	.itemList__submit a:hover,
	.btn__toitems a:hover {
		background: #fff;
		color: #000203;
	}

}
