@charset "UTF-8";
/*----------
	icons
----------*/
@font-face {
	font-family: iconfont;
	src: url(/_assets_company/_fonts/iconfont.woff) format("woff"), url(/_assets_company/_fonts/iconfont.svg) format("svg");
	font-weight: normal;
	font-style: normal;
	font-display: block;
}
.icon, .icon-search, .icon-plus, .icon-minus, .icon-language, .icon-keyword, .icon-download, .icon-close, .icon-blank, .icon-arrow2-r, .icon-arrow2-b, .icon-arrow1-t, .icon-arrow1-r {
	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-arrow1-r::before {
	content: "\e901";
}
.icon-arrow1-t::before {
	content: "\e902";
}
.icon-arrow2-b::before {
	content: "\e903";
}
.icon-arrow2-r::before {
	content: "\e904";
}
.icon-blank::before {
	content: "\e905";
}
.icon-close::before {
	content: "\e906";
}
.icon-download::before {
	content: "\e907";
}
.icon-keyword::before {
	content: "\e908";
}
.icon-language::before {
	content: "\e909";
}
.icon-minus::before {
	content: "\e90a";
}
.icon-plus::before {
	content: "\e90b";
}
.icon-search::before {
	content: "\e90c";
}

/*----------
	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: 140px;
}
.c-logo > img {
	display: block;
	width: auto;
	max-width: 100%;
	height: auto;
}
@media (width >= 768px), print {
	.c-logo {
		width: 374px;
	}
}

/*----------
	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: var(--color-txt-caption);
}
.c-tag > a,
.c-tag > span {
	height: 20px;
	display: block;
	max-width: 100%;
	min-width: 80px;
	padding: 0 8px;
	color: inherit;
	background-color: #DCE8E8;
	border-radius: 12px;
	overflow: hidden;
	text-align: center;
	white-space: nowrap;
	text-overflow: ellipsis;
	font-size: 1.2rem;
	font-weight: 500;
	line-height: 20px;
}
@media (width >= 768px), print {
	.c-tag > a,
	.c-tag > span {
		height: 24px;
		min-width: 110px;
		font-size: 1.4rem;
		line-height: 24px;
	}
}

/*----------
	pdf
----------*/
.c-pdf {
	display: inline-block;
	transform: translateY(-1px);
	width: 37px;
	height: 16px;
	margin-left: 8px;
	background-color: #E55454;
	border-radius: 5px;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.1rem;
	font-weight: 500;
	text-align: center;
	text-transform: uppercase;
	line-height: 16px;
}
@media (width >= 768px), print {
	.c-pdf {
		width: 40px;
		height: 18px;
		font-size: 1.3rem;
		line-height: 18px;
		transform: translateY(-2px);
	}
}

/*----------
	xlsx
----------*/
.c-xlsx {
	display: inline-block;
	transform: translateY(-1px);
	width: 37px;
	height: 16px;
	margin-left: 8px;
	background-color: #67B921;
	border-radius: 5px;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.1rem;
	font-weight: 500;
	text-align: center;
	text-transform: uppercase;
	line-height: 16px;
}
@media (width >= 768px), print {
	.c-xlsx {
		width: 40px;
		height: 18px;
		font-size: 1.3rem;
		line-height: 18px;
		transform: translateY(-2px);
	}
}

/*----------
	file-data
----------*/
.c-file-data {
	position: relative;
	top: 2px;
	display: inline-block;
	margin-left: 5px;
	font-size: 1.2rem;
	color: inherit;
	transform: translateY(-2px);
}
@media (width >= 768px), print {
	.c-file-data {
		font-size: 1.4rem;
		transform: translateY(-3px);
	}
}

/*----------
	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;
}
.c-figure__image > img {
	max-width: 100%;
	width: auto;
}

/*----------
	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 i::before {
	font-size: 2rem;
	vertical-align: middle;
}
.c-image-scaling__text {
	display: inline-block;
	font-size: 1.2rem;
	vertical-align: middle;
	margin-left: 8px;
}
@media (width >= 768px), print {
	.c-image-scaling {
		display: none;
	}
}

/*----------
	youtube
----------*/
.c-youtube {
	position: relative;
}
.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%;
}

/*----------
	content box
----------*/
.c-contentbox {
	padding: 30px 20px;
	background-color: var(--color-bg);
	border-radius: 10px;
}
@media (width >= 768px), print {
	.c-contentbox {
		padding: 40px 30px;
	}
}

/*----------
	support
----------*/
.c-support {
	padding: 0 15px;
	margin: 20px auto 0;
	background-color: var(--color-bg);
	border-radius: 15px;
	color: #456383;
	font-size: 1.1rem;
	line-height: 36px;
	font-weight: 500;
}
.c-support::before {
	content: "";
	display: inline-block;
	position: relative;
	top: -2px;
	width: 16px;
	height: 16px;
	margin-right: 5px;
	vertical-align: middle;
}
.c-support--scroll {
	width: 185px;
}
.c-support--scroll::before {
	background: url(/_assets_company/_images/common/icon_swipe.svg) no-repeat 0 0/cover;
}
.c-support--pinchout {
	width: 250px;
}
.c-support--pinchout::before {
	background: url(/_assets_company/_images/common/icon_pinchout.svg) no-repeat 0 0/cover;
}
@media (width >= 768px), print {
	.c-support {
		display: none;
	}
}

/*----------
	billboard
----------*/
.c-billboard {
	position: relative;
	height: 270px;
	margin-bottom: 60px;
	z-index: var(--z-2);
}
.c-billboard__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 30px;
	padding-right: 30px;
}
@media (width >= 768px), print {
	.c-billboard__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard__inner {
	height: 100%;
}
.c-billboard__main {
	display: grid;
	place-content: center;
	width: 100%;
	height: 100%;
}
.c-billboard__title {
	color: var(--color-txt);
	font-weight: 500;
	font-size: 3.6rem;
	line-height: var(--line-height-xs);
	text-align: center;
}
.c-billboard__title-sub {
	margin-top: 10px;
	color: var(--color-prim);
	font-family: var(--font-roboto);
	font-weight: 500;
	font-size: 1.3rem;
	text-align: center;
	text-transform: uppercase;
}
.c-billboard__image {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: var(--z-back);
}
.c-billboard__image > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (width >= 768px), print {
	.c-billboard {
		width: 100%;
		height: 430px;
		margin-bottom: 100px;
	}
	.c-billboard__title {
		font-size: 6rem;
	}
	.c-billboard__title-sub {
		font-size: 1.8rem;
	}
}

/*----------
	billboard
----------*/
.c-billboard-v2 {
	position: relative;
	margin-bottom: 60px;
}
.c-billboard-v2__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 30px;
	padding-right: 30px;
}
@media (width >= 768px), print {
	.c-billboard-v2__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-billboard-v2__main {
	padding-top: 60px;
}
.c-billboard-v2__title {
	position: relative;
	padding-bottom: 50px;
	color: var(--color-txt);
	font-weight: 500;
	font-size: 3.2rem;
	line-height: 1.5;
}
.c-billboard-v2__title::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 110px;
	height: 2px;
	background-color: var(--color-prim);
	border-radius: 20px;
}
.c-billboard-v2__title-lv2 {
	margin-bottom: 10px;
	color: var(--color-prim);
	font-weight: 500;
	font-size: 1.8rem;
}
.c-billboard-v2__title-sub {
	margin-left: 10px;
	color: var(--color-bg-dark);
	font-weight: 700;
	font-size: 2.2rem;
}
.c-billboard-v2__image {
	width: 100%;
	height: 200px;
}
.c-billboard-v2__image > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (width >= 768px), print {
	.c-billboard-v2 {
		margin-bottom: 100px;
	}
	.c-billboard-v2__main {
		padding-top: 74px;
	}
	.c-billboard-v2__title {
		padding-bottom: 90px;
		font-size: 5rem;
		line-height: 1.13;
	}
	.c-billboard-v2__title::after {
		width: 200px;
		height: 4px;
	}
	.c-billboard-v2__title-lv2 {
		margin-bottom: 5px;
		font-size: 2.8rem;
	}
	.c-billboard-v2__title-sub {
		margin-left: 22px;
		font-size: 3.4rem;
	}
	.c-billboard-v2__image {
		height: 320px;
	}
}

