@charset "UTF-8";

/******************/
/* RESET CSS */
.noto-sans-jp {
	font-family: "Noto Sans JP", sans-serif;
	font-weight: 400;
	font-style: normal;
}
.poppins {
	font-family: "Poppins", sans-serif;
	font-weight: 400;
	font-style: normal;
}
:root {
	--color-black:#222222;
	--color-white:#ffffff;
	--color-dark-white:#bbbbbb;
	--color-border:rgba(255, 255, 255, 0.15);

	--font-light: 300;
	--font-regular: 400;
	--font-medium: 500;
	--font-main: "Noto Sans JP", serif;
	--font-sub: "Poppins", sans-serif;
}

/* 全体設定 */
*,*::before,*::after{
	box-sizing:border-box
}
*{
	border:0;
	margin:0;
	outline:0;
	padding:0;
	font:inherit;
	font-family:inherit;
	font-size:100%;
	font-style:inherit;
	font-weight:inherit;
	text-decoration:none;
	vertical-align:baseline
}
article,aside,footer,header,main,nav,article,section{
	display:block
}
img,picture,audio,canvas,video,svg{
	display:block;
	max-width:100%;
	height:auto;
	width:100%
}
br,hr{
	display:block
}
ol,ul{
	list-style:none
}
blockquote,q{
	quotes:none
}
blockquote:before,blockquote:after,q:before,q:after{
	content:none
}
input,select{
	vertical-align:middle
}
body{
	line-height:1;
	line-break:strict;
	overflow-wrap:break-word;
	overflow-wrap:anywhere;
	word-break:normal;
	font-feature-settings:"palt";
	-webkit-text-size-adjust:100%;
	-webkit-font-smoothing:antialiased;
}
a{
	-webkit-tap-highlight-color:transparent
}
button{
	all:unset;
	display:inline-block;
	cursor:pointer;
	background:none;
	border:none;
	padding:0;
	margin:0;
	text-decoration:none;
	appearance:none;
	-webkit-appearance:none;
}


/******************/
/******************/
/* html format ****/


html {
	font-size: 62.5%;
	scroll-behavior: smooth;
}
@media screen and (max-width: 1200px) {
	html {
		font-size: 50%;
	}
}
@media screen and (max-width: 600px) {
	html {
		font-size: 62.5%;
	}
}
@media screen and (max-width: 390px) {
	html {
		font-size: 58%;
	}
}
@media screen and (max-width: 370px) {
	html {
		font-size: 50%;
	}
}

body {
	background-color:#333333;
	color:var(--color-white);
	font-family: var(--font-main);
	font-weight: var(--font-regular);
	font-size:16px;
	font-size:1.6rem;
	line-height:1;
	position:relative;
	text-align:left;
	text-size-adjust:100%;
	font-feature-settings:"palt";
	-webkit-font-smoothing:antialiased;
	font-smoothing:antialiased;
	-webkit-tap-highlight-color:transparent;
	width: 100%;
	height: auto;
	margin: 0 auto;
}


a,
a:link,
a:visited,
a:hover,
a:active {
	color: inherit;
	-webkit-tap-highlight-color: transparent rgba(0, 0, 0, 0);
	text-decoration: none;
	-webkit-text-decoration-skip: objects;
}
h1,
h2,
h3,
h4,
h5,
h6 {
	display: block;
	line-height: 1.4;
}
b {
	font-weight: bold;
}
button {
	line-height: 1;
}
i {
	font-style: normal;
	font-family: var(--font-sub);
	font-weight: var(--font-regular);
}
u {
	text-decoration: underline;
}
em {
	font-weight: bold;
}
strong {
	font-weight: bold;
	font-size: 1.4em;
}
mark {
	background: transparent;
}
q:before,
q:after {
	content: '"';
}
s {
	text-decoration: underline;
}
del {
	text-decoration: line-through;
}
rt {
	font-size: 0.5em;
}
sup {
	vertical-align: super;
	font-size: smaller;
}
sub {
	vertical-align: sub;
	font-size: smaller;
}
details {
	margin: 0 0 40px 0;
}
hr {
	margin: 0;
	border: 0;
	border-top: 1px solid var(--color-black);
	height: 0;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
	empty-cells: show;
	border: 0;
	width: 100%;
	margin: 0;
	border-top: 1px solid var(--color-black);
}
table th,
table td {
	padding: 1.5em 1em;
	vertical-align: top;
	border-bottom: 1px solid var(--color-black);
}
table caption {
	text-align: left;
}
::-moz-selection {
	background-color: var(--color-black);
	color: var(--color-white);
}
::selection {
	background-color: var(--color-orange);
	color: var(--color-white);
}
p {
	line-height: 1.8;
}


