@charset "UTF-8";



/* -------------------------------------------

kv

------------------------------------------- */
.CMS-NOT-EDITABLE-AREA {
	height: 64rem;
}

.top-kv {
	position: relative;
}

.top-kv-slider > * {
	height: 64rem;
}

.top-kv-slider div:nth-of-type(1) {
	background: url(../img/top-kv-1.jpg) no-repeat center / cover;
}

.top-kv-slider div:nth-of-type(2) {
	background: url(../img/top-kv-2.jpg) no-repeat center / cover;
}

@media screen and (max-width: 768px) {
	.CMS-NOT-EDITABLE-AREA {
		height: 36rem;
	}

	.top-kv-slider > * {
		height: 36rem;
	}
}

/* ---- scroll ---- */
.scroll {
	position: absolute;
	left: 4rem;
	bottom: 0;
	z-index: 0;
	color: #fff;
	font-weight: bold;
	z-index: 10;
	display: flex;
	align-items: center;
	font-size: 1.2rem;
}

.scroll span {
	width: 1px;
	height: 10rem;
	background-color: #fff;
	animation: scroll infinite 1s;
	margin-right: 0.3rem;
}

@keyframes scroll {
	0% {
		transform: scale(1, 1);
		transform-origin: bottom;
	}

	100% {
		transform: scale(1, 0);
		transform-origin: bottom;
	}
}

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



/* -------------------------------------------

about

------------------------------------------- */
.top-about {
	padding: 12rem 0;
	background: url(../img/bg-deco.png) no-repeat right center;
	background-size: auto 100%;
	background-color: var(--bg-grey);
	display: flex;
}

.top-about > div {
	width: 60%;
	padding-left: calc((100% - 88rem) / 2);
	padding-right: 5rem;
}

.top-about > figure {
	width: 40%;
}

@media screen and (max-width: 768px) {
	.top-about {
		padding: 8rem 3rem;
		background: url(../img/bg-deco.png) no-repeat right -10rem bottom;
		background-size: 100% auto;
		background-color: var(--bg-grey);
		display: block;
	}

	.top-about > div {
		width: 100%;
		padding: 0;
		margin-bottom: 4rem;
	}

	.top-about > figure {
		width: 100%;
	}
}

/* ---- h3 ---- */
.top-about h3 {
	font-weight: 900;
	font-size: 2.2rem;
}

/* ---- p ---- */
.top-about p {
	margin: 2rem 0 3rem 0;
}

/* ---- more ---- */
.top-about .more {
	margin: 0;
}



/* -------------------------------------------

business

------------------------------------------- */
.top-business {
	padding: 10rem 0;
}

@media screen and (max-width: 768px) {
	.top-business {
		padding: 8rem 3rem;
	}
}

/* ---- ul ---- */
.top-business ul li {
	display: flex;
	align-items: center;
}

.top-business ul li:nth-child(odd) {
	flex-direction: row-reverse;
}

.top-business ul li:not(:last-child) {
	margin-bottom: 5rem;
}

.top-business ul li > figure {
	width: 55%;
}

.top-business ul li:nth-child(odd) figure {
	margin-left: -5%;
}

.top-business ul li:nth-child(even) div {
	margin-left: -5%;
}

@media screen and (max-width: 768px) {
	.top-business ul li {
		display: block;
	}

	.top-business ul li:not(:last-child) {
		margin-bottom: 3rem;
	}

	.top-business ul li > figure {
		width: 100%;
	}

	.top-business ul li:nth-child(odd) figure {
		margin-left: 0;
	}

	.top-business ul li:nth-child(even) div {
		margin-left: 0;
	}
}

/* txt */
.txt {
	color: #fff;
	padding: 3.5rem 3.5rem;
	width: 50%;
	position: relative;
	z-index: 10;
}

@media screen and (max-width: 768px) {
	.txt {
		width: 100%;
	}
}

.top-business ul li:nth-child(1) .txt {
	background: url(../img/num-1.png) no-repeat right 2rem bottom 2rem;
	background-size: auto 8rem;
	background-color: var(--prime);
}

.top-business ul li:nth-child(2) .txt {
	background: url(../img/num-2.png) no-repeat right 2rem bottom 2rem;
	background-size: auto 8rem;
	background-color: var(--prime);
}