/*----------
	heading-primary
----------*/
.c-heading-primary {
	padding-top: 60px;
	margin-bottom: 60px;
	border-bottom: 1px solid var(--color-border);
}
.c-heading-primary__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 30px;
	padding-right: 30px;
}
@media (width >= 768px), print {
	.c-heading-primary__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.c-heading-primary__inner {
	padding-inline: 20px;
}
.c-heading-primary__title {
	position: relative;
	padding-bottom: 50px;
	color: var(--color-txt);
	font-weight: 500;
	font-size: 3.2rem;
	line-height: 1.5;
}
.c-heading-primary__title::after {
	content: "";
	display: block;
	position: absolute;
	left: 0;
	bottom: 0;
	width: 110px;
	height: 2px;
	background-color: var(--color-prim);
	border-radius: 20px;
}
.c-heading-primary__lv2 {
	margin-bottom: 10px;
	color: var(--color-prim);
	font-weight: 500;
	font-size: 1.8rem;
}
@media (width >= 768px), print {
	.c-heading-primary {
		padding-top: 74px;
		margin-bottom: 100px;
	}
	.c-heading-primary__title {
		padding-bottom: 90px;
		font-size: 5rem;
		line-height: 1.13;
	}
	.c-heading-primary__title::after {
		width: 200px;
		height: 4px;
	}
	.c-heading-primary__lv2 {
		margin-bottom: 5px;
		font-size: 2.8rem;
	}
}

/*----------
	heading-secondary
----------*/
.c-heading-secondary {
	margin-top: 80px;
	margin-bottom: 40px;
	color: var(--color-txt);
	font-size: 2.4rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	border-bottom: 1px solid var(--color-border);
}
.c-heading-secondary::after {
	content: "";
	display: block;
	position: relative;
	top: 0.8px;
	width: 50px;
	height: 2px;
	background: var(--color-prim);
	border-radius: 20px;
	margin-top: 16px;
}
@media (width >= 768px), print {
	.c-heading-secondary {
		margin-top: 100px;
		margin-bottom: 50px;
		font-size: 3.2rem;
	}
	.c-heading-secondary::after {
		width: 70px;
		margin-top: 14px;
	}
}

/*----------
	heading-secondarybox
----------*/
.c-heading-secondarybox {
	padding: 10px 20px;
	margin-top: 40px;
	margin-bottom: 30px;
	background-color: #DCE8E8;
	border-radius: 10px;
	color: var(--color-txt);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-m);
	text-align: center;
}
.c-heading-secondarybox > * {
	position: relative;
	display: inline-block;
	padding-left: 35px;
}
.c-heading-secondarybox-icon {
	display: block;
	position: absolute;
	top: 3px;
	left: 0;
	width: 26px;
	height: 26px;
	background-color: var(--color-bg-dark);
	border-radius: 100%;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: 26px;
	text-align: center;
}
.c-heading-secondarybox--left {
	text-align: left;
}
@media (width >= 768px), print {
	.c-heading-secondarybox {
		padding: 17px 30px;
		margin-top: 50px;
		margin-bottom: 50px;
		font-size: 2.4rem;
	}
	.c-heading-secondarybox > * {
		padding-left: 50px;
	}
	.c-heading-secondarybox-icon {
		top: 2px;
		width: 35px;
		height: 35px;
		font-size: 2.4rem;
		line-height: 36px;
	}
}

/*----------
	heading-tertiary
----------*/
.c-heading-tertiary {
	margin-top: 40px;
	margin-bottom: 25px;
	color: var(--color-txt);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-s);
}
.c-heading-tertiary::after {
	content: "";
	display: block;
	width: 20px;
	height: 2px;
	background: var(--color-prim);
	border-radius: 20px;
	margin-top: 10px;
}
@media (width >= 768px), print {
	.c-heading-tertiary {
		margin-top: 50px;
		margin-bottom: 30px;
		font-size: 2.4rem;
	}
	.c-heading-tertiary::after {
		width: 30px;
	}
}

/*----------
	heading-quaternary
----------*/
.c-heading-quaternary {
	position: relative;
	padding-left: 10px;
	margin-block: 25px 10px;
	color: var(--color-txt);
	font-weight: 500;
	font-size: 1.6rem;
	line-height: var(--line-height-m);
}
.c-heading-quaternary::before {
	content: "";
	display: block;
	position: absolute;
	top: 3px;
	left: 0;
	width: 2px;
	height: calc(100% - 6px);
	background-color: var(--color-prim);
}
@media (width >= 768px), print {
	.c-heading-quaternary {
		margin-top: 30px;
		margin-bottom: 15px;
		font-size: 1.8rem;
	}
}

/*----------
	heading-image
----------*/
.c-heading-other {
	margin-block: 25px 20px;
}
.c-heading-other > * {
	color: #456383;
	font-weight: 500;
	font-size: 1.6rem;
}
@media (width >= 768px), print {
	.c-heading-other {
		margin-block: 30px 20px;
	}
	.c-heading-other > * {
		font-size: 1.8rem;
	}
}

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

/*----------
	flextext
----------*/
.c-flextext {
	display: flex;
	font-size: 1.1rem;
	line-height: var(--line-height-l);
}
.c-flextext dt {
	margin-right: 5px;
	white-space: nowrap;
}
@media (width >= 768px), print {
	.c-flextext {
		font-size: 1.4rem;
	}
}

/*----------
	lead
----------*/
.c-lead {
	color: var(--color-txt);
	font-size: 1.8rem;
	font-weight: 500;
	line-height: var(--line-height-xl);
}
@media (width >= 768px), print {
	.c-lead {
		font-size: 2.2rem;
	}
}

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