/******************/
/* shortcodes *****/
small.small {
	font-size: 0.8em;
}
.pc {
	display: block;
}
.sp {
	display: none;
}
@media screen and (max-width: 760px) {
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}
}


/* 共通スタイル */
br[data-break] {
	display: block;
}
@media screen and (max-width: 860px) {
	br[data-break] {
		display: none;
	}
}
.image-wrapper{
	height: fit-content;
	width: 100%;
	display: block;
	line-height: 1;
}
.image-wrapper img {
	width: 100%;
	height: auto;
	line-height: 0;
	user-select: none;
}

.site-main {
	padding: 0;
	margin: 0;
	line-height: 1.5;
	text-align: left;
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
	position: relative;
}

#article {
	position: relative;
	height: 100dvh;
	overflow-y: auto;
	overflow-x: hidden;
}
@media screen and (max-width: 600px) {
	#article{
		-ms-overflow-style: none;
		scrollbar-width: none;
	}
	#article::-webkit-scrollbar{
		display: none;
	}
}


.section-wrapper {
	padding: 100vh 7rem 0 7rem;
	transition: 0.7s;
	overflow: hidden;
	max-height: 100dvh;
	z-index: 4;
	position: relative;
	max-width: 1340px;
	margin: 0 auto;
}
/* 下層ページ用 */
.subpage .section-wrapper {
	padding-top: 8rem;
	overflow: visible;
}
/* ///////// */
@media screen and (max-width: 1024px) {
	.section-wrapper {
		padding-left: 3rem;
		padding-right: 3rem;
	}
}
@media screen and (max-width: 600px) {
	.section-wrapper {
		padding-left: 2.4rem;
		padding-right: 2.4rem;
	}
	.section-wrapper.is-keyboard-show {
		margin-top: -20rem;
	}
}
.site-main.is-section-active {
	cursor: pointer;
}
.site-main.is-section-active .section-wrapper {
	padding-top: 16rem !important;
	overflow: visible;
}
@media screen and (max-width: 600px) {
	.site-main.is-section-active .section-wrapper {
		padding-top: 18rem !important;
	}
}

.section {
	position: relative;
	display: none;
	padding: 0 0 12rem 0;
	margin: 12rem 0 0 0;
	max-width: 1000px;
	cursor: default;
	letter-spacing: 0.05em;
}
/* 下層ページ用 */
.subpage .section {
	display: block;
}
/* ///////// */
@media screen and (max-width: 600px) {
	.section {
		padding: 0 0 8rem 0;
		margin: 6rem 0 0 0;
	}
}

.inner {
	clear: both;
	display: block;
	margin: 0 auto;
	position: relative;
	width: 100%;
	padding: 0;
}
@media screen and (max-width: 600px) {
	.inner {
		padding: 0;
	}
}


