body {
	font-family: "Noto Sans JP", sans-serif;
}

.u-bg {
	background: #0d1036;
}

.u-bg-01 {
	background: #09182f;
}

.u-bg-02 {
	background: #0e264a;
}

.u-bg-03 {
	background: #173c73;
}

.u-bg-04 {
	background: #1b4789;
}

.u-bg-05 {
	background: #3c567e;
}

.u-desktop {
	display: none;
}

/* リキッドレイアウト対応 */

html {
	font-size: 16px;
	scrollbar-gutter: stable;
}

/* pcの電話番号発信対応 */

/* ホバー */

a {
	-webkit-text-decoration: none;
	color: inherit;
	text-decoration: none;
	transition: opacity 0.3s;
}

body {
	position: relative;
}

/* スキップリンク */

.c-skip-link {
	-webkit-text-decoration: none;
	background: #1c4b90;
	border-radius: 0 0 0.25rem 0.25rem;
	color: #fff;
	font-size: 0.875rem;
	font-weight: 700;
	left: 1rem;
	padding: 0.625rem 1.25rem;
	position: absolute;
	text-decoration: none;
	top: -100%;
	transition: top 0.2s ease;
	white-space: nowrap;
	z-index: 99999;
}

.c-skip-link:focus {
	outline: 3px solid #fff;
	outline-offset: 2px;
	top: 0;
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

/* Remove default padding */

ul,
ol {
	padding: 0;
}

/* Remove default margin */

body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
figure,
blockquote,
dl,
dd {
	margin: 0;
}

/* Set core root defaults */

html {
	scroll-behavior: smooth;
}

/* Set core body defaults */

body {
	line-height: 1.5;
	min-height: 100vh;
	text-rendering: optimizeSpeed;
}

/* Remove list styles on ul, ol elements with a class attribute */

ul,
ol {
	list-style: none;
}

/* A elements that don't have a class get default styles */

a:not([class]) {
	-webkit-text-decoration-skip: ink;
	text-decoration-skip-ink: auto;
}

/* Make images easier to work with */

img {
	display: block;
	max-width: 100%;
	width: 100%;
}

/* Natural flow and rhythm in articles by default */

article > * + * {
	margin-top: 1em;
}

/* Inherit fonts for inputs and buttons */

input,
button,
textarea,
select {
	font: inherit;
}

/* Blur images when they have no alt attribute */

img:not([alt]) {
	filter: blur(10px);
}

/* フォームリセット */

input,
button,
select,
textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background: transparent;
	border: none;
	border-radius: 0;
	font: inherit;
	outline: none;
}

textarea {
	resize: vertical;
}

input[type=checkbox],
input[type=radio] {
	display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
	cursor: pointer;
}

select::-ms-expand {
	display: none;
}

.l-activities {
	padding: 3.75rem 0;
}

.l-business {
	padding: 3.75rem 0;
}

.l-header {
	left: 0;
	position: fixed;
	right: 0;
	top: 0;
	z-index: 900;
}

.l-inner {
	margin-left: auto;
	margin-right: auto;
	padding-left: 20px;
	padding-right: 20px;
	width: 100%;
}

.l-instagram {
	background: linear-gradient(to bottom, transparent, rgba(64, 134, 255, 0.16));
	padding: 3.75rem 0;
}

.l-main {
	position: relative;
}

#particles-js {
	bottom: 0;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 0;
}

.l-main > *:not(#particles-js) {
	position: relative;
	z-index: 1;
}

.l-media {
	padding: 3.75rem 0;
}

.l-message {
	padding: 3.75rem 0;
}

.l-news-archive {
	padding: 3.75rem 0;
}

.l-news {
	padding: 3.75rem 0;
}

.l-scroll-text {
	padding: 1.875rem 0;
}

.p-service-intro {
	padding: 3.75rem 0;
	text-align: center;
}

.c-breadcrumb,
.p-breadcrumb,
.breadcrumb {
	font-size: 0.75rem;
	line-height: 1.5;
	opacity: 0.76;
	padding: 0.625rem 0;
}

.c-button {
	-webkit-text-decoration: none;
	align-items: center;
	background: #1c4b90;
	border-radius: 1.5rem;
	color: #fff;
	display: inline-block;
	display: flex;
	font-family: "Poppins", sans-serif;
	font-weight: 500;
	justify-content: space-around;
	line-height: 1.8;
	max-width: 14.375rem;
	padding: 0.625rem 0px 0.625rem 1.5625rem;
	position: relative;
	text-decoration: none;
	transition: 0.3s ease-in-out;
	width: 100%;
}

.c-button:before,
.c-button:after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
}

.c-button:before {
	border-right: solid 2px #fff;
	border-top: solid 2px #fff;
	height: 0.5rem;
	left: 1.1rem;
	transform: translateY(-50%) rotate(45deg);
	transition: all 0.3s;
	width: 0.5rem;
	z-index: 2;
}

.c-button:after {
	background: #1c4b90;
	border-radius: 1.5rem;
	height: 3rem;
	left: 0;
	transform: translateY(-50%);
	transition: all 0.5s;
	width: 3rem;
	z-index: 1;
}

.c-button span {
	position: relative;
	transition: all 0.3s;
	z-index: 3;
}

.c-button:hover {
	opacity: 0.8;
}

.c-button.c-button--white {
	background: #fff;
	color: #1c4b90;
}

.c-button--white:after {
	background: #fff;
	border-radius: 1.5rem;
	height: 3rem;
	left: 0;
	transform: translateY(-50%);
	transition: 0.5s;
	width: 3rem;
	z-index: 1;
}

.c-button--white:before {
	border-right: solid 2px #1c4b90;
	border-top: solid 2px #1c4b90;
}

.c-button-circle {
	align-items: center;
	background: #fff;
	border-radius: 50%;
	display: flex;
	height: 3rem;
	justify-content: center;
	position: relative;
	transition: opacity 0.3s;
	width: 3rem;
}

.c-button-circle:before {
	border-right: solid 2px #1c4b90;
	border-top: solid 2px #1c4b90;
	content: "";
	display: block;
	height: 0.5rem;
	left: 1.1rem;
	position: absolute;
	top: 50%;
	transform: translateY(-50%) rotate(45deg);
	transition: opacity 0.3s;
	width: 0.5rem;
	z-index: 2;
}

.c-button-circle:hover {
	opacity: 0.8;
}

/* =========================
   Card
========================= */

.c-card-activities {
	-webkit-text-decoration: none;
	color: inherit;
	display: block;
	filter: saturate(0.84) brightness(0.94);
	height: 100%;
	opacity: 0.5;
	text-decoration: none;
	transform: scale(0.88);
	transition: transform 0.55s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.55s ease, filter 0.55s ease;
}

.c-card-activities__media {
	background-color: #0b1738;
	overflow: hidden;
	position: relative;
	transition: box-shadow 0.45s ease, transform 0.45s ease;
}

.c-card-activities__img {
	-o-object-fit: cover;
	aspect-ratio: 540/330;
	display: block;
	height: 100%;
	object-fit: cover;
	transform: scale(1.08);
	transition: transform 0.8s ease, filter 0.6s ease;
	width: 100%;
}

.c-card-activities__mask {
	background: linear-gradient(to top, rgba(7, 20, 64, 0.98) 0%, rgba(7, 20, 64, 0.8) 28%, rgba(7, 20, 64, 0.5) 55%, rgba(7, 20, 64, 0.08) 88%);
	bottom: 0;
	left: 0;
	opacity: 0.96;
	position: absolute;
	right: 0;
	top: 0;
	transition: opacity 0.45s ease;
}

.c-card-activities__content {
	bottom: 1.25rem;
	color: #fff;
	left: 1.25rem;
	position: absolute;
	right: 1.25rem;
	transform: translateY(0.625rem);
	transition: transform 0.45s ease;
	z-index: 2;
}

.c-card-activities__category {
	-webkit-backdrop-filter: blur(4px);
	backdrop-filter: blur(4px);
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.6);
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 0.625rem;
	padding: 0.375rem 0.625rem;
}

.c-card-activities__title {
	font-family: "Noto Sans JP", sans-serif;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.4;
	margin: 0;
}

/* 前後 */

.p-activities-swiper .swiper-slide-prev .c-card-activities,
.p-activities-swiper .swiper-slide-next .c-card-activities {
	filter: saturate(0.94) brightness(0.98);
	opacity: 0.76;
	transform: scale(0.94);
}

.p-activities-swiper .swiper-slide-prev .c-card-activities__img,
.p-activities-swiper .swiper-slide-next .c-card-activities__img {
	transform: scale(1.04);
}

.p-activities-swiper .swiper-slide-prev .c-card-activities__content,
.p-activities-swiper .swiper-slide-next .c-card-activities__content {
	transform: translateY(0.25rem);
}

/* 中央 */

.p-activities-swiper .swiper-slide-active .c-card-activities {
	filter: saturate(1) brightness(1);
	opacity: 1;
	transform: scale(1) translateY(-0.75rem);
}

.p-activities-swiper .swiper-slide-active .c-card-activities__media {
	box-shadow: 0 1.125rem 2.5rem rgba(0, 0, 0, 0.2), 0 0 1.75rem rgba(64, 134, 255, 0.18);
}

.p-activities-swiper .swiper-slide-active .c-card-activities__img {
	transform: scale(1);
}

.p-activities-swiper .swiper-slide-active .c-card-activities__content {
	transform: translateY(0);
}

/* hover */

.c-card-activities:hover {
	opacity: 1;
}

.c-card-activities:hover .c-card-activities__img {
	transform: scale(1.04);
}

.c-card-activities:hover .c-card-activities__content {
	transform: translateY(0);
}

.p-activities__button {
	align-items: center;
	display: flex;
	justify-content: center;
	margin-top: 1.75rem;
	text-align: center;
}

/* =========================
   SP
========================= */

/* =========================
   PC
========================= */

/* =========================
   Card Activity
========================= */

.c-card-activity {
	background: #fff;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.c-card-activity:hover {
	box-shadow: 0 1rem 1.875rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.25rem);
}

.c-card-activity__link {
	-webkit-text-decoration: none;
	color: inherit;
	display: flex;
	flex-direction: column;
	height: 100%;
	text-decoration: none;
}

.c-card-activity__media {
	overflow: hidden;
	position: relative;
}

.c-card-activity__img {
	-o-object-fit: cover;
	aspect-ratio: 16/10;
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	width: 100%;
}

.c-card-activity:hover .c-card-activity__img {
	transform: scale(1.05);
}

.c-card-activity__mask {
	background: linear-gradient(to top, rgba(7, 20, 64, 0.78) 0%, rgba(7, 20, 64, 0.18) 45%, rgba(7, 20, 64, 0) 100%);
	bottom: 0;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
}

.c-card-activity__category {
	-webkit-backdrop-filter: blur(4px);
	align-items: center;
	backdrop-filter: blur(4px);
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 255, 255, 0.4);
	bottom: 1rem;
	color: #fff;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: 700;
	justify-content: center;
	left: 1rem;
	line-height: 1;
	min-height: 1.875rem;
	padding: 0.375rem 0.75rem;
	position: absolute;
	z-index: 2;
}

.c-card-activity__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 1rem;
}

.c-card-activity__title {
	color: #1c4b90;
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.5;
	margin: 0;
}

.c-card-activity__text {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	color: #333;
	display: -webkit-box;
	font-size: 0.875rem;
	letter-spacing: 0.03em;
	line-height: 1.7;
	margin-bottom: 0;
	margin-top: 0.75rem;
	overflow: hidden;
}

.c-card-activity__footer {
	align-items: center;
	display: flex;
	gap: 0.625rem;
	margin-top: auto;
	padding-top: 1.125rem;
}

.c-card-activity__more {
	color: rgba(28, 75, 144, 0.62);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	line-height: 1;
}

.c-card-activity__arrow {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 1.875rem;
	position: relative;
	width: 1.875rem;
}

.c-card-activity__arrow::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 48%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	width: 0.4375rem;
}

.c-card-media {
	background: #fff;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.c-card-media:hover {
	box-shadow: 0 1rem 1.875rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.25rem);
}

/* --- 動画 / サムネイル --- */

.c-card-media__visual {
	background: #000;
	overflow: hidden;
	position: relative;
}

.c-card-media__embed {
	aspect-ratio: 16/9;
	position: relative;
	width: 100%;
}

.c-card-media__embed iframe {
	border: 0;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.c-card-media__video-file {
	-o-object-fit: contain;
	background: #000;
	display: block;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.c-card-media__thumb-link {
	display: block;
	overflow: hidden;
}

.c-card-media__img {
	-o-object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	width: 100%;
}

.c-card-media__thumb-link:hover .c-card-media__img {
	transform: scale(1.05);
}

/* --- テキストエリア --- */

.c-card-media__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 1rem;
}

.c-card-media__mask {
	background: linear-gradient(to top, rgba(7, 20, 64, 0.78) 0%, rgba(7, 20, 64, 0.18) 45%, rgba(7, 20, 64, 0) 100%);
	bottom: 0;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
}

.c-card-media__category {
	background: linear-gradient(to top, rgba(7, 20, 64, 0.98) 0%, rgba(7, 20, 64, 0.8) 28%, rgba(7, 20, 64, 0.5) 55%, rgba(7, 20, 64, 0.08) 88%);
	bottom: 0;
	left: 0;
	opacity: 0.96;
	position: absolute;
	right: 0;
	top: 0;
	transition: opacity 0.45s ease;
}

.c-card-media__title {
	color: #1c4b90;
	font-size: 1.0625rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.55;
	margin: 0;
}

.c-card-media__title-link {
	-webkit-text-decoration: none;
	color: inherit;
	text-decoration: none;
	transition: opacity 0.25s ease;
}

.c-card-media__title-link:hover {
	opacity: 0.7;
}

/* --- READ MORE --- */

.c-card-media__more {
	-webkit-text-decoration: none;
	align-items: center;
	color: rgba(28, 75, 144, 0.62);
	display: inline-flex;
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	gap: 0.625rem;
	letter-spacing: 0.14em;
	line-height: 1;
	margin-top: auto;
	padding-top: 1rem;
	text-decoration: none;
}

.c-card-media__arrow {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 1.875rem;
	position: relative;
	width: 1.875rem;
}

.c-card-media__arrow::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 48%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	width: 0.4375rem;
}

.c-card-media__play {
	background: rgba(255, 255, 255, 0.9);
	border-radius: 50%;
	height: 64px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 64px;
	z-index: 3;
}

.c-card-media__play::before {
	border-color: transparent transparent transparent #333;
	border-style: solid;
	border-width: 12px 0 12px 18px;
	content: "";
	height: 0;
	left: 53%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 0;
}

.c-card-movie {
	background: #fff;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
	height: 100%;
	overflow: hidden;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.c-card-movie:hover {
	box-shadow: 0 1rem 1.875rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.25rem);
}

/* --- 動画 / サムネイル --- */

.c-card-movie__visual {
	background: #000;
	overflow: hidden;
	position: relative;
}

.c-card-movie__embed {
	aspect-ratio: 16/9;
	position: relative;
	width: 100%;
}

.c-card-movie__embed iframe {
	border: 0;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.c-card-movie__video-file {
	-o-object-fit: contain;
	background: #000;
	display: block;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.c-card-movie__thumb-link {
	display: block;
	overflow: hidden;
}

.c-card-movie__img {
	-o-object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 0.5s ease;
	width: 100%;
}

.c-card-movie__thumb-link:hover .c-card-movie__img {
	transform: scale(1.05);
}

/* --- テキストエリア --- */

.c-card-movie__body {
	display: flex;
	flex: 1;
	flex-direction: column;
	padding: 1rem;
}

.c-card-movie__mask {
	background: linear-gradient(to top, rgba(7, 20, 64, 0.78) 0%, rgba(7, 20, 64, 0.18) 45%, rgba(7, 20, 64, 0) 100%);
	bottom: 0;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
}

.c-card-movie__category {
	-webkit-backdrop-filter: blur(4px);
	align-items: center;
	backdrop-filter: blur(4px);
	background: rgba(255, 255, 255, 0.14);
	border: 1px solid rgba(255, 255, 255, 0.4);
	bottom: 1rem;
	color: #fff;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: 700;
	justify-content: center;
	left: 1rem;
	line-height: 1;
	min-height: 1.875rem;
	padding: 0.375rem 0.75rem;
	position: absolute;
	z-index: 2;
}

.c-card-movie__title {
	color: #1c4b90;
	font-size: 1.0625rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.55;
	margin: 0;
}

.c-card-movie__title-link {
	-webkit-text-decoration: none;
	color: inherit;
	text-decoration: none;
	transition: opacity 0.25s ease;
}

.c-card-movie__title-link:hover {
	opacity: 0.7;
}

/* --- READ MORE --- */

.c-card-movie__more {
	-webkit-text-decoration: none;
	align-items: center;
	color: rgba(28, 75, 144, 0.62);
	display: inline-flex;
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	gap: 0.625rem;
	letter-spacing: 0.14em;
	line-height: 1;
	margin-top: auto;
	padding-top: 1rem;
	text-decoration: none;
}

.c-card-movie__arrow {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 1.875rem;
	position: relative;
	width: 1.875rem;
}

.c-card-movie__arrow::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 48%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%) rotate(45deg);
	width: 0.4375rem;
}

.c-card-movie__media {
	overflow: hidden;
	position: relative;
}

.c-card-movie__play {
	background: rgba(255, 255, 255, 0.9);
	border-radius: 50%;
	height: 64px;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 64px;
	z-index: 3;
}

.c-card-movie__play::before {
	border-color: transparent transparent transparent #333;
	border-style: solid;
	border-width: 12px 0 12px 18px;
	content: "";
	height: 0;
	left: 53%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 0;
}