/*----------
	icontext
----------*/
.c-icontext > a,
.c-icontext > span {
	display: inline-block;
	position: relative;
	padding-left: 19px;
	color: var(--color-txt);
	font-size: 1.4rem;
}
.c-icontext > a i[class^=icon-],
.c-icontext > span i[class^=icon-] {
	text-indent: 0;
	color: var(--color-prim);
}
.c-icontext .icon-arrow1-r,
.c-icontext .icon-arrow2-r {
	position: absolute;
	top: 1px;
	left: 0;
	font-size: 1.3rem;
}
.c-icontext .icon-arrow1-r {
	transform: translateY(0.35em);
}
.c-icontext .icon-arrow2-r {
	transform: translateY(0.5em);
}
.c-icontext .icon-blank {
	display: inline-block;
	transform: translateY(0.2em);
	margin-left: 3px;
	font-size: 1.8rem;
}
.c-icontext--sizel > a,
.c-icontext--sizel > span {
	padding-left: 28px;
	font-size: 1.6rem;
	font-weight: 500;
}
.c-icontext--sizel .icon-arrow1-r {
	left: 0;
	font-size: 2rem;
}
.c-icontext--sizel .icon-blank {
	display: inline-block;
	margin-left: 3px;
	font-size: 1.2rem;
}
@media (width >= 768px), print {
	.c-icontext > a,
	.c-icontext > span {
		padding-left: 20px;
		font-size: 1.6rem;
	}
	.c-icontext .icon-arrow2-r {
		transform: translateY(0.5em);
		font-size: 1.6rem;
	}
	.c-icontext .icon-blank {
		display: inline-block;
		transform: translateY(0.2em);
		margin-left: 5px;
		font-size: 2rem;
	}
	.c-icontext--sizel > a,
	.c-icontext--sizel > span {
		padding-left: 29px;
		font-size: 1.8rem;
	}
	.c-icontext--sizel i[class^=icon-] {
		font-size: 2.4rem;
	}
}
@media (hover: hover) {
	.c-icontext > a {
		transition: color 0.3s;
	}
	.c-icontext > a:hover {
		color: var(--color-txt-hover);
	}
}

/*----------
	list
----------*/
.c-list__item {
	position: relative;
	padding-left: 16px;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
}
.c-list__item::before {
	content: "";
	display: inline-block;
	position: absolute;
	top: 8px;
	left: 0;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background-color: #446383;
	font-size: 1.4rem;
}
+ .c-list__item__item {
	margin-top: 8px;
}
@media (width >= 768px), print {
	.c-list__item {
		font-size: 1.6rem;
	}
	.c-list__item::before {
		top: 10px;
	}
}
.c-list--none .c-list__item {
	padding-left: 0;
}
.c-list--none .c-list__item::before {
	display: none;
}

/*----------
	order list
----------*/
.c-orderlist {
	counter-reset: orderlist;
}
.c-orderlist__item {
	padding-left: 2em;
	text-indent: -2.5em;
	line-height: var(--line-height-l);
}
.c-orderlist__item::before {
	counter-increment: orderlist;
	content: counter(orderlist) ".";
	display: inline-block;
	margin-right: 0.5em;
	min-width: 2em;
	color: #446383;
	font-weight: 600;
	text-align: right;
}
.c-orderlist__item + .c-orderlist__item {
	margin-top: 8px;
}

/*----------
	remarks
----------*/
.c-remarks {
	font-size: 1.1rem;
	line-height: var(--line-height-l);
}
.c-remarks__item {
	padding-left: 1.5em;
	text-indent: -0.75em;
	color: var(--color-bg-dark);
}
.c-remarks__item a {
	color: var(--color-bg-dark);
	transition: color 0.3s;
}
.c-remarks__item::before {
	content: "※";
	display: inline-block;
	margin-right: 0.5em;
}
.c-remarks__item + .c-remarks__item {
	margin-top: 5px;
}
.c-remarks--inline {
	display: flex;
	flex-wrap: wrap;
}
.c-remarks--inline .c-remarks__item {
	display: inline-block;
	margin-right: 10px;
	margin-left: 0;
}
.c-remarks--inline .c-remarks__item + .c-remarks__item {
	margin-top: 0;
}
.c-remarks--order {
	counter-reset: orderlist;
}
.c-remarks--order .c-remarks__item {
	position: relative;
	padding-left: 3em;
	text-indent: 0;
}
.c-remarks--order .c-remarks__item::before {
	counter-increment: orderlist;
	content: "※" counter(orderlist);
	min-width: 2em;
	text-align: right;
	position: absolute;
	top: 0;
	left: 0;
}
.c-remarks--start1 {
	counter-reset: orderlist 0;
}
.c-remarks--start2 {
	counter-reset: orderlist 1;
}
.c-remarks--start3 {
	counter-reset: orderlist 2;
}
.c-remarks--start4 {
	counter-reset: orderlist 2;
}
.c-remarks--start5 {
	counter-reset: orderlist 4;
}
.c-remarks--start6 {
	counter-reset: orderlist 5;
}
.c-remarks--start7 {
	counter-reset: orderlist 6;
}
.c-remarks--start8 {
	counter-reset: orderlist 7;
}
.c-remarks--start9 {
	counter-reset: orderlist 8;
}
.c-remarks--start10 {
	counter-reset: orderlist 9;
}
.c-remarks--none .c-remarks__item {
	padding-left: 0;
	text-indent: 0;
}
.c-remarks--none .c-remarks__item::before {
	display: none;
}
@media (width >= 768px), print {
	.c-remarks {
		font-size: 1.4rem;
	}
}
@media (hover: hover) {
	.c-remarks__item a:hover {
		color: var(--color-prim);
	}
}

/*----------
	anchor
----------*/
.c-anchor__item {
	border: #CCC solid 1px;
}
.c-anchor__item:not(:last-child) {
	border-bottom: none;
}
.c-anchor__link {
	display: block;
	height: 100%;
	padding: 17px 48px 17px 24px;
	position: relative;
}
.c-anchor__text {
	font-size: 1.5rem;
	line-height: var(--line-height-m);
}
.c-anchor__icon {
	position: absolute;
	right: 16px;
	top: 0;
	bottom: 0;
	margin: auto;
	color: var(--color-txt);
	display: flex;
	align-items: center;
}
@media (width < 768px) {
	.c-anchor__text {
		color: var(--color-txt);
	}
}
@media (width >= 768px), print {
	.c-anchor {
		display: flex;
		flex-wrap: wrap;
		gap: 10px 0;
	}
	.c-anchor__item {
		width: 25%;
		border: none;
		border-left: #CCC solid 1px;
		text-align: center;
	}
	.c-anchor__item:nth-child(4n), .c-anchor__item:last-child {
		border-right: #CCC solid 1px;
	}
	.c-anchor__link {
		padding: 10px 15px 23px;
	}
	.c-anchor__text {
		font-size: 1.6rem;
		transition: color 0.3s;
	}
	.c-anchor__icon {
		left: 0;
		right: 0;
		top: auto;
		bottom: 5px;
		justify-content: center;
	}
}
@media (hover: hover) {
	.c-anchor__link:hover .c-anchor__text {
		color: var(--color-txt-hover);
	}
}

