@charset "UTF-8";

/* ------------------------------------------------
                   Company
--------------------------------------------------- */

/*---------- 共通 ----------*/

/* ページタイトル */
.sec-page-ttl {
	width: 100%;
	height: 300px;
	padding: 20px 0;
	position: relative;
}
.page-ttl-bg {
	width: 100%;
	height: 100%;
	background: url("../../img/company/bg_ttl.jpg") center top -21.2222px no-repeat;
	background-size: cover;
	position: absolute;
	top: 0;
	left: 0;
}
/*
.sec-page-ttl::before {
	content: '';
	width: 100%;
	height: 100%;
	background: rgba(0, 0, 0, 0.35);
	position: absolute;
	top: 0;
	left: 0;
	mix-blend-mode: multiply;
}
*/
.sec-page-ttl .cont-inn {
	height: 100%;
}
.page-ttl-wrap {
	width: 100%;
	max-width: 960px;
	text-align: left;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}
.page-ttl-en {
	margin-bottom: 10px;
	color: #fff;
	font-size: 1.7rem;
    font-weight: 500;
	line-height: 1.73;
	letter-spacing: 0.05em;
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-variation-settings:
	"wdth" 100;
}
.page-ttl {
	color: #fff;
	font-size: 3.8rem;
    font-weight: 500;
	line-height: 1.05;
}
.page-sub-ttl {
	margin-top: 30px;
	color: #fff;
	font-size: 1.9rem;
	line-height: 2.05;
}

/* パンクズ */
.breadcrumbs, 
.breadcrumbs a {
	color: #fff;
}

/* セクションタイトル */
.sec-ttl-en {
	margin-bottom: 10px;
	color: var(--color-black);
	font-size: 1.7rem;
    font-weight: 500;
	line-height: 1.35;
	letter-spacing: 0.05em;
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-variation-settings:
	"wdth" 100;
	opacity: 0.5;
}
.sec-ttl {
	color: var(--color-black);
	font-size: 2.3rem;
    font-weight: 500;
	line-height: 1.73;
}
.sec-lead-txt {
	margin-top: 30px;
	color: var(--color-black);
	font-size: 1.7rem;
    font-weight: 600;
	line-height: 1.85;
}

@media (max-width: 768px) {
	/* ページタイトル */
	.sec-page-ttl {
		width: 100%;
		height: 120vw;
		padding: 1.6vw 0 50.13vw;
		background: #fff;
		border-top: 1px solid var(--color-blue);
	}
	.page-ttl-bg {
		width: 100%;
		height: 50.13vw;
		background: url("../../img/company/bg_ttl_sp.jpg") center top 0 no-repeat;
		background-size: 120%;
		position: absolute;
		top: auto;
		bottom: 0;
		left: 0;
	}
	/*
	.sec-page-ttl::after {
		content: '';
		width: 100%;
		height: 50.13vw;
		background: url("../../img/company/bg_ttl_sp.jpg") center center no-repeat;
		background-size: cover;
		position: absolute;
		bottom: 0;
		left: 0;
	}*/
	.page-ttl-wrap {
		max-width: initial;
		text-align: center;
	}

	/* パンクズ */
	.breadcrumbs, 
	.breadcrumbs a {
		color: #000;
	}
	

	/* ページタイトル */
	.page-ttl-en {
		margin-bottom: 2.66vw;
		color: var(--color-black);
		font-size: var(--fs-sp-14);
		opacity: 0.5;
	}
	.page-ttl {
		color: #000;
		font-size: var(--fs-sp-30);
		text-shadow: none;
	}
	.page-sub-ttl {
		margin-top: 8vw;
		color: var(--color-black);
		font-size: var(--fs-sp-17);
		font-weight: 600;
		text-shadow: none;
	}


	/* セクションタイトル */
	.sec-ttl-en {
		margin-bottom: 1.33vw;
		font-size: var(--fs-sp-14);
	}
	.sec-ttl {
		font-size: var(--fs-sp-23);
	}
	.sec-lead-txt {
		margin-top: 8vw;
		font-size: var(--fs-sp-17);
	}

	
	
}



/*---------- ページ コピー ----------*/
.sec-page-copy {
	width: 100%;
	padding: 70px 0 40px;
	text-align: center;
}
.page-copy {
	color: var(--color-black);
	font-size: 1.9rem;
	line-height: 2;
}

