/*===============================
MARK: root 
=================================*/
:root {
	--fz10: 0.625rem;
	--fz12: 0.75rem;
	--fz13: 0.8125rem;
	--fz14: 0.875rem;
	--fz16: 1rem;
	--fz17: 1.0625rem;
	--fz18: 1.125rem;
	--fz20: 1.25rem;
	--fz22: 1.375rem;
	--fz24: 1.5rem;
	--fz26: 1.625rem;
	--fz28: 1.75rem;
	--fz30: 1.875rem;
	--fz32: 2rem;
	--fz34: 2.125rem;
	--fz36: 2.25rem;
	--fz38: 2.375rem;
	--fz40: 2.5rem;
	--transform-center: translate(-50%, -50%);
}

/*===============================
MARK: common
=================================*/
html {
	font-size: 100%;
}

body.l-free-body {
	position: relative;
	overflow-x: hidden;
	font-family: 'Zen Kaku Gothic New', 'Helvetica Neue', Arial, 'Hiragino Kaku Gothic ProN',
		'Hiragino Sans', Meiryo, sans-serif;
	font-weight: 500;
	-webkit-font-smoothing: antialiased;
}

a {
	transition: 0.3s;
}

a:hover {
	opacity: 0.8;
}

.d-flex {
	display: flex;
	align-items: start;
	justify-content: start;
}

.tb-content {
	display: none;
}

.sp-content {
	display: none;
}

.indent1em {
	text-indent: -1em;
	margin-left: 1em;
}

.indent2em {
	text-indent: -2em;
	margin-left: 2em;
}

.text-center {
	text-align: center !important;
}

.text-right {
	text-align: right !important;
}

.c-white,
.c-white * {
	color: #fff;
}

/*===============================
MARK: ボタン
=================================*/

.btn {
	position: relative;
	display: inline-block;
	line-height: 1;
	text-decoration: none;
	padding: 1.2em 4em;
	font-size: 1.5625rem;
	font-weight: 500;
	background: #fff;
	border: 4px solid #000;
	color: #000;
}

.btn::before {
	content: '';
	position: absolute;
	box-sizing: border-box;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	border: solid 3px transparent;
	transition: 0.2s;
}

.btn::after {
	content: '';
	display: block;
	width: 0.8em;
	height: 0.8em;
	position: absolute;
	top: 50%;
	right: 17%;
	transform: translateY(-50%);
	background: url(../img/arrow.png) no-repeat;
	background-size: contain;
	transition: 0.2s;
}

.btn:hover {
	opacity: 1;
}

.btn:hover::before {
	border: solid 3px #000;
}
.btn:hover::after {
	right: 16%;
}

.btn02 {
	border-radius: 50em;
	background-color: #fffac0;
	font-size: clamp(1.0625rem, calc(0.9583333333333334rem + 0.4166666666666667vw), 1.3125rem);
	font-weight: 700;
	padding: 1.2em 2.5em;
}
.btn02::before {
	border-radius: 50em;
}
.btn02::after {
	right: 6%;
}
.btn02:hover::after {
	right: 5%;
}

/*===============================
MARK: header
=================================*/
.site-header {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0;
	width: 100%;
	z-index: 1;
}

.site-logo h1 {
	display: inline-block;
	width: clamp(80px, 10%, 142px);
}

.site-logo img {
	display: block;
	max-width: 100%;
}

/*===============================
MARK: MV
=================================*/
#mv {
	position: relative;
	width: 100%;
	height: 100%;
}

.mv-image img {
	max-width: 100%;
	display: block;
}

/*===============================
MARK: TOP-CONTENT
=================================*/
#lead {
	position: relative;
	overflow: hidden;
	background: rgb(255, 250, 192);
	background: linear-gradient(0deg, rgba(255, 250, 192, 1) 0%, rgba(136, 218, 229, 1) 100%);
}

#lead .heading {
	position: relative;
	z-index: 1;
	margin-inline: auto;
	padding-block: 71px 61px;
	width: min(42.9%, 578.5px);
}

#lead .heading img {
	max-width: 100%;
}

.futo-hoso {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: var(--transform-center);
	width: 101%;
	max-width: 1400px;
	margin-left: -7px;
	justify-content: space-between;
	z-index: 0;
}

.arrow {
	position: relative;
	background-color: #fff;
	height: 12px;
}

.arrow::after {
	position: absolute;
	top: 12px;
	left: 50%;
	transform: translateX(-50%) rotate(180deg);
	content: '';
	display: block;
	height: calc(120px / 2);
	width: 120px;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
	background-color: #fff;
}

#comparison {
	background-color: #fcfafa;
	padding-top: 95px;
}

#comparison .inner {
	position: relative;
	padding-bottom: 85px;
}

.line {
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 2px;
	background: #000;
	height: 100%;
	z-index: 0;
}

