@charset "utf-8";

/*　751px以上の対応
////////////////////////////////////////////////////*/
@media screen and (min-width:751px) {
#company #wrap{
	width: 100%;
	min-width: 1000px;
	margin: 0 auto;
	letter-spacing: 0.06em;
	font-size: 16px;
}
#company #wrap #contents{
	width: 1000px;
	margin: 0 auto;
}
#company #wrap p{
	line-height: 1.5;
}
/* ファーストビューエリア */
.underlayer--firstview__wrap{
	width: 100%;
	min-width: 1000px;
	margin: 0 auto 40px;
	background: #F9F1F1;
	padding: 32px 0;
}
.underlayer--firstview__inr{
	width: 1000px;
	margin: 0 auto;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
}
.underlayer--firstview__left{
}
.underlayer--firstview__ttl h1{
	font-size: 38px;
	color: #EA0029;
	letter-spacing: 0.03em;
	margin-bottom: 18px;
}
.underlayer--firstview__lead{
	font-size: 18px;
	line-height: 1.66;
	letter-spacing: 0.06em;
	font-weight: 400;
}
.underlayer--firstview__right{
	text-align: center;
}
.underlayer--firstview__image{
	margin-bottom: 12px;
	position: relative;
}
.underlayer--firstview__image::before{
	content: "資料配布中";
	font-size: 13px;
	letter-spacing: 0.04em;
	text-align: center;
	color: #fff;
	line-height: 78px;
	background: #EA0029;
	border-radius: 50px;
	width: 78px;
	height: 78px;
	position: absolute;
	top: -20px;
	right: -34px;
}
.underlayer--firstview__btn {
	text-align: center;
}
.underlayer--firstview__btn p{
	margin-bottom: 10px;
	font-weight: 400;
	letter-spacing: 0;
}
.underlayer--firstview__btn a{
	display: inline-block;
	letter-spacing: 0;
	color: #fff;
	font-weight: 700;
	background: #185ABC;
	border-radius: 4px;
	padding: 16px 40px;
	position: relative;
	transition: 0.3s;
}
.underlayer--firstview__btn a:hover{
	background-image: linear-gradient(to right, #185ABC, #0c3169);
}
.underlayer--firstview__btn a::before{
	content: "";
	background: url("../../case-studies/img/fv-document-dl-icon.svg");
	width: 18px;
	height: 18px;
	position: absolute;
	top: 14px;
	right: 12px;
}


/* 各セクション共通ヘッダーの対応（三角グレーと見出し） */
.sections {
	position: relative;
	padding-top: 80px;
	margin-bottom: 80px;
}
.sections:before{
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 160px 190px 0 0;
	border-color: #fafafa transparent transparent transparent;
	z-index: -1;
}
.sections h2{
	font-size: 20px;
	margin-bottom: 30px;
	font-weight: bold;
	padding-left: 50px;
	line-height: 1.5;
}
.sections .sections-ttl-lead{
	margin-bottom: 30px;
	padding-left: 50px;
}


/** ページタイトルの対応 **/
#company .page_info{
	margin-top: 80px;
	margin-bottom: 70px;
}
#company .page_ttl p{
	margin-bottom: 15px;
	text-align: center;
	line-height: 1.0;
	width: 120px;
	margin: 0 auto 5px;
}
#company .page_ttl p img{
	width: 100%;
}
#company .page_info h1{
	font-size: 16px;
	font-size: 1.6rem;
	text-align: center;
	margin-bottom: 50px;
}
#company .page_info .page_lead{
	font-size: 15px;
	font-size: 1.5rem;
	text-align: center;
	line-height: 2;
	margin: 0 auto;
}	
#company .company--info{
	width: 1000px;
	margin: 0 auto 30px;
}
.company--info__inr{
	border: 1px solid #E4E4E4;
	box-sizing: border-box;
	border-radius: 4px;
}
#company .company--info__child {
	min-height: 60px;
	display: flex;
	align-items: center;
	border-bottom: 1px solid #E4E4E4;
	box-sizing: border-box;
}
#company .company--info__child.company--info__history {
	border-bottom: 0;
}
#company .company--info__child dl {
	display: flex;
	flex-wrap: wrap;
}
#company .company--info__child dl dt {
	font-size: 18px;
	font-weight: 400;
	width: 200px;
	line-height: 1;
	background: #F5F5F2;
	min-height: 60px;
	display: flex;
	align-items: center;
	padding-left: 26px;
}
#company .company--info__child dl dd {
	line-height: 1.7;
	font-size: 18px;
	font-weight: 400;
	padding-left: 26px;
	min-height: 60px;
	display: flex;
	align-items: center;
}
#company .company--info__child.company--info__history dl dd dt {
	font-size: 18px;
	font-weight: 400;
	width: inherit;
	line-height: 1.8;
	background: inherit;
	min-height: auto;
	display: flex;
	align-items: center;
	padding-left: 0;
}
#company .company--info__child.company--info__history dl dd dl dd {
	line-height: 1.8;
	font-size: 18px;
	font-weight: 400;
	padding-left: 1em;
	min-height: auto;
	display: flex;
	align-items: center;
}
#company .company--info__child.company--info__business dl dd{
	padding: 16px 0 16px 26px;
}
#company .company--info__child.company--info__history dl dd div{
	padding: 16px 0;
}

