/* --------------------------------
    main
-------------------------------- */
.fv{
    padding: 114px 40px 40px;
    position: relative;
}
.fv .pc{
    display: block;
}
.fv .sp{
    display: none;
}
.fv img{
    border-radius: 12px;
}

.news_topic{
    max-width: 1180px;
    width: 100%;
    z-index: 50;
    padding: 0 170px;
    padding: 36px 40px 36px 36px;
    border-radius: 12px;
    position: absolute;
    bottom: -10%;
    left: 50%;
    transform: translateX(-50%);
}
.topic_ttl{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 0 24px 0;
}
.topic_ttl .news{
    font-size: 2.4rem;
}
.more_btn{
    width: 90px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.catch_area{
    background-image: url(../img/blue_gradient.png);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    width: 1500px;
    width: 100%;
    /* height: 1181px; */
    position: relative;
    padding: 0 0 180px;

}
.catch_area .flex_box{
    display: flex;
    padding: 206px 240px 0 170px;

    max-width: 1110px;
    width: 100%;
    display: flex;
    padding: 206px 0 170px;
    margin: 0 auto;
}
.catch_area .catchcopy{
    display: flex;
    flex-direction: column;
    width: 100%;
    max-width: 1100px;
}
.catch_area .catchcopy p{
    color: var(--white);
    font-size: 3.6rem;
    letter-spacing: 0.1em;
}
.catch_area .catchcopy .en{
    font-size: 5.6rem;
    padding: 1em 0 0;
}
.catch_area .message{
    color: var(--white);
    line-height: 2.2;
    width: 62%;
}
.catch_area .message p{
    padding: 1em 0;
    letter-spacing: 0.1em;
}
.link_btn{
    max-width: 300px;
    height: 64px;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    background-color: var(--white);
    border-radius: 50px;
    /* padding: 24px 94px; */
    margin: 60px 0 0;
}
.link_btn:hover{
    opacity: 0.6;
}

.catch_area .message .link_btn p{
    padding: 0;
}

.catch_area .message .link_btn p{
    position: relative;
}
.catch_area .message .link_btn p::after {
    position: absolute;
    display: block;
    content: "";
    background-image: url(https://test.lachichoken.com/wp-content/uploads/2024/12/arrow.png);
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    width: 19px;
    height: 17px;
    top: 50%;
    transform: translateY(-50%);
    right: -4em;
}
.swiper{
    width: 100%;
}
.swiper.top{
    width: 100%;
    position: absolute;
    left: 0;
    bottom: -30px;
}
.swiper-wrapper{
    display: flex;
    align-items: center;
    max-width: 300px;
    width: 100%;
    transition-timing-function: linear;
}
.swiper-slide{
    padding: 0 10px;
    margin: 0;
}

.to_under{
    width: 100%;
    margin: 0 auto;
    padding: 84px 0 44px;
}
.under_link{
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    padding: 0 40px;
}
h2{
    color: var(--white);
    font-size: 3.8rem;
}
.under_link .under_contents{
    border-radius: 12px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1420px;
    width: 100%;
}
.under_introduce{
    display: flex;
    justify-content: space-between;
    align-items: center;
    background-size: contain;
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    max-width: 1420px;
    width: 100%;
    height: 400px;
    border-radius: 12px;
    padding: 0 80px 0 120px;
}
.under_introduce.products{
    background-image: url(../img/to_products.png);
}
.under_introduce.company{
    background-image: url(../img/to_company.png);
}
.under_introduce.recruit{
    background-image: url(../img/to_recruit.png);
}
.under_link .under_page{
    color: var(--white);
    display: flex;
    flex-direction: column;
}
.under_link .under_page h2{
    margin: 0 0 0.6em;
}
.under_link .under_page p{
    line-height: 2.2;
}
.under_link .company{
    width: 50%;
}
.under_introduce.company{
    width: 100%;
    margin: 42px 20px 0 0;
}
.under_link .recruit{
    width: 50%;
}
.under_introduce.recruit{
    width: 100%;
    margin: 42px 0 0 20px;
}
/* 下層ページリンクのflexboxテキスト部分 */
.under_introduce .under_page{
    width: 60%;
}
.cricle_and_arrow{
    width: 62px;
    height: 62px;
    padding: 22px;
    border: 1px solid var(--white);
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 160px 0 0;
}
/* 矢印 (右向き) */
.dli-arrow-right {
    display: inline-block;
    vertical-align: middle;
    color: var(--white);
    line-height: 1;
    position: relative;
    width: 1em;
    height: 0.1em;
    background: currentColor;
    transition: background-color 0.8s ease;
}
.dli-arrow-right::before {
    content: '';
    width: 0.65em;
    height: 0.65em;
    border: 0.1em solid currentColor;
    border-left: 0;
    border-bottom: 0;
    transform: rotate(45deg);
    transform-origin: top right;
    position: absolute;
    top: 50%;
    right: -0.05em;
    box-sizing: border-box;
}
/* hover */
.under_contents:hover .cricle_and_arrow{
    background-color: var(--blue);
    border: none;
}

.address_area{
    max-width: 1420px;
    margin: 0 auto 96px;
    padding: 0 30px;
}
.address_area .bg_light_green{
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 66px 120px 78px;
    max-width: 1420px;
    border-radius: 12px;
}
.address_container{
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    align-items: center;
    width: 70%;
}
.address_contents{
    width: 100%;
}
.bg_green{
    border-radius: 8px;
    padding: 16px 0 16px 20px;
}
h3{
    font-size: 2.6rem;
}
.address_container .address{
    display: flex;
    flex-direction: column;
    padding: 0.6em 0 1em 1em;
    line-height: 1.8;
}
.address_container .number{
    display: flex;
    align-items: center;
}
.address_container .number p{
    font-size: 2.8rem;
}
.address_container .number .txt_width{
    width: 40%;
}
.address_container .tel_number{
    display: flex;
    align-items: center;
}
.address_container .tel_number img{
    margin: 0 0.6em 0 1.2em;
}
.address_container .number .fz_16{
    font-size: 16px;
}
.tel_number span{
    font-size: 1.28rem;
}

.useful_links{
    width: 100%;
    border-top: 1px solid var(--border_gray);
    border-bottom: 1px solid var(--border_gray);
}
.useful_links .contents{
    max-width: 882px;
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    margin: 0 auto;
    padding: 16px 0;
}
.useful_links a{
    width: 30%;
}
.useful_links img{
    width: 100%;
    padding: 10px ;
}

@media screen and (max-width:1200px) {
    .fv{
        padding: 40px;
    }
    .news_topic{
        bottom: -5%;
        max-width: 80%;
    }
    .catch_area .flex_box{
        padding: 40px 60px 70px 44px;
    }
    .under_introduce{
        padding: 0 40px 0 60px;
    }
    .address_container .number {
        flex-direction: column;
    }
    .address_container .number .txt_width {
        width: 100%;
    }
    .address_container .tel_number {
        width: 100%;
    }
    .address_container .tel_number img {
        margin: 0 0.6em 0 0;
    }
    .tel_number p.free_dial{
        line-height: 1.4;
    }
    .tel_number .fz_12{
        display: block;
    }
}

@media screen and (max-width:768px) {
    .news_topic{
        padding: 18px 20px 18px 18px;
        bottom: -20%;
    }
    .topic_ttl {
        padding: 0 0 16px 0;
    }
    .catch_area .flex_box {
        padding: 100px 60px 70px 44px;
        flex-direction: column;
        align-items: center;
        margin: 0;
    }
    .catch_area .catchcopy p{
        font-size: 2.2rem;
    }
    .catch_area .catchcopy .en{
        font-size: 3.6rem;
    }
    .catch_area .message{
        width: 100%;
    }
    .under_link {
        flex-direction: column;
    }
    .under_introduce{
        background-position: 20% 0;
    }

    /* 取扱商品ページリンク */
    .under_introduce.products{
        width: 100%;
    }
    .under_introduce .under_page {
        width: 100%;
    }

    .under_introduce.company, 
    .under_introduce.recruit{
        background-position: right;
    }
    .under_link .company {
        width: 100%;
        margin: 20px 0 0;
    }
    .under_link .recruit{
        width: 100%;
        margin: 20px 0;
    }
    .address_area .bg_light_green{
        flex-direction: column;
        padding: 32px 60px 40px;
        padding: 30px;
    }
    .address_container {
        width: 100%;
    }
    .address_container .bg_green {
        margin: 0 0 10px;
    }
    .address_container .number{
        line-height: 1.4;
        padding: 14px 0;
    }
    .address_container .number .txt_width{
        padding: 0 0 10px;
    }
    .address .block{
        display: block;
        line-height: 1;
    }
    .line_qr{
        padding: 0 0 8px;
    }
    .useful_links a{
        width: 50%;
    }

    .swiper-slide {
        height: 200px !important;
    }
    .swiper-wrapper {
        max-width: 200px;
    }
    .swiper-slide {
        width: 100% !important;
    }
    .swiper-slide img{
        height: 100%;
    }
    .under_link {
        padding: 0 20px;
    }
    .under_introduce {
        flex-direction: column;
        align-items: end;
        height: auto;
        padding: 50px 40px 50px 42px;
    }
    .cricle_and_arrow {
        margin: 1em 0 0;
    }
}

@media screen and (max-width:440px) {
    .fv .pc{
        display: none;
    }
    .fv .sp{
        display: block;
        width: 100%;
    }

    #top{
        margin: 44px 0 0;
    }
    .fv {
        padding: 40px 40px 0;
    }
    .news_topic {
        max-width: 334px;
        bottom: -6%;
    }
    .catch_area .flex_box {
        padding: 80px 46px 70px 44px;
    }
    .address_container .number p {
        font-size: 2.4rem;
    }
    .under_introduce.products {
        background-position: 24%;
    }
    .under_link .company {
        background-position: 78%;
    }
    .under_link .recruit {
        background-position: 80%;
    }
    .under_link .recruit {
        background-position: 80%;
    }
}