/* 固有スタイル */
#header {
	width: 100%;
	max-width: 1340px;
	padding: 0 4rem;
	position: fixed;
	top: 3rem;
	left: 50%;
	transform: translateX(-50%);
	display: flex;
	align-items: center;
	justify-content: space-between;
	z-index: 999;
}
#header .site-title {
	font-size: 2.6rem;
	font-weight: var(--font-medium);
	font-family: var(--font-sub);
}
#header .site-title .site-description {
	opacity: 0;
	position: absolute;
	height: 0;
	pointer-events: none;
}
#header .site-navi {
	width: fit-content;
	padding: 1rem 3rem;
	background-color: rgba(0, 0, 0, 0.6);
	border-radius: 999px;
	border: 1px solid rgba(0, 0, 0, 0.7);
}
#header .site-navi .menu {
	display: flex;
	column-gap: 3rem;
}
#header .site-navi .menu li {
	font-size: 1.5rem;
	cursor: pointer;
}
@media screen and (min-width: 1024px) {
	#header .site-navi .menu li i {
		transition: 0.3s;
		display: block;
	}
	#header .site-navi .menu li:hover i {
		transform: translateY(-0.5rem);
	}
}
#header .site-navi .menu li {
	font-size: 1.5rem;
	cursor: pointer;
}
@media screen and (max-width: 600px) {
	#header {
		display: block;
		padding: 0 2.4rem;
		top: 2rem;
	}
	#header .site-title {
		font-size: 2.4rem;
	}
	#header .site-navi {
		margin-top: 1.6rem;
		width: 104%;
		margin-left: -2%;
		padding: 1.2rem 1.6rem;
	}
	#header .site-navi .menu li {
		font-size: 1.6rem;
	}
	#header .site-navi .menu li i {
		font-weight: var(--font-medium);
	}
	#header .site-navi .menu {
		column-gap: 0;
		justify-content: space-between;
	}
}




.section-close-button {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 998;
	pointer-events: none;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s, visibility 0.3s;
	width: 10rem;
	height: 10rem;
	border: 1px solid rgb(0, 0, 0, 0.7);
	background-color: rgb(0, 0, 0, 0.6);
	color: var(--color-white);
	border-radius: 50%;
	margin: -5rem 0 0 -5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	color: rgb(255, 255, 255, 0.7);
}
.section-close-button.is-close-active {
	opacity: 1;
	visibility: visible;
	cursor: pointer;
}
.section-close-button-sp {
	position: fixed;
	bottom: 2.4rem;
	right: 2.4rem;
	z-index: 998;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s, visibility 0.3s;
	border: 1px solid rgb(0, 0, 0, 0.7);
	background-color: rgb(0, 0, 0, 0.6);
	color: var(--color-white);
	border-radius: 999px;
	display: none;
	padding: 1rem 2rem 1rem 1.8rem;
	align-items: center;
	gap: 1rem;
}
.section-close-button-sp::before {
	content: "";
	display: block;
	width: 0.8em;
	height: 0.8em;
	background-image: url("../img/button-close.png");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
}
.section-close-button-sp.is-close-active {
	opacity: 1;
	visibility: visible;
	cursor: pointer;
}
@media screen and (max-width: 600px) {
	.section-close-button {
		display: none;
	}
	.section-close-button-sp {
		display: flex;
	}
}


.site-main .main-filter {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	backdrop-filter: blur(0px);
	transition: 0.3s;
	pointer-events: none;
	z-index: 3;
	background-color: rgba(0, 0, 0, 0);
}
.site-main.is-filter .main-filter {
	backdrop-filter: blur(30px);
	background-color: rgba(0, 0, 0, 0.5);
}
.site-main.is-filter.is-overlay .main-filter {
	backdrop-filter: blur(30px);
	background-color: rgba(0, 0, 0, 0.7);
}
/* 下層ページ用 */
.site-main.subpage .main-filter {
	backdrop-filter: blur(30px);
	background-color: rgba(0, 0, 0, 0.7);
}
/* ///////// */
.site-main .main-overlay {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background-image: url("../img/overlay.png");
	background-repeat: repeat;
	background-size: 5px;
	background-position: center;
	transition: 0.3s;
	opacity: 0.3;
	pointer-events: none;
	z-index: 2;
}
@media screen and (max-width: 600px) {
	.site-main .main-overlay {
		background-size: 4px;
	}
}


