@charset "utf-8";
@import url('https://use.fontawesome.com/releases/v7.2.0/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;
}
p{
	line-height: 1.8;
}

:root {
	--blue: #0756a3;
	--gradtop: #9ad6ed;
	--gradbottom: #f0f0f0;
	--orange: #ff6b3e;
	--icon: 'Font Awesome 7 Free';
	--campaign: #66382a;
	--serif: 'Noto Serif JP', serif;
	--yellow: #dbc41a;
	--pink: #e65668;
	--purple: #c02c7c;
	--brown: #835c25;
	--green: #5aaa4d;
	--red: #ca142d;
}

/* 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.2rem;
	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) center no-repeat;
	background-size: 100vw auto;
	position: absolute;
	bottom: 8rem;
	left: 0;
}*/
.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.4rem;
	font-weight: 600;
}

.lead {
	padding: 0 0;
}
.lead__trouble {
	background: url(img/bg_lead.png) center no-repeat;
	background-size: cover;
	padding: 6rem 0 0;
}
.lead__trouble__list {
	margin: 0 14vw 0 50%;
}
.lead__trouble__list li {
	font-size: 1.1rem;
}
.lead__trouble__list li::before {
	content: "・";
}
.lead__trouble__list li + li {
	margin-top: 2rem;
}
.lead__sum {
	background: rgba(255,255,255,0.4);
	margin: 6rem 14vw 0;
	padding: 2rem;
	border-radius: 2rem;
	position: relative;
}
.lead__sum p {
	margin: 0 calc(20% + 2rem) 0 0;
	font-size: 1.2rem;
}
.lead__sum strong {
	display: block;
	color: var(--red);
	font-size: 1.6rem;
	font-weight: 700;
}
.lead__sum__obj {
	width: 14.4vw;
	position: absolute;
	right: 2rem;
	bottom: 0;
}
.lead__outline {
	margin: 6rem 0;
	position: relative;
}
.lead__outline__col {
	width: 36%;
	margin: 0 auto;
	padding: 6rem 0;
}
.lead__outline__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.lead__outline__col h3 {
	padding-left: 1rem;
	border-left: var(--yellow) solid 2px;
}
.lead__outline__col p + h3 {
	margin-top: 4rem;
}
.lead__outline__image {
	width: 24%;
	position: absolute;
	overflow: hidden;
}
.lead__outline__image.top {
	left: 0;
	top: 0;
	border-radius: 0 1rem 1rem 0;
}
.lead__outline__image.bottom {
	right: 0;
	bottom: 0;
	border-radius: 1rem 0 0 1rem;
}

.introduce {
	padding: 6rem 0 12rem;
}
.introduce__leadtxt {
	margin: 0 14vw;
}
.introduce__wrap {
	position: relative;
}
.introduce__image {
	width: calc(50% + 3rem);
	position: absolute;
	top: 6rem;
	right: 0;
	bottom: -6rem;
}
.introduce__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 2rem 0 0 2rem;
	border: var(--yellow) solid 2px;
	border-right: none;
}
.introduce__point {
	background: var(--yellow);
	margin: 3rem 50% 0 0;
	padding: 5rem;
	border-radius: 0 2rem 2rem 0;
}
.introduce__point__title {
	text-align: center;
	padding-bottom: 1rem;
}
.introduce__point__title .common__midheading {
	font-size: 1.5rem;
}
.introduce__point__inner {
	gap: 4rem;
	position: relative;
}
.introduce__point__block {
	display: flex;
}
.introduce__point__block + .introduce__point__block {
	margin-top: 3rem;
}
.introduce__point__block h4 {
	width: 35%;
	color: #fff;
}
.introduce__point__block h4 span {
	background: var(--green);
	padding: 0.5rem 2rem;
	font-family: var(--serif);
	border-radius: 2rem;
}
.introduce__point__block + .introduce__point__block h4 span {
	background: #333;
}
.introduce__point__block ul {
	width: 65%;
}
.introduce__point__block ul li {
	padding: 0 0 0 1rem;
	line-height: 1.4;
}
.introduce__point__block ul li::before {
	content: "・";
	width: 1rem;
	margin: 0 0 0 -1rem;
}
.introduce__point__block ul li + li {
	margin-top: 1rem;
}
.introduce__point p {
	margin: 3rem 0 0;
}

