@charset "utf-8";

/* ==========================================
BUSINESS01
========================================== */

.business01-contents {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.business01-msg-box {
    width: 100%;
    margin: 4.5rem 0 0;
    position: relative;
}

.business01-text-box {
    margin: 5rem 0 0;
}

.business01-text-box .text01 {
    font-weight: 700;
    line-height: 2.35em;
}

.business01-illust {
    position: absolute;
    max-width: 22.1rem;
    width: 30%;
    height: 14.4rem;
    top: 0;
    left: 0;
    bottom: 0;
    margin: auto;
}

.business01-img-box {
    max-width: 110rem;
    width: 100%;
    margin: 6rem auto 0;
    border-radius: 7rem;
    padding: 6.9rem 1.5rem 8rem;
    box-shadow: 0 .4rem 1rem rgba(0,0,0,.1);
}

.business01-img-box.bg-white {
    background-color: var(--white);
}

.business01-img {
    max-width: 87.4rem;
    width: 100%;
    margin: 0 auto;
}

.in-msg-mt {
    margin: 1rem 0 0;
}

/* ==========================================
BUSINESS02
========================================== */

.business02.bg-fifth {
    background-color: var(--fifth);
}

.business02 {
    border-radius: 0 30rem 0 0;
}

.business02-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    margin: 7rem auto 0;
}

.business02-card {
    max-width: 50rem;
    width: 32.5%;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    position: relative;
}

.business-title {
    font-family: var(--font-family01);
    font-size: 2.5rem;
    font-weight: 700;
    letter-spacing: 0.05em;
    text-align: center;
}

.business02-card .business-title {
    margin: 2rem 0 0;
}

.business-title .has-inline-color {
    color: var(--primary) !important;
}

.business-text-box {
    max-width: 35rem;
    width: 100%;
    margin: 2.4rem auto 0;
}

.business-text-box .text01 {
    font-weight: 700;
    line-height: 1.85em;
}

/* ==========================================
BUSINESS03
========================================== */

/*------TEXT LOOP------*/

.loop-wrapper {
  display: flex;
  align-items: center;
  overflow: hidden;
  height: auto;
}

.loop-img-area {
  display: flex;
  animation: loop-slide 50s infinite linear 1s both;
}

.text-loop-img-box01 {
	width: 220rem;
    /*height: 0; /* 追加 */
	position: relative;
	padding: 0;
    margin: 0;
    overflow: hidden;
}

.text-loop-img-box01 img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    overflow: hidden;
}

/*アニメーション*/
@keyframes loop-slide {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
} 

/*------contents------*/

