:root {
	--padding-inline: 30px;
	--max-width: 1200px;
}

:root {
	--font-family-base: "Noto Serif JP","Hiragino Mincho ProN", sans-serif;
	--font-family-second: "Noto Sans JP", "Hiragino Sans", "Yu Gothic", sans-serif;
	--font-family-third: "annabelle-jf", sans-serif;
	--font-family-fourth: "Open Sans", sans-serif;
}

:root {
	--font-weight-light: 300;
	--font-weight-regular: 400;
	--font-weight-medium: 500;
	--font-weight-semibold: 600;
	--font-weight-bold: 700;
	--font-weight-extrabold: 800;
	--font-weight-black: 900;
}

:root {
	--black: #000;
	--white: #fff;
	--text-black: #444444;
	--main-color: #888434;
	--main-color-hover: #aaa31f;
	--main-bg-gold: #898534;
	--main-bg-black: #353535;
	--main-bg-gray: #F2F2F2;
	--main-gray-opacity: rgba(0, 0, 0, 0.05);
	--main-brown: #68341D;
	--main-green: #006934;
}

:root {
	--z-index-header: 100;
	--z-index-to-top: 200;
	--z-index-drawer: 1000;
	--z-index-hamburger: 10000;
	--z-index-modal: 100000;
}

:root {
	--cq-ref-mobile: 375;
	--cq-ref: 1300;
	--fluid-basis-mobile: (100vw - 320px) / (375 - 320);
	--fluid-basis: (100vw - 768px) / (1300 - 768);
	--fluid-basis-2: (100vw - 1440px) / (1800 - 1440);
}

:root {
	--duration-ui: 0.25s;
	--duration-hover: 0.3s;
	--duration-scroll: 0.5s;
	--duration-emphasis: 0.7s;
	--ease-smooth-bounce: cubic-bezier(.48, .07, .33, .79);
}

body {
	color: var(--text-black);
	font-family: var(--font-family-base);
}

.u-desktop {
	display: none;
}

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

html {
	font-size: 16px;
}

html {
	scroll-padding-block-start: 3.4375rem;
}

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

html {
	-webkit-text-size-adjust: 100%;
	-moz-text-size-adjust: 100%;
	text-size-adjust: 100%;
	scroll-behavior: smooth;
}

html.no-smooth-scroll {
	scroll-behavior: auto;
}

body {
	word-wrap: anywhere;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	line-break: strict;
	line-height: 1.5;
	margin: 0;
	overflow-wrap: anywhere;
	text-rendering: optimizeLegibility;
	word-break: normal;
}

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

ul,
ol {
	list-style: none;
}

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

a,
span,
button {
	display: inline-block;
}

small,
time,
figure {
	border: 0;
	font: inherit;
	font-size: 100%;
	vertical-align: baseline;
}

address {
	font-style: normal;
}

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

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

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

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

textarea {
	resize: vertical;
}

input[type=checkbox],
input[type=radio] {
	-webkit-clip-path: polygon(0 0, 0 0, 0 0, 0 0);
	border: 0;
	clip-path: polygon(0 0, 0 0, 0 0, 0 0);
	height: 1px;
	margin: -1px;
	padding: 0;
	position: absolute;
	width: 1px;
}

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

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

button {
	color: inherit;
}

a {
	-webkit-tap-highlight-color: transparent;
}

button {
	-webkit-tap-highlight-color: transparent;
}

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

.access {
	margin-top: 5.9375rem;
}

.access__list {
	display: flex;
	flex-direction: column;
	gap: 1.625rem;
	margin-top: 2.5rem;
}

.access__item {
	display: flex;
	flex-direction: column;
	gap: 0.3125rem;
}

.access__map {
	aspect-ratio: 680/428;
	display: block;
	height: 100%;
	width: 100%;
}

.access__address {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
}

.section-title__label-wrap {
	position: relative;
	width: 100%;
}

.section-title__label-bg {
	color: var(--main-gray-opacity);
	font-family: var(--font-family-fourth);
	font-size: 3.9375rem;
	font-weight: var(--font-weight-regular);
	left: -0.5625rem;
	letter-spacing: 0.08em;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	top: -2.5rem;
	white-space: nowrap;
	z-index: 0;
}

.section-title__label {
	color: var(--main-green);
	font-family: var(--font-family-fourth);
	font-size: 1.125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.3em;
}

.section-title__title {
	font-size: 1.875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.3em;
	line-height: 1.4;
	margin-top: 0.75rem;
}

.company-section {
	padding-block: 4.0625rem 2.625rem;
}

.company-section.company-section--bg-gray {
	background-color: var(--main-bg-gray);
}

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

.company-section__text {
	color: var(--text-black);
	font-size: 1rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.08em;
	line-height: 1.76;
}

.company {
	background-color: var(--main-bg-gray);
	padding-block: 4.0625rem 2.8125rem;
}

.company__info-list {
	display: flex;
	flex-direction: column;
	gap: 1.5625rem;
	margin-top: 2.4375rem;
}

.company__info-item {
	display: grid;
	gap: 0.375rem;
	grid-template-columns: 1fr;
}

.company__info-term {
	-moz-text-align-last: justify;
	font-size: 0.9375rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.15em;
	text-align-last: justify;
}

.company__info-term--en {
	display: inline-flex;
	justify-content: space-between;
}

.company__info-desc {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
}

.company__info-desc a {
	word-break: break-all;
}

.company__license-blocks {
	display: flex;
	flex-direction: column;
	gap: 0.5625rem;
}

.company__license-block {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
}

.history {
	margin-top: 4.375rem;
}

.history__info-list {
	display: flex;
	flex-direction: column;
	gap: 1.5625rem;
	margin-top: 3.125rem;
}

.history__info-item {
	display: grid;
	gap: 0.5rem;
	grid-template-columns: 1fr;
}

.history__info-term {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.14em;
}

.history__info-desc {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.18em;
}

.history__desc-blocks {
	display: flex;
	flex-direction: column;
	gap: 0;
}

.history__desc-block {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
}

.message {
	padding-block: 4.375rem 2.5rem;
}

.message__content-wrap {
	display: grid;
	gap: 1.5rem;
	grid-template-areas: "img" "text" "signature";
	grid-template-columns: 1fr;
	margin-top: 1.8125rem;
}

.message__text-wrap {
	grid-area: text;
}

.message__text {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.13em;
	line-height: 1.87;
	text-align: justify;
}

.message__img-wrap {
	grid-area: img;
}

.message__img {
	-o-object-fit: contain;
	height: auto;
	object-fit: contain;
}

.message__signature-block {
	grid-area: signature;
}

.message__company-name {
	display: inline-block;
	font-size: 1.1875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.17em;
}

.message__name-row {
	align-items: center;
	display: grid;
	gap: 0.75rem;
	grid-template-columns: max-content auto;
	margin-top: 0.25rem;
	width: -moz-fit-content;
	width: fit-content;
}

.message__role {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.17em;
}

.message__ceo-name-img {
	-o-object-fit: contain;
	height: auto;
	object-fit: contain;
}

.privacy-policy {
	margin-top: 9.375rem;
	padding-bottom: 5rem;
}

.privacy-policy__list {
	display: flex;
	flex-direction: column;
	gap: 2.8125rem;
	margin-top: 2.8125rem;
}

.privacy-policy__text-title {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.14em;
	line-height: 2.3;
	margin-top: 2.5rem;
}

.privacy-policy__intro {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.14em;
	line-height: 1.8;
}

.privacy-policy__item-title {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.14em;
	margin-bottom: 0.625rem;
}

.privacy-policy__text {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.14em;
	line-height: 1.8;
}

.privacy-policy__text--mt {
	margin-top: 0.625rem;
}

.privacy-policy__bullet-list {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.14em;
	line-height: 1.8;
	margin-top: 0.625rem;
}

.privacy-policy__bullet-list li {
	align-items: flex-start;
	display: flex;
	padding-left: 0.3125rem;
}

.privacy-policy__bullet-list li::before {
	aspect-ratio: 1/1;
	background-color: var(--text-black);
	border-radius: calc(infinity * 1px);
	content: "";
	display: inline-block;
	flex-shrink: 0;
	margin-right: 0.4375rem;
	margin-top: 0.85em;
	width: 0.25rem;
}

.news {
	padding-block: 2.5rem 5rem;
}

.news__title {
	font-size: 1.5625rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	text-align: center;
}

.news__list {
	display: flex;
	flex-direction: column;
	margin-top: 3.75rem;
}

.news__item {
	border-bottom: 1px solid var(--text-black);
}

.news__item:first-child .news__link {
	padding-block: 0 0.9375rem;
}

.news__link {
	align-items: center;
	display: grid;
	gap: 0.375rem;
	grid-template-columns: 1fr;
	padding-block: 0.9375rem;
}

.news__date {
	font-size: 1rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.17em;
	transition: color var(--duration-ui) ease;
}

.news__item-title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	display: -webkit-box;
	font-size: 1rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.17em;
	overflow: hidden;
	transition: color var(--duration-ui) ease;
}

.recruit {
	padding-block: 2.6875rem 5rem;
}

