html {
	scroll-padding-top: 56px;
}

html.pt-0 {
	scroll-padding-top: 0;
}

body {
	background-color: #EBEBEB;
	color: #1C1C1C;
	font-family: "Noto Sans JP", sans-serif;
}

body.is-hidden {
	overflow: hidden;
}

body.single,
body.page-id-208 {
	background-color: #fff;
}

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

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

html {
	font-size: 16px;
}

*,
*::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: optimizeLegibility;
}

/* 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%;
}

/* 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;
}

/* ホバー */

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

.case-contact-l {
	margin-top: 15rem;
}

.case-l {
	margin-top: 4.5rem;
}

.case-single-contact-l {
	margin-top: 15rem;
}

.case-single-l {
	margin-top: 8.4375rem;
}

.company-contact-l {
	margin-top: 8.75rem;
}

.equipment-contact-l {
	margin-top: 15rem;
}

.faq-contact-l {
	margin-top: 8.875rem;
}

.faq-l {
	margin-top: 8.5625rem;
}

.flow-l {
	margin-top: 8.5625rem;
}

.greeting-l {
	margin-top: 10.625rem;
}

.header-l {
	left: 50%;
	position: fixed;
	top: 0.5rem;
	transform: translateX(-50%);
}

.history-l {
	margin-top: 7.5rem;
}

.introduction-l {
	margin-top: 8rem;
}

.news-contact-l {
	margin-top: 15rem;
}

.news-l {
	margin-top: 13.75rem;
}

.overview-l {
	margin-top: 7.5rem;
}

.policy-l {
	margin-top: 11.4375rem;
}

.post-nav-l {
	margin-top: 9.75rem;
}

.purpose-l {
	margin-top: 7.5rem;
}

.service-l {
	margin-top: 16.125rem;
}

.service-lead-l {
	margin-top: 5.625rem;
}

.service-what-l {
	margin-top: 12.5625rem;
}

.single-contact-l {
	margin-top: 15rem;
}

.single-l {
	margin-top: 7.5rem;
}

.sub-404-l {
	margin-top: 6.25rem;
}

.sub-contact-l {
	margin-top: 10.4375rem;
}

.sub-head-l {
	margin-top: 8.5625rem;
}

.sub-head-l.sub-head--single {
	margin-top: 10.625rem;
}

.sub-head.sub-head--topics {
	margin-top: 11.5625rem;
}

.sub-head-l.sub-head--404 {
	margin-top: 13.3125rem;
}

.thanks-l {
	margin-top: 7.5rem;
}

