@charset "UTF-8";
/*----------
	icons
----------*/
@font-face {
	font-family: iconfont;
	src: 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-swipe, .icon-pinchout, .icon-global, .icon-download, .icon-blank, .icon-arrow5-r, .icon-arrow4-r, .icon-arrow3-r, .icon-arrow3-l, .icon-arrow2-t, .icon-arrow1-r, .icon-arrow1-b, .icon-pdf, .icon-powerpoint, .icon-mail, .icon-minus, .icon-plus {
	display: inline-block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	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-plus::before {
	content: "\e90e";
}
.icon-minus::before {
	content: "\e90b";
}
.icon-mail::before {
	content: "\e90a";
}
.icon-powerpoint::before {
	content: "\e90c";
}
.icon-pdf::before {
	content: "\e913";
}
.icon-arrow1-b::before {
	content: "\e901";
}
.icon-arrow1-r::before {
	content: "\e902";
}
.icon-arrow2-t::before {
	content: "\e903";
}
.icon-arrow3-l::before {
	content: "\e904";
}
.icon-arrow3-r::before {
	content: "\e905";
}
.icon-arrow4-r::before {
	content: "\e906";
}
.icon-arrow5-r::before {
	content: "\e900";
}
.icon-blank::before {
	content: "\e907";
}
.icon-download::before {
	content: "\e908";
}
.icon-global::before {
	content: "\e909";
}
.icon-pinchout::before {
	content: "\e90d";
}
.icon-swipe::before {
	content: "\e911";
}

/*----------
	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;
}
@media (min-width: 768px), print {
	.c-logo {
		width: 220px;
	}
}

/*----------
	separator
----------*/
.c-separator {
	display: block;
	margin: 50px 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: var(--color-prim);
	border-color: var(--color-prim);
}
.c-tag > a,
.c-tag > span {
	height: 28px;
	display: block;
	max-width: 100%;
	min-width: 120px;
	padding: 0 8px;
	color: inherit;
	border: 1px solid;
	border-color: inherit;
	border-radius: 100px;
	background-color: #fff;
	overflow: hidden;
	text-align: center;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 26px;
}
.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);
}
@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 {
		/* stylelint-disable no-descending-specificity */
		/* stylelint-enable no-descending-specificity */
	}
	.c-tag--fill > a:hover {
		background-color: #fff;
		color: var(--color-prim);
	}
}

/*----------
	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__image {
	text-align: center;
	border-radius: 8px;
	overflow: hidden;
}
.c-figure__image > img {
	max-width: 100%;
	width: auto;
}
.c-figure__caption {
	margin-top: 20px;
	text-align: left;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
	color: var(--color-txt-caption);
}
.c-figure--maxwidth {
	max-width: 1000px;
	margin: 0 auto;
}

/*----------
	image fit
----------*/
.c-image-fit {
	height: 0;
	padding-top: 56.2%;
	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--static {
	height: auto;
	padding-top: 0;
}
.c-image-fit--static > img,
.c-image-fit--static > iframe,
.c-image-fit--static > video,
.c-image-fit--static > object,
.c-image-fit--static > embed, .c-image-fit--static__element {
	position: static;
}

/*----------
	image scaling
----------*/
.c-image-scaling {
	display: block;
	width: 160px;
	height: 28px;
	margin-bottom: 20px;
	background-color: #DDDDDD;
	border-radius: 14px;
	text-align: center;
}
.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;
	line-height: 27px;
}
[lang=en] .c-image-scaling {
	width: 200px;
}
[lang=en] .c-image-scaling::after {
	content: "Image can be enlarged.";
}
@media (min-width: 768px), print {
	.c-image-scaling {
		display: none;
	}
}

/*----------
	content box
----------*/
.c-contentbox {
	padding: 25px;
	background-color: var(--color-bg);
	border-radius: 8px;
}
@media (min-width: 768px), print {
	.c-contentbox {
		padding: 50px;
	}
}

/*----------
	pagination
----------*/
.c-pagination {
	margin-top: 40px;
}
.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__page {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 50px;
	height: 32px;
	text-align: center;
	font-size: 1.6rem;
	line-height: 1;
	font-weight: bold;
	border: 1px solid var(--color-prim);
	border-radius: 3px;
	color: var(--color-prim);
}
.c-pagination__page--current {
	background: var(--color-prim);
	color: #fff;
}
.c-pagination__ellip {
	display: block;
	width: 24px;
	height: 32px;
	font-size: 0;
	background: radial-gradient(var(--color-prim) 1px, transparent 1px) repeat-x left center;
	background-size: 8px 8px;
}
.c-pagination__prev, .c-pagination__next {
	color: var(--color-txt);
	font-size: 1.6rem;
	line-height: 32px;
}
@media (min-width: 768px), print {
	.c-pagination {
		margin-top: 50px;
	}
	.c-pagination__page {
		transition: background 0.2s, color 0.2s;
	}
	.c-pagination a:hover .c-pagination__page {
		background: var(--color-prim);
		color: #fff;
	}
}