#company .company--info__child dl dd div dl{
	display: flex;
	flex-wrap: wrap;
}
#company .company--info__child dl dd div dl dt{
	font-weight: 400;
}
#company .company--info__child dl dd div dl dd{
	line-height: 1.7;
}

.design_document{
	margin-bottom: 80px;
}
.design_document a{
	background: #F5F5F2;
	padding: 20px;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: 0.3s;
}
.design_document a:hover{
	background: #fff;
}
.design_document a:hover h3{
	color: #EA0029;
}
.design_document a:hover img{
	opacity: 1;
}
.design_document-img{
	width: 347px;
}
.design_document-txt{
	width: 580px;
}
.design_document-txt h3{
	font-size: 20px;
	font-weight: 400;
	margin-bottom: 12px;
	padding-left: 36px;
	position: relative;
}
.design_document-txt h3::before{
	content: "";
	position: absolute;
	top: -1px;
	left: 0;
	background-size: cover;
	width: 24px;
	height: 24px;
	background: url("../../img/toppage/top-arrow.svg");
	background-size: cover;
}
.design_document-txt p{
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	letter-spacing: 0.06em;
}
.design_document-txt p span{
	background: linear-gradient(transparent 50%, #FFFF15 50%);
	padding: 0.6% 0% 0% 0%;
}


.handling_service_box{
	margin-bottom: 80px;
}
.handling_service_box h2 {
	font-size: 28px;
	font-weight: 700;
	text-align: center;
	margin-bottom: 32px;
	line-height: 1.5;
}
.handling_service_box .handling_service_list{
	display: flex;
	flex-wrap: wrap;
	gap: 68px;
	row-gap: 60px;
	width: 952px;
	margin: 0 auto;
}
.handling_serviceCommon{
	display: block;
	width: 272px;
	text-align: center;
}
.handling_service_img{
	position: relative;
	width: 272px;
	height: 194px;
	margin-bottom: 20px;
}
.handling_service_img.icon_stores::before{
	position: absolute;
	top: 125px;
    right: -28px;
	content: "";
	background: url("../../img/icon-stores.svg");
	background-size: cover;
	width: 93px;
	height: 79px;
}
.handling_service_name{
	font-size: 20px;
	font-weight: 400;
	line-height: 1.5;
	margin-bottom: 14px;
	letter-spacing: 0.06em;
}
.handling_service_lead{
	font-size: 17px;
	line-height: 1.5;
	letter-spacing: 0.06em;
	text-align: left;
	margin-bottom: 18px;
}
.handling_service_btn_page{
	display: block;
	background: #EA0029;
	font-size: 16px;
	width: 224px;
	margin: 0 auto 20px;
	padding: 16px 0;
	border-radius: 30px;
	letter-spacing: 0;
	color: #fff;
}
.handling_service_btn_page:hover{
	background: #000;
}
.handling_service_btn_dl{
	position: relative;
	font-size: 16px;
	letter-spacing: 0;
	padding-left: 32px;
}
.handling_service_btn_dl::before{
	position: absolute;
	top: 0;
	left: 0;
	content: "";
	background: url("../../company/img/arrow.svg");
	background-size: cover;
	width: 26px;
	height: 26px;
}
.handling_service_btn_dl:hover span{
	border-bottom: 1px solid #000;
}




}