.top-business ul li:nth-child(3) .txt {
	background: url(../img/num-3.png) no-repeat right 2rem bottom 2rem;
	background-size: auto 8rem;
	background-color: var(--prime);
}

@media screen and (max-width: 768px) {
	.top-business ul li:nth-child(1) .txt {
		background: url(../img/num-1.png) no-repeat right 1.5rem top 1.5rem;
		background-size: auto 6rem;
		background-color: var(--prime);
	}

	.top-business ul li:nth-child(2) .txt {
		background: url(../img/num-2.png) no-repeat right 1.5rem top 1.5rem;
		background-size: auto 6rem;
		background-color: var(--prime);
	}

	.top-business ul li:nth-child(3) .txt {
		background: url(../img/num-3.png) no-repeat right 1.5rem top 1.5rem;
		background-size: auto 6rem;
		background-color: var(--prime);
	}
}

/* dl */
.txt dt {
	font-weight: bold;
	font-size: 2rem;
}

.txt dd {
	margin: 1rem 0 2rem 0;
}

/* more */
.top-business .more {
	margin: 0;
}



/* -------------------------------------------

recruit

------------------------------------------- */
.top-recruit {
	background: var(--prime);
	display: flex;
	align-items: center;
	flex-direction: row-reverse;
}

.top-recruit > * {
	width: 50%;
}

.top-recruit > div {
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: 6rem 0 4rem 0;
}

@media screen and (max-width: 768px) {
	.top-recruit {
		display: block;
		flex-direction: row-reverse;
		overflow: hidden;
	}

	.top-recruit > * {
		width: 100%;
	}

	.top-recruit > figure {
		width: 130%;
		margin-left: -30%;
	}

	.top-recruit .more-wrap {
		width: calc(100% - 6rem);
		margin: 0 auto;
	}
}

/* ---- h2 ---- */
.top-recruit h2 {
	line-height: 0;
}

.top-recruit h2 .en {
	color: #000;
	opacity: 0.1;
}

.top-recruit h2 .en::first-letter {
	color: #000;
}

.top-recruit h2 .jp {
	color: #fff;
	margin-top: 0.6rem;
}

/* ---- p ---- */
.top-recruit p {
	margin: 3rem 0 4rem 0;
	color: #fff;
}

@media screen and (max-width: 768px) {
	.top-recruit p {
		margin: 1rem 0 3rem 0;
	}
}

.recruit a {
	margin-bottom: 60px;
}



/* -------------------------------------------

contact

------------------------------------------- */
.top-contact {
	background: var(--bg-grey);
	padding: 10rem 0;
}

@media screen and (max-width: 768px) {
	.top-contact {
		padding: 3rem;
	}
}

/* ---- wrap ---- */
.top-contact > a {
	border: solid 2px var(--prime);
	background: url(../img/top-bg-1.jpg) no-repeat center / cover;
	display: block;
	padding: 3rem 5rem 5rem 44rem;
}

@media screen and (max-width: 768px) {
	.top-contact > a {
		background: url(../img/top-bg-1.jpg) no-repeat left center / cover;
		display: block;
		padding: 3rem;
		position: relative;
	}

	.top-contact > a > * {
		position: relative;
		z-index: 99;
	}

	.top-contact > a::before {
		content: "";
		width: 100%;
		height: 100%;
		position: absolute;
		left: 0;
		top: 0;
		background: #fff;
		opacity: 0.6;
	}
}




/* -------------------------------------------

news

------------------------------------------- */
.top-news {
	padding: 10rem 0;
}

/* ---- wrap ---- */
.top-news .wrap {
	display: flex;
}

.top-news .wrap > div:nth-of-type(1) {
	width: 35%;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
}

.top-news .wrap > div:nth-of-type(2) {
	width: 65%;
}

.top-news .more {
	margin: 3rem 0 0 0;
}

@media screen and (max-width: 768px) {
	.top-news .wrap {
		display: block;
	}

	.top-news .wrap > div:nth-of-type(1) {
		width: 100%;
	}

	.top-news .wrap > div:nth-of-type(2) {
		width: 100%;
	}

	.top-news .more {
		margin: 4rem 0 0 0;
	}
}

/* ---- cms ---- */
.top-news .CMS-NEWS-INDEX {
	padding-bottom: 0;
}

.top-news .CMS-NEWS-MORE-READ {
	display: none;
}

