@charset "UTF-8";

/*===============*/
/* page_visual */
/*===============*/
.page_visual {
	background-color: #525D67;
}

.page_visual>div::before {
	background: -moz-linear-gradient(left, rgba(82, 93, 103, 1), rgba(82, 93, 103, 0));
	background: -webkit-linear-gradient(left, rgba(82, 93, 103, 1), rgba(82, 93, 103, 0));
	background: linear-gradient(to right, rgba(82, 93, 103, 1), rgba(82, 93, 103, 0));
}

.page_visual>div::after {
	background: -moz-linear-gradient(right, rgba(82, 93, 103, 1), rgba(82, 93, 103, 0));
	background: -webkit-linear-gradient(right, rgba(82, 93, 103, 1), rgba(82, 93, 103, 0));
	background: linear-gradient(to left, rgba(82, 93, 103, 1), rgba(82, 93, 103, 0));
}
.works .page_visual>div img {
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  z-index: -1;
}
/*===============*/
/* contents */
/*===============*/
.contents h2 {
	margin-bottom: 30px;
}

.contents h2>* {
	display: block;
}

.contents h2 small {
	display: block;
	margin-bottom: 20px;
	color: #67B6DD;
	letter-spacing: .05em;
	font-size: 160%;
	font-family: 'Saira Extra Condensed', sans-serif;
}

.contents h2 span {
	color: #67B6DD;
	letter-spacing: .05em;
	font-size: 200%;
}

.contents h3 {
	margin-bottom: 25px;
}

.contents h3 span {
	display: inline-block;
	font-size: 140%;
	line-height: 1.8;
}

.contents p {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Verdana, Meiryo, "M+ 1p", sans-serif;
}


@media (max-width:768px) {

	.contents .txt h2,
	.contents .txt h3 {
		text-align: center;
	}

	.contents h2 {
		margin-bottom: 2em;
	}

	.contents h2 small {
		margin-bottom: 1em;
		font-size: 120%;
	}

	.contents h2 span {
		font-size: 150%;
	}

	.contents h3 {
		margin-bottom: 2em;
	}

	.contents h3 span {
		font-size: 110%;
	}
}

/*===============*/
/* works */
/*===============*/
.works {
	position: relative;
}
.works .contents {
  box-sizing: border-box;
  padding: 65px 0;
}
.works section .section-box {
    width: 90%;
    max-width: 1080px;
    margin: 0 auto;
}
.works .block {
    box-sizing: border-box;
    padding: 80px 0;
}
.block-bule, .job-schedule.block-blue {
    background: #F4F8FA
}

