@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');
* {
	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: #64acd4;
	--green: #129b84;
	--purple: #884a99;
	--brown: #856744;
	--orange: #ed6e34;
	--icon: 'Font Awesome 6 Free';
	--tegaki: 'Klee One', cursive;
	--tegaki02: 'Klee One', cursive;
	--campaign: #bd6c1b;
}


/* COMMON */
body {
}
.icon-times:before {
    font-family: "Font Awesome 5 Free";
    content: "\f00d";
    font-weight: 900;
    margin: 0 0.5rem 0 0;
}
:root {
	--red: #d9434b;
	--green: #4ab242;
	--orange: #ea5514;
	--blue: #1d78b7;
	--pink: #d04658;
}

html{
	font-size: 16px;
}
body{
	font-family: arial, 'Noto Sans JP', sans-serif;
	line-height: 1.5;
	position: relative;
	z-index: 0;
}

.common__center {
	text-align: center;
}
.common__heading {
	margin: 0 0 4rem;
	font-family: var(--tegaki);
	font-size: 3.0rem;
	font-weight: bold;
	letter-spacing: 0.1rem;
	position: relative;
	z-index: 0;
}
.common__heading small {
	display: block;
	font-size: 2rem;
	font-weight: bold;
}
.common__heading * {
	font-weight: bold;
}
.common__midheading {
	margin: 0 0 1rem;
	font-family: var(--tegaki02);
	font-size: 1.6rem;
	font-weight: bold;
	letter-spacing: 0.1rem;
}
.common__midheading.margin {
	margin-top: 4rem;
}
.common__midheading small {
	display: block;
	font-size: 1.4rem;
	font-weight: bold;
}
.common__minheading {
	margin: 0 0 0.5rem;
	font-size: 1.2rem;
	font-weight: bold;
	letter-spacing: 0.1rem;
}
.common__minheading small {
	display: block;
	font-size: 0.8rem;
	font-weight: bold;
}
.common__insert {
	height: 60vh;
}
.common__insert img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.title {
	display: flex;
	align-items: center;
	background: url(img/bg_title.jpg) bottom no-repeat;
	background-size: 100% auto;
	height: 100vh;
}
.title__inner {
	width: 36%;
	margin: 0 14vw;
}
.title__heading {
	font-family: var(--tegaki02);
	letter-spacing: 2px;
	line-height: 1.2;
}
.title__heading small {
	display: block;
	margin: 0 0 1rem;
	font-size: 2rem;
	font-weight: bold;
}
.title__heading h1 {
	font-size: 3.8rem;
	font-weight: bold;
}
.title__comment {
	margin: 2rem 0 0;
	font-size: 1.2rem;
	font-weight: bold;
	line-height: 1.8;
}

