@charset "UTF-8";

/* --------------------------------------------------
 00: Variables
-------------------------------------------------- */
:root {
	/* width - Number */
	--base-number-view: 1366;
	--base-number: 1100;
	--base-number-sp: 750;

	/* width - Base */
	--base-width-view: calc(var(--base-number-view) * 1px);
	--base-width: calc(var(--base-number) * 1px);

	/* font */
	--font-base: "Noto Sans JP", "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic W3", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, system-ui, sans-serif;
	--font-maru: 'M PLUS Rounded 1c', sans-serif;
	--font-zen-maru: "Zen Maru Gothic", sans-serif;


	/* color */
	--color-main: #666;
	--color-sub: #f5f5f5;
	--color-gray: #d5d5d6;
	--color-gray-light: #efefef;
	--color-accent-orange: #f39800;
	--color-accent-green: #21a84a;
	--color-accent-login: #eb5a24;

	/* link color */
	--link-color: inherit;
	--link-color-hover: inherit;

	/* ground color */
	--ground-color: #ffedca;

	/* rollover value */
	--opacity-value: .7;
}

/* --------------------------------------------------
 00: Reset Style
 -------------------------------------------------- */
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, menu, nav, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	outline: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

*, *::before, *::after {
	box-sizing: border-box;
}

body {
	line-height: 1;
}

article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, picture {
	display: block;
}

h1, h2, h3, h4, h5, h6, dt, th {
	font-weight: 500;
}

ol, ul {
	list-style: none;
}

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after, q:before, q:after {
	content: "";
	content: none;
}

a {
	margin: 0;
	padding: 0;
	font-size: 100%;
	vertical-align: baseline;
	background: transparent;
}

/* change colours to suit your needs */
ins {
	background-color: #ff9;
	color: #000;
	text-decoration: none;
}

/* change colours to suit your needs */
mark {
	background-color: #ff9;
	color: #000;
	font-style: italic;
	font-weight: bold;
}

del {
	text-decoration: line-through;
}

abbr[title], dfn[title] {
	border-bottom: 1px dotted;
	cursor: help;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid #ccc;
	margin: 1em 0;
	padding: 0;
}

input, select, button, textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	margin: 0;
	padding: 0;
	border-radius: 0;
	border: none;
	background-color: transparent;
	color: inherit;
	font-family: inherit;
	font-size: 100%;
	vertical-align: middle;
}

select {
	text-indent: .01px;
	text-overflow: "";
}

select::-ms-expand {
	display: none;
}

/* --------------------------------------------------
 01: Utility Style
 -------------------------------------------------- */
/* Float */
.u-fl {
	float: left !important;
}

.u-fr {
	float: right !important;
}

/* Align */
.u-taL {
	text-align: left !important;
}

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

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

/* size */
.u-txXS {
	font-size: 10px !important;
}

.u-txSS {
	font-size: 11px !important;
}

.u-txS {
	font-size: 12px !important;
}

.u-txM {
	font-size: 14px !important;
}

.u-txL {
	font-size: 16px !important;
}

.u-txLL {
	font-size: 18px !important;
}

.u-txXL {
	font-size: 20px !important;
}

/* Width */
.u-w15px {
	width: 15px !important;
}

.u-w20px {
	width: 20px !important;
}

.u-w25px {
	width: 25px !important;
}

.u-w30px {
	width: 30px !important;
}

.u-w35px {
	width: 35px !important;
}

.u-w40px {
	width: 40px !important;
}

.u-w45px {
	width: 45px !important;
}

.u-w50px {
	width: 50px !important;
}

.u-w55px {
	width: 55px !important;
}

.u-w60px {
	width: 60px !important;
}

.u-w65px {
	width: 65px !important;
}

.u-w70px {
	width: 70px !important;
}

.u-w75px {
	width: 75px !important;
}

.u-w80px {
	width: 80px !important;
}

.u-w85px {
	width: 85px !important;
}

.u-w90px {
	width: 90px !important;
}

.u-w95px {
	width: 95px !important;
}

.u-w100px {
	width: 100px !important;
}

.u-w105px {
	width: 105px !important;
}

.u-w110px {
	width: 110px !important;
}

.u-w115px {
	width: 115px !important;
}

.u-w120px {
	width: 120px !important;
}

.u-w125px {
	width: 125px !important;
}

.u-w130px {
	width: 130px !important;
}

.u-w135px {
	width: 135px !important;
}

.u-w140px {
	width: 140px !important;
}

.u-w145px {
	width: 145px !important;
}

.u-w150px {
	width: 150px !important;
}

.u-w155px {
	width: 155px !important;
}

.u-w160px {
	width: 160px !important;
}

.u-w165px {
	width: 165px !important;
}

.u-w170px {
	width: 170px !important;
}

.u-w175px {
	width: 175px !important;
}

.u-w180px {
	width: 180px !important;
}

.u-w185px {
	width: 185px !important;
}

.u-w190px {
	width: 190px !important;
}

.u-w195px {
	width: 195px !important;
}

.u-w200px {
	width: 200px !important;
}

.u-w205px {
	width: 205px !important;
}

.u-w210px {
	width: 210px !important;
}

.u-w215px {
	width: 215px !important;
}

.u-w220px {
	width: 220px !important;
}

.u-w225px {
	width: 225px !important;
}

.u-w230px {
	width: 230px !important;
}

.u-w235px {
	width: 235px !important;
}

.u-w240px {
	width: 240px !important;
}

.u-w245px {
	width: 245px !important;
}

.u-w250px {
	width: 250px !important;
}

.u-w255px {
	width: 255px !important;
}

.u-w260px {
	width: 260px !important;
}

.u-w265px {
	width: 265px !important;
}

.u-w270px {
	width: 270px !important;
}

.u-w275px {
	width: 275px !important;
}

.u-w280px {
	width: 280px !important;
}

.u-w285px {
	width: 285px !important;
}

.u-w290px {
	width: 290px !important;
}

.u-w295px {
	width: 295px !important;
}

.u-w300px {
	width: 300px !important;
}

.u-w305px {
	width: 305px !important;
}

.u-w310px {
	width: 310px !important;
}

.u-w315px {
	width: 315px !important;
}

.u-w320px {
	width: 320px !important;
}

.u-w325px {
	width: 325px !important;
}

.u-w330px {
	width: 330px !important;
}

.u-w335px {
	width: 335px !important;
}

.u-w340px {
	width: 340px !important;
}

.u-w345px {
	width: 345px !important;
}

.u-w350px {
	width: 350px !important;
}

.u-w355px {
	width: 355px !important;
}

.u-w360px {
	width: 360px !important;
}

.u-w365px {
	width: 365px !important;
}

.u-w370px {
	width: 370px !important;
}

.u-w375px {
	width: 375px !important;
}

.u-w380px {
	width: 380px !important;
}

.u-w385px {
	width: 385px !important;
}

.u-w390px {
	width: 390px !important;
}

.u-w395px {
	width: 395px !important;
}

.u-w400px {
	width: 400px !important;
}

.u-w405px {
	width: 405px !important;
}

.u-w410px {
	width: 410px !important;
}

.u-w415px {
	width: 415px !important;
}

.u-w420px {
	width: 420px !important;
}

.u-w425px {
	width: 425px !important;
}

.u-w430px {
	width: 430px !important;
}

.u-w435px {
	width: 435px !important;
}

.u-w440px {
	width: 440px !important;
}

.u-w445px {
	width: 445px !important;
}

.u-w450px {
	width: 450px !important;
}

.u-w455px {
	width: 455px !important;
}

.u-w460px {
	width: 460px !important;
}

.u-w465px {
	width: 465px !important;
}

.u-w470px {
	width: 470px !important;
}

.u-w475px {
	width: 475px !important;
}

.u-w480px {
	width: 480px !important;
}

.u-w485px {
	width: 485px !important;
}

.u-w490px {
	width: 490px !important;
}

.u-w495px {
	width: 495px !important;
}

.u-w500px {
	width: 500px !important;
}

.u-w5per {
	width: 5% !important;
}

.u-w10per {
	width: 10% !important;
}

.u-w15per {
	width: 15% !important;
}