@media screen and (max-width: 768px) {
	.top-news {
		padding: 8rem 3rem;
	}
}



/* -------------------------------------------

blog

------------------------------------------- */
.top-blog {
	padding: 10rem 0;
	background: var(--bg-prime);
}

.top-blog .more {
	margin: 6rem auto 0 auto;
}

@media screen and (max-width: 768px) {
	.top-blog {
		padding: 8rem 3rem;
	}

	.top-blog .more {
		margin: 4rem auto 0 auto;
	}
}

/* ---- h2 ---- */
.top-blog h2 {
	line-height: 0;
	margin-bottom: 8rem;
}

.top-blog h2 .en {
	color: var(--prime);
	opacity: 0.1;
}

/* ---- cms ---- */
.top-blog .CMS-ARTICLE-MORE-READ {
	display: none;
}

.top-blog .CMS-ARTICLE-INDEX {
	padding-bottom: 0;
}



/* -------------------------------------------

form

------------------------------------------- */
.CMS-FORM-GROUP {
	display: flex;
	align-items: center;
}

.CMS-FORM-GROUP:not(:last-of-type) {
	margin-bottom: 4rem;
}

.CMS-FORM-GROUP > label {
	width: 30%;
	font-weight: bold;
}

.CMS-FORM-GROUP input,
.CMS-FORM-GROUP textarea {
	width: 70%;
	padding: 2rem;
	border: none;
	background: rgba(245, 245, 245);
}

.CMS-FORM-INPUT,
.CMS-FORM-EMAIL {
	-webkit-appearance: none;
	appearance: none;
}

.CMS-FORM-GROUP textarea {
	height: 16rem;
	-webkit-appearance: none;
	appearance: none;
}

.CMS-FORM-GROUP input[type="submit"] {
	background: var(--prime);
	border: none;
	color: #fff;
	display: block;
	font-weight: bold;
	font-size: 1.6rem;
	width: 24rem;
	padding: 1.5rem 0 1.6rem 0;
	margin: 0 auto;
	transition: all .3s;
	font-weight: bold;
}

.CMS-FORM-GROUP input[type="submit"]:hover {
	cursor: pointer;
	opacity: 0.5;
}

.CMS-FORM-RADIO input[type="radio"] {
	width: 2rem;
	height: 2rem;
	display: block;
	margin-top: 0.9rem;
	border-radius: 50%;
}

.CMS-FORM-RADIO {
	width: 70%;
}

.CMS-FORM-RADIO > div {
	display: flex;
	align-items: center;
}

.CMS-FORM-RADIO label {
	display: block;
	width: calc(100% - 3.5rem);
	margin-top: 0.8rem;
	margin-left: 0.5rem;
	font-weight: normal;
}

_::-webkit-full-page-media,
_:future,
:root .CMS-FORM-RADIO label {
	margin-top: 0;
}

input[type="submit"],
input[type="button"] {
	border-radius: 0;
	-webkit-appearance: button;
	appearance: button;
	border: none;
}

input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
	display: none;
}

input[type="date"] {
	-webkit-appearance: none;
	appearance: none;
	background: #fff;
}

.his {
	background: rgba(230, 0, 0, 1);
	line-height: 1;
	color: #fff;
	font-size: 1rem;
	padding: 0.2rem 0.7rem 0.4rem 0.7rem;
	margin-left: 1.0rem;
	vertical-align: 0.1rem;
	font-weight: normal;
	border-radius: 10rem;
}

select {
	border: solid 0.15rem #ccc;
	appearance: none;
	border-radius: 0;
	padding: 0.8rem 4rem 0.7rem 1rem;
	font-size: 1.4rem;
	position: relative;
	background: #fff;
	color: #000;
}

.select-wrap {
	position: relative;
}

.select-wrap::before {
	content: "";
	width: 0.6rem;
	height: 0.6rem;
	border-right: solid 0.15rem #333;
	border-bottom: solid 0.15rem #333;
	transform: rotate(45deg);
	position: absolute;
	right: 1.2rem;
	top: calc(50% - 0.6rem);
	z-index: 10;
}