.video-content {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
}
.video-content video {
	object-fit: cover;
	width: 100%;
	height: 100%;
	line-height: 0;
}
.video-content .video-sp {
	display: none;
}
/* 下層ページ用 */
.subpage .video-content img {
	object-fit: cover;
}
/* ///////// */
@media (max-aspect-ratio: 1 / 1) {
	.video-content .video-pc { display: none; }
	.video-content .video-sp { display: block; }
}



#custom-keyboard {
	background-color: rgba(0, 0, 0, 0.6);
	border: 1px solid rgba(0, 0, 0, 0.7);
	border-radius: 2rem 2rem 0 0;
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	height: fit-content;
	padding: 2rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	row-gap: 0.8rem;
	z-index: 999;
	backdrop-filter: blur(3rem);
	transform: translateY(100vh);
	transition: 0.5s;
	display: none;
}
#custom-keyboard.is-keyboard-active {
	transform: translateY(0);
}
#custom-keyboard .key-wrap {
	display: flex;
	justify-content: center;
	width: fit-content;
	column-gap: 0.8rem;
}
#custom-keyboard .keyboard-button {
	font-size: 2rem;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 4rem;
	background-color: var(--color-black);
	border-radius: 0.8rem;
	transition: background-color 0.2s linear 0.1s;
}
#custom-keyboard .keyboard-button[data-key="Backspace"] {
	background-image: url("../img/icon-backspace.png");
	background-repeat: no-repeat;
	background-size: 70%;
	background-position: center;
}
#custom-keyboard .keyboard-button:active {
	background-color: #000;
	transition: background-color 0s;
}
@media screen and (max-width: 600px) {
	#custom-keyboard {
		display: flex;
	}
}






.question-container {
	position: relative;
}
.question-container .question-item {
	display: none;
	width: fit-content;
}
.question-container .question-item.is-hide {
	display: block;
	animation: data-question-anim-hide 0.3s ease-out 1 normal forwards;
}
@keyframes data-question-anim-hide {
	0% { opacity: 1;transform: translateY(0); }
	100% { opacity: 0;transform: translateY(-3rem); }
}
.question-container .question-item.is-show {
	display: block;
}


.question-container .question-item [data-question-anim] {
	min-width: 0.3em;
	display: inline-block;
}
.question-container .question-item.is-show [data-question-anim] {
	animation: data-question-anim 0.5s ease-out 1 normal forwards;
	opacity: 0;
	transform: translateY(100px);
}

@keyframes data-question-anim {
	0% { opacity:0; transform: translateY(0.5em); }
	100% { opacity:1; transform: translateY(0); }
}

[data-question-anim="01"] { animation-delay: 0.03s !important; }
[data-question-anim="02"] { animation-delay: 0.06s !important; }
[data-question-anim="03"] { animation-delay: 0.09s !important; }
[data-question-anim="04"] { animation-delay: 0.12s !important; }
[data-question-anim="05"] { animation-delay: 0.15s !important; }
[data-question-anim="06"] { animation-delay: 0.18s !important; }
[data-question-anim="07"] { animation-delay: 0.21s !important; }
[data-question-anim="08"] { animation-delay: 0.24s !important; }
[data-question-anim="09"] { animation-delay: 0.27s !important; }
[data-question-anim="10"] { animation-delay: 0.30s !important; }

[data-question-anim="11"] { animation-delay: 0.33s !important; }
[data-question-anim="12"] { animation-delay: 0.36s !important; }
[data-question-anim="13"] { animation-delay: 0.39s !important; }
[data-question-anim="14"] { animation-delay: 0.42s !important; }
[data-question-anim="15"] { animation-delay: 0.45s !important; }
[data-question-anim="16"] { animation-delay: 0.48s !important; }
[data-question-anim="17"] { animation-delay: 0.51s !important; }
[data-question-anim="18"] { animation-delay: 0.54s !important; }
[data-question-anim="19"] { animation-delay: 0.57s !important; }
[data-question-anim="20"] { animation-delay: 0.60s !important; }

