@charset "utf-8";

/* CSS Document */
/* ----------------------------------------------------------------------------------------------------
 * Set
@media screen and (max-width: 1920px) {}
@media screen and (max-width: 1536px) {}
@media screen and (max-width: 1280px) {}
@media print, screen and (max-width: 1024px) {}
@media screen and (max-width: 560px) {}

color: rgba(245,245,245,1.00);
color: rgba(224,224,224,1.00);
color: rgba(158,158,158,1.00);
---------------------------------------------------------------------------------------------------- */
/* ----------------------------------------------------------------------------------------------------
 * Common
---------------------------------------------------------------------------------------------------- */
html,
body {
	width: 100%;
	text-align: center;
	color: rgba(33, 33, 33, 1.00);
	font-family: "Lato", "Zen Kaku Gothic New", '游ゴシック体', YuGothic, '游ゴシック Medium', 'Yu Gothic Medium', '游ゴシック', 'Yu Gothic', sans-serif;
	font-size: 17px;
	line-height: 2.0;
	letter-spacing: 0.02em;
	overflow-wrap: break-word;
}

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	font-family: inherit;
}

body.loadAct * {
	transition: none !important;
}

.noselect,
.noselect * {
	-ms-user-select: none;
	-moz-user-select: -moz-none;
	-khtml-user-select: none;
	-webkit-user-select: none;
	user-select: none;
}

h1,
h2,
h3,
h4,
th,
small {
	font-weight: normal;
	font-size: 100%;
}

a,
button {
	outline: none;
	transition: all 0.08s linear;
}

*:focus {
	outline: none;
}

a {
	color: rgba(33, 33, 33, 1.00);
}

a:not(.not):hover {
	color: rgba(244, 67, 54, 1.00);
}

a:not(.not) .photo,
a:not(.not) .image,
a:not(.not) img {
	transition: all 0.08s linear;
}

a:not(.not):hover .photo,
a:not(.not):hover .image,
a:not(.not):hover img {
	filter: brightness(64%);
}

ol,
ul {
	list-style: none;
}

img,
svg {
	max-width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	vertical-align: middle;
}

header,
footer,
div,
ul,
li,
h1,
h2,
h3,
nav,
button,
blockquote,
dt,
dd,
figure {
	position: relative;
}

p,
a,
span {
	position: relative;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
}

.clear::after {
	content: '';
	display: block;
	clear: both;
}

.none {
	display: none;
}

p {
	margin-bottom: 1.6em;
}

p:not(.not):last-child,
ul:not(.not):last-child,
ol:not(.not):last-child,
li:not(.not):last-child,
figure:not(.not):last-child,
table:not(.not):last-child,
blockquote:not(.not):last-child {
	margin-bottom: 0 !important;
}

mark {
	background-color: rgba(255, 238, 88, 1.00);
}

label {
	display: inline-block;
}

sup {
	font-weight: normal;
	font-size: 0.62rem;
	padding: 0 0.2em;
	vertical-align: middle;
}

strong,
.text-bold {
	font-weight: bold;
}

cite {
	font-style: normal;
}

.text-normal {
	font-weight: normal;
}

.text-underline {
	text-decoration: underline;
}

.text-line {
	transform: scale(2.4, 1);
	display: inline-block;
	transform-origin: left center;
	padding-right: 1.4em;
}

.text-small {
	font-size: 0.89em;
}

.text-xsmall {
	font-size: 0.79em;
}

.text-xxsmall {
	font-size: 0.70em;
}

.text-large {
	font-size: 1.13em;
}

.text-xlarge {
	font-size: 1.27em;
}

.text-xxlarge {
	font-size: 1.42em;
}

.text-gray {
	color: rgba(158, 158, 158, 1.00);
}

.text-red {
	color: rgba(244, 67, 54, 1.00);
}

.text-white {
	color: rgba(255, 255, 255, 1.00);
}

.text-vertical {
	writing-mode: vertical-rl;
	text-align: left;
}

.in-center {
	text-align: center !important;
}

.in-right {
	text-align: right !important;
}

.in-left {
	text-align: left !important;
}

.pos-center {
	display: flex;
}

.pos-center>* {
	margin: auto;
}

.nowrap {
	white-space: nowrap;
}

.block {
	display: block;
}

.inline-block {
	display: inline-block;
}

.inline {
	display: inline;
}

.block-note {
	padding-left: 1em;
	text-indent: -1em;
}

.block-note::before {
	content: '※';
}

.bg-white {
	background-color: rgba(255, 255, 255, 1.00);
}

.bg-gray {
	background-color: rgba(245, 245, 245, 1.00);
}

.margin-bt0 {
	margin-bottom: 0 !important;
}

.margin-bt02 {
	margin-bottom: 0.2em !important;
}

.margin-bt04 {
	margin-bottom: 0.4em !important;
}

.margin-bt06 {
	margin-bottom: 0.6em !important;
}

.margin-bt08 {
	margin-bottom: 0.8em !important;
}

.margin-bt10 {
	margin-bottom: 1.0em !important;
}

.margin-bt12 {
	margin-bottom: 1.2em !important;
}

.margin-bt14 {
	margin-bottom: 1.4em !important;
}

.margin-bt16 {
	margin-bottom: 1.6em !important;
}

.margin-bt18 {
	margin-bottom: 1.8em !important;
}

.margin-bt20 {
	margin-bottom: 2.0em !important;
}

.list-disc {
	list-style: disc;
	margin-left: 1.6em;
	margin-bottom: 1.6em;
}

.list-decimal {
	list-style: decimal;
	margin-left: 1.8em;
	margin-bottom: 1.6em;
}

input[type="text"],
input[type="number"],
input[type="email"],
input[type="password"],
textarea {
	border: 1px solid rgba(33, 33, 33, 1.00) !important;
	background-color: rgba(255, 255, 255, 1.00) !important;
	line-height: 1.8 !important;
	border-radius: 0.24em !important;
	color: rgba(33, 33, 33, 1.00) !important;
	padding-left: 0.6em !important;
	padding-right: 0.6em !important;
	padding-top: 0.4em !important;
	padding-bottom: 0.4em !important;
	max-width: 100% !important;
	transition: all 0.08s linear !important;
	display: inline-block !important;
}

textarea {
	width: 100% !important;
	height: 12.0em !important;
}

input[type="text"]:focus,
input[type="number"]:focus,
input[type="email"]:focus,
textarea:focus {
	box-shadow: inset 0px 0px 4px rgba(0, 0, 0, 0.16);
	background-color: #FAFAFA !important;
}

select {
	border: 1px solid rgba(33, 33, 33, 1.00) !important;
	background-color: rgba(255, 255, 255, 1.00) !important;
	line-height: 1.8 !important;
	border-radius: 0.24em !important;
	color: rgba(33, 33, 33, 1.00) !important;
	padding-left: 0.6em !important;
	padding-right: 0.6em !important;
	padding-top: 0.4em !important;
	padding-bottom: 0.4em !important;
	max-width: 100% !important;
	transition: all 0.08s linear !important;
	display: inline-block !important;
}

.pd {
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	padding-left: 128px;
	padding-right: 128px;
	width: 100%;
	max-width: 1536px;
}

.pd.narrow {
	max-width: 1280px;
}

.pd.wide {
	max-width: 1920px;
}

.pd.full {
	max-width: none;
}

.show-tb,
.show-sp {
	display: none !important;
	/* default inline */
}

.hide-tb,
.hide-sp {}

@media screen and (max-width: 1920px) {

	html,
	body {
		font-size: 16px;
	}
}

@media screen and (max-width: 1280px) {
	.pd {
		padding-left: 80px;
		padding-right: 80px;
	}
}

@media print,
screen and (max-width: 1024px) {
	.pd {
		padding-left: 9.6vw;
		padding-right: 9.6vw;
	}

	.show-tb {
		display: inline !important;
	}

	.show-tb.block {
		display: block !important;
	}

	.show-tb.inline-block {
		display: inline-block !important;
	}

	.hide-tb {
		display: none;
	}
}

