@charset "UTF-8";

.-know-yoshindo .sec{
    margin-bottom: 165px;
}

.about-list li{
    width: 100%;
    height: 400px;
    overflow: hidden;
}

.about-list li:not(:last-of-type){
    margin-bottom: 52px;
}

.about-list li a{
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    transition: .3s ease-in-out;
}

.about-list li.movie a{
    background-image: url(../../img/know-yoshindo/img-about-01.jpg);
}

.about-list li.feature a{
    background-image: url(../../img/know-yoshindo/img-about-02.jpg);
}

.about-list li.data a{
    background-image: url(../../img/know-yoshindo/img-about-03.jpg);
}

.about-list li:hover a{
    transform: scale(1.1);
}

.about-list li.movie .visual{
    padding-top: 64px;
    background: url(../../img/know-yoshindo/img-ic-movie.svg) center top / 49px auto no-repeat;
}

.about-list .visual .ttl{
    font-size: 14px;
    text-align: center;
    color: #fff;
}

.about-list .visual em{
    display: block;
    font-size: 40px;
    line-height: 1.2;
    color: #fff;
}

/* data */
.-know-yoshindo.-data .sec{
    margin-bottom: 125px;
}

.-know-yoshindo.-data .sec:last-of-type{
    margin-bottom: 119px;
}

.data-block{
    display: flex;
    justify-content: space-between;
}

.data-hero{
    flex-shrink: 0;
    width: 381px;
    padding-top: 3px;
    text-align: center;
}

.data-hero .icon{
    margin-bottom: 23px;
}

.data-hero .btn{
    margin: 24px auto 0;
}

.data-ttl{
    font-size: 28px;
    font-weight: bold;
}

.data-flex-area{
    display: flex;
    flex-wrap: wrap;
    align-items: stretch;
    gap: 13px;
}

.data-inner-block{
    display: flex;
    flex-flow: column;
    justify-content: space-between;
    gap: 12px;
}

.data-card{
    width: 365px;
    padding: 20px 35px 0;
    background: #F7F7F7;
    text-align: center;
}

.data-card.left-icon,
.data-card.right-icon{
    width: 100%;
    text-align: left;
}

.data-card.left-icon .ttl,
.data-card.right-icon .ttl{
    text-align: left;
}

.data-card.left-icon{
    padding-left: 197px;
    padding-right: 20px;
    background-position: center left 42px;
    background-size: auto;
    background-repeat: no-repeat;
    background-image: url(../../img/know-yoshindo/img-data-bg-04.svg);
}

.data-card.right-icon{
    background-size: auto;
    background-repeat: no-repeat;
}

.-com .data-card.right-icon{
    background-position: center right 24px;
    background-image: url(../../img/know-yoshindo/img-data-bg-01.svg);
}

.-wor .data-card.right-icon{
    background-position: center right 54px;
    background-image: url(../../img/know-yoshindo/img-data-bg-05.svg);
}

.-ben .data-card.right-icon{
    background-position: center right 70px;
    background-image: url(../../img/know-yoshindo/img-data-bg-06.svg);
}

.data-card.side-icon{    
    position: relative;
}

.data-card.side-icon::before{
    content: url(../../img/know-yoshindo/img-data-bg-02.svg);
    position: absolute;
    top: 51px;
    left: 51px;
}

.data-card.side-icon::after{
    content: url(../../img/know-yoshindo/img-data-bg-03.svg);
    position: absolute;
    top: 51px;
    right: 51px;
}

.data-card .ttl{
    font-size: 28px;
    font-weight: bold;
    text-align: center;
    letter-spacing: -0.07em;
}

.data-card .ttl strong{
    padding: 0 11px;
    font-size: 74px;
    color: #EA6876;
    line-height: 1;
}

.data-card .ttl small{
    font-size: 14px;
    font-weight: 500;
    font-family: 'Noto Sans JP';
}

.data-card .ttl span{
    vertical-align: text-bottom;
}

.data-card .txt{
    display: inline-block;
    margin-top: 12px;
    padding-bottom: 25px;
    font-size: 14px;
    text-align: left;
}

.data-card div.txt{
    padding-bottom: 21px;
}

/* feature */
.-feature.-know-yoshindo .sec{
    margin-bottom: 113px;
}

.-feature .breadcrumd{
    position: absolute;
    padding-top: 5px;
    z-index: 50;
}

.-feature .breadcrumd li,
.-feature .breadcrumd li a{
    color: #fff;
}

.-feature .f-hero .f-hero-txt{
    position: absolute;
    width: 100%;
    margin-top: 6.25vw;
    text-align: center;
    color: #fff;
}

.f-hero-txt .txt:first-of-type{
    font-size: 14px;
}

.f-hero-txt .txt:nth-of-type(2){
    font-size: 30px;
}

.f-hero-txt .ttl{
    margin-top: 10px;
    font-size: 78px;
    font-weight: bold;
    line-height: 1.8;
}