.wokrs-links, .cothic-text {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Verdana, Meiryo, "M+ 1p", sans-serif;
}
.wokrs-links {
    width: 90%;
    max-width: 1080px;
    margin: 0 auto 80px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.wokrs-links li {
    width: 24%;
    background-color: #67B6DD;
    padding: 70px 0;
    text-align: center;
    font-size: 130%;
    color: #FFF;
    font-weight: 600;
    position: relative;
    cursor: pointer;
}
.wokrs-links li:before {
    content: "";
    position: absolute;
    width: 140px;
    height: 90px;
    top: calc(50% - 55px);
    left: calc(50% - 70px);
    opacity: .7;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center;
    z-index: 1;
}
.wokrs-links li:nth-child(1):before {
    background-image: url("../img/works/works-icon01.svg");
}
.wokrs-links li:nth-child(2):before {
    background-image: url("../img/works/works-icon02.svg");
}
.wokrs-links li:nth-child(3):before {
    background-image: url("../img/works/works-icon03.svg");
}
.wokrs-links li:nth-child(4):before {
    background-image: url("../img/works/works-icon04.svg");
}

.works h2 {
    position: relative;
    padding-left: 60px;
}
.works h2:before {
    content: "";
    position: absolute;
    width: 40px;
    height: 60px;
    top: calc(50% - 30px);
    left: 0;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center;
}
.icon01:before {
    background-image: url("../img/works/works-icon01-blue.svg");
}
.icon02:before {
    background-image: url("../img/works/works-icon02-blue.svg");
}
.icon03:before {
    background-image: url("../img/works/works-icon03-blue.svg");
}
.icon04:before {
    background-image: url("../img/works/works-icon04-blue.svg");
}
.works .section-box .split-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.job-detail {
    width: calc(100% - 450px);
}
.job-schedule {
    width: 380px;
    background: #FFF;
    box-sizing: border-box;
    padding: 40px;
}
.job-detail .image-box {
    margin: 50px 0 0;
}
.job-schedule .title {
    color: #67B6DD;
    font-size: 120%;
    font-weight: 600;
    margin-bottom: 20px;
}
.job-schedule .schedule {
    position: relative;
    box-sizing: border-box;
    padding-left: 30px;
}
.job-schedule .schedule:before {
    content: "";
    position: absolute;
    width: 2px;
    height: calc(100% - 10px);
    top: 10px;
    left: 10px;
    background: #E4E7EA;
}
.schedule dl {
    position: relative;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", Verdana, Meiryo, "M+ 1p", sans-serif;
    margin-bottom: 5px;
}
.schedule dt {
    position: relative;
    color: #67B6DD;
    font-size: 160%;
    font-weight: 600;
    width: 20px;
}
.schedule dt:before {
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    left: -28px;
    top: 6px;
    background: #67B6DD;
    border-radius: 50%;
}
.schedule dd {
    font-size: 110%;
    line-height: 160%;
    font-weight: 600;
    padding: 3px 0 0 10px;
    width: calc(100% - 35px);
}
.schedule p {
    font-size: 90%;
    margin-bottom: 20px;
    line-height: 150%;
}



@media (max-width:768px) {
.works section .section-box {
    width: 90%;
    margin: 0 auto;
}
.works .block {
    box-sizing: border-box;
    padding: 60px 0;
}
.block-bule, .job-schedule.block-blue {
    background: #F4F8FA
}
.wokrs-links {
    width: 90%;
    margin: 0 auto 50px;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.wokrs-links li {
    width: 49%;
    background-color: #67B6DD;
    padding: 30px 0;
    margin-bottom: 2%;
    font-size: 15px;
}
.wokrs-links li:before {
    width: 80px;
    height: 60px;
    top: calc(50% - 30px);
    left: calc(50% - 40px);
}

.works h2 {
    position: relative;
    padding-left: 40px;
}
.works h2:before {
    content: "";
    position: absolute;
    width: 30px;
    height: 40px;
    top: calc(50% - 20px);
    left: 0;
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center center;
}
.works .section-box .split-box {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
}
.job-detail {
    width: 100%;
    margin-bottom: 30px;
}
.job-schedule {
    width: 100%;
    background: #FFF;
    box-sizing: border-box;
    padding: 30px;
}
.job-detail .image-box {
    margin: 50px 0 0;
}
.job-schedule .title {
    color: #67B6DD;
    font-size: 120%;
    font-weight: 600;
    margin-bottom: 20px;
}
.job-schedule .schedule {
    position: relative;
    box-sizing: border-box;
    padding-left: 30px;
}
.job-schedule .schedule:before {
    content: "";
    position: absolute;
    width: 2px;
    height: calc(100% - 10px);
    top: 10px;
    left: 10px;
    background: #E4E7EA;
}
.schedule dt {
    position: relative;
    color: #67B6DD;
    font-size: 160%;
    font-weight: 600;
    width: 100%;
}
.schedule dt:before {
    content: "";
    position: absolute;
    width: 18px;
    height: 18px;
    left: -28px;
    top: 6px;
    background: #67B6DD;
    border-radius: 50%;
}
.schedule dd {
    font-size: 110%;
    line-height: 160%;
    font-weight: 600;
    padding: 3px 0 0 0;
    box-sizing: border-box;
    width: 100%;
}
.schedule p {
    font-size: 90%;
    margin-bottom: 20px;
    line-height: 150%;
}
}

@media (max-width: 480px) {

}