@charset "UTF-8";
/*----------
	icons
----------*/
@font-face {
	font-family: iconfont;
	src: url(/assets/fonts/iconfont.ttf) format("truetype"), url(/assets/fonts/iconfont.woff2) format("woff2"), url(/assets/fonts/iconfont.woff) format("woff"), url(/assets/fonts/iconfont.svg) format("svg");
	font-weight: normal;
	font-style: normal;
	font-display: block;
}
.icon, .icon-zip, .icon-word, .icon-url, .icon-unlocked, .icon-to-top, .icon-swipe, .icon-stop, .icon-search, .icon-rss, .icon-right_angle, .icon-question, .icon-plus, .icon-play, .icon-pinch-out, .icon-pinch-in, .icon-phone, .icon-pdf, .icon-new, .icon-minus, .icon-mail, .icon-locked, .icon-last, .icon-humberger, .icon-global, .icon-first, .icon-exclamation, .icon-excel, .icon-download, .icon-doc, .icon-close, .icon-circle, .icon-circle_border, .icon-check, .icon-cart, .icon-calendar, .icon-bookmark, .icon-blank, .icon-arrow2-t, .icon-arrow2-r, .icon-arrow2-l, .icon-arrow2-b, .icon-arrow1-t, .icon-arrow1-r, .icon-arrow1-l, .icon-arrow1-b, .icon-alert, .icon-access {
	display: inline-block;
	font-family: iconfont !important;
	speak: never;
	font-style: normal !important;
	font-size: inherit;
	font-weight: normal !important;
	font-variant: normal !important;
	text-transform: none;
	line-height: 1;
	color: inherit;
}
.icon-access::before {
	content: "\e900";
}
.icon-alert::before {
	content: "\e901";
}
.icon-arrow1-b::before {
	content: "\e902";
}
.icon-arrow1-l::before {
	content: "\e903";
}
.icon-arrow1-r::before {
	content: "\e904";
}
.icon-arrow1-t::before {
	content: "\e905";
}
.icon-arrow2-b::before {
	content: "\e906";
}
.icon-arrow2-l::before {
	content: "\e907";
}
.icon-arrow2-r::before {
	content: "\e908";
}
.icon-arrow2-t::before {
	content: "\e909";
}
.icon-blank::before {
	content: "\e90a";
}
.icon-bookmark::before {
	content: "\e90b";
}
.icon-calendar::before {
	content: "\e90c";
}
.icon-cart::before {
	content: "\e90d";
}
.icon-check::before {
	content: "\e90e";
}
.icon-circle_border::before {
	content: "\e90f";
}
.icon-circle::before {
	content: "\e910";
}
.icon-close::before {
	content: "\e911";
}
.icon-doc::before {
	content: "\e912";
}
.icon-download::before {
	content: "\e913";
}
.icon-excel::before {
	content: "\e914";
}
.icon-exclamation::before {
	content: "\e915";
}
.icon-first::before {
	content: "\e916";
}
.icon-global::before {
	content: "\e917";
}
.icon-humberger::before {
	content: "\e918";
}
.icon-last::before {
	content: "\e919";
}
.icon-locked::before {
	content: "\e91a";
}
.icon-mail::before {
	content: "\e91b";
}
.icon-minus::before {
	content: "\e91c";
}
.icon-new::before {
	content: "\e91d";
}
.icon-pdf::before {
	content: "\e91e";
}
.icon-phone::before {
	content: "\e91f";
}
.icon-pinch-in::before {
	content: "\e920";
}
.icon-pinch-out::before {
	content: "\e921";
}
.icon-play::before {
	content: "\e922";
}
.icon-plus::before {
	content: "\e923";
}
.icon-question::before {
	content: "\e924";
}
.icon-right_angle::before {
	content: "\e925";
}
.icon-rss::before {
	content: "\e926";
}
.icon-search::before {
	content: "\e927";
}
.icon-stop::before {
	content: "\e928";
}
.icon-swipe::before {
	content: "\e929";
}
.icon-to-top::before {
	content: "\e92a";
}
.icon-unlocked::before {
	content: "\e92b";
}
.icon-url::before {
	content: "\e92c";
}
.icon-word::before {
	content: "\e92d";
}
.icon-zip::before {
	content: "\e92e";
}

.icon-freedial {
	display: inline-block;
	vertical-align: baseline;
	line-height: 1;
	width: 70px;
}

.icon-sns {
	display: inline-block;
	vertical-align: baseline;
	line-height: 1;
	width: 40px;
}

/*----------
	icon container
----------*/
.g-icon-container {
	margin-top: -8px;
	font-size: 0;
}
.g-icon-container__item {
	display: inline-block;
	margin-right: 24px;
	margin-top: 8px;
}

/*----------
	logo
----------*/
.c-logo {
	width: 120px;
}
.c-logo > img {
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
}

/*----------
	separator
----------*/
.c-separator {
	display: block;
	margin: 40px auto;
	border-top: 1px solid var(--color-border);
}
.c-separator--dashed {
	border-top-style: dashed;
}

/*----------
	tag
----------*/
.c-tag {
	display: inline-block;
	vertical-align: middle;
	color: #888;
	border-color: #D0D0D0;
}
.c-tag > a,
.c-tag > span {
	height: 20px;
	display: block;
	max-width: 100%;
	min-width: 90px;
	padding: 0 8px;
	color: inherit;
	border: 1px solid;
	border-color: inherit;
	background-color: #fff;
	border-radius: 12px;
	overflow: hidden;
	text-align: center;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 1rem;
	line-height: 18px;
}
.c-tag > a {
	border-color: var(--color-txt-link);
	color: var(--color-txt-link);
}
.c-tag--fill {
	border-color: var(--color-prim);
	color: #fff;
}
.c-tag--fill > a,
.c-tag--fill > span {
	background-color: var(--color-prim);
}
.c-tag--lg > a,
.c-tag--lg > span {
	height: 24px;
	min-width: 110px;
	font-size: 1.2rem;
	line-height: 22px;
}
@media (min-width: 768px), print {
	.c-tag > a {
		transition: background-color 0.2s, color 0.2s;
	}
	.c-tag > a:hover {
		background-color: var(--color-prim);
		color: #fff;
	}
	.c-tag--fill > a:hover {
		background-color: #fff;
		color: var(--color-prim);
	}
}

.c-tag-red {
	display: inline-block;
	vertical-align: middle;
	color: var(--color-caution);
	border-color: var(--color-caution);
}
.c-tag-red > a,
.c-tag-red > span {
	height: 20px;
	display: block;
	max-width: 100%;
	min-width: 90px;
	padding: 0 8px;
	color: inherit;
	border: 1px solid;
	border-color: inherit;
	background-color: #fff;
	border-radius: 12px;
	overflow: hidden;
	text-align: center;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 1rem;
	line-height: 18px;
}
.c-tag-red--lg > a,
.c-tag-red--lg > span {
	height: 24px;
	min-width: 110px;
	font-size: 1.2rem;
	line-height: 22px;
}
@media (min-width: 768px), print {
	.c-tag-red > a {
		transition: background-color 0.2s, color 0.2s;
	}
	.c-tag-red > a:hover {
		background-color: var(--color-caution);
		color: #fff;
	}
}

.c-tag-new {
	display: inline-block;
	vertical-align: middle;
	color: var(--color-prim);
	border-color: var(--color-prim);
}
.c-tag-new > a,
.c-tag-new > span {
	height: 16px;
	display: block;
	max-width: 100%;
	min-width: 40px;
	padding: 0 8px;
	color: inherit;
	color: var(--color-prim);
	border: 1px solid;
	border-color: inherit;
	background-color: #fff;
	border-radius: 12px;
	overflow: hidden;
	text-align: center;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 1rem;
	line-height: 14px;
}
@media (min-width: 768px), print {
	.c-tag-new > a {
		transition: background-color 0.2s, color 0.2s;
	}
	.c-tag-new > a:hover {
		background-color: var(--color-prim);
		color: #fff;
	}
}

/*----------
	tag container
----------*/
.g-tag-container {
	margin-top: -8px;
	font-size: 0;
}
.g-tag-container__item {
	display: inline-block;
	margin-right: 10px;
	margin-top: 8px;
}

/*----------
	figure
----------*/
.c-figure {
	margin-bottom: 30px;
}
.c-figure__image {
	text-align: center;
}
.c-figure__image > img {
	max-width: 100%;
	width: auto;
}
.c-figure__caption {
	margin-top: 12px;
	text-align: left;
	font-size: 1.2rem;
	line-height: var(--line-height-l);
	color: var(--color-txt-caption);
}
@media (min-width: 768px), print {
	.c-figure {
		margin-bottom: 40px;
	}
	.c-figure__caption {
		font-size: 1.4rem;
	}
}

/*----------
	image fit
----------*/
.c-image-fit {
	height: 0;
	padding-bottom: 66.6666666667%;
	position: relative;
	overflow: hidden;
}
.c-image-fit > img,
.c-image-fit > iframe,
.c-image-fit > video,
.c-image-fit > object,
.c-image-fit > embed, .c-image-fit__element {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	object-position: center;
}
.c-image-fit--2t1 {
	padding-bottom: 50%;
}
.c-image-fit--16t9 {
	padding-bottom: 56.25%;
}
.c-image-fit--sq {
	padding-bottom: 100%;
}

/*----------
	image scaling
----------*/
.c-image-scaling {
	display: block;
	margin-bottom: 20px;
}
.c-image-scaling::before {
	font-size: 2rem;
	vertical-align: middle;
}
.c-image-scaling::after {
	content: "画像は拡大できます";
	display: inline-block;
	font-size: 1.2rem;
	vertical-align: middle;
	margin-left: 8px;
}
@media (min-width: 768px), print {
	.c-image-scaling {
		display: none;
	}
}