.u-w20per {
	width: 20% !important;
}

.u-w25per {
	width: 25% !important;
}

.u-w30per {
	width: 30% !important;
}

.u-w35per {
	width: 35% !important;
}

.u-w40per {
	width: 40% !important;
}

.u-w45per {
	width: 45% !important;
}

.u-w50per {
	width: 50% !important;
}

.u-w55per {
	width: 55% !important;
}

.u-w60per {
	width: 60% !important;
}

.u-w65per {
	width: 65% !important;
}

.u-w70per {
	width: 70% !important;
}

.u-w75per {
	width: 75% !important;
}

.u-w80per {
	width: 80% !important;
}

.u-w85per {
	width: 85% !important;
}

.u-w90per {
	width: 90% !important;
}

.u-w95per {
	width: 95% !important;
}

.u-w100per {
	width: 100% !important;
}

/* Margin Padding */
.u-noMargin {
	margin: 0 !important;
}

.u-noPadding {
	padding: 0 !important;
}

.u-mt0 {
	margin-top: 0 !important;
}

.u-mb0 {
	margin-bottom: 0 !important;
}

.u-pt0 {
	padding-top: 0 !important;
}

.u-pb0 {
	padding-bottom: 0 !important;
}

.u-mt5 {
	margin-top: 5px !important;
}

.u-mb5 {
	margin-bottom: 5px !important;
}

.u-pt5 {
	padding-top: 5px !important;
}

.u-pb5 {
	padding-bottom: 5px !important;
}

.u-mt10 {
	margin-top: 10px !important;
}

.u-mb10 {
	margin-bottom: 10px !important;
}

.u-pt10 {
	padding-top: 10px !important;
}

.u-pb10 {
	padding-bottom: 10px !important;
}

.u-mt15 {
	margin-top: 15px !important;
}

.u-mb15 {
	margin-bottom: 15px !important;
}

.u-pt15 {
	padding-top: 15px !important;
}

.u-pb15 {
	padding-bottom: 15px !important;
}

.u-mt20 {
	margin-top: 20px !important;
}

.u-mb20 {
	margin-bottom: 20px !important;
}

.u-pt20 {
	padding-top: 20px !important;
}

.u-pb20 {
	padding-bottom: 20px !important;
}

.u-mt25 {
	margin-top: 25px !important;
}

.u-mb25 {
	margin-bottom: 25px !important;
}

.u-pt25 {
	padding-top: 25px !important;
}

.u-pb25 {
	padding-bottom: 25px !important;
}

.u-mt30 {
	margin-top: 30px !important;
}

.u-mb30 {
	margin-bottom: 30px !important;
}

.u-pt30 {
	padding-top: 30px !important;
}

.u-pb30 {
	padding-bottom: 30px !important;
}

.u-mt35 {
	margin-top: 35px !important;
}

.u-mb35 {
	margin-bottom: 35px !important;
}

.u-pt35 {
	padding-top: 35px !important;
}

.u-pb35 {
	padding-bottom: 35px !important;
}

.u-mt40 {
	margin-top: 40px !important;
}

.u-mb40 {
	margin-bottom: 40px !important;
}

.u-pt40 {
	padding-top: 40px !important;
}

.u-pb40 {
	padding-bottom: 40px !important;
}

.u-mt45 {
	margin-top: 45px !important;
}

.u-mb45 {
	margin-bottom: 45px !important;
}

.u-pt45 {
	padding-top: 45px !important;
}

.u-pb45 {
	padding-bottom: 45px !important;
}

.u-mt50 {
	margin-top: 50px !important;
}

.u-mb50 {
	margin-bottom: 50px !important;
}

.u-pt50 {
	padding-top: 50px !important;
}

.u-pb50 {
	padding-bottom: 50px !important;
}

/* Clear */
.u-clr {
	clear: both;
}

/* Display */
.u-display-pc {
	display: none;
}

@media only screen and (min-width: 1024px) {
	.u-display-pc {
		display: block;
	}
}
@media only screen and (min-width: 1024px) {
	.u-display-sp {
		display: none;
	}
}
/* --------------------------------------------------
 02: Base Style
 -------------------------------------------------- */
:root {
	scroll-padding: calc(75px + 1vh);
}

@media only screen and (min-width: 1024px) {
	:root {
		scroll-padding: calc(120px + 1vh);
	}
}

html {
	font-size: 62.5%;
	-ms-overflow-style: -ms-autohiding-scrollbar;
}

body {
	margin: 0 auto;
	color: var(--color-main);
	font-family: "Noto Sans JP", "游ゴシック", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic W3", "Hiragino Sans", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, system-ui, sans-serif;
	font-size: 1.2rem;
	font-feature-settings: "palt";
	font-weight: 400;
	line-height: 1.5;
	-webkit-text-size-adjust: 100%;

	@media only screen and (min-width: 1024px) {
		font-size: 2.2rem;
	}
}

h1, h2, h3, h4, h5, h6, p, dt, dd, li, th, td {
	letter-spacing: .05em;
}

img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
	transition: .3s;
}

/* --------------------------------------------------
 03: Animation
 -------------------------------------------------- */
