@charset "UTF-8";
/* CSS Document */


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

.layout-concept p {
    text-align: left;
}
    
    
.contents01 {
	padding: 35px 4% 60px;
}


/* layout01 */

.layout01 {
	padding: 30px;
	margin-top: 40px;
}

.layout01 img {
	max-width: 400px;
}
	
/* layout02 */

.layout02 ul {
  justify-content: center;
	gap:10px 2%;
}

.layout02 ul li {
	width: 49%;
}
	
@media screen and (max-width: 550px) {
	.layout02 ul li {
	width: 100%;
}
}

.layout02 ul li a {
	padding: 20px 30px;
}

.layout02 ul li a::after {
right: 15px;
}

/* layout03 */

.layout03 {
  justify-content: center;
	gap:30px 0px;
	margin-bottom: 40px;
}

.layout03 .box-detail {
	width: 100%;
}

.layout03 .box-img {
	flex: auto;
	width: 100%;
	padding-left: 0px;
	text-align: center;
}
	
.layout03 .box-img img {
	width: 88%;
	max-width: 400px;
}

.layout03 h3 {
	font-size: 19px;
}

.layout03 ul li {
	font-size: 12px;
}

/* layout04 */

.layout04 .box {
	padding: 35px 20px;
}

.layout04 .box:not(:last-child) {
	margin-bottom: 30px;
}

.layout04 .box-text {
	margin-bottom: 40px;
}

.layout04 .box-works {
	min-height: 0px;
}

.layout04 .box-works::before {
	display: none;
}

.layout04 .box-works .box-img {
	text-align: center;
	padding-top: 30px;
	max-width: 400px;
	margin: 0px auto;
	display: block;
}
	
.layout04 .box-skil .box-inner {
	padding: 25px 10px;
}

.layout04 h3 {
	font-size: 22px;
	padding-bottom: 20px;
	margin-bottom: 25px;
}

.layout04 h5 {
	font-size: 18px;
}

.layout04 .box-works ul {
	width: 100%;
}

    .pc-view {
        display: none;
    }
    .sp-view {
        display: inline-block;
    }
   
}
