<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@charset "utf-8";

/* 変数設置 */
:root {
	--main-color: #0885A8;
	--sub-color: #FF6341;
	--btn-color: #CED9DC;
	--card-color: #fffaff;
	--card-color-blue: #e2f4f9;
}

main {
	margin: 0 auto;
	padding: 0;
	font-size: 16px;
	color: #001;
	font-weight: 400;
	letter-spacing: 0.05em;
	line-height: 1;
	height: 100%;
	font-family: "Lato", 'Noto Sans JP', YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, "メイリオ", Meiryo, sans-serif;
	position: relative;
}

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

　   HEADER

--------------------------------------------------------------------------------------------- */
.mv {
	background-image: url(../img/mv.webp);
	background-size: cover;
	background-position: center;
	color: var(--card-color);
	/* text-shadow: 2px 2px 5px #00001199; */
}

h1 {
	/* line-height: 1;
	filter: drop-shadow(1px 1px 13px #001);
	text-shadow: 1px 1px 24px #0000115c, -1px -1px 24px #0000115c; */
	line-height: 0.75;
	color: var(--main-color);
	font-weight: bold;
}

.mv p {
	line-height: 1.5;
	/* filter: drop-shadow(2px 2px 4px black); */
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
	/* background: linear-gradient(90deg, rgb(17 187 248) 0%, rgb(245 236 22) 50%, rgb(241 106 17) 100%); */
	background: linear-gradient(90deg, rgb(31 173 204) 0%, rgb(79 93 238) 30%, rgb(217 51 231) 60%, rgb(241 106 17) 100%);
	display: inline;
	font-weight: bold;
	/* color: var(--card-color); */
}

/* .mv .container div {
	line-height: 1.5;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
	background: linear-gradient(90deg, rgb(17 187 248) 0%, rgb(196 214 41) 50%, rgb(241 106 17) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	font-weight: bold;
} */

@media only screen and (max-width : 1280px) {
	.mv {
		height: 50svh;
	}

	.mv .container {
		margin-top: 1rem;
	}

	h1 {
		padding: 10px;
		font-size: 2.5rem;
	}

	.mv h1 span {
		font-size: 1.5rem;
	}

	.mv p {
		margin-top: 10%;
		font-size: 1.35rem;
		padding: 0 0.5rem;
	}

}

@media print,
screen and (min-width : 1280px) {
	.mv {
		height: 840px;
	}

	.mv h1 {
		padding: 2rem 4rem;
		font-size: 5rem;
	}

	.mv h1 span {
		font-size: 3.25rem;
	}

	.mv .container {
		margin-top: 13%;
	}

	.mv p {
		/* margin-top: 13%; */
		font-size: 4rem;
		padding: .5rem;
	}
}

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

　   フッタ

--------------------------------------------------------------------------------------------- */
#footer {
	color: #434343;
}

#footer p,
#footer li,
#footer li a {
	line-height: 1.8em;
}

#footer * {
	-webkit-box-sizing: content-box;
	-moz-box-sizing: content-box;
	box-sizing: content-box;
	*behavior: url(/scripts/boxsizing.htc);
	font-family: 'Noto Sans', "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

@media only screen and (max-width : 640px) {
	#footer {
		font-size: 13px;
	}

	#footer h3 {
		margin-bottom: 0;
		font-weight: normal;
		font-size: 100%;
	}
}

@media (max-width: 1200px) and (min-width: 641px) {
	#footer * {
		line-height: 1.8em;
		font-weight: normal;
		font-size: 11px;
	}
}

/* @media only screen and (max-width : 1024px) {
	#footer .sp_none {
		display: none;
	}
} */

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

　   COMMON

--------------------------------------------------------------------------------------------- */
section {
	padding: 4rem 0;
}

main h2 {
	color: var(--main-color);
	font-size: 3rem;
	font-weight: bold;
	margin-bottom: 4rem;
}

h2 span {
	font-size: 1.5rem;
}

main h3 {
	font-weight: bold;
}

main p {
	margin-bottom: 1rem;
}

p.catch {
	font-size: 2rem;
	font-weight: bold;
	color: #434343;
	margin-bottom: 2rem;
}

main .btn {
	background-color: var(--main-color);
	border-radius: 30px;
}