/*----------
	youtube
----------*/
.c-embed {
	position: relative;
}
.c-embed.is-play .c-embed__poster {
	display: none;
}
.c-embed > video {
	display: block;
	width: 100%;
	height: auto;
}
.c-embed__poster {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
	cursor: pointer;
}
.c-embed__poster > button {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 2;
	margin: auto;
	width: 50px;
	height: 50px;
	font-size: 0;
	background: url(/assets/images/icon_play.svg) no-repeat center;
	cursor: pointer;
}
.c-embed__poster > img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/*----------
	youtube
----------*/
.c-youtube {
	position: relative;
	margin-bottom: 30px;
}
.c-youtube::before {
	content: "";
	display: block;
	padding-top: 56.25%;
}
.c-youtube > iframe {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
@media (min-width: 768px), print {
	.c-youtube {
		margin-bottom: 40px;
	}
}

/*----------
	content box
----------*/
.c-contentbox {
	padding: 24px;
	margin-bottom: 30px;
	background: #FFFFFF;
	border: 5px solid var(--color-bg);
}
.c-contentbox--colored {
	background: var(--color-bg);
}
@media (min-width: 768px), print {
	.c-contentbox {
		padding: 42px;
		margin-bottom: 40px;
		border-width: 8px;
	}
}

/*----------
	search
----------*/
.c-search {
	border-bottom: 1px solid #4A4A4A;
	background: #fff;
}
.c-search__body {
	position: relative;
}
.c-search__text {
	display: block;
	width: 100%;
	padding: 18px 60px 18px 16px;
	line-height: 1.6;
	border-radius: 0;
	appearance: none;
}
.c-search__text:focus {
	outline: none;
}
.c-search__submit {
	position: absolute;
	top: 0;
	right: 0;
	width: 60px;
	height: 60px;
	font-size: 2.4rem;
	line-height: 60px;
	cursor: pointer;
	color: var(--color-txt);
}
.c-search__submit > span {
	font-size: 0;
}

/*----------
	pagination
----------*/
.c-pagination__items {
	display: flex;
	align-items: center;
	justify-content: center;
}
.c-pagination__item {
	margin: 0 4px;
}
.c-pagination__item > a {
	display: block;
	color: inherit;
}
.c-pagination__item--current {
	pointer-events: none;
}
.c-pagination__page {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	text-align: center;
	font-size: 1.4rem;
	line-height: 34px;
	font-weight: 500;
	border: 1px solid var(--color-border-v2);
	border-radius: 50%;
	color: var(--color-txt);
}
.c-pagination__page--current {
	background: var(--color-prim);
	border: 1px solid var(--color-prim);
	color: #fff;
	pointer-events: none;
}
.c-pagination__ellip {
	display: block;
	width: 24px;
	height: 32px;
	font-size: 0;
	background: radial-gradient(var(--color-txt) 1px, transparent 1px) repeat-x left center;
	background-size: 8px 8px;
}
.c-pagination__prev, .c-pagination__next {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	text-align: center;
	font-size: 1.4rem;
	line-height: 34px;
	font-weight: 500;
	border: 1px solid var(--color-border-v2);
	border-radius: 50%;
}
@media (min-width: 768px), print {
	.c-pagination__page, .c-pagination__prev, .c-pagination__next {
		width: 56px;
		height: 56px;
		font-size: 1.6rem;
	}
}
@media (min-width: 768px), print {
	.c-pagination a .c-pagination__page,
	.c-pagination a .c-pagination__prev,
	.c-pagination a .c-pagination__next {
		transition: 0.3s all;
	}
	.c-pagination a:hover .c-pagination__page,
	.c-pagination a:hover .c-pagination__prev,
	.c-pagination a:hover .c-pagination__next {
		border-color: var(--color-txt);
		color: var(--color-txt);
	}
}

/*----------
	billboard
----------*/
.c-billboard {
	position: relative;
	height: 375px;
	padding: 0 0 30px;
}
.c-billboard::before {
	content: "";
	display: block;
	width: 100%;
	height: 50%;
	position: absolute;
	bottom: 0;
	z-index: 1;
	background-image: linear-gradient(rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
}
@media (min-width: 768px), print {
	.c-billboard {
		height: 500px;
		padding: 0 0 50px;
	}
}
.c-billboard__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	position: relative;
	z-index: 2;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
}
@media (min-width: 768px), print {
	.c-billboard__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard__title {
	font-weight: bold;
	font-size: 3.2rem;
	display: flex;
	flex-direction: column;
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.c-billboard__title {
		font-size: 4.8rem;
		align-items: center;
		flex-direction: row;
		flex-wrap: wrap;
	}
}
.c-billboard__title-sub {
	font-weight: 500;
	font-size: 1.8rem;
	line-height: var(--line-height-s);
	color: #fff;
}
@media (min-width: 768px), print {
	.c-billboard__title-sub {
		font-size: 2.6rem;
	}
}
.c-billboard__lead {
	margin-top: 16px;
	border-top: 1px solid #fff;
	padding-top: 12px;
	font-size: 1.2rem;
	color: #fff;
	line-height: 1.8;
}
@media (min-width: 768px), print {
	.c-billboard__lead {
		margin-top: 20px;
		font-size: 1.6rem;
		line-height: 1.7;
	}
}
.c-billboard__image {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	overflow: hidden;
}
.c-billboard__image > img, .c-billboard__image > picture {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/*----------
	billboard
----------*/
.c-billboard-v2 {
	position: relative;
	padding: 48px 0 67px;
	z-index: 2;
	background: var(--color-bg);
}
@media (min-width: 768px), print {
	.c-billboard-v2 {
		padding: 30px 0 70px;
	}
}
.c-billboard-v2__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px), print {
	.c-billboard-v2__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard-v2__title {
	font-weight: bold;
	font-size: 3.2rem;
	display: flex;
	flex-direction: column;
	line-height: var(--line-height-s);
	margin-bottom: 12px;
}
@media (min-width: 768px), print {
	.c-billboard-v2__title {
		font-size: 4rem;
		align-items: center;
		flex-direction: row;
		flex-wrap: wrap;
	}
}
.c-billboard-v2__title-sub {
	font-weight: bold;
	font-size: 1.6rem;
	color: var(--color-txt-caption-v2);
}
@media (min-width: 768px), print {
	.c-billboard-v2__title-sub {
		font-size: 2rem;
	}
}
.c-billboard-v2__lead {
	font-size: 1.4rem;
	color: var(--color-txt-caption-v2);
	line-height: var(--line-height-l);
}
@media (min-width: 768px), print {
	.c-billboard-v2__lead {
		font-size: 1.8rem;
		margin-top: 12px;
	}
}
.c-billboard-v2__image {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.c-billboard-v2__image > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/*----------
	heading-primary
----------*/
.c-heading-primary {
	position: relative;
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	font-weight: 500;
	font-size: 2.6rem;
	line-height: var(--line-height-s);
	z-index: 2;
}
.c-heading-primary::before {
	content: "";
	display: block;
	position: absolute;
	left: 50%;
	bottom: 0;
	width: 100vw;
	padding-top: 1px;
	background-color: var(--color-border);
	transform: translateX(-50%);
	z-index: -1;
}
.c-heading-primary::after {
	content: "";
	position: relative;
	z-index: 1;
	display: block;
	width: 70px;
	height: 5px;
	background: var(--color-prim);
	margin-top: 32px;
	margin-bottom: -1px;
}
@media (min-width: 768px), print {
	.c-heading-primary {
		padding-left: 40px;
		padding-right: 40px;
		font-size: 3.8rem;
	}
	.c-heading-primary::before {
		min-width: 1024px;
	}
	.c-heading-primary::after {
		width: 100px;
	}
}

/*----------
	heading-secondary
----------*/
.c-heading-secondary {
	margin-bottom: 30px;
	padding: 0 0 0 18px;
	position: relative;
	font-weight: 500;
	font-size: 2.2rem;
	line-height: var(--line-height-s);
}
* + .c-heading-secondary {
	margin-top: 80px;
}
.c-heading-secondary::before {
	content: "";
	width: 4px;
	height: calc(100% - 8px);
	background-color: var(--color-prim);
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-45%);
}
.c-heading-secondary--noline {
	padding: 0;
	line-height: var(--line-height-s);
}
.c-heading-secondary--noline::before {
	content: none;
}
@media (min-width: 768px), print {
	.c-heading-secondary {
		margin-bottom: 40px;
		padding: 0 0 0 25px;
		font-size: 3rem;
	}
	* + .c-heading-secondary {
		margin-top: 120px;
	}
	.c-heading-secondary::before {
		width: 5px;
	}
	.c-heading-secondary--noline {
		padding: 0;
	}
}

/*----------
	heading-tertiary
----------*/
.c-heading-tertiary {
	margin-bottom: 30px;
	border-bottom: 1px solid var(--color-border);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-s);
}
* + .c-heading-tertiary {
	margin-top: 50px;
}
.c-heading-tertiary::after {
	content: "";
	display: block;
	width: 30px;
	height: 4px;
	background: var(--color-prim);
	margin-top: 11px;
}
@media (min-width: 768px), print {
	.c-heading-tertiary {
		margin-bottom: 40px;
		font-size: 2.4rem;
	}
	* + .c-heading-tertiary {
		margin-top: 60px;
	}
	.c-heading-tertiary::after {
		width: 80px;
		height: 5px;
		margin-top: 19px;
	}
}

/*----------
	heading-quaternary
----------*/
.c-heading-quaternary {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: var(--line-height-s);
	margin-bottom: 20px;
	padding-bottom: 11px;
	border-bottom: 1px solid var(--color-border);
	position: relative;
}
* + .c-heading-quaternary {
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.c-heading-quaternary {
		margin-bottom: 30px;
		padding-bottom: 15px;
		font-size: 2rem;
	}
	* + .c-heading-quaternary {
		margin-top: 40px;
	}
}

/*----------
	heading-quinary
----------*/
.c-heading-quinary {
	font-weight: bold;
	font-size: 1.4rem;
	line-height: var(--line-height-s);
	position: relative;
	margin-bottom: 10px;
}
* + .c-heading-quinary {
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.c-heading-quinary {
		font-size: 1.6rem;
		margin-bottom: 20px;
	}
	* + .c-heading-quinary {
		margin-top: 40px;
	}
}

/*----------
	heading-point
----------*/
.c-heading-point {
	display: flex;
	margin-bottom: 30px;
}
.c-heading-point + .c-heading-point {
	margin: 30px 0 0;
}
.c-heading-point__icon {
	flex: 0 0 64px;
	margin: 0 20px 0 0;
}
.c-heading-point__icon-inner {
	background: #fff;
	color: var(--color-txt);
	width: 50px;
	height: 50px;
	padding: 0 8px 0 0;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	font-weight: 500;
	border-right: 1px solid var(--color-txt);
}
.c-heading-point__icon-title {
	display: block;
	font-size: 1.1rem;
	line-height: 1.5;
	letter-spacing: 0.05rem;
}
.c-heading-point__icon-title:only-child {
	margin: 0;
}
.c-heading-point__icon-num {
	display: block;
	font-size: 2.8rem;
	line-height: 1;
	font-weight: 500;
	line-height: 1;
}
.c-heading-point__text {
	width: calc(100% - 80px);
	display: flex;
	flex: 1 1 auto;
	align-items: center;
}
.c-heading-point__title {
	margin-top: 12px;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-s);
}
.c-heading-point__lead {
	color: var(--color-txt);
	margin: 8px 0 0;
	font-size: 1.6rem;
	line-height: 1.8;
}
@media (min-width: 768px), print {
	.c-heading-point {
		margin-bottom: 40px;
	}
	.c-heading-point + .c-heading-point {
		margin: 50px 0 0;
	}
	.c-heading-point__icon {
		flex-basis: 70px;
		margin-right: 40px;
	}
	.c-heading-point__icon-inner {
		width: 70px;
		height: 70px;
		padding: 0 18px 0 0;
	}
	.c-heading-point__icon-title {
		margin: 0;
		font-size: 1.4rem;
	}
	.c-heading-point__icon-num {
		font-size: 4rem;
	}
	.c-heading-point__text {
		width: calc(100% - 96px);
	}
	.c-heading-point__title {
		margin-top: 22px;
		font-size: 2.4rem;
	}
}

/*----------
	heading-icon
----------*/
.c-heading-icon {
	display: flex;
}
.c-heading-icon + .c-heading-icon {
	margin: 30px 0 0;
}
.c-heading-icon__image {
	margin-right: 16px;
	width: 64px;
}
.c-heading-icon__image > img {
	width: 100%;
}
.c-heading-icon__text {
	padding: 3px 0 0;
	width: calc(100% - 80px);
	display: flex;
	align-items: center;
}
.c-heading-icon__title {
	font-size: 2rem;
	font-weight: bold;
	line-height: var(--line-height-s);
}
.c-heading-icon__lead {
	color: var(--color-txt-caption-v2);
	margin: 5px 0 0;
}
@media (min-width: 768px), print {
	.c-heading-icon + .c-heading-icon {
		margin: 50px 0 0;
	}
	.c-heading-icon__image {
		width: 80px;
	}
	.c-heading-icon__text {
		width: calc(100% - 96px);
	}
	.c-heading-icon__title {
		font-size: 2.4rem;
	}
}

/*----------
	heading-no
----------*/
.c-heading-no {
	display: flex;
	margin-bottom: 30px;
}
.c-heading-no + .c-heading-no {
	margin: 30px 0 0;
}
.c-heading-no__icon {
	margin: 0 20px 0 0;
}
.c-heading-no__icon-inner {
	background: var(--color-bg);
	border-radius: 100%;
	color: var(--color-prim);
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	gap: 2px;
	font-weight: 500;
}
.c-heading-no__icon-num {
	display: block;
	font-size: 2.4rem;
	line-height: 1;
}
.c-heading-no__text {
	width: calc(100% - 80px);
	display: flex;
	align-items: center;
}
.c-heading-no__title {
	margin-top: 8px;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-s);
}
.c-heading-no__lead {
	color: var(--color-txt-caption-v2);
	margin: 5px 0 0;
}
@media (min-width: 768px), print {
	.c-heading-no {
		margin-bottom: 40px;
	}
	.c-heading-no + .c-heading-no {
		margin: 50px 0 0;
	}
	.c-heading-no__icon {
		margin-right: 40px;
	}
	.c-heading-no__icon-inner {
		width: 70px;
		height: 70px;
	}
	.c-heading-no__icon-title {
		margin: 7px 0 0;
	}
	.c-heading-no__icon-num {
		font-size: 3.2rem;
	}
	.c-heading-no__text {
		width: calc(100% - 96px);
	}
	.c-heading-no__title {
		margin-top: 16px;
		font-size: 2.4rem;
	}
}

/*----------
	text
----------*/
.c-text {
	font-size: 1.4rem;
	line-height: var(--line-height-l);
}
.c-text > a {
	text-decoration: underline;
	color: var(--color-prim);
}
@media (min-width: 768px), print {
	.c-text {
		font-size: 1.6rem;
	}
	.c-text > a {
		text-decoration: underline;
		transition: color 0.3s;
	}
	.c-text > a:hover {
		color: rgba(var(--color-prim-rgb), 0.7);
	}
}

/*----------
	lead
----------*/
.c-lead {
	font-size: 2rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	text-align: center;
	margin-bottom: 50px;
}
.c-lead--white {
	color: #fff;
}
@media (min-width: 768px), print {
	.c-lead {
		font-size: 2.6rem;
		margin-bottom: 60px;
	}
}

/*----------
	caption
----------*/
.c-caption {
	font-size: 1.2rem;
	line-height: var(--line-height-m);
	color: var(--color-txt-caption);
}
.c-caption > a {
	text-decoration: underline;
	color: var(--color-prim);
}
@media (min-width: 768px), print {
	.c-caption {
		font-size: 1.4rem;
	}
	.c-caption > a {
		text-decoration: none;
		background: linear-gradient(var(--color-prim), var(--color-prim)) 100% 100%/0 1px no-repeat;
		transition: background-size 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.3s;
	}
	.c-caption > a:hover {
		background-position: 0 100%;
		background-size: 100% 1px;
	}
}

/*----------
	icontext
----------*/
.c-icontext {
	padding-left: 22px;
	text-indent: -22px;
}
.c-icontext i[class^=icon-] {
	text-indent: 0;
	margin-right: 8px;
	font-size: 1.4rem;
	color: var(--color-prim);
}
.c-icontext i[class^=icon-pdf] {
	color: var(--color-txt-caption);
	margin-left: 4px;
}
.c-icontext i[class^=icon-blank] {
	font-size: 1rem;
	margin-right: 0;
	margin-left: 4px;
}
.c-icontext--bold {
	font-weight: 500;
}
.c-icontext--rev {
	padding-left: 0;
	text-indent: 0;
}
.c-icontext--rev i[class^=icon-] {
	margin-right: 0;
	margin-left: 4px;
}
@media (min-width: 768px), print {
	.c-icontext > a {
		text-decoration: none;
		background: linear-gradient(var(--color-txt), var(--color-txt)) 100% 100%/0 1px no-repeat;
		transition: background-size 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.3s;
	}
	.c-icontext > a:hover {
		background-position: 0 100%;
		background-size: 100% 1px;
	}
}

/*----------
	list
----------*/
.c-list {
	margin-bottom: 30px;
}
.c-list__item {
	padding-left: 1em;
	text-indent: -1em;
}
.c-list__item::before {
	content: "";
	display: inline-block;
	width: 0.25em;
	height: 0.25em;
	margin-right: 0.75em;
	border-radius: 50%;
	vertical-align: middle;
	transform: translate(50%, -50%);
	background-color: var(--color-txt);
}
.c-list__item.u-txt-caution::before {
	background-color: var(--color-caution);
}
.c-list__item + .c-list__item {
	margin-top: 8px;
}
@media (min-width: 768px), print {
	.c-list {
		margin-bottom: 40px;
	}
	.c-list__item::before {
		width: 0.375em;
		height: 0.375em;
	}
}

/*----------
	order list
----------*/
.c-orderlist {
	counter-reset: orderlist;
	margin-bottom: 8px;
}
.c-orderlist__item {
	padding-left: 2em;
	text-indent: -2.5em;
}
.c-orderlist__item::before {
	counter-increment: orderlist;
	content: counter(orderlist) ".";
	display: inline-block;
	margin-right: 0.5em;
	min-width: 2em;
	text-align: right;
}
.c-orderlist__item + .c-orderlist__item {
	margin-top: 8px;
}

/*----------
	remarks
----------*/
.c-remarks {
	margin-bottom: 8px;
	font-size: 1.4rem;
	line-height: var(--line-height-s);
}
.c-remarks__item {
	padding-left: 1.5em;
	text-indent: -0.75em;
}
.c-remarks__item::before {
	content: "※";
	display: inline-block;
	margin-right: 0.5em;
}
.c-remarks__item + .c-remarks__item {
	margin-top: 10px;
}
.c-remarks--order {
	counter-reset: orderlist;
	margin-bottom: 8px;
}
.c-remarks--order .c-remarks__item {
	padding-left: 3em;
	text-indent: -3em;
}
.c-remarks--order .c-remarks__item::before {
	counter-increment: orderlist;
	content: "※" counter(orderlist);
	min-width: 2em;
	margin-right: 1em;
	text-align: right;
}
@media (min-width: 768px), print {
	.c-remarks {
		font-size: 1.6rem;
	}
}

/*----------
	remarks
----------*/
.c-qalist__header {
	display: flex;
}
.c-qalist__header-icon {
	min-width: 40px;
	padding: 5px;
	height: 40px;
	background: var(--color-txt-caption);
	color: #FFF;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	margin-right: 20px;
	font-size: 2rem;
	font-weight: bold;
}
.c-qalist__header-text {
	margin-top: 7px;
	flex: 1;
}
.c-qalist__body {
	display: flex;
	margin-top: 16px;
}
.c-qalist__body-icon {
	min-width: 40px;
	padding: 5px;
	height: 40px;
	background: var(--color-txt-caption);
	color: #FFF;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	margin-right: 20px;
	font-size: 2rem;
	font-weight: bold;
}
.c-qalist__body-text {
	margin-top: 2px;
	flex: 1;
}

/*----------
	button
----------*/
.c-button__inner {
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 48px;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
	background-color: var(--color-prim);
	border: 1px solid var(--color-prim);
	color: #fff;
	border-radius: 36px;
	cursor: pointer;
}
.c-button__inner > span {
	padding: 8px 40px 8px 30px;
	text-align: center;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	color: inherit;
}
.c-button__icon {
	width: 1em;
	height: 1em;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 16px;
	line-height: 1;
	color: inherit;
	font-size: 1.4rem;
}
@media (min-width: 768px), print {
	.c-button__inner {
		min-height: 56px;
		transition: all 0.2s;
	}
	.c-button__inner:hover {
		background-color: #fff;
		color: var(--color-prim);
	}
	.c-button__inner > span {
		font-size: 1.6rem;
	}
}

/* バリエーション */
/* color */
.c-button--seco .c-button__inner {
	background-color: var(--color-txt);
	border: 1px solid var(--color-txt);
	color: #fff;
}
@media (min-width: 768px), print {
	.c-button--seco .c-button__inner:hover {
		background-color: #fff;
		color: var(--color-txt);
	}
}

/* size */
.c-button--l .c-button__inner {
	min-height: 64px;
}
.c-button--l .c-button__inner > span {
	font-size: 1.6rem;
}
@media (min-width: 768px), print {
	.c-button--l .c-button__inner {
		min-height: 72px;
	}
	.c-button--l .c-button__inner > span {
		font-size: 1.8rem;
	}
}
.c-button--s .c-button__inner {
	min-height: 32px;
}
.c-button--s .c-button__inner > span {
	font-size: 1.2rem;
}

/* border */
.c-button--border .c-button__inner {
	border: 1px solid var(--color-prim);
	background-color: #fff;
	color: var(--color-prim);
}
@media (min-width: 768px), print {
	.c-button--border .c-button__inner:hover {
		background-color: var(--color-prim);
		color: #fff;
	}
}