/* fadeIn */
@-webkit-keyframes fadeIn {
	0% {
		visibility: hidden;
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
@keyframes fadeIn {
	0% {
		visibility: hidden;
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
/* arrowUp */
@-webkit-keyframes arrowUp {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	50% {
		-webkit-transform: translateY(-4px);
		transform: translateY(-4px);
	}
	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}
@keyframes arrowUp {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	50% {
		-webkit-transform: translateY(-4px);
		transform: translateY(-4px);
	}
	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}
@media only screen and (max-width: 1024px) {
	@-webkit-keyframes arrowUp {
		0% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
		50% {
			-webkit-transform: translateY(-8px);
			transform: translateY(-8px);
		}
		100% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
	}
	@keyframes arrowUp {
		0% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
		50% {
			-webkit-transform: translateY(-8px);
			transform: translateY(-8px);
		}
		100% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
	}
}
/* arrowDown */
@-webkit-keyframes arrowDown {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	50% {
		-webkit-transform: translateY(4px);
		transform: translateY(4px);
	}
	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}
@keyframes arrowDown {
	0% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
	50% {
		-webkit-transform: translateY(4px);
		transform: translateY(4px);
	}
	100% {
		-webkit-transform: translateY(0);
		transform: translateY(0);
	}
}
@media only screen and (max-width: 1024px) {
	@-webkit-keyframes arrowDown {
		0% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
		50% {
			-webkit-transform: translateY(8px);
			transform: translateY(8px);
		}
		100% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
	}
	@keyframes arrowDown {
		0% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
		50% {
			-webkit-transform: translateY(8px);
			transform: translateY(8px);
		}
		100% {
			-webkit-transform: translateY(0);
			transform: translateY(0);
		}
	}
}
@-webkit-keyframes progressbar {
	0% {
		width: 0;
	}
}
@keyframes progressbar {
	0% {
		width: 0;
	}
}

/* scrollAnimation */
[data-scroll] {
	opacity: 0;
	-webkit-transform: translate(0, 30px);
	transform: translate(0, 30px);
	transition: opacity .6s cubic-bezier(.55, .055, .675, .19), -webkit-transform .6s cubic-bezier(.55, .055, .675, .19);
	transition: opacity .6s cubic-bezier(.55, .055, .675, .19), transform .6s cubic-bezier(.55, .055, .675, .19);
	transition: opacity .6s cubic-bezier(.55, .055, .675, .19), transform .6s cubic-bezier(.55, .055, .675, .19), -webkit-transform .6s cubic-bezier(.55, .055, .675, .19);

	&.is-active {
		opacity: 1;
		-webkit-transform: translate(0);
		transform: translate(0);
		transition: opacity 1.2s cubic-bezier(.37, .16, .12, 1), -webkit-transform 1.2s cubic-bezier(.37, .16, .12, 1);
		transition: opacity 1.2s cubic-bezier(.37, .16, .12, 1), transform 1.2s cubic-bezier(.37, .16, .12, 1);
		transition: opacity 1.2s cubic-bezier(.37, .16, .12, 1), transform 1.2s cubic-bezier(.37, .16, .12, 1), -webkit-transform 1.2s cubic-bezier(.37, .16, .12, 1);

		&[data-scroll-delay="100"] {
			transition-delay: .1s;
		}

		&[data-scroll-delay="200"] {
			transition-delay: .2s;
		}

		&[data-scroll-delay="300"] {
			transition-delay: .3s;
		}

		&[data-scroll-delay="400"] {
			transition-delay: .4s;
		}

		&[data-scroll-delay="500"] {
			transition-delay: .5s;
		}

		&[data-scroll-delay="600"] {
			transition-delay: .6s;
		}

		&[data-scroll-delay="700"] {
			transition-delay: .7s;
		}

		&[data-scroll-delay="800"] {
			transition-delay: .8s;
		}

		&[data-scroll-delay="900"] {
			transition-delay: .9s;
		}

		&[data-scroll-delay="1000"] {
			transition-delay: 1s;
		}
	}
}

/* --------------------------------------------------
 04: Link Style
 -------------------------------------------------- */
a {
	color: inherit;
	transition: .3s;

	&:hover {
		text-decoration: none;
	}
}

/* --------------------------------------------------
 05: Wrapper Style
 -------------------------------------------------- */
.l-wrap {
	box-sizing: content-box;
	max-width: 1100px;
	margin-inline: auto;
	padding-inline: 15px;
	@media only screen and (min-width: 1024px) {
		padding-inline: 20px;
	}
}


/* --------------------------------------------------
 06: Header Style
 -------------------------------------------------- */
.l-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	z-index: 100;
	height: 75px;
	/* padding-inline: 20px 10px; */
	background-color: #fff;
	box-shadow: 0 0 15px rgb(0 0 0 / .1);
	&.--sticky {
		position: sticky;
		top: 0;
	}
	.l-wrap{
		display: flex;
    align-items: center;
    justify-content: space-between;
		flex: 1;
	}

	.l-header__logo {
		img {
			width: auto;
			height: 35px;
		}
	}

	@media only screen and (min-width: 1024px) {
		height: 120px;
		padding-inline: 40px;
		box-shadow: 0 0 30px rgb(0 0 0 / .1);

		.l-header__logo {
			position: relative;
			z-index: 300;

			img{
				height: 45px;
			}
		}
	}
}

/* re-l-nav-utility */
.l-nav-utility {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	flex: 1;

	li {
		flex-basis: 72px;

		&:not(:first-child) {
			margin-left: 10px;
		}
	}

	.c-btn {
		height: 26px;
		padding-right: 12px;
		padding-bottom: 0;
		font-family: var(--font-base);
		font-size: 1rem;

		&::after {
			right: 7px;
			width: 10px;
			height: 10px;
		}
	}

	@media only screen and (min-width: 1024px) {
		margin-right: 30px;

		li {
			flex-basis: 144px;

			&:not(:first-child) {
				margin-left: 20px;
			}
		}

		.c-btn {
			height: 52px;
			padding-right: 20px;
			font-size: 2rem;

			&::after {
				right: 12px;
				width: 20px;
				height: 20px;
			}
		}
	}
}

/* re-l-nav-menu */
.l-nav-menu {
	position: relative;
	z-index: 200;
	width: 50px;
	height: 45px;
	cursor: pointer;
	text-indent: -9999px;
	transition: .3s;

	&:hover {
		&::before {
			transform: translate(-50%, 2px);
		}

		&::after {
			transform: translate(-50%, -2px);
		}
	}

	> span,
	&::before,
	&::after {
		display: inline-block;
		position: absolute;
		left: 50%;
		width: 30px;
		height: 4px;
		border-radius: 4px;
		background-color: #595757;
		transform: translateX(-50%);
		transition: .3s;
	}

	> span {
		top: calc(50% - 2px);
		will-change: opacity;
	}

	&::before,
	&::after {
		content: "";
	}

	&::before {
		top: 10px;
	}

	&::after {
		bottom: 10px;
	}

	&[aria-expanded=true] {
		> span {
			opacity: 0;
		}

		&:before {
			transform: translate(-50%, 10.5px) rotate(-45deg);
		}

		&:after {
			transform: translate(-50%, -10.5px) rotate(45deg);
		}
	}

	@media only screen and (min-width: 1024px) {
		width: 48px;
		height: 40px;

		> span,
		&::before,
		&::after {
			width: 48px;
			height: 6px;
		}

		> span {
			top: calc(50% - 3px);
		}

		&::before {
			top: 0;
		}

		&::after {
			bottom: 0;
		}

		&[aria-expanded=true] {
			&::before {
				transform: translate(-50%, 17px) rotate(-45deg);
			}

			&::after {
				transform: translate(-50%, -17px) rotate(45deg);
			}
		}

	}
}

/* re-l-nav-global */
.l-nav-global {
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	z-index: 100;
	backface-visibility: hidden;
	pointer-events: none;

	&[aria-hidden=false] {
		pointer-events: auto;

		.l-nav-global__overlay {
			visibility: visible;
			opacity: 1;
		}

		.l-nav-global__contents {
			transform: translateX(0);
		}
	}

	.l-nav-global__overlay {
		visibility: hidden;
		opacity: 0;
		position: fixed;
		top: 0;
		right: 0;
		bottom: 0;
		left: 0;
		width: 100%;
		height: 100%;
		transition: .3s;
	}

	.l-nav-global__contents {
		box-sizing: content-box;
		display: flex;
		flex-direction: column;
		position: absolute;
		top: 0;
		right: 0;
		bottom: 0;
		z-index: 3;
		min-width: 215px;
		height: calc(100% - 90px);
		padding-top: 75px;
		padding-bottom: 15px;
		background-color: #fff;
		transform: translateX(100%);
		transition: .3s;
	}

	.l-nav-global__inner {
		overflow-x: hidden;
		overflow-y: auto;
		-ms-overflow-style: none;
		-webkit-overflow-scrolling: touch;
		padding-right: 15px;
		padding-left: 15px;
	}

	.l-nav-global__list {
		overflow: hidden;
		border-radius: 10px;
		background-color: #efefef;

		li {
			position: relative;
			font-size: 1.5rem;
			font-weight: 700;

			&:not(:first-child) {
				&::before {
					content: "";
					position: absolute;
					top: 0;
					right: 15px;
					left: 15px;
					border-top: 1px solid #fff;
				}
			}
		}

		a {
			display: flex;
			align-items: center;
			height: 44px;
			padding-right: 15px;
			padding-left: 15px;
			text-decoration: none;

			&:hover {
				background-color: var(--color-accent-orange);
				color: #fff;
			}
		}
	}

	.l-nav-global__link {
		margin-top: 16px;

		li {
			font-size: 1.1rem;

			&:not(:first-child) {
				margin-top: 4px;
			}
		}

		a {
			display: flex;
			align-items: center;
			text-decoration: none;

			&::after {
				content: "";
				width: 7px;
				height: 7px;
				margin-left: 4px;
				border-top: 2px solid var(--color-gray);
				border-right: 2px solid var(--color-gray);
				-webkit-transform: rotate(45deg);
				transform: rotate(45deg);
				transition: .3s;
			}

			&:hover {
				text-decoration: underline;

				&::after {
					-webkit-transform: translateX(3px) rotate(45deg);
					transform: translateX(3px) rotate(45deg);
				}
			}
		}
	}

	.l-nav-global__btn {
		flex-basis: 180px;
		margin: 20px auto 0;

		.c-btn {
			height: 40px;
			font-size: 1.3rem;
		}
	}

	@media only screen and (min-width: 1024px) {
		&[aria-hidden=false] {
			.l-nav-global__contents {
				visibility: visible;
				opacity: 1;
			}
		}

		.l-nav-global__contents {
			visibility: hidden;
			opacity: 0;
			left: 0;
			bottom: auto;
			min-width: auto;
			height: auto;
			padding-top: 120px;
			padding-bottom: 50px;
			-webkit-transform: none;
			transform: none;
		}

		.l-nav-global__inner {
			overflow: visible;
			display: flex;
			flex-flow: wrap;
			align-items: center;
			justify-content: flex-end;
			width: 100%;
			max-width: 990px;
			margin-right: auto;
			margin-left: auto;
			padding-right: 15px;
			padding-left: 15px;
		}

		.l-nav-global__list {
			display: flex;
			align-items: center;
			justify-content: center;
			flex-basis: 100%;
			margin-bottom: 20px;

			li {
				flex: 1 0 auto;

				&:not(:first-child)::before {
					content: "";
					position: absolute;
					top: 15px;
					right: auto;
					bottom: 15px;
					left: 0;
					border-top: 0;
					border-left: 1px solid #fff;
				}
			}

			a {
				justify-content: center;
				height: auto;
				padding: 15px 8px;
				text-align: center;
			}
		}

		.l-nav-global__link {
			display: flex;
			align-items: center;
			margin-top: 0;

			li {
				font-size: 1.1rem;

				&:not(:first-child) {
					margin-top: 0;
					margin-left: 24px;
				}
			}
		}

		.l-nav-global__btn {
			flex-basis: 160px;
			margin: 0 0 0 auto;

			.c-btn {
				height: 40px;
				font-family: var(--font-base);
				font-size: 1.6rem;

				&::after {
					right: 10px;
					width: 17px;
					height: 17px;
				}
			}
		}
	}
}

/* --------------------------------------------------
 07: Contents Style
-------------------------------------------------- */
/* l-main */
.l-main {
	overflow-x: clip;
	position: relative;
	z-index: 3;

	#top & {
		&::before {
			bottom: 0;
		}

		&::after {
			mask: none;
			background-image: linear-gradient(to bottom, transparent 3%, #fff 20%);
		}
	}

	&::before,
	&::after {
		content: "";
		position: absolute;
		background-color: var(--ground-color);
	}

	&::before {
		inset: 0 0 72px;
		z-index: -5;
	}

	&::after {
		inset: auto 0 0;
		z-index: -1;
		height: 153px;
		mask: url(/image/nacharge/bg_wave.svg) center top / contain no-repeat;
	}

	@media only screen and (min-width: 1024px) {
		#top & {
			&::before {
				bottom: 0;
			}
		}

		&::before {
			bottom: 153px;
		}

		&::after {
			height: 306px;
		}
	}
}

/* l-contents */
.l-contents {
	position: relative;
	padding-block: 15px 40px;

	#top & {
		padding-bottom: 0;

		&::before,
		&::after {
			content: none;
		}
	}

	#contract &,
	#rule & {
		padding-block: 20px;
		background-color: #f5f5f5;

		&::before {
			content: none;
		}
	}

	&::before,
	&::after {
		content: "";
		position: absolute;
		z-index: -3;
		background-color: var(--color-sub);
	}

	&::before {
		inset: 236px 0 72px;
	}

	&::after {
		inset: 164px 0 auto;
		height: 153px;
		mask: url(/image/nacharge/bg_wave.svg) center top / contain no-repeat;
	}

	.l-contents__logo {
		margin-top: 20px;
		text-align: center;
	}

	.l-contents__back {
		margin-top: 12px;
	}

	@media only screen and (min-width: 1024px) {
		padding-block: 40px 80px;

		#top & {
			padding-bottom: 12px;
		}

		#contract &,
		#rule & {
			padding-block: 55px 45px;
		}

		&::before {
			inset: 399px 0 153px;
		}

		&::after {
			inset: 246px 0 auto;
			height: 306px;
			mask: url(/image/nacharge/bg_wave.svg) center top / contain no-repeat;
		}

		.l-contents__logo {
			margin-top: 28px;

			img {
				width: 356px;
			}
		}

		.l-contents__back {
			margin-top: 24px;
		}
	}
}

