.c-arrow {
	background-color: #E7E7E7;
	border-radius: 0.46875rem;
	display: inline-block;
	height: 1.3125rem;
	overflow: hidden;
	position: absolute;
	width: 2.3125rem;
}

.c-arrow.--big {
	height: 1.875rem;
	width: 3.375rem;
}

.c-arrow::after {
	-webkit-mask: url(../images/common/arrow-btn.svg) center center/46% no-repeat;
	background-color: #000;
	content: "";
	height: 100%;
	left: 0;
	mask: url(../images/common/arrow-btn.svg) center center/46% no-repeat;
	position: absolute;
	width: 100%;
}

.c-arrow.--button {
	border: 1px solid #E7E7E7;
}

.c-arrow.--button::before {
	background-color: #000;
	border-radius: 2px;
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 1rem;
}

.c-arrow.--button::after {
	-webkit-mask: unset;
	background: #000;
	border-radius: 2px;
	content: "";
	height: 1px;
	left: 50%;
	mask: unset;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%) rotate(90deg);
	transition: all 0.45s;
	width: 0.6875rem;
}

.c-arrow.--button.is-active::after {
	transform: translate(-50%, -50%) rotate(0deg);
}

.c-bg {
	display: inline-block;
	position: relative;
	z-index: 1;
}

.c-bg::before {
	background-color: #F2FF40;
	content: "";
	height: 1.9375rem;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	transition: all 0.45s 0.45s;
	width: 0%;
	z-index: -1;
}

.c-bg.is-active::before {
	width: 100%;
}

.c-btn {
	align-items: center;
	background-color: #fff;
	border: 1px solid #E7E7E7;
	border-radius: 1.25rem;
	display: inline-flex;
	font-size: 1.25rem;
	font-weight: 400;
	height: 3.125rem;
	letter-spacing: 0.005em;
	padding-inline: 1.25rem 3.75rem;
	position: relative;
	width: 16.375rem;
}

.c-btn.--reverse {
	justify-content: flex-end;
	padding-inline: 3.75rem 1.25rem;
}

.c-btn.--reverse .c-btn__arrow {
	left: 1.25rem;
	right: initial;
	transform: rotate(180deg);
}

.c-btn.--small {
	border-radius: 0.9375rem;
	font-size: 1rem;
	height: 2.6875rem;
	letter-spacing: 0.001em;
}

.c-btn__text {
	display: block;
	overflow: hidden;
	position: relative;
}

.c-btn__text span,
.c-btn__text::after {
	display: block;
	transform: translateY(0);
}

.c-btn__text::after {
	content: attr(data-text);
	left: 0;
	position: absolute;
	top: 100%;
}

.c-btn:hover .c-btn__text span,
.c-btn:hover .c-btn__text::after {
	animation: none, textSlide 0.5s forwards;
}

.c-btn__arrow {
	right: 1.25rem;
}

.c-btn2 {
	align-items: center;
	border: 1px solid #000;
	border-radius: 0.9375rem;
	display: inline-flex;
	font-size: 1.25rem;
	height: 4.6875rem;
	overflow: hidden;
	padding-inline: 2.25rem 1.5625rem;
	width: 25rem;
}

.c-btn2.u-bg-black {
	color: #fff;
}

.c-btn2.u-bg-black .c-btn2__icon {
	filter: brightness(0) invert(1);
}

.c-btn2.--big {
	padding-inline: 2.875rem 1.5625rem;
	width: 30.4375rem;
}

.c-btn2__text {
	align-items: flex-end;
	display: flex;
	line-height: 1.25;
	overflow: hidden;
	position: relative;
}

.c-btn2__text span,
.c-btn2__text::after {
	display: block;
	transform: translateY(0);
}

.c-btn2__text::after {
	content: attr(data-text);
	left: 0;
	position: absolute;
	top: 105%;
}

.c-btn2__icon {
	display: block;
	margin-left: auto;
	width: 3.6875rem;
}

.c-btn2:hover .c-btn2__text span,
.c-btn2:hover .c-btn2__text::after {
	animation: none, textSlide 0.5s forwards;
}

.c-btn2:hover .c-btn2__icon {
	animation: jet 0.75s cubic-bezier(0.215, 0.61, 0.255, 0.1) 0s 1 forwards;
}

