@charset "utf-8";
body{
    background-color: #e4ecff;
}
.mainVisual{
    display:block;
    background-color: transparent;
    height: auto;
    width:100%;
    padding:43px 62px 0;
    background-image: url(/resource/coupon/images/couponImg/visualBg.png);
    background-repeat: no-repeat;
    background-size: auto;
    background-position: center bottom;
    margin-bottom:140px;
    overflow: visible;
}
.mainVisual > .logoArea{
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: flex-start;
    width: 100%;
}
.mainVisual .logo{
    position:static;
}
.mainVisual > .titleBx{
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: flex-start;
    margin-top: -81px;
    padding-bottom: 227px;
    position: relative;
}
.mainVisual > .titleBx::after{
    display: block;
    content:'';
    width:100%;
    max-width:516px;
    background-image: url(/resource/coupon/images/couponImg/visualItem.png);
    background-repeat: no-repeat;
    background-size: auto;
    background-position: center bottom;
    aspect-ratio: 516 / 275;
    position:absolute;
    bottom:-69px;
    left:50%;
    transform: translate(-50%, 0);
}
section{
    width:100%;
    max-width:1196px;
    margin:0 auto 70px;
}
.container{
    width:100%;
}
.conBox{
    display: flex;
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    gap: 38px 0;
    border: 0;
    padding: 0;
    width:100%;
}
.conBox .title{
    margin-bottom:0;
}
.imgBx{
    width:100%;
    margin:0 auto;
}
.imgBx > img{
    display: block;
    width:100%;
}
button.topBtn{
    background: url(/resource/coupon/images/couponImg/top_btn.png) no-repeat;
    background-size:100%;
}

@media screen and (max-width: 1280px) {
    .mainVisual > .logoArea > .pageLogo > a > img{
        width: 10rem;
    }
    .mainVisual > .titleBx{
        margin-top:-20px;
    }
    .mainVisual > .titleBx > img{
        height: 12rem;
    }
    .mainVisual > .titleBx::after{
        max-width:440px;
        background-size:100% auto;
        min-width: 280px;
    }
    section{
        max-width: inherit;
        padding: 0 62px;
        box-sizing: border-box;
    }
    .conBox .title > h3 > img{
        height:10rem;
    }
}

@media screen and (max-width: 1024px) {
    .mainVisual{
        padding:43px 32px 0;
        margin-bottom:100px;
    }
    .mainVisual > .titleBx::after{
        max-width:320px;
    }
    .mainVisual > .titleBx > img{
        height: 8rem;
    }
    section{
        padding:0 32px;
    }
    .conBox .title > h3 > img{
        height:8rem;
    }
}
@media screen and (max-width: 768px) {
    section{
        padding:0 20px;
    }
    .mainVisual{
        background-size:auto 30%;
        margin-bottom: 70px;
        padding:11px 15px 0 10px;
    }
    .logoArea > .pageLogo{
        margin-top:4px;
    }
    .mainVisual > .titleBx {
        padding-bottom: 160px;
        margin-top: 0;
    }
    .mainVisual > .titleBx::after{
        bottom:-30px;
    }
}
@media screen and (max-width: 480px) {
    .mainVisual{
        padding:11px 10px 0 10px;
    }
    .pc3{
        display: block !important;
        width:7rem !important;
    }
}