@charset "utf-8";

/* -----------------------------------------------------------
    共通
-------------------------------------------------------------- */
.jp {
    color: #333;
}

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

/* -----------------------------------------------------------
   catch-area 
-------------------------------------------------------------- */
.catch-area {
    padding: 60px 0 100px;
}

.catch-area .inner {
    width: 100%;
    display: flex;
    justify-content: space-between;
}

.catch-area .bg-block {
    width: 40%;
    background: url("../img/about-catch-bg.jpg") center/cover, no-repeat;
}

.catch-area .txt-block {
    width: 60%;
    padding: 2vw calc( ( 100% - 1200px) / 2 ) 2vw 5%;
    container-type: inline-size;
}

.catch-area .txt-block .catch {
    font-size: min(4.7cqw,3.6rem);
}

.catch-area .txt-block .txt-box {
    padding: 30px;
    border: 1px solid var(--green);
    margin: 40px 0 0;
    position: relative;
}

.catch-area .txt-block .txt-box .box-ttl {
    font-size: 1.6rem;
    font-weight: bold;
    display: inline-block;
    background: #fff;
    padding: 0 12px;
    position: absolute;
    color: var(--green);
    top: -8px;
    left: 20px;
}

.catch-area .txt-block .txt-box .box-txt {
    line-height: 1.7;
    font-weight: 500;
}

.catch-area .txt-block .txt-box .ill-wrap {
    position: absolute;
    bottom: 0;
    right: 10px;
}


@media screen and (max-width: 768px) {
    .catch-area {
        padding: 0 0 50px;
    }
    
    .catch-area .inner {
        flex-wrap: wrap;
    }
    
    .catch-area .bg-block {
        width: 100%;
        height: 50vw;
		border-radius: 10px;
    }
    
    .catch-area .txt-block {
        width: 100%;
        padding: 25px 0 0;
    }
    
    .catch-area .txt-block .catch {
        font-size: min(6.6cqw,3.6rem);
        line-height: 1.6;
    }
    
    .catch-area .txt-block .txt-box {
        padding: 25px 20px 20px;
        margin: 30px 0 0;
    }
    
    .catch-area .txt-block .txt-box .box-ttl {
        font-size: 1.6rem;
        padding: 0 8px;
        top: -8px;
        left: 10px;
    }
    
    .catch-area .txt-block .txt-box .box-txt {
        font-size: 1.5rem;
        padding-right: 18vw;
    }
    
    .catch-area .txt-block .txt-box .ill-wrap {
        width: 25vw;
        right: -20px;
    }
}

/* -----------------------------------------------------------
   ex-area 
-------------------------------------------------------------- */
.ex-area {
    padding: 100px 0;
	/*background: url("../img/bg-grid-white.png") repeat, var(--beige);*/
	background: url("../img/bg-grid-white.png") repeat, #F5F8EC;
	/*background-size: 500px auto;*/
	background-size: 18px auto;
}