/*----------
	billboard
----------*/
.c-billboard {
	position: relative;
	padding: 20px 0;
	margin-bottom: 60px;
	min-height: 172px;
	z-index: 2;
}
.c-billboard::before {
	content: "";
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	padding-top: 10.67%;
	background: url(/assets/images/common/bg_h1_line-sp.png) no-repeat center 0;
	background-size: cover;
}
@media (min-width: 768px), print {
	.c-billboard {
		padding: 120px 0 60px;
		margin-bottom: 80px;
		min-height: 300px;
	}
	.c-billboard::before {
		padding-top: 4.17%;
		background: url(/assets/images/common/bg_h1_line-pc.png) no-repeat center 0;
		background-size: cover;
	}
}
.c-billboard__inner {
	width: 100%;
	max-width: 1280px;
	margin-inline: auto;
	padding-left: 5.3333333333%;
	padding-right: 5.3333333333%;
}
@media (min-width: 768px), print {
	.c-billboard__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard__detail {
	padding-top: 40px;
}
@media (min-width: 768px), print {
	.c-billboard__detail {
		padding-top: 38px;
	}
}
.c-billboard__title {
	font-weight: 500;
	font-size: 2.4rem;
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.c-billboard__title {
		font-size: 4.4rem;
	}
}
.c-billboard__image {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}
.c-billboard__image > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/*----------
	billboard-v2（第二階層）
----------*/
.c-billboard-v2 {
	position: relative;
	padding: 20px 0 28px;
	z-index: 2;
	background: var(--color-bg);
	margin-bottom: 80px;
}
@media (min-width: 768px), print {
	.c-billboard-v2 {
		padding: 20px 0 30px;
		margin-bottom: 80px;
	}
}
.c-billboard-v2__inner {
	width: 100%;
	max-width: 1280px;
	margin-inline: auto;
	padding-left: 5.3333333333%;
	padding-right: 5.3333333333%;
}
@media (min-width: 768px), print {
	.c-billboard-v2__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard-v2__detail {
	padding-top: 20px;
}
@media (min-width: 768px), print {
	.c-billboard-v2__detail {
		padding-top: 35px;
	}
}
.c-billboard-v2__title {
	font-weight: 500;
	font-size: 2.4rem;
	display: flex;
	flex-direction: column;
	line-height: var(--line-height-s);
}
.c-billboard-v2__title-sub {
	font-weight: 500;
	font-size: 1.6rem;
	color: var(--color-prim);
}
@media (min-width: 768px), print {
	.c-billboard-v2__title-sub {
		font-size: 2rem;
	}
}
@media (min-width: 768px), print {
	.c-billboard-v2__title {
		font-size: 4.4rem;
		align-items: center;
		flex-direction: row;
		flex-wrap: wrap;
	}
}

/*----------
	billboard-v3（第三階層〜）
----------*/
.c-billboard-v3 {
	position: relative;
	padding: 20px 0 50px;
	z-index: 2;
	background: #fff;
	border-bottom: 1px solid var(--color-border);
	margin-bottom: 80px;
}
@media (min-width: 768px), print {
	.c-billboard-v3 {
		padding: 20px 0 40px;
		margin-bottom: 80px;
	}
}
.c-billboard-v3__inner {
	width: 100%;
	max-width: 1280px;
	margin-inline: auto;
	padding-left: 5.3333333333%;
	padding-right: 5.3333333333%;
}
@media (min-width: 768px), print {
	.c-billboard-v3__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard-v3__info {
	display: flex;
	margin-bottom: 34px;
}
.c-billboard-v3__date {
	padding-top: 6px;
	margin-right: 20px;
	color: var(--color-txt-caption);
	font-size: 1.4rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	vertical-align: middle;
}
.c-billboard-v3__detail {
	padding-top: 50px;
}
.c-billboard-v3__title {
	font-weight: 500;
	font-size: 2.4rem;
	display: flex;
	flex-direction: column;
	line-height: var(--line-height-s);
}
.c-billboard-v3__title-sub {
	font-weight: 500;
	font-size: 1.6rem;
	color: var(--color-prim);
}
@media (min-width: 768px), print {
	.c-billboard-v3__title-sub {
		font-size: 2rem;
	}
}
@media (min-width: 768px), print {
	.c-billboard-v3__title {
		font-size: 4.4rem;
		align-items: center;
		flex-direction: row;
		flex-wrap: wrap;
	}
}

/*----------
	billboard-v4（第三階層〜 タイトルのみ）
----------*/
.c-billboard-v4 {
	position: relative;
	display: flex;
	align-items: center;
	height: 172px;
	z-index: 2;
	background: var(--color-bg);
	margin-bottom: 60px;
}
@media (min-width: 768px), print {
	.c-billboard-v4 {
		height: 200px;
		margin-bottom: 80px;
	}
}
.c-billboard-v4__inner {
	width: 100%;
	max-width: 1280px;
	margin-inline: auto;
	padding-left: 5.3333333333%;
	padding-right: 5.3333333333%;
}
@media (min-width: 768px), print {
	.c-billboard-v4__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard-v4__title {
	font-weight: 500;
	font-size: 2.4rem;
	display: flex;
	flex-direction: column;
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.c-billboard-v4__title {
		font-size: 4.4rem;
		align-items: center;
		flex-direction: row;
		flex-wrap: wrap;
	}
}

/*----------
	heading-secondary
----------*/
.c-heading-secondary {
	position: relative;
	padding-bottom: 22px;
	margin-bottom: 40px;
	border-bottom: 1px solid var(--color-border);
	font-weight: 500;
	font-size: 2.2rem;
	line-height: var(--line-height-s);
}
.c-heading-secondary::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -1px;
	width: 40px;
	height: 2px;
	background: var(--color-prim);
}
@media (min-width: 768px), print {
	.c-heading-secondary {
		margin-bottom: 50px;
		font-size: 3.2rem;
	}
}

/*----------
	heading-tertiary
----------*/
.c-heading-tertiary {
	position: relative;
	padding: 13px 16px;
	margin-bottom: 20px;
	background-color: var(--color-bg);
	font-weight: 500;
	font-size: 2rem;
	line-height: var(--line-height-s);
	border-left: 4px solid var(--color-seco);
}
.c-heading-tertiary::before {
	content: "";
	width: 4px;
	height: 50%;
	background-color: var(--color-prim);
	position: absolute;
	left: -4px;
	top: 0;
}
@media (min-width: 768px), print {
	.c-heading-tertiary {
		margin-bottom: 30px;
		font-size: 2.4rem;
	}
}

/*----------
	heading-quaternary
----------*/
.c-heading-quaternary {
	font-weight: 500;
	font-size: 2rem;
	line-height: var(--line-height-s);
	padding: 0 0 0 30px;
	margin-bottom: 30px;
	position: relative;
}
.c-heading-quaternary::before {
	content: "";
	display: block;
	position: absolute;
	top: 0.75em;
	left: 0;
	width: 16px;
	height: 16px;
	background: rgba(63, 151, 201, 0.2);
	border-radius: 100%;
	transform: translateY(-50%);
}
.c-heading-quaternary::after {
	content: "";
	display: block;
	position: absolute;
	top: 0.75em;
	left: 4px;
	width: 8px;
	height: 8px;
	background: var(--color-prim);
	border-radius: 100%;
	transform: translateY(-50%);
}
@media (min-width: 768px), print {
	.c-heading-quaternary {
		margin-bottom: 20px;
	}
}

/*----------
	heading-quinary
----------*/
.c-heading-quinary {
	margin-bottom: 20px;
	font-weight: 500;
	font-size: 1.8rem;
	line-height: var(--line-height-s);
}

/*----------
	heading-point
----------*/
.c-heading-point {
	display: flex;
}
.c-heading-point + .c-heading-point {
	margin: 30px 0 0;
}
.c-heading-point__icon {
	flex: 0 0 50px;
	margin: 0 14px 0 0;
}
.c-heading-point__icon-inner {
	background: url(/assets/images/common/bg_pointtl.png) no-repeat 0 0;
	background-size: contain;
	width: 50px;
	height: 46px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	color: #fff;
	font-weight: 500;
}
.c-heading-point__icon-title {
	display: block;
	font-size: 0.8rem;
	line-height: 1;
	margin: 0;
	text-align: center;
}
.c-heading-point__icon-title:only-child {
	margin: 0;
}
.c-heading-point__icon-num {
	display: block;
	font-size: 2rem;
	line-height: 1;
}
.c-heading-point__text {
	width: calc(100% - 64px);
	display: flex;
	flex: 1 1 auto;
	align-items: center;
}
.c-heading-point__title {
	font-size: 2rem;
	font-weight: 500;
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.c-heading-point + .c-heading-point {
		margin: 30px 0 0;
	}
	.c-heading-point__icon {
		flex-basis: 70px;
		margin-right: 20px;
	}
	.c-heading-point__icon-inner {
		width: 70px;
		height: 65px;
	}
	.c-heading-point__icon-title {
		font-size: 1rem;
	}
	.c-heading-point__icon-num {
		font-size: 2.8rem;
	}
	.c-heading-point__text {
		width: calc(100% - 90px);
	}
	.c-heading-point__title {
		font-size: 2.4rem;
	}
}

/*----------
	text
----------*/
.c-text {
	font-size: 1.4rem;
	line-height: var(--line-height-xl);
}
.c-text + .c-text {
	margin-top: 40px;
}
.c-text > a {
	text-decoration: underline;
}
.c-text--bold {
	font-weight: 700;
}
@media (min-width: 768px), print {
	.c-text {
		font-size: 1.6rem;
	}
	.c-text + .c-text {
		margin-top: 50px;
	}
	.c-text > a {
		transition: color 0.2s;
	}
	.c-text > a:hover {
		text-decoration: none;
	}
}

/* add 2024.12 */
.c-text-right{
	text-align: right;
}
.c-text-12px{
	font-size: 12px;
}


/*----------
	text-attention
----------*/
.c-text-attention {
	font-size: 1.6rem;
	line-height: var(--line-height-xl);
	color: var(--color-red);
}
.c-text-attention > a {
	text-decoration: underline;
}
.c-text-attention--bold {
	font-weight: bold;
}
@media (min-width: 768px), print {
	.c-text-attention > a {
		transition: color 0.2s;
	}
	.c-text-attention > a:hover {
		color: var(--color-txt-hover);
	}
}

/*----------
	lead
----------*/
.c-lead {
	font-size: 1.8rem;
	font-weight: 700;
	line-height: var(--line-height-xl);
}
@media (min-width: 768px), print {
	.c-lead {
		font-size: 2.4rem;
	}
}

/*----------
	caption
----------*/
.c-caption {
	font-size: 1.2rem;
	line-height: var(--line-height-xl);
	color: var(--color-txt-caption);
}
.c-caption > a {
	text-decoration: underline;
}
@media (min-width: 768px), print {
	.c-caption {
		font-size: 1.4rem;
	}
	.c-caption > a {
		transition: color 0.2s;
	}
	.c-caption > a:hover {
		color: var(--color-txt-hover);
	}
}

/*----------
	icontext
----------*/
.c-icontext > a {
	word-break: break-all;
}
.c-icontext > a,
.c-icontext > span {
	position: relative;
	display: inline-block;
	padding-right: 32px;
}
.c-icontext > a::after,
.c-icontext > span::after {
	content: "\e902";
	display: inline-block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	margin-left: 7px;
	color: var(--color-prim);
	font-size: 1.8rem;
	vertical-align: middle;
}
.c-icontext > a[href^="#"]::after,
.c-icontext > span[href^="#"]::after {
	content: "\e901";
}
.c-icontext > a[target=_blank]::after,
.c-icontext > span[target=_blank]::after {
	color: var(--color-prim);
	content: "\e907";
}
.c-icontext > a[href$=".pdf"][target=_blank]::after,
.c-icontext > span[href$=".pdf"][target=_blank]::after {
	content: "\e913";
	color: var(--color-red);
}
@media (min-width: 768px), print {
	.c-icontext > a:hover {
		text-decoration: underline;
	}
}

/*----------
	list
----------*/
.c-list__item {
	padding-left: 1.6em;
	text-indent: -1.6em;
}
.c-list__item::before {
	content: "";
	position: relative;
	top: 3px;
	display: inline-block;
	width: 8px;
	height: 10px;
	padding-left: 5px;
	margin-right: 15px;
	background: url(/assets/images/common/icon_dot.svg) no-repeat 0 0;
	background-size: cover;
	vertical-align: middle;
	transform: translate(50%, -50%);
}
.c-list__item + .c-list__item {
	margin-top: 8px;
}

/*----------
	disclist
----------*/
.c-disclist__item {
	position: relative;
	padding-left: 1em;
}
.c-disclist__item::before {
	content: "・";
	display: inline-block;
	width: 1em;
	position: absolute;
	left: 0;
}
.c-disclist__item + .c-disclist__item {
	margin-top: 8px;
}

/*----------
	order list
----------*/
.c-orderlist {
	counter-reset: orderlist;
	line-height: var(--line-height-l);
}
.c-orderlist__item {
	padding-left: 2em;
	text-indent: -2.6em;
}
.c-orderlist__item::before {
	counter-increment: orderlist;
	content: counter(orderlist)'.';
	display: inline-block;
	margin-right: 10px;
	min-width: 2em;
	text-align: right;
}
.c-orderlist__item + .c-orderlist__item {
	margin-top: 8px;
}
.c-orderlist--icon .c-orderlist__item::before {
	counter-increment: orderlist;
	content: counter(orderlist);
	display: inline-block;
	margin-right: 10px;
	min-width: 2em;
	width: 30px;
	height: 30px;
	background-color: var(--color-prim);
	border-radius: 100%;
	text-align: center;
	line-height: 30px;
}
.c-orderlist--ver2 .c-orderlist__item {
	padding-left: 1.6em;
	text-indent: -1.6em;
}
.c-orderlist--ver2 .c-orderlist__item::before {
	content: "（" counter(orderlist) "）";
	margin-right: 0;
}

/*----------
	order list
----------*/
.c-orderlisticon {
	counter-reset: orderlist;
	line-height: var(--line-height-l);
}
.c-orderlisticon__item {
	position: relative;
	padding-top: 2px;
	padding-left: 60px;
	font-weight: 700;
	font-size: 1.8rem;
	min-height: 40px;
}
.c-orderlisticon__item::before {
	position: absolute;
	top: 0;
	left: 0;
	counter-increment: orderlist;
	content: counter(orderlist);
	display: block;
	width: 40px;
	height: 40px;
	background-color: var(--color-prim);
	border-radius: 100%;
	color: #fff;
	font-size: 1.8rem;
	text-align: center;
	line-height: 39px;
}
.c-orderlisticon__item + .c-orderlisticon__item {
	margin-top: 10px;
}
@media (min-width: 768px), print {
	.c-orderlisticon__item {
		padding-top: 10px;
		padding-left: 80px;
		font-size: 2.4rem;
		min-height: 60px;
	}
	.c-orderlisticon__item::before {
		top: 3px;
		width: 60px;
		height: 60px;
		font-size: 2.2rem;
		line-height: 59px;
	}
}

/*----------
	remarks
----------*/
.c-remarks {
	font-size: 1.4rem;
	line-height: var(--line-height-xl);
}
.c-remarks__item {
	padding-left: 1.5em;
	text-indent: -0.8em;
	color: var(--color-txt-caption);
}
.c-remarks__item::before {
	content: "※";
	display: inline-block;
	margin-right: 10px;
}
[lang=en] .c-remarks__item::before {
	content: "*";
}
.c-remarks__item + .c-remarks__item {
	margin-top: 10px;
}
.c-remarks--order {
	counter-reset: orderlist;
}
.c-remarks--order .c-remarks__item {
	padding-left: 3em;
	text-indent: -2.6em;
}
.c-remarks--order .c-remarks__item::before {
	counter-increment: orderlist;
	content: "※" counter(orderlist);
	min-width: 2em;
	margin-right: 10px;
	text-align: right;
}
[lang=en] .c-remarks--order .c-remarks__item {
	padding-left: 2.2em;
	text-indent: -1.8em;
}
[lang=en] .c-remarks--order .c-remarks__item::before {
	content: "*" counter(orderlist);
	min-width: 1.2em;
}
@media (min-width: 768px), print {
	.c-remarks {
		font-size: 1.6rem;
	}
}

/*----------
	button
----------*/
/* stylelint-disable no-duplicate-selectors */
.c-button__inner {
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 50px;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	border: 1px solid var(--color-prim);
	background-color: var(--color-prim);
	border-radius: 25px;
	color: #fff;
	cursor: pointer;
}
.c-button__inner::before {
	content: "\e902";
	display: block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 20px;
	font-size: 1.8rem;
	transform: translateY(-50%);
}
.c-button__inner[target=_blank]::before {
	content: "\e907";
}
.c-button__inner[href$=".pdf"][target=_blank]::before {
	content: "\e913";
}
.c-button__inner > span {
	padding: 8px 45px;
	text-align: center;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
	color: inherit;
}
.c-button__icon {
	width: 1em;
	height: 1em;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 16px;
	line-height: 1;
	color: inherit;
}
@media (min-width: 768px), print {
	.c-button__inner {
		transition: color 0.2s, background-color 0.2s;
	}
	.c-button__inner:hover {
		color: var(--color-prim);
		background-color: #fff;
	}
	.c-button__inner:hover[href$=".pdf"][target=_blank]::before {
		color: var(--color-red);
	}
	.c-button__inner > span {
		font-size: 1.6rem;
	}
	.c-button--auto .c-button__inner {
		display: inline-flex;
		width: auto;
		line-height: 50px;
	}
	.c-button--auto .c-button__inner > span {
		display: inline-block;
		padding: 8px 60px;
	}
}

/* textlink */
.c-button--textlink .c-button__inner {
	display: block;
	border: none;
	border-bottom: 1px solid var(--color-border);
	border-radius: 0;
	background-color: transparent;
	color: var(--color-txt);
	min-height: 45px;
}
.c-button--textlink .c-button__inner > span {
	display: inline-block;
	padding: 0 0 15px;
	text-align: left;
	font-size: 1.4rem;
}
.c-button--textlink a.c-button__inner::before {
	top: calc(50% - 17px);
	right: 0;
	color: var(--color-prim);
	transform: none;
}
.c-button--textlink a.c-button__inner[href$=".pdf"][target=_blank]::before {
	color: var(--color-red);
}
.c-button--textlink a.c-button__inner::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -1px;
	right: 0;
	width: 20px;
	height: 1px;
	background: var(--color-prim);
}
.c-button--textlink a.c-button__inner > span {
	padding-right: 28px;
}
.c-button--textlink p.c-button__inner {
	cursor: default;
}
.c-button--textlink p.c-button__inner::before {
	display: none;
}
@media (min-width: 768px), print {
	.c-button--textlink .c-button__inner > span {
		font-size: 1.6rem;
	}
	.c-button--textlink a.c-button__inner {
		transition: color 0.2s;
	}
	.c-button--textlink a.c-button__inner:hover {
		background-color: transparent;
		color: var(--color-txt-link);
	}
}

/* stylelint-enable no-duplicate-selectors */
/*----------
	button container
----------*/
.g-button-container {
	margin: 0 auto;
	/* ボーダー接合 3カラム（改行左寄せ） */
}
@media (max-width: 767px) {
	.g-button-container__item {
		margin: 0 auto 20px;
	}
	.g-button-container__item:last-child {
		margin-bottom: 0;
	}
}
@media (min-width: 768px), print {
	.g-button-container__item {
		margin-left: auto;
		margin-right: auto;
		max-width: 312px;
	}
	.g-button-container__item + .g-button-container__item {
		margin-top: 42px;
	}
	@supports (display: grid) {
		.g-button-container {
			display: flex;
			flex-wrap: nowrap;
			justify-content: center;
			align-items: stretch;
		}
		.g-button-container .g-button-container__item {
			flex: 1 1 312px;
			margin: 0;
		}
		.g-button-container--1up {
			display: block;
		}
		.g-button-container--1up .g-button-container__item {
			width: 100%;
			max-width: 372px;
			margin: 0;
		}
		.g-button-container--1upauto {
			display: block;
		}
		.g-button-container--1upauto .g-button-container__item {
			width: auto;
			max-width: 523px;
		}
		.g-button-container--2up {
			justify-content: center;
		}
		.g-button-container--2up .g-button-container__item {
			flex: 1 1 372px;
		}
		.g-button-container--2up .g-button-container__item + .g-button-container__item {
			margin-left: 42px;
		}
		.g-button-container--2upfit {
			display: grid;
			gap: 42px;
			grid-template-columns: repeat(2, 1fr);
		}
		.g-button-container--2upfit .g-button-container__item {
			width: 100%;
			max-width: 100%;
		}
		.g-button-container--2upauto {
			display: grid;
			gap: 42px;
			grid-template-columns: repeat(2, auto);
		}
		.g-button-container--2upauto .g-button-container__item {
			width: auto;
			max-width: 523px;
		}
		.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: 42px;
		}
		.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: 42px;
	}
}

/*----------
	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 > a {
	display: block;
}
.c-imagelink > a[target=_blank] .c-imagelink__title::before {
	color: var(--color-prim);
	content: "\e907";
}
.c-imagelink > a[href$=".pdf"][target=_blank] .c-imagelink__title::before {
	content: "\e913";
	color: var(--color-red);
}
.c-imagelink > a .c-imagelink__title {
	position: relative;
	padding-right: 32px;
	color: var(--color-txt);
}
.c-imagelink > a .c-imagelink__title::before {
	content: "\e902";
	display: block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 4px;
	right: 0;
	color: var(--color-prim);
	font-size: 1.8rem;
}
.c-imagelink__inner {
	height: 100%;
	display: block;
}
.c-imagelink__image {
	margin-bottom: 24px;
	width: 100%;
	height: 0;
	padding-top: 56.1194%;
	position: relative;
	border-radius: 8px;
	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__title {
	font-weight: 500;
	font-size: 1.6rem;
	line-height: var(--line-height-m);
}
.c-imagelink__text {
	margin-top: 24px;
	font-size: 1.4rem;
	color: var(--color-txt);
	line-height: var(--line-height-xl);
}
@media (min-width: 768px), print {
	.c-imagelink a.c-imagelink__inner .c-imagelink__title {
		font-size: 2rem;
		transition: color 0.2s;
	}
	.c-imagelink a.c-imagelink__inner .c-imagelink__title::before {
		top: 8px;
	}
	.c-imagelink a.c-imagelink__inner .c-imagelink__image img {
		transition: transform 0.2s;
	}
	.c-imagelink a.c-imagelink__inner:hover .c-imagelink__title {
		color: var(--color-txt-hover);
	}
	.c-imagelink a.c-imagelink__inner:hover .c-imagelink__image img {
		transform: scale(1.05);
	}
	.c-imagelink__text {
		font-size: 1.6rem;
	}
	.c-imagelink--1clm .c-imagelink__image {
		padding-top: 33.33%;
	}
}

/*----------
	image link
----------*/
.c-cardlink > a {
	display: block;
}
.c-cardlink > a[target=_blank] .c-cardlink__title::before {
	color: var(--color-prim);
	content: "\e907";
}
.c-cardlink > a[href$=".pdf"][target=_blank] .c-cardlink__title::before {
	content: "\e913";
	color: var(--color-red);
}
.c-cardlink > a .c-cardlink__title {
	position: relative;
	padding-right: 45px;
	color: var(--color-txt);
}
.c-cardlink > a .c-cardlink__title::before {
	content: "\e902";
	display: block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 20px;
	color: var(--color-prim);
	font-size: 1.8rem;
	transform: translateY(-50%);
}
.c-cardlink__inner {
	display: block;
	height: 100%;
	position: relative;
	background-color: #fff;
	border-radius: 8px;
	box-sizing: border-box;
	overflow: hidden;
}
.c-cardlink__image {
	width: 100%;
	height: 0;
	padding-top: 56.99%;
	position: absolute;
	z-index: 1;
	border-radius: 8px 8px 0 0;
	border: 1px solid var(--color-border);
	overflow: hidden;
}
.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: 56.99%;
	justify-content: flex-start;
	align-items: center;
	overflow: hidden;
	background-color: #fff;
	border: 1px solid var(--color-border);
	border-radius: 0 0 8px 8px;
}
.c-cardlink__title {
	display: block;
	width: 100%;
	padding: 24px 40px 24px 24px;
	position: relative;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: var(--line-height-m);
	color: inherit;
}
.c-cardlink--no-border .c-cardlink__image {
	border: none;
}
.c-cardlink--no-border .c-cardlink__header {
	border: none;
}
@media (min-width: 768px), print {
	.c-cardlink a.c-cardlink__inner {
		transition: border 0.2s, box-shadow 0.2s;
	}
	.c-cardlink a.c-cardlink__inner .c-cardlink__title {
		transition: color 0.2s;
	}
	.c-cardlink a.c-cardlink__inner .c-cardlink__image img {
		transition: transform 0.2s;
	}
	.c-cardlink a.c-cardlink__inner:hover {
		box-shadow: 0 0 30px rgba(34, 34, 34, 0.2);
	}
	.c-cardlink a.c-cardlink__inner:hover .c-cardlink__title {
		color: var(--color-txt-hover);
	}
	.c-cardlink a.c-cardlink__inner:hover .c-cardlink__image img {
		transform: scale(1.05);
	}
	.c-cardlink a.c-cardlink__inner:hover .c-cardlink__header {
		border-color: #fff;
	}
	.c-cardlink__header {
		transition: color 0.2s;
	}
	.c-cardlink__title {
		padding: 30px 50px 30px 20px;
		font-size: 1.6rem;
	}
	.c-cardlink--1fr .c-cardlink__image {
		padding-top: 26.6666%;
	}
	.c-cardlink--1fr .c-cardlink__header {
		padding-top: 26.6666%;
	}
}

