@charset "utf-8";

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

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1100px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

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

	.main::after{
		background: #e5e5e5 !important;
	}
	
}



/*-------------------------------
	会社概要
-------------------------------*/

.Profile-block:not(:last-child){
	margin-bottom: 16.5rem;
}
.Profile-block-table{
	width: 100%;
	border-top: 1px solid #fff;
}
.Profile-block-table__item{
	border-bottom: 1px solid #fff;
}
.Profile-block-table__item-title{
	width: 30rem;
	padding-left: 3rem;
	font-weight: 700;
	padding-top: 1rem;
	padding-bottom: 1rem;
	letter-spacing: .05em;
	vertical-align: middle;
}
.Profile-block-table__item-body{
	width: calc(100% - 30rem);
	padding-right: 3rem;
	padding-top: 1rem;
	padding-bottom: 1rem;
}
.Profile-block-table__item-text{
	line-height: calc(2.4 / 1.6);
	min-height: 5rem;
	font-weight: 400;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
.Profile-block-table-child__item{
	width: 100%;
	padding-top: 1rem;
	padding-bottom: 1rem;
	min-height: 7rem;
	display: flex;
	align-items: center;
	justify-content: flex-start;
}
.Profile-block-table-child__item:not(:last-child){
	border-bottom: 1px solid #fff;
}
.Profile-block-table-child__item-title{
	width: 14.8rem;
	font-weight: 700;
	line-height: calc(2.4 / 1.6);
}
.Profile-block-table-child__item-text{
	width: calc(100% - 14.8rem);
	line-height: calc(2.4 / 1.6);
}

.Profile-block-table:has(.Profile-block-table-child) .Profile-block-table__item-title,
.Profile-block-table:has(.Profile-block-table-child) .Profile-block-table__item-body{
	padding-top: 0;
	padding-bottom: 0;
	padding-right: 0;
}

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

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1100px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

	.Profile-block-table__item-title{
		width: 22.5rem;
	}
	.Profile-block-table__item-body{
		width: calc(100% - 22.5rem);
	}

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

	.Profile-block:not(:last-child){
		margin-bottom: 18rem;
	}
	.Profile-block-table,
	.Profile-block-table__body,
	.Profile-block-table__item{
		display: block;
	}
	.Profile-block-table__item{
		padding-top: 2.5rem;
		padding-bottom: 2.5rem;
	}
	.Profile-block-table__item-title{
		width: 100%;
		font-size: 3.2rem;
		line-height: calc(4.8 / 3.2);
		padding-left: 0;
		font-weight: 700;
		padding-top: 0;
		padding-bottom: 0;
		display: block;
	}
	.Profile-block-table__item-body{
		width: 100%;
		padding-right: 0;
		padding-top: 0;
		padding-bottom: 0;
		display: block;
	}
	.Profile-block-table__item-text{
		font-size: 3.2rem;
		line-height: calc(4.8 / 3.2);
		min-height: 5rem;
		font-weight: 400;
		display: flex;
		align-items: center;
		justify-content: flex-start;
	}
	.Profile-block-table-child__item{
		width: 100%;
		padding-top: 2rem;
		padding-bottom: 2rem;
		flex-direction: column;
	}
	.Profile-block-table-child__item:first-child{
		padding-top: 0;
	}
	.Profile-block-table-child__item-title{
		width: 100%;
		line-height: calc(4.8 / 3.2);
	}
	.Profile-block-table-child__item-text{
		width: 100%;
		line-height: calc(4.8 / 3.2);
	}

	.Profile-block-table:has(.Profile-block-table-child) .Profile-block-table__item-title,
	.Profile-block-table:has(.Profile-block-table-child) .Profile-block-table__item-body{
		padding-top: 0;
		padding-bottom: 0;
		padding-right: 0;
	}

	#Office .Profile-block-table__item{
		width: 100%;
		display: flex;
		align-items: flex-start;
		justify-content: flex-start;
	}
	#Office .Profile-block-table__item-title{
		width: 20rem;
	}
	#Office .Profile-block-table__item-body{
		width: calc(100% - 20rem);
	}

}



/*-------------------------------
	アクセス
-------------------------------*/