/* cv */
.c-button--cv {
	margin-bottom: 20px;
}
.c-button--cv .c-button__inner {
	min-height: 64px;
	background-color: var(--color-cv);
	border: 1px solid var(--color-cv);
	color: #fff;
}
.c-button--cv .c-button__inner > span {
	font-size: 1.8rem;
	font-weight: 500;
}
@media (min-width: 768px), print {
	.c-button--cv {
		margin-bottom: 30px;
	}
	.c-button--cv .c-button__inner {
		min-height: 72px;
	}
	.c-button--cv .c-button__inner:hover {
		background-color: #fff;
		color: var(--color-cv);
	}
}

/* textlink */
.c-button--textlink .c-button__inner {
	justify-content: flex-start;
	border: none;
	border-bottom: 1px solid var(--color-border);
	border-radius: 0;
	background-color: transparent;
	color: var(--color-txt);
	font-weight: 500;
}
.c-button--textlink .c-button__inner > span {
	padding: 8px 30px 8px 0;
	text-align: left;
	font-size: 1.4rem;
}
.c-button--textlink .c-button__icon {
	right: 10px;
	line-height: 1;
	color: var(--color-prim);
}
@media (min-width: 768px), print {
	.c-button--textlink .c-button__inner::after {
		content: "";
		width: 100%;
		height: 1px;
		position: absolute;
		bottom: 0;
		left: 0;
		background: #333;
		transform: scale(0, 1);
		transform-origin: left top;
		transition: transform 0.4s;
	}
	.c-button--textlink .c-button__inner > span {
		font-size: 1.6rem;
	}
	.c-button--textlink .c-button__inner:hover::after {
		transform: scale(1, 1);
	}
}

/*----------
	button container
----------*/
.g-button-container {
	margin: 0 auto;
	/* ボーダー接合 3カラム（改行左寄せ） */
}
.g-button-container__item {
	max-width: 400px;
}
@media (max-width: 767px) {
	.g-button-container__item {
		margin: 0 auto 16px;
	}
	.g-button-container__item:last-child {
		margin-bottom: 0;
	}
}
@media (min-width: 768px), print {
	.g-button-container {
		display: flex;
		flex-wrap: nowrap;
		justify-content: center;
		align-items: stretch;
	}
	.g-button-container__item {
		flex: 1 1 400px;
	}
	.g-button-container--2up {
		justify-content: center;
	}
	.g-button-container--2up .g-button-container__item {
		flex: 1 1 312px;
	}
	.g-button-container--2up .g-button-container__item + .g-button-container__item {
		margin-left: 32px;
	}
	.g-button-container--center {
		justify-content: center;
	}
	.g-button-container--left {
		justify-content: flex-start;
	}
	.g-button-container--right {
		justify-content: flex-end;
	}
	.g-button-container--3up, .g-button-container--4up {
		display: grid;
		gap: 32px;
	}
	.g-button-container--3up .g-button-container__item, .g-button-container--4up .g-button-container__item {
		max-width: none;
	}
	.g-button-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-button-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}
.g-button-container--collapse .g-button-container__item {
	max-width: none;
}
@media (max-width: 767px) {
	.g-button-container--collapse .g-button-container__item {
		margin: 0 auto;
	}
}
@media (min-width: 768px), print {
	.g-button-container--collapse.g-button-container--2up, .g-button-container--collapse.g-button-container--3up, .g-button-container--collapse.g-button-container--4up {
		gap: 0 32px;
	}
}

/*----------
	textlink container
----------*/
.g-textlink-container {
	margin: 0 auto;
	/* ボーダー接合 3カラム（改行左寄せ） */
}
.g-textlink-container__item {
	max-width: 312px;
}
@media (max-width: 767px) {
	.g-textlink-container__item {
		margin: 0 auto 16px;
	}
	.g-textlink-container__item:last-child {
		margin-bottom: 0;
	}
	.g-textlink-container--4up {
		display: flex;
		flex-wrap: wrap;
	}
	.g-textlink-container--4up .g-textlink-container__item {
		width: calc(50% - 14px);
		margin: 0 7px;
	}
}
@media (min-width: 768px), print {
	.g-textlink-container {
		display: flex;
		flex-wrap: nowrap;
		justify-content: center;
		align-items: stretch;
	}
	.g-textlink-container__item {
		flex: 1 1 312px;
		margin: 0;
	}
	.g-textlink-container--center {
		justify-content: center;
	}
	.g-textlink-container--left {
		justify-content: flex-start;
	}
	.g-textlink-container--right {
		justify-content: flex-end;
	}
	.g-textlink-container--2up, .g-textlink-container--3up, .g-textlink-container--4up {
		display: grid;
		gap: 32px;
	}
	.g-textlink-container--2up .g-textlink-container__item, .g-textlink-container--3up .g-textlink-container__item, .g-textlink-container--4up .g-textlink-container__item {
		max-width: none;
	}
	.g-textlink-container--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-textlink-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-textlink-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}
.g-textlink-container--collapse .g-textlink-container__item {
	max-width: none;
}
@media (max-width: 767px) {
	.g-textlink-container--collapse .g-textlink-container__item {
		margin: 0 auto;
	}
}
@media (min-width: 768px), print {
	.g-textlink-container--collapse.g-textlink-container--2up, .g-textlink-container--collapse.g-textlink-container--3up, .g-textlink-container--collapse.g-textlink-container--4up {
		gap: 0 32px;
	}
}

/*----------
	card
----------*/
.c-card__inner {
	height: 100%;
	display: block;
	border: 1px solid var(--color-border);
}
.c-card__image {
	margin: -1px -1px 12px;
	height: 0;
	padding-bottom: 50%;
	position: relative;
	overflow: hidden;
	z-index: 1;
}
.c-card__image > img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	object-position: center;
}
.c-card__content {
	padding: 0 16px 23px;
}
.c-card__title {
	font-weight: bold;
	font-size: 1.8rem;
	line-height: var(--line-height-s);
}
.c-card__text {
	margin-top: 8px;
	color: var(--color-txt);
}
.c-card__tag {
	margin-top: 8px;
	border-color: #999;
	color: #999;
}
.c-card__button {
	margin: 16px auto 0;
}
@media (min-width: 768px), print {
	.c-card a.c-card__inner {
		transition: box-shadow 0.2s, border-color 0.2s;
	}
	.c-card a.c-card__inner:hover {
		box-shadow: 0 0 15px 0 rgba(0, 0, 0, 0.2);
		border-color: transparent;
	}
	.c-card a.c-card__inner:hover .c-card__title {
		color: var(--color-txt-hover);
	}
	.c-card a.c-card__inner .c-card__tag {
		padding-left: 0;
		padding-right: 0;
	}
	.c-card__title {
		transition: color 0.2s;
	}
	.c-card__tag {
		padding-left: 10px;
		padding-right: 10px;
	}
	.c-card__button {
		padding-left: 10px;
		padding-right: 10px;
	}
}

/*----------
	image link
----------*/
.c-imagelink__inner {
	height: 100%;
	display: flex;
	flex-direction: column;
}
.c-imagelink a.c-imagelink__inner {
	cursor: pointer;
}
.c-imagelink__image {
	width: 100%;
	height: 0;
	padding-bottom: 50%;
	position: relative;
	overflow: hidden;
	z-index: 1;
}
.c-imagelink__image > img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	object-position: center;
}
.c-imagelink__content {
	padding: 20px 15px;
	background-color: var(--color-bg);
	height: 100%;
}
.c-imagelink__title {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: var(--line-height-s);
}
.c-imagelink__text {
	margin-top: 8px;
	font-size: 1.4rem;
	color: var(--color-txt);
}
@media (min-width: 768px), print {
	.c-imagelink a.c-imagelink__inner:hover .c-imagelink__image > img {
		transform: scale(1.05);
	}
	.c-imagelink__image > img {
		transform: scale(1);
		transition: transform 0.3s ease-out;
	}
	.c-imagelink__content {
		padding: 18px 20px;
	}
}

/*----------
	g-imagelink-container
----------*/
.g-imagelink-container {
	margin: 0 auto 20px;
}
@media (max-width: 767px) {
	.g-imagelink-container__item + .g-imagelink-container__item {
		margin-top: 20px;
	}
}
@media (min-width: 768px), print {
	.g-imagelink-container {
		margin-bottom: 40px;
		display: grid;
		gap: 40px;
	}
	.g-imagelink-container--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-imagelink-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-imagelink-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}

/*----------
	image link
----------*/
.c-imagelink-v2 a.c-imagelink-v2__inner {
	cursor: pointer;
}
.c-imagelink-v2__image {
	width: 100%;
	height: 0;
	padding-bottom: 50%;
	position: relative;
	overflow: hidden;
	z-index: 1;
}
.c-imagelink-v2__image > img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	object-position: center;
}
.c-imagelink-v2__content {
	padding: 30px 15px;
	background-color: var(--color-bg);
	height: 100%;
}
.c-imagelink-v2__title {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: var(--line-height-s);
}
.c-imagelink-v2__text {
	margin-top: 8px;
	font-size: 1.4rem;
	color: var(--color-txt);
}
@media (max-width: 767px) {
	.c-imagelink-v2__inner {
		display: flex;
	}
	.c-imagelink-v2__image {
		width: 47.3372781065%;
		height: auto;
		padding-bottom: 0;
	}
	.c-imagelink-v2__image::before {
		content: "";
		display: block;
		padding-bottom: 50%;
	}
	.c-imagelink-v2__content {
		flex: 1 1 0;
		display: flex;
		justify-content: flex-start;
		align-items: center;
		padding: 15px;
		min-height: 80px;
	}
}
@media (min-width: 768px), print {
	.c-imagelink-v2__inner {
		height: 100%;
		display: flex;
		flex-direction: column;
	}
	.c-imagelink-v2 a.c-imagelink-v2__inner:hover .c-imagelink-v2__image > img {
		transform: scale(1.05);
	}
	.c-imagelink-v2__image > img {
		transform: scale(1);
		transition: transform 0.3s ease-out;
	}
	.c-imagelink-v2__content {
		padding: 15px 20px;
	}
}

/*----------
	g-imagelink-v2-container
----------*/
.g-imagelink-v2-container {
	margin: 0 auto 20px;
}
@media (max-width: 767px) {
	.g-imagelink-v2-container__item + .g-imagelink-v2-container__item {
		margin-top: 20px;
	}
}
@media (min-width: 768px), print {
	.g-imagelink-v2-container {
		margin-bottom: 40px;
		display: grid;
		gap: 40px;
	}
	.g-imagelink-v2-container--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-imagelink-v2-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-imagelink-v2-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}

/*----------
	image link
----------*/
.c-cardlink__inner {
	display: block;
	height: 100%;
	border: 1px solid var(--color-border);
	position: relative;
	background-color: #fff;
	box-shadow: 0 4px 12px -5px rgba(0, 0, 0, 0.15);
}
.c-cardlink a.c-cardlink__inner {
	cursor: pointer;
}
.c-cardlink__image {
	width: 100%;
	height: 0;
	padding-bottom: 50%;
	position: absolute;
	z-index: 1;
}
.c-cardlink__image > img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	object-position: center;
}
.c-cardlink__header {
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 60px;
	padding-top: 50%;
	justify-content: flex-start;
	align-items: center;
	overflow: hidden;
	background-color: #fff;
}
.c-cardlink__title {
	display: block;
	width: 100%;
	padding: 16px 40px 16px 24px;
	position: relative;
	font-size: 1.4rem;
	line-height: var(--line-height-s);
	color: inherit;
}
.c-cardlink__icon {
	width: 16px;
	height: 16px;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 16px;
	line-height: 1;
	color: var(--color-txt);
}
@media (min-width: 768px), print {
	.c-cardlink a.c-cardlink__inner {
		transition: box-shadow 0.2s;
	}
	.c-cardlink a.c-cardlink__inner:hover {
		box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.25);
	}
	.c-cardlink a.c-cardlink__inner:hover .c-cardlink__title {
		color: var(--color-txt-hover);
	}
	.c-cardlink__header {
		transition: color 0.2s;
		font-size: 1.6rem;
	}
}

/*----------
	feature
----------*/
.g-card-feature-container {
	margin: 0 auto;
}
@media (min-width: 768px), print {
	.g-card-feature-container {
		display: grid;
		gap: 0;
	}
	.g-card-feature-container--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-card-feature-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
}

/*----------
	feature
----------*/
.c-card-feature__inner {
	display: block;
	height: 100%;
	position: relative;
	background-color: #fff;
}
.c-card-feature__inner::before {
	content: "";
	display: block;
	width: 100%;
	height: 40%;
	position: absolute;
	bottom: 0;
	z-index: 1;
	background-image: linear-gradient(rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.8) 100%);
}
.c-card-feature a.c-card-feature__inner {
	cursor: pointer;
}
.c-card-feature a.c-card-feature__inner .c-card-feature__title {
	color: var(--color-txt-link);
}
.c-card-feature__image {
	width: 100%;
	height: 0;
	padding-bottom: 66.6666666667%;
	position: relative;
	overflow: hidden;
}
.c-card-feature__image > img {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	object-fit: cover;
	object-position: center;
}
.c-card-feature__content {
	width: 100%;
	padding: 16px;
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 2;
}
.c-card-feature__title {
	width: 100%;
	color: var(--color-txt-link);
	font-weight: bold;
	font-size: 1.6rem;
	line-height: var(--line-height-s);
}
.c-card-feature__title > i[class^=icon-] {
	color: var(--color-txt);
}
.c-card-feature__text {
	margin-top: 8px;
	font-size: 1.4rem;
	line-height: var(--line-height-s);
	color: var(--color-txt);
}
.c-card-feature__text i[class^=icon] {
	color: #000;
}
@media (min-width: 768px), print {
	.c-card-feature__image > img {
		transform: scale(1);
		transition: transform 0.2s ease-out;
	}
	.c-card-feature a.c-card-feature__inner:hover .c-card-feature__image > img {
		transform: scale(1.1);
	}
	.c-card-feature__content {
		padding: 24px;
	}
	.c-card-feature__title {
		font-size: 2rem;
	}
	.c-card-feature__title i[class^=icon] {
		font-size: 1.4rem;
		vertical-align: 3px;
	}
	.c-card-feature__text {
		margin-top: 12px;
		font-size: 1.6rem;
		line-height: var(--line-height-m);
	}
}

/*----------
	imageset
----------*/
.c-imageset {
	margin-bottom: 60px;
}
.c-imageset__title {
	font-weight: 500;
	font-size: 1.8rem;
	line-height: var(--line-height-s);
}
.c-imageset__text {
	margin-top: 20px;
}
.c-imageset__button {
	margin: 28px auto 0;
	padding: 0 10px;
}
.c-imageset__caption {
	margin-top: 10px;
	font-size: 1.2rem;
	color: #888;
}
@media (max-width: 767px) {
	.c-imageset__image {
		margin-bottom: 16px;
	}
}
@media (min-width: 768px), print {
	.c-imageset {
		margin-bottom: 80px;
	}
	.c-imageset__inner {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
	}
	.c-imageset__image {
		flex: 0 0 calc(50% - 16px);
		margin-right: 32px;
	}
	.c-imageset__caption {
		margin-top: 14px;
	}
	.c-imageset__content {
		flex: 1 0 calc(50% - 16px);
		padding-top: 20px;
	}
	.c-imageset__title {
		font-size: 2.4rem;
	}
	.c-imageset__text {
		margin-top: 30px;
	}
	.c-imageset__button {
		max-width: 312px;
		margin-top: 40px;
		margin-left: 0;
		padding: 0;
	}
	.c-imageset--1t2 .c-imageset__image {
		flex-basis: calc(33.3333% - 16px);
	}
	.c-imageset--1t3 .c-imageset__image {
		flex-basis: calc(25% - 16px);
	}
	.c-imageset--reverse .c-imageset__inner {
		flex-direction: row-reverse;
	}
	.c-imageset--reverse .c-imageset__image {
		margin-right: 0;
		margin-left: 32px;
	}
}