/* --------------------------------------------------
 08: Footer Style
 -------------------------------------------------- */
.l-footer {
	position: relative;
	z-index: 5;
	padding-top: 24px;
	padding-bottom: 20px;

	.l-footer__unit {
		display: grid;
		grid-template-columns: 1fr auto;
		align-items: center;
		gap: 30%;
	}

	.l-footer__logo {
		display: flex;
		align-items: center;
		gap: 12px;
		text-align: center;
	}

	.l-footer__inquiry {
		padding-top: 6px;

		a {
			display: flex;
			align-items: center;
			justify-content: center;
			gap: 4px;
			font-size: 1.2rem;
			text-decoration: none;

			&::after {
				content: "";
				width: 16px;
				height: 14px;
				background: url(/image/nacharge/ic_blank.svg) center / contain no-repeat;
			}

			&:hover {
				text-decoration: underline;
			}
		}
	}

	@media only screen and (min-width: 1024px) {
		padding-bottom: 24px;

		.l-footer__logo {
			gap: 30px;

			img {
				&[src*=logo_miraiz] {
					width: 179px;
				}
				&[src*=logo_katene] {
					width: 109px;
				}
			}
		}

		.l-footer__inquiry {
			padding-top: 6px;

			a {
				font-size: 1.6rem;

				&::after {
					width: 20px;
					height: 17px;
				}
			}
		}
	}
}

/* l-copyright */
.l-copyright {
	margin-top: 20px;
	font-size: 1rem;
	text-align: center;

	@media only screen and (min-width: 1024px) {
		font-size: 1.2rem;
	}
}

/* --------------------------------------------------
 Component
 -------------------------------------------------- */

