@charset "utf-8";
/* Copyright 2022 FSFIELD All Rights Reserved. */

/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

PC、タブレット、スマートフォン共通

_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

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

トップページ

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

/* .nav_global ul li a{
	color: #333;
} */

/*▼▼▼▼231011_ヒロミ掲載時のみスタイル変更▼▼▼▼*/
/* .nav_global ul li.g09 a{	
	width: 120px;	
	padding: 12px 0;	
	background: #0270BB;	
	color: #FFF;	
	text-align: center;	
	border-radius: 40px;	
	transition: background .3s, color .3s;	
	}	
	.scroll-nav .nav_global ul li.g09 a{	
	background: #0270BB;	
	color: #FFF;	
	}	
	.nav_global ul li.g09 a:hover{	
	background: #333;	
	color: #FFF;	
	opacity: 1;	
	}	 */
/*▲▲▲▲ここまで▲▲▲▲*/

/* 休業のお知らせ-モーダルウィンドウ
---------------------------------------------- */

.overlary_news {
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 1000;
	width: 100vw;
	height: 100vh;
	padding: 50px;
	background-color: rgba(0, 0, 0, 0.8);
	opacity: 0;
	visibility: hidden;
	transition: 0.5s;
}

.overlary_news.active {
	opacity: 1;
	width: 100%;
	visibility: visible;
}

.overlary_news .inner_overlary {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%) translateY(-50%);
	width: 1000px;
	background: url("../img/home/bg_news01.jpg") no-repeat center center;
	padding: 80px 30px;
}

.inner_overlary .inner {
	width: 800px;
	margin: 0 auto;
}

.inner_overlary .inner h3 {
	font-size: 3rem;
	letter-spacing: 0.1em;
	margin-bottom: 25px;
	color: #0270BB;
}

.inner_overlary .inner>p {
	letter-spacing: 0.1em;
	margin-bottom: 22px;
}

.inner_overlary .inner>p:last-child {
	margin-bottom: 0;
}

.inner_overlary .inner>p>span {
	color: #0270BB;
}

.close_overlay {
	width: 50px;
	height: 50px;
	position: fixed;
	top: 0;
	right: 0;
	z-index: 9999;
	cursor: pointer;
	background: #0270BB;
}

.close_overlay:before,
.close_overlay:after {
	display: block;
	content: "";
	position: absolute;
	top: 23px;
	right: 12px;
	width: 23px;
	height: 2px;
	background: #FFF;
}

.close_overlay:before {
	transform: rotate(45deg);
}

.close_overlay:after {
	transform: rotate(-45deg);
}

.close_overlay span {
	display: none;
}


/* メインビジュアル
---------------------------------------------- */
.main {
	width: 100%;
	position: relative;
	padding: 6px 0 0 3.64vw;
}

.main_inner {
	position: relative;
}

/*--231011_.limited　ヒロミ掲載時のみ使用--*/
.main_inner .limited img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: relative;
}

.main_inner .swiper-slide img {
	width: 100%;
	height: calc(100vh - 6px);
	object-fit: cover;
	position: relative;
}

.main_inner .txt_main {
	width: 42.34vw;
	max-width: 813px;
	height: 10.468vw;
	max-height: 201px;
	position: absolute;
	left: min(6.25vw, 120px);
	bottom: min(9.6vw, 200px);
	z-index: 1;
}

.main_inner .txt_main p:nth-of-type(2) {
	display: none;
}

.txt_main img {
	width: 100%;
	height: auto;
}

/*--scrolldown--*/
.main .scrolldown {
	overflow: hidden;
	display: flex;
	align-items: center;
	position: absolute;
	left: 2.4vw;
	bottom: 205px;
	transform: rotate(90deg);
	transform-origin: 0 0;
}

.main .scrolldown .txt {
	font-family: "Amiri";
	font-size: 1.4rem;
	line-height: 1;
	font-weight: 700;
	color: #0270BB;
	padding-right: 14px;
	display: inline-block;
}