.check {
	padding: 6rem 14vw;
}
.check__list {
	background: #fff;
	margin: 3rem 0 0;
	border: var(--yellow) solid 5px;
	border-radius: 2rem;
	overflow: hidden;
}
.check__list__title {
	background: var(--yellow);
	padding: 1rem 0;
	text-align: center;
}
.check__list__title .common__midheading,
.check__list__title .common__label {
	color: #fff;
}
.check__list__title .common__midheading {
	margin: 0;
}
.check__list__inner {
	padding: 3rem;
}
.check__list__list {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 2rem 1rem;
}
.check__list__list li {
	width: calc((100% - 2rem) / 3);
}
.check__list__list li label {
	display: flex;
	align-items: center;
}
.check__list__list li input {
	margin: 0 0.5rem 0 0;
}
.check__submit {
	margin: 3rem 0 0;
	padding: 3rem 0 0;
	border-top: #ddd solid 1px;
}
.check__submit button {
	display: block;
	background: var(--yellow);
	width: 50%;
	margin: 1rem auto 0;
	padding: 1rem 0;
	color: #fff;
	font-size: 1.4rem;
	text-decoration: none;
	text-align: center;
	border: var(--yellow) solid 1px;
	border-radius: 2rem;
	cursor: pointer;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	transition: all .3s ease-out;
}
.check__result {
}
.check__result__inner {
	display: flex;
	width: 100%;
	height: 100vh;
	padding: 6rem 14vw;
	gap: 2rem;
	position: absolute;
	top: 0;
}
.check__result__inner.orange {
	background: rgba(255,107,62,0.2);
}
.check__result__inner.green {
	background: rgba(90,170,77,0.2);
}
.check__result__inner.blue {
	background: rgba(7,86,163,0.12);
}
.check__result__image {
	width: 40%;
}
.check__result__image img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}
.check__result__col {
	width: calc(60% - 2rem);
}
.check__result__label {
	margin: 0 0 1rem;
	font-family: var(--serif);
	font-size: 1.1rem;
	letter-spacing: 0.2rem;
	line-height: 1.2;
	opacity: 0.4;
}
.check__result__label strong {
	margin: 0 0 0 0.5rem;
	font-size: 2.2rem;
}
.check__result__inner .common__heading {
	padding: 0 0 1rem;
	text-align: left;
	border-bottom: #000 solid 2px;
}
.check__result__inner.orange .common__heading {
	color: var(--orange);
	border-bottom-color: var(--orange);
}
.check__result__inner.green .common__heading {
	color: var(--green);
	border-bottom-color: var(--green);
}
.check__result__inner.blue .common__heading {
	color: var(--blue);
	border-bottom-color: var(--blue);
}
.check__result__inner p {
	font-size: 1.2rem;	
}
.check__caution {
	display: flex;
	align-items: center;
	margin: 4rem 0 0;
	gap: 2rem;
}
.check__caution i {
	color: var(--red);
	font-size: 10vw;
	text-align: center;
}
.check__caution .common__midheading {
	color: var(--red);
}

