@charset "utf-8";
/*--------------------------------------------------------------------------------
  * PC *
  ------------------------------------------------------------------------------*/

/* ************************************************************************
*
* STYLE
*
************************************************************************ */
.sp {
    display: none;
}

.pc {
    display: block;
}

body.is-fixed {
    overflow: hidden;
}


.lc_wrapper {
    width: 100%;
    margin: 0 auto;
    text-align: center;
    font-family: "Yu Gothic Medium", "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.lc_wrapper a {
    display: block;
    text-decoration: none;
}

.lc_wrapper a.sp {
    display: none;
}

.lc_wrapper a:hover {
    opacity: 0.6;
}

.lc_wrapper .link_btn {
    width: 305px;
    height: 60px;
    box-sizing: border-box;
    border: 1px solid #0090d5;
    line-height: 60px;
    background: #0090d5;
    color: #fff;
    font-size: 18px;
    position: relative;
    text-align: center;
    margin: 0 auto;
}

.lc_wrapper .join .link_btn {
    background: #000000;
    border: 1px solid #000000;
}

.lc_wrapper .join .link_btn:hover {
    border: 1px solid #000000;
    opacity: 1;
}

.lc_wrapper .link_btn a,
.lc_wrapper .link_btn i {
    color: #fff;
}

.lc_wrapper .link_btn:hover {
    background: #fff;
    transition: .5s;
    -webkit-transition: .5s;
}

.lc_wrapper .link_btn a:hover {
    color: #0090d5;
    transition: .5s;
    -webkit-transition: .5s;
}

.lc_wrapper .join .link_btn a:hover,
.lc_wrapper .join .link_btn i:hover {
    color: #000000;
    opacity: 1;
}

.lc_wrapper .link_btn::after {
    content: "";
    display: block;
    position: absolute;
    pointer-events: none;
    border-top: 0;
    border-right: 0;
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
    width: 10px;
    height: 10px;
    right: 30px;
    top: 23px;
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
}

.lc_wrapper .link_btn:hover:after {
    border-bottom: 1px solid #0090d5;
    border-left: 1px solid #0090d5;
    transition: .5s;
    -webkit-transition: .5s;
}

.lc_wrapper .join .link_btn:hover:after {
    border-bottom: 1px solid #000000;
    border-left: 1px solid #000000;
}

/* ----- 02(JRE POINTアプリ用) ----- */

.lc_wrapper .link_btn02 {
    width: 305px;
    height: 60px;
    padding-top: 10px;
    box-sizing: border-box;
    border: 1px solid #0090d5;
    line-height: 20px;
    background: #0090d5;
    color: #fff;
    font-size: 18px;
    position: relative;
    text-align: center;
    margin: 0 auto;
    margin-top: 20px;
}



.lc_wrapper .link_btn02 a,
.lc_wrapper .link_btn02 i {
    color: #fff;
}



.lc_wrapper .link_btn02:hover {
    background: #fff;
    transition: .5s;
    -webkit-transition: .5s;
}



.lc_wrapper .link_btn02 a:hover {
    color: #0090d5;
    transition: .5s;
    -webkit-transition: .5s;
}



.lc_wrapper .link_btn02::after {
    content: "";
    display: block;
    position: absolute;
    border-top: 0;
    border-right: 0;
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
    width: 10px;
    height: 10px;
    right: 30px;
    top: 23px;
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
}



.lc_wrapper .link_btn02:hover:after {
    border-bottom: 1px solid #0090d5;
    border-left: 1px solid #0090d5;
    transition: .5s;
    -webkit-transition: .5s;
}

/* フェードイン */
.fadein {
    opacity: 0;
    transform: translate(0, 50px);
    transition: all 1s;
}

.fadein.scrollin {
    opacity: 1;
    transform: translate(0, 0);
}


/* 
    header
    ---------------------------------- */
.lc_wrapper header {
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 200;
}

.lc_wrapper header .top {
    background: url(../img/head_bg.jpg) repeat-x;
    padding: 27px 0;
}

.lc_wrapper header .top_inner {
    width: 980px;
    margin: 0 auto;
}

.lc_wrapper header .top h1 {
    font-size: 0;
    background: url(../img/card_logo.jpg) no-repeat;
    width: 330px;
    height: 38px;
}

.lc_wrapper header .top h1 a {
    width: 330px;
    height: 38px;
}

.lc_wrapper header .top h1:hover {
    opacity: .7;
}

.lc_wrapper header .link_btn {
    background: #0090d5;
    width: 170px;
    text-align: center;
    border: 1px solid #0090d5;
    box-sizing: border-box;
    float: right;
    height: 40px;
    font-size: 16px;
    letter-spacing: 1px;
    margin: -39px 0 0 0;
    position: relative;
    line-height: 40px;
}

.lc_wrapper header .link_btn::after {
    right: 12px;
    top: 15px;
    width: 7px;
    height: 7px;
}

/* --- nav --- */
.lc_wrapper nav {
    background: #e5e5e5;
    /* #eeeeee */
}

.lc_wrapper nav ul {
    font-size: 0;
    width: 986px;
    margin: 0 auto;
}

.lc_wrapper nav ul li {
    display: inline-block;
    box-sizing: border-box;
    font-size: 13px;
    /* width: 16.6%; */
    width: 14.64%;
    height: 80px;
    line-height: 80px;
    vertical-align: middle;
    border-right: 2px solid #fff;
    border-bottom: 1px solid #0090d5;
    position: relative;
}

.lc_wrapper nav ul li[data-type="join"] {
    background-color: #0090d5;
    font-size: 18px;
    font-weight: 700;
    width: 26.8%;
}

.lc_wrapper nav ul li a {
    color: #000;
    font-weight: 500;
}

.lc_wrapper nav ul li[data-type="join"] a {
    color: #fff;
    font-weight: 700;
}

.lc_wrapper nav ul li a:hover {
    opacity: .7;
}

.lc_wrapper nav ul li:nth-child(5),
.lc_wrapper nav ul li:nth-child(6) {
    padding: 20px 0 0;
    line-height: 17px;
}

.lc_wrapper nav ul li:first-child {
    border-left: 2px solid #fff;
}

.lc_wrapper nav ul li span {
    display: block;
    margin: -32px 0 0 0;
}

.lc_wrapper nav ul .arrow::after {
    content: '';
    width: 6px;
    height: 6px;
    border: 0px;
    border-top: solid 1px #000;
    border-right: solid 1px #000;
    -ms-transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
    position: absolute;
    top: 80%;
    left: 50%;
    margin-top: -4px;
}

.lc_wrapper nav ul .arrow[data-type="join"]::after {
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
}

.main_contents {
    padding-top: 175px;
    width: 100%;
}

.lc_wrapper nav ul li.link:after {
    content: '';
    width: 11px;
    height: 11px;
    position: absolute;
    top: 81%;
    left: 50%;
    margin-top: -4px;
    background: url(../img/wi.png) no-repeat;
}

/* 
    slider
    ---------------------------------- */
.main_slider {
    position: relative;
    width: 980px;
    margin: 0 auto;
}

.slider {
    width: 980px;
    height: 548px;
    box-sizing: border-box;
    margin: 30px auto 21px;
    border: 1px solid #000;
    /* padding: 10px 10px 22px; */
    padding: 12px 4px 22px;
}

.slider img {
    width: 100%;
}

.slick-slide:not(.slick-current) {
    opacity: .5;
}

.slick-next {
    background: url(../img/next.gif) no-repeat;
    position: absolute;
    top: 245px;
    right: 173px;
    width: 51px;
    height: 110px;
    font-size: 0;
    z-index: 100;
}

.slick-prev {
    font-size: 0;
    background: url(../img/prev.gif) no-repeat;
    position: absolute;
    top: 245px;
    left: 173px;
    width: 51px;
    height: 110px;
    z-index: 100;
}

.slick-dots {
    bottom: 18px;
}

.slick-dots li button:before {
    font-size: 40px;
}

.slick-dots li {
    margin: 0 5px;
}

.slick-initialized .slick-slide {
    margin: 0 10px 0;
    outline: none;
}

.slick-list {
    /* width: 456px; */
    width: 510px;
}

/* 
    ルミネカードをおすすめする5つの理由
    ---------------------------------- */
#reason {
    padding-top: 240px;
    margin-top: -240px;
}

.reason {
    padding-top: 80px;
    background: url(../img/join_bg.png);
    background-size: cover;
    padding-bottom: 80px;
}

.reason h2 {
    font-size: 0;
    background: url(../img/reson_ttl.png) no-repeat;
    width: 520px;
    height: 64px;
    margin: 0 auto 80px;
}

/* アコーディオン */
.reason .accordion {
    border: 1px solid #000;
}

.accordion .btn::after {
    /*　ボタンの向き */
    content: "";
    display: block;
    position: absolute;
    border-top: 1px solid #000;
    border-right: 1px solid #000;
    width: 12px;
    height: 12px;
    right: 40px;
    top: 45px;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}

.accordion .btn_up::after {
    content: "";
    display: block;
    position: absolute;
    border-top: 0;
    border-right: 0;
    border-bottom: 1px solid #000;
    border-left: 1px solid #000;
    width: 12px;
    height: 12px;
    right: 40px;
    top: 45px;
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
}

.box h3 {
    font-size: 0;
    width: 100%;
    height: 110px;
    margin-bottom: 10px;
    cursor: pointer;
    position: relative;
}

.inner {
    /* アコーディオン中身 */
    display: none;
    padding: 0 40px 30px;
}

#modal .inner {
    display: block;
    padding: 0;
}

.box {
    width: 980px;
    margin: 0 auto;
    text-align: left;
    background: #fff;
    margin: 0 auto 10px;
}

.box .inner .lead {
    background: #f5fcff;
    padding: 18px 22px 18px 22px;
    font-size: 16px;
    line-height: 28px;
    margin: 0 auto 30px;
    font-weight: bold;
}

/* 
    01(いつでも5％OFF)
    ---------------------------------- */
.reason01 h3 {
    background: url(../img/reason01.png) no-repeat;
}

.reason01 .inner .txt {
    font-size: 16px;
    margin-bottom: 20px;
}

.reason01 .inner .txt .ttl {
    display: block;
    color: #0090d5;
    border: 1px solid #0090d5;
    width: 245px;
    padding: 7px 0;
    font-size: 18px;
    letter-spacing: 1px;
    text-align: center;
    margin-bottom: 10px;
}

.reason01 .inner .txt .app {
    display: block;
    color: #d70101;
    font-size: 14px;
    line-height: 22px;
    margin-top: 30px;
}

.reason01 .inner .txt .app a {
    display: inline-block;
    color: #0090d5;
    text-decoration: underline;
}

.reason01 .inner ul {
    font-size: 0;
    text-align: center;
}

.reason01 .inner ul li {
    display: inline-block;
    margin-left: 30px;
}

.reason01 .inner ul li::after {
    content: "";
    display: block;
    position: absolute;
    border-top: 0;
    border-right: 0;
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
    width: 10px;
    height: 10px;
    right: 30px;
    top: 23px;
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
}

/* 
    02 (ポイントがたまる)
    ---------------------------------- */
#reason02_1 {
    margin-top: -300px;
    padding-top: 300px;
}

.reason02 h3 {
    background: url(../img/reason02.png) no-repeat;
}

.reason02 .inner .lead {
    font-size: 19px;
}