/*----------
	iconset
----------*/
.c-iconset__image {
	width: 80px;
	margin-right: 24px;
}
.c-iconset__content > *:first-child {
	margin-top: 0 !important;
}
.c-iconset__content > *:last-child {
	margin-bottom: 0 !important;
}
.c-iconset__title {
	font-weight: bold;
	font-size: 1.8rem;
	line-height: var(--line-height-s);
}
.c-iconset__text {
	margin-top: 8px;
	font-size: 1.6rem;
}
.c-iconset__button {
	margin-top: 16px;
}
@media (max-width: 767px) {
	.c-iconset__inner {
		display: grid;
		grid-template-columns: auto 1fr;
		grid-template-rows: auto auto;
	}
	.c-iconset__image {
		grid-column: 1;
		grid-row: 1/3;
	}
	.c-iconset__content {
		grid-column: 2;
		grid-row: 1;
	}
	.c-iconset__button {
		grid-column: 2;
		grid-row: 2;
	}
}
@media (min-width: 768px), print {
	.c-iconset__inner {
		display: flex;
		justify-content: flex-start;
		align-items: flex-start;
		flex-wrap: wrap;
	}
	.c-iconset__image {
		flex: 0 0 80px;
	}
	.c-iconset__content {
		flex: 1;
	}
	.c-iconset__button {
		width: 100%;
		margin-top: 40px;
		margin-left: auto;
		margin-right: auto;
	}
	.c-iconset__button-inner {
		max-width: 312px;
		margin-left: auto;
		margin-right: auto;
	}
}

/*----------
	iconset vertical
----------*/
.c-iconset-v__image {
	width: 110px;
	margin: 0 auto;
}
.c-iconset-v__content {
	margin-top: 24px;
}
.c-iconset-v__content > *:first-child {
	margin-top: 0 !important;
}
.c-iconset-v__content > *:last-child {
	margin-bottom: 0 !important;
}
.c-iconset-v__title {
	text-align: center;
	font-weight: bold;
	font-size: 1.6rem;
	line-height: var(--line-height-s);
}
.c-iconset-v__text {
	margin-top: 16px;
	font-size: 1.6rem;
}
.c-iconset-v__button {
	margin: 24px auto;
	padding: 0 10px;
}
@media (min-width: 768px), print {
	.c-iconset-v__button {
		padding: 0;
	}
	.c-iconset-v__button-inner {
		max-width: 312px;
		margin-left: auto;
		margin-right: auto;
	}
}

/*----------
	textpanel
----------*/
.c-txtpanel-link__inner {
	display: block;
	height: 100%;
	border: #CCC solid 1px;
	padding: 32px 40px 42px;
}
.c-txtpanel-link__title {
	font-size: 1.6rem;
	line-height: var(--line-height-m);
	padding-left: 1.9em;
	text-indent: -1.9em;
}
.c-txtpanel-link__title-icon {
	font-size: 1.6rem;
	color: var(--color-txt);
	text-indent: 0;
	margin-right: 1em;
}
.c-txtpanel-link__text {
	font-size: 1.4rem;
	line-height: var(--line-height-l);
	color: var(--color-txt);
	margin-top: 19px;
}
@media (min-width: 768px), print {
	.c-txtpanel-link__inner:hover .c-txtpanel-link__title {
		color: var(--color-txt-hover);
	}
	.c-txtpanel-link__title {
		font-size: 2rem;
		padding-left: 1.6em;
		text-indent: -1.6em;
		transition: color 0.2s;
	}
}

/*----------
	anchor
----------*/
@media (min-width: 768px), print {
	.c-anchor {
		display: flex;
		flex-wrap: wrap;
	}
}
.c-anchor__item {
	min-height: 48px;
	border: var(--color-border-v2) solid 1px;
	background-color: #fff;
}
@media (max-width: 767px) {
	.c-anchor__item:not(:last-child) {
		border-bottom: none;
	}
}
@media (min-width: 768px), print {
	.c-anchor__item {
		flex: 1;
		min-width: 25%;
		min-height: 56px;
		position: relative;
		margin-bottom: -1px;
		margin-right: -1px;
		text-align: center;
	}
	.c-anchor__item:nth-child(n+5) {
		max-width: calc(25% + 1px);
	}
	.c-anchor__item:hover {
		border-color: var(--color-txt);
		position: relative;
		z-index: 1;
		transition: 0.6s all;
	}
}
.c-anchor__link {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	height: 100%;
	padding: 11px 20px 11px 44px;
	position: relative;
}
@media (min-width: 768px), print {
	.c-anchor__link {
		padding: 17px 20px 17px 52px;
		transition: all 0.2s;
	}
}
.c-anchor__text {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	font-size: 1.4rem;
	margin-top: -1px;
	line-height: var(--line-height-l);
	color: var(--color-txt);
	text-align: left;
}
@media (min-width: 768px), print {
	.c-anchor__text {
		font-size: 1.6rem;
	}
}
.c-anchor__icon {
	position: absolute;
	left: 18px;
	top: 0;
	bottom: 0;
	margin: auto;
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--color-prim);
	font-size: 1.4rem;
}
@media (min-width: 768px), print {
	.c-anchor__icon {
		left: 20px;
		font-size: 1.6rem;
	}
}

/*----------
	anchor
----------*/
.c-tab {
	margin-bottom: 50px;
}
@media (min-width: 768px), print {
	.c-tab {
		margin-bottom: 60px;
	}
}
.c-tab__tab {
	display: flex;
	flex-wrap: wrap;
}
@media (min-width: 768px), print {
	.c-tab__tab {
		flex-wrap: nowrap;
	}
}
.c-tab__tab-item {
	width: 50%;
	margin-bottom: 14px;
	border: none;
	border-left: var(--color-border) solid 1px;
	text-align: center;
	color: var(--color-txt);
}
.c-tab__tab-item:not(:last-child) {
	border-bottom: none;
}
.c-tab__tab-item:nth-child(2n), .c-tab__tab-item:last-child {
	border-right: var(--color-border) solid 1px;
}
.c-tab__tab-item.is-active {
	color: var(--color-prim);
	font-weight: bold;
	pointer-events: none;
	cursor: default;
	position: relative;
}
.c-tab__tab-item.is-active::after {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	margin: auto 10px 0;
	padding-top: 3px;
	background-color: var(--color-prim);
}
.c-tab__tab-item.is-active .c-tab__tab-link > span {
	background: none;
}
@media (min-width: 768px), print {
	.c-tab__tab-item {
		width: 25%;
		margin-bottom: 0;
	}
	.c-tab__tab-item:nth-child(2n) {
		border-right: none;
	}
	.c-tab__tab-item:nth-child(4n) {
		border-right: var(--color-border) solid 1px;
	}
}
.c-tab__tab-link {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.4rem;
	line-height: var(--line-height-s);
	text-align: center;
	width: 100%;
	min-height: 48px;
	height: 100%;
	padding: 6px 10px;
	color: inherit;
}
@media (min-width: 768px), print {
	.c-tab__tab-link {
		min-height: 56px;
		font-size: 1.6rem;
		padding: 10px 15px;
	}
	.c-tab__tab-link > span {
		text-decoration: none;
		background: linear-gradient(var(--color-txt), var(--color-txt)) 100% 100%/0 1px no-repeat;
		transition: background-size 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.3s;
	}
	.c-tab__tab-link:hover > span {
		background-position: 0 100%;
		background-size: 100% 1px;
	}
}
@media (hover: none) {
	.c-tab__tab-link > span {
		background: none;
	}
}
.c-tab__contents-item {
	display: none;
}
.c-tab__contents-item.is-active {
	display: block;
}

/*----------
	news
----------*/
.c-news > a {
	display: block;
	border-color: #999;
	border-color: var(--color-txt-caption);
	color: var(--color-txt-link);
	line-height: var(--line-height-l);
}
.c-news__detail {
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto auto;
	padding: 16px 0;
}
.c-news__date {
	grid-column: 1;
	grid-row: 1;
	margin-right: 16px;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
	vertical-align: middle;
}
.c-news__tag {
	grid-column: 2;
	grid-row: 1;
	align-self: center;
}
.c-news__headline {
	grid-column: 1/3;
	grid-row: 2;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
}
.c-news__headline > i[class^=icon-] {
	color: var(--color-txt);
}
.c-news__title > i[class^=icon-] {
	text-indent: 0;
	margin-left: 5px;
	color: var(--color-txt-caption);
}
.c-news__title .icon-blank {
	font-size: 1.2rem;
}
.c-news a.c-news__title {
	display: inline-block;
}
.c-news__file {
	display: inline-block;
	line-height: var(--line-height-l);
	margin-left: 5px;
	font-size: 1.4rem;
	text-indent: 0;
}
@media (max-width: 767px) {
	.c-news__date {
		margin-bottom: 8px;
	}
	.c-news__tag {
		margin-bottom: 8px;
	}
}
@media (min-width: 768px), print {
	.c-news__detail {
		grid-template-columns: auto auto 1fr;
		grid-template-rows: auto;
		padding-top: 18px;
		padding-bottom: 19px;
	}
	.c-news__date {
		grid-column: 1;
		grid-row: 1;
	}
	.c-news__tag {
		grid-column: 2;
		grid-row: 1;
		margin-top: 4px;
		margin-right: 8px;
		align-self: flex-start;
	}
	.c-news__headline {
		grid-column: 3;
		grid-row: 1;
	}
	.c-news__text {
		text-decoration: none;
		background: linear-gradient(var(--color-txt), var(--color-txt)) 100% 100%/0 1px no-repeat;
		transition: background-size 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.3s;
	}
	.c-news a .c-news__text {
		text-decoration: none;
		background: linear-gradient(var(--color-txt), var(--color-txt)) 100% 100%/0 1px no-repeat;
		transition: background-size 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.3s;
	}
	.c-news a:hover .c-news__text {
		background-position: 0 100%;
		background-size: 100% 1px;
	}
	.c-news--breaked .c-news__detail {
		grid-template-columns: auto 1fr;
		grid-template-rows: auto auto;
		padding-top: 24px;
		padding-bottom: 24px;
	}
	.c-news--breaked .c-news__headline {
		grid-column: 1/3;
		grid-row: 2;
		margin-top: 8px;
	}
}

/*----------
	news list
----------*/
.g-news-container__item {
	border-bottom: 1px solid var(--color-border);
}
.g-news-container__item:first-child {
	border-top: 1px solid var(--color-border);
}

/*----------
	important-info
----------*/
.c-important-info {
	padding-bottom: 4px;
	background-color: #FFEAEB;
	color: var(--color-caution);
	position: relative;
}
.c-important-info__title {
	margin-bottom: 17px;
	padding: 9px 20px;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
	color: var(--color-caution);
	font-weight: bold;
}
.c-important-info__title::before {
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-exclamation);
	vertical-align: -3px;
	width: 18px;
	height: 18px;
	margin-right: 6px;
	font-size: 1.8rem;
}
.c-important-info__item {
	padding: 0 20px 17px;
}
.c-important-info__date {
	font-size: 1.4rem;
	line-height: var(--line-height-s);
	color: var(--color-txt-caution);
}
.c-important-info__content {
	margin-top: 6px;
	line-height: var(--line-height-s);
	color: var(--color-caution);
	font-size: 1.4rem;
}
.c-important-info__content a {
	text-decoration: none;
	background: linear-gradient(var(--color-caution), var(--color-caution)) 100% 100%/0 1px no-repeat;
	transition: background-size 0.4s cubic-bezier(0.215, 0.61, 0.355, 1), color 0.3s;
}
.c-important-info__content a:hover {
	background-position: 0 100%;
	background-size: 100% 1px;
}
@media (max-width: 767px) {
	.c-important-info__title {
		border-bottom: 1px solid #FFCACC;
	}
}
@media (min-width: 768px), print {
	.c-important-info {
		position: relative;
		padding: 20px 20px 20px 204px;
	}
	.c-important-info__item {
		display: flex;
		justify-content: flex-start;
		align-items: flex-start;
		padding: 0;
	}
	.c-important-info__title {
		position: absolute;
		top: 20px;
		left: 20px;
		font-size: 1.6rem;
		line-height: 1.5;
		padding: 0 0 0 30px;
	}
	.c-important-info__title::before {
		position: absolute;
		width: 22px;
		height: 22px;
		top: 2px;
		left: 0;
		font-size: 2.2rem;
	}
	.c-important-info__item + .c-important-info__item {
		margin-top: 10px;
	}
	.c-important-info__date {
		flex: 0 0 6.5em;
		font-size: 1.6rem;
	}
	.c-important-info__content {
		margin-top: 0;
		font-size: 1.6rem;
	}
}

/*----------
	deflist
----------*/
.c-deflist {
	border-bottom: 1px solid var(--color-border);
}
.c-deflist__body {
	border-top: 1px solid var(--color-border);
}
.c-deflist__term {
	padding: 20px 0 8px;
	background-color: #fff;
	font-weight: bold;
}
.c-deflist__detail {
	padding: 8px 0 20px;
	background-color: #fff;
}
@media (min-width: 768px), print {
	.c-deflist__body {
		display: flex;
		justify-content: space-between;
		align-items: stretch;
	}
	.c-deflist__term {
		flex: 0 0 25%;
		padding: 20px 16px 20px 0;
	}
	.c-deflist__detail {
		flex: 1 1 auto;
		margin-left: -1px;
		padding: 20px 0 20px 16px;
	}
}

/*----------
	deflist
----------*/
.c-deflist-v2 {
	border-bottom: 1px solid var(--color-border);
}
.c-deflist-v2__body {
	border-top: 1px solid var(--color-border);
}
.c-deflist-v2__term {
	padding: 20px 0 8px;
	background-color: #fff;
	font-weight: bold;
}
.c-deflist-v2__detail {
	padding: 8px 0 28px;
	background-color: #fff;
}
.c-deflist-v2__image {
	padding: 0 0 24px;
}
@media (min-width: 768px), print {
	.c-deflist-v2__body {
		display: flex;
		justify-content: space-between;
		align-items: stretch;
		padding: 0;
	}
	.c-deflist-v2__term {
		flex: 0 0 25%;
		padding: 20px 16px 20px 0;
	}
	.c-deflist-v2__detail {
		flex: 1 1 auto;
		margin-left: -1px;
		padding: 20px 0 20px 16px;
	}
	.c-deflist-v2__image {
		flex: 0 0 25%;
		margin-left: -1px;
		padding: 20px 0 20px 16px;
	}
}