[data-question-anim="21"] { animation-delay: 0.63s !important; }
[data-question-anim="22"] { animation-delay: 0.66s !important; }
[data-question-anim="23"] { animation-delay: 0.69s !important; }
[data-question-anim="24"] { animation-delay: 0.72s !important; }
[data-question-anim="25"] { animation-delay: 0.75s !important; }
[data-question-anim="26"] { animation-delay: 0.78s !important; }
[data-question-anim="27"] { animation-delay: 0.81s !important; }
[data-question-anim="28"] { animation-delay: 0.84s !important; }
[data-question-anim="29"] { animation-delay: 0.87s !important; }
[data-question-anim="30"] { animation-delay: 0.90s !important; }

[data-question-anim="31"] { animation-delay: 0.93s !important; }
[data-question-anim="32"] { animation-delay: 0.96s !important; }
[data-question-anim="33"] { animation-delay: 0.99s !important; }
[data-question-anim="34"] { animation-delay: 1.02s !important; }
[data-question-anim="35"] { animation-delay: 1.05s !important; }
[data-question-anim="36"] { animation-delay: 1.08s !important; }
[data-question-anim="37"] { animation-delay: 1.11s !important; }
[data-question-anim="38"] { animation-delay: 1.14s !important; }
[data-question-anim="39"] { animation-delay: 1.17s !important; }
[data-question-anim="40"] { animation-delay: 1.20s !important; }





.question-container .question-item .title {
	font-size: 5.6rem;
	font-weight: var(--font-light);
	font-family: var(--font-sub);
	line-height: 1.3;
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	width: fit-content;
}
.question-container .question-item .title .prompt-text {
	display: inline-block;
}
.question-container .question-item .title .answer-container {
	display: inline-flex;
	gap: 0.8rem;
	align-items: center;
	flex-wrap: wrap;
}
.question-container .question-item .title .answer-container .letter-slot {
	display: block;
	width: 1em;
	height: 1em;
	text-align: center;
	position: relative;
	opacity: 0;
	animation-name: data-question-anim-letter-slot;
}
.question-container .question-item .title .answer-container .letter-slot:first-of-type {
	text-transform: uppercase;
}

@keyframes data-question-anim-letter-slot {
	0% { opacity:0; transform: translateY(0.5em); }
	100% { opacity:0.3; transform: translateY(0); }
}
.question-container .question-item.is-hide .title .answer-container .letter-slot {
	opacity: 0.5 !important;
}
.question-container .question-item .title .answer-container .letter-slot.filled {
	opacity: 1 !important;
}
.question-container .question-item .title .answer-container .letter-slot::before {
	content: "";
	position: absolute;
	bottom: -1.5rem;
	left: 0;
	display: block;
	width: 100%;
	height: 2px;
	background-color: var(--color-white);
}
.question-container .question-item .title .answer-container .letter-slot.active::after {
	content: '';
	position: absolute;
	left: 0.07em;
	top: 20%;
	width: 0.2rem;
	height: 5rem;
	background: var(--color-white);
	animation: blink 1s infinite;
}
@keyframes blink {
	0%, 49% {
		opacity: 1;
	}
	50%, 100% {
		opacity: 0;
	}
}
.question-container .question-item .subtitle[data-question-anim] {
	font-size: 2.2rem;
	margin-top: 2.4rem;
	animation-delay: 1.2s;
}
.question-container #hidden-input {
	position: fixed;
	top: 0;
	left: 0;
	opacity: 0;
	pointer-events: none;
	font-size: 10rem;
	width: 100px;
	overflow: hidden;
}
@media screen and (max-width: 1024px) {
	.question-container .question-item .title {
		font-size: 4.2rem;
	}
	.question-container .question-item .subtitle[data-question-anim] {
		font-size: 1.6rem;
		margin-top: 1.6rem;
	}
}
@media screen and (max-width: 780px) {
	.question-container .question-item .title {
		font-size: 3.2rem;
	}
}
@media screen and (max-width: 600px) {
	.question-container .question-item .title {
		font-size: 3.2rem;
	}
	.question-container .question-item .title .answer-container {
		gap: 0.3rem;
	}
	.question-container .question-item .title .answer-container .letter-slot {
		width: 0.75em;
	}
	.question-container .question-item .title .answer-container .letter-slot::before {
		bottom: -1rem;
	}
	.question-container .question-item .title .answer-container .letter-slot.active::after {
		height: 2.6rem;
	}
	.question-container .question-item .subtitle[data-question-anim] {
		margin-top: 2rem;
	}
	.question-container .question-item[data-answer="contact"] .title .answer-container + .prompt-text {
		margin-top: 0.7em;
	}
	.question-container .question-item[data-answer="contact"] .title .answer-container + .prompt-text span:first-child {
		display: none;
	}
}
@media screen and (max-width: 450px) {
	.question-container .question-item .title {
		font-size: 3.3rem;
	}
}
@media screen and (max-width: 400px) {
	.question-container .question-item .title {
		font-size: 3.2rem;
	}
}