.c-card-movie__media img {
	-o-object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.c-contact-confirm {
	width: 100%;
}

.c-contact-confirm__item {
	grid-gap: 0.5rem;
	border-bottom: 1px solid #e5e7eb;
	display: grid;
	gap: 0.5rem;
	padding: 1.25rem 0;
}

.c-contact-confirm__label {
	color: #0d1036;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.6;
}

.c-contact-confirm__value {
	color: #0d1036;
	font-size: 1rem;
	line-height: 1.9;
	white-space: pre-wrap;
	word-break: break-word;
}

.c-contact-confirm__actions {
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
	margin-top: 2rem;
}

.c-contact-confirm__back-btn,
.c-contact-confirm__submit-btn {
	cursor: pointer;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1;
	min-height: 3.5rem;
	min-width: 12.5rem;
	padding: 0.875rem 1.75rem;
	transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.c-contact-confirm__back-btn {
	background: #fff;
	border: 1px solid #1c4b90;
	color: #1c4b90;
}

.c-contact-confirm__submit-btn {
	background: linear-gradient(135deg, #1c4b90 0%, #173c73 100%);
	border: 0;
	box-shadow: 0 0.875rem 1.625rem rgba(28, 75, 144, 0.16);
	color: #fff;
}

.c-contact-confirm__back-btn:hover,
.c-contact-confirm__submit-btn:hover {
	transform: translateY(-0.125rem);
}

.c-contact-confirm__submit-btn:hover {
	box-shadow: 0 1.125rem 2rem rgba(28, 75, 144, 0.2);
}

.c-contact-confirm {
	width: 100%;
}

.c-contact-confirm__item {
	grid-gap: 0.5rem;
	border-bottom: 1px solid #e5e7eb;
	display: grid;
	gap: 0.5rem;
	padding: 1.25rem 0;
}

.c-contact-confirm__label {
	color: #0d1036;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.6;
}

.c-contact-confirm__value {
	color: #0d1036;
	font-size: 1rem;
	line-height: 1.9;
	white-space: pre-wrap;
	word-break: break-word;
}

.c-contact-confirm__actions {
	display: flex;
	flex-direction: column;
	gap: 0.875rem;
	margin-top: 2rem;
}

.c-contact-confirm__back-btn,
.c-contact-confirm__submit-btn {
	cursor: pointer;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1;
	min-height: 3.5rem;
	min-width: 12.5rem;
	padding: 0.875rem 1.75rem;
	transition: transform 0.25s ease, box-shadow 0.25s ease, background-color 0.25s ease, color 0.25s ease;
}

.c-contact-confirm__back-btn {
	background: #fff;
	border: 1px solid #1c4b90;
	color: #1c4b90;
}

.c-contact-confirm__submit-btn {
	background: linear-gradient(135deg, #1c4b90 0%, #173c73 100%);
	border: 0;
	box-shadow: 0 0.875rem 1.625rem rgba(28, 75, 144, 0.16);
	color: #fff;
}

.c-contact-confirm__back-btn:hover,
.c-contact-confirm__submit-btn:hover {
	transform: translateY(-0.125rem);
}

.c-contact-confirm__submit-btn:hover {
	box-shadow: 0 1.125rem 2rem rgba(28, 75, 144, 0.2);
}

.c-contact-form-line__row {
	grid-gap: 1.25rem;
	align-items: center;
	border-bottom: 1px solid #e5e7eb;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 8.75rem 3.75rem 1fr;
	padding: 1.125rem 0;
}

.c-contact-form-line__row--top {
	align-items: flex-start;
}

.c-contact-form-line__label {
	color: #1f2937;
	font-size: 0.9375rem;
	font-weight: 700;
}

.c-contact-form-line__required {
	align-items: center;
	background: #dc2626;
	border-radius: 62.4375rem;
	color: #fff;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: 700;
	justify-content: center;
	min-height: 1.5rem;
	padding: 0 0.625rem;
	width: 3.125rem;
}

.c-contact-form-line__field {
	min-width: 0;
}

.c-contact-form-line__input,
.c-contact-form-line__textarea {
	background: #fff;
	border: 1px solid #d9e1ea;
	border-radius: 0.625rem;
	font-size: 1rem;
	padding: 0.875rem;
	width: 100%;
}

.c-contact-form-line__input {
	height: 3.5rem;
}

.c-contact-form-line__textarea {
	min-height: 11.25rem;
	resize: vertical;
}

.c-contact-form-line__input:focus,
.c-contact-form-line__textarea:focus {
	border-color: #1c4b90;
	box-shadow: 0 0 0 0.25rem rgba(28, 75, 144, 0.08);
	outline: none;
}

.c-contact-form-line__check {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem 1.25rem;
}

.c-contact-form-line__check .wpcf7-list-item {
	margin: 0;
}

.c-contact-form-line__check .wpcf7-list-item label {
	align-items: center;
	color: #334155;
	cursor: pointer;
	display: inline-flex;
	font-size: 0.875rem;
	gap: 0.5rem;
}

.c-contact-form-line__check input[type=checkbox] {
	accent-color: #1c4b90;
	cursor: pointer;
	display: block;
	flex-shrink: 0;
	height: 1.125rem;
	margin: 0;
	width: 1.125rem;
}

.c-contact-form-line__check input[type=checkbox] + span::before,
.c-contact-form-line__check input[type=checkbox] + span::after {
	display: none;
}

.c-contact-form-line__row--agree {
	border-bottom: 1px solid #e5e7eb;
	display: block;
	padding: 1.5rem 0;
}

.c-contact-form-line__row--agree .c-contact-form-line__field {
	width: 100%;
}

.c-contact-form-line__agree {
	align-items: center;
	color: #334155;
	display: flex;
	font-size: 0.875rem;
	justify-content: center;
	line-height: 1.8;
	text-align: center;
}

.c-contact-form-line__agree .wpcf7-form-control-wrap {
	display: block;
}

.c-contact-form-line__agree .wpcf7-acceptance {
	display: block;
}

.c-contact-form-line__agree .wpcf7-list-item {
	display: block;
	margin: 0;
}

.c-contact-form-line__agree .wpcf7-list-item label {
	align-items: center;
	cursor: pointer;
	display: inline-flex;
	gap: 0.625rem;
}

.c-contact-form-line__agree .wpcf7-list-item-label {
	color: #334155;
	font-size: 0.875rem;
	line-height: 1.8;
	text-align: left;
}

.c-contact-form-line__agree input[type=checkbox],
input.c-contact-form-line__agree-input,
.c-contact-form-line__field input[type=checkbox],
.wpcf7-acceptance input[type=checkbox] {
	-webkit-appearance: auto;
	-moz-appearance: auto;
	accent-color: #1c4b90;
	appearance: auto;
	cursor: pointer;
	display: block;
	flex-shrink: 0;
	height: 1.125rem;
	margin: 0;
	width: 1.125rem;
}

.c-contact-form-line__agree input[type=checkbox] + span::before,
.c-contact-form-line__agree input[type=checkbox] + span::after,
.wpcf7-acceptance input[type=checkbox] + span::before,
.wpcf7-acceptance input[type=checkbox] + span::after {
	display: none;
}

.c-contact-form-line__submit {
	display: flex;
	justify-content: center;
	margin-top: 2.5rem;
}

.c-contact-form-line__btn {
	align-items: center;
	background: linear-gradient(135deg, #1c4b90, #2f6bc5);
	border: none;
	border-radius: 62.4375rem;
	color: #fff;
	cursor: pointer;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 700;
	height: 3.5rem;
	justify-content: center;
	letter-spacing: 0.08em;
	min-width: 13.75rem;
	padding: 0 2.25rem;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.c-contact-form-line__btn:hover {
	box-shadow: 0 0.75rem 1.5rem rgba(0, 0, 0, 0.15);
	transform: translateY(-0.125rem);
}

.c-contact-form-line .wpcf7-list-item {
	margin-left: 0;
}

.c-contact-form-line__submit .wpcf7-spinner {
	position: absolute;
}

.c-geometric-bg {
	position: relative;
	z-index: 0;
}

.c-geometric-bg::after {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	bottom: 0;
	content: "";
	height: 100%;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 0;
}

.c-geometric-bg--service01::after {
	background-image: url("../images/common/service_bg01.png");
}

.c-geometric-bg--service02::after {
	background-image: url("../images/common/service_bg02.png");
}

.c-geometric-bg--service03::after {
	background-image: url("../images/common/service_bg03.png");
}

.c-geometric-bg--service04::after {
	background-image: url("../images/common/service_bg04.png");
}

.c-geometric-bg--service05::after {
	background-image: url("../images/common/service_bg03.png");
}

.c-hamburger {
	height: 1.875rem;
	position: relative;
	width: 1.875rem;
	z-index: 100;
}

.c-hamburger span {
	background-color: #fff;
	height: 0.125rem;
	position: absolute;
	transition: 0.3s;
	width: inherit;
}

.c-hamburger span:nth-child(1) {
	top: 15%;
}

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

.c-hamburger span:nth-child(3) {
	top: 85%;
}

.c-hamburger.is-active span:nth-child(1) {
	top: 60%;
	transform: rotate(45deg);
}

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

.c-hamburger.is-active span:nth-child(3) {
	top: 60%;
	transform: rotate(-45deg);
}

.c-page-link {
	color: #391E88;
	margin-top: 2.5rem;
}

.c-page-link__flex {
	align-items: center;
	border-bottom: 1px solid #B8AED5;
	border-top: 1px solid #B8AED5;
	display: flex;
	padding: 0.9375rem 0;
}

.c-page-link__prev,
.c-page-link__next {
	font-size: 0.75rem;
	line-height: 1.5714285714;
	padding: 0 1.25rem;
	position: relative;
	width: 50%;
}

.c-page-link__prev {
	margin-right: auto;
}

.c-page-link__prev::after {
	background-color: #B8AED5;
	bottom: 0;
	content: "";
	height: 100%;
	position: absolute;
	right: 0;
	top: 0;
	width: 1px;
}

.c-page-link__next {
	margin-left: auto;
}

.c-page-link__archive {
	font-size: 0.875rem;
	margin-top: 1.25rem;
	text-align: center;
}

.c-scroll-down {
	bottom: 0;
	color: #fff;
	font-family: "Poppins", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1;
	padding-bottom: 5rem;
	position: relative;
	position: absolute;
	right: 1%;
	text-align: center;
	text-transform: uppercase;
	writing-mode: vertical-rl;
	z-index: 100;
}

.c-scroll-down::after {
	animation: scroll-down 2s infinite;
	background: #fff;
	bottom: 0;
	content: "";
	height: 4.375rem;
	left: 50%;
	position: absolute;
	width: 1px;
}

.c-section-header {
	color: #1c4b90;
	text-align: left;
}

.c-section-header__engtitle {
	font-family: "Poppins", sans-serif;
	font-size: max(2.625rem, min(6vw, 4.375rem));
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 0.95;
	margin: 0;
	opacity: 0;
	position: relative;
	text-transform: uppercase;
	transform: translateY(1.5rem);
	transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
	z-index: 2;
}

.c-section-header__engtitle--white {
	color: #fff;
}

.c-section-header__jatitle {
	display: inline-block;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1;
	margin-bottom: 0;
	margin-top: 0.5rem;
	opacity: 0;
	padding-bottom: 0.875rem;
	position: relative;
	transform: translateY(1.125rem);
	transition: opacity 0.8s ease 0.14s, transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.14s;
	z-index: 2;
}

.c-section-header__jatitle::after {
	background: linear-gradient(90deg, rgba(64, 134, 255, 0.9) 0%, rgba(64, 134, 255, 0.2) 100%);
	bottom: 0;
	content: "";
	height: 0.125rem;
	left: 0;
	position: absolute;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1) 0.28s;
	width: 5.625rem;
}

.c-section-header__jatitle--beige {
	color: #dcd4a2;
}

.c-section-header__subpage {
	font-size: 1.5rem;
	font-weight: bold;
	line-height: 1.5;
}

.c-section-header--center {
	text-align: center;
}

.c-section-header--white {
	color: #fff;
}

/* ===============================
   背景英字
=============================== */

.c-section-header--bg {
	isolation: isolate;
	position: relative;
}

.c-section-header--bg::before {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(7, 20, 64, 0.035);
	content: attr(data-bg);
	filter: blur(0.375rem);
	font-family: "Poppins", sans-serif;
	font-size: 3.125rem;
	font-weight: 800;
	left: 0.5rem;
	letter-spacing: 0.03em;
	line-height: 0.9;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: -20%;
	transition: opacity 1s ease 0.06s, filter 1s ease 0.06s;
	user-select: none;
	white-space: nowrap;
	z-index: 1;
}

.c-section-header--bg-center::before {
	left: 50%;
	transform: translateX(-50%);
}

/* ===============================
   inview後
=============================== */

.js-section-header.is-inview .c-section-header__engtitle {
	opacity: 1;
	transform: translateY(0);
}

.js-section-header.is-inview .c-section-header__jatitle {
	opacity: 1;
	transform: translateY(0);
}

.js-section-header.is-inview .c-section-header__jatitle::after {
	transform: scaleX(1);
}

.js-section-header.is-inview.c-section-header--bg::before {
	filter: blur(0);
	opacity: 1;
}

.c-to-top {
	border: 1px solid;
	border-radius: 50%;
	bottom: 6.25rem;
	overflow: hidden;
	position: fixed;
	right: 0.625rem;
	z-index: 999;
}

.c-to-top a {
	background-color: #fff;
	display: block;
	height: 3.125rem;
	position: relative;
	width: 3.125rem;
}

.c-to-top a span {
	background-color: transparent;
	border-right: 2px solid;
	border-top: 2px solid;
	height: 1.25rem;
	left: 50%;
	position: absolute;
	top: 50%;
	transform: translate(-50%, calc(-50% + 0.25em)) rotate(-45deg);
	width: 1.25rem;
}

/* =========================
   ABOUT ACTION
========================= */

.p-about-action {
	background: linear-gradient(180deg, #fbfcfd 0%, #fff 48%, #f8fafc 100%);
	overflow: hidden;
	padding: 4.5rem 0 5.5rem;
	position: relative;
}

.p-about-action::before {
	background: linear-gradient(90deg, rgba(28, 75, 144, 0) 0%, rgba(28, 75, 144, 0.12) 22%, rgba(28, 75, 144, 0.12) 78%, rgba(28, 75, 144, 0) 100%);
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	top: 0;
	transform: translateX(-50%);
	width: 100vw;
}

.p-about-action__inner {
	position: relative;
}

.p-about-action__head {
	margin-bottom: 3rem;
	position: relative;
	z-index: 2;
}

.p-about-action__heading-block {
	position: relative;
}

.p-about-action__sub {
	color: rgba(28, 75, 144, 0.64);
	font-family: "Poppins", sans-serif;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.28em;
	line-height: 1;
	margin: 0;
	position: relative;
	z-index: 2;
}

.p-about-action__title {
	color: #1c4b90;
	font-size: max(2.125rem, min(9vw, 4.75rem));
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.08;
	margin: 0.875rem 0 0;
	position: relative;
	z-index: 2;
}

.p-about-action__heading-block::after {
	background: linear-gradient(90deg, rgba(28, 75, 144, 0.82) 0%, rgba(28, 75, 144, 0.1) 100%);
	content: "";
	display: block;
	height: 1px;
	margin-top: 1.375rem;
	width: 6.75rem;
}

.p-about-action__lead {
	color: #475569;
	font-size: 1rem;
	letter-spacing: 0.04em;
	line-height: 2;
	margin: 1.375rem 0 0;
	position: relative;
	z-index: 2;
}

.p-about-action__bg-text {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(28, 75, 144, 0.03);
	font-family: "Poppins", sans-serif;
	font-size: max(3.875rem, min(19vw, 14.375rem));
	font-weight: 800;
	left: 0;
	letter-spacing: 0.04em;
	line-height: 0.9;
	margin: 0;
	pointer-events: none;
	position: absolute;
	top: -0.5rem;
	user-select: none;
	white-space: nowrap;
	z-index: 1;
}

.p-about-action__body {
	position: relative;
	z-index: 2;
}

.p-about-action__list {
	grid-gap: 2.375rem;
	display: grid;
	gap: 2.375rem;
	position: relative;
}

.p-about-action__list::before {
	content: none;
}

.p-about-action__line {
	bottom: 1.125rem;
	left: 1.25rem;
	pointer-events: none;
	position: absolute;
	top: 1rem;
	width: 1px;
}

.p-about-action__line-base,
.p-about-action__line-progress {
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 1px;
}

.p-about-action__line-base {
	background: linear-gradient(180deg, rgba(28, 75, 144, 0.12) 0%, rgba(28, 75, 144, 0.03) 100%);
}

.p-about-action__line-progress {
	background: linear-gradient(180deg, rgba(76, 169, 240, 0.95) 0%, rgba(124, 58, 237, 0.72) 55%, rgba(28, 75, 144, 0.28) 100%);
	box-shadow: 0 0 0.875rem rgba(76, 169, 240, 0.22);
	transform: scaleY(1);
	transform-origin: top center;
}

.p-about-action-card {
	padding-left: 2.875rem;
	position: relative;
}

.p-about-action-card::before {
	background: linear-gradient(135deg, rgba(76, 169, 240, 0.92) 0%, rgba(124, 58, 237, 0.78) 100%);
	border-radius: 50%;
	box-shadow: 0 0 0 0.4375rem rgba(76, 169, 240, 0.05), 0 0 1.125rem rgba(76, 169, 240, 0.12);
	content: "";
	height: 0.75rem;
	left: 0.875rem;
	position: absolute;
	top: 0.875rem;
	transition: transform 0.45s ease, box-shadow 0.45s ease, filter 0.45s ease, opacity 0.45s ease;
	width: 0.75rem;
}

.p-about-action-card__num {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(28, 75, 144, 0.07);
	font-family: "Poppins", sans-serif;
	font-size: 3.25rem;
	font-weight: 700;
	left: 0rem;
	letter-spacing: 0.01em;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	top: -0.625rem;
	transform-origin: left center;
	transition: transform 0.45s ease, color 0.45s ease, opacity 0.45s ease, text-shadow 0.45s ease;
	user-select: none;
	z-index: 1;
}

.p-about-action-card__content {
	padding-left: 0.375rem;
	position: relative;
	transition: transform 0.45s ease, opacity 0.45s ease, background-color 0.45s ease;
	z-index: 2;
}

.p-about-action-card__content::before {
	background: linear-gradient(180deg, rgba(28, 75, 144, 0.12) 0%, rgba(28, 75, 144, 0.03) 100%);
	content: "";
	height: 100%;
	left: -0.375rem;
	position: absolute;
	top: 0;
	width: 1px;
}

.p-about-action-card__content::after {
	background: linear-gradient(90deg, rgba(76, 169, 240, 0.07) 0%, rgba(76, 169, 240, 0.025) 48%, rgba(76, 169, 240, 0) 100%);
	border-radius: 0.75rem;
	bottom: -0.375rem;
	content: "";
	left: -0.625rem;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: -0.5rem;
	top: -0.375rem;
	transform: translateX(-0.5rem);
	transition: opacity 0.45s ease, transform 0.45s ease;
	z-index: -1;
}

.p-about-action-card__title {
	color: rgba(28, 75, 144, 0.7);
	font-size: max(1.25rem, min(5.4vw, 2.125rem));
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.65;
	margin: 0;
	transition: color 0.45s ease, transform 0.45s ease, text-shadow 0.45s ease, opacity 0.45s ease;
}

.p-about-action-card__text {
	color: rgba(51, 65, 85, 0.76);
	font-size: 0.875rem;
	letter-spacing: 0.03em;
	line-height: 2;
	margin: 0.75rem 0 0;
	max-width: 40rem;
	transition: transform 0.45s ease, color 0.45s ease, opacity 0.45s ease;
}

/* 通常時に少し抑える */

.p-about-action-card:not(.is-active) .p-about-action-card__title {
	color: rgba(28, 75, 144, 0.72);
}

.p-about-action-card:not(.is-active) .p-about-action-card__text {
	color: rgba(51, 65, 85, 0.82);
}

/* アクティブ時 */

.p-about-action-card.is-active::before {
	box-shadow: 0 0 0 0.625rem rgba(76, 169, 240, 0.08), 0 0 1.5rem rgba(76, 169, 240, 0.24);
	filter: saturate(1.15);
	transform: scale(1.22);
}

.p-about-action-card.is-active .p-about-action-card__num {
	color: rgba(28, 75, 144, 0.14);
	text-shadow: 0 0 0.75rem rgba(76, 169, 240, 0.1);
	transform: translateY(-0.375rem) scale(1.04);
}

.p-about-action-card.is-active .p-about-action-card__content {
	transform: translateY(-0.125rem);
}

.p-about-action-card.is-active .p-about-action-card__content::after {
	opacity: 1;
	transform: translateX(0);
}

.p-about-action-card.is-active .p-about-action-card__title {
	color: #1c4b90;
	text-shadow: 0 0 0.0625rem rgba(28, 75, 144, 0.12);
	transform: translateY(-0.0625rem);
}

.p-about-action-card.is-active .p-about-action-card__text {
	color: #334155;
	transform: translateY(-0.0625rem);
}

/* 非アクティブ時を少し静かにする */

.p-about-action-card:not(.is-active) .p-about-action-card__title {
	color: rgba(28, 75, 144, 0.68);
}

.p-about-action-card:not(.is-active) .p-about-action-card__text {
	color: rgba(51, 65, 85, 0.74);
}

/* アクティブ時の説明文の反応 */

.p-about-action-card.is-active .p-about-action-card__content {
	transform: translateY(-0.125rem);
}

.p-about-action-card.is-active .p-about-action-card__content::after {
	opacity: 1;
	transform: translateX(0);
}

.p-about-action-card.is-active .p-about-action-card__title {
	color: #1c4b90;
	text-shadow: 0 0 0.0625rem rgba(28, 75, 144, 0.08);
	transform: translateY(-0.0625rem);
}

.p-about-action-card.is-active .p-about-action-card__text {
	color: rgba(51, 65, 85, 0.96);
	transform: translateY(-0.0625rem);
}

/* SP */

/* =========================
   VISUAL
========================= */

.p-about-action__visual {
	margin-top: 3.5rem;
	padding-bottom: 1.5rem;
	position: relative;
}

.p-about-action__shape {
	pointer-events: none;
	position: absolute;
	will-change: transform, opacity;
}

/* 背面の菱形 */

.p-about-action__shape--back {
	-webkit-clip-path: polygon(14% 0, 100% 0, 86% 100%, 0 100%);
	aspect-ratio: 1.9/1;
	background: linear-gradient(135deg, rgba(143, 131, 29, 0.92) 0%, rgba(163, 149, 45, 0.88) 100%);
	bottom: 0;
	clip-path: polygon(14% 0, 100% 0, 86% 100%, 0 100%);
	left: 1.25rem;
	width: 76%;
	z-index: 1;
}

/* 前面の淡い光 */

.p-about-action__shape--front {
	background: radial-gradient(circle, rgba(76, 169, 240, 0.18) 0%, rgba(76, 169, 240, 0) 72%);
	border-radius: 50%;
	height: 5.25rem;
	right: 0.5rem;
	top: -1.125rem;
	width: 5.25rem;
	z-index: 3;
}

/* 画像の菱形 */

.p-about-action__image-wrap {
	-webkit-clip-path: polygon(14% 0, 100% 0, 86% 100%, 0 100%);
	aspect-ratio: 1.9/1;
	box-shadow: 0 1.5rem 3rem rgba(15, 23, 42, 0.08), 0 0.5rem 1.125rem rgba(15, 23, 42, 0.05);
	clip-path: polygon(14% 0, 100% 0, 86% 100%, 0 100%);
	margin-left: auto;
	overflow: hidden;
	position: relative;
	width: 76%;
	z-index: 2;
}

.p-about-action__image-wrap::after {
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.02) 0%, rgba(15, 23, 42, 0.08) 100%);
	bottom: 0;
	content: "";
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
}

.p-about-action__image-wrap::before {
	background: linear-gradient(110deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.18) 48%, rgba(255, 255, 255, 0) 100%);
	content: "";
	height: 100%;
	left: -120%;
	pointer-events: none;
	position: absolute;
	top: 0;
	transform: skewX(-18deg);
	width: 50%;
	z-index: 3;
}

.p-about-action__image-wrap.is-shining::before {
	animation: actionShine 0.7s ease forwards;
}

.p-about-action__image {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* SP */

/* =========================
   HERO
========================= */

.p-about-hero {
	background: #000;
	color: #fff;
	min-height: 13.75rem;
	overflow: hidden;
	position: relative;
}

.p-about-hero__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-about-hero__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: brightness(0.62) contrast(1.06);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-about-hero__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.46) 45%, rgba(0, 0, 0, 0.74) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.14) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-about-hero__glow {
	background: radial-gradient(circle at 55% 34%, rgba(120, 180, 255, 0.18) 0%, rgba(120, 180, 255, 0.08) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-about-hero__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.58) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.375rem;
	height: 0.0625rem;
	opacity: 0.68;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-about-hero__grid {
	background-image: linear-gradient(rgba(255, 255, 255, 0.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px);
	background-size: 1.75rem 1.75rem;
	bottom: 0;
	left: 0;
	opacity: 0.08;
	position: absolute;
	right: 0;
	top: 0;
}

.p-about-hero__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 13.75rem;
	padding-bottom: 1.75rem;
	padding-top: 6.875rem;
	position: relative;
	z-index: 1;
}

.p-about-hero__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-about-hero__title {
	font-size: max(1.875rem, min(7vw, 3.5rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.75rem;
	position: relative;
	z-index: 2;
}

.p-about-hero__bg-text {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(255, 255, 255, 0.06);
	font-family: "Poppins", sans-serif;
	font-size: max(4rem, min(20vw, 15rem));
	font-weight: 800;
	left: 0;
	letter-spacing: 0.04em;
	line-height: 0.9;
	margin: 0;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-40%);
	user-select: none;
	white-space: nowrap;
	z-index: 1;
}

/* =========================
   ABOUT MVV
========================= */

.p-about-mvv {
	isolation: isolate;
	overflow: hidden;
	padding: 5rem 0;
	position: relative;
}

.p-about-mvv__inner {
	position: relative;
	z-index: 2;
}

.js-about-mvv-pin {
	backface-visibility: hidden;
	background: #fff;
	position: relative;
	transform: translateZ(0);
	z-index: 3;
}

.p-about-mvv__head {
	background: #fff;
	margin-bottom: 1.5rem;
	padding-bottom: 1.125rem;
	position: relative;
	z-index: 30;
}

.p-about-mvv__head::after {
	background: linear-gradient(90deg, rgba(28, 75, 144, 0.95) 0%, rgba(28, 75, 144, 0.12) 100%);
	bottom: 0;
	content: "";
	height: 1px;
	left: 0;
	position: absolute;
	width: 6rem;
}

.p-about-mvv__sub {
	color: rgba(28, 75, 144, 0.62);
	font-family: "Poppins", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	line-height: 1;
	margin: 0;
	position: relative;
	z-index: 2;
}

.p-about-mvv__heading {
	color: #1c4b90;
	font-size: max(1.625rem, min(6.6vw, 2.5rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.35;
	margin: 0.625rem 0 0;
	position: relative;
	z-index: 2;
}

.p-about-mvv__bg-text {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(28, 75, 144, 0.04);
	font-family: "Poppins", sans-serif;
	font-size: max(1.625rem, min(9vw, 7.5rem));
	font-weight: 800;
	left: 0;
	letter-spacing: 0.05em;
	line-height: 1;
	margin: 0;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	user-select: none;
	white-space: nowrap;
	z-index: 1;
}

.p-about-mvv__stage {
	grid-gap: 1.25rem;
	background: #fff;
	display: grid;
	gap: 1.25rem;
	position: relative;
	z-index: 10;
}

.p-about-mvv__left,
.p-about-mvv__right {
	position: relative;
	z-index: 2;
}

.p-about-mvv__left {
	min-height: 16.875rem;
	order: 2;
}

.p-about-mvv__right {
	align-items: center;
	display: flex;
	justify-content: center;
	min-height: 18.75rem;
	order: 1;
	width: 100%;
}

.p-about-mvv__right::before {
	background: radial-gradient(circle at center, rgba(28, 75, 144, 0.08) 0%, rgba(28, 75, 144, 0.03) 38%, rgba(28, 75, 144, 0) 68%);
	border-radius: 50%;
	bottom: 8%;
	content: "";
	filter: blur(1rem);
	left: 6%;
	pointer-events: none;
	position: absolute;
	right: 6%;
	top: 10%;
	z-index: 0;
}

.p-about-mvv__panels {
	min-height: 16.875rem;
	position: relative;
}

.p-about-mvv__panel {
	align-items: flex-start;
	bottom: 0;
	display: flex;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-about-mvv__panel-inner {
	background: #fff;
	border: 0;
	box-shadow: none;
	max-width: 100%;
	padding: 1.125rem 0 1.125rem 1.25rem;
	position: relative;
	width: 100%;
	will-change: transform, opacity, filter;
}

.p-about-mvv__panel-inner::before {
	background: linear-gradient(180deg, #1c4b90 0%, rgba(28, 75, 144, 0.18) 100%);
	content: "";
	height: 3.25rem;
	left: 0;
	opacity: 0.35;
	position: absolute;
	top: 0.375rem;
	transition: opacity 0.4s ease, height 0.4s ease, transform 0.4s ease;
	width: 0.125rem;
}

.p-about-mvv__panel-inner::after {
	background: radial-gradient(circle, rgba(28, 75, 144, 0.07) 0%, rgba(28, 75, 144, 0.03) 42%, rgba(28, 75, 144, 0) 74%);
	content: "";
	height: 6.875rem;
	left: -0.5rem;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: -0.5rem;
	transition: opacity 0.4s ease;
	width: 6.875rem;
}

.p-about-mvv__panel-inner.is-active::before {
	height: 4.25rem;
	opacity: 1;
	transform: translateY(0.0625rem);
}

.p-about-mvv__panel-inner.is-active::after {
	opacity: 1;
}

.p-about-mvv__label {
	color: rgba(28, 75, 144, 0.42);
	font-family: "Poppins", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.28em;
	line-height: 1;
	margin: 0;
	transition: color 0.35s ease, transform 0.35s ease;
}

.p-about-mvv__panel-inner.is-active .p-about-mvv__label {
	color: rgba(28, 75, 144, 0.9);
	transform: translateX(0.125rem);
}

.p-about-mvv__title {
	color: #1c4b90;
	font-size: max(1.125rem, min(6.8vw, 1.75rem));
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.45;
	margin: 0.75rem 0 0;
}

.p-about-mvv__panel-inner.is-active .p-about-mvv__title {
	text-shadow: 0 0 0.0625rem rgba(28, 75, 144, 0.08);
}

.p-about-mvv__text {
	color: #2e3440;
	font-size: 0.9375rem;
	letter-spacing: 0.02em;
	line-height: 1.85;
	margin: 0.875rem 0 0;
	max-width: 100%;
}

.p-about-mvv__visual {
	margin-left: auto;
	margin-right: auto;
	max-width: 19rem;
	position: relative;
	width: 100%;
}

.p-about-mvv__svg {
	display: block;
	height: auto;
	margin-left: auto;
	margin-right: auto;
	max-width: 100%;
	overflow: visible;
	position: relative;
	transform-origin: center center;
	width: 100%;
	z-index: 1;
}

.p-about-mvv__blend-group {
	isolation: isolate;
}

.p-about-mvv__circle-group {
	transform-origin: center;
}

.p-about-mvv__circle-line {
	fill: none;
	stroke-width: 1.5;
}

.p-about-mvv__circle-line--blue {
	stroke: #3fb8ff;
}

.p-about-mvv__circle-line--orange {
	stroke: #f9731f;
}

.p-about-mvv__circle-line--green {
	stroke: #06ba50;
}

.p-about-mvv__circle-fill {
	mix-blend-mode: multiply;
	opacity: 0.92;
}

.p-about-mvv__circle-fill--blue {
	fill: #3fb8ff;
}

.p-about-mvv__circle-fill--orange {
	fill: #f9731f;
}

.p-about-mvv__circle-fill--green {
	fill: #06ba50;
}

.p-about-mvv__overlay-text {
	-webkit-font-smoothing: antialiased;
	color: #fff;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.5;
	margin: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	text-align: center;
	transform: translate(-50%, -50%);
	will-change: transform, opacity;
	z-index: 2;
}

.p-about-mvv__overlay-text--blue {
	font-size: 0.9375rem;
	left: 50%;
	top: 27.5%;
	width: 55%;
}

.p-about-mvv__overlay-text--orange {
	font-size: 0.9375rem;
	left: 30.6%;
	top: 64.5%;
	width: 44%;
}

.p-about-mvv__overlay-text--green {
	font-size: 0.9375rem;
	left: 69.4%;
	top: 63%;
	width: 34%;
}

/* =========================
   SP TAB NAV (md未満のみ表示)
========================= */

.p-about-mvv__tabs {
	display: flex;
	gap: 0.375rem;
	margin-bottom: 1.25rem;
}

.p-about-mvv__tab {
	-webkit-tap-highlight-color: transparent;
	background: transparent;
	border: 1px solid rgba(28, 75, 144, 0.25);
	border-radius: 0.25rem;
	color: rgba(28, 75, 144, 0.45);
	cursor: pointer;
	flex: 1;
	font-family: "Poppins", sans-serif;
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	padding: 0.625rem 0.125rem;
	transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}

.p-about-mvv__tab.is-active {
	background: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
}

.p-access {
	padding: 3.75rem 0;
}

.p-access__wrapper {
	margin-top: 1.875rem;
}

.p-access__contents {
	display: flex;
	flex-direction: column;
	gap: 1.875rem;
}

.p-access__info {
	width: 100%;
}

.p-access__item-title {
	font-size: 1.125rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.5;
}

.p-access__item-address {
	font-size: 0.875rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.5;
	margin-top: 0.625rem;
}

.p-access__item-tel {
	font-size: 0.875rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.5;
}

.p-access__button {
	margin-top: 1.875rem;
	text-align: center;
}

.p-access__line {
	border-top: 1px solid #333;
	margin-top: 0.9375rem;
}

.p-access__routes {
	gap: 0.625rem;
}

.p-access__route {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
}

.p-access__route + .p-access__route {
	margin-top: 0.625rem;
}

.p-access__map {
	width: 100%;
}

.p-access__map-frame {
	width: 100%;
}

.p-access__map iframe {
	height: 18.75rem;
	width: 100%;
}

.p-access__route-head {
	font-size: 1rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	line-height: 1.5;
}

.p-access__route-body {
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.5;
}

/* =========================
   MV
========================= */

.p-activities-mv {
	background: #000;
	color: #fff;
	min-height: 11.25rem;
	overflow: hidden;
	position: relative;
}

.p-activities-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activities-mv__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.58);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-activities-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.76) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activities-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activities-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.125rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-activities-mv__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 11.25rem;
	padding-bottom: 1.5rem;
	padding-top: 6.25rem;
	position: relative;
	z-index: 1;
}

.p-activities-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-activities-mv__title {
	font-size: max(1.75rem, min(6vw, 3rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
}

/* =========================
   Archive
========================= */

.p-activities-archive {
	padding: 2rem 0 4.5rem;
}

.p-activities-archive__inner {
	max-width: 68.75rem;
}

.p-activities-archive__lead {
	margin-bottom: 2rem;
}

.p-activities-archive__lead-text {
	color: #1c4b90;
	font-size: 1rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
	margin: 0;
}

.p-activities-archive__pagination {
	margin-bottom: 4.5rem;
	margin-top: 3rem;
}

.p-activities-archive__pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	justify-content: center;
}

.p-activities-archive__pagination a,
.p-activities-archive__pagination span {
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 2.5rem;
	min-width: 2.5rem;
	padding: 0.5rem 0.75rem;
	text-decoration: none;
}

.p-activities-archive__pagination .current {
	background: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
}

.p-activities-archive__empty {
	color: rgba(28, 75, 144, 0.7);
	padding: 2.5rem 0;
	text-align: center;
}

/* =========================
   Filter
========================= */

.p-activities-filter {
	margin-bottom: 2rem;
}

.p-activities-filter__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.p-activities-filter__item a {
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 2.375rem;
	padding: 0.5rem 1rem;
	text-decoration: none;
	transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}

.p-activities-filter__item a:hover,
.p-activities-filter__item.is-current a {
	background: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
}

/* =========================
   Grid
========================= */

.p-activities-grid {
	grid-gap: 1.25rem;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

/* =========================
   SP
========================= */

/* =========================
   Activities section
========================= */

.p-activities__inner,
.p-activities__swiper {
	position: relative;
	z-index: 1;
}

.p-activities__swiper {
	margin-top: 1.75rem;
	overflow: visible;
	padding-left: 0.5rem;
	padding-right: 0.5rem;
	position: relative;
}

.p-activities__swiper::after {
	background: rgba(64, 134, 255, 0.16);
	bottom: 0.5rem;
	content: "";
	filter: blur(3.125rem);
	height: 6.25rem;
	left: 50%;
	pointer-events: none;
	position: absolute;
	transform: translateX(-50%);
	width: 100%;
	z-index: 0;
}

.p-activities-swiper .swiper {
	overflow: visible;
}

.p-activities-swiper .swiper-wrapper {
	align-items: stretch;
}

.p-activities-swiper .swiper-slide {
	height: auto;
}

/* 初期ちらつき防止 */

.js-activities-swiper:not(.is-ready) {
	opacity: 0;
}

.js-activities-swiper.is-ready {
	opacity: 1;
	transition: opacity 0.4s ease;
}

/* =========================
   Contact CTA
========================= */

.p-activity-contact {
	margin-top: 3rem;
}

.p-activity-contact__box {
	background: linear-gradient(135deg, rgb(7, 20, 64) 0%, rgb(20, 54, 128) 100%);
	border-radius: 1.25rem;
	box-shadow: 0 1rem 2.125rem rgba(0, 0, 0, 0.12);
	color: #fff;
	padding: 1.75rem 1.25rem;
	text-align: center;
}

.p-activity-contact__sub {
	color: rgba(255, 255, 255, 0.72);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin: 0;
}

.p-activity-contact__title {
	font-size: max(1.5rem, min(4vw, 2.375rem));
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 0.75rem;
}

.p-activity-contact__text {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.9375rem;
	line-height: 1.9;
	margin-bottom: 0;
	margin-top: 1rem;
}

.p-activity-contact__buttons {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1.5rem;
}

/* =========================
   Pager
========================= */

.p-activity-pager {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	margin-top: 3rem;
}

.p-activity-pager__link {
	grid-gap: 0.875rem;
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	border-radius: 0.875rem;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	color: #1c4b90;
	display: grid;
	gap: 0.875rem;
	min-height: 6.5rem;
	padding: 0.875rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.p-activity-pager__link:hover {
	border-color: rgba(28, 75, 144, 0.28);
	box-shadow: 0 0.875rem 1.75rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.125rem);
}

.p-activity-pager__link.is-disabled {
	opacity: 0.5;
	pointer-events: none;
}

.p-activity-pager__thumb {
	align-items: center;
	aspect-ratio: 1/1;
	background: rgba(28, 75, 144, 0.04);
	border-radius: 0.625rem;
	display: flex;
	justify-content: center;
	overflow: hidden;
}

.p-activity-pager__img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-activity-pager__img--logo {
	-o-object-fit: contain;
	height: 70%;
	object-fit: contain;
	padding: 0.375rem;
	width: 70%;
}

.p-activity-pager__body {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	min-width: 0;
	text-align: left;
}

.p-activity-pager__label {
	color: rgba(28, 75, 144, 0.56);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
}

.p-activity-pager__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #1c4b90;
	display: -webkit-box;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.6;
	overflow: hidden;
}

.p-activity-pager__icon {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 2.125rem;
	position: relative;
	width: 2.125rem;
}

.p-activity-pager__icon::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 0.4375rem;
}

/* prev */

.p-activity-pager__link--prev {
	grid-template-columns: 2.375rem 1fr 5.25rem;
}

.p-activity-pager__link--prev .p-activity-pager__icon {
	order: 1;
}

.p-activity-pager__link--prev .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--prev .p-activity-pager__thumb {
	order: 3;
}

.p-activity-pager__link--prev .p-activity-pager__icon::before {
	transform: translate(-35%, -50%) rotate(-135deg);
}

/* next */

.p-activity-pager__link--next {
	grid-template-columns: 5.25rem 1fr 2.375rem;
}

.p-activity-pager__link--next .p-activity-pager__thumb {
	order: 1;
}

.p-activity-pager__link--next .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--next .p-activity-pager__icon {
	order: 3;
}

.p-activity-pager__link--next .p-activity-pager__icon::before {
	transform: translate(-65%, -50%) rotate(45deg);
}

/* =========================
   MV
========================= */

.p-activity-mv {
	background: #000;
	color: #fff;
	min-height: 11.25rem;
	overflow: hidden;
	position: relative;
}

.p-activity-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activity-mv__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.58);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-activity-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.76) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activity-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activity-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.125rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-activity-mv__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 11.25rem;
	padding-bottom: 1.5rem;
	padding-top: 6.25rem;
	position: relative;
	z-index: 1;
}

.p-activity-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-activity-mv__title {
	font-size: max(1.75rem, min(6vw, 3rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
}

/* =========================
   Pager
========================= */

.p-activity-pager {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	margin-top: 3rem;
}

.p-activity-pager__link {
	grid-gap: 0.875rem;
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	border-radius: 0.875rem;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	color: #1c4b90;
	display: grid;
	gap: 0.875rem;
	min-height: 6.5rem;
	padding: 0.875rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.p-activity-pager__link:hover {
	border-color: rgba(28, 75, 144, 0.28);
	box-shadow: 0 0.875rem 1.75rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.125rem);
}

.p-activity-pager__link.is-disabled {
	opacity: 0.5;
	pointer-events: none;
}

.p-activity-pager__thumb {
	align-items: center;
	aspect-ratio: 1/1;
	background: rgba(28, 75, 144, 0.04);
	border-radius: 0.625rem;
	display: flex;
	justify-content: center;
	overflow: hidden;
}

.p-activity-pager__img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-activity-pager__img--logo {
	-o-object-fit: contain;
	height: 70%;
	object-fit: contain;
	padding: 0.375rem;
	width: 70%;
}

.p-activity-pager__body {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	min-width: 0;
	text-align: left;
}

.p-activity-pager__label {
	color: rgba(28, 75, 144, 0.56);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
}

.p-activity-pager__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #1c4b90;
	display: -webkit-box;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.6;
	overflow: hidden;
}

.p-activity-pager__icon {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 2.125rem;
	position: relative;
	width: 2.125rem;
}

.p-activity-pager__icon::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 0.4375rem;
}

/* prev */

.p-activity-pager__link--prev {
	grid-template-columns: 2.375rem 1fr 5.25rem;
}

.p-activity-pager__link--prev .p-activity-pager__icon {
	order: 1;
}

.p-activity-pager__link--prev .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--prev .p-activity-pager__thumb {
	order: 3;
}

.p-activity-pager__link--prev .p-activity-pager__icon::before {
	transform: translate(-35%, -50%) rotate(-135deg);
}

/* next */

.p-activity-pager__link--next {
	grid-template-columns: 5.25rem 1fr 2.375rem;
}

.p-activity-pager__link--next .p-activity-pager__thumb {
	order: 1;
}

.p-activity-pager__link--next .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--next .p-activity-pager__icon {
	order: 3;
}

.p-activity-pager__link--next .p-activity-pager__icon::before {
	transform: translate(-65%, -50%) rotate(45deg);
}

/* =========================
   Single
========================= */

.p-activity-single {
	padding: 2rem 0 4.5rem;
}

.p-activity-single__inner {
	max-width: 53.75rem;
}

.p-activity-single__header {
	border-bottom: 1px solid rgba(28, 75, 144, 0.18);
	padding-bottom: 1.5rem;
}

.p-activity-single__meta {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
}

.p-activity-single__category {
	align-items: center;
	background: #dcd4a2;
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 1.875rem;
	padding: 0.375rem 0.75rem;
}

.p-activity-single__date {
	color: rgba(28, 75, 144, 0.76);
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.4;
}

.p-activity-single__title {
	color: #1c4b90;
	font-size: max(1.6875rem, min(4.2vw, 2.875rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 1.125rem;
}

.p-activity-single__lead {
	color: #333;
	font-size: 1rem;
	line-height: 1.9;
	margin-bottom: 0;
	margin-top: 1rem;
}

.p-activity-single__thumbnail {
	border-radius: 1rem;
	box-shadow: 0 0.875rem 2rem rgba(0, 0, 0, 0.12);
	margin-top: 2.25rem;
	overflow: hidden;
}

.p-activity-single__img {
	-o-object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.p-activity-single__body {
	margin-top: 2.25rem;
}

.p-activity-single__content {
	color: #222;
	font-size: 1.0625rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
}

.p-activity-single__content > *:first-child {
	margin-top: 0;
}

.p-activity-single__content p {
	margin-bottom: 0;
	margin-top: 1.25rem;
}

.p-activity-single__content h2,
.p-activity-single__content h3,
.p-activity-single__content h4 {
	color: #1c4b90;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 1rem;
	margin-top: 2.5rem;
}

.p-activity-single__content h2 {
	font-size: 1.5rem;
	padding-left: 1rem;
	position: relative;
}

.p-activity-single__content h2::before {
	background: linear-gradient(180deg, #1c4b90 0%, rgba(28, 75, 144, 0.35) 100%);
	border-radius: 62.4375rem;
	content: "";
	height: calc(100% - 0.5rem);
	left: 0;
	position: absolute;
	top: 0.25rem;
	width: 0.25rem;
}

.p-activity-single__content ul,
.p-activity-single__content ol {
	margin-top: 1.25rem;
	padding-left: 1.5rem;
}

.p-activity-single__content li + li {
	margin-top: 0.5rem;
}

.p-activity-single__content blockquote {
	background: rgba(28, 75, 144, 0.04);
	border-left: 0.25rem solid #1c4b90;
	margin: 1.75rem 0 0;
	padding: 1.25rem;
}

/* =========================
   Contact CTA
========================= */

.p-activity-contact {
	margin-top: 3rem;
}

.p-activity-contact__box {
	background: linear-gradient(135deg, rgb(7, 20, 64) 0%, rgb(20, 54, 128) 100%);
	border-radius: 1.25rem;
	box-shadow: 0 1rem 2.125rem rgba(0, 0, 0, 0.12);
	color: #fff;
	padding: 1.75rem 1.25rem;
	text-align: center;
}

.p-activity-contact__sub {
	color: rgba(255, 255, 255, 0.72);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin: 0;
}

.p-activity-contact__title {
	font-size: max(1.5rem, min(4vw, 2.375rem));
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 0.75rem;
}

.p-activity-contact__text {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.9375rem;
	line-height: 1.9;
	margin-bottom: 0;
	margin-top: 1rem;
}

.p-activity-contact__buttons {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1.5rem;
}

/* =========================
   Pager
========================= */

.p-activity-pager {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	margin-top: 3rem;
}

.p-activity-pager__link {
	grid-gap: 0.875rem;
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	border-radius: 0.875rem;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	color: #1c4b90;
	display: grid;
	gap: 0.875rem;
	min-height: 6.5rem;
	padding: 0.875rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.p-activity-pager__link:hover {
	border-color: rgba(28, 75, 144, 0.28);
	box-shadow: 0 0.875rem 1.75rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.125rem);
}

.p-activity-pager__link.is-disabled {
	opacity: 0.5;
	pointer-events: none;
}

.p-activity-pager__thumb {
	align-items: center;
	aspect-ratio: 1/1;
	background: rgba(28, 75, 144, 0.04);
	border-radius: 0.625rem;
	display: flex;
	justify-content: center;
	overflow: hidden;
}

.p-activity-pager__img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-activity-pager__img--logo {
	-o-object-fit: contain;
	height: 70%;
	object-fit: contain;
	padding: 0.375rem;
	width: 70%;
}

.p-activity-pager__body {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	min-width: 0;
	text-align: left;
}

.p-activity-pager__label {
	color: rgba(28, 75, 144, 0.56);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
}

.p-activity-pager__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #1c4b90;
	display: -webkit-box;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.6;
	overflow: hidden;
}

.p-activity-pager__icon {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 2.125rem;
	position: relative;
	width: 2.125rem;
}

.p-activity-pager__icon::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 0.4375rem;
}

/* prev */

.p-activity-pager__link--prev {
	grid-template-columns: 2.375rem 1fr 5.25rem;
}

.p-activity-pager__link--prev .p-activity-pager__icon {
	order: 1;
}

.p-activity-pager__link--prev .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--prev .p-activity-pager__thumb {
	order: 3;
}

.p-activity-pager__link--prev .p-activity-pager__icon::before {
	transform: translate(-35%, -50%) rotate(-135deg);
}

/* next */

.p-activity-pager__link--next {
	grid-template-columns: 5.25rem 1fr 2.375rem;
}

.p-activity-pager__link--next .p-activity-pager__thumb {
	order: 1;
}

.p-activity-pager__link--next .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--next .p-activity-pager__icon {
	order: 3;
}

.p-activity-pager__link--next .p-activity-pager__icon::before {
	transform: translate(-65%, -50%) rotate(45deg);
}

.p-achievements-archive {
	background-color: #fff;
	padding-bottom: 3.75rem;
	padding-top: 2.5rem;
}

.p-achievements-archive__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 68.75rem;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	width: 100%;
}

.p-achievements-archive__title {
	color: #0d1036;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0.075rem;
	text-align: center;
}

/* ========================================
  Category Filter
======================================== */

.p-achievements-archive__filter {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	justify-content: center;
	margin-top: 1.5rem;
}

.p-achievements-archive__filter-btn {
	background-color: #fff;
	border: 0.03125rem solid #c1c1c1;
	border-radius: 0.125rem;
	color: #c1c1c1;
	cursor: pointer;
	font-family: "Hiragino Kaku Gothic ProN", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	padding: 0.25rem 1rem;
	transition: all 0.3s ease;
}

.p-achievements-archive__filter-btn:hover {
	background-color: #c1c1c1;
	color: #fff;
}

.p-achievements-archive__filter-btn.is-active {
	background-color: #fff;
	border-color: #c1c1c1;
}

/* ========================================
  Card List
======================================== */

.p-achievements-archive__list {
	grid-gap: 2.5rem;
	display: grid;
	gap: 2.5rem;
	grid-template-columns: 1fr;
	margin-top: 2.5rem;
}

/* ========================================
  Card
======================================== */

.p-achievements-archive__card {
	width: 100%;
}

.p-achievements-archive__card-link {
	-webkit-text-decoration: none;
	display: block;
	text-decoration: none;
	transition: opacity 0.3s ease;
}

.p-achievements-archive__card-link:hover {
	opacity: 0.8;
}

.p-achievements-archive__card-img-wrap {
	height: 12.5rem;
	overflow: hidden;
	width: 100%;
}

.p-achievements-archive__card-img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-achievements-archive__card-body {
	margin-top: 1rem;
}

.p-achievements-archive__card-cat {
	align-items: center;
	border: 0.0625rem solid #1c4b90;
	color: #1c4b90;
	display: inline-flex;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 0.8125rem;
	font-weight: 500;
	justify-content: center;
	line-height: 1.8;
	padding: 0.25rem 0.5rem;
	text-align: center;
}

.p-achievements-archive__card-title {
	color: #0d1036;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.0675rem;
	line-height: 1.5;
	margin-top: 0.75rem;
}

.p-achievements-archive__card-desc {
	color: #c1c1c1;
	font-family: "Noto Sans JP", sans-serif;
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: 0.06rem;
	margin-top: 0.5rem;
}

/* ========================================
  Pagination
======================================== */

.p-achievements-archive__pagination {
	align-items: center;
	display: flex;
	gap: 0.5rem;
	justify-content: center;
	margin-top: 3.125rem;
}

.p-achievements-archive__pagination-prev,
.p-achievements-archive__pagination-next {
	-webkit-text-decoration: none;
	align-items: center;
	border: 0.0625rem solid #0d1036;
	border-radius: 50%;
	display: flex;
	height: 2.375rem;
	justify-content: center;
	text-decoration: none;
	transition: all 0.3s ease;
	width: 2.375rem;
}

.p-achievements-archive__pagination-prev:hover,
.p-achievements-archive__pagination-next:hover {
	background-color: #0d1036;
}

.p-achievements-archive__pagination-prev:hover .p-achievements-archive__pagination-arrow,
.p-achievements-archive__pagination-next:hover .p-achievements-archive__pagination-arrow {
	border-color: #fff;
}

.p-achievements-archive__pagination-arrow {
	border-right: 0.125rem solid #0d1036;
	border-top: 0.125rem solid #0d1036;
	display: block;
	height: 0.5rem;
	width: 0.5rem;
}

.p-achievements-archive__pagination-arrow--prev {
	margin-left: 0.1875rem;
	transform: rotate(-135deg);
}

.p-achievements-archive__pagination-arrow--next {
	margin-right: 0.1875rem;
	transform: rotate(45deg);
}

.p-achievements-archive__pagination-list {
	align-items: center;
	display: flex;
	gap: 0rem;
}

.p-achievements-archive__pagination-item {
	list-style: none;
}

.p-achievements-archive__pagination-num {
	-webkit-text-decoration: none;
	align-items: center;
	border: 0.0625rem solid #0d1036;
	color: #0d1036;
	display: flex;
	font-family: "Montserrat", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	height: 2.375rem;
	justify-content: center;
	text-decoration: none;
	transition: all 0.3s ease;
	width: 2.375rem;
}

.p-achievements-archive__pagination-num:hover {
	background-color: #0d1036;
	color: #fff;
}

.p-achievements-archive__pagination-num.is-current {
	background-color: #0d1036;
	color: #fff;
}

/* =========================
   MV
========================= */

.p-activity-mv {
	background: #000;
	color: #fff;
	min-height: 11.25rem;
	overflow: hidden;
	position: relative;
}

.p-activity-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activity-mv__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.58);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-activity-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.76) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activity-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-activity-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.125rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-activity-mv__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 11.25rem;
	padding-bottom: 1.5rem;
	padding-top: 6.25rem;
	position: relative;
	z-index: 1;
}