/* BUTTON
------------------------------ */
/* c-btn */
.c-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 100%;
	max-width: 295px;
	height: 42px;
	margin-inline: auto;
	padding-bottom: 2px;
	border-radius: calc(infinity * 1px);
	background-color: var(--color-accent-orange);
	color: #fff;
	font-family: var(--font-zen-maru);
	font-size: 1.9rem;
	font-weight: 500;
	text-align: center;
	letter-spacing: .06em;
	line-height: 1;
	text-decoration: none;
	cursor: pointer;
	transition: .3s;

	&.-login {
		background-color: var(--color-accent-login);

		&::after {
			background-image: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzQgMzQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGNpcmNsZSBjeD0iMTciIGN5PSIxNyIgZmlsbD0iI2ZmZiIgcj0iMTciLz48cGF0aCBkPSJtMTQuMDYgNi45NyA5LjA2IDkuNDEtOS4wNiA5LjQ1IiBmaWxsPSJub25lIiBzdHJva2U9IiNlYjVhMjQiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIgc3Ryb2tlLXdpZHRoPSIyLjQ1Ii8+PC9zdmc+Cg==);
		}
	}

	&::after {
		content: "";
		position: absolute;
		inset: 0 10px 0 auto;
		width: 17px;
		height: 17px;
		margin-block: auto;
		background: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMzQgMzQiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyI+PGNpcmNsZSBjeD0iMTciIGN5PSIxNyIgZmlsbD0iI2ZmZiIgcj0iMTciLz48cGF0aCBkPSJtMTQuMDYgNi45NyA5LjA2IDkuNDEtOS4wNiA5LjQ1IiBmaWxsPSJub25lIiBzdHJva2U9IiNmMzk4MDAiIHN0cm9rZS1saW5lY2FwPSJyb3VuZCIgc3Ryb2tlLWxpbmVqb2luPSJyb3VuZCIgc3Ryb2tlLXdpZHRoPSIyLjQ1Ii8+PC9zdmc+) center / contain no-repeat;
	}

	@media (any-hover: hover) {
		&.-login {
			&:hover {
				background-color: color-mix(in srgb,var(--color-accent-login),#fff 30%);

				&::after {
					background-color: color-mix(in srgb,var(--color-accent-login),#fff 30%);
				}
			}
		}

		&:hover {
			background-color: color-mix(in srgb,var(--color-accent-orange),#fff 30%);
		}
	}

	@media only screen and (min-width: 1024px) {
		max-width: 592px;
		height: 84px;
		padding-bottom: 4px;
		font-size: 3.8rem;

		&::after {
			right: 20px;
			width: 34px;
			height: 34px;
		}
	}
}

/* LINK
------------------------------ */
/* c-link */
.c-link {
	display: flex;
	align-items: center;
	gap: 0.5em;
	position: relative;
	width: fit-content;
	margin-inline: auto;
	font-size: 1rem;
	text-decoration: none;
	cursor: pointer;
	transition: color .3s;

	&.-back {
		margin-left: 0;

		&::before {
			content: "";
		}

		&::after {
			content: none;
		}
	}

	&.-more {
		&::after {
			margin-top: 0;
			background: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjUuNSAyNS41IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxjaXJjbGUgY3g9IjEyLjc1IiBjeT0iMTIuNzUiIGZpbGw9Im5vbmUiIHI9IjEyIiBzdHJva2U9IiM2NjYiIHN0cm9rZS1taXRlcmxpbWl0PSIxMCIgc3Ryb2tlLXdpZHRoPSIxLjUiLz48cGF0aCBkPSJtMTIuMDMgMTUuNzFjLS4xMS0uNTctLjA5LTEuMDguMDctMS41My4xNi0uNDYuNC0uODcuNzItMS4yMy4zMi0uMzcuNjgtLjcgMS4wOC0xLjAxcy43Ny0uNjIgMS4xMy0uOTIuNjYtLjYyLjg5LS45NC4zNS0uNjguMzUtMS4wN2MwLS40OC0uMTItLjkxLS4zNS0xLjI4cy0uNTgtLjY3LTEuMDQtLjg4LTEuMDQtLjMyLTEuNzYtLjMyLTEuMzguMTYtMi4wNC40Ny0xLjI4Ljc4LTEuODcgMS40MmwtMS4xMi0xLjA0Yy42OS0uNzMgMS40Ni0xLjMxIDIuMy0xLjc1czEuODItLjY1IDIuOTQtLjY1Yy45OCAwIDEuODMuMTYgMi41NC40OHMxLjI2Ljc2IDEuNjYgMS4zNGMuMzkuNTcuNTkgMS4yNi41OSAyLjA2IDAgLjUyLS4xMi45OS0uMzUgMS4zOXMtLjU0Ljc3LS45IDEuMWMtLjM3LjMzLS43NS42NS0xLjE1Ljk2cy0uNzcuNjMtMS4xMS45Ni0uNTkuNy0uNzcgMS4xLS4yMS44Ni0uMTEgMS4zN2gtMS43em0uODkgNS4xMWMtLjM3IDAtLjY5LS4xMi0uOTUtLjM3cy0uMzktLjU4LS4zOS0uOTkuMTMtLjc1LjM5LTEgLjU4LS4zOC45NS0uMzguNjcuMTMuOTMuMzhjLjI2LjI2LjM5LjU5LjM5IDFzLS4xMy43NS0uMzkuOTljLS4yNi4yNS0uNTcuMzctLjkzLjM3eiIgZmlsbD0iIzY2NiIvPjwvc3ZnPg==);
		}
	}

	&::before,
	&::after {
		width: 13px;
		height: 13px;
		margin-top: 2px;
		background: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjYuMSAyNi4xIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxjaXJjbGUgY3g9IjEzLjA1IiBjeT0iMTMuMDUiIGZpbGw9IiM2NjYiIHI9IjEzLjA1Ii8+PHBhdGggZD0ibTEwLjkzIDUuODEgNi45NiA3LjIzLTYuOTYgNy4yNiIgZmlsbD0ibm9uZSIgc3Ryb2tlPSIjZmZmIiBzdHJva2UtbGluZWNhcD0icm91bmQiIHN0cm9rZS1saW5lam9pbj0icm91bmQiIHN0cm9rZS13aWR0aD0iMS44OCIvPjwvc3ZnPg==) center / contain no-repeat;
		transition: translate .3s;
	}

	&::before {
		rotate: 180deg;
	}

	&::after {
		content: "";
	}

	@media (any-hover: hover) {
		&:hover {
			/* color: var(--color-accent-orange); */
			text-decoration: underline;

			/* &.-more {
				&::after {
					translate: 0;
				}
			}

			&::before {
				translate: -3px;
			}

			&::after {
				translate: 3px;
			} */
		}
	}

	@media only screen and (min-width: 1024px) {
		font-size: 2rem;

		&::before,
		&::after {
			width: 26px;
			height: 26px;
			margin-top: 2px;
		}
	}
}

/* PANEL
------------------------------ */
/* c-panel */
.c-panel {
	padding: 16px 12px 24px;
	border-top: 5px solid var(--color-accent-orange);
	border-radius: 0 0 5px 5px;
	background-color: #fff;
	box-shadow: 2px 2px 2px rgb(220 221 221 / .75);

	.c-panel__inner {
		width: 100%;
		max-width: 620px;
		margin-inline: auto;
	}

	.c-panel__headline,
	.c-panel__lead {
		font-family: var(--font-zen-maru);
		font-weight: 500;
		text-align: center;

		span {
			font-size: 1.7rem;
		}
	}

	.c-panel__headline {
		font-size: 2.1em;

		span {
			font-size: 1.7rem;
		}
	}

	.c-panel__lead {
		margin-top: 16px;
		line-height: 1.667;
	}

	.c-panel__text {
		max-width: 250px;
		margin: 8px auto 0;
		font-size: 1.1rem;
		line-height: 1.667;
	}

	.c-panel__notes {
		font-size: 1rem;
		text-align: center;
	}

	.c-panel__link {
		margin-top: 20px;

		span {
			display: block;
			margin-top: 4px;
			font-size: 1rem;
			text-align: center;
		}
	}

	@media only screen and (min-width: 1024px) {
		padding: 40px 48px;
		border-radius: 0 0 10px 10px;
		box-shadow: 4px 4px 4px rgb(220 221 221 / .75);

		.c-panel__headline {
			font-size: 4.4rem;

			span {
				font-size: 3.6rem;
			}
		}

		.c-panel__lead {
			margin-top: 28px;
			font-size: 2.8rem;
		}

		.c-panel__text {
			max-width: 500px;
			margin-top: 16px;
			font-size: 2.2rem;
		}

		.c-panel__notes {
			font-size: 1.8rem;
		}

		.c-panel__link {

			span {
        margin-top: 8px;
        font-size: 1.4rem;
			}
		}
	}
}

/* MODAL
------------------------------ */
/* c-modal */


.c-modal__headline {
	font-family: var(--font-zen-maru);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.2;
	text-align: center;

	&:not(:first-child) {
		margin-top: 28px;
	}
}

.c-modal__sub-headline{
	font-family: var(--font-zen-maru);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: 1.2;
	text-align: center;
	margin-top: 28px;
}

.c-modal__lead {
	margin-top: 8px;
	font-size: 1.1rem;
	text-align: center;
}

.c-modal__list {
	display: flex;
	justify-content: space-between;
	margin-top: 12px;
	gap: 8px;
	li {
		flex: 1;
		font-size: 1rem;
		span {
			display: block;
			margin-top: 4px;
			padding-left: 1em;
			text-indent: -1em;
		}
	}
}