main .btn a {
	color: #fff;
	padding: 1rem 2rem;
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	display: flex;
	gap: 1rem;
}

main .btn a:after {
	content: "〉";
}

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

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

.txt-c {
	text-align: center;
}

.txt-r {
	text-align: right;
}

/* @media only screen and (max-width : 1280px) {
	main {
		padding-top: 60px;
	}
}

@media print,
screen and (min-width : 1280px) {
	main {
		padding-top: 70px;
	}
} */

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

　   Message メッセージ

--------------------------------------------------------------------------------------------- */
#message {
	position: relative;
	overflow: hidden;
}

#message .d-grid .catch {
	grid-area: catch;
}

#message .d-grid .contents {
	grid-area: content;
}

#message .d-grid .link {
	grid-area: link;
	align-self: end;
	justify-self: center;
}

@media only screen and (max-width : 1280px) {
	#message .d-grid {
		display: block;
	}

	#message .image-placeholder {
		position: inherit;
		margin-inline: auto;
	}

	.image-placeholder img {
		width: 100%;
		height: auto;
		margin-bottom: 1rem;
	}

	#message .d-grid .link {
		width: -webkit-fit-content;
		width: -moz-fit-content;
		width: fit-content;
		margin-inline: auto;
	}
}

@media print,
screen and (min-width : 1281px) {
	#message .d-grid {
		grid-template-columns: 1fr 700px;
		grid-template-areas: "catch ."
			"content link";
		grid-template-rows: auto auto;

	}

	#message .image-placeholder {
		position: absolute;
		width: 700px;
		height: 400px;
		/* background-color: #ccc; */
		top: 10%;
		right: 0;
		z-index: -1;
	}
}

@media print,
screen and (min-width : 1540px) {
	#message .d-grid {
		grid-template-columns: 700px 1fr;
	}

	#message .image-placeholder {
		width: 820px;
	}
}

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

　   Mission　私たちのミッション

--------------------------------------------------------------------------------------------- */
#mission .d-flex {
	align-items: center;
	gap: 1.5rem;
}

#mission .d-grid {
	display: grid;
	grid-template-columns: 120px 1fr;
	align-items: center;
	row-gap: 1.5rem;
}

#mission .d-grid div {
	aspect-ratio: 1/1;
	border-radius: 50%;
	display: grid;
	place-items: center;
	color: #fff;
}

#mission .d-grid div:nth-of-type(odd) {
	background-color: #0885a8;
}

#mission .d-grid div:nth-of-type(even) {
	background-color: #db3900;
}

#mission .d-grid p {
	margin: 0;
}

#mission .comment {
	margin-block: 5rem;
	line-height: 1.5;
	word-break: keep-all;
	overflow-wrap: anywhere;
	font-weight: bold;
}

@media only screen and (max-width : 1280px) {
	#mission img {
		width: 50%;
		height: auto;
		margin-inline: auto;
	}

	#mission .d-grid div {
		width: 75px;
	}
}

@media only screen and (max-width : 500px) {
	#mission img {
		width: 70%;

	}

	#mission .d-flex {
		flex-wrap: wrap;
	}

	#mission .d-grid {
		grid-template-columns: 90px 1fr;
		margin-inline: auto;
	}

}

@media print,
screen and (min-width : 1280px) {
	#mission .comment {
		font-size: 2rem;
	}

	#mission .d-grid div {
		width: 100px;
		font-size: 2rem;
	}

	#mission .d-grid p {
		font-size: 2rem;
	}
}

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

　  Ideal 求める人物像

--------------------------------------------------------------------------------------------- */
#ideal {
	background-color: rgb(8 133 168 / 20%);
	box-shadow: inset 0px 4px 10px #787C7C;
}

#ideal .card {
	border-radius: 15px;
	aspect-ratio: 3/4;
	flex-direction: column;
	padding: .5rem;
	background-color: var(--btn-color);
	background-size: cover;
}

#ideal .card.d-flex {
	justify-content: flex-end;
}

#ideal .card1 {
	background-image: url(../img/idea.webp);
}

#ideal .card2 {
	background-image: url(../img/teamwork.webp);
}

#ideal .card3 {
	background-image: url(../img/problem.webp);
}