@media (max-width: 768px) {
	.sec-page-copy {
		padding: 13.33vw 0 0vw;
		text-align: left;
	}
	.page-copy {
		color: var(--color-gray);
		font-size: var(--fs-sp-14);
	}
}


/*---------- 会社概要 ----------*/
.sec-profile {
	width: 100%;
	padding: 50px 0 110px;
	position: relative;
}
.sec-profile .cont-inn {
	max-width: 960px;
}

.profile-outline {
	width: 100%;
	margin-top: 50px;
}
.profile-outline dt {
	width: 330px;
	padding: 20px 0 20px 5px;
	border-top: 1px solid rgba(68, 68, 68, 0.3);
	font-size: 1.5rem;
}
.profile-outline dd {
	width: calc(100% - 330px);
	padding: 20px 0;
	display: flex;
	flex-wrap: wrap;
	border-top: 1px solid rgba(68, 68, 68, 0.3);
	font-size: 1.5rem;
	font-weight: 500;
	line-height: 1.8;
}
.profile-outline dd .profile-position {
	width: 210px;
}
.profile-outline dd .profile-name {
	width: calc(100% - 210px);
}
.profile-outline dd .txt-indent {
	width: 100%;
	text-indent: -1.1em;
	padding-left: 1.1em;
}
.profile-outline dd .txt-indent a.normal-link {
	display: inline;
}



@media (max-width: 768px) {
	.sec-profile {
		width: 100%;
		padding: 29.33vw 0 17.33vw;
	}
	
	.sec-profile .cont-inn {
		max-width: 73.33vw;
	}

	.profile-outline {
		width: 100%;
		margin-top: 8vw;
		border-bottom: 1px solid rgba(68, 68, 68, 0.3);
	}
	.profile-outline dt {
		width: 21.33vw;
		padding: 4vw 0 8vw;
		border-top: 1px solid rgba(68, 68, 68, 0.3);
		font-size: var(--fs-sp-14);
		font-weight: 300;
	}
	.profile-outline dd {
		width: calc(100% - 21.33vw);
		padding: 4vw 0 8vw;
		display: flex;
		flex-wrap: wrap;
		border-top: 1px solid rgba(68, 68, 68, 0.3);
		font-size: var(--fs-sp-14);
	}
	.profile-outline dt:first-child, 
	.profile-outline dd:first-of-type {
		border-top: none;
	}
	
	.profile-outline dd .profile-position {
		width: 100%;
	}
	.profile-outline dd .profile-name {
		width: 100%;
		margin-bottom: 1.8em;
	}
	.profile-outline dd .profile-name:last-of-type {
		margin-bottom: 0;
	}
}



/*---------- 事業紹介 ----------*/
.sec-service {
	width: 100%;
	padding: 0 0 110px;
	position: relative;
	overflow: hidden;
}

.service-list {
    width: 100%;
	max-width: 830px;
    margin: 50px auto 0 0;
	justify-content: space-between;
	align-items: center;
    position: relative;
}
.service-item {
	width: 160px;
}

/* タイトル */
.service-item-ttl-en {
	margin-bottom: 5px;
	color: var(--color-black);
	font-size: 1.4rem;
    font-weight: 500;
	line-height: 1.35;
	letter-spacing: 0.05em;
	font-family: "Roboto", sans-serif;
	font-optical-sizing: auto;
	font-style: normal;
	font-variation-settings:
	"wdth" 100;
	opacity: 0.5;
}
.service-item-ttl {
	margin-bottom: 30px;
	color: var(--color-black);
	font-size: 1.9rem;
    font-weight: 400;
	line-height: 1.52;
}
.btn-service-item-more {
	width: 100%;
	height: 40px;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 20px;
	border: 1px solid #707070;
	color: var(--color-black);
	transition: 0.3s ease-in-out;
}

@media (min-width: 769px) {
	.btn-service-item-more:hover {
		border: 1px solid var(--color-green);
		background: var(--color-green);
		color: #fff;
	}
	
}