.is-section-active[data-section="section-about"] #section-about {
	display: block;
}
.is-section-active[data-section="section-service"] #section-service {
	display: block;
}
.is-section-active[data-section="section-history"] #section-history {
	display: block;
}
.is-section-active[data-section="section-news"] #section-news {
	display: block;
}
.is-section-active[data-section="section-contact"] #section-contact {
	display: block;
}


[data-content-fade] {
	opacity: 0;
	transform: translateY(3rem);
	transition: opacity 0.6s ease, transform 0.6s ease;
}
[data-content-fade="is-visible"] {
	opacity: 1;
	transform: translateY(0);
}

h3 {
	font-size: 3.2rem;
	margin-top: 6.4rem;
	margin-bottom: 3.2rem;
}
h3 i {
	font-size: 3.6rem;
	margin-top: 6.4rem;
}
@media screen and (max-width: 600px) {
	h3 {
		font-size: 2.8rem;
		margin-top: 5.2rem;
		margin-bottom: 1.6rem;
	}
	h3 i {
		font-size: 2.8rem;
		margin-top: 5.2rem;
	}
}
.link {
	margin-top: 1.2rem;
}
.link a {
	display: block;
	position: relative;
	padding-right: 1.5em;
	background-image: url("../img/icon-external.png");
	background-repeat: no-repeat;
	background-size: 1.6rem;
	background-position: bottom right;
	height: 1.5em;
	width: fit-content;
}
.link a::after {
	content: "";
	position: absolute;
	bottom: -0.6rem;
	left: 0;
	display: block;
	width: 100%;
	height: 1px;
	background-color: var(--color-dark-white);
}

.note {
	margin-top: 1.2rem;
	font-size: 1.2rem;
}


#section-about .about-description {
	font-size: 1.7rem;
	line-height: 3;
}
#section-about .about-list tr {
	border-bottom: 1px solid var(--color-border);
}
#section-about .about-list tr:first-of-type {
	border-top: 1px solid var(--color-border);
}
#section-about .about-list th,
#section-about .about-list td {
	padding: 3.2rem 2rem;
	vertical-align: middle;
	border: none;
}
#section-about .about-list th {
	font-size: 1.1em;
}
@media screen and (max-width: 600px) {
	#section-about .about-description {
		font-size: 1.6rem;
		line-height: 2.4;
	}
	#section-about .about-list th,
	#section-about .about-list td {
		display: block;
		padding: 1.6rem 0.8rem;
	}
	#section-about .about-list th {
		padding-bottom: 0;
	}
	#section-about .about-list td {
		padding-top: 0.8rem;
	}
}