/* 追加 */
.reason02 .inner .lead .add02 {
    font-size: 15px;
    line-height: 25px;
}

.reason02 .inner .lead .add02 a {
    display: inline-block;
    color: #0090d5;
    text-decoration: underline;
}

/* ここまで */

.reason02 .inner .lead .add {
    display: inline-block;
    margin-top: 10px;
    line-height: 1.3;
    font-size: 14px;
}

/* ----- jre ----- */
.reason02 .jre ul {
    font-size: 0;
    text-align: center;
}

.reason02 .jre ul .present {
    background: url(../img/reason02_2.jpg) no-repeat;
    width: 900px;
    height: 251px;
    margin-bottom: 10px;
}

.about_detail {
    background: url(../img/reason02_1.jpg) no-repeat;
    width: 900px;
    height: 345px;
    margin-bottom: 6px;
    z-index: 1;
    position: relative;
}

/* 追加 */
.mark {
    text-align: center;
    padding-top: 5px;
    margin: auto;
    width: 30px;
}

/* ここまで */

/* 
    02 (JRE POINTアプリ)
    ---------------------------------- */
.reason02 .apri {
    width: 900px;
    margin-top: 30px;
}

.reason02 .apri .black-box {
    padding: 0px 20px 40px;
    border: 1px solid #221815;
    margin-bottom: 15px;
}

/* 追加 */

.reason02 .apri .ttl-box {
    margin: -19px auto 10px;
}

.reason02 .apri .ttl-box img {
    text-align: center;
    margin: 0 auto;
    width: 100%;
    max-width: 430px;
}

.reason02 .apri .img-box-present img {
    margin: 30px auto 0 auto;
    max-width: 896px;
}

/* ここまで */


.reason02 .apri .img-box {
    position: relative;
}

.reason02 .apri .img-box img {
    padding-top: 50px;
    margin: 0 auto;
    width: 100%;
    max-width: 896px;
}

.reason02 .apri .img-box p {
    position: absolute;
    top: 60%;
    left: 50%;
    transform: translateY(-50%);
    font-size: 20px;
    line-height: 1.6;
    letter-spacing: 0.04em;
    text-align: center;
    font-weight: bold;
}

.reason02 .apri .note {
    margin: 10px 0 20px;
    text-align: center;
}

.reason02 .apri .red {
    color: #d70101;
}

.reason02 .apri .note li {
    font-size: 12px;
    line-height: 1.6;
    letter-spacing: 0.06em;
}

.reason02 .apri .dl-box {
    padding: 22px 0;
    border: 1px solid #221815;
    border-radius: 10px;
    width: 80%;
    margin: 0 auto;
}

.reason02 .apri .dl-box p {
    font-size: 18px;
    letter-spacing: 0.04em;
    text-align: center;
}

.reason02 .apri .dl-box>.row {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 20px auto 13px;
}

.reason02 .apri .dl-box>.row .row {
    display: flex;
    justify-content: center;
    align-items: center;
}

.reason02 .apri .dl-box .apple {
    padding-right: 30px;
    border-right: 1px solid #221815;
}

.reason02 .apri .dl-box .apple a img {
    margin-right: 12px;
    width: 152px;
    height: auto;
}

.reason02 .apri .dl-box .google {
    padding-left: 30px;
}

.reason02 .apri .dl-box .google a img {
    margin-right: 12px;
    width: 186px;
    height: auto;
}

.reason02 .apri .dl-box .dl-txt {
    margin: 0 auto;
    width: 82%;
    font-size: 12px;
    text-align: left;
    line-height: 1.3;
    letter-spacing: 0.04em;
}

.about_detail p.small {
    font-size: 12px;
    position: absolute;
    line-height: 1.2rem;
    left: 25px;
    bottom: 39px;
    font-weight: 600;
    letter-spacing: 0.02rem;
}

.about_detail p.small a {
    display: inline-block;
    color: #0090d5;
    text-decoration: underline;
}

.about_detail .red {
    color: #d70101;
}


/*
    03(食・美・旅などの優待サービス「LUMINE STYLE」が充実!)
    ------------------------------------------------*/

#reason03_1 {
    margin-top: -300px;
    padding-top: 300px;
}

.reason03 h3 {
    background: url(../img/reason03.png) no-repeat;
}

.reason03 .inner .reason03_box .title h4 {
    font-size: 0;
    width: 900px;
    height: 46px;
    margin: 0 auto 35px;
}


/* ルミネスタイル */
.reason03 .inner .style .title h4 {
    background: url(../img/reson03_ttl1.png) no-repeat;
}

.reason03 .inner .style ul {
    font-size: 0;
    padding-bottom: 35px;
}

.reason03 .inner .style .logo {
    background: url(../img/reason03_1.jpg) no-repeat;
    width: 691px;
    height: 100px;
    margin: 0 auto 50px;
}

.reason03 .inner .style .sample {
    background: url(../img/reason03_2.jpg) no-repeat;
    width: 690px;
    height: 500px;
    margin: 0 auto 40px;
}

/* サービス */
#reason03_3 {
    margin-top: -200px;
    padding-top: 200px;
}

.reason03 .inner .service .title h4 {
    background: url(../img/reson03_ttl2.png) no-repeat;
}

.reason03 .inner .service p {
    font-size: 0;
    background: url(../img/reason03_3.png) no-repeat;
    /*width: 680px;*/
    width: 100%;
    height: 654px;
    /*height: 475px;*/
    margin: 0 auto 85px;
    background-size: contain;
}

/* プレゼント */
.reason03 .inner .present .title h4 {
    background: url(../img/reson03_ttl3.png) no-repeat;
}

.reason03 .inner .present ul {
    position: relative;
    background: url(../img/reason03_4.jpg) no-repeat;
    width: 1000px;
    height: 619px;
    margin-bottom: 20px;
}

.reason03 .inner .present ul li.p_btn {
    position: absolute;
    top: 180px;
    right: 113px;
    width: 395px;
    height: 86px;
}

.reason03 .inner .present .app {
    display: block;
    font-size: 12px;
    line-height: 16px;
}

.reason03 .inner .present ul+p {
    font-size: 15px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.06em;
}

.reason03 .inner .present ul+p a {
    display: inline;
    color: #0090d5;
    text-decoration: underline;
}





/*
    04(アプリでさらにおトク!)
    ------------------------------------------------*/

#reason04_1 {
    margin-top: -300px;
    padding-top: 300px;
}

.reason04 h3 {
    background: url(../img/reason04.png) no-repeat;
}

.reason04 .inner .lead {
    font-size: 19px;
}

.reason04 .inner ul {
    font-size: 0;
    text-align: left;
    margin-bottom: 40px;
}

.reason04 .inner ul li {
    display: inline-block;
    vertical-align: top;
}

.reason04 .inner ul li:nth-child(1) {
    background: url(../img/reson04_1.jpg) no-repeat;
    width: 278px;
    height: 91px;
    margin: 0 30px 0;
}

.reason04 .inner ul li:nth-child(2) {
    font-size: 18px;
    width: 530px;
    line-height: 27px;
    font-weight: bold;
}


.reason p.txt {
    font-size: 19px;
    font-weight: bold;
    margin: 50px auto 0;
}

.reason p.txt .red {
    color: #d70101;
    font-size: 25px;
    line-height: 2;
}


/* 
    入会方法
    ---------------------------------- */
#join {
    padding-top: 180px;
    margin-top: -180px;
}

.join {
    background: #eeeeee;
    /*background-size: contain;*/
    padding: 80px 0;
}

.join_inner {
    width: 980px;
    margin: 0 auto;
    padding: 60px 40px 40px;
}

.join .join_inner h2 {
    margin-bottom: 30px;
}

.join .join_inner h2 span[data-lang="en"] {
    display: block;
    color: #0090d5;
    font-family: "Overpass", sans-serif;
    font-size: 17px;
    font-weight: 600;
    letter-spacing: 0.13em;
    margin-bottom: 25px;
}

.join .join_inner h2 span[data-lang="ja"] {
    display: block;
    font-size: 28px;
    font-weight: 500;
    letter-spacing: 0.13em;
}

.join .join_inner .join_lead {
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.08em;
    margin-bottom: 70px;
}

.join .join_inner .join_container {
    display: flex;
    justify-content: space-between;
    gap: 60px;
}

.join .join_inner .join_container .join_unit {
    background-color: #ffffff;
    border: 1px solid #000000;
    box-sizing: border-box;
    width: calc(50% - 30px);
    padding: 30px 20px;
    display: flex;
    flex-direction: column;
}


.join .join_inner .join_container .join_unit h3 {
    color: #0090d5;
    font-size: 28px;
    font-weight: bold;
    margin: 0 auto 30px;
    letter-spacing: 1px;
}

.join .join_inner .join_container .join_unit .join_text {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 1px;
    flex: 1;
}

.join .join_inner .join_container .join_unit .join_img {
    flex: 1;
    margin: 10px auto 0 auto;
}

.join .join_inner .join_container .join_unit[data-type="store"] .join_img {
    width: 50%;
    margin: 30px auto 0 auto;
}

.join .join_inner .join_container .join_unit[data-type="online"] .join_img {
    width: 50%;
}

.join .join_inner .join_container .join_unit .join_img img {
    width: 100%;
    height: auto;
}

.join .join_inner .join_container .join_unit .join_btn {
    background: #0090d5;
    border: 1px solid #0090d5;
    border-radius: 20px;
    padding: 22px 57px 18px 45px;
    margin: 30px auto 0 auto;
    font: inherit;
    font-size: 22px;
    font-weight: 500;
    letter-spacing: 0.1em;
    line-height: 1;
    color: #ffffff;
    outline: none;
    box-shadow: none;
    cursor: pointer;
    position: relative;
    transition: background 0.3s, color 0.3s;
}

.join .join_inner .join_container .join_unit .join_btn::before {
    content: "+";
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 28px;
    color: #ffffff;
    pointer-events: none;
    transition: color 0.3s;
}

.join .join_inner .join_container .join_unit .join_btn:hover {
    background: #fff;
    color: #0090d5;
}

.join .join_inner .join_container .join_unit .join_btn:hover::before {
    color: #0090d5;
}

.join .join_inner .join_container .join_unit .join_link {
    background-color: #F5FCFF;
    margin: 30px 0 0 0;
    padding: 40px 50px;
}

.join .join_inner .join_container .join_unit .join_link .link_text span {
    color: #000000;
    font-size: 18px;
    line-height: 1.6;
    letter-spacing: 2px;
    text-decoration: underline;
}

.join .join_inner .join_container .join_unit .join_link .link_btn {
    margin: 30px auto 0 auto;
}





#modal .accordion_title .check {
    background: url(../img/check.png) no-repeat;
    width: 100px;
    background-size: 100px;
    margin: 20px 10px 0 0;
    display: inline-block;
}

#modal .txt_box a {
    color: #0090d5;
    text-decoration: underline;
    display: inline;
}


#modal .modal_content[data-type="online"] .title ul {
    background: #f5fcff;
    font-size: 0;
    padding: 40px 0 45px;
}

/*.join_inner .online ul li:nth-child(1){
        font-size: 24px;
        text-decoration: underline;
        margin-bottom: 40px;
    }*/
/* online */

#modal .modal_content .modal_head {
    background-color: #eeeeee;
    width: 100%;
    height: 160px;
    justify-content: center;
    vertical-align: middle;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 20px;
    margin: 0 auto;
}