.main .scrolldown .bdr {
	overflow: hidden;
	position: relative;
	display: block;
	width: 170px;
}

.main .scrolldown .bdr::after {
	content: "";
	display: block;
	height: 1px;
	width: 170px;
	background: #D9D9D9;
}

.main .scrolldown .bdr::before {
	content: "";
	display: block;
	width: 30px;
	height: 1px;
	background: #0270BB;
	position: absolute;
	top: 0;
	right: 172px;
	animation: scrolldown 2s ease-in-out infinite forwards;
}

@keyframes scrolldown {
	0% {
		transform: translate3d(0, 0, 0);
		opacity: 1;
	}

	75% {
		transform: translate3d(202px, 0, 0);
		opacity: 1;
	}

	100% {
		transform: translate3d(202px, 0, 0);
		opacity: 0;
	}
}

/*--バナー--*/
.main_banner{
	width: calc(100%/1850*454);
	position: absolute;
	bottom: calc(100%/880*138);
	right: calc(100%/1850*177);
	z-index: 1;
}

.main_banner a{
	display: block;
	transition: filter .3s;
}

.main_banner a:hover{
	filter: brightness(1.1);
}

.main_banner a img{
	width: 100%;
	height: auto;
}

/* お知らせ
---------------------------------------------- */
.sec_news {
	padding: 100px 0;
	border-bottom: 1px solid #CBD6DE;
}

.sec_news .inner {
	text-align: center;
}

.sec_news .inner .heading01::before {
	left: 50%;
	margin-left: -35px;
}

.sec_news .inner .heading01::after {
	left: 50%;
	transform: translateX(calc(-50%));
}


/* 私たちの想い
---------------------------------------------- */
.sec_idea {
	background: url("../img/home/bg_idea01.jpg") no-repeat right 0;
	background-size: contain;
	padding: 120px 0 120px 3.64vw;
	display: flex;
	align-items: center;
	flex-direction: row-reverse;
}

.sec_idea .inner {
	padding: 0 7.56%;
	width: 37.84%;
	min-width: 570px;
}

.sec_idea .inner .heading02 {
	margin-bottom: 30px;
}

.sec_idea .inner .txt p {
	line-height: 2;
	margin-bottom: 15px;
}

.sec_idea .inner .txt p:last-of-type {
	margin-bottom: 0;
}

.sec_idea .image {
	width: 62.16%;
}

.sec_idea .image img {
	width: 100%;
	min-height: 440px;
	height: auto;
	object-fit: cover;
	object-position: 0 center;
}

/* 事業紹介
---------------------------------------------- */
.sec_service {
	padding-top: 120px;
	position: relative;
	overflow: hidden;
}

.sec_service::before {
	content: "Service";
	font-family: "Amiri";
	font-size: 40rem;
	color: #FFF;
	line-height: 1;
	letter-spacing: -0.03em;
	opacity: 0.8;
	position: absolute;
	top: 100px;
	left: -25px;
	z-index: -1;
}

.sec_service .heading01 {
	text-align: center;
}

.sec_service .heading01::before {
	left: 50%;
	margin-left: -35px;
}

.sec_service .heading01::after {
	left: 50%;
	transform: translateX(calc(-50%));
}

.sec_service .heading02 {
	text-align: center;
}

.nav_service {
	display: flex;
}

.service {
	display: contents;
}

.service a {
	flex: 1;
	min-height: 640px;
	transition: flex .3s;
	background-size: cover;
}

.service:nth-of-type(1) a {
	background: url("../img/home/img_service01.jpg") no-repeat center;
}

.service:nth-of-type(2) a {
	background: url("../img/home/img_service02.jpg") no-repeat center;
}

.service:nth-of-type(3) a {
	background: url("../img/home/img_service03.jpg") no-repeat center;
}

.service a.focus-visible {
	outline: 2px dotted #FFF;
	outline-offset: -3px;
}

.service:hover a {
	flex: 1 1 20%;
	background-size: cover;
}

.service.not_active .inner {
	opacity: 0;
}