#ideal .card4 {
	background-image: url(../img/growth.webp);
}

#ideal .card h3 {
	font-size: 1.5rem;
	margin: 1rem 0;
}

#ideal .card p {
	margin: 0;
	word-break: keep-all;
	overflow-wrap: anywhere;
}

/* #ideal .card {
	background-color: var(--card-color);
	border-radius: 20px;
	padding: 0.5rem;
}

#ideal .card h3 {
	font-size: 1.5rem;
	margin: 1rem 0;
}

#ideal .card img {
	display: block;
	width: 100%;
	aspect-ratio: 1/1;
} */

@media only screen and (max-width : 1280px) {
	#ideal .container&gt;.d-flex {
		flex-wrap: wrap;
		row-gap: 2rem;
		column-gap: 1rem;
	}

	#ideal .card {
		width: calc(100% / 2 - 1rem);
	}
}

@media only screen and (max-width : 500px) {
	#ideal .container&gt;.d-flex {
		flex-wrap: wrap;
		row-gap: 2rem;
		column-gap: 0;
	}

	#ideal .card {
		width: 100%;
	}
}

@media print,
screen and (min-width : 1280px) {
	#ideal .container&gt;.d-flex {
		gap: 1rem;
	}

	#ideal .card {
		width: calc(100% / 4 - 1rem);
	}

	/* #ideal .card1 {
		background-position: -111px -102px;
	}

	#ideal .card2 {
		background-position: -127px -276px;
	}

	#ideal .card3 {
		background-position: -190px -250px;
	}

	#ideal .card4 {
		background-position: -94px -185px;
	} */
}

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

　  Approach私たちの強み

--------------------------------------------------------------------------------------------- */
#approach .card.d-flex {
	align-items: center;
	gap: 2rem;
}

#approach .card.d-flex:nth-of-type(even) {
	flex-direction: row-reverse;
}

#approach .card h3 {
	font-size: 2rem;
	margin-bottom: 1rem;
}

@media only screen and (max-width : 500px) {
	#approach .card.d-flex {
		flex-direction: column !important;
	}
}

@media print,
screen and (min-width : 1280px) {}

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

　   Company data 数値で見る会社

--------------------------------------------------------------------------------------------- */
#data {
	background-image: url(../img/data_back.webp);
	background-size: cover;
}

#data h2 {
	color: var(--card-color);
}

#data .container&gt;.d-flex {
	flex-wrap: wrap;
	justify-content: space-around;
	gap: 2rem;
}

#data .card {
	padding: 1.5rem;
	background-color: var(--card-color);
	border-radius: 30px;
	display: flex;
	flex-direction: column;
	aspect-ratio: 2.5/1;
}

#data .txt-r {
	color: var(--card-color);
}

#data .card h3 {
	color: var(--sub-color);
	font-size: 2rem;
	text-align: center;
	margin: 0;
}

#data .card p {
	font-family: 'Noto Sans JP', YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, "メイリオ", Meiryo, sans-serif;
	text-align: center;
	font-weight: bold;
	z-index: 2;
	animation: graf-bigTxt .5s ease-in-out .8s alternate;
}

#data .card .d-flex {
	justify-content: center;
	align-items: center;
	gap: 3rem;
	margin-top: 1.5rem;
	height: 100%;
}

#data .comment {
	margin-block: 5rem;
	line-height: 1.5;
	word-break: keep-all;
	overflow-wrap: anywhere;
	font-weight: bold;
	color: var(--card-color);
}

#data .card p span {
	display: inline-block;
	font-size: 2em;
	transition: transform 0.5s ease, font-size 0.5s ease;
	/* アニメーション */
}

#data .card p span.is-inview {
	font-size: 2.5em;
	/* 拡大アニメーション */
}

#data .card p span {
	color: #DB3900;
}

/* #data .data1.card p:first-of-type span {
	color: #6c63ff;
}
#data .data1.card p:last-of-type span {
	color: #ff6584;
}
#data .data2.card p span {
	color: #ef8d21;
}
#data .data3.card p span {
	color: #0c9b44;
} */
@media only screen and (max-width : 1280px) {
	#data .card {
		width: calc(100% / 2 - 2rem);
	}

	#data .card p {
		font-size: 32px;
	}

	#data .comment {
		text-align: center;
	}
}

