@charset "UTF-8";
/*----------
	トップページ
----------*/
/*-----------
	top-category__title
----------*/
.top-category__title {
	color: var(--color-txt);
	font-size: 3rem;
	font-weight: 500;
	text-align: center;
	line-height: var(--line-height-m);
}
.top-category__title span {
	display: block;
	color: var(--color-prim);
	font-size: 1.2rem;
	font-weight: 500;
	text-transform: uppercase;
	line-height: var(--line-height-xs);
}
@media (width >= 768px), print {
	.top-category__title {
		font-size: 4rem;
	}
	.top-category__title span {
		margin-top: 5px;
		font-size: 1.5rem;
	}
}

/*-----------
	top-mainvis
----------*/
.top-mainvis {
	position: relative;
	margin-bottom: 30px;
}
.top-mainvis__copy {
	position: absolute;
	top: 6.98%;
	left: 0;
	z-index: var(--z-3);
}
.top-mainvis__copy-text {
	display: inline;
	padding-block: 5px 10px;
	background-color: #fff;
	box-decoration-break: clone;
	color: var(--color-txt);
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 1.8;
}
.top-mainvis__copy-text span {
	padding-inline: 10px;
}
.top-mainvis__copy-text em {
	color: var(--color-prim);
}
.top-mainvis__image {
	position: relative;
	overflow: hidden;
}
.top-mainvis .swiper {
	overflow: visible;
}
.top-mainvis .swiper .swiper-slide {
	width: 100%;
	position: relative;
	overflow: hidden;
}
.top-mainvis .swiper-usability {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	max-width: 1200px;
	margin-top: 25px;
}
.top-mainvis .swiper-usability .swiper-pagination {
	position: relative;
	bottom: auto;
	width: auto;
	height: 16px;
	line-height: 1;
}
.top-mainvis .swiper-usability .swiper-pagination-bullet {
	width: 7px;
	height: 7px;
	background-color: var(--color-border);
	margin: 0 5px;
	opacity: 1;
}
.top-mainvis .swiper-usability .swiper-pagination-bullet-active {
	background-color: var(--color-prim);
}
.top-mainvis .swiper-usability .swiper-pagination-bullet {
	width: 7px;
	height: 7px;
	background-color: var(--color-border);
	margin: 0 5px;
	opacity: 1;
}
.top-mainvis .swiper-usability .swiper-pagination-bullet-active {
	background-color: var(--color-prim);
}
.top-mainvis .swiper-usability .swiper-pause {
	display: inline-block;
	margin-left: 13px;
	cursor: pointer;
}
.top-mainvis .swiper-usability .swiper-pause::before {
	content: "";
	display: block;
	width: 22px;
	height: 22px;
	background-color: var(--color-prim);
	background-image: url(/_assets_company/_images/common/icon_stop.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: auto 8px;
	border-radius: 100%;
}
.top-mainvis .swiper-usability .swiper-pause.is-paused::before {
	background-image: url(/_assets_company/_images/common/icon_play.svg);
	background-size: 8px auto;
}
.top-mainvis .top-mainvis__photo {
	width: 100%;
	height: 100%;
}
.top-mainvis .top-mainvis__photo span {
	display: block;
	position: relative;
	width: 100%;
	height: 100%;
}
.top-mainvis .top-mainvis__photo img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.top-mainvis .top-mainvis__cover {
	position: relative;
	display: block;
	width: 100%;
	z-index: var(--z-2);
}
.top-mainvis {
	/* slide無効時 */
}
.top-mainvis .top-mainvis__images.disabled-swiper {
	display: flex;
	justify-content: center;
}
.top-mainvis .top-mainvis__images.disabled-swiper .swiper-wrapper {
	display: flex;
	gap: 0 40px;
}
.top-mainvis .top-mainvis__images.disabled-swiper .swiper-slide {
	max-width: auto;
}
.top-mainvis .top-mainvis__images.disabled-swiper .swiper-usability {
	display: none;
}
@media (width < 768px) {
	.top-mainvis .swiper {
		position: relative;
		margin: 0 -15.33%;
	}
	.top-mainvis .swiper::after {
		display: none;
	}
	.top-mainvis .swiper-slide {
		position: relative;
		width: 100% !important;
		aspect-ratio: 490/430;
	}
	.top-mainvis .top-mainvis__cover {
		position: absolute;
		inset: 0;
		margin: auto;
		width: calc(100% + 2px);
		height: 100.5%;
		background: url(/_assets_company/_images/top/slide_cover.png) no-repeat 0 0/cover;
		z-index: var(--z-1);
		translate: -1.5px;
	}
	.top-mainvis .top-mainvis__photo {
		width: 130.67%;
	}
	.top-mainvis .top-mainvis__cover img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
}
@media (width >= 768px), print {
	.top-mainvis {
		margin-bottom: 100px;
	}
	.top-mainvis__copy {
		top: 70px;
		left: 50%;
		width: 1200px;
		transform: translateX(-50%);
	}
	.top-mainvis__copy-text {
		display: inline;
		font-size: 3.9rem;
		font-weight: 700;
		line-height: 1.8;
		padding-block: 5px 10px;
		background-color: #fff;
		-webkit-box-decoration-break: clone;
		box-decoration-break: clone;
	}
	.top-mainvis__copy-text span {
		padding-inline: 20px;
	}
	.top-mainvis .swiper-slide {
		position: relative;
		width: 950px !important;
		height: 620px;
	}
	.top-mainvis .top-mainvis__cover {
		position: absolute;
		inset: 0;
		margin: auto;
		width: calc(100% + 2px);
		height: 100%;
		background: url(/_assets_company/_images/top/slide_cover_pc.png) no-repeat 0 0/cover;
		z-index: var(--z-1);
		translate: -1px;
	}
	.top-mainvis .swiper-usability {
		width: 950px;
		justify-content: flex-end;
		margin: 18px auto 0;
	}
	.top-mainvis .swiper-usability .swiper-pagination-bullet {
		position: relative;
		bottom: 3px;
	}
	.top-mainvis .top-mainvis__photo img {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		width: 1500px;
		object-fit: cover;
	}
}

/*-----------
	news
----------*/
.top-news__title {
	margin-bottom: 50px;
	color: var(--color-txt);
	font-size: 2.4rem;
	font-weight: 500;
	line-height: 1.46;
}
.top-news__title span {
	display: block;
	color: var(--color-prim);
	font-size: 1.4rem;
	font-family: var(--font-roboto);
	font-weight: 500;
	text-transform: uppercase;
	margin-top: 8px;
}
.top-news__textlink {
	margin-top: 20px;
	text-align: right;
}
@media (width >= 768px), print {
	.top-news {
		position: relative;
		display: grid;
		gap: 45px 70px;
		grid-template-columns: 237px auto;
		grid-template-rows: auto 1fr;
		margin-bottom: 140px;
	}
	.top-news__title {
		margin-bottom: 0;
		font-size: 3rem;
	}
	.top-news__title span {
		font-size: 1.5rem;
	}
	.top-news__textlink {
		grid-column-start: 1;
		grid-row-start: 2;
		margin-top: 0;
		text-align: left;
	}
	.top-news__body {
		grid-row: span 2/span 2;
		grid-column-start: 2;
		grid-row-start: 1;
	}
}

/*-----------
	company
----------*/
.top-company {
	margin-top: 80px;
}
.top-company__title {
	margin-bottom: 40px;
}
.top-company__body {
	position: relative;
	padding-bottom: 135px;
}
.top-company__body::after {
	content: "";
	display: block;
	width: 100%;
	height: calc(100% - 50px);
	position: absolute;
	bottom: 0;
	left: 50%;
	background: #D7EDF8 url(/_assets_company/_images/top/bg_company.webp) no-repeat center bottom/768px auto;
	transform: translateX(-50%);
}
.top-company__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 30px;
	padding-right: 30px;
}
@media (width >= 768px), print {
	.top-company__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.top-company__inner {
	position: relative;
	z-index: var(--z-1);
}
.top-company__topbutton {
	margin-top: 30px;
}
@media (width >= 768px), print {
	.top-company {
		margin-top: 140px;
	}
	.top-company__body {
		padding-bottom: 340px;
	}
	.top-company__body::after {
		height: calc(100% - 60px);
		background: #D7EDF8 url(/_assets_company/_images/top/bg_company.webp) no-repeat center bottom/contain;
	}
	.top-company__topbutton {
		margin-top: 50px;
	}
}

/*-----------
	IR
----------*/
.top-ir {
	position: relative;
	margin-top: 80px;
}
.top-ir::before {
	content: "";
	display: block;
	width: 100%;
	background: url(/_assets_company/_images/top/bg_ir.webp) no-repeat right top/cover;
	border-radius: 0 350px 350px 0;
	position: absolute;
	top: 0;
	left: -50%;
}
.top-ir__body {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 30px;
	padding-right: 30px;
}
@media (width >= 768px), print {
	.top-ir__body {
		padding-left: 40px;
		padding-right: 40px;
	}
}
@media (width < 768px) {
	.top-ir {
		margin-top: 30px;
	}
	.top-ir::before {
		height: 300px;
		left: -50%;
	}
	.top-ir__heading {
		position: relative;
		width: 100%;
		height: 300px;
	}
	.top-ir__title {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translateY(-50%);
		padding: 0 5%;
		text-align: left;
	}
	.top-ir__body {
		margin-top: 30px;
	}
	.top-ir__topbutton {
		margin-top: 30px;
	}
	.top-ir__buttons > li + li {
		margin-top: 20px;
	}
}
@media (width >= 768px), print {
	.top-ir {
		display: flex;
		align-items: center;
		margin-top: 140px;
		min-height: 550px;
	}
	.top-ir::before {
		height: 550px;
		left: calc(-50% - 64px);
	}
	.top-ir__title {
		text-align: left;
	}
	.top-ir__inner {
		width: 600px;
		margin-left: 50%;
	}
	.top-ir__body {
		margin-top: 50px;
		padding: 0;
	}
	.top-ir__topbutton {
		max-width: 373px;
		margin: 40px auto 0;
	}
	.top-ir__buttons > li + li {
		margin-top: 30px;
	}
}

/*-----------
	sustainability
----------*/
.top-sustainability {
	position: relative;
	margin-top: 80px;
}
.top-sustainability__title {
	text-align: center;
	margin-bottom: 40px;
}
.top-sustainability__body {
	position: relative;
}
.top-sustainability__body::before {
	content: "";
	display: block;
	background: url(/_assets_company/_images/top/bg_sustainability.webp) no-repeat left top/cover;
	border-radius: 420px 0 0 420px;
	position: absolute;
	left: 0;
	z-index: var(--z-back);
}
.top-sustainability__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 30px;
	padding-right: 30px;
}
@media (width >= 768px), print {
	.top-sustainability__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.top-sustainability__inner {
	position: relative;
	z-index: var(--z-1);
}
.top-sustainability__buttons {
	margin-top: 30px;
}
.top-sustainability__buttons li + li {
	margin-top: 30px;
}
@media (width < 768px) {
	.top-sustainability__body::before {
		width: 200%;
		height: 823px;
		position: absolute;
		top: 35px;
		left: 0;
		transform: translateX(-105px);
	}
}
@media (width >= 768px), print {
	.top-sustainability {
		margin-top: 140px;
	}
	.top-sustainability__body {
		min-height: 590px;
	}
	.top-sustainability__body::before {
		width: 100%;
		height: 500px;
		background: url(/_assets_company/_images/top/bg_sustainability.webp) no-repeat left top/cover;
		border-radius: 420px 0 0 420px;
		top: 90px;
		left: 180px;
	}
	.top-sustainability__buttons {
		max-width: 373px;
		margin: 35px auto 0;
	}
}

/*-----------
	recruit
----------*/
.top-recruit {
	margin-top: 80px;
}
.top-recruit__title {
	margin-bottom: 40px;
	text-align: center;
}
@media (width >= 768px), print {
	.top-recruit {
		margin-top: 140px;
	}
	.top-recruit__title {
		margin-bottom: 50px;
	}
}

/*-----------
	business-info
----------*/
.top-business-info {
	background-color: var(--color-bg);
}
.top-business-info__inner {
	width: 100%;
	max-width: 1280px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 30px;
	padding-right: 30px;
}
@media (width >= 768px), print {
	.top-business-info__inner {
		padding-left: 40px;
		padding-right: 40px;
	}
}
.top-business-info__inner {
	padding: 50px 30px;
}
.top-business-info__title {
	margin-bottom: 40px;
	text-align: left;
}
.top-business-info__button .c-button__inner {
	min-height: 35px;
	padding-bottom: 15px;
}
.top-business-info__button .c-button__inner > span {
	font-weight: 400;
	font-size: 1.4rem;
	line-height: var(--line-height-s);
}
@media (width >= 768px), print {
	.top-business-info__inner {
		padding: 80px 20px 100px;
	}
	.top-business-info__button {
		gap: 20px 40px;
	}
	.top-business-info__button .c-button__inner {
		min-height: 50px;
	}
	.top-business-info__button .c-button__inner > span {
		font-size: 1.6rem;
	}
}

/*-----------
	otherlink
----------*/
.top-otherlink {
	padding: 25px 30px;
	background-color: #fff;
}
.top-otherlink__button {
	display: grid;
	grid-template-columns: repeat(2, 50%);
	gap: 10px 5px;
}
.top-otherlink__button .c-icontext > a,
.top-otherlink__button .c-icontext > span {
	padding-left: 15px;
	font-size: 1.2rem;
}
@media (width >= 768px), print {
	.top-otherlink {
		width: 100%;
		max-width: 1240px;
		margin-left: auto;
		margin-right: auto;
		padding: 30px;
	}
	.top-otherlink__button {
		display: grid;
		grid-template-columns: repeat(4, 1fr);
		gap: 10px 5px;
	}
	.top-otherlink__button .c-icontext > a,
	.top-otherlink__button .c-icontext > span {
		padding-left: 20px;
		font-size: 1.6rem;
	}
	.top-otherlink__button .c-icontext .icon-arrow2-r {
		transform: translateY(0.59em);
		font-size: 1.6rem;
	}
	.top-otherlink__button .c-icontext .icon-blank {
		display: inline-block;
		transform: translateY(0.2em);
		margin-left: 5px;
		font-size: 2rem;
	}
}