/*----------
	imageset
----------*/
.c-imageset__title {
	font-weight: 700;
	font-size: 1.8rem;
	line-height: var(--line-height-m);
}
.c-imageset__title + .c-imageset__text {
	margin-top: 20px;
}
.c-imageset__button {
	margin: 40px auto 0;
}
.c-imageset__image {
	border-radius: 8px;
	overflow: hidden;
}
@media (max-width: 767px) {
	.c-imageset__image {
		margin-bottom: 20px;
	}
	.c-imageset--spreverse .c-imageset__inner {
		display: flex;
		flex-direction: column-reverse;
	}
	.c-imageset--spreverse .c-imageset__image {
		margin-bottom: 0;
	}
	.c-imageset--spreverse .c-imageset__content {
		margin-bottom: 20px;
	}
}
@media (min-width: 768px), print {
	.c-imageset__inner {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
	}
	.c-imageset__title {
		font-size: 2.4rem;
	}
	.c-imageset__title + .c-imageset__text {
		margin-top: 30px;
	}
	.c-imageset__image {
		flex: 0 0 calc(50% - 21px);
		margin-right: 42px;
	}
	.c-imageset__content {
		flex: 1 0 calc(50% - 21px);
	}
	.c-imageset__button {
		max-width: 372px;
		margin-top: 50px;
		margin-left: 0;
		padding: 0;
	}
	.c-imageset--1t2 .c-imageset__image {
		flex-basis: calc(33.3333% - 21px);
		max-width: 372px;
	}
	.c-imageset--1t3 .c-imageset__image {
		flex-basis: calc(25% - 21px);
	}
	.c-imageset--reverse .c-imageset__inner {
		flex-direction: row-reverse;
	}
	.c-imageset--reverse .c-imageset__image {
		margin-right: 0;
		margin-left: 42px;
	}
}