.p-activity-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-activity-mv__title {
	font-size: max(1.75rem, min(6vw, 3rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
}

/* =========================
   Single
========================= */

.p-activity-single {
	padding: 2rem 0 4.5rem;
}

.p-activity-single__inner {
	max-width: 53.75rem;
}

.p-activity-single__header {
	border-bottom: 1px solid rgba(28, 75, 144, 0.18);
	padding-bottom: 1.5rem;
}

.p-activity-single__meta {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
}

.p-activity-single__category {
	align-items: center;
	background: #dcd4a2;
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 1.875rem;
	padding: 0.375rem 0.75rem;
}

.p-activity-single__date {
	color: rgba(28, 75, 144, 0.76);
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.4;
}

.p-activity-single__title {
	color: #1c4b90;
	font-size: max(1.6875rem, min(4.2vw, 2.875rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 1.125rem;
}

.p-activity-single__lead {
	color: #333;
	font-size: 1rem;
	line-height: 1.9;
	margin-bottom: 0;
	margin-top: 1rem;
}

.p-activity-single__thumbnail {
	border-radius: 1rem;
	box-shadow: 0 0.875rem 2rem rgba(0, 0, 0, 0.12);
	margin-top: 2.25rem;
	overflow: hidden;
}

.p-activity-single__img {
	-o-object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.p-activity-single__body {
	margin-top: 2.25rem;
}

.p-activity-single__content {
	color: #222;
	font-size: 1.0625rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
}

.p-activity-single__content > *:first-child {
	margin-top: 0;
}

.p-activity-single__content p {
	margin-bottom: 0;
	margin-top: 1.25rem;
}

.p-activity-single__content h2,
.p-activity-single__content h3,
.p-activity-single__content h4 {
	color: #1c4b90;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 1rem;
	margin-top: 2.5rem;
}

.p-activity-single__content h2 {
	font-size: 1.5rem;
	padding-left: 1rem;
	position: relative;
}

.p-activity-single__content h2::before {
	background: linear-gradient(180deg, #1c4b90 0%, rgba(28, 75, 144, 0.35) 100%);
	border-radius: 62.4375rem;
	content: "";
	height: calc(100% - 0.5rem);
	left: 0;
	position: absolute;
	top: 0.25rem;
	width: 0.25rem;
}

.p-activity-single__content ul,
.p-activity-single__content ol {
	margin-top: 1.25rem;
	padding-left: 1.5rem;
}

.p-activity-single__content li + li {
	margin-top: 0.5rem;
}

.p-activity-single__content blockquote {
	background: rgba(28, 75, 144, 0.04);
	border-left: 0.25rem solid #1c4b90;
	margin: 1.75rem 0 0;
	padding: 1.25rem;
}

/* =========================
   Contact CTA
========================= */

.p-activity-contact {
	margin-top: 3rem;
}

.p-activity-contact__box {
	background: linear-gradient(135deg, rgb(7, 20, 64) 0%, rgb(20, 54, 128) 100%);
	border-radius: 1.25rem;
	box-shadow: 0 1rem 2.125rem rgba(0, 0, 0, 0.12);
	color: #fff;
	padding: 1.75rem 1.25rem;
	text-align: center;
}

.p-activity-contact__sub {
	color: rgba(255, 255, 255, 0.72);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin: 0;
}

.p-activity-contact__title {
	font-size: max(1.5rem, min(4vw, 2.375rem));
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 0.75rem;
}

.p-activity-contact__text {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.9375rem;
	line-height: 1.9;
	margin-bottom: 0;
	margin-top: 1rem;
}

.p-activity-contact__buttons {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1.5rem;
}

/* =========================
   Pager
========================= */

.p-activity-pager {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	margin-top: 3rem;
}

.p-activity-pager__link {
	grid-gap: 0.875rem;
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	border-radius: 0.875rem;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	color: #1c4b90;
	display: grid;
	gap: 0.875rem;
	min-height: 6.5rem;
	padding: 0.875rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.p-activity-pager__link:hover {
	border-color: rgba(28, 75, 144, 0.28);
	box-shadow: 0 0.875rem 1.75rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.125rem);
}

.p-activity-pager__link.is-disabled {
	opacity: 0.5;
	pointer-events: none;
}

.p-activity-pager__thumb {
	align-items: center;
	aspect-ratio: 1/1;
	background: rgba(28, 75, 144, 0.04);
	border-radius: 0.625rem;
	display: flex;
	justify-content: center;
	overflow: hidden;
}

.p-activity-pager__img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-activity-pager__img--logo {
	-o-object-fit: contain;
	height: 70%;
	object-fit: contain;
	padding: 0.375rem;
	width: 70%;
}

.p-activity-pager__body {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	min-width: 0;
	text-align: left;
}

.p-activity-pager__label {
	color: rgba(28, 75, 144, 0.56);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
}

.p-activity-pager__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #1c4b90;
	display: -webkit-box;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.6;
	overflow: hidden;
}

.p-activity-pager__icon {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 2.125rem;
	position: relative;
	width: 2.125rem;
}

.p-activity-pager__icon::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 0.4375rem;
}

/* prev */

.p-activity-pager__link--prev {
	grid-template-columns: 2.375rem 1fr 5.25rem;
}

.p-activity-pager__link--prev .p-activity-pager__icon {
	order: 1;
}

.p-activity-pager__link--prev .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--prev .p-activity-pager__thumb {
	order: 3;
}

.p-activity-pager__link--prev .p-activity-pager__icon::before {
	transform: translate(-35%, -50%) rotate(-135deg);
}

/* next */

.p-activity-pager__link--next {
	grid-template-columns: 5.25rem 1fr 2.375rem;
}

.p-activity-pager__link--next .p-activity-pager__thumb {
	order: 1;
}

.p-activity-pager__link--next .p-activity-pager__body {
	order: 2;
}

.p-activity-pager__link--next .p-activity-pager__icon {
	order: 3;
}

.p-activity-pager__link--next .p-activity-pager__icon::before {
	transform: translate(-65%, -50%) rotate(45deg);
}

.p-archive-home__inner.l-inner {
	max-width: 60.3125rem;
}

.p-archive-home__item:not(:first-child) {
	margin-top: 2rem;
}

.p-archive-works__inner.l-inner {
	padding: 0 0.9375rem;
}

.p-archive-works__items {
	grid-gap: 2.5rem;
	display: grid;
	gap: 2.5rem;
	grid-template-columns: repeat(1, 1fr);
}

.p-archive-works__img {
	aspect-ratio: 345/235;
	overflow: hidden;
}

.p-archive-works__img img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-archive-works__title {
	margin-top: 0.9375rem;
}

.p-archive-works__name {
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0.05em;
	text-align: center;
}

.p-business-closing {
	background: #060a14;
	overflow: hidden;
	padding-bottom: max(96px, min(14vh, 172px));
	padding-left: max(60px, min(7vw, 112px));
	padding-right: max(60px, min(7vw, 112px));
	padding-top: max(96px, min(14vh, 172px));
	position: relative;
	text-align: center;
}

.p-business-closing::before {
	background: radial-gradient(ellipse 70% 50% at 50% 50%, rgba(26, 79, 216, 0.12) 0%, transparent 70%);
	bottom: 0;
	content: "";
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-business-closing__label {
	align-items: center;
	color: #d4b483;
	display: inline-flex;
	font-family: "JetBrains Mono", "SF Mono", "Menlo", monospace;
	font-size: 10px;
	gap: 14px;
	letter-spacing: 0.24em;
	margin-bottom: 30px;
	position: relative;
	text-transform: uppercase;
	z-index: 2;
}

.p-business-closing__label::before,
.p-business-closing__label::after {
	background: #c59c63;
	content: "";
	height: 1px;
	width: 28px;
}

.p-business-closing__title {
	font-family: "Poppins", sans-serif;
	font-size: max(38px, min(7.5vw, 104px));
	letter-spacing: 0.02em;
	line-height: 0.92;
	position: relative;
	z-index: 2;
}

.p-business-closing__title em {
	color: #00d4ff;
	font-family: "Noto Serif JP", serif;
	font-size: 1.06em;
	font-style: italic;
	font-weight: 300;
}

.p-business-closing__body {
	color: rgba(13, 16, 54, 0.35);
	font-size: 14px;
	font-weight: 300;
	line-height: 2;
	margin: 26px auto 0;
	max-width: 600px;
	position: relative;
	z-index: 2;
}

.p-business-hero {
	align-items: flex-end;
	display: flex;
	min-height: 100vh;
	overflow: hidden;
	padding-bottom: max(60px, min(8vh, 110px));
	padding-left: max(60px, min(7vw, 112px));
	padding-right: max(60px, min(7vw, 112px));
	position: relative;
}

.p-business-hero::after {
	animation: scanline 5s linear infinite;
	background: linear-gradient(90deg, transparent 0%, rgba(0, 212, 255, 0.3) 50%, transparent 100%);
	content: "";
	height: 1px;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: -1px;
	z-index: 3;
}

.p-business-hero__canvas {
	bottom: 0;
	height: 100%;
	left: 0;
	opacity: 0.25;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
}

.p-business-hero__grid {
	background-image: linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
	background-size: 60px 60px;
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-business-hero__particles {
	bottom: 0;
	left: 0;
	overflow: hidden;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
}

.p-business-hero__content {
	max-width: 960px;
	position: relative;
	z-index: 2;
}

.p-business-hero__eyebrow {
	align-items: center;
	color: #00d4ff;
	display: flex;
	font-family: "JetBrains Mono", "SF Mono", "Menlo", monospace;
	font-size: 11px;
	gap: 14px;
	letter-spacing: 0.24em;
	margin-bottom: 22px;
	text-transform: uppercase;
}

.p-business-hero__eyebrow::before {
	background: #00d4ff;
	content: "";
	height: 1px;
	width: 36px;
}

.p-business-hero__title {
	display: block;
	font-family: "Poppins", sans-serif;
	font-size: max(60px, min(11vw, 156px));
	letter-spacing: 0.015em;
	line-height: 0.88;
}

.p-business-hero__title-line {
	display: block;
	line-height: 1.05;
	overflow: hidden;
}

.p-business-hero__title-line span {
	display: block;
	transform: translateY(110%);
	transition: transform 1.1s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-business-hero__title-line.is-in span {
	transform: translateY(0);
}

.p-business-hero__title-line:nth-child(2) span {
	transition-delay: 0.14s;
}

.p-business-hero__title-em {
	color: #00d4ff;
	font-family: "Noto Serif JP", serif;
	font-size: 1.07em;
	font-style: italic;
	font-weight: 300;
}

.p-business-hero__desc {
	color: rgba(13, 16, 54, 0.45);
	font-size: max(13px, min(1.2vw, 15px));
	font-weight: 300;
	line-height: 2;
	margin-top: 26px;
	max-width: 500px;
}

.p-business-hero__keywords {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 30px;
}

.p-business-hero__scroll {
	align-items: center;
	bottom: 40px;
	color: rgba(159, 143, 236, 0.55);
	display: flex;
	font-family: "JetBrains Mono", "SF Mono", "Menlo", monospace;
	font-size: 9px;
	gap: 10px;
	letter-spacing: 0.22em;
	position: absolute;
	right: max(60px, min(7vw, 112px));
	writing-mode: vertical-rl;
}

.p-business-hero__scroll::after {
	animation: scrollbar 1.8s ease infinite;
	background: linear-gradient(to bottom, rgba(159, 143, 236, 0.55), transparent);
	content: "";
	height: 52px;
	width: 1px;
}

.p-business-story {
	padding-left: max(60px, min(7vw, 112px));
	padding-right: max(60px, min(7vw, 112px));
}

.p-business-story__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 1200px;
}

.p-business-story__item {
	grid-gap: max(48px, min(7vw, 108px));
	align-items: center;
	border-bottom: 1px solid rgba(54, 23, 209, 0.6);
	display: grid;
	gap: max(48px, min(7vw, 108px));
	grid-template-columns: 1fr 1fr;
	padding: max(80px, min(10vw, 136px)) 0;
	position: relative;
}

.p-business-story__item:last-child {
	border-bottom: none;
}

.p-business-story__item--rev {
	direction: rtl;
}

.p-business-story__item--rev > * {
	direction: ltr;
}

.p-business-story__ghost {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(255, 255, 255, 0.024);
	font-family: "Poppins", sans-serif;
	font-size: max(140px, min(20vw, 300px));
	left: -0.02em;
	letter-spacing: -0.02em;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	top: -0.06em;
	transition: color 0.6s, transform 0.6s cubic-bezier(0.16, 1, 0.3, 1);
	user-select: none;
}

.p-business-story__item:hover .p-business-story__ghost {
	color: rgba(26, 79, 216, 0.05);
	transform: scale(1.02) translateX(8px);
}

.p-business-story__content {
	position: relative;
	z-index: 2;
}

.p-business-story__index {
	align-items: center;
	color: #d4b483;
	display: flex;
	font-family: "JetBrains Mono", "SF Mono", "Menlo", monospace;
	font-size: 10px;
	gap: 12px;
	letter-spacing: 0.22em;
	margin-bottom: 18px;
}

.p-business-story__index::before {
	background: #d4b483;
	content: "";
	height: 1px;
	width: 22px;
}

.p-business-story__title-wrap {
	overflow: hidden;
}

.p-business-story__title {
	color: #0d1036;
	display: block;
	font-family: "Poppins", sans-serif;
	font-size: max(38px, min(5.4vw, 72px));
	letter-spacing: 0.03em;
	line-height: 0.95;
	transform: translateY(105%);
	transition: transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-business-story__title-wrap.is-in .p-business-story__title {
	transform: translateY(0);
}

.p-business-story__sub {
	color: #5b8def;
	font-family: "JetBrains Mono", "SF Mono", "Menlo", monospace;
	font-size: 11px;
	letter-spacing: 0.12em;
	margin-bottom: 26px;
	margin-top: 6px;
}

.p-business-story__lead {
	border-left: 2px solid #00d4ff;
	color: #0d1036;
	font-family: "Noto Serif JP", serif;
	font-size: max(19px, min(2vw, 26px));
	font-weight: 300;
	line-height: 1.65;
	margin-bottom: 16px;
	padding-left: 18px;
}

.p-business-story__body {
	color: rgba(13, 16, 54, 0.45);
	font-size: 13.5px;
	font-weight: 300;
	line-height: 2;
	margin-bottom: 34px;
	max-width: 420px;
}

.p-business-story__visual {
	position: relative;
}

.p-business-story__frame {
	aspect-ratio: 3/4;
	overflow: hidden;
	position: relative;
	transform-style: preserve-3d;
}

.p-business-story__frame::before {
	border-left: 1.5px solid rgba(0, 212, 255, 0.45);
	border-top: 1.5px solid rgba(0, 212, 255, 0.45);
	content: "";
	height: 22px;
	left: 12px;
	pointer-events: none;
	position: absolute;
	top: 12px;
	transition: width 0.4s cubic-bezier(0.16, 1, 0.3, 1), height 0.4s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s;
	width: 22px;
	z-index: 4;
}

.p-business-story__frame::after {
	border-bottom: 1.5px solid rgba(0, 212, 255, 0.45);
	border-right: 1.5px solid rgba(0, 212, 255, 0.45);
	bottom: 12px;
	content: "";
	height: 22px;
	pointer-events: none;
	position: absolute;
	right: 12px;
	transition: width 0.4s cubic-bezier(0.16, 1, 0.3, 1), height 0.4s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.4s;
	width: 22px;
	z-index: 4;
}

.p-business-story__item:hover .p-business-story__frame::before,
.p-business-story__item:hover .p-business-story__frame::after {
	border-color: #00d4ff;
	height: 36px;
	width: 36px;
}

.p-business-story__frame-bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-business-story__item:hover .p-business-story__frame-bg {
	transform: scale(1.05);
}

.p-business-story__frame-bg--1 {
	background: linear-gradient(145deg, #061530 0%, #0d2854 50%, #072060 100%);
}

.p-business-story__frame-bg--2 {
	background: linear-gradient(145deg, #06150e 0%, #0d2c1a 50%, #072a14 100%);
}

.p-business-story__frame-bg--3 {
	background: linear-gradient(145deg, #110d26 0%, #1c1040 50%, #150b50 100%);
}

.p-business-story__frame-bg--4 {
	background: linear-gradient(145deg, #201006 0%, #3a1c0a 50%, #4a1e06 100%);
}

.p-business-story__frame-bg--5 {
	background: linear-gradient(145deg, #061620 0%, #0d2838 50%, #07243a 100%);
}

.p-business-story__frame-overlay {
	background: linear-gradient(135deg, rgba(10, 14, 26, 0.72) 0%, rgba(26, 79, 216, 0.12) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 2;
}

.p-business-story__frame-icon {
	align-items: center;
	bottom: 0;
	display: flex;
	justify-content: center;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 3;
}

.p-business-story__frame-data {
	-webkit-backdrop-filter: blur(8px);
	align-items: center;
	backdrop-filter: blur(8px);
	background: rgba(10, 14, 26, 0.6);
	bottom: 0;
	display: flex;
	justify-content: space-between;
	left: 0;
	padding: 12px 18px;
	position: absolute;
	right: 0;
	z-index: 5;
}

.p-business-story__data-label {
	color: rgba(13, 16, 54, 0.38);
	font-family: "JetBrains Mono", "SF Mono", "Menlo", monospace;
	font-size: 9px;
	letter-spacing: 0.2em;
	text-transform: uppercase;
}

.p-business-story__data-value {
	color: #00d4ff;
	font-family: "JetBrains Mono", "SF Mono", "Menlo", monospace;
	font-size: 10px;
	letter-spacing: 0.12em;
}

.p-business-story__bridge {
	grid-gap: 20px;
	align-items: center;
	display: grid;
	gap: 20px;
	grid-template-columns: 1fr auto 1fr;
	padding: max(20px, min(4vh, 44px)) 0;
}

.p-business-story__bridge-line {
	background: linear-gradient(90deg, transparent, rgba(159, 143, 236, 0.52));
	height: 1px;
}

.p-business-story__bridge-line--r {
	background: linear-gradient(90deg, rgba(159, 143, 236, 0.52), transparent);
}

.p-business-story__bridge-text {
	color: rgba(13, 16, 54, 0.18);
	font-family: "Noto Serif JP", serif;
	font-size: max(14px, min(1.7vw, 19px));
	font-style: italic;
	font-weight: 300;
	letter-spacing: 0.06em;
	white-space: nowrap;
}

.svg-icon-mgmt .orbit-1 {
	animation: spin 8s linear infinite;
	transform-origin: 50px 50px;
}

.svg-icon-mgmt .orbit-2 {
	animation: spin 12s linear infinite reverse;
	transform-origin: 50px 50px;
}

.svg-icon-ball .ball {
	animation: ballpath 3s cubic-bezier(0.16, 1, 0.3, 1) infinite;
}

.svg-icon-ball .trail {
	stroke-dasharray: 120;
	stroke-dashoffset: 120;
	animation: draw 3s cubic-bezier(0.16, 1, 0.3, 1) infinite;
}

.svg-icon-chart .bar {
	animation: barGrow 2s cubic-bezier(0.16, 1, 0.3, 1) infinite alternate;
}

.svg-icon-chart .bar:nth-child(1) {
	animation-delay: 0s;
	transform-origin: 14px 85px;
}

.svg-icon-chart .bar:nth-child(2) {
	animation-delay: 0.2s;
	transform-origin: 41px 85px;
}

.svg-icon-chart .bar:nth-child(3) {
	animation-delay: 0.4s;
	transform-origin: 68px 85px;
}

.svg-icon-gem .facet {
	animation: facetPulse 4s ease-in-out infinite;
}

.svg-icon-gem .facet:nth-child(2) {
	animation-delay: 0.5s;
}

.svg-icon-gem .facet:nth-child(3) {
	animation-delay: 1s;
}

.svg-icon-clock .hand {
	animation: clockHand 4s linear infinite;
	transform-origin: 50px 50px;
}

.svg-icon-clock .hand-s {
	animation: clockHand 1s linear infinite;
	transform-origin: 50px 50px;
}

.js-cursor-dot {
	background: #00d4ff;
	border-radius: 50%;
	height: 8px;
	mix-blend-mode: screen;
	pointer-events: none;
	position: fixed;
	transform: translate(-50%, -50%);
	width: 8px;
	z-index: 9999;
}

.js-cursor-ring {
	border: 1.5px solid rgba(0, 212, 255, 0.35);
	border-radius: 50%;
	height: 36px;
	pointer-events: none;
	position: fixed;
	transform: translate(-50%, -50%);
	transition: width 0.3s cubic-bezier(0.16, 1, 0.3, 1), height 0.3s cubic-bezier(0.16, 1, 0.3, 1), border-color 0.3s;
	width: 36px;
	z-index: 9998;
}

.js-cursor-ring.is-hover {
	border-color: #00d4ff;
	height: 60px;
	width: 60px;
}

.js-cursor-ring.is-click {
	height: 18px;
	width: 18px;
}

.js-progress {
	background: linear-gradient(90deg, #1a4fd8 0%, #00d4ff 100%);
	box-shadow: 0 0 8px rgba(0, 212, 255, 0.5);
	height: 2px;
	left: 0;
	position: fixed;
	top: 0;
	transition: width 0.05s linear;
	width: 0;
	z-index: 110;
}

.js-particle {
	animation: pfloat 9s linear 0s infinite;
	animation: pfloat var(--pd, 9s) linear var(--dd, 0s) infinite;
	background: #00d4ff;
	border-radius: 50%;
	height: 1.5px;
	opacity: 0;
	position: absolute;
	width: 1.5px;
}

.u-reveal-right,
.u-reveal-left,
.u-reveal {
	transition: opacity 0.8s cubic-bezier(0.16, 1, 0.3, 1), transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.u-reveal {
	opacity: 0;
	transform: translateY(34px);
}

.u-reveal.is-in {
	opacity: 1;
	transform: none;
}

.u-reveal-left {
	opacity: 0;
	transform: translateX(-42px);
}

.u-reveal-left.is-in {
	opacity: 1;
	transform: none;
}

.u-reveal-right {
	opacity: 0;
	transform: translateX(42px);
}

.u-reveal-right.is-in {
	opacity: 1;
	transform: none;
}

.u-d1 {
	transition-delay: 0.08s;
}

.u-d2 {
	transition-delay: 0.16s;
}

.u-d3 {
	transition-delay: 0.24s;
}

.u-d4 {
	transition-delay: 0.32s;
}

.u-d5 {
	transition-delay: 0.4s;
}

.u-d6 {
	transition-delay: 0.48s;
}

.p-service-detail {
	padding-bottom: 6rem;
	padding-top: 3.5rem;
}

.p-service-detail__contents {
	margin-top: 2.5rem;
}

.p-service-detail__item + .p-service-detail__item {
	margin-top: 3.5rem;
}

.p-service-detail__item-body {
	position: relative;
	width: 100%;
	z-index: 2;
}

.p-service-detail__item-head {
	align-items: flex-start;
	border-bottom: 1px solid rgba(13, 16, 54, 0.15);
	display: flex;
	gap: 1rem;
	padding-bottom: 1.25rem;
}

.number01 {
	position: relative;
}

.number01::before {
	background-image: url("../images/common/number01.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 8.125rem;
	left: 0;
	position: absolute;
	top: -80%;
	width: 10rem;
	z-index: -3;
}

.number02 {
	position: relative;
}

.number02::before {
	background-image: url("../images/common/number02.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 8.125rem;
	left: 0;
	position: absolute;
	top: -56%;
	width: 12.5rem;
	z-index: -3;
}

.number03 {
	position: relative;
}

.number03::before {
	background-image: url("../images/common/number03.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 8.125rem;
	left: 0;
	position: absolute;
	top: -80%;
	width: 12.5rem;
	z-index: -3;
}

.number04 {
	position: relative;
}

.number04::before {
	background-image: url("../images/common/number04.png");
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	height: 8.125rem;
	left: 0;
	position: absolute;
	top: -80%;
	width: 13.75rem;
	z-index: -3;
}

.p-service-detail__title {
	color: #0d1036;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.4;
}

.p-service-detail__subtitle {
	color: #90811c;
	font-family: "Poppins", sans-serif;
	font-size: 0.875rem;
	font-style: italic;
	font-weight: 500;
	letter-spacing: 0.1em;
	margin-top: 0.5rem;
}

.p-service-detail__lead {
	color: #1c4b90;
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.7;
	padding-top: 1rem;
	position: relative;
}

.p-service-detail__text-block {
	margin-top: 1rem;
	max-width: 38.75rem;
}

.p-service-detail__text {
	color: #333;
	font-size: 1rem;
	letter-spacing: 0.04em;
	line-height: 2;
}

.p-service-detail__text + .p-service-detail__text {
	margin-top: 0.75rem;
}

.p-service-detail__image {
	position: relative;
	width: 100%;
}

.p-service-detail__image img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-service-detail__item-inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 70.625rem;
	width: 100%;
}

.p-service-detail__wrapper {
	background: rgba(28, 75, 144, 0.06);
	margin-top: 0.625rem;
	padding: 2.5rem 1.25rem;
}

.p-service-detail__card-head {
	align-items: center;
	display: flex;
	justify-content: center;
}

.p-service-detail__card-title {
	font-size: 1.5rem;
}

.p-service-detail__card-list {
	grid-gap: 1.25rem;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: repeat(1, 1fr);
	margin-left: auto;
	margin-right: auto;
	margin-top: 1.25rem;
}

.sub-card-head {
	align-items: center;
	color: #0d1036;
	display: flex;
	font-size: 1.125rem;
	font-weight: 700;
	gap: 8px;
	margin-bottom: 7px;
}

.sub-tag {
	background: #1c4b90;
	border-radius: 1px;
	color: #fff;
	font-size: 0.9375rem;
	font-weight: 700;
	letter-spacing: 0.15em;
	padding: 2px 7px;
}

.sub-pills {
	display: flex;
	flex-direction: column;
}

.sub-pill {
	color: #0d1036;
	font-size: 1rem;
	letter-spacing: 0.05em;
	line-height: 1.5;
	padding: 0.1875rem 0.625rem;
	padding-left: 0.625rem;
	position: relative;
}

.sub-pill::before {
	background: linear-gradient(180deg, #1c4b90 0%, rgba(28, 75, 144, 0.35) 100%);
	border-radius: 62.4375rem;
	content: "";
	height: 0.375rem;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 0.375rem;
}

.p-service-detail__item + .p-service-detail__item {
	margin-top: 3.5rem;
}

.p-common-lists__list {
	border-bottom: 1px solid #ddd;
	padding: 1.25rem 0;
}

.p-common-lists__list dt {
	font-weight: bold;
}

.p-common-lists__list dd {
	margin-top: 0.625rem;
}

/* =========================
   Company Access
========================= */

.p-company-access {
	margin-top: 3.5rem;
}

.p-company-access__head {
	margin-bottom: 1.5rem;
}

.p-company-access__title {
	color: #1c4b90;
	font-family: "Poppins", sans-serif;
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	line-height: 1;
	margin: 0;
}

.p-company-access__sub {
	color: #1c4b90;
	font-size: 1rem;
	font-weight: 700;
	margin: 0.5rem 0 0;
}

.p-company-access__map {
	border-radius: 1rem;
	box-shadow: 0 0.875rem 2rem rgba(0, 0, 0, 0.12);
	overflow: hidden;
}

.p-company-access__map iframe {
	display: block;
	height: 20rem;
	width: 100%;
}

.p-company-access__address {
	color: #333;
	font-size: 0.9375rem;
	line-height: 1.8;
	margin-bottom: 0;
	margin-top: 1rem;
}

/* =========================
   Company Info
========================= */

.p-company-info {
	margin-top: 2.5rem;
}

.p-company-info__title {
	color: #1c4b90;
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.4;
	margin: 0 0 1.5rem;
}

.p-company-info__list {
	margin: 0;
}

.p-company-info__row {
	grid-gap: 0.625rem;
	border-bottom: 1px solid rgba(28, 75, 144, 0.12);
	display: grid;
	gap: 0.625rem;
	grid-template-columns: 1fr;
	padding: 1.125rem 0;
}

.p-company-info__term {
	color: #1c4b90;
	font-size: 0.9375rem;
	font-weight: 700;
	line-height: 1.6;
	margin: 0;
}

.p-company-info__desc {
	color: #333;
	font-size: 0.9375rem;
	line-height: 1.9;
	margin: 0;
}

/* =========================
   MV
========================= */

.p-company-mv {
	background: #000;
	color: #fff;
	min-height: 11.25rem;
	overflow: hidden;
	position: relative;
}

.p-company-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-company-mv__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.58);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-company-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.76) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-company-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-company-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.125rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-company-mv__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 11.25rem;
	padding-bottom: 1.5rem;
	padding-top: 6.25rem;
	position: relative;
	z-index: 1;
}

.p-company-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-company-mv__title {
	font-size: max(1.75rem, min(6vw, 3rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
}

/* =========================
   Company
========================= */

.p-company {
	padding: 2rem 0 4.5rem;
}

.p-company__inner {
	max-width: 61.25rem;
}

.p-company__lead {
	margin-bottom: 2.5rem;
}

.p-company__lead-text {
	color: #1c4b90;
	font-size: 1rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
	margin: 0;
}

/* =========================
   CONTACT CONFIRM PAGE
========================= */

.p-contact-confirm {
	background: linear-gradient(180deg, #f8fafc 0%, #fff 42%, #f8fafc 100%);
	padding: 3.5rem 0 5rem;
	position: relative;
}

.p-contact-confirm__inner {
	max-width: 57.5rem;
}

.p-contact-confirm__header {
	margin-bottom: 1.75rem;
	text-align: center;
}

.p-contact-confirm__title {
	color: rgba(28, 75, 144, 0.68);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.24em;
	line-height: 1;
	margin: 0;
}

.p-contact-confirm__lead {
	color: #1c4b90;
	font-size: max(1.375rem, min(5vw, 2rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.4;
	margin: 0.875rem 0 0;
}

.p-contact-confirm__note {
	color: #475569;
	font-size: 0.875rem;
	letter-spacing: 0.03em;
	line-height: 1.8;
	margin: 0.75rem auto 0;
	max-width: 35rem;
}

.p-contact-confirm__form {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 0.75rem;
	box-shadow: 0 1.25rem 2.5rem rgba(15, 23, 42, 0.05), 0 0.375rem 0.875rem rgba(15, 23, 42, 0.03);
	overflow: hidden;
	padding: 1.75rem 1.25rem;
	position: relative;
}

.p-contact-confirm__form::before {
	background: linear-gradient(90deg, #1c4b90 0%, rgba(28, 75, 144, 0.28) 100%);
	content: "";
	height: 0.1875rem;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

/* =========================
   CF7 CONFIRM LAYOUT TUNE
========================= */

.p-contact-confirm__form .c-contact-confirm {
	display: flex;
	flex-direction: column;
	gap: 1.125rem;
}

.p-contact-confirm__form .c-contact-confirm__item {
	grid-gap: 0.625rem;
	background: linear-gradient(180deg, #fff 0%, #f8fafc 100%);
	border: 1px solid #e5e7eb;
	border-radius: 0.625rem;
	display: grid;
	gap: 0.625rem;
	padding: 1rem 0.875rem;
}

.p-contact-confirm__form .c-contact-confirm__label {
	color: #1c4b90;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.6;
}

.p-contact-confirm__form .c-contact-confirm__value {
	color: #334155;
	font-size: 0.875rem;
	letter-spacing: 0.03em;
	line-height: 1.9;
	word-break: break-word;
}

.p-contact-confirm__form .c-contact-confirm__value .wpcf7-list-item {
	margin: 0;
}

.p-contact-confirm__form .c-contact-confirm__actions {
	display: flex;
	flex-direction: column-reverse;
	gap: 0.875rem;
	margin-top: 0.625rem;
}

.p-contact-confirm__form .c-contact-confirm__back-btn,
.p-contact-confirm__form .c-contact-confirm__submit-btn {
	-webkit-text-decoration: none;
	align-items: center;
	border-radius: 62.4375rem;
	display: inline-flex;
	font-size: 0.9375rem;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.08em;
	line-height: 1;
	min-height: 3.5rem;
	padding: 1rem 1.5rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, opacity 0.25s ease, background-color 0.25s ease, color 0.25s ease;
	width: 100%;
}

.p-contact-confirm__form .c-contact-confirm__back-btn {
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.2);
	color: #1c4b90;
}

.p-contact-confirm__form .c-contact-confirm__submit-btn {
	background: #1c4b90;
	border: 1px solid #1c4b90;
	box-shadow: 0 0.625rem 1.5rem rgba(28, 75, 144, 0.14);
	color: #fff;
}

.p-contact-confirm__form .c-contact-confirm__back-btn:hover,
.p-contact-confirm__form .c-contact-confirm__submit-btn:hover {
	transform: translateY(-0.125rem);
}

.p-contact-confirm__form .c-contact-confirm__back-btn:hover {
	background: rgba(28, 75, 144, 0.03);
}

.p-contact-confirm__form .c-contact-confirm__submit-btn:hover {
	opacity: 0.92;
}

/* =========================
   SENDING STATE
========================= */

.p-contact-confirm__form.is-submitting .wpcf7-form {
	opacity: 0;
	pointer-events: none;
}

.p-contact-confirm__form.is-submitting::after {
	background: rgba(255, 255, 255, 0.96);
	bottom: 0;
	content: "";
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 10;
}

.p-contact-confirm__form.is-submitting .p-contact-confirm__loading {
	opacity: 1;
	visibility: visible;
}

.p-contact-confirm__loading {
	align-items: center;
	bottom: 0;
	display: flex;
	flex-direction: column;
	gap: 1.125rem;
	justify-content: center;
	left: 0;
	opacity: 0;
	position: absolute;
	right: 0;
	top: 0;
	transition: opacity 0.25s ease, visibility 0.25s ease;
	visibility: hidden;
	z-index: 11;
}

.p-contact-confirm__loading-text {
	color: #1c4b90;
	font-size: 0.9375rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	margin: 0;
}

.p-contact-confirm__loading-dots {
	align-items: center;
	display: inline-flex;
	gap: 0.5rem;
}

.p-contact-confirm__loading-dot {
	animation: contactConfirmLoading 1.2s infinite ease-in-out;
	background: rgba(28, 75, 144, 0.28);
	border-radius: 50%;
	height: 0.5rem;
	width: 0.5rem;
}

.p-contact-confirm__loading-dot:nth-child(2) {
	animation-delay: 0.15s;
}

.p-contact-confirm__loading-dot:nth-child(3) {
	animation-delay: 0.3s;
}

/* =========================
   CF7 MESSAGE HIDE
========================= */

.p-contact-confirm__form .wpcf7-response-output {
	display: none !important;
}

.p-contact-confirm__form .wpcf7-spinner {
	display: none !important;
}

.p-contact-confirm__form.is-submitting input[type=submit],
.p-contact-confirm__form.is-submitting button[type=submit] {
	pointer-events: none;
}

/* =========================
   MV
========================= */

.p-contact-mv {
	background: #000;
	color: #fff;
	min-height: 11.25rem;
	overflow: hidden;
	position: relative;
}

.p-contact-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-contact-mv__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.58);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-contact-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.76) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-contact-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-contact-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.125rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-contact-mv__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 11.25rem;
	padding-bottom: 1.5rem;
	padding-top: 6.25rem;
	position: relative;
	z-index: 1;
}

.p-contact-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-contact-mv__title {
	font-size: max(1.75rem, min(6vw, 3rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
}

/* =========================
   CONTACT PAGE
========================= */

.p-contact-page {
	background: linear-gradient(180deg, #f8fafc 0%, #fff 42%, #f8fafc 100%);
	padding: 3.5rem 0 5rem;
	position: relative;
}

.p-contact-page__inner {
	max-width: 57.5rem;
}

.p-contact-page__head {
	text-align: center;
}

.p-contact-page__sub {
	color: rgba(28, 75, 144, 0.68);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.24em;
	line-height: 1;
	margin: 0;
}

.p-contact-page__title {
	color: #1c4b90;
	font-size: max(1.875rem, min(7vw, 3.25rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.3;
	margin: 0.875rem 0 0;
}

.p-contact-page__lead {
	color: #1c4b90;
	font-size: max(1.125rem, min(4vw, 1.75rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.8;
	margin: 1.375rem 0 0;
}

.p-contact-page__text {
	color: #475569;
	font-size: 0.9375rem;
	letter-spacing: 0.04em;
	line-height: 2;
	margin: 1.125rem auto 0;
	max-width: 47.5rem;
}

.p-contact-page__info {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	margin-top: 2.25rem;
}

.p-contact-page__info-item {
	-webkit-backdrop-filter: blur(0.625rem);
	backdrop-filter: blur(0.625rem);
	background: rgba(255, 255, 255, 0.88);
	border: 1px solid #e2e8f0;
	border-radius: 1rem;
	padding: 1.25rem 1.375rem;
}

.p-contact-page__info-label {
	color: rgba(28, 75, 144, 0.7);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin: 0;
}

.p-contact-page__info-text {
	color: #1f2937;
	font-size: 0.9375rem;
	line-height: 1.9;
	margin: 0.625rem 0 0;
}

.p-contact-page__form-wrap {
	background: #fff;
	border: 1px solid #e2e8f0;
	border-radius: 0.75rem;
	box-shadow: 0 1.25rem 2.5rem rgba(15, 23, 42, 0.05), 0 0.375rem 0.875rem rgba(15, 23, 42, 0.03);
	margin-top: 2.25rem;
	padding: 1.75rem 1.25rem;
}

.p-contact-page__form-head {
	margin-bottom: 1.75rem;
	text-align: center;
}

.p-contact-page__form-title {
	color: #1c4b90;
	font-size: 1.25rem;
	font-weight: 700;
	line-height: 1.5;
	margin: 0;
}

.p-contact-page__form-meta {
	color: #64748b;
	font-size: 0.8125rem;
	line-height: 1.8;
	margin: 0.625rem 0 0;
}

.p-contact-page__notes {
	margin-top: 1.75rem;
	padding: 1.25rem 1.25rem 0;
}

.p-contact-page__notes-title {
	color: #1c4b90;
	font-size: 1rem;
	font-weight: 700;
	margin: 0;
}

.p-contact-page__notes-list {
	color: #475569;
	font-size: 0.875rem;
	line-height: 2;
	margin: 0.875rem 0 0;
	padding-left: 1.4em;
}

.p-contact {
	padding-top: 3.75rem;
}

.p-contact__inner {
	margin: 0 auto;
	width: 100%;
}

.p-contact__visual {
	background-image: url("../images/common/contact_bg.png"); /* 差し替え */
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding: 3.75rem 2.5rem;
	position: relative;
}

.p-contact__visual::before {
	background: rgba(28, 75, 144, 0.55);
	bottom: 0;
	content: "";
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 0;
}

.p-contact__visual::after {
	display: none;
}

.p-contact__overlay {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 0;
}

.p-contact__content {
	color: #fff;
	position: relative;
	text-align: center;
	z-index: 1;
}

.p-contact__title {
	font-size: 3rem;
	font-weight: 700;
	margin: 0;
}

.p-contact__subtitle {
	color: #c59c63;
	font-size: 1.125rem;
	font-weight: 600;
	margin-top: 0.625rem;
}

.p-contact__actions {
	margin-top: 1.25rem;
}

.p-contact__action {
	align-items: center;
	color: #fff;
	display: flex;
	font-weight: 600;
	gap: 0.5rem;
	justify-content: center;
}

.p-contact__action + .p-contact__action {
	margin-top: 1.25rem;
}

.p-contact__icon {
	align-items: center;
	background: rgba(255, 255, 255, 0.15);
	border-radius: 50%;
	display: flex;
	font-size: 1.125rem;
	height: 2.75rem;
	justify-content: center;
	width: 2.75rem;
}

.p-contact__telBox {
	background: #fff;
	color: #333;
	margin-top: 1.25rem;
	max-width: 43.75rem;
	padding: 0.625rem;
}

.p-contact__telLeft {
	align-items: center;
	display: flex;
	justify-content: center;
}

.p-contact__telIcon {
	display: inline-block;
	height: 1.75rem;
	margin-right: 0.625rem;
	padding-top: 0.3125rem;
	width: 1.75rem;
}

.p-contact__tel {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
}

.p-contact__telRight {
	text-align: center;
}

.p-contact__telTime {
	font-size: 0.875rem;
	margin: 0;
}

.p-contact__telHours {
	font-size: 0.875rem;
}

.p-contact__head {
	margin-bottom: 3rem;
	text-align: center;
}

.p-contact__sub {
	color: #1c4b90;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.2em;
}

.p-contact__info-title {
	color: #1c4b90;
	font-size: max(32px, min(6vw, 60px));
	font-weight: 700;
	margin-top: 0.75rem;
}

.p-contact__lead {
	color: #475569;
	font-size: 1rem;
	line-height: 1.9;
	margin-top: 1rem;
}

.p-contact__form {
	margin: auto;
	max-width: 720px;
}

.p-footer-nav__items {
	display: flex;
	flex-wrap: wrap;
	gap: 1.25rem;
}

.p-footer-nav__item a {
	color: #fff;
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1.25;
}

.p-footer {
	background: #0d1036;
	color: #fff;
	padding: 4rem 0 0.625rem;
}

/* brand */

.p-footer__brand {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 1.125rem;
	justify-content: center;
}

.p-footer__logo {
	display: inline-block;
	padding: 1.125rem;
	width: 10rem;
}

.p-footer__logo img {
	display: block;
	height: auto;
	width: 100%;
}

/* sns */

.p-footer__sns {
	display: flex;
	gap: 0.875rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.p-footer__snsLink {
	-webkit-text-decoration: none;
	align-items: center;
	display: inline-flex;
	height: 2.5rem;
	justify-content: center;
	text-decoration: none;
	width: 2.5rem;
}

.p-footer__snsLink img {
	display: block;
	height: 2.5rem;
	width: 2.5rem;
}

/* nav */

.p-footer__groupTitle {
	font-weight: 700;
	margin-bottom: 14px;
}

.p-footer__list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.p-footer__item + .p-footer__item {
	margin-top: 0.375rem;
}

.p-footer__item:last-child {
	margin-bottom: 0;
}

.p-footer__item--sub {
	padding-left: 0.625rem;
}

.p-footer__item a {
	color: #fff;
	display: block;
	padding: 0.3125rem 0;
	position: relative;
	transition: opacity 0.25s ease, color 0.25s ease;
}

.p-footer__item a span {
	display: inline-block;
	position: relative;
}

.p-footer__item a span::after {
	background-color: currentColor;
	bottom: 0;
	content: "";
	height: 0.0625rem;
	left: 0;
	position: absolute;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.25s ease;
	width: 100%;
}

.p-footer__item a:hover span::after {
	transform: scaleX(1);
}

.p-footer__copy {
	margin-top: 1.25rem;
	text-align: center;
}

.p-footer__copy-text {
	color: #fff;
	display: block;
	font-size: 0.875rem;
	opacity: 0.85;
}

.p-footer__nav {
	margin-top: 1.25rem;
}

.p-form {
	letter-spacing: 0.05em;
}

.p-form__radio {
	display: flex;
	flex-direction: column;
	gap: 0.3125rem;
	margin-top: 0.3125rem;
}

.p-form dl:not(:first-child) {
	margin-top: 1.875rem;
}

.p-form__item dt {
	font-size: 0.9375rem;
	font-weight: 600;
	line-height: 2;
}

.p-form__item dt span {
	color: #391e88;
	font-size: 0.75rem;
	margin-left: 0.625rem;
}

.p-form__item dt span.p-form__tel-info {
	color: #333;
	font-size: 0.75rem;
	margin-left: 0;
}

.p-form__btn {
	margin-top: 3.125rem;
	text-align: center;
}

.p-header {
	background-color: transparent;
	height: 5rem;
	transition: background-color 0.3s ease, -webkit-backdrop-filter 0.3s ease;
	transition: background-color 0.3s ease, backdrop-filter 0.3s ease;
	transition: background-color 0.3s ease, backdrop-filter 0.3s ease, -webkit-backdrop-filter 0.3s ease;
}

.p-header.is-color {
	-webkit-backdrop-filter: blur(10px);
	backdrop-filter: blur(10px);
	background-color: rgba(255, 255, 255, 0.65);
}

.p-header__inner {
	align-items: center;
	display: flex;
	height: inherit;
	justify-content: space-between;
	padding-left: 0.9375rem;
}

.p-header__logo {
	height: inherit;
	max-width: 4.625rem;
	width: 100%;
	z-index: 1000;
}

.p-header__logo a {
	align-items: center;
	display: flex;
	height: inherit;
}

.p-header__logo img {
	-o-object-fit: contain;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

/* =========================
   PC nav
========================= */

.p-header__nav {
	display: none;
}

/* 上段 utility */

.p-header__utility {
	align-items: center;
	display: flex;
	gap: 0.75rem;
	justify-content: flex-end;
}

.p-header__utility-item {
	height: auto;
}

.p-header__utility-item a {
	-webkit-text-decoration: none;
	align-items: center;
	border-radius: 62.4375rem;
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.03em;
	line-height: 1;
	min-height: 2.5rem;
	padding: 0 1rem;
	text-decoration: none;
	transition: transform 0.25s ease, opacity 0.25s ease, background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.p-header__utility-item a:hover {
	transform: translateY(-0.0625rem);
}

/* 電話 */

.p-header__utility-item--tel a {
	background: transparent;
	border-radius: 0;
	color: #fff;
	font-size: 1rem;
	font-weight: 600;
	min-height: auto;
	padding-left: 0;
	padding-right: 0;
	position: relative;
}

.p-header__utility-item--tel a::before {
	background-image: url(../images/common/tell-icon-w.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	flex-shrink: 0;
	height: 1.25rem;
	margin-right: 0.5rem;
	position: relative;
	width: 1.25rem;
}

.p-header__utility-item--tel a:hover {
	opacity: 0.8;
	transform: none;
}

.p-header.is-color .p-header__utility-item--tel a {
	color: #1c4b90;
}

.p-header.is-color .p-header__utility-item--tel a::before {
	background-image: url(../images/common/tel-icon-n.png);
}

/* LINE */

.p-header__utility-item--line a {
	background-color: #19b84f;
	box-shadow: 0 0.25rem 0.875rem rgba(25, 184, 79, 0.24);
	color: #fff;
}

.p-header__utility-item--line a::before {
	background-image: url(../images/common/line-icon.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	flex-shrink: 0;
	height: 1.25rem;
	margin-right: 0.5rem;
	position: relative;
	width: 1.25rem;
}

/* お問い合わせ */

.p-header__utility-item--contact a {
	background-color: #fff;
	box-shadow: 0 0.25rem 0.875rem rgba(0, 0, 0, 0.08);
	color: #1c4b90;
}

.p-header__utility-item--contact a::before {
	background-image: url(../images/common/mail-icon.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	flex-shrink: 0;
	height: 1.25rem;
	margin-right: 0.5rem;
	position: relative;
	width: 1.25rem;
}

/* 下段 nav */

.p-header__nav-list {
	align-items: center;
	display: flex;
	gap: 1.75rem;
	justify-content: flex-end;
}

.p-header__nav-item {
	height: auto;
}

.p-header__nav-item a {
	align-items: center;
	color: #fff;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 500;
	height: auto;
	line-height: 1;
	padding: 0 1rem;
	position: relative;
	transition: opacity 0.25s ease, color 0.25s ease;
}

.p-header__nav-item a::after {
	background-color: currentColor;
	bottom: -0.5rem;
	content: "";
	height: 0.0625rem;
	left: 0;
	position: absolute;
	transform: scaleX(0);
	transform-origin: left center;
	transition: transform 0.25s ease;
	width: 100%;
}

.p-header__nav-item a:hover::after {
	transform: scaleX(1);
}

.p-header__nav-item a.is-scroll {
	color: #fff;
}

.p-header.is-color .p-header__nav-item a {
	color: #0d1036;
}

/* =========================
   Hamburger
========================= */

.p-header__hamburger {
	background: transparent;
	border: none;
	cursor: pointer;
	height: inherit;
	margin: 0;
	outline: none;
	padding: 0;
	position: relative;
	transition: 0.3s;
	width: 2.5rem;
	z-index: 999;
}

.p-header__hamburger.is-open {
	background-color: transparent;
}

.p-header__hamburger span {
	background-color: #fff;
	display: block;
	height: 1px;
	left: 50%;
	position: relative;
	transform: translateX(-50%);
	transition: 0.5s;
	width: 1.5625rem;
}

.p-header.is-color .p-header__hamburger span {
	background-color: #0d1036;
}

.p-header__hamburger.is-open span {
	background-color: #1c4b90;
}

.p-header__hamburger span:nth-of-type(1) {
	top: -0.5rem;
}

.p-header__hamburger span:nth-of-type(2) {
	top: 0;
}

.p-header__hamburger span:nth-of-type(3) {
	top: 0.5rem;
}

.p-header__hamburger.is-open span:nth-of-type(1) {
	top: 0;
	transform: translateX(-50%) rotate(45deg);
}

.p-header__hamburger.is-open span:nth-of-type(2) {
	opacity: 0;
}

.p-header__hamburger.is-open span:nth-of-type(3) {
	top: -0.125rem;
	transform: translateX(-50%) rotate(-45deg);
}

/* =========================
   Drawer
========================= */

.p-header__drawer {
	background-color: #fff;
	bottom: 0;
	display: none;
	height: 100vh;
	left: 0;
	overflow-y: scroll;
	padding: 7.5rem 0;
	position: absolute;
	right: 0;
	scrollbar-width: none;
	top: 0;
	width: 100%;
	z-index: 900;
}

.p-header__drawer::-webkit-scrollbar {
	display: none;
}

.p-header__drawer-nav {
	margin: auto;
	padding: 0 0.9375rem;
	width: 100%;
}

.p-header__drawer-item a {
	border-bottom: 1px solid #1c4b90;
	color: #1c4b90;
	display: block;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.3;
	padding: 0.9375rem 0;
}

.p-header__drawer-item {
	border-bottom: 1px solid rgba(28, 75, 144, 0.5);
}

/* CTA */

.p-header__drawer-cta {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1.75rem;
}

.p-header__drawer-cta-button {
	-webkit-text-decoration: none;
	align-items: center;
	border-radius: 62.4375rem;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.03em;
	line-height: 1;
	min-height: 3.25rem;
	padding: 0.75rem 1.125rem;
	text-decoration: none;
	transition: transform 0.25s ease, opacity 0.25s ease;
}

.p-header__drawer-cta-button:active {
	transform: scale(0.98);
}

.p-header__drawer-cta-button--contact {
	background-color: #1c4b90;
	color: #fff;
}

.p-header__drawer-cta-button--contact::before {
	background-image: url(../images/common/mail-icon.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	flex-shrink: 0;
	height: 1.25rem;
	margin-right: 0.5rem;
	position: relative;
	width: 1.25rem;
}

.p-header__drawer-cta-button--line {
	background-color: #19b84f;
	color: #fff;
}

.p-header__drawer-cta-button--line::before {
	background-image: url(../images/common/line-icon.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	flex-shrink: 0;
	height: 1.25rem;
	margin-right: 0.5rem;
	position: relative;
	width: 1.25rem;
}

.p-header__drawer-tel {
	-webkit-text-decoration: none;
	align-items: center;
	border: 1px solid rgba(28, 75, 144, 0.24);
	border-radius: 62.4375rem;
	color: #1c4b90;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 3rem;
	padding: 0.625rem 1rem;
	text-decoration: none;
}

.p-header__drawer-tel::before {
	background-image: url(../images/common/tell_icon.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	flex-shrink: 0;
	height: 1.25rem;
	margin-right: 0.5rem;
	position: relative;
	width: 1.25rem;
}

/* =========================
   Instagram
========================= */

.p-instagram__button {
	display: flex;
	justify-content: center;
	margin-top: 2.5rem;
}

/* ======================================
   Loading
====================================== */

.p-loading {
	align-items: center;
	background: #ffffff;
	bottom: 0;
	display: grid;
	justify-items: center;
	left: 0;
	opacity: 1;
	place-items: center;
	position: fixed;
	right: 0;
	top: 0;
	transition: opacity 0.6s ease, visibility 0.6s ease;
	visibility: visible;
	will-change: transform, opacity;
	z-index: 9999;
}

.p-loading.is-hidden {
	opacity: 0;
	pointer-events: none;
	visibility: hidden;
}

.p-loading__logo {
	aspect-ratio: 400.38/409;
	position: relative;
	width: 100%;
}

.p-loading__parts,
.p-loading__final {
	bottom: 0;
	left: 50%;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translate(-50%, -50%);
}

.p-loading__parts {
	z-index: 2;
}

.p-loading__part {
	display: block;
	opacity: 0;
	transform: translateY(10px);
	will-change: transform, opacity;
}

.p-loading__circle-outline {
	left: 50%;
	opacity: 1;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	z-index: 5;
}

.p-loading__circle-outline svg {
	display: block;
	height: min(250px, 67vw);
	transform: translate(10px, 0%) scale(0.96);
	transform-origin: center center;
	width: min(250px, 67vw);
}

.p-loading__circle-path {
	fill: none;
	stroke: #1d2087;
	stroke-width: 2;
	stroke-linecap: round;
	stroke-linejoin: round;
	stroke-dasharray: 4000;
	stroke-dashoffset: 4000;
}

.p-loading__kabu-block {
	grid-column-gap: 1.8px;
	-moz-column-gap: 1.8px;
	grid-row-gap: 4.3px;
	column-gap: 1.8px;
	display: grid;
	grid-template-columns: auto auto;
	grid-template-rows: auto auto;
	left: -46.80469px;
	position: absolute;
	row-gap: 4.3px;
	top: 49.578px;
	z-index: 3;
}

.p-loading__kanji-block {
	align-items: center;
	display: flex;
	gap: 0;
	left: 7.30208px;
	position: absolute;
	top: 27.83333px;
	z-index: 3;
}

.p-loading__english-block {
	align-items: center;
	display: flex;
	gap: 2.7px;
	left: 23.5781px;
	position: absolute;
	top: 106.008px;
	z-index: 3;
}

.p-loading__kabu-block .p-loading__part {
	height: 24.48px;
	width: auto;
}

.p-loading__kanji-block .p-loading__part {
	height: 67.68px;
	width: auto;
}

.p-loading__english-block .p-loading__part {
	height: 18.72px;
	width: auto;
}

.p-loading__final {
	display: block;
	height: min(250px, 67vw);
	left: 50%;
	opacity: 0;
	top: 50%;
	transform: translate(-50%, -50%);
	width: min(250px, 67vw);
	will-change: transform, opacity;
	z-index: 4;
}

body.is-loading {
	overflow: hidden;
}

.p-loading__inner {
	width: min(82vw, 520px);
	will-change: transform, opacity;
}

/* =========================
   Lower MV
========================= */

.p-lower-mv {
	background-color: #333;
	color: #fff;
	min-height: 13.75rem;
	overflow: hidden;
	position: relative;
}

.p-lower-mv::after {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.5rem;
	content: "";
	height: 0.0625rem;
	opacity: 0.7;
	position: absolute;
	right: -10%;
	transform: rotate(-6deg);
	width: 60%;
}

.p-lower-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-lower-mv__bg-img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.06) brightness(0.72);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-lower-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.78) 0%, rgba(0, 0, 0, 0.44) 45%, rgba(0, 0, 0, 0.72) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.08) 0%, rgba(0, 0, 0, 0.54) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-lower-mv__glow {
	background: radial-gradient(circle at 50% 40%, rgba(120, 180, 255, 0.18) 0%, rgba(120, 180, 255, 0.08) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-lower-mv__grid {
	background-image: linear-gradient(rgba(255, 255, 255, 0.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px);
	background-size: 1.75rem 1.75rem;
	bottom: 0;
	left: 0;
	opacity: 0.12;
	position: absolute;
	right: 0;
	top: 0;
}

.p-lower-mv__inner {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: inherit;
	padding-bottom: 1.625rem;
	padding-top: 6.875rem;
	position: relative;
	z-index: 1;
}

.p-lower-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
	position: relative;
	z-index: 2;
}

.p-lower-mv__title {
	color: #fff;
	font-size: max(1.875rem, min(7vw, 3.5rem));
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.75rem;
	position: relative;
	text-shadow: 0 0.25rem 1.125rem rgba(0, 0, 0, 0.35);
	z-index: 2;
}

.p-lower-mv__bg-text {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(255, 255, 255, 0.08);
	font-family: "Poppins", sans-serif;
	font-size: max(3.5rem, min(13vw, 10rem));
	font-weight: 800;
	left: 0;
	letter-spacing: 0.04em;
	line-height: 0.9;
	margin: 0;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-44%);
	user-select: none;
	white-space: nowrap;
	z-index: 1;
}

.p-media__content {
	margin-top: 1.75rem;
}

.p-media__wrapper {
	margin-top: 2.5rem;
}

.p-media__list {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(1, 1fr);
}

.p-media__item {
	height: 100%;
}

.p-media__button {
	display: flex;
	justify-content: center;
	margin-top: 2.5rem;
}

.p-media__empty {
	color: rgba(0, 0, 0, 0.5);
	font-size: 1rem;
	line-height: 1.8;
	padding: 2.5rem 0;
	text-align: center;
}

/* =========================
   MESSAGE
========================= */

.p-message {
	position: relative;
}

.p-message__wrapper {
	align-items: center;
	display: flex;
	gap: 2rem;
}

.p-message__left {
	flex: 1 1 58%;
	min-width: 0;
}

.p-message__right {
	flex: 0 0 38%;
	min-width: 0;
}

.p-message__head {
	max-width: 38.75rem;
}

.p-message__content {
	font-size: 1rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.7;
	margin-top: 1.375rem;
	max-width: 38.75rem;
}

.p-message__content-text:not(:first-child) {
	margin-top: 0.3125rem;
}

.p-message__content-text:last-child {
	margin-bottom: 0;
}

.p-message__button {
	margin-top: 1.375rem;
}

/* =========================
   左側時間差
========================= */

.js-message-step {
	opacity: 0;
	transform: translateY(1.5rem);
	transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: opacity, transform;
}

.js-message-step.is-inview {
	opacity: 1;
	transform: translateY(0);
}

.js-message-step[data-delay="1"] {
	transition-delay: 0.12s;
}

.js-message-step[data-delay="2"] {
	transition-delay: 0.24s;
}

/* =========================
   カードエリア
========================= */

.p-message__cards {
	aspect-ratio: 1/1;
	margin-left: auto;
	margin-right: auto;
	max-width: 21.25rem;
	position: relative;
	width: 100%;
}

/* 装飾フレーム */

.p-message__cards::before {
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 0.5rem;
	content: "";
	height: 96%;
	left: 6%;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: 8%;
	transform: rotate(-4deg) scale(0.96);
	transform-origin: center;
	transition: opacity 0.8s ease 0.18s, transform 1s cubic-bezier(0.16, 1, 0.3, 1) 0.18s;
	width: 96%;
	z-index: 0;
}

/* 青グロー */

.p-message__cards::after {
	background: rgba(64, 134, 255, 0.18);
	border-radius: 50%;
	bottom: -4%;
	content: "";
	filter: blur(2.25rem);
	height: 42%;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: -4%;
	transition: opacity 0.9s ease 0.28s;
	width: 42%;
	z-index: 0;
}

.js-message-cards.is-inview::before {
	opacity: 1;
	transform: rotate(-4deg) scale(1);
}

.js-message-cards.is-inview::after {
	opacity: 1;
}

/* =========================
   カード本体
========================= */

.p-message__card {
	border-radius: 0.375rem;
	bottom: 0;
	left: 0;
	opacity: 0;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 0;
	transform-origin: center center;
	transition: opacity 0.9s ease, transform 0.9s cubic-bezier(0.16, 1, 0.3, 1), box-shadow 0.4s ease;
	will-change: transform, opacity;
}

.p-message__card::before {
	background: #1c4b90;
	border-radius: 0.375rem;
	bottom: -0.5rem;
	content: "";
	left: 0.5rem;
	position: absolute;
	right: -0.5rem;
	top: 0.5rem;
	z-index: 0;
}

.p-message__card img {
	-o-object-fit: cover;
	aspect-ratio: 1/1;
	display: block;
	height: 100%;
	object-fit: cover;
	position: relative;
	transform: scale(1.04);
	transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1);
	width: 100%;
	z-index: 1;
}

/* 初期位置 */

.p-message__card--left {
	transform: translate3d(0.375rem, 0.75rem, 0) rotate(-2deg) scale(0.97);
	z-index: 1;
}

.p-message__card--center {
	box-shadow: 0 0.5rem 1.25rem rgba(0, 0, 0, 0.12);
	transform: translate3d(0, 0.875rem, 0) rotate(0deg) scale(0.99);
	z-index: 3;
}

.p-message__card--right {
	transform: translate3d(-0.375rem, 0.75rem, 0) rotate(2deg) scale(0.97);
	z-index: 2;
}

/* inview後 */

.js-message-cards.is-inview .p-message__card--left {
	opacity: 1;
	transform: translate3d(-1.125rem, 0.875rem, 0) rotate(-4deg) scale(0.96);
	transition-delay: 0.08s;
}

.js-message-cards.is-inview .p-message__card--center {
	opacity: 1;
	transform: translate3d(0, 0, 0) rotate(0deg) scale(1);
	transition-delay: 0.24s;
}

.js-message-cards.is-inview .p-message__card--right {
	opacity: 1;
	transform: translate3d(1.125rem, 0.875rem, 0) rotate(4deg) scale(0.96);
	transition-delay: 0.16s;
}

.js-message-cards.is-inview .p-message__card img {
	transform: scale(1);
}

/* hover */

.p-message__cards:hover .p-message__card--center {
	transform: translate3d(0, -0.25rem, 0) rotate(0deg) scale(1.01);
}

.p-message__cards:hover .p-message__card--center img {
	transform: scale(1.02);
}

/* PC微調整 */

/* =========================
   SP
========================= */

.p-message__content-image {
	align-items: center;
	display: flex;
	justify-content: right;
}

.p-message__content-image img {
	height: auto;
	width: 40%;
}

/* =========================
   MV
========================= */

.p-movie-mv {
	background: #000;
	color: #fff;
	min-height: 11.25rem;
	overflow: hidden;
	position: relative;
}

.p-movie-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-movie-mv__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.58);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-movie-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.76) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-movie-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-movie-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.125rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-movie-mv__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 11.25rem;
	padding-bottom: 1.5rem;
	padding-top: 6.25rem;
	position: relative;
	z-index: 1;
}

.p-movie-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-movie-mv__title {
	font-size: max(1.75rem, min(6vw, 3rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
}

/* =========================
   Archive
========================= */

.p-movie-archive {
	padding: 2rem 0 4.5rem;
}

.p-movie-archive__inner {
	max-width: 68.75rem;
}

.p-movie-archive__lead {
	margin-bottom: 2rem;
}

.p-movie-archive__lead-text {
	color: #1c4b90;
	font-size: 1rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
	margin: 0;
}

.p-movie-archive__pagination {
	margin-bottom: 4.5rem;
	margin-top: 3rem;
}

.p-movie-archive__pagination .nav-links {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	justify-content: center;
}

.p-movie-archive__pagination a,
.p-movie-archive__pagination span {
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 2.5rem;
	min-width: 2.5rem;
	padding: 0.5rem 0.75rem;
	text-decoration: none;
	transition: background-color 0.25s ease-in-out, color 0.25s ease-in-out, border-color 0.25s ease-in-out, transform 0.25s ease-in-out;
}

.p-movie-archive__pagination a:hover {
	background: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
}

.p-movie-archive__pagination .current {
	background: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
}

.p-movie-archive__empty {
	color: rgba(28, 75, 144, 0.7);
	padding: 2.5rem 0;
	text-align: center;
}

/* =========================
   Filter
========================= */

.p-movie-filter {
	margin-bottom: 2rem;
}

.p-movie-filter__list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.p-movie-filter__item a {
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.875rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 2.375rem;
	padding: 0.5rem 1rem;
	text-decoration: none;
	transition: background-color 0.25s ease, color 0.25s ease, border-color 0.25s ease, transform 0.25s ease;
}

.p-movie-filter__item a:hover,
.p-movie-filter__item.is-current a {
	background: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
}

/* =========================
   Grid
========================= */

.p-movie-grid {
	grid-gap: 1.25rem;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}

/* =========================
   Single
========================= */

.p-movie-single {
	padding: 2rem 0 4.5rem;
}

.p-movie-single__inner {
	max-width: 53.75rem;
}

.p-movie-single__header {
	border-bottom: 1px solid rgba(28, 75, 144, 0.18);
	padding-bottom: 1.5rem;
}

.p-movie-single__meta {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
}

.p-movie-single__category {
	align-items: center;
	background: #dcd4a2;
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 1.875rem;
	padding: 0.375rem 0.75rem;
}

.p-movie-single__date {
	color: rgba(28, 75, 144, 0.76);
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.4;
}

.p-movie-single__title {
	color: #1c4b90;
	font-size: max(1.6875rem, min(4.2vw, 2.875rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 1.125rem;
}

.p-movie-single__lead {
	color: #333;
	font-size: 1rem;
	line-height: 1.9;
	margin-bottom: 0;
	margin-top: 1rem;
}

.p-movie-single__thumbnail {
	border-radius: 1rem;
	box-shadow: 0 0.875rem 2rem rgba(0, 0, 0, 0.12);
	margin-top: 2.25rem;
	overflow: hidden;
}

.p-movie-single__img {
	-o-object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.p-movie-single__body {
	margin-top: 2.25rem;
}

.p-movie-single__content {
	color: #222;
	font-size: 1.0625rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
}

.p-movie-single__content > *:first-child {
	margin-top: 0;
}

.p-movie-single__content p {
	margin-bottom: 0;
	margin-top: 1.25rem;
}

.p-movie-single__content h2,
.p-movie-single__content h3,
.p-movie-single__content h4 {
	color: #1c4b90;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 1rem;
	margin-top: 2.5rem;
}

.p-movie-single__content h2 {
	font-size: 1.5rem;
	padding-left: 1rem;
	position: relative;
}

.p-movie-single__content h2::before {
	background: linear-gradient(180deg, #1c4b90 0%, rgba(28, 75, 144, 0.35) 100%);
	border-radius: 62.4375rem;
	content: "";
	height: calc(100% - 0.5rem);
	left: 0;
	position: absolute;
	top: 0.25rem;
	width: 0.25rem;
}

.p-movie-single__content ul,
.p-movie-single__content ol {
	margin-top: 1.25rem;
	padding-left: 1.5rem;
}

.p-movie-single__content li + li {
	margin-top: 0.5rem;
}

.p-movie-single__content blockquote {
	background: rgba(28, 75, 144, 0.04);
	border-left: 0.25rem solid #1c4b90;
	margin: 1.75rem 0 0;
	padding: 1.25rem;
}

/* =========================
   Contact CTA
========================= */

.p-movie-contact {
	margin-top: 3rem;
}

.p-movie-contact__box {
	background: linear-gradient(135deg, rgb(7, 20, 64) 0%, rgb(20, 54, 128) 100%);
	border-radius: 1.25rem;
	box-shadow: 0 1rem 2.125rem rgba(0, 0, 0, 0.12);
	color: #fff;
	padding: 1.75rem 1.25rem;
	text-align: center;
}

.p-movie-contact__sub {
	color: rgba(255, 255, 255, 0.72);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	margin: 0;
}

.p-movie-contact__title {
	font-size: max(1.5rem, min(4vw, 2.375rem));
	font-weight: 700;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 0.75rem;
}

.p-movie-contact__text {
	color: rgba(255, 255, 255, 0.9);
	font-size: 0.9375rem;
	line-height: 1.9;
	margin-bottom: 0;
	margin-top: 1rem;
}

.p-movie-contact__buttons {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1.5rem;
}

/* =========================
   Pager
========================= */

.p-movie-pager {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	margin-top: 3rem;
}

.p-movie-pager__link {
	grid-gap: 0.875rem;
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	border-radius: 0.875rem;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	color: #1c4b90;
	display: grid;
	gap: 0.875rem;
	min-height: 6.5rem;
	padding: 0.875rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.p-movie-pager__link:hover {
	border-color: rgba(28, 75, 144, 0.28);
	box-shadow: 0 0.875rem 1.75rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.125rem);
}

.p-movie-pager__link.is-disabled {
	opacity: 0.5;
	pointer-events: none;
}

.p-movie-pager__thumb {
	align-items: center;
	aspect-ratio: 1/1;
	background: rgba(28, 75, 144, 0.04);
	border-radius: 0.625rem;
	display: flex;
	justify-content: center;
	overflow: hidden;
}

.p-movie-pager__img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-movie-pager__img--logo {
	-o-object-fit: contain;
	height: 70%;
	object-fit: contain;
	padding: 0.375rem;
	width: 70%;
}

.p-movie-pager__body {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	min-width: 0;
	text-align: left;
}

.p-movie-pager__label {
	color: rgba(28, 75, 144, 0.56);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
}

.p-movie-pager__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #1c4b90;
	display: -webkit-box;
	font-size: 0.875rem;
	font-weight: 700;
	line-height: 1.6;
	overflow: hidden;
}

.p-movie-pager__icon {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 2.125rem;
	position: relative;
	width: 2.125rem;
}

.p-movie-pager__icon::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 0.4375rem;
}

/* prev */

.p-movie-pager__link--prev {
	grid-template-columns: 2.375rem 1fr 5.25rem;
}

.p-movie-pager__link--prev .p-movie-pager__icon {
	order: 1;
}

.p-movie-pager__link--prev .p-movie-pager__body {
	order: 2;
}

.p-movie-pager__link--prev .p-movie-pager__thumb {
	order: 3;
}

.p-movie-pager__link--prev .p-movie-pager__icon::before {
	transform: translate(-35%, -50%) rotate(-135deg);
}

/* next */

.p-movie-pager__link--next {
	grid-template-columns: 5.25rem 1fr 2.375rem;
}

.p-movie-pager__link--next .p-movie-pager__thumb {
	order: 1;
}

.p-movie-pager__link--next .p-movie-pager__body {
	order: 2;
}

.p-movie-pager__link--next .p-movie-pager__icon {
	order: 3;
}

.p-movie-pager__link--next .p-movie-pager__icon::before {
	transform: translate(-65%, -50%) rotate(45deg);
}

.p-movie-single__video {
	aspect-ratio: 16/9;
	width: 100%;
}

.p-movie-single__video iframe {
	border: none;
	height: 100%;
	width: 100%;
}

/* ===============================
   MV
=============================== */

.p-mv {
	background-color: #333;
	color: #fff;
	min-height: 100vh;
	overflow: hidden;
	position: relative;
	z-index: 1;
}

.p-mv__inner {
	align-items: flex-end;
	display: flex;
	min-height: 100vh;
	padding: 0 1.25rem 4.5rem;
	position: relative;
	z-index: 10;
}

/* ===============================
   Background
=============================== */

.p-mv__bg {
	bottom: 0;
	left: 0;
	overflow: hidden;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 1;
}

.p-mv__bg-base,
.p-mv__bg-blur {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-mv__bg-base {
	z-index: 1;
}

.p-mv__bg-base picture,
.p-mv__bg-blur picture {
	display: block;
	height: 100%;
	width: 100%;
}

.p-mv__bg-base img,
.p-mv__bg-blur img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-mv__bg-base img {
	-o-object-position: center;
	filter: brightness(0.82) contrast(1.08) saturate(1.04);
	object-position: center;
	transform: scale(1.05);
	will-change: transform, filter;
}

.p-mv.is-active .p-mv__bg-base img {
	animation: p-mv-bg-base 9s ease-in-out infinite alternate;
}

.p-mv__bg-blur {
	mix-blend-mode: screen;
	opacity: 0.16;
	z-index: 2;
}

.p-mv__bg-blur img {
	-o-object-position: center;
	filter: blur(20px) brightness(1.02) contrast(1.08);
	object-position: center;
	transform: scale(1.16);
	will-change: transform, opacity, filter;
}

.p-mv.is-active .p-mv__bg-blur img {
	animation: p-mv-bg-blur 7.5s ease-in-out infinite alternate;
}

.p-mv__particles {
	bottom: 0;
	height: 100%;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
	z-index: 3;
}

.p-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.84) 0%, rgba(0, 0, 0, 0.48) 35%, rgba(0, 0, 0, 0.18) 68%, rgba(0, 0, 0, 0.3) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.34) 0%, rgba(0, 0, 0, 0.04) 40%, rgba(0, 0, 0, 0.6) 100%);
	bottom: 0;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 4;
}

.p-mv__vignette {
	background: radial-gradient(circle at center, rgba(0, 0, 0, 0) 42%, rgba(0, 0, 0, 0.16) 74%, rgba(0, 0, 0, 0.42) 100%);
	bottom: 0;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 5;
}

.p-mv__backlight {
	background: radial-gradient(circle at 62% 40%, rgba(190, 230, 255, 0.56) 0%, rgba(190, 230, 255, 0.24) 14%, rgba(190, 230, 255, 0.08) 24%, rgba(190, 230, 255, 0) 40%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 6;
}

.p-mv.is-active .p-mv__backlight {
	animation: p-mv-backlight-in 1s ease 0.15s forwards, p-mv-backlight-pulse 4.8s ease-in-out 1.1s infinite;
}

.p-mv__flash {
	background: radial-gradient(circle at 62% 40%, rgba(255, 255, 255, 0.92) 0%, rgba(220, 240, 255, 0.42) 10%, rgba(220, 240, 255, 0) 24%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 7;
}

.p-mv.is-active .p-mv__flash {
	animation: p-mv-flash 0.9s ease 0.18s forwards;
}

.p-mv__light-sweep {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(173, 227, 255, 0.12) 42%, rgba(255, 255, 255, 0.54) 50%, rgba(173, 227, 255, 0.12) 58%, rgba(255, 255, 255, 0) 100%);
	filter: blur(2px);
	height: 156%;
	left: -42%;
	mix-blend-mode: screen;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: -18%;
	transform: rotate(-18deg) translateX(0);
	width: 58%;
	z-index: 7;
}

.p-mv.is-active .p-mv__light-sweep {
	animation: p-mv-light-sweep 1.4s ease 0.62s forwards;
}

.p-mv__blue-line {
	background: linear-gradient(90deg, rgba(0, 170, 255, 0), rgba(0, 170, 255, 0.6), rgba(0, 255, 255, 0.9), rgba(0, 170, 255, 0.6), rgba(0, 170, 255, 0));
	filter: blur(1px);
	height: 2px;
	left: -40%;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: 55%;
	transform: rotate(-6deg);
	width: 120%;
	z-index: 8;
}

.p-mv.is-active .p-mv__blue-line {
	animation: blueLine 2s ease 0.6s forwards;
}

.p-mv__smoke {
	mix-blend-mode: screen;
	pointer-events: none;
	position: absolute;
	z-index: 6;
}

.p-mv__smoke--1 {
	background: radial-gradient(circle at 16% 74%, rgba(185, 225, 255, 0.3) 0%, rgba(185, 225, 255, 0) 36%), radial-gradient(circle at 34% 60%, rgba(255, 255, 255, 0.24) 0%, rgba(255, 255, 255, 0) 32%), radial-gradient(circle at 56% 70%, rgba(255, 255, 255, 0.22) 0%, rgba(255, 255, 255, 0) 34%), radial-gradient(circle at 82% 46%, rgba(185, 225, 255, 0.24) 0%, rgba(185, 225, 255, 0) 38%);
	bottom: -8%;
	filter: blur(34px);
	height: 58%;
	left: -12%;
	opacity: 0.88;
	right: -12%;
	top: auto;
}

.p-mv__smoke--2 {
	background: radial-gradient(circle at 24% 78%, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 34%), radial-gradient(circle at 50% 64%, rgba(185, 225, 255, 0.2) 0%, rgba(185, 225, 255, 0) 36%), radial-gradient(circle at 72% 58%, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0) 32%), radial-gradient(circle at 90% 40%, rgba(185, 225, 255, 0.18) 0%, rgba(185, 225, 255, 0) 34%);
	bottom: -12%;
	filter: blur(42px);
	height: 50%;
	left: -8%;
	opacity: 0.74;
	right: -8%;
	top: auto;
}

.p-mv.is-active .p-mv__smoke--1 {
	animation: p-mv-smoke-1 4.8s ease-in-out infinite alternate;
}

.p-mv.is-active .p-mv__smoke--2 {
	animation: p-mv-smoke-2 6.2s ease-in-out infinite alternate;
}

/* ===============================
   Content
=============================== */

.p-mv__content {
	color: #fff;
	text-align: center;
	width: 100%;
}

.p-mv__title-wrap {
	display: inline-block;
	overflow: hidden;
	position: relative;
}

.p-mv__title {
	filter: drop-shadow(0 0 18px rgba(170, 225, 255, 0.12));
	font-family: "Poppins", sans-serif;
	font-weight: 800;
	letter-spacing: 0.03em;
	line-height: 0.86;
	margin: 0;
	position: relative;
	text-transform: uppercase;
	z-index: 2;
}

.p-mv__title-row {
	display: block;
	overflow: hidden;
}

.p-mv__title-row--2 {
	margin-top: 0.25rem;
}

.p-mv__title-word {
	display: block;
	filter: blur(8px);
	opacity: 0;
	position: relative;
	text-shadow: 0 8px 28px rgba(0, 0, 0, 0.62), 0 0 18px rgba(170, 225, 255, 0.08), 0 0 36px rgba(170, 225, 255, 0.08);
	transform: translateY(110%) scale(1.03);
	will-change: transform, opacity, filter;
}

.p-mv__title-word--1 {
	font-size: max(3rem, min(10vw, 5.625rem));
	letter-spacing: 0.06em;
}

.p-mv__title-word--2 {
	font-size: max(3rem, min(10vw, 5.625rem));
	letter-spacing: 0.02em;
}

.p-mv__title-sweep {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(170, 225, 255, 0.22) 35%, rgba(255, 255, 255, 0.98) 50%, rgba(170, 225, 255, 0.22) 65%, rgba(255, 255, 255, 0) 100%);
	box-shadow: 0 0 18px rgba(180, 230, 255, 0.35), 0 0 42px rgba(180, 230, 255, 0.18);
	filter: blur(2px);
	height: 130%;
	left: -55%;
	mix-blend-mode: screen;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: -10%;
	transform: skewX(-22deg) translateX(0);
	width: 38%;
	z-index: 3;
}

.p-mv.is-active .p-mv__title-sweep {
	animation: p-mv-title-sweep-main 1s ease 0.55s forwards;
}

.p-mv.is-active .p-mv__title-word--1 {
	animation: p-mv-title-reveal 0.9s cubic-bezier(0.16, 1, 0.3, 1) 0.92s forwards;
}

.p-mv.is-active .p-mv__title-word--2 {
	animation: p-mv-title-reveal 0.95s cubic-bezier(0.16, 1, 0.3, 1) 1.08s forwards;
}

.p-mv__copy {
	filter: blur(8px);
	font-family: "Shippori Mincho", serif;
	font-size: max(1rem, min(3.8vw, 1.875rem));
	font-weight: 700;
	letter-spacing: 0.12em;
	line-height: 1.5;
	margin-bottom: 0;
	margin-top: 1.125rem;
	opacity: 0;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.45);
	transform: translateY(1.125rem);
}

.p-mv.is-active .p-mv__copy {
	animation: p-mv-copy-in 0.95s ease 1.55s forwards;
}

.p-mv__button {
	display: flex;
	justify-content: center;
	margin-top: 1.75rem;
	opacity: 0;
	transform: translateY(1.125rem);
}

.p-mv.is-active .p-mv__button {
	animation: p-mv-button-in 0.75s ease 1.78s forwards;
}

/* ===============================
   SP optimize
=============================== */

/* ===============================
   PC adjust
=============================== */

/* ===============================
   Animation
=============================== */

.js-mv .p-mv__bg-base,
.js-mv .p-mv__bg-blur,
.js-mv .p-mv__overlay,
.js-mv .p-mv__vignette,
.js-mv .p-mv__backlight,
.js-mv .p-mv__flash,
.js-mv .p-mv__light-sweep,
.js-mv .p-mv__blue-line,
.js-mv .p-mv__smoke {
	opacity: 0;
	will-change: transform, opacity, filter;
}

.js-mv .p-mv__bg-base,
.js-mv .p-mv__bg-blur {
	transform: scale(1.06);
	transform-origin: center center;
}

.js-mv .p-mv__backlight,
.js-mv .p-mv__flash,
.js-mv .p-mv__light-sweep,
.js-mv .p-mv__blue-line {
	transform: translateY(12px);
}

.js-mv .p-mv__smoke--1,
.js-mv .p-mv__smoke--2 {
	transform: translateY(16px) scale(1.03);
}

.p-news-archive {
	padding: 3.75rem 0;
}

.p-news-archive__inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 62.5rem;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	width: 100%;
}

.p-news-list__item a {
	border-bottom: 1px solid #ddd;
	display: block;
	padding: 0.625rem 0;
}

.p-news-list__item-meta {
	align-items: center;
	display: flex;
}

.p-news-list__item-date {
	font-size: 1rem;
	line-height: 1;
}

.p-news-list__item-category {
	background-color: #dcd4a2;
	color: #white;
	font-size: 0.875rem;
	line-height: 1;
	margin-left: 1.875rem;
	min-width: 5rem;
	padding: 0.3125rem;
	text-align: center;
	width: -moz-fit-content;
	width: fit-content;
}

.p-news-list__item-title {
	font-size: 1rem;
	line-height: 1.5;
	margin-top: 0.75rem;
}

.p-news {
	position: relative;
}

.p-news__inner {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

/* 左：タイトル */

/* NEWSだけ背景文字を小さく */

/* NEWS見出しは少しコンパクト */

.p-news__title .c-section-header__engtitle {
	font-size: 2.5rem;
	letter-spacing: 0.03em;
	line-height: 0.95;
}

.p-news__title .c-section-header__jatitle {
	font-size: 1rem;
	margin-top: 0.375rem;
	padding-bottom: 0.625rem;
}

.p-news__title .c-section-header__jatitle::after {
	width: 4rem;
}

/* 右：一覧 */

/* 左下：ボタン */

.p-news__button {
	align-items: center;
	display: flex;
	justify-content: center;
	margin-top: 1.25rem;
}

.p-page-contact__text {
	font-size: 0.9375rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	text-align: center;
}

.p-page-contact__content {
	background-color: #F7F7F7;
	margin-top: 1.875rem;
	padding: 1.875rem;
}

/* =========================
   MV
========================= */

.p-privacy-mv {
	background: #000;
	color: #fff;
	min-height: 11.25rem;
	overflow: hidden;
	position: relative;
}

.p-privacy-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-privacy-mv__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.58);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-privacy-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.76) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-privacy-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-privacy-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.125rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-privacy-mv__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 11.25rem;
	padding-bottom: 1.5rem;
	padding-top: 6.25rem;
	position: relative;
	z-index: 1;
}

.p-privacy-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-privacy-mv__title {
	font-size: max(1.75rem, min(6vw, 3rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
}

/* =========================
   Privacy Content
========================= */

.p-privacy {
	padding: 2rem 0 4.5rem;
}

.p-privacy__inner {
	max-width: 61.25rem;
}

.p-privacy__lead {
	margin-bottom: 2.5rem;
}

.p-privacy__lead-text {
	color: #1c4b90;
	font-size: 0.9375rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
	margin: 0;
}

.p-privacy__body {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
}

.p-privacy__section {
	border-bottom: 1px solid rgba(0, 0, 0, 0.08);
	padding-bottom: 2.5rem;
}

.p-privacy__section:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.p-privacy__heading {
	color: #1c4b90;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.5;
	margin: 0 0 1rem;
}

.p-privacy__text {
	color: #333;
	font-size: 0.875rem;
	letter-spacing: 0.04em;
	line-height: 1.9;
	margin: 0;
}

.p-privacy__list {
	color: #333;
	font-size: 0.875rem;
	letter-spacing: 0.04em;
	line-height: 2;
	margin: 0.75rem 0 0;
	padding-left: 1.25rem;
}

.p-privacy__list li {
	padding-left: 0.25rem;
}

.p-privacy__list li::marker {
	color: #1c4b90;
}

.p-privacy__contact-info {
	background: rgba(0, 0, 0, 0.02);
	border: 1px solid rgba(0, 0, 0, 0.06);
	border-radius: 0.5rem;
	margin-top: 1rem;
	padding: 1.25rem 1.5rem;
}

.p-scroll-text__content {
	overflow: hidden;
}

.p-scroll-text__row {
	overflow: hidden;
}

.p-scroll-text__track {
	display: flex;
	width: -moz-max-content;
	width: max-content;
	will-change: transform;
}

.p-scroll-text__list {
	display: flex;
	list-style: none;
	margin: 0;
	padding: 0;
}

.p-scroll-text__item {
	color: #fff;
	font-family: "Poppins", sans-serif;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1;
	padding-right: 0.625rem;
	white-space: nowrap;
}

/* Direction modifiers */

.p-scroll-text__row--rtl .p-scroll-text__track {
	animation: scrollRTL 150s linear infinite;
}

.p-scroll-text__row--ltr .p-scroll-text__track {
	animation: scrollRTL 200s linear infinite reverse;
}

/* Size modifiers */

.p-scroll-text__row--lg .p-scroll-text__item {
	color: rgba(193, 193, 193, 0.3);
	font-size: 2.5rem;
}

.p-scroll-text__row--md .p-scroll-text__item {
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background: linear-gradient(135deg, #e4ff99 10%, #fdff7d 30%, #fdf736 50%, #fbf019 70%, #fffb01 100%);
	background-clip: text;
	display: inline-block;
	font-size: 3.125rem;
}

.p-scroll-text__row--sm .p-scroll-text__item {
	color: rgba(193, 193, 193, 0.3);
	font-size: 2.5rem;
}

/* Keyframes（基準は右→左） */

.p-scroll-text__row--md .p-scroll-text__item {
	font-weight: 900;
}

.p-service-band {
	margin-top: 2.5rem;
	overflow: hidden;
	padding: 2.25rem 1.5rem 3rem;
	position: relative;
	z-index: 3;
}

.p-service-band::before {
	-webkit-text-stroke: 1px rgba(255, 255, 255, 0.08);
	bottom: -1.125rem;
	color: transparent;
	content: attr(data-label);
	font-family: "Poppins", sans-serif;
	font-size: max(3.5rem, min(11vw, 8.625rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	right: -0.5rem;
	white-space: nowrap;
}

.p-service-band__inner {
	margin: 0 auto;
	max-width: 68.75rem;
	position: relative;
	z-index: 1;
}

.p-service-band__title {
	align-items: center;
	color: #fff;
	display: flex;
	font-size: 1.125rem;
	font-weight: 700;
	gap: 0.875rem;
	justify-content: center;
	margin-bottom: 1.75rem;
	text-align: center;
}

.p-service-band__title::before,
.p-service-band__title::after {
	background: rgba(255, 255, 255, 0.5);
	content: "";
	height: 1px;
	width: 2rem;
}

.p-service-band__grid {
	grid-gap: 0.875rem;
	display: grid;
	gap: 0.875rem;
	grid-template-columns: 1fr;
}

.p-service-band__col {
	background: rgba(255, 255, 255, 0.54);
	border: 1px solid rgba(255, 255, 255, 0.8);
	padding: 1.5rem 1.25rem 1.5rem;
}

.p-service-band__col-head {
	align-items: flex-start;
	border-bottom: 1px solid rgba(255, 255, 255, 0.8);
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	margin-bottom: 1.125rem;
	padding-bottom: 0.875rem;
}

.p-service-band__badge {
	align-items: center;
	background: rgba(184, 146, 42, 0.6);
	border: 1px solid rgba(255, 255, 255, 0.18);
	color: #fff;
	display: inline-flex;
	font-family: "Poppins", sans-serif;
	font-size: 0.875rem;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.12em;
	min-height: 1.75rem;
	padding: 0.25rem 0.625rem;
	text-transform: uppercase;
	white-space: nowrap;
}

.p-service-band__col-name {
	color: #fff;
	font-size: 1.25rem;
	font-weight: 700;
}

.p-service-band__list {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	list-style: none;
}

.p-service-band__list li {
	color: rgba(255, 255, 255, 0.88);
	font-size: 1rem;
	line-height: 1.9;
	padding-left: 0.875rem;
	position: relative;
}

.p-service-band__list li::before {
	background: rgba(255, 255, 255, 0.72);
	border-radius: 50%;
	content: "";
	height: 0.375rem;
	left: 0;
	position: absolute;
	top: 0.82em;
	width: 0.375rem;
}

.js-service-fade {
	opacity: 0;
	transform: translateY(1.75rem);
	transition: opacity 0.75s ease, transform 0.75s ease;
}

.js-service-fade.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.js-service-fade--delay1 {
	transition-delay: 0.12s;
}

.js-service-fade--delay2 {
	transition-delay: 0.24s;
}

.js-service-fade--delay3 {
	transition-delay: 0.36s;
}

/* Q形式 pain point */

.p-service-band__pain-grid {
	grid-gap: 12px;
	display: grid;
	gap: 12px;
	grid-template-columns: repeat(1, 1fr);
	margin-bottom: 2rem;
}

.p-service-band__pain-item {
	align-items: center;
	background: rgba(255, 255, 255, 0.55);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-left: 3px solid #b8922a;
	border-radius: 0 0.1875rem 0.1875rem 0;
	display: flex;
	gap: 0.625rem;
	justify-content: left;
	padding: 0.875rem 1rem;
	transition: transform 0.4s, border-color 0.4s, background 0.4s;
}

.p-service-band__pain-q {
	color: #b8922a;
	font-family: "Poppins", sans-serif;
	font-size: 1rem;
	font-weight: 700;
}

.p-service-band__pain-item p {
	color: rgba(255, 255, 255, 0.82);
	font-size: 1rem;
}

/* =========================
   HERO
========================= */

.p-service-hero {
	background: #000;
	color: #fff;
	min-height: 13.75rem;
	overflow: hidden;
	position: relative;
}

.p-service-hero__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-service-hero__img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: brightness(0.62) contrast(1.06);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-service-hero__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.82) 0%, rgba(0, 0, 0, 0.46) 45%, rgba(0, 0, 0, 0.74) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.14) 0%, rgba(0, 0, 0, 0.62) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-service-hero__glow {
	background: radial-gradient(circle at 55% 34%, rgba(120, 180, 255, 0.18) 0%, rgba(120, 180, 255, 0.08) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-service-hero__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.58) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 2.375rem;
	height: 0.0625rem;
	opacity: 0.68;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-service-hero__grid {
	background-image: linear-gradient(rgba(255, 255, 255, 0.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px);
	background-size: 1.75rem 1.75rem;
	bottom: 0;
	left: 0;
	opacity: 0.08;
	position: absolute;
	right: 0;
	top: 0;
}

.p-service-hero__content {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: 13.75rem;
	padding-bottom: 1.75rem;
	padding-top: 6.875rem;
	position: relative;
	z-index: 1;
}

.p-service-hero__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
}

.p-service-hero__title {
	font-size: max(1.875rem, min(7vw, 3.5rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.75rem;
	position: relative;
	z-index: 2;
}

.p-service-hero__bg-text {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(255, 255, 255, 0.06);
	font-family: "Poppins", sans-serif;
	font-size: max(4rem, min(20vw, 15rem));
	font-weight: 800;
	left: 0;
	letter-spacing: 0.04em;
	line-height: 0.9;
	margin: 0;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-40%);
	user-select: none;
	white-space: nowrap;
	z-index: 1;
}

.p-service-intro__title {
	color: #0d1036;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	margin: 0;
}

.p-service-intro__text {
	color: #0d1036;
	font-size: 1rem;
	margin-top: 1rem;
}

.p-service-section {
	overflow: hidden;
	position: relative;
}

.p-service-section--white {
	background: #fff;
}

.p-service-section--off {
	background: #f4f6fb;
}

.p-service-section__bg-num {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: transparent;
	font-family: "Poppins", sans-serif;
	font-size: max(6.25rem, min(18vw, 16.25rem));
	font-weight: 700;
	letter-spacing: -0.04em;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	top: -0.125rem;
	user-select: none;
	z-index: 0;
}

.p-service-section--right .p-service-section__bg-num {
	-webkit-text-stroke: 2px rgba(26, 39, 68, 0.055);
	left: -24px;
}

.p-service-section--left .p-service-section__bg-num {
	-webkit-text-stroke: 2px rgba(26, 39, 68, 0.055);
	right: -24px;
}

.p-service-section__bg-fade {
	height: 100%;
	pointer-events: none;
	position: absolute;
	top: 0;
	width: 50%;
	z-index: 2;
}

.p-service-section--right .p-service-section__bg-fade {
	background: linear-gradient(to right, #fff 0%, transparent 45%);
	right: 0;
}

.p-service-section--off.p-service-section--right .p-service-section__bg-fade {
	background: linear-gradient(to right, #f4f6fb 0%, transparent 45%);
}

.p-service-section--left .p-service-section__bg-fade {
	background: linear-gradient(to left, #fff 0%, transparent 45%);
	left: 0;
}

.p-service-section--off.p-service-section--left .p-service-section__bg-fade {
	background: linear-gradient(to left, #f4f6fb 0%, transparent 45%);
}

.p-service-section__main {
	grid-gap: 2rem 0;
	display: grid;
	gap: 2rem 0;
	grid-template-columns: 1fr;
	margin: 0 auto;
	max-width: 1200px;
	padding: 3rem 1.75rem 0;
	position: relative;
	z-index: 3;
}

.p-service-section__title {
	color: #1a2744;
	font-size: max(1.5rem, min(2.8vw, 2rem));
	font-weight: 900;
	letter-spacing: 0.04em;
	line-height: 1.25;
	margin-bottom: 0.375rem;
}

.p-service-section__en {
	color: #b8922a;
	font-family: "Poppins", sans-serif;
	font-size: 1rem;
	font-style: italic;
	font-weight: 300;
	letter-spacing: 0.03em;
	margin-bottom: 1.25rem;
}

.p-service-section__rule {
	background: #dde4f0;
	height: 1px;
	margin-bottom: 1.375rem;
	width: 100%;
}

.p-service-section__lead {
	color: #1e5bab;
	font-size: 1.1875rem;
	font-weight: 700;
	line-height: 1.8;
	margin-bottom: 1rem;
}

.p-service-section__desc {
	color: #5a6a84;
	font-size: 1rem;
	line-height: 1.5;
}

.p-service-section__button-block {
	margin-top: 1.25rem;
}

.p-service-section__img {
	position: relative;
}

.p-service-section__img::before {
	background: #111e3c;
	content: "";
	position: absolute;
	z-index: 0;
}

.p-service-section--right .p-service-section__img::before {
	-webkit-clip-path: polygon(0 30%, 100% 0, 100% 100%, 0 100%);
	bottom: -1.125rem;
	clip-path: polygon(0 30%, 100% 0, 100% 100%, 0 100%);
	height: 52%;
	right: -1.125rem;
	width: 52%;
}

.p-service-section--left .p-service-section__img::before {
	-webkit-clip-path: polygon(0 0, 100% 30%, 100% 100%, 0 100%);
	bottom: -1.125rem;
	clip-path: polygon(0 0, 100% 30%, 100% 100%, 0 100%);
	height: 52%;
	left: -1.125rem;
	width: 52%;
}

.p-service-section__img img {
	-o-object-fit: cover;
	aspect-ratio: 4/3;
	border-radius: 2px;
	display: block;
	object-fit: cover;
	position: relative;
	width: 100%;
	z-index: 1;
}

.js-service-fade {
	opacity: 0;
	transform: translateY(1.75rem);
	transition: opacity 0.75s ease, transform 0.75s ease;
}

.js-service-fade.is-visible {
	opacity: 1;
	transform: translateY(0);
}

.js-service-fade--delay1 {
	transition-delay: 0.12s;
}

.js-service-fade--delay2 {
	transition-delay: 0.24s;
}

.js-service-fade--delay3 {
	transition-delay: 0.36s;
}

.p-service-section {
	overflow: hidden;
	position: relative;
}

.p-service-section--white {
	background: #fff;
}

.p-service-section--off {
	background: #f4f6fb;
}

.p-service-section__bg-num {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: transparent;
	font-family: "Poppins", sans-serif;
	font-size: max(6.25rem, min(18vw, 15rem));
	font-weight: 700;
	letter-spacing: -0.05em;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	top: -0.25rem;
	user-select: none;
	z-index: 0;
}

.p-service-section--right .p-service-section__bg-num {
	-webkit-text-stroke: 2px rgba(26, 39, 68, 0.05);
	left: -1.125rem;
}

.p-service-section--left .p-service-section__bg-num {
	-webkit-text-stroke: 2px rgba(26, 39, 68, 0.05);
	right: -1.125rem;
}

.p-service-section__bg-fade {
	height: 100%;
	pointer-events: none;
	position: absolute;
	top: 0;
	width: 50%;
	z-index: 1;
}

.p-service-section--right .p-service-section__bg-fade {
	background: linear-gradient(to right, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0) 48%);
	right: 0;
}

.p-service-section--off.p-service-section--right .p-service-section__bg-fade {
	background: linear-gradient(to right, rgba(244, 246, 251, 0.94) 0%, rgba(244, 246, 251, 0) 48%);
}

.p-service-section--left .p-service-section__bg-fade {
	background: linear-gradient(to left, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0) 48%);
	left: 0;
}

.p-service-section--off.p-service-section--left .p-service-section__bg-fade {
	background: linear-gradient(to left, rgba(244, 246, 251, 0.94) 0%, rgba(244, 246, 251, 0) 48%);
}

.p-service-section__main {
	grid-gap: 2rem;
	display: grid;
	gap: 2rem;
	grid-template-columns: 1fr;
	margin: 0 auto;
	max-width: 75rem;
	padding: 3rem 1.5rem 0;
	position: relative;
	z-index: 3;
}

.p-service-section__text {
	position: relative;
	z-index: 2;
}

.p-service-section__eyebrow {
	color: rgba(26, 39, 68, 0.55);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	margin-bottom: 0.75rem;
	text-transform: uppercase;
}

.p-service-section__img {
	min-width: 0;
	position: relative;
}

.p-service-section__img::before {
	background: #111e3c;
	content: "";
	position: absolute;
	z-index: 0;
}

.p-service-section--right .p-service-section__img::before {
	-webkit-clip-path: polygon(0 18%, 100% 0, 100% 100%, 0 100%);
	bottom: -1.125rem;
	clip-path: polygon(0 18%, 100% 0, 100% 100%, 0 100%);
	height: 56%;
	right: -1.125rem;
	width: 56%;
}

.p-service-section--left .p-service-section__img::before {
	-webkit-clip-path: polygon(0 0, 100% 18%, 100% 100%, 0 100%);
	bottom: -1.125rem;
	clip-path: polygon(0 0, 100% 18%, 100% 100%, 0 100%);
	height: 56%;
	left: -1.125rem;
	width: 56%;
}

.p-service-slider {
	background: #111e3c;
	border-radius: 0.125rem;
	overflow: hidden;
	position: relative;
	width: 100%;
	z-index: 1;
}

.p-service-slider::after {
	background: linear-gradient(180deg, rgba(8, 20, 42, 0.1) 0%, rgba(8, 20, 42, 0.22) 100%);
	bottom: 0;
	content: "";
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	z-index: 2;
}

.p-service-slider .swiper-slide {
	overflow: hidden;
}

.p-service-slider .swiper-slide img {
	-o-object-fit: cover;
	aspect-ratio: 4/3;
	display: block;
	filter: brightness(0.9) contrast(1.04);
	object-fit: cover;
	transform: scale(1.04);
	transition: transform 6s ease;
	width: 100%;
}

.p-service-slider .swiper-slide-active img {
	transform: scale(1);
}

.p-service {
	padding: 3.75rem 0;
}

.p-service__contents {
	margin-top: 1.875rem;
}

.p-service__list {
	counter-reset: service-num;
}

.p-service__item {
	counter-increment: service-num;
	display: flex;
	flex-direction: column;
	gap: 1.875rem;
	margin-right: calc(50% - 50vw);
	margin-right: calc(50% - 50svw);
	overflow: hidden;
	padding-bottom: 2.1875rem;
	padding-top: 2.1875rem;
	position: relative;
	transition: transform 0.35s ease;
}

.p-service__item:hover {
	transform: translateY(-0.25rem);
}

.p-service__item + .p-service__item {
	margin-top: 1.875rem;
}

/* 背景色レイヤー */

.p-service__item::after {
	background: linear-gradient(100deg, transparent 0%, transparent 20%, #09182f 20%, #09182f 80%, #09182f 100%);
	bottom: 0;
	content: "";
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1);
	z-index: 0;
}

/* 背景柄レイヤー */

.p-service__item::before {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	bottom: 0;
	content: "";
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	top: 0;
	transform: scale(1.04);
	transition: opacity 0.8s ease 0.18s, transform 1s ease 0.18s;
	z-index: 1;
}

/* 逆方向 */

.p-service__item.p-service__item--reverse {
	margin-left: calc(50% - 50vw);
	margin-left: calc(50% - 50svw);
	margin-right: 0;
}

.p-service__item--reverse::after {
	background: linear-gradient(-80deg, transparent 0%, transparent 20%, #0e264a 20%, #0e264a 80%, #0e264a 100%);
	transform-origin: right;
}

.p-service__item.p-service__item--color::after {
	background: linear-gradient(100deg, transparent 0%, transparent 20%, #173c73 20%, #173c73 80%, #173c73 100%);
}

.p-service__item.p-service__item--reverse.p-service__item--color::after {
	background: linear-gradient(-80deg, transparent 0%, transparent 20%, #1b4789 20%, #1b4789 80%, #1b4789 100%);
}

/* 背景柄画像 */

.p-service__item--bg01::before {
	background-image: url("../images/common/service_bg01.png");
}

.p-service__item--bg02::before {
	background-image: url("../images/common/service_bg02.png");
}

.p-service__item--bg03::before {
	background-image: url("../images/common/service_bg03.png");
}

.p-service__item--bg04::before {
	background-image: url("../images/common/service_bg04.png");
}

/* inview時 */

.js-service-item.is-inview::after {
	transform: scaleX(1);
}

.js-service-item.is-inview::before {
	opacity: 1;
	transform: scale(1);
}

.p-service__item-body {
	margin-right: auto;
	position: relative;
	width: 100%;
	z-index: 2;
}

.p-service__item-image,
.p-service__item-content {
	opacity: 0;
	position: relative;
	transition-property: opacity, transform;
	transition-timing-function: cubic-bezier(0.16, 1, 0.3, 1);
	will-change: opacity, transform;
	z-index: 2;
}

/* 画像は2番目 */

.p-service__item-image {
	overflow: hidden;
	transform: translateY(1.5rem);
	transition-delay: 0.28s;
	transition-duration: 0.9s;
	width: 100%;
}

.p-service__item-image img {
	-o-object-fit: cover;
	aspect-ratio: 500/320;
	display: block;
	height: 100%;
	object-fit: cover;
	transform: scale(1.08);
	transition: transform 1.2s cubic-bezier(0.16, 1, 0.3, 1), filter 0.6s ease;
	width: 100%;
	will-change: transform;
}

/* テキストは3番目 */

.p-service__item-content {
	transform: translateY(1.5rem);
	transition-delay: 0.46s;
	transition-duration: 0.9s;
	width: 100%;
}

.p-service__item-title {
	color: #fff;
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.5;
}

.p-service__item-subtitle {
	color: #c59c63;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.5;
}

.p-service__item-text-block {
	margin-top: 0.625rem;
}

.p-service__item-text {
	color: #fff;
	font-size: 0.875rem;
	font-weight: 300;
	letter-spacing: 0.05em;
	line-height: 1.5;
}

.p-service__item-button {
	align-items: center;
	display: flex;
	justify-content: flex-end;
	margin-top: 1.875rem;
}

/* 番号 */

.p-service__item-content::before {
	color: #fff;
	content: counter(service-num, decimal-leading-zero);
	font-size: 1.5rem;
	font-weight: 700;
	left: -3%;
	letter-spacing: 0.06em;
	line-height: 1;
	opacity: 0.9;
	position: absolute;
	top: -4%;
}

/* 縦線 */

.p-service__item-content::after {
	background-color: #fff;
	content: "";
	height: 15.625rem;
	left: 0;
	position: absolute;
	top: 1.5rem;
	width: 0.125rem;
}

/* テキスト上を走る光 */

.js-service-content {
	position: relative;
}

.js-service-content .p-service__item-text-block::after {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 190, 255, 0.14) 45%, rgba(255, 255, 255, 0.22) 50%, rgba(120, 190, 255, 0.14) 55%, rgba(255, 255, 255, 0) 100%);
	content: "";
	height: 100%;
	left: -20%;
	mix-blend-mode: screen;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
	transform: skewX(-20deg);
	width: 24%;
}

.js-service-item.is-inview .js-service-image,
.js-service-item.is-inview .js-service-content {
	opacity: 1;
	transform: translateY(0);
}

.js-service-item.is-inview .js-service-image img {
	transform: scale(1);
}

.js-service-item.is-inview .js-service-content .p-service__item-text-block::after {
	animation: p-service-content-shine 1.1s ease 0.62s 1 forwards;
}

.p-service__item-image img {
	transition: transform 0.6s ease;
}

.p-service__item:hover .p-service__item-image img {
	transform: scale(1.04);
}

.p-service__item-button .c-button-circle {
	transition: transform 0.3s ease, box-shadow 0.3s ease;
}

.p-service__item:hover .p-service__item-button .c-button-circle {
	transform: translateX(0.25rem);
}

/* =========================
   SP
========================= */

/* =========================
   Keyframes
========================= */

/* =========================
   Service image parallax
========================= */

.p-service__item-image {
	overflow: hidden;
}

.p-service__item-image-inner {
	height: 100%;
	transform: translate3d(0, 0, 0);
	will-change: transform;
}

.p-service__item-image-inner img {
	-o-object-fit: cover;
	aspect-ratio: 500/320;
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
	width: 100%;
	will-change: transform;
}

.p-service__item:hover .p-service__item-image-inner img {
	transform: scale(1.04);
}

.p-service__item::before {
	transform: translateY(0);
	transform: translateY(var(--bg-move, 0));
	transition: transform 0.2s linear;
}

/* =========================
SERVICE Animation
========================= */

.js-service-image,
.js-service-content {
	opacity: 0;
	transform: translateY(1.875rem);
	transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.js-service-image {
	transition-delay: 0.35s;
}

.js-service-content {
	transition-delay: 0.55s;
}

.js-service-item.is-inview .js-service-image,
.js-service-item.is-inview .js-service-content {
	opacity: 1;
	transform: translateY(0);
}

/* =========================
image parallax
========================= */

.p-service__item-image-inner {
	transform: translate3d(0, 0, 0);
	will-change: transform;
}

.p-service__item-image-inner img {
	transition: transform 0.6s ease;
}

.p-service__item:hover .p-service__item-image-inner img {
	transform: scale(1.05);
}

/* =========================
background zoom
========================= */

.p-service__item::before {
	transform: scale(1.06);
	transition: opacity 0.8s ease 0.2s, transform 1.2s ease 0.2s;
}

.js-service-item.is-inview::before {
	transform: scale(1);
}

/* =========================
   SERVICE: stronger animation
========================= */

/* 背景色の入りを少し強く */

.p-service__item::after {
	filter: saturate(1.05);
	opacity: 1;
	will-change: transform;
}

/* 背景柄の見え方を少し強く */

.p-service__item::before {
	will-change: transform, opacity;
}

/* 画像とテキストの初期状態 */

.js-service-image,
.js-service-content {
	opacity: 0;
	transform: translateY(1.875rem);
	transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: opacity, transform;
}

.js-service-image {
	transition-delay: 0.32s;
}

.js-service-content {
	transition-delay: 0.52s;
}

.js-service-item.is-inview .js-service-image,
.js-service-item.is-inview .js-service-content {
	opacity: 1;
	transform: translateY(0);
}

/* 画像の奥行き感 */

.p-service__item-image {
	overflow: hidden;
}

.p-service__item-image-inner {
	height: 100%;
	transform: translate3d(0, 0, 0);
	will-change: transform;
}

.p-service__item-image-inner img {
	-o-object-fit: cover;
	aspect-ratio: 500/320;
	display: block;
	height: 100%;
	object-fit: cover;
	transform: scale(1.08);
	transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1), filter 0.6s ease;
	width: 100%;
	will-change: transform;
}

.js-service-item.is-inview .p-service__item-image-inner img {
	transform: scale(1);
}

.p-service__item:hover .p-service__item-image-inner img {
	transform: scale(1.05);
}

/* テキストの光ライン */

.js-service-content .p-service__item-text-block {
	overflow: hidden;
	position: relative;
}

.js-service-content .p-service__item-text-block::after {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 190, 255, 0.1) 40%, rgba(255, 255, 255, 0.2) 50%, rgba(120, 190, 255, 0.1) 60%, rgba(255, 255, 255, 0) 100%);
	content: "";
	height: 100%;
	left: -24%;
	mix-blend-mode: screen;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
	transform: skewX(-20deg);
	width: 20%;
}

.js-service-item.is-inview .js-service-content .p-service__item-text-block::after {
	animation: p-service-text-shine 1s ease 0.7s 1 forwards;
}

/* 番号の演出 */

.p-service__item-content::before {
	opacity: 0;
	transform: translateY(0.75rem);
	transition: opacity 0.6s ease 0.64s, transform 0.6s ease 0.64s;
}

.p-service__item-content::after {
	transform: scaleY(0);
	transform-origin: top;
	transition: transform 0.7s cubic-bezier(0.16, 1, 0.3, 1) 0.72s;
}

.js-service-item.is-inview .p-service__item-content::before {
	opacity: 0.9;
	transform: translateY(0);
}

.js-service-item.is-inview .p-service__item-content::after {
	transform: scaleY(1);
}

/* ボタン */

.p-service__item-button .c-button-circle {
	transition: transform 0.3s ease, box-shadow 0.3s ease, opacity 0.4s ease;
}

.p-service__item:hover .p-service__item-button .c-button-circle {
	box-shadow: 0 0 0.875rem rgba(255, 255, 255, 0.18);
	transform: translateX(0.25rem);
}

/* inview後の背景柄ズーム感を少し強める */

.js-service-item.is-inview::before {
	transform: scale(1);
}

.p-single-body__inner.l-inner {
	max-width: 50rem;
}

.p-single-body__title h1 {
	font-size: 1.375rem;
	font-weight: normal;
	line-height: 1.4375;
}

.p-single-body__meta {
	margin-top: 1.25rem;
}

.p-single-body__image {
	margin-top: 0.875rem;
	position: relative;
}

.p-single-body__image::before {
	content: "";
	display: block;
	padding-top: 55.8%;
}

.p-single-body__image img {
	-o-object-fit: cover;
	height: 100%;
	left: 50%;
	object-fit: cover;
	position: absolute;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.p-single-body__content p {
	font-size: 0.875rem;
	line-height: 1.7142857143;
	margin-top: 1.875rem;
}

.p-single-body__content h2 {
	font-size: 1.125rem;
	line-height: 1.5;
	margin-top: 2.5rem;
	padding-left: 0.9375rem;
	position: relative;
}

.p-single-body__content h2::before {
	background-color: #391E88;
	border-radius: 5px;
	content: "";
	height: 100%;
	left: -0.1875rem;
	position: absolute;
	width: 0.375rem;
}

.p-single-body__content h3 {
	font-size: 1rem;
	line-height: 1.5;
	margin-top: 2.5rem;
	position: relative;
}

/* =========================
   Single MV
========================= */

.p-single-mv {
	background-color: #000;
	color: #fff;
	min-height: 8.75rem;
	overflow: hidden;
	position: relative;
}

.p-single-mv__bg {
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-single-mv__bg-img {
	-o-object-fit: cover;
	-o-object-position: center;
	display: block;
	filter: grayscale(100%) contrast(1.08) brightness(0.6);
	height: 100%;
	object-fit: cover;
	object-position: center;
	transform: scale(1.04);
	width: 100%;
}

.p-single-mv__overlay {
	background: linear-gradient(90deg, rgba(0, 0, 0, 0.84) 0%, rgba(0, 0, 0, 0.56) 45%, rgba(0, 0, 0, 0.78) 100%), linear-gradient(180deg, rgba(0, 0, 0, 0.12) 0%, rgba(0, 0, 0, 0.64) 100%);
	bottom: 0;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
}

.p-single-mv__glow {
	background: radial-gradient(circle at 52% 36%, rgba(120, 180, 255, 0.16) 0%, rgba(120, 180, 255, 0.07) 20%, rgba(120, 180, 255, 0) 42%);
	bottom: 0;
	left: 0;
	mix-blend-mode: screen;
	position: absolute;
	right: 0;
	top: 0;
}

.p-single-mv__line {
	background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(120, 180, 255, 0.6) 50%, rgba(255, 255, 255, 0) 100%);
	bottom: 1.75rem;
	height: 0.0625rem;
	opacity: 0.72;
	position: absolute;
	right: -8%;
	transform: rotate(-6deg);
	width: 62%;
}

.p-single-mv__grid {
	background-image: linear-gradient(rgba(255, 255, 255, 0.12) 1px, transparent 1px), linear-gradient(90deg, rgba(255, 255, 255, 0.12) 1px, transparent 1px);
	background-size: 1.75rem 1.75rem;
	bottom: 0;
	left: 0;
	opacity: 0.1;
	position: absolute;
	right: 0;
	top: 0;
}

.p-single-mv__inner {
	display: flex;
	flex-direction: column;
	justify-content: flex-end;
	min-height: inherit;
	padding-bottom: 1.25rem;
	padding-top: 5.5rem;
	position: relative;
	z-index: 1;
}

.p-single-mv__sub {
	color: rgba(255, 255, 255, 0.86);
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.18em;
	line-height: 1;
	margin: 0;
	position: relative;
	z-index: 2;
}

.p-single-mv__title {
	color: #fff;
	font-size: max(1.5rem, min(5vw, 2.5rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.2;
	margin-bottom: 0;
	margin-top: 0.625rem;
	position: relative;
	text-shadow: 0 0.25rem 1.125rem rgba(0, 0, 0, 0.35);
	z-index: 2;
}

.p-single-mv__bg-text {
	-webkit-user-select: none;
	-moz-user-select: none;
	color: rgba(255, 255, 255, 0.06);
	font-family: "Poppins", sans-serif;
	font-size: max(3.5rem, min(16vw, 11.25rem));
	font-weight: 800;
	left: 0;
	letter-spacing: 0.04em;
	line-height: 0.9;
	margin: 0;
	pointer-events: none;
	position: absolute;
	top: 50%;
	transform: translateY(-38%);
	user-select: none;
	white-space: nowrap;
	z-index: 1;
}

/* =========================
   Single
========================= */

.p-single {
	padding: 1.75rem 0 4.5rem;
}

.p-single__inner {
	max-width: 42.5rem;
}

/* =========================
   Hero
========================= */

.p-single__hero {
	border-bottom: 1px solid rgba(28, 75, 144, 0.18);
	margin-bottom: 2.5rem;
	padding-bottom: 1.5rem;
	position: relative;
}

.p-single__hero::after {
	background: linear-gradient(90deg, #1c4b90 0%, rgba(28, 75, 144, 0.2) 100%);
	bottom: -1px;
	content: "";
	height: 0.125rem;
	left: 0;
	position: absolute;
	width: 5.625rem;
}

.p-single__meta {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
}

.p-single__cat {
	align-items: center;
	background: #dcd4a2;
	color: #1c4b90;
	display: inline-flex;
	font-size: 0.75rem;
	font-weight: 700;
	justify-content: center;
	line-height: 1;
	min-height: 1.875rem;
	padding: 0.375rem 0.75rem;
}

.p-single__date {
	color: rgba(28, 75, 144, 0.76);
	font-size: 0.875rem;
	font-weight: 500;
	line-height: 1.4;
}

.p-single__title {
	color: #1c4b90;
	font-size: max(1.75rem, min(4.2vw, 2.5rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.4;
	margin-bottom: 0;
	margin-top: 1.125rem;
}

/* =========================
   Thumbnail
========================= */

.p-single__thumbnail {
	border-radius: 0.75rem;
	box-shadow: 0 0.875rem 2rem rgba(0, 0, 0, 0.12);
	margin-top: 2.25rem;
	overflow: hidden;
}

.p-single__img {
	-o-object-fit: cover;
	aspect-ratio: 16/9;
	display: block;
	height: auto;
	object-fit: cover;
	width: 100%;
}

/* =========================
   Body / Content
========================= */

.p-single__body {
	margin-top: 2.25rem;
}

.p-single__content {
	color: #222;
	font-size: 1.0625rem;
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.9;
}

.p-single__content > *:first-child {
	margin-top: 0;
}

.p-single__content p {
	margin-bottom: 0;
	margin-top: 1.25rem;
}

.p-single__content h2,
.p-single__content h3,
.p-single__content h4 {
	color: #1c4b90;
	font-weight: 700;
	line-height: 1.5;
	margin-bottom: 1rem;
	margin-top: 2.5rem;
}

.p-single__content h2 {
	font-size: 1.5rem;
	padding-left: 1rem;
	position: relative;
}

.p-single__content h2::before {
	background: linear-gradient(180deg, #1c4b90 0%, rgba(28, 75, 144, 0.35) 100%);
	border-radius: 62.4375rem;
	content: "";
	height: calc(100% - 0.5rem);
	left: 0;
	position: absolute;
	top: 0.25rem;
	width: 0.25rem;
}

.p-single__content h3 {
	font-size: 1.25rem;
}

.p-single__content ul,
.p-single__content ol {
	margin-top: 1.25rem;
	padding-left: 1.5rem;
}

.p-single__content li + li {
	margin-top: 0.5rem;
}

.p-single__content blockquote {
	background: rgba(28, 75, 144, 0.04);
	border-left: 0.25rem solid #1c4b90;
	color: #333;
	margin: 1.75rem 0 0;
	padding: 1.25rem;
}

.p-single__content img {
	border-radius: 0.625rem;
	display: block;
	height: auto;
	margin-top: 1.75rem;
	max-width: 100%;
}

.p-single__content a {
	-webkit-text-decoration: underline;
	color: #1c4b90;
	text-decoration: underline;
	text-underline-offset: 0.15em;
}

/* =========================
   Pager
========================= */

.p-single__pager {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	margin-top: 3rem;
}

.p-single__pager-link {
	grid-gap: 0.875rem;
	-webkit-text-decoration: none;
	align-items: center;
	background: #fff;
	border: 1px solid rgba(28, 75, 144, 0.16);
	border-radius: 0.875rem;
	box-shadow: 0 0.625rem 1.5rem rgba(0, 0, 0, 0.05);
	color: #1c4b90;
	display: grid;
	gap: 0.875rem;
	min-height: 6.5rem;
	padding: 0.875rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
}

.p-single__pager-link:hover {
	border-color: rgba(28, 75, 144, 0.28);
	box-shadow: 0 0.875rem 1.75rem rgba(0, 0, 0, 0.08);
	transform: translateY(-0.125rem);
}

.p-single__pager-link.is-disabled {
	opacity: 0.5;
	pointer-events: none;
}

.p-single__pager-thumb {
	align-items: center;
	aspect-ratio: 1/1;
	background: rgba(28, 75, 144, 0.04);
	border-radius: 0.625rem;
	display: flex;
	justify-content: center;
	overflow: hidden;
}

.p-single__pager-img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

.p-single__pager-img--logo {
	-o-object-fit: contain;
	height: 70%;
	object-fit: contain;
	padding: 0.375rem;
	width: 70%;
}

.p-single__pager-body {
	display: flex;
	flex-direction: column;
	gap: 0.375rem;
	min-width: 0;
	text-align: left;
}

.p-single__pager-label {
	color: rgba(28, 75, 144, 0.56);
	font-family: "Poppins", sans-serif;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	line-height: 1;
}

.p-single__pager-title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	color: #1c4b90;
	display: -webkit-box;
	font-size: 0.875rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1.6;
	overflow: hidden;
}

.p-single__pager-icon {
	background: #1c4b90;
	border-radius: 50%;
	flex-shrink: 0;
	height: 2.125rem;
	position: relative;
	width: 2.125rem;
}

.p-single__pager-icon::before {
	border-right: 2px solid #fff;
	border-top: 2px solid #fff;
	content: "";
	height: 0.4375rem;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 0.4375rem;
}

/* prev */

.p-single__pager-link--prev {
	grid-template-columns: 2.375rem 1fr 5.25rem;
}

.p-single__pager-link--prev .p-single__pager-icon {
	order: 1;
}

.p-single__pager-link--prev .p-single__pager-body {
	order: 2;
	text-align: left;
}

.p-single__pager-link--prev .p-single__pager-thumb {
	order: 3;
}

.p-single__pager-link--prev .p-single__pager-icon::before {
	transform: translate(-35%, -50%) rotate(-135deg);
}

/* next / index */

.p-single__pager-link--next {
	grid-template-columns: 5.25rem 1fr 2.375rem;
}

.p-single__pager-link--next .p-single__pager-thumb {
	order: 1;
}

.p-single__pager-link--next .p-single__pager-body {
	order: 2;
	text-align: left;
}

.p-single__pager-link--next .p-single__pager-icon {
	order: 3;
}

.p-single__pager-link--next .p-single__pager-icon::before {
	transform: translate(-65%, -50%) rotate(45deg);
}

/* =========================
   SP
========================= */

/* =========================
   SP fixed CTA
========================= */

.p-sp-fixed-cta {
	display: none;
}

.p-sp-fixed-cta__item {
	-webkit-text-decoration: none;
	align-items: center;
	display: flex;
	font-size: 0.8125rem;
	font-weight: 700;
	gap: 0.5rem;
	justify-content: center;
	letter-spacing: 0.03em;
	line-height: 1.2;
	min-height: 3.5rem;
	padding: 0.625rem 0.5rem;
	text-decoration: none;
}

.p-sp-fixed-cta__item--tel {
	background-color: #1c4b90;
	color: #fff;
}

.p-sp-fixed-cta__item--line {
	background-color: #06c755;
	color: #fff;
}

.p-sp-fixed-cta__item--contact {
	background-color: #fff;
	color: #1c4b90;
}

.p-sp-fixed-cta__icon {
	flex-shrink: 0;
	height: 1.25rem;
	width: 1.25rem;
}

.p-sp-fixed-cta__icon img {
	-o-object-fit: contain;
	display: block;
	height: 100%;
	object-fit: contain;
	width: 100%;
}

.p-sp-fixed-cta__text {
	white-space: nowrap;
}

/* =========================
   bodyの下余白
========================= */

.p-sub-mv {
	height: 26.25rem;
	position: relative;
}

.p-sub-mv__title {
	color: #fff;
	font-size: 1.875rem;
	left: 50%;
	line-height: 1;
	position: absolute;
	text-align: center;
	top: 50%;
	transform: translate(-50%, -50%);
	width: 100%;
}

.p-sub-mv__img {
	height: inherit;
}

.p-sub-mv__img img {
	-o-object-fit: cover;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* =========================
   THANKS PAGE
========================= */

.p-thanks {
	background: linear-gradient(180deg, #f8fafc 0%, #fff 42%, #f8fafc 100%);
	padding: 3.5rem 0 5rem;
	position: relative;
}

.p-thanks__inner {
	max-width: 45rem;
	text-align: center;
}

.p-thanks__icon {
	align-items: center;
	background: linear-gradient(135deg, rgba(28, 75, 144, 0.08) 0%, rgba(28, 75, 144, 0.03) 100%);
	border-radius: 50%;
	color: #1c4b90;
	display: flex;
	height: 5.5rem;
	justify-content: center;
	margin: 0 auto 1.75rem;
	width: 5.5rem;
}

.p-thanks__icon svg {
	height: 2.5rem;
	width: 2.5rem;
}

.p-thanks__heading {
	color: #1c4b90;
	font-size: max(1.375rem, min(5vw, 2rem));
	font-weight: 700;
	letter-spacing: 0.04em;
	line-height: 1.5;
	margin: 0;
}

.p-thanks__desc {
	color: #475569;
	font-size: 0.9375rem;
	letter-spacing: 0.03em;
	line-height: 2;
	margin-top: 1.5rem;
}

.p-thanks__desc p {
	margin: 0 0 0.5rem;
}

.p-thanks__desc p:last-child {
	margin-bottom: 0;
}

.p-thanks__btn-wrap {
	margin-top: 2.25rem;
}

.p-thanks__btn {
	-webkit-text-decoration: none;
	align-items: center;
	background: linear-gradient(135deg, #1c4b90 0%, #173c73 100%);
	border: 0;
	border-radius: 62.4375rem;
	box-shadow: 0 0.875rem 1.625rem rgba(28, 75, 144, 0.16);
	color: #fff;
	display: inline-flex;
	font-size: 1rem;
	font-weight: 700;
	justify-content: center;
	letter-spacing: 0.06em;
	line-height: 1;
	min-height: 3.5rem;
	min-width: 15rem;
	padding: 0.875rem 2.25rem;
	text-decoration: none;
	transition: transform 0.25s ease, box-shadow 0.25s ease;
}

.p-thanks__btn:hover {
	box-shadow: 0 1.125rem 2rem rgba(28, 75, 144, 0.22);
	transform: translateY(-0.125rem);
}

.pc-nav__items {
	align-items: center;
	display: flex;
	height: inherit;
	justify-content: center;
}

.pc-nav__item,
.pc-nav__item a {
	height: inherit;
}

.pc-nav__item a {
	align-items: center;
	color: #fff;
	display: flex;
	font-family: serif;
	font-family: "Poppins", sans-serif;
	font-size: 0.9375rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	line-height: 1;
	padding-left: 0.8125rem;
	padding-right: 0.75rem;
}

.pc-nav__item:first-child a {
	padding-left: 0;
}

.pc-nav__item:last-child a {
	padding-right: 0;
}

.sp-nav {
	background-color: #642390;
	display: none;
	height: 100vh;
	left: 0;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
}

.sp-nav.is-active {
	display: block;
}

.sp-nav__items {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	min-height: 100vh;
	padding: 6.25rem 0;
}

.sp-nav__item {
	width: 100%;
}

.sp-nav__item a {
	color: #fff;
	display: block;
	font-family: "Poppins", sans-serif;
	font-size: 0.9375rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1;
	padding: 0.625rem 0;
	text-align: center;
}

/*デフォルト色の指定*/

/*サイズ等の指定*/

/*ボタン系の指定*/

/*ラジオボタンの指定*/

/*チェックボックスの指定*/

/*テキストエリアの指定*/

[type=text],
[type=search],
[type=tel],
[type=url],
[type=email],
[type=password],
[type=date],
textarea {
	background: #fff;
	background-image: none; /*↓リセットCSS */
	border: none;
	border: 1px solid #aaaaaa;
	border-radius: 0;
	border-radius: 0.375rem;
	font-family: inherit;
	font-size: 1rem; /*↓カスタム */
	margin-top: 0.625rem;
	max-width: 18.75rem;
	padding: 0.625rem 0.625rem;
	width: 100%; /*↓↓↓↓不要ならコメントアウト or 削除 */ /*↓↓選択されているときの色*/
}

[type=text]:focus,
[type=search]:focus,
[type=tel]:focus,
[type=url]:focus,
[type=email]:focus,
[type=password]:focus,
[type=date]:focus,
textarea:focus {
	border: 1px solid #391e88;
}

[type=tel] {
	max-width: 12.5rem;
	width: 100%;
}

button,
[type=button],
[type=submit] {
	-webkit-text-decoration: none;
	background: transparent linear-gradient(90deg, #7633a4 0%, #250d65 100%) 0% 0% no-repeat padding-box;
	border: none;
	border-radius: 0;
	border-radius: 3.125rem;
	color: white;
	cursor: pointer;
	display: inline-block;
	font-size: 0.875rem;
	line-height: 1; /*↓リセットCSS */
	margin: 0; /*↓カスタム */
	padding: 1.25rem 4.5rem;
	text-decoration: none;
	transition: 0.3s ease;
	width: auto;
}

[type=radio] {
	display: none;
}

[type=radio] + span {
	cursor: pointer;
	display: inline-block;
	font-size: 0.75rem;
	line-height: 1;
	margin: 0 2.1875rem 0 0;
	padding: 0 0 0 1.75rem;
	position: relative;
}

[type=radio] + span::before {
	background: #fff;
	border: 1px solid #707070;
	border-radius: 50%;
	content: "";
	display: block;
	height: 1.125rem;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1.125rem;
}

[type=radio] + span::after {
	opacity: 0;
	transition: 0.3s ease;
}

[type=radio]:checked + span::after {
	background: #391e88;
	border-radius: 50%;
	content: "";
	display: block;
	height: 0.75rem;
	left: 0.1875rem;
	opacity: 1;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 0.75rem;
}

[type=checkbox] {
	display: none;
}

[type=checkbox] + span {
	cursor: pointer;
	display: inline-block;
	font-size: 0.875rem;
	line-height: 1;
	margin: 0 1.25rem 0 0;
	padding: 0 0 0 1.5625rem;
	position: relative;
	transition: 0.3s ease;
}

[type=checkbox] + span::before {
	background: #fff;
	border: 1px solid #f00;
	content: "";
	display: block;
	height: 1.25rem;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 1.25rem;
}

[type=checkbox] + span::after {
	opacity: 0;
	transition: 0.3s ease;
}

[type=checkbox]:checked + span::after {
	border-bottom: 4px solid #f00;
	border-left: 4px solid #f00;
	content: "";
	display: block;
	height: 0.625rem;
	left: 0;
	margin-left: 0.1em;
	margin-top: -0.1em;
	opacity: 1;
	position: absolute;
	top: 50%; /*チェックマークじゃない場合は以下を変更する*/
	transform: translateY(-50%) rotate(-45deg);
	width: 1.125rem;
}

select { /*↓デフォルトのアイコンを消す場合はコメントアウト（noneにする）*/
	-webkit-appearance: auto;
	-moz-appearance: auto;
	appearance: auto;
	background-color: #fff;
	border: none;
	border: 1px solid #aaaaaa; /*↓リセットCSS */
	border-radius: 0;
	border-radius: 0.375rem;
	color: inherit;
	cursor: pointer;
	font-family: inherit;
	font-size: 1rem; /*↓カスタム */
	margin-top: 0.625rem;
	padding: 0.625rem 0.625rem;
	width: 100%; /*↓デフォルトではないアイコンを使う場合は入力する*/
}

select:focus {
	border: 1px solid #391e88;
}

[type=date] { /*↓デフォルトのアイコンを消す場合はコメントアウト（noneにする）*/
	-webkit-appearance: auto;
	-moz-appearance: auto;
	appearance: auto;
	position: relative; /*↓デフォルトではないアイコンを使う場合は入力する*/
}

[type=date]:focus {
	border-color: 1px solid #391e88;
}

input[type=date]::-webkit-calendar-picker-indicator {
	height: 100%;
	opacity: 0;
	position: absolute;
	width: 100%;
}

textarea {
	height: 15.9375rem;
	max-width: 37.5rem;
	width: 100%;
}

.p-activities-swiper .swiper-pagination {
	bottom: 4.0625rem;
}

.p-activities-swiper .swiper-pagination .swiper-pagination-bullet {
	background: #1c4b90;
	border: 1px solid #fff;
}

.p-activities-swiper .swiper-pagination .swiper-pagination-bullet-active {
	background: #de8430;
}

.p-activities-swiper__button-wrap {
	display: flex;
	justify-content: center;
	margin-top: 3.125rem;
}

.p-activities-swiper__button-wrap .swiper-button-prev,
.p-activities-swiper__button-wrap .swiper-button-next {
	background-color: #1c4b90;
	border: 1px solid #1c4b90;
	border-radius: 50%;
	height: 1.875rem;
	position: relative;
	width: 1.875rem;
}

.p-activities-swiper__button-wrap .swiper-button-next {
	margin-left: 6.25rem;
}

.p-activities-swiper__button-wrap .swiper-button-prev:hover {
	opacity: 0.8;
}

.p-activities-swiper__button-wrap .swiper-button-next:hover {
	opacity: 0.8;
}

.p-activities-swiper__button-wrap .swiper-button-prev::before,
.p-activities-swiper__button-wrap .swiper-button-next::before {
	border-right: 0.1875rem solid #fff;
	border-top: 0.1875rem solid #fff;
	content: "";
	height: 0.625rem;
	left: 50%;
	position: absolute;
	top: 50%;
	width: 0.625rem;
}

.p-activities-swiper__button-wrap .swiper-button-prev:hover::before {
	border-right: 0.1875rem solid #1c4b90;
	border-top: 0.1875rem solid #1c4b90;
}

.p-activities-swiper__button-wrap .swiper-button-next:hover::before {
	border-right: 0.1875rem solid #1c4b90;
	border-top: 0.1875rem solid #1c4b90;
}

.p-activities-swiper__button-wrap .swiper-button-prev::before {
	transform: translate(-50%, -50%) rotate(-135deg);
}

.p-activities-swiper__button-wrap .swiper-button-next::before {
	transform: translate(-50%, -50%) rotate(45deg);
}

.swiper-horizontal > .swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
	bottom: -1.5625rem;
	text-align: center;
}

.swiper-pagination-bullet-active {
	background: #1c4b90;
}

/* ===============================
   Common inview animation
=============================== */

.js-fade-up,
.js-mask-in {
	opacity: 0;
	transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: opacity, transform;
}

.js-fade-up {
	transform: translateY(1.5rem);
}

.js-fade-up.is-inview {
	opacity: 1;
	transform: translateY(0);
}

.js-mask-in {
	overflow: hidden;
	transform: translateY(0.75rem);
}

.js-mask-in > img,
.js-mask-in img,
.js-mask-in iframe {
	display: block;
	height: auto;
	transform: scale(1.08);
	transition: transform 1s cubic-bezier(0.16, 1, 0.3, 1), filter 0.6s ease;
	width: 100%;
	will-change: transform;
}

.js-mask-in.is-inview {
	opacity: 1;
	padding-bottom: 1.25rem;
	padding-top: 1.25rem;
	transform: translateY(0);
}

.js-mask-in.is-inview > img,
.js-mask-in.is-inview img,
.js-mask-in.is-inview iframe {
	transform: scale(1);
}

/* ===============================
   News
=============================== */

.p-news-list__item {
	transition: transform 0.35s ease, box-shadow 0.35s ease;
}

.p-news-list__item:hover {
	transform: translateY(-0.125rem);
}

/* ===============================
   Message
=============================== */

.p-message__image {
	overflow: hidden;
}

.p-message__image img {
	transition: transform 0.8s ease;
	will-change: transform;
}

.p-message__image:hover img {
	transform: scale(1.03);
}

/* ===============================
   Activities
=============================== */

.p-activities-card {
	transition: transform 0.35s ease;
}

.p-activities-card:hover {
	transform: translateY(-0.25rem);
}

.p-activities-card__img {
	transition: transform 0.6s ease;
}

.p-activities-card:hover .p-activities-card__img {
	transform: scale(1.04);
}

/* ===============================
   Access
=============================== */

.p-access__map {
	overflow: hidden;
}

.p-access__map iframe {
	transition: transform 0.8s ease;
}

.p-access__map:hover iframe {
	transform: scale(1.02);
}

canvas {
	display: none;
}

/* ---- particles.js container ---- */

/* ---- stats.js ---- */

.count-particles {
	background: #000022;
	color: #13e8e9;
	font-family: Helvetica, Arial, sans-serif;
	font-size: 0.8em;
	font-weight: bold;
	left: 0;
	line-height: 14px;
	padding-bottom: 2px;
	position: absolute;
	text-align: left;
	text-indent: 4px;
	top: 48px;
	width: 80px;
}

.js-count-particles {
	font-size: 1.1em;
}

#stats,
.count-particles {
	-webkit-user-select: none;
	margin-left: 5px;
	margin-top: 5px;
}

#stats {
	border-radius: 3px 3px 0 0;
	overflow: hidden;
}

.count-particles {
	border-radius: 0 0 3px 3px;
}

/* ======================================
   Utility: Kagi（かぎ括弧の詰め調整）
====================================== */

.u-kagi {
	--kagi-open-space: -0.12em;
	--kagi-close-space: -0.08em;
}

.u-kagi__open {
	margin-right: var(--kagi-open-space);
}

.u-kagi__close {
	margin-left: var(--kagi-close-space);
}

/* 強め（見出し・FV用） */

.u-kagi--tight {
	--kagi-open-space: -0.18em;
	--kagi-close-space: -0.12em;
}

/* 弱め（本文用） */

.u-kagi--loose {
	--kagi-open-space: -0.08em;
	--kagi-close-space: -0.04em;
}

/* ==========================================================================
   Project - Pagination (WP-PageNavi)
   ========================================================================== */

.p-pagination {
	display: flex;
	justify-content: center;
	margin-top: 2.5rem;
}

.p-pagination .wp-pagenavi {
	border: 0;
	display: flex;
	flex-wrap: wrap;
	font-size: 1rem;
	gap: 0.5rem;
	justify-content: center;
	margin: 0;
	padding: 0;
}

.p-pagination .wp-pagenavi a,
.p-pagination .wp-pagenavi span {
	-webkit-text-decoration: none;
	align-items: center;
	background-color: #fff;
	border: 1px solid #1c4b90;
	color: #333;
	display: flex;
	height: 2.5rem;
	justify-content: center;
	line-height: 1;
	min-width: 2.5rem;
	padding: 0 0.75rem;
	text-decoration: none;
	transition: background-color 0.3s, color 0.3s, border-color 0.3s;
}

.p-pagination .wp-pagenavi a:hover {
	background-color: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
}

.p-pagination .wp-pagenavi span.current {
	background-color: #1c4b90;
	border-color: #1c4b90;
	color: #fff;
	font-weight: 700;
}

.p-pagination .wp-pagenavi span.pages,
.p-pagination .wp-pagenavi span.extend {
	background-color: transparent;
	border: 0;
	color: #333;
	min-width: auto;
	padding: 0 0.25rem;
}

.p-pagination .wp-pagenavi .previouspostslink,
.p-pagination .wp-pagenavi .nextpostslink {
	font-size: 0.875rem;
	padding: 0 0.875rem;
}

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

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

html {
	font-size: 1.4814814815vw;
}

a[href^="tel:"] {
	pointer-events: none;
}

a:hover {
	opacity: 0.8;
}

.l-activities {
	padding: 5rem 0;
}

.l-business {
	padding: 6.25rem 0;
}

.l-inner {
	max-width: 1130px;
	padding-left: 25px;
	padding-right: 25px;
}

.l-instagram {
	padding: 5rem 0;
}

.l-media {
	padding: 5rem 0;
}

.l-message {
	padding: 5rem 0;
}

.l-news-archive {
	padding: 5rem 0;
}

.l-news {
	padding: 5rem 0;
}

.l-scroll-text {
	padding: 3.125rem 0;
}

.p-service-intro {
	padding: 5rem 0;
}

.c-breadcrumb,
.p-breadcrumb,
.breadcrumb {
	font-size: 0.8125rem;
}

.c-button {
	background: transparent;
	color: #333;
}

.c-button:hover {
	opacity: 1;
}

.c-button:hover span {
	color: #fff;
}

.c-button:hover:before {
	border-right: solid 2px #fff;
	border-top: solid 2px #fff;
	left: 2.5rem;
}

.c-button:hover:after {
	background: #1c4b90;
	right: 0;
	width: 100%;
}

.c-button.c-button--white {
	background: transparent;
	color: #fff;
}

.c-button--white:hover span {
	color: #1c4b90;
}

.c-button--white:hover:before {
	border-right: solid 2px #1c4b90;
	border-top: solid 2px #1c4b90;
	left: 2.5rem;
}

.c-button--white:hover:after {
	background: #fff;
	right: 0;
	width: 100%;
}

.c-card-activities__title {
	font-size: 1rem;
}

.p-activities__button {
	align-items: center;
	justify-content: right;
	margin-top: 2.25rem;
}

.c-card-activities {
	opacity: 0.56;
	transform: scale(0.9);
}

.p-activities-swiper .swiper-slide-prev .c-card-activities,
.p-activities-swiper .swiper-slide-next .c-card-activities {
	opacity: 0.8;
	transform: scale(0.95);
}

.p-activities-swiper .swiper-slide-active .c-card-activities {
	opacity: 1;
	transform: scale(1) translateY(-0.75rem);
}

.c-card-activity__body {
	padding: 1.125rem;
}

.c-card-activity__title {
	font-size: 1.375rem;
}

.c-card-media__body {
	padding: 1.25rem;
}

.c-card-media__title {
	font-size: 1.1875rem;
}

.c-card-movie__body {
	padding: 1.25rem;
}

.c-card-movie__title {
	font-size: 1.1875rem;
}

.c-contact-confirm__item {
	align-items: start;
	gap: 1.5rem;
	grid-template-columns: 11.25rem 1fr;
	padding: 1.5rem 0;
}

.c-contact-confirm__actions {
	flex-direction: row;
	gap: 1.125rem;
	justify-content: center;
	margin-top: 2.5rem;
}

.c-contact-confirm__item {
	align-items: start;
	gap: 1.5rem;
	grid-template-columns: 11.25rem 1fr;
	padding: 1.5rem 0;
}

.c-contact-confirm__actions {
	flex-direction: row;
	gap: 1.125rem;
	justify-content: center;
	margin-top: 2.5rem;
}

.c-page-link__prev,
.c-page-link__next {
	font-size: 0.875rem;
}

.c-section-header__jatitle {
	font-size: 1.375rem;
	margin-top: 0.75rem;
}

.c-section-header__jatitle::after {
	width: 6.875rem;
}

.c-section-header__subpage {
	font-size: 2rem;
}

.c-section-header--bg::before {
	font-size: 10rem;
	left: -0.625rem;
	top: -1.25rem;
}

.p-about-action {
	padding: 8.25rem 0 7.75rem;
}

.p-about-action__head {
	grid-column-gap: 4.375rem;
	-moz-column-gap: 4.375rem;
	align-items: end;
	column-gap: 4.375rem;
	display: grid;
	grid-template-columns: 28.75rem 1fr;
	margin-bottom: 5.5rem;
}

.p-about-action__sub {
	font-size: 0.75rem;
	letter-spacing: 0.34em;
}

.p-about-action__title {
	font-size: max(3.75rem, min(6vw, 5.75rem));
	letter-spacing: 0.04em;
	line-height: 1.02;
}

.p-about-action__heading-block::after {
	margin-top: 1.625rem;
	width: 8.25rem;
}

.p-about-action__lead {
	align-self: end;
	font-size: 1.25rem;
	line-height: 2.1;
	margin: 0 0 0.75rem;
	max-width: 30rem;
}

.p-about-action__bg-text {
	font-size: max(8.625rem, min(15vw, 17.5rem));
	left: -0.75rem;
	top: -1.875rem;
}

.p-about-action__list {
	gap: 3rem;
	width: min(56.25rem, 100%);
}

.p-about-action__line {
	bottom: 1.25rem;
	left: 2.25rem;
	top: 1.25rem;
}

.p-about-action-card {
	padding-left: 5.625rem;
}

.p-about-action-card::before {
	box-shadow: 0 0 0 0.5rem rgba(76, 169, 240, 0.045), 0 0 1.375rem rgba(76, 169, 240, 0.11);
	height: 0.8125rem;
	left: 1.875rem;
	top: 1.125rem;
	width: 0.8125rem;
}

.p-about-action-card__num {
	color: rgba(28, 75, 144, 0.06);
	font-size: 4.875rem;
	left: -0.125rem;
	top: -0.875rem;
}

.p-about-action-card__content {
	padding-left: 1.625rem;
}

.p-about-action-card__content::before {
	left: 0;
}

.p-about-action-card__content::after {
	border-radius: 1rem;
	bottom: -0.625rem;
	left: -0.875rem;
	right: -0.875rem;
	top: -0.625rem;
}

.p-about-action-card__title {
	font-size: max(1.75rem, min(2.45vw, 2.25rem));
	letter-spacing: 0.025em;
	line-height: 1.58;
}

.p-about-action-card__text {
	font-size: 1.25rem;
	letter-spacing: 0.035em;
	line-height: 2.1;
	margin-top: 0.875rem;
}

.p-about-action-card.is-active::before {
	box-shadow: 0 0 0 0.75rem rgba(76, 169, 240, 0.075), 0 0 1.875rem rgba(76, 169, 240, 0.24);
}

.p-about-action__visual {
	margin: 6rem auto 0;
	padding-bottom: 2rem;
	width: min(57.5rem, 100%);
}

.p-about-action__shape--back {
	aspect-ratio: 1.9/1;
	left: 4.5rem;
	width: min(35rem, 72%);
}

.p-about-action__shape--front {
	height: 8.25rem;
	right: 2.75rem;
	top: -1.625rem;
	width: 8.25rem;
}

.p-about-action__image-wrap {
	aspect-ratio: 1.9/1;
	margin-right: 3.5rem;
	width: min(35rem, 72%);
}

.p-about-hero {
	min-height: 22.5rem;
}

.p-about-hero__content {
	min-height: 22.5rem;
	padding-bottom: 2.5rem;
	padding-top: 9.375rem;
}

.p-about-hero__sub {
	font-size: 0.8125rem;
}

.p-about-hero__bg-text {
	font-size: max(8.75rem, min(18vw, 20rem));
	left: -0.5rem;
}

.p-about-mvv {
	padding: 10rem 0;
}

.p-about-mvv__head {
	margin-bottom: 2.5rem;
	padding-bottom: 1.5rem;
}

.p-about-mvv__head::after {
	width: 6.875rem;
}

.p-about-mvv__sub {
	font-size: 1.125rem;
	letter-spacing: 0.24em;
}

.p-about-mvv__heading {
	font-size: max(1.75rem, min(3.8vw, 2.5rem));
}

.p-about-mvv__bg-text {
	font-size: max(2.125rem, min(8vw, 7.5rem));
	left: -1rem;
	letter-spacing: 0.06em;
	transform: translateY(-52%);
}

.p-about-mvv__stage {
	align-items: center;
	gap: 4rem;
	grid-template-columns: minmax(0, 1fr) 32.5rem;
	min-height: 18.75rem;
}

.p-about-mvv__left {
	min-height: auto;
	order: 1;
	padding-top: 0.5rem;
}

.p-about-mvv__right {
	min-height: auto;
	order: 2;
}

.p-about-mvv__right::before {
	bottom: 6%;
	filter: blur(1.25rem);
	left: 4%;
	right: 4%;
	top: 8%;
}

.p-about-mvv__panels {
	min-height: 26.25rem;
}

.p-about-mvv__panel {
	align-items: center;
}

.p-about-mvv__panel-inner {
	max-width: 32.5rem;
	padding: 2rem 0 2rem 2.125rem;
}

.p-about-mvv__panel-inner::before {
	height: 3.875rem;
	top: 0.5rem;
}

.p-about-mvv__panel-inner::after {
	height: 8.75rem;
	top: -0.625rem;
	width: 8.75rem;
}

.p-about-mvv__panel-inner.is-active::before {
	height: 5.5rem;
	transform: translateY(0.125rem);
}

.p-about-mvv__label {
	font-size: 1.25rem;
	letter-spacing: 0.32em;
}

.p-about-mvv__title {
	font-size: max(1.75rem, min(3.2vw, 2rem));
	letter-spacing: 0.04em;
	margin: 0.875rem 0 0;
}

.p-about-mvv__text {
	font-size: 1rem;
	letter-spacing: 0.04em;
	line-height: 2.05;
	margin: 1.375rem 0 0;
	max-width: 27.5rem;
}

.p-about-mvv__visual {
	max-width: 31.25rem;
}

.p-about-mvv__overlay-text {
	line-height: 1.6;
}

.p-about-mvv__overlay-text--blue {
	font-size: 1.625rem;
}

.p-about-mvv__overlay-text--orange {
	font-size: 1.625rem;
}

.p-about-mvv__overlay-text--green {
	font-size: 1.625rem;
}

.p-about-mvv__tabs {
	display: none;
}

.p-access {
	padding: 5rem 0;
}

.p-access__wrapper {
	align-items: center;
	margin-top: 3.125rem;
}

.p-access__contents {
	align-items: flex-start;
	flex-direction: row;
	gap: 3.75rem;
	justify-content: space-around;
}

.p-access__info {
	width: 50%;
}

.p-access__item-title {
	font-size: 1.5rem;
}

.p-access__item-address {
	font-size: 1rem;
	margin-top: 1.25rem;
}

.p-access__item-tel {
	font-size: 1rem;
}

.p-access__button {
	margin-top: 1.875rem;
}

.p-access__line {
	margin-top: 1.875rem;
}

.p-access__routes {
	gap: 1.25rem;
}

.p-access__route + .p-access__route {
	margin-top: 1.25rem;
}

.p-access__map {
	width: 50%;
}

.p-access__map iframe {
	height: 28.125rem;
}

.p-activities-mv {
	min-height: 16.25rem;
}

.p-activities-mv__content {
	min-height: 16.25rem;
	padding-bottom: 2rem;
	padding-top: 8.5rem;
}

.p-activities-mv__sub {
	font-size: 0.8125rem;
}

.p-activities-archive {
	padding: 3rem 0 6rem;
}

.p-activities-archive__lead {
	margin-bottom: 2.5rem;
}

.p-activities-archive__lead-text {
	font-size: 1.125rem;
}

.p-activities-archive__pagination {
	margin-bottom: 6rem;
	margin-top: 4rem;
}

.p-activities-filter {
	margin-bottom: 2.5rem;
}

.p-activities__swiper {
	margin-top: 2.5rem;
	padding-left: 0.75rem;
	padding-right: 0.75rem;
}

.p-activities__swiper::after {
	bottom: 1rem;
	height: 7.5rem;
}

.p-activity-contact {
	margin-top: 4rem;
}

.p-activity-contact__box {
	padding: 2.75rem 2.5rem;
}

.p-activity-contact__buttons {
	flex-direction: row;
	justify-content: center;
}

.p-activity-pager {
	gap: 1.5rem;
	grid-template-columns: 1fr 1fr;
	margin-top: 4rem;
}

.p-activity-pager__link {
	min-height: 7.375rem;
	padding: 1.125rem;
}

.p-activity-pager__title {
	font-size: 1rem;
}

.p-activity-pager__link--prev {
	grid-template-columns: 2.625rem 1fr 6.25rem;
}

.p-activity-pager__link--next {
	grid-template-columns: 6.25rem 1fr 2.625rem;
}

.p-activity-mv {
	min-height: 16.25rem;
}

.p-activity-mv__content {
	min-height: 16.25rem;
	padding-bottom: 2rem;
	padding-top: 8.5rem;
}

.p-activity-mv__sub {
	font-size: 0.8125rem;
}

.p-activity-pager {
	gap: 1.5rem;
	grid-template-columns: 1fr 1fr;
	margin-top: 4rem;
}

.p-activity-pager__link {
	min-height: 7.375rem;
	padding: 1.125rem;
}

.p-activity-pager__title {
	font-size: 1rem;
}

.p-activity-pager__link--prev {
	grid-template-columns: 2.625rem 1fr 6.25rem;
}

.p-activity-pager__link--next {
	grid-template-columns: 6.25rem 1fr 2.625rem;
}

.p-activity-single {
	padding: 3rem 0 6.25rem;
}

.p-activity-single__header {
	padding-bottom: 2rem;
}

.p-activity-single__body {
	margin-top: 2.5rem;
}

.p-activity-single__content {
	font-size: 1.125rem;
}

.p-activity-single__content h2 {
	font-size: 1.875rem;
	padding-left: 1.25rem;
}

.p-activity-contact {
	margin-top: 4rem;
}

.p-activity-contact__box {
	padding: 2.75rem 2.5rem;
}

.p-activity-contact__buttons {
	flex-direction: row;
	justify-content: center;
}

.p-activity-pager {
	gap: 1.5rem;
	grid-template-columns: 1fr 1fr;
	margin-top: 4rem;
}

.p-activity-pager__link {
	min-height: 7.375rem;
	padding: 1.125rem;
}

.p-activity-pager__title {
	font-size: 1rem;
}

.p-activity-pager__link--prev {
	grid-template-columns: 2.625rem 1fr 6.25rem;
}

.p-activity-pager__link--next {
	grid-template-columns: 6.25rem 1fr 2.625rem;
}

.p-achievements-archive {
	padding-bottom: 5rem;
	padding-top: 3.4375rem;
}

.p-achievements-archive__title {
	font-size: 2.5rem;
}

.p-achievements-archive__filter {
	gap: 0.75rem;
	margin-top: 1.875rem;
}

.p-achievements-archive__list {
	gap: 4rem 2.5rem;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 3.125rem;
}

.p-achievements-archive__card-img-wrap {
	height: 15rem;
}

.p-achievements-archive__card-title {
	font-size: 1.125rem;
}

.p-achievements-archive__card-desc {
	font-size: 1rem;
}

.p-achievements-archive__pagination {
	margin-top: 5rem;
}

.p-activity-mv {
	min-height: 16.25rem;
}

.p-activity-mv__content {
	min-height: 16.25rem;
	padding-bottom: 2rem;
	padding-top: 8.5rem;
}

.p-activity-mv__sub {
	font-size: 0.8125rem;
}

.p-activity-single {
	padding: 3rem 0 6.25rem;
}

.p-activity-single__header {
	padding-bottom: 2rem;
}

.p-activity-single__body {
	margin-top: 2.5rem;
}

.p-activity-single__content {
	font-size: 1.125rem;
}

.p-activity-single__content h2 {
	font-size: 1.875rem;
	padding-left: 1.25rem;
}

.p-activity-contact {
	margin-top: 4rem;
}

.p-activity-contact__box {
	padding: 2.75rem 2.5rem;
}

.p-activity-contact__buttons {
	flex-direction: row;
	justify-content: center;
}

.p-activity-pager {
	gap: 1.5rem;
	grid-template-columns: 1fr 1fr;
	margin-top: 4rem;
}

.p-activity-pager__link {
	min-height: 7.375rem;
	padding: 1.125rem;
}

.p-activity-pager__title {
	font-size: 1rem;
}

.p-activity-pager__link--prev {
	grid-template-columns: 2.625rem 1fr 6.25rem;
}

.p-activity-pager__link--next {
	grid-template-columns: 6.25rem 1fr 2.625rem;
}

.p-archive-home__item:not(:first-child) {
	margin-top: 0.9375rem;
}

.p-archive-works__items {
	gap: 1.75rem 1.875rem;
	grid-template-columns: repeat(3, 1fr);
}

.p-service-detail {
	padding-bottom: 8.75rem;
	padding-top: 5.5rem;
}

.p-service-detail__contents {
	margin-top: 4rem;
}

.p-service-detail__item + .p-service-detail__item {
	margin-top: 6rem;
}

.p-service-detail__item-top {
	display: flex;
	gap: 2.5rem;
}

.p-service-detail__item-body {
	width: 50%;
}

.p-service-detail__item-head {
	gap: 1.5rem;
	padding-bottom: 1.75rem;
}

.p-service-detail__title {
	font-size: 2.375rem;
}

.p-service-detail__subtitle {
	font-size: 1rem;
}

.p-service-detail__lead {
	font-size: 1.75rem;
	padding-top: 1.25rem;
}

.p-service-detail__text-block {
	margin-top: 1.375rem;
}

.p-service-detail__text {
	font-size: 1.125rem;
}

.p-service-detail__image {
	width: 50%;
}

.p-service-detail__item-bottom {
	display: flex;
	gap: 2.5rem;
}

.p-service-detail__wrapper {
	margin-top: 1.25rem;
}

.p-service-detail__card-list {
	grid-template-columns: repeat(3, 1fr);
	margin-top: 1.25rem;
}

.p-service-detail__item--reverse .p-service-detail__item-top {
	flex-direction: row-reverse;
}

.p-service-detail__item + .p-service-detail__item {
	margin-top: 8.125rem;
}

.p-common-lists__list {
	display: flex;
	padding: 1.875rem 0;
}

.p-common-lists__list dt {
	width: 10.875rem;
}

.p-common-lists__list dd {
	margin-top: 0;
	width: calc(100% - 10.875rem);
}

.p-company-access__map iframe {
	height: 26.25rem;
}

.p-company-info__row {
	gap: 1.5rem;
	grid-template-columns: 11.25rem 1fr;
	padding: 1.375rem 0;
}

.p-company-mv {
	min-height: 16.25rem;
}

.p-company-mv__line {
	bottom: 1.5rem;
	right: -20%;
	width: 84%;
}

.p-company-mv__content {
	min-height: 16.25rem;
	padding-bottom: 2rem;
	padding-top: 8.5rem;
}

.p-company-mv__sub {
	font-size: 0.8125rem;
}

.p-company {
	padding: 3rem 0 6rem;
}

.p-company__lead-text {
	font-size: 1.125rem;
}

.p-contact-confirm {
	padding: 5.5rem 0 7.5rem;
}

.p-contact-confirm__header {
	margin-bottom: 2.5rem;
}

.p-contact-confirm__note {
	font-size: 0.9375rem;
}

.p-contact-confirm__form {
	border-radius: 1.25rem;
	padding: 3.25rem 4rem;
}

.p-contact-confirm__form .c-contact-confirm {
	gap: 1.25rem;
}

.p-contact-confirm__form .c-contact-confirm__item {
	align-items: start;
	border-radius: 0.75rem;
	gap: 1.25rem;
	grid-template-columns: 11.25rem 1fr;
	padding: 1.25rem 1.5rem;
}

.p-contact-confirm__form .c-contact-confirm__label {
	font-size: 0.9375rem;
}

.p-contact-confirm__form .c-contact-confirm__value {
	font-size: 0.9375rem;
}

.p-contact-confirm__form .c-contact-confirm__actions {
	flex-direction: row;
	gap: 1.25rem;
	justify-content: center;
	margin-top: 1.125rem;
}

.p-contact-confirm__form .c-contact-confirm__back-btn,
.p-contact-confirm__form .c-contact-confirm__submit-btn {
	font-size: 1rem;
	min-width: 13.75rem;
	width: auto;
}

.p-contact-confirm__loading-text {
	font-size: 1rem;
}

.p-contact-mv {
	min-height: 16.25rem;
}

.p-contact-mv__line {
	bottom: 1.5rem;
	right: -20%;
	width: 84%;
}

.p-contact-mv__content {
	min-height: 16.25rem;
	padding-bottom: 2rem;
	padding-top: 8.5rem;
}

.p-contact-mv__sub {
	font-size: 0.8125rem;
}

.p-contact-page {
	padding: 5.5rem 0 7.5rem;
}

.p-contact-page__text {
	font-size: 1rem;
}

.p-contact-page__info {
	gap: 1.25rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	margin-top: 2.75rem;
}

.p-contact-page__form-wrap {
	margin-top: 3rem;
	padding: 3.25rem 4rem;
}

.p-contact-page__form-head {
	margin-bottom: 2.25rem;
}

.p-contact-page__form-title {
	font-size: 1.5rem;
}

.p-contact-page__form-meta {
	font-size: 0.875rem;
}

.p-contact-page__notes {
	margin-top: 2.125rem;
	padding: 1.5rem 0.5rem 0;
}

.p-contact {
	padding: 5rem 0;
}

.p-contact__inner {
	max-width: 56.25rem;
}

.p-contact__visual {
	padding: 6.25rem 2.5rem;
}

.p-contact__visual::after {
	background: #90811c;
	bottom: -2.1875rem;
	content: "";
	display: block;
	left: 0.875rem;
	position: absolute;
	right: -0.875rem;
	top: 2.1875rem;
	transform: rotate(-1.2deg);
	z-index: -1;
}

.p-contact__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.p-contact__actions {
	display: flex;
	gap: 2.5rem;
	justify-content: center;
	margin-top: 1.875rem;
}

.p-contact__action + .p-contact__action {
	margin-top: 0;
}

.p-contact__telBox {
	align-items: center;
	display: flex;
	gap: 1.25rem;
	justify-content: space-around;
	margin-top: 2.5rem;
	padding: 1.875rem;
}

.p-contact__telLeft {
	gap: 1rem;
}

.p-contact__telIcon {
	height: 2.5rem;
	width: 2.5rem;
}

.p-contact__tel {
	font-size: 2.25rem;
}

.p-contact__telRight {
	gap: 0.25rem;
	text-align: left;
}

.p-footer-nav__items {
	justify-content: center;
}

.p-footer {
	padding: 5rem 0 0.625rem;
}

.p-footer__contents {
	align-items: flex-start;
	display: flex;
	gap: 1.25rem;
	justify-content: space-around;
}

.p-footer__brand {
	gap: 1.125rem;
}

.p-footer__logo {
	padding: 1.125rem;
	width: 10rem;
}

.p-footer__sns {
	gap: 0.875rem;
}

.p-footer__snsLink {
	height: 2.5rem;
	width: 2.5rem;
}

.p-footer__snsLink img {
	height: 2.5rem;
	width: 2.5rem;
}

.p-footer__groupTitle {
	font-weight: 700;
	margin-bottom: 0.875rem;
}

.p-footer__item--sub {
	padding-left: 0.625rem;
}

.p-footer__copy {
	margin-top: 1.875rem;
}

.p-footer__nav {
	margin-top: 0;
}

.p-form__radio {
	display: block;
	gap: 0;
}

.p-header {
	height: 7.75rem;
}

.p-header__inner {
	padding: 0 2.5rem 0 2rem;
}

.p-header__logo {
	max-width: 6rem;
}

.p-header__nav {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	height: 100%;
	justify-content: center;
}

.p-header__hamburger {
	display: none;
}

.p-instagram__button {
	margin-top: 3rem;
}

.p-loading__kabu-block {
	left: 5.19531px;
	top: 103.578px;
}

.p-loading__kanji-block {
	left: 71.30208px;
	top: 83.83333px;
}

.p-loading__english-block {
	left: 73.5781px;
	top: 162.008px;
}

.p-lower-mv {
	min-height: 20rem;
}

.p-lower-mv__inner {
	padding-bottom: 2.125rem;
	padding-top: 9.25rem;
}

.p-lower-mv__sub {
	font-size: 0.875rem;
}

.p-lower-mv__bg-text {
	color: rgba(255, 255, 255, 0.07);
	font-size: max(7.5rem, min(13vw, 11.25rem));
	left: -0.5rem;
	transform: translateY(-38%);
}

.p-media__content {
	margin-top: 2.5rem;
}

.p-media__wrapper {
	margin-top: 3.75rem;
}

.p-media__list {
	gap: 1.5rem;
	grid-template-columns: repeat(3, 1fr);
}

.p-media__button {
	margin-top: 3rem;
}

.p-message__wrapper {
	gap: 2.5rem;
}

.p-message__content {
	font-size: 1.125rem;
	margin-top: 1.875rem;
}

.p-message__content-text:not(:first-child) {
	margin-top: 0.625rem;
}

.p-message__button {
	margin-top: 1.875rem;
}

.js-message-cards.is-inview .p-message__card--left {
	transform: translate3d(-1.5rem, 1rem, 0) rotate(-4deg) scale(0.95);
}

.js-message-cards.is-inview .p-message__card--right {
	transform: translate3d(1.5rem, 1rem, 0) rotate(4deg) scale(0.95);
}

.p-movie-mv {
	min-height: 16.25rem;
}

.p-movie-mv__content {
	min-height: 16.25rem;
	padding-bottom: 2rem;
	padding-top: 8.5rem;
}

.p-movie-mv__sub {
	font-size: 0.8125rem;
}

.p-movie-archive {
	padding: 3rem 0 6rem;
}

.p-movie-archive__lead {
	margin-bottom: 2.5rem;
}

.p-movie-archive__lead-text {
	font-size: 1.125rem;
}

.p-movie-archive__pagination {
	margin-bottom: 6rem;
	margin-top: 4rem;
}

.p-movie-filter {
	margin-bottom: 2.5rem;
}

.p-movie-single {
	padding: 3rem 0 6.25rem;
}

.p-movie-single__header {
	padding-bottom: 2rem;
}

.p-movie-single__body {
	margin-top: 2.5rem;
}

.p-movie-single__content {
	font-size: 1.125rem;
}

.p-movie-single__content h2 {
	font-size: 1.875rem;
	padding-left: 1.25rem;
}

.p-movie-contact {
	margin-top: 4rem;
}

.p-movie-contact__box {
	padding: 2.75rem 2.5rem;
}

.p-movie-contact__buttons {
	flex-direction: row;
	justify-content: center;
}

.p-movie-pager {
	gap: 1.5rem;
	grid-template-columns: 1fr 1fr;
	margin-top: 4rem;
}

.p-movie-pager__link {
	min-height: 7.375rem;
	padding: 1.125rem;
}

.p-movie-pager__title {
	font-size: 1rem;
}

.p-movie-pager__link--prev {
	grid-template-columns: 2.625rem 1fr 6.25rem;
}

.p-movie-pager__link--next {
	grid-template-columns: 6.25rem 1fr 2.625rem;
}

.p-mv__inner {
	padding: 0 4rem 4rem;
}

.p-mv__content {
	max-width: 61.25rem;
	text-align: left;
	text-shadow: 0 0 10px rgba(0, 0, 0, 0.5);
}

.p-mv__title-row--2 {
	margin-top: 0.5rem;
}

.p-mv__title-word--1 {
	font-size: max(5.625rem, min(9vw, 8.75rem));
}

.p-mv__title-word--2 {
	font-size: max(6.25rem, min(10vw, 10rem));
}

.p-mv__copy {
	margin-top: 1.625rem;
}

.p-mv__button {
	justify-content: flex-start;
	margin-top: 2.5rem;
}

.p-mv__bg-base img,
.p-mv__bg-blur img {
	-o-object-position: center;
	object-position: center;
}

.p-news-archive {
	padding: 5rem 0;
}

.p-news-list__item a {
	align-items: flex-start;
	display: flex;
}

.p-news-list__item-title {
	margin-left: 3.75rem;
	margin-top: 0;
}

.p-news__inner {
	grid-column-gap: 3.5rem;
	-moz-column-gap: 3.5rem;
	grid-row-gap: 1.75rem;
	align-items: start;
	column-gap: 3.5rem;
	display: grid;
	grid-template-columns: 16.25rem 1fr;
	row-gap: 1.75rem;
}

.p-news__title {
	grid-column: 1;
	grid-row: 1;
}

.p-news .c-section-header--bg::before {
	color: rgba(7, 20, 64, 0.035);
	font-size: 5.25rem;
	left: -0.375rem;
	top: -0.375rem;
}

.p-news__title .c-section-header__engtitle {
	font-size: 3.5rem;
}

.p-news__title .c-section-header__jatitle {
	font-size: 1.125rem;
	margin-top: 0.5rem;
	padding-bottom: 0.75rem;
}

.p-news__title .c-section-header__jatitle::after {
	width: 5.125rem;
}

.p-news__list {
	grid-column: 2;
	grid-row: 1/3;
}

.p-news__button {
	align-self: start;
	grid-column: 1;
	grid-row: 2;
	margin-top: 0;
}

.p-page-contact__text {
	font-size: 1rem;
}

.p-page-contact__content {
	margin-top: 2.5rem;
	padding: 5.625rem;
}

.p-privacy-mv {
	min-height: 16.25rem;
}

.p-privacy-mv__line {
	bottom: 1.5rem;
	right: -20%;
	width: 84%;
}

.p-privacy-mv__content {
	min-height: 16.25rem;
	padding-bottom: 2rem;
	padding-top: 8.5rem;
}

.p-privacy-mv__sub {
	font-size: 0.8125rem;
}

.p-privacy {
	padding: 3rem 0 6rem;
}

.p-privacy__lead {
	margin-bottom: 3.5rem;
}

.p-privacy__lead-text {
	font-size: 1rem;
}

.p-privacy__body {
	gap: 3rem;
}

.p-privacy__section {
	padding-bottom: 3rem;
}

.p-privacy__heading {
	font-size: 1.25rem;
	margin-bottom: 1.25rem;
}

.p-privacy__text {
	font-size: 0.9375rem;
}

.p-privacy__list {
	font-size: 0.9375rem;
	margin-top: 1rem;
}

.p-privacy__contact-info {
	padding: 1.5rem 2rem;
}

.p-scroll-text__row--lg .p-scroll-text__item {
	font-size: 6rem;
}

.p-scroll-text__row--md .p-scroll-text__item {
	font-size: 8rem;
}

.p-scroll-text__row--sm .p-scroll-text__item {
	font-size: 6rem;
}

.p-service-band {
	margin-top: 3.5rem;
	padding: 3rem 3.5rem 3.5rem;
}

.p-service-band__title {
	font-size: 1.875rem;
	margin-bottom: 2.25rem;
}

.p-service-band__grid.p-service-band__grid--col2 {
	grid-template-columns: repeat(2, 1fr);
}

.p-service-band__grid.p-service-band__grid--col3 {
	grid-template-columns: repeat(3, 1fr);
}

.p-service-band__grid.p-service-band__grid--col4 {
	grid-template-columns: repeat(4, 1fr);
}

.p-service-band__col {
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	min-height: 16.25rem;
	min-height: 16.25rem;
	padding: 1.75rem 1.5rem 1.625rem;
	padding: 1.75rem 1.5rem 1.625rem;
	transition: transform 0.4s, border-color 0.4s, background 0.4s;
}

.p-service-band__col:hover {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.24);
	transform: translateY(-0.1875rem);
}

.p-service-band__col-name {
	font-size: 1.5rem;
}

.p-service-band__pain-grid {
	gap: 0.875rem;
	grid-template-columns: repeat(3, 1fr);
}

.p-service-band__pain-item {
	justify-content: center;
	padding: 0.875rem 1rem;
}

.p-service-band__pain-item:hover {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.24);
	transform: translateY(-0.1875rem);
}

.p-service-hero {
	min-height: 22.5rem;
}

.p-service-hero__content {
	min-height: 22.5rem;
	padding-bottom: 2.5rem;
	padding-top: 9.375rem;
}

.p-service-hero__sub {
	font-size: 0.8125rem;
}

.p-service-hero__bg-text {
	font-size: max(8.75rem, min(18vw, 20rem));
	left: -0.5rem;
}

.p-service-intro__title {
	font-size: 2.5rem;
}

.p-service-intro__text {
	font-size: 1.25rem;
	margin-top: 1.25rem;
}

.p-service-section__main {
	align-items: center;
	gap: 0 3.25rem;
	grid-template-columns: 1fr 1fr;
	min-height: 28.75rem;
	padding: 4.5rem 3.5rem 0;
}

.p-service-section--left .p-service-section__text {
	order: 2;
}

.p-service-section--left .p-service-section__img {
	order: 1;
}

.p-service-section__en {
	font-size: 1.25rem;
}

.p-service-section__lead {
	font-size: 1.5rem;
}

.p-service-section__main {
	align-items: center;
	gap: 3.5rem;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
	min-height: 31.25rem;
	padding: 5rem 3.5rem 0;
}

.p-service-section--left .p-service-section__text {
	order: 2;
}

.p-service-section--left .p-service-section__img {
	order: 1;
}

.p-service-section__eyebrow {
	font-size: 0.8125rem;
}

.p-service {
	padding: 5rem 0;
}

.p-service__contents {
	margin-top: 3.75rem;
}

.p-service__item + .p-service__item {
	margin-top: 3.75rem;
}

.p-service__item-body {
	align-items: center;
	display: flex;
	gap: 3.75rem;
	justify-content: center;
	margin-left: auto;
	margin-right: auto;
	max-width: none;
	padding-left: 25px;
	padding-right: 25px;
	width: min(100%, 1080px);
}

.p-service__item-body--reverse {
	flex-direction: row-reverse;
	margin: 0 auto;
}

.p-service__item.p-service__item--reverse .p-service__item-body {
	margin-left: auto;
	margin-right: auto;
}

.p-service__item-image {
	width: 50%;
}

.p-service__item-content {
	padding-left: 3.5rem;
	padding-top: 0.625rem;
	width: 50%;
}

.p-service__item-title {
	font-size: 2rem;
}

.p-service__item-subtitle {
	font-size: 1.5rem;
}

.p-service__item-text-block {
	margin-top: 1.25rem;
}

.p-service__item-text {
	font-size: 1.125rem;
}

.p-service__item-button {
	margin-top: 2.5rem;
	max-width: 25rem;
}

.p-single-body__title h1 {
	font-size: 2rem;
}

.p-single-body__meta {
	margin-top: 0.625rem;
}

.p-single-body__image {
	margin-top: 1.6875rem;
}

.p-single-body__content h2 {
	font-size: 1.5rem;
	margin-top: 3.75rem;
}

.p-single-body__content h3 {
	font-size: 1.125rem;
}

.p-single-mv {
	min-height: 11.25rem;
}

.p-single-mv__inner {
	padding-bottom: 1.5rem;
	padding-top: 7rem;
}

.p-single-mv__sub {
	font-size: 0.8125rem;
}

.p-single-mv__bg-text {
	color: rgba(255, 255, 255, 0.07);
	font-size: max(6.25rem, min(14vw, 13.75rem));
	left: -0.5rem;
}

.p-single {
	padding: 2.5rem 0 6.25rem;
}

.p-single__hero {
	margin-bottom: 3rem;
	padding-bottom: 1.875rem;
}

.p-single__hero::after {
	width: 8.75rem;
}

.p-single__cat {
	font-size: 0.8125rem;
	min-height: 2.125rem;
}

.p-single__date {
	font-size: 0.9375rem;
}

.p-single__thumbnail {
	border-radius: 1rem;
}

.p-single__body {
	margin-top: 2.5rem;
}

.p-single__content {
	font-size: 1.125rem;
}

.p-single__content h2 {
	font-size: 1.875rem;
	padding-left: 1.25rem;
}

.p-single__content h3 {
	font-size: 1.5rem;
}

.p-single__pager {
	gap: 1.5rem;
	grid-template-columns: 1fr 1fr;
	margin-top: 4rem;
}

.p-single__pager-link {
	min-height: 7.375rem;
	padding: 1.125rem;
}

.p-single__pager-label {
	font-size: 0.8125rem;
}

.p-single__pager-title {
	font-size: 1rem;
}

.p-single__pager-link--prev {
	grid-template-columns: 2.625rem 1fr 6.25rem;
}

.p-single__pager-link--next {
	grid-template-columns: 6.25rem 1fr 2.625rem;
}

.p-sub-mv {
	height: 34.375rem;
}

.p-sub-mv__title {
	font-size: 2.1875rem;
}

.p-thanks {
	padding: 5.5rem 0 7.5rem;
}

.p-thanks__icon {
	height: 6.5rem;
	margin-bottom: 2.25rem;
	width: 6.5rem;
}

.p-thanks__icon svg {
	height: 3rem;
	width: 3rem;
}

.p-thanks__heading {
	font-size: max(1.75rem, min(3vw, 2.25rem));
}

.p-thanks__desc {
	font-size: 1rem;
	line-height: 2.1;
	margin-top: 2rem;
}

.p-thanks__btn-wrap {
	margin-top: 3rem;
}

.p-thanks__btn {
	font-size: 1.0625rem;
	min-height: 3.75rem;
	min-width: 17.5rem;
}

.p-activities-swiper .swiper-pagination {
	bottom: 1.5rem;
}

.p-activities-swiper__button-wrap {
	justify-content: right;
}

.p-activities-swiper__button-wrap .swiper-button-prev,
.p-activities-swiper__button-wrap .swiper-button-next {
	height: 3.125rem;
	transition: background-color 0.3s, border 0.3s;
	width: 3.125rem;
}

.p-activities-swiper__button-wrap .swiper-button-prev:hover {
	background-color: #fff;
	border: 1px solid #1c4b90;
	opacity: 1;
}

.p-activities-swiper__button-wrap .swiper-button-next:hover {
	background-color: #fff;
	border: 1px solid #1c4b90;
	opacity: 1;
}

.p-activities-swiper__button-wrap .swiper-button-prev::before,
.p-activities-swiper__button-wrap .swiper-button-next::before {
	height: 0.8125rem;
	transition: border-top 0.3s, border-right 0.3s;
	width: 0.8125rem;
}

canvas {
	display: block;
	display: block;
	vertical-align: bottom;
}

#particles-js {
	background-color: #ffffff;
	background-image: url("");
	background-position: 50% 50%;
	background-repeat: no-repeat;
	background-size: cover;
	height: 100%;
	position: absolute;
	width: 50%;
	z-index: -1;
}

.p-pagination {
	margin-top: 3.5rem;
}

.p-pagination .wp-pagenavi a,
.p-pagination .wp-pagenavi span {
	height: 3rem;
	min-width: 3rem;
}

.p-pagination .wp-pagenavi .previouspostslink,
.p-pagination .wp-pagenavi .nextpostslink {
	padding: 0 1.125rem;
}

}

@media (min-width: 768px) {

.p-activities-grid {
	gap: 1.5rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

.p-movie-grid {
	gap: 1.5rem;
	grid-template-columns: repeat(2, minmax(0, 1fr));
}

}

@media (min-width: 1024px) {

.p-activities-grid {
	gap: 1.75rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

.p-movie-grid {
	gap: 1.75rem;
	grid-template-columns: repeat(3, minmax(0, 1fr));
}

}

@media (min-width: 1080px) {

html {
	font-size: 16px;
}

}

@media (max-width: 860px) {

.p-business-story__item {
	gap: 48px;
	grid-template-columns: 1fr;
	padding: 72px 0;
}

.p-business-story__item--rev {
	direction: ltr;
}

.p-business-story__frame {
	aspect-ratio: 16/9;
}

}

@media (max-width: 768px) {

.c-contact-form-line__row {
	gap: 0.625rem;
	grid-template-columns: 1fr;
}

.c-contact-form-line__required {
	width: 3.125rem;
}

.c-contact-form-line__check {
	gap: 0.5rem 1rem;
}

.c-contact-form-line__agree .wpcf7-list-item label {
	align-items: flex-start;
	display: flex;
	gap: 0.5rem;
}

.c-contact-form-line__agree input[type=checkbox],
.wpcf7-acceptance input[type=checkbox] {
	margin-top: 0.25rem;
}

}

@media (max-width: 767px) {

.p-activities::before {
	font-size: max(2.25rem, min(16vw, 4rem));
	top: 1.25rem;
}

.p-activities__swiper {
	padding-left: 0.5rem;
	padding-right: 0.5rem;
}

.c-card-activities {
	filter: saturate(0.84) brightness(0.94);
	opacity: 0.52;
	transform: scale(0.86);
}

.p-activities-swiper .swiper-slide-prev .c-card-activities,
.p-activities-swiper .swiper-slide-next .c-card-activities {
	filter: saturate(0.9);
	opacity: 0.72;
	transform: scale(0.9);
}

.p-activities-swiper .swiper-slide-active .c-card-activities {
	filter: saturate(1);
	opacity: 1;
	transform: scale(1);
}

.c-card-activities__content {
	bottom: 1rem;
	left: 1rem;
	right: 1rem;
}

.c-card-activities__title {
	font-size: 0.9375rem;
}

.p-about-action-card {
	padding-left: 2.625rem;
}

.p-about-action-card::before {
	height: 0.625rem;
	left: 0.75rem;
	top: 0.75rem;
	width: 0.625rem;
}

.p-about-action-card__num {
	font-size: 2.625rem;
	left: 0;
	top: -0.375rem;
}

.p-about-action-card__content {
	padding-left: 0.25rem;
}

.p-about-action-card__content::before {
	left: -0.25rem;
}

.p-about-action-card__content::after {
	height: 1.25rem;
	left: 0;
	width: 4.375rem;
}

.p-about-action-card__title {
	font-size: 1.25rem;
	line-height: 1.55;
}

.p-about-action-card__text {
	font-size: 1rem;
	line-height: 1.9;
	margin-top: 0.625rem;
}

.p-about-action-card.is-active .p-about-action-card__num {
	transform: translateY(-0.25rem) scale(1.03);
}

.p-about-action__visual {
	margin-top: 2.75rem;
	padding-bottom: 1rem;
}

.p-about-action__shape--back {
	-webkit-clip-path: polygon(12% 0, 100% 0, 88% 100%, 0 100%);
	aspect-ratio: 1.75/1;
	clip-path: polygon(12% 0, 100% 0, 88% 100%, 0 100%);
	left: 1rem;
	width: 76%;
}

.p-about-action__shape--front {
	height: 4rem;
	right: 0.375rem;
	top: -0.5rem;
	width: 4rem;
}

.p-about-action__image-wrap {
	-webkit-clip-path: polygon(12% 0, 100% 0, 88% 100%, 0 100%);
	aspect-ratio: 1.75/1;
	box-shadow: 0 0.875rem 1.75rem rgba(15, 23, 42, 0.08), 0 0.25rem 0.625rem rgba(15, 23, 42, 0.04);
	clip-path: polygon(12% 0, 100% 0, 88% 100%, 0 100%);
	margin-left: auto;
	margin-right: 0;
	width: 76%;
}

.p-activities-mv__line {
	bottom: 1.5rem;
	right: -20%;
	width: 84%;
}

.p-message__wrapper {
	align-items: stretch;
	display: flex;
	flex-direction: column;
	gap: 1.125rem;
}

.p-message__left {
	display: contents;
}

.p-message__head {
	max-width: none;
	order: 1;
}

.p-message__right {
	order: 2;
}

.p-message__content {
	max-width: none;
	order: 3;
}

.p-message__button {
	align-items: center;
	display: flex;
	justify-content: center;
	margin-top: 0.625rem;
	order: 4;
}

.p-message__cards {
	margin-left: auto;
	margin-right: auto;
	max-width: 20rem;
}

.p-message__cards::before,
.p-message__cards::after,
.p-message__card--left,
.p-message__card--right {
	display: none;
}

/* SPは中央1枚のみ・フェードのみ */

.p-message__card--center {
	transform: translateY(1.5rem) !important;
}

.p-message__card--center {
	bottom: auto;
	box-shadow: none;
	left: auto;
	opacity: 0;
	position: relative;
	right: auto;
	top: auto;
	transition: opacity 0.8s ease, transform 0.8s cubic-bezier(0.16, 1, 0.3, 1);
}

.p-message__card--center.is-inview {
	transform: translateY(0) !important;
}

.p-message__card--center.is-inview {
	opacity: 1;
}

.p-message__card--center::before {
	bottom: -0.5rem;
	left: 0.5rem;
	right: -0.5rem;
	top: 0.5rem;
}

.p-message__card--center img {
	transform: scale(1);
}

.p-mv__inner {
	align-items: flex-end;
	padding: 0 1.25rem 5.25rem;
}

.p-mv__content {
	position: relative;
	text-align: center;
	width: 100%;
}

.p-mv__title-wrap {
	display: block;
	width: 100%;
}

.p-mv__title {
	width: 100%;
}

.p-mv__title-row--2 {
	margin-top: 0.125rem;
}

.p-mv__copy {
	letter-spacing: 0.08em;
	margin-top: 0.875rem;
}

.p-mv__button {
	margin-top: 1.5rem;
}

.p-mv__button .c-button {
	min-width: 13.75rem;
}

/* SPは演出を整理 */

.p-mv__bg-blur,
.p-mv__particles,
.p-mv__flash,
.p-mv__light-sweep,
.p-mv__blue-line,
.p-mv__smoke--2 {
	display: none;
}

.p-mv__bg-base img {
	-o-object-position: center top;
	filter: brightness(0.78) contrast(1.06) saturate(1.02);
	object-position: center top;
	transform: scale(1.02);
}

.p-mv.is-active .p-mv__bg-base img {
	animation: p-mv-bg-base-sp 8s ease-in-out infinite alternate;
}

.p-mv__overlay {
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.36) 0%, rgba(0, 0, 0, 0.1) 28%, rgba(0, 0, 0, 0.72) 100%), linear-gradient(90deg, rgba(0, 0, 0, 0.42) 0%, rgba(0, 0, 0, 0.08) 50%, rgba(0, 0, 0, 0.32) 100%);
}

.p-mv__vignette {
	background: radial-gradient(circle at center, rgba(0, 0, 0, 0) 32%, rgba(0, 0, 0, 0.12) 68%, rgba(0, 0, 0, 0.42) 100%);
}

.p-mv__backlight {
	background: radial-gradient(circle at 58% 34%, rgba(190, 230, 255, 0.42) 0%, rgba(190, 230, 255, 0.18) 16%, rgba(190, 230, 255, 0.04) 28%, rgba(190, 230, 255, 0) 42%);
}

.p-mv.is-active .p-mv__backlight {
	animation: p-mv-backlight-in 0.9s ease 0.12s forwards, p-mv-backlight-pulse-sp 4s ease-in-out 1s infinite;
}

.p-mv__smoke--1 {
	bottom: -8%;
	filter: blur(26px);
	height: 42%;
	left: -10%;
	opacity: 0.6;
	right: -10%;
	top: auto;
}

.p-mv.is-active .p-mv__smoke--1 {
	animation: p-mv-smoke-sp 5s ease-in-out infinite alternate;
}

.c-scroll-down {
	bottom: 1.375rem;
	font-size: 0.6875rem;
	right: 0.875rem;
}

.c-scroll-down::before {
	height: 4rem;
	margin-bottom: 0.625rem;
}

.p-service-section--left .p-service-section__text {
	order: 2;
}

.p-service-section--left .p-service-section__img {
	order: 1;
}

.p-service-section__bg-num {
	font-size: 40vw;
	top: -0.875rem;
}

.p-service-section__bg-fade {
	display: none;
}

.p-service-section__img::before {
	display: none;
}

.p-service-band::before {
	bottom: 0.5rem;
	font-size: 18vw;
	right: -0.375rem;
}

.p-service-section--left .p-service-section__text {
	order: 1;
}

.p-service-section--left .p-service-section__img {
	order: 2;
}

.p-service-section__bg-num {
	font-size: 42vw;
	top: -1rem;
}

.p-service-section__bg-fade {
	display: none;
}

.p-service-section__img::before {
	display: none;
}

.p-service__item {
	gap: 0;
}

.p-service__item-content {
	padding-bottom: 1.875rem;
	padding-left: calc(20vw + 1.5rem);
	padding-right: 1rem;
	padding-top: 1.5rem;
}

.p-service__item-content::before {
	font-size: 1rem;
	left: calc(20vw - 1.75rem);
	top: 1.25rem;
}

.p-service__item-content::after {
	height: calc(100% - 3.4375rem);
	left: calc(20vw - 1.125rem);
	top: 2.75rem;
	width: 0.0625rem;
}

.p-service__item:not(.p-service__item--reverse) .p-service__item-content {
	text-align: left;
}

.p-service__item:not(.p-service__item--reverse) .p-service__item-button {
	justify-content: flex-end;
}

.p-service__item--reverse .p-service__item-content {
	padding-left: 1rem;
	padding-right: calc(20vw + 1.5rem);
	text-align: left;
}

.p-service__item--reverse .p-service__item-content::before {
	left: auto;
	right: calc(30vw - 1.75rem);
}

.p-service__item--reverse .p-service__item-content::after {
	left: auto;
	right: calc(30vw - 1.125rem);
}

.p-service__item--reverse .p-service__item-button {
	justify-content: flex-start;
}

.p-single-mv__line {
	bottom: 1.5rem;
	right: -20%;
	width: 84%;
}

.p-single-mv__bg-text {
	color: rgba(255, 255, 255, 0.05);
	left: -0.125rem;
}

.p-sp-fixed-cta {
	bottom: 0;
	box-shadow: 0 -0.25rem 1rem rgba(0, 0, 0, 0.18);
	display: grid;
	grid-template-columns: 1fr 1.35fr 1.35fr;
	left: 0;
	padding-bottom: env(safe-area-inset-bottom);
	position: fixed;
	width: 100%;
	z-index: 950;
}

body {
	padding-bottom: calc(3.5rem + env(safe-area-inset-bottom));
}

.p-sp-fixed-cta {
	opacity: 0;
	transform: translateY(100%);
	transition: opacity 0.25s ease, visibility 0.25s ease, transform 0.25s ease;
	visibility: hidden;
}

.p-sp-fixed-cta.is-show {
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
}

.p-sp-fixed-cta.is-hidden {
	opacity: 0;
	transform: translateY(100%);
	visibility: hidden;
}

}

@media (max-width: 600px) {

.p-business-hero__title {
	font-size: max(40px, min(13vw, 68px));
}

.p-business-story__title {
	font-size: max(32px, min(9vw, 52px));
}

.js-cursor-dot {
	display: none;
}

.js-cursor-ring {
	display: none;
}

}

@media (max-width: 375px) {

html {
	font-size: 4.2666666667vw;
}

}

@keyframes scroll-down {

0% {
	transform: scale(1, 0);
	transform-origin: 0 0;
}

50% {
	transform: scale(1, 1);
	transform-origin: 0 0;
}

50.1% {
	transform: scale(1, 1);
	transform-origin: 0 100%;
}

100% {
	transform: scale(1, 0);
	transform-origin: 0 100%;
}

}

@keyframes actionShine {

0% {
	left: -120%;
	opacity: 0;
}

18% {
	opacity: 1;
}

100% {
	left: 140%;
	opacity: 0;
}

}

@keyframes contactConfirmLoading {

0%,80%,100% {
	opacity: 0.4;
	transform: scale(0.7);
}

40% {
	opacity: 1;
	transform: scale(1);
}

}

@keyframes p-mv-bg-base {

0% {
	filter: brightness(0.82) contrast(1.08) saturate(1.04);
	transform: scale(1.05) translate3d(0, 0, 0);
}

100% {
	filter: brightness(0.88) contrast(1.1) saturate(1.08);
	transform: scale(1.11) translate3d(-1%, -0.6%, 0);
}

}

@keyframes p-mv-bg-blur {

0% {
	filter: blur(20px) brightness(1.02);
	opacity: 0.12;
	transform: scale(1.16) translate3d(0, 0, 0);
}

100% {
	filter: blur(24px) brightness(1.12);
	opacity: 0.24;
	transform: scale(1.24) translate3d(1.4%, -1%, 0);
}

}

@keyframes p-mv-backlight-in {

0% {
	opacity: 0;
}

100% {
	opacity: 1;
}

}

@keyframes p-mv-backlight-pulse {

0% {
	opacity: 0.72;
}

50% {
	opacity: 1;
}

100% {
	opacity: 0.78;
}

}

@keyframes p-mv-backlight-pulse-sp {

0% {
	opacity: 0.58;
}

50% {
	opacity: 0.82;
}

100% {
	opacity: 0.62;
}

}

@keyframes p-mv-flash {

0% {
	opacity: 0;
}

18% {
	opacity: 0.9;
}

42% {
	opacity: 0.14;
}

100% {
	opacity: 0;
}

}

@keyframes p-mv-light-sweep {

0% {
	opacity: 0;
	transform: rotate(-18deg) translateX(0);
}

16% {
	opacity: 1;
}

100% {
	opacity: 0;
	transform: rotate(-18deg) translateX(248%);
}

}

@keyframes p-mv-smoke-1 {

0% {
	opacity: 0.68;
	transform: translate3d(-3%, 0, 0) scale(1);
}

100% {
	opacity: 0.96;
	transform: translate3d(3%, -28px, 0) scale(1.14);
}

}

@keyframes p-mv-smoke-2 {

0% {
	opacity: 0.42;
	transform: translate3d(3%, 0, 0) scale(1);
}

100% {
	opacity: 0.74;
	transform: translate3d(-3%, -20px, 0) scale(1.1);
}

}

@keyframes p-mv-smoke-sp {

0% {
	opacity: 0.46;
	transform: translate3d(-2%, 0, 0) scale(1);
}

100% {
	opacity: 0.68;
	transform: translate3d(2%, -14px, 0) scale(1.06);
}

}

@keyframes p-mv-title-sweep-main {

0% {
	left: -55%;
	opacity: 0;
}

12% {
	opacity: 1;
}

100% {
	left: 125%;
	opacity: 0;
}

}

@keyframes p-mv-title-reveal {

0% {
	filter: blur(8px);
	opacity: 0;
	transform: translateY(110%) scale(1.03);
}

60% {
	filter: blur(0);
	opacity: 1;
	transform: translateY(-4%) scale(1.005);
}

100% {
	filter: blur(0);
	opacity: 1;
	transform: translateY(0) scale(1);
}

}

@keyframes p-mv-copy-in {

0% {
	filter: blur(8px);
	opacity: 0;
	transform: translateY(1.125rem);
}

100% {
	filter: blur(0);
	opacity: 1;
	transform: translateY(0);
}

}

@keyframes p-mv-button-in {

0% {
	opacity: 0;
	transform: translateY(1.125rem);
}

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

}

@keyframes p-mv-scroll-float {

0% {
	transform: translateY(0);
}

50% {
	transform: translateY(0.5rem);
}

100% {
	transform: translateY(0);
}

}

@keyframes blueLine {

0% {
	opacity: 0;
	transform: translateX(-100%) rotate(-6deg);
}

20% {
	opacity: 1;
}

100% {
	opacity: 0;
	transform: translateX(120%) rotate(-6deg);
}

}

@keyframes p-mv-bg-base-sp {

0% {
	transform: scale(1.02) translate3d(0, 0, 0);
}

100% {
	transform: scale(1.06) translate3d(-1%, -0.4%, 0);
}

}

@keyframes scrollRTL {

from {
	transform: translateX(0);
}

to {
	transform: translateX(-50%);
}

}

@keyframes p-service-content-shine {

0% {
	left: -20%;
	opacity: 0;
}

20% {
	opacity: 1;
}

100% {
	left: 120%;
	opacity: 0;
}

}

@keyframes p-service-text-shine {

0% {
	left: -24%;
	opacity: 0;
}

18% {
	opacity: 1;
}

100% {
	left: 120%;
	opacity: 0;
}

}

@keyframes scanline {

0% {
	top: -1%;
}

100% {
	top: 101%;
}

}

@keyframes scrollbar {

0% {
	opacity: 1;
	transform: scaleY(0);
	transform-origin: top;
}

50% {
	opacity: 1;
	transform: scaleY(1);
	transform-origin: top;
}

100% {
	opacity: 0;
	transform: scaleY(1);
	transform-origin: bottom;
}

}

@keyframes marquee {

from {
	transform: translateX(0);
}

to {
	transform: translateX(-50%);
}

}

@keyframes pfloat {

0% {
	opacity: 0;
	transform: translateY(105vh) scale(0.5);
}

8% {
	opacity: 0.7;
}

88% {
	opacity: 0.25;
}

100% {
	opacity: 0;
	transform: translateY(-60px) scale(1.8);
}

}

@keyframes spin {

from {
	transform: rotate(0deg);
}

to {
	transform: rotate(360deg);
}

}

@keyframes ballpath {

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

10% {
	opacity: 1;
}

100% {
	opacity: 0;
	transform: translate(50px, -30px) scale(1);
}

}

@keyframes draw {

0% {
	stroke-dashoffset: 120;
}

60% {
	stroke-dashoffset: 0;
}

100% {
	stroke-dashoffset: -120;
}

}

@keyframes barGrow {

from {
	transform: scaleY(0.3);
}

to {
	transform: scaleY(1);
}

}

@keyframes facetPulse {

0%,100% {
	opacity: 0.12;
}

50% {
	opacity: 0.42;
}

}

@keyframes clockHand {

from {
	transform: rotate(0deg);
}

to {
	transform: rotate(360deg);
}

}


/*# sourceMappingURL=styles.css.map */