.recruit__intro {
	font-size: 1.125rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	margin-inline: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.recruit__conditions {
	display: flex;
	flex-direction: column;
	margin-top: 2.5625rem;
}

.recruit__condition-item {
	--cq-ref-mobile: 520;
	display: grid;
	gap: 0.3125rem;
	grid-template-columns: 7.125rem 1fr;
}

.recruit__condition-label {
	border-bottom: 1px solid var(--text-black);
	font-size: 0.875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.17em;
	padding-block: 1.5625rem;
}

.recruit__condition-item:first-child .recruit__condition-label {
	border-top: 1px solid var(--text-black);
}

.recruit__condition-detail {
	border-bottom: 1px solid rgba(153, 153, 153, 0.7019607843);
	font-size: 0.9375rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.14em;
	padding-block: 1.5625rem;
	padding-left: 0.625rem;
}

.recruit__condition-item:first-child .recruit__condition-detail {
	border-top: 1px solid rgba(153, 153, 153, 0.7019607843);
}

.recruit__inquiry-text {
	font-size: 1.125rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	line-height: 1.95;
	margin-top: 3.125rem;
}

.mv {
	background-color: #000;
	height: 100vh;
	margin-top: 3.4375rem;
	max-height: 27.5rem;
	overflow: hidden;
	position: relative;
	width: 100%;
}

/* 共通レイヤー（動画 / スライド） */

.mv__layer {
	height: 100%;
	inset: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	transition: opacity 1.8s ease-in-out;
	width: 100%;
}

/* 表示中レイヤー */

.mv__layer.is-active {
	opacity: 1;
	pointer-events: auto;
}

/* =======================================
 * 動画
 * ======================================= */

.mv__video-wrap {
	position: relative;
}

.mv__video-wrap video {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* =======================================
 * 動画上のテキストオーバーレイ
 * ======================================= */

.mv__video-text {
	left: 50%;
	padding: 20px;
	position: absolute;
	text-align: center;
	top: 40%;
	translate: -50% -50%;
	width: 100%;
	z-index: 10;
}

.mv__video-title {
	animation: fadeInUp 0.8s ease-out 0.2s forwards;
	color: #fff;
	font-size: max(2rem, min(5vw, 4rem));
	font-size: clamp(2rem, 5vw, 4rem);
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 1rem;
	opacity: 0;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
	transform: translateY(30px);
}

.mv__video-subtitle {
	animation: fadeInUp 0.9s ease-out 0.4s forwards;
	color: #fff;
	font-size: max(1rem, min(2.5vw, 1.5rem));
	font-size: clamp(1rem, 2.5vw, 1.5rem);
	font-weight: 400;
	line-height: 1.5;
	opacity: 0;
	text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
	transform: translateY(30px);
}

/* モバイル対応 */

/* =======================================
 * スライド（Swiper）
 * ======================================= */

.mv__slider-wrap {
	display: flex;
}

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

.swiper-slide {
	align-items: center;
	display: flex;
	height: 100%;
	justify-content: center;
	overflow: hidden;
	position: relative;
	width: 100%;
}

.swiper-slide picture,
.swiper-slide img {
	-o-object-fit: cover;
	display: block;
	height: 100%;
	object-fit: cover;
	width: 100%;
}

/* スライド上のテキストオーバーレイ */

.mv__slide-text {
	display: flex;
	flex-direction: column;
	opacity: 0;
	position: absolute;
	top: 50%;
	transition: opacity 1s ease;
	translate: 0 -50%;
	z-index: 10;
}

.mv__slide-text.mv__slide-text--right {
	align-items: center;
	top: 20%;
}

.mv__slide-text--center {
	left: 50%;
	top: 50%;
	translate: -50% -50%;
}

.mv__slide-title {
	color: var(--white);
	font-family: var(--font-family-third);
	font-size: 2.5rem;
	font-weight: var(--font-weight-regular);
	line-height: 1.2;
}

.swiper-slide.swiper-slide-active .mv__slide-text {
	opacity: 1;
}

.mv__slide-desc {
	color: var(--white);
	font-size: clamp(4px, 14  * 100 / var(--cq-ref-mobile) * 1cqw, 15px);
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	margin-left: 1.25rem;
	margin-top: 0.1875rem;
}

.mv__slide-copy {
	color: var(--white);
	font-size: 1.75rem;
	font-weight: var(--font-weight-medium);
	line-height: 1.6;
	text-align: center;
}

.mv__slider-wrap.is-zoom .swiper-slide.swiper-slide-active .swiper-img,
.mv__slider-wrap.is-zoom .swiper-slide.swiper-slide-duplicate-active .swiper-img,
.mv__slider-wrap.is-zoom .swiper-slide.swiper-slide-prev .swiper-img {
	animation: scale 8s linear 0s normal both;
	transform-origin: left bottom;
}

.mv-pagination {
	align-items: center;
	background-color: var(--main-bg-gray);
	display: flex;
	justify-content: center;
	padding-top: 0.625rem;
	width: 100%;
}

.mv-pagination__pagination {
	align-items: center;
	display: flex;
	gap: 0.75rem;
	justify-content: center;
}

.mv-pagination__bullet {
	aspect-ratio: 1/1;
	background-color: #007C34;
	border-radius: 50%;
	cursor: pointer;
	transition: background-color 0.25s ease;
	width: 0.6875rem;
}

.mv-pagination__bullet--active {
	background-color: #009944;
}

.top-company {
	background-color: var(--main-bg-gray);
	container-type: inline-size;
	padding-block: 3.75rem 3.125rem;
}

.top-company__content-wrap {
	display: grid;
	grid-template-areas: "label" "title" "img" "text" "btn";
	grid-template-columns: 1fr;
}

.top-company__content {
	grid-area: content;
}

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

.top-company__label-bg {
	color: var(--main-gray-opacity);
	font-family: var(--font-family-fourth);
	font-size: 3.9375rem;
	font-weight: var(--font-weight-regular);
	left: -0.625rem;
	letter-spacing: 0.08em;
	line-height: 1;
	position: absolute;
	top: -2.375rem;
	white-space: nowrap;
	z-index: 0;
}

.top-company__label {
	color: var(--main-green);
	font-family: var(--font-family-fourth);
	font-size: 1.125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.3em;
}

.top-company__title {
	font-size: 1.875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.3em;
	line-height: 1.4;
}

.top-company__text {
	font-size: 1.125rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	line-height: 2.2;
	margin-left: 0.3125rem;
	margin-top: 1.4375rem;
}

.top-company__btn {
	margin-left: 0.3125rem;
	margin-top: 1.5rem;
}

.top-company__img-wrap {
	grid-area: img;
}

.top-company__img {
	-o-object-fit: cover;
	aspect-ratio: 390/273;
	height: auto;
	object-fit: cover;
}

.top-fullwidth-img img {
	-o-object-fit: cover;
	height: auto;
	object-fit: cover;
}

.top-news {
	background-color: var(--white);
	container-type: inline-size;
	padding-block: 5rem 2.375rem;
	text-align: center;
}

.top-news__label-wrap {
	position: relative;
	text-align: center;
	width: 100%;
}

.top-news__label-bg {
	color: var(--main-gray-opacity);
	font-family: var(--font-family-fourth);
	font-size: 3.9375rem;
	font-weight: var(--font-weight-regular);
	left: 50%;
	letter-spacing: 0.08em;
	line-height: 1;
	position: absolute;
	top: -2.375rem;
	transform: translateX(-50%);
	white-space: nowrap;
	z-index: 0;
}

.top-news__label {
	color: var(--main-green);
	font-family: var(--font-family-fourth);
	font-size: 1.125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.2em;
	position: relative;
	z-index: 1;
}

.top-news__title {
	font-size: 1.875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.3em;
	line-height: 1.4;
	margin-top: 0.9375rem;
	position: relative;
	z-index: 1;
}

.top-news__list {
	display: flex;
	flex-direction: column;
	gap: 2.25rem;
	margin-top: 3.125rem;
}

.top-news__item-link {
	display: grid;
	gap: 0.625rem;
	grid-template-columns: 1fr;
}

.top-news__date {
	display: inline-block;
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	text-align: left;
	transition: color var(--duration-ui) ease;
}

.top-news__item-title {
	line-clamp: 2;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	display: -webkit-box;
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.06em;
	overflow: hidden;
	text-align: left;
	transition: color var(--duration-ui) ease;
}

.top-news__btn {
	margin-top: 3.625rem;
}

.top-news__empty {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-medium);
	margin-block: 3.125rem;
	text-align: center;
}

.top-philosophy {
	background-color: var(--main-bg-gray);
	container-type: inline-size;
	padding-block: 5.625rem 1.625rem;
}

.top-philosophy__content-wrap {
	display: grid;
	grid-template-areas: "label" "title" "img" "text" "btn";
	grid-template-columns: 1fr;
}

.top-philosophy__content {
	grid-area: content;
}

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

.top-philosophy__label-bg {
	color: var(--main-gray-opacity);
	font-family: var(--font-family-fourth);
	font-size: 3.9375rem;
	font-weight: var(--font-weight-regular);
	left: -0.625rem;
	letter-spacing: 0.08em;
	line-height: 1;
	position: absolute;
	top: -2.375rem;
	white-space: nowrap;
	z-index: 0;
}

.top-philosophy__label {
	color: var(--main-green);
	font-family: var(--font-family-fourth);
	font-size: 1.125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.3em;
}

.top-philosophy__title {
	font-size: 1.875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.36em;
	line-height: 1.4;
	margin-top: 0.9375rem;
}

.top-philosophy__text {
	font-size: 1.125rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	line-height: 1.9;
	margin-left: 0.3125rem;
	margin-top: 1.125rem;
}

.top-philosophy__btn {
	margin-left: 0.3125rem;
	margin-top: 1.25rem;
}

.top-philosophy__img-wrap {
	grid-area: img;
}

.top-philosophy__img {
	-o-object-fit: cover;
	aspect-ratio: 390/288;
	height: auto;
	object-fit: cover;
}

.top-service {
	background-color: var(--main-bg-gold);
	container-type: inline-size;
	padding-block: 3.125rem 5.375rem;
}

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

.top-service__label-bg {
	color: var(--main-gray-opacity);
	font-family: var(--font-family-fourth);
	font-size: 3.9375rem;
	font-weight: var(--font-weight-regular);
	left: -0.625rem;
	letter-spacing: 0.08em;
	line-height: 1;
	pointer-events: none;
	position: absolute;
	top: -2.375rem;
	white-space: nowrap;
	z-index: 0;
}

.top-service__label {
	color: var(--white);
	font-family: var(--font-family-fourth);
	font-size: 1.125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.3em;
}

.top-service__title {
	color: var(--white);
	font-size: 1.875rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.36em;
	line-height: 1.4;
}

.top-service__lead-text {
	color: var(--white);
	font-size: 1.5rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.24em;
	line-height: 1.8;
	margin-top: 2.25rem;
	text-align: center;
}

.top-service__first {
	display: grid;
	gap: 1.25rem;
	grid-template-areas: "img" "content";
	grid-template-columns: 1fr;
	margin-top: 2.125rem;
}

.top-service__list {
	display: flex;
	flex-direction: column;
	gap: 3.125rem;
	margin-top: 3.125rem;
}

.top-service__item {
	display: grid;
	gap: 1.25rem;
	grid-template-areas: "img" "content";
	grid-template-columns: 1fr;
}

.top-service__img-wrap {
	grid-area: img;
}

.top-service__img {
	-o-object-fit: cover;
	height: auto;
	object-fit: cover;
	width: 100%;
}

.top-service__first .top-service__img {
	aspect-ratio: 390/330;
}

.top-service__item .top-service__img {
	aspect-ratio: 392/182;
}

.top-service__content {
	grid-area: content;
}

.top-service__item-title {
	color: var(--white);
	font-family: var(--font-family-second);
	font-size: 1.375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.18em;
	line-height: 1.4;
}

.top-service__item-text {
	font-feature-settings: "palt";
	color: var(--white);
	font-family: var(--font-family-second);
	font-size: 0.9375rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.08em;
	line-height: 1.85;
	margin-top: 1.625rem;
}

.top-service__btn {
	margin-top: 2.125rem;
}

.works-category-archive {
	padding-block: 1.875rem 2.5rem;
}

.works-category-archive__tabs {
	display: flex;
	flex-wrap: wrap;
	gap: 0.9375rem 2.25rem;
	justify-content: center;
}

.works-category-archive__tab-link {
	color: #999999;
	display: block;
	font-family: var(--font-family-second);
	font-size: 1rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	position: relative;
	transition: color var(--duration-hover) ease;
}

.works-category-archive__tab-link::before {
	background-color: currentColor;
	bottom: 0;
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	transform: scale(0, 1);
	transform-origin: right top;
	transition: transform 0.5s cubic-bezier(0.6, 0, 0, 1);
	translate: -50% 0;
	width: 100%;
}

.is-current .works-category-archive__tab-link::before {
	transform: scale(1, 1);
}

.works-category-archive__tab.is-current .works-category-archive__tab-link {
	color: #006837;
}

.works-category-archive__list {
	display: grid;
	gap: 2.5rem;
	grid-template-columns: 1fr;
	margin-top: 1.875rem;
}

.works-category-archive__item {
	display: block;
}

.works-category-archive__card {
	display: block;
}

.works-category-archive__img-wrap {
	overflow: hidden;
}

.works-category-archive__img {
	-o-object-fit: cover;
	aspect-ratio: 217/174;
	display: block;
	height: 100%;
	object-fit: cover;
	transition: transform var(--duration-hover) ease;
	will-change: transform;
}

.works-category-archive__title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	display: -webkit-box;
	font-family: var(--font-family-second);
	font-size: 1rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.2em;
	line-height: 1.4;
	margin-inline: auto;
	margin-top: 0.625rem;
	overflow: hidden;
	transition: color var(--duration-hover) ease;
	width: -moz-fit-content;
	width: fit-content;
}