/*----------
	table
----------*/
.c-table__content {
	width: 100%;
	text-align: left;
	border: none;
	font-size: 1.3rem;
	line-height: var(--line-height-m);
}
.c-table__layouter--for-pc {
	display: none;
}
.c-table__layouter--for-sp {
	display: table-column-group;
}
.c-table__header {
	border: 1px solid var(--color-border-v2);
	vertical-align: middle;
	padding: 10px 16px;
	background-color: var(--color-prim);
	font-weight: bold;
	text-align: left;
	color: #fff;
}
.c-table__header:empty {
	background: none;
}
.c-table__header--red {
	background: var(--color-caution);
}
.c-table__narrow-header {
	border: 1px solid var(--color-border-v2);
	vertical-align: middle;
	padding: 10px 16px;
	background-color: var(--color-prim);
	font-weight: bold;
	text-align: left;
	color: #fff;
}
.c-table__narrow-header:empty {
	background: none;
	border: none;
}
.c-table__narrow-header--red {
	background: var(--color-caution);
}
.c-table__subheader {
	border: 1px solid var(--color-border-v2);
	vertical-align: middle;
	padding: 10px 16px;
	background-color: var(--color-bg);
	font-weight: bold;
	text-align: left;
}
.c-table__subheader:empty {
	background: none;
	border: none;
}
.c-table__cell {
	padding: 10px 16px;
	border: 1px solid var(--color-border-v2);
	vertical-align: middle;
}
.c-table__cell:empty {
	background: none;
	border: none;
}
.c-table__cell--red {
	background: #FFF7F7;
}
@media (max-width: 767px) {
	.c-table--scrollable {
		margin-left: -20px;
		margin-right: -20px;
		position: relative;
	}
	.c-table--scrollable::before {
		content: var(--icon-swipe);
		display: block;
		font-family: iconfont !important;
		font-size: 20px;
		margin-bottom: 20px;
		line-height: 1;
		color: #000;
		margin-left: 20px;
		margin-right: 20px;
	}
	.c-table--scrollable::after {
		content: "表は左右にスライドできます";
		font-size: 12px;
		position: absolute;
		top: 0;
		left: 25px;
		letter-spacing: -0.1rem;
		margin-left: 20px;
		margin-right: 20px;
	}
	.c-table--scrollable .c-table__inner {
		overflow: auto;
		padding-bottom: 8px;
	}
	.c-table--scrollable .c-table__inner::-webkit-scrollbar {
		width: 132px;
		height: 4px;
	}
	.c-table--scrollable .c-table__inner::-webkit-scrollbar-thumb {
		background: #666;
		border-radius: 30px;
	}
	.c-table--scrollable .c-table__body {
		width: 1000px;
		padding-bottom: 8px;
		padding-left: 20px;
		padding-right: 20px;
	}
	.c-table--scrollable-float .c-table__inner {
		overflow: auto;
		margin-right: -5.3333333333%;
		padding-bottom: 8px;
		position: relative;
	}
	.c-table--scrollable-float .c-table__inner::-webkit-scrollbar {
		width: 132px;
		height: 4px;
	}
	.c-table--scrollable-float .c-table__inner::-webkit-scrollbar-thumb {
		background: #666;
		border-radius: 30px;
	}
	.c-table--scrollable-float .c-table__inner::before {
		position: absolute;
		content: "";
		background: url(/assets/images/icon_slide_float.svg) no-repeat;
		background-size: contain;
		width: 68px;
		height: 32px;
		top: calc(50% - 8px);
		left: 50%;
		transform: translate(-50%, -50%);
		z-index: 1;
	}
	.c-table--scrollable-float .c-table__inner.is-scroll::before {
		opacity: 0;
	}
	.c-table--scrollable-float .c-table__body {
		min-width: 1000px;
		padding-bottom: 8px;
	}
	.c-table--scrollable-float .c-table__content {
		position: relative;
	}
	.c-table--scrollable-float .c-table__content::before {
		position: absolute;
		content: "";
		width: 100%;
		height: 100%;
		background: rgba(0, 0, 0, 0.4);
		top: 0;
		left: 0;
		transition: background-color 0.3s;
	}
	.c-table--scrollable-float .c-table__content.is-scroll::before {
		opacity: 0;
	}
}
@media (min-width: 768px), print {
	.c-table__content {
		font-size: 1.4rem;
	}
	.c-table__layouter--for-pc {
		display: table-column-group;
	}
	.c-table__layouter--for-sp {
		display: none;
	}
}

/*----------
	c-box
----------*/
.c-box {
	margin-bottom: 30px;
	background: var(--color-bg);
}
.c-box__header {
	background: var(--color-prim);
	padding: 15px 24px;
}
.c-box__header-title {
	color: #fff;
	font-size: 1.6rem;
	font-weight: 500;
}
.c-box__body {
	padding: 25px;
}
.c-box__body-text {
	color: var(--color-txt);
	font-size: 1.6rem;
	line-height: var(--line-height-l);
}
@media (min-width: 768px), print {
	.c-box {
		margin-bottom: 40px;
	}
	.c-box__header {
		padding: 12px 24px;
	}
	.c-box__header-title {
		font-size: 1.8rem;
	}
	.c-box__body {
		padding: 30px;
	}
}

/*----------
	c-txtpanel
----------*/
.c-txtpanel {
	border: 1px solid var(--color-border);
	padding: 30px;
}
.c-txtpanel__title {
	font-size: 1.6rem;
	font-weight: bold;
	line-height: var(--line-height-s);
}
.c-txtpanel__body {
	margin-top: 15px;
}
@media (min-width: 768px), print {
	.c-txtpanel {
		padding: 40px;
	}
	.c-txtpanel__title {
		font-size: 1.8rem;
	}
}

/*----------
	g-txtpanel-container
----------*/
.g-txtpanel-container {
	margin: 0 auto 20px;
}
@media (max-width: 767px) {
	.g-txtpanel-container__item + .g-txtpanel-container__item {
		margin-top: 30px;
	}
}
@media (min-width: 768px), print {
	.g-txtpanel-container {
		margin-bottom: 40px;
		display: grid;
		gap: 40px;
	}
	.g-txtpanel-container--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-txtpanel-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-txtpanel-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}

/*----------
	c-panel
----------*/
.c-panel {
	border: 1px solid var(--color-border);
	padding: 30px;
}
.c-panel__title {
	font-size: 1.6rem;
	font-weight: 500;
	line-height: var(--line-height-s);
}
.c-panel__body {
	margin-top: 16px;
}
.c-panel__body:only-child {
	margin-top: 0;
}
.c-panel__text {
	margin-top: 15px;
	color: var(--color-txt-caption-v2);
}
@media (min-width: 768px), print {
	.c-panel {
		padding: 40px;
	}
	.c-panel__title {
		font-size: 1.8rem;
	}
	.c-panel__body {
		margin-top: 26px;
	}
	.c-panel__text {
		margin-top: 20px;
	}
}

/*----------
	g-panel-container
----------*/
.g-panel-container {
	margin: 0 auto 20px;
}
@media (max-width: 767px) {
	.g-panel-container__item + .g-panel-container__item {
		margin-top: 30px;
	}
}
@media (min-width: 768px), print {
	.g-panel-container {
		margin-bottom: 40px;
		display: grid;
		gap: 40px;
	}
	.g-panel-container--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-panel-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-panel-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}

/*----------
	c-point
----------*/
.c-point {
	margin-bottom: 60px;
	text-align: center;
}
.c-point__item {
	position: relative;
	padding: 40px 15px 0;
}
.c-point__item + .c-point__item {
	margin-top: 50px;
}
.c-point__icon {
	background: var(--color-bg);
	border-radius: 100%;
	color: var(--color-prim);
	font-weight: 500;
	line-height: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 80px;
	height: 80px;
	margin: 40px 0 0;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-135px);
}
.c-point__icon-title {
	font-size: 1.4rem;
	display: block;
	font-weight: bold;
}
.c-point__icon-num {
	font-size: 24px;
	display: block;
	font-weight: 500;
	margin-top: 3px;
}
.c-point__icon-num:only-child {
	margin-top: 0;
}
.c-point__image {
	max-width: 240px;
	margin: 0 auto;
}
.c-point__image > img {
	width: 100%;
	height: auto;
	vertical-align: top;
}
.c-point__text {
	min-width: 240px;
	margin-top: 15px;
	font-size: 2rem;
	font-weight: 500;
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.c-point {
		display: flex;
		flex-wrap: no-wrap;
		justify-content: space-around;
		margin-bottom: 80px;
		gap: 40px;
	}
	.c-point__icon {
		width: 100px;
		height: 100px;
	}
	.c-point__icon-num {
		font-size: 4rem;
	}
	.c-point__item + .c-point__item {
		margin-top: 0;
	}
	.c-point__image, .c-point__text {
		min-width: 280px;
	}
}

/*----------
	c-qa
----------*/
.c-qa + .c-qa {
	position: relative;
	margin-top: -1px;
}
.c-qa:not(.is-disabled) .c-qa__item--parent {
	cursor: pointer;
}
.c-qa:not(.is-disabled) .c-qa__item--parent::after {
	visibility: visible;
}
.c-qa:not(.is-disabled) .c-qa__item--child {
	height: 0;
	position: relative;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
	transition: all 0.4s linear;
}
.c-qa__item {
	position: relative;
}
.c-qa__item--parent {
	border-top: var(--color-border) solid 1px;
	border-bottom: var(--color-border) solid 1px;
	font-size: 1.6rem;
}
.c-qa__item--parent::after {
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-plus);
	display: block;
	width: 16px;
	height: 16px;
	font-size: 16px;
	position: absolute;
	right: 18px;
	top: 0;
	bottom: 0;
	margin: auto;
	color: var(--color-prim);
	visibility: hidden;
}
.c-qa__item--child {
	font-size: 1.4rem;
}
.c-qa__item-inner {
	position: relative;
	line-height: var(--line-height-m);
	display: flex;
}
.c-qa__item-inner::before {
	content: attr(title);
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1;
	display: inline-block;
	margin-top: 3px;
	padding-right: 20px;
}
.c-qa__item-inner--parent {
	padding: 16px 36px 16px 16px;
}
.c-qa__item-inner--parent::before {
	color: var(--color-prim);
}
.c-qa__item-inner--child {
	margin-bottom: 16px;
	padding: 16px 36px 16px 18px;
	background: var(--color-bg);
}
.c-qa__item-inner--child::before {
	color: var(--color-txt);
}
.c-qa__item-txt {
	flex: 1;
}
.c-qa.is-active:not(.is-disabled) .c-qa__item--parent {
	border-bottom: none;
}
.c-qa.is-active:not(.is-disabled) .c-qa__item--parent::after {
	content: var(--icon-minus);
}
.c-qa.is-active:not(.is-disabled) .c-qa__item--child {
	height: auto;
	opacity: 1;
	pointer-events: all;
}
@media (min-width: 768px), print {
	.c-qa__item--parent {
		font-size: 1.8rem;
	}
	.c-qa__item--child {
		font-size: 1.6rem;
	}
	.c-qa__item--child.is-active {
		margin-bottom: 0;
	}
	.c-qa__item-inner--parent {
		padding: 24px 20px;
	}
	.c-qa__item-inner::before {
		font-size: 2rem;
		margin-top: 5px;
	}
	.c-qa__item-inner--child {
		margin: 10px 0 30px 60px;
		padding: 24px;
		background: var(--color-bg);
	}
}

/*----------
	slider
----------*/
.c-slider {
	position: relative;
}
.c-slider:not(.is-initialized) {
	padding: 0;
}
.c-slider:not(.is-initialized) .c-slider__wrapper {
	display: block;
}
.c-slider:not(.is-initialized) .c-slider__inner {
	max-width: none;
}
.c-slider:not(.is-initialized) .c-slider__item {
	opacity: 1;
	transition: none;
}
.c-slider:not(.is-initialized) .c-slider__image {
	height: 100%;
}
.c-slider:not(.is-initialized) .c-slider__image > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.c-slider:not(.is-initialized) .c-slider__controllers {
	display: none;
}
.c-slider:not(.is-initialized) .c-slider__prev,
.c-slider:not(.is-initialized) .c-slider__next {
	display: none;
}
.c-slider__inner {
	position: relative;
}
.c-slider__item {
	position: relative;
}
.c-slider__content {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	justify-content: flex-end;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 9.866% 9.866% 13.333%;
}
.c-slider__copy {
	font-size: 2.1rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	color: #fff;
}
.c-slider__button {
	margin: 30px 0 0;
	width: 100%;
	max-width: 160px;
}
.c-slider__image {
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
}
.c-slider__image > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.c-slider__controllers {
	position: static;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 20px auto 0;
}
.c-slider__arrow-prev, .c-slider__arrow-next {
	cursor: pointer;
	color: var(--color-txt);
}
.c-slider__pagination {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 6px;
}
.c-slider__bullet {
	display: block;
	width: 8px;
	height: 8px;
	margin: 0 8px;
	border-radius: 50%;
	background: #aaa;
	cursor: pointer;
}
.c-slider__bullet.is-active {
	background: var(--color-prim);
}
@media (max-width: 767px) {
	.c-slider .c-slider__item {
		height: 450px;
	}
	.c-slider__prev, .c-slider__next {
		display: none;
	}
}
@media (min-width: 768px), print {
	.c-slider {
		padding: 0 40px;
	}
	.c-slider:not(.is-fade) .c-slider__item {
		opacity: 0.7;
		transition: opacity 0.3s ease 0.3s;
	}
	.c-slider:not(.is-fade) .c-slider__item.is-active {
		opacity: 1;
	}
	.c-slider__inner {
		max-width: 1200px;
		margin: 0 auto;
		overflow: visible;
	}
	.c-slider__content {
		margin: 0 100px;
		padding: 20px 20px 100px;
	}
	.c-slider__copy {
		font-size: 5rem;
	}
	.c-slider__button {
		margin-top: 40px;
		max-width: 312px;
	}
	.c-slider__image {
		position: static;
	}
	.c-slider__controllers {
		justify-content: center;
		position: absolute;
		bottom: 0;
		left: 0;
		right: 0;
		z-index: 1;
		margin: 0 auto 30px;
	}
	.c-slider__prev {
		position: absolute;
		top: 50%;
		left: 0;
		z-index: 2;
		font-size: 4.8rem;
		color: var(--color-txt);
		transform: translate(-50%, -50%);
		cursor: pointer;
	}
	.c-slider__next {
		position: absolute;
		top: 50%;
		right: 0;
		z-index: 2;
		font-size: 4.8rem;
		color: var(--color-txt);
		transform: translate(50%, -50%);
		cursor: pointer;
	}
}

/*----------
	kv
----------*/
.c-kv {
	position: relative;
	padding: 114px 20px 90px;
	background: var(--color-bg);
	overflow: hidden;
}
.c-kv__inner {
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
}
.c-kv__image {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}
.c-kv__image > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.c-kv__content {
	position: relative;
}
.c-kv__title {
	font-size: 3.2rem;
	font-weight: bold;
	line-height: 1.2;
}
.c-kv__text {
	margin-top: 32px;
	line-height: var(--line-height-m);
}
.c-kv__button {
	margin: 32px auto 0;
}
@media (min-width: 768px), print {
	.c-kv {
		padding: 160px 24px 190px;
	}
	.c-kv__title {
		font-size: 4rem;
	}
	.c-kv__button {
		margin-top: 40px;
		max-width: 400px;
	}
}