@media screen and (max-width: 768px) {
	.CMS-FORM-GROUP {
		display: block;
	}

	.CMS-FORM-GROUP label {
		width: 100%;
		display: block;
		margin-bottom: 1rem;
	}

	.CMS-FORM-GROUP input,
	.CMS-FORM-GROUP textarea {
		width: 100%;
	}

	.CMS-FORM-RADIO input[type="radio"] {
		transform: scale(0.6);
	}

	_::-webkit-full-page-media,
	_:future,
	:root .CMS-FORM-RADIO label {
		margin-top: 1.4rem;
		margin-left: 0;
	}

	.CMS-FORM-GROUP input[type="submit"] {
		width: 100%;
		padding: 2rem 0;
		font-size: 1.8rem;
	}

	input[type="date"] {
		width: 100%;
		font-size: 2rem;
		color: #000;
	}

	select {
		width: 100%;
	}
}


/* -------------------------------------------

privacy

------------------------------------------- */
.privacy {
	border: 0.2rem solid #ccc;
	padding: 2rem;
	height: 24rem;
	overflow: auto;
	background: #fff;
	font-size: 1.2rem;
}

.privacy-note {
	margin: 4rem 0 2rem 0;
	font-size: 1.2rem;
}



/* -------------------------------------------

thanx

------------------------------------------- */
.thanx {
	text-align: center;
}

.back {
	text-align: center;
	display: block;
}

.back a {
	color: var(--prime);
}

@media screen and (max-width: 768px) {
	.thanx {
		text-align: left;
	}
}



/* -------------------------------------------

thanx

------------------------------------------- */
.thanx {
	text-align: center;
}

.back {
	text-align: center;
	display: block;
}

.back a {
	color: var(--prime);
}

@media screen and (max-width: 768px) {
	.thanx {
		text-align: left;
	}
}



/* -------------------------------------------

recruit

------------------------------------------- */
.recruit-person figure {
	width: 44rem;
	margin: 0 auto 3rem auto;
}

@media screen and (max-width: 768px) {
	.recruit-person figure {
		width: 100%;
	}
}

.recruit-person ul li {
	background: var(--bg-grey);
	padding: 1.5rem 0 3rem 0;
	font-size: 1.8rem;
}

.recruit-person ul li:not(:last-child) {
	margin-bottom: 3rem;
}

.recruit-person ul dt {
	background: var(--prime);
	color: #fff;
	font-weight: bold;
	width: 16rem;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 2.5rem;
	height: 4rem;
	padding-bottom: 0.15rem;
}

.recruit-person ul dd {
	padding: 0 3rem;
}

/* ---- interview ---- */
.recruit-interview ul li {
	border: solid 1px rgba(0, 0, 0, 0.3);
	padding: 3rem;
	position: relative;
}

@media screen and (max-width: 768px) {
	.recruit-interview ul li {
		padding: 2rem;
	}
}

.recruit-interview ul li:not(:last-child) {
	margin-bottom: 3rem;
}

/* interview-wrap */
.interview-wrap {
	display: flex;
	justify-content: space-between;
}

.interview-wrap figure {
	width: 40%;
}

.interview-wrap div {
	width: 56%;
}

.interview-wrap h4 {
	color: var(--prime);
	font-size: 2.0rem;
	margin-bottom: 1.5rem;
}

.interview-wrap p {
	line-height: 1.8;
}

@media screen and (max-width: 768px) {
	.interview-wrap {
		display: block;
	}

	.interview-wrap figure {
		width: 100%;
		margin-bottom: 2rem;
	}

	.interview-wrap div {
		width: 100%;
	}
}

/* interview-toggle */
.interview-toggle {
	position: absolute;
	right: 3rem;
	top: 3rem;
	border: solid 1px var(--prime);
	color: var(--prime);
	display: flex;
	align-items: center;
	justify-content: center;
	height: 4rem;
	padding: 0 2rem 0 2.5rem;
	transition: ease-in-out .3s;
	font-weight: bold;
}

@media screen and (max-width: 768px) {
	.interview-toggle {
		margin-top: 2rem;
		position: relative;
		right: auto;
		top: auto;
	}
}

.interview-toggle:hover {
	cursor: pointer;
	background: var(--prime);
	color: #fff;
}

.interview-toggle i {
	width: 2rem;
	height: 2rem;
	border-radius: 50%;
	margin-left: 0.5rem;
	position: relative;
	background: var(--prime);
}

.interview-toggle i::before,
.interview-toggle i::after {
	content: "";
	background: #fff;
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	border-radius: 10rem;
	transition: ease-in-out .3s;
}