.works-category-archive__desc {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	display: -webkit-box;
	font-family: var(--font-family-second);
	font-size: 0.9375rem;
	font-weight: var(--font-weight-medium);
	margin-top: 0.625rem;
	overflow: hidden;
	transition: color var(--duration-hover) ease;
}

.works-category-archive__empty {
	font-family: var(--font-family-second);
	font-size: 1rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.2em;
	margin-block: 3.75rem;
	text-align: center;
}

.works {
	background-color: var(--main-bg-gray);
	container-type: inline-size;
	padding-block: 1.5625rem 1rem;
}

.works__content {
	display: grid;
	gap: 2.5rem;
	grid-template-areas: "body" "media";
	grid-template-columns: 1fr;
}

.works__media {
	grid-area: media;
}

.works__media-main {
	width: 100%;
}

.works__media-list {
	display: grid;
	gap: 0.3125rem;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 0.3125rem;
}

.works__img {
	-o-object-fit: cover;
	height: auto;
	object-fit: cover;
}

.works__media-main .works__img {
	aspect-ratio: 558/381;
}

.works__media-item .works__img {
	aspect-ratio: 286/188;
}

.works__body {
	grid-area: body;
}

.works__logo {
	border-right: 2px solid var(--main-color);
	color: var(--main-color);
	font-size: 0.875rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	line-height: 1.3;
	padding-right: 0.625rem;
	text-align: right;
}

.works__title-wrap {
	margin-top: 1.25rem;
}

.works__title-en {
	color: #B3B3B3;
	font-size: 1.0625rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.18em;
	line-height: 1.3;
}

.works__title {
	font-size: 1.6875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.15em;
	line-height: 1.3;
	margin-top: 0.3125rem;
}

.works__text {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.05em;
	line-height: 1.87;
	margin-top: 2.375rem;
	text-align: justify;
}

.works__media--column {
	display: grid;
	gap: 0.3125rem;
	grid-template-columns: repeat(2, 1fr);
}

.works__media--column .works__media-list {
	gap: 0.3125rem;
	grid-template-columns: 1fr;
	margin-top: 0;
}

.works__media--column .works__media-main .works__img {
	aspect-ratio: 284/389;
	height: 100%;
}

.works__media--column .works__media-item .works__img {
	aspect-ratio: 286/190;
	height: 100%;
}

/* ===============================================
# フェードアニメーション：IntersectionObserver＆GSAP用
=============================================== */

/* フェード */

.js-fade-in {
	opacity: 0;
	transition: opacity var(--duration-scroll) ease;
}

.js-fade-in.is-active {
	opacity: 1;
}

/* 上方向にスライド */

.js-fade-up {
	opacity: 0;
	transition: opacity var(--duration-scroll) ease, translate var(--duration-scroll) ease;
	translate: 0 20px;
}

.js-fade-up.is-active {
	opacity: 1;
	translate: 0 0;
}

/* 左方向にスライド */

.js-slide-left {
	opacity: 0;
	transition: opacity var(--duration-scroll) ease, translate var(--duration-scroll) ease;
	translate: -20px 0;
}

.js-slide-left.is-active {
	opacity: 1;
	translate: 0 0;
}

/* 下方向にスライド */

.js-fade-down {
	opacity: 0;
	transition: opacity var(--duration-scroll) ease, translate var(--duration-scroll) ease;
	translate: 0 -20px;
}

.js-fade-down.is-active {
	opacity: 1;
	translate: 0 0;
}

/* 右方向にスライド */

.js-slide-right {
	opacity: 0;
	transition: opacity var(--duration-scroll) ease, translate var(--duration-scroll) ease;
	translate: 10px 0;
}

.js-slide-right.is-active {
	opacity: 1;
	translate: 0 0;
}

.js-scaleImg {
	overflow: hidden;
}

.js-scaleImg img {
	opacity: 0;
	scale: 1.2;
	transition: scale var(--duration-emphasis) ease, opacity var(--duration-emphasis) ease;
}

.js-scaleImg.is-active img {
	opacity: 1;
	scale: 1;
}

/* クリップパス */

.js-clip-img {
	overflow: hidden;
}

.js-clip-img img {
	-webkit-clip-path: inset(0 100% 0 0);
	clip-path: inset(0 100% 0 0);
	scale: 1.3;
	transition: scale 1s var(--ease-smooth-bounce), -webkit-clip-path 1s var(--ease-smooth-bounce);
	transition: scale 1s var(--ease-smooth-bounce), clip-path 1s var(--ease-smooth-bounce);
	transition: scale 1s var(--ease-smooth-bounce), clip-path 1s var(--ease-smooth-bounce), -webkit-clip-path 1s var(--ease-smooth-bounce);
}

.js-clip-img.is-active img {
	-webkit-clip-path: inset(0 0 0 0);
	clip-path: inset(0 0 0 0);
	scale: 1;
}

:root {
	--delay-1: 0.1s;
	--delay-2: 0.2s;
	--delay-3: 0.3s;
	--delay-4: 0.4s;
	--delay-5: 0.5s;
}

.--delay-1 {
	transition-delay: var(--delay-1);
}

.--delay-2 {
	transition-delay: var(--delay-2);
}

.--delay-3 {
	transition-delay: var(--delay-3);
}

.--delay-4 {
	transition-delay: var(--delay-4);
}

.--delay-5 {
	transition-delay: var(--delay-5);
}

.breadcrumb-wrapper {
	margin-top: 4.375rem;
}

.breadcrumb {
	background-color: var(--main-bg-gold);
	padding-block: 0.3125rem;
}

.breadcrumb__list {
	align-items: center;
	display: flex;
	padding-inline: 0.625rem;
}

.breadcrumb__item {
	align-items: center;
	color: var(--white);
	display: flex;
	font-size: 0.8125rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.2em;
}

.breadcrumb__item::after {
	content: ">";
	display: inline-block;
	margin-inline: 0.3125rem;
}

.breadcrumb__item:last-child::after {
	content: none;
}

.breadcrumb__link {
	transition: opacity var(--duration-ui) ease;
}

.drawer {
	align-items: center;
	background-color: #fff;
	display: flex;
	flex-direction: column;
	height: 100vh;
	inset: 0;
	opacity: 0;
	overflow: auto;
	padding: 0.625rem 0 0 0;
	position: fixed;
	scrollbar-width: none;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	visibility: hidden;
	width: 100vw;
	z-index: var(--z-index-drawer);
}

.drawer::-webkit-scrollbar {
	display: none;
}

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

.drawer__top {
	padding-inline: 2.5rem;
}

.drawer__logo {
	width: 10.75rem;
}

.drawer__logo-img {
	-o-object-fit: contain;
	height: auto;
	object-fit: contain;
}

.drawer__content {
	overflow-y: auto;
	padding-bottom: 5rem;
	width: 100%;
}