.service .inner {
	padding: 50px;
	height: 100%;
	display: flex;
	justify-content: flex-end;
	flex-direction: column;
	transition: backdrop-filter .5s, opacity .1s;
}

.service:hover .inner {
	backdrop-filter: blur(0px) saturate(150%) brightness(110%) contrast(105%);
}

.service .inner h3 {
	font-size: 2.8rem;
	line-height: 1;
	font-weight: 700;
	color: #FFF;
	letter-spacing: 4px;
	margin-bottom: 30px;
}

.service .inner .txt {
	letter-spacing: 0;
	color: #FFF;
	margin-bottom: 30px;
}

.service .inner .ico_arrow01 {
	position: relative;
	width: 80px;
	height: 80px;
	border-radius: 80px;
	border: 1px solid #b9b9b9;
	transition: .3s;
	display: flex;
	justify-content: center;
	align-items: center;
}

.service .inner .ico_arrow01 svg {
	width: 22px;
	height: 22px;
	fill: #FFF;
}

.service:hover .inner .ico_arrow01 {
	width: 60px;
	height: 60px;
	border: 1px solid #FFF;
	background: #FFF;
}

.service:hover .inner .ico_arrow01 svg {
	fill: #0270BB;
}

/* 会社案内
---------------------------------------------- */
.sec_company {
	background: #E5ECF0;
	padding: 120px 0;
	position: relative;
	overflow: hidden;
}

.company {
	padding: 0 0 0 20%;
	position: relative;
	z-index: 1;
}

.company::after {
	content: "Company";
	font-family: "Amiri";
	font-size: 30rem;
	color: #FFF;
	line-height: 1;
	letter-spacing: -0.03em;
	opacity: 0.4;
	position: absolute;
	top: -30px;
	left: 395px;
	z-index: -1;
	pointer-events: none;
}

.nav_company {
	display: flex;
	justify-content: space-between;
	position: relative;
	z-index: 1;
}

.nav_company .item {
	width: calc(50% - 20px);
}

.nav_company .item .image {
	overflow: hidden;
	margin-bottom: 30px;
}

.nav_company .item .image img {
	width: 100%;
	height: auto;
	transform: scale(1.07);
	transition: transform .3s;
}

.nav_company .item:hover .image img {
	transform: scale(1);
}

.nav_company .item a {
	display: block;
	color: #333;
}

.nav_company .item h3 {
	font-size: 1.8rem;
	letter-spacing: 0.02em;
	display: flex;
	margin-bottom: 15px;
}

.nav_company .item h3 .ico_arrow01 {
	background: #0270BB;
	width: 20px;
	height: 20px;
	border-radius: 20px;
	display: flex;
	justify-content: center;
	align-items: center;
	margin-right: 10px;
}

.nav_company .item h3 .ico_arrow01 svg {
	width: 16px;
	height: 16px;
	fill: #FFF;
}

.nav_company .item h3 .word {
	line-height: 1;
	transition: color .3s;
}

.nav_company .item:hover h3 .word {
	color: #0270BB;
}

.nav_company .item .txt {
	letter-spacing: 0;
	padding-right: 20px;
}

#waveCanvas {
	width: 100%;
	transform: scale(-1, 1);
	position: absolute;
	top: 160px;
	left: 0;
}

/* 採用情報
---------------------------------------------- */
.sec_recruit {
	background: url("../img/home/bg_recruit01.jpg") no-repeat right center;
	background-size: cover;
	position: relative;
	padding: 373px 20% 160px 0;
	margin-top: -373px;
	overflow: hidden;
}

.sec_recruit::after {
	content: "Recruit";
	font-family: "Amiri";
	font-size: 30rem;
	color: #FFF;
	line-height: 1;
	letter-spacing: -0.03em;
	opacity: 0.5;
	position: absolute;
	left: -10px;
	bottom: 25px;
	z-index: 1;
	pointer-events: none;
}

.recruit {
	background: url("../img/home/bg_recruit02.jpg") no-repeat 0 0;
	background-size: cover;
	padding: 50px;
	display: flex;
	justify-content: space-between;
	flex-direction: row-reverse;
}

