.cooperation-page{
    background-color: #fff;
    padding-bottom: 40px;
}
.page-wrapper{
    width: 100%;
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 22px;
}
@media(max-width: 833px){
    .page-wrapper{
        padding: 0 16px;
    }
}
@media(max-width: 734px){
    .page-wrapper{
        max-width: 430px;
    }
}
.banner{
    width: 100%;
    height: 300px;
    box-shadow: rgba(0, 0, 0, 0.1) 0px 1px 3px 0px;
}
.banner-box{
    width: 100%;
    height: 100%;
    position: relative;
}
.banner-text{
    position: absolute;
    width: 100%;
    max-width: 1280px;
    padding: 0 22px;
    left: 50%;
    top: 46%;
    transform: translate(-50%,-50%);
}
.banner-text h3{
    margin: 0;
    padding: 0;
    font-size: 40px;
    text-align: center;
    color: #fff;
    line-height: 1;
    margin-bottom: 20px;
}
.banner-text p{
    margin: 0;
    padding: 0;
    font-size: 20px;
    color: #ddd;
    text-align: center;
    line-height: 1.3;
}
.banner-image{
    width: 100%;
    height: 100%;
}
.banner-image .wap{
    display: none;
}
.banner-image .pc{
    width: 100%;
    height: 100%;
}
.banner-image .wap{
    width: 100%;
    height: 100%;
}
.banner-image .pc img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.banner-image .wap img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
@media(max-width: 1068px){
    .banner{
        height: 240px;
    }
    .banner-text h3{
        font-size: 32px;
    }
    .banner-text p{
        font-size: 16px;
    }
}
@media(max-width: 734px){
    .banner-image .pc{
        display: none;
    }
    .banner-image .wap{
        display: block;
    }
}






.title h2{
    font-size: 24px;
    line-height: 1.57;
    font-weight: 600;
    color: #1d1d1f;
    padding: 20px 0;
    border-bottom: 1px solid rgba(0, 0, 0, 0.08);
    margin: 30px 0;
}
@media(max-width: 734px){
  .title h2{
    font-size: 20px;
    padding: 10px 0;
    margin: 20px 0;
  }  
}


.list-item-wrap{
    display: flex;
    flex-wrap: wrap;
    gap: 48px;
}
.type-list-item{
    width: calc(50% - 24px);
}
.type-list-item .item-link{
    display: block;
    aspect-ratio: 594 / 273;
    border-radius: 16px;
    overflow: hidden;
}
.type-list-item .item-link picture{
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 100%;
    display: block;
}
.type-list-item .item-link img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .3s;
    transform-origin: center;
    will-change: transform;
    backface-visibility: hidden;
}
.list-item{
    width: calc(25% - 36px);

}
.list-item .item-box{
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    aspect-ratio: 1 / 1;
    background: #f6f6f6;
    border-radius: 16px;
    overflow: hidden;
}
.item-img-box{
    position: relative;
    display: flex;
    justify-content: center;
    width: 70%;
    aspect-ratio: 1 / 1;
}
.item-img-box .item-img{
    display:flex;
    justify-content: center;
    align-items: center;
}
.item-img-box .item-img img{
    /*position: absolute;*/
    max-width: 100%;
    max-height: 100%;
    transition: transform .3s;
    transform-origin: center;
    will-change: transform;
    backface-visibility: hidden;
}
.item-description{
    margin-top: 10px;
}
.item-description .item-title{
    display: inline-block;
    color: #3c3c3c;
    line-height: 1.75;
    font-size: 16px;
    font-weight: bold;
}
.item-description .item-subtitle{
    color: #000;
    margin-top: 2px;
    line-height: 1.75;
    font-size: 14px;
    white-space:nowrap; 
    overflow:hidden; 
    text-overflow:ellipsis;
}
.item-btn-wrap{
    margin-top: 6px;
}
.item-btn-wrap .item-btn{
    font-size: 14px;
    display: inline-block;
    position: relative;
    color: #000;
}
.item-btn-wrap .item-btn:after{
    content: "";
    width: 100%;
    height: 1px;
    bottom: -1px;
    left: 0;
    position: absolute;
    background: currentColor;
}
.item-btn-wrap .item-btn:not(:last-of-type){
    margin-right: 12px;
}
.item-btn-wrap .item-btn:hover{
    opacity: .7;
}
.item-btn-wrap .item-btn a{
    display: block;
    color: inherit;
}
.item-btn-wrap .item-btn a:focus,
.item-btn-wrap .item-btn a:hover{
    text-decoration: none;
}
@media only screen and (min-width: 834px){
    .type-list-item .item-link:hover img{
        transform: scale(1.06);
    }
    .item-img-box:hover .item-img img{
        transform: scale(1.06);
    }
}
@media only screen and (max-width: 1279px){
    .list-item-wrap{
        gap: 42px;
    }
    .type-list-item{
        width: calc(50% - 21px);
    }
    .list-item{
        width: calc(25% - ((42px * 3) / 4));

    }
}
@media only screen and (max-width: 1068px){
    .list-item-wrap{
        gap: 36px;
    }
    .type-list-item{
        width: calc(100% - ((100% - 72px) / 3) - 36px);
    }
    .list-item{
        width: calc((100% - 72px) / 3);

    }
}
@media only screen and (max-width:833px){
    .list-item-wrap{
        gap: 30px;
    }
    .type-list-item{
        width: calc(100% - ((100% - 60px) / 3) - 30px);
    }
    .list-item{
        width: calc((100% - 60px) / 3);

    }
}
@media only screen and (max-width: 734px){
    .type-list-item .item-link,
    .list-item .item-box{
        height: auto;
        aspect-ratio: 1 / 1;
    }
    .list-item-wrap{
        gap: 24px;
        margin-top: 24px;
    }
    .type-list-item{
        width: 100%;
        position: relative;
    }
    .list-item{
        width: calc(50% - 12px);
    }
    .type-list-item .item-description .item-title {
        color: #fff;
        font-size: 20px;
        text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
    }
    .type-list-item .item-description{
        width: 100%;
        position: absolute;
        left: 0;
        bottom: 80px;
        margin-top: 0;
        padding: 0 72px;
        text-align: center;
    }
    .type-list-item .item-description .item-subtitle{
        color: #fff;
        margin-top: 0;
        text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
    }
    .type-list-item .item-btn-wrap .item-btn {
        color: #fff;
        text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
    }
}
@media only screen and (max-width: 430px){
    .type-list-item .item-link,
    .list-item .item-box{
        border-radius: 12px;
    }
    .list-item-wrap{
        gap: 16px;
        margin-bottom: -16px;
        margin-top: 16px;
    }
    .list-item{
        width: calc(50% - 8px);
    }
    .type-list-item .item-description {
        bottom: 11.2835vw;
    }
    .item-description{
        margin-top: 0;
        padding: 8px 0 12px;
    }
    .item-description .item-title{
        font-size: 14px;
    }
    .item-description .item-subtitle{
        font-size: 12px;
        margin-top: 0;
    }
    .item-btn-wrap{
        margin-top: 4px;
    }
    .item-btn-wrap .item-btn{
        font-size: 12px;
    }
    .type-list-item .item-description{
        padding: 0 10vw;
    }
    .type-list-item .item-description .item-title{
        font-size: 18px;
    }
    .type-list-item .item-description .item-subtitle{
        font-size: 14px;
    }
    .type-list-item .item-btn-wrap{
        margin-top: 5px;
    }
    .type-list-item .item-btn-wrap .item-btn{
        font-size: 12px;
    }
}