.interview-toggle i::before {
	width: 1.2rem;
	height: 0.2rem;
}

.interview-toggle i::after {
	width: 0.2rem;
	height: 1.2rem;
}

.interview-toggle.open i::after {
	transform: translate(-50%, -50%) rotate(90deg);
}

/* interview-contents */
.interview-contents {
	padding-top: 3rem;
}

@media screen and (max-width: 768px) {
	.interview-contents {
		padding-top: 2rem;
	}
}

.interview-contents dt {
	margin-bottom: 0.8rem;
}

.interview-contents dd {
	padding: 0 1.5rem;
	line-height: 1.8;
}

.interview-contents dd:not(:last-of-type) {
	margin-bottom: 2.5rem;

}




/* -------------------------------------------

about

------------------------------------------- */
.sns {
	display: flex;
	align-items: center;
	margin-top: 3rem;
}

.sns li:not(:last-child) {
	margin-right: 2rem;
}

.sns li img {
	width: 4rem;
}

@media screen and (max-width: 768px) {
	.sns {
		justify-content: center;
	}

	.sns li img {
		width: 4rem;
	}

	.sns .more {
		padding-left: 3rem;
		padding-right: 3rem;
	}
}



/* -------------------------------------------

blog CMS

------------------------------------------- */
.topNews_list {
    display: flex;
    flex-wrap: wrap;
    gap: 3rem;
    list-style: none;
}
.topNews_item {
    display: inline-block;
    width: calc(33.33333333333% - 3rem * 2/3);
}
.topNews_image {
    margin-bottom: 1rem;
    position: relative;
    overflow: hidden;
    padding: 35%;
    aspect-ratio: 1/1;
}
.topNews_image img,
.topNews_image video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    transition: .2s;
}
.topNews_content {
    margin-top: 1.5rem; 
}
.topNews_caption {

}
.topNews_date {
    font-size: 1.2rem;
    width: fit-content;
    color: var(--prime);
}
.topNews_btn {
    display: flex;
    justify-content: center;
    margin: auto;
}
.news_link {
    font-weight: 500;
}
@media screen and (max-width: 767px) {
.topNews_list {
    flex-direction: column;
        margin-bottom: 32px;
    }
    .topNews_item {
        width: 100%;
    }
}
/* ---- news index ---- */
.news_container {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-gap: 20px;
  }
.news_item {
    display: flex;
    gap: 1.2rem;
    cursor: pointer;
}
.news_item:hover {
    opacity: 0.5;
}
.news_image {
    position: relative;
    width: 50%;
    overflow: hidden;
    aspect-ratio: 1/1;
}
.news_image img,
.news_image video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    transition: .2s;
    object-fit: cover;
}
.news_item:hover img {
    transform: translate(-50%, -50%) scale(1.2);
}
.news_content {
    width: 50%;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    padding: 1.2rem;
}
.news_caption {
    padding-top: 0;
    padding-bottom: 0;
    margin-bottom: 5px;
}
.news_date {
    font-size: 1.4rem;
    text-align: center;
    line-height: 1.2;
    padding-top: 0;
    padding-bottom: 0;
    align-self: flex-end;
}
.news_day {
    font-size: 2rem;
    text-align: right;
}
.news_month {
    font-size: 1.2rem;
}
.pagination {
    display: flex;
    justify-content: center;
    gap: 4px;
    margin-top: 3rem;
}
.pagination-number,
.pagination-arrow {
    font-size: 1.6rem;
    padding: 8px 12px;
}
.pagination-number.active {
    background-color: orange;
    color: white;
    cursor: default;
}
.pagination-no-number {
    align-self: center;
}
@media screen and (max-width: 767px) {
    .news_container {
        grid-template-columns: 1fr;
    }
    .news_item {
        flex-direction: column;
    }
    .news_image {
        width: 100%;
    }
    .news_content {
        width: calc(100% - 24px);
    }
}
/* ---- blog detail ---- */
.newsDetail_image img,
.newsDetail_image video {
    width: 100%;
    height: auto;
}
.newsDetail_content {
    margin-top: 3rem;
    font-size: 1.8rem;
}
.newsDetail_back-link {
    margin-top: 4rem;
    text-align: center;
}
.newsDetail_back-link a {
    color: var(--prime);
    position: relative;
    padding: 1rem 4rem;
}
.newsDetail_caption{
    white-space: pre-wrap; 
}