.recruit .btn {
	width: 340px;
	height: 340px;
	border-radius: 340px;
	background: #FFF;
	flex: none;
}

.recruit .btn a {
	width: 340px;
	height: 340px;
	border-radius: 340px;
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
}

.recruit .btn a .txt_recruit_animation01 {
	width: 300px;
	height: 300px;
	position: absolute;
	top: 20px;
	left: 20px;
	z-index: 2;
	animation: rotate 22s linear infinite;
	fill: #D3D9DA;
	transition: fill .3s;
	display: block;
	pointer-events: none;
}

.recruit .btn a .txt_recruit_animation01 svg {
	width: 100%;
	height: 100%;
}

.recruit .btn a:hover .txt_recruit_animation01 {
	fill: #0270BB;
	animation-play-state: paused;
}

@keyframes rotate {
	0% {
		transform: rotate(360deg);
	}

	100% {
		transform: rotate(0);
	}
}

.recruit .btn .inner {
	align-items: center;
	height: 117.5px;
	margin-top: 30px;
	position: relative;
}

.recruit .btn .inner h1 {
	width: 156px;
}

.recruit .btn .inner h1 img {
	width: 100%;
	height: auto;
}

.recruit .btn .ico_arrow01 {
	width: 60px;
	height: 60px;
	border: 1px solid #E2E5EA;
	border-radius: 60px;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all .3s;
	position: absolute;
	left: 50%;
	bottom: 0;
	margin-left: -30px;
}

.recruit .btn a:hover .ico_arrow01 {
	width: 40px;
	height: 40px;
	border: 1px solid #0270BB;
	margin-left: -20px;
	bottom: 10px;
}

.recruit .btn .ico_arrow01 svg {
	width: 22px;
	height: 22px;
	fill: #0270BB;
}

.recruit .lead {
	padding: 60px 30px 0 0;
	font-size: 2.8rem;
	color: #FFF;
	font-weight: 700;
	letter-spacing: 0.2em;
	text-shadow: 0px 0px 6px rgba(0, 0, 0, 0.2);
}

/* ACCEL JAPAN バナーエリア
---------------------------------------------- */
.sec_banner {
	background: url("../img/home/bg_banner01.jpg") no-repeat 0 0;
	background-size: cover;
	position: relative;
	padding: 70px 0;
	text-align: center;
}

.sec_banner .sp {
	display: none;
}

/* 導入事例のご紹介
---------------------------------------------- */
.sec_voice {
	padding: 120px 40px;
	position: relative;
}