.bottom-control{
    margin-top: 36px;
}
.paginations {
    padding: 15px 0;
}
.paginations .pagination-wrap {
    text-align: left;
}
@media(max-width: 734px){
    .bottom-control{
        margin-top: 30px;
    }
}


.contact-list{
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 48px;
}
.contact-list li{
    width: calc(50% - 24px);
    background-color: #f6f6f6;
    border-radius: 16px;
    padding: 30px;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.contact-list li p{
    margin: 0;
    padding: 0;
    font-size: 15px;
    line-height: 1.5;
}
@media(max-width: 1279px){
    .contact-list{
        gap: 42px;
    }
    .contact-list li{
        width: calc(50% - 21px);
    }
}
@media(max-width: 1068px){
    .contact-list{
        gap: 36px;
    }
    .contact-list li{
        width: calc(50% - 18px);
    }
}
@media(max-width: 833px){
    .contact-list{
        gap: 30px;
    }
    .contact-list li{
        width: calc(50% - 15px);
    }
}
@media(max-width: 734px){
    .contact-list{
        gap: 24px;
    }
    .contact-list li{
        width: calc(50% - 12px);
        gap: 6px;
    }
    .contact-list li{
        padding: 16px 18px;
    }
    .contact-list li p{
        font-size: 14px;
    }
}
@media(max-width: 430px){
    .contact-list{
        gap: 16px;
    }
    .contact-list li{
        width: calc(50% - 8px);
        border-radius: 12px;
    }
}

.hot-list{
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 48px;
}
.hot-list li{
    width: calc(25% - 36px);
    background-color: #f6f6f6;
    border-radius: 16px;
    display: flex;
    flex-direction: column;
    border-radius: 16px;
    overflow: hidden;
}
.hot-list li .top-img{
    margin: 0;
    padding: 0;
    width: 100%;
}
.hot-list li .top-img i{
    display: flex;
    width: 100%;
    height: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    align-items: center;
    justify-content: center;
}
.hot-list li .inner{
    display: flex;
    padding: 20px;
    gap: 10px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.hot-list li .top-img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.hot-list li .bottom-img{
    margin: 0;
    padding: 0;
    width: 20%;
    aspect-ratio: 1 / 1;
}
.hot-list li .bottom-img img{
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.hot-list li .text-box{
    text-align: center;
}
.hot-list li .text-box h3{
    margin: 0;
    font-size: 20px;
    line-height: 1.3;
    color: #1d1d1f;
}
.hot-list li .text-box p{
    margin: 0;
    font-size: 14px;
    line-height: 1.4;
    color: #777;
}
@media(max-width: 1279px){
    .hot-list{
        gap: 42px;
    }
    .hot-list li{
        width: calc(25% - ((42px / 4) * 3));
    }
}
@media(max-width: 1068px){
    .hot-list{
        gap: 36px;
    }
    .hot-list li{
        width: calc(25% - 27px);
    }
    .hot-list li .bottom-img{
        width: 36px;
    }
}
@media(max-width: 833px){
    .hot-list{
        gap: 30px;
    }
    .hot-list li{
        width: calc(25% - ((30px / 4) * 3));
    }
}
@media(max-width: 734px){
    .hot-list{
        gap: 24px;
        flex-wrap: wrap;
    }
    .hot-list li{
        width: calc(50% - 12px);
    }
    .hot-list li .inner{
        padding: 16px 12px;
    }
    .hot-list li .text-box h3{
        font-size: 16px;
    }
    .hot-list li .text-box p{
        font-size: 12px;
    }
}
@media(max-width: 430px){
    .hot-list{
        gap: 16px;
        flex-wrap: wrap;
    }
    .hot-list li{
        width: calc(50% - 8px);
        border-radius: 12px;
    }
}