.knowledge {
	background: rgba(255,255,255,0.4);
	padding: 6rem 14vw 12rem;
	position: relative;
	z-index: 0;
}
.knowledge::before {
	content: "";
	background: url(img/ils_knowledge.png) no-repeat right 4vw bottom;
	background-size: 30vw auto;
	width: 100%;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: -1;
}
.knowledge__chart {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 2rem;
	margin: 3rem 0 0;
}
.knowledge__chart dl {
	background: -moz-linear-gradient(left, #5f3832, #f6c31f);
	background: linear-gradient(to right, #5f3832, #f6c31f);
	margin: 0 4rem 0 0;
	padding: 1px;
	color: var(--brown);
	position: relative;
}
.knowledge__chart dl dt {
	background: #fff;
	padding: 2rem 2rem 1rem;
	font-size: 1.1rem;
	font-weight: 700;
}
.knowledge__chart dl dd {
	background: #fff;
	padding: 0 2rem 2rem;
}
.knowledge__chart dl::after {
	content: "+";
	width: 2rem;
	height: 2rem;
	margin: auto;
	font-size: 2rem;
	text-align: center;
	position: absolute;
	top: 0;
	right: -4rem;
	bottom: 0;
}
.knowledge__chart dl:nth-of-type(2)::after {
	content: "→";
}
.knowledge__block {
	display: flex;
	gap: 2rem;
	margin: 3rem 0 0;
}
.bglayer {
	background: rgba(255,255,255,0.2);
	margin: 5rem -2rem 2rem;
	padding: 2rem;
	border-radius: 2rem;
}
.knowledge__block__image {
	width: 40%;
}
.knowledge__block__image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 1rem;
}
.knowledge__block__col {
	width: calc(60% - 2rem);
}
.knowledge__block__col.wide {
	width: 100%;
}
.knowledge__block__col .common__minheading {
	margin-top: 2rem;
}
.knowledge__block__list {
	counter-reset: number 0;
}
.knowledge__block__list li .common__minheading {
	display: flex;
	align-items: center;
}
.knowledge__block__list li .common__minheading::before {
	counter-increment: number 1;
	content: counter(number);
	width: 2.4rem;
	font-family: var(--serif);
	font-size: 2.4rem;
}
.knowledge__block__list li + li {
	margin-top: 2erm;
}
.knowledge__block__list li p {
	margin-left: 2.4rem;
}

/*===============================================
モーダルウィンドウ部分
===============================================*/
.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;
	position: absolute;
	z-index: 11;
	top: 0;
	right: 0;
}
.modal__close a {
	background: #fff;
	height: 40px;
	display: block;
	text-align: center;
}
.modal__close a i {
	line-height: 40px;
}

.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;
	-webkit-transition: all .3s ease-out;
	-moz-transition: all .3s ease-out;
	transition: all .3s ease-out;
}
.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__wrap {
	border: #000 solid 2px;
	border-top: none;
	margin: -4.2rem 0 0;
	padding: 4rem;
}
.items__wrap.orange {
	border-color: var(--orange)
}
.items__wrap.green {
	border-color: var(--green)
}
.items__wrap.blue {
	border-color: var(--blue)
}
.items__wrap + .items__heading {
	margin-top: 6rem;
}
.items__heading {
	display: flex;
	align-items: center;
	margin: 0;
	padding: 3rem 0;
	font-family: var(--serif);
	font-size: 2.4rem;
	font-weight: 400;
	letter-spacing: 0.1rem;
	line-height: 1;
	text-align: center;
}
.items__heading::before {
	content: "";
	display: block;
	height: 2px;
	margin-right: 8rem;
	flex-grow: 1;
}
.items__heading::after {
	content: "";
	display: block;
	height: 2px;
	margin-left: 8rem;
	flex-grow: 1;
}
.items__heading.orange {
	background: url(img/frame_01.png) no-repeat center;
	background-size: auto 100%;
	color: var(--orange);
}
.items__heading.orange::before,
.items__heading.orange::after {
	background: var(--orange);
}
.items__heading.green {
	background: url(img/frame_02.png) no-repeat center;
	background-size: auto 100%;
	color: var(--green);
}
.items__heading.green::before,
.items__heading.green::after {
	background: var(--green);
}
.items__heading.blue {
	background: url(img/frame_03.png) no-repeat center;
	background-size: auto 100%;
	color: var(--blue);
}
.items__heading.blue::before,
.items__heading.blue::after {
	background: var(--blue);
}
.items__subheading {
	margin: 4rem 0 2rem;
	font-family: var(--serif);
	font-size: 2.4rem;
	font-weight: 600;
	text-align: center;
}
.items__subheading small {
	display: block;
	margin: 0 0 1rem;
	font-size: 1.8rem;
	font-weight: 600;
}

.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.6rem;
	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;
	}

	.check__submit button:hover {
		background: #fff;
		color: var(--yellow);
	}

}
