.sub-visual{
    background: linear-gradient(0deg, rgba(0, 0, 0, 0.30) 0%, rgba(0, 0, 0, 0.30) 100%), url(../img/sub/product/visual.jpg) lightgray 50% / cover no-repeat;
}

.product-section2{
    padding-bottom: 60px;
}

.product-wrap{
    display: flex;
    flex-direction: column;
}

.img-wrap{
    display: flex;
    align-items: center;
    gap: 20px;  
    align-items: stretch;
}

.product-img{
    width: 50%;
    max-height: 650px;
    background-color: #fafafa;
    text-align: center;
    padding: 50px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end;
}

.product-img2{
    height: 650px;
    justify-content: center;
}

.product-img img{
    width: auto;
    height: auto;
    max-width: none;
    max-height: none;
    
}

.product-img p{
    color: #111;
    text-align: center;
    font-size: 20px;
    font-weight: 400;
    line-height: 140%; 
    margin-top: 28px;
}

.product-wrap .content{
    margin-top: 60px;
}

.product-wrap .info{
    margin-top: 40px;
}

.product-wrap .info .name{
    color: #111;
    font-size: 40px;
    font-weight: 700;
    line-height: 140%; 
    margin-bottom: 20px;
}

.product-wrap .info ul{
    display: flex;
    flex-direction: column;
    gap: 30px;
}

.product-wrap .info .txt{
    color: #585858;
    font-size: 24px;
    font-weight: 400;
    line-height: 140%; 
}

.product-wrap .range{
    margin-top: 60px;
    display: flex;
    flex-direction: column;
}

.product-wrap .range span{
    color: #111;
    font-size: 30px;
    font-weight: 700;
    line-height: 140%; 
    margin-bottom: 20px;
}

.product-wrap .range p{
    color: #585858;
    font-size: 24px;
    font-style: normal;
    font-weight: 400;
    line-height: 130%; 
}

.product-wrap .spec{
    margin-top: 60px;
}

.product-wrap .spec > p{
    color: #111;
    font-size: 30px;
    font-weight: 700;
    line-height: 140%; 
    margin-bottom: 20px;
}

.product-wrap .spec table{
    width: 100%;
    border-collapse: collapse;
    border: 1px solid #DDD;
    text-align: center;
}

.product-wrap .spec table th{
    color: #FFF;
    font-size: 20px;
    font-weight: 600;
    line-height: normal;
    background-color: var(--main-color);
    border: 1px solid #ffffff;
    height: 60px;
}

.product-wrap .spec table td:first-of-type{
    color: #1467A7;
    font-size: 20px;
    font-weight: 600;
    line-height: 130%;
    border-top: 1px solid #DDD;
    background: #FAFAFA;
}

.product-wrap .spec table td{
    color: #222;
    font-size: 18px;
    font-weight: 400;
    line-height: 130%; 
    border: 1px solid #DDD;
    height: 70px;
    background: #FFF;
}


@media screen and (max-width:1280px) {
    .product-img p{
        font-size: 18px;
    }
    .product-img{
        padding: 40px;
    }
    .product-img2{
        height: auto;
        padding: 100px 40px;
    }
    .product-img img{
        max-width: 100%;
    }
    .product-wrap .content{
        margin-top: 50px;
    }
    .product-wrap .info .name{
        font-size: 34px;  
    }
    .product-wrap .info .txt{
        font-size: 20px;
    }
    .product-wrap .range{
        margin-top: 50px;
    }
    .product-wrap .range span{
        font-size: 24px;
    }
    .product-wrap .range p{
        font-size: 20px;
    }
    .product-wrap .spec{
        margin-top: 50px;
    }
    .product-wrap .spec > p{
        font-size: 24px;
    }
    .product-wrap .spec table th{
        font-size: 18px;
    }
    .product-wrap .spec table td:first-of-type{
        font-size: 18px;
    }
    .product-wrap .spec table td{
        font-size: 16px;
    }
    .certificate > p{
        font-size: 34px;
    }
}

@media screen and (max-width:768px) {
    .product-img p{
        font-size: 16px;
    }
    .img-wrap{
        flex-direction: column;
    }
    .product-img{
        width: 100%;
        padding: 30px;
    }
    .product-wrap .content{
        margin-top: 40px;
    }
    .mark-img{
        max-width: 40%;
    }
    .product-wrap .info .name{
        font-size: 28px;  
    }
    .product-wrap .info .txt{
        font-size: 16px;
    }
    .product-wrap .range{
        margin-top: 40px;
    }
    .product-wrap .range span{
        font-size: 20px;
    }
    .product-wrap .range p{
        font-size: 18px;
    }
    .product-wrap .spec{
        margin-top: 40px;
    }
    .product-wrap .spec > p{
        font-size: 20px;
    }
    .product-wrap .spec table th{
        font-size: 15px;
    }
    .product-wrap .spec table td:first-of-type{
        font-size: 14px;
    }
    .product-wrap .spec table td{
        font-size: 14px;
    }
    .certificate > p{
        font-size: 30px;
    }
}

@media screen and (max-width:500px) {
    .product-wrap .info .name{
        font-size: 22px;
    }

}