.l-top-content {
	padding-bottom: 60px;
}
@media (min-width: 768px), print {
	.l-top-content {
		min-width: 1280px;
		padding-bottom: 140px;
	}
}

.l-mainheader {
	opacity: 0;
	transform: translateY(-120px);
}
.l-mainheader__inner {
	background-color: transparent;
}
.l-mainheader.is-fixed .l-mainheader__inner, .l-mainheader:has(.pc-subnav-active) .l-mainheader__inner {
	background-color: #fff;
}
@media (min-width: 768px), print {
	.l-mainheader__logo {
		width: 200px;
	}
}

.top-loading {
	position: fixed;
	top: 0;
	width: 100%;
	height: 100svh;
	background: #fff;
	z-index: 10000;
	display: grid;
	place-content: center;
	transition: opacity 0.6s, visibility 0.6s;
}

.is-fetched .top-loading {
	opacity: 0;
	visibility: hidden;
}
.is-fetched .top-kv__mask-images {
	animation: maskExpandAnime 1.6s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 1s;
}
.is-fetched .top-kv__images {
	animation: imgFadeInAnime 1.6s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 1s;
}
.is-fetched .top-kv__layer1__car1 {
	animation: car1Anime 4.6s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer1__tree1 {
	animation: tree1Anime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer1__cloud1 {
	animation: cloud1Anime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer1__sun {
	animation: sunAnime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer1__cloud2 {
	animation: cloud2Anime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer1__solar {
	animation: solarAnime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer1__tree2 {
	animation: tree2Anime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer2__tree3 {
	animation: tree3Anime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}
.is-fetched .top-kv__layer2__car2 {
	animation: car2Anime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 8s;
}
.is-fetched .l-mainheader {
	animation: headerAppearAnime 1.5s cubic-bezier(0.33, 1, 0.68, 1) forwards;
	animation-delay: 3s;
}

.top-kv {
	position: relative;
	overflow: hidden;
	min-height: calc(100svh + 50px);
}
.top-kv__mask-images {
	position: absolute;
	width: 100%;
	bottom: 0;
	-webkit-mask-image: url(/en/assets/images/common/circle-mask.svg);
	mask-image: url(/en/assets/images/common/circle-mask.svg);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center top;
	mask-position: center top;
}
.top-kv__images {
	min-height: calc(100svh - 90px);
	position: absolute;
	bottom: 0;
	width: 100%;
	height: 100%;
}
.top-kv__layer1 {
	position: absolute;
	height: calc(100% - 160px);
	width: 100%;
	bottom: 0;
	z-index: -1;
}
.top-kv__layer1__car1 {
	position: absolute;
	top: 0;
	left: calc(50% - 2500px);
	opacity: 0;
	width: 147px;
	height: 49px;
	transform: translateY(-23px);
	background: url(/en/assets/images/common/illust-car1.png) no-repeat center/contain;
	offset-path: path("M1250,339.587S1770.437-.7,2500,.183s1250,339.4,1250,339.4");
}
.top-kv__layer1__tree1 {
	position: absolute;
	top: 66px;
	opacity: 0;
	left: calc(50% - 610px);
	width: 122px;
	height: 105px;
	background: url(/en/assets/images/common/illust-tree1.png) no-repeat center/contain;
	z-index: -1;
	transform: rotate(-14deg) translateX(-50%);
}
.top-kv__layer1__cloud1 {
	position: absolute;
	top: -190px;
	opacity: 0;
	left: calc(50% - 470px);
	width: 120px;
	height: 20px;
	background: url(/en/assets/images/common/illust-cloud1.png) no-repeat center/contain;
	z-index: 1;
	transform: rotate(-16deg) translateX(-50%);
}
.top-kv__layer1__sun {
	position: absolute;
	top: -175px;
	opacity: 0;
	left: calc(50% + 320px);
	width: 34px;
	height: 31px;
	background: url(/en/assets/images/common/illust-sun.png) no-repeat center/contain;
	z-index: 1;
	transform: translateX(-50%);
}
.top-kv__layer1__cloud2 {
	position: absolute;
	top: -190px;
	opacity: 0;
	left: calc(50% + 420px);
	width: 114px;
	height: 66px;
	background: url(/en/assets/images/common/illust-cloud2.png) no-repeat center/contain;
	z-index: 1;
	transform: translateX(-50%);
}
.top-kv__layer1__solar {
	position: absolute;
	top: -104px;
	opacity: 0;
	left: calc(50% + 510px);
	width: 77px;
	height: 37px;
	background: url(/en/assets/images/common/illust-solar.png) no-repeat center/contain;
	z-index: 1;
	transform: rotate(11deg) translateX(-50%);
}
.top-kv__layer1__tree2 {
	position: absolute;
	top: 66px;
	opacity: 0;
	left: calc(50% + 610px);
	width: 98px;
	height: 126px;
	background: url(/en/assets/images/common/illust-tree2.png) no-repeat center/contain;
	z-index: -1;
	transform: rotate(11deg) translateX(-50%);
}
.top-kv__layer2 {
	position: absolute;
	width: 100%;
	bottom: 0;
	z-index: 1;
}
.top-kv__layer2__tree3 {
	position: absolute;
	bottom: -200px;
	opacity: 0;
	left: calc(50% - 540px);
	width: 203px;
	height: 185px;
	background: url(/en/assets/images/common/illust-tree3.png) no-repeat center/contain;
	z-index: 1;
	transform: translateX(-50%);
}
@media (min-width: 1340px) {
	.top-kv__layer2__tree3 {
		left: calc(50% - 580px);
	}
}
.top-kv__layer2__car2 {
	position: absolute;
	bottom: 49px;
	opacity: 0;
	left: calc(50% + 1250px);
	width: 341px;
	height: 106px;
	background: url(/en/assets/images/common/illust-car2.png) no-repeat center/contain;
	z-index: 1;
	transform: translateX(-50%);
}

.top-kv-slider {
	height: 100%;
}
.top-kv-slider__slide {
	position: relative;
	height: 100%;
}
.top-kv-slider__slide::after {
	content: "";
	display: block;
	position: absolute;
	width: 100%;
	height: 60%;
	top: 0;
	background: linear-gradient(to bottom, rgba(0, 37, 102, 0.5) 0%, transparent 100%);
}
.top-kv-slider__bg img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	position: absolute;
	top: 0;
}
.top-kv-slider__controller {
	position: absolute;
	bottom: 80px;
	width: 200px;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	z-index: 1;
}
.top-kv-slider__controller .swiper-pagination {
	position: static;
}
.top-kv-slider__controller .swiper-pagination-bullet {
	background-color: #fff;
	opacity: 1;
}
.top-kv-slider__controller .swiper-pagination-bullet-active {
	background-color: var(--color-prim);
}
.top-kv-slider__playbutton {
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background: #707070;
	border: 1px solid #707070;
	position: absolute;
	right: 30px;
	top: 2px;
	z-index: 100;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}
.top-kv-slider__playbutton::before {
	content: "";
	width: 0px;
	height: 0px;
	border: 0.3em solid transparent;
	border-left: 0.5em solid currentColor;
	margin-left: 6px;
}
.top-kv-slider__playbutton.is-playing {
	gap: 2px;
}
.top-kv-slider__playbutton.is-playing::before, .top-kv-slider__playbutton.is-playing::after {
	content: "";
	display: block;
	width: 2px;
	height: 6px;
	margin: 0;
	border: 0;
	background: currentColor;
}
@media (hover: hover) {
	.top-kv-slider__playbutton {
		transition: border-color 0.3s, background-color 0.3s;
	}
	.top-kv-slider__playbutton:hover {
		border-color: var(--color-prim);
		background-color: #fff;
		color: var(--color-prim);
	}
}
.top-kv-slider__copy {
	margin-top: 70px;
	position: relative;
	z-index: 1;
	width: 100%;
	text-align: center;
	color: #fff;
}
@media (min-width: 768px), print {
	.top-kv-slider__copy {
		margin-top: 140px;
		background-size: unset;
	}
}
.top-kv-slider__copy-text1 {
	font-size: 3rem;
	font-weight: 600;
	font-family: var(--font-mont);
	text-shadow: 0 1px 15px rgba(0, 56, 153, 0.5);
	text-transform: uppercase;
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.top-kv-slider__copy-text1 {
		font-size: 5rem;
	}
}
.top-kv-slider__copy-text2 {
	margin-top: 15px;
	margin-inline: 20px;
	font-size: 1.4rem;
	font-weight: bold;
	text-shadow: 0 1px 10px rgba(18, 67, 149, 0.8);
	line-height: var(--line-height-l);
}
@media (min-width: 768px), print {
	.top-kv-slider__copy-text2 {
		margin-top: 30px;
		font-size: 2.1rem;
	}
}

@keyframes tree1Anime {
	0% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -44px;
	}
	100% {
		opacity: 1;
		top: -42px;
	}
}
@keyframes cloud1Anime {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -68px;
	}
	100% {
		opacity: 1;
		top: -70px;
	}
}
@keyframes sunAnime {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -53px;
	}
	100% {
		opacity: 1;
		top: -55px;
	}
}
@keyframes cloud2Anime {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -68px;
	}
	100% {
		opacity: 1;
		top: -70px;
	}
}
@keyframes solarAnime {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: 22px;
	}
	100% {
		opacity: 1;
		top: 24px;
	}
}
@keyframes tree2Anime {
	0% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -42px;
	}
	100% {
		opacity: 1;
		top: -40px;
	}
}
@keyframes tree3Anime {
	0% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		bottom: 46px;
	}
	100% {
		opacity: 1;
		bottom: 44px;
	}
}
@keyframes car1Anime {
	0% {
		opacity: 0;
	}
	10% {
		opacity: 1;
	}
	26% {
		offset-distance: 50.4%;
	}
	35% {
		offset-distance: 49.8%;
	}
	52% {
		offset-distance: 49.8%;
	}
	90% {
		opacity: 1;
	}
	100% {
		opacity: 0;
		offset-distance: 100%;
	}
}
@keyframes car2Anime {
	0% {
		opacity: 0;
	}
	10% {
		opacity: 1;
	}
	80% {
		left: calc(50% + 480px);
	}
	100% {
		opacity: 1;
		left: calc(50% + 500px);
	}
}
@keyframes maskExpandAnime {
	0% {
		-webkit-mask-size: 100%;
		mask-size: 100%;
		height: 0;
	}
	80% {
		height: calc(100% - 140px);
	}
	100% {
		-webkit-mask-size: 5000px;
		mask-size: 5000px;
		height: calc(100% - 160px);
	}
}
@keyframes imgFadeInAnime {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
@keyframes headerAppearAnime {
	0% {
		opacity: 0;
	}
	80% {
		transform: translateY(3px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}
@keyframes tree1AnimeSp {
	0% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -44px;
	}
	100% {
		opacity: 1;
		top: -42px;
	}
}
@keyframes cloud1AnimeSp {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -28px;
	}
	100% {
		opacity: 1;
		top: -30px;
	}
}
@keyframes sunAnimeSp {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -48px;
	}
	100% {
		opacity: 1;
		top: -50px;
	}
}
@keyframes cloud2AnimeSp {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -68px;
	}
	100% {
		opacity: 1;
		top: -70px;
	}
}
@keyframes solarAnimeSp {
	0% {
		opacity: 0;
	}
	20% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -2px;
	}
	100% {
		opacity: 1;
		top: -4px;
	}
}
@keyframes tree2AnimeSp {
	0% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		top: -54px;
	}
	100% {
		opacity: 1;
		top: -52px;
	}
}
@keyframes tree3AnimeSp {
	0% {
		opacity: 0;
	}
	80% {
		opacity: 1;
		bottom: 30px;
	}
	100% {
		opacity: 1;
		bottom: 28px;
	}
}
@keyframes car1AnimeSp {
	0% {
		opacity: 0;
	}
	10% {
		opacity: 1;
	}
	26% {
		offset-distance: 50.4%;
	}
	35% {
		offset-distance: 49.8%;
	}
	52% {
		offset-distance: 49.8%;
	}
	90% {
		opacity: 1;
	}
	100% {
		opacity: 0;
		offset-distance: 100%;
	}
}
@keyframes car2AnimeSp {
	0% {
		opacity: 0;
	}
	10% {
		opacity: 1;
	}
	80% {
		right: 6%;
	}
	100% {
		opacity: 1;
		right: 5%;
	}
}
@keyframes maskExpandAnimeSp {
	0% {
		-webkit-mask-size: 100%;
		mask-size: 100%;
		height: 0;
	}
	80% {
		height: calc(100% - 90px);
	}
	100% {
		-webkit-mask-size: 2000px;
		mask-size: 2000px;
		height: calc(100% - 110px);
	}
}
@keyframes imgFadeInAnimeSp {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
@keyframes headerAppearAnimeSp {
	0% {
		opacity: 0;
	}
	80% {
		transform: translateY(3px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}
@media (max-width: 767px) {
	.top-kv {
		min-height: max(100svh + 30px, 500px);
	}
	.top-kv__images {
		min-height: max(100svh - 60px, 410px);
	}
	.top-kv__layer1 {
		height: calc(100% - 110px);
	}
	.top-kv__layer1__car1 {
		left: calc(50% - 1000px);
		width: 67px;
		height: 21px;
		transform: translateY(-10px);
		offset-path: path("M500,134.9S713.429-.415,1000-.1s500,134.78,500,134.78");
	}
	.top-kv__layer1__tree1 {
		display: none;
	}
	.top-kv__layer1__cloud1 {
		top: -120px;
		left: calc(50% - 140px);
		width: 47px;
		height: 8px;
		transform: rotate(-9deg) translateX(-50%);
	}
	.top-kv__layer1__sun {
		top: -120px;
		left: calc(50% + 50px);
		width: 17px;
		height: 15px;
	}
	.top-kv__layer1__cloud2 {
		display: none;
	}
	.top-kv__layer1__solar {
		top: -104px;
		left: calc(50% + 134px);
		width: 37px;
		height: 18px;
		transform: rotate(11deg) translateX(-50%);
	}
	.top-kv__layer1__tree2 {
		top: 66px;
		left: calc(50% + 70px);
		width: 45px;
		height: 58px;
		transform: rotate(4deg);
	}
	.top-kv__layer2__tree3 {
		display: none;
	}
	.top-kv__layer2__car2 {
		bottom: 30px;
		left: unset;
		right: -30%;
		width: 110px;
		height: 34px;
		transform: unset;
	}
	.is-fetched .top-kv__mask-images {
		animation-name: maskExpandAnimeSp;
	}
	.is-fetched .top-kv__images {
		animation-name: imgFadeInAnimeSp;
	}
	.is-fetched .top-kv__layer1__car1 {
		animation-name: car1AnimeSp;
	}
	.is-fetched .top-kv__layer1__tree1 {
		animation-name: tree1AnimeSp;
	}
	.is-fetched .top-kv__layer1__cloud1 {
		animation-name: cloud1AnimeSp;
	}
	.is-fetched .top-kv__layer1__sun {
		animation-name: sunAnimeSp;
	}
	.is-fetched .top-kv__layer1__cloud2 {
		animation-name: cloud2AnimeSp;
	}
	.is-fetched .top-kv__layer1__solar {
		animation-name: solarAnimeSp;
	}
	.is-fetched .top-kv__layer1__tree2 {
		animation-name: tree2AnimeSp;
	}
	.is-fetched .top-kv__layer2__tree3 {
		animation-name: tree3AnimeSp;
	}
	.is-fetched .top-kv__layer2__car2 {
		animation-name: car2AnimeSp;
	}
	.is-fetched .l-mainheader {
		animation-name: headerAppearAnimeSp;
	}
}
.top-heading__en {
	color: var(--color-seco);
	font-family: var(--font-mont);
	line-height: var(--line-height-s);
	font-size: 3rem;
	font-weight: 800;
}
@media (min-width: 768px), print {
	.top-heading__en {
		font-size: 4.8rem;
	}
}

.top-button__inner {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: nowrap;
	width: 100%;
	height: 100%;
	min-height: 48px;
	max-width: 250px;
	margin: 0 auto;
	border-radius: 100px;
	padding-right: 50px;
	padding-left: 20px;
	position: relative;
	border: 1px solid var(--color-prim);
	background-color: var(--color-prim);
	text-decoration: none;
	color: #fff;
	cursor: pointer;
}
.top-button__inner > span {
	font-weight: bold;
	line-height: var(--line-height-s);
}
.top-button__inner::after {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	-webkit-mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
	mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
	background: currentColor;
	right: 18px;
}
@media (hover: hover) {
	.top-button__inner {
		transition: color 0.3s, background-color 0.3s;
	}
	.top-button__inner:hover {
		color: var(--color-prim);
		background-color: #fff;
	}
}
@media (min-width: 768px), print {
	.top-button__inner {
		min-height: 56px;
	}
}

.top-section-news {
	margin-top: -30px;
	border-radius: 30px 30px 0 0;
	background-color: #fff;
	padding-block: 30px 60px;
	position: relative;
}
@media (min-width: 768px), print {
	.top-section-news {
		margin-top: -50px;
		border-radius: 50px 50px 0 0;
		padding-block: 80px 100px;
	}
}
@media (min-width: 768px), print {
	.top-section-news__inner {
		position: relative;
		display: flex;
		justify-content: space-between;
	}
}
.top-section-news__menus {
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.top-section-news__menus {
		margin-top: 60px;
	}
}
@media (min-width: 768px), print {
	.top-section-news__contents {
		width: 880px;
	}
}
.top-section-news__tab-panel {
	display: none;
}
.top-section-news__tab-panel.is-active {
	display: block;
}
.top-section-news__button {
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.top-section-news__button {
		margin-top: 40px;
	}
	.top-section-news__button .top-button__inner {
		margin-right: unset;
	}
}

.top-section-topics {
	border-top: 1px solid var(--color-border);
	padding-block: 40px 90px;
}
@media (min-width: 768px), print {
	.top-section-topics {
		padding-block: 80px 150px;
	}
}
.top-section-topics__header {
	position: relative;
}
.top-section-topics__header::before {
	display: block;
	content: "";
	position: absolute;
	width: 30px;
	height: 3px;
	background-color: var(--color-prim);
	top: -41px;
}
@media (min-width: 768px), print {
	.top-section-topics__header::before {
		width: 40px;
		top: -81px;
	}
}
@media (min-width: 768px), print {
	.top-section-topics__header {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
}
.top-section-topics__description {
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.top-section-topics__description {
		margin-top: 0;
		width: 880px;
	}
}
.top-section-topics__contents {
	overflow: hidden;
}
.top-section-topics__button {
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.top-section-topics__button {
		margin-top: -52px;
	}
	.top-section-topics__button .top-button__inner {
		margin-right: unset;
	}
}

.top-topics-slider {
	margin-top: 30px;
}
.top-topics-slider__slide > a {
	text-decoration: none;
}
.top-topics-slider__slide > a > p {
	padding-top: 14px;
	font-weight: bold;
	line-height: var(--line-height-s);
}
.top-topics-slider__slide > a figure {
	overflow: hidden;
	border-radius: 10px;
	position: relative;
}
.top-topics-slider__slide > a figure::after {
	position: absolute;
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	-webkit-mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
	mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
	background: #fff;
	bottom: 20px;
	right: 20px;
}
.top-topics-slider__slide > a figure img {
	object-fit: cover;
	aspect-ratio: 352/198;
}
@media (hover: hover) {
	.top-topics-slider__slide > a {
		transition: color 0.3s;
	}
	.top-topics-slider__slide > a figure::after {
		transition: background-color 0.3s;
	}
	.top-topics-slider__slide > a figure img {
		transition: transform 0.3s;
	}
	.top-topics-slider__slide > a:hover {
		color: var(--color-prim);
	}
	.top-topics-slider__slide > a:hover figure::after {
		background: var(--color-prim);
	}
	.top-topics-slider__slide > a:hover figure img {
		transform: scale(1.1);
	}
}
.top-topics-slider__ui {
	width: 130px;
	height: 50px;
	margin: 20px auto 0;
	position: relative;
}
.top-topics-slider__ui::after {
	content: "";
	display: block;
	position: absolute;
	height: 30px;
	width: 1px;
	background-color: var(--color-border);
	top: 13px;
	left: 65px;
}
.top-topics-slider__prev, .top-topics-slider__next {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	bottom: 0;
	background-color: #fff;
	text-align: center;
}
.top-topics-slider__prev::after, .top-topics-slider__next::after {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
}
.top-topics-slider__prev.swiper-button-disabled, .top-topics-slider__next.swiper-button-disabled {
	opacity: 0.3;
}
@media (hover: hover) {
	.top-topics-slider__prev:not(.swiper-button-disabled), .top-topics-slider__next:not(.swiper-button-disabled) {
		cursor: pointer;
		transition: opacity 0.3s;
	}
	.top-topics-slider__prev:not(.swiper-button-disabled):hover, .top-topics-slider__next:not(.swiper-button-disabled):hover {
		opacity: 0.7;
	}
}
.top-topics-slider__prev {
	left: 0;
}
.top-topics-slider__prev::after {
	background: url(/en/assets/images/top/icon-slider-arrow-left.svg) no-repeat center center;
}
.top-topics-slider__next {
	left: 80px;
}
.top-topics-slider__next::after {
	background: url(/en/assets/images/top/icon-slider-arrow-right.svg) no-repeat center center;
}
@media (min-width: 768px), print {
	.top-topics-slider {
		margin-top: 78px;
		padding-top: 40px;
	}
	.top-topics-slider__slides {
		max-width: 1180px;
		margin: 0 auto;
	}
	.top-topics-slider__slide {
		width: 352px !important;
	}
	.top-topics-slider__slide > p {
		padding-top: 20px;
	}
	.top-topics-slider__slide figure {
		transition: transform 0.3s;
	}
}
@media (min-width: 768px) and (min-width: 768px), print and (min-width: 768px), print and (min-width: 768px), print {
	.top-topics-slider__slide.swiper-slide-active {
		margin-left: 30px !important;
		margin-right: 70px !important;
	}
	.top-topics-slider__slide.swiper-slide-active figure {
		transform: scale(1.18);
		transform-origin: center bottom;
	}
	.top-topics-slider__slide.swiper-slide-active p {
		margin-inline: -30px;
	}
	.top-topics-slider__slide.swiper-slide-active > a::after {
		right: -10px;
	}
}
@media (min-width: 768px), print {
	.top-topics-slider__ui {
		margin: 40px 0 0;
	}
}

.top-section-guide {
	margin-top: -30px;
	border-radius: 30px 30px 0 0;
	background-color: var(--color-bg);
	padding-block: 60px 80px;
}
@media (min-width: 768px), print {
	.top-section-guide {
		margin-top: -50px;
		border-radius: 50px 50px 0 0;
		padding-block: 110px 150px;
	}
}
.top-section-guide__contents {
	position: relative;
}
.top-section-guide__illust-tree {
	display: none;
	position: absolute;
	background: url(/en/assets/images/common/illust-tree2.png) no-repeat center/contain;
	width: 61px;
	height: 78px;
	bottom: -72px;
	z-index: 1;
}
@media (min-width: 768px), print {
	.top-section-guide__illust-tree {
		display: block;
		width: 85px;
		height: 110px;
		left: 40px;
		bottom: -101px;
	}
}
.top-section-guide__illust-car {
	display: none;
	position: absolute;
	background: url(/en/assets/images/common/illust-car1.png) no-repeat center/contain;
	width: 89px;
	height: 28px;
	bottom: -72px;
	left: 42px;
	z-index: 1;
}
@media (min-width: 768px), print {
	.top-section-guide__illust-car {
		display: block;
		width: 124px;
		height: 39px;
		left: 100px;
		bottom: -101px;
	}
}
.top-section-guide__bg {
	overflow: hidden;
	border-radius: 20px;
	position: relative;
	z-index: 1;
	background: url(/en/assets/images/top/guide-bg-sp.jpg) no-repeat center top/cover;
	padding: 40px 20px;
}
@media (min-width: 768px), print {
	.top-section-guide__bg {
		background: url(/en/assets/images/top/guide-bg.jpg) no-repeat center top/cover;
		border-radius: 30px;
		width: 100%;
		height: 374px;
		display: flex;
		justify-content: space-between;
		padding: 0 90px 0 100px;
	}
	.top-section-guide__bg::after {
		content: "";
		display: block;
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: -1;
		background-image: linear-gradient(to right, rgba(0, 35, 93, 0.7) 0%, transparent 100%);
	}
}
@media (min-width: 768px), print {
	.top-section-guide__content1 {
		width: 500px;
		padding-top: 90px;
	}
}
.top-section-guide__title {
	font-weight: bold;
	color: #fff;
	font-size: 3rem;
	font-family: var(--font-mont);
	line-height: var(--line-height-s);
}
@media (min-width: 768px), print {
	.top-section-guide__title {
		font-size: 5.2rem;
	}
}
.top-section-guide__description {
	font-weight: bold;
	color: #fff;
	line-height: var(--line-height-l);
	margin-top: 10px;
}
@media (min-width: 768px), print {
	.top-section-guide__description {
		margin-top: 20px;
	}
}
.top-section-guide__button {
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.top-section-guide__button {
		margin-top: 50px;
	}
	.top-section-guide__button a {
		margin-left: unset;
	}
}
.top-section-guide__content2 {
	display: none;
	color: #fff;
}
@media (min-width: 768px), print {
	.top-section-guide__content2 {
		display: block;
		width: 430px;
		padding-top: 80px;
	}
}
.top-section-guide__content2 dl {
	font-size: 1.3rem;
	white-space: nowrap;
}
@media (min-width: 768px), print {
	.top-section-guide__content2 dl {
		font-size: 1.6rem;
	}
}
.top-section-guide__content2 dd em {
	font-size: 3.6rem;
	font-family: var(--font-mont);
	margin-right: 14px;
}
@media (min-width: 768px), print {
	.top-section-guide__content2 dd em {
		font-size: 5rem;
	}
}
.top-section-guide__content2 dd i {
	display: inline-block;
	line-height: 1.2;
}
.top-section-guide__content2 p {
	font-size: 1.3rem;
}
.top-section-guide__content2-upper {
	display: flex;
	justify-content: center;
	gap: 20px;
	font-weight: bold;
	margin-top: 30px;
}
@media (min-width: 768px), print {
	.top-section-guide__content2-upper {
		gap: 30px;
		justify-content: flex-start;
		margin-top: 0;
	}
}
.top-section-guide__content2-lower {
	display: flex;
	justify-content: center;
	gap: 20px;
	font-weight: bold;
	margin-top: 10px;
}
@media (min-width: 768px), print {
	.top-section-guide__content2-lower {
		gap: 30px;
		justify-content: flex-start;
		margin-top: 20px;
	}
}

.top-section-ir {
	margin-top: -30px;
	border-radius: 30px 30px 0 0;
	background-color: #FFF;
	padding-block: 60px 0;
}
@media (min-width: 768px), print {
	.top-section-ir {
		margin-top: -50px;
		border-radius: 50px 50px 0 0;
		padding-block: 110px 0;
	}
}
.top-section-ir__contents {
	margin-top: 30px;
	position: relative;
}
@media (min-width: 768px), print {
	.top-section-ir__contents {
		margin-top: 40px;
	}
}
.top-section-ir__bg {
	overflow: hidden;
	border-radius: 15px;
	position: relative;
	z-index: 1;
	background: url(/en/assets/images/top/ir-bg-sp.jpg) no-repeat center center;
	background-size: cover;
	height: 130px;
}
.top-section-ir__bg::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	background-image: linear-gradient(to bottom, rgba(0, 35, 93, 0.7) 0%, transparent 100%);
}
@media (min-width: 768px), print {
	.top-section-ir__bg {
		border-radius: 30px;
		width: 100%;
		height: 374px;
		background: url(/en/assets/images/top/ir-bg.jpg) no-repeat center center;
	}
	.top-section-ir__bg::after {
		background-image: linear-gradient(to right, rgba(0, 35, 93, 0.7) 0%, transparent 100%);
	}
}
.top-section-ir__links {
	display: flex;
	justify-content: center;
	gap: 32px;
	margin-top: 20px;
}
@media (min-width: 768px), print {
	.top-section-ir__links {
		position: absolute;
		bottom: 0;
		right: 0;
		background-color: #fff;
		gap: 64px;
		padding: 50px 50px 20px;
		border-radius: 30px 0 0 0;
		z-index: 1;
	}
}
.top-section-ir__links li a {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	height: 100%;
	gap: 0;
}
@media (min-width: 768px), print {
	.top-section-ir__links li a {
		text-decoration: none;
		text-align: left;
		gap: 20px;
	}
}
@media (hover: hover) {
	.top-section-ir__links li a {
		transition: color 0.3s;
	}
	.top-section-ir__links li a:hover {
		color: var(--color-prim);
	}
}
.top-section-ir__links li a figure {
	width: 80px;
	height: 80px;
	display: grid;
	place-content: center;
}
@media (min-width: 768px), print {
	.top-section-ir__links li a figure {
		width: 100px;
		height: 100px;
	}
}
@media (max-width: 767px) {
	.top-section-ir__links li a figure img {
		transform: scale(0.8);
	}
}
.top-section-ir__links li a figure .icon-strategy {
	width: 73px;
}
.top-section-ir__links li a figure .icon-library {
	width: 77px;
}
.top-section-ir__links li a figure .icon-highlight {
	width: 59px;
}
.top-section-ir__links li a p {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	font-weight: bold;
	gap: 7px;
}
@media (min-width: 768px), print {
	.top-section-ir__links li a p::before {
		content: "";
		display: block;
		width: 16px;
		height: 16px;
		-webkit-mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
		mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
		-webkit-mask-size: 16px;
		mask-size: 16px;
		background: var(--color-prim);
		margin-top: 5px;
	}
}
@media (min-width: 768px), print {
	.top-section-ir__text {
		position: absolute;
		top: 0;
		z-index: 1;
		width: 400px;
		padding: 90px 0 0 0;
		margin-left: 65px;
	}
}
.top-section-ir__description {
	font-weight: bold;
	color: #fff;
	line-height: var(--line-height-l);
}
@media (max-width: 767px) {
	.top-section-ir__description {
		position: absolute;
		top: 0;
		z-index: 1;
		padding: 20px;
	}
}
.top-section-ir__button {
	margin-top: 40px;
}
@media (min-width: 768px), print {
	.top-section-ir__button {
		margin-top: 50px;
	}
	.top-section-ir__button a {
		margin-left: unset;
	}
}

.top-section-sustainability {
	position: relative;
	background-color: #FFF;
	padding-block: 80px 60px;
	overflow: hidden;
}
.top-section-sustainability::after {
	content: "";
	display: block;
	position: absolute;
	width: 609px;
	height: 135px;
	top: 82px;
	left: calc(50% - 30px);
	background: url(/en/assets/images/top/sustainability-illust-bg1-sp.png) no-repeat center/100% auto;
}
@media (min-width: 768px), print {
	.top-section-sustainability {
		padding-block: 100px 130px;
	}
	.top-section-sustainability::after {
		width: 1233px;
		height: 274px;
		left: calc(50% + 20px);
		background-image: url(/en/assets/images/top/sustainability-illust-bg1.png);
	}
	.top-section-sustainability::before {
		content: "";
		display: block;
		position: absolute;
		top: 290px;
		right: 0;
		height: 1px;
		width: calc(50% - 1253px);
		background-color: var(--color-prim);
	}
}
.top-section-sustainability__contents {
	margin-top: 30px;
	position: relative;
}
@media (min-width: 768px), print {
	.top-section-sustainability__contents {
		margin-top: 40px;
	}
}
.top-section-sustainability__bg {
	overflow: hidden;
	border-radius: 15px;
	position: relative;
	z-index: 1;
	background: url(/en/assets/images/top/sustainability-bg-sp.jpg) no-repeat center center/cover;
	height: 130px;
}
.top-section-sustainability__bg::after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
	background-image: linear-gradient(to bottom, rgba(0, 35, 93, 0.7) 0%, rgba(0, 35, 93, 0.3) 100%);
}
@media (min-width: 768px), print {
	.top-section-sustainability__bg {
		border-radius: 30px;
		width: 100%;
		height: 374px;
		background: url(/en/assets/images/top/sustainability-bg.jpg) no-repeat center center/cover;
	}
	.top-section-sustainability__bg::after {
		background-image: linear-gradient(to right, rgba(0, 35, 93, 0.7) 0%, transparent 100%);
	}
}
.top-section-sustainability__links {
	display: flex;
	justify-content: center;
	gap: 32px;
	margin-top: 20px;
}
@media (min-width: 768px), print {
	.top-section-sustainability__links {
		position: absolute;
		bottom: 0;
		right: 0;
		background-color: #fff;
		gap: 64px;
		padding: 50px 50px 20px;
		border-radius: 30px 0 0 0;
		z-index: 1;
	}
}
.top-section-sustainability__links li a {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	height: 100%;
	gap: 0;
}
@media (min-width: 768px), print {
	.top-section-sustainability__links li a {
		text-decoration: none;
		text-align: left;
		gap: 20px;
	}
}
@media (hover: hover) {
	.top-section-sustainability__links li a {
		transition: color 0.3s;
	}
	.top-section-sustainability__links li a:hover {
		color: var(--color-prim);
	}
}
.top-section-sustainability__links li a figure {
	width: 80px;
	height: 80px;
	display: grid;
	place-content: center;
}
@media (min-width: 768px), print {
	.top-section-sustainability__links li a figure {
		width: 100px;
		height: 100px;
	}
}
@media (max-width: 767px) {
	.top-section-sustainability__links li a figure img {
		transform: scale(0.8);
	}
}
.top-section-sustainability__links li a figure .icon-environment {
	width: 73px;
}
.top-section-sustainability__links li a figure .icon-social {
	width: 81px;
}
.top-section-sustainability__links li a figure .icon-governance {
	width: 74px;
}
.top-section-sustainability__links li a p {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	font-weight: bold;
	gap: 7px;
}
@media (min-width: 768px), print {
	.top-section-sustainability__links li a p::before {
		content: "";
		display: block;
		width: 16px;
		height: 16px;
		-webkit-mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
		mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
		-webkit-mask-size: 16px;
		mask-size: 16px;
		background: var(--color-prim);
		margin-top: 5px;
	}
}
@media (min-width: 768px), print {
	.top-section-sustainability__text {
		position: absolute;
		top: 0;
		z-index: 1;
		width: 400px;
		padding: 90px 0 0 0;
		margin-left: 65px;
	}
}
.top-section-sustainability__description {
	font-weight: bold;
	color: #fff;
	line-height: var(--line-height-l);
}
@media (max-width: 767px) {
	.top-section-sustainability__description {
		position: absolute;
		top: 0;
		z-index: 1;
		padding: 20px;
	}
}
.top-section-sustainability__button {
	margin-top: 40px;
}
@media (min-width: 768px), print {
	.top-section-sustainability__button {
		margin-top: 50px;
	}
	.top-section-sustainability__button a {
		margin-left: unset;
	}
}

.top-section-product {
	background-color: #FFF;
	padding-block: 192px 60px;
	position: relative;
}
@media (min-width: 768px), print {
	.top-section-product {
		padding-block: 300px 0;
	}
}
.top-section-product__mask-image {
	position: absolute;
	width: 100%;
	top: 0;
	-webkit-mask-image: url(/en/assets/images/common/circle-mask.svg);
	mask-image: url(/en/assets/images/common/circle-mask.svg);
	-webkit-mask-repeat: no-repeat;
	mask-repeat: no-repeat;
	-webkit-mask-position: center top;
	mask-position: center top;
	-webkit-mask-size: 2000px;
	mask-size: 2000px;
	height: 222px;
}
@media (min-width: 768px), print {
	.top-section-product__mask-image {
		-webkit-mask-size: 5000px;
		mask-size: 5000px;
		height: 600px;
	}
}
.top-section-product__mask-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.top-section-product__inner {
	position: relative;
	z-index: 1;
	background: #fff;
	border-radius: 30px;
	box-shadow: 0 6px 16px rgba(0, 0, 0, 0.1);
	padding: 30px 20px;
	margin-inline: -20px;
}
@media (min-width: 768px), print {
	.top-section-product__inner {
		padding: 50px 100px;
		margin-inline: 100px;
	}
}
.top-section-product__en {
	font-weight: 800;
	font-size: 1.6rem;
	font-family: var(--font-mont);
	color: var(--color-seco);
}
@media (min-width: 768px), print {
	.top-section-product__en {
		font-size: 2.5rem;
		text-align: center;
	}
}
.top-section-product__title {
	line-height: var(--line-height-s);
	margin-top: 8px;
	font-weight: bold;
	font-size: 2.4rem;
	font-family: var(--font-mont);
}
@media (min-width: 768px), print {
	.top-section-product__title {
		margin-top: 10px;
		font-size: 3rem;
		text-align: center;
	}
}
.top-section-product__description {
	margin-top: 20px;
}
@media (min-width: 768px), print {
	.top-section-product__description {
		margin-top: 30px;
	}
}
.top-section-product__buttons {
	margin-top: 30px;
	display: flex;
	flex-direction: column;
	gap: 20px;
}
@media (min-width: 768px), print {
	.top-section-product__buttons {
		margin-top: 40px;
		flex-direction: row;
		justify-content: center;
		align-items: center;
		gap: 40px;
	}
	.top-section-product__buttons li {
		width: 300px;
	}
	.top-section-product__buttons li a {
		max-width: 100%;
	}
}

.top-section-links {
	background-color: #FFF;
	padding-block: 30px 60px;
	position: relative;
}
@media (min-width: 768px), print {
	.top-section-links {
		padding-block: 100px 100px;
	}
}

.top-link-list {
	display: grid;
	gap: 20px;
	grid-template-columns: repeat(1, 1fr);
}
@media (min-width: 768px), print {
	.top-link-list {
		gap: 40px;
		grid-template-columns: repeat(3, 1fr);
	}
}
.top-link-list a {
	text-decoration: none;
}
@media (hover: hover) {
	.top-link-list a {
		transition: color 0.3s;
	}
	.top-link-list a img {
		transition: transform 0.3s;
	}
	.top-link-list a:hover {
		color: var(--color-prim);
	}
	.top-link-list a:hover img {
		transform: scale(1.1);
	}
}
.top-link-list figure {
	border-radius: 15px;
	overflow: hidden;
}
.top-link-list__contents {
	background-color: #fff;
	margin-top: -46px;
	position: relative;
	border-radius: 10px 0 10px 10px;
	margin-left: 36px;
	padding: 16px 0 16px 20px;
}
@media (min-width: 768px), print {
	.top-link-list__contents {
		border-radius: 20px 0 20px 20px;
		padding: 20px 0 20px 24px;
	}
}
.top-link-list__en {
	display: flex;
	align-items: center;
	justify-content: space-between;
	font-weight: bold;
	font-size: 1.8rem;
	font-family: var(--font-mont);
}
@media (min-width: 768px), print {
	.top-link-list__en {
		font-size: 2.1rem;
	}
}
.top-link-list__en::after {
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	-webkit-mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
	mask-image: url(/en/assets/images/common/icon-circle-arrow-right.svg);
	background: var(--color-prim);
	right: 18px;
}
/*# sourceMappingURL=top.css.map */