@media (max-width: 768px) {
	.sec-service {
		width: 100%;
		padding: 0 0 26.66vw;
	}

	.service-list {
		width: 100%;
		max-width: initial;
		margin: 10.66vw auto 0;
		flex-direction: column;
		justify-content: flex-start;
		align-items: center;
		position: relative;
	}
	.service-item {
		width: 100%;
		margin-bottom: 13.33vw;
		display: flex;
		justify-content: space-between;
		align-items: flex-end;
	}
	.service-item:last-child {
		margin-bottom: 0;
	}

	/* タイトル */
	.service-item-ttl-en {
		margin-bottom: 1.33vw;
		font-size: var(--fs-sp-14);
	}
	.service-item-ttl {
		margin-bottom: 0;
		font-size: var(--fs-sp-19);
	}
	.btn-service-item-more {
		width: 42.66vw;
		height: 10.66vw;
		border-radius: 6vw;
	}
	
}




/*---------- ボタン ----------*/
.sec-btn-area {
	width: 100%;
	padding: 50px 0 80px;
	background: var(--color-lightgray);
	position: relative;
	z-index: 2;
}
.btn-wrap {
	width: 100%;
	align-items: center;
	justify-content: center;
}
.btn-link {
	width: 260px;
	height: 60px;
	padding-right: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 30px;
	background: #fff;
	font-weight: 500;
	position: relative;
}
.btn-link::before {
	content: '';
	width: 60px;
	height: 60px;
	background: var(--color-green);
	border-radius: 50%;
	position: absolute;
	top: calc(50% - 30px);
	right: 0;
	transition: 0.3s ease-in-out;
}
.btn-link::after {
	content: '';
	width: 60px;
	height: 60px;
	background: url("../../img/common/icon_arrow_w.svg") center center no-repeat;
	background-size: 22px;
	position: absolute;
	top: calc(50% - 30px);
	right: 0;
	transition: 0.3s ease-in-out;
}

.btn-link + .btn-link {
	margin-left: 200px;
}


.btn-back {
	width: 260px;
	height: 60px;
	padding-left: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 30px;
	background: #fff;
	font-weight: 500;
	position: relative;
}
.btn-back::before {
	content: '';
	width: 60px;
	height: 60px;
	background: var(--color-green);
	border-radius: 50%;
	position: absolute;
	top: calc(50% - 30px);
	left: 0;
	transition: 0.3s ease-in-out;
}
.btn-back::after {
	content: '';
	width: 60px;
	height: 60px;
	background: url("../../img/common/icon_arrow_back_w.svg") center center no-repeat;
	background-size: 22px;
	position: absolute;
	top: calc(50% - 30px);
	left: 0;
	transition: 0.3s ease-in-out;
}

@media (min-width: 769px) {
	.btn-link:hover::before {
		background: var(--color-darkblue);
	}
	
	.btn-back:hover::before {
		background: var(--color-darkblue);
	}
    
}


@media (max-width: 1100px) {
	.btn-link + .btn-link {
		margin-left: 15%;
	}
}


@media (max-width: 768px) {
	.sec-btn-area {
		width: 100%;
		padding: 13.33vw 0 21.33vw;
		background: var(--color-lightgray);
		position: relative;
		z-index: 2;
	}
	.btn-wrap {
		width: 100%;
		align-items: center;
		justify-content: center;
	}
	.btn-link {
		width: 80%;
		height: 15vw;
		padding-right: 3vw;
		border-radius: 8vw;
		font-size: 3.8vw;
	}
	.btn-link::before {
		content: '';
		width: 15vw;
		height: 15vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		right: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-link::after {
		content: '';
		width: 15vw;
		height: 15vw;
		background: url("../../img/common/icon_arrow_w.svg") center center no-repeat;
		background-size: 6vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		right: 0;
		transition: 0.3s ease-in-out;
	}

	.btn-link + .btn-link {
		margin-left: 0;
		margin-top: 12vw;
	}

    
	.btn-back {
		width: 80%;
		height: 15vw;
		padding-left: 3vw;
		border-radius: 8vw;
		font-size: 3.8vw;
	}
	.btn-back::before {
		content: '';
		width: 15vw;
		height: 15vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		left: 0;
		transition: 0.3s ease-in-out;
	}
	.btn-back::after {
		content: '';
		width: 15vw;
		height: 15vw;
		background: url("../../img/common/icon_arrow_back_w.svg") center center no-repeat;
		background-size: 6vw;
		position: absolute;
		top: calc(50% - 7.5vw);
		left: 0;
		transition: 0.3s ease-in-out;
	}
}