#section-service .intro {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	border-top: 1px solid var(--color-border);
	padding: 5.6rem 5.6rem 7.2rem 5.6rem;
	margin-top: 7.2rem;
}
#section-service .intro.reverse {
	flex-direction: row-reverse;
}
#section-service .intro:first-of-type {
	margin-top: 0;
}
#section-service .intro .thumbnail {
	width: 45%;
}
#section-service .intro .text {
	width: 45%;
}
#section-service .intro .text h3 i {
	font-size: 1.4rem;
	margin-top: 1.6rem;
	font-weight: var(--font-light);
	color: var(--color-dark-white);
	display: block;
}
#section-service .intro .text .title-description {
	margin-top: 3.6rem;
	color: var(--color-dark-white);
}
#section-service .service-list {
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
	row-gap: 4.8rem;
}
#section-service .list-item {
	width: 47.5%;
	border: 1px solid var(--color-border);
	background-color: rgb(26, 26, 26, 0.6);
	border-radius: 2rem;
	padding: 5.2rem;
}
#section-service .list-item .icon {
	background-color: rgb(0, 0, 0,0.3);
	border-radius: 1.6rem;
	margin-bottom: 3.2rem;
	width: 12rem;
	height: 12rem;
	background-image: url("");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
}
#section-service .list-item h4 {
	font-size: 2.8rem;
	margin-bottom: 2.4rem;
}
#section-service .list-item p {
	color: var(--color-dark-white);
}
#section-service .list-item.coming-soon {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 2.4rem;
	color: var(--color-dark-white);
}
@media screen and (max-width: 600px) {
	#section-service .intro {
		display: block;
		padding: 4rem 0 5.2rem 0;
		padding-right: 0;
	}
	#section-service .intro .thumbnail {
		width: 70%;
		margin: 0 auto;
	}
	#section-service .intro .text {
		width: 100%;
	}
	#section-service .intro .text h3 {
		font-size: 2.4rem;
		margin-top: 2.4rem;
		margin-bottom: 2.4rem;
	}
	#section-service .intro .text h3 i {
		margin-top: 0.8rem;
	}
	#section-service .intro .text .title-description {
		margin-top: 2.4rem;
	}
	#section-service .service-list {
		display: block;
	}
	#section-service .list-item {
		width: 100%;
		padding: 2.8rem;
	}
	#section-service .list-item + .list-item {
		margin-top: 2.4rem;
	}
	#section-service .list-item.coming-soon {
		display: none;
	}
	#section-service .list-item .icon {
		width: 6rem;
		height: 6rem;
		margin-bottom: 2rem;
	}
	#section-service .list-item h4 {
		font-size: 2.2rem;
		margin-bottom: 1.6rem;
	}
}

#section-history dl {
	padding-left: 12rem;
}
#section-history dl dt {
	font-size: 2rem;
	margin-bottom: 1.6rem;
	position: relative;
}
#section-history dl dt i {
	position: absolute;
	left: -12rem;
	top: -0.2em;
	font-size: 3.2rem;
	font-weight: var(--font-medium);
}
#section-history dl dd {
	color: var(--color-dark-white);
	border-left: 1px solid var(--color-border);
	padding: 0 0 3.2rem 3rem;
	margin: 0 0 1.6rem 1.6rem;
}
#section-history dl dd:last-of-type {
	margin-bottom: 0;
}
@media screen and (max-width: 600px) {
	#section-history dl {
		padding-left: 0;
	}
	#section-history dl dt i {
		position: static;
		display: block;
		font-size: 2.4rem;
		margin-bottom: 0.8rem;
	}
	#section-history dl dd {
		padding-left: 2rem;
	}
}


#section-news .news-list li {
	display: flex;
	border-bottom: 1px solid var(--color-border);
	padding: 3.2rem 2rem;
	column-gap: 2.8rem;
}
#section-news .news-list li:first-child {
	border-top: 1px solid var(--color-border);
}
#section-news .news-list li .summary {
	font-size: 1.4rem;
	color: var(--color-dark-white);
	width: 6em;
}
#section-news .news-list li .description {
	flex: 1;
}
#section-news .news-list li .description h3 {
	font-size: 2rem;
	margin: 0;
}
#section-news .news-list li .description h3 + p {
	margin: 1.2rem 0 0 0;
}
#section-news .news-list li .description p {
	color: var(--color-dark-white);
}
@media screen and (max-width: 600px) {
	#section-news .news-list li {
		padding: 2.4rem 0.8rem;
		display: block;
	}
	#section-news .news-list li .summary {
		margin-bottom: 1rem;
	}
	#section-news .news-list li .description h3 {
		font-size: 2rem;
	}
}