@media only screen and (max-width : 640px) {
	#data .card {
		width: 100%;
	}
}

@media print,
screen and (min-width : 1280px) {
	#data .card {
		width: calc(100% / 2 - 2rem);
	}

	#data .card p {
		font-size: 48px;
	}

	#data .comment {
		font-size: 2rem;
	}
}

/* 画像の動き等 */
.data1.card,
.data5.card,
.data6.card {
	position: relative;
}

.data1.card img,
.data5.card img {
	position: absolute;
}

#data .data1.card .d-flex {
	gap: 1.5rem;
}

#data .data1.card p {
	line-height: 1;
}

.data1.card img:nth-of-type(1) {
	left: 0;
	bottom: 2%;
}

.data1.card img:nth-of-type(2) {
	right: 0;
	top: 2%;
}



.data6.card p {
	z-index: 2;
}



.data5.card img:nth-of-type(1) {
	left: 0;
	bottom: 3%;
}

.data5.card img:nth-of-type(2) {
	right: 0;
	top: 11%;
}

.data6.card img {
	position: absolute;
	left: -2%;
	bottom: -2%;
}


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

	.data1.card img:nth-of-type(1),
	.data1.card img:nth-of-type(2) {
		height: 150px;
		top: 30%;
	}

	.data1.card img:nth-of-type(1) {
		left: 2%;
	}

	.data1.card img:nth-of-type(2) {
		right: 2%;
	}

	.data5.card img {
		height: 100px;
	}

	.data5.card img:nth-of-type(2) {
		right: 0;
		top: 24%;
	}

	.data6.card img {
		height: 110px;
		bottom: 0;
	}
}

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

　   Requirements 募集要項

--------------------------------------------------------------------------------------------- */
#requirements .d-flex {
	/*justify-content: center;*/
	gap: 1rem;
	border-bottom: 1px solid var(--btn-color);
	/*margin-bottom: 3rem;*/
}

#requirements button {
	background-color: var(--btn-color);
	border-radius: 16px 16px 0 0;
	color: var(--main-color);
	padding: 1rem .5rem;
	/*width: 260px;*/
	width: 15em;
	display: flex;
	justify-content: center;
	gap: 1rem;
	font-size: 1.5rem;
	font-weight: bold;
}

#requirements button.active {
	background-color: var(--main-color);
	color: #fff;
}

/*#requirements button:after {
	content: "&gt;";
	transform: rotate(90deg);
}*/

/* #requirements table:not(.active) {
	display: none;
}

#requirements th,
#requirements td {
	padding: 1.5rem;
	font-size: 1.5rem;
	border: solid 1px #605F5F;
	text-align: left;
} */

#requirements p {
	font-weight: bold;
	line-height: 1.5;
	margin-block: 5rem;
	word-break: keep-all;
	overflow-wrap: anywhere;
}

#requirements .btn {
	width: -webkit-fit-content;
	width: -moz-fit-content;
	width: fit-content;
	margin-inline: auto;
}

#requirements dt {
	background-color: #0885a8;
	color: #fff;
}

#requirements dt,
#requirements dd {
	padding: 1rem;
	text-align: left;
}

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

	/* #requirements th,
	#requirements td {
		display: block;
	}

	#requirements th {
		background-color: #ffe4e6;
	} */

	#requirements p {
		font-size: 1.25rem;
	}

	main .btn a {
		font-size: 1rem;
	}
}

@media print,
screen and (min-width : 1280px) {

	/* #requirements th {
		width: 440px;
		border-bottom: 1px #ffe4e6;
	}

	#requirements td {
		width: 440px;
		border-bottom: #001;
	} */
	#requirements .d-grid {
		grid-template-columns: 250px 1fr;
		grid-template-rows: 1fr 1fr;
		row-gap: 1rem;
		grid-template-areas: ". .";
	}

	#requirements dt,
	#requirements dd {
		font-size: 1.5rem;
	}

	#requirements p {
		font-size: 2rem;
	}
}

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

　   Welfare 福利厚生

--------------------------------------------------------------------------------------------- */
#welfare {
	background-color: rgb(8 133 168 / 20%);
	box-shadow: inset 0px 4px 10px #787C7C;
}