.top-contact-l {
	background-image: url(../images/top/contact-bg.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	margin-top: 10rem;
}

.appeal {
	background-color: #1C1C1C;
	color: #fff;
	overflow: clip;
	padding-bottom: 2.1875rem;
	padding-top: 7.6875rem;
}

.appeal__inner.inner {
	display: grid;
	grid-template-columns: min(30.7638888889vw, 28rem) 1fr min(17.2222222222vw, 15.5rem);
	padding-left: 2rem;
	padding-right: 2rem;
}

.appeal__content {
	padding-left: 3.75rem;
	padding-right: 1.75rem;
}

.appeal__title {
	margin-top: 5rem;
}

.appeal__text {
	font-size: 1.25rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 2.23;
	margin-top: 3.875rem;
}

.appeal__text + .appeal__text {
	margin-top: 1lh;
}

.appeal__image01 {
	border-radius: 0.625rem;
	overflow: hidden;
	width: 100%;
}

.appeal__image01 img {
	-o-object-fit: cover;
	aspect-ratio: 448/333;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.appeal__image02 {
	border-radius: 0.625rem;
	margin-left: auto;
	margin-top: 3.75rem;
	overflow: hidden;
	width: 72.9910714286%;
}

.appeal__image02 img {
	-o-object-fit: cover;
	aspect-ratio: 327/230;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.appeal__image03 {
	border-radius: 0.625rem;
	margin-right: auto;
	margin-top: 12.625rem;
	overflow: hidden;
	width: min(15vw, 13.5rem);
}

.appeal__image03 img {
	-o-object-fit: cover;
	aspect-ratio: 216/289;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.appeal__image04 {
	border-radius: 0.625rem;
	margin-left: auto;
	margin-right: -6.875rem;
	margin-top: 5.5625rem;
	overflow: hidden;
	width: min(17.3611111111vw, 15.625rem);
}

.appeal__image04 img {
	-o-object-fit: cover;
	aspect-ratio: 250/334;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.breadcrumbs {
	align-items: center;
	color: #1C1C1C;
	display: flex;
	gap: 0.875rem;
}

.breadcrumbs span {
	color: rgba(28, 28, 28, 0.7);
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.1;
}

.breadcrumbs span.current-item {
	color: #1C1C1C;
}

.breadcrumbs a {
	background-image: linear-gradient(#1C1C1C, #1C1C1C);
	background-position: bottom right;
	background-repeat: no-repeat;
	background-size: 0 1px;
	display: flex;
	height: 100%;
	transition: background-size 0.3s;
}

.breadcrumbs span a:hover {
	background-position: bottom left;
	background-size: 100% 1px;
	color: #1C1C1C;
}

.breadcrumbs.breadcrumbs--recruit,
.breadcrumbs.breadcrumbs--recruit span,
.breadcrumbs.breadcrumbs--recruit span.current-item {
	color: #fff;
}

.breadcrumbs.breadcrumbs--recruit a {
	background-image: linear-gradient(#fff, #fff);
}

.button {
	-moz-text-align-last: left;
	background-color: #1C1C1C;
	border-radius: 0.3125rem;
	display: inline-block;
	max-width: 18.25rem;
	padding-bottom: 0.6875rem;
	padding-left: 1.1875rem;
	padding-right: 1.1875rem;
	padding-top: 0.8125rem;
	position: relative;
	text-align-last: left;
	width: 100%;
}

.button::before {
	aspect-ratio: 1;
	border-left: 1px solid #fff;
	content: "";
	display: inline-block;
	height: 100%;
	margin-left: 1.1875rem;
	position: absolute;
	right: 0;
	top: 0;
	width: 3.4375rem;
}

.button::after {
	aspect-ratio: 1;
	background-color: #fff;
	border-radius: 100vh;
	content: "";
	display: block;
	height: 0.4375rem;
	position: absolute;
	right: 1.4375rem;
	top: 50%;
	transform: translateY(-50%) scale(1);
	transition: transform 0.3s;
	width: 0.4375rem;
}

.button:hover:after {
	transform: translateY(-50%) scale(1.571);
}

.button span {
	color: transparent;
	display: inline-block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	margin-right: auto;
	overflow: hidden;
	text-shadow: 0 -1.5em 0 #fff, 0 0 0 #fff;
	transition: text-shadow 0.3s;
}

.button:hover span {
	text-shadow: 0 0 0 #fff, 0 1.5em 0 #fff;
}

.button.button--white {
	background-color: white;
}

.button.button--white::before {
	border-color: #1C1C1C;
}

.button.button--white::after {
	background-color: #1C1C1C;
}

.button.button--white span {
	text-shadow: 0 -1.5em 0 #1C1C1C, 0 0 0 #1C1C1C;
}

.button.button--white:hover span {
	text-shadow: 0 0 0 #1C1C1C, 0 1.5em 0 #1C1C1C;
}

.case-single__inner.inner {
	max-width: 60.125rem;
}

.case-single__title-name {
	color: #124D8A;
	font-family: "Oswald", sans-serif;
	font-size: 0.8125rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1.1;
}

.case-single__title {
	border-bottom: 1px solid #d9d9d9;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.5;
	padding-bottom: 1.5rem;
}

.case-single__gallery {
	margin-top: 2.5rem;
}

.case-single__gallery-main {
	border-radius: 0.3125rem;
	overflow: hidden;
}

.case-single__main-img {
	-o-object-fit: cover;
	aspect-ratio: 912/512;
	height: auto;
	object-fit: cover;
	transition: opacity 0.36s ease, transform 0.36s ease;
	width: 100%;
	will-change: opacity, transform;
}

.case-single__main-img.is-fade-out {
	opacity: 0;
	transform: scale(0.995);
}

.case-single__gallery-thumbs {
	display: flex;
	gap: 0.6875rem;
	list-style: none;
	margin: 0;
	margin-top: 0.75rem;
	padding: 0;
}

.case-single__thumb-item {
	border-radius: 0.1875rem;
	flex: 1 1 0;
	opacity: 1;
	overflow: hidden;
	transition: opacity 0.3s;
}

.case-single__thumb-item:hover {
	opacity: 0.7;
}

.case-single__thumb-btn {
	background: none;
	border: 0;
	cursor: pointer;
	display: block;
	padding: 0;
	width: 100%;
}

.case-single__thumb-img {
	-o-object-fit: cover;
	aspect-ratio: 179/129;
	height: auto;
	object-fit: cover;
	transition: opacity 0.22s ease, transform 0.22s ease;
	width: 100%;
	will-change: opacity, transform;
}

.case-single__thumb-img.is-fade-out {
	opacity: 0;
	transform: scale(0.98);
}

.case-single__contents {
	grid-gap: 4.25rem 3rem;
	display: grid;
	gap: 4.25rem 3rem;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 7.5rem;
}

.case-single__content-title {
	border-top: 2px solid #d9d9d9;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.75;
	padding-top: 0.5rem;
	position: relative;
}

.case-single__content-title::before {
	background-color: #124D8A;
	content: "";
	display: block;
	height: 2px;
	left: 0;
	position: absolute;
	top: 0;
	transform: translateY(-50%);
	width: min(45.6018518519%, 12.3125rem);
}

.case-single__content-text {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.5;
	margin-top: 1rem;
}

.case-slider-pager {
	display: flex;
}

.swiper-button-prev.case-slider-pager__prev,
.swiper-button-next.case-slider-pager__next {
	align-self: end;
	aspect-ratio: 1;
	background-color: #1C1C1C;
	border-radius: 0.3125rem;
	display: flex;
	height: 3.3125rem;
	position: static;
	width: 3.3125rem;
}

.swiper-button-next.case-slider-pager__next {
	margin-left: 0.3125rem;
}

.swiper-button-prev.case-slider-pager__prev::before,
.swiper-button-next.case-slider-pager__next::before {
	-webkit-mask-image: url(../images/common/arrow01.svg);
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	aspect-ratio: 1;
	background-color: #fff;
	content: "";
	display: block;
	height: 1rem;
	mask-image: url(../images/common/arrow01.svg);
	mask-position: center;
	mask-repeat: no-repeat;
	mask-size: contain;
	transition: all 0.3s;
	width: 1rem;
}

.swiper-button-prev.case-slider-pager__prev::before {
	transform: rotate(-180deg);
}

.swiper-button-prev.case-slider-pager__prev:hover::before {
	transform: rotate(-180deg) scale(1.2);
}

.swiper-button-next.case-slider-pager__next:hover::before {
	transform: scale(1.2);
}

.swiper-button-prev.case-slider-pager__prev::after,
.swiper-button-next.case-slider-pager__next::after {
	display: none;
}

.case-slider-pager__pagination.swiper-pagination {
	flex: 1;
	margin-left: 2.5rem;
	position: static;
	width: -moz-fit-content;
	width: fit-content;
}

.case-slider-pager__pagination.swiper-pagination .swiper-pagination-bullet {
	background: rgba(28, 28, 28, 0.2);
	border-radius: 0;
	height: 2px;
	margin: 0;
	opacity: 1;
	position: relative;
	transform: translateY(0.625rem);
	width: 6.575rem;
}

.case-slider-pager__pagination.swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active::before {
	animation: progress 3000ms linear 0s 1 forwards;
	background-color: #1C1C1C;
	content: "";
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
}

.case-slider-thumbnail {
	align-self: end;
}

.case-slider-thumbnail__slide.swiper-slide {
	opacity: 1;
	transition: opacity 0.3s, visibility 0.3s;
	visibility: visible;
	width: 13.5rem;
}

.case-slider-thumbnail__slide.swiper-slide-active {
	display: none;
	opacity: 0;
	transition: all 0.3s;
	visibility: hidden;
}

.case-slider-thumbnail__slide.swiper-slide-prev {
	opacity: 0;
	transition: all 0.3s;
	visibility: hidden;
}

.case-slider {
	width: 100%;
}

.case-slider__slide {
	background-color: #fff;
	border-radius: 0.3125rem;
}

.case-slider__link {
	display: grid;
	grid-template-columns: 1fr min(23.0555555556vw, 20.75rem);
	grid-template-rows: auto auto;
	position: relative;
	width: 42.5rem;
}

.case-slider__content {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: auto repeat(2, 1fr);
	padding: 1.5rem;
}

.case-slider__slide-num {
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1.45;
	text-transform: uppercase;
}

.case-slider__slide-title {
	align-self: self-end;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.45;
	margin-bottom: 1.25rem;
}

.case-slider__slide-text {
	font-size: 0.6875rem;
	font-weight: 400;
	letter-spacing: 0.02em;
	line-height: 1.45;
}

.case-slider__slide-img {
	border-radius: 0.3125rem;
	overflow: hidden;
	width: 100%;
}

.case-slider__slide-img img {
	-o-object-fit: cover;
	aspect-ratio: 332/339;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.case__inner.inner {
	max-width: 74.625rem;
}

.case__list {
	grid-gap: 3.5rem 1.25rem;
	display: grid;
	gap: 3.5rem 1.25rem;
	grid-template-columns: repeat(auto-fit, minmax(21.875rem, 1fr));
}

.case__img {
	border-radius: 0.3125rem;
	overflow: hidden;
}

.case__img img {
	-o-object-fit: cover;
	aspect-ratio: 368/206;
	height: auto;
	object-fit: cover;
	transform: scale(1);
	transition: transform 0.3s;
	width: 100%;
}

.case__link:hover .case__img img {
	transform: scale(1.1);
}

.case__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	display: -webkit-box;
	font-size: 1.375rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.2;
	margin-top: 1.5rem;
	overflow: hidden;
	text-overflow: ellipsis;
	word-break: break-word;
}

.case__applications {
	margin-top: 1rem;
}

.case__applications dt {
	align-items: center;
	color: #124D8A;
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	gap: 0.5rem;
	letter-spacing: 0.02em;
	line-height: 1.5;
}

.case__applications dt::before {
	background-color: #124D8A;
	content: "";
	display: block;
	height: 0.5rem;
	width: 0.5rem;
}

.case__applications dd {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	display: -webkit-box;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.5;
	margin-top: 0.1875rem;
	overflow: hidden;
	text-indent: 1rem;
	text-overflow: ellipsis;
	word-break: break-word;
}

.case__pagination {
	margin-left: auto;
	margin-right: auto;
	margin-top: 5rem;
	max-width: 57rem;
}

.company-list {
	border-top: 1px solid #D3D3D3;
}

.company-list__unit {
	border-bottom: 1px solid #D3D3D3;
	display: grid;
	grid-template-columns: 13.8125rem 1fr;
	padding-bottom: 2.5rem;
}

.company-list__unit {
	margin-top: 2.25rem;
}

.company-list__title,
.company-list__item {
	color: #2E2E2E;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.5;
}

.company-list__item a {
	-webkit-text-decoration: underline;
	text-decoration: underline;
}

.company-list__map {
	aspect-ratio: 806/568;
	margin-top: 1.5rem;
}

.company-list__map iframe {
	height: 100%;
	width: 100%;
}

.company-title {
	border-top: 2px solid #B4B4B4;
	font-size: 2.75rem;
	font-weight: 700;
	letter-spacing: 0;
	padding-top: 1.5rem;
	position: relative;
}

.company-title::before {
	background-color: #124D8A;
	content: "";
	display: block;
	height: 0.125rem;
	left: 0;
	position: absolute;
	top: -0.125rem;
	width: 6.25rem;
}

.contact {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	height: 22.75rem;
}

.contact__link {
	align-items: center;
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	display: flex;
	justify-content: center;
	position: relative;
}

.contact__link::before {
	-webkit-backdrop-filter: blur(6px);
	backdrop-filter: blur(6px);
	background-color: #262626;
	content: "";
	display: block;
	height: 100%;
	position: absolute;
	transition: background-color 0.3s;
	width: 100%;
}

.contact__link:hover::before {
	background-color: transparent;
}

.contact__link:nth-child(1) {
	background-image: url(../images/common/case.webp);
}

.contact__link:nth-child(2) {
	background-image: url(../images/common/facility.webp);
}

.contact.contact--recruit .contact__link:nth-child(2) {
	background-image: url(../images/common/recruit.webp);
}

.contact__link span {
	color: #fff;
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.5rem;
	font-weight: 500;
	justify-content: space-between;
	letter-spacing: 0.02em;
	max-width: 44.9375rem;
	padding-left: 5rem;
	padding-right: 6rem;
	position: relative;
	width: 100%;
	z-index: 5;
}

.contact__link span::after {
	background-image: url(../images/common/arrow04.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 1.875rem;
	transform: rotate(90deg);
	width: 1.25rem;
}

.culture {
	overflow-x: clip;
	padding-bottom: 13.625rem;
	padding-top: 7.5rem;
}

.culture__contents {
	margin-left: auto;
	margin-right: auto;
	margin-top: 5.5rem;
	max-width: 71.375rem;
}

.culture__content {
	background-color: rgba(255, 255, 255, 0.42);
	border-radius: 0 0.3125rem 0.3125rem 0;
	display: flow-root;
	margin-left: calc(50% - 50vw);
	position: relative;
}

.culture__content:nth-child(1)::before,
.culture__content:nth-child(3)::before {
	aspect-ratio: 1;
	background-image: url(../images/recruit/culture01.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	bottom: 0;
	content: "";
	display: block;
	height: auto;
	position: absolute;
	right: 0;
	transform: translate(2.3125rem, 1.5625rem);
	width: 14.375rem;
	z-index: 1;
}

.culture__content:nth-child(3)::before {
	background-image: url(../images/recruit/culture02.webp);
	transform: translate(2.125rem, 5.875rem);
}

.culture__content:nth-child(2n) {
	border-radius: 0.3125rem 0 0 0.3125rem;
	margin-left: 0;
	margin-right: calc(50% - 50vw);
}

.culture__content + .culture__content {
	margin-top: 4.25rem;
}

.culture__content-inner {
	display: grid;
	margin-left: auto;
	max-width: min(89.7222222222vw, 80.75rem);
	padding-bottom: 3.9375rem;
	padding-left: 2.9375rem;
	padding-right: 3.1875rem;
	padding-top: 3.625rem;
	width: 100%;
	writing-mode: vertical-rl;
}

.culture__content:nth-child(2n) .culture__content-inner {
	margin-left: 0;
	margin-right: auto;
	padding-left: 2.1875rem;
	writing-mode: vertical-lr;
}

.culture__content:nth-child(3) .culture__content-inner {
	padding-bottom: 1.25rem;
	padding-left: 2.0625rem;
	padding-right: 2.25rem;
}

.culture__content-title {
	font-size: 2.75rem;
	font-weight: 700;
	line-height: 1.3;
	writing-mode: vertical-rl;
}

.culture__content-title span {
	background: linear-gradient(90deg, transparent 0%,transparent 20%, #fff 20%,#fff 35%, transparent 35%, transparent 100%);
	background: linear-gradient(90deg, transparent 0% 20%, #fff 20% 35%, transparent 35% 100%);
	display: inline;
	padding: 0 1px 0px;
}

.culture__content-title .culture__content-title--blue {
	color: #124D8A;
}

.culture__comments {
	display: grid;
	grid-template-columns: auto 1fr auto;
	margin-right: min(6.9444444444vw, 6.25rem);
	margin-top: 1.25rem;
	width: min(59.8611111111vw, 53.875rem);
	writing-mode: horizontal-tb;
}

.culture__comment {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	height: -moz-max-content;
	height: max-content;
}

.culture__comment:nth-child(1) {
	font-size: 1.5625rem;
	grid-column: 3/4;
	grid-row: 1/5;
	margin-left: 1.8125rem;
	margin-top: 2.3125rem;
	writing-mode: vertical-rl;
}

.culture__comment:nth-child(1) span {
	display: inline-block;
}

.culture__comment:nth-child(2) {
	color: #124D8A;
	font-size: 2.625rem;
	font-weight: normal;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
}

.culture__comment:nth-child(3) {
	font-size: 1.3125rem;
	letter-spacing: -0.1em;
	line-height: 1.4;
	margin-top: 2.6875rem;
	text-align: right;
}

.culture__comment:nth-child(3) span {
	letter-spacing: 0;
}

.culture__comment:nth-child(4) {
	font-size: 2.625rem;
	font-weight: 700;
	letter-spacing: -0.02em;
	line-height: 1;
	margin-top: 0.875rem;
}

.culture__comment:nth-child(4) span {
	display: block;
	margin-left: auto;
	margin-top: 1.125rem;
	width: -moz-fit-content;
	width: fit-content;
}

.culture__comment:nth-child(4) span.u-mobile {
	display: none;
}

.culture__comment:nth-child(5) span.culture__comment-marker {
	-webkit-box-decoration-break: clone;
	background-color: #fff;
	box-decoration-break: clone;
	font-size: 1.3125rem;
	letter-spacing: -0.13em;
}

.culture__comment:nth-child(6) {
	grid-column: 1/2;
	grid-row: 1/5;
	margin-right: 1.875rem;
	margin-top: 2.875rem;
	writing-mode: vertical-rl;
}

.culture__comment:nth-child(6) span.culture__comment-marker {
	-webkit-box-decoration-break: clone;
	background-color: #fff;
	box-decoration-break: clone;
	font-size: 1.5625rem;
}

.culture__comment span {
	font-size: 1.1875rem;
	font-weight: 500;
}

.culture__desc {
	display: inline-block;
}

.culture__comment:nth-child(2) .culture__desc {
	margin-left: -1.375rem;
}

.culture__comment-num {
	-webkit-text-combine: horizontal;
	text-combine-upright: all;
}

.culture__job-type {
	grid-column-gap: min(4.5138888889vw, 4.0625rem);
	-moz-column-gap: min(4.5138888889vw, 4.0625rem);
	column-gap: min(4.5138888889vw, 4.0625rem);
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	margin-left: min(7.4305555556vw, 6.6875rem);
	margin-top: 1.625rem;
	width: min(66.5277777778vw, 59.875rem);
	writing-mode: horizontal-tb;
}

.culture__type {
	background-image: url(../images/recruit/job-type-bg01.svg);
	background-position: right bottom;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	color: #124D8A;
	height: -moz-fit-content;
	height: fit-content;
	padding: 0.875rem 1.75rem 3rem;
}

.culture__type:nth-child(2) {
	background-image: url(../images/recruit/job-type-bg.svg);
}

.culture__type-title {
	border-bottom: 1px solid currentColor;
	padding-bottom: 0.5rem;
	text-align: center;
}

.culture__type-title p {
	font-family: "Oswald", sans-serif;
	font-size: 0.875rem;
	font-weight: 400;
	line-height: 1.3;
	text-transform: uppercase;
}

.culture__type-title h4 {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.1875rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1.3;
	margin-top: 0.6875rem;
}

.culture__type-list {
	margin-top: 1.25rem;
}

.culture__type-item {
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.1875rem;
	font-weight: 500;
	gap: 0.625rem;
	line-height: 1.3;
}

.culture__type-item::before {
	background-color: rgba(18, 77, 138, 0.5);
	content: "";
	display: block;
	flex-shrink: 0;
	height: 0.125rem;
	margin-top: 0.5lh;
	width: 1.1875rem;
}

.culture__type-item + .culture__type-item {
	margin-top: 0.6875rem;
}

.culture__points {
	grid-row-gap: 0.75rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	margin-right: -7.5rem;
	row-gap: 0.75rem;
	width: -moz-fit-content;
	width: fit-content;
	writing-mode: horizontal-tb;
}

.culture__point {
	-webkit-mask-image: url(../images/recruit/point-mask.svg);
	-webkit-mask-position: center;
	-webkit-mask-size: 100% 100%;
	-webkit-mask-repeat: no-repeat;
	align-items: center;
	aspect-ratio: 322/210;
	background-color: #fff;
	background-color: #fff;
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.25rem;
	font-weight: 500;
	justify-content: center;
	letter-spacing: 0;
	line-height: 1.5;
	mask-image: url(../images/recruit/point-mask.svg);
	mask-position: center;
	mask-repeat: no-repeat;
	mask-size: 100% 100%;
	padding: 1.5rem 1.5rem 2.5rem;
	position: relative;
	text-align: center;
	width: min(23.0555555556vw, 20.75rem);
}

.culture__point::before {
	content: "";
}

.culture__point:nth-child(2n) {
	background-color: #C0CBD8;
	color: #124D8A;
}

:root {
	--translate: calc(111 / 16 * 1rem * -1);
}

.culture__point:nth-child(1) {
	transform: translate(calc(111 / 16 * 1rem * -1), 0rem);
	transform: translate(var(--translate), 0rem);
}

.culture__point:nth-child(2) {
	transform: translate(calc((111 / 16 * 1rem * -1) - 0.5625rem), 0.5625rem);
	transform: translate(calc(calc(111 / 16 * 1rem * -1) - 0.5625rem), 0.5625rem);
	transform: translate(calc(var(--translate) - 0.5625rem), 0.5625rem);
}

.culture__point:nth-child(3) {
	transform: translate(calc((111 / 16 * 1rem * -1) - 1.125rem), 0rem);
	transform: translate(calc(calc(111 / 16 * 1rem * -1) - 1.125rem), 0rem);
	transform: translate(calc(var(--translate) - 1.125rem), 0rem);
}

.culture__point:nth-child(4) {
	text-align: left;
}

.culture__point:nth-child(5) {
	text-align: left;
	transform: translate(-0.5625rem, 0.5625rem);
}

.culture__point:nth-child(6) {
	text-align: left;
	transform: translate(-1.125rem, 0rem);
}

.description {
	background-color: #fff;
	padding-bottom: 8.4375rem;
	padding-top: 6.375rem;
}

.description__tab {
	margin-left: auto;
	margin-right: auto;
	margin-top: 5rem;
	max-width: 57rem;
}

.drawer {
	background-color: rgba(28, 28, 28, 0.5);
	bottom: 0;
	height: 100lvh;
	inset: 0;
	left: 0;
	opacity: 0;
	position: fixed;
	right: 0;
	top: 0;
	transition: opacity 0.3s, visibility 0.3s;
	visibility: hidden;
	width: 100vw;
	z-index: 90;
}

.drawer.is-open {
	display: flex;
	opacity: 1;
	visibility: visible;
}

.drawer__container {
	background-color: #000000;
	height: 47.4375rem;
	max-width: 44.4375rem;
	position: absolute;
	right: 0;
	top: 0;
	width: 100%;
}

.drawer__inner {
	align-items: end;
	display: flex;
	height: inherit;
	justify-content: space-between;
	padding: 1.875rem 2.3125rem 2.1875rem;
}

.drawer__nav {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
}

.drawer__nav-item a {
	background-image: linear-gradient(#fff, #fff);
	background-position: bottom right;
	background-repeat: no-repeat;
	background-size: 0 1px;
	color: #fff;
	font-family: "Oswald", sans-serif;
	font-size: 2.3125rem;
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1;
	text-transform: uppercase;
	transition: background-size 0.3s;
}

.drawer__nav-item a:hover {
	background-position: bottom left; /* 下線のホバー時位置 */
	background-size: 100% 1px; /* 下線の横幅を100%にする */
}

.drawer__nav-item a span {
	display: inline-block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.5rem;
	font-weight: 500;
	letter-spacing: -0.01em;
	margin-left: 0.75rem;
}

.drawer__sitename {
	width: 11.25rem;
}

.equip-list {
	grid-gap: 3.5rem 3.75rem;
	display: grid;
	gap: 3.5rem 3.75rem;
	grid-template-columns: repeat(2, 1fr);
}

.equip-item__thumb {
	border-radius: 0.3125rem;
	overflow: hidden;
}

.equip-item__thumb img {
	-o-object-fit: cover;
	aspect-ratio: 368/206;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.equip-item__body {
	margin-top: 0.375rem;
}

.equip-item__desc {
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.5;
}

.equipment__inner.inner {
	max-width: 74.25rem;
}

.equipment__contents {
	grid-gap: 2.5rem;
	display: grid;
	gap: 2.5rem;
	grid-template-columns: auto min(55.2777777778vw, 49.75rem);
	margin-top: 4.125rem;
}

.equipment__nav {
	height: 100%;
}

.equipment__nav-inner {
	position: sticky;
	top: 7.5rem;
}

.equipment__nav-title {
	color: #124D8A;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.2;
}

.equipment__nav-list {
	margin-top: 0.75rem;
}

.equipment__nav-item + .equipment__nav-item {
	margin-top: 0.6875rem;
}

.equipment__nav-item a {
	background-image: linear-gradient(#1C1C1C, #1C1C1C);
	background-position: bottom right;
	background-repeat: no-repeat;
	background-size: 0 1px;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1.2;
	padding-bottom: 0.125rem;
	transition: background-size 0.3s;
}

.equipment__nav-item a:hover {
	background-position: bottom left;
	background-size: 100% 1px;
}

.faq__contents {
	grid-gap: 6.875rem;
	display: grid;
	gap: 6.875rem;
	grid-template-columns: auto 1fr;
	margin-left: auto;
	margin-right: auto;
	max-width: 71.5rem;
}

.faq__title {
	position: relative;
}

.faq__title p {
	color: rgba(28, 28, 28, 0.1);
	font-family: "Oswald", sans-serif;
	font-family: 400;
	font-size: 8.6875rem;
	font-weight: 400;
	line-height: 1;
	text-transform: uppercase;
}

.faq__title h2 {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 3rem;
	font-weight: 700;
	transform: translate(3.125rem, -3.125rem);
	width: -moz-fit-content;
	width: fit-content;
}

.faq__content {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	margin-top: 1.5rem;
}

.faq__item {
	background-color: #fff;
	border-radius: 0.3125rem;
	padding: 1.25rem 2.5rem;
}

.faq__q {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.4;
	padding-left: 2.1875rem;
	position: relative;
}

.faq__q::before {
	color: #124D8A;
	content: "q";
	font-family: "Oswald", sans-serif;
	font-size: 1.625rem;
	font-weight: 400;
	left: 0;
	letter-spacing: 0.06em;
	line-height: 1;
	position: absolute;
	text-transform: uppercase;
	top: 0;
}

.faq__a {
	font-size: 0.9375rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.5;
	margin-top: 1.5rem;
	padding-left: 2.1875rem;
	position: relative;
}

.faq__a::before {
	color: #124D8A;
	content: "a";
	font-family: "Oswald", sans-serif;
	font-size: 1.625rem;
	font-weight: 400;
	left: 0;
	letter-spacing: 0.06em;
	line-height: 1;
	position: absolute;
	text-transform: uppercase;
	top: 0;
}

.flow {
	background-color: #1C1C1C;
	padding-bottom: 6.5rem;
	padding-top: 5rem;
}

.flow__title {
	position: relative;
}

.flow__title p {
	color: #525050;
	font-family: "Oswald", sans-serif;
	font-size: 8.6875rem;
	font-weight: 400;
	line-height: 1;
}

.flow__title h2 {
	bottom: -0.8125rem;
	color: #fff;
	font-size: 3rem;
	font-weight: 700;
	left: 3.125rem;
	position: absolute;
}

.flow__list {
	grid-gap: 2.375rem;
	display: grid;
	gap: 2.375rem;
	grid-template-columns: repeat(6, 1fr);
	margin-top: 7.6875rem;
}

.flow__item {
	background-color: #fff;
	border-radius: 0.3125rem;
	display: flex;
	justify-content: center;
	padding-bottom: 4.8125rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 3.5rem;
	position: relative;
}

.flow__item::after {
	aspect-ratio: 23/48;
	background-image: url(../images/service/flow-arrow.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: auto;
	position: absolute;
	right: 0;
	top: 50%;
	transform: translate(1.9375rem, -50%);
	width: 1.4375rem;
}

.flow__item:last-child {
	background-color: #C0CBD8;
	color: #124D8A;
}

.flow__item:last-child::after {
	display: none;
}

.flow__text {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	writing-mode: vertical-rl;
}

.flow__text span {
	font: 0.8125rem sans-serif;
	font-weight: 400;
}

.footer {
	background-color: #1C1C1C;
	color: #fff;
	overflow: clip;
	padding-bottom: 1.5rem;
}

.footer__copy {
	font-family: "Oswald", sans-serif;
	font-size: min(21.8055555556svw, 19.625rem);
	font-weight: 400;
	letter-spacing: -0.01em;
	line-height: 1;
	margin-left: -1.5625rem;
	margin-right: -1.5625rem;
	position: relative;
	text-align: center;
	text-transform: uppercase;
}

.footer__text {
	border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: -0.075em;
	line-height: 1.6;
	margin-top: 1.8125rem;
	padding-bottom: 4.0625rem;
}

.footer__contents {
	-moz-column-gap: min(45.9027777778vw, 41.3125rem);
	column-gap: min(45.9027777778vw, 41.3125rem);
	display: flex;
	margin-top: 6.5625rem;
}

.footer__site-name {
	width: 13.5rem;
}

.footer__info {
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.5;
	margin-top: 2.0625rem;
}

.footer__info + .footer__info {
	margin-top: 1.125rem;
}

.footer__title {
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.5;
}

.footer__address {
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.5;
}

.footer__map {
	border-bottom: 1px solid #fff;
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.5;
	padding-bottom: 0.0625rem;
	position: relative;
}

.footer__map::after {
	background-image: url(../images/common/arrow03.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 1.25rem;
	position: absolute;
	right: -0.1875rem;
	top: 50%;
	transform: translate(100%, -50%);
	width: 1.25rem;
}

.footer__tel {
	display: flex;
	gap: 1em;
	margin-top: 1.125rem;
}

.footer__nav-list {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}

.footer__nav-item a {
	background-image: linear-gradient(#fff, #fff);
	background-position: bottom right;
	background-repeat: no-repeat;
	background-size: 0 1px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 2.125rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	padding-bottom: 0.125rem;
	transition: background-size 0.3s;
}

.footer__nav-item a:hover {
	background-position: bottom left;
	background-size: 100% 1px;
}

.footer__links {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
	margin-top: 2.25rem;
}

.footer__link a {
	background-image: linear-gradient(#fff, #fff);
	background-position: bottom right;
	background-repeat: no-repeat;
	background-size: 0 1px;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	padding-bottom: 0.125rem;
	transition: background-size 0.3s;
}

.footer__link a:hover {
	background-position: bottom left;
	background-size: 100% 1px;
}

.footer__bottom {
	margin-top: 3.125rem;
	position: relative;
}

.footer__copyrights {
	display: inline-block;
	font-size: 0.6875rem;
	text-align: center;
	width: 100%;
}

.footer__page-top {
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
}

.form-input input {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: transparent;
	background-color: #F5F5F5;
	background-image: none;
	border-radius: 0.3125rem;
	font-size: 1.0625rem;
	font-weight: 500;
	line-height: 2;
	padding: 1rem;
	width: 100%;
}

.form-input.form-input--file input {
	background-color: transparent;
	padding: 0;
}

.form-input input::-moz-placeholder {
	color: #999999;
	font-size: 1rem;
}

.form-input input::placeholder {
	color: #999999;
	font-size: 1rem;
}

.form-input input:focus {
	border: 1px solid #ccc;
	box-shadow: none;
	outline: none;
}

.form-radio label {
	display: block;
}

.form-radio span {
	display: contents;
}

.form-radio .wpcf7-list-item + .wpcf7-list-item {
	display: block;
	margin-left: 0;
	margin-top: 0.5rem;
}

.form-radio label:not(:first-of-type) {
	margin-top: 0.5rem;
}

.form-radio input {
	display: none;
}

.form-radio input + span {
	color: #2E2E2E;
	cursor: pointer;
	display: block;
	font-size: 1.0625rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	line-height: 2;
	padding: 0 0 0 1.5625rem;
	position: relative;
}

.form-radio input + span::before {
	background-color: #F5F5F5;
	border-radius: 0.125rem;
	content: "";
	display: block;
	height: 0.875rem;
	left: 0;
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 0.875rem;
}

.form-radio input + span::after {
	border-bottom: 0.1875rem solid #124D8A;
	border-left: 0.1875rem solid #124D8A;
	content: "";
	display: block;
	height: 0.5rem;
	left: 0.125rem;
	margin-top: -0.125rem;
	opacity: 0;
	position: absolute;
	top: 0.75rem;
	transform: rotate(-45deg);
	transition: 0.3s;
	width: 0.9375rem;
}

.form-radio input:checked + span::after {
	opacity: 1;
}

.form-select select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url(./../images/common/arrow.svg);
	background-position: right 0.9375rem top 0.9375rem;
	background-repeat: no-repeat;
	background-size: 0.9375rem;
	border: 1px solid #ccc;
	border-radius: 0;
	cursor: pointer;
	font-size: 0.9375rem;
	line-height: 1;
	padding: 0.71875rem 3.125rem 0.71875rem 0.9375rem;
	width: 100%;
}

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

.form-select select:focus {
	border: 1px solid #ccc;
	box-shadow: none;
	outline: none;
}

.form-submit {
	display: inline-block;
	max-width: 18.25rem;
	position: relative;
	width: 100%;
}

.form-submit::before {
	background-color: #fff;
	content: "";
	display: block;
	height: 100%;
	position: absolute;
	right: 3.4375rem;
	top: 0;
	width: 1px;
}

.form-submit::after {
	background-color: #D7D7D7;
	border-radius: 100vh;
	content: "";
	display: block;
	height: 0.4375rem;
	position: absolute;
	right: 1.5rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0.4375rem;
}

.form-submit input {
	-webkit-text-decoration: none;
	background-color: rgba(28, 28, 28, 0.7);
	border: none;
	border-radius: 0.3125rem;
	color: #fff;
	cursor: pointer;
	display: inline-block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1rem;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1;
	line-height: 1.67;
	max-width: 18.25rem;
	padding: 0.8125rem 1.1875rem;
	text-align: left;
	text-decoration: none;
	transition: 0.3s;
	width: 100%;
}

.form-submit input:hover,
.form-submit input:focus {
	outline: none;
}

.form-submit input:hover {
	background-color: #1c1c1c;
}

.form-submit input::-moz-foucus-inner {
	border: none;
	padding: 0;
}

.form-textarea textarea {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-color: transparent;
	background-color: #F5F5F5;
	background-image: none;
	border-radius: 0.3125rem;
	font-size: 1.0625rem;
	font-weight: 500;
	height: 15.4375rem;
	letter-spacing: 0;
	line-height: 2;
	padding: 1.1875rem 1.25rem;
	width: 100%;
}

.form-textarea textarea::-moz-placeholder {
	color: #999999;
}

.form-textarea textarea::placeholder {
	color: #999999;
}

.form-textarea textarea:focus {
	border: 1px solid #ccc;
	box-shadow: none;
	outline: none;
}

.form {
	padding-top: 3.5rem;
}

.form__wrap {
	align-items: top;
	display: flex;
	gap: 1.5rem;
}

.form__wrap + .form__wrap {
	margin-top: 2.5rem;
}

.form__label {
	color: #2E2E2E;
	flex: 1;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1;
}

.form__label span,
.form__privacy .wpcf7-list-item-label span {
	background-color: #999999;
	border-radius: 100vh;
	color: #F5F5F5;
	display: inline-block;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0.03em;
	line-height: 1;
	margin-left: 0.5rem;
	padding: 0.25rem 0.5rem;
}

.form__label.form__label--required span,
.form__privacy .wpcf7-list-item-label span {
	background-color: #124D8A;
}

.form__input,
.form__select,
.form__radio,
.form__checkbox,
.form__textarea {
	max-width: 39.25rem;
	width: 100%;
}

.form__input,
.form__textarea {
	flex-grow: 1;
}

.form__submit {
	margin-top: 7.875rem;
	text-align: center;
}

.form__privacy {
	margin-top: 5.9375rem;
}

.form__privacy label input {
	display: none;
}

.form__privacy label input + span {
	color: #2E2E2E;
	cursor: pointer;
	display: inline-block;
	font-size: 1rem;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	letter-spacing: 0;
	line-height: 1.5;
	line-height: 1;
	padding-left: 1.875rem;
	position: relative;
}

.form__privacy label input + span::before {
	background: #F5F5F3;
	content: "";
	display: block;
	height: 0.875rem;
	left: 0;
	position: absolute;
	top: 0.3125rem;
	width: 0.875rem;
}

.form__privacy label input + span::after {
	border-bottom: 0.1875rem solid #124D8A;
	border-left: 0.1875rem solid #124D8A;
	content: "";
	display: block;
	height: 0.5rem;
	left: 0.125rem;
	margin-top: -0.125rem;
	opacity: 0;
	position: absolute;
	top: 0.625rem;
	transform: rotate(-45deg);
	transition: 0.3s;
	width: 0.9375rem;
}

.form__privacy label input:checked + span::after {
	opacity: 1;
}

.form__privacy-disc {
	color: #2E2E2E;
	display: block;
	font-size: 0.9375rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 2;
	margin-top: 0.25rem;
	padding-left: 1.875rem;
}

.form__privacy-disc a {
	-webkit-text-decoration: underline;
	text-decoration: underline;
}

.greeting__wrap {
	margin-left: auto;
	margin-right: auto;
	max-width: 71.375rem;
}

.greeting__contents {
	grid-gap: 3rem;
	display: grid;
	gap: 3rem;
	grid-template-columns: auto 1fr;
	margin-left: auto;
	margin-top: 3.125rem;
	max-width: 64.25rem;
}

.greeting__img {
	border-radius: 0.25rem;
	overflow: hidden;
	width: min(24.6527777778vw, 22.1875rem);
}

.greeting__img img {
	aspect-ratio: 355/488;
	height: auto;
	width: 100%;
}

.greeting__text {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.75;
}

.greeting__text + .greeting__text {
	margin-top: 2.1875rem;
}

.greeting__position {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.3;
	margin-top: 1.25rem;
}

.greeting__position span {
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: -0.5rem;
}

.hamburger {
	background-color: #1C1C1C;
	border: 1px solid transparent;
	border-radius: 0.25rem;
	height: inherit;
	position: relative;
	transition: background-color 0.3s, border 0.3s;
	width: 7.25rem;
	z-index: 900;
}

.hamburger.is-open,
.hamburger:hover {
	background-color: #fff;
	border-color: #1C1C1C;
}

.hamburger span {
	background-color: #fff;
	display: inline-block;
	height: 0.0625rem;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	transition: background-color 0.3s, top 0.3s, left 0.3s, transform 0.3s;
	width: 2.5rem;
}

.hamburger.is-open span,
.hamburger:hover span {
	background-color: #1C1C1C;
}

.hamburger span:nth-child(1) {
	top: 2.25rem;
}

.hamburger span:nth-child(2) {
	top: 2.5625rem;
}

.hamburger.is-open span:nth-child(1) {
	left: 2.25rem;
	top: 2.3125rem;
	transform: rotate(164deg);
}

.hamburger.is-open span:nth-child(2) {
	left: 2.25rem;
	top: 2.3125rem;
	transform: rotate(-164deg);
}

.header {
	height: 5rem;
	width: 100%;
	z-index: 100;
}

.header__inner {
	align-items: center;
	display: flex;
	height: inherit;
	padding-left: 2rem;
	padding-right: 0.5rem;
}

.header__site-name {
	width: 19.25rem;
}

.header__site-name img {
	-o-object-fit: contain;
	filter: none;
	height: auto;
	object-fit: contain;
	transition: filter 0.3s;
	width: 100%;
}

.header.change-color .header__site-name img {
	filter: invert(88%) sepia(61%) saturate(0%) hue-rotate(229deg) brightness(107%) contrast(101%);
}

.header__cta {
	align-items: center;
	background-color: #124D8A;
	border: 1px solid transparent;
	border-radius: 0.25rem;
	color: #fff;
	display: flex;
	font-family: "Oswald", sans-serif;
	font-size: 1rem;
	font-weight: 500;
	height: inherit;
	letter-spacing: 0.14em;
	margin-left: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	position: relative;
	text-transform: uppercase;
	transition: color 0.3s, background-color 0.3s, border 0.3s;
	z-index: 900;
}

.header__cta:hover {
	background-color: #fff;
	border-color: currentColor;
	color: #124D8A;
}

.header__hamburger {
	margin-left: 0.75rem;
}

.history__wrap {
	margin-left: auto;
	margin-right: auto;
	max-width: 71.375rem;
}

.overview__contents {
	margin-left: auto;
	margin-top: 3.5rem;
	max-width: 64.25rem;
}

.inner {
	margin-left: auto;
	margin-right: auto;
	max-width: 1426px;
	padding-left: 25px;
	padding-right: 25px;
	width: 100%;
}

.introduction__wrap {
	margin-left: auto;
	margin-right: auto;
	max-width: 71.375rem;
}

.introduction__contents {
	grid-gap: 3rem;
	display: grid;
	gap: 3rem;
	grid-template-columns: auto 1fr;
	margin-left: auto;
	margin-top: 4.4375rem;
	max-width: 64.25rem;
}

.introduction__img {
	border-radius: 0.25rem;
	overflow: hidden;
	width: min(15vw, 13.5rem);
}

.introduction__img img {
	aspect-ratio: 216/298;
	height: auto;
	width: 100%;
}

.introduction__text {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.75;
}

.introduction__position {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.2;
	margin-top: 1.6875rem;
}

.introduction__position span {
	font-size: 0.875rem;
	font-weight: 500;
	letter-spacing: 0;
	line-height: 1;
	margin-bottom: -0.5rem;
}

.introduction__section-img {
	margin-top: 8.75rem;
	max-height: 37.3125rem;
	overflow: hidden;
	width: 100%;
}

.introduction__section-img img {
	-o-object-fit: cover;
	aspect-ratio: 1440/597;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.job {
	padding-bottom: 7.5rem;
	padding-top: 7.5rem;
}

.job__contents {
	background-color: #fff;
	border-radius: 0.3125rem;
	margin-top: 3rem;
	padding-bottom: 5.5rem;
	padding-top: 6.25rem;
}

.job__contents-inner {
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.job__content-top {
	grid-column-gap: 1rem;
	-moz-column-gap: 1rem;
	column-gap: 1rem;
	display: grid;
	grid-template-columns: 1fr min(31.1111111111vw, 28rem);
	margin-left: auto;
	margin-right: auto;
	max-width: 71.5rem;
}

.job__content-title h3 {
	font-size: 2.125rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 2.2;
}

.job__content-title h3 span {
	color: #124D8A;
}

.job__content-title p {
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1;
	margin-top: -0.625rem;
	margin-top: -0.25rem;
	text-transform: uppercase;
}

.job__content-title.job__content-title--sm {
	text-align: center;
}

.job__content-title.job__content-title--sm h3 {
	font-size: 1.75rem;
}

.job__content-title.job__content-title--sm p {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.5;
}

.job__text {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.75;
	margin-top: 0.875rem;
}

.job__text + .job__text {
	margin-top: 1.125rem;
}

.job__img {
	grid-column: 2/3;
	grid-row: 1/4;
	margin-top: 1.375rem;
}

.job__img img {
	aspect-ratio: 448/329;
	height: auto;
	width: 100%;
}

.job__content-bottom {
	margin-top: 7rem;
}

.job__list {
	grid-column-gap: 0.9375rem;
	-moz-column-gap: 0.9375rem;
	column-gap: 0.9375rem;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	margin-top: 2.625rem;
}

.job__item {
	border-radius: 0.3125rem 0.3125rem 0.625rem 0.625rem;
	display: grid;
	grid-row: span 2;
	grid-template-rows: subgrid;
	overflow: hidden;
}

.job__item-img {
	border-radius: 0.3125rem;
	overflow: hidden;
}

.job__item-img img {
	-o-object-fit: cover;
	aspect-ratio: 320/200;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.job__item-text {
	align-self: center;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.3;
	padding: 0.375rem;
	text-align: center;
}

.loading {
	align-items: center;
	background-color: #fff;
	display: flex;
	gap: 1.625rem;
	height: 100vh;
	justify-content: center;
	left: 0;
	position: fixed;
	top: 0;
	transition: opacity 0.8s ease-out, transform 0.8s ease-out;
	width: 100%;
	z-index: 999;
}

.loading.is-hide {
	opacity: 0;
	pointer-events: none;
	transform: scale(1.1);
}

.loading__dot {
	background-color: #1C1C1C;
	border-radius: 50%;
	height: 1rem;
	width: 1rem;
}

.loading__dot:nth-of-type(1) {
	animation: loading 1s -0.24s cubic-bezier(0.25, 1, 0.5, 1) infinite;
}

.loading__dot:nth-of-type(2) {
	animation: loading 1s -0.12s cubic-bezier(0.25, 1, 0.5, 1) infinite;
}

.loading__dot:nth-of-type(3) {
	animation: loading 1s 0s cubic-bezier(0.25, 1, 0.5, 1) infinite;
}

.mv-swiper {
	height: auto;
	width: 100%;
}

.mv-swiper__wrapper {
	aspect-ratio: 793/1000;
	border-radius: 0.3125rem;
	overflow: hidden;
}

.mv {
	overflow-x: clip;
	padding-bottom: 7.5rem;
	padding-top: 6.875rem;
	position: relative;
}

.mv::before {
	aspect-ratio: 1745/1607;
	background-image: url(../images/top/bg_logo.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	height: auto;
	left: -47%;
	position: absolute;
	top: 53%;
	transform: translateY(-50%);
	width: min(121.1805555556vw, 109.0625rem);
	z-index: -1;
}

.mv__inner.inner {
	display: grid;
	grid-template-columns: auto min(56.1111111111vw, 50.5rem);
}

.mv__title {
	grid-column: span 2;
}

.mv__title .title__en {
	display: block;
	font-size: min(20.8333333333svw, 18.75rem);
	font-weight: 500;
	letter-spacing: 0;
	margin-left: -25px;
	margin-right: -25px;
	margin-top: -1.6875rem;
	text-align: center;
	transform: translateX(-0.4375rem);
}

.mv__text-area {
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: 1fr auto;
}

.mv__copy-ja {
	font-size: 5.4375rem;
	font-weight: 900;
	justify-self: center;
	letter-spacing: 0.05em;
	line-height: 1.24;
	margin-top: 7.625rem;
	transform: translateX(-1rem);
	writing-mode: vertical-rl;
}

.mv__text {
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 1.2;
	margin-left: 1.75rem;
}

.mv__slide-container {
	margin-top: 0.1875rem;
	padding-right: 1rem;
}

.title__en--mv,
.mv-swiper,
.mv__copy-ja {
	opacity: 0;
	transition: opacity 3s cubic-bezier(0.2, 0.8, 0.2, 1);
	will-change: opacity;
}

.mv--is-visible {
	opacity: 1;
}

/* reduced motion 配慮 */

.news__pagination {
	margin-top: 10rem;
}

.overview__wrap {
	margin-left: auto;
	margin-right: auto;
	max-width: 71.375rem;
}

.overview__contents {
	margin-left: auto;
	margin-top: 3rem;
	max-width: 64.25rem;
}

.overview__section-img {
	margin-top: 7.5rem;
}

.page-top {
	align-items: center;
	display: flex;
	gap: 1.375rem;
}

.page-top span {
	color: transparent;
	display: inline-block;
	font-size: 0.875rem;
	font-weight: 400;
	letter-spacing: -0.02em;
	line-height: 1.5;
	overflow: hidden;
	text-shadow: 0 -1.5em 0 #fff, 0 0 0 #fff;
	transition: text-shadow 0.3s;
}

.page-top:hover span {
	text-shadow: 0 0 0 #fff, 0 1.5em 0 #fff;
}

.page-top::after {
	background-image: url(../images/common/arrow04.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 0.875rem;
	width: 0.625rem;
}

.pagenavi {
	align-items: end;
	display: flex;
	justify-content: center;
}

.pagenavi .pagination-list {
	align-items: center;
	display: flex;
	gap: 0.5rem;
	justify-content: center;
}

.pagenavi .pagination span,
.pagenavi .pagination a {
	align-items: center;
	background-color: rgba(28, 28, 28, 0.6);
	border-radius: 0.3125rem;
	color: #fff;
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1rem;
	font-weight: 700;
	height: 3.375rem;
	justify-content: center;
	transition: background-color 0.3s;
	width: 3.375rem;
}

.pagenavi .pagination span,
.pagenavi .pagination a:hover {
	background-color: #1C1C1C;
}

.pagenavi .prev-link,
.pagenavi .next-link {
	background-color: transparent;
	background-image: url(../images/common/arrow01.svg);
	background-position: center;
	background-size: contain;
	color: transparent;
	height: 2.25rem;
	width: 2.25rem;
}

.pagenavi .prev-link a,
.pagenavi .next-link a {
	display: inline-block;
	height: 100%;
	width: 100%;
}

.pagenavi .prev-link {
	margin-right: auto;
	transform: scale(-1, 1);
}

.pagenavi .next-link {
	margin-left: auto;
}

.pagenavi span:has(.disabled) {
	visibility: hidden;
}

.policy__contents {
	border-top: 1px solid #d9d9d9;
	margin-left: auto;
	margin-right: auto;
	max-width: 57rem;
	padding-bottom: 15rem;
}

.policy__content {
	margin-top: 4.125rem;
}

.policy__title {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1;
}

.policy__text {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 2.2;
	margin-top: 1.375rem;
}

.policy__list {
	list-style-type: decimal;
}

.policy__item {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 2.2;
	margin-left: 1em;
}

.post-nav__inner.inner {
	border-top: 1px solid #c2c2c2;
	max-width: 58.875rem;
}

.post-nav__list {
	display: flex;
	justify-content: space-between;
	padding-top: 1.5rem;
}

.post-nav__item {
	background-image: linear-gradient(#1C1C1C, #1C1C1C);
	background-position: bottom right;
	background-repeat: no-repeat;
	background-size: 0 1px;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.5;
	padding-bottom: 0.125rem;
	transition: background-size 0.3s;
}

.post-nav__item:has(a:hover) {
	background-position: bottom left;
	background-size: 100% 1px;
}

.post-nav__item:has(.is-disabled) {
	opacity: 0.3;
}

.post-nav__item {
	align-items: center;
	display: flex;
	gap: 0.75rem;
}

.post-nav__item--prev::before,
.post-nav__item--next::after {
	background-image: url(../images/common/arrow01.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 1.5rem;
	width: 1.5rem;
}

.post-nav__item--prev::before {
	transform: scale(-1, 1);
}

.purpose__title {
	position: relative;
}

.purpose__title p {
	color: #fff;
	font-family: "Oswald", sans-serif;
	font-size: 8.6875rem;
	font-weight: 400;
	line-height: 1;
	opacity: 0.5;
	text-align: center;
}

.purpose__title h2 {
	bottom: 0;
	font-size: 3rem;
	font-weight: 700;
	left: 50%;
	position: absolute;
	transform: translateX(-50%);
	width: -moz-max-content;
	width: max-content;
}

.purpose__contents {
	margin-left: auto;
	margin-right: auto;
	margin-top: 6.9375rem;
	max-width: 71.5625rem;
}

.purpose__list-wrap {
	background-color: #fff;
	border-radius: 0.3125rem;
	overflow: hidden;
}

.purpose__list {
	border-bottom: 1px solid rgba(238, 238, 238, 0.4);
	display: grid;
	grid-template-columns: min(23.0555555556vw, 20.75rem) 1fr;
}

.purpose__list-title {
	align-items: center;
	background-color: #124D8A;
	color: #fff;
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.5;
	padding: 3.125rem 1.5rem;
}

.purpose__list-item {
	border-left: 1px solid rgba(238, 238, 238, 0.4);
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.5;
	padding: 2.5rem 1.5rem;
}

.purpose__content {
	grid-gap: 3.875rem;
	display: grid;
	gap: 3.875rem;
	grid-template-columns: 1fr auto;
	margin-top: 4.75rem;
}

.purpose__text {
	align-self: center;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.65;
}

.purpose__images {
	grid-gap: 0.8125rem 1rem;
	display: grid;
	gap: 0.8125rem 1rem;
	grid-template-columns: repeat(3, 1fr);
}

.purpose__img {
	border-radius: 0.3125rem;
	overflow: hidden;
	width: min(15vw, 13.5rem);
}

.purpose__img img {
	-o-object-fit: cover;
	aspect-ratio: 216/218;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.recruit-lead {
	display: flex;
	flex-direction: column;
}

.recruit-lead::after {
	aspect-ratio: 1440/655;
	background-image: url(../images/recruit/lead-img.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	height: 40.9375rem;
	max-height: 40.9375rem;
	width: 100%;
}

.recruit-lead__container {
	font-family: "Zen Kaku Gothic New", sans-serif;
	overflow-x: clip;
	padding-bottom: 12rem;
	padding-top: 4.0625rem;
	position: relative;
	width: 100%;
}

.recruit-lead__container::before {
	background-image: url(../images/recruit/lead-bg.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 49.25rem;
	position: absolute;
	right: -1.25rem;
	top: 50%;
	transform: translateY(-50%);
	width: 54rem;
	z-index: -1;
}

.recruit-lead__inner.inner {
	writing-mode: vertical-rl;
}

.recruit-lead__copy-wrap {
	margin-right: min(6.9444444444vw, 6.25rem);
}

.recruit-lead__copy {
	font-size: 5.5rem;
	font-weight: 500;
	letter-spacing: -0.16em;
}

.recruit-lead__copy:nth-child(2) {
	margin-top: 9rem;
}

.recruit-lead__copy span {
	font-size: 10.875rem;
}

.recruit-lead__copy span {
	display: inline-block;
	height: -moz-fit-content;
	height: fit-content;
	line-height: 1;
	width: -moz-fit-content;
	width: fit-content;
}

.recruit-lead__copy span:nth-child(1) {
	transform: translateX(-3.25rem);
}

.recruit-lead__copy span:nth-child(2) {
	margin-top: -1.3125rem;
	transform: translateX(-0.3125rem);
}

.recruit-lead__copy span:nth-child(3) {
	margin-top: 1.5625rem;
	transform: translateX(-3.3125rem);
}

.recruit-lead__content {
	margin-right: min(19.8611111111vw, 17.875rem);
	margin-top: 6.6875rem;
}

.recruit-lead__text + .recruit-lead__text {
	margin-right: min(2.7777777778vw, 2.5rem);
}

.recruit-lead__text {
	font-size: 1.1875rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 2.1052631579;
}

.recruit-lead__text span {
	background-color: #fff;
}

.section-head {
	grid-row-gap: 1.375rem;
	grid-column-gap: 6.6875rem;
	-moz-column-gap: 6.6875rem;
	column-gap: 6.6875rem;
	display: grid;
	grid-template-columns: auto 1fr;
	row-gap: 1.375rem;
}

.section-head__title {
	position: relative;
}

.section-head__title p {
	color: rgba(28, 28, 28, 0.1);
	font-family: "Oswald", sans-serif;
	font-size: 8.6875rem;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1;
	padding-left: 1.4375rem;
	text-transform: uppercase;
}

.section-head__title h2 {
	font-size: 2.75rem;
	font-weight: 700;
	left: 4.625rem;
	position: absolute;
	top: 3.125rem;
}

.section-head__copy {
	font-size: 2.625rem;
	font-weight: 700;
	grid-column: 1/2;
	grid-row: 2/3;
	padding-left: 5.875rem;
}

.section-head__text {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.25rem;
	font-weight: 500;
	grid-column: 2/3;
	grid-row: 2/3;
	letter-spacing: 0.02em;
	line-height: 1.6;
	margin-top: 0.625rem;
}

.section-head.section-head--appeal {
	display: block;
}

.section-head.section-head--appeal .section-head__title h2 {
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: 0;
	position: static;
}

.section-head.section-head--appeal .section-head__title p {
	color: rgba(255, 255, 255, 0.05);
	position: absolute;
	right: 4.625rem;
	top: -6.875rem;
	white-space: nowrap;
	writing-mode: vertical-lr;
}

.section-head.section-head--culture {
	-moz-column-gap: min(20.9722222222vw, 18.875rem);
	column-gap: min(20.9722222222vw, 18.875rem);
	row-gap: 0;
}

.section-head.section-head--culture .section-head__copy {
	grid-column: unset;
	grid-row: unset;
	margin-top: 2.5rem;
	padding-left: 0;
}

.section-head.section-head--culture .section-head__text {
	margin-top: -1rem;
}

.section-head.section-head--culture .section-head__title {
	row-gap: span 2;
}

.section-head.section-head--culture .section-head__title p,
.section-head.section-head--description .section-head__title p {
	text-transform: capitalize;
}

.section-head.section-head--description {
	display: block;
}

.section-head.section-head--description .section-head__title {
	text-align: center;
	width: 100%;
}

.section-head.section-head--description .section-head__title p {
	right: 0;
}

.section-head.section-head--description .section-head__title h2 {
	left: 0;
	top: 5.375rem;
	width: 100%;
}

.sub-head.sub-head--404 .sub-head__breadcrumb {
	transform: translate(0);
}

.service-lead {
	background-image: url(../images/service/lead.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	padding-bottom: 12.1875rem;
	padding-top: 8.875rem;
	position: relative;
}

.service-lead::before {
	background: linear-gradient(90deg, #1C1C1C 0%, transparent 100%);
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.service-lead__inner.inner {
	padding-left: 5.125rem;
	padding-right: 5.125rem;
	position: relative;
	z-index: 1;
}

.service-lead__copy {
	color: #fff;
	font-size: 4.25rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.4;
}

.service-lead__text {
	color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.375rem;
	font-weight: 700;
	letter-spacing: 0.01em;
	line-height: 2;
	margin-top: 3rem;
	text-shadow: 0 0.25rem 3.125rem rgba(52, 52, 44, 0.4);
}

.service-what__content {
	background-color: #1C1C1C;
	border-radius: 0.3125rem;
	margin-left: auto;
	margin-right: auto;
	max-width: 71.5rem;
	padding-bottom: 6.5rem;
	padding-left: min(5.9027777778vw, 5.3125rem);
	padding-right: min(5.9027777778vw, 5.3125rem);
	padding-top: 6.125rem;
	position: relative;
}

.service-what__content::before {
	color: #fff;
	content: "what is etching?";
	font-family: "Oswald", sans-serif;
	font-size: 10.125rem;
	font-weight: 400;
	left: 50%;
	letter-spacing: 0;
	line-height: 1;
	opacity: 0.03;
	position: absolute;
	text-transform: uppercase;
	top: 1.125rem;
	transform: translateX(-50%);
	width: 100%;
}

.service-what__content::after {
	aspect-ratio: 587/455;
	background-image: url(../images/service/service-what.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	border-radius: 0.3125rem;
	bottom: 0;
	content: "";
	display: block;
	height: auto;
	left: 0;
	position: absolute;
	transform: translate(-4.5625rem, 6.9375rem);
	width: min(40.7638888889vw, 36.6875rem);
}

.service-what__content-inner {
	margin-left: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.service-what__title {
	color: #fff;
	font-size: 2.625rem;
	font-weight: 700;
	letter-spacing: 0;
}

.service-what__text {
	color: #fff;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 2.2;
	margin-top: 1.75rem;
}

.service-what__text span {
	background-color: rgba(255, 212, 0, 0.9);
	color: #1C1C1C;
	font-weight: 700;
}

.service {
	background-color: #fff;
	padding-bottom: 4.8125rem;
	padding-top: 3.8125rem;
}

.service__contents {
	grid-gap: 2.875rem;
	display: grid;
	gap: 2.875rem;
	grid-template-columns: auto 1fr;
}

.service__title {
	align-self: center;
	padding-left: 10.5rem;
	position: relative;
}

.service__title p {
	color: #1C1C1C;
	font-family: "Oswald", sans-serif;
	font-size: 8.6875rem;
	font-weight: 400;
	left: 0;
	letter-spacing: 0;
	line-height: 1;
	opacity: 0.1;
	position: absolute;
	top: 50%;
	transform: translateY(-60%);
}

.service__title h2 {
	font-size: 700;
	font-size: 2.75rem;
}

.service__content {
	grid-gap: 0;
	border-top: 1px solid rgba(28, 28, 28, 0.1);
	counter-reset: num;
	display: grid;
	gap: 0;
	grid-template-columns: 1fr;
	grid-template-rows: repeat(5, 1fr);
}

.service__content-item {
	align-self: center;
	border-bottom: 1px solid rgba(28, 28, 28, 0.1);
	counter-increment: num;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.6875rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	line-height: 1.17;
	padding-bottom: 2.5rem;
	padding-left: 3.5625rem;
	padding-right: 3.5625rem;
	padding-top: 2.5rem;
	position: relative;
}

.service__content-item::before {
	color: #124D8A;
	content: "(" counter(num, decimal-leading-zero) ")";
	font-family: "Oswald", sans-serif;
	font-size: 0.6875rem;
	font-weight: 400;
	left: 0;
	letter-spacing: 0.13em;
	position: absolute;
	top: 50%;
	transform: translate(0.75rem, -50%);
}

.single-swiper-main {
	border-radius: 0.3125rem;
}

.single-swiper-main__slide img {
	-o-object-fit: cover;
	aspect-ratio: 912/512;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.single-swiper-sub__slide {
	border-radius: 0.1875rem;
	overflow: hidden;
}

.single-swiper-sub__slide img {
	-o-object-fit: cover;
	aspect-ratio: 172/129;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.single-swiper-sub__slide.swiper-slide-active {
	display: none;
	opacity: 0;
	visibility: hidden;
}

.single__contents {
	margin-left: auto;
	margin-right: auto;
	max-width: 57rem;
}

.single__head {
	border-bottom: 1px solid #d9d9d9;
	padding-bottom: 1.5rem;
}

.single__date {
	font-family: "Oswald", sans-serif;
	font-size: 0.8125rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.65;
}

.single__title {
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.5;
	margin-top: 0.3125rem;
}

.single__content {
	margin-top: 5rem;
}

.single__content * + * {
	margin-top: 2.5rem;
}

.single__content h2 {
	border-left: 3px solid #124D8A;
	color: #124D8A;
	font-size: 2.25rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.75;
	padding-left: 1.5rem;
}

.single__content h3 {
	background-color: #124D8A;
	color: #fff;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.75;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.single__content h4 {
	border-bottom: 2px solid #d9d9d9;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.75;
	padding-bottom: 0.5rem;
	padding-left: 1.375rem;
	padding-right: 1.375rem;
	position: relative;
}

.single__content h4::before {
	background-color: #124D8A;
	bottom: -0.125rem;
	content: "";
	display: block;
	height: 0.125rem;
	left: 0;
	position: absolute;
	width: min(13.0555555556vw, 11.75rem);
}

.single__content h5 {
	color: #124D8A;
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.75;
}

.single__content p {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 2;
}

.single__content p::after {
	clear: both;
	content: "";
	display: block;
}

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

.single__content img.alignleft,
.single__content .alignleft {
	margin-right: auto;
}

.single__content img.alignright,
.single__content .alignright {
	margin-left: auto;
}

.single__content img.aligncenter,
.single__content .aligncenter {
	margin-left: auto;
	margin-right: auto;
}

.single__content img.size-medium {
	max-width: 300px;
}

.sub-404 {
	padding-bottom: 18.1875rem;
}

.sub-404__contents {
	margin-left: auto;
	margin-right: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.sub-404__text {
	font-size: 0.9375rem;
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1.8;
}

.sub-404__link {
	margin-top: 2.375rem;
}

.sub-contact {
	padding-bottom: 15rem;
}

.sub-contact__contents {
	margin-left: auto;
	margin-right: auto;
	max-width: 60rem;
}

.sub-contact__tel {
	background-color: #F5F5F5;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	padding-bottom: 3.8125rem;
	padding-left: min(8.75vw, 7.875rem);
	padding-right: min(8.75vw, 7.875rem);
	padding-top: 3.8125rem;
}

.sub-contact__tel-title {
	align-self: center;
	color: #242422;
	font-size: 1.375rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.5;
}

.sub-contact__tel-link {
	color: #242422;
	font-size: 3rem;
	font-weight: 700;
	position: relative;
}

.sub-contact__tel-link::before {
	-webkit-mask-image: url(../images/common/tel-icon.svg);
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	aspect-ratio: 1;
	background-color: #4B4B4B;
	content: "";
	display: block;
	height: auto;
	left: -0.5rem;
	mask-image: url(../images/common/tel-icon.svg);
	mask-position: center;
	mask-repeat: no-repeat;
	mask-size: contain;
	position: absolute;
	top: 50%;
	transform: translate(-100%, -50%);
	width: 2.5rem;
}

.sub-contact__tel-text {
	color: #242422;
	font-size: 1rem;
	font-weight: 400;
	letter-spacing: 0.04em;
	line-height: 1.5;
}

.sub-contact__mail {
	margin-top: 5rem;
}

.sub-contact__mail-title {
	color: #242422;
	font-size: 1.75rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.5;
}

.sub-contact__mail-text {
	color: #242422;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.5;
	margin-top: 1.375rem;
}

.sub-contact__mail-text + .sub-contact__mail-text {
	margin-top: 1lh;
}

.sub-contact__form {
	border-top: 1px solid #d9d9d9;
	margin-top: 5rem;
}

.sub-contact__recaptcha {
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.67;
	margin-top: 4.375rem;
	text-align: center;
}

.sub-contact__recaptcha a {
	-webkit-text-decoration: underline;
	color: #124D8A;
	text-decoration: underline;
}

.sub-head__inner.inner {
	display: grid;
	grid-template-columns: 1fr auto;
	position: relative;
	z-index: 5;
}

.sub-head__title h1 {
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	line-height: 1.67;
	margin-left: 0.4375rem;
}

.sub-head__title p {
	font-family: "Oswald", sans-serif;
	font-size: 7.5rem;
	font-weight: 400;
	letter-spacing: 0em;
	line-height: 0.7;
	margin-top: 1rem;
	text-transform: uppercase;
}

.sub-head__breadcrumb {
	align-self: end;
	justify-self: right;
	transform: translateY(1.125rem);
}

.sub-head__text {
	border-bottom: 1px solid #d9d9d9;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-weight: 500;
	grid-column: span 2;
	letter-spacing: 0.02em;
	line-height: 1.67;
	margin-left: auto;
	margin-right: auto;
	margin-top: 7.25rem;
	max-width: 71.125rem;
	padding-bottom: 2.625rem;
	width: 100%;
}

.sub-head.sub-head--recruit {
	background-image: url(../images/recruit/fv.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	color: #fff;
	padding-bottom: 4.8125rem;
	padding-top: 8.5625rem;
	position: relative;
}

.sub-head.sub-head--recruit::before {
	background: linear-gradient(180deg, transparent 0%, #1C1C1C 100%);
	content: "";
	display: block;
	height: 100%;
	left: 0;
	opacity: 0.4;
	position: absolute;
	top: 0;
	width: 100%;
}

.sub-head__link-wrap {
	display: flex;
	gap: 2.5rem;
	margin-top: 4.125rem;
}

.sub-head__link {
	display: flex;
	gap: 0.4375rem;
}

.sub-head__link::after {
	background-image: url(../images/recruit/arrow.svg);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 1.25rem;
	margin-top: 0.1875rem;
	transition: transform 0.3s;
	width: 1.25rem;
}

.sub-head__link a {
	border-bottom: 1px dashed #fff;
	padding-bottom: 0.125rem;
}

.sub-head__link span {
	color: transparent;
	display: inline-block;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.1;
	overflow: hidden;
	text-shadow: 0 -1.5em 0 #fff, 0 0 0 #fff;
	transition: text-shadow 0.3s;
}

.sub-head__link a:hover span {
	text-shadow: 0 0 0 #fff, 0 1.5em 0 #fff;
}

.sub-head.sub-head--404 .sub-head__title p {
	margin-top: 0;
}

.sub-head.sub-head--404 .sub-head__title h1 {
	margin-top: 0;
	margin-top: 2.3125rem;
}

.sub-head__title.js-fade {
	opacity: 0;
	transform: translateY(3.125rem);
}

.tab__menu {
	grid-gap: 1rem;
	display: grid;
	gap: 1rem;
	grid-template-columns: repeat(2, 1fr);
	justify-content: center;
	position: relative;
	z-index: 1;
}

.tab__menu-item {
	background-color: #C0CBD8;
	border-radius: 0.3125rem 0.3125rem 0 0;
	color: rgba(18, 77, 138, 0.7);
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0;
	line-height: 1.5;
	padding: 1.0625rem;
	text-align: center;
}

.tab__menu-item.is-active {
	background-color: #fff;
	border-left: 1px solid #d9d9d9;
	border-right: 1px solid #d9d9d9;
	border-top: 1px solid #d9d9d9;
	color: #1C1C1C;
}

.tab__content {
	margin-top: -0.0625rem;
}

.tab__content-item {
	background-color: #fff;
	border: 1px solid #d9d9d9;
	display: none;
	padding-bottom: 3.875rem;
	padding-top: 4rem;
}

.tab__content-item.is-active {
	animation: fade 0.3s;
	display: block;
}

.tab__list {
	align-items: center;
	display: flex;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	line-height: 1.5;
	padding-right: 1.4375rem;
}

.tab__title {
	padding: 1.5rem 3.125rem;
	width: min(16.1111111111vw, 14.5rem);
}

.tab__item {
	border-top: 1px solid rgba(28, 28, 28, 0.3);
	flex: 1;
	padding: 1.5rem 0.5rem;
}

.tab__list:nth-last-child(1) .tab__item {
	border-bottom: 1px solid rgba(28, 28, 28, 0.3);
}

.thanks {
	padding-bottom: 7.5rem;
}

.thanks__content {
	margin-left: auto;
	margin-right: auto;
	max-width: 60rem;
}

.thanks__title {
	font-size: 2rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	line-height: 1.7;
	text-align: center;
}

.thanks__text {
	font-size: 1.125rem;
	font-weight: 500;
	letter-spacing: 0.05em;
	line-height: 1.7;
	margin-left: auto;
	margin-right: auto;
	margin-top: 2.5rem;
	width: -moz-fit-content;
	width: fit-content;
}

.thanks__link {
	margin-top: 5rem;
	text-align: center;
}

h1.title__ja {
	font-size: 1.625rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	line-height: 1.52;
	margin-right: 0.875rem;
	text-align: right;
}

h2.title__ja {
	background-color: #124D8A;
	border-radius: 0.375rem;
	color: #fff;
	display: inline-block;
	font-size: 1.5rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	line-height: 1.5;
	margin-left: 2.125rem;
	padding-bottom: 0.5rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
	padding-top: 0.5rem;
	vertical-align: text-bottom;
}

.title__en {
	display: inline-block;
	font-family: "Oswald", sans-serif;
	font-size: min(20.8333333333vw, 18.75rem);
	font-weight: 400;
	letter-spacing: -0.05em;
	line-height: 1;
	text-transform: uppercase;
}

.top-case {
	background-color: #EBEBEB;
	background-image: url(../images/top/case-bg.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	overflow: hidden;
	padding-bottom: 7.5rem;
	padding-top: 4.5rem;
	position: relative;
	transition: background-color 0.5s ease;
	z-index: 5;
}

.top-case::after {
	aspect-ratio: 1528/1407;
	background-image: url(../images/top/bg_logo02.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	height: auto;
	position: absolute;
	right: -30%;
	top: 50%;
	transform: translateY(-50%);
	width: min(106.1111111111vw, 95.5rem);
	z-index: -1;
}

.top-case__inner {
	position: relative;
	z-index: 5;
}

.top-case__title {
	border-bottom: 1px solid rgba(28, 28, 28, 0.5);
	padding-bottom: 2.5rem;
}

.top-case__slider-wrap {
	grid-gap: 3.75rem 1rem;
	display: grid;
	gap: 3.75rem 1rem;
	grid-template-columns: 42.5rem 1fr;
	margin-top: 5rem;
}

.top-case__slider-thumbnail {
	margin-left: 0;
	margin-right: -25px;
	width: calc(100% + 25px);
}

.top-case__link {
	text-align: right;
}

.top-contact {
	padding-bottom: 10.75rem;
	padding-top: 8.75rem;
	position: relative;
}

.top-contact::before {
	background-color: rgba(28, 28, 28, 0.2);
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.top-contact__inner.inner {
	position: relative;
	z-index: 5;
}

.top-contact__link {
	display: block;
	margin-left: auto;
	margin-right: auto;
	max-width: 71.5rem;
}

.top-contact__title p {
	color: #fff;
	font-family: "Oswald", sans-serif;
	font-size: 0.75rem;
	font-weight: 400;
	letter-spacing: -0.01em;
	line-height: 1;
}

.top-contact__title h2 {
	align-items: center;
	display: flex;
	margin-top: 2.5rem;
}

.top-contact__title h2 span {
	color: transparent;
	display: inline-block;
	font-size: 3rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1;
	overflow: hidden;
	text-shadow: 0 -1.5em 0 #fff, 0 0 0 #fff;
	transition: text-shadow 0.3s;
}

.top-contact__link:hover .top-contact__title h2 span {
	text-shadow: 0 0 0 #fff, 0 1.5em 0 #fff;
}

.top-contact__title h2::after {
	background-image: url(../images/common/arrow02.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	content: "";
	display: block;
	height: 1.5rem;
	margin-left: auto;
	transform: translateX(0);
	transition: transform 0.3s;
	width: 2.3125rem;
}

.top-contact__link:hover .top-contact__title h2::after {
	transform: translateX(10px);
}

.top-contact__text {
	color: #fff;
	font-size: 1.125rem;
	font-weight: "Zen Kaku Gothic New", sans-serif;
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1;
	margin-top: 2.5rem;
}

.top-gallery {
	padding-bottom: 5rem;
	padding-top: 37rem;
	position: relative;
	width: 100%;
}

.top-gallery__bg {
	background-attachment: fixed;
	background-image: url(../images/top/gallery-bg.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 100%;
	left: 0;
	overflow-x: clip;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

.top-gallery.is-active .top-gallery__bg {
	position: fixed;
}

.top-gallery__bg::before {
	-webkit-backdrop-filter: blur(0px);
	backdrop-filter: blur(0px);
	background-color: rgba(28, 28, 28, 0.85);
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transition: -webkit-backdrop-filter 0.5s;
	transition: backdrop-filter 0.5s;
	transition: backdrop-filter 0.5s, -webkit-backdrop-filter 0.5s;
	width: 100%;
}

.top-gallery.is-active .top-gallery__bg::before {
	-webkit-backdrop-filter: blur(5px);
	backdrop-filter: blur(5px);
}

.top-gallery__bg::after {
	background-color: transparent;
	color: #D7D7D7;
	content: "etchingism";
	display: inline-block;
	font-family: "Oswald", sans-serif;
	font-size: min(20.8333333333vw, 18.75rem);
	font-weight: 400;
	letter-spacing: 0.02em;
	line-height: 1.7;
	padding-top: 7.1875rem;
	position: sticky;
	text-align: center;
	text-transform: uppercase;
	width: 100%;
}

.top-gallery__container {
	height: 217.4375rem;
	position: relative;
}

.top-gallery__img {
	overflow: hidden;
	position: absolute;
}

.top-gallery__img img {
	display: block;
	height: auto;
	transform: translate3d(0, 0, 0);
	width: 100%;
	will-change: transform;
}

.top-gallery__img:nth-child(1) {
	left: 28.625rem;
	top: 0;
	width: min(24.1666666667vw, 21.75rem);
}

.top-gallery__img:nth-child(2) {
	left: 0.5625rem;
	top: 13.6875rem;
	width: min(22.3611111111vw, 20.125rem);
}

.top-gallery__img:nth-child(3) {
	right: 0;
	top: 23.8125rem;
	width: min(43.8888888889vw, 39.5rem);
}

.top-gallery__img:nth-child(4) {
	left: 11.875rem;
	top: 54.1875rem;
	width: min(43.8888888889vw, 39.5rem);
}

.top-gallery__img:nth-child(5) {
	right: 2.25rem;
	top: 62.75rem;
	width: min(24.7222222222vw, 22.25rem);
}

.top-gallery__img:nth-child(6) {
	left: 7.875rem;
	top: 93.5rem;
	width: min(22.3611111111vw, 20.125rem);
}

.top-gallery__img:nth-child(7) {
	right: 9.625rem;
	top: 123.25rem;
	width: min(43.8888888889vw, 39.5rem);
}

.top-gallery__img:nth-child(8) {
	left: 0.5625rem;
	top: 154.5rem;
	width: min(23.0555555556vw, 20.75rem);
}

.top-gallery__img:nth-child(9) {
	right: 0;
	top: 164.625rem;
	width: min(43.8888888889vw, 39.5rem);
}

.top-gallery__img:nth-child(10) {
	left: 11.875rem;
	top: 195rem;
	width: min(43.8888888889vw, 39.5rem);
}

.top-lead {
	position: relative;
	z-index: 5;
}

.top-lead__item {
	position: relative;
	width: 100%;
}

.top-lead__bg {
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	height: 100vh;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
	z-index: -1;
}

.top-lead__item.is-active .top-lead__bg {
	position: fixed;
}

.top-lead__bg::before {
	background-color: rgba(0, 0, 0, 0.4);
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	width: 100%;
}

.top-lead__bg.top-lead__bg02::before {
	background-color: rgba(0, 0, 0, 0.3);
}

.top-lead__container {
	z-index: 5;
}

.top-lead__item:nth-child(1) .top-lead__container {
	padding-bottom: 20.125rem;
	padding-top: 20.125rem;
	z-index: 5;
}

.top-lead__item:nth-child(2) .top-lead__container {
	padding-bottom: 5rem;
	padding-top: 8.6875rem;
	z-index: 5;
}

.top-lead__text {
	color: #fff;
	font-size: 2.1875rem;
	font-weight: 700;
	letter-spacing: 0.07em;
	line-height: 1.6;
	width: 100%;
}

.top-lead__text span {
	font-size: 3rem;
	font-weight: 900;
}

.top-lead__link {
	margin-top: 4.5625rem;
	text-align: center;
}

.top-recruit__contents {
	background-color: #fff;
	border-radius: 0.3125rem;
	display: grid;
	grid-template-columns: min(31.1111111111vw, 28rem) 1fr;
	margin-left: auto;
	margin-right: auto;
	max-width: 71.5rem;
	overflow: hidden;
}

.top-recruit__img img {
	aspect-ratio: 448/456;
	height: auto;
	width: 100%;
}

.top-recruit__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 2.5rem 1rem;
}

.top-recruit__title {
	color: #124D8A;
	font-family: "Oswald", sans-serif;
	font-size: 10rem;
	font-weight: 400;
	letter-spacing: -0.05em;
	line-height: 1;
	text-transform: uppercase;
}

.top-recruit__link {
	margin-top: 2.5rem;
	text-align: center;
	width: 100%;
}

.top-topics {
	background-color: #EBEBEB;
	overflow: hidden;
	padding-bottom: 10rem;
	padding-top: 4.5rem;
	position: relative;
	transition: background-color 0.5s ease;
	z-index: 5;
}

.top-topics::after {
	aspect-ratio: 1528/1407;
	background-image: url(../images/top/bg_logo03.webp);
	background-position: center;
	background-repeat: no-repeat;
	background-size: cover;
	content: "";
	display: block;
	height: auto;
	position: absolute;
	right: -11%;
	top: 30%;
	transform: translateY(-50%);
	width: min(106.1111111111vw, 95.5rem);
	z-index: -1;
}

.top-topics__inner {
	position: relative;
	z-index: 5;
}

.top-topics__list {
	margin-top: 3.0625rem;
}

.top-topics__link {
	margin-top: 5rem;
	text-align: right;
}

.topics {
	border-top: 1px solid rgba(28, 28, 28, 0.2);
}

.topics__link {
	align-items: center;
	border-bottom: 1px solid rgba(28, 28, 28, 0.2);
	display: block;
	display: flex;
	padding: 2.25rem 0.75rem;
	position: relative;
}

.topics__link::after {
	-webkit-mask-image: url(../images/common/arrow01.svg);
	-webkit-mask-position: center;
	-webkit-mask-size: contain;
	-webkit-mask-repeat: no-repeat;
	background-color: #1C1C1C;
	content: "";
	display: block;
	height: 2.25rem;
	margin-left: auto;
	mask-image: url(../images/common/arrow01.svg);
	mask-position: center;
	mask-repeat: no-repeat;
	mask-size: contain;
	position: absolute;
	right: 0.75rem;
	top: 50%;
	transform: translate(0, -50%);
	transition: transform 0.3s;
	width: 2.25rem;
}

.topics__link:hover::after {
	transform: translate(10px, -50%);
}

.topics__date {
	font-family: "Oswald", sans-serif;
	font-size: 0.8125rem;
	font-weight: 400;
	letter-spacing: -0.06em;
	opacity: 1;
	transition: opacity 0.3s;
}

.topics__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;
	display: -webkit-box;
	flex: 1;
	font-family: "Zen Kaku Gothic New", sans-serif;
	font-size: 1.125rem;
	font-size: 1rem;
	font-weight: 700;
	letter-spacing: 0.02em;
	margin-left: 3.0625rem;
	margin-left: 4.25rem;
	margin-right: 3.0625rem;
	margin-right: 4.25rem;
	opacity: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	transition: opacity 0.3s;
	word-break: break-word;
}

.topics__link:hover .topics__date,
.topics__link:hover .topics__title {
	opacity: 0.7;
}

@media (prefers-reduced-motion: reduce) {

.mv__title,
.mv-swiper,
.mv__copy-ja {
	opacity: 1;
	transition: none;
}

}

@media (any-hover: hover) {

.sub-head__link:hover::after {
	transform: translateY(0.1875rem);
}

}

@media (max-width: 1376px) {

html {
	font-size: 1.1627906977vw;
}

}

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

.u-desktop {
	display: none;
}

.u-mobile {
	display: block;
}

html {
	font-size: 16px;
}

.case-contact-l {
	margin-top: 10rem;
}

.case-single-contact-l {
	margin-top: 5rem;
}

.case-single-l {
	margin-top: 3.5rem;
}

.equipment-contact-l {
	margin-top: 7.5rem;
}

.faq-l {
	margin-top: 5rem;
}

.flow-l {
	margin-top: 5rem;
}

.greeting-l {
	margin-top: 7.5rem;
}

.header-l {
	top: 0.75rem;
}

.introduction-l {
	margin-top: 5rem;
}

.news-contact-l {
	margin-top: 5rem;
}

.news-l {
	margin-top: 7.5rem;
}

.overview-l {
	margin-top: 5rem;
}

.policy-l {
	margin-top: 5rem;
}

.post-nav-l {
	margin-top: 5rem;
}

.purpose-l {
	margin-top: 5rem;
}

.service-l {
	margin-top: 7.5rem;
}

.service-what-l {
	margin-top: 7.5rem;
}

.single-contact-l {
	margin-top: 5rem;
}

.single-l {
	margin-top: 5rem;
}

.sub-404-l {
	margin-top: 5rem;
}

.sub-contact-l {
	margin-top: 5rem;
}

.sub-head-l.sub-head--single {
	margin-top: 8.5625rem;
}

.sub-head.sub-head--topics {
	margin-top: 8.5625rem;
}

.thanks-l {
	margin-top: 5rem;
}

.top-contact-l {
	margin-top: 7.5rem;
}

.appeal {
	padding-top: 5rem;
}

.appeal__inner.inner {
	grid-template-columns: 1fr;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}

.appeal__content {
	padding-left: 0;
	padding-right: 0;
}

.appeal__text {
	font-size: 1.125rem;
	margin-top: 2.5rem;
}

.appeal__image01 {
	border-radius: 0.3125rem;
	width: 60%;
}

.appeal__image02 {
	border-radius: 0.3125rem;
	margin-top: -2.5rem;
	width: 50%;
}

.appeal__image03 {
	border-radius: 0.3125rem;
	margin-left: 2.5rem;
	margin-top: 5rem;
	width: 40%;
}

.appeal__image04 {
	border-radius: 0.3125rem;
	margin-left: auto;
	margin-right: 1.25rem;
	margin-top: -7.5rem;
	width: 50%;
}

.breadcrumbs a {
	font-size: 1.75rem;
}

.button {
	max-width: 15rem;
	padding-bottom: 0.625rem;
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.625rem;
}

.button span {
	font-size: 0.875rem;
}

.case-single__inner.inner {
	max-width: 600px;
}

.case-single__title {
	font-size: 1.625rem;
	margin-top: 0.5rem;
	padding-bottom: 0.5rem;
}

.case-single__gallery-thumbs-wrap {
	margin-right: -20px;
	overflow-x: auto;
	padding-bottom: 0.5rem;
}

.case-single__gallery-thumbs {
	margin-right: 1.25rem;
	width: 35rem;
}

.case-single__contents {
	gap: 3.5rem;
	grid-template-columns: 1fr;
	margin-top: 5rem;
}

.case-single__content-title {
	font-size: 1.25rem;
}

.case-single__content-text {
	font-size: 1rem;
	margin-top: 0.5rem;
}

.swiper-button-prev.case-slider-pager__prev,
.swiper-button-next.case-slider-pager__next {
	height: 2.5rem;
	width: 2.5rem;
}

.case-slider-pager__pagination.swiper-pagination {
	margin-left: 1.25rem;
	transform: translateY(-0.25rem);
}

.case-slider-pager__pagination.swiper-pagination .swiper-pagination-bullet {
	transform: translateY(-0.625rem);
	width: 20%;
}

.case-slider-thumbnail__slide.swiper-slide {
	width: min(30.7692307692vw, 7.5rem);
}

.case-slider__link {
	grid-template-columns: 1fr 10rem;
	width: 100%;
}

.case-slider__content {
	padding: 1rem;
}

.case-slider__slide-num {
	font-size: 0.625rem;
}

.case-slider__slide-title {
	font-size: 1.125rem;
	margin-bottom: 0.625rem;
}

.case__inner.inner {
	max-width: 600px;
}

.case__list {
	grid-template-columns: repeat(auto-fit, minmax(12.5rem, 1fr));
}

.case__title {
	font-size: 1.25rem;
	margin-top: 1rem;
}

.case__applications {
	margin-top: 0.5rem;
}

.case__applications dt {
	font-size: 1rem;
}

.case__applications dd {
	font-size: 1rem;
	margin-top: 0;
}

.company-list__unit {
	gap: 0.5rem;
	grid-template-columns: 1fr;
	padding-bottom: 1.25rem;
}

.company-list__unit {
	margin-top: 1.25rem;
}

.company-list__title,
.company-list__item {
	font-size: 1rem;
}

.company-title {
	font-size: 1.625rem;
}

.contact {
	grid-template-columns: 1fr;
}

.contact__link span {
	font-size: 1.125rem;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

.contact__link span::after {
	height: 1.25rem;
}

.culture {
	padding-bottom: 5rem;
}

.culture__contents {
	margin-top: 5rem;
}

.culture__content:nth-child(1)::before,
.culture__content:nth-child(3)::before {
	bottom: auto;
	right: 0;
	top: 0;
	transform: translate(1.25rem, -2.5rem);
	width: 11.25rem;
}

.culture__content-inner {
	max-width: 37.5rem;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	writing-mode: horizontal-tb;
}

.culture__content:nth-child(2n) .culture__content-inner {
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	writing-mode: horizontal-tb;
}

.culture__content:nth-child(3) .culture__content-inner {
	padding-bottom: 3.9375rem;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
	padding-top: 3.625rem;
}

.culture__content-title {
	font-size: 1.75rem;
	writing-mode: horizontal-tb;
}

.culture__content-title span {
	background: linear-gradient(180deg, transparent 0%,transparent 80%, #fff 80%, #fff 100%);
	background: linear-gradient(180deg, transparent 0% 80%, #fff 80% 100%);
}

.culture__comments {
	grid-template-columns: 1fr;
	margin-right: 0;
	margin-top: 4rem;
	width: 100%;
}

.culture__comment:nth-child(1) {
	font-size: 1rem;
	grid-column: unset;
	grid-row: unset;
	margin-left: 0;
	margin-top: 0;
	writing-mode: horizontal-tb;
}

.culture__comment:nth-child(2) {
	font-size: 1.5rem;
	margin-top: 2rem;
}

.culture__comment:nth-child(3) {
	font-size: 1.125rem;
	margin-top: 2rem;
}

.culture__comment:nth-child(4) {
	font-size: 1.5625rem;
	margin-top: 2rem;
}

.culture__comment:nth-child(4) span.u-mobile {
	display: inline-block;
	margin-top: 0;
}

.culture__comment:nth-child(5) {
	margin-top: 2rem;
}

.culture__comment:nth-child(5) span.culture__comment-marker {
	font-size: 1rem;
}

.culture__comment:nth-child(6) {
	grid-column: unset;
	grid-row: unset;
	margin-right: 0;
	margin-top: 2rem;
	writing-mode: horizontal-tb;
}

.culture__comment span {
	font-size: 1rem;
}

.culture__comment:nth-child(2) .culture__desc {
	margin-left: 0;
}

.culture__job-type {
	grid-template-columns: 1fr;
	margin-left: 0;
	margin-top: 4rem;
	row-gap: 2.5rem;
	width: 100%;
}

.culture__type-title p {
	font-size: 0.75rem;
}

.culture__type-title h4 {
	glyph-orientation-horizontal: 1rem;
	margin-top: 0.5rem;
}

.culture__type-item {
	font-size: 1rem;
}

.culture__type-item::before {
	width: 0.625rem;
}

.culture__points {
	grid-template-columns: 1fr;
	margin-right: 0;
	margin-top: 2.5rem;
	row-gap: 0.625rem;
}

.culture__point {
	aspect-ratio: unset;
	height: 100%;
	width: 100%;
}

.culture__point:nth-child(1) {
	transform: translate(0);
}

.culture__point:nth-child(2) {
	transform: translate(0);
}

.culture__point:nth-child(3) {
	transform: translate(0);
}

.culture__point:nth-child(5) {
	transform: translate(0);
}

.culture__point:nth-child(6) {
	transform: translate(0);
}

.drawer__container {
	height: 100lvh;
	max-width: 100vw;
}

.drawer__inner {
	align-items: start;
	flex-direction: column;
	gap: 2.5rem;
	height: auto;
	padding: 7.5rem 2.5rem 5rem;
}

.drawer__nav-item a {
	font-size: 2.25rem;
}

.drawer__nav-item a span {
	font-size: 1.125rem;
}

.equip-list {
	gap: 2.5rem 2.5rem;
	grid-template-columns: repeat(auto-fit, minmax(12.5rem, 1fr));
}

.equip-item__desc {
	font-size: 1rem;
}

.equipment__contents {
	gap: 3rem;
	grid-template-columns: 1fr;
	margin-top: 4.5rem;
}

.equipment__nav-inner {
	position: static;
}

.equipment__nav-list {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 0.9375rem;
}

.equipment__nav-item + .equipment__nav-item {
	margin-top: 0;
}

.faq__contents {
	gap: 2.5rem;
	grid-template-columns: 1fr;
}

.faq__title p {
	font-size: 5rem;
}

.faq__title h2 {
	font-size: 1.75rem;
}

.faq__content {
	margin-top: 0;
}

.faq__item {
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}

.faq__q {
	font-size: 1.125rem;
	padding-left: 1.5rem;
}

.faq__q::before {
	font-size: 1.25rem;
}

.faq__a {
	padding-left: 1.5rem;
}

.faq__a::before {
	font-size: 1.25rem;
}

.flow__title p {
	font-size: 5rem;
}

.flow__title h2 {
	font-size: 1.75rem;
}

.flow__list {
	grid-template-columns: 1fr;
}

.flow__item {
	padding-bottom: 2rem;
	padding-top: 2rem;
}

.flow__item::after {
	right: 50%;
	top: 100%;
	transform: translate(50%, -0.25rem) rotate(90deg);
}

.flow__text {
	font-size: 1.25rem;
	text-align: center;
	writing-mode: horizontal-tb;
}

.footer {
	padding-top: 2.5rem;
}

.footer__copy {
	font-size: min(19.7435897436svw, 7.5rem);
	left: 0;
}

.footer__text {
	font-size: 1.125rem;
}

.footer__contents {
	flex-direction: column-reverse;
	margin-top: 4.0625rem;
	row-gap: 5rem;
}

.footer__site-name {
	width: 11.25rem;
}

.footer__nav-item a {
	font-size: 1.75rem;
}

.footer__bottom {
	margin-top: 7.5rem;
}

.footer__page-top {
	right: 0;
	top: -2.5rem;
}

.form-input input {
	font-size: 1rem;
	padding: 0.5rem;
}

.form-input input::-moz-placeholder {
	font-size: 1rem;
}

.form-input input::placeholder {
	font-size: 1rem;
}

.form__wrap {
	flex-direction: column;
	gap: 1rem;
}

.form__wrap + .form__wrap {
	margin-top: 4rem;
}

.form__privacy label input + span {
	font-size: 1.125rem;
	line-height: 1.5;
	padding-left: 1.25rem;
}

.form__privacy-disc {
	margin-top: 0.5rem;
	padding-left: 1.25rem;
}

.greeting__contents {
	gap: 2.5rem;
	grid-template-columns: 1fr;
	margin-top: 2.5rem;
}

.greeting__img {
	width: 100%;
}

.greeting__text {
	font-size: 1rem;
}

.greeting__text + .greeting__text {
	margin-top: 1lh;
}

.greeting__position {
	font-size: 1.25rem;
}

.greeting__position span {
	font-size: 12px;
}

.hamburger {
	width: 3.625rem;
}

.hamburger span {
	width: 1.25rem;
}

.hamburger span:nth-child(1) {
	top: 0.9375rem;
}

.hamburger span:nth-child(2) {
	top: 1.25rem;
}

.hamburger.is-open span:nth-child(1) {
	left: 1.125rem;
	top: 1.125rem;
}

.hamburger.is-open span:nth-child(2) {
	left: 1.125rem;
	top: 1.125rem;
}

.header {
	height: 2.5rem;
}

.header__inner {
	padding-left: 0.625rem;
	padding-right: 0.625rem;
}

.header__site-name {
	flex-shrink: 0;
	width: 13.75rem;
}

.header:has(.header__hamburger.is-open) .header__site-name img {
	filter: invert(88%) sepia(61%) saturate(0%) hue-rotate(229deg) brightness(107%) contrast(101%);
}

.header__cta {
	font-size: 0.5rem;
	padding-left: 0.625rem;
	padding-right: 0.625rem;
}

.header__hamburger {
	margin-left: 0.3125rem;
}

.inner {
	max-width: 600px;
	padding-left: 20px;
	padding-right: 20px;
}

.introduction__contents {
	gap: 2.5rem;
	grid-template-columns: 1fr;
	margin-top: 2.5rem;
}

.introduction__img {
	width: 100%;
}

.introduction__text {
	font-size: 1rem;
}

.introduction__position {
	font-size: 1.25rem;
}

.introduction__position span {
	font-size: 12px;
}

.introduction__section-img {
	margin-top: 5rem;
}

.job {
	padding-bottom: 5rem;
	padding-top: 5rem;
}

.job__contents {
	padding-bottom: 2rem;
	padding-top: 2rem;
}

.job__contents-inner {
	padding-left: 1rem;
	padding-right: 1rem;
}

.job__content-top {
	grid-template-columns: 1fr;
}

.job__content-title h3 {
	font-size: 1.625rem;
	line-height: 1.5;
}

.job__content-title p {
	margin-top: 1rem;
}

.job__content-title.job__content-title--sm h3 {
	font-size: 1.5rem;
}

.job__content-title.job__content-title--sm p {
	font-size: 1rem;
}

.job__text {
	font-size: 1rem;
}

.job__text + .job__text {
	margin-top: 1lh;
}

.job__img {
	grid-column: unset;
	grid-row: 2/3;
}

.job__content-bottom {
	margin-top: 5rem;
}

.job__list {
	gap: 1.5rem 1rem;
	grid-template-columns: repeat(2, 1fr);
}

.job__item {
	row-gap: 0;
}

.job__item-text {
	font-size: 0.875rem;
}

.mv-swiper {
	aspect-ratio: 370/466;
	justify-self: center;
}

.mv-swiper__wrapper {
	aspect-ratio: 370/466;
	border-radius: 0.1875rem;
}

.mv {
	padding-top: 5.25rem;
}

.mv__inner.inner {
	grid-template-columns: 1fr;
	padding-left: 10px;
	padding-right: 10px;
}

.mv__title {
	grid-column: unset;
}

.mv__title .title__en {
	font-size: min(19.7435897436svw, 7.5rem);
	margin-left: -20px;
	margin-right: -20px;
	margin-top: -0.1875rem;
	transform: translateX(0rem);
}

.mv__copy-ja {
	font-size: 1.5rem;
	font-weight: 700;
	justify-self: start;
	letter-spacing: 0.06em;
	margin-top: 1.125rem;
	transform: translateX(0rem);
	writing-mode: inherit;
}

.mv__text {
	margin-left: 0;
}

.mv__slide-container {
	margin-top: 1.125rem;
	padding-right: 0;
}

.news__pagination {
	margin-top: 5rem;
}

.overview__contents {
	margin-top: 2.5rem;
}

.overview__section-img {
	margin-top: 5rem;
}

.pagenavi .pagination span,
.pagenavi .pagination a {
	height: 2.5rem;
	width: 2.5rem;
}

.pagenavi .prev-link,
.pagenavi .next-link {
	height: 1.75rem;
	width: 1.75rem;
}

.policy__title {
	font-size: 1.25rem;
	line-height: 1.5;
}

.policy__text {
	font-size: 1rem;
}

.policy__item {
	font-size: 1rem;
}

.post-nav__list {
	align-items: center;
	flex-direction: column;
	gap: 1.25rem;
	padding-top: 5rem;
}

.post-nav__item--prev::before,
.post-nav__item--next::after {
	height: 1.125rem;
	width: 1.125rem;
}

.purpose__title p {
	font-size: 5rem;
}

.purpose__title h2 {
	bottom: 50%;
	font-size: 1.75rem;
	text-align: center;
	transform: translate(-50%, 60%);
}

.purpose__contents {
	margin-top: 5rem;
}

.purpose__list {
	border: none;
	grid-template-columns: 1fr;
}

.purpose__list-title {
	font-size: 1rem;
	padding: 1.25rem 0.625rem;
}

.purpose__list-item {
	border: none;
	font-size: 1rem;
	padding: 1.5rem 0.625rem;
}

.purpose__content {
	grid-template-columns: 1fr;
}

.purpose__text {
	font-size: 1.25rem;
}

.purpose__img {
	width: 100%;
}

.recruit-lead::after {
	height: 18.75rem;
}

.recruit-lead__container {
	padding-bottom: 5rem;
	padding-top: 5rem;
}

.recruit-lead__container::before {
	right: 50%;
	transform: translate(65%, -50%);
}

.recruit-lead__inner.inner {
	writing-mode: horizontal-tb;
}

.recruit-lead__copy-wrap {
	margin-left: auto;
	margin-right: auto;
	transform: translateX(1.25rem);
	writing-mode: vertical-rl;
}

.recruit-lead__copy {
	font-size: 2.5rem;
}

.recruit-lead__copy:nth-child(2) {
	margin-top: 4rem;
}

.recruit-lead__copy span {
	font-size: 4rem;
}

.recruit-lead__copy span:nth-child(1) {
	transform: translateX(-1.25rem);
}

.recruit-lead__copy span:nth-child(2) {
	margin-top: 0rem;
	transform: translateX(-0.3125rem);
}

.recruit-lead__copy span:nth-child(3) {
	margin-top: 1.25rem;
	transform: translateX(-1rem);
}

.recruit-lead__content {
	margin-right: 0;
	margin-top: 5rem;
}

.recruit-lead__text + .recruit-lead__text {
	margin-right: 0;
	margin-top: 1lh;
}

.recruit-lead__text {
	font-size: 1rem;
	line-height: 2;
}

.section-head {
	grid-template-columns: 1fr;
	row-gap: 0;
}

.section-head__title p {
	font-size: 5.375rem;
}

.section-head__title h2 {
	font-size: 2rem;
	left: 2rem;
	top: 1.5rem;
}

.section-head__copy {
	font-size: 1.625rem;
	grid-column: unset;
	grid-row: unset;
	margin-top: 2.5rem;
	padding-left: 0;
}

.section-head__text {
	font-size: 1rem;
	grid-column: unset;
	grid-row: unset;
	margin-top: 1rem;
}

.section-head.section-head--appeal .section-head__title h2 {
	font-size: 2.125rem;
}

.section-head.section-head--appeal .section-head__title p {
	right: 1.5rem;
	top: 0rem;
}

.section-head.section-head--culture .section-head__text {
	margin-top: 1rem;
}

.section-head.section-head--description .section-head__title p {
	padding-left: 0;
}

.section-head.section-head--description .section-head__title h2 {
	top: 2.5rem;
}

.service-lead {
	padding-bottom: 7.5rem;
	padding-top: 5rem;
}

.service-lead__inner.inner {
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}

.service-lead__copy {
	font-size: 2.5rem;
}

.service-lead__text {
	font-size: 1.125rem;
}

.service-what__content {
	padding-bottom: 5rem;
	padding-top: 5rem;
}

.service-what__content::before {
	font-size: 6.25rem;
}

.service-what__content::after {
	margin-top: 2.5rem;
	position: static;
	transform: translate(0);
	width: 100%;
}

.service-what__title {
	font-size: 2rem;
}

.service-what__text {
	font-size: 1rem;
}

.service {
	padding-top: 5rem;
}

.service__contents {
	grid-template-columns: 1fr;
}

.service__title {
	padding-left: 1.5rem;
}

.service__title p {
	font-size: 5rem;
}

.service__title h2 {
	font-size: 1.75rem;
}

.service__content {
	grid-template-rows: repeat(5, auto);
	margin-top: 2.5rem;
}

.service__content-item {
	font-size: 1.125rem;
	padding-bottom: 1.5rem;
	padding-left: 4rem;
	padding-right: 1.25rem;
	padding-top: 1.5rem;
}

.single__head {
	padding-bottom: 1rem;
}

.single__title {
	font-size: 1.75rem;
}

.single__content {
	margin-top: 3.5rem;
}

.single__content * + * {
	margin-top: 1lh;
}

.single__content h2 {
	font-size: 1.625rem;
	padding-left: 1rem;
}

.single__content h3 {
	font-size: 1.5rem;
	padding-left: 1rem;
	padding-right: 1rem;
}

.single__content h4 {
	font-size: 1.25rem;
	padding-bottom: 0.25rem;
	padding-left: 0.5em;
	padding-right: 0.5em;
}

.single__content h4::before {
	width: min(20.5128205128vw, 6.25rem);
}

.single__content h5 {
	font-size: 1.125rem;
}

.single__content p {
	font-size: 1rem;
}

.sub-404 {
	padding-bottom: 5rem;
}

.sub-contact {
	padding-bottom: 7.5rem;
}

.sub-contact__tel {
	gap: 1.5rem;
	grid-template-columns: 1fr;
	padding-left: 1.25rem;
	padding-right: 1.25rem;
}

.sub-contact__tel-title {
	font-size: 1.25rem;
	text-align: center;
}

.sub-contact__tel-link {
	display: flex;
	font-size: min(10.2564102564vw, 2.5rem);
	gap: 0.5rem;
	justify-content: center;
}

.sub-contact__tel-link::before {
	left: auto;
	position: static;
	top: auto;
	transform: translate(0);
	width: min(6.6666666667vw, 1.625rem);
}

.sub-contact__tel-text {
	margin-top: 0.5rem;
	text-align: center;
}

.sub-contact__mail-title {
	font-size: 1.375rem;
}

.sub-contact__mail-text {
	font-size: 1rem;
}

.sub-head__inner.inner {
	grid-template-columns: 1fr;
}

.sub-head__title {
	margin-top: 2rem;
}

.sub-head__title h1 {
	font-size: 1.125rem;
}

.sub-head__title p {
	font-size: 4.8125rem;
}

.sub-head__breadcrumb {
	grid-row: 1/2;
	justify-self: start;
	transform: translate(0);
}

.sub-head__text {
	font-size: 1rem;
	grid-column: unset;
	margin-top: 2.5rem;
}

.sub-head.sub-head--policy .sub-head__title p {
	line-height: 1.2;
}

.sub-head__link-wrap {
	grid-gap: 1.5rem;
	display: grid;
	gap: 1.5rem;
	grid-auto-flow: column;
	grid-template-columns: auto 1fr;
	grid-template-rows: repeat(2, 1fr);
	margin-top: 4rem;
}

.sub-head__link {
	gap: 0.1875rem;
}

.sub-head__link span {
	font-size: 1rem;
}

.sub-head.sub-head--404 .sub-head__title p {
	line-height: 1.2;
}

.tab__inner {
	padding-left: 0.625rem;
	padding-right: 0.625rem;
}

.tab__list {
	align-items: start;
	border-top: 1px solid rgba(28, 28, 28, 0.3);
	flex-direction: column;
	padding-bottom: 1rem;
	padding-right: 0;
	padding-top: 1rem;
}

.tab__title {
	font-size: 1.125rem;
	padding-bottom: 0;
	padding-left: 0.5rem;
	padding-right: 0.5rem;
	padding-top: 0;
	width: 100%;
}

.tab__item {
	border: none;
	margin-top: 1rem;
	padding: 0rem 0.5rem;
}

.tab__list:nth-last-child(1) .tab__item {
	border: none;
}

.tab__list:nth-last-child(1) {
	border-bottom: 1px solid rgba(28, 28, 28, 0.3);
}

.thanks {
	padding-bottom: 5rem;
}

.thanks__title {
	font-size: 1.625rem;
	text-align: left;
}

.thanks__text {
	font-size: 1rem;
	margin-left: 0;
}

h1.title__ja {
	font-size: 0.6875rem;
	margin-right: -0.125rem;
}

h2.title__ja {
	font-size: 1rem;
	padding-bottom: 0.25rem;
	padding-left: 1rem;
	padding-right: 1rem;
	padding-top: 0.25rem;
}

.title__en {
	font-size: 4.8125rem;
}

.top-case {
	padding-bottom: 5rem;
	padding-top: 5rem;
}

.top-case__title {
	padding-bottom: 1.25rem;
}

.top-case__slider-wrap {
	gap: 0;
	grid-template-columns: 1fr;
}

.top-case__slider-thumbnail {
	margin-left: 0px;
	margin-right: 0px;
	margin-top: 1.25rem;
}

.top-case__slider-pager {
	margin-top: 2rem;
}

.top-case__link {
	margin-top: 2.5rem;
}

.top-contact {
	padding-bottom: 5rem;
	padding-top: 5rem;
}

.top-contact__link {
	max-width: 600px;
}

.top-contact__title h2 span {
	font-size: 2.25rem;
}

.top-contact__text {
	font-size: 1rem;
	line-height: 1.6;
}

.top-gallery {
	padding-top: 11.25rem;
}

.top-gallery__inner.inner {
	padding-left: 0;
	padding-right: 0;
}

.top-gallery__bg::after {
	font-size: min(19.7435897436svw, 7.5rem);
	top: 7.5rem;
}

.top-gallery__container {
	height: 280vw;
}

.top-gallery__img:nth-child(1) {
	left: 34%;
	width: min(30.7692307692vw, 9.625rem);
}

.top-gallery__img:nth-child(2) {
	left: 0;
	top: 8%;
	width: min(28.2051282051vw, 8.875rem);
}

.top-gallery__img:nth-child(3) {
	top: 15%;
	width: min(48.7179487179vw, 17.5rem);
}

.top-gallery__img:nth-child(4) {
	left: 0;
	top: 28%;
	width: min(53.8461538462vw, 17.5rem);
}

.top-gallery__img:nth-child(5) {
	right: 0;
	top: 32%;
	width: min(33.3333333333vw, 9.875rem);
}

.top-gallery__img:nth-child(6) {
	left: 0;
	top: 44%;
	width: min(41.0256410256vw, 8.875rem);
}

.top-gallery__img:nth-child(7) {
	right: 0;
	top: 60%;
	width: min(51.2820512821vw, 17.5rem);
}

.top-gallery__img:nth-child(8) {
	left: 0;
	top: 68%;
	width: min(28.2051282051vw, 8.875rem);
}

.top-gallery__img:nth-child(9) {
	top: 80%;
	width: min(53.8461538462vw, 17.5rem);
}

.top-gallery__img:nth-child(10) {
	left: 20%;
	top: 95%;
	width: min(51.2820512821vw, 17.5rem);
}

.top-lead__item {
	min-height: 80svh;
}

.top-lead__bg {
	background-position: right center;
}

.top-lead__item:nth-child(1) {
	align-items: center;
	display: flex;
}

.top-lead__item:nth-child(1) .top-lead__container {
	padding-bottom: 6.25rem;
	padding-top: 6.25rem;
}

.top-lead__text {
	font-size: 1rem;
	line-height: 2;
}

.top-lead__text span {
	font-size: 1.5rem;
}

.top-recruit__contents {
	grid-template-columns: 1fr;
}

.top-recruit__img img {
	-o-object-fit: cover;
	aspect-ratio: 3/2;
	object-fit: cover;
}

.top-recruit__title {
	font-size: 6.25rem;
}

.top-recruit__link {
	margin-top: 1.25rem;
}

.top-topics {
	padding-bottom: 7.5rem;
	padding-top: 5rem;
}

.top-topics__list {
	margin-top: 1.25rem;
}

.top-topics__link {
	margin-top: 2.5rem;
}

.topics__link {
	align-items: start;
	flex-direction: column;
	padding: 1rem 0.625rem;
}

.topics__link::after {
	height: 1.25rem;
	width: 1.25rem;
}

.topics__title {
	margin-left: 0;
	margin-right: 2.5rem;
}

}

@media (max-width: 375px) {

html {
	font-size: 4.2666666667vw;
}

}

@keyframes progress {

from {
	width: 0%;
}

to {
	width: 100%;
}

}

@keyframes loading {

0% {
	transform: scale(1);
}

50% {
	transform: scale(0.5);
}

100% {
	transform: scale(1);
}

}

@keyframes fade {

from {
	opacity: 0;
}

to {
	opacity: 1;
}

}


/*# sourceMappingURL=style.css.map */