/*----------
	textpanel
----------*/
.c-txtpanel-link > a {
	display: block;
}
.c-txtpanel-link > a .c-txtpanel-link__date {
	color: var(--color-txt-caption);
}
.c-txtpanel-link > a[target=_blank] .c-txtpanel-link__title::before {
	color: var(--color-prim);
	content: "\e907";
}
.c-txtpanel-link > a[href$=".pdf"][target=_blank] .c-txtpanel-link__title::before {
	content: "\e913";
	color: var(--color-red);
}
.c-txtpanel-link > a .c-txtpanel-link__title {
	color: var(--color-txt);
	position: relative;
	padding-right: 44px;
}
.c-txtpanel-link > a .c-txtpanel-link__title::before {
	content: "\e902";
	display: block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 0;
	color: var(--color-prim);
	font-size: 1.8rem;
	transform: translateY(-50%);
}
.c-txtpanel-link__inner {
	display: block;
	height: 100%;
	border: var(--color-border) solid 1px;
	border-radius: 8px;
	padding: 20px;
}
.c-txtpanel-link__title {
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-m);
}
.c-txtpanel-link__text {
	padding-top: 20px;
	margin-top: 20px;
	border-top: 1px dashed var(--color-border);
	font-size: 1.4rem;
	line-height: var(--line-height-l);
	color: var(--color-txt);
}
@media (min-width: 768px), print {
	.c-txtpanel-link__inner {
		padding: 30px;
		transition: border 0.2s, box-shadow 0.2s;
	}
	.c-txtpanel-link__inner:hover {
		box-shadow: 0 0 30px rgba(34, 34, 34, 0.2);
		border-color: #fff;
	}
	.c-txtpanel-link__inner:hover .c-txtpanel-link__title {
		color: var(--color-txt-hover);
	}
	.c-txtpanel-link__title {
		font-size: 2rem;
		transition: color 0.2s;
	}
}

