.pc {display: block;}
.sp {display: none;}

.img_w {
    width: 100%;
    height: auto;
}

#contents {
    overflow: hidden;
}
#wrapper {
    width: 100%;
    max-width: 680px;
    margin: auto;
}

.cont01 {
    position: relative;
    padding-bottom: 100px;
margin-top: -21px;
    background: url(/files/user/img/page/hakkenpj/top/top_back.png) #ffeb59;
    background-size: cover;
    background-position: center;
}
.top_copy {
    padding: 50px 0 0 50px;
}
.cont01 .top_text {
    margin: 20px 0 0 50px;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 170%; /* 27.2px */
    letter-spacing: 0.06em;
    font-family: Noto Sans JP;
}
.top_body_copy {
    margin-top: 277px;
    text-align: center;
    font-size: 17px;
    font-style: normal;
    font-weight: 400;
    line-height: 174%; /* 29.58px */
    letter-spacing: 0.2em;
    font-family: Noto Sans JP;
}
.hakken_top {
    position: absolute;
    top: 250px;
    left: 262px;
    width: 318px;
}
.sennin_top {
    position: absolute;
    top: 370px;
    left: 125px;
    width: 135px;
}

.cont_title {
    text-align: center;
    width: 100%;
    max-width: 587px;
    margin: auto;
}

.union1 {
    position: absolute;
    top: -56px;
    left: 39px;
    width: 98px;
}
.union2 {
    position: absolute;
    top: -50px;
    right: 39px;
    width: 98px;
}

.aisyo_bn {
    width: 80%;
    margin: 50px auto 0;
}

.cont02 {
    position: relative;
    padding: 50px 0 80px;
    background: #FFFADD;
}
.slider1,
.slider2 {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    width: calc(100% - 40px);
    margin-top: 30px;
    padding: 0 20px;
    list-style: none;
}
.slider_box {
    position: relative;
    width: 250px;
    padding: 20px;
    margin-bottom: 32px;
    background: #FFEB59;
    border-radius: 20px;
}
.white .slider_box {
    background: #FFFADD;
}
.slider_box p:nth-of-type(1) {
    margin-top: 15px;
    padding-left: 10px;
    font-size: 14px;
    font-style: normal;
    font-weight: 500;
    line-height: 150%; /* 21px */
    letter-spacing: 0.56px;
    border-left: 4px solid #fff;
font-family: Noto Sans JP;
}
.white .slider_box p:nth-of-type(1) {
    border-left: 4px solid #FFEB59;
}
.slider_box p:nth-of-type(2) {
    margin-top: 10px;
    font-size: 17px;
    font-style: normal;
    font-weight: 500;
    line-height: 170%; /* 28.9px */
    letter-spacing: 0.68px;
font-family: Noto Sans JP;
}

.more_btn {
    width: 100%;
    max-width: 187px;
    margin: 30px auto;
}

.cont03 {
    position: relative;
    padding: 50px 0 120px;
    background: #FFEB59;
}
.sennin1 {
    position: absolute;
    top: -60px;
    left: 50px;
    width: 109px;
}
.hakken2 {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    width: 303px;
    margin: auto;
    text-align: center;
}

.cont04 {
    position: relative;
    padding: 100px 0 230px;
    background: #FFFADD;
}
.hakken1 {
    position: absolute;
    top: -80px;
    right: 106px;
    width: 133px;
    z-index: 50;
}
.cont03_back {
    position: absolute;
    top: -140px;
    right: 38px;
    width: 213px;
    z-index: 30;
}
.cont04_text {
    margin-top: 50px;
    text-align: center;
    font-family: Noto Sans JP;
    font-size: 16px;
    font-style: normal;
    font-weight: 400;
    line-height: 170%; /* 27.2px */
    letter-spacing: 0.64px;
}
.cont04_inner {
    position: relative;
    width: 100%;
    margin-top: 50px;
    height: 442px;
    background: url(/files/user/img/page/hakkenpj/top/cont04_img_back.png) no-repeat;
    background-position: center;
}
.cont04_box {
    position: absolute;
    width: 308px;
}
.no1 {top: 0px;left: 25px;}
.no2 {top: 40px;right: 25px;}
.no3 {top: 235px;left: 25px;}
.no4 {top: 277px;right: 25px;}

.cont05 {
    position: relative;
    padding: 50px 0;
    background: #FFEB59;
}
.cont05_inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: calc(100% - 40px);
    max-width: 640px;
    margin: 50px auto 0;
}
.cont05_box1 {
    width: 285px;
}
.cont05_btn_area {
    position: relative;
    margin: 40px 0;
}
.cont05_btn_area ul {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 30px;
    display: flex;
    justify-content: space-between;
    width: calc(100% - 20px);
    max-width: 600px;
    margin: auto;
    list-style: none;
}
.mfp-zoom-out-cur, .mfp-zoom-out-cur .mfp-image-holder .mfp-close {
    cursor: pointer !important;
    color: #000 !important;
}
.mfp-close {
    top: 57px !important;
    right: 26px !important;
}
.mfp-figure:after {
     background: inherit !important;
    -webkit-box-shadow: inherit !important;
    box-shadow: inherit !important;
}

.mfp-bg {
    background: #FFFADD !important;
}