/*----------
	button
----------*/
.c-button__inner {
	position: relative;
	display: flex;
	flex-wrap: nowrap;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	min-height: 50px;
	padding: 8px 40px;
	background-color: #424A4D;
	border-radius: calc(infinity * 1px);
	color: #fff;
	text-align: center;
	font-size: 1.5rem;
	font-weight: 500;
	line-height: var(--line-height-s);
	cursor: pointer;
	overflow: hidden;
}
.c-button__icon {
	position: absolute;
	top: 0;
	bottom: 0;
	right: 15px;
	width: 20px;
	height: 20px;
	margin: auto;
	color: var(--color-prim);
	font-size: 2rem;
	line-height: 1;
}
@media (width >= 768px), print {
	.c-button__inner {
		min-height: 60px;
		padding: 8px 45px;
		font-size: 1.8rem;
	}
	.c-button__icon {
		width: 24px;
		height: 24px;
		right: 25px;
		font-size: 2.4rem;
	}
}
@media (hover: hover) {
	.c-button__inner {
		transition: background-color 0.3s, color 0.3s;
	}
	.c-button__inner .c-button__icon {
		transition: color 0.3s;
	}
	.c-button__inner:hover {
		background-color: var(--color-prim);
		color: #fff;
	}
	.c-button__inner:hover .c-button__icon {
		color: #fff;
	}
}

/* バリエーション */
/* color */
.c-button--seco .c-button__inner {
	background-color: #fff;
	border: 1px solid var(--color-border);
	color: var(--color-txt);
}
@media (hover: hover) {
	.c-button--seco .c-button__inner {
		transition: color 0.3s;
	}
	.c-button--seco .c-button__inner:hover {
		color: var(--color-prim);
	}
	.c-button--seco .c-button__inner:hover .c-button__icon {
		color: var(--color-prim);
	}
}

/* color */
.c-button--download .c-button__inner {
	padding: 13px 45px;
	text-align: left;
	font-weight: 600;
	font-size: 1.5rem;
}
.c-button--download .c-button__inner .c-file-data {
	font-size: 1.3rem;
}
@media (width >= 768px), print {
	.c-button--download .c-button__inner {
		font-size: 1.8rem;
	}
	.c-button--download .c-button__inner .c-file-data {
		font-size: 1.5rem;
	}
}

/* textlink */
.c-button--textlink .c-button__inner {
	justify-content: flex-start;
	min-height: 50px;
	padding: 0 0 16px;
	border: none;
	border-radius: 0;
	background: transparent url(/_assets_company/_images/common/line_border.png) repeat-x left bottom;
	background-size: auto 1px;
	color: var(--color-txt);
	text-align: left;
}
.c-button--textlink__text {
	position: relative;
	display: block;
	padding-right: 40px;
	width: 100%;
	font-size: 1.8rem;
	line-height: var(--line-height-m);
}
.c-button--textlink__pdf {
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 37px;
	height: 16px;
	margin-left: 8px;
	background-color: #E55454;
	border-radius: 5px;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.1rem;
	font-weight: 500;
	text-align: center;
	line-height: var(--line-height-m);
}
.c-button--textlink__file {
	display: inline-block;
	margin-left: 5px;
	font-size: 1.2rem;
	transform: translateY(-2px);
}
.c-button--textlink .c-button__icon {
	right: 10px;
	color: var(--color-prim);
	font-size: 2rem;
	line-height: 1;
}
@media (width >= 768px), print {
	.c-button--textlink .c-button__inner {
		min-height: 60px;
		padding: 0 0 30px 0;
	}
	.c-button--textlink__text {
		font-size: 2rem;
	}
	.c-button--textlink__pdf {
		width: 40px;
		height: 18px;
		font-size: 1.3rem;
		line-height: 18px;
	}
	.c-button--textlink .c-button__icon {
		right: 0;
		font-size: 2.4rem;
		transform: none;
	}
}
@media (hover: hover) {
	.c-button--textlink .c-button__inner {
		transition: color 0.3s;
	}
	.c-button--textlink .c-button__inner:hover {
		color: var(--color-prim);
	}
	.c-button--textlink .c-button__inner:hover .c-button__icon {
		color: var(--color-prim);
	}
}
.c-button--textlink--lv3 .c-button__icon {
	display: grid;
	place-content: center;
	right: 0;
	background-color: var(--color-prim);
	border-radius: 100%;
	width: 23px;
	height: 23px;
	color: #fff;
	font-size: 1.8rem;
	line-height: 1;
}
@media (width >= 768px), print {
	.c-button--textlink--lv3 .c-button__inner {
		min-height: 80px;
	}
	.c-button--textlink--lv3 .c-button__icon {
		width: 26px;
		height: 26px;
		font-size: 2rem;
		transform: none;
	}
}
@media (hover: hover) {
	.c-button--textlink--lv3 .c-button__inner {
		transition: color 0.3s;
	}
	.c-button--textlink--lv3 .c-button__inner:hover {
		color: var(--color-prim);
	}
	.c-button--textlink--lv3 .c-button__inner:hover .c-button__icon {
		color: #fff;
	}
}

/*----------
	button container
----------*/
.g-button-container {
	margin-inline: auto;
}
@media (width < 768px) {
	.g-button-container__item {
		margin: 0 auto 30px;
	}
	.g-button-container__item:last-child {
		margin-bottom: 0;
	}
	.g-button-container:has(.c-button--textlink) .g-button-container__item {
		margin-bottom: 20px;
	}
}
@media (width >= 768px), print {
	.g-button-container__item {
		max-width: 373px;
		margin-left: auto;
		margin-right: auto;
	}
	.g-button-container__item + .g-button-container__item {
		margin-top: 40px;
	}
	.g-button-container {
		display: flex;
		flex-wrap: nowrap;
		justify-content: center;
		align-items: stretch;
	}
	.g-button-container .g-button-container__item {
		flex: 1 1 373px;
		margin: 0;
	}
	.g-button-container--2up {
		justify-content: center;
	}
	.g-button-container--2up .g-button-container__item {
		flex: 1 1 373px;
	}
	.g-button-container--2up .g-button-container__item + .g-button-container__item {
		margin-left: 40px;
	}
	.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: 40px;
	}
	.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);
	}
}

/*----------
	fileblock
----------*/
.c-fileblock {
	background-color: var(--color-bg);
}
.c-fileblock__contents {
	padding: 30px 20px 40px;
}
.c-fileblock__title {
	color: var(--color-txt);
	font-size: 1.8rem;
	font-weight: 500;
}
.c-fileblock__detail {
	overflow: hidden;
	margin-top: 20px;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
}
.c-fileblock__detail dt {
	clear: left;
	float: left;
	margin-right: 5px;
	color: var(--color-txt-sub);
	font-weight: 600;
	white-space: nowrap;
}
.c-fileblock__detail dd {
	float: left;
	flex: 0 0 100%;
}
.c-fileblock__button {
	margin-top: 30px;
}
@media (width >= 768px), print {
	.c-fileblock {
		display: flex;
		align-items: center;
	}
	.c-fileblock__image {
		flex: 0 0 400px;
	}
	.c-fileblock__contents {
		flex: 0 0 calc(100% - 400px);
		padding: 0 55px;
	}
	.c-fileblock__summary {
		display: grid;
		place-content: center;
	}
	.c-fileblock__title {
		font-size: 2.2rem;
	}
	.c-fileblock__detail {
		margin-top: 20px;
		font-size: 1.6rem;
	}
	.c-fileblock__button {
		max-width: 490px;
		margin: 50px auto 0;
	}
	.c-fileblock--1t1 .c-fileblock__image,
	.c-fileblock--1t1 .c-fileblock__contents {
		flex: 0 0 600px;
	}
}