/*----------
	anchor
----------*/
@media (min-width: 768px), print {
	.c-anchor {
		display: flex;
		flex-wrap: wrap;
	}
}
.c-anchor__item {
	border: solid 1px var(--color-border);
}
@media (max-width: 767px) {
	.c-anchor + .c-anchor {
		margin-top: -1px;
	}
	.c-anchor__item:not(:last-child) {
		border-bottom: none;
	}
}
@media (min-width: 768px), print {
	.c-anchor--2up .c-anchor__item {
		flex: 0 0 50%;
		width: 50%;
		margin-top: -1px;
		margin-left: -1px;
	}
	.c-anchor--3up .c-anchor__item {
		flex: 0 0 33.333%;
		width: 33.333%;
		margin-top: -1px;
		margin-left: -1px;
	}
	.c-anchor--4up .c-anchor__item {
		flex: 0 0 25%;
		width: 25%;
		margin-top: -1px;
		margin-left: -1px;
	}
}
.c-anchor__link {
	position: relative;
	display: flex;
	align-items: center;
	height: 100%;
	padding: 17px 48px 17px 24px;
	background-color: #fff;
}
.c-anchor__link::before {
	content: "\e901";
	display: block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 20px;
	font-size: 1.8rem;
	transform: translateY(-50%);
}
@media (min-width: 768px), print {
	.c-anchor__link {
		position: relative;
		padding: 17px 48px 17px 20px;
		transition: box-shadow 0.2s;
	}
	.c-anchor__link:hover {
		box-shadow: 0 0 30px rgba(34, 34, 34, 0.2);
		z-index: 1;
	}
	.c-anchor__link:hover .c-anchor__text {
		color: var(--color-txt-hover);
	}
}
.c-anchor__text {
	color: var(--color-txt);
	font-size: 1.6rem;
	line-height: var(--line-height-l);
}
@media (min-width: 768px), print {
	.c-anchor__text {
		transition: color 0.2s;
	}
}

/*----------
	anchor
----------*/
.c-tab__tab {
	display: flex;
	flex-wrap: wrap;
	padding: 4px;
	background-color: var(--color-bg);
	border-radius: 10px;
}
@media (min-width: 768px), print {
	.c-tab__tab {
		flex-wrap: nowrap;
		overflow-x: auto;
	}
}
.c-tab__tab-item {
	background: var(--color-bg);
	color: var(--color-txt);
	width: calc((100% - 1px) / 2);
}
@media (min-width: 768px), print {
	.c-tab__tab-item {
		flex: 1 25%;
		border-radius: 5px 5px 0 0;
	}
}
.c-tab__tab-item.is-active {
	background: var(--color-prim);
	border-radius: 6px;
	color: #FFF;
	font-weight: 700;
	pointer-events: none;
	cursor: default;
}
.c-tab__tab-link {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.2rem;
	line-height: var(--line-height-s);
	text-align: center;
	width: 100%;
	min-height: 40px;
	height: 100%;
	padding: 6px 10px;
	color: inherit;
}
@media (min-width: 768px), print {
	.c-tab__tab-link {
		min-height: 52px;
		font-size: 1.6rem;
		padding: 10px;
	}
}
.c-tab__contents {
	margin-top: 50px;
}
.c-tab__contents-item {
	display: none;
}
.c-tab__contents-item.is-active {
	display: block;
}

/*----------
	news
----------*/
.c-news {
	color: var(--color-txt-caption);
}
.c-news > a {
	display: block;
}
.c-news > a .c-news__date {
	color: var(--color-txt-caption);
}
.c-news > a[target=_blank] .c-news__title::before {
	content: "\e907";
}
.c-news > a[href$=".pdf"][target=_blank] .c-news__title::before {
	content: "\e913";
	color: var(--color-red);
}
.c-news > a .c-news__title {
	position: relative;
	padding-right: 44px;
}
.c-news > a .c-news__title::before {
	content: "\e902";
	display: block;
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	position: absolute;
	top: 50%;
	right: 0;
	font-size: 1.8rem;
	transform: translateY(-50%);
}
.c-news__detail {
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto auto;
	padding: 20px 0;
}
.c-news__date {
	grid-column: 1;
	grid-row: 1;
	padding-top: 6px;
	margin-right: 20px;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	vertical-align: middle;
}
.c-news__tag {
	grid-column: 2;
	grid-row: 1;
}
.c-news__headline {
	grid-column: 1/3;
	grid-row: 2;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: var(--line-height-xl);
}
.c-news a.c-news__title {
	position: relative;
	display: inline-block;
	padding-left: 1.2em;
	text-indent: -1.2em;
}
.c-news__file {
	display: inline-block;
	line-height: var(--line-height-m);
	margin-left: 8px;
	font-size: 1.4rem;
	text-indent: 0;
	color: #999;
}
@media (max-width: 767px) {
	.c-news__date {
		margin-bottom: 16px;
	}
	.c-news__tag {
		margin-bottom: 16px;
	}
}
@media (min-width: 768px), print {
	.c-news > a {
		transition: box-shadow 0.2s;
	}
	.c-news > a .c-news__title::before {
		top: 18px;
		right: 20px;
	}
	.c-news > a:hover {
		box-shadow: 0 0 30px rgba(30, 30, 30, 0.2);
	}
	.c-news > a:hover .c-news__title {
		text-decoration: underline;
	}
	.c-news__detail {
		grid-template-columns: auto auto 1fr;
		grid-template-rows: auto;
		padding-top: 24px;
		padding-left: 24px;
		padding-bottom: 24px;
	}
	.c-news__tag {
		margin-right: 8px;
		margin-top: 10px;
	}
	.c-news__headline {
		font-size: 1.6rem;
	}
	.c-news a.c-news__title {
		transition: color 0.2s;
	}
	.c-news a.c-news__title:hover {
		color: var(--color-txt-hover);
	}
	@supports (display: grid) {
		.c-news__detail {
			grid-template-columns: auto auto 1fr;
			grid-template-rows: auto;
		}
		.c-news__date {
			grid-column: 1;
			grid-row: 1;
		}
		.c-news__tag {
			grid-column: 2;
			grid-row: 1;
			margin-top: 2px;
		}
		.c-news__headline {
			grid-column: 3;
			grid-row: 1;
			margin-top: 0;
		}
	}
}

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