.c-modal__btn {
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 100%;
	max-width: 145px;
	height: 26px;
	margin: 20px auto 0;
	padding-bottom: 2px;
	border-radius: calc(infinity * 1px);
	background-color: var(--color-accent-orange);
	color: #fff;
	font-size: 1.1rem;
	text-align: center;
	cursor: pointer;
	pointer-events: auto;
	transition: .3s;

	&.-close {
		max-width: 100px;
		border: 1px solid;
		background-color: #fff;
		color: var(--color-main);

		@media (any-hover: hover) {
			&:hover {
				border-color: var(--color-main);
				background-color: var(--color-main);
				color: #fff;
			}
		}
	}

	&[disabled] {
		background-color: #efefef;
		color: #58595b;
		pointer-events: none;
	}

	@media (any-hover: hover) {
		&:hover {
			background-color: color-mix(in srgb,var(--color-accent-orange),#fff 30%);
			color: #fff;
		}
	}
}

.c-modal__close {
	position: fixed;
	top: -16px;
	right: -16px;
	z-index: 100;
	width: 40px;
	height: 40px;
	border-radius: 100%;
	background-color: var(--color-accent-orange);
	text-indent: -9999px;
	cursor: pointer;
	transition: opacity .3s .2s, background-color .3s;

	&::before,
	&::after {
		content: "";
		position: absolute;
		top: 50%;
		left: 50%;
		width: 20px;
		height: 2px;
		margin: auto;
		border-radius: calc(infinity * 1px);
		background-color: #fff;
		transition: .3s;
	}

	&::before {
		transform: translate(-50%, -50%) rotate(45deg);
	}

	&::after {
		transform: translate(-50%, -50%) rotate(-45deg);
	}

	@media (any-hover: hover) {
		&:hover {
			background-color: color-mix(in srgb,var(--color-accent-orange),#fff 30%);
		}
	}
}

@media only screen and (min-width: 1024px) {
	.c-modal__contents {
		min-height: 560px;
		padding: 40px 20px;
	}

	.c-modal__headline {
		font-size: 3.6rem;
		&:not(:first-child) {
			margin-top: 56px;
		}
	}
	.c-modal__sub-headline{
		font-size: 3rem;
		margin-top: 48px;
	}

	.c-modal__lead {
		margin-top: 16px;
		font-size: 2.2rem;
	}

	.c-modal__list {
		margin-top: 24px;
		gap: 16px;
		li {
			font-size: 1.6rem;
		}
	}

	.c-modal__btn {
		max-width: 200px;
		height: 40px;
		margin-top: 40px;
		font-size: 1.8rem;
		text-align: center;
		cursor: pointer;
		pointer-events: auto;
		transition: .3s;

		&.-close {
			max-width: 200px;
		}
	}

	.c-modal__close {
		width: 48px;
		height: 48px;

		&::before,
		&::after {
			width: 24px;
			height: 5px;
		}
	}
}


/* --------------------------------------------------
 Project
 -------------------------------------------------- */
/* --------------------------------------------------
 INDEX
 -------------------------------------------------- */
/* p-visual */
.p-visual {
	position: relative;
	z-index: 3;

	&::before,
	&::after {
		content: "";
		position: absolute;
		inset: 200px calc(50% - 50vw) -64px;
		z-index: -1;
		background-image: linear-gradient(to bottom, transparent 3%, #fff 20%, #fff 80%, transparent 97%);
	}
	.p-visual__top{
		display: flex;
		flex-direction: column;
		gap: 1em;
		.p-bnr{
			margin-top: 0;
		}
	}

	.p-visual__news {
		font-size: 1.1rem;
		text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.5em;
		a {
			text-decoration: none;
		}

		span {
			display: inline-block;
			margin-right: .5em;
		}
	}

	.p-visual__logo {
		margin-top: 24px;
		text-align: center;
	}

	.p-visual__headline {
		margin-top: 16px;
		color: var(--color-accent-orange);
		font-family: var(--font-zen-maru);
		font-size: 2.7rem;
		font-weight: 500;
		letter-spacing: normal;
		text-align: center;

		span {
			display: block;
			margin-bottom: 4px;
			font-size: 1.9rem;
			letter-spacing: .05em;
		}
	}

	.p-visual__text {
		margin-top: 8px;
		font-family: var(--font-zen-maru);
		font-size: 1.5rem;
		letter-spacing: normal;
		text-align: center;
	}

	.p-visual__movie {
		width: 100%;
		max-width: 288px;
		margin: 16px auto 0;

		iframe {
			width: 100%;
			height: 100%;
			aspect-ratio: 16 / 9;
		}
	}

	.p-visual__headline-sub {
		margin-top: 16px;
		color: var(--color-accent-orange);
		font-family: var(--font-zen-maru);
		font-size: 1.5rem;
		font-weight: 500;
		text-align: center;
	}

	.p-visual__btn {
		margin-top: 8px;

		span {
			display: block;
			margin-top: 6px;
			font-size: 1rem;
			text-align: center;
		}
	}


	@media only screen and (min-width: 1024px) {
		&::before,
		&::after {
			top: 400px;
			bottom: -128px;
		}
		.p-visual__top{
			gap: 20px;
		}

		.p-visual__news {
			font-size: 2rem;
			a:hover{
				text-decoration: underline;
			}
		}

		.p-visual__logo {
			margin-top: 40px;

			img {
				width: 164px;
			}
		}

		.p-visual__headline {
			margin-top: 32px;
			font-size: 4rem;

			span {
				font-size: 2.7rem;
			}
		}

		.p-visual__text {
			font-size: 2.2rem;
		}

		.p-visual__movie {
			max-width: 576px;
			margin-top: 32px;
		}

		.p-visual__headline-sub {
			margin-top: 32px;
			font-size: 3rem;
		}

		.p-visual__btn {
			span {
				font-size: 1.8rem;
			}
		}
	}
}

/* p-bnr */
.p-bnr {
	margin-top: 28px;
	position: relative;
	.swiper-container {
		display: none;
		position: relative;
		overflow: hidden;
		/* width: 100%; */
		/* max-width: 295px; */
		/* margin-inline: auto; */
		padding-bottom: 20px;
		margin-left: -20px;
		margin-right: -20px;

		&.swiper-initialized {
			display: block;
			animation: fadeIn .3s ease-in-out;
		}
		&.js-noSlide{
			padding-bottom: 0;
		}
	}

	.swiper-slide {
		/* padding-inline: 12px; */

		img {
			width: 100%;
		}

		span {
			display: block;
			margin-top: 6px;
			text-align: center;
		}
	}

	.swiper-pagination {
		bottom: 0 !important;

		span {
			vertical-align: bottom;
		}
	}

	.swiper-pagination-bullet {
		width: 8px;
		height: 8px;
		margin-inline: 6px !important;
		background-color: #b2b2b2;
	}

	.swiper-pagination-bullet-active {
		background-color: var(--color-main);
	}

	@media only screen and (min-width: 1024px) {
		margin-top: 56px;

		.swiper-container {
			/* max-width: 590px; */
			padding-bottom: 28px;
			margin: 0;
			&.js-noSlide{
				padding-bottom: 0;
			}
		}

		/* .swiper-slide {
			padding-inline: 20px;
		} */

		.swiper-pagination-bullet {
			width: 12px;
			height: 12px;
			margin-inline: 8px !important;
		}
	}
}

/* p-area-explain-top */
.p-area-explain-top {
	margin-top: 32px;

	@media only screen and (min-width: 1024px) {
		margin-top: 120px;
	}
}

/* p-area-service */
.p-area-service {
	margin-top: 16px;

	.p-area-service__image {
		margin-top: 12px;
		text-align: center;
	}

	.p-area-service__more {
		margin-top: 12px;
	}

	.p-area-service__text {
		position: relative;
		width: fit-content;
		margin: 20px auto 0;
		padding-inline: 16px;
		font-family: var(--font-zen-maru);
		font-size: 1.8rem;
		font-weight: 500;
		letter-spacing: normal;
		line-height: 1.25;
		text-align: center;

		&::before,
		&::after {
			content: "";
			position: absolute;
			top: -2px;
			bottom: -8px;
			width: 3px;
			border-radius: calc(infinity * 1px);
			background-color: #ccc;
		}

		&::before {
			left: 0;
			rotate: -15deg;
			background-color: var(--color-accent-orange);
		}

		&::after {
			right: 0;
			rotate: 15deg;
			background-color: var(--color-accent-green);
		}

		b {
			color: var(--color-accent-orange);
			font-weight: 500;
		}
	}

	.p-area-service__notes {
		margin-top: 8px;
		font-size: 1.1rem;
		text-align: center;
	}

	@media only screen and (min-width: 1024px) {
		margin-top: 32px;

		.p-area-service__image {
			margin-top: 32px;

			img {
				width: 592px;
			}
		}

		.p-area-service__more {
			margin-top: 28px;
		}

		.p-area-service__text {
			margin-top: 40px;
			padding-inline: 40px;
			font-size: 3.8rem;

			&::before,
			&::after {
				bottom: -12px;
				width: 6px;
			}
		}

		.p-area-service__notes {
			font-size: 2.2rem;
		}
	}
}

/* p-area-faq */
.p-area-faq {
	margin-top: 16px;

	.p-area-faq__list {
		margin-top: 12px;

		> div {
			overflow: hidden;
			border-radius: 12px;
			background-color: #efefef;

			&:not(:first-child) {
				margin-top: 6px;
			}
		}

		dt,
		dd {
			position: relative;
			padding: 12px 16px;
			font-size: 1.1rem;

			&::before {
				content: "";
				position: absolute;
				font-weight: 900;
			}
		}

		dt {
			padding-right: 40px;
			font-weight: 400;
			cursor: pointer;
			transition: .3s;

			&[aria-expanded=true] {
				i {
					&::after {
						opacity: 0;
					}
				}
			}

			&:hover {
				background-color: var(--color-accent-orange);
				color: #fff;

				i {
					&::before,
					&::after {
						background-color: #fff;
					}
				}
			}

			i {
				position: absolute;
				top: 50%;
				right: 16px;
				width: 9px;
				height: 9px;
				translate: 0 -5px;

				&::before,
				&::after {
					content: "";
					position: absolute;
					top: 50%;
					width: 100%;
					height: 1px;
					background-color: var(--color-main);
					transition: .3s;
				}

				&::after {
					rotate: 90deg;
				}
			}
		}

		dd {
			display: none;
			padding-inline: 12px;

			&::after {
				content: "";
				position: absolute;
				inset: 0 12px auto;
				border-top: 1px solid var(--color-main);
			}
		}
	}

	.p-area-faq__text {
		p {
			&:not(:first-child) {
				margin-top: 1em;
			}
		}
	}

	.p-area-faq__btn {
		margin-top: 12px;
	}

	.p-area-faq__notes {
		margin-top: 4px;
		padding-left: 1em;
		font-size: 1rem;
		text-indent: -1em;
	}

	.p-area-faq__list-lower{
		margin-top: 8px;

		li{
			margin-top: 0.5em;
			padding-left: 1em;
			text-indent: -1em;
		}
	}

	@media only screen and (min-width: 1024px) {
		margin-top: 32px;

		.p-area-faq__list {
			margin-top: 24px;

			> div {
				border-radius: 24px;

				&:not(:first-child) {
					margin-top: 12px;
				}
			}

			dt,
			dd {
				padding: 16px 0 16px 64px;
				font-size: 2.2rem;
			}

			dt {
				padding-right: 126px;

				i {
					right: 64px;
					width: 20px;
					height: 20px;
					translate: 0 -10px;

					&::before,
					&::after {
						height: 2px;
					}
				}
			}

			dd {
				padding-top: 28px;
				padding-right: 64px;

				&::after {
					right: 40px;
					left: 40px;
				}
			}
		}

		.p-area-faq__notes {
			font-size: 1.8rem;
		}

		.p-area-faq__btn {
			margin-top: 20px;
		}
	}
}

/* p-block-point */
.p-block-point {
	overflow: hidden;
	margin-top: 16px;
	border-radius: 12px;
	background-color: #fff;
	text-align: center;

	.p-block-point__headline-main {
		padding: 8px 12px;
		background-color: #d9d9d9;
		font-size: 1.2em;
		font-weight: 400;
	}

	.p-block-point__headline {
		font-size: 1.2em;
		font-weight: 400;
	}

	.p-block-point__panel {
		padding: 16px 12px;
	}

	.p-block-point__unit {
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
		margin-top: 16px;
	}

	.p-block-point__headline-sub {
		font-size: 1rem;
		font-weight: 400;
	}

	.p-block-point__image {
		margin-top: 8px;
		text-align: center;
	}

	.p-block-point__notes {
		margin-top: 8px;
		text-align: left;

		li {
			padding-left: 1em;
			font-size: 1rem;
			text-indent: -1em;
		}
	}

	@media only screen and (min-width: 1024px) {
		margin-top: 32px;
		border-radius: 20px;

		.p-block-point__headline-main {
			padding: 16px 24px;
			font-size: 2.2rem;
		}

		.p-block-point__headline {
			font-size: 2.2rem;
		}

		.p-block-point__panel {
			padding: 32px 24px;
		}

		.p-block-point__unit {
			gap: 16px;
			margin-top: 32px;
		}

		.p-block-point__headline-sub {
			font-size: 2rem;
		}

		.p-block-point__image {
			margin-top: 16px;
		}

		.p-block-point__notes {
			margin-top: 16px;

			li {
				font-size: 1.8rem;
			}
		}
	}
}

/* p-area-apply */
.p-area-apply {
	margin-top: 16px;

	.p-area-apply__list {
		margin-top: 16px;
	}

	.p-area-apply__item {
		position: relative;
		padding: 8px 12px 12px;
		border-radius: 20px;
		background-color: #ededeb;
		text-align: center;

		&:not(:first-child) {
			margin-top: 40px;

			&::before {
				content: "";
				position: absolute;
				inset: auto 0 calc(100% + 12px);
				width: 26px;
				height: 16px;
				margin-inline: auto;
				clip-path: polygon(0 0, 100% 0, 50% 100%);
				background-color: var(--color-accent-orange);
			}
		}
	}

	.p-area-apply__headline {
		font-family: var(--font-zen-maru);
		font-size: 1.7rem;
		font-weight: 500;

		i {
			display: block;
			font: normal 700 1.3rem var(--font-base);
		}

		button {
			display: flex;
			align-items: center;
			justify-content: center;
			gap: 6px;
			margin-inline: auto;
			font-weight: 500;
			cursor: pointer;
			transition: color .3s;

			&::after {
				content: "";
				width: 13px;
				height: 13px;
				margin-top: 2px;
				background: url(data:image/svg+xml;base64,PHN2ZyB2aWV3Qm94PSIwIDAgMjUuNSAyNS41IiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjxjaXJjbGUgY3g9IjEyLjc1IiBjeT0iMTIuNzUiIGZpbGw9Im5vbmUiIHI9IjEyIiBzdHJva2U9IiM2NjYiIHN0cm9rZS1taXRlcmxpbWl0PSIxMCIgc3Ryb2tlLXdpZHRoPSIxLjUiLz48cGF0aCBkPSJtMTIuMDMgMTUuNzFjLS4xMS0uNTctLjA5LTEuMDguMDctMS41My4xNi0uNDYuNC0uODcuNzItMS4yMy4zMi0uMzcuNjgtLjcgMS4wOC0xLjAxcy43Ny0uNjIgMS4xMy0uOTIuNjYtLjYyLjg5LS45NC4zNS0uNjguMzUtMS4wN2MwLS40OC0uMTItLjkxLS4zNS0xLjI4cy0uNTgtLjY3LTEuMDQtLjg4LTEuMDQtLjMyLTEuNzYtLjMyLTEuMzguMTYtMi4wNC40Ny0xLjI4Ljc4LTEuODcgMS40MmwtMS4xMi0xLjA0Yy42OS0uNzMgMS40Ni0xLjMxIDIuMy0xLjc1czEuODItLjY1IDIuOTQtLjY1Yy45OCAwIDEuODMuMTYgMi41NC40OHMxLjI2Ljc2IDEuNjYgMS4zNGMuMzkuNTcuNTkgMS4yNi41OSAyLjA2IDAgLjUyLS4xMi45OS0uMzUgMS4zOXMtLjU0Ljc3LS45IDEuMWMtLjM3LjMzLS43NS42NS0xLjE1Ljk2cy0uNzcuNjMtMS4xMS45Ni0uNTkuNy0uNzcgMS4xLS4yMS44Ni0uMTEgMS4zN2gtMS43em0uODkgNS4xMWMtLjM3IDAtLjY5LS4xMi0uOTUtLjM3cy0uMzktLjU4LS4zOS0uOTkuMTMtLjc1LjM5LTEgLjU4LS4zOC45NS0uMzguNjcuMTMuOTMuMzhjLjI2LjI2LjM5LjU5LjM5IDFzLS4xMy43NS0uMzkuOTljLS4yNi4yNS0uNTcuMzctLjkzLjM3eiIgZmlsbD0iIzY2NiIvPjwvc3ZnPg==) center / contain no-repeat;
				transition: translate .3s;
			}

			@media (any-hover: hover) {
				&:hover {
					color: var(--color-accent-orange);
				}
			}
		}
	}

	.p-area-apply__text {
		margin-top: 2px;
		font-size: 1.1rem;
	}

	.p-area-apply__btn {
		margin-top: 28px;
	}

	@media only screen and (min-width: 1024px) {
		margin-top: 32px;

		.p-area-apply__list {
			margin-top: 24px;
		}

		.p-area-apply__item {
			position: relative;
			padding: 16px 20px 20px;
			border-radius: 40px;

			&:not(:first-child) {
				margin-top: 72px;

				&::before {
					inset: auto 0 calc(100% + 18px);
					width: 52px;
					height: 32px;
				}
			}
		}

		.p-area-apply__headline {
			font-size: 3.4rem;

			i {
				font-size: 2.6rem;
			}

			button {
				gap: 12px;

				&::after {
					width: 26px;
					height: 26px;
					margin-top: 4px;
				}
			}
		}

		.p-area-apply__text {
			margin-top: 4px;
			font-size: 2.2rem;
		}

		.p-area-apply__btn {
			margin-top: 48px;
		}
	}
}

/* p-block-conditions */
.p-block-conditions {
	width: 100%;
	max-width: 474px;
	margin: 24px auto 0;
	padding-left: 28px;

	.c-modal__headline + & {
		margin-top: 12px;
	}

	.p-block-conditions__headline {
		position: relative;
		font-family: var(--font-zen-maru);
		font-size: 1.5rem;
		font-weight: 500;

		&::before {
			content: "";
			display: block;
			position: absolute;
			top: 6px;
			right: calc(100% + 8px);
			width: 16px;
			height: 8px;
			border-left: 2px solid;
			border-bottom: 2px solid;
			rotate: -45deg;
		}

		&:not(:first-child) {
			margin-top: 20px;
		}
	}

	.p-block-conditions__text {
		margin-top: 4px;
		font-size: 1rem;
		line-height: 1.667;
	}

	.p-block-conditions__notes {
		margin-top: 20px;
		padding: 2px 4px;
		border: 1px solid;

		li {
			font-size: 1rem;

			&:not(:first-child) {
				margin-top: .5em;
			}

			b {
				display: block;
				margin-bottom: .25em;
				font-weight: 400;
			}
		}

		+ .p-block-conditions__text {
			margin-top: 24px;
		}
	}

	.p-block-conditions__link {
		margin-top: 8px;

		li {
			&:not(:first-child) {
				margin-top: 4px;
			}
		}

		.c-link {
			margin-left: 0;
		}
	}

	@media only screen and (min-width: 1024px) {
		margin-top: 48px;
		padding-left: 0;

		.c-modal__headline + & {
			margin-top: 12px;
		}

		.p-block-conditions__headline {
			font-size: 3rem;

			&::before {
				top: 11px;
				right: calc(100% + 12px);
				width: 32px;
				height: 16px;
				border-left-width: 3px;
				border-bottom-width: 3px;
			}

			&:not(:first-child) {
				margin-top: 40px;
			}
		}

		.p-block-conditions__text {
			margin-top: 8px;
			font-size: 1.7rem;
		}

		.p-block-conditions__notes {
			margin-top: 40px;
			padding: 6px 8px;

			li {
				font-size: 1.3rem;

				b {
					font-size: 1.4rem;
				}
			}

			+ .p-block-conditions__text {
				margin-top: 48px;
			}
		}

		.p-block-conditions__link {
			margin-top: 16px;

			li {
				&:not(:first-child) {
					margin-top: 8px;
				}
			}
		}
	}
}

/* --------------------------------------------------
 EXPLAIN
 -------------------------------------------------- */
/* p-area-explain */
.p-area-explain {
	position: relative;
	padding: 20px 16px;
	border-radius: 10px;
	background-color: #fff;
	box-shadow: 2px 2px 2px rgb(220 221 221 / .75);

	.p-area-explain__headline-main,
	.p-area-explain__lead {
		position: relative;
		z-index: 5;
		text-align: center;
	}

	.p-area-explain__headline-main {
		font-family: var(--font-zen-maru);
		font-size: 2.7rem;
		font-weight: 500;
		line-height: 1.25;
	}

	.p-area-explain__lead {
		margin-top: 8px;
		font-size: 1.2rem;
		line-height: 1.667;
	}

	.p-area-explain__unit {
		margin-top: 20px;
	}

	.p-area-explain__item {
		margin-top: 26px;

		&.-start {
			.p-area-explain__headline,
			.p-area-explain__text {
				margin-left: 15px;
			}
		}

		&.-box {
			padding: 15px;
			background-color: #ffedcb;

			.p-area-explain__text {
				margin-right: 0;
				margin-left: 0;
			}
		}
	}

	.p-area-explain__headline {
		padding: 8px 12px;
		border-left: 6px solid var(--color-accent-orange);
		background-color: #ffedcb;
		font-size: 1.2rem;
		font-weight: 500;
	}

	.p-area-explain__headline-sub {
		margin-top: 16px;
		font-size: 1.2rem;
		text-align: center;

		+ .p-area-explain__item {
			margin-top: 24px;
		}
	}

	.p-area-explain__text {
		margin: 12px 18px 0;
	}

	.p-area-explain__image {
		margin: 20px 20px 0;
		text-align: center;

		img {
			transition: none;
		}
	}

	.p-area-explain__result {
		position: relative;
		margin-top: 48px;
		padding: 15px;
		background-color: #ffedcb;

		&::before {
			content: "";
			position: absolute;
			top: -32px;
			left: 50%;
			width: 40px;
			height: 20px;
			background: url(data:image/svg+xml;base64,PHN2ZyBoZWlnaHQ9IjM3LjA2IiB2aWV3Qm94PSIwIDAgNzQuMDEgMzcuMDYiIHdpZHRoPSI3NC4wMSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj48cGF0aCBkPSJtMzguMzggMzYuNTFjLS43Ny43My0xLjk4LjczLTIuNzUgMGwtMzUtMzMuMDZjLTEuMzEtMS4yNC0uNDQtMy40NSAxLjM3LTMuNDVoNzBjMS44MSAwIDIuNjkgMi4yMSAxLjM3IDMuNDV6IiBmaWxsPSIjZjM5ODAwIi8+PC9zdmc+) center/contain no-repeat;
			transform: translateX(-50%);
		}
	}

	.p-area-explain__finish {
		margin-top: 16px;
		color: var(--color-accent-orange);
		text-align: center;
	}

	.p-area-explain__btn {
		margin-top: 16px;
	}

	.l-panel__lead {
		margin-top: 16px;
	}

	@media only screen and (min-width: 1024px) {
		padding: 40px;

		.p-area-explain__headline-main {
			font-size: 3.5rem;
		}

		.p-area-explain__lead {
			margin-top: 24px;
			font-size: 2.2rem;
		}

		.p-area-explain__unit {
			display: flex;
			align-items: center;
			margin-top: 40px;

			.p-area-explain__image {
				margin-right: -16px;
				flex-shrink: 0;
			}
		}

		.p-area-explain__contents {
			flex: 1;
			margin-right: 20px;
		}

		.p-area-explain__item {
			margin-top: 52px;

			&.-start {
				.p-area-explain__headline,
				.p-area-explain__text {
					margin-inline: 30px;
				}

				.p-area-explain__image {
					margin-top: 32px;
				}
			}

			&.-box {
				padding: 30px;
			}
		}

		.p-area-explain__headline {
			padding: 16px 24px;
			font-size: 2.4rem;
			text-align: left;
		}

		.p-area-explain__headline-sub {
			margin-top: 16px;
			font-size: 2.4rem;

			+ .p-area-explain__item {
				margin-top: 64px;
			}
		}

		.p-area-explain__text {
			margin: 24px 30px 0;
		}

		.p-area-explain__image {
			margin: 40px 92px 0;

			img[src*="01"] {
				width: 640px;
			}
		}

		.p-area-explain__result {
			margin-top: 136px;
			padding: 30px;

			&::before {
				top: -88px;
				left: 50%;
				width: 76px;
				height: 36px;
			}
		}

		.p-area-explain__finish {
			margin-top: 92px;
			font-size: 3rem;

			img {
				width: 954px;
			}
		}

		.p-area-explain__btn {
			margin-top: 64px;
		}

		.l-panel__lead {
			margin-top: 32px;
		}
	}
}