.sec_voice::before {
	content: "";
	display: block;
	background: url(../img/home/bg_voice01.jpg) no-repeat 0 0 / cover;
	width: 50%;
	max-width: 960px;
	padding-top: min(calc(100%/1920*600), 600px);
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.sec_voice::after {
	content: "Voice";
	font-family: "Amiri";
	font-size: 30rem;
	color: #FFF;
	line-height: 1;
	letter-spacing: -0.03em;
	opacity: 0.4;
	position: absolute;
	top: -30px;
	right: 0;
	z-index: -1;
	pointer-events: none;
}

.sec_voice_inner {
	overflow: hidden;
	max-width: 1260px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
}

.sec_voice_inner .heading01 {
	margin-bottom: 40px;
}

.sec_voice_inner .heading01::before {
	left: 50%;
	margin-left: -35px;
}

.sec_voice_inner .heading01::after {
	left: 50%;
	transform: translateX(calc(-50%));
}

.sec_voice_inner .btn_type01 {
	margin-top: 50px;
}

.voiceList {
	width: 430px;
	overflow: visible !important;
}

.voiceCard {
	padding: 0 15px;
}

.voiceCard a {
	display: block;
	background-color: #FFF;
	height: 100%;
	color: #333;
}

.voiceCard_image {
	position: relative;
	padding-top: calc(100%/400*300);
}

.voiceCard_image img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.voiceCard_inner {
	position: relative;
	padding: 25px 25px 20px;
}

.voiceCard_company {
	line-height: normal;
	margin-bottom: 18px;
	display: flex;
	align-items: center;
	gap: 5px;
	font-size: 1.4rem;
	font-weight: 700;
}

.voiceCard_company svg {
	display: inline-block;
	width: 14px;
	height: 14px;
	fill: #0270BB;
	margin-top: 2px;
}

.voiceCard_ttl {
	line-height: 1.4;
	margin-bottom: 45px;
	display: -webkit-box;
    overflow: hidden;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
}

.voiceCard_location {
	line-height: normal;
	width: calc(100% - 50px);
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 1.4rem;
}

.voiceCard_location::before {
	content: "";
	display: block;
	background-color: #0270BB;
	width: 6px;
	height: 6px;
	border-radius: 50%;
}

.voiceCard_arrow {
	width: 30px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	bottom: 20px;
	right: 20px;
}

.voiceCard_arrow {
	width: 30px;
	height: 30px;
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	bottom: 20px;
	right: 20px;
}

.voiceCard_arrow::before {
	content: "";
	display: block;
	border: 1px solid #E2E5EA;
	border-radius: 50%;
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	transition: transform .3s;
}

.voiceCard a:hover .voiceCard_arrow::before {
	transform: scale(0.8);
}

.voiceCard_arrow svg {
	width: 16px;
	height: 16px;
	fill: #0270BB;
}


@media only screen and (max-width:1295px) {
	/* 表示領域が1295px以下の場合に適用するスタイル */

	/* 採用情報
	---------------------------------------------- */
	.recruit .lead br {
		display: none;
	}


}

/*--@media--*/


@media only screen and (max-width:1024px) {
	/* 表示領域が1024px以下の場合に適用するスタイル */

	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	タブレット

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

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

	トップページ

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

	.nav_global ul li a {
		color: #FFF;
	}

	/* 休業のお知らせ-モーダルウィンドウ
	---------------------------------------------- */
	.overlary_news .inner_overlary {
		width: calc(100% - 100px);
	}

	.inner_overlary .inner {
		width: auto;
	}

	/* メインビジュアル
	---------------------------------------------- */
	.main {
		padding: 0 0 0 15px;
	}

	.main_inner .swiper-slide img {
		height: calc(100vh - 64px);
	}

	.main_inner .txt_main {
		width: calc(100% - 40px);
		max-width: 320px;
		height: auto;
		max-height: 181px;
		left: 20px;
		bottom: 80px;
	}

	.main_inner .txt_main p:nth-of-type(1) {
		display: none;
	}

	.main_inner .txt_main p:nth-of-type(2) {
		display: block;
	}

	/*--scrolldown--*/
	.main .scrolldown {
		display: none;
	}

	/*--バナー--*/
	.main_banner{
		width: calc(100%/360*220);
		bottom: calc(100%/500*30);
		right: unset;
		left: 0;
	}

	/* お知らせ
	---------------------------------------------- */
	.sec_news {
		padding: 50px 15px;
	}

	/* 私たちの想い
	---------------------------------------------- */
	.sec_idea {
		background: url("../img/home/bg_idea01_sp.jpg") no-repeat right 0;
		background-size: 80%;
		padding: 50px 15px 90px 15px;
		flex-direction: column-reverse;
	}

	.sec_idea .inner {
		padding: 0;
		width: 100%;
		min-width: unset;
	}

	.sec_idea .inner .heading02 {
		margin-bottom: 20px;
	}

	.sec_idea .image {
		width: 100%;
		margin-bottom: 40px;
	}

	.sec_idea .image img {
		min-height: unset;
	}

	/* 事業紹介
	---------------------------------------------- */
	.sec_service {
		padding: 0;
	}

	.sec_service::before {
		font-size: 20rem;
		top: 126px;
		left: -10px;
	}

	.sec_service .heading01 {
		padding: 0 15px 20px;
		text-align: left;
	}

	.sec_service .heading01::before {
		left: 15px;
		margin-left: unset;
	}

	.sec_service .heading01::after {
		left: 15px;
		transform: none;
	}

	.sec_service .lead {
		padding: 0 15px 60px;
	}

	.sec_service .lead .heading02 {
		text-align: left;
		margin-bottom: 0;
	}

	.nav_service {
		display: block;
	}

	.service {
		display: block;
	}

	.service a {
		display: flex;
		align-items: flex-end;
		min-height: 375px;
		transition: unset;
		background-size: cover !important;
	}

	.service:hover a {
		flex: unset;
		background-size: unset;
	}

	.service .inner {
		padding: 30px 20px;
	}

	.service.not_active .inner {
		opacity: 1;
	}

	.service:hover .inner {
		backdrop-filter: unset;
	}

	.service .inner h2 {
		font-size: 2rem;
		margin-bottom: 15px;
	}

	.service .inner .txt {
		margin-bottom: 20px;
	}

	.service .inner .ico_arrow01,
	.service:hover .inner .ico_arrow01 {
		width: 50px;
		height: 50px;
		border-radius: 50px;
	}

	.service:hover .inner .ico_arrow01 {
		border: 1px solid #b9b9b9;
		background: unset;
	}

	.service:hover .inner .ico_arrow01 svg {
		fill: #FFF;
	}

	/* 会社案内
	---------------------------------------------- */
	.company::after {
		font-size: 20rem;
		top: 50px;
		left: 280px;
	}

	/* 採用情報
	---------------------------------------------- */
	.sec_recruit {
		background: url("../img/home/bg_recruit01_sp.jpg") no-repeat 0 0;
		background-size: cover;
		padding: 320px 15px 100px 0;
		margin-top: -320px;
	}

	.sec_recruit::after {
		font-size: 20rem;
		letter-spacing: -0.03em;
		left: -10px;
		bottom: 12px;
	}

	.recruit {
		background: url("../img/home/bg_recruit02_sp.jpg") no-repeat 0 0;
		background-size: cover;
		padding: 62px 40px 80px 15px;
		flex-direction: column-reverse;
	}

	.recruit .btn,
	.recruit .btn a {
		width: 260px;
		height: 260px;
		border-radius: 260px;
	}

	.recruit .btn a .txt_recruit_animation01 {
		width: 228px;
		height: 228px;
		top: 17px;
		left: 17px;
	}

	.recruit .btn .inner {
		height: 93.8px;
		margin-top: 25px;
	}

	.recruit .btn .inner h1 {
		width: 118.48px;
		margin-bottom: 20px;
	}

	.recruit .btn .ico_arrow01,
	.recruit .btn a:hover .ico_arrow01 {
		width: 50px;
		height: 50px;
		border-radius: 50px;
		margin-left: -25px;
		bottom: unset;
	}

	.recruit .btn .ico_arrow01 svg {
		width: 22px;
		height: 22px;
	}

	.recruit .lead {
		padding: 0;
		font-size: 2rem;
		margin-bottom: 40px;
	}

	.recruit .lead br {
		display: block;
	}

	/* ACCEL JAPAN バナーエリア
	---------------------------------------------- */
	.sec_banner {
		background: url("../img/home/bg_banner01_sp.jpg") no-repeat 0 0;
		background-size: cover;
		position: relative;
		padding: 64px 30px;
	}

	.sec_banner figure img {
		width: 100%;
	}

	.sec_banner .pc {
		display: none;
	}

	.sec_banner .sp {
		display: block;
	}

	/* 導入事例のご紹介
	---------------------------------------------- */
	.sec_voice::after {
		font-size: 20rem;
		top: -20px;

	}
}

/*--@media--*/


@media only screen and (max-width:767px) {
	/* 表示領域が767px以下の場合に適用するスタイル */
	/*_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/

	スマートフォン（iPhone,Android)

	_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_/_*/

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

	トップページ

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

	/* 休業のお知らせ-モーダルウィンドウ
	---------------------------------------------- */
	.overlary_news {
		padding: 50px 15px;
	}

	.overlary_news .inner_overlary {
		width: calc(100% - 30px);
		padding: 20px 15px;
	}

	.inner_overlary .inner h3 {
		font-size: 1.5rem;
		margin-bottom: 15px;
	}

	.inner_overlary .inner>p {
		font-size: 1.2rem;
		margin-bottom: 15px;
	}

	.close_overlay {
		width: 35px;
		height: 35px;
	}

	.close_overlay:before,
	.close_overlay:after {
		width: 17px;
		top: 17px;
		right: 9px;
	}

	/* 私たちの想い
	---------------------------------------------- */
	.sec_idea .inner .lead {
		font-size: 2rem;
		margin-bottom: 15px;
	}

	.sec_idea .inner .txt p {
		margin-bottom: 10px;
	}

	/* 事業紹介
	---------------------------------------------- */
	.sec_service::before {
		font-size: 13rem;
		top: 145px;
	}

	/* 会社案内
	---------------------------------------------- */
	.sec_company {
		padding: 60px 15px 100px;
	}

	.company {
		padding: 0;
	}

	.company::after {
		font-size: 10rem;
		top: 100px;
		left: -15px;
	}

	.nav_company {
		display: block;
	}

	.nav_company .item {
		width: 100%;
	}

	.nav_company .item:not(:last-of-type) {
		margin-bottom: 50px;
	}

	.nav_company .item .image {
		margin-bottom: 25px;
	}

	.nav_company .item h3 .word {
		letter-spacing: 0.2em;
	}

	#waveCanvas {
		top: 150px;
	}

	/* 採用情報
	---------------------------------------------- */
	.sec_recruit::after {
		font-size: 13rem;
		bottom: 45px;
	}

	/* 導入事例のご紹介
	---------------------------------------------- */
	.sec_voice {
		padding: 70px 0 60px;
	}

	.sec_voice::before {
		width: calc(100%/375*280);
		padding-top: calc(100%/375*175);
	}

	.sec_voice::after {
		font-size: 10rem;

		top: -10px;
	}

	.sec_voice_inner .heading01 {
		margin-bottom: 30px;
	}

	.sec_voice_inner .btn_type01 {
		margin-top: 30px;
	}

	.voiceList {
		width: calc(100%/375*275);
	}

	.voiceCard {
		padding: 0 5px;
	}

	.voiceCard_inner {
		padding: 25px 20px;
	}

	.voiceCard_company {
		font-size: 1.3rem;
	}

	.voiceCard_ttl {
		display: -webkit-box;
		overflow: hidden;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		margin-bottom: 30px;
	}

	.voiceCard_location {
		font-size: 1.3rem;
	}

}