/*----------
	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 20px 5px;
	background-color: #fff;
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.7;
}
.c-deflist__detail {
	display: flex;
	align-items: center;
	gap: 0 1em;
	padding: 5px 20px 20px;
	background-color: #fff;
}
.c-deflist__detail__name {
	flex: 0 0 50%;
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 1.6;
}
.c-deflist__detail__ruby {
	flex: 0 0 50%;
	font-size: 1.2rem;
	color: var(--color-txt-caption);
}
@media (min-width: 768px), print {
	.c-deflist {
		border-bottom: 1px solid var(--color-border);
	}
	.c-deflist__body {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	.c-deflist__term {
		flex: 0 0 25%;
		padding: 20px 16px 20px 20px;
		font-size: 1.4rem;
	}
	.c-deflist__detail {
		display: block;
		flex: 1 1 auto;
		margin-left: -1px;
		padding: 20px 0 20px 16px;
	}
	.c-deflist__detail__name {
		font-size: 2rem;
	}
	.c-deflist__detail__ruby {
		font-size: 1.4rem;
	}
}

/*----------
	table
----------*/
.c-table__content {
	width: 100%;
	text-align: left;
	border: none;
	font-size: 1.4rem;
	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);
	vertical-align: middle;
	padding: 20px 15px;
	background-color: var(--color-prim);
	font-weight: 700;
	text-align: center;
	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);
	vertical-align: middle;
	padding: 14px 10px;
	background-color: var(--color-prim);
	font-weight: 700;
	text-align: center;
	color: #fff;
}
.c-table__narrow-header:empty {
	background: none;
	border: none;
}
.c-table__narrow-header--red {
	background: #DE5252;
}
.c-table__subheader {
	border: 1px solid var(--color-border);
	vertical-align: middle;
	padding: 20px 15px;
	background-color: var(--color-bg);
	font-weight: 700;
	text-align: center;
}
.c-table__subheader:empty {
	background: none;
	border: none;
}
.c-table__cell {
	padding: 20px 15px;
	border: 1px solid var(--color-border);
	vertical-align: middle;
}
.c-table__cell:empty {
	background: none;
	border: none;
}
.c-table__cell--red {
	background: #FFF7F7;
}
@media (max-width: 767px) {
	.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::before {
		position: absolute;
		content: "";
		background: url(/assets/images/common/icon_slide_float.png) no-repeat;
		background-size: contain;
		width: 135px;
		height: 78px;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		z-index: 1;
	}
	[lang=en] .c-table--scrollable-float .c-table__inner::before {
		background: url(/en/assets/images/common/icon_slide_float.png) no-repeat;
		background-size: contain;
	}
	.c-table--scrollable-float .c-table__inner.is-scroll::before {
		opacity: 0;
		display: none;
	}
	.c-table--scrollable-float .c-table__body {
		min-width: 860px;
		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.1);
		top: 0;
		left: 0;
		transition: background-color 0.3s;
	}
	.c-table--scrollable-float .c-table__content.is-scroll::before {
		opacity: 0;
		display: none;
	}
}
@media (min-width: 768px), print {
	.c-table__content {
		font-size: 1.6rem;
	}
	.c-table__header, .c-table__subheader {
		padding: 28px 10px;
	}
	.c-table__cell {
		padding: 28px 24px;
	}
	.c-table__layouter--for-pc {
		display: table-column-group;
	}
	.c-table__layouter--for-sp {
		display: none;
	}
}

/*----------
	table swipe
----------*/
.c-table-swipe {
	display: block;
	width: 210px;
	height: 28px;
	margin-bottom: 20px;
	background-color: #DDDDDD;
	border-radius: 14px;
	text-align: center;
}
.c-table-swipe::before {
	font-size: 2rem;
	vertical-align: middle;
}
.c-table-swipe::after {
	content: "表は左右にスライドできます";
	display: inline-block;
	font-size: 1.2rem;
	vertical-align: middle;
	margin-left: 8px;
	line-height: 27px;
}
@media (min-width: 768px), print {
	.c-table-swipe {
		display: none;
	}
}

/*----------
	c-qa
----------*/
.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:not(.is-disabled) .c-qa__item--child.is-active {
	height: auto;
	opacity: 1;
	pointer-events: all;
}
.c-qa__item {
	position: relative;
}
.c-qa__item--parent {
	border-bottom: var(--color-border) solid 1px;
}
.c-qa__item--parent::after {
	content: "\e90e";
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	display: inline-block;
	position: absolute;
	right: 20px;
	top: 22px;
	width: 30px;
	height: 30px;
	margin: auto;
	background: var(--color-bg);
	border-radius: 100%;
	color: var(--color-prim);
	text-align: center;
	line-height: 30px;
}
.c-qa__item--parent.is-active {
	border-bottom: none;
}
.c-qa__item--parent.is-active::after {
	content: "\e90b";
	background-color: var(--color-prim);
	color: #fff;
}
.c-qa__item-inner {
	position: relative;
	font-size: 1.6rem;
	line-height: var(--line-height-xl);
	display: flex;
}
.c-qa__item-inner--parent {
	padding: 20px 65px;
	font-weight: 700;
}
.c-qa__item-inner--parent::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 22px;
	left: 20px;
	width: 30px;
	height: 30px;
	background: url(/assets/images/common/icon_qa_q.png) no-repeat 0 0;
	background-size: cover;
}
.c-qa__item-inner--child {
	padding-bottom: 20px;
	border-bottom: 1px solid var(--color-border);
}
.c-qa__item-inner--child__detail {
	display: flex;
	position: relative;
	width: 100%;
	min-height: 70px;
	padding: 20px;
	background-color: var(--color-bg);
	border-radius: 8px;
}
.c-qa__item-inner--child__detail::before {
	content: "";
	display: inline-block;
	width: 30px;
	height: 30px;
	background: url(/assets/images/common/icon_qa_a.png) no-repeat 0 0;
	background-size: cover;
	margin-right: 20px;
}
.c-qa__item-txt {
	flex: 1;
}
@media (min-width: 768px), print {
	.c-qa__item--parent {
		transition: all 0.2s;
	}
	.c-qa__item--parent::after {
		top: 30px;
		width: 40px;
		height: 40px;
		line-height: 40px;
		transition: all 0.2s;
	}
	.c-qa__item--parent:hover {
		border-bottom-color: #fff;
		box-shadow: 0 0 30px rgba(34, 34, 34, 0.2);
	}
	.c-qa__item--parent:hover::before {
		content: "";
		display: block;
		position: relative;
		top: -1px;
		width: 100%;
		height: 1px;
		background-color: #fff;
		z-index: 1;
	}
	.c-qa__item--parent:hover::after {
		background-color: var(--color-prim);
		color: #fff;
	}
	.c-qa__item-inner {
		font-size: 1.8rem;
	}
	.c-qa__item-inner::before {
		width: 40px;
		height: 40px;
	}
	.c-qa__item-inner--parent {
		padding: 33px 80px;
	}
	.c-qa__item-inner--parent::before {
		position: absolute;
		top: 30px;
		left: 20px;
		background: url(/assets/images/common/icon_qa_q.png) no-repeat 0 0;
		background-size: cover;
	}
	.c-qa__item-inner--child {
		padding-bottom: 30px;
	}
	.c-qa__item-inner--child__detail {
		padding: 30px 20px;
	}
	.c-qa__item-inner--child__detail::before {
		width: 40px;
		height: 40px;
		margin-right: 20px;
	}
	.c-qa__item-txt {
		flex: 1;
	}
}