.c-card__thumbnail img {
	-o-object-fit: cover;
	aspect-ratio: 415/277;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.c-card__title {
	align-items: center;
	display: flex;
	font-size: 1.5625rem;
	font-weight: 400;
	line-height: 1.5;
	margin-top: 1rem;
	min-height: 5.6875rem;
}

.c-card__text {
	margin-top: 1rem;
}

.c-card__btn {
	margin-top: 1rem;
}

.c-contact {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	height: 100%;
	justify-content: center;
}

.c-contact img {
	width: 2.1875rem;
	width: 2.5rem;
}

.c-contact span {
	color: #777777;
	font-size: 0.65rem;
	letter-spacing: 0.1em;
}

.c-entry {
	align-items: center;
	display: inline-flex;
	gap: 5.4375rem;
	height: 18.75rem;
	max-width: 87.5rem;
	padding-inline: 6.25rem;
	position: relative;
	width: 100%;
	z-index: 1;
}

.c-entry::before {
	background-color: #F2FF40;
	border: 1px solid #000;
	border-radius: 3.125rem;
	content: "";
	height: 100%;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	transition: all 0.45s;
	width: 100%;
	will-change: transform;
	z-index: -1;
}

.c-entry__icon {
	width: 10.1875rem;
}

.c-entry__en {
	font-size: 2.25rem;
	letter-spacing: 0.01em;
}

.c-entry__title {
	font-size: 3rem;
	font-weight: 300;
	letter-spacing: 0.2em;
	line-height: 0.8333333333;
	margin-top: 0.9375rem;
}

.c-entry__text {
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.8;
	margin-top: 0.875rem;
}

.c-entry__arrow {
	right: 5.3125rem;
}

.c-entryBtn {
	align-items: center;
	background-color: #F2FF40;
	border: 1px solid #000;
	border-radius: 0.9375rem;
	display: inline-flex;
	height: 3.0625rem;
	justify-content: center;
	position: relative;
	width: 16.0625rem;
}

.c-entryBtn::before {
	background: url(../images/common/icon_toonkigo.svg) center center/contain no-repeat;
	content: "";
	display: block;
	height: 2.1875rem;
	width: 2.1875rem;
}

.c-entryBtn__text {
	display: block;
	overflow: hidden;
	position: relative;
}

.c-entryBtn__text span,
.c-entryBtn__text::after {
	display: block;
	transform: translateY(0);
}

.c-entryBtn__text::after {
	content: attr(data-text);
	left: 0;
	position: absolute;
	top: 100%;
}

.c-entryBtn:hover .c-entryBtn__text span,
.c-entryBtn:hover .c-entryBtn__text::after {
	animation: none, textSlide 0.5s forwards;
}

.c-hamburger {
	height: 100%;
	position: relative;
	width: 100%;
}

.c-hamburger span {
	background-color: #777777;
	display: inline-block;
	height: 1px;
	left: 50%;
	position: absolute;
	transform: translate(-50%, -50%);
	transition: all 0.45s;
	width: 2.03125rem;
}

.c-hamburger span:nth-child(1) {
	top: calc(50% - 0.78125rem);
}

.c-hamburger span:nth-child(2) {
	top: 50%;
}

.c-hamburger span:nth-child(3) {
	top: calc(50% + 0.78125rem);
}

.c-hamburger.is-active span:nth-child(1) {
	top: 50%;
	transform: translate(-50%, -50%) rotate(37.15deg);
}

.c-hamburger.is-active span:nth-child(2) {
	opacity: 0;
}

.c-hamburger.is-active span:nth-child(3) {
	top: 50%;
	transform: translate(-50%, -50%) rotate(-37.15deg);
}

.c-icon {
	align-items: center;
	background-color: #E7E7E7;
	border-radius: 50%;
	display: inline-flex;
	height: 3.5625rem;
	justify-content: center;
	transition: all 0.45s;
	width: 3.5625rem;
}

.c-icon img {
	-o-object-fit: contain;
	height: 1.25rem;
	object-fit: contain;
	width: 1.6875rem;
}

.c-news {
	align-items: flex-start;
	background-color: #fff;
	border: 1px solid #E7E7E7;
	border-radius: 2.5rem;
	display: grid;
	gap: 1.625rem;
	grid-template-columns: 9.375rem 1fr;
	padding: 2.6875rem 14.1875rem 2.6875rem 4.0625rem;
	position: relative;
}

.c-news__thumbnail {
	overflow: hidden;
}

.c-news__thumbnail img {
	-o-object-fit: cover;
	aspect-ratio: 150/105;
	height: 100%;
	object-fit: cover;
	transition: all 0.45s;
	width: 100%;
}

.c-news__head {
	align-items: center;
	display: flex;
	gap: 0.25rem;
}

.c-news__tag {
	align-items: center;
	background-color: #F2FF40;
	border-radius: 50%;
	display: flex;
	font-size: 1.1875rem;
	height: 1.3125rem;
	justify-content: center;
	width: 1.3125rem;
}

.c-news__info {
	color: #777777;
	font-size: 0.75rem;
	font-weight: 300;
	line-height: 2;
	text-align: left;
}

.c-news__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	display: -webkit-box;
	font-size: 1.125rem;
	font-weight: 400;
	line-height: 1.8;
	margin-top: 0.3125rem;
	overflow: hidden;
}