#section-contact h3 {
	margin-bottom: 2.4rem;
}
#section-contact p {
	color: var(--color-dark-white);
	margin-bottom: 1.6rem;
}
#section-contact .button.arrow {
	margin-top: 1rem;
}
#section-contact .button.arrow + .button.arrow{
	margin-top: 2rem;
}
#section-contact .button.arrow a {
	font-size: 1.8rem;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	column-gap: 1.6rem;
	width: fit-content;
	position: relative;
}
#section-contact .button.arrow a::before {
	content: "";
	display: block;
	background-image: url("../img/arrow-right.png");
	background-repeat: no-repeat;
	background-size: contain;
	background-position: center;
	width: 0.8em;
	height: 0.8em;
	margin-top: 0.2em;
}
#section-contact .button.arrow a::after {
	content: "";
	position: absolute;
	top: calc(100% + 0.3em);
	left: 0;
	display: block;
	width: 0%;
	height: 1px;
	background-color: var(--color-white);
	transition: 0.5s ease-out;
}
#section-contact .button.arrow a:hover::after {
	width: 100%;
}
@media screen and (max-width: 600px) {
	#section-contact h3 {
		margin-bottom: 1.6rem;
	}
	#section-contact p {
		margin-bottom: 2rem;
	}
}



#section-privacy li {
	line-height: 1.85;
}
#section-privacy h2 {
	margin-bottom: 12rem;
}
#section-privacy h2 .title {
	font-size: 5.6rem;
	font-weight: var(--font-light);
	font-family: var(--font-sub);
	line-height: 1.3;
	display: block;
}
#section-privacy h2 .subtitle {
	font-size: 2.2rem;
	margin-top: 2.4rem;
	display: block;
}

#section-privacy h3 {
	font-size: 3.2rem;
	margin-top: 7.2rem;
	margin-bottom: 2.4rem;
}

#section-privacy ol li > ol {
	list-style: decimal;
	margin-top: 2.8rem;
	padding-left: 2.8rem;
	padding-bottom: 1.2rem;
}
#section-privacy ol li > ol > li + li {
	margin-top: 1.2rem;
}
#section-privacy ol li > ol li > ol {
	list-style: lower-alpha;
	margin-top: 1.6rem;
	padding-left: 2.8rem;
	padding-bottom: 1.2rem;
}
#section-privacy ol li > ol li > ol li > ol {
	list-style: lower-roman;
	margin-top: 1.6rem;
	padding-left: 2.8rem;
	padding-bottom: 1.2rem;
}


#section-privacy ul {
	list-style: disc;
	margin-top: 1.2rem;
	padding-left: 2rem;
	padding-bottom: 1.2rem;
}
#section-privacy ul > li + li {
	margin-top: 0.4rem;
}
#section-privacy dl {
	margin-top: 2.4rem;
}
#section-privacy dl dd + dt {
	margin-top: 1.2rem;
}


#section-privacy p.end {
	margin-top: 7.2rem;
}
#section-privacy p.date {
	margin-top: 2.4rem;
}







#copy {
	position: fixed;
	top: 50%;
	right: 2rem;
	z-index: 4;
	transform: translateY(-50%);
	writing-mode: vertical-rl;
	text-combine-upright: none;
	letter-spacing: 0.2em;
	display: inline-block;
	opacity: 0.5;
	pointer-events: none;
	font-size: 1.2rem;
}
@media screen and (max-width: 600px) {
	#copy {
		right: 1rem;
		font-size: 1rem;
	}
}

/* end ************/
/******************/
/******************/