#modal .modal_content .modal_head .title {
    color: #0090d5;
    font-size: 28px;
    font-weight: 700;
    letter-spacing: 0.1em;
}

#modal .modal_content .modal_head .sub_title {
    font-size: 16px;
    font-weight: 500;
    line-height: 1.6;
}

#modal .modal_content .inner {
    border-top: 2px solid #0090d5;
    box-sizing: border-box;
    padding: 40px 0 40px 10%;
}


#modal .modal_content[data-type="online"] .online_box {
    margin-bottom: 65px;
}


#modal .modal_content[data-type="online"] .online_box ul {
    font-size: 0;
    text-align: left;
    background: none;
}

#modal .modal_content[data-type="online"] .online_box ul .txt_box {
    /* width: 600px; */
}

#modal .modal_content[data-type="online"] .online_box ul li {
    display: inline-block;
    vertical-align: top;
}

#modal .modal_content[data-type="online"] .online_box .txt_box .txt {
    display: block;
    font-size: 24px;
    font-weight: bold;
    text-decoration: underline;
    margin-bottom: 25px;
}

#modal .modal_content[data-type="online"] .online_box .txt_box .small {
    display: block;
    font-size: 16px;
    line-height: 25px;
    background: #f7f7f7;
    padding: 25px;
    width: 355px;
}

/* STEP00 */
#modal .modal_content[data-type="online"] .step00 p.txt {
    width: 730px;
    margin: 0 auto;
    font-size: 22px;
}

#modal .modal_content[data-type="online"] .step00 p.txt span.blue {
    color: #0090d5;
    font-weight: bold;
    letter-spacing: 2.5px;
}

#modal .modal_content[data-type="online"] .step00 p.txt span.app {
    font-size: 14px;
}

/* STEP01 */
#modal .modal_content[data-type="online"] .step01 {
    background: url(../img/online_step1_bg.png) no-repeat top 45px left 534px;
    background-size: 200px;
}

#modal .modal_content[data-type="online"] .step01 .nom {
    background: url(../img/online_step1.png) no-repeat;
    width: 34px;
    height: 206px;
    margin-right: 55px;
}

/* STEP02 */
#modal .modal_content[data-type="online"] .step02 {
    background: url(../img/online_step2_bg.png) no-repeat top 125px left 534px;
    background-size: 235px;
}

#modal .pc {
    display: inline-block;
}

#modal .modal_content[data-type="online"] .step02 .app {
    display: block;
    font-size: 14px;
    margin: -15px auto 25px;
}

#modal .modal_content[data-type="online"] .step02 .nom {
    background: url(../img/online_step2.png) no-repeat;
    width: 34px;
    height: 628px;
    margin-right: 55px;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue {
    background-color: #f5fcff;
    display: block;
    line-height: 25px;
    padding: 25px;
    width: 355px;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue p {
    font-size: 16px;
    margin: 0 0 15px 0;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue .bg_blue_title {
    background: url(../img/accounttransfer.png) no-repeat;
    width: 230px;
    height: 35px;
    background-size: 230px;
    margin: 0 0 10px 0;
    font-size: 0;
    display: block;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue .checkmark {
    padding: 0 0 0 30px;
    position: relative;
    display: block;
    color: #0090d5;
    font-size: 19px;
    text-decoration: underline;
    font-weight: bold;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue .checkmark:nth-of-type(3) {
    margin: 3px 0 15px 0;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue .checkmark:before,
#modal .modal_content[data-type="online"] .step02 .bg_blue .checkmark:after {
    content: "";
    display: block;
    position: absolute;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue .checkmark:before {
    width: 16px;
    height: 16px;
    border: 1px solid #0090d5;
    left: 0;
    top: 2px;
}

#modal .modal_content[data-type="online"] .step02 .bg_blue .checkmark:after {
    border-left: 2.5px solid #0090d5;
    border-bottom: 2.5px solid #0090d5;
    width: 15px;
    height: 5px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    left: 0px;
    top: 4px;
}

#modal .modal_content[data-type="online"] .step02 .txt_box .note {
    display: block;
    font-size: 13px;
    padding-left: 1em;
    text-indent: -1em;
    line-height: 18px;
}

#modal .modal_content[data-type="online"] .step02 .txt_box .bg_blue .note:nth-child(1) {
    margin-top: 15px;
}

#modal .modal_content[data-type="online"] .step02 .txt_box .small {
    margin: 10px 0 0 0;
}


/* STEP03 */
#modal .modal_content[data-type="online"] .step03 {
    background: url(../img/online_step3_bg.png) no-repeat top 52px left 534px;
    background-size: 235px;
}

#modal .modal_content[data-type="online"] .step03 .nom {
    background: url(../img/online_step3.png) no-repeat;
    width: 34px;
    height: 274px;
    margin-right: 55px;
}

#modal .modal_content[data-type="online"] .step03 .txt_box .note {
    display: block;
    font-size: 13px;
    padding-left: 1em;
    text-indent: -1em;
    line-height: 18px;
}

#modal .modal_content[data-type="online"] .step03 .txt_box .note:nth-child(1) {
    margin-top: 15px;
}

/* STEP04 */
#modal .modal_content[data-type="online"] .step04 {
    background: url(../img/online_step4_bg.png) no-repeat top 46px left 534px;
    background-size: 235px;
    margin-bottom: 0;
}

#modal .modal_content[data-type="online"] .step04 .nom {
    background: url(../img/online_step4.png) no-repeat;
    width: 34px;
    height: 173px;
    margin-right: 55px;
}

#modal .modal_content[data-type="online"] .step04 .txt_box .note {
    display: block;
    font-size: 13px;
    padding-left: 1em;
    text-indent: -1em;
    line-height: 18px;
}

#modal .modal_content[data-type="online"] .step04 .txt_box .note:nth-child(1) {
    margin-top: 15px;
}


#modal .modal_content[data-type="online"] .online_new ul {
    font-size: 0;
    background: #f5fcff;
    padding: 40px 0;
    margin: 30px 0 0 0;
}

#modal .online_new ul li:nth-child(1) {
    font-size: 24px;
    text-decoration: underline;
    margin-bottom: 30px;
    letter-spacing: 2px;
}

/* STEP */
#modal .modal_content[data-type="store"] .store_box {
    margin-bottom: 65px;
}

#modal .modal_content[data-type="store"] .store_box ul {
    font-size: 0;
    text-align: left;
}

#modal .modal_content[data-type="store"] .store_box ul .txt_box {
    /* width: 600px; */
}

#modal .modal_content[data-type="store"] .store_box ul li {
    display: inline-block;
    vertical-align: top;
}

#modal .modal_content[data-type="store"] .store_box .txt_box .txt {
    display: flex;
    align-items: center;
    margin-bottom: 25px;
}

#modal .modal_content[data-type="store"] .store_box .txt_box .txt span {
    display: inline-block;
    font-size: 24px;
    font-weight: bold;
    text-decoration: underline;
}

#modal .modal_content[data-type="store"] .store_box .txt_box .txt span.comment {
    display: inline-block;
    font-size: 13px;
    font-weight: 500;
    text-decoration: none;
    margin-left: 20px;
}

#modal .modal_content[data-type="store"] .store_box .txt_box .small {
    display: block;
    font-size: 16px;
    line-height: 25px;
    background: #f7f7f7;
    padding: 25px;
    width: 355px;
}

/* STEP00 */
#modal .modal_content[data-type="store"] .step00 p.txt {
    width: 730px;
    margin: 0 auto;
    font-size: 22px;
}

#modal .modal_content[data-type="store"] .step00 p.txt span.blue {
    color: #0090d5;
    font-weight: bold;
    letter-spacing: 8px;
}

#modal .modal_content[data-type="store"] .step00 p.txt span.app {
    font-size: 14px;
}

/* STEP01 */
#modal .modal_content[data-type="store"] .step01 {
    background: url(../img/step1_1.png) no-repeat top 50px left 534px;
    background-size: 205px;
}

#modal .modal_content[data-type="store"] .step01 .nom {
    background: url(../img/step1.png) no-repeat;
    width: 34px;
    height: 215px;
    margin-right: 55px;
}

/* STEP02 */
#modal .modal_content[data-type="store"] .step02 {
    background: url(../img/step2_1.png) no-repeat top 65px left 565px;
    background-size: 130px;
}

#modal .modal_content[data-type="store"] .step02 .app {
    display: block;
    font-size: 14px;
    margin: -15px auto 25px;
}

#modal .modal_content[data-type="store"] .step02 .nom {
    background: url(../img/step2.png) no-repeat;
    width: 34px;
    height: 234px;
    margin-right: 55px;
}

/* 本人確認書類(アコーディオン) */
#modal .modal_content[data-type="store"] .step02 .accordion h3 {
    background: #fff;
    color: #000;
    width: 810px;
    height: 80px;
    line-height: 80px;
    margin: 0 auto;
    cursor: pointer;
}

#modal .modal_content[data-type="store"] .step02 .accordion::before,
#modal .modal_content[data-type="store"] .step02 .accordion::after {
    content: '';
    display: block;
    border: 0.5px solid #000;
    width: 810px;
}

#modal .modal_content[data-type="store"] .step02 .accordion {
    margin: -110px 0 90px 75px;
}

#modal .modal_content[data-type="store"] .step02 .accordion .btn::after {
    top: 25px;
    right: 25px;
    width: 18px;
    height: 18px;
}

#modal .modal_content[data-type="store"] .step02 .accordion .inner {
    margin-left: -40px;
}

#modal .modal_content[data-type="store"] .step02 .accordion .inner .one {
    background: url(../img/step2_2.png) no-repeat;
    width: 810px;
    height: 136px;
    margin: 55px auto 10px;
}

#modal .modal_content[data-type="store"] .step02 .accordion .inner .two {
    background: url(../img/step2_3.png) no-repeat;
    width: 810px;
    height: 209px;
}

/* STEP03 */
#modal .modal_content[data-type="store"] .step03 {
    background: url(../img/step3_1.png) no-repeat bottom left 534px;
    background-size: 235px;
}

#modal .modal_content[data-type="store"] .step03 .nom {
    background: url(../img/step3.png) no-repeat;
    width: 34px;
    height: 247px;
    margin-right: 55px;
}

#modal .modal_content[data-type="store"] .step03 .txt_box .note {
    display: block;
    font-size: 13px;
    padding-left: 1em;
    text-indent: -1em;
    line-height: 18px;
}

#modal .modal_content[data-type="store"] .step03 .txt_box .note:nth-child(1) {
    margin-top: 15px;
}

#modal .store_new ul {
    font-size: 0;
    background: #f5fcff;
    padding: 40px 0;
    margin: 30px 0 0 0;
}

#modal .store_new ul li:nth-child(1) {
    font-size: 24px;
    text-decoration: underline;
    margin-bottom: 30px;
    letter-spacing: 2px;
}



/*============================
#modal
============================*/
#modal {
    background-color: rgba(51, 51, 51, 0.7);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    z-index: 300;
}

#modal:not([data-type="store"]):not([data-type="online"]) {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

#modal .modal_content {
    background-color: #fff;
    border: 2px solid #0090d5;
    box-sizing: border-box;
    width: 90%;
    margin: 0 auto;
    max-width: 986px;
    position: relative;
}

#modal:not([data-type="store"]) .modal_content[data-type="store"] {
    display: none;
}

#modal:not([data-type="online"]) .modal_content[data-type="online"] {
    display: none;
}

#modal .modal_content .inner {
    max-height: calc(90vh - 160px);
    overflow-y: auto;
    overflow-x: hidden;
}


#modal .modal_close {
    position: absolute;
    top: 15px;
    right: 15px;
    width: 36px;
    height: 36px;
    cursor: pointer;
}

#modal .modal_close img {
    aspect-ratio: 1/1;
    width: 100%;
    height: auto;
}








/* 
    ルミネカード活用術
    ---------------------------------- */
#activation {
    padding-top: 240px;
    margin-top: -240px;
}

.activation {
    background: #eeeeee;
    padding: 80px 0 110px;
    overflow: hidden;
}

.activation h2 {
    font-size: 0;
    background: url(../img/activation_ttl.png) no-repeat;
    width: 523px;
    height: 70px;
    margin: 0 auto 90px;
}

.activation .act_inner {
    width: 980px;
    margin: 0 auto;
}

.activation .actbox {
    width: 840px;
    border: 1px solid #1e9cd8;
}

.activation .actbox ul {
    font-size: 0;
    width: 980px;
    text-align: left;
}

.activation .actbox ul li {
    display: inline-block;
    vertical-align: top;
}

/* SHOPPING */
.activation .shopping {
    float: left;
    padding: 0 0 20px 40px;
    margin-bottom: 30px;
}

.activation .shopping .no1 {
    background: url(../img/activation01.png) no-repeat;
    width: 34px;
    height: 140px;
    margin: 40px 90px 0 0;
}

.activation .shopping .no2 {
    background: url(../img/activation02.png) no-repeat;
    width: 780px;
    height: 308px;
    margin: -20px 10px 0 0;
}

/* APP */
.activation .app {
    clear: both;
    float: right;
    margin-bottom: 80px;
}

.activation .app ul {
    text-align: right;
    margin: 40px 0 -55px -205px;
}

.activation .app .no1 {
    background: url(../img/activation03.png) no-repeat;
    width: 34px;
    height: 110px;
    margin-right: -25px;
    margin-left: 90px;
}

.activation .app .no2 {
    background: url(../img/activation04.png) no-repeat;
    width: 785px;
    height: 275px;
    margin-right: 10px;
}

/* other */
.activation .other {
    clear: both;
    float: left;
    padding: 0 0 20px 40px;
    margin: 20px 0;
}

.activation .other .no1 {
    background: url(../img/activation05.png) no-repeat;
    width: 34px;
    height: 87px;
    margin: 40px 90px 0 0;
}

.activation .other .no2 {
    background: url(../img/activation06.png) no-repeat;
    width: 783px;
    height: 308px;
    margin: -20px 10px 0 0;
}

.activation .act_inner .point {
    font-size: 0;
    clear: both;
    text-align: left;
    margin-bottom: 40px;
}

.activation .act_inner .point li {
    display: block;
    font-size: 15px;
    line-height: 25px;
}

.activation .act_inner .point li a {
    display: inline-block;
    color: #0090d5;
    text-decoration: underline;
}

.activation .act_inner .point li a:hover {
    opacity: .7;
}


/* 
    もしものときの連絡先
    ---------------------------------- */
.trouble {
    width: 980px;
    margin: 0 auto;
    text-align: center;
    padding: 90px 0;
}

.trouble .card {
    margin-bottom: 70px;
}

.trouble .card .cardbox {
    width: 420px;
    display: inline-block;
    vertical-align: top;
    border: 0.5px solid #0090d5;
    padding: 27px 25px 0;
    text-align: left;
}

.trouble .card .cardbox:nth-child(1) {
    margin-right: 15px;
}

.trouble .card .cardbox:nth-child(2) {
    margin-left: 15px;
}

.trouble .card .cardbox a {
    color: #000;
    text-decoration: none;
}

.trouble .card .cardbox ul li {
    margin-bottom: 10px;
}

.trouble .card .cardbox ul li:nth-child(1) {
    font-size: 18px;
}

.trouble .card .cardbox ul li:nth-child(2) {
    font-size: 24px;
    color: #0090d5;
}

.trouble .card .cardbox:nth-child(2) ul li:nth-child(2) {
    margin: 28px 0 10px 0;
}

.trouble .card .cardbox ul li:nth-child(3) {
    font-size: 18px;
}

.trouble .card .cardbox:nth-child(2) ul li:nth-child(3)::after {
    margin-top: 23px;
}

.trouble .card .cardbox ul li:nth-child(3) .caution {
    font-size: 12px;
    line-height: 1.4;
    padding: 10px 0 0 0;
    display: inline-block;
}

.trouble .card .cardbox ul li:nth-child(3)::after {
    content: '';
    display: block;
    border: 0.5px solid #0090d5;
    margin: 15px auto 20px;
}

.trouble .card .cardbox ul li:nth-child(4) {
    font-size: 31px;
    color: #0090d5;
    font-weight: bold;
    margin-bottom: 22px;
}


.trouble .card .cardbox p {
    font-size: 14px;
    text-align: right;
    background: #0090d5;
    padding: 5px 20px 5px 0px;
    width: 440px;
    margin: 5px 0 5px -20px;
    position: relative;
    color: #fff;
}

.trouble .card .cardbox p::after {
    content: "";
    display: block;
    position: absolute;
    border-top: 0;
    border-right: 0;
    border-bottom: 1px solid #fff;
    border-left: 1px solid #fff;
    width: 6px;
    height: 6px;
    right: 8px;
    top: 8px;
    -webkit-transform: rotate(225deg);
    transform: rotate(225deg);
}

.trouble a:hover {
    opacity: .7;
    transition: .5s;
    -webkit-transition: .5s;

}


/* ----- TOPへ戻る ----- */

.lc_wrapper .follow_top {
    font-size: 0;
    background: url(../img/pagetop.png) no-repeat;
    width: 94px;
    height: 94px;
    position: fixed;
    right: 26px;
    bottom: 0;
    cursor: pointer;
}

/*--------------------------------------------------------------------------------
  * SP *
  ------------------------------------------------------------------------------*/