.drawer__nav {
	height: -moz-fit-content;
	height: fit-content;
	margin: 0 auto;
	margin-top: 1.875rem;
	max-width: 500px;
	padding-inline: 2.5rem;
	width: 100%;
}

.drawer__list {
	display: flex;
	flex-direction: column;
}

.drawer__link {
	border-bottom: 1px solid var(--black);
	display: block;
	font-family: var(--font-family-second);
	font-size: 1rem;
	font-weight: 500;
	font-weight: 700;
	line-height: 1;
	padding: 1.5625rem 0;
	text-align: left;
	text-transform: uppercase;
	width: 100%;
}

.drawer__item:first-of-type {
	border-top: 1px solid var(--black);
}

.drawer__contact-btn {
	align-items: center;
	background-color: var(--main-color);
	border: 1px solid var(--main-color);
	border-radius: 0;
	color: var(--white);
	display: inline-flex;
	font-family: var(--font-family-second);
	font-size: 0.875rem;
	font-weight: var(--font-weight-medium);
	justify-content: center;
	min-width: 15rem;
	padding: 0.9375rem 0.9375rem;
	text-align: center;
}

.drawer__bottom {
	align-items: center;
	display: flex;
	flex-direction: column;
	margin-top: 1.875rem;
}

.drawer__info-hours {
	font-family: var(--font-family-second);
	font-size: 1rem;
	font-weight: var(--font-weight-medium);
	margin-top: 0.625rem;
}

.drawer__info-tel {
	font-family: var(--font-family-second);
	font-size: 1rem;
	font-weight: var(--font-weight-medium);
}

body.body-hidden {
	overflow: hidden;
}

.drawer__item-link-text {
	display: block;
	font-family: var(--font-family-second);
	font-size: 1rem;
	font-weight: 500;
	font-weight: 700;
	line-height: 1;
	padding: 1.5625rem 0;
	position: relative;
	text-align: left;
	text-transform: uppercase;
	width: 100%;
}

.drawer__item-link-text::before,
.drawer__item-link-text::after {
	background: var(--black);
	content: "";
	position: absolute;
	top: 50%;
	translate: 0 -50%;
}

.drawer__item-link-text::before {
	height: 0.0625rem;
	right: 0.5rem;
	width: 0.9375rem;
}

.drawer__item-link-text::after {
	height: 0.9375rem;
	right: 0.9375rem;
	transition: rotate 0.3s ease;
	width: 0.0625rem;
}

.drawer__item-link-text.is-open::after {
	rotate: 90deg;
}

.drawer__sub-nav-service {
	max-height: 0;
	overflow: hidden;
	transition: max-height 0.3s ease-in-out;
}

.drawer__sub-nav-service-list {
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	padding-bottom: 1.25rem;
}

.drawer__sub-nav-service-link {
	font-family: var(--font-family-second);
	font-size: 0.875rem;
	font-weight: var(--font-weight-medium);
	line-height: 1;
	width: 100%;
}

.drawer__item--border {
	border-top: 1px solid var(--black);
}

.footer-contact {
	background-color: var(--main-bg-gold);
	padding-block: 3.75rem;
	text-align: center;
}

.footer-contact__label-wrap {
	position: relative;
	text-align: center;
	width: 100%;
}

.footer-contact__label-bg {
	color: var(--main-gray-opacity);
	font-family: var(--font-family-fourth);
	font-size: 3.9375rem;
	font-weight: var(--font-weight-regular);
	left: 51%;
	letter-spacing: 0.2em;
	line-height: 1;
	position: absolute;
	top: -2.0625rem;
	transform: translateX(-50%);
	white-space: nowrap;
	z-index: 0;
}

.footer-contact__label {
	color: var(--white);
	font-family: var(--font-family-fourth);
	font-size: 1.125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.25em;
}

.footer-contact__title {
	color: var(--white);
	font-size: 1.875rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.27em;
	line-height: 1.2;
	margin-top: 1.625rem;
}

.footer-contact__content {
	align-items: center;
	display: flex;
	flex-direction: column;
	gap: 2.1875rem;
	margin-top: 2.5625rem;
}

.footer-contact__item {
	align-items: stretch;
	display: flex;
	flex-direction: column;
	gap: 0.625rem;
	width: 100%;
}

.footer-contact__item-label {
	color: var(--white);
	font-family: var(--font-family-second);
	font-size: 1.1875rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.35em;
}

.footer-contact__btn {
	align-items: center;
	background-color: var(--white);
	border: 3px solid var(--white);
	color: var(--main-green);
	display: flex;
	font-family: var(--font-family-second);
	font-size: 1.375rem;
	font-weight: var(--font-weight-regular);
	justify-content: center;
	letter-spacing: 0.25em;
	min-height: 4.625rem;
	padding: 0.625rem 1.25rem;
	width: 100%;
}

.footer-contact__tel-box {
	align-items: center;
	border: 3px solid var(--white);
	display: flex;
	flex-direction: column;
	gap: 0.3125rem;
	justify-content: center;
	min-height: 4.625rem;
	padding: 0.3125rem 1.25rem;
	text-align: center;
	width: 100%;
}

.footer-contact__tel {
	color: var(--white);
	display: block;
	font-family: var(--font-family-fourth);
	font-size: 2.0625rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.08em;
	line-height: 1;
}

.footer-contact__hours {
	color: var(--white);
	display: block;
	font-family: var(--font-family-second);
	font-size: 0.875rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.2em;
	line-height: 1;
}

.footer {
	background-color: var(--main-bg-black);
	color: var(--white);
	container-type: inline-size;
	padding-block: 1.6875rem 0.625rem;
}