/*--@media--*/


@media only screen and (max-width:562px) {
	/* 表示領域が562px以下の場合に適用するスタイル */

	/* 事業紹介
	---------------------------------------------- */
	.sec_service .lead .heading02 br:nth-of-type(2) {
		display: none;
	}


}

/*--@media--*/


@media only screen and (max-width:476px) {
	/* 表示領域が476px以下の場合に適用するスタイル */

	/* 事業紹介
	---------------------------------------------- */
	.sec_service::before {
		top: 180px;
	}


}

/*--@media--*/


@media only screen and (max-width:432px) {
	/* 表示領域が432px以下の場合に適用するスタイル */

	/* 会社案内
	---------------------------------------------- */
	.company .heading02 br {
		display: none;
	}


}

/*--@media--*/


@media only screen and (max-width:364px) {
	/* 表示領域が364px以下の場合に適用するスタイル */

	/* 事業紹介
	---------------------------------------------- */
	.sec_service .lead .heading02 br:nth-of-type(1) {
		display: none;
	}


}

/*--@media--*/


@media only screen and (max-width:354px) {
	/* 表示領域が354px以下の場合に適用するスタイル */

	/* 事業紹介
	---------------------------------------------- */
	.sec_service::before {
		top: 214px;
	}


}

/*--@media--*/