.Access-block-wrap{
	width: 100%;
	display: flex;
	gap: 14rem 5rem;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: space-between;
}
.Access-block{
	width: calc((100% - 5rem) / 2);
}
.Access-block:nth-of-type(1){
	order: 1;
}
.Access-block:nth-of-type(2){
	order: 3;
}
.Access-block:nth-of-type(3){
	order: 5;
}
.Access-block:nth-of-type(4){
	order: 7;
}
.Access-block:nth-of-type(5){
	order: 2;
}
.Access-block:nth-of-type(6){
	order: 4;
}
.Access-block:nth-of-type(7){
	order: 6;
}
.Access-block:nth-of-type(8){
	order: 8;
}
.Access-block:nth-of-type(9){
	order: 9;
}
.Access-block__body{
	width: 100%;
	padding-left: 5rem;
}
.Access-block__image{
	width: 100%;
	margin-bottom: 2.8rem;
}
.Access-block__image img{
	width: 100%;
}
.Access-block__address{
	width: 100%;
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
}
.Access-block__address-text{
	letter-spacing: .05em;
	font-weight: 400;
}
.Access-block__address-button{
	width: 17rem;
	height: 5rem;
}
.Access-block__address-button a{
	border: 1px solid var(--blackcolor);
	font-family: var(--en);
	width: 100%;
	height: 100%;
	font-size: 1.4rem;
	font-weight: 500;
	letter-spacing: .15em;
	border-radius: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	position: relative;
	z-index: 5000;
	opacity: 1 !important;
}
.Access-block__address-button a::before{
	background: var(--maincolor);
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
	right: 0;
	bottom: 0;
	z-index: -1;
	transform-origin: right;
	transform: scaleX(0);
	transition: transform .3s ease-in-out;
}
.Access-block__address-button a::after{
	transition: var(--transition);
	content: "";
	display: block;
	width: 1.1rem;
	height: 1.1rem;
	margin-left: .8rem;
	background-image: url(../images/common/icon_blank-black.svg);
	background-size: contain;
	background-repeat: no-repeat;
	background-position: center center;
}
.Access-block__address-button a:hover{
	color: #fff;
}
.Access-block__address-button a:hover::before{
	transform-origin: left;
	transform: scaleX(1);
}
.Access-block__address-button a:hover::after{
	background-image: url(../images/common/icon_blank-white.svg);
}

.Access-block:not(:has(.Access-block__image)) .Access-block__title{
	margin-bottom: 1.5rem;
}
.Access-block__body:not(:has(.Access-block__image)) .Access-block__address{
	flex-direction: column;
}
.Access-block__body:not(:has(.Access-block__image)) .Access-block__address-text{
	margin-bottom: 2rem;
}


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

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1100px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

	.Access-block__body{
		padding-left: 0;
	}
	.Access-block__address{
		flex-direction: column;
	}
	.Access-block__address-button{
		margin-top: 2.8rem;
	}

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

	#Access{
		padding-top: 0;
		background: #e5e5e5;
	}
	.Access-block-wrap{
		gap: 9rem 0;
		flex-direction: column;
	}
	.Access-block{
		width: 100%;
	}
	.Access-block:nth-of-type(1){
		order: 1;
	}
	.Access-block:nth-of-type(2){
		order: 2;
	}
	.Access-block:nth-of-type(3){
		order: 3;
	}
	.Access-block:nth-of-type(4){
		order: 4;
	}
	.Access-block:nth-of-type(5){
		order: 5;
	}
	.Access-block:nth-of-type(6){
		order: 6;
	}
	.Access-block:nth-of-type(7){
		order: 7;
	}
	.Access-block:nth-of-type(8){
		order: 8;
	}
	.Access-block:nth-of-type(9){
		order: 9;
	}
	.Access-block__body{
		padding-left: 0;
	}
	.Access-block__image{
		margin-bottom: 4rem;
	}
	.Access-block__address{
		flex-direction: column;
	}
	.Access-block__address-text{
		width: 100%;
		margin-bottom: 3.2rem;
	}
	.Access-block__address-button{
		width: 34rem;
		height: 10rem;
	}
	.Access-block__address-button a{
		font-size: 2.8rem;
		border-radius: 5rem;
	}
	.Access-block__address-button a::after{
		width: 2.2rem;
		height: 2.2rem;
		margin-left: 1rem;
	}

	.Access-block:not(:has(.Access-block__image)) .Access-block__title{
		margin-bottom: 2.5rem;
	}
	.Access-block__body:not(:has(.Access-block__image)) .Access-block__address-text{
		margin-bottom: 3.2rem;
	}

}