/*----------
	kv v2
----------*/
.c-kv-v2__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px), print {
	.c-kv-v2__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-kv-v2__content {
	padding: 0 20px;
}
.c-kv-v2__title {
	font-weight: bold;
	font-size: 3.2rem;
	line-height: var(--line-height-s);
}
.c-kv-v2__text {
	margin-top: 8px;
}
.c-kv-v2__button {
	margin: 24px auto 0;
}
@media (max-width: 767px) {
	.c-kv-v2__inner {
		padding-left: 0;
		padding-right: 0;
	}
	.c-kv-v2__image {
		margin-bottom: 16px;
	}
	.c-kv-v2__title {
		text-align: center;
	}
	.c-kv-v2__text {
		text-align: center;
	}
}
@media (min-width: 768px), print {
	.c-kv-v2__inner {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.c-kv-v2__image {
		flex: 0 0 calc(50% - 80px);
		margin-right: 80px;
	}
	.c-kv-v2__content {
		flex: 1 0 calc(50% - 80px);
		padding: 0;
	}
	.c-kv-v2__title {
		font-size: 4rem;
	}
	.c-kv-v2__text {
		margin-top: 23px;
	}
	.c-kv-v2__button {
		max-width: 312px;
		margin-top: 40px;
		margin-left: 0;
		padding: 0;
	}
}

/*----------
	kv v3
----------*/
.c-kv-v3 {
	padding: 30px 20px 40px;
	background: var(--color-bg);
}
.c-kv-v3__lead {
	font-size: 2rem;
	font-weight: bold;
	text-align: center;
	line-height: 1.3;
}
.c-kv-v3__button {
	margin: 32px auto 0;
}
@media (min-width: 768px), print {
	.c-kv-v3 {
		padding: 37px 20px 46px;
	}
	.c-kv-v3__inner {
		max-width: 760px;
		margin: 0 auto;
	}
	.c-kv-v3__lead {
		font-size: 2.8rem;
	}
	.c-kv-v3__button {
		margin-top: 40px;
		max-width: 400px;
	}
}

/*----------
	contact
----------*/
.c-contact {
	padding: 55px 0;
	background: var(--color-bg);
	color: #3B4043;
	text-align: center;
}
.c-contact__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
}
@media (min-width: 768px), print {
	.c-contact__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-contact__lead {
	margin-bottom: 8px;
	font-weight: bold;
	font-size: 2rem;
}
.c-contact__title {
	font-size: 1.4rem;
}
.c-contact__address {
	margin-top: 20px;
}
.c-contact__phone > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 60px;
	font-size: 2.2rem;
	line-height: 1;
	font-weight: bold;
	background: var(--color-prim);
	color: #fff;
}
.c-contact__icon {
	height: auto;
	margin-right: 12px;
}
.c-contact__icon--phone {
	width: 32px;
	font-size: 0;
}
.c-contact__icon--freecall {
	width: 44px;
	font-size: 0;
}
.c-contact__detail {
	margin-top: 10px;
	font-size: 1.2rem;
	line-height: var(--line-height-m);
	color: var(--color-txt-caption-v2);
}
@media (max-width: 767px) {
	.c-contact {
		margin-left: -20px;
		margin-right: -20px;
	}
}
@media (min-width: 768px), print {
	.c-contact {
		padding: 43px 0 54px;
	}
	.c-contact__lead {
		margin-bottom: 25px;
		font-size: 2.4rem;
	}
	.c-contact__title {
		font-size: 1.6rem;
	}
	.c-contact__address {
		margin-top: 10px;
		margin-left: auto;
		margin-right: auto;
		max-width: 440px;
	}
	.c-contact__phone > a {
		background: none;
		pointer-events: none;
		font-size: 5.6rem;
		color: #3B4043;
	}
	.c-contact__icon {
		margin-right: 6px;
	}
	.c-contact__icon--phone {
		width: 80px;
	}
	.c-contact__icon--freecall {
		width: 80px;
	}
	.c-contact__detail {
		margin-top: 10px;
		font-size: 1.6rem;
	}
}

/*----------
	contact
----------*/
.c-contactset {
	padding: 40px 20px;
	background-image: linear-gradient(150deg, rgba(187, 187, 187, 1), rgba(221, 221, 221, 1));
	color: var(--color-txt);
	text-align: left;
}
.c-contactset__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	background-color: #fff;
	text-align: center;
}
.c-contactset__header {
	padding: 30px 30px 40px;
	border-bottom: 1px solid var(--color-border);
}
.c-contactset__header-item {
	text-align: left;
}
.c-contactset__header-title {
	font-size: 2rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	padding: 0 0 0 18px;
	position: relative;
}
.c-contactset__header-title::before {
	position: absolute;
	content: "";
	width: 4px;
	height: 25px;
	background: var(--color-prim);
	left: 0;
	top: 5px;
}
.c-contactset__header-text {
	margin-top: 30px;
	font-size: 1.6rem;
	font-weight: 500;
}
.c-contactset__header-button {
	margin-top: 30px;
}
.c-contactset__cv > a {
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 64px;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
	background-color: var(--color-txt);
	border: 1px solid var(--color-txt);
	color: #fff;
	border-radius: 36px;
	cursor: pointer;
}
.c-contactset__cv > a > span {
	padding: 8px 40px;
	text-align: center;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	color: inherit;
}
.c-contactset__cv i[class^=icon-] {
	width: 1em;
	height: 1em;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 16px;
	line-height: 1;
	color: inherit;
	font-size: 1.2rem;
}
.c-contactset__title {
	font-size: 1.6rem;
	font-weight: 500;
}
.c-contactset__address {
	margin-top: 20px;
}
.c-contactset__phone > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	min-height: 60px;
	font-size: 2.2rem;
	line-height: 1;
	font-weight: bold;
	background: var(--color-prim);
	border-radius: 36px;
	color: #fff;
}
.c-contactset__freecall > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	font-size: 2.2rem;
	line-height: 1;
	font-weight: bold;
	border: 1px solid var(--color-txt-caption);
	background: #fff;
	color: var(--color-txt);
}
.c-contactset__mail {
	word-break: break-all;
	line-height: 1;
}
.c-contactset__mail > a {
	display: flex;
	width: 100%;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	color: var(--color-txt);
	font-size: 2.4rem;
	font-weight: bold;
}
.c-contactset__icon {
	height: auto;
	color: var(--color-prim);
}
.c-contactset__icon--phone {
	display: none;
}
.c-contactset__icon--freecall {
	width: 44px;
	font-size: 0;
}
.c-contactset__icon--mail {
	margin-top: 4px;
	margin-right: 10px;
	font-size: 2.4rem;
}
.c-contactset__detail {
	margin-top: 10px;
	font-size: 1.2rem;
	line-height: var(--line-height-m);
	color: var(--color-txt-caption-v2);
}
@media (max-width: 767px) {
	.c-contactset__item {
		padding: 30px 30px 40px;
		border-bottom: 1px solid var(--color-border);
	}
}
@media (min-width: 768px), print {
	.c-contactset {
		padding: 80px 40px 90px;
	}
	.c-contactset__inner {
		max-width: 1200px;
		padding-left: 0;
		padding-right: 0;
	}
	.c-contactset__header {
		padding: 70px 80px;
	}
	.c-contactset__header-item {
		display: flex;
		justify-content: space-around;
		gap: 80px 50px;
	}
	.c-contactset__header-body {
		flex: 1;
	}
	.c-contactset__header-title {
		font-size: 2.6rem;
	}
	.c-contactset__header-title::before {
		width: 5px;
		height: 32px;
	}
	.c-contactset__header-text {
		font-size: 1.8rem;
		margin-top: 20px;
	}
	.c-contactset__header-button {
		width: 42.31%;
		margin-top: 10px;
	}
	.c-contactset__cv > a {
		min-height: 72px;
		transition: all 0.2s;
	}
	.c-contactset__cv > a:hover {
		background-color: #fff;
		color: var(--color-txt);
	}
	.c-contactset__cv i[class^=icon-] {
		font-size: 1.4rem;
	}
	.c-contactset__title {
		font-size: 1.8rem;
	}
	.c-contactset__address {
		margin-top: 12px;
		margin-left: auto;
		margin-right: auto;
		max-width: 400px;
	}
	.c-contactset__phone > a {
		min-height: 0;
		background: none;
		pointer-events: none;
		font-size: 2.8rem;
		color: var(--color-txt);
	}
	.c-contactset__freecall > a {
		background: none;
		pointer-events: none;
		font-size: 4.2rem;
		color: var(--color-txt);
		border: none;
	}
	.c-contactset__mail > a {
		font-size: 2.8rem;
		transition: color 0.3s;
	}
	.c-contactset__mail > a:hover {
		color: var(--color-txt-hover);
	}
	.c-contactset__icon {
		color: var(--color-prim);
	}
	.c-contactset__icon--phone {
		display: inline-block;
		margin-top: 5px;
		font-size: 2.7rem;
	}
	.c-contactset__icon--freecall {
		width: 70px;
		margin-right: 16px;
	}
	.c-contactset__icon--mail {
		display: inline-block;
		margin-top: 5px;
		margin-right: 9px;
		font-size: 2.7rem;
	}
	.c-contactset__detail {
		margin-top: 23px;
	}
	.c-contactset--2up .c-contactset__items {
		display: flex;
		justify-content: center;
		flex-wrap: wrap;
	}
	.c-contactset--2up .c-contactset__item {
		width: 50%;
		padding: 45px 80px 50px;
	}
	.c-contactset--2up .c-contactset__item + .c-contactset__item {
		border-left: 1px solid var(--color-border);
	}
}

/*----------
	radio-container
----------*/
.g-radio-container__item {
	display: table;
}
.g-radio-container__item + .g-radio-container__item {
	margin-top: 16px;
}

/*----------
	checkbox-container
----------*/
.g-checkbox-container__item {
	display: table;
}
.g-checkbox-container__item + .g-checkbox-container__item {
	margin-top: 16px;
}

/*----------
	radio
----------*/
.c-radio {
	cursor: pointer;
}
.c-radio input[type=radio] {
	position: absolute;
	clip: rect(0 0 0 0);
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	border: 0;
}
.c-radio input[type=radio]:checked + span {
	color: var(--color-txt);
}
.c-radio input[type=radio]:checked + span::before {
	background-image: url(/assets/images/marker_radio_on.svg);
}
.c-radio span {
	position: relative;
	padding-left: 32px;
	display: inline-block;
	line-height: 2.4rem;
	text-align: left;
}
.c-radio span::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 24px;
	height: 24px;
	margin-right: 8px;
	background: #fff url(/assets/images/marker_radio.svg) no-repeat center;
	background-size: contain;
}
.c-radio span a {
	text-decoration: underline;
}
.c-radio.is-error {
	color: var(--color-caution);
}
.c-radio.is-error span::before {
	margin-right: 8px;
	background-image: url(/assets/images/marker_radio_error.svg);
}
.is-error .c-radio {
	color: var(--color-caution);
}
.is-error .c-radio span::before {
	margin-right: 8px;
	background-image: url(/assets/images/marker_radio_error.svg);
}

/*----------
	checkbox
----------*/
.c-checkbox {
	cursor: pointer;
}
.c-checkbox input[type=checkbox] {
	position: absolute;
	clip: rect(0 0 0 0);
	width: 1px;
	height: 1px;
	margin: -1px;
	padding: 0;
	overflow: hidden;
	border: 0;
}
.c-checkbox input[type=checkbox]:checked + span {
	color: var(--color-txt);
}
.c-checkbox input[type=checkbox]:checked + span::before {
	background-image: url(/assets/images/marker_checkbox_on.svg);
}
.c-checkbox span {
	position: relative;
	padding-left: 32px;
	display: inline-block;
	line-height: 2.4rem;
	text-align: left;
}
.c-checkbox span::before {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 24px;
	height: 24px;
	margin-right: 8px;
	background: #fff url(/assets/images/marker_checkbox.svg) no-repeat center;
	background-size: contain;
}
.c-checkbox span a {
	text-decoration: underline;
	color: var(--color-prim);
}
.c-checkbox span i[class^=icon-] {
	text-indent: 0;
	font-size: 1.2rem;
	color: var(--color-prim);
}
.c-checkbox.is-error {
	color: var(--color-caution);
}
.c-checkbox.is-error span::before {
	margin-right: 8px;
	background-image: url(/assets/images/marker_checkbox_error.svg);
}
.is-error .c-checkbox {
	color: var(--color-caution);
}
.is-error .c-checkbox span::before {
	margin-right: 8px;
	background-image: url(/assets/images/marker_checkbox_error.svg);
}

/*----------
	input
----------*/
.c-input > input[type=text],
.c-input > input[type=number],
.c-input > input[type=email] {
	display: block;
	width: 100%;
	height: 48px;
	padding: 17px 15px;
	border: 1px solid var(--color-border-v2);
	border-radius: 5px;
	appearance: none;
	-webkit-appearance: none;
}
.c-input > input[type=text]:focus,
.c-input > input[type=number]:focus,
.c-input > input[type=email]:focus {
	outline: none;
}
.c-input > input[type=text]:focus-visible,
.c-input > input[type=number]:focus-visible,
.c-input > input[type=email]:focus-visible {
	outline: 1px solid #ccc;
}
.c-input > input[type=text]::placeholder,
.c-input > input[type=number]::placeholder,
.c-input > input[type=email]::placeholder {
	color: var(--color-txt-caption);
}
.c-input > input[type=text]::-webkit-input-placeholder,
.c-input > input[type=number]::-webkit-input-placeholder,
.c-input > input[type=email]::-webkit-input-placeholder {
	color: var(--color-txt-caption);
}
.c-input > input[type=text]:-moz-placeholder,
.c-input > input[type=number]:-moz-placeholder,
.c-input > input[type=email]:-moz-placeholder {
	color: var(--color-txt-caption);
}
.c-input > input[type=text]::-moz-placeholder,
.c-input > input[type=number]::-moz-placeholder,
.c-input > input[type=email]::-moz-placeholder {
	color: var(--color-txt-caption);
}
.c-input > input[type=text]:-ms-input-placeholder,
.c-input > input[type=number]:-ms-input-placeholder,
.c-input > input[type=email]:-ms-input-placeholder {
	color: var(--color-txt-caption);
}
@media (min-width: 768px), print {
	.c-input > input[type=text],
	.c-input > input[type=number],
	.c-input > input[type=email] {
		height: 56px;
	}
}
.c-input.is-error > input[type=text],
.c-input.is-error > input[type=number],
.c-input.is-error > input[type=email] {
	color: var(--color-caution);
	border-color: var(--color-caution);
	background: #FEDFDF;
}

/*----------
	input v2
----------*/
.c-input-v2 > input[type=text],
.c-input-v2 > input[type=number],
.c-input-v2 > input[type=email] {
	display: block;
	width: 100%;
	height: 48px;
	padding: 12px 18px;
	border: 1px solid var(--color-border-v2);
	border-radius: 6px;
	appearance: none;
	-webkit-appearance: none;
}
.c-input-v2 > input[type=text]:focus,
.c-input-v2 > input[type=number]:focus,
.c-input-v2 > input[type=email]:focus {
	outline: none;
}
.c-input-v2 > input[type=text]:focus-visible,
.c-input-v2 > input[type=number]:focus-visible,
.c-input-v2 > input[type=email]:focus-visible {
	outline: 1px solid #ccc;
}
.c-input-v2 > input[type=text]::placeholder,
.c-input-v2 > input[type=number]::placeholder,
.c-input-v2 > input[type=email]::placeholder {
	color: var(--color-txt-caption);
}
.c-input-v2 > input[type=text]::-webkit-input-placeholder,
.c-input-v2 > input[type=number]::-webkit-input-placeholder,
.c-input-v2 > input[type=email]::-webkit-input-placeholder {
	color: var(--color-txt-caption);
}
.c-input-v2 > input[type=text]:-moz-placeholder,
.c-input-v2 > input[type=number]:-moz-placeholder,
.c-input-v2 > input[type=email]:-moz-placeholder {
	color: var(--color-txt-caption);
}
.c-input-v2 > input[type=text]::-moz-placeholder,
.c-input-v2 > input[type=number]::-moz-placeholder,
.c-input-v2 > input[type=email]::-moz-placeholder {
	color: var(--color-txt-caption);
}
.c-input-v2 > input[type=text]:-ms-input-placeholder,
.c-input-v2 > input[type=number]:-ms-input-placeholder,
.c-input-v2 > input[type=email]:-ms-input-placeholder {
	color: var(--color-txt-caption);
}
.c-input-v2.is-error > input[type=text],
.c-input-v2.is-error > input[type=number],
.c-input-v2.is-error > input[type=email] {
	color: var(--color-caution);
	border-color: var(--color-caution);
	background: #FEDFDF;
}
@media (min-width: 768px), print {
	.c-input-v2 > input[type=text],
	.c-input-v2 > input[type=number],
	.c-input-v2 > input[type=email] {
		height: 56px;
		padding: 16px 20px;
	}
}

/*----------
	textarea
----------*/
.c-textarea > textarea {
	display: block;
	width: 100%;
	min-height: 211px;
	padding: 17px 15px;
	border: 1px solid var(--color-border-v2);
	border-radius: 5px;
	appearance: none;
	-webkit-appearance: none;
}
.c-textarea > textarea:focus {
	outline: none;
}
.c-textarea > textarea:focus-visible {
	outline: 1px solid #ccc;
}
.c-textarea > textarea::placeholder {
	color: var(--color-txt-caption);
}
.c-textarea > textarea::-webkit-input-placeholder {
	color: var(--color-txt-caption);
}
.c-textarea > textarea:-moz-placeholder {
	color: var(--color-txt-caption);
}
.c-textarea > textarea::-moz-placeholder {
	color: var(--color-txt-caption);
}
.c-textarea > textarea:-ms-input-placeholder {
	color: var(--color-txt-caption);
}
.c-textarea.is-error > textarea {
	color: var(--color-caution);
	border-color: var(--color-caution);
	background: #FEDFDF;
}