.-feature .intro{
    padding: 158px 0 83px;
    text-align: center;
}

.-feature .intro .graph{
    width: 868px;
    margin: auto;
}

.-feature .intro .txt{
    margin-top: 95px;
}

.-feature .feature-list{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 84px 44px;
}

.-feature .feature-list .f-com{
    width: 540px;
}

.-feature .f-com .ttl{
    margin-top: 18px;
    font-size: 24px;
    font-weight: bold;
}

.-feature .f-com .txt{
    margin-top: 13px;
    letter-spacing: -0.01em;
    line-height: 1.6;
}

.-feature .feature-contents .inner > .txt{
    margin-top: 84px;
    text-align: center;
    font-size: 22px;
    font-weight: bold;
}


@media screen and (max-width:949px) {
    .-know-yoshindo .sec{
        margin-bottom: 64px;
    }
    
    .about-list li{
        height: 260px;
    }
    
    .about-list li:not(:last-of-type){
        margin-bottom: 32px;
    }  
    
    .about-list li.movie .visual{
        padding-top: 42px;
        background-size: 38px auto;
    }
    
    .about-list .visual .ttl{
        font-size: 12px;
    }
    
    .about-list .visual em{
        font-size: 28px;
    }
    /* data */
    .-know-yoshindo.-data .sec{
        margin-bottom: 48px;
    }

    .-know-yoshindo.-data .sec:last-of-type{
        margin-bottom: 98px;
    }

    .data-block{
        display: block;
    }

    .data-hero{
        width: 100%;
        margin-bottom: 32px;
        padding-top: 0;
    }

    .data-hero .icon{
        margin-bottom: 16px;
    }

    .data-hero .icon img{
        width: 100%;
        max-width: 130px;
        margin: auto;
    }

    .data-hero .btn{
        margin: 18px auto 0;
    }

    .data-ttl{
        font-size: 22px;
    }

    .data-flex-area{
        display: flex;
        flex-wrap: wrap;
        align-items: stretch;
        gap: 13px;
    }

    .data-inner-block{
        display: flex;
        flex-flow: column;
        justify-content: space-between;
        gap: 12px;
    }

    .data-card{
        width: 100%;
        padding: 20px 18px 0;
        background: #F7F7F7;
        text-align: center;
    }

    .data-card.left-icon,
    .data-card.right-icon{
        width: 100%;
        padding-top: 158px;
        text-align: left;
    }

    .data-card.left-icon .ttl,
    .data-card.right-icon .ttl{
        text-align: center;
    }

    .data-card.left-icon{
        padding-left: 18px;
        padding-right: 18px;
        background-position: center top 18px;
    }

    .data-card.right-icon{
        background-size: auto;
        background-repeat: no-repeat;
    }

    .-com .data-card.right-icon{
        background-position: center top 18px;
    }

    .-wor .data-card.right-icon{
        background-position: center top 18px;
    }

    .-ben .data-card.right-icon{
        background-position: center top 18px;
    }

    .data-card.side-icon{    
        position: relative;
    }

    .data-card.side-icon::before{
        content: none;
    }

    .data-card.side-icon::after{
        content: none;
    }

    .data-card .ttl{
        font-size: 18px;
    }

    .data-card.pad-btm .ttl{
        padding-bottom: 20px;
    }

    .data-card .ttl strong{
        padding: 0 8px;
        font-size: 42px;
    }

    .data-card .ttl small{
        font-size: 12px;
    }

    .data-card .ttl span{
        vertical-align: text-bottom;
    }

    .data-card .txt{
        display: inline-block;
        margin-top: 12px;
        padding-bottom: 25px;
        font-size: 14px;
        text-align: left;
    }

    .data-card div.txt{
        padding-bottom: 5px;
    }

    /* feature */
    .-feature.-know-yoshindo .sec{
        margin-bottom: 56px;
    }

    .-feature .f-hero .f-hero-txt{
        margin-top: 6.25vw;
    }

    .f-hero-txt .txt:first-of-type{
        font-size: 10px;
    }

    .f-hero-txt .txt:nth-of-type(2){
        font-size: 16px;
    }

    .f-hero-txt .ttl{
        margin-top: 0;
        font-size: 26px;
    }

    .-feature .intro{
        padding: 36px 0 52px;
    }

    .-feature .intro .graph{
        width: 100%;
        margin: auto;
        padding: 0 4.8%;
    }

    .-feature .intro .txt{
        margin-top: 48px;
        padding: 0 4.8%
    }

    .-feature .feature-list{
        display: block;
    }

    .-feature .feature-list .f-com{
        width: 100%;
    }

    .-feature .feature-list .f-com:not(:last-of-type){
        margin-bottom: 32px;
    }

    .-feature .f-com .ttl{
        margin-top: 8px;
        font-size: 18px;
    }

    .-feature .f-com .txt{
        margin-top: 10px;
    }

    .-feature .feature-contents .inner > .txt{
        margin-top: 52px;
        font-size: 18px;
        line-height: 2;
    }
}