.c-news__arrow {
	right: 3.875rem;
	top: 50%;
	transform: translateY(-50%);
}

.c-pageLink {
	align-items: center;
	background-color: #fff;
	border: 1px solid #000;
	border-radius: 3.125rem;
	display: grid;
	gap: 0 6rem;
	grid-template-columns: 27.3125rem 1fr;
	margin-inline: auto;
	max-width: 87.5rem;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.c-pageLink__img {
	overflow: hidden;
}

.c-pageLink__img img {
	-o-object-fit: cover;
	aspect-ratio: 437/259;
	height: 100%;
	object-fit: cover;
	transition: all 0.45s;
	width: 100%;
}

.c-pageLink__arrow.c-arrow {
	right: 5.625rem;
	top: 50%;
	transform: translateY(-50%);
}

@property --r {
	syntax: "<angle>";
	initial-value: 90deg;
	inherits: false;
}

.c-plus {
	--r: 90deg;
	background-color: #E7E7E7;
	border-radius: 0.5rem;
	display: inline-block;
	height: 1.875rem;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 3.375rem;
}

.c-plus::before {
	background-color: #000;
	border-radius: 1px;
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 1.5rem;
}

.c-plus::after {
	background-color: #000;
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%) rotate(var(--r));
	transition: all 0.45s;
	width: 0.875rem;
}

.c-plus.is-active::after {
	--r: 0deg;
}

.c-smallCard {
	display: grid;
	gap: 0;
	grid-row: span 2;
	grid-template-rows: subgrid;
}

.c-smallCard:has(.c-smallCard__text) {
	grid-row: span 3;
}

.c-smallCard__img {
	display: block;
}