@media screen and (max-width: 560px) {

	html,
	body {
		font-size: 15px;
	}

	.show-sp {
		display: inline !important;
	}

	.show-sp.block {
		display: block !important;
	}

	.show-sp.inline-block {
		display: inline-block !important;
	}

	.hide-sp {
		display: none;
	}
}

#wrap {
	width: 100%;
	overflow: hidden;
	display: grid;
	grid-template-columns: 100%;
	grid-template-rows: auto 1fr auto;
	min-height: 100vh;
	min-height: 100lvh;
	padding-top: 8.0em;
}


@media screen and (max-width: 1920px) {}

@media screen and (max-width: 1536px) {
	#wrap {
		padding-top: 7.6em;
	}

}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	#wrap {
		padding-top: 6.8em;
	}

}

@media screen and (max-width: 560px) {
	#wrap {
		padding-top: 6.0em;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Common (add)
---------------------------------------------------------------------------------------------------- */
strong,
.text-bold {
	font-weight: 600;
}

.mont {
	font-family: "Montserrat", sans-serif;
}

/* ----------------------------------------------------------------------------------------------------
 * Header
---------------------------------------------------------------------------------------------------- */
header {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: end;
	z-index: 10000;
	padding-top: 3.2em;
	padding-left: 64px;
	padding-right: 80px;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	background-color: #ffffff;
	padding-bottom: 1.6em;
}

header .logo img {
	height: 3.2em;
	width: auto;
}

header ul {
	display: flex;
	justify-content: flex-end;
	gap: 4.0em;
	font-weight: 500;
	font-size: 1.00em;
}

header ul a {
	text-decoration: none;
	display: block;
	color: rgba(33, 33, 33, 1.00) !important;
}

header ul a::after {
	content: '';
	position: absolute;
	display: block;
	left: 0;
	top: 100%;
	width: 0%;
	border-bottom: 1px solid rgba(33, 33, 33, 1.00);
	transition: all 0.12s ease;
}

header ul a:hover::after,
header ul li.common a::after {
	width: 100%;
}

header .toggle {
	display: none;
}

@media screen and (max-width: 1920px) {}

@media screen and (max-width: 1536px) {
	header .logo img {
		height: 2.8em;
	}

	header ul {
		font-size: 0.89em;
	}
}

@media screen and (max-width: 1280px) {
	header {
		padding-left: 48px;
		padding-right: 64px;
	}

	header ul {
		gap: 2.4em;
	}


}

@media print,
screen and (max-width: 1024px) {
	body.show-menu {
		overflow: hidden;
	}

	header {
		padding-top: 2.4em;
		padding-left: 36px;
	}

	header nav {
		display: flex;
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		height: 100lvh;
		opacity: 0;
		transition: all 0.32s ease;
		visibility: hidden;
	}

	body.show-menu header nav {
		opacity: 1;
		visibility: visible;
		background-color: rgba(0, 0, 0, 0.88);
	}

	header nav ul {
		margin: auto;
		display: grid;
		font-size: 1.13em;
		gap: 2.0em;
		text-align: center;
	}

	header ul a {
		color: rgba(255, 255, 255, 1.00) !important;
		letter-spacing: 0.08em;
	}

	header .toggle {
		display: block;
		position: fixed;
		right: 2.0em;
		top: 1.8em;
		width: 3.2em;
		height: 3.2em;
		border-radius: 100vh;
		background-color: rgba(33, 33, 33, 1.00);
		cursor: pointer;
		z-index: 2;
	}

	header .toggle>span {
		display: block;
		left: 24%;
		right: 24%;
		border-bottom: 2px solid rgba(255, 255, 255, 1.00);
		position: absolute;
		transition: all 0.32s ease;
	}

	header .toggle>span.line1 {
		top: 32%;
	}

	header .toggle>span.line2 {
		top: 50%;
		transform: translate(0, -50%);
	}

	header .toggle>span.line3 {
		bottom: 32%;
	}

	body.show-menu header .toggle>span.line1 {
		top: 48%;
		transform: rotate(225deg);
	}

	body.show-menu header .toggle>span.line2 {
		left: 50%;
		right: 50%;
	}

	body.show-menu header .toggle>span.line3 {
		bottom: 48%;
		transform: rotate(-225deg);
	}
}

@media screen and (max-width: 560px) {
	header {
		padding-top: 2.0em;
		padding-left: 24px;
	}

	header .logo img {
		height: 2.4em;
	}

	header .toggle {
		right: 1.2em;
		top: 1.4em;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Footer
---------------------------------------------------------------------------------------------------- */
footer>.inner {
	background-color: rgba(33, 33, 33, 1.00);
	color: rgba(255, 255, 255, 1.00);
	font-size: 0.89em;
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: end;
	padding-top: 1.6em;
	padding-bottom: 1.6em;
	padding-left: 64px;
	padding-right: 64px;
	gap: 2.4em;
}

footer>.inner a {
	color: rgba(255, 255, 255, 1.00);
	text-decoration: none;
}

footer>.inner ul {
	display: flex;
	flex-wrap: wrap;
	gap: 2.4em;
}

footer .aioseo-breadcrumbs {
	font-size: 0.79em;
	color: rgba(158, 158, 158, 1.00);
	display: flex;
	justify-content: end;
	padding-bottom: 1.2em;
	gap: 0.6em;
	line-height: 1.6;
	padding-left: 64px;
	padding-right: 64px;
}

footer .aioseo-breadcrumbs a {
	color: rgba(158, 158, 158, 1.00);
	text-decoration: none;
}

body#home footer .aioseo-breadcrumbs {
	display: none;
}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	footer>.inner {
		gap: 1.6em;
		padding-left: 2.4em;
		padding-right: 2.4em;
	}

	footer>.inner ul {
		gap: 0.6em 1.6em;
	}

	footer .aioseo-breadcrumbs {
		padding-left: 2.4em;
		padding-right: 2.4em;
	}
}

@media screen and (max-width: 560px) {

	footer>.inner {
		font-size: 0.79em;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Loading
---------------------------------------------------------------------------------------------------- */
body.load {
	overflow: hidden
}

body.load #loading {
	display: flex;
	position: fixed;
	z-index: 100000;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	height: 100lvh;
	background-color: rgba(255, 255, 255, 1.00);
}

body.load #loading .icon {
	width: 80px;
	aspect-ratio: 1 / 1;
	background-color: rgba(0, 0, 0, 1.00);
	margin: auto;
	background: conic-gradient(rgba(33, 33, 33, 0.0), rgba(33, 33, 33, 1.0));
	border-radius: 100vh;
	animation: 1.2s linear infinite loading;
}

@keyframes loading {
	0% {
		transform: rotate(0deg);
	}

	100% {
		transform: rotate(360deg);
	}
}

body.load #loading .icon::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transform: scale(0.92);
	background-color: rgba(255, 255, 255, 1.00);
	border-radius: 100vh;
}

@media screen and (max-width: 1536px) {
	body.load #loading .icon {
		width: 64px;
	}
}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {}