.introduce {
	position: relative;
}
.introduce::before {
	content: "";
	width: 14vw;
	background: url(img/obj_page01.png) no-repeat;
	background-size: 100% auto;
	position: absolute;
	top: -215px;
	bottom: 0;
	left: 0;
	z-index: -1;
}
.introduce__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	background: #f1e9e2;
	padding: 4rem 14vw;
}
.introduce__col {
	width: 48%;
}
.introduce__col h2 {
	color: var(--orange);
}
.introduce__image {
	width: 48%;
}
.introduce__wrap {
	display: flex;
	background: linear-gradient(135deg, #fff, #f0e9e2);
}
.introduce__check {
	width: 50%;
	padding: 4rem 2rem 6rem 14vw;
}
.introduce__check h3 {
	color: var(--orange);
}
.introduce__check__point {
	margin: 2rem 0 0;
}
.introduce__check__point .common__minheading {
	padding: 0 0 0 2rem;
}
.introduce__check__point .common__minheading::before {
	content: "\f14a";
	display: inline-block;
	width: 2rem;
	margin: 0 0 0 -2rem;
	color: #6bb82d;
	font-family: var(--icon);
	font-weight: 400;
}
.introduce__check__point dd {
	padding: 0 0 0 2rem;
}
.introduce__reason {
	background: #b8dec6;
	width: 50%;
	padding: 4rem 14vw 6rem 2rem;
}
.introduce__reason ul {
	display: flex;
	margin: 0 0 2rem;
}
.introduce__reason ul li {
	padding: 3.5rem 0 0;
	writing-mode: vertical-rl;
	text-orientation: upright;
	font-size: 1.2rem;
	font-weight: bold;
	line-height: 40px;
	white-space: nowrap;
}
.introduce__reason ul li:nth-of-type(1) {
	background: url(img/icon_reason_01.png) no-repeat top;
	background-size: 40px auto;
}
.introduce__reason ul li:nth-of-type(2) {
	background: url(img/icon_reason_02.png) no-repeat top;
	background-size: 40px auto;
}
.introduce__reason ul li:nth-of-type(3) {
	background: url(img/icon_reason_03.png) no-repeat top;
	background-size: 40px auto;
}
.introduce__reason ul li:nth-of-type(4) {
	background: url(img/icon_reason_04.png) no-repeat top;
	background-size: 40px auto;
}
.introduce__reason ul li:nth-of-type(5) {
	background: url(img/icon_reason_05.png) no-repeat top;
	background-size: 40px auto;
}
.introduce__reason ul li + li {
	margin-left: 2rem;
}


.selfcheck {
	background: linear-gradient(135deg, #f0e9e2, #fff);
	padding: 6rem 14vw;
	position: relative;
	z-index: 0;
}
.selfcheck::before {
	content: "";
	border-top: var(--brown) solid 2px;
	border-left: var(--brown) solid 2px;
	position: absolute;
	top: 3rem;
	right: 0;
	bottom: 0;
	left: 7vw;
	z-index: -1;
}
.selfcheck::after {
	content: "";
	width: 14vw;
	background: url(img/obj_page02.png) no-repeat;
	background-size: 100% auto;
	position: absolute;
	top: -6rem;
	right: 0;
	bottom: 0;
	z-index: -2;
}
.selfcheck__title {
	display: flex;
	align-items: center;
}
.selfcheck__title div {
	width: 75%;
}
.selfcheck__image {
	width: 25%;
}
.selfcheck__image img {
	border-radius: 50%;
	overflow: hidden;
}
.selfcheck__question {
	display: flex;
	justify-content: space-between;
	margin: 2rem auto 0;
	position: relative;
	z-index: 0;
}
.selfcheck__question::before {
	content: "";
	display: block;
	width: 35%;
	border-right: var(--brown) solid 1px;
	border-left: var(--brown) solid 1px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 32.5%;
	z-index: -1;
}
.selfcheck__question__col {
	width: 30%;
}
.selfcheck__question__col h3 {
	display: flex;
	align-items: center;
	color: var(--brown);
	font-family: arial, 'Noto Sans JP', sans-serif;
}
.selfcheck__question__col h3 strong {
	margin: 0 0 0 0.5rem;
	font-size: 3.2rem;
	font-weight: bold;
}
.selfcheck__question__list {
	background: url(img/arw.png) no-repeat bottom;
	background-size: 80px auto;
	margin: 0 0 4rem;
	padding: 0 0 calc(4rem + 110px);
}
.selfcheck__question__list li {
	padding: 0 0 0 1.5rem;
}
.selfcheck__question__list li::before {
	content: "";
	background: #fff;
	width: 1rem;
	height: 1rem;
	display: inline-block;
	vertical-align: middle;
	border: var(--brown) solid 1px;
	margin: 0 0.5rem 0 -1.5rem;
}
.selfcheck__question__list li + li {
	margin-top: 1rem;
}
.selfcheck__question__col h4 {
	margin-bottom: 1rem;
}
.selfcheck__question__col h4 small {
	display: flex;
	align-items: center;
	color: var(--brown);
	font-size: 1rem;
}
.selfcheck__question__col h4 small span {
	margin: 0 0.5rem;
	font-size: 2.0rem;
	font-weight: bold;
}
.selfcheck__question__col h4 strong {
	display: inline-block;
	margin: 0 0.5rem 0 0;
	padding: 0.5rem 1rem;
	border-radius: 0.5rem;
	color: #fff;
}
.selfcheck__question__col h4 strong.type01 {
	background: var(--blue);
}
.selfcheck__question__col h4 strong.type02 {
	background: var(--green);
}
.selfcheck__question__col h4 strong.type03 {
	background: var(--purple);
}
.selfcheck__question__image {
	width: 80%;
	margin: 0 auto 2rem;
}
.selfcheck__answer {
	margin: 4rem auto 0;
	position: relative;
}
.selfcheck__answer::after {
	content: "";
	width: 14vw;
	background: url(img/obj_page03.png) no-repeat bottom;
	background-size: 100% auto;
	position: absolute;
	top: 0;
	right: -14vw;
	bottom: -6rem;
	z-index: -2;
}
.selfcheck__answer__inner {
	display: flex;
	justify-content: space-between;
	margin: 2rem auto 0;
	position: relative;
	z-index: 0;
}
.selfcheck__answer__inner::before {
	content: "";
	display: block;
	width: 35%;
	border-right: var(--brown) solid 1px;
	border-left: var(--brown) solid 1px;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 32.5%;
	z-index: -1;
}
.selfcheck__answer__col {
	width: 30%;
}
.selfcheck__answer__col h4 {
	margin-bottom: 1rem;
}
.selfcheck__answer__col h4 > div {
	display: flex;
	align-items: center;
}
.selfcheck__answer__col h4 span {
	display: flex;
	align-items: center;
	color: var(--brown);
	font-weight: bold;
}
.selfcheck__answer__col h4 span span {
	margin: 0 0.5rem;
	font-size: 2.0rem;
}
.selfcheck__answer__col h4 strong {
	display: block;
	font-size: 1.5rem;
	font-weight: bold;
}
.selfcheck__answer__col h4 strong.type01 {
	color: var(--blue);
}
.selfcheck__answer__col h4 strong.type02 {
	color: var(--green);
}
.selfcheck__answer__col h4 strong.type03 {
	color: var(--purple);
}

.page__wrap {
	background: linear-gradient(135deg, #f0e9e2, #fff);
	position: relative;
}
.page__wrap::after {
	content: "";
	width: 14vw;
	background: url(img/obj_page04.png) no-repeat;
	background-size: 100% auto;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
}
.prevention {
	padding: 6rem 14vw;
	position: relative;
	z-index: 0;
}
.prevention::before {
	content: "";
	background: linear-gradient(135deg, #fff, #f0e9e2);
	position: absolute;
	top: 3rem;
	right: 7vw;
	bottom: 3rem;
	left: 7vw;
	z-index: -1;
}
.prevention::after {
	content: "";
	background: url(img/img_prevention.png) no-repeat bottom;
	background-size: 14vw auto; 
	width: 14vw;
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: -1;
}
.prevention .common__midheading {
	color: #088647;
}
.prevention .common__minheading {
	padding: 0 0 0 2rem;
	color: #d33237;
}
.prevention .common__minheading::before {
	content: "\f057";
	display: inline-block;
	width: 2rem;
	margin: 0 0 0 -2rem;
	font-family: var(--icon);
	font-weight: 900;
}
.prevention__inner {
	display: flex;
	justify-content: space-between;
	margin: 2rem auto 0;
}
.prevention__col {
	width: 48%;
}
.prevention__col .common__midheading:nth-of-type(n+2){
	margin-top: 2rem;
}
.prevention__list li:nth-of-type(n+2) {
	margin-top: 1rem;
}
.prevention__list li p {
	padding: 0 0 0 2rem;
}


.cycle {
	padding: 6rem 0;
	position: relative;
}
.cycle__heading {
	width: 20vw;
	height: 20vw;
	padding: 7vw 0;
	position: absolute;
	top: 39%;
	left: 38%;
	color: #fff;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 2vw;
	text-align: center;
	z-index: 1;
}
.cycle__inner {
	width: 70vw;
	margin: 0 auto;
	position: relative;
}
.cycle__list {
	counter-reset: cycle_number 0;
}
.cycle__list  li {
	position: absolute;
}
.cycle__list  li::before {
	counter-increment: cycle_number 1;
	content: '0' counter(cycle_number);
	font-size: 4rem;
	font-weight: bold;
	position: absolute;
	color: #fff;
	opacity: 0.7;
}
.cycle__list li:nth-of-type(1) {
	width: 30%;
	padding: 0 0 0 5rem;
	color: #fff;
	top: 4%;
	left: 29%;
}
.cycle__list li:nth-of-type(1)::before {
	top: 33%;
	left: 0;
}
.cycle__list li:nth-of-type(2) {
	width: 20%;
	padding: 5rem 0 0;
	top: 24%;
	left: 80%;
}
.cycle__list li:nth-of-type(2)::before {
	top: 0;
	left: 0;
}
.cycle__list li:nth-of-type(3) {
	width: 32%;
	padding: 0 0 0 5rem;
	top: 70%;
	left: 78%;
}
.cycle__list li:nth-of-type(3)::before {
	top: 0;
	left: 0;
}
.cycle__list li:nth-of-type(4) {
	width: 20%;
	top: 70%;
	left: -10%;
}
.cycle__list li:nth-of-type(4)::before {
	right: -15rem;
	bottom: -5rem;
}
.cycle__list li:nth-of-type(5) {
	width: 32%;
	top: 14%;
	left: -10%;
}
.cycle__list li:nth-of-type(5)::before {
	left: 45%;
	bottom: -19rem;
}

.btn__toitems {
	padding: 6rem 0;
}
.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;
}

.items {
	background: linear-gradient(135deg, #f0e9e2, #fff);
}
.items__inner {
	background: url(img/obj_page05.png) no-repeat fixed right;
	background-size: 21vw auto;
	padding: 6rem 14vw;
}
.items__data {
	display: flex;
	align-items: center;
	margin: 0 auto 2rem 0;
	padding: 1rem 0;
	border-top: var(--campaign) solid 2px;
	border-bottom: var(--campaign) solid 2px;
	position: relative;
}
.items__data dt {
	background: var(--campaign);
	color: #fff;
	padding: 1rem 2rem;
	text-shadow: none;
}
.items__data dd {
	padding: 0 2rem;
	color: var(--campaign);
	font-size: 1.2rem;
	font-weight: bold;
}
.items__data dd strong {
	display: flex;
	align-items: center;
	justify-content: center;
	background: var(--campaign);
	width: 150px;
	height: 150px;
	margin: auto;
	color: #fff;
	font-weight: bold;
	line-height: 30px;
	text-align: center;
	border-radius: 50%;
	box-sizing: border-box;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 0;
	text-shadow: none;
}

.items .items__title {
}
.itemList + .common__midheading {
	margin-top: 6rem;
}
.itemList {
	margin: 2rem auto 0;
}
.itemList > li {
	background: rgba(255,255,255,0.8);
	max-width: 80vw;
	margin: 0 auto;
	position: relative;
	box-sizing: border-box;
	border: #bfa796 solid 2px;
	/*box-shadow: #ccc 0 0 5px;*/
}
.itemList > li:nth-of-type(n+2) {
	margin-top: 4rem;
}
.itemList__inner{
	padding: 2rem;
	display: flex;
	justify-content: flex-end;
	flex-direction: row-reverse;
	position: relative;
}
.itemList__itemImg {
	width: 240px;
	margin: 0 0 0 auto;
}
.itemList__itemImg img {
	width: 100%;
	border: #ccc solid 1px;
}
.itemList__col {
	width: calc(100% - 240px - 2rem);
}
.itemList__title {
	margin: 0 0 1rem;
	padding: 0 0 0.5rem;
	color: #005590;
	font-size: 1.4rem;
	font-weight: bold;
	border-bottom: #ccc dotted 1px;
}
.itemList__category {
	display: flex;
	margin: 0 0 1rem;
}
.itemList__category li {
	padding: 0.5rem 1rem;
	border-radius: 0.5rem;
	font-size: 0.9rem;
	color: #fff;
}
.itemList__category li.type01 {
	background: var(--blue);
}
.itemList__category li.type02 {
	background: var(--green);
}
.itemList__category li.type03 {
	background: var(--purple);
}
.itemList__category li + li {
	margin-left: 0.5rem;
}
.itemList__heading {
	font-size: 1.2rem;
	font-weight: bold;
	margin: 0 0 1rem;
	position: relative;
}
.itemList__comment {
	margin-bottom: 0.5rem;
}
.itemList__size {
	margin-bottom: 0.5rem;
}
.itemList__price {
	color: #e60012;
	font-size: 1.2rem;
	font-weight: bold;
}
.itemList__submit {
	max-width: 220px;
	margin: 30px 0 0;
}
.itemList__submit a {
	display: block;
	background: #000203;
	padding: 10px 0;
	color: #fff;
	text-decoration: none;
	text-align: center;
}

@media screen and (min-width: 981px){
	
	.sp__only {
		display: none;
	}
	.btn__toitems a:hover {
		background: #fff;
		color: #000203;
	}

}