/*----------
	imageset
----------*/
.c-imageset__title {
	font-weight: 700;
	font-size: 1.8rem;
	line-height: var(--line-height-s);
}
.c-imageset__text {
	line-height: var(--line-height-xl);
}
.c-imageset__button {
	margin: 16px auto 0;
	padding: 0 10px;
}
@media (width < 768px) {
	.c-imageset__image {
		margin-bottom: 16px;
	}
	.c-imageset--1t3-flex .c-imageset__inner {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
	}
	.c-imageset--1t3-flex .c-imageset__image {
		flex: 0 0 calc(50% - 8px);
		margin-right: 16px;
		margin-bottom: 0;
	}
	.c-imageset--1t3-flex .c-imageset__content {
		flex: 1 0 calc(50% - 8px);
	}
	.c-imageset--1t3-flex.c-imageset--reverse .c-imageset__inner {
		flex-direction: row-reverse;
	}
	.c-imageset--1t3-flex.c-imageset--reverse .c-imageset__image {
		margin-right: 0;
		margin-left: 16px;
	}
}
@media (width >= 768px), print {
	.c-imageset__inner {
		display: flex;
		justify-content: space-between;
		align-items: flex-start;
	}
	.c-imageset__image {
		flex: 0 0 calc(50% - 20px);
		margin-right: 40px;
	}
	.c-imageset__content {
		flex: 1 0 calc(50% - 20px);
	}
	.c-imageset__button {
		margin-top: 30px;
		margin-left: 0;
		padding: 0;
	}
	.c-imageset__button-max {
		max-width: 312px;
	}
	.c-imageset--1t2 .c-imageset__image {
		flex-basis: calc(33.3333% - 20px);
		max-width: 373px;
	}
	.c-imageset--1t3 .c-imageset__image {
		flex-basis: calc(25% - 10px);
	}
	.c-imageset--1t3-flex .c-imageset__content {
		flex: 1 0 calc(50% - 10px);
	}
	.c-imageset--1t3-flex .c-imageset__image {
		flex-basis: calc(50% - 10px);
		margin-right: 20px;
	}
	.c-imageset--1t3-flex.c-imageset--reverse .c-imageset__image {
		margin-left: 20px;
	}
	.c-imageset--reverse .c-imageset__inner {
		flex-direction: row-reverse;
	}
	.c-imageset--reverse .c-imageset__image {
		margin-right: 0;
		margin-left: 40px;
	}
}

/*----------
	fileset
----------*/
.c-fileset__title {
	color: var(--color-txt);
	font-weight: 500;
	line-height: var(--line-height-s);
}
@media (width < 768px) {
	.c-fileset__item {
		display: grid;
		align-items: center;
		grid-template-columns: 50% 50%;
		grid-template-rows: auto auto;
	}
	.c-fileset__item:not(:first-child) {
		margin-top: 40px;
		padding-top: 40px;
		padding-bottom: 20px;
		background-image: repeating-linear-gradient(to right, var(--color-border) 0 2px, transparent 2px 4px);
		background-position: left top;
		background-repeat: repeat-x;
		background-size: 100% 1px;
	}
	.c-fileset__image {
		grid-column: 1/2;
		grid-row: 1/2;
		margin-right: 20px;
	}
	.c-fileset__content {
		display: contents;
	}
	.c-fileset__button {
		grid-column: 1/3;
		grid-row: 2/3;
		margin-top: 20px;
	}
	.c-fileset__title {
		grid-column: 2/3;
		grid-row: 1/2;
		font-size: 1.8rem;
	}
	.c-fileset .c-button--download .c-button__inner {
		padding: 13px 30px;
		font-size: 1.5rem;
	}
}
@media (width >= 768px), print {
	.c-fileset {
		display: grid;
		gap: 0 40px;
		grid-template-columns: repeat(2, 1fr);
		margin-top: -35px;
	}
	.c-fileset__item {
		display: grid;
		gap: 0 30px;
		align-items: center;
		grid-template-columns: 160px auto;
		padding-top: 35px;
		padding-bottom: 35px;
		background-image: repeating-linear-gradient(to right, var(--color-border) 0 2px, transparent 2px 4px);
		background-position: left bottom;
		background-repeat: repeat-x;
		background-size: 100% 1px;
	}
	.c-fileset__image {
		width: 160px;
	}
	.c-fileset__content {
		padding-right: 18px;
	}
	.c-fileset__title {
		font-size: 2.2rem;
	}
	.c-fileset__button {
		margin-top: 12px;
	}
	.c-fileset .c-button--download .c-button__inner {
		padding-inline: 20px 50px;
		font-size: 1.8rem;
	}
}