#comparison .heading {
	position: sticky;
	top: 20px;
	left: 0;
	width: min(100%, 1030px);
	padding-inline: 20px;
	margin-inline: auto;
	z-index: 2;
}

#comparison .heading h3 {
	font-size: clamp(1.125rem, calc(0.5520833333333334rem + 2.2916666666666665vw), 2.5rem);
	font-weight: 500;
	border: 3px solid #000;
	background: #fff;
	box-shadow: 8px 9px 0 rgba(0, 0, 0, 0.09);
	line-height: 1.3;
	padding: 0.2em 10px;
}

.item-container {
	position: relative;
	width: min(100%, 1306px);
	padding-inline: 20px;
	margin-inline: auto;
	margin-block: 40px 100px;
}

.item-main {
	justify-content: space-between;
	align-items: center;
}

.cat-wrap {
	order: 2;
	width: min(100%, 218px);
	flex-shrink: 0;
}

.item-category {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background: #000;
	color: #fff;
	text-align: center;
	width: 100%;
	height: 100%;
	padding: 20px 10px;
	font-size: clamp(0.875rem, calc(0.5885416666666667rem + 1.1458333333333333vw), 1.5625rem);
}

.item-category h4 {
	line-height: 1.1;
	margin-bottom: 0.7em;
	white-space: nowrap;
}

.item-category img {
	width: min(100%, 158px);
	display: block;
	margin-inline: auto;
}

.item-main .item-wrap:first-child {
	order: 1;
}
.item-main .item-wrap:last-child {
	order: 3;
}

.item-main .item-wrap img {
	max-width: 100%;
	display: block;
}

.item-explain {
	width: min(100%, 1110px);
	padding-inline: 20px;
	margin-inline: auto;
	margin-top: 33px;
}

.item-explain p {
	border: 1px solid #d3d3d3;
	background: #fff;
	font-size: clamp(0.6875rem, calc(0.5833333333333334rem + 0.4166666666666667vw), 0.9375rem);
	text-align: center;
	color: #4e4e4e;
	line-height: 1.8;
	border-radius: 50em;
	padding: 2em 15px;
}

.all-items {
	padding-inline: 20px;
}

.notice {
	position: relative;
	border: 1px solid #d3d3d3;
	background: #fff;
	font-size: clamp(0.6875rem, 0.583333rem + 0.416667vw, var(--fz12));
	text-align: center;
	color: #4e4e4e;
	line-height: 1.8;
	padding: 1em 15px;
	margin-top: 20px;
	margin-inline: auto;
	max-width: fit-content;
}

#face-type {
	padding-block: 78px;
}

#face-type .inner,
#face-type .btn-wrap {
	width: min(100%, 760px);
	padding-inline: 20px;
	margin-inline: auto;
}

#face-type h3 {
	position: relative;
	font-size: clamp(1.125rem, calc(0.96875rem + 0.625vw), 1.5rem);
	padding: 1em 15px;
	margin-bottom: 45px;
}

#face-type h3 span {
	display: inline-block;
}

#face-type h3 span::before,
#face-type h3 span::after {
	position: absolute;
	left: 0;
	content: '';
	display: inline-block;
	width: 100%;
	height: 4px;
	background: #000;
	border-radius: 50em;
}

#face-type h3 span::before {
	top: 0;
}
#face-type h3 span::after {
	bottom: 0;
}

#face-type h3::after {
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%) rotate(180deg);
	content: '';
	display: block;
	height: calc(35px / 2);
	width: 35px;
	clip-path: polygon(50% 0, 100% 100%, 0 100%);
	background-color: #000;
}

#face-type .inner img {
	display: block;
	max-width: 100%;
}

.point {
	justify-content: space-between;
	align-items: stretch;
	gap: 29px;
	margin-top: 35px;
}

.point-item {
	display: flex;
	align-items: center;
	justify-content: center;
	flex: 1;
	border: 1px solid #707070;
	background: #fff;
	border-radius: 20px;
	padding: 15px 10px;
}

#face-type p {
	font-size: clamp(1rem, calc(0.8958333333333334rem + 0.4166666666666667vw), 1.25rem);
	margin-block: 70px 75px;
	line-height: 2.2;
	padding-inline: 15px;
}

#face-type .btn-wrap {
	justify-content: center;
	gap: 44px;
}

/*===============================
MARK: footer
=================================*/

.copyright {
	padding-block: 1em 1.5em;
	font-size: clamp(0.75rem, calc(0.5416666666666666rem + 0.8333333333333334vw), 1.25rem);
	text-align: center;
}

/*===============================
fix
=================================*/
.l-free-wrapper div:has(#js-unt-getAjaxHeader),
.l-free-wrapper div:has(#js-unt-getAjaxFooter),
.u-pc-only,
.u-sp-only {
  display: none !important;
}
.l-free-main > .forcms_block:not(.p-lensComSearchStore):last-of-type {
  padding-bottom: 0;
}