/*----------
	c-accordion
----------*/
.c-accordion + .c-accordion {
	margin-top: 40px;
}
.c-accordion:not(.is-disabled) .c-accordion__item--parent {
	cursor: pointer;
}
.c-accordion:not(.is-disabled) .c-accordion__item--child {
	height: 0;
	position: relative;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
	transform: translateY(10px);
	transition: all 0.4s ease-out;
}
.c-accordion:not(.is-disabled) .c-accordion__item--child.is-active {
	height: auto;
	opacity: 1;
	transform: translateY(0);
	pointer-events: all;
}
.c-accordion:not(.is-disabled) .c-accordion__item-icon {
	visibility: visible;
}
.c-accordion__item--parent {
	position: relative;
	border-bottom: var(--color-border) solid 1px;
}
.c-accordion__item--parent::before {
	content: "\e90e";
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	display: inline-block;
	position: absolute;
	top: 22px;
	right: 0;
	width: 30px;
	height: 30px;
	margin: auto;
	background: var(--color-bg);
	border-radius: 100%;
	color: var(--color-prim);
	text-align: center;
	line-height: 30px;
}
.c-accordion__item--parent::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -1px;
	width: 40px;
	height: 2px;
	background: var(--color-prim);
}
.c-accordion__item--parent.is-active::before {
	content: "\e90b";
	background-color: var(--color-prim);
	color: #fff;
}
.c-accordion__item-inner {
	line-height: var(--line-height-m);
}
.c-accordion__item-inner--parent {
	position: relative;
	padding: 20px 50px 30px 66px;
	font-weight: 500;
	font-size: 2.2rem;
	line-height: var(--line-height-s);
}
.c-accordion__item-inner--child {
	position: relative;
	width: 100%;
	padding: 16px 10px;
	margin-top: 20px;
}
.c-accordion__item-icon {
	display: inline-block;
	position: absolute;
	top: 12px;
	left: 0;
	width: 50px;
	height: 50px;
}
@media (min-width: 768px), print {
	.c-accordion + .c-accordion {
		margin-top: 50px;
	}
	.c-accordion__item--parent {
		transition: color 0.2s;
	}
	.c-accordion__item--parent::before {
		top: 25px;
		right: 20px;
		width: 40px;
		height: 40px;
		line-height: 40px;
		transition: all 0.2s;
	}
	.c-accordion__item--parent:hover {
		color: var(--color-prim);
	}
	.c-accordion__item--parent:hover::before {
		background-color: var(--color-prim);
		color: #fff;
	}
	.c-accordion__item-inner--parent {
		min-height: 110px;
		padding: 20px 80px 30px 100px;
		font-size: 3.2rem;
	}
	.c-accordion__item-inner--child {
		padding: 26px 20px;
	}
	.c-accordion__item-icon {
		top: 0;
		width: 80px;
		height: 80px;
	}
}

/*----------
	checkbox-container
----------*/
.g-checkbox-container__item {
	display: flex;
	justify-content: center;
	margin-top: 16px;
}
.g-checkbox-container a {
	text-decoration: underline;
}

/*----------
	checkbox
----------*/
.c-checkbox {
	/* stylelint-disable no-descending-specificity */
	cursor: pointer;
	/* stylelint-enable no-descending-specificity */
}
.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/contact/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: 50%;
	left: 0;
	width: 18px;
	height: 18px;
	margin-right: 14px;
	background: #fff url(/assets/images/contact/marker_checkbox.svg) no-repeat center;
	background-size: contain;
	transform: translateY(-50%);
}
.c-checkbox span a {
	text-decoration: underline;
}

/*----------
	input
----------*/
.c-input > input[type=text],
.c-input > input[type=number],
.c-input > input[type=email] {
	display: block;
	width: 100%;
	height: 50px;
	padding: 16px 13px;
	border: 1px solid var(--color-border);
	border-radius: 5px;
	appearance: none;
	-webkit-appearance: none;
}
.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);
}
.c-input.is-error > input[type=text],
.c-input.is-error > input[type=number],
.c-input.is-error > input[type=email] {
	color: var(--color-red);
	border-color: var(--color-red);
	background: #FEDFDF;
}

/*----------
	textarea
----------*/
.c-textarea > textarea {
	display: block;
	width: 100%;
	min-height: 180px;
	padding: 13px 17px;
	border: 1px solid var(--color-border);
	border-radius: 5px;
	appearance: none;
	-webkit-appearance: none;
}
.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-red);
	border-color: var(--color-red);
	background: #FEDFDF;
}

/*----------
	select
----------*/
.c-select {
	position: relative;
	cursor: pointer;
}
.c-select::after {
	content: "";
	display: block;
	width: 11px;
	height: 9px;
	background: url(/assets/images/contact/icon_arrow-b.svg) no-repeat 0 0;
	position: absolute;
	top: 50%;
	right: 16px;
	transform: translateY(-50%);
	pointer-events: none;
}
.c-select > select {
	display: block;
	width: 100%;
	height: 50px;
	padding: 8px 13px;
	color: var(--color-txt);
	border: 1px solid var(--color-border);
	border-radius: 5px;
	appearance: none;
	-webkit-appearance: none;
	/* stylelint-disable no-descending-specificity */
}
.c-select > select option:first-child {
	color: var(--color-txt-caption);
}
.c-select > select:invalid {
	color: var(--color-txt-caption);
}
.c-select > select option {
	color: var(--color-txt);
}
.c-select > select::-ms-expand {
	display: none;
}
.c-select.is-error::after {
	color: var(--color-red);
}
.c-select.is-error > select {
	border-color: var(--color-red);
	background: #FEDFDF;
}

/*----------
	inputset
----------*/
.c-inputset__required {
	display: inline-block;
	min-width: 60px;
	margin-left: 10px;
	padding: 6px 8px;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1;
	text-align: center;
	background-color: var(--color-prim);
	border-radius: 4px;
	vertical-align: middle;
}
.c-inputset__required--en {
	color: var(--color-red);
	font-size: 1.6rem;
}
.c-inputset__note {
	margin-top: 12px;
	font-size: 1.2rem;
	line-height: 1.2;
	color: var(--color-txt-caption-v2);
}
.c-inputset__header {
	width: 100%;
	color: var(--color-txt-caption-v2);
	font-size: 1.6rem;
	text-align: left;
}
.c-inputset__errors {
	margin-bottom: 16px;
	color: var(--color-red);
	font-size: 1.6rem;
	line-height: 1.2;
}
@media (max-width: 767px) {
	.c-inputset {
		margin-top: -40px;
	}
	.c-inputset__inner, .c-inputset__body, .c-inputset__row {
		display: block;
		width: 100%;
	}
	.c-inputset__header {
		padding: 40px 0 15px;
	}
	.c-inputset__detail {
		display: block;
		width: 100%;
	}
}
@media (min-width: 768px), print {
	.c-inputset {
		margin-top: -50px;
	}
	.c-inputset__inner {
		width: 100%;
	}
	.c-inputset__header {
		padding: 50px 0 15px;
	}
	.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__required {
		display: inline-block;
	}
	.c-inputset__note {
		font-size: 1.4rem;
	}
}
@media print {
	.c-inputset__inner {
		display: table;
		width: 100%;
	}
	.c-inputset__body {
		display: table-row-group;
	}
	.c-inputset__row {
		display: table-row;
	}
	.c-inputset__header {
		display: table-cell;
		float: none;
	}
	.c-inputset__detail {
		display: table-cell;
		float: none;
		width: auto;
	}
}