@media screen and (max-width: 560px) {
	body.load #loading .icon {
		width: 48px;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Page wrap
---------------------------------------------------------------------------------------------------- */
.wrap-page {
	margin-top: 9.6em;
	margin-bottom: 9.6em;
}

.wrap-title>.inner {
	display: inline-block;
	color: rgba(255, 255, 255, 1.00);
	background-color: rgba(33, 33, 33, 1.00);
	padding-left: 80px;
	padding-right: 0.8em;
	font-size: 1.42em;
	transform: translate(-128px, 0);
	letter-spacing: 0.08em;
	z-index: 1;
	font-weight: 500;
}

.wrap-contents {
	margin-top: 8.0em;
}

@media screen and (max-width: 1280px) {
	.wrap-title>.inner {
		padding-left: 64px;
		transform: translate(-80px, 0);
	}
}

@media print,
screen and (max-width: 1024px) {
	.wrap-page {
		margin-top: 8.0em;
		margin-bottom: 8.0em;
	}

	.wrap-title>.inner {
		padding-left: 6.4vw;
		transform: translate(-9.6vw, 0);
	}

	.wrap-contents {
		margin-top: 5.4em;
	}
}

@media screen and (max-width: 560px) {
	.wrap-page {
		margin-top: 6.4em;
		margin-bottom: 6.4em;
	}

	.wrap-title>.inner {
		font-size: 1.27em;
	}

	.wrap-contents {
		margin-top: 4.8em;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Page
---------------------------------------------------------------------------------------------------- */

.list-tab {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	text-align: center;
	margin-bottom: 7.2em;
}

.list-tab::before,
.list-tab::after {
	content: '';
	display: block;
	width: 100vw;
	height: 0;
	border-bottom: 1px solid #212121;
	position: absolute;
	bottom: 0;
}

.list-tab::before {
	left: 100%;
}

.list-tab::after {
	right: 100%;
}

.list-tab .tab {
	cursor: pointer;
	font-size: 1.27em;
	letter-spacing: 0.08em;
	line-height: 3.2em;
	border-bottom: 1px solid rgba(33, 33, 33, 1);
	border-top: 1px solid rgba(33, 33, 33, 0);
	border-left: 1px solid rgba(33, 33, 33, 0);
	border-right: 1px solid rgba(33, 33, 33, 0);
	background-color: #f7f7f7;
	transition: all 0.08s ease;
	padding-left: 0.8em;
	padding-right: 0.8em;

}

.list-tab .tab.current {
	border-bottom: 1px solid rgba(33, 33, 33, 0);
	border-top: 1px solid rgba(33, 33, 33, 1);
	border-left: 1px solid rgba(33, 33, 33, 1);
	border-right: 1px solid rgba(33, 33, 33, 1);
	background-color: #ffffff;
	cursor: auto;
}

section.tab-contents:not(.current) {
	display: none;
}

.title-page {
	font-size: 1.60em;
	font-weight: 500;
	margin-bottom: 0.2em;
	margin-top: 1.6em;

}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	.list-tab {
		margin-bottom: 6.4em;
	}

	.list-tab .tab {
		font-size: 1.13em;
	}

	.title-page {
		font-size: 1.42em;

	}

}

@media screen and (max-width: 560px) {
	.list-tab {
		margin-bottom: 5.6em;
	}

	.list-tab .tab {
		font-size: 1.00em;
	}

	.title-page {
		font-size: 1.27em;

	}

}


/* ----------------------------------------------------------------------------------------------------
 * About
---------------------------------------------------------------------------------------------------- */
.block-about-message {
	padding-top: 8.0em;
	padding-bottom: 8.0em;
	overflow: hidden;
	margin-top: -1.4em;
}





.block-about-message .photo {
	margin-top: 4.0em;
	width: 100%;
	overflow: hidden;
}

.block-about-message .photo+.photo {
	margin-top: 0;
}

.block-about-message .photo img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
}

.block-about-message .photo .swiper-wrapper {
	transition-timing-function: linear;
}


.block-about-message video {
	position: absolute;
	width: 100%;
	height: auto;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.block-about-message.vertical video {
	width: auto;
	height: 100%;
}

.block-about-message figure {
	width: 6.4em;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 2.0em;
}

.block-about-message h2 {
	margin-bottom: 0.56em;
	letter-spacing: 0.06em;
	font-family: "Shippori Mincho", serif;
	text-align: center;
	font-size: min(3.65em, 8.0vw);
	padding-left: 0.4em;
	white-space: nowrap;
}

.block-about-message p {
	font-weight: 500;
	margin-bottom: 2.0em;
	text-align: center;
}

.block-about-contents {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 6.4em 4.8em;
}

.block-about-contents h2 {
	font-size: 1.80em;
	font-weight: 500;
	line-height: 1.5;
}

.block-about-contents h2 br {
	display: none;
}

.block-about-contents h3>.inner {
	display: inline-block;
	border-bottom: 2px dotted rgba(0, 0, 0, 1.00);
	letter-spacing: 0.06em;
	font-size: 1.27em;
	font-weight: 500;
	margin-bottom: 0.5em;
}

.block-about-contents .contents {
	padding-top: 0.8em;
}

.list-about-company {
	display: grid;
	grid-template-columns: auto 1fr;
	margin-bottom: 2.8em;
	border-top: 1px dotted rgba(33, 33, 33, 1.00);
}

.list-about-company dt {
	font-weight: 500;
	padding-right: 1.6em;
}

.list-about-company dt,
.list-about-company dd {
	border-bottom: 1px dotted rgba(33, 33, 33, 1.00);
	padding-top: 1.0em;
	padding-bottom: 1.0em;
}

.block-map {
	display: block;
	aspect-ratio: 2 / 1;
	width: 100%;
	height: auto;
}

@media screen and (max-width: 1280px) {
	.block-about-contents h2 br {
		display: inline;
	}


}

@media print,
screen and (max-width: 1024px) {
	.block-about-contents {
		column-gap: 6.4vw;
	}

	.block-about-contents h2 {
		font-size: 1.60em;
	}
}

@media screen and (max-width: 560px) {
	.block-about-message {
		padding-top: 6.4em;
		padding-bottom: 6.4em;
	}

	.block-about-message figure {
		width: 5.6em;
	}

	.block-about-message h2 {
		font-size: 2.03em;
	}

	.block-about-contents h2 br {
		display: none;
	}

	.block-about-message p {
		text-align: left;
	}

	.block-about-message p .inline-block {
		display: inline;
	}

	.block-about-contents {
		grid-template-columns: 1fr;
		gap: 1.6em;
	}

	.block-about-contents .contents {
		padding-top: 0;
		padding-left: 4.8vw;
		padding-bottom: 3.2em;
	}

	.block-about-contents .contents:last-child {
		padding-bottom: 0;
	}

	.block-map {
		aspect-ratio: 1 / 1;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Service
---------------------------------------------------------------------------------------------------- */
.block-service-lead {
	padding-top: 6.4em;
	padding-bottom: 6.4em;
	text-align: center;
	margin-top: -1.4em;
	background-image: url(../images/service-bg.jpg);
	box-shadow: 0 0 80px rgba(0, 0, 0, 0.06) inset;
}



.block-service-lead figure {
	width: 6.4em;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 2.0em;
}

.block-service-lead p {
	font-size: 1.13em;
	font-weight: 500;
	line-height: 2.2;
	margin-bottom: 2.0em;
}

.block-service {
	display: grid;
	grid-template-columns: auto 1fr;
	gap: 6.4em 4.8em;
}

.block-service h2 {
	border: 1px solid rgba(33, 33, 33, 1.00);
	padding: 2.0em 1.6em;
	overflow: hidden;
}

.block-service h2::before {
	content: '';
	display: block;
	width: 2.0em;
	height: 2.0em;
	background-color: rgba(33, 33, 33, 1.00);
	position: absolute;
	top: -1.4em;
	left: -1.4em;
	transform: rotate(45deg);
}

.block-service h2>span {
	display: block;
}

.block-service h2>.en {
	font-size: 1.60em;
	letter-spacing: 0.08em;
	line-height: 1.6em;
}

.block-service h2>.ja {
	font-weight: 500;
	font-size: 0.89em;
}

.block-service>.contents {
	padding: 1.6em 0;
}

.list-service {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	gap: 2.4em 1.6em;
	margin-top: 2.4em;
	line-height: 1.8;
}

.list-service a {
	display: block;
	text-decoration: none;
}

.list-service a .image {
	aspect-ratio: 1 / 1;
	border-radius: 0.48em;
	margin-bottom: 0.8em;
	overflow: hidden;
	border: 3px solid #F5F5F5;
}

.list-service a .image>span {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: all 0.32s ease;
}

.list-service a:hover .image>span {
	transform: scale(1.12);
}

.list-service a .title {
	font-size: 0.89em;
	font-weight: 500;
	line-height: 1.7;
}

@media screen and (max-width: 1280px) {
	.list-service {
		grid-template-columns: 1fr 1fr 1fr;
	}



}

@media print,
screen and (max-width: 1024px) {
	.block-service {
		gap: 2.4em;
		grid-template-columns: 1fr;
	}

	.block-service .contents {
		padding-left: 1.8em;
		padding-right: 1.8em;
		padding-bottom: 3.2em;
		padding-top: 0;
	}

	.block-service .contents:last-child {
		padding-bottom: 0;
	}
}

@media screen and (max-width: 560px) {

	.block-service-lead {
		padding-bottom: 5.6em;
	}


	.block-service .contents {
		padding-left: 0;
		padding-right: 0;
	}


	.block-service-lead figure {
		width: 5.6em;
	}

	.block-service-lead p {
		font-size: 1.00em;
		text-align: left;
	}

	.block-service-lead p .inline-block {
		display: inline;
	}

	.block-service h2>.en {
		font-size: 1.42em;
	}

	.list-service {
		grid-template-columns: 1fr 1fr;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Works
---------------------------------------------------------------------------------------------------- */
.title-taxonomy {
	text-align: center;
	margin-bottom: 4.0em;
	background-color: #F5F5F5;
	padding: 0.4em 0.4em 0.6em;
	font-weight: 500;
}

.title-taxonomy .name {
	font-weight: bold;
	font-size: 1.27em;
	padding-left: 0.1em;
}

.block-works {
	display: grid;
	grid-template-columns: 16em 1fr;
	gap: 120px;
}

.block-works .sub .search {
	display: none;
}

.block-works .sub .title {
	border-bottom: 1px solid rgba(33, 33, 33, 1.00);
	margin-bottom: 1.0em;
	padding-bottom: 0.2em;
	font-size: 1.13em;
	font-weight: 500;
}

.block-works .sub .title a {
	font-size: 0.79em;
	font-weight: normal;
	float: right;
	transform: translate(0, 0.3em);
	font-weight: 500;
}

.block-works .sub a {
	text-decoration: none;
	display: block;
}

.block-works .sub .category {
	display: grid;
	font-weight: 700;
	margin-bottom: 4.0em;
	gap: 0.4em 1.2em;
	font-size: 1.13em;
}

.block-works .sub .keyword {
	display: flex;
	flex-wrap: wrap;
	font-size: 0.89em;
	gap: 0.4em 1.0em;
}

.block-works .sub .keyword a::before {
	content: '#';
}

.list-works {
	display: grid;
	grid-template-columns: 1fr 1fr 1fr;
	gap: 6.4em 4.8em;
	line-height: 1.8;
}

.list-works a {
	display: block;
	text-decoration: none;
}

.list-works a.entry .category {
	writing-mode: vertical-rl;
	z-index: 2;
	position: absolute;
	top: 0;
	left: 0;
	background-color: rgba(255, 255, 255, 1.00);
	font-weight: 700;
	font-size: 1.60em;
	white-space: nowrap;
	padding-bottom: 0.6em;
	padding-top: 0.4em;
	padding-right: 0.2em;
	letter-spacing: 0.08em;
	color: rgba(33, 33, 33, 1.00);
	border-bottom: 1px solid #212121;
	border-right: 1px solid #212121;
}

.list-works a.entry {
	z-index: 1;
}

.list-works a.entry .image {
	aspect-ratio: 1 / 1;
	border-radius: 0.80em;
	margin-bottom: 0.6em;
	overflow: hidden;
	margin-bottom: 1.0em;
}

.list-works a.entry .image>span {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: all 0.32s ease;
}

.list-works a.entry:hover .image>span {
	transform: scale(1.08);
}

.list-works a.entry .title {
	font-weight: 700;
	font-size: 1.13em;
	line-height: 1.7;
}

.list-works a.entry .title .date {
	font-size: 0.89em;
}

.list-works .keyword {
	display: flex;
	flex-wrap: wrap;
	font-size: 0.79em;
	gap: 0.2em 0.8em;
	margin-top: 0.6em;
}

.list-works .keyword a::before {
	content: '#';
}

@media screen and (max-width: 1536px) {
	.block-works {
		grid-template-columns: 14em 1fr;
		gap: 80px;
	}

	.list-works {
		gap: 4.8em 4.0em;
	}
}

@media screen and (max-width: 1280px) {
	.block-works {
		grid-template-columns: 12em 1fr;
		gap: 64px;
	}

	.list-works {
		grid-template-columns: 1fr 1fr;
	}
}

@media print,
screen and (max-width: 1024px) {
	.block-works {
		grid-template-columns: 1fr;
		gap: 4.8em;
	}

	.block-works .sub .search {
		display: block;
		border: 1px solid rgba(33, 33, 33, 1.00);
		text-align: center;
		border-radius: 0.24em;
		cursor: pointer;
		padding: 0.2em;
	}

	.block-works .sub .search .label {
		display: inline-block;
		font-size: 0.89em;
		line-height: 1.3;
		background-image: url(../images/icon-search.svg);
		background-size: contain;
		background-position: left center;
		padding-left: 1.6em;
	}

	.block-works .sub>.inner {
		display: none;
		padding-top: 2.4em;
	}

	.block-works .sub .category {
		margin-bottom: 2.4em;
		display: flex;
		flex-wrap: wrap;
	}

	.list-works {
		column-gap: 6.4vw;
	}
}

@media screen and (max-width: 560px) {
	.title-taxonomy {
		font-size: 0.89em;
	}

	.block-works {
		gap: 4.0em;
	}

	.list-works {
		grid-template-columns: 1fr;
	}
}

.block-works-entry {
	display: grid;
	grid-template-columns: auto 1fr;
	align-items: start;
	column-gap: 3.2em;
}

.block-works-entry>.category {
	writing-mode: vertical-lr;
	font-weight: 700;
	font-size: 2.89em;
	white-space: nowrap;
	letter-spacing: 0.12em;
	padding-top: 0.8em;
	padding-bottom: 0.6em;
	line-height: 2.2em;
	border-right: 1px solid #212121;
	border-bottom: 1px solid #212121;
}

.block-thumbnail {}

.block-thumbnail img {
	width: 100%;
	border-radius: 0.80em;
}

.wrap-works {
	padding-top: 2.4em;
	padding-left: 80px;
	padding-right: 80px;
}

.wrap-works h1 {
	font-size: 2.28em;
	line-height: 1.7;
	margin-bottom: 0.6em;
	font-weight: 600;
}

.wrap-works .list-info a {
	text-decoration: none;
}

.wrap-works .list-info {
	display: grid;
	grid-template-columns: auto 1fr;
	border-top: 1px dotted rgba(33, 33, 33, 1.00);
	margin-bottom: 2.4em;
	line-height: 1.8;
}

.wrap-works .list-info dt,
.wrap-works .list-info dd {
	border-bottom: 1px dotted rgba(33, 33, 33, 1.00);
}

.wrap-works .list-info dt {
	font-size: 0.79em;
	padding-top: 1.0em;
}

.wrap-works .list-info dd {
	font-size: 0.89em;
	padding-top: 0.8em;
	padding-bottom: 0.8em;
	padding-left: 1.6em;
}

.wrap-works .list-info dd.keyword {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4em 1.0em;
}

.wrap-works .list-info dd.keyword a::before {
	content: '#';
}

.wrap-works .list-info dd.url a {
	overflow-wrap: anywhere;
}


@media screen and (max-width: 1280px) {
	.wrap-works {
		padding-left: 48px;
		padding-right: 48px;
	}

	.block-works-entry {
		column-gap: 2.0em;
	}

	.block-works-entry>.category {
		font-size: 2.28em;
	}

	.wrap-works h1 {
		font-size: 2.03em;
	}
}

@media print,
screen and (max-width: 1024px) {}

@media screen and (max-width: 560px) {
	.wrap-works {
		padding-left: 0;
		padding-right: 0;
	}

	.block-works-entry {
		grid-template-columns: 1fr;
	}

	.block-works-entry>.category {
		z-index: 1;
		position: absolute;
		top: 0;
		left: -9.6vw;
		background-color: rgba(255, 255, 255, 1.00);
		font-size: 1.60em;
		padding-top: 0.4em;
	}

	.block-thumbnail {
		margin-left: -9.6vw;
		margin-right: -9.6vw;
	}

	.block-thumbnail img {
		border-radius: 0;
	}

	.wrap-works h1 {
		font-size: 1.80em;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Contact
---------------------------------------------------------------------------------------------------- */
.list-contact {
	display: grid;
	grid-template-columns: auto 1fr;
	border-top: 1px dotted rgba(33, 33, 33, 1.00);
	margin-top: 2.4em;
	margin-bottom: 2.4em;
}

.list-contact dt,
.list-contact dd {
	border-bottom: 1px dotted rgba(33, 33, 33, 1.00);
	padding-top: 1.2em;
	padding-bottom: 1.2em;
}

.list-contact dt {
	padding-top: 1.6em;
}

.list-contact dt sup {
	padding-left: 0.4em;
	color: rgba(244, 67, 54, 1.00);
}

.list-contact dd {
	padding-left: 1.6em;
}

.list-contact dd label {
	margin-right: 0.4em;
}

.list-contact dd.normal input {
	width: 60%;
}

.list-contact dd.tel input {
	max-width: 25% !important;
}

.list-contact dd .error {
	padding-top: 0.2em;
	color: rgba(244, 67, 54, 1.00);
}

.block-button {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1.2em;
}

.block-button button {
	border: 2px solid rgba(33, 33, 33, 1.00);
	text-decoration: none;
	width: 10em;
	text-align: center;
	font-size: 0.89em;
	border-radius: 100vh;
	padding-top: 0.3em;
	padding-bottom: 0.3em;
	overflow: hidden;
	font-weight: 600;
}

.block-button button.back {
	opacity: 0.48;
}


.block-button button::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 0;
	height: 100%;
	background-color: rgba(33, 33, 33, 1.00);
	transition: all 0.16s cubic-bezier(0.33, 1, 0.68, 1);
}

.block-button button:hover {
	color: rgba(255, 255, 255, 1.00);
}

.block-button button:hover::before {
	width: 100%;
}



@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	.list-contact dd.normal input {
		width: 100%;
	}
}

@media screen and (max-width: 560px) {
	.list-contact {
		grid-template-columns: 1fr;
	}

	.list-contact dt {
		border-bottom: none;
		padding-bottom: 0;
		padding-top: 1.2em;
	}

	.list-contact dd {
		padding-top: 0.6em;
		padding-left: 0;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * News
---------------------------------------------------------------------------------------------------- */
.list-news {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 4.0em 3.6em;
}

.list-news a {
	text-decoration: none;
	line-height: 1.7;
}

.list-news a .image {
	margin-bottom: 1.2em;
}

.list-news a .image img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
	border-radius: 0.80em;
}


.list-news a .date {
	text-decoration: none;
	font-size: 0.89em;
	color: #212121;
	margin-bottom: 0.2em;
}

.list-news a .title {
	font-weight: bold;
}

.wrap-news {}

.wrap-news .block-date>.inner {
	font-weight: 500;
	font-size: 1.13em;
	border-bottom: 1px dotted rgba(33, 33, 33, 1.00);
	display: inline-block;
	line-height: 1.8;
	margin-bottom: 0.4em;
}

.wrap-news h1 {
	font-size: 2.28em;
	line-height: 1.8;
	margin-bottom: 0.8em;
	font-weight: 600;
}

@media screen and (max-width: 1280px) {
	.list-news {
		grid-template-columns: repeat(3, 1fr);
	}

}

@media print,
screen and (max-width: 1024px) {
	.wrap-news h1 {
		font-size: 2.03em;
	}



	.list-news {
		column-gap: 2.4em;
	}





}

@media screen and (max-width: 560px) {
	.wrap-news .block-date>.inner {
		font-size: 1.00em;
	}

	.wrap-news h1 {
		font-size: 1.80em;
	}

	.list-news {
		grid-template-columns: repeat(2, 1fr);
		column-gap: 2.0em;
	}

}

/* ----------------------------------------------------------------------------------------------------
 * Entry
---------------------------------------------------------------------------------------------------- */
.wrap-entry h2 {
	font-size: 1.60em;
	font-weight: 500;
	margin-bottom: 0.8em;
	margin-top: 2.4em;
}

.wrap-entry .wp-block-image {
	margin-top: 2.4em;
	margin-bottom: 2.4em;
	text-align: center;
}

.wrap-entry.wrap-news .wp-block-image {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.wrap-entry .wp-block-image figcaption {
	font-size: 0.89em;
	line-height: 1.8em;
	padding-top: 0.2em;
}

.wrap-entry .wp-block-embed-youtube {
	margin-top: 2.4em;
	margin-bottom: 2.4em;
	text-align: center;
}

.wrap-entry.wrap-news .wp-block-embed-youtube {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}

.wrap-entry .wp-block-embed-youtube iframe {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
}

.wrap-entry ul {
	list-style: disc;
	margin-left: 1.4em;
	margin-bottom: 1.6em;
}

.wrap-entry ol {
	list-style: decimal;
	margin-left: 1.6em;
	margin-bottom: 1.6em;
}

.wrap-entry hr {
	margin-top: 2.4em;
	margin-bottom: 2.4em;
	height: 0;
	border: 0;
	border-bottom: 1px dotted #212121;
}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	.wrap-entry h2 {
		font-size: 1.42em;
	}
}

@media screen and (max-width: 560px) {
	.wrap-entry h2 {
		font-size: 1.27em;
	}
}

/* ----------------------------------------------------------------------------------------------------
 * Pagenavi
---------------------------------------------------------------------------------------------------- */
.wp-pagenavi {
	margin-top: 5.6em;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	font-size: 0.89em;
	gap: 0.24em;
}

.wp-pagenavi>* {
	border: 1px solid rgba(33, 33, 33, 1.00);
	line-height: 2.4;
	min-width: 2.4em;
	text-decoration: none;
	text-align: center;
	padding: 0 0.8em;
}

.wp-pagenavi .current {
	background: rgba(33, 33, 33, 1.00);
	color: rgba(255, 255, 255, 1.00);
}

.wp-pagenavi .extend {
	border-color: rgba(33, 33, 33, 0.00);
	padding-left: 0.4em;
	padding-right: 0.4em;
	min-width: auto;
}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	.wp-pagenavi {
		margin-top: 4.8em;
	}
}

@media screen and (max-width: 560px) {}

/* ----------------------------------------------------------------------------------------------------
 * Home
---------------------------------------------------------------------------------------------------- */
.title-home>.inner {
	display: inline-block;
	font-size: 2.03em;
	letter-spacing: 0.08em;
	border-bottom: 2px dotted rgba(33, 33, 33, 1.00);
	line-height: 1.8;
	font-weight: 600;
}

.block-link {
	display: flex;
	justify-content: center;
	align-items: center;
}

.block-link a {
	background-color: #212121;
	color: #ffffff;
	text-decoration: none;
	width: 10em;
	text-align: center;
	font-size: 0.79em;
	border-radius: 100vh;
	padding-top: 0.5em;
	padding-bottom: 0.5em;
	overflow: hidden;
	font-weight: 600;
}



.block-link a:hover {
	background-color: rgba(244, 67, 54, 1.00);
	color: #ffffff;
}


@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	.title-home {
		text-align: center;
	}
}

@media screen and (max-width: 560px) {
	.title-home>.inner {
		font-size: 1.80em;
	}
}

.block-home-main {
	height: calc(100vh - 8em - 2.4em);
	height: calc(100vh - 8em - 2.4em);
}




@media screen and (max-width: 1920px) {}

@media screen and (max-width: 1536px) {
	.block-home-main {
		height: calc(100vh - 7.6em - 2.4em);
		height: calc(100vh - 7.6em - 2.4em);
	}

}

@media screen and (max-width: 1280px) {
	.block-home-main {
		height: calc(100vh - 7.6em - 1.6em);
		height: calc(100vh - 7.6em - 1.6em);
	}
}

@media print,
screen and (max-width: 1024px) {

	.block-home-main {
		height: calc(100vh - 6.8em);
		height: calc(100vh - 6.8em);
	}


}

@media screen and (max-width: 560px) {
	.block-home-main {
		height: calc(100vh - 6.0em);
		height: calc(100vh - 6.0em);
	}
}




.block-home-main .text * {
	color: rgba(33, 33, 33, 1.00) !important;
}

.block-home-main .swiper-photo {
	position: absolute;
	top: 0;
	left: 23.8em;
	right: 2.4em;
	bottom: 0;
}

.block-home-main .swiper-photo .item-photo {
	border-top-left-radius: 2.4em;
}

.block-home-main .text {
	position: absolute;
	left: 120px;
	bottom: 12vh;
	bottom: 12svh;
	z-index: 100;
	text-align: left;
}

.block-home-main .text * {
	font-weight: 700;
}

.block-home-main .text .together {
	font-size: 5.85em;
	line-height: 1.8em;
	letter-spacing: 0.06em;
	margin-bottom: 0.1em;
}

.block-home-main .text .change {
	width: 100%;
	font-size: 7.41em;
	border: 0.07em solid rgba(0, 0, 0, 1.00);
	text-align: center;
	height: calc(1.45em + 0.16em);
	line-height: 1.45em;
	margin-bottom: 0.3em;
	background-color: rgba(255, 255, 255, 1.00);
}

.block-home-main .text .change .swiper-text {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

.block-home-main .text h1 {
	font-size: 1.60em;
	line-height: 1.9em;
}

.block-home-main mark {
	background-color: rgba(255, 255, 255, 1.00);
}


.block-home-main .news {
	position: absolute;
	right: 4.0em;
	bottom: 1.6em;
	z-index: 100;
	max-width: 64%;
	text-align: left;
}

.block-home-main .news a {
	background-color: rgba(255, 255, 255, 0.92);
	border-radius: 100vh;
	font-size: 0.89em;
	line-height: 1.6;
	display: grid;
	grid-template-columns: auto 1fr;
	text-decoration: none;
	padding: 0.6em 1.2em;
	gap: 0.4em;
}

.block-home-main .news a .date {
	font-weight: 500;
}

.block-home-main .news a .title {
	font-weight: 600;
	max-height: 3.2em;
	overflow: hidden;
}


@media screen and (max-width: 1920px) {
	.block-home-main .swiper-photo {
		left: 21em;
	}

	.block-home-main .text {
		font-size: 0.89em;
		left: 96px;
	}
}

@media screen and (max-width: 1536px) {
	.block-home-main .swiper-photo {
		left: 18.3em;
	}

	.block-home-main .text {
		font-size: 0.79em;
		left: 80px;
	}
}

@media screen and (max-width: 1280px) {
	.block-home-main .swiper-photo {
		left: 15.8em;
		right: 1.6em;
	}

	.block-home-main .text {
		font-size: 0.70em;
		left: 64px;
	}
}

@media print,
screen and (max-width: 1024px) {
	.block-home-main .swiper-photo {
		left: 16vw;
		right: 0;
	}

	.block-home-main .swiper-photo .item-photo {
		border-top-left-radius: 2.0em;
	}

	.block-home-main .text {
		left: 6.4vw;
		font-size: 1.6vw;
	}

	.block-home-main .text h1 {
		font-size: 2.03em;
	}

	.block-home-main .news {
		right: 1.6em;
		max-width: 72%;
	}

}

@media screen and (max-width: 560px) {
	.block-home-main .swiper-photo {}

	.block-home-main .swiper-photo .item-photo {
		border-top-left-radius: 1.6em;
	}

	.block-home-main .text {
		font-size: 2.0vw;
		bottom: 16vh;
		bottom: 16svh;
	}

	.block-home-main .text h1 {
		font-size: 2.28em;
	}

	.block-home-main .news {
		right: 1.2em;
		bottom: 1.2em;
	}

	.block-home-main .news a {
		font-size: 0.79em;
	}


}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {}

@media screen and (max-width: 560px) {}

.block-home-link {
	padding-top: 9.6em;
	padding-bottom: 9.6em;
}

.block-home-link h2 {
	text-align: center;
	margin-bottom: 4.0em;
}

.list-home-link {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 2.4em;
	line-height: 1.8em;
}

.list-home-link a {
	text-decoration: none;
}

.list-home-link>li>a {
	display: grid;
	text-decoration: none;
}

.list-home-link>li>a .image {
	aspect-ratio: 3 / 2;
	border: 1px solid rgba(33, 33, 33, 1.00);
	overflow: hidden;
	margin-bottom: 1.4em;
	border-radius: 0.80em;
}

.list-home-link>li>a .image>span {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: all 0.32s ease;
}

.list-home-link>li>a:hover .image>span {
	transform: scale(1.08);
}

.list-home-link>li>a .title {
	font-size: 1.13em;
	font-weight: 700;
	margin-bottom: 0.1em;
}

.list-home-link>li>a .copy {
	font-size: 0.89em;
	color: rgba(33, 33, 33, 1.00);
	margin-bottom: 1.2em;
}

.list-home-link .sns {
	display: flex;
	gap: 0.6em;
	flex-wrap: wrap;
}

.list-home-link .sns a {
	display: block;
	width: 2.2em;
	height: 2.2em;
	background-color: #E0E0E0;
	border-radius: 100vh;
}

.list-home-link .sns a.site {
	background-image: url(../images/icon-site.svg);
	background-size: 52% auto;
}

.list-home-link .sns a.instagram {
	background-image: url(../images/icon-instagram.svg);
	background-size: 52% auto;
}

.list-home-link .sns a.x {
	background-image: url(../images/icon-x.svg);
	background-size: 48% auto;
}

.list-home-link .sns a.facebook {
	background-image: url(../images/icon-facebook.svg);
	background-size: 32% auto;
}

@media screen and (max-width: 1280px) {
	.list-home-link {
		gap: 2.0em;
	}

}

@media print,
screen and (max-width: 1024px) {
	.list-home-link {
		grid-template-columns: 1fr 1fr;
	}
}

@media screen and (max-width: 560px) {
	.block-home-link h2 {
		margin-bottom: 3.2em;
	}

	.block-home-link {
		padding-top: 8em;
		padding-bottom: 8em;
	}

	.list-home-link {
		grid-template-columns: 1fr;
		gap: 3.2em;
	}
}

.block-home-about {
	padding-top: 8.0em;
	padding-bottom: 10.2em;
	text-align: center;
	overflow: hidden;
	margin-top: 8em;
}

.block-home-about::after {
	content: '';
	display: block;
	position: absolute;
	left: 0;
	width: 100%;
	bottom: -1px;
	height: 3.2em;
	background-image: url(../images/bg-wave.svg);
	background-position: top center;
	background-size: 100% 100%;
}







.block-home-about video {
	position: absolute;
	width: 100%;
	height: auto;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
}

.block-home-about.vertical video {
	width: auto;
	height: 100%;
}

.block-home-about figure {
	width: 6.4em;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 2.0em;
}


.block-home-about {
	padding-top: 8.0em;
	padding-bottom: 10.2em;
	text-align: center;
	overflow: hidden;
	margin-top: 8em;
}

.block-home-about h2 {
	margin-bottom: 0.56em;
	letter-spacing: 0.06em;
	font-family: "Shippori Mincho", serif;
	text-align: center;
	font-size: min(3.65em, 8.0vw);
	padding-left: 0.4em;
	white-space: nowrap;
}

.block-home-about p {
	font-size: 1.13em;
	font-weight: 500;
	line-height: 2.2;
	margin-bottom: 2.2em;
}



.block-home-about .photo {
	margin-top: 4.0em;
	width: 100%;
	overflow: hidden;
}

.block-home-about .photo+.photo {
	margin-top: 0;
}

.block-home-about .photo img {
	width: 100%;
	aspect-ratio: 1;
	object-fit: cover;
}



.block-home-about .photo .swiper-wrapper {
	transition-timing-function: linear;
}



@media screen and (max-width: 1280px) {
	.block-home-about::after {
		height: 2.6em;
	}

}

@media print,
screen and (max-width: 1024px) {
	.block-home-about::after {
		height: 2.0em;
	}

}

@media screen and (max-width: 560px) {
	.block-home-about {
		padding-top: 5.6em;
		padding-bottom: 7.2em;
		margin-top: 6.4em;
	}

	.block-home-about::after {
		height: 1.4em;
	}

	.block-home-about figure {
		width: 5.6em;
	}

	.block-home-about h2 {}

	.block-home-about p {
		font-size: 1.00em;
		text-align: left;
	}

	.block-home-about p .inline-block {
		display: inline;
	}


	.block-home-about .photo {
		grid-template-columns: repeat(3, 1fr);
	}

	.block-home-about .photo .item:nth-child(n+7) {
		display: none;
	}
}


.block-home-service {
	display: grid;
	grid-template-columns: 0.4fr 1fr;
	grid-template-rows: auto 1fr;
	background-color: rgba(255, 255, 255, 1.00);
	padding-top: 8.0em;
	padding-bottom: 8.0em;
	gap: 0 4.8em;
	align-items: start;
}


.block-home-service>.text h2 {
	margin-bottom: 2.0em;
}

.list-home-service {
	display: grid;
	gap: 3.2em;
}

.list-home-service>li {
	border: 1px solid rgba(33, 33, 33, 1.00);
	padding: 2.4em;
	overflow: hidden;
}


.list-home-service>li::before {
	content: '';
	display: block;
	width: 2.0em;
	height: 2.0em;
	background-color: rgba(33, 33, 33, 1.00);
	position: absolute;
	top: -1.4em;
	left: -1.4em;
	transform: rotate(45deg);
}

.list-home-service>li>.en {
	font-size: 1.80em;
	letter-spacing: 0.08em;
	line-height: 1.6em;
	font-weight: 500;
}

.list-home-service>li .ja {
	font-weight: 600;
	font-size: 0.89em;
	line-height: 1.7;
}

.list-home-service>li p {
	line-height: 1.8em;
	font-size: 0.89em;
}



.list-home-service>li .list-branding {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 1.2em;
	margin-top: 2.2em;
	margin-bottom: 1.6em;
}

.list-home-service>li .list-branding li {
	border: 1px solid #212121;
	aspect-ratio: 1;
	border-radius: 100vh;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 0.89em;
	line-height: 1.7;
}

.list-home-service>li .list-branding li .en {
	letter-spacing: 0.08em;
	line-height: 1.6em;
	display: block;
	font-size: 1.42em;
}


.list-home-service>li .list-collaboration {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0.8em;
	margin-top: 2.2em;
	margin-bottom: 1.6em;
}

.list-home-service>li .list-collaboration img {
	border: 3px solid #F5F5F5;
	border-radius: 0.48em;
}


@media screen and (max-width: 1920px) {
	.block-home-service::before {
		transform: translate(calc(-50% + 1.6em), calc(-100% + 1px));

	}
}

@media screen and (max-width: 1536px) {
	.list-home-service>li .list-branding li .en {
		font-size: 1.27em;
	}

}

@media screen and (max-width: 1280px) {
	.block-home-service::before {
		display: none;
	}

	.block-home-service {
		padding-top: 8.0em;
	}

	.list-home-service>li .list-branding {
		grid-template-columns: repeat(2, 1fr);
		max-width: 32em;
		margin-left: auto;
		margin-right: auto;
	}


}

@media print,
screen and (max-width: 1024px) {
	.block-home-service {
		grid-template-columns: 1fr;
		grid-template-rows: auto;
		gap: 2.8em 4.8em;
	}

	.list-home-service>li>.en {
		font-size: min(1.80em, 6.0vw);
	}

}

@media screen and (max-width: 560px) {
	.block-home-service {
		padding-top: 6.4em;
		padding-bottom: 6.4em;
	}

	.list-home-service {
		grid-template-columns: 1fr;
	}


	.list-home-service>li {
		padding: 2.2em;
	}



	.list-home-service>li .list-branding {
		font-size: 0.79em;
	}

	.list-home-service>li .list-collaboration {
		grid-template-columns: repeat(2, 1fr);
	}





}


.block-home-works {
	padding-top: 8.0em;
	padding-bottom: 8.0em;
}


.block-home-works::before {}



.block-home-works>.inner {
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: auto auto;
	row-gap: 4.0em;
}






.block-home-works .swiper-works {}

.list-home-works a {
	display: block;
	text-decoration: none;
}

.list-home-works a.entry .category {
	writing-mode: vertical-rl;
	z-index: 2;
	position: absolute;
	top: 0;
	left: 0;
	background-color: rgba(255, 255, 255, 1.00);
	font-weight: 700;
	font-size: 1.27em;
	white-space: nowrap;
	padding-bottom: 0.6em;
	padding-top: 0.4em;
	padding-right: 0.2em;
	letter-spacing: 0.08em;
	color: rgba(33, 33, 33, 1.00);
	border-bottom: 1px solid #212121;
	border-right: 1px solid #212121;
}

.list-home-works a.entry {
	z-index: 1;
}

.list-home-works a.entry .image {
	aspect-ratio: 1 / 1;
	border-radius: 0.80em;
	margin-bottom: 0.6em;
	overflow: hidden;
	margin-bottom: 1.0em;
}

.list-home-works a.entry .image>span {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	transition: all 0.32s ease;
}

.list-home-works a.entry:hover .image>span {
	transform: scale(1.08);
}

.list-home-works a.entry .title {
	font-weight: 700;
	font-size: 1.00em;
	line-height: 1.7;
}

.list-home-works a.entry .title .date {
	font-size: 0.89em;
}


.swiper-works .swiper-button-prev,
.swiper-works .swiper-button-next {
	color: #212121;
	top: 0;
	bottom: 0;
	height: auto;
	background-color: #ffffff;
	width: 100vw;
}

.swiper-works .swiper-button-prev {
	left: auto;
	right: 100%;
	justify-content: flex-end;
	padding-right: 1.6em;
}

.swiper-works .swiper-button-next {
	right: auto;
	left: 100%;
	justify-content: flex-start;
	padding-left: 1.6em;

}

.swiper-works .swiper-button-prev::after,
.swiper-works .swiper-button-next::after {
	font-size: 2.4em;

}

.block-home-works .block-link.sp {
	display: none;
}



@media screen and (max-width: 1536px) {}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	.block-home-works .block-link.pc {
		display: none;
	}

	.block-home-works .block-link.sp {
		display: flex;
		margin-top: 3.2em;
	}

	.swiper-works .swiper-button-prev::after,
	.swiper-works .swiper-button-next::after {
		font-size: 2.0em;

	}

}

@media screen and (max-width: 560px) {
	.block-home-works {
		padding-top: 6.4em;
		padding-bottom: 6.4em;
	}

	.list-home-works a {
		font-size: 0.89em;
	}

	.swiper-works .swiper-button-prev {
		padding-right: 1.0em;
	}

	.swiper-works .swiper-button-next {
		padding-left: 1.0em;

	}

	.swiper-works .swiper-button-prev::after,
	.swiper-works .swiper-button-next::after {
		font-size: 1.6em;

	}

}

.block-home-news {
	padding-top: 8.0em;
	padding-bottom: 8.0em;
	display: grid;
	grid-template-columns: 1fr auto;
	grid-template-rows: auto auto;
	row-gap: 2.4em;
}



.block-home-news::before {
	content: '';
	display: block;
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	width: 100vw;
	width: 100lvw;
	transform: translate(-50%, 0);
	background-color: #f7f7f7;
}


.block-home-news h2 {
	grid-column: 1/ 2;
	grid-row: 1/ 2;
}

.block-home-news .list-news {
	grid-column: 1/ 3;
	grid-row: 2/ 3;
}

.block-home-news .block-link {
	grid-column: 2/ 3;
	grid-row: 1/ 2;
}

@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {
	.block-home-news {
		grid-template-columns: 1fr;
		grid-template-rows: auto;
	}

	.block-home-news h2 {
		grid-column: 1/ 2;
		grid-row: 1/ 2;
	}

	.block-home-news .list-news {
		grid-column: 1/ 2;
		grid-row: 2/ 3;
	}

	.block-home-news .block-link {
		grid-column: 1/ 2;
		grid-row: 3/ 4;
	}
}

@media screen and (max-width: 560px) {
	.block-home-news {
		padding-top: 6.4em;
		padding-bottom: 6.4em;
	}
}



.block-home-design {
	background-color: #f7f7f7;
	padding-top: 8.0em;
	padding-bottom: 8.0em;
}

.block-home-design>.inner {
	display: flex;
	justify-content: center;
	gap: 8.0em;
	align-items: center;
}


.block-home-design .image {
	text-align: center;
}

.block-home-design .image img {
	max-width: 320px;
}

.block-home-design .text {
	white-space: nowrap;
}

.block-home-design .text h2 {
	font-family: "Shippori Mincho", serif;
	font-size: min(2.89em, 2.8vw);
	line-height: 1.6;
	margin-bottom: 0.4em;
	text-indent: -0.4em;
}


.block-home-design .block-link {
	justify-content: flex-start;
}



@media screen and (max-width: 1536px) {
	.block-home-design>.inner {
		gap: 8vw;
	}

	.block-home-design .image img {
		max-width: 20vw;
	}

}


@media screen and (max-width: 1280px) {}

@media print,
screen and (max-width: 1024px) {

	.block-home-design>.inner {
		flex-direction: column;
		gap: 2.8em;
	}

	.block-home-design .image img {
		width: 240px;
		max-width: 40vw;
	}

	.block-home-design .text h2 {
		font-size: min(2.28em, 6.0vw);
	}

	.block-home-design .block-link {
		justify-content: center;
	}

}

@media screen and (max-width: 560px) {
	.block-home-design {
		padding-top: 6.4em;
		padding-bottom: 6.4em;
	}

}



.list-member {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 3.2em 2.0em;
	line-height: 1.8;
}

.list-member figure {
	margin-bottom: 1.1em;
}

.list-member figure img {
	aspect-ratio: 4 / 3;
	width: 100%;
	object-fit: cover;
}

.list-member .position {
	font-weight: bold;
	font-size: 0.79em;
}

.list-member .name {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: end;
	gap: 0.4em;
	line-height: 1.6;
}

.list-member .name .text {
	font-weight: bold;
	font-size: 1.42em;
}



.list-member .name .link {
	display: flex;
	gap: 0.2em;
	padding-bottom: 0.2em;
}

.list-member .name .link a {
	display: block;
	width: 2.0em;
	aspect-ratio: 1;
	background-color: #E0E0E0;
	border-radius: 100vh;
}

.list-member .name .link a.site {
	background-image: url(../images/icon-site.svg);
	background-size: 52% auto;
}

.list-member .name .link a.instagram {
	background-image: url(../images/icon-instagram.svg);
	background-size: 52% auto;
}

.list-member .name .link a.x {
	background-image: url(../images/icon-x.svg);
	background-size: 48% auto;
}

.list-member .name .link a.facebook {
	background-image: url(../images/icon-facebook.svg);
	background-size: 32% auto;
}

.list-member .name .link a.note {
	background-image: url(../images/icon-note.svg);
	background-size: 40% auto;
}





.list-member .profile {
	font-size: 0.89em;
	margin-top: 0.4em;
}

.list-member .profile p {
	margin-bottom: 0 !important;
}

.list-member .works {
	font-size: 0.89em;
	margin-top: 1.0em;
}

.list-member .works .title {
	display: grid;
	grid-template-columns: 1fr auto;
	font-weight: bold;
	align-items: end;
	margin-bottom: 0.1em;
}

.list-member .works .title .toggle {
	font-size: 0.70em;
	display: none;
	padding-bottom: 0.3em;
	cursor: pointer;
	transition: all 0.08s linear;
}

.list-member .works .title .toggle:hover {
	color: rgba(244, 67, 54, 1.00);
}





.list-member .works .list {
	display: grid;
	gap: 0.2em;
	font-size: 0.89em;
}

.list-member .works .list li {
	width: 100%;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}

.list-member .works .list li::before {
	display: inline-block;
	content: '〇';
	font-size: 0.55em;
	padding-right: 0.4em;
}



.list-member .works.many .title .toggle {
	display: block;
}

.list-member .works.many .title .toggle .close {
	display: none;
}

.list-member .works.many .list li:nth-child(n+5) {
	display: none;
}


.list-member .works.many.show .title .toggle .more {
	display: none;
}

.list-member .works.many.show .title .toggle .close {
	display: block;
}

.list-member .works.many.show .list li:nth-child(n+5) {
	display: block;
}



@media screen and (max-width: 1280px) {
	.list-member {
		grid-template-columns: repeat(2, 1fr);
	}

}

@media print,
screen and (max-width: 1024px) {}

@media screen and (max-width: 810px) {
	.list-member {
		grid-template-columns: repeat(1, 1fr);
	}

}

@media screen and (max-width: 560px) {}



/* ----------------------------------------------------------------------------------------------------
 * Food Design
---------------------------------------------------------------------------------------------------- */
.title-design {
	letter-spacing: 0.04em;
	font-family: "Shippori Mincho", serif;
	text-align: center;
	font-size: min(3.65em, 6.0vw);
	padding-left: 0.4em;
	padding-top: 0.8em;
	line-height: 1.6;
	margin-bottom: 0.4em;

}

.list-design-lead {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	border: 1px solid #212121;
}

.list-design-lead li {
	border-right: 1px solid #212121;
	padding: 2.0em;
}

.list-design-lead li:last-child {
	border: none;
}

.list-design-lead li .title {
	font-size: 2.03em;
	font-family: "Shippori Mincho", serif;
	display: grid;
	grid-template-columns: auto 1fr;
	line-height: 1.6;
	gap: 1.0em;
	margin-bottom: 0.4em;
}

.list-design-lead li .title::after {
	content: '';
	display: block;
	position: absolute;
	top: 0.1em;
	bottom: 0;
	left: 1.0em;
	border-right: 1px solid #212121;
	transform: rotate(20deg);
}

.list-design-lead li:nth-child(1) .title::before {
	content: '1';
}

.list-design-lead li:nth-child(2) .title::before {
	content: '2';
}

.list-design-lead li:nth-child(3) .title::before {
	content: '3';
}

.list-design {
	display: grid;
	gap: 6.4em;
}

.list-design>li {
	display: grid;
	grid-template-columns: 22em 1fr;
	gap: 4.8em;

}

.list-design li .title {
	border-right: 1px solid #212121;
	font-family: "Shippori Mincho", serif;
}

.list-design li .title .no {
	font-size: 4.62em;
	line-height: 1.0;
	margin-bottom: 0.3em;
}

.list-design li .title .text {
	font-weight: bold;
	font-size: 1.27em;
	line-height: 1.7;
}

.list-design li .more {
	display: grid;
	grid-template-columns: 1fr 40%;
	gap: 2.4em;
	align-items: center;
}

.list-design li .more.column1 {
	grid-template-columns: 1fr;
}


@media screen and (max-width: 1536px) {
	.list-design>li {
		grid-template-columns: 18em 1fr;
		gap: 3.2em;

	}

	.list-design-lead li .title {
		font-size: min(1.8em, 5.6vw);
	}

	.list-design li .title {
		font-size: 0.89em;
	}

}

@media screen and (max-width: 1280px) {
	.list-design-lead {
		grid-template-columns: repeat(1, 1fr);
	}

	.list-design-lead li {
		border-right: none;
		border-bottom: 1px solid #212121;
	}

	.list-design>li {
		display: grid;
		grid-template-columns: 1fr;
		gap: 2.4em;

	}

	.list-design li .title {
		border-right: none;
		border-left: 1px solid #212121;
		padding-left: 3.2em;
	}

	.list-design li .more {
		gap: 1.6em;
	}



}

@media print,
screen and (max-width: 1024px) {
	.title-design {
		padding-top: 1.2em;
		margin-bottom: 0.8em;

	}

	.list-design {
		gap: 5.4em;
	}

}

@media screen and (max-width: 560px) {
	.title-design {
		padding-top: 1.6em;
		margin-bottom: 1.2em;

	}

	.title-design-lead {
		padding-top: 1.2em;
		margin-bottom: 0.8em;

	}


	.list-design-lead li {
		padding: 1.6em;
	}

	.list-design {
		gap: 4.8em;
	}

	.list-design>li {
		gap: 1.6em;

	}


	.list-design li .title {
		padding-left: 2.4em;

	}

	.list-design li .title .no {
		font-size: 3.65em;
	}

	.list-design li .more {
		grid-template-columns: 1fr;
	}


	.list-design li .more .image {
		position: relative;
		right: auto;
		bottom: auto;
		width: 100%;
	}


}