/*----------
	select
----------*/
.c-select {
	position: relative;
	cursor: pointer;
}
.c-select::after {
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-arrow2-b);
	font-size: 1.4rem;
	position: absolute;
	top: 50%;
	right: 16px;
	color: var(--color-txt-caption);
	transform: translateY(-50%);
	pointer-events: none;
}
.c-select > select {
	display: block;
	width: 100%;
	height: 48px;
	padding: 12px 42px 12px 16px;
	border: 1px solid var(--color-border-v2);
	border-radius: 5px;
	color: var(--color-txt);
	appearance: none;
	-webkit-appearance: none;
}
.c-select > select:focus {
	outline: none;
}
.c-select > select:focus-visible {
	outline: 1px solid #ccc;
}
.c-select > select::-ms-expand {
	display: none;
}
@media (min-width: 768px), print {
	.c-select::after {
		font-size: 1.6rem;
	}
	.c-select > select {
		height: 56px;
		padding: 16px 42px 16px 16px;
		transition: 0.3s all;
	}
	.c-select > select:hover {
		border: 1px solid var(--color-txt);
	}
}
.c-select.is-error::after {
	color: var(--color-caution);
}
.c-select.is-error > select {
	color: var(--color-caution);
	border-color: var(--color-caution);
	background: #FEDFDF;
}
.c-select:not(.is-selected):not(.parsley-success) > select {
	color: var(--color-txt);
}

/*----------
	select
----------*/
.c-select-v2 {
	position: relative;
	cursor: pointer;
}
.c-select-v2::after {
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-arrow2-b);
	font-size: 1.4rem;
	position: absolute;
	top: 50%;
	right: 16px;
	color: var(--color-txt-caption);
	transform: translateY(-50%);
	pointer-events: none;
}
.c-select-v2 > select {
	display: block;
	width: 100%;
	height: 48px;
	padding: 10px 50px 10px 14px;
	border: 1px solid var(--color-border-v2);
	border-radius: 6px;
	color: var(--color-txt);
	appearance: none;
	-webkit-appearance: none;
}
.c-select-v2 > select:focus {
	outline: none;
}
.c-select-v2 > select:focus-visible {
	outline: 1px solid #ccc;
}
.c-select-v2 > select::-ms-expand {
	display: none;
}
@media (min-width: 768px), print {
	.c-select-v2::after {
		font-size: 1.6rem;
	}
	.c-select-v2 > select {
		height: 56px;
		transition: 0.3s all;
	}
	.c-select-v2 > select:hover {
		border: 1px solid var(--color-txt);
	}
}
.c-select-v2.is-error::after {
	color: var(--color-caution);
}
.c-select-v2.is-error > select {
	color: var(--color-caution);
	border-color: var(--color-caution);
	background: #FEDFDF;
}
.c-select-v2:not(.is-selected):not(.parsley-success) > select {
	color: var(--color-txt);
}

/*----------
	inputset
----------*/
.c-inputset__required {
	display: inline-block;
	margin-left: 10px;
	padding: 3px 8px;
	font-size: 1rem;
	line-height: 1;
	color: var(--color-caution);
	border-radius: 16px;
	border: 1px solid var(--color-caution);
}
.c-inputset__note {
	margin-top: 12px;
	font-size: 1.2rem;
	line-height: 1.2;
	color: var(--color-txt-caption);
}
.c-inputset .parsley-errors-list {
	font-size: 1.2rem;
	line-height: 1.2;
	color: var(--color-caution);
}
.c-inputset .parsley-errors-list.filled {
	margin-top: 8px;
}
@media (max-width: 767px) {
	.c-inputset__inner, .c-inputset__body, .c-inputset__row {
		display: block;
		width: 100%;
	}
	.c-inputset__row {
		overflow: hidden;
	}
	.c-inputset__header, .c-inputset__subheader, .c-inputset__detail {
		clear: both;
		float: left;
		text-align: left;
	}
	.c-inputset__body {
		border-top: 1px solid var(--color-border);
		border-bottom: 1px solid var(--color-border);
	}
	.c-inputset__header {
		display: flex;
		align-items: center;
		justify-content: flex-start;
		width: 100%;
		padding: 11px 20px;
		font-size: 1.4rem;
		font-weight: 500;
		background: var(--color-bg-v2);
		color: var(--color-txt-caption-v2);
	}
	.c-inputset__subheader {
		display: block;
		width: 100%;
		padding: 12px 16px 13px;
		font-size: 1.4rem;
		color: var(--color-txt-caption-v2);
		border-top: 1px solid var(--color-border);
	}
	.c-inputset__detail {
		display: block;
		width: 100%;
		padding: 20px 16px;
		border-top: 1px solid var(--color-border);
	}
}
@media (min-width: 768px), print {
	.c-inputset__inner {
		width: 100%;
	}
	.c-inputset__header {
		vertical-align: middle;
		width: 300px;
		padding: 18px 16px;
		font-size: 1.6rem;
		font-weight: 500;
		background: var(--color-bg-v2);
		color: var(--color-txt-caption-v2);
		border: 1px solid var(--color-border);
		border-left: none;
		text-align: left;
	}
	.c-inputset__header--top {
		vertical-align: top;
	}
	.c-inputset__subheader {
		vertical-align: middle;
		width: 240px;
		padding: 18px 16px;
		font-size: 1.8rem;
		background: var(--color-bg-v2);
		color: var(--color-txt-caption-v2);
		text-align: left;
		border: 1px solid var(--color-border);
		border-left: none;
	}
	.c-inputset__subheader--top {
		vertical-align: top;
	}
	.c-inputset__detail {
		padding: 18px 40px;
		border: 1px solid var(--color-border);
		border-right: none;
		border-left: none;
	}
	.c-inputset__item--300 {
		max-width: 300px;
	}
	.c-inputset__item--340 {
		max-width: 340px;
	}
	.c-inputset__item--400 {
		max-width: 400px;
	}
	.c-inputset__item--420 {
		max-width: 420px;
	}
	.c-inputset__item--460 {
		max-width: 460px;
	}
	.c-inputset__note {
		font-size: 1.4rem;
	}
	.c-inputset .parsley-errors-list {
		font-size: 1.4rem;
	}
}

/*----------s
	personalset
----------*/
.c-personalset__policy {
	margin-top: 60px;
	color: var(--color-txt-caption);
	font-size: 1.4rem;
}
.c-personalset__policy-inner {
	height: 240px;
	margin: 20px auto 0;
	padding: 20px;
	border: 1px solid var(--color-border);
	overflow: auto;
}
.c-personalset__policy-title {
	margin-bottom: 8px;
	font-weight: bold;
	font-size: 1.6rem;
	color: #3B4043;
	text-align: center;
}
.c-personalset__agreement {
	margin: 30px auto 0;
}
.c-personalset__agreement-body {
	padding: 30px 16px;
	background: var(--color-bg-v2);
	text-align: center;
}
.c-personalset__agreement-check {
	display: table;
	margin: 20px auto 0;
}
.c-personalset__agreement_error {
	text-align: center;
}
.c-personalset__note {
	margin: 50px auto 0;
	line-height: var(--line-height-s);
	color: var(--color-txt);
	text-align: center;
}
.c-personalset__submit {
	margin: 30px auto 0;
}
.c-personalset__submit-inner {
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 48px;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
	background-color: var(--color-prim);
	border: 1px solid var(--color-prim);
	color: #fff;
	border-radius: 36px;
}
.c-personalset__submit-inner[disabled] {
	opacity: 0.6;
}
.c-personalset__submit-inner:not([disabled]) {
	cursor: pointer;
}
.c-personalset__submit-inner > span {
	padding: 8px 40px;
	text-align: center;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	color: inherit;
}
.c-personalset__submit-icon {
	width: 14px;
	height: 14px;
	font-size: 1.4rem;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 16px;
	line-height: 1;
	color: inherit;
}
.c-personalset .parsley-errors-list {
	font-size: 1.2rem;
	line-height: 1.2;
	color: var(--color-caution);
}
.c-personalset .parsley-errors-list.filled {
	margin-top: 8px;
}
@media (min-width: 768px), print {
	.c-personalset__policy {
		margin-top: 80px;
		padding: 36px 66px;
	}
	.c-personalset__policy-inner {
		padding: 30px;
	}
	.c-personalset__policy-title {
		margin-bottom: 17px;
		font-size: 1.8rem;
	}
	.c-personalset__agreement {
		max-width: 800px;
		margin: 40px auto 0;
	}
	.c-personalset__agreement-body {
		padding: 40px;
	}
	.c-personalset__note {
		margin: 80px auto 0;
	}
	.c-personalset__submit {
		max-width: 400px;
		margin: 40px auto 0;
	}
	.c-personalset__submit-inner {
		min-height: 56px;
		transition: all 0.2s;
	}
	.c-personalset__submit-inner > span {
		font-size: 1.6rem;
	}
	.c-personalset__submit-inner:not([disabled]) {
		opacity: 1;
	}
	.c-personalset__submit-inner:not([disabled]):hover {
		background-color: #fff;
		color: var(--color-prim);
	}
}

/*----------
	field
----------*/
/* お名前入力用 */
.c-field-name {
	display: grid;
	grid-template-rows: repeat(2, auto);
	grid-auto-flow: column;
	grid-auto-columns: 1fr;
	gap: 5px 10px;
}
.c-field-name__item {
	flex: 1;
}
.c-field-name__item + .c-field-name__item {
	margin-left: 10px;
}
@media (min-width: 768px), print {
	.c-field-name {
		display: flex;
		justify-content: center;
		gap: 0;
	}
	.c-field-name__label {
		display: flex;
		align-items: center;
		line-height: 50px;
		width: 35px;
		margin-right: 8px;
	}
	.c-field-name__item + .c-field-name__label {
		margin-left: 30px;
	}
}

/* 郵便番号入力用（検索ボタンも含む） */
.c-field-zip__items {
	display: flex;
	align-items: flex-start;
}
.c-field-zip__item {
	flex: 1;
}
.c-field-zip__hyphen {
	display: flex;
	align-items: center;
	margin: 0 8px;
	line-height: 50px;
}
.c-field-zip__search {
	display: block;
	margin: 15px auto 0;
	max-width: 200px;
}
.c-field-zip__search-inner {
	display: flex;
	align-items: center;
	width: 100%;
	min-height: 40px;
	border: 1px solid var(--color-txt-caption);
	box-sizing: border-box;
	border-radius: 30px;
	font-weight: 500;
	color: var(--color-txt);
	cursor: pointer;
}
.c-field-zip__search-inner > span {
	display: block;
	width: 100%;
	padding: 9px 10px 10px;
	text-align: center;
	font-size: 1.4rem;
	line-height: var(--line-height-s);
	color: inherit;
}
@media (min-width: 768px), print {
	.c-field-zip {
		display: flex;
		align-items: flex-start;
		flex-wrap: wrap;
		margin-bottom: -16px;
	}
	.c-field-zip__items {
		flex: 1;
		margin: 0 32px 16px 0;
	}
	.c-field-zip__item {
		min-width: 100px;
	}
	.c-field-zip__search {
		flex-basis: 142px;
		margin: 0 0 16px;
	}
	.c-field-zip__search-inner {
		transition: background-color 0.2s, color 0.2s;
	}
	.c-field-zip__search-inner:hover {
		background-color: #3B4043;
		color: #fff;
	}
}

/* 電話番号入力用 */
.c-field-tel {
	display: flex;
	align-items: flex-start;
	justify-content: center;
}
.c-field-tel__item {
	flex: 1;
}
.c-field-tel__hyphen {
	display: flex;
	align-items: center;
	margin: 0 8px;
	line-height: 50px;
}

/*----------
	single column
----------*/
.g-center-col__item + .g-center-col__item {
	margin-top: 40px;
}
@media (min-width: 768px), print {
	.g-center-col {
		display: flex;
		justify-content: center;
		align-items: flex-start;
	}
	.g-center-col__item {
		flex: 1 1 66.6666666667%;
		max-width: 75%;
	}
	.g-center-col__item + .g-center-col__item {
		margin-top: 0;
	}
	.g-center-col--small .g-center-col__item {
		flex-basis: 33.3333333333%;
		max-width: 33.3333333333%;
	}
	.g-center-col--2up .g-center-col__item {
		flex-basis: 33.3333333333%;
		max-width: 33.3333333333%;
	}
	.g-center-col--2up .g-center-col__item + .g-center-col__item {
		margin-left: 40px;
	}
}

/*----------
	grid
----------*/
.g-grid {
	margin: 0 auto;
}
@media (max-width: 767px) {
	.g-grid__item + .g-grid__item {
		margin-top: 40px;
	}
}
@media (min-width: 768px), print {
	.g-grid {
		display: grid;
		gap: 40px;
	}
	.g-grid--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-grid--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-grid--4up {
		grid-template-columns: repeat(4, 1fr);
	}
}

/*----------
	c-contactbox
----------*/
.c-contactbox {
	border: 1px solid var(--color-border);
	padding: 40px 30px;
}
.c-contactbox__head {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}
.c-contactbox__icon {
	margin-top: 3px;
	font-weight: normal;
}
.c-contactbox__icon::before {
	font-size: 2.1rem;
	color: var(--color-prim);
}
.c-contactbox__title {
	display: inline-block;
	font-size: 1.6rem;
	font-weight: 500;
	position: relative;
	margin-left: 12px;
}
.c-contactbox__text {
	margin-top: 20px;
	font-size: 1.4rem;
}
.c-contactbox__btn {
	margin-top: 20px;
}
@media (min-width: 768px), print {
	.c-contactbox {
		padding: 50px 100px 50px 80px;
		display: flex;
		align-items: center;
		justify-content: space-between;
	}
	.c-contactbox__body {
		max-width: 440px;
	}
	.c-contactbox__head {
		position: relative;
		justify-content: flex-start;
	}
	.c-contactbox__icon {
		margin-right: 16px;
	}
	.c-contactbox__icon::before {
		font-size: 2.7rem;
	}
	.c-contactbox__title {
		font-size: 1.8rem;
		margin-left: 0;
	}
	.c-contactbox__btn {
		margin-top: 8px;
		width: 39.294%;
	}
}

/*----------
	c-contactbox-v
----------*/
.c-contactbox-v {
	border: 1px solid var(--color-border);
	padding: 40px 30px;
}
.c-contactbox-v__head {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}
.c-contactbox-v__title {
	display: inline-block;
	font-size: 1.6rem;
	font-weight: 500;
	position: relative;
	margin-left: 12px;
}
.c-contactbox-v__icon {
	margin-top: 3px;
	font-weight: normal;
}
.c-contactbox-v__icon::before {
	font-size: 2.1rem;
	color: var(--color-prim);
}
.c-contactbox-v__text {
	margin-top: 13px;
	font-size: 1.4rem;
}
.c-contactbox-v__btn {
	margin-top: 20px;
}
@media (min-width: 768px), print {
	.c-contactbox-v {
		padding: 40px;
		display: flex;
		flex-direction: column;
		padding: 40px 80px;
	}
	.c-contactbox-v__head {
		position: relative;
	}
	.c-contactbox-v__icon {
		margin-right: 16px;
	}
	.c-contactbox-v__icon::before {
		font-size: 2.7rem;
	}
	.c-contactbox-v__title {
		margin-left: 0;
		font-size: 1.8rem;
	}
	.c-contactbox-v__body {
		flex: 1;
		display: flex;
		flex-direction: column;
		margin-top: 20px;
	}
	.c-contactbox-v__text {
		text-align: center;
		margin-bottom: 30px;
	}
	.c-contactbox-v__btn {
		margin-top: auto;
	}
}

/*----------
	contactbox-v-container
----------*/
.g-contactbox-v-container {
	margin: 0 auto;
}
@media (max-width: 767px) {
	.g-contactbox-v-container__item + .g-contactbox-v-container__item {
		position: relative;
		margin-top: -1px;
	}
}
@media (min-width: 768px), print {
	.g-contactbox-v-container {
		display: grid;
	}
	.g-contactbox-v-container--2up {
		grid-template-columns: repeat(2, 1fr);
	}
	.g-contactbox-v-container--2up .g-contactbox-v-container__item:nth-child(n+3) {
		margin-top: -1px;
	}
	.g-contactbox-v-container--3up {
		grid-template-columns: repeat(3, 1fr);
	}
	.g-contactbox-v-container--3up .g-contactbox-v-container__item:nth-child(n+4) {
		margin-top: -1px;
	}
	.g-contactbox-v-container--4up {
		grid-template-columns: repeat(4, 1fr);
	}
	.g-contactbox-v-container--4up .g-contactbox-v-container__item:nth-child(n+5) {
		margin-top: -1px;
	}
	.g-contactbox-v-container__item + .g-contactbox-v-container__item {
		margin-left: -1px;
	}
}