.footer__main {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.footer__company {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

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

.footer__logo {
	height: auto;
	width: 75.2%;
}

.footer__logo-img {
	-o-object-fit: contain;
	height: auto;
	object-fit: contain;
}

.footer__info {
	color: var(--white);
	display: flex;
	flex-direction: column;
	font-family: var(--font-family-second);
	font-size: 0.8125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.1em;
}

.footer__tel-fax,
.footer__postal {
	letter-spacing: 0.14em;
}

.footer__nav {
	display: none;
}

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

.footer__nav-link {
	color: var(--white);
	font-family: var(--font-family-second);
	font-size: 0.8125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.17em;
	transition: opacity var(--duration-hover) ease;
}

.footer__nav-business {
	align-items: center;
	display: flex;
	gap: 1.25rem;
}

.footer__nav-business-title {
	color: var(--white);
	font-family: var(--font-family-second);
	font-size: 0.8125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.17em;
	transition: opacity var(--duration-hover) ease;
}

.footer__nav-business-list {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
}

.footer__nav-business-item {
	align-items: center;
	display: flex;
}

.footer__nav-business-item:not(:last-child)::after {
	align-self: stretch;
	background-color: var(--white);
	content: "";
	margin-inline: 0.5rem;
	min-width: 1px;
	width: 1px;
}

.footer__nav-business-link {
	color: var(--white);
	font-family: var(--font-family-second);
	font-size: 0.8125rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.17em;
	transition: opacity var(--duration-hover) ease;
}

.footer__copyright {
	color: var(--white);
	font-family: var(--font-family-second);
	font-size: 0.5625rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.2em;
	margin-top: 1.5rem;
	text-align: center;
}

.hamburger {
	display: flex;
	flex-direction: column;
	height: 1rem;
	justify-content: space-between;
	position: fixed;
	right: 1.25rem;
	top: 1.25rem;
	width: 1.5rem;
	z-index: var(--z-index-hamburger);
}

.hamburger__bar {
	background: #fff;
	height: 1px;
	transition: background 0.3s ease, rotate 0.3s ease, translate 0.3s ease;
	width: 100%;
}

.hamburger.is-open .hamburger__bar {
	background: var(--black);
}

.hamburger.is-open .hamburger__bar:nth-of-type(1) {
	rotate: 45deg;
	translate: 0 0.46875rem;
}

.hamburger.is-open .hamburger__bar:nth-of-type(2) {
	display: none;
}

.hamburger.is-open .hamburger__bar:nth-of-type(3) {
	rotate: -45deg;
	translate: 0 -0.46875rem;
}

.header {
	background-color: var(--main-bg-black);
	container-type: inline-size;
	height: 3.4375rem;
	inset: 0;
	position: fixed;
	z-index: var(--z-index-header);
}

.header__inner {
	align-items: center;
	display: flex;
	height: 100%;
	justify-content: space-between;
	padding-inline: 1.25rem;
}

.header__logo {
	display: block;
	transition: opacity var(--duration-ui) ease;
}

.header__logo-body {
	max-width: 9rem;
}

.header__logo-img {
	-o-object-fit: contain;
	height: auto;
	object-fit: contain;
}

.header__content {
	align-items: center;
	display: flex;
}

.header__nav {
	flex: 1;
}

.header__nav-list {
	align-items: center;
	display: flex;
	height: 100%;
}

.header__nav-item {
	align-items: center;
	display: flex;
	height: 100%;
}

.header__nav-item:first-child::before {
	align-self: stretch;
	background-color: var(--black);
	content: "";
	margin-right: 1.15625rem;
	min-width: 1px;
	width: 1px;
}

.header__nav-item:not(:last-child)::after {
	align-self: stretch;
	background-color: var(--black);
	content: "";
	margin-inline: 1.15625rem;
	min-width: 1px;
	width: 1px;
}

.header__nav-link {
	font-family: var(--font-family-second);
	font-size: clamp(10px, 13 * 100 / var(--cq-ref) * 1cqw, 16px);
	font-weight: var(--font-weight-medium);
}

.header__right {
	align-items: center;
	display: flex;
	flex-shrink: 0;
	gap: 0.625rem;
	margin-left: 1.875rem;
}

.header__contact-btn {
	align-items: center;
	background-color: var(--main-color);
	border: 1px solid var(--main-color);
	color: var(--white);
	display: inline-flex;
	font-family: var(--font-family-second);
	font-size: 0.875rem;
	font-weight: var(--font-weight-medium);
	justify-content: center;
	min-width: 6.5rem;
	padding: 0.25rem 0.8125rem;
	transition: background-color var(--duration-ui) ease, color var(--duration-ui) ease;
}

.header__info {
	display: flex;
	flex-direction: column;
	gap: 0.1875rem;
}

.header__info-hours {
	font-family: var(--font-family-second);
	font-size: clamp(9px, 13 * 100 / var(--cq-ref) * 1cqw, 14px);
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.1em;
	line-height: 1;
}

.header__info-tel {
	font-family: var(--font-family-second);
	font-size: clamp(9px, 13 * 100 / var(--cq-ref) * 1cqw, 14px);
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.1em;
	line-height: 1;
}

.more-btn {
	align-items: center;
	background-color: var(--main-brown);
	border: 2px solid var(--main-brown);
	color: var(--white);
	display: inline-flex;
	font-family: var(--font-family-fourth);
	font-size: 0.8125rem;
	font-style: italic;
	font-weight: var(--font-weight-semibold);
	gap: 0.625rem;
	letter-spacing: 0.15em;
	overflow: hidden;
	padding: 0.625rem 0.375rem 0.625rem 1.25rem;
	position: relative;
	transition: color var(--duration-hover) ease;
	will-change: transform;
}

.more-btn::before {
	background-color: var(--white);
	content: "";
	display: block;
	height: 100%;
	left: 0;
	position: absolute;
	top: 0;
	transform: scaleX(0);
	transform-origin: right;
	transition: transform var(--duration-hover) ease;
	width: 100%;
	will-change: transform;
}

.more-btn span {
	position: relative;
	transition: color var(--duration-hover) ease;
	z-index: 1;
}

.more-btn__arrow {
	-webkit-mask-image: url("../images/common/arrow-right.svg");
	-webkit-mask-repeat: no-repeat;
	-webkit-mask-size: contain;
	aspect-ratio: 100/9;
	background-color: currentColor;
	display: inline-block;
	mask-image: url("../images/common/arrow-right.svg");
	mask-repeat: no-repeat;
	mask-size: contain;
	position: relative;
	width: 4rem;
	z-index: 1;
}

.more-btn.more-btn--white {
	background-color: var(--main-color);
	border: 2px solid var(--white);
	color: var(--white);
	font-size: 1.125rem;
	padding: 0.75rem 0.75rem 0.75rem 1.4375rem;
}

.more-btn.more-btn--white::before {
	background-color: var(--white);
}

.more-btn.more-btn--white .more-btn__arrow {
	width: 5.375rem;
}

.more-btn.more-btn--large {
	font-size: 1.125rem;
	padding: 0.75rem 0.75rem 0.75rem 1.4375rem;
}

.more-btn.more-btn--large .more-btn__arrow {
	width: 5.375rem;
}

.pagination {
	align-items: center;
	display: flex;
	flex-wrap: wrap;
	gap: 0.625rem;
	justify-content: center;
	margin-top: 2.5rem;
}

.pagination .page-link,
.pagination .current-page {
	align-items: center;
	aspect-ratio: 1/1;
	display: flex;
	font-size: 0.9375rem;
	justify-content: center;
	min-width: 1.5rem;
	padding: 0 0.25rem;
}

.pagination .page-link {
	background-color: #E6E6E6;
	transition: background-color 0.2s, color 0.2s;
}

.pagination .page-link:hover {
	background-color: var(--main-bg-gold);
	color: var(--white);
}

.pagination .current-page {
	background-color: var(--main-bg-gold);
	color: var(--white);
}

.pagination .dots {
	font-size: 0.9375rem;
	padding: 0 0.125rem;
}

.post-single-related {
	margin-top: 3.125rem;
}

.post-single-related__title {
	border-left: 2px solid var(--text-black);
	font-family: var(--font-family-second);
	font-size: 1.25rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	line-height: 1;
	padding-left: 0.9375rem;
}

.post-single-related__list {
	display: grid;
	gap: 2.125rem;
	grid-template-columns: 1fr;
	margin-top: 2.5rem;
}

.post-single-related__item {
	min-width: 0;
	width: 100%;
}

.post-single-related__link {
	display: block;
	width: 100%;
}

.post-single-related__item-title {
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	display: -webkit-box;
	font-size: 1.125rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	margin-inline: auto;
	margin-top: 0.625rem;
	overflow: hidden;
	transition: color var(--duration-hover) ease;
	width: -moz-fit-content;
	width: fit-content;
}

.news__empty {
	font-size: 1rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	margin-top: 2.5rem;
	text-align: center;
}

.post-single-related__img-wrap {
	overflow: hidden;
}

.post-single-related__img {
	-o-object-fit: cover;
	aspect-ratio: 353/250;
	height: 100%;
	object-fit: cover;
	transition: transform var(--duration-hover) ease;
	width: 100%;
	will-change: transform;
}

.post-single {
	padding-block: 1.875rem 3.125rem;
}

.post-single__header {
	display: flex;
	flex-direction: column-reverse;
	gap: 0.625rem;
}

.post-single__date {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.2em;
}

.post-single__logo {
	border-right: 2px solid var(--main-color);
	padding-right: 0.625rem;
	text-align: right;
}

.post-single__logo-text {
	color: var(--main-color);
	font-size: 0.875rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	line-height: 1.3;
}

.post-single__title {
	border-left: 2px solid var(--text-black);
	font-size: 1.5625rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	line-height: 1.3;
	margin-top: 0.625rem;
	padding-left: 0.9375rem;
}

.post-single__category {
	font-size: 0.875rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.2em;
	margin-top: 0.625rem;
}

.post-single__mv {
	margin-top: 1.875rem;
}

.post-single__mv-img {
	-o-object-fit: cover;
	aspect-ratio: 353/250;
	height: 100%;
	object-fit: cover;
}

.post-single__content {
	margin-top: 1.875rem;
}

.post-single__content h2 {
	font-size: 1.4375rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	margin-top: 10px;
}

.post-single__content h3 {
	font-size: 1.3125rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	margin-top: 10px;
}

.post-single__content h4 {
	font-size: 1.1875rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	margin-top: 10px;
}

.post-single__content h5 {
	font-size: 1.0625rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	margin-top: 10px;
}

.post-single__content p {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-bold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	margin-top: 10px;
}

.post-single__content a {
	-webkit-text-decoration: underline currentColor;
	color: #3a2cff;
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	text-decoration: underline;
	text-decoration: underline currentColor;
	transition: opacity 0.3s ease;
}

.post-single__content a:hover {
	opacity: 0.7;
}

.post-single__content ul {
	margin-top: 10px;
}

.post-single__content ul li {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	padding-left: 1.4375rem;
	text-indent: -18px;
}

.post-single__content ul li:not(:first-of-type),
.post-single__content ol li:not(:first-of-type) {
	margin-top: 10px;
}

.post-single__content ul li::before {
	background-color: var(--text-black);
	border-radius: 50%;
	content: "";
	display: inline-block;
	height: 0.375rem;
	margin-right: 5px;
	position: relative;
	top: -2.5px;
	width: 0.375rem;
}

.post-single__content ol {
	counter-reset: number;
	margin-top: 10px;
}

.post-single__content ol li {
	font-size: 0.9375rem;
	font-weight: var(--font-weight-semibold);
	letter-spacing: 0.15em;
	line-height: 1.6;
	padding-left: 1.75rem;
	text-indent: -12px;
}

.post-single__content ol li::before {
	color: var(--text-black);
	content: counter(number) ".";
	counter-increment: number;
	display: inline-block;
	line-height: 1;
	margin-right: 2px;
}

.post-single__content figure {
	margin-top: 20px;
	padding-bottom: 10px;
}

.sub-mv {
	height: 14.375rem;
	margin-top: 3.4375rem;
	position: relative;
}

.sub-mv__img {
	-o-object-fit: cover;
	aspect-ratio: 1300/422;
	height: 100%;
	object-fit: cover;
}

.sub-mv__text-wrap {
	left: 50%;
	position: absolute;
	top: 44%;
	translate: -50% -50%;
	width: 100%;
}

.sub-mv__title {
	color: var(--white);
	font-size: 1.25rem;
	font-weight: var(--font-weight-medium);
	letter-spacing: 0.3em;
	text-align: center;
}

.sub-mv__title-en {
	color: var(--white);
	font-family: var(--font-family-fourth);
	font-size: 0.5625rem;
	font-weight: var(--font-weight-regular);
	letter-spacing: 0.3em;
	text-align: center;
	text-transform: uppercase;
}

@media (any-hover: hover) {

a:hover {
	cursor: pointer;
}

.news__link:hover .news__date,
.news__link:hover .news__item-title {
	color: var(--main-color-hover);
}

.top-news__item-link:hover .top-news__date,
.top-news__item-link:hover .top-news__item-title {
	color: var(--main-color-hover);
}

.works-category-archive__tab-link:hover {
	color: #006837;
}

.works-category-archive__tab-link:hover::before {
	transform: scale(1, 1);
	transform-origin: left top;
}

.works-category-archive__card:hover .works-category-archive__img {
	transform: scale(1.07);
}

.works-category-archive__card:hover .works-category-archive__title,
.works-category-archive__card:hover .works-category-archive__desc {
	color: var(--main-color-hover);
}

.breadcrumb__link:hover {
	opacity: 0.8;
}

.footer-contact__btn:hover {
	background-color: var(--main-bg-gold);
	color: var(--white);
}

.footer__nav-link:hover {
	opacity: 0.7;
}

.footer__nav-business-title:hover {
	opacity: 0.7;
}

.footer__nav-business-link:hover {
	opacity: 0.7;
}

.header__logo:hover {
	opacity: 0.8;
}

.header__nav-link:hover {
	color: var(--main-color-hover);
}

.header__contact-btn:hover {
	background-color: var(--white);
	color: var(--main-color);
}

.more-btn:hover {
	color: var(--main-brown);
}

.more-btn:hover::before {
	transform: scaleX(1);
	transform-origin: left;
}

.more-btn.more-btn--white:hover {
	color: var(--main-color);
}

.post-single-related__link:hover .post-single-related__img {
	transform: scale(1.07);
}

.post-single-related__link:hover .post-single-related__item-title {
	color: var(--main-color-hover);
}

}

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

.u-desktop {
	display: block;
}

.u-mobile {
	display: none;
}

html {
	font-size: 1.6vw;
}

html {
	scroll-padding-block-start: 6.5625rem;
}

.inner {
	max-width: 1060px;
	padding-left: 30px;
	padding-right: 30px;
}

.access {
	margin-top: 10.375rem;
}

.access__list {
	gap: 3.125rem;
	margin-inline: auto;
	margin-top: 5.625rem;
	max-width: 42.5rem;
}

.access__item {
	gap: 1.25rem;
}

.access__address {
	font-size: 1.0625rem;
}

.section-title__label-bg {
	font-size: 5.3125rem;
	left: -0.75rem;
	top: -3.125rem;
}

.section-title__label {
	font-size: 1.5625rem;
	letter-spacing: 0.25em;
}

.section-title__title {
	font-size: 2.5rem;
	margin-left: 0.25rem;
	margin-top: 0.3125rem;
}

.company-section {
	padding-block: 8.0625rem 5.125rem;
}

.company-section__body {
	margin-top: 2.75rem;
	padding-inline: 5.9375rem 2.0625rem;
}

.company-section__text {
	font-size: 1.0625rem;
	letter-spacing: 0.14em;
	line-height: 1.7;
}

.company {
	padding-block: 5rem 2.75rem;
}

.company__header.section-title {
	margin-inline: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.company__header .section-title__label-wrap {
	left: -5.625rem;
	position: relative;
}

.company__header .section-title__label-bg {
	left: -1.875rem;
}

.company__info-list {
	gap: 1.875rem;
	margin-top: 4.375rem;
	padding-inline: 5.625rem 5.625rem;
}

.company__info-item {
	gap: 4.25rem;
	grid-template-columns: 6.6875rem 1fr;
}

.company__info-term {
	font-size: 1.0625rem;
}

.company__info-desc {
	font-size: 1.0625rem;
}

.company__license-blocks {
	gap: 0.8125rem;
}

.company__license-block {
	font-size: 1.0625rem;
}

.history {
	margin-top: 6.25rem;
}

.history__header.section-title {
	margin-inline: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.history__header .section-title__label-wrap {
	left: -8.125rem;
	position: relative;
}

.history__header .section-title__label-bg {
	left: -0.25rem;
}

.history__info-list {
	gap: 0.875rem;
	margin-top: 5.3125rem;
	padding-inline: 5.625rem 5.625rem;
}

.history__info-item {
	gap: 2.875rem;
	grid-template-columns: max-content 1fr;
}

.history__info-term {
	font-size: 1.0625rem;
	letter-spacing: 0.1em;
}

.history__info-desc {
	font-size: 1.0625rem;
	letter-spacing: 0.15em;
}

.history__desc-blocks {
	gap: 1rem;
}

.history__desc-block {
	font-size: 1.0625rem;
}

.message {
	padding-block: 6.6875rem 4.1875rem;
}

.message__content-wrap {
	gap: 2.125rem;
	grid-template-areas: "text right";
	grid-template-columns: 480fr 333fr;
	margin-top: 2.8125rem;
	padding-inline: 6.125rem 2.9375rem;
}

.message__text {
	font-size: 1.0625rem;
	line-height: 1.64;
}

.message__signature-wrap {
	grid-area: right;
}

.message__signature-block {
	margin-left: 0.4375rem;
	margin-top: 3.1875rem;
	text-align: left;
}

.message__company-name {
	font-size: 1.875rem;
}

.message__name-row {
	gap: 0.3125rem;
	margin-top: 0.5rem;
}

.message__role {
	font-size: 1.5rem;
}

.privacy-policy {
	margin-top: 9.5rem;
	padding-bottom: 4rem;
}

.privacy-policy__text-title {
	font-size: 1.0625rem;
	letter-spacing: 0.13em;
	line-height: 2.2;
	margin-top: 5rem;
}

.privacy-policy__intro {
	font-size: 1.0625rem;
	letter-spacing: 0.13em;
	line-height: 1.8;
	margin-top: 0.75rem;
}

.privacy-policy__item-title {
	font-size: 1.0625rem;
	letter-spacing: 0.13em;
}

.privacy-policy__text {
	font-size: 1.0625rem;
	letter-spacing: 0.13em;
}

.privacy-policy__bullet-list {
	font-size: 1.0625rem;
	letter-spacing: 0.13em;
}

.privacy-policy__bullet-list li::before {
	margin-right: 0.5rem;
	margin-top: 0.75em;
	width: 0.3125rem;
}

.news {
	padding-block: 5.625rem 11.875rem;
}

.news__inner.inner {
	max-width: 930px;
}

.news__list {
	margin-top: 6.875rem;
	padding-inline: 3.125rem;
}

.news__item:first-child .news__link {
	padding-block: 0 0.625rem;
}

.news__link {
	gap: 3.75rem;
	grid-template-columns: 9rem 1fr;
	padding-block: 0.625rem;
}

.news__date {
	font-size: 1.1875rem;
	padding-left: 0.3125rem;
}

.news__item-title {
	font-size: 1.1875rem;
}

.recruit {
	padding-block: 5.9375rem 5.5rem;
}

.recruit__inner.inner {
	max-width: 53.3125rem;
}

.recruit__intro {
	font-size: 1.5625rem;
}

.recruit__conditions {
	margin-top: 5rem;
}

.recruit__condition-item {
	gap: 0.3125rem;
	grid-template-columns: 12.75rem 1fr;
}

.recruit__condition-label {
	font-size: 1.1875rem;
	padding-block: 2.125rem;
	padding-left: 0.5rem;
}

.recruit__condition-detail {
	font-size: 1.1875rem;
	letter-spacing: 0.18em;
	padding-block: 2.125rem;
}

.recruit__inquiry-text {
	font-size: 1.25rem;
	line-height: 2;
	margin-top: 6.5625rem;
	text-align: center;
}

.mv {
	height: 100vh;
	margin-top: 0;
	max-height: 59.375rem;
	min-height: 34.375rem;
}

.mv__slide-text.mv__slide-text--right {
	right: 4.1875rem;
	top: 27%;
}

.mv__slide-title {
	font-size: 4.875rem;
}

.mv__slide-desc {
	font-size: 1.25rem;
	letter-spacing: 0.24em;
	line-height: 1.7;
	margin-left: 2.5rem;
	margin-top: 0.5625rem;
}

.mv__slide-copy {
	font-size: 3rem;
}

.mv-pagination {
	padding-top: 0.625rem;
}

.mv-pagination__bullet {
	width: 0.75rem;
}

.top-company {
	padding-block: 4.5rem 5rem;
}

.top-company__inner.inner {
	max-width: calc(1200px + var(--padding-inline) * 2);
}

.top-company__content-wrap {
	align-items: center;
	gap: clamp(50px, 120 * 100 / var(--cq-ref) * 1cqw, 120px);
	grid-template-areas: "content img";
	grid-template-columns: 1fr clamp(380px, 646 * 100 / var(--cq-ref) * 1cqw, 100%);
	margin-right: calc(50% - 50cqw);
}

.top-company__content {
	margin-left: auto;
}

.top-company__label-bg {
	font-size: clamp(55px, 85 * 100 / var(--cq-ref) * 1cqw, 90px);
	left: -0.75rem;
	letter-spacing: 0.08em;
	top: -3.5625rem;
}

.top-company__label {
	font-size: clamp(14px, 25 * 100 / var(--cq-ref) * 1cqw, 28px);
	letter-spacing: 0.25em;
}

.top-company__title {
	font-size: clamp(24px, 40 * 100 / var(--cq-ref) * 1cqw, 45px);
}

.top-company__text {
	font-size: clamp(14px, 21 * 100 / var(--cq-ref) * 1cqw, 26px);
	line-height: 2;
	margin-top: clamp(20px, 39 * 100 / var(--cq-ref) * 1cqw, 39px);
}

.top-company__btn {
	margin-top: clamp(40px, 75 * 100 / var(--cq-ref) * 1cqw, 75px);
}

.top-company__img {
	aspect-ratio: 646/452;
}

.top-fullwidth-img img {
	-o-object-fit: contain;
	object-fit: contain;
}

.top-news {
	padding-block: 6.375rem 4.875rem;
}

.top-news__inner.inner {
	max-width: 1030px;
}

.top-news__label-bg {
	font-size: 5.3125rem;
	letter-spacing: 0.08em;
	top: -3.25rem;
}

.top-news__label {
	font-size: 1.5625rem;
	letter-spacing: 0.25em;
}

.top-news__title {
	font-size: 2.5rem;
	margin-top: 0.125rem;
}

.top-news__list {
	gap: 1.5rem;
	margin-top: 5rem;
}

.top-news__item-link {
	align-items: center;
	display: grid;
	gap: clamp(40px, 40px + 80 * var(--fluid-basis), 120px);
	grid-template-columns: max-content 1fr;
}

.top-news__date {
	font-size: 1.3125rem;
	letter-spacing: 0.25em;
}

.top-news__item-title {
	font-size: 1.3125rem;
}

.top-news__btn {
	margin-top: 5.625rem;
}

.top-news__empty {
	font-size: 1.3125rem;
}

.top-philosophy {
	padding-block: 5rem 2.5rem;
}

.top-philosophy__inner.inner {
	max-width: calc(1200px + var(--padding-inline) * 2);
}

.top-philosophy__content-wrap {
	align-items: center;
	gap: clamp(50px, 110 * 100 / var(--cq-ref) * 1cqw, 110px);
	grid-template-areas: "content img";
	grid-template-columns: 1fr clamp(380px, 680 * 100 / var(--cq-ref) * 1cqw, 100%);
	margin-right: calc(50% - 50cqw);
}

.top-philosophy__content {
	margin-left: auto;
	margin-top: -2.5rem;
}

.top-philosophy__label-bg {
	font-size: clamp(55px, 85 * 100 / var(--cq-ref) * 1cqw, 90px);
	left: -0.75rem;
	letter-spacing: 0.08em;
	top: -3.5625rem;
}

.top-philosophy__label {
	font-size: clamp(14px, 25 * 100 / var(--cq-ref) * 1cqw, 28px);
}

.top-philosophy__title {
	font-size: clamp(24px, 40 * 100 / var(--cq-ref) * 1cqw, 45px);
	letter-spacing: 0.3em;
	margin-top: clamp(10px, 16 * 100 / var(--cq-ref) * 1cqw, 16px);
}

.top-philosophy__text {
	font-size: clamp(14px, 21 * 100 / var(--cq-ref) * 1cqw, 26px);
	margin-top: clamp(30px, 45 * 100 / var(--cq-ref) * 1cqw, 45px);
}

.top-philosophy__btn {
	margin-top: clamp(40px, 75 * 100 / var(--cq-ref) * 1cqw, 75px);
}

.top-philosophy__img {
	aspect-ratio: 680/503;
}

.top-service {
	padding-block: 2.875rem 5.1875rem;
}

.top-service__inner.inner {
	max-width: clamp(1055px, 1055 * 100 / var(--cq-ref) * 1cqw, 1200px);
}

.top-service__label-bg {
	font-size: clamp(65px, 85 * 100 / var(--cq-ref) * 1cqw, 90px);
	left: -0.75rem;
	letter-spacing: 0.08em;
	top: -1.875rem;
}

.top-service__label {
	font-size: clamp(14px, 25 * 100 / var(--cq-ref) * 1cqw, 28px);
	letter-spacing: 0.25em;
}

.top-service__title {
	font-size: clamp(24px, 40 * 100 / var(--cq-ref) * 1cqw, 45px);
}

.top-service__lead-text {
	font-size: 2.1875rem;
	line-height: 1.3;
	margin-top: 4rem;
}

.top-service__first {
	align-items: center;
	gap: 2.1875rem;
	grid-template-areas: "img content";
	grid-template-columns: 524fr 410fr;
	margin-top: 3.75rem;
}

.top-service__list {
	gap: 4.375rem;
	margin-top: 7.1875rem;
}

.top-service__item {
	align-items: center;
	gap: 2.75rem;
	grid-template-areas: "img content";
	grid-template-columns: 558fr 528fr;
}

.top-service__item:nth-child(odd) {
	margin-left: calc(50% - 50cqw);
}

.top-service__item:nth-child(even) {
	grid-template-areas: "content img";
	grid-template-columns: 528fr 558fr;
	margin-right: calc(50% - 50cqw);
}

.top-service__first .top-service__img {
	aspect-ratio: 534/445;
}

.top-service__item .top-service__img {
	aspect-ratio: 568/265;
}

.top-service__first .top-service__content {
	margin-top: 0.9375rem;
}

.top-service__item-title {
	font-size: clamp(20px, 25* 100 / var(--cq-ref) * 1cqw, 28px);
	letter-spacing: 0.2em;
}

.top-service__item-text {
	font-size: clamp(12px, 16 * 100 / var(--cq-ref) * 1cqw, 19px);
	line-height: 1.8;
	margin-top: 1.25rem;
}

.top-service__first .top-service__btn {
	margin-right: 1.375rem;
	margin-top: 2.75rem;
	text-align: center;
}

.top-service__btn {
	margin-top: 2.125rem;
}

.works-category-archive {
	padding-block: 6.25rem 5rem;
}

.works-category-archive__tabs {
	gap: 1.25rem 4.0625rem;
}

.works-category-archive__tab-link {
	font-size: 1.125rem;
	padding-bottom: 0.125rem;
}

.works-category-archive__list {
	gap: 2.1875rem 2.5rem;
	grid-template-columns: repeat(4, 1fr);
	margin-top: 4.0625rem;
}

.works-category-archive__img {
	aspect-ratio: 217/174;
}

.works-category-archive__title {
	font-size: 1rem;
}

.works-category-archive__desc {
	font-size: 0.875rem;
}

.works-category-archive__empty {
	font-size: 1.1875rem;
	margin-block: 5rem;
}

.works {
	padding-block: 3.125rem 1.5625rem;
}

.works__inner.inner {
	max-width: clamp(720px, 1060 * 100 / var(--cq-ref) * 1cqw, 1200px);
}

.works__content {
	gap: clamp(10px, 40 * 100 / var(--cq-ref) * 1cqw, 50px);
	grid-template-areas: "media body";
	grid-template-columns: clamp(380px, 577 * 100 / var(--cq-ref) * 1cqw, 100%) 1fr;
	margin-left: calc(50% - 50cqw);
}

.works__content.works__content--reverse {
	grid-template-areas: "body media";
	grid-template-columns: 1fr clamp(380px, 577 * 100 / var(--cq-ref) * 1cqw, 100%);
	margin-left: auto;
	margin-right: calc(50% - 50cqw);
}

.works__media {
	margin-left: auto;
	max-width: 860px;
}

.works__logo {
	font-size: clamp(10px, 17 * 100 / var(--cq-ref) * 1cqw, 20px);
}

.works__title-wrap {
	margin-top: clamp(20px, 45 * 100 / var(--cq-ref) * 1cqw, 80px);
}

.works__title-en {
	font-size: clamp(14px, 29 * 100 / var(--cq-ref) * 1cqw, 32px);
}

.works.works--septictank .works__title-en {
	margin-right: calc(50% - 50cqw);
	width: -moz-fit-content;
	width: fit-content;
}

.works__title {
	font-size: clamp(21px, 35 * 100 / var(--cq-ref) * 1cqw, 38px);
	letter-spacing: 0.16em;
}

.works__text {
	font-size: clamp(8px, 17 * 100 / var(--cq-ref) * 1cqw, 20px);
	letter-spacing: 0.13em;
	line-height: 1.64;
	margin-top: clamp(25px, 40 * 100 / var(--cq-ref) * 1cqw, 60px);
}

.works.works--watertreatment .works__content {
	margin-top: 1.875rem;
}

.works.works--watertreatment .works__title-wrap {
	margin-top: 0;
}

.works__logo-wrap {
	display: grid;
	gap: clamp(10px, 40 * 100 / var(--cq-ref) * 1cqw, 50px);
	grid-template-columns: 1fr clamp(380px, 577 * 100 / var(--cq-ref) * 1cqw, 100%);
	margin-left: auto;
	margin-right: calc(50% - 50cqw);
}

.js-slide-right {
	translate: 20px 0;
}

.js-clip-img img {
	transition: scale 1.2s var(--ease-smooth-bounce), -webkit-clip-path 1.2s var(--ease-smooth-bounce);
	transition: scale 1.2s var(--ease-smooth-bounce), clip-path 1.2s var(--ease-smooth-bounce);
	transition: scale 1.2s var(--ease-smooth-bounce), clip-path 1.2s var(--ease-smooth-bounce), -webkit-clip-path 1.2s var(--ease-smooth-bounce);
}

.breadcrumb-wrapper {
	margin-top: 6.5625rem;
}

.breadcrumb {
	padding-block: 0.625rem;
}

.breadcrumb__list {
	padding-inline: 3.75rem;
}

.breadcrumb__item {
	font-size: 1.1875rem;
}

.breadcrumb__item::after {
	margin-inline: 0.625rem;
}

.drawer {
	display: none;
}

.footer-contact {
	padding-block: 3.25rem 5.4375rem;
}

.footer-contact__inner.inner {
	max-width: 915px;
}

.footer-contact__label-bg {
	font-size: 3.5625rem;
	left: 50%;
	letter-spacing: 0.25em;
	top: -1.25rem;
}

.footer-contact__label {
	font-size: 1.5625rem;
	letter-spacing: 0.3em;
}

.footer-contact__title {
	font-size: 2rem;
	line-height: 1.3;
	margin-top: 0.875rem;
}

.footer-contact__content {
	align-items: start;
	display: grid;
	gap: 2.5rem;
	grid-template-columns: repeat(2, 1fr);
	margin-top: 3.3125rem;
}

.footer-contact__item-label {
	font-size: 1.375rem;
	letter-spacing: 0.33em;
}

.footer-contact__btn {
	font-size: 1.5625rem;
	min-height: 5.1875rem;
	padding: 0.625rem 1.25rem;
}

.footer-contact__tel-box {
	gap: 0.3125rem;
	min-height: 5.1875rem;
	padding: 0.3125rem 1.25rem;
}

.footer-contact__tel {
	font-size: 2.3125rem;
}

.footer-contact__hours {
	font-size: 1rem;
}

.footer {
	padding-block: 3.125rem 1.25rem;
}

.footer__inner.inner {
	max-width: clamp(1030px, 1030 * 100 / var(--cq-ref) * 1cqw, 1200px);
	padding-inline: 1.875rem 0.9375rem;
}

.footer__main {
	align-items: flex-start;
	flex-direction: row;
	gap: 1.25rem;
	justify-content: space-between;
}

.footer__company {
	gap: 1.625rem;
}

.footer__company-head {
	align-items: center;
	flex-direction: row;
	gap: 1.25rem;
}

.footer__logo {
	width: 18.25rem;
}

.footer__info {
	font-size: 0.8125rem;
	margin-left: 0.3125rem;
}

.footer__tel-fax,
.footer__postal {
	letter-spacing: 0.17em;
}

.footer__nav {
	align-items: flex-start;
	display: flex;
	gap: 1.25rem;
	margin-top: 0.9375rem;
}

.footer__copyright {
	font-size: clamp(9px, 10 * 100 / var(--cq-ref) * 1cqw, 12px);
	letter-spacing: 0.27em;
	margin-top: 4.75rem;
}

.hamburger {
	display: none;
}

.header {
	background-color: var(--white);
	height: 6.5625rem;
}

.header.header--top {
	background-color: transparent;
	transition: background-color 0.3s ease;
	will-change: background-color;
}

.header.header--top .header__nav-link {
	color: var(--white);
	transition: color 0.3s ease;
}

.header.header--top .header__nav-item:first-child::before {
	background-color: var(--white);
	transition: background-color 0.3s ease;
}

.header.header--top .header__nav-item:not(:last-child)::after {
	background-color: var(--white);
	transition: background-color 0.3s ease;
}

.header.header--top .header__info-hours {
	color: var(--white);
	transition: color 0.3s ease;
}

.header.header--top .header__info-tel {
	color: var(--white);
	transition: color 0.3s ease;
}

.header.header--top.is-scroll {
	background-color: var(--white);
}

.header.header--top.is-scroll .header__nav-link {
	color: var(--black);
}

.header.header--top.is-scroll .header__nav-item:first-child::before {
	background-color: var(--black);
}

.header.header--top.is-scroll .header__nav-item:not(:last-child)::after {
	background-color: var(--black);
}

.header.header--top.is-scroll .header__info-hours {
	color: var(--black);
}

.header.header--top.is-scroll .header__info-tel {
	color: var(--black);
}

.header__inner {
	--fluid-basis: (100vw - 850px) / (1300 - 850);
	padding-inline: clamp(20px, 20px + 130 * var(--fluid-basis), 150px) clamp(20px, 20px + 133 * var(--fluid-basis), 153px);
}

.header__logo-body {
	max-width: 15.875rem;
}

.header__contact-btn {
	font-size: clamp(10px, 13 * 100 / var(--cq-ref) * 1cqw, 16px);
}

.more-btn {
	font-size: 1.125rem;
	padding: 0.75rem 0.75rem 0.75rem 1.4375rem;
}

.more-btn__arrow {
	width: 5.375rem;
}

.pagination {
	margin-top: 3.125rem;
}

.pagination .page-link,
.pagination .current-page {
	font-size: 1.0625rem;
	min-width: 1.875rem;
}

.pagination .dots {
	font-size: 1.0625rem;
}

.post-single-related {
	margin-top: 6.25rem;
}

.post-single-related__title {
	font-size: 1.5625rem;
}

.post-single-related__list {
	gap: 0.9375rem;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 3.75rem;
}

.post-single-related__item-title {
	font-size: 1.4375rem;
	margin-top: 0.9375rem;
}

.news__empty {
	font-size: 1.3125rem;
}

.post-single-related__img {
	aspect-ratio: 260/184;
}

.post-single {
	padding-block: 9.375rem 7.5rem;
}

.post-single__inner {
	max-width: 54.375rem;
}

.post-single__header {
	align-items: flex-end;
	flex-direction: row;
	justify-content: space-between;
}

.post-single__date {
	font-size: 1.1875rem;
	margin-bottom: 0.3125rem;
}

.post-single__logo-text {
	font-size: 1.0625rem;
}

.post-single__title {
	font-size: 2.125rem;
}

.post-single__category {
	font-size: 0.9375rem;
	margin-top: 0.9375rem;
}

.post-single__mv {
	margin-top: 1.25rem;
}

.post-single__mv-img {
	aspect-ratio: 810/572;
}

.post-single__content {
	margin-top: 2.5rem;
	padding-inline: 1.875rem;
}

.post-single__content h2 {
	font-size: 1.5625rem;
	line-height: 1.9;
}

.post-single__content h3 {
	font-size: 1.4375rem;
	line-height: 1.9;
}

.post-single__content h4 {
	font-size: 1.3125rem;
	line-height: 1.9;
}

.post-single__content h5 {
	font-size: 1.1875rem;
	line-height: 1.9;
}

.post-single__content p {
	font-size: 1.0625rem;
	line-height: 1.9;
}

.post-single__content a {
	font-size: 1.0625rem;
	line-height: 1.9;
}

.post-single__content ul li {
	font-size: 1.0625rem;
	line-height: 1.9;
}

.post-single__content ul li::before {
	height: 0.4375rem;
	margin-right: 7px;
	width: 0.4375rem;
}

.post-single__content ol li {
	font-size: 1.0625rem;
	line-height: 1.9;
	padding-left: 1.875rem;
}

.post-single__content figure {
	margin-top: 30px;
}

.sub-mv {
	height: 26.375rem;
	margin-top: 6.5625rem;
}

.sub-mv--recruit .sub-mv__text-wrap {
	top: 56%;
}

.sub-mv__text-wrap {
	top: 49%;
}

.sub-mv__title {
	font-size: 2.5rem;
}

.sub-mv__title-en {
	font-size: 0.8125rem;
}

}

@media (min-width: 768px) {

a[href*="tel:"] {
	-webkit-text-decoration: none;
	cursor: default;
	pointer-events: none;
	text-decoration: none;
}

}

@media screen and (min-width: 768px) and (any-hover: hover) {

.header.header--top .header__nav-link:hover {
	color: var(--main-color-hover);
}

.header.header--top.is-scroll .header__nav-link:hover {
	color: var(--main-color-hover);
}

}

@media (min-width: 1000px) {

html {
	font-size: 16px;
}

}

@media (min-width: 1440px) {

.news__title {
	font-size: clamp(25px, 25px + 3 * var(--fluid-basis-2), 28px);
}

.footer__logo {
	width: clamp(292px, 292 * 100 / var(--cq-ref) * 1cqw, 330px);
}

.footer__info {
	font-size: clamp(13px, 13 * 100 / var(--cq-ref) * 1cqw, 15px);
}

.footer__nav-link {
	font-size: clamp(10px, 13 * 100 / var(--cq-ref) * 1cqw, 15px);
}

.footer__nav-business-title {
	font-size: clamp(10px, 13 * 100 / var(--cq-ref) * 1cqw, 15px);
}

.footer__nav-business-link {
	font-size: clamp(10px, 13 * 100 / var(--cq-ref) * 1cqw, 15px);
}

}

@media (max-width: 768px) {

.--delay-1,
.--delay-2,
.--delay-3,
.--delay-4 {
	transition-delay: 0s;
}

}

@media (max-width: 767px) {

:root {
	--padding-inline: 15px;
	--max-width: 500px;
}

.company-section {
	overflow-x: clip;
}

.company-section.company-section--philosophy {
	padding-block: 5.1875rem 2.0625rem;
}

.company__info-term {
	line-height: 1.7;
	width: 6.875rem;
}

.company__info-desc {
	line-height: 1.7;
}

.company__license-block {
	line-height: 1.7;
}

.message__signature-wrap {
	display: contents;
}

.message__img-wrap {
	padding-inline: 2.9375rem;
}

.message__signature-block {
	margin-left: auto;
	width: -moz-fit-content;
	width: fit-content;
}

.message__ceo-name-img {
	width: 6.75rem;
}

.privacy-policy__header .section-title__label-bg {
	left: -0.0625rem;
	top: -6rem;
}

.privacy-policy__header .section-title__title {
	letter-spacing: 0.13em;
}

.recruit__inner.inner {
	padding-inline: 0.8125rem;
}

.recruit__intro {
	line-height: 1.9;
}

.recruit__condition-label {
	letter-spacing: 0.15em;
	line-height: 1.3;
	word-break: keep-all;
}

.recruit__condition-detail {
	line-height: 1.3;
	word-break: auto-phrase;
}

.recruit__inquiry-text {
	padding-inline: 1.25rem;
}

.mv__video-text {
	padding: 15px;
}

.mv__slide-text {
	width: 100%;
}

.mv__slide-text.mv__slide-text--right {
	left: 50%;
	translate: -50% -50%;
}

.top-company {
	overflow-x: clip;
}

.top-company__content {
	display: contents;
}

.top-company__label-wrap {
	grid-area: label;
	margin-left: 0.625rem;
}

.top-company__title {
	grid-area: title;
	margin-left: 0.625rem;
	margin-top: 0.375rem;
}

.top-company__text {
	grid-area: text;
}

.top-company__btn {
	grid-area: btn;
}

.top-company__img-wrap {
	margin-inline: calc(50% - 50cqw);
	margin-top: 1.625rem;
}

.top-fullwidth-img img {
	aspect-ratio: 390/305;
}

.top-philosophy {
	overflow-x: clip;
}

.top-philosophy__content {
	display: contents;
}

.top-philosophy__label-wrap {
	grid-area: label;
}

.top-philosophy__title {
	grid-area: title;
}

.top-philosophy__text {
	grid-area: text;
}

.top-philosophy__btn {
	grid-area: btn;
}

.top-philosophy__img-wrap {
	margin-inline: calc(50% - 50cqw);
	margin-top: 0.625rem;
}

.top-service {
	overflow-x: clip;
}

.top-service__title {
	margin-top: 0.75rem;
}

.top-service__img-wrap {
	margin-inline: calc(50% - 50cqw);
}

.top-service__item-title {
	margin-top: 0.375rem;
	text-align: center;
}

.top-service__btn {
	text-align: center;
}

.works-category-archive__list {
	padding-inline: 4.1875rem;
}

.works__title-en {
	text-align: center;
}

.works__title {
	text-align: center;
}

.works__logo-wrap .spacer {
	display: none;
}

.breadcrumb {
	margin-right: calc(50% - 50vw);
	overflow-x: auto;
}

.breadcrumb__item {
	white-space: nowrap;
}

.footer-contact {
	overflow-x: clip;
}

.footer__inner.inner {
	padding-inline: 1.5625rem;
}

.footer__logo {
	margin-inline: auto;
}

.footer__info {
	gap: 0.3125rem;
	padding-inline: 1.4375rem;
}

.header__content {
	display: none;
}

.post-single-related__list {
	padding-inline: 2.5rem;
}

}

@media (max-width: 375px) {

html {
	font-size: 4.2666666667vw;
}

}

@keyframes fadeInUp {

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

}

@keyframes scale {

0% {
	transform: scale(1);
}

100% {
	transform: scale(1.05);
}

}