.ex-area .inner {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.ex-area .txt-wrap {
    width: calc( 100% - 400px );
    padding-right: 5%;
}

.ex-area .txt-wrap .jp {
    color: var(--green);
    font-size: 2.4rem;
}

.ex-area .txt-wrap .catch {
    font-size: 3.2rem;
}

.ex-area .ill-wrap {
    width: 400px;
}
.ex-area .ill-wrap img {
    width: 100%;
}

.ex-area .ex-wrap {
    margin: 50px 0 0;
    width: 100%;
}

.ex-area .ex-title {
	display: flex;
	gap: 20px;
}

.ex-area .ex-title .fukidashi {
    width: 200px;
}

.ex-area .ex-title .fukidashi img {
    width:100%;
    height: 100%;
    object-fit: cover;
}

.ex-area .ex-title .jp {
    font-size: 2.8rem;
    margin: 5px 0 0;
}

.ex-area .ill-list {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    margin: 30px 0 0;
}

.ex-area .ill-list-item {
    /*width: calc( ( 100% - 80px ) / 5 );*/
    flex: 1;
    background: #fff;
    padding: 20px;
    box-shadow: 2px 2px 30px rgba(227,227,225,.5);
    text-align: center;
}

.ex-area .ill-list-item .ill-wrap {
    width: 100%;
    text-align: center;
}

.ex-area .ill-list-item .ill-wrap img {
    width: auto;
    height: auto;
    max-width: 200px;
    max-height: 100px;
    object-fit: cover;
}

.ex-area .ill-list-item .list-txt {
    margin: 20px 0 0;
    line-height: 1.7;
    font-weight: bold;
    font-size: 1.5rem;
}


@media screen and (max-width: 768px) {
    .ex-area {
        padding: 40px 0;
    }
    
    .ex-area .inner {
        position: relative;
    }
    
    .ex-area .txt-wrap {
        width: 100%;
        padding: 0;
        position: relative;
        z-index: 1;
    }
    
    .ex-area .ill-wrap {
        width: 100%;
    }
    
    .ex-area .inner > .ill-wrap {
        position: absolute;
        top: -10px;
        right: -20px;
        width: 44vw;
    }
    
    .ex-area .txt-wrap .jp {
        font-size: 1.7rem;
    }
    
    .ex-area .txt-wrap .catch {
        /*font-size: min(5cqw,4.0rem);*/
		font-size: min(5.6cqw,3.6rem);
    }
    
    .ex-area .ex-wrap {
        margin: 30px 0 0;
    }
    
	.ex-area .ex-title {
		gap: 10px;
	}
	
    .ex-area .ex-title .fukidashi {
        width: 40vw;
    }
    
    .ex-area .ex-title .jp {
        font-size: 2rem;
    }
    
    .ex-area .ill-list {
        gap: 10px;
        margin: 20px 0 0;
    }
    
    .ex-area .ill-list-item {
        width: 100%;
        padding: 15px;
        text-align: left;
        display: flex;
        gap: 20px;
        align-items: center;
        flex: auto;
    }
    
    .ex-area .ill-list-item .ill-wrap {
        width: 25vw;
        text-align: center;
    }
    
    .ex-area .ill-list-item .ill-wrap img {
        max-width: 25vw;
        max-height: 20vw;
    }
    
    .ex-area .ill-list-item .list-txt {
        margin: 0;
        width: calc( 100% - ( 25vw + 20px ) );
        font-size: 1.6rem;
    }
}


/* -----------------------------------------------------------
    reason-area
-------------------------------------------------------------- */
.reason-area {
}

/*---------- 共通 ----------*/
.reason-area .section-title {
    text-align: center;
}

/*---------- top-block ----------*/
.reason-area .top-block {
    padding: 80px 0 0;
    text-align: center;
    position: relative;
    z-index: 2;
}

.reason-area .top-block::before {
    content: "";
    display: inline-block;
    -webkit-clip-path: polygon(50% 100%, 0 0, 100% 0);
    clip-path: polygon(50% 100%, 0 0, 100% 0);
    /*background: var(--beige);*/
	
	background: url("../img/bg-grid-white.png") repeat, #F5F8EC;
	background-size: 18px auto;
	
    width: 160px;
    height: 50px;
    position: absolute;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
}

.reason-area .top-block .catch {
    font-size: 3.2rem;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 40px;
    color: var(--orange);
    position: relative;
}

.reason-area .top-block .catch::before,
.reason-area .top-block .catch::after {
    content: "";
    display: inline-block;
    width: 1px;
    height: 50px;
    transform: rotate(-30deg);
    background: var(--orange);
}

.reason-area .top-block .catch::after {
    transform: rotate(30deg);
}

.reason-area .top-block .ill-wrap {
    margin: 30px 0 0;
}
.reason-area .top-block .ill-wrap img {
	width: 240px;
}

/*---------- bottom-block ----------*/
.reason-area .bottom-block {
    padding: 120px 0 100px;
    background: var(--beige_2);
    position: relative;
    margin-top: -80px;
    z-index: 1;
}

.reason-area .bottom-block .reason-block-wrap {
    margin: 40px 0 0;
}

.reason-area .bottom-block .reason-block {
    background: #fff;
    padding: 50px;
    display: flex;
    align-items: center;
    gap: 5%;
}

.reason-area .bottom-block .reason-block + .reason-block {
    margin-top: 40px;
}

.reason-area .bottom-block .reason-block .ill-wrap {
    width: 320px;
}

.reason-area .bottom-block .reason-block .ill-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.reason-area .bottom-block .reason-block .txt-wrap {
    width: calc( 95% - 320px );
}

.reason-area .bottom-block .reason-block .txt-wrap .num {
    font-size: 1.5rem;
    background: var(--orange);
    color: #fff;
    padding: 5px 10px;
    display: inline-block;
    font-family: var(--en);
    margin: 0 0 20px;
}

.reason-area .bottom-block .reason-block .txt-wrap .sub-catch {
    font-size: 1.8rem;
    font-weight: bold;
    color: var(--orange);
    margin: 0 0 10px;
}

.reason-area .bottom-block .reason-block .txt-wrap .catch {
    font-size: 3.4rem;
    font-weight: bold;
    line-height: 1.6;
}

@media screen and (min-width: 769px) {
    .reason-area .bottom-block .reason-block:nth-child(even) {
        flex-direction: row-reverse;
    }
}


@media screen and (max-width: 768px) {
    
    .reason-area .top-block {
        padding: 50px 0 0;
    }
    
    .reason-area .top-block::before {
        width: 100px;
        height: 30px;
    }
    
    .reason-area .top-block .catch {
        font-size: min(5.5cqw,4.0rem);
        gap: 20px;
    }
    
    .reason-area .top-block .basic-txt {
        font-size: 1.5rem;
		text-align: left;
    }
    
    .reason-area .top-block .ill-wrap {
        margin: 20px 0 0;
    }
    
    .reason-area .top-block .ill-wrap img {
        width: 50vw;
    }
    
    .reason-area .bottom-block {
        padding: 30vw 0 30px;
    }
    
    .reason-area .bottom-block .reason-block-wrap {
        margin: 20px 0 0;
    }
    
    .reason-area .bottom-block .reason-block {
        padding: 30px 20px;
        flex-wrap: wrap;
        gap: 20px;
        justify-content: center;
    }
    
    .reason-area .bottom-block .reason-block + .reason-block {
        margin-top: 20px;
    }
    
    .reason-area .bottom-block .reason-block .ill-wrap {
        width: 50vw;
    } 
    
    .reason-area .bottom-block .reason-block .txt-wrap {
        width: 100%;
        text-align: center;
    }
    
    .reason-area .bottom-block .reason-block .txt-wrap .num {
        font-size: 1.4rem;
        margin: 0 0 10px;
    }
    
    .reason-area .bottom-block .reason-block .txt-wrap .sub-catch {
        font-size: 1.7rem;
        line-height: 1.5;
        margin: 0 0 10px;
    }
    
    .reason-area .bottom-block .reason-block .txt-wrap .catch {
        font-size: 2.1rem;
        margin: 0 0 10px;
    }
    
    .reason-area .bottom-block .reason-block .txt-wrap .basic-txt {
        text-align: left;
    }
    
}

/* -----------------------------------------------------------
    cmn-service-area
-------------------------------------------------------------- */
.cmn-service-area{
	background: #fff;
	padding: 100px 0 0;
}
/*.cmn-service-area .intro .txt-area .catch,
.cmn-service-area .intro .txt-area .basic-txt,
.cmn-service-area .intro .ill{
	display: none
}*/
/*.cmn-service-area .intro .txt-area .jp{
	font-size: 2.4rem;
}*/
@media screen and (max-width: 768px) {

	.cmn-service-area {
		padding: 50px 20px 0;
	}
	
}