.business03-contents {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.flow-box {
    margin: 10rem auto 0;
}

.business03-row {
    width:100%;
    height:auto;
    display:flex;
    justify-content:space-between;
    flex-wrap:wrap; /* 折り返し指定 */
    margin: 4rem auto 0;
}

.flow-box01 .business03-row {
    flex-wrap:wrap; /* 折り返し指定 */
}

.flow-box01 .business03-card {
    width:30%;
}

.flow-box02 {
    max-width: 90rem;
    width: 100%;
}

.flow-box02 .business03-card {
    width:46%;
}

.business03-card {
    height:auto; 
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    align-items:center;
    padding: 2rem 1.5rem 3rem;
    border-radius: 4.4rem;
    box-shadow: 0 .4rem 1rem rgba(0,0,0,.2);
}

.business03-card.bg-white {
    background-color: var(--white);
}

.flow-box01 .business03-card:nth-of-type(4) {
    margin-left:17.5%;/* 4番目の子要素の左に計算した余白を指定 */
}

.flow-box01 .business03-card:nth-of-type(5) {
    margin-right:17.5%;/* 5番目の子要素の左に計算した余白を指定 */
}

.flow-box01 .business03-card:nth-of-type(n+4) {
    margin-top: 6rem;/* 4番目以降の子要素の上に余白指定 */
}

.flow-box02 .business03-card:nth-of-type(n+3) {
    margin-top: 6rem;
}

.business03-card .num-text {
    font-family: var(--font-family01);
    font-size: 4.7rem;
    font-weight: 700;
    letter-spacing: 0.05em;
}

.business03-card .business-text-box {
    max-width: 38rem;
    width: 100%;
    margin: 2.4rem auto 0;
    padding: 2rem 1rem 0;
    border-top: .3rem dashed var(--secondary);
}

/* ==========================================
BUSINESS04
========================================== */

.business04 {
    border-radius: 30rem 0 0 0;
} 

.business04.bg-seventh {
    background-color: var(--seventh);
}

.business04-row {
    max-width: 122rem;
    margin: 8rem auto 0;
}

.business-left {
    width: 44%;
}

.business-right {
    width: 50%;
}

.business-right .business-text {
    margin: 4rem 0 0;
    font-weight: 700;
    line-height: 2em;
}

.business04-img01 img {
    width: 100%;
}

/* ==========================================
BUSINESS05
========================================== */

.business05-contents {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.faq {
    width: 100%;
    margin: 8rem 0 0;
}

.faq-block {
    border-bottom: .3rem dashed;
}

.faq-header {
    display: flex;
    align-items: center;
    padding: 0 0 2rem 0;
}

.faq-block:nth-child(n+2) .faq-header {
    padding: 2rem 0;
}

.faq-body {
    display: flex;
    align-items: baseline;
    letter-spacing: 0.05em;
    line-height: 1.6em;
    padding: .5rem 0 1rem 0;
    font-weight: 500;
}

.faq-body {
    padding: .5rem 0 1.5rem 0;
}

.faq-icon {
    max-width: 6rem;
    width: 100%;
    height: 6rem;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    font-size: 3rem;
    line-height: 1em;
    letter-spacing: 0;
    font-weight: 700;
}

.faq-icon-q {
    background-color: var(--primary);
}

.faq-text-box {
    flex-grow: 1;
    flex-basis: .1rem;
    margin: 0 0 0 2%;
}

.q-text {
    font-size: 1.8rem;
    font-weight: 700;
}

.faq-icon-a {
    background-color: #fff;
    border: 1px solid var(--primary);
}


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1920px) {


}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1550px) {



}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1024px) {



    /* ==========================================
	BUSINESS01
	========================================== */

    .business01-illust {
        width: 16%;
    }

    /* ==========================================
	BUSINESS02
	========================================== */

    .business02 {
     	border-radius: 0 20rem 0 0;   
    }

    .business-title {
        font-size: 1.8rem;
    }

    /* ==========================================
    BUSINESS04
    ========================================== */

    .business04 {
     	border-radius: 20rem 0 0 0;   
    }


}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 768px) {


    /* ==========================================
	BUSINESS02
	========================================== */

    .business02 {
     	border-radius: 0 15rem 0 0;   
    }

    .business02-row {
        flex-direction: column;
        margin: 6rem auto 0;
    }


    .business02-card {
        width: 100%;
        margin: 0 auto;
    }

    .business02-card:nth-child(n+2) {
        margin: 4rem auto 0;
    }

    .business-title {
        font-size: 2rem;
    }


    /* ==========================================
    BUSINESS03
    ========================================== */

    .flow-box01 .business03-card, .flow-box02 .business03-card {
        width:48%;
    }

    .flow-box01 .business03-card:nth-of-type(4) {
        margin-left:0;/* 4番目の子要素の左に計算した余白を指定 */
    }

    .flow-box01 .business03-card:nth-of-type(5) {
        margin-left:auto;
        margin-right:auto;/* 5番目の子要素の左に計算した余白を指定 */
    }

    .flow-box01 .business03-card:nth-of-type(n+3) {
        margin-top: 6rem;/* 4番目以降の子要素の上に余白指定 */
    }
    
    /* ==========================================
    BUSINESS04
    ========================================== */

    .business04 {
     	border-radius: 15rem 0 0 0;   
    }

    .business-left {
        width: 100%;
    }

    .business-right {
        width: 100%;
        margin: 3rem 0 0;
    }

    /* ==========================================
    BUSINESS05
    ========================================== */

    .faq-icon {
        max-width: 4rem;
        height: 4rem;
        font-size: 2rem;
    }

    .q-text {
        font-size: 1.6rem;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 576px) {

    /* ==========================================
	BUSINESS01
	========================================== */

    .business01-text-box .text01 {
        text-align: left;
    }

    .business01-text-box .text01 br {
        display: none;
    }


    /* ==========================================
	BUSINESS02
	========================================== */

    .business02 {
     	border-radius: 0 10rem 0 0;   
    }

    /* ==========================================
	BUSINESS03
	========================================== */

    .flow-box01 .business03-card, .flow-box02 .business03-card  {
        width:100%;
    }

    .flow-box01 .business03-card:nth-of-type(n+2), .flow-box02 .business03-card:nth-of-type(n+2) {
        margin-top: 6rem;/* 4番目以降の子要素の上に余白指定 */
    }

    /* ==========================================
    BUSINESS04
    ========================================== */

    .business04 {
     	border-radius: 10rem 0 0 0;   
    }


}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 414px) {



}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */