
.hero-section {
    position: relative;
    width: 100%;
    aspect-ratio: 16 / 9;
    max-height: 100vh;
    overflow: hidden;
}
.hero-image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    opacity: 0;
    transition: opacity 2s ease-in-out;
    object-fit: cover;
}
.hero-image.ajust{
    object-fit: contain;
    top:auto;
    bottom:0;
}
.hero-image.active {opacity: 1;}
.hero-section > .left{
    position:absolute;
    left:0;
    top:0;
    width:60%;
    max-width:600px;
}
.hero-section > .left img{height:100%;}
.hero-section > .right{
    position:absolute;
    right:0;
    top:0;
    display: flex;
    max-width: 415px;
    padding: 20px 20px 20px 0px;
    gap: 20px;
}
.hero-section > .right > .tel{
    width:220px;
    height: 40px;
}
.hero-section > .right > .inquiry:hover,.hero-section > .right > .inquiry:active{opacity:0.5;}
@media screen and (max-width: 768px) {
    .hero-section {
        height: auto;
        overflow: visible;
    }
    .hero-section::after {
        content: "";
        display: block;
        padding-top:100%
    }
    .hero-image {position: absolute;}
    .hero-section .left{display:none;}
    .hero-section > .right{padding:12px 8px 12px 0px;}
    .hero-section > .right > .tel{display:none;}
}

#catchphrase{
    background-image: url(../images/index/bg_minamo.svg), linear-gradient(112deg, #015D96 14.28%, #012E57 74.3%);
    background-size: 540px auto, cover;
    background-position: right 15% top -40px, 0 0;
    background-repeat: no-repeat, no-repeat;
    display: flex;
    padding: 80px 0px;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
    gap: 80px;
}
#catchphrase h1{
    width:95%;
    max-width:800px;
    margin:auto;
}
.plan{
    display: flex;
    flex-direction: column;
    align-items: center;
    align-self: stretch;
}
.plan h2{
    width:100%;
    max-width:450px;
    margin:80px auto 20px auto;
}
.plan .plan-box{
    display: flex;
    width:100%;
    justify-content:center;
    margin:20px 0px 0px 0px;
}
.plan .left{
    display: flex;
    width:50%;
    min-width: 380px;
    max-width: 430px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    border-radius: 100px 0px 0px 0px;
    background: #082232;
    padding:29px 0px;
}
.plan .left > h3{
    width:220px;
}
.plan .left > div{
    padding:20px 0px;
    width: 360px;
}
.plan .left > a{
    color: #FFF;
    text-align: center;
    font-size: 12px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.2px;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: auto;
    text-underline-offset: 4px;
    text-underline-position: from-font;
}
.plan .left > a::before{content:"→";}
.plan .left > a:hover,.plan .left > a:active{color: #DFDEAC;}
.plan .right{
    width:50%;
    min-width: 360px;
    max-width: 430px;
    background: #FFF;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.plan .right .detail{
    display: flex;
    gap: 30px;
    align-items: center;
    flex-shrink: 0;
    align-self: stretch;
    padding:0px 48px;
}
.plan .right .img{width:132px;}
.plan .right .spec{
    color: #555;
    font-size: 14px;
    font-weight: 500;
    line-height: 22px;
    letter-spacing: 1.12px;
}
.plan .right .spec > span{
    font-size: 11px;
    font-weight: 500;
    line-height: 22px;
    letter-spacing: 0.88px;
}
.plan .right .spec > b{
    font-size: 16px;
    font-weight: 500;
    line-height: 22px;
    letter-spacing: 1.28px;
}
.plan .right .spec > a{
    color: #0171E2;
    font-size: 14px;
    font-weight: 400;
    letter-spacing: 1.4px;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: auto;
    text-underline-offset: 4px;
    text-underline-position: from-font;
}
.plan .right .spec > a::before{content:"→"}
.plan .right .spec > a:hover,.plan .right .spec > a:active{color: #06417E;}
.plan .right > a{display:none;}
#img-scroll {
    overflow: hidden;
    white-space: nowrap;
}
#img-scroll div{
    margin:0px 5px;
    width:286px;
    display:inline-block;
}
@media screen and (max-width: 768px) {
    #catchphrase{
        padding:30px 0px 40px 0px;
        gap: 30px;
        background-size: 320px auto, cover;
        background-position: right -100px top -2%, 0 0;
    }
    #catchphrase h1{max-width:290px;}
    .plan h2{
        max-width:280px;
        margin:40px auto 0px auto;
    }
    .plan .plan-box{
        flex-wrap:wrap;
    }
    .plan .left{
        border-radius: 60px 0px 0px 0px;
        width:100%;
        max-width: none;
        min-width: auto;
        padding:27px 0px;
    }
    .plan .left > div{width:240px;}
    .plan .right{
        max-width: none;
        min-width: auto;
        width:100%;
    }
    .plan .right .detail{
        justify-content:center;
        padding:20px 12px 0px 12px;
        gap:15px;
    }
    .plan .right .img{min-width:120px;}
    .plan .right .spec > a{display:none;}
    .plan .right > a{
        display: inline-block;
        margin:0px 0px 13px 0px;
        color: #0171E2;
        font-size: 14px;
        font-weight: 400;
        line-height: normal;
        letter-spacing: 1.4px;
        text-decoration-line: underline;
        text-decoration-style: solid;
        text-decoration-skip-ink: auto;
        text-decoration-thickness: auto;
        text-underline-offset: 4px;
        text-underline-position: from-font;
    }
    .plan .right > a::before{content:"→"}
    .plan .right > a:hover,.plan .right > a:active{color: #06417E}
    .plan-c .right > a{margin-top:15px}
    #img-scroll div{width:173px;}
}

#access{
    background: #F5F5F7;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 60px 0px;
    gap: 40px;
}
#access h2{
    width:100%;
    max-width:500px;
    margin:auto;
}
#access h3{
    color: #8D7A57;
    font-size: 24px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 2.88px;
}
#access p{
    color: #333;
    font-size: 16px;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.92px;
    padding:10px 0px 0px 0px;
}
#access a{
    color: #0171E2;
    font-size: 14px;
    font-style: normal;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.4px;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: auto;
    text-underline-offset: 4px;
    text-underline-position: from-font;
    margin:0px 0px 0px 20px;
}
#access a:hover,#access a:active{color: #06417E;}
#gMap{
    width:100%;
    height: 300px;
    margin:40px 0px 30px 0px;
}
@media screen and (max-width: 768px) {
    #access{
        padding: 40px 0px;
        gap:20px
    }
    #access h2{max-width:280px;}
    #gMap{
        margin:20px 0px;
        height: 231px;
    }
    #access h3{
        font-size: 16px;
        letter-spacing: 1.92px;
    }
    #access p{
        padding:6px 0px;
        font-size: 12px;
        letter-spacing: 1.44px;
    }
    #access a{
        margin:0px
    }
}

#features{
    display: flex;
    padding: 60px 0px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    align-self: stretch;
    border-radius: 0px 200px 0px 0px;
    background: #082232;
}
#features h2{
    width:100%;
    max-width:500px;
    margin:0px auto 40px auto;
}
.features-box{
    display: flex;
    align-items: flex-start;
    align-content: flex-start;
    gap: 20px 10px;
    align-self: stretch;
    flex-wrap: wrap;
}
.features-box div{
    display: flex;
    width: 280px;
    flex-direction: column;
    align-items: flex-start;
}
.features-box img{
    width:auto;
    height: 170px;
}
.features-box h3{
    color:#FFF;
    font-size: 16px;
    font-weight: 600;
    line-height: 20px;
    letter-spacing: 1.92px;
    padding:15px 0px 10px 0px;
}
.features-box p{
    color: #FFF;
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    letter-spacing: 1.68px;
}
@media screen and (max-width: 768px) {
    #features{
        padding: 40px 20px;
        border-radius: 0px 80px 0px 0px;
        gap: 20px;
    }
    #features h2{
        max-width:280px;
        margin: 0px auto 20px auto;
    }
    .features-box div{
        width:100%;
        min-width:280px;
    }
    .features-box img{
        width:100%;
        height:auto;
    }
}

#ideas{
    background: #F5F5F7;
    display: flex;
    padding: 60px 40px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    align-self: stretch;
}
#ideas h2{
    width:100%;
    max-width:500px;
    margin:auto;
}
.ideas-box{
    padding:40px 0px;
    display: flex;
    align-content: flex-start;
    align-items: flex-start;
    gap: 20px 10px;
    align-self: stretch;
    flex-wrap: wrap;
}
.ideas-box div{
    display: flex;
    width: 280px;
    flex-direction: column;
    align-items: flex-start;
}
.ideas-box img{
    width:auto;
    height: 170px;
}
.ideas-box h3{
    color:#3E3A39;
    font-size: 16px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 1.92px;
    margin:15px 0px 7px 0px;
}
.ideas-box p{
    color: #281A24;
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    letter-spacing: 1.68px;
}
#ideas ul{
    list-style:none;
    margin:0px auto;
    padding:0;
    width:100%;
    max-width:460px;
}
#ideas ul li{
    color: #281A24;
    font-size: 14px;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.68px;
    -webkit-text-size-adjust: none;
}
#ideas ul li::before{content:"※"}
@media screen and (max-width: 768px) {
    #ideas{
        padding: 40px 20px;
        gap:20px;
    }
    #ideas h2{max-width:280px;}
    .ideas-box{padding:20px 0px}
    .ideas-box div{
        width:100%;
        min-width:280px;
    }
    .ideas-box img{
        width:100%;
        height:auto;
    }
    #ideas ul li{
        font-size: 12px;
        font-weight: 400;
        line-height: 16px;
        letter-spacing: 1.44px;
    }
}

#facility{
    background: #FFF;
    display: flex;
    padding: 60px 0px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}
#facility h2{
    width:100%;
    max-width:500px;
    margin:auto;
}
#facility .icon{
    display: flex;
    max-width: 740px;
    margin:auto;
    padding: 40px 0px;
    align-items: flex-start;
    align-content: flex-start;
    gap: 20px 40px;
    align-self: stretch;
    flex-wrap: wrap;
}
#facility .detail{
    display: flex;
    width: 183px;
    justify-content: center;
    align-items: center;
    border: 1px solid #C3C3C3;
    color: #555;
    font-size: 12px;
    font-weight: 400;
    line-height: 16px;
    letter-spacing: 0.96px;
    padding:16px 15px;
    -webkit-text-size-adjust: none;
}
#facility-img-box {
    overflow: hidden;
    width:100%;
    position: relative;
}
.content_area{
    max-width: 860px;
    padding: 0 40px;
    margin: 0 auto;
}
.slick-list{overflow: visible;}
.slick-initialized .slick-slide{margin:0px 5px;width:286px;}
.slick-dots{bottom:-35px}
.slick-dots li{margin:0px 1px}
.slick-dots li button::before{font-size:11px;}
.prev-arrow,.next-arrow {
    display: block;
    width: 40px;
    height: 60px;
    cursor: pointer;
    filter: drop-shadow(0px 4px 4px rgba(0, 0, 0, 0.25));
    position:absolute;
    top:-30px;
    bottom:0;
    margin:auto;
}

.prev-arrow{
    content:url(../images/index/facility/slide/arrow_slide_l.svg);
    left:0;
}
.next-arrow{
    content:url(../images/index/facility/slide/arrow_slide_r.svg);
    right:0;
}

@media screen and (max-width: 768px) {
    #facility{padding: 40px 0px;}
    #facility h2{max-width:280px;}
    #facility .icon{
        gap:20px 5px;
        padding:40px 0px 0px 0px;
        justify-content:center;
    }
    #facility .detail{
        font-size: 11px;
        letter-spacing: 0.88px;
        padding:16px 10px;
        width:160px;
    }
    .content_area{
        width:100%;
        max-width:none;
        padding:0px;
    }
    .facility-img-box .slick-slide{
        width:300px;
    }
}

#qa{
    display: flex;
    padding: 80px 0px;
    flex-direction: column;
    align-items: center;
    gap: 10px;
    align-self: stretch;
    background: #F5F5F7;    
}
#qa h2{
    width:100%;
    max-width:180px;
}
.qa-box{
    display: flex;
    max-width: 860px;
    align-items: flex-start;
    gap: 80px;
    align-self: stretch;
}
.qa-box .left{
    display: flex;
    align-items: center;
    width:254px;
    flex-wrap:wrap;
}
.qa-box .left > a{
    content:url(../images/index/QA/button_pc.svg);
    width:254px;
    height:50px;
    display: block;
    margin:40px 0px 0px 0px;
}
.qa-box .left > a:hover,.qa-box .left > a:active{content:url(../images/index/QA/button_pc_inversion.svg)}
.qa-box .right > a{display:none;}
.qa-box dl{width:482px;}
.qa-box dl dt{
    display: flex;
    min-height:27px;
    padding: 17px 24px 17px 20px;
    align-self: stretch;
    align-items: flex-start;
    border-radius: 6px;
    background: #FFF;
    color: #333;
    font-size: 16px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 1.92px;
    text-align:left;
    position: relative;
    margin:18px 0px 0px 0px;
    cursor: pointer;
    transition: border-radius 0.3s ease;
}
.qa-box dl .open{border-radius: 6px 6px 0px 0px;}
.qa-box dl dt > span{padding:2px 35px 0px 45px}
.qa-box dl dt::before{
    content:"";
    background-image: url(../images/index/QA/icon_qa_q.svg);
    width:27px;
    height:27px;
    background-repeat:no-repeat;
    background-size:100%;
    background-position:center center;
    display:inline-block;
    position:absolute;
    top:0;
    bottom:0;
    left:20px;
    margin:auto;
}
.qa-box dl dt::after{
    content:"";
    background-image: url(../images/index/QA/icon_qa_plus.svg);
    width:27px;
    height:27px;
    background-repeat:no-repeat;
    background-size:100%;
    background-position:center center;
    position:absolute;
    top:0;
    bottom:0;
    right:20px;
    margin:auto;
}
.qa-box dl .open::after{
    background-image: url(../images/index/QA/icon_qa_minus.svg);
}
.qa-box dl dd{
    display:none;
    margin-bottom:18px;
    background: #FFF;
    border-radius: 0px 0px 6px 6px;
    color: #333;
    font-size: 16px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 1.92px;
    padding: 0px 24px 23px 20px;
}
.qa-box dl dd > span{
    display:table-cell;
    vertical-align:top;
    padding:0px 60px 0px 19px;
}
.qa-box dl dd::before{
    content:"";
    background-image: url(../images/index/QA/icon_qa_a.svg);
    width:27px;
    height:27px;
    background-repeat:no-repeat;
    background-size:100%;
    background-position:top center;
    display:table-cell;
}
@media screen and (max-width: 768px) {
    #qa{
        padding: 40px 0px;
        gap: 20px;
    }
    #qa h2{
        max-width:280px;
        margin-bottom:10px;
    }
    #qa .box{
        display:flex;
        max-width:none;
        width:90%;
    }
    .qa-box{
        flex-wrap:wrap;
        gap:0;
    }
    .qa-box .left{
        width:100%;
        justify-content:center;
    }
    .qa-box .left > a{display:none;}
    .qa-box .right{width:100%;}
    .qa-box .right > a{
        display: block;
        width:220px;
        height: 40px;
        content:url(../images/index/QA/button_sp.svg);
        margin:20px auto 0px auto;
    }
    .qa-box .right > a:active{content:url(../images/index/QA/button_sp_inversion.svg);}
    .qa-box dl{
        width:100%;
        min-width:260px;
    }
    .qa-box dl dt{
        font-size: 12px;
        font-weight: 600;
        line-height: normal;
        letter-spacing: 1.44px;
        padding:12px 0px 5px 0px;
    }
    .qa-box dl dt::before{left:10px;}
    .qa-box dl dt::after{right:10px;}
    .qa-box dl dt > span{padding:2px 35px 7px 48px;}
    .qa-box dl dd{
        font-size: 12px;
        letter-spacing: 1.44px;
        padding:0px 35px 10px 50px;
        position:relative;
    }
    .qa-box dl dd::before{
        position:absolute;
        top:2px;
        left:10px
    }
    .qa-box dl dd >span{padding:0px 60px 0px 0px}
}

#news{
    display: flex;
    padding: 60px 50px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
    align-self: stretch;
    border-radius: 200px 0px 0px 0px;
    background: #FFF;
}
#news h2{
    width:100%;
    max-width:500px;
    margin:auto;
}
#news dl{
    display: flex;
    width:100%;
    max-width: 800px;
    flex-direction: column;
    align-items: flex-start;
    margin:0px;
}
#news dl dt{
    color: #555;
    font-size: 16px;
    font-weight: 500;
    line-height: normal;
    letter-spacing: 1.28px;
    padding-bottom:30px;
    width:100%;
    border-bottom:1px solid #D9D9D9;
    margin:40px 0px 0px 0px;
    position: relative;
}
#news dl dt::after{
    content:"";
    width: 24px;
    height: 24px;
    background-image: url(../images/index/news/arrow_open.svg);
    background-repeat: no-repeat;
    background-size:100%;
    display:inline-block;
    position:absolute;
    top:5px;
    right:0;
    margin:auto;
}
#news dl .open{border-bottom:none}
#news dl .open::after{background-image: url(../images/index/news/arrow_close.svg);}
#news dl dt > .label{
    color: #FFF;
    font-size: 14px;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.12px;
    display:inline-block;
    background: #555;
    width:114px;
    padding:5px 0px;
    text-align:center;
    margin:0px 75px 0px 20px
}
#news dl dt > .title{
    color: #0171E2;
    font-size: 14px;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.12px;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: auto;
    text-underline-offset: 4px;
    text-underline-position: from-font;
}
#news dl .open > .title{
    color:#333;
    text-decoration-line: none;
}
#news dl dd{
    display:none;
    padding:0px 0px 40px 305px;
    border-bottom:1px solid #D9D9D9;
    color: #333;
    font-size: 14px;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.12px;
}
.close-button{display:none;}
@media screen and (max-width: 768px) {
    #news{
        padding:40px 0px;
        gap: 20px;
        border-radius: 80px 0px 0px 0px;
    }
    #news .box{
        display:flex;
        width:90%;
        max-width:none;
        flex-wrap:wrap;
    }
    #news h2{
        margin:0px auto 10px auto;
        max-width:280px;
    }
    #news .news-box{
        width:100%;
        min-width:260px;
    }
    #news dl dt{
        margin:10px 0px 0px 0px;
        padding-bottom:27px;
        font-size: 14px;
        letter-spacing: 1.12px;
    }
    #news dl .open{padding-bottom:10px}
    #news dl .open::after{background-image:none;}
    #news dl dt > .label{
        font-size: 11px;
        letter-spacing: 0.88px;
        padding:2px 4px;
        width:auto;
        margin:0px 0px 0px 10px
    }
    #news dl dt > .title{
        display: block;
        padding:10px 0px 0px 0px;
        font-size: 13px;
        line-height: 18px;
        letter-spacing: 0.52px;
        text-underline-offset: 2px;
    }
    #news dl dt::after{
        top:auto;
        bottom:4px;
    }
    #news dl dd{
        padding:0px 0px 27px 0px;
        font-size: 13px;
        letter-spacing: 1.04px;
        position: relative;
    }
    #news dl dd > .close-btn{
        width: 24px;
        height: 24px;
        background-image: url(../images/index/news/arrow_close.svg);
        background-repeat: no-repeat;
        background-size:100%;
        display:inline-block;
        position:absolute;
        bottom:5px;
        right:0;
        margin:auto;
    }
}