/*////////////////////////////////////////////////////////////////////////////

　750px以下の対応

////////////////////////////////////////////////////////////////////////////*/

@media screen and (max-width:750px) {
#header{
	padding-bottom: 5%;
}
#company #wrap{
	width: 100%;
	letter-spacing: 0.06em;
}
#company #wrap #contents{
	width: 90%;
	margin: 0 auto 10%;
}
#company #wrap #contents p{
	line-height: 1.6;
}

/* ファーストビューエリア */
.underlayer--firstview__wrap{
	width: 100%;
	margin-bottom: 8%;
	background: #F9F1F1;
	padding: 10% 0;
}
.underlayer--firstview__inr{
	width: 90%;
	margin: 0 auto;
}
.underlayer--firstview__left{
	margin-bottom: 10%;
}
.underlayer--firstview__ttl h1{
	font-size: 28px;
	color: #EA0029;
	letter-spacing: 0.03em;
	margin-bottom: 3%;
	line-height: 1.3;
}
.underlayer--firstview__ttl h1 span{
	font-size: 16px;
	letter-spacing: 0.06em;
	display: block;
}
.underlayer--firstview__lead{
	font-size: 16px;
	line-height: 1.6;
	letter-spacing: 0.03em;
	font-weight: 400;
}
.underlayer--firstview__image{
	margin-bottom: 1.5%;
	position: relative;
	width: 89%;
	margin: 0 auto 3%;
}
.underlayer--firstview__image::before{
	content: "資料配布中";
	font-size: 12px;
	letter-spacing: 0;
	text-align: center;
	color: #fff;
	line-height: 70px;
	background: #EA0029;
	border-radius: 60px;
	width: 70px;
	height: 70px;
	position: absolute;
	top: -22%;
	right: -7%;
}
.underlayer--firstview__btn {
	text-align: center;
}
.underlayer--firstview__btn p{
	margin-bottom: 10px;
	font-weight: 400;
	letter-spacing: 0;
	font-size: 16px;
	line-height: 1.5;
}
.underlayer--firstview__btn a{
	display: inline-block;
	letter-spacing: 0;
	color: #fff;
	font-weight: 700;
	background: #185ABC;
	border-radius: 5px;
	padding: 6.5% 16%;
	position: relative;
	transition: 0.3s;
	font-size: 16px;
	line-height: 1;
}
.underlayer--firstview__btn a::before{
	content: "";
	background: url("../../case-studies/img/fv-document-dl-icon.svg");
	width: 26px;
	height: 26px;
	position: absolute;
	top: 27%;
	right: 5%;
	background-size: contain;
}

/* 各セクション共通ヘッダーの対応（三角グレーと見出し） */
.sections {
	position: relative;
	padding-top: 8%;
	margin-bottom: 80px;
}
.sections:before{
	position: absolute;
	top: 0;
	left: -2.5%;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 80px 100px 0 0;
	border-color: #fafafa transparent transparent transparent;
	z-index: -1;
}
.sections h2{
	font-size: 16px;
	font-size: 1.6rem;
	margin-bottom: 20px;
	font-weight: bold;
	line-height: 1.6;
}
.sections .sections-ttl-lead{
	margin-bottom: 30px;
}

	
/** ページタイトルの対応 **/
#company .page_info{
	margin-top: 50px;
	margin-bottom: 30px;
}
#company .page_ttl p{
	margin-bottom: 15px;
	text-align: center;
	line-height: 1.0;
	width: 106px;
	margin: 0 auto;
}
#company .page_info h1{
	font-size: 16px;
	font-size: 1.6rem;
	text-align: center;
	margin-bottom: 20px;
}
#company .page_info .page_lead{
	font-size: 16px;
	font-size: 1.4rem;
	text-align: left;
	line-height: 1.8;
}