.c-smallCard__img img {
	-o-object-fit: cover;
	aspect-ratio: 327/263;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.c-smallCard__title {
	align-items: center;
	display: flex;
	font-size: 1.25rem;
	font-weight: 300;
	justify-content: center;
	letter-spacing: 0.2em;
	line-height: 1.3;
	margin-top: 1.125rem;
	min-height: 3.25rem;
	text-align: center;
}

.c-smallCard__text {
	margin-top: 0.875rem;
}

.c-smallEntry {
	align-items: center;
	background-color: #F2FF40;
	border: 1px solid #000;
	border-radius: 0.9375rem;
	display: inline-flex;
	gap: 0.5rem;
	height: 7.375rem;
	padding-inline: 1.125rem;
	position: relative;
	width: 100%;
}

.c-smallEntry__icon {
	width: 3.9375rem;
}

.c-smallEntry__en {
	font-size: 2.5rem;
	letter-spacing: 0.02em;
}

.c-smallEntry__title {
	font-size: 0.75rem;
	font-weight: 300;
	letter-spacing: 0.1em;
	margin-top: 0.1875rem;
}

.c-smallEntry__arrow {
	right: 1.6875rem;
}

.c-tag {
	display: inline-block;
	font-size: 1.5rem;
	font-weight: 300;
	gap: 0.25rem;
	letter-spacing: 0.1em;
	line-height: 2;
}

.c-tag span {
	align-items: center;
	background-color: #F2FF40;
	border-radius: 50%;
	display: inline-flex;
	font-size: 1.875rem;
	height: 2.0625rem;
	justify-content: center;
	margin-right: 0.3125rem;
	width: 2.0625rem;
}

.c-title__en {
	text-align: center;
	text-transform: uppercase;
}

.c-title__ja {
	color: #777777;
	margin-top: -1.25rem;
	text-align: center;
}

.u-white {
	color: #fff;
}

.u-bg-white {
	background-color: #fff;
}

.u-bg-black {
	background-color: #000;
}

.u-bg01 {
	background-color: #F2FF40;
}

.u-bg02 {
	background-color: #E6EEEA;
}

.u-text03 {
	color: #777777;
}

.u-text04 {
	color: #ADADAD;
}

.u-ja-font {
	font-family: "Noto Sans JP", sans-serif;
}

.u-en-font {
	font-family: "Lancelot", serif;
}

.u-text-left {
	text-align: left;
}

.u-text-center {
	text-align: center;
}

.u-text-right {
	text-align: right;
}

.u-mt-0 {
	margin-top: 0 !important;
}

.u-pt-0 {
	padding-top: 0 !important;
}

.u-pt-0-sp {
	padding-top: 0 !important;
}

.c-en-title {
	font-size: 4.375rem;
	font-weight: 400;
	letter-spacing: 0.02em;
	line-height: 1.3;
}

.c-ja-title {
	font-size: 2.5rem;
	font-weight: 300;
	letter-spacing: 0.2em;
	line-height: 1.5;
}

.c-subTitle {
	font-size: 2rem;
	font-weight: 400;
	letter-spacing: 0.2em;
	line-height: 1.5;
}

.c-lead {
	font-size: 1.5rem;
	font-weight: 300;
	letter-spacing: 0.1em;
	line-height: 2;
}

.c-text {
	font-size: 1.25rem;
	font-weight: 300;
	letter-spacing: 0.2em;
	line-height: 1.8;
}

.c-text a {
	text-decoration: underline;
}

.c-note {
	font-size: 0.9375rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.8;
}

@media (hover: hover) {

summary:hover .c-arrow::after,
button:hover .c-arrow::after,
a:hover .c-arrow::after {
	animation: arrow_animation 0.5s cubic-bezier(0.215, 0.61, 0.255, 0.1) 0s 1 forwards;
}

.c-entry:hover::before {
	transform: translate(-50%, -50%) scale(1.037);
}

.c-icon:hover {
	background-color: #ADADAD;
}

.c-news:hover .c-news__thumbnail img {
	transform: scale(1.05);
}

.c-pageLink:hover .c-pageLink__img img {
	transform: scale(1.05);
}

}

@media screen and (max-width: 768px) {

.c-arrow {
	height: 1.4375rem;
	width: 2.5625rem;
}

.c-arrow.--big {
	height: 1.4375rem;
	width: 2.5625rem;
}

.c-arrow.--small {
	height: 0.9375rem;
	width: 1.6875rem;
}

.c-bg::before {
	height: 1.4375rem;
}

.c-btn {
	border-radius: 0.9375rem;
	font-size: 0.8125rem;
	height: 2.75rem;
	padding-inline: 1rem 3.75rem;
	padding-top: 0.125rem;
	width: 13.5rem;
}

.c-btn.u-en-font {
	font-size: 1rem;
}

.c-btn.--reverse {
	padding-inline: 3.75rem 1rem;
}

.c-btn.--reverse .c-btn__arrow {
	left: 0.8125rem;
	right: initial;
}

.c-btn__arrow {
	right: 0.8125rem;
}

.c-btn2 {
	font-size: 0.9375rem;
	height: 3.5rem;
	padding-inline: 1.9375rem;
	padding-top: 0.1875rem;
	width: 20.3125rem;
}

.c-btn2.u-en-font {
	font-size: 1.25rem;
}

.c-btn2__icon {
	width: 3.1875rem;
}

.c-card__title {
	font-size: 1.375rem;
	margin-top: 0.625rem;
	min-height: 3.125rem;
}

.c-card__text {
	margin-top: 0.625rem;
}

.c-card__btn {
	margin-top: 0.8125rem;
}

.c-entry {
	flex-direction: column;
	height: 14.1875rem;
	justify-content: center;
	max-width: 33.75rem;
	padding-inline: 1.9375rem;
	padding-top: 1.875rem;
}

.c-entry::before {
	border-radius: 1.5625rem;
}

.c-entry__icon {
	left: 1.9375rem;
	position: absolute;
	top: -0.8125rem;
	width: 4rem;
}

.c-entry__en {
	font-size: 0.975rem;
	text-align: left;
}

.c-entry__title {
	font-size: 1.4375rem;
	letter-spacing: 0.1em;
	line-height: 0.7391304348;
	margin-top: 0.375rem;
	text-align: left;
}

.c-entry__text {
	font-size: 0.875rem;
	letter-spacing: 0.1em;
	line-height: 1.7857142857;
	text-align: left;
}

.c-icon {
	height: 2.875rem;
	width: 2.875rem;
}

.c-icon img {
	height: 1.125rem;
	width: 1.375rem;
}

.c-news {
	align-items: center;
	border-radius: 1.25rem;
	gap: 0.5rem;
	grid-template-columns: 4.375rem 1fr;
	padding: 0.875rem 4.9375rem 0.875rem 1.25rem;
	padding: 0.75rem 3.5rem 0.75rem 1rem;
}

.c-news__thumbnail img {
	aspect-ratio: 70/58;
}

.c-news__head {
	gap: 0.1875rem;
}

.c-news__tag {
	align-self: flex-start;
	font-size: 0.8125rem;
	height: 0.9375rem;
	margin-top: 0.1875rem;
	width: 0.9375rem;
}

.c-news__info {
	line-height: 1.8;
}

.c-news__title {
	font-size: 0.85rem;
	line-height: 1.4;
	margin-top: 0.25rem;
}

.c-news__arrow {
	right: 1.5625rem;
}

.c-pageLink {
	border-radius: 0.8125rem;
	gap: 0 4.3%;
	grid-template-columns: 28.9% 1fr;
	max-width: 33.75rem;
}

.c-pageLink__img {
	height: 100%;
}

.c-pageLink__img img {
	aspect-ratio: 94/88;
}

.c-pageLink__title .c-en-title {
	font-size: 1.4375rem;
}

.c-pageLink__title .c-lead {
	font-size: 0.75rem;
}

.c-pageLink__arrow.c-arrow {
	height: 1.125rem;
	right: 0.875rem;
	width: 2rem;
}

.c-plus {
	border-radius: 0.375rem;
	height: 1.375rem;
	width: 2.5rem;
}

.c-plus::before {
	width: 1.0625rem;
}

.c-plus::after {
	width: 0.625rem;
}

.c-smallCard__img img {
	aspect-ratio: 170/138;
}

.c-smallCard__title {
	font-size: 0.875rem;
	margin-top: 0.3125rem;
	min-height: 2.25rem;
}

.c-smallCard__title br {
	display: none;
}

.c-smallCard__text {
	margin-top: 0.25rem;
}

.c-tag {
	font-size: 0.75rem;
}

.c-tag span {
	font-size: 0.875rem;
	height: 1rem;
	margin-right: 0.1875rem;
	width: 1rem;
}

.c-title__ja {
	margin-top: -0.625rem;
}

.u-mt-0-sp {
	margin-top: 0 !important;
}

.c-en-title {
	font-size: 2.8125rem;
}

.c-ja-title {
	font-size: 1.875rem;
}

.c-subTitle {
	font-size: 1.5625rem;
}

.c-lead {
	font-size: 1rem;
}

.c-text {
	font-size: 0.875rem;
	letter-spacing: 0.1em;
	line-height: 1.7857142857;
}

.c-note {
	font-size: 0.75rem;
}

}

@keyframes textSlide {

0% {
	transform: translateY(0);
}

100% {
	transform: translateY(-105%);
}

}

@keyframes jet {

0% {
	opacity: 1;
	transform: translate(0, 0);
}

50% {
	opacity: 0;
	transform: translate(60%, -60%);
}

50.1% {
	opacity: 0;
	transform: translate(-60%, 60%);
}

100% {
	opacity: 1;
	transform: translate(0, 0);
}

}

@keyframes arrow_animation {

0% {
	opacity: 1;
	transform: translateX(0);
}

50% {
	opacity: 0;
	transform: translateX(60%);
}

50.1% {
	opacity: 0;
	transform: translateX(-60%);
}

to {
	opacity: 1;
	transform: translateX(0);
}

}

@keyframes dotscroll {

0% {
	opacity: 0;
	top: 0%;
}

50% {
	opacity: 1;
}

100% {
	opacity: 0;
	top: 100%;
}

}