/*----------s
	personalset
----------*/
.c-personalset__agreement {
	margin: 20px auto 0;
}
.c-personalset__agreement-body {
	padding: 10px 16px;
	background: var(--color-bg);
	text-align: center;
}
.c-personalset__agreement-check {
	display: table;
	margin: auto;
}
.c-personalset__agreement-error {
	text-align: center;
}
.c-personalset__note {
	margin: 20px auto 0;
	line-height: var(--line-height-m);
	color: var(--color-txt-caption);
	text-align: center;
}
.c-personalset__submit {
	margin: 60px auto 0;
}
.c-personalset__submit--2clm {
	display: flex;
	flex-direction: column-reverse;
	gap: 40px 0;
}
.c-personalset__submit-inner {
	display: flex;
	width: 100%;
	height: 100%;
	min-height: 50px;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	position: relative;
	border: 1px solid var(--color-txt-caption);
	background-color: var(--color-txt-caption);
	border-radius: 25px;
	color: #fff;
	cursor: pointer;
}
.c-personalset__submit-inner[disabled] {
	background-color: var(--color-txt-caption);
	cursor: default;
}
.c-personalset__submit-inner:not([disabled]) {
	cursor: pointer;
	border: 1px solid var(--color-prim);
	background-color: var(--color-prim);
}
.c-personalset__submit-inner::before {
	content: "";
	display: block;
	background: url(/assets/images/contact/icon_arrow-r.svg) no-repeat 0 0;
	background-size: cover;
	position: absolute;
	top: 50%;
	right: 20px;
	width: 18px;
	height: 18px;
	transform: translateY(-50%);
}
.c-personalset__submit-inner.c-personalset__submit-inner--back {
	color: var(--color-prim);
	border: 1px solid var(--color-prim);
	background-color: #fff;
}
.c-personalset__submit-inner.c-personalset__submit-inner--back::before {
	background: url(/assets/images/contact/icon_arrow-r-hvr.svg) no-repeat 0 0;
	right: auto;
	left: 20px;
	transform: translateY(-50%) rotate(180deg);
}
.c-personalset__submit-inner > span {
	padding: 8px 45px;
	text-align: center;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
	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__agreement {
		margin: 80px auto 0;
	}
	.c-personalset__agreement-body {
		padding: 25px;
	}
	.c-personalset__note {
		margin: 20px auto 0;
	}
	.c-personalset__submit {
		max-width: 372px;
		margin: 80px auto 0;
	}
	.c-personalset__submit--2clm {
		flex-direction: row;
		max-width: 800px;
		gap: 0 40px;
	}
	.c-personalset__submit-inner {
		transition: background-color 0.2s, opacity 0.2s;
	}
	.c-personalset__submit-inner:not([disabled]):hover {
		color: var(--color-prim);
		background-color: #fff;
	}
	.c-personalset__submit-inner:not([disabled]):hover::before {
		background: url(/assets/images/contact/icon_arrow-r-hvr.svg) no-repeat 0 0;
		background-size: cover;
	}
	.c-personalset__submit-inner.c-personalset__submit-inner--back:hover {
		color: #fff;
		background-color: var(--color-prim);
	}
	.c-personalset__submit-inner.c-personalset__submit-inner--back:hover::before {
		background: url(/assets/images/contact/icon_arrow-r.svg) no-repeat 0 0;
	}
	.c-personalset__submit-inner > span {
		font-size: 1.6rem;
	}
}

/*----------
	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 100%;
		max-width: 100%;
	}
	.g-center-col__item + .g-center-col__item {
		margin-top: 0;
	}
	.g-center-col--maxwidth .g-center-col__item {
		flex-basis: 83.3333333333%;
		max-width: 83.3333333333%;
	}
	.g-center-col--w400 .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: 28px;
	}
}
@media (min-width: 768px), print {
	.g-grid {
		width: 50%;
	}
	.g-grid__item + .g-grid__item {
		margin-top: 42px;
	}
	@supports (display: grid) {
		.g-grid {
			display: grid;
			gap: 42px;
			width: auto;
		}
		.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);
		}
		.g-grid__item + .g-grid__item {
			margin-top: 0;
		}
	}
}

/*----------
	profileset
----------*/
.c-profileset .c-profileset__item {
	margin-top: 40px;
}
.c-profileset__header {
	margin-bottom: 30px;
}
.c-profileset__header__image {
	border-radius: 8px;
	overflow: hidden;
}
.c-profileset__header__detail {
	margin-top: 20px;
}
.c-profileset__header__job {
	margin-bottom: 8px;
	color: var(--color-prim);
	font-size: 1.4rem;
}
.c-profileset__header__name {
	font-weight: 700;
	font-size: 2rem;
	line-height: 1.45;
}
.c-profileset__header__ruby {
	color: var(--color-txt-caption);
	font-size: 1.2rem;
	font-weight: 700;
}
.c-profileset__trigger {
	position: relative;
	padding: 20px;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	font-size: 1.4rem;
	text-align: center;
	cursor: pointer;
}
.c-profileset__trigger::before {
	content: "\e90e";
	font-family: iconfont !important; /* stylelint-disable-line declaration-no-important,font-family-no-missing-generic-family-keyword */
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	display: inline-block;
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	width: 30px;
	height: 30px;
	margin: auto;
	color: var(--color-prim);
	line-height: 30px;
}
.c-profileset__trigger.is-active {
	color: #fff;
	background-color: var(--color-prim);
	border-top: 1px solid var(--color-prim);
	border-bottom: 1px solid var(--color-prim);
}
.c-profileset__trigger.is-active::before {
	color: #fff;
	content: "\e90b";
}
.c-profileset__trigger.is-active::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -12px;
	left: 50%;
	transform: translateX(-50%);
	width: 0;
	height: 0;
	border-style: solid;
	border-right: 14px solid transparent;
	border-left: 14px solid transparent;
	border-top: 12px solid var(--color-prim);
	border-bottom: 0;
}
.c-profileset__career {
	height: 0;
	position: relative;
	overflow: hidden;
	opacity: 0;
	pointer-events: none;
	transition: all 0.4s linear;
}
.c-profileset__career.is-active {
	height: auto;
	opacity: 1;
	pointer-events: all;
}
.c-profileset__lower__detail {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	background-color: var(--color-bg);
	border-top: 1px solid var(--color-border);
	margin-top: 42px;
}
.c-profileset__lower__detail dt {
	flex: 0 0 30%;
	align-self: stretch;
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	border-bottom: 1px solid var(--color-border);
}
.c-profileset__lower__detail dd {
	flex: 0 0 70%;
	padding: 20px;
	background-color: #fff;
	border-bottom: 1px solid var(--color-border);
}
@media (min-width: 768px), print {
	.c-profileset__upper {
		display: flex;
		gap: 0 42px;
	}
	.c-profileset__item {
		flex: 1 1 33.3333333333%;
		max-width: 372px;
	}
	.c-profileset__header {
		margin-bottom: 40px;
	}
	.c-profileset__header__detail {
		margin-top: 30px;
	}
	.c-profileset__header__job {
		margin-bottom: 12px;
		font-size: 1.6rem;
	}
	.c-profileset__header__name {
		font-size: 2.4rem;
	}
	.c-profileset__header__ruby {
		font-size: 1.4rem;
	}
	.c-profileset__cts {
		display: none;
	}
	.c-profileset__trigger {
		flex: 1 1 33.3333333333%;
		max-width: 372px;
		position: relative;
		padding: 17px 38px;
		font-size: 1.6rem;
		transition: color 0.2s, background-color 0.2s, border 0.2s;
	}
	.c-profileset__trigger::before {
		transition: color 0.2s;
	}
	.c-profileset__trigger:hover {
		color: #fff;
		background-color: var(--color-prim);
		border-top: 1px solid var(--color-prim);
		border-bottom: 1px solid var(--color-prim);
	}
	.c-profileset__trigger:hover::before {
		color: #fff;
	}
	.c-profileset__lower__header {
		display: flex;
		gap: 0 42px;
	}
	.c-profileset__lower__detail {
		margin-top: 55px;
	}
	.c-profileset__lower__detail dt {
		flex: 0 0 11.67%;
	}
	.c-profileset__lower__detail dd {
		flex: 0 0 88.33%;
	}
}

/*----------
	modal
----------*/
@media (max-width: 767px) {
	.c-modal {
		pointer-events: none;
	}
	.c-modal__icon {
		display: none;
	}
	.c-modal__wrapper {
		display: none;
	}
}
@media (min-width: 768px), print {
	.c-modal__image {
		display: block;
		position: relative;
		cursor: pointer;
	}
	.c-modal__icon {
		display: block;
		position: absolute;
		right: 0;
		bottom: 0;
		width: 40px;
		height: 40px;
		background: var(--color-prim);
		border-radius: 8px 0;
	}
	.c-modal__icon::after {
		content: "";
		display: block;
		position: absolute;
		top: 50%;
		left: 50%;
		width: 18px;
		height: 18px;
		background: url(/assets/images/common/icon_zoom.png) no-repeat 0 0;
		background-size: cover;
		transform: translate(-50%, -50%);
	}
	.c-modal__wrapper {
		width: 100%;
		height: 100%;
		position: fixed;
		top: 0;
		left: 0;
		background: rgba(0, 0, 0, 0.7);
		pointer-events: none;
		opacity: 0;
		transition: 0.25s ease-out;
		z-index: 100;
	}
	.c-modal__wrapper.is-show {
		opacity: 1;
		pointer-events: all;
	}
	.c-modal__wrapper.is-show .c-modal__contents {
		opacity: 1;
	}
	.c-modal__contents {
		position: absolute;
		width: 60%;
		max-height: 100%;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		object-fit: cover;
		opacity: 0;
		transition: 0.5s ease-out;
	}
	.c-modal__caption {
		color: #fff;
		font-size: 1.4rem;
		margin-top: 5px;
	}
}