#company .company--info{
	width: 100%;
	margin: 0 auto 10%;
}
.company--info__inr{
	border: 1px solid #E4E4E4;
	box-sizing: border-box;
	border-radius: 4px;
}
#company .company--info__child dl dt {
	font-size: 16px;
	font-weight: 700;
	line-height: 1;
	background: #F5F5F2;
	padding: 5% 3%;
}
#company .company--info__child.company--info__history dl dd dt {
	font-size: 18px;
	font-weight: 400;
	width: inherit;
	line-height: 1.8;
	background: inherit;
	min-height: auto;
	display: flex;
	align-items: center;
	padding-left: 0;
}
#company .company--info__child dl dd {
	font-size: 16px;
	line-height: 1.5;
	padding: 5% 3%;
}
#company .company--info__child.company--info__business dl dd ul li + li{
	margin-top: 3%;
}
#company .company--info__child.company--info__history dl dd div dl dt{
	font-size: 15px;
	line-height: 1.4;
	font-weight: 400;
	padding: 0;
	margin: 0;
}
#company .company--info__child.company--info__history dl dd div dl dd{
	padding: 0;
	line-height: 1.5;
}
#company .company--info__child.company--info__history dl dd div dl + dl{
	margin-top: 5%;
}
#company .company--info__child dl dd div dl dd{
	line-height: 1.6;

}

.design_document{
	margin-bottom: 10%;
}
.design_document a{
	background: #F5F5F2;
	padding: 20px 20px 24px 20px;
	border-top: 1px solid #000;
	border-bottom: 1px solid #000;
	box-sizing: border-box;
	display: flex;
	justify-content: space-between;
	align-items: center;
	transition: 0.3s;
	flex-direction: column-reverse;
}
.design_document a:hover img{
	opacity: 1;
}
.design_document-img{
	width: 100%;
	height: auto;
}
.design_document-txt{
	width: 100%;
}
.design_document-txt h3{
	font-size: 20px;
	font-weight: 400;
	margin-bottom: 1%;
	padding-left: 36px;
	position: relative;
	line-height: 1.6;
}
.design_document-txt h3::before{
	content: "";
	position: absolute;
	top: 3px;
	left: 0;
	background-size: cover;
	width: 28px;
	height: 28px;
	background: url("../../img/toppage/top-arrow.svg");
	background-size: cover;
}
.design_document-txt p{
	font-size: 14px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.06em;
	margin-bottom: 3%;
}
.design_document-txt p span{
	background: linear-gradient(transparent 50%, #FFFF15 50%);
	padding: 0.6% 0% 0% 0%;
}







.handling_service_box{
	margin-bottom: 13%;
}
.handling_service_box h2 {
	font-size: 26px;
	font-weight: 500;
	text-align: center;
	line-height: 1.6;
	width: 90%;
	margin: 0 auto 3%;
}
.handling_service_box .handling_service_list{
	width: 100%;
	margin: 0 auto;
}
.handling_serviceCommon{
	display: block;
	text-align: center;
}
#company #wrap #contents .handling_service_img{
	position: relative;
	width: 88%;
	height: auto;
	margin: 0 auto 3%;
	line-height: 1;
}
.handling_service_img.icon_stores::before{
	position: absolute;
	top: 125px;
    right: -28px;
	content: "";
	background: url("../../img/icon-stores.svg");
	background-size: cover;
	width: 93px;
	height: 79px;
}
.handling_service_name{
	font-size: 20px;
	font-weight: 400;
	line-height: 1.5;
	margin-bottom: 2%;
}
#company #wrap #contents .handling_service_lead{
	font-size: 16px;
	line-height: 1.6;
	text-align: left;
	width: 94%;
	margin: 0 auto 4%;
}
.handling_service_btn_page{
	display: block;
	background: #EA0029;
	font-size: 16px;
	width: 80%;
	margin: 0 auto 6%;
	padding: 14px 0;
	border-radius: 40px;
	letter-spacing: 0;
	color: #fff;
}
.handling_service_btn_dl{
	position: relative;
	font-size: 16px;
	letter-spacing: 0;
	padding-left: 10%;
	width: 11em;
	margin: 0 auto 12%;
	line-height: 1;
}
.handling_service_btn_dl::before{
	position: absolute;
	top: -3px;
	left: 0;
	content: "";
	background: url("../../company/img/arrow.svg");
	background-size: cover;
	width: 26px;
	height: 26px;
}
.handling_service_btn_dl span{
	text-decoration: underline;
}



}