#inquiry{
    background: #8D7A57;
    display: flex;
    padding: 60px 0px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}
#inquiry h2{
    width:100%;
    max-width:500px;
    margin:auto;
}
.inquiry-box{
    display: flex;
    width:90%;
    max-width: 730px;
    align-items: center;
    gap: 10px;
    align-self: stretch;
    margin:40px auto 0px auto;
    justify-content: center;
}
.inquiry-box div{
    background: #FFF;
    text-align: center;
}
.inquiry-box h3{
    color: #333;
    font-size: 14px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 1.68px;
}
.inquiry-box p{
    color: #333;
    font-size: 12px;
    text-align: center;
    font-weight: 400;
    line-height: 16px;
    letter-spacing: 1.44px;
}
.inquiry-box .tel{padding: 25px 70px;}
.inquiry-box .tel-link{
    content:url(../images/index/inquiry/tel_inquiry_pc.svg);
    padding:10px 0px 0px 0px;
}
.inquiry-box .mail{padding:23px 53px}
.inquiry-box .mail a{
    content:url(../images/index/inquiry/btn_mail_inquiry_pc.svg);
    margin-top:15px;
}
.inquiry-box .mail a:hover,.inquiry-box .mail a:active{content: url(../images/index/inquiry/btn_mail_inquiry_pc_inversion.svg);}
@media screen and (max-width: 768px) {
    #inquiry{
        padding: 40px 0px;
        gap: 20px;
    }
    #inquiry h2{max-width:280px;}
    .inquiry-box{
        width:100%;
        margin:20px 0px 0px 0px;
        flex-wrap: wrap;
    }
    .inquiry-box h3{
        font-size: 13px;
        letter-spacing: 1.56px;
    }
    .inquiry-box .tel{
        width:100%;
        padding:15px 0px;
    }
    .inquiry-box .tel-link{
        content:url(../images/index/inquiry/btn_tel_inquiry_sp.svg);
        margin:10px auto;
        padding:0px;
        width:220px;
        height:40px;
    }
    .inquiry-box .tel-link:active{content:url(../images/index/inquiry/btn_tel_inquiry_sp_inversion.svg)}
    .inquiry-box p{
        font-size: 10px;
        line-height: 14px;
        letter-spacing: 1.2px;
    }
    .inquiry-box .mail{
        width:100%;
        padding:15px 0px 20px 0px;
    }
    .inquiry-box .mail a{
        margin:10px auto 0px auto;
        width: 220px;
        height: 40px;
        content:url(../images/index/inquiry/btn_mail_inquiry_sp.svg);
    }
    .inquiry-box .mail a:active{content:url(../images/index/inquiry/btn_mail_inquiry_sp_inversion.svg)}
}