/*----------
	image link
----------*/
.c-cardlink__inner {
	display: block;
	position: relative;
	height: 100%;
	background-color: #fff;
	border-radius: 10px;
	overflow: hidden;
}
.c-cardlink__image {
	width: 100%;
	aspect-ratio: 580/295;
	position: relative;
	z-index: var(--z-1);
}
.c-cardlink__image > img {
	position: absolute;
	inset: 0;
	margin: auto;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.c-cardlink__header {
	display: flex;
	justify-content: flex-start;
	align-items: center;
	width: 100%;
	min-height: 68px;
	background-color: #fff;
	overflow: hidden;
	position: relative;
	z-index: var(--z-2);
}
.c-cardlink__title {
	display: block;
	width: 100%;
	padding: 20px 45px 20px 20px;
	position: relative;
	font-size: 1.8rem;
	font-weight: 600;
	line-height: var(--line-height-s);
	color: var(--color-txt);
	text-align: center;
}
.c-cardlink__subtext {
	display: inline-block;
	margin-left: 10px;
	color: var(--color-bg-dark);
	font-size: 1.4rem;
}
.c-cardlink__icon {
	width: 20px;
	height: 20px;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 20px;
	line-height: 1;
	color: var(--color-prim);
	font-size: 2rem;
}
.c-cardlink__pdf {
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 37px;
	height: 16px;
	margin-left: 8px;
	background-color: #E55454;
	border-radius: 5px;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.1rem;
	font-weight: 500;
	text-align: center;
	line-height: var(--line-height-m);
}
.c-cardlink__xlsx {
	display: inline-block;
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	width: 37px;
	height: 16px;
	margin-left: 8px;
	background-color: #67B921;
	border-radius: 5px;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.1rem;
	font-weight: 500;
	text-align: center;
	text-transform: capitalize;
	line-height: var(--line-height-m);
}
.c-cardlink__file {
	display: inline-block;
	margin-left: 5px;
	font-size: 1.2rem;
	transform: translateY(-2px);
}
.c-cardlink:has(figure) {
	display: contents;
}
.c-cardlink:has(figure) .c-cardlink__inner {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 2;
	gap: 0;
}
.c-cardlink:has(figure) .c-cardlink__title {
	padding: 7px 45px 7px 20px;
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__block {
	display: grid;
	grid-template-rows: subgrid;
	grid-row: span 2;
	gap: 0;
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__inner {
	display: block;
	grid-row: auto;
	border-radius: 10px 10px 0 0;
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__body {
	padding: 16px 20px;
	background-color: #fff;
	border-top: 1px solid var(--color-border);
	border-radius: 0 0 10px 10px;
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__title {
	padding: 7px 50px 7px 20px;
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink a {
	display: block;
	padding-bottom: 14px;
	background: url(/_assets_company/_images/common/line_border.png) repeat-x left bottom/auto 1px;
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink-text {
	display: block;
	position: relative;
	padding-right: 30px;
	color: var(--color-txt);
	font-size: 1.5rem;
	line-height: var(--line-height-m);
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink + .c-cardlink__textlink {
	margin-top: 14px;
}
.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink i {
	position: absolute;
	top: 50%;
	right: 0;
	transform: translateY(-50%);
	color: var(--color-prim);
	font-size: 2rem;
}
@media (width >= 768px), print {
	.c-cardlink__image {
		aspect-ratio: 580/295;
	}
	.c-cardlink__header {
		min-height: 80px;
	}
	.c-cardlink__title {
		padding: 25px 50px 25px 25px;
		font-size: 2rem;
	}
	.c-cardlink__subtext {
		margin-left: 12px;
		font-size: 1.6rem;
	}
	.c-cardlink__icon {
		width: 24px;
		height: 24px;
		right: 25px;
		font-size: 2.4rem;
	}
	.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__body {
		padding: 25px 30px;
	}
	.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink a {
		padding-bottom: 16px;
	}
	.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink-text {
		padding-right: 30px;
		font-size: 1.8rem;
	}
	.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink + .c-cardlink__textlink {
		margin-top: 18px;
	}
	.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink i {
		font-size: 2.4rem;
	}
}
@media (hover: hover) {
	.c-cardlink a.c-cardlink__inner .c-cardlink__title,
	.c-cardlink a.c-cardlink__inner .c-cardlink__subtext {
		transition: color 0.3s;
	}
	.c-cardlink a.c-cardlink__inner .c-cardlink__image {
		transform: scale(1, 1);
		transition: transform 0.3s;
	}
	.c-cardlink a.c-cardlink__inner:hover .c-cardlink__title,
	.c-cardlink a.c-cardlink__inner:hover .c-cardlink__subtext {
		color: var(--color-txt-hover);
	}
	.c-cardlink a.c-cardlink__inner:hover .c-cardlink__image {
		transform: scale(1.1, 1.1);
	}
	.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink a .c-cardlink__textlink-text {
		transition: color 0.3s;
	}
	.c-cardlink:has(.c-cardlink__body):has(figure) .c-cardlink__textlink a:hover .c-cardlink__textlink-text {
		color: var(--color-txt-hover);
	}
}
.c-cardlink--onlytxt .c-cardlink__inner {
	display: block;
}

/*-----------
	c-list-links リンクリスト
----------*/
.c-list-links > li {
	padding-top: 20px;
	padding-bottom: 20px;
	background-image: repeating-linear-gradient(to right, var(--color-border) 0 2px, transparent 2px 4px);
	background-position: left bottom;
	background-repeat: repeat-x;
	background-size: 100% 1px;
	color: var(--color-txt);
}
.c-list-links > li a {
	display: block;
}
[class^=c-heading-secondary] + .c-list-links,
.c-contentbox .c-list-links:first-child {
	margin-top: -20px;
}

/*----------
	news
----------*/
.c-news > a {
	display: inline-block;
}
.c-news__detail {
	display: grid;
	grid-template-columns: auto 1fr;
	grid-template-rows: auto auto;
	padding: 16px 0;
}
.c-news:first-child .c-news__detail {
	padding-top: 0;
}
.c-news__date {
	grid-column: 1;
	grid-row: 1;
	margin-right: 5px;
	color: #456383;
	font-size: 1.2rem;
	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;
	line-height: var(--line-height-l);
}
.c-news a.c-news__title {
	display: inline-block;
	padding-left: 1.2em;
	text-indent: -1.2em;
}
.c-news__title {
	color: var(--color-txt);
}
.c-news__pdf {
	display: inline-block;
	width: 37px;
	height: 16px;
	margin-left: 8px;
	background-color: #E55454;
	border-radius: 5px;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.1rem;
	font-weight: 500;
	text-align: center;
	line-height: var(--line-height-m);
	transform: translateY(-2px);
}
.c-news__xlsx {
	display: inline-block;
	width: 37px;
	height: 16px;
	margin-left: 8px;
	background-color: #67B921;
	border-radius: 5px;
	color: #fff;
	font-family: var(--font-roboto);
	font-size: 1.1rem;
	font-weight: 500;
	text-align: center;
	line-height: var(--line-height-m);
	transform: translateY(-2px);
}
.c-news__file {
	display: inline-block;
	margin-left: 5px;
	font-size: 1.2rem;
	color: inherit;
	transform: translateY(-2px);
}
@media (width < 768px) {
	.c-news__date {
		margin-bottom: 10px;
	}
	.c-news__tag {
		margin-bottom: 10px;
	}
}
@media (hover: hover) {
	.c-news > a .c-news__title {
		transition: color 0.3s;
	}
	.c-news > a:hover .c-news__title {
		color: var(--color-txt-hover);
	}
}
@media (width >= 768px), print {
	.c-news__detail {
		grid-template-columns: auto auto 1fr;
		grid-template-rows: auto;
		padding-top: 24px;
		padding-bottom: 24px;
	}
	.c-news__date {
		grid-column: 1;
		grid-row: 1;
		margin-top: 3px;
		margin-right: 20px;
		font-size: 1.4rem;
	}
	.c-news__tag {
		grid-column: 2;
		grid-row: 1;
		margin-top: 2px;
		margin-right: 12px;
	}
	.c-news__headline {
		grid-column: 3;
		grid-row: 1;
	}
	.c-news__text {
		font-size: 1.6rem;
	}
	.c-news__pdf, .c-news__xlsx {
		width: 40px;
		height: 18px;
		font-size: 1.3rem;
		transform: none;
	}
	.c-news__file {
		margin-left: 8px;
		font-size: 1.4rem;
		transform: none;
	}
}

/*----------
	news list
----------*/
.g-news-container__item {
	background: url(/_assets_company/_images/common/line_border.png) repeat-x left bottom;
	background-size: auto 1px;
}

/*----------
	tab
----------*/
.c-tab__tab {
	display: flex;
}
.c-tab__tab-item {
	flex: 1 0 0;
	margin-top: 10px;
	margin-left: -1px;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: 10px 10px 0 0;
	color: var(--color-txt);
	font-size: 1.1rem;
	font-weight: 600;
	line-height: var(--line-height-m);
	overflow: hidden;
}
.c-tab__tab-item:first-child {
	margin-left: 0;
}
.c-tab__tab-item.is-active {
	margin-top: 0;
	background: #fff;
	border-bottom: 0;
	color: var(--color-prim);
	pointer-events: none;
	cursor: default;
}
.c-tab__tab-link {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: var(--line-height-s);
	width: 100%;
	min-height: 60px;
	height: 100%;
	padding: 10px 8px;
	color: inherit;
	text-align: center;
	cursor: pointer;
}
@media (width >= 768px), print {
	.c-tab__tab-link {
		min-height: 70px;
		font-size: 1.8rem;
	}
}
.c-tab__contents-item {
	display: none;
}
.c-tab__contents-item.is-active {
	display: block;
}
.c-tab__contents-item.is-active:not(:has(.c-accordion)) {
	padding-top: 30px;
}

/*----------
	deflist
----------*/
.c-deflist__body {
	border-top: 1px solid var(--color-border);
}
.c-deflist__term {
	padding: 20px 10px;
	background-color: var(--color-bg);
	font-weight: 500;
}
.c-deflist__detail {
	padding: 20px 10px;
	background-color: #fff;
}
@media (width >= 768px), print {
	.c-deflist {
		border-bottom: 1px solid var(--color-border);
	}
	.c-deflist__body {
		display: flex;
		justify-content: space-between;
		align-items: stretch;
	}
	.c-deflist__term {
		display: flex;
		align-items: center;
		flex: 0 0 30%;
		padding: 25px 20px;
	}
	.c-deflist__detail {
		display: flex;
		align-items: center;
		flex: 0 0 70%;
		margin-left: -1px;
		padding: 25px 20px;
	}
	.c-deflist--harf .c-deflist__term,
	.c-deflist--harf .c-deflist__detail {
		flex: 0 0 50%;
	}
}

/*----------
	table
----------*/
.c-table {
	overflow: hidden;
}
.c-table__inner {
	margin-inline: -1px;
}
.c-table__content {
	width: calc(100% + 2px);
	margin-inline: auto;
	text-align: left;
	border: none;
	font-size: 1.4rem;
	line-height: var(--line-height-l);
}
.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);
	border-left-color: #fff;
	border-right-color: #fff;
	border-bottom: 1px solid #fff;
	vertical-align: middle;
	padding: 20px 10px;
	background-color: var(--color-bg-dark);
	font-weight: 500;
	text-align: center;
	color: #fff;
}
.c-table__header:empty {
	background: none;
}
.c-table__narrow-header {
	border: 1px solid var(--color-border);
	border-left-color: #fff;
	border-right-color: #fff;
	vertical-align: middle;
	padding: 20px 10px;
	background-color: var(--color-bg-dark);
	font-weight: 500;
	text-align: center;
	color: #fff;
}
.c-table__narrow-header:empty {
	background: none;
	border: none;
}
.c-table__narrow-header--red {
	background-color: var(--color-prim);
}
.c-table__subheader {
	border: 1px solid var(--color-border);
	border-left-color: #fff;
	border-right-color: #fff;
	vertical-align: middle;
	padding: 20px 10px;
	background-color: var(--color-bg);
	font-weight: 500;
	text-align: center;
}
.c-table__subheader:empty {
	background: none;
	border: none;
}
.c-table__subheader--red {
	background-color: var(--color-prim);
}
.c-table__cell {
	padding: 20px 10px;
	border-top: 1px solid var(--color-border);
	border-bottom: 1px solid var(--color-border);
	border-left: none;
	border-right: none;
	vertical-align: middle;
	background: url(/_assets_company/_images/common/line_border-v.png) repeat-y right top/1px auto;
}
.c-table__cell:empty {
	background: none;
	border: none;
}
.c-table__cell--red {
	background-color: var(--color-prim);
	color: #fff;
}
.c-table-scaling {
	display: block;
	margin-bottom: 20px;
}
.c-table-scaling i::before {
	font-size: 2rem;
	vertical-align: middle;
}
.c-table-scaling__text {
	display: inline-block;
	font-size: 1.2rem;
	vertical-align: middle;
	margin-left: 6px;
}
@media (width >= 768px), print {
	.c-table-scaling {
		display: none;
	}
}
.c-table-switch {
	display: block;
	padding: 6px 12px 8px;
	border-radius: 6px;
	border: 1px solid #DDDDDD;
	padding-left: 58px;
	min-height: 36px;
	position: relative;
	margin: 0 0 20px auto;
}
.c-table-switch::before, .c-table-switch::after {
	content: "";
	display: block;
	width: 16px;
	height: 16px;
	background: url(/assets/images/icon_table_slide.svg) no-repeat center/contain;
	margin: auto;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 12px;
}
.c-table-switch::after {
	background-image: url(/assets/images/icon_table_fit.svg);
	left: 34px;
	filter: invert(0.7);
}
.c-table-switch__text {
	font-size: 1.2rem;
}
.c-table-switch__text--fit {
	display: none;
}
@media (width >= 768px), print {
	.c-table-switch {
		display: none;
	}
}
@media (width < 768px) {
	.c-table--scrollable {
		position: relative;
	}
	.c-table--scrollable .c-table__inner {
		overflow: auto;
		margin-right: -20px;
		margin-left: -20px;
		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 {
		padding-right: 20px;
		padding-left: 20px;
	}
	.c-table--scrollable--sm .c-table__body {
		width: 780px;
	}
	.c-table--scrollable--md .c-table__body {
		width: 900px;
	}
	.c-table--scrollable--lg .c-table__body {
		width: 1000px;
	}
}
@media (width >= 768px), print {
	.c-table__header, .c-table__narrow-header, .c-table__subheader, .c-table__cell {
		padding: 25px 20px;
	}
	.c-table__content {
		font-size: 1.6rem;
	}
	.c-table-scroll {
		display: none;
	}
	.c-table__layouter--for-pc {
		display: table-column-group;
	}
	.c-table__layouter--for-sp {
		display: none;
	}
}

/*----------
	c-box
----------*/
.c-box__header {
	background: var(--color-txt-caption);
	padding: 15px 24px;
}
.c-box__header-title {
	color: #fff;
	font-size: 2rem;
}
.c-box__body {
	background: var(--color-bg);
	padding: 24px 24px 30px;
}
.c-box__body-text {
	color: var(--color-txt-caption-v2);
	font-size: 1.6rem;
	line-height: var(--line-height-m);
}
@media (width >= 768px), print {
	.c-box__header {
		padding: 12px 24px;
	}
	.c-box__header-title {
		font-size: 2.4rem;
	}
}

/*----------
	c-txtpanel
----------*/
.c-txtpanel {
	border: 8px solid var(--color-bg);
	padding: 24px;
}
.c-txtpanel__title {
	font-size: 1.6rem;
	font-weight: bold;
}
.c-txtpanel__body {
	margin-top: 10px;
}
.c-txtpanel__text {
	font-size: 1.4rem;
}
@media (width >= 768px), print {
	.c-txtpanel {
		padding: 32px;
	}
	.c-txtpanel__title {
		font-size: 2rem;
	}
}

/*----------
	c-panel
----------*/
.c-panel {
	border: 8px solid var(--color-bg);
	padding: 30px 20px;
}
.c-panel__title {
	font-size: 2rem;
	font-weight: bold;
}
.c-panel__body {
	margin-top: 5px;
}
.c-panel__body:only-child {
	margin-top: 0;
}
.c-panel__text {
	margin-top: 15px;
	color: var(--color-txt-caption-v2);
}
@media (width >= 768px), print {
	.c-panel {
		padding: 30px 22px;
	}
	.c-panel__title {
		font-size: 2rem;
	}
	.c-panel__body {
		margin-top: 15px;
	}
	.c-panel__text {
		margin-top: 20px;
	}
}

/*----------
	c-point
----------*/
.c-point {
	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-txt-caption);
	border-radius: 100%;
	color: #fff;
	font-weight: bold;
	line-height: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 80px;
	height: 80px;
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
}
.c-point__icon-title {
	font-size: 1.4rem;
	display: block;
}
.c-point__icon-num {
	font-size: 24px;
	display: block;
	margin-top: 3px;
}
.c-point__icon-num:only-child {
	margin-top: 0;
}
.c-point__image > img {
	width: auto;
}
.c-point__text {
	margin-top: 15px;
	font-size: 2rem;
	font-weight: bold;
}
@media (width >= 768px), print {
	.c-point {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.c-point__item {
		width: 360px;
		padding: 40px 30px;
	}
	.c-point__item + .c-point__item {
		margin-top: 0;
	}
}

/*----------
	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__item {
	position: relative;
}
.c-qa__item--parent {
	border-bottom: #CCC solid 1px;
	pointer-events: none;
}
.c-qa__item--parent::after {
	content: "";
	display: inline-block;
	vertical-align: middle;
	color: #333;
	line-height: 1;
	width: 10px;
	height: 10px;
	border: 0.15em solid currentColor;
	border-left: 0;
	border-bottom: 0;
	transform: translateY(-25%) rotate(135deg);
	position: absolute;
	right: 18px;
	top: 0;
	bottom: 0;
	margin: auto;
	visibility: hidden;
}
.c-qa__item--child {
	background: var(--color-bg);
}
.c-qa__item-inner {
	position: relative;
	font-size: 1.6rem;
	line-height: var(--line-height-m);
	padding: 15px 35px 15px 16px;
	display: flex;
	width: 100%;
	text-align: left;
	pointer-events: all;
	color: var(--color-txt);
}
.c-qa__item-inner::before {
	content: attr(title);
	font-size: 2.4rem;
	font-weight: bold;
	line-height: 1;
	display: inline-block;
	vertical-align: top;
	padding-right: 20px;
}
.c-qa__item-inner--parent {
	cursor: pointer;
}
.c-qa__item-inner--parent::before {
	color: #3048A8;
}
.c-qa__item-inner--child {
	min-height: 104px;
}
.c-qa__item-inner--child::before {
	color: #F09E39;
}
.c-qa__item-txt {
	flex: 1;
}
.c-qa.is-active:not(.is-disabled) .c-qa__item--parent::after {
	transform: translateY(-25%) rotate(315deg);
}
.c-qa.is-active:not(.is-disabled) .c-qa__item--child {
	height: auto;
	opacity: 1;
	pointer-events: all;
}
@media (width >= 768px), print {
	.c-qa__item-inner {
		padding: 23px 40px;
	}
}

/*----------
	c-qa
----------*/
.c-accordion {
	overflow: hidden;
}
.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;
	transition: all 0.4s linear;
}
.c-accordion:not(.is-disabled) .c-accordion__item-icon {
	visibility: visible;
}
.c-accordion__item {
	width: 100%;
	color: var(--color-txt);
}
.c-accordion__item--parent {
	position: relative;
	padding: 30px 40px 30px 0;
	background-image: repeating-linear-gradient(to right, var(--color-border) 0 2px, transparent 2px 4px);
	background-position: left bottom;
	background-repeat: repeat-x;
	background-size: 100% 1px;
	color: var(--color-txt);
	font-size: 1.6rem;
	font-weight: 500;
	line-height: var(--line-height-m);
	text-align: left;
}
.c-accordion__item-inner--child {
	min-height: 150px;
	padding: 0 0 30px;
	background-image: repeating-linear-gradient(to right, var(--color-border) 0 2px, transparent 2px 4px);
	background-position: left bottom;
	background-repeat: repeat-x;
	background-size: 100% 1px;
}
.c-accordion__item-icon {
	position: absolute;
	top: 50%;
	right: 3px;
	transform: translateY(-50%);
	width: 26px;
	height: 26px;
	background-color: var(--color-bg);
	border-radius: 100%;
	transition: transform 0.2s ease-out;
	visibility: hidden;
}
.c-accordion__item-icon::before {
	font-family: iconfont !important;
	speak: none;
	font-style: normal;
	font-weight: normal;
	line-height: 1;
	content: var(--icon-plus);
	display: block;
	font-size: 2rem;
	line-height: 24px;
	text-align: center;
}
.c-accordion + .c-accordion {
	margin-top: -1px;
}
.c-accordion.is-active:not(.is-disabled) .c-accordion__item-icon::before {
	content: var(--icon-minus);
}
.c-accordion.is-active:not(.is-disabled) .c-accordion__item--parent {
	background: none;
}
.c-accordion.is-active:not(.is-disabled) .c-accordion__item--child {
	height: auto;
	opacity: 1;
	pointer-events: all;
}
@media (width >= 768px), print {
	.c-accordion__item--parent {
		padding: 50px 45px 50px 0;
	}
	.c-accordion__item-inner {
		font-size: 2.4rem;
	}
	.c-accordion__item-inner--child {
		padding-bottom: 50px;
	}
	.c-accordion__item-icon {
		right: 10px;
		width: 36px;
		height: 36px;
	}
	.c-accordion__item-icon::before {
		font-size: 2.4rem;
		line-height: 36px;
	}
}

/*----------
	single column
----------*/
.g-center-col__item + .g-center-col__item {
	margin-top: 40px;
}
@media (width >= 768px), print {
	.g-center-col {
		display: flex;
		justify-content: center;
		align-items: flex-start;
	}
	.g-center-col__item {
		flex: 1 1 150%;
		max-width: 150%;
	}
	.g-center-col__item + .g-center-col__item {
		margin-top: 0;
	}
	.g-center-col--fit .g-center-col__item {
		flex-basis: 100%;
		max-width: 100%;
	}
	.g-center-col--medium .g-center-col__item {
		flex: 1 1 75%;
		max-width: 75%;
	}
	.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
----------*/
@media (width < 768px) {
	.g-grid__item + .g-grid__item {
		margin-top: 30px;
	}
	.g-grid:has(.c-cardlink) {
		display: grid;
		gap: 30px 0;
	}
}
@media (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);
	}
}