@media only screen and (max-width: 768px) {

    /* ************************************************************************
* 
*   ルミネカード
*
************************************************************************ */
    .pc {
        display: none !important;
    }

    .sp {
        display: block !important;
    }

    .lc_wrapper {
        font-family: "Yu Gothic Medium", "游ゴシック", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
        margin: 0 auto;
        text-align: center;
        overflow: hidden;
    }

    .lc_wrapper img {
        width: 100%;
        height: auto;
    }

    /* リンク */
    .lc_wrapper .link_btn {
        background: #0090d5;
        width: 75vw;
        border: 1px solid #0090d5;
        margin: 0 auto 4vw;
        position: relative;
        pointer-events: painted;
    }

    .lc_wrapper .join .link_btn {
        background: #000000;
        border: 1px solid #000000;
    }

    .lc_wrapper .link_btn::after {
        content: '';
        display: block;
        position: absolute;
        border-bottom: 1px solid #fff;
        border-left: 1px solid #fff;
        width: 3vw;
        height: 3vw;
        right: 5vw;
        /* top: 6.5vw; */
        top: 6vw;
    }

    .lc_wrapper .join .link_btn::after {
        border-bottom: 1px solid #fff;
        border-left: 1px solid #fff;
        width: 2vw;
        height: 2vw;
        right: 3vw;
        top: 3.6vw;
    }

    .lc_wrapper .link_btn a {
        /* display: block; */
        display: flex;
        align-items: center;
        justify-content: center;
        width: 100%;
        /* height: 10vw; */
        height: 100%;
        padding: 0;
        color: #fff;
        text-decoration: none;
        font-size: 4.8vw;
    }

    /* ----- 02(JRE POINTアプリ用) ----- */

    .lc_wrapper .link_btn02 {
        background: #0090d5;
        width: 75vw;
        height: 17vw;
        padding-bottom: 20px;
        border: 1px solid #0090d5;
        line-height: 20px;
        margin: 0 auto 4vw;
        padding: 0.4vw 0;
        position: relative;
        display: inline-block;
        pointer-events: painted;
        margin-top: 7vw;
        line-height: auto;
    }

    .lc_wrapper .link_btn02::after {
        content: '';
        display: block;
        position: absolute;
        border-left: 2px solid #fff;
        border-bottom: 2px solid #fff;
        width: 3vw;
        height: 3vw;
        right: 3vw;
        top: 6.5vw;
    }

    .lc_wrapper .link_btn02 a {
        display: block;
        width: 100%;
        height: 10vw;
        padding: 2.2vw 0 0;
        color: #fff;
        text-decoration: none;
        font-size: 4.6vw;
        line-height: 1.4rem;
    }



    /* フェードイン */
    .fadein {
        opacity: 0;
        transform: translate(0, 10px);
        transition: all 1s;
    }

    .fadein.scrollin {
        opacity: 1;
        transform: translate(0, 0);
    }

    /*
header
==============================================*/
    header {
        background: url(../img/head_bg_sp.png);
        background-size: cover;
        padding: 4vw 0 2vw;
        border-bottom: 1px solid #b6b6b6;
        width: 100%;
        height: 12vw;
        margin: 0 auto 7vw;
        position: fixed;
        z-index: 100;
    }

    header .header h1 {
        font-size: 0;
        background: url(../img/card_logo_sp.jpg) no-repeat;
        background-size: contain;
        width: 54vw;
        height: 8vw;
        float: left;
        margin-left: 6vw;
        margin-top: 1.5vw;
    }

    header .header h1 a {
        display: block;
        width: 55vw;
        height: 9vw;
    }

    /* ----- menu ----- */
    .menu {
        font-size: 2vw;
        opacity: .95;
        position: absolute;
        top: 4vw;
        right: 3vw;
        z-index: 100;
        width: 10%;
    }

    .menu.open {
        z-index: 100;
        width: 100%;
        height: 100vh;
        background: rgba(255, 255, 255, 0.7);
    }

    .menu #menuBtn {
        font-size: 0;
        background: url(../img/menu_open.jpg) no-repeat;
        background-size: contain;
        width: 18vw;
        height: 18vw;
        position: absolute;
        top: -4vw;
        right: -4vw;
    }

    .gNav_wrap {
        width: 100%;
        position: relative;
        right: 0;
        top: 0;
    }

    .gNavtop {
        background: #0090d5;
        opacity: .95;
        width: 76vw;
        position: absolute;
        right: -3vw;
        top: -4vw;
        display: none;
    }

    .gNav {
        height: 100vh;
    }

    .gNav li {
        display: block;
        width: 64vw;
        border-bottom: 1px solid #fff;
        margin: 0 auto;
        text-align: center;
        line-height: 14vw;
        font-size: 5.5vw;
        font-weight: bold;
        position: relative;
    }

    .gNav li a img {
        width: 4%;
    }

    .gNav .inquiry {
        background: #fff;
    }

    .gNav .inquiry a {
        color: #0090d5;
    }

    .gNav .inquiry::after {
        content: '';
        display: block;
        border-top: 2px solid #0090d5;
        border-right: 2px solid #0090d5;
        position: absolute;
        width: 3vw;
        height: 3vw;
        right: 4vw;
        top: 5vw;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    }

    /*.gNav .list:hover{
    background: #fff;
}*/
    /*.gNav li a:hover{
    color: #0090d5;
}*/
    .gNav li a {
        display: inline;
        color: #fff;
        text-decoration: none;
        font-size: 4.5vw;
    }

    .gNav li:last-child {
        border: none;
    }

    /* closeBtn */
    .gNav .closeBtn {
        font-size: 0;
        background: url(../img/menu_close.png) no-repeat;
        background-size: contain;
        width: 10vw;
        height: 10vw;
        position: relative;
        top: 4vw;
        left: 62vw;
        border: none;
        margin: 0 0 5vw;
    }

    /* ----- ルミネカード入会追従バナー ----- */
    .fix_bnr {
        position: fixed;
        top: 18vw;
        left: 0;
        width: 100%;
        z-index: 199;
    }

    .fix_bnr a {
        display: flex;
        justify-content: center;
        align-items: center;
        gap: 6.67vw;
        width: 100%;
        height: 12vw;
        /* padding: 0 0 0 4vw; */
        background: #0090d5;
        opacity: 1 !important;
    }

    .fix_bnr a span {
        font-size: 5.13vw;
        color: #ffffff;
        letter-spacing: 0.1em;
        text-align: center;
        font-weight: 700;
        margin: 0.8vw 0 0 0;
    }

    .fix_bnr a::after {
        content: "";
        display: block;
        border-top: 1px solid #ffffff;
        border-right: 1px solid #ffffff;
        width: 2.6vw;
        height: 2.6vw;
        margin: -1.5vw 0 0 0;
        -webkit-transform: rotate(135deg);
        transform: rotate(135deg);
        position: absolute;
        right: 9vw;
    }




    .lc_wrapper .main_contents {
        /* padding-top: 17vw; */
        padding-top: 30vw;
    }


    /*
slider
==============================================*/
    .main_slider {
        width: 80%;
        /* height: 74vw; */
        height: 93vw;
        margin: 0 auto;
        position: relative;
        z-index: 1;
    }

    .slider {
        width: 100%;
        height: auto;
        border: none;
        padding: 0;
    }

    .slick-list {
        padding: 0;
        width: 100%;
    }

    .slick-prev {
        left: -8vw;
        background: url(../img/prev_sp.gif) no-repeat;
        background-size: contain;
        width: 8vw;
        height: 16vw;
        top: 50%;
    }

    .slick-next {
        right: -8vw;
        background: url(../img/next_sp.gif) no-repeat;
        background-size: contain;
        width: 8vw;
        height: 16vw;
        top: 50%;
    }

    .slick-initialized .slick-slide {
        display: block;
        outline: none;
        margin: 0;
    }

    .slick-initialized .slick-slide.hover {
        opacity: 0.6;
    }

    .slick-slide:not(.slick-current) {
        opacity: 1;
    }

    .slick-dots li button:before {
        font-size: 7vw;
    }

    .slick-dots {
        bottom: -8vw;
    }



    /*
入会方法
==============================================*/
    #join {
        margin-top: -36vw;
        padding-top: 36vw;
    }

    .join {
        width: 100%;
        padding: 8vw 0 10vw;
        background: #eeeeee;
    }

    .join_inner {
        width: 90%;
        padding: 2vw 0 0;
    }

    .join .join_inner h2 {
        margin-bottom: 7vw;
    }

    .join .join_inner h2 span[data-lang="en"] {
        display: block;
        color: #0090d5;
        font-family: "Overpass", sans-serif;
        font-size: 3.85vw;
        font-weight: 600;
        letter-spacing: 0.13em;
        margin-bottom: 5vw;
    }

    .join .join_inner h2 span[data-lang="ja"] {
        display: block;
        font-size: 5.64vw;
        font-weight: 500;
        letter-spacing: 0.13em;
    }

    .join .join_inner .join_lead {
        font-size: 3.5vw;
        font-weight: 500;
        letter-spacing: 0.08em;
        line-height: 1.6;
        margin-bottom: 12.8vw;
    }

    .join .join_inner .join_container {
        display: flex;
        justify-content: space-between;
        gap: 3vw;
    }

    .join .join_inner .join_container .join_unit {
        background-color: #ffffff;
        border: 1px solid #000000;
        box-sizing: border-box;
        width: calc(50% - 1.5vw);
        padding: 7.7vw 3.8vw;
        display: flex;
        flex-direction: column;
    }


    .join .join_inner .join_container .join_unit h3 {
        color: #0090d5;
        font-size: 5.128vw;
        font-weight: bold;
        margin: 0 auto 3.8vw;
        letter-spacing: 0.02em;
        white-space: nowrap;
    }

    .join .join_inner .join_container .join_unit .join_text {
        font-size: 3.33vw;
        font-weight: 700;
        line-height: 1.6;
        letter-spacing: 1px;
        text-align: left;
        flex: 1;
    }

    .join .join_inner .join_container .join_unit .join_img {
        flex: 1;
        margin: 10px auto 0 auto;
    }

    .join .join_inner .join_container .join_unit[data-type="store"] .join_img {
        width: 94%;
    }

    .join .join_inner .join_container .join_unit[data-type="online"] .join_img {
        width: 94%;
    }

    .join .join_inner .join_container .join_unit .join_btn {
        background: #0090d5;
        border: none;
        border-radius: 3.85vw;
        padding: 3.0vw 0 2.2vw 0;
        margin: 3.8vw auto 0 auto;
        width: 100%;
        font: inherit;
        font-size: 3.33vw;
        font-weight: 500;
        letter-spacing: 0.1em;
        line-height: 1.3;
        color: #ffffff;
        outline: none;
        box-shadow: none;
        cursor: pointer;
        position: relative;
    }

    .join .join_inner .join_container .join_unit .join_btn::before {
        content: "+";
        position: absolute;
        right: 2vw;
        top: 50%;
        transform: translateY(-50%);
        font-size: 5vw;
        color: #ffffff;
        pointer-events: none;
    }

    .join .join_inner .join_container .join_unit .join_link {
        background-color: #F5FCFF;
        margin: 3.8vw 0 0 0;
        padding: 3vw 0;
    }

    .join .join_inner .join_container .join_unit .join_link .link_text span {
        color: #000000;
        font-size: 3.4vw;
        line-height: 1.6;
        letter-spacing: 0.02em;
        text-decoration: underline;
    }

    .join .join_inner .join_container .join_unit .join_link .link_btn {
        margin: 3.8vw auto 0 auto;
        width: 90%;
        height: 10vw;
    }

    .join .join_inner .join_container .join_unit .join_link .link_btn a {
        font-size: 3.33vw;
        display: flex;
        align-items: center;
        width: 100%;
        height: 100%;
        box-sizing: border-box;
        padding: 0.5vw 0 0 0;
        text-indent: -0.6em;
    }

    .join .step_box h3 {
        width: 74vw;
        height: 16vw;
        margin: 0;
    }

    .join h3::after {
        border-color: #fff;
    }

    .join .btn_up::after {
        border-color: #fff;
    }

    .join .box .issue {
        background: #000;
        color: #fff;
        width: 77vw;
        font-size: 4vw;
        font-weight: bold;
        padding: 3vw 0;
        margin: 0 auto 8vw;
        position: relative;
    }

    .join .box .issue::before {
        content: '';
        display: block;
        border: 0.5px solid #000;
        width: 4vw;
        position: absolute;
        top: 5vw;
        left: -4vw;
    }

    .join .box .issue::after {
        content: '';
        display: block;
        border: 0.5px solid #000;
        width: 4vw;
        position: absolute;
        top: 5vw;
        right: -4vw;
    }



    /*
ルミネカードをおすすめする理由
==============================================*/
    /* 共通 */
    .reason {
        padding: 10vw 5vw;
        background: url(../img/join_bg_sp.png);
        background-size: 100%;
    }

    #reason {
        margin-top: -25vw;
        padding-top: 25vw;
    }

    /* アコーディオン */
    .box {
        background: #fff;
        margin-bottom: 4vw;
        width: 100%;
    }

    .box h3 {
        width: 90vw;
        height: 19vw;
        margin: 0;
    }

    .accordion .btn::after {
        content: '';
        display: block;
        position: absolute;
        border-top: 1px solid #000;
        border-right: 1px solid #000;
        width: 3vw;
        height: 3vw;
        right: 4vw;
        top: 6vw;
        -webkit-transform: rotate(135deg);
        transform: rotate(135deg);
    }

    .accordion .btn_up::after {
        content: '';
        display: block;
        position: absolute;
        border-top: none;
        border-right: none;
        width: 3vw;
        height: 3vw;
        right: 4vw;
        top: 8vw;
        -webkit-transform: rotate(-45deg);
        transform: rotate(135deg);
    }

    /* アコーディオン中身 */
    .box .inner {
        display: none;
        padding: 3vw;
        margin-top: -5vw;
    }

    .box .inner .lead {
        background: #f5fcff;
        padding: 5vw 3vw;
        text-align: left;
        line-height: 6vw;
        font-size: 3.2vw;
        font-weight: bold;
        margin: 5vw auto 5vw;
        letter-spacing: -0.5px;
    }

    /* ----- 01(いつでも5％OFF) ----- */
    .reason h2 {
        font-size: 0;
        background: url(../img/reson_ttl_sp.png) no-repeat;
        background-size: contain;
        width: 70vw;
        height: 21vw;
        margin: 0 auto 5vw;
    }

    .reason01 h3 {
        font-size: 0;
        background: url(../img/reson01_sp.png) no-repeat;
        background-size: contain;
    }

    .reason01 h3 span {
        background: url(../img/reson01.gif) no-repeat;
        background-size: contain;
        top: 3vw;
    }

    .reason01 .inner .lead span {
        display: block;
        margin-top: 2vw;
    }

    .reason01 .inner .txt .ttl {
        display: block;
        color: #0090d5;
        border: 1px solid #0090d5;
        width: 53vw;
        text-align: center;
        padding: 1.5vw;
        font-size: 4vw;
        font-weight: bold;
        margin-bottom: 2vw;
    }

    .reason01 .inner .txt {
        font-size: 3.4vw;
        font-weight: bold;
        text-align: left;
        line-height: 5.5vw;
        margin-bottom: 3vw;
    }

    .reason01 .inner .txt .app {
        display: block;
        font-size: 3vw;
        line-height: 4vw;
        font-weight: normal;
        color: #d70101;
        margin-top: 2vw;
    }

    .reason01 .inner .txt .app1 {
        text-indent: -1em;
        display: block;
        padding-left: 1em;
    }


    /* ----- 02(ポイントがたまる) ----- */

    #reason02_1 {
        margin-top: -45%;
        padding-top: 45%;
    }

    .reason02 h3 {
        font-size: 0;
        background: url(../img/reson02_sp.png) no-repeat;
        background-size: contain;
    }

    /* 追加 */
    .reason02 .inner .lead .add02 {
        line-height: 1.8;
        font-size: 3.0vw;
    }

    .reason02 .inner .lead .add02 a {
        display: inline-block;
        color: #0090d5;
        text-decoration: underline;
    }

    /* ここまで */

    .reason02 .inner .lead .add {
        display: inline-block;
        line-height: 1.8;
        font-size: 2.5vw;
    }

    .reason02 .inner .text {
        position: relative;
    }

    .reason02 .inner ul {
        font-size: 0;
    }


    /* 追加 */
    .mark {
        width: 10%;
        line-height: 0;
        margin: auto;
        padding-left: 0;
    }

    /* ここまで */

    /* ----- 02(JRE POINTアプリ) ----- */

    .reason02 .apri {
        width: 100%;
        margin-top: 5vw;
    }

    .reason02 .apri .black-box {
        margin: 0 auto;
        padding: 0vw 5% 3vw;
        width: 90%;
        border: 1px solid #221815;
    }


    /* 追加 */

    .reason02 .apri .ttl-box {
        margin-top: -2vw;
    }

    .reason02 .apri .ttl-box img {
        font-size: 0;
        background: url(../img/reason02_point_ttl_sp.png) no-repeat;
        margin: 100 auto;
    }

    .reason02 .apri .img-box-present img {
        font-size: 0;
        background: url(../img/reason02_2_sp.jpg) no-repeat;
        margin: 5px 0 -20px -11px;
        width: 81vw;
    }

    .reason02 .apri .img-box img {
        margin-top: 5px;
    }

    /*ここまで */

    .reason02 .apri .img-box p {
        margin-top: 20px;
        top: 55.2%;
        transform: translate(-50%, 0);
        width: 85%;
        font-size: 3.73vw;
        line-height: 1.3;
        position: absolute;
        left: 50%;
        letter-spacing: 0.04em;
        text-align: center;
        font-weight: bold;
    }

    .reason02 .apri .note {
        margin: 2% 0 3%;
    }

    .reason02 .apri .red {
        color: #d70101;
    }

    .reason02 .apri .note li {
        font-size: 2.67vw;
        text-align: left;
        line-height: 1.5;
        letter-spacing: 0.06em;
    }

    .reason02 .apri .note li.center {
        text-align: center;
    }

    .reason02 .apri .dl-box {
        padding: 3.2vw 0;
        width: 100%;
        border: 1px solid #221815;
        border-radius: 10px;
        margin: 0 auto;
    }

    .reason02 .apri .dl-box p {
        font-size: 3.33vw;
        font-weight: bold;
        letter-spacing: 0.04em;
    }

    .reason02 .apri .dl-box>.row {
        width: 80%;
        margin: 2.67vw auto 1.87vw;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    .reason02 .apri .dl-box .apple {
        padding: 0;
        border: none;
    }

    .reason02 .apri .dl-box .google {
        padding-left: 30px;
    }

    .reason02 .apri .dl-box .apple a img {
        margin: 0;
        width: 100%;
        height: auto;
    }

    .reason02 .apri .dl-box .google a img {
        margin: 0;
        width: 100%;
        height: auto;
    }

    .reason02 .apri .dl-box .dl-txt {
        font-size: 2.4vw;
        font-weight: normal;
        margin: 0 auto;
        width: 82%;
        text-align: left;
        line-height: 1.3;
        letter-spacing: 0.04em;
    }

    .reason02 .apri .link_btn .p {
        font-size: 3.6vw;
    }

    .about_detail {
        background: url(../img/reson02_1_sp.jpg) no-repeat;
        background-size: contain;
        width: 84vw;
        height: 97vw;
        position: relative;
    }

    .about_detail p.small {
        font-size: 2.5vw;
        position: absolute;
        bottom: 52vw;
        width: 83vw;
        line-height: 1rem;
        text-align: left;
        padding-left: 3vw;
        font-weight: 600;
        left: 0;
    }

    .about_detail p.small a {
        display: inline-block;
        color: #0090d5;
        text-decoration: underline;
    }

    .about_detail .red {
        color: #d70101;
    }

    /* ----- 03(優待サービスが充実!) ----- */

    /* 共通 */

    #reason03_1 {
        margin-top: -45%;
        padding-top: 45%;
    }

    .reason03 .inner .inner_box h4 {


        height: 12vw;
        margin-bottom: 5vw;
    }

    .reason03 h3 {
        font-size: 0;
        background: url(../img/reson03_sp.png) no-repeat;
        background-size: contain;
    }

    /* STYLE */
    .reason03 .inner .style {
        margin: 6vw auto 10vw;
    }

    .reason03 .inner .style .title h4 {
        font-size: 0;
        background: url(../img/reson03_ttl1_sp.png) no-repeat;
        background-size: contain;
        width: auto;
        margin-bottom: 4vw;
    }

    .reason03 .inner .style ul .logo {
        font-size: 0;
        background: url(../img/reson03_1_sp.jpg) no-repeat;
        background-size: contain;
        width: 84vw;
        height: 13vw;
        margin: 0 auto;
    }

    .reason03 .inner .style .sample {
        font-size: 0;
        background: url(../img/reson03_3_sp.jpg) no-repeat;
        background-size: contain;
        width: 75vw;
        height: 130vw;
        margin: 2vw auto 5vw;
    }

    /* .reason03 .inner .style ul .entry {
    font-size: 0;
    background: url(../img/reson03_3_sp.jpg) no-repeat;
    background-size: contain;
    width: 75vw;
    height: 61vw;
    margin: 0 auto 4vw;
} */

    /* SERVICE */
    .reason03 .inner .service {
        margin-bottom: 10vw;
    }

    .reason03 .inner .service .title h4 {
        font-size: 0;
        background: url(../img/reson03_ttl2_sp.png) no-repeat;
        background-size: contain;
        width: auto;
        margin-bottom: 4vw;
    }

    .reason03 .inner .service p {
        font-size: 0;
        background: url(../img/reson03_4_sp.png) no-repeat;
        background-size: contain;
        width: 84vw;
        height: 115vw;
        margin-bottom: 3vw;
    }

    .reason03 .inner .service ul li.app {
        text-align: left;
        padding-left: 1em;
        text-indent: -1em;
        font-size: 3vw;
        line-height: 4vw;
        margin: 0 1vw;
        letter-spacing: -0.03em;
    }

    .reason03 .inner .style ul {
        padding-bottom: 1vw;
    }

    /* PRESENT */
    #reason03_3 {
        margin-top: -30%;
        padding-top: 30%;
    }

    .reason03 .inner .present .title h4 {
        font-size: 0;
        background: url(../img/reson03_ttl3_sp.png) no-repeat;
        background-size: contain;
        width: auto;
        margin-bottom: 4vw;
    }

    .reason03 .inner .present ul {
        width: 100%;
        height: auto;
        background: none;
    }

    .reason03 .inner .present ul li.txt {
        font-size: 3.5vw;
        font-weight: 700;
        line-height: 1.6;
        letter-spacing: 0.06em;
        margin: 2vw 0 3vw 0;
    }

    .reason03 .inner .present ul li.txt a {
        display: inline;
        color: #0090d5;
        text-decoration: underline;
    }

    .reason03 .inner .present img {
        width: 100%;
        height: auto;
    }

    .reason03 .inner .present ul li.p_btn {
        position: absolute;
        width: 93%;
        right: 2.8vw;
        top: 170vw;
    }

    .reason03 .inner .present .p_btn img {
        margin-bottom: 3vw;
    }

    .reason03 .inner .present ul li.app {
        text-align: left;
        padding-left: 1em;
        text-indent: -1em;
        font-size: 3vw;
        line-height: 4vw;
        margin: 2vw 1vw;
    }




    /* ----- 04(アプリでおトク！) ----- */

    #reason04_1 {
        margin-top: -45%;
        padding-top: 45%;
    }

    .reason04 h3 {
        font-size: 0;
        background: url(../img/reson04_sp.png) no-repeat;
        background-size: contain;
    }

    .reason04 ul {
        font-size: 0;
        text-align: left;
        margin-bottom: 5vw;
    }

    .reason04 ul li {
        display: inline-block;
        vertical-align: top;
    }

    .reason04 .inner ul li:nth-child(1) {
        background: url(../img/reson04_1.jpg) no-repeat;
        background-size: contain;
        width: 34vw;
        height: 12vw;
        margin: 4vw auto 0;
    }

    .reason04 .inner ul li:nth-child(2) {
        font-size: 2vw;
        text-align: left;
        width: 46vw;
        margin-left: 3vw;
        line-height: 3.5vw;
        font-weight: bold;
    }


    /* ----- テキスト ----- */
    .reason p.txt {
        font-size: 3.5vw;
        font-weight: bold;
        text-align: center;
        display: block;
        margin: 9vw 0 0 0;
    }

    .reason p.txt .red {
        font-size: 4.5vw;
        color: #d70101;
        display: block;
        line-height: 1;
    }



    /* 共通 */
    #modal .step {
        border: 1px solid #0090d5;
        width: 75vw;
        margin: 0 auto 3vw;
    }

    #modal .modal_content[data-type="online"] .online_box ul {
        /*border: 1px solid #d8d8d8;*/
        width: 100%;
        /* margin: 0 auto 3vw; */
        /* padding: 0 0 3vw 0; */
        font-size: 0;
        text-align: center;
    }

    #modal .accordion.outer {
        border: 2px solid #0090d5;
    }

    #modal .accordion.outer .wrap {
        margin-top: 3vw;
    }

    #modal .modal_content .modal_head {
        background-color: #eeeeee;
        width: 100%;
        height: 33.85vw;
        justify-content: center;
        vertical-align: middle;
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        gap: 4vw;
        margin: 0 auto;
        border-bottom: 2px solid #0090d5;
    }

    #modal .modal_content .modal_head .title {
        color: #0090d5;
        font-size: 6.15vw;
        font-weight: 700;
        letter-spacing: 0.1em;
    }

    #modal .modal_content .modal_head .sub_title {
        font-size: 3.5vw;
        font-weight: 500;
        line-height: 1.6;
    }



    #modal .modal_content[data-type="online"] .online_box .txt_box .txt {
        font-size: 5vw;
        font-weight: bold;
        text-decoration: underline;
        text-align: left;
        line-height: 8vw;
        /*width: 74vw;*/
        margin-bottom: 2vw;
    }

    #modal .modal_content[data-type="online"] .online_box ul .txt_box {
        width: 74vw;
    }

    #modal .modal_content[data-type="online"] .online_box .txt_box .small {
        background: #f6f6f6;
        padding: 2vw;
        text-align: left;
        font-size: 3.5vw;
        line-height: 5.5vw;
        width: 74vw;
    }


    /* STEP00 */
    #modal .modal_content[data-type="online"] .step00 p.txt {
        width: 100%;
        margin: 0 auto 5vw;
        font-size: 4vw;
        line-height: 1.5;
    }

    #modal .step00 p.txt span.blue {
        color: #0090d5;
        font-weight: bold;
        letter-spacing: 2px;
    }

    #modal .step00 p.txt span.app {
        font-size: 3vw;
        text-align: right;
        display: block;
    }


    /* STEP01 */
    #modal .step01 h3 {
        font-size: 0;
        background: url(../img/step01.png) no-repeat;
        background-size: cover;
    }

    #modal .modal_content[data-type="online"] .step01 {
        background: none;
    }

    #modal .modal_content[data-type="online"] .online_box ul .no1 {
        font-size: 5vw;
        font-weight: bold;
        text-decoration: underline;
        text-align: left;
        line-height: 8vw;
        margin-bottom: 2vw;
        display: block;
    }

    #modal .modal_content[data-type="online"] .online_box ul .step01 .no2 {
        background: url(../img/online_step1_bg_sp.png) no-repeat;
        background-size: contain;
        height: 35vw;
        margin: 8vw;
        font-weight: normal;
    }

    #modal .modal_content[data-type="online"] .online_box ul .no3 {
        text-align: left;
        font-size: 3.5vw;
        line-height: 5.5vw;
    }

    /* STEP02 */
    #modal .modal_content[data-type="online"] .step02 {
        background: none;
    }

    .join_inner .store .accordion_title {
        background-color: #eeeeee;
        color: #0090d5;
        width: 100%;
        height: 18vw;
        font-size: 4vw;
        margin: 0 auto;
        line-height: 1.3;
        display: block;
    }

    #modal .step02 h3 {
        font-size: 0;
        background: url(../img/step02.png) no-repeat;
        background-size: cover;
    }

    #modal .modal_content[data-type="online"] .online_box ul .step02 .no2 {
        background: url(../img/online_step2_bg_sp.png) no-repeat;
        background-size: contain;
        height: 35vw;
        margin: 8vw;
        font-weight: normal;
    }

    #modal .modal_content[data-type="online"] .step02 .bg_blue {
        width: auto;
        line-height: 1.6;
        padding: 3vw;
    }

    /* STEP03 */
    #modal .modal_content[data-type="online"] .step03 {
        background: none;
    }

    #modal .step03 h3 {
        font-size: 0;
        background: url(../img/step03.png) no-repeat;
        background-size: cover;
    }

    #modal .modal_content[data-type="online"] .online_box ul .step04 .no2 {
        background: url(../img/online_step4_bg_sp.png) no-repeat;
        background-size: contain;
        height: 35vw;
        margin: 8vw;
        font-weight: normal;
    }

    #modal .modal_content[data-type="online"] .step03 ul .no3 {
        background: #f6f6f6;
        padding: 2vw;
    }

    /* STEP04 */
    #modal .step04 h3 {
        font-size: 0;
        background: url(../img/step04.png) no-repeat;
        background-size: cover;
    }

    /* オンライン申し込み */
    #modal .modal_content[data-type="online"] {
        width: 90%;
        margin: 0 auto 10vw;
        background: #fff;
    }

    #modal .join_inner h3 {
        font-size: 4vw;
        font-weight: bold;
        color: #fff;
        background: #000;
        width: 77vw;
        padding: 3vw 0;
        margin: -4vw auto 6vw;
        letter-spacing: 0.5px;
        position: relative;
        line-height: 1;
        height: auto;
    }

    #modal .join_inner .store .title {
        margin-bottom: 6vw;
    }

    #modal .join_inner .title::before {
        content: '';
        display: block;
        border: 0.5px solid #000;
        width: 4vw;
        position: absolute;
        top: 5vw;
        left: -4vw;
    }

    #modal .join_inner .title::after {
        content: '';
        display: block;
        border: 0.5px solid #000;
        width: 4vw;
        position: absolute;
        top: 5vw;
        right: -4vw;
    }

    .join_inner .online_new ul li:nth-child(1) {
        padding: 0 7vw;
        font-size: 3.5vw;
        font-weight: bold;
        line-height: 6vw;
        text-decoration: underline;
        margin-bottom: 3vw;
    }

    .online .link_btn,
    .store .link_btn {
        width: 65vw;
    }

    #modal .modal_content[data-type="online"] .accordion_title::after {
        border-top: 2px solid #0090d5;
        border-right: 2px solid #0090d5;
        -webkit-transform: rotate(135deg);
        transform: rotate(135deg);
        top: 40%;
        right: 6vw;
        width: 3vw;
        height: 3vw;
    }

    #modal .modal_content[data-type="online"] .accordion_title.btn_up::after {
        position: absolute;
        top: 40%;
        right: 6vw;
        border-top: none;
        border-right: none;
    }

    #modal .modal_content[data-type="online"] .inner {
        padding: 5.13vw 3vw;
        border: none;
        /* width: 73vw; */
    }


    #modal .modal_content[data-type="online"] .online_box {
        margin-bottom: 5vw;
    }

    #modal .modal_content[data-type="online"] .step00 p.txt {
        width: 100%;
        margin: 0;
        font-size: 3.5vw;
        line-height: 1.5;
        padding: 0;
        text-decoration: none;
        font-weight: normal;
    }

    #modal .modal_content[data-type="online"] .step00 p.txt span.blue {
        letter-spacing: 0;
    }



    #modal .modal_content[data-type="online"] .online_box .nom {
        font-size: 0;
        background-size: cover;
        background-repeat: no-repeat;
        width: 100%;
        height: 12.8vw;
    }

    #modal .modal_content[data-type="online"] .step01 .nom {
        background-image: url(../img/step01_sp.png);
    }

    #modal .modal_content[data-type="online"] .step02 .nom {
        background-image: url(../img/step02_sp.png);
        margin: 7.8vw 0 0 0;
    }

    #modal .modal_content[data-type="online"] .step03 .nom {
        background-image: url(../img/step03_sp.png);
        margin: 7.8vw 0 0 0;
    }

    #modal .modal_content[data-type="online"] .step04 .nom {
        background-image: url(../img/step04_sp.png);
        margin: 7.8vw 0 0 0;
    }



    /* STEP01 */
    #modal .modal_content[data-type="online"] .step01 ul .no2 {
        background: url(../img/online_step1_bg_sp.png) no-repeat;
        background-size: contain;
        height: 35vw;
        margin: 8vw;
        font-weight: normal;
    }

    #modal .modal_content[data-type="online"] .step01 ul .no3 {
        background: #f6f6f6;
        padding: 2vw;
    }

    /* STEP02 */
    #modal .step02 ul .no1 {
        margin-bottom: 0;
    }

    #modal .step02 ul .app {
        font-size: 3vw;
        text-align: left;
        margin: 0 auto 6vw;
    }

    #modal .modal_content[data-type="online"] .step02 ul .no2 {
        background: url(../img/online_step2_bg_sp.png) no-repeat;
        background-size: contain;
        width: 62vw;
        height: 42vw;
        margin: 4vw 6vw 4vw 6vw;
    }

    #modal .step02 ul .no3 {
        padding: 0;
    }

    #modal .step02 ul .no3 .bg_blue {
        background-color: #f5fcff;
        display: block;
        line-height: 1.6;
        padding: 3vw;
    }

    #modal .modal_content[data-type="online"] .step02 .bg_blue .bg_blue_title {
        color: #ffffff;
        padding: 3px 10px 0px 10px;
        font-size: 5vw;
        font-weight: bold;
        letter-spacing: 0.06em;
        margin: 0 0 3vw 0;
        display: inline-block;
        background: none;
        background-color: #0090d5;
        width: auto;
        height: auto;
    }

    #modal .step02 ul .no3 .bg_blue .checkmark {
        padding: 0 0 0 7vw;
        position: relative;
        display: block;
        color: #0090d5;
        font-size: 4vw;
        text-decoration: underline;
        font-weight: bold;
    }

    #modal .modal_content[data-type="online"] .step02 .bg_blue p {
        font-size: 3.5vw;
        margin-bottom: 2vw;
    }

    #modal .modal_content[data-type="online"] .step02 .bg_blue .checkmark:nth-of-type(3) {
        margin-bottom: 2vw;
    }

    #modal .step02 ul .no3 .bg_blue .checkmark:before,
    #modal .step02 ul .no3 .bg_blue .checkmark:after {
        content: "";
        display: block;
        position: absolute;
    }

    #modal .step02 ul .no3 .bg_blue .checkmark:before {
        width: 13px;
        height: 13px;
        border: 1px solid #0090d5;
        left: 0;
        top: 5px;
    }

    #modal .step02 ul .no3 .bg_blue .checkmark:after {
        border-left: 2.5px solid #0090d5;
        border-bottom: 2.5px solid #0090d5;
        width: 10px;
        height: 5px;
        -webkit-transform: rotate(-45deg);
        transform: rotate(-45deg);
        left: 1px;
        top: 7px;
    }

    #modal .step02 ul .no3 .bg_blue .note {
        display: block;
        padding-left: 1em;
        text-indent: -1em;
        font-size: 2.5vw;
        line-height: 4vw;
    }

    #modal .step02 ul .no4 {
        background: #f6f6f6;
        padding: 2vw;
        text-align: left;
        margin: 3vw 0 0 0;
    }

    #modal .step02 ul .no4 .note {
        display: block;
        padding-left: 1em;
        text-indent: -1em;
        font-size: 2.5vw;
        line-height: 4vw;
    }

    #modal .step02 ul .no5 {
        background: url(../img/step2_2.png) no-repeat;
        background-size: contain;
        width: 79vw;
        height: 31vw;
        margin-bottom: 3vw;
    }

    #modal .step02 ul .no6 {
        background: url(../img/step2_3.png) no-repeat;
        background-size: contain;
        width: 79vw;
        height: 76vw;
        border-bottom: 1px solid #000;
        padding-bottom: 3vw;
    }

    #modal .modal_content[data-type="online"] .step02 ul a {
        padding-left: 1em;
    }

    /* STEP03 */
    #modal .modal_content[data-type="online"] .step03 ul .no2 {
        background: url(../img/online_step3_bg_sp.png) no-repeat;
        background-size: contain;
        height: 41vw;
        margin: 6vw;
        width: 62vw;
    }

    #modal .step03 ul .no3 span {
        display: block;
        padding-left: 1em;
        text-indent: -1em;
        font-size: 2.5vw;
        line-height: 4vw;
    }

    #modal .step03 ul .no3 span:nth-child(1) {
        margin-top: 3vw;
    }

    /* STEP04 */
    #modal .modal_content[data-type="online"] .step04 {
        background: none;
    }

    #modal .modal_content[data-type="online"] .step04 ul .no2 {
        background: url(../img/online_step4_bg_sp.png) no-repeat;
        background-size: contain;
        height: 41vw;
        margin: 3vw 3vw 0 3vw;
        width: 66vw;
    }


    #modal .modal_content[data-type="online"] .online_box ul .no3 a {
        display: inline-block;
    }

    #modal .step04 ul .no3 span {
        display: block;
        padding-left: 1em;
        text-indent: -1em;
        font-size: 2.5vw;
        line-height: 4vw;
    }

    #modal .step04 ul .no3 span:nth-child(1) {
        margin-top: 3vw;
    }

    #modal .modal_content[data-type="online"] .step04 ul .no3 {
        background: #f6f6f6;
        padding: 2vw;
    }


    #modal .modal_content[data-type="online"] .online_new ul {
        background: #f5fcff;
        padding: 5vw 6vw 2vw;
        margin: 3vw 0 0 0;
    }

    /* 店舗申し込み */
    #modal .modal_content[data-type="store"] {
        width: 90%;
        margin: 0 auto 5vw;
        background: #fff;
    }

    #modal .modal_content[data-type="store"] .inner {
        padding: 3vw;
        margin-top: 0;
        border-top: none;
    }

    #modal .modal_content[data-type="store"] .accordion_title::after {
        border-top: 2px solid #0090d5;
        border-right: 2px solid #0090d5;
        -webkit-transform: rotate(135deg);
        transform: rotate(135deg);
        top: 40%;
        right: 6vw;
        width: 3vw;
        height: 3vw;
    }

    #modal .modal_content[data-type="store"] .accordion_title.btn_up::after {
        position: absolute;
        top: 40%;
        right: 6vw;
        border-top: none;
        border-right: none;
    }


    #modal .modal_content ul .no1 span {
        display: inline-block;
        font-size: 4.6vw;
        font-weight: bold;
        text-decoration: underline;
        margin: 5vw 0 0 0;
    }

    #modal .modal_content[data-type="store"] ul .no1 span.comment {
        display: block;
        font-size: 3.33vw;
        font-weight: 500;
        text-decoration: none;
        margin-top: 1em;
    }



    #modal .modal_content[data-type="store"] .step00 p.txt {
        width: 100%;
        margin: 0;
        font-size: 3.5vw;
        line-height: 1.5;
    }

    #modal .modal_content[data-type="store"] .step00 p.txt span.blue {
        letter-spacing: 0;
    }

    #modal .modal_content[data-type="store"] .step01 {
        background: none;
    }

    #modal .modal_content[data-type="store"] .store_box .nom {
        font-size: 0;
        background-size: cover;
        background-repeat: no-repeat;
        width: 100%;
        height: 12.8vw;
    }

    #modal .modal_content[data-type="store"] .step01 .nom {
        background-image: url(../img/step01_sp.png);
    }

    #modal .modal_content[data-type="store"] .step02 .nom {
        background-image: url(../img/step02_sp.png);
        margin: 7.8vw 0 0 0;
    }

    #modal .modal_content[data-type="store"] .step03 .nom {
        background-image: url(../img/step03_sp.png);
        margin: 7.8vw 0 0 0;
    }


    #modal .modal_content[data-type="store"] .store_box {
        margin-bottom: 5vw;
    }

    #modal .modal_content[data-type="store"] .step01 ul .no2 {
        background: url(../img/step1_1.png) no-repeat;
        background-size: contain;
        height: 38vw;
        margin: 5vw calc((100% - 56vw)/2);
        width: 56vw;
    }

    #modal .modal_content[data-type="store"] .step01 ul .no3 {
        background: #f6f6f6;
        padding: 2vw;
        text-align: left;
        font-size: 3.5vw;
        line-height: 5.5vw;
    }

    #modal .modal_content[data-type="store"] .step02 {
        background: none;
    }

    #modal .modal_content[data-type="store"] .step02 ul .no2 {
        background: url(../img/step2_1.png) no-repeat;
        background-size: contain;
        height: 30vw;
        margin: 4vw calc((100% - 43.6vw)/2);
        width: 43.6vw;
    }

    #modal .modal_content[data-type="store"] .step02 ul .no3 {
        background: #f6f6f6;
        padding: 2vw;
        text-align: left;
        font-size: 3.5vw;
        line-height: 5.5vw;
    }

    #modal .modal_content a {
        text-decoration: underline;
        display: inline-block;
        color: #0090d5;
    }

    #modal .modal_content[data-type="store"] .step03 ul .no2 {
        background: url(../img/step3_1.png) no-repeat;
        background-size: contain;
        height: 40vw;
        margin: 5vw calc((100% - 52.6vw)/2);
        width: 52.6vw;
    }

    #modal .modal_content[data-type="store"] .step03 {
        background: none;
    }

    #modal .modal_content[data-type="store"] .step03 ul .no3 {
        background: #f6f6f6;
        padding: 2vw;
        text-align: left;
        font-size: 3.5vw;
        line-height: 5.5vw;
    }

    .join_inner .store_new ul li:nth-child(1) {
        font-weight: bold;
        font-size: 3.5vw;
        text-decoration: underline;
        margin-bottom: 3vw;
        letter-spacing: 0.8vw;
    }

    #modal .modal_content[data-type="store"] .store_box .link_btn {
        width: 65vw;
    }

    .join_inner .store_new ul {
        background: #f5fcff;
        padding: 5vw 6vw 2vw;
        margin: 3vw 0 0 0;
    }




    /*============================
    #modal
    ============================*/
    #modal .modal_content {
        max-width: 90vw;
    }

    #modal .modal_content .inner {
        /* max-height: calc(90vh - 33.85vw); */
        max-height: calc(90dvh - 33.85vw);
        overflow-y: auto;
    }

    #modal .modal_close {
        top: 3vw;
        right: 3vw;
        width: 7.18vw;
        height: 7.18vw;
    }




    /*
いつでも5％OFF
==============================================*/
    #activation {
        margin-top: -25vw;
        padding-top: 25vw;
    }

    .activation {
        background: #eeeeee;
        padding-top: 10vw;
        padding-bottom: 5vw;
    }

    .activation a {
        text-decoration: underline;
    }

    .activation h2 {
        font-size: 0;
        background: url(../img/activation_ttl_sp.png) no-repeat;
        background-size: contain;
        width: 52vw;
        height: 20vw;
        margin: 0 auto 7vw;
    }

    .activation .app {
        float: none;
    }

    .activation .point {
        font-size: 0;
        background: url(../img/activation_ttl1.png) no-repeat;
        background-size: contain;
        width: 84vw;
        height: 9vw;
        margin: 0 auto 6vw;
    }

    .activation .box {
        background: #eeeeee;
        margin-bottom: 0;
    }

    .activation .accordion {
        border: 1px solid #0090d5;
        color: #0090d5;
        width: 90%;
        margin: 0 auto 3vw;
        text-align: left;
    }

    .activation .accordion:last-of-type {
        margin: 0 auto 5vw;
    }

    .activation .box h3 {
        width: 85vw;
        height: 19vw;
        margin: 0;
    }

    .activation .shopping {
        padding: 0;
        float: none;
    }

    .activation .shopping h3 {
        font-size: 0;
        background: url(../img/act_ttl01_sp.png) no-repeat;
        background-size: contain;
    }

    .activation .beauty h3 {
        font-size: 0;
        background: url(../img/act_ttl02_sp.png) no-repeat;
        background-size: contain;
    }

    .activation .commute h3 {
        font-size: 0;
        background: url(../img/act_ttl03_sp.png) no-repeat;
        background-size: contain;
    }

    .activation .box h3::after {
        content: '';
        display: block;
        position: absolute;
        width: 3vw;
        height: 3vw;
        border-top: 2px solid #0090d5;
        border-right: 2px solid #0090d5;
        top: 7vw;
        right: 0;
        transform: rotate(135deg);
    }

    .activation .box .btn_up::after {
        border-bottom: none;
        border-left: none;
        transform: rotate(-45deg);
    }

    .activation .box ul {
        font-size: 0;
        text-align: left;
        margin-top: 4vw;
    }

    .activation .box ul li {
        display: inline-block;
        vertical-align: top;
    }

    .activation .box ul .img {
        width: 91%;
        height: 54vw;
        margin-right: 3vw;
    }

    /* shopping */
    .activation .shopping {
        margin-bottom: 3vw;
    }

    .activation .box .shopping .img {
        background: url(../img/activation01_sp.png) no-repeat;
        background-size: contain;
        height: 60.5vw;
    }

    .activation .box .shopping .ttl {
        background: url(../img/activation02_sp.png) no-repeat;
        background-size: contain;
        width: 5%;
        height: 23vw;
    }

    /* beauty */
    .activation .box .beauty .img {
        background: url(../img/activation03_sp.png) no-repeat;
        background-size: contain;
    }

    .activation .box .beauty .ttl {
        background: url(../img/activation04_sp.png) no-repeat;
        background-size: contain;
        width: 3%;
        height: 19vw;
    }

    /* other */
    .activation .other {
        float: none;
        padding: 0;
        margin: 0;
    }

    .activation .box .other .img {
        background: url(../img/activation05_sp.png) no-repeat;
        background-size: contain;
    }

    .activation .box .other .ttl {
        background: url(../img/activation06_sp.png) no-repeat;
        background-size: contain;
        width: 3%;
        height: 14vw;
    }

    .activation .box .app {
        width: 80vw;
        text-align: left;
        margin: 3vw 0 0 0;
        font-size: 2.5vw;
        padding-left: 1em;
        text-indent: -1em;
        line-height: 2vw;
        color: #000000;
    }

    .activation .box .app a {
        display: inline;
        color: #0095d5;
    }



    /*
わからないことは...
==============================================*/
    .trouble {
        padding: 5vw 0;
        width: 90%;
    }

    .trouble ul {
        font-size: 0;
        text-align: left;
        width: 100%;
        padding: 5vw 0 0;
    }

    .trouble .card {
        margin-bottom: 0;
    }

    .trouble .card .cardbox {
        width: auto;
        margin: 0 auto 5vw;
        display: block;
        padding: 0;
        border: 1px solid #0090d5;
    }

    .trouble .card .cardbox:nth-child(1) {
        margin-right: 0;
    }

    .trouble .card .cardbox:nth-child(2) {
        margin-left: 0;
    }

    .trouble .card .cardbox ul li.txt1 {
        font-size: 3.5vw;
        padding-left: 3vw;
        margin-bottom: 3vw;
    }

    .trouble .card .cardbox ul li.txt2 {
        font-size: 5vw;
        margin-bottom: 1vw;
        line-height: 6vw;
    }

    .trouble .loss {
        padding-left: 3vw;
    }

    .trouble .txt2 span {
        font-size: 3.5vw;
        margin-bottom: 7.8vw;
        display: inline-block;
    }

    .trouble .card .cardbox ul li:nth-child(3)::after {
        border: none;
    }

    .trouble .card .cardbox ul li.txt3 {
        font-size: 3.5vw;
        padding-left: 3vw;
        margin-bottom: 3vw;
        line-height: 1.6;
    }

    .trouble .card .cardbox ul li:nth-child(3) .caution {
        padding-top: 0;
    }

    .trouble .card .cardbox:nth-child(2) ul li:nth-child(2) {
        margin: 0 0 1vw 0;
    }

    .trouble .card .cardbox ul li.txt4 {
        font-size: 7vw;
        color: #0090d5;
        font-weight: bold;
        padding-left: 3vw;
        margin-bottom: 5vw;
    }

    .trouble .card .cardbox ul li.txt4 a {
        color: #0090d5;
        text-decoration: none;
    }

    .trouble .txt4::before {
        content: '';
        display: block;
        border: 1px solid #0090d5;
        width: 95%;
        margin-bottom: 4vw;
    }

    .trouble .card .cardbox ul li.txt5 {
        font-size: 3.5vw;
        text-align: right;
        background: #0090d5;
        width: 91.5%;
        margin: 0 auto 0.5vw;
        padding: 2vw 7vw 2vw 0;
        position: relative;
    }

    .trouble .card .cardbox ul li.txt5 a {
        color: #fff;
        text-decoration: none;
    }

    .trouble .card .cardbox ul li.txt5::after {
        content: '';
        display: block;
        border-top: 1px solid #fff;
        border-right: 1px solid #fff;
        position: absolute;
        width: 1.5vw;
        height: 1.5vw;
        right: 3vw;
        top: 2.9vw;
        -webkit-transform: rotate(45deg);
        transform: rotate(45deg);
    }

    .trouble .movie {
        width: 100%;
        margin: 15vw auto 3vw;
    }

    .trouble .movie iframe {
        width: 100%;
        max-width: 100vw;
        max-height: 51vw;
    }

    .lc_wrapper .follow_top {
        font-size: 0;
        background: url(/card/img/pagetop.png) no-repeat;
        background-size: 100%;
        width: 12.533333333333333vw;
        height: 12.533333333333333vw;
        position: fixed;
        right: 1.7333333333333334vw;
        bottom: 4.933333333333334vw;
        cursor: pointer;
    }
}