/*----------
	copy-card
----------*/
.c-copy-card {
	position: relative;
	margin-bottom: 80px;
}
.c-copy-card__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	height: 100%;
	display: block;
	cursor: pointer;
	padding: 30px 38px 40px;
}
@media (min-width: 768px), print {
	.c-copy-card__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-copy-card__image {
	position: relative;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.c-copy-card__image > img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.c-copy-card__copy {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.7;
	color: var(--color-txt);
}
.c-copy-card__button {
	margin: 30px 0 0;
	width: 100%;
}
@media (max-width: 767px) {
	.c-copy-card__inner {
		background-color: var(--color-bg);
	}
	.c-copy-card__image {
		padding-bottom: 66.6666666667%;
	}
}
@media (min-width: 768px), print {
	.c-copy-card {
		margin-bottom: 120px;
		overflow: hidden;
	}
	.c-copy-card::before {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		bottom: 0;
		z-index: 0;
		background: linear-gradient(270deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
		pointer-events: none;
	}
	.c-copy-card:hover .c-copy-card__image {
		transform: scale(1.05);
	}
	.c-copy-card__inner {
		position: relative;
		width: 100%;
		min-height: 480px;
		padding-top: 120px;
		pointer-events: none;
	}
	.c-copy-card__copy {
		max-width: 600px;
		font-size: 3.2rem;
		line-height: var(--line-height-s);
		color: #fff;
	}
	.c-copy-card__image {
		position: absolute;
		top: 0;
		left: 0;
		transition: 0.3s all;
	}
	.c-copy-card__button {
		margin-top: 40px;
		max-width: 300px;
		pointer-events: auto;
	}
}

/*----------
	c-copy-card-v2
----------*/
.c-copy-card-v2 {
	position: relative;
	margin-bottom: 30px;
}
.c-copy-card-v2__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	height: 100%;
	display: block;
	cursor: pointer;
	padding: 30px 38px 40px;
}
@media (min-width: 768px), print {
	.c-copy-card-v2__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-copy-card-v2__image {
	position: relative;
	width: 100%;
	height: 100%;
	z-index: 0;
}
.c-copy-card-v2__image > img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.c-copy-card-v2__copy {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	color: var(--color-txt);
}
.c-copy-card-v2__button {
	margin: 30px 0 0;
	width: 100%;
}
@media (max-width: 767px) {
	.c-copy-card-v2 {
		margin-left: -6.6666666667%;
		margin-right: -6.6666666667%;
	}
	.c-copy-card-v2__inner {
		background-color: var(--color-bg);
	}
	.c-copy-card-v2__image {
		padding-bottom: 66.6666666667%;
	}
}
@media (min-width: 768px), print {
	.c-copy-card-v2 {
		margin-bottom: 40px;
		overflow: hidden;
	}
	.c-copy-card-v2::before {
		content: "";
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		bottom: 0;
		z-index: 1;
		background: linear-gradient(270deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
		pointer-events: none;
	}
	.c-copy-card-v2:hover .c-copy-card-v2__image {
		transform: scale(1.05);
	}
	.c-copy-card-v2__inner {
		position: relative;
		width: 100%;
		min-height: 400px;
		padding-top: 120px;
		padding-left: 80px;
		z-index: 2;
		pointer-events: none;
	}
	.c-copy-card-v2__copy {
		max-width: 600px;
		font-size: 2.8rem;
		color: #fff;
	}
	.c-copy-card-v2__image {
		position: absolute;
		top: 0;
		left: 0;
		transition: 0.3s all;
	}
	.c-copy-card-v2__button {
		margin-top: 40px;
		max-width: 300px;
		pointer-events: auto;
	}
}

/*----------
	copy-imgset
----------*/
.c-copy-imgset {
	position: relative;
	margin-bottom: 80px;
}
.c-copy-imgset__inner {
	height: 100%;
	display: block;
	cursor: pointer;
	padding: 30px 38px 40px;
	background-color: var(--color-bg);
}
.c-copy-imgset__image {
	position: relative;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.c-copy-imgset__image > img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.c-copy-imgset__copy {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-l);
	color: var(--color-txt);
}
.c-copy-imgset__button {
	margin: 30px 0 0;
	width: 100%;
}
@media (max-width: 767px) {
	.c-copy-imgset {
		margin-left: -6.6666666667%;
		margin-right: -6.6666666667%;
	}
	.c-copy-imgset__image {
		padding-bottom: 66.6666666667%;
	}
}
@media (min-width: 768px), print {
	.c-copy-imgset {
		min-height: 400px;
		margin-bottom: 120px;
	}
	.c-copy-imgset__inner {
		width: 50%;
		max-width: 600px;
		height: auto;
		min-height: 309px;
		padding: 70px 60px;
		position: absolute;
		top: 46px;
		right: 0;
	}
	.c-copy-imgset__copy {
		font-size: 2.2rem;
	}
	.c-copy-imgset__image {
		position: absolute;
		top: 0;
		left: 0;
		width: calc(50% + 100px);
	}
	.c-copy-imgset__button {
		margin-top: 30px;
		max-width: 300px;
	}
}

/*----------
	pagination
----------*/
.c-pagination-v2__inner {
	position: relative;
	display: table;
	margin: auto;
	padding: 0 60px;
}
.c-pagination-v2__items {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin-bottom: -8px;
}
.c-pagination-v2__arrow {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}
.c-pagination-v2__arrow--prev {
	left: 0;
}
.c-pagination-v2__arrow--next {
	right: 0;
}
.c-pagination-v2__item {
	margin: 0 4px 8px;
}
.c-pagination-v2__item > a {
	display: block;
	color: inherit;
}
.c-pagination-v2__item--current {
	pointer-events: none;
}
.c-pagination-v2__page {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	text-align: center;
	font-size: 1.4rem;
	line-height: 34px;
	font-weight: 500;
	border: 1px solid var(--color-border-v2);
	border-radius: 50%;
	color: var(--color-txt);
}
.c-pagination-v2__page--current {
	background: var(--color-prim);
	border: 1px solid var(--color-prim);
	color: #fff;
}
.c-pagination-v2__ellip {
	display: block;
	width: 24px;
	height: 32px;
	font-size: 0;
	background: radial-gradient(var(--color-txt) 1px, transparent 1px) repeat-x left center;
	background-size: 8px 8px;
}
.c-pagination-v2__prev, .c-pagination-v2__next {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	text-align: center;
	font-size: 1.4rem;
	line-height: 34px;
	font-weight: 500;
	border: 1px solid var(--color-border-v2);
	border-radius: 50%;
}
@media (min-width: 768px), print {
	.c-pagination-v2__page, .c-pagination-v2__prev, .c-pagination-v2__next {
		width: 56px;
		height: 56px;
		font-size: 1.6rem;
	}
}
@media (min-width: 768px), print {
	.c-pagination-v2 a .c-pagination-v2__page,
	.c-pagination-v2 a .c-pagination-v2__prev,
	.c-pagination-v2 a .c-pagination-v2__next {
		transition: 0.3s all;
	}
	.c-pagination-v2 a:hover .c-pagination-v2__page,
	.c-pagination-v2 a:hover .c-pagination-v2__prev,
	.c-pagination-v2 a:hover .c-pagination-v2__next {
		border-color: var(--color-txt);
		color: var(--color-txt);
	}
}

/*----------
	c-contactset-v2
----------*/
.c-contactset-v2 {
	padding: 40px 20px;
	background: var(--color-bg);
	color: var(--color-txt);
	text-align: left;
}
.c-contactset-v2 + .c-contactset-v2 {
	margin-top: -40px;
	padding-top: 20px;
}
@media (min-width: 768px), print {
	.c-contactset-v2 + .c-contactset-v2 {
		margin-top: -90px;
		padding-top: 40px;
	}
}
.c-contactset-v2__inner {
	width: 100%;
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	background-color: #fff;
	text-align: center;
}
.c-contactset-v2__header-body {
	text-align: left;
}
.c-contactset-v2__header-title {
	font-size: 2rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	padding: 0 0 0 18px;
	position: relative;
}
.c-contactset-v2__header-title::before {
	position: absolute;
	content: "";
	width: 4px;
	height: 25px;
	background: var(--color-prim);
	left: 0;
	top: 5px;
}
.c-contactset-v2__header-text {
	margin-top: 20px;
	font-size: 1.6rem;
	font-weight: 500;
}
.c-contactset-v2__header-button {
	margin-top: 20px;
}
.c-contactset-v2__title {
	font-size: 1.6rem;
}
.c-contactset-v2__address {
	margin-top: 20px;
}
.c-contactset-v2__phone > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 60px;
	font-size: 2.2rem;
	line-height: 1;
	font-weight: 500;
	background: var(--color-prim);
	border-radius: 36px;
	color: #fff;
}
.c-contactset-v2__freecall > a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	min-height: 60px;
	font-size: 2.2rem;
	line-height: 1;
	font-weight: bold;
	border: 1px solid var(--color-txt-caption);
	background: #fff;
	color: var(--color-txt);
}
.c-contactset-v2__mail {
	word-break: break-all;
	line-height: 1;
}
.c-contactset-v2__mail > a {
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	overflow: hidden;
	color: var(--color-txt);
	font-size: 2.4rem;
	font-weight: bold;
}
.c-contactset-v2__icon {
	height: auto;
	padding-top: 5px;
	color: var(--color-prim);
}
.c-contactset-v2__icon--phone {
	display: none;
}
.c-contactset-v2__icon--freecall {
	width: 44px;
	font-size: 0;
}
.c-contactset-v2__icon--mail {
	margin-right: 10px;
	font-size: 2.4rem;
}
.c-contactset-v2__detail {
	margin-top: 20px;
	font-size: 1.2rem;
	line-height: var(--line-height-l);
	color: var(--color-txt-caption-v2);
}
.c-contactset-v2__btn {
	margin-bottom: 0;
}
@media (max-width: 767px) {
	.c-contactset-v2__item {
		padding: 40px 8.9552238%;
	}
	.c-contactset-v2__item + .c-contactset-v2__item {
		padding-top: 0;
	}
}
@media (min-width: 768px), print {
	.c-contactset-v2 {
		padding: 80px 40px 90px;
	}
	.c-contactset-v2__inner {
		padding-left: 0;
		padding-right: 0;
		max-width: 1200px;
	}
	.c-contactset-v2__items {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
	}
	.c-contactset-v2__item {
		width: 50%;
		padding: 50px 80px;
	}
	.c-contactset-v2__header-title {
		font-size: 2.6rem;
	}
	.c-contactset-v2__header-title::before {
		width: 5px;
		height: 32px;
	}
	.c-contactset-v2__header-text {
		font-size: 1.8rem;
		margin-top: 20px;
	}
	.c-contactset-v2__header-button {
		width: 50%;
		margin-top: 10px;
	}
	.c-contactset-v2__title {
		font-size: 1.6rem;
	}
	.c-contactset-v2__address {
		margin-top: 5px;
		margin-left: auto;
		margin-right: auto;
		max-width: 400px;
	}
	.c-contactset-v2__phone > a {
		background: none;
		pointer-events: none;
		min-height: auto;
		font-size: 3.6rem;
		font-weight: bold;
		color: var(--color-txt);
	}
	.c-contactset-v2__freecall > a {
		background: none;
		pointer-events: none;
		min-height: auto;
		font-size: 4.2rem;
		color: var(--color-txt);
		border: none;
	}
	.c-contactset-v2__mail > a {
		font-size: 2.8rem;
		transition: color 0.3s;
	}
	.c-contactset-v2__mail > a:hover {
		color: var(--color-txt-hover);
	}
	.c-contactset-v2__icon {
		color: var(--color-prim);
	}
	.c-contactset-v2__icon--phone {
		display: inline-block;
		font-size: 3.6rem;
	}
	.c-contactset-v2__icon--freecall {
		width: 70px;
		margin-right: 16px;
	}
	.c-contactset-v2__icon--mail {
		margin-right: 9px;
		font-size: 3rem;
	}
	.c-contactset-v2__detail {
		margin-top: 10px;
	}
}
.c-contactset-v2--type1 .c-contactset-v2__item {
	padding: 0 8.9552238% 40px;
}
.c-contactset-v2--type1 .c-contactset-v2__header {
	padding: 30px 8.9552238%;
}
.c-contactset-v2--type1 .c-contactset-v2__textlink {
	margin-top: 10px;
	margin-bottom: 0;
}
@media (max-width: 767px) {
	.c-contactset-v2--type1 .c-contactset-v2__item + .c-contactset-v2__item {
		padding-top: 30px;
		border-top: 1px solid var(--color-border);
	}
}
@media (min-width: 768px), print {
	.c-contactset-v2--type1 .c-contactset-v2__items {
		padding: 50px 80px;
	}
	.c-contactset-v2--type1 .c-contactset-v2__item {
		width: 50%;
		padding: 0;
	}
	.c-contactset-v2--type1 .c-contactset-v2__item + .c-contactset-v2__item {
		padding-left: 80px;
	}
	.c-contactset-v2--type1 .c-contactset-v2__item:not(:only-child) .c-contactset-v2__content {
		padding-right: 80px;
		border-right: 1px solid var(--color-border);
	}
	.c-contactset-v2--type1 .c-contactset-v2__header {
		display: flex;
		justify-content: flex-start;
		align-items: center;
		gap: 50px;
		padding: 50px 80px 30px;
	}
	.c-contactset-v2--type1 .c-contactset-v2__header-body {
		width: 50%;
	}
	.c-contactset-v2--type1 .c-contactset-v2__header + .c-contactset-v2__items {
		margin-top: -30px;
	}
}
.c-contactset-v2--type2 .c-contactset-v2__header {
	padding: 30px 8.9552238% 40px;
}
.c-contactset-v2--type2 .c-contactset-v2__header-button {
	margin-top: 30px;
}
.c-contactset-v2--type2 .c-contactset-v2__title {
	font-weight: 600;
}
.c-contactset-v2--type2 .c-contactset-v2__detail {
	margin-top: 20px;
}
@media (max-width: 767px) {
	.c-contactset-v2--type2 .c-contactset-v2__items {
		border-top: 1px solid var(--color-border);
	}
	.c-contactset-v2--type2 .c-contactset-v2__item {
		padding: 30px 8.9552238%;
		border-bottom: 1px solid var(--color-border);
	}
	.c-contactset-v2--type2 .c-contactset-v2__item + .c-contactset-v2__item {
		padding-bottom: 40px;
	}
}
@media (min-width: 768px), print {
	.c-contactset-v2--type2 .c-contactset-v2__item {
		width: 50%;
		padding: 40px 80px 50px;
	}
	.c-contactset-v2--type2 .c-contactset-v2__item:not(:first-child) {
		border-left: 1px solid var(--color-border);
	}
	.c-contactset-v2--type2 .c-contactset-v2__header {
		display: flex;
		justify-content: flex-start;
		align-items: center;
		gap: 50px;
		padding: 50px 80px;
	}
	.c-contactset-v2--type2 .c-contactset-v2__header-body {
		width: 50%;
	}
	.c-contactset-v2--type2 .c-contactset-v2__header + .c-contactset-v2__items {
		border-top: 1px solid var(--color-border);
	}
	.c-contactset-v2--type2 .c-contactset-v2__phone > a {
		font-size: 2.8rem;
	}
	.c-contactset-v2--type2 .c-contactset-v2__icon--mail, .c-contactset-v2--type2 .c-contactset-v2__icon--phone {
		font-size: 2.7rem;
	}
}
/*# sourceMappingURL=components.css.map */