#gojokai{
    display: flex;
    padding: 60px 0px 150px 0px;
    flex-direction: column;
    align-items: center;
    gap: 40px;
}
#gojokai .catch{
    width:98%;
    max-width:730px;
    margin:auto;
    text-align:center;
}
#gojokai .catch h2{
    color: #06417E;
    font-size: 24px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 2.88px;
    text-align:center;
}
#gojokai .catch h2 > span{
    background-position: top left 3px;
    background-repeat: repeat-x;
    background-size: 1em 1em;
    background-image: radial-gradient(.1em .1em at center center,#06417E,#06417E 100%,transparent,transparent);
    padding-top: 0.5em;
}
#gojokai .catch p{
    color: #3E3A39;
    font-size: 14px;
    font-weight: 400;
    line-height: 22px;
    letter-spacing: 1.68px;
    text-align:left;
    padding:7px 0px 14px 0px;
}
#gojokai .catch a{
    color: #0171E2;
    text-align: center;
    font-size: 12px;
    font-weight: 400;
    line-height: normal;
    letter-spacing: 1.2px;
    text-decoration-line: underline;
    text-decoration-style: solid;
    text-decoration-skip-ink: auto;
    text-decoration-thickness: auto;
    text-underline-offset: 4px;
    text-underline-position: from-font;
}
#gojokai .catch a::before{content:"→";}
#gojokai .catch a:hover,#gojokai .catch a:active{color:#06417E;}
.gojokai-box{
    display: flex;
    align-items: flex-start;
    align-content: flex-start;
    gap: 10px;
    align-self: stretch;
    flex-wrap: wrap;
}
.gojokai-box > div{
    display: flex;
    width: 280px;
    justify-content: center;
    align-items: center;
    background: #FFF;
    box-shadow: 0px 4px 12px 0px rgba(0, 0, 0, 0.25);
    -webkit-text-size-adjust: none;
}
.gojokai-box a{
    width:100%;
    padding: 27px 0px;
}
.gojokai-box a:hover,.gojokai-box a:active{
    opacity:0.5;
}
.gojokai-box > .appleclub a{
    padding:19px 0px;
}
.gojokai-box .icon{
    width:36px;
    margin:0px auto 8px auto;
}
.gojokai-box .text{
    color: #333;
    text-align: center;
    font-size: 11px;
    font-weight: 600;
    line-height: normal;
    letter-spacing: 1.32px;
}
@media screen and (max-width: 768px) {
    #gojokai{
        padding: 40px 0px;
        gap: 20px;
    }
    #gojokai .catch{
        width:90%;
        min-width:280px;
    }
    #gojokai .catch h2{
        font-size: 16px;
        letter-spacing: 0.64px;
        text-align:left;
    }
    #gojokai .catch p{
        padding:10px 0px;
        font-size: 12px;
        line-height: 18px;
        letter-spacing: 0.96px;
    }
    .gojokai-box{gap: 15px;}
    .gojokai-box > div{
        width:100%;
    }
    .gojokai-box > div > a{
        width:100%;
        display:table;
        padding:12px 45px 12px 12px;
    }
    .gojokai-box .icon{
        display:table-cell;
        vertical-align:middle;
    }
    .gojokai-box .text{
        display:table-cell;
        vertical-align:middle;
        text-align:left;
        padding:0px 0px 0px 8px
    }
    .gojokai-box > .appleclub a{
        padding:9px 12px;
    }
}
.campaign-banner-box{
    position:fixed;
    bottom:21px;
    right: 20px;
    width:240px;
    filter: drop-shadow(4px 4px 16px rgba(0, 0, 0, 0.16));
}
.campaign-banner-box a:hover,.campaign-banner-box a:active{opacity:0.5;}
.campaign-banner-box .point{display:none;}
@media screen and (max-width: 768px) {
    .campaign-banner-box{
        width:100%;
        border-radius: 20px 0px 0px 0px;
        background: rgba(255, 255, 255, 0.90);
        bottom:0;
        left:0;
        right:auto;
        position:fixed;
        filter:none
    }
    .campaign-banner-box a{
        width:100%;
        height:100%;
    }
    .campaign-banner-box a > div{
        width:100%;
        max-width:280px;
        margin:auto;
    }
    .campaign-banner-box .point{
        display: block;
        position:absolute;
        top:0;
        right:0;
        width:42px;
    }
}