#welfare .d-flex {
	flex-wrap: wrap;
	justify-content: space-between;
}

#welfare .d-flex .card {
	background-color: var(--card-color);
	padding: 1.5rem;
	border-radius: 30px;
}

#welfare .d-flex .card img {
	margin-inline: auto;
	margin-bottom: 1.5rem;
	margin-inline: auto;
	display: block;
}

#welfare .d-flex .card h3 {
	font-size: 1.5rem;
	margin-bottom: 1rem;
}

#welfare .d-flex .card li:not(:last-of-type) {
	margin-bottom: .5rem;
}

@media only screen and (max-width : 1280px) {
	#welfare .d-flex {
		gap: 1rem;
	}

	#welfare .d-flex .card {
		width: 100%;
	}
}

@media print,
screen and (min-width : 1280px) {
	#welfare .d-flex {
		gap: 1rem;
	}

	#welfare .d-flex .card {
		width: calc(100% / 4 - 1rem);
	}
}

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

　   Picture

--------------------------------------------------------------------------------------------- */
#Pictures {
	background-image: url(../img/slide_backimg.webp);
	background-size: cover;
}

#Pictures .gallery {
	position: relative;
	overflow: hidden;
}

#Pictures .gallery img {
	aspect-ratio: 2.5/1;
	object-fit: cover;
	width: 100%;
	display: block;
}

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev,
.swiper-button-next {
	height: 50px !important;
	width: 50px !important;
}

/* 前へ次への矢印カスタマイズ */
.swiper-button-prev::after,
.swiper-button-next::after {
	background-repeat: no-repeat;
	background-size: contain;
	content: "" !important;
	height: 50px;
	margin: auto;
	width: 50px;
}

/* 前への矢印カスタマイズ */
.swiper-button-prev::after,
.swiper-button-next::after {
	background-image: url(../img/right.svg);
}

.swiper-button-prev::after {
	transform: scale(-1.1);
}

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

	.swiper-button-prev,
	.swiper-button-next,
	.swiper-button-prev::after,
	.swiper-button-next::after {
		height: 30px !important;
		width: 30px !important;
	}
}

/* .slide {
	overflow: hidden;
	padding-top: calc(149px - 4rem);
}

.slide ul li {
	z-index: 2;
}

.slide ul {
	animation: loop-slide 40s infinite linear 1s both;
} */
/* 
@keyframes loop-slide {
	from {
		transform: translateX(0);
	}

	to {
		transform: translateX(-100%);
	}
}

.slide ul li:nth-child(2) {
	margin-left: -20px;
	margin-top: 105px;
	z-index: 1;
}

.slide ul li:nth-child(3) {
	margin-top: -68px;
	margin-left: 100px;
}

.slide ul li:nth-child(4) {
	margin-left: 75px;
	margin-right: 100px;
	margin-top: 223px;

} */

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

　   animation

--------------------------------------------------------------------------------------------- */
/* .animation {
	opacity: 0;
} */
/* (初期値) */
.fadeIn {
	opacity: 0;
	transition: opacity .8s, transform .8s;
}

.fadeUp {
	opacity: 0;
	transform: translateY(30px);
	transition: opacity .8s, transform .8s;
}

.fadeIn-right {
	opacity: 0;
	transform: translateX(30px);
	transition: opacity .8s, transform .8s;
}

/* (スクロールした後) */
.fadeIn.is-inview {
	opacity: 1;
	transition-delay: .4s;
}

.fadeUp.is-inview {
	opacity: 1;
	transform: translateY(0);
	transition-delay: .2s;
}

.fadeIn-right.is-inview {
	opacity: 1;
	transform: translateX(0);
	transition-delay: .4s;
}

/* カードが順番に表示される*/
.cardfadeUp {
	opacity: 0;
	transform: translateY(50px);
	transition: all 0.4s ease-out;
}

.cardfadeUp.is-inview {
	opacity: 1;
	transform: translateY(0);
}

.mv p span {
	opacity: 0;
	display: inline-block;
	transition: opacity 0.3s ease, transform 0.3s ease;
	transform: translateY(20px);
}

.mv p span.is-inview {
	opacity: 1;
	transform: translateY(0);
}

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

@media print,
screen and (min-width : 1280px) {}</pre></body></html>