@charset "UTF-8";
/* CSS Document */

/* =============================================
  オンラインストア（プラン購入、ポイント購入）用CSS
============================================= */

/* --------------------- PC --------------------- */

/* =============== 共通 =============== */

/* ===== タイトル、見出し ===== */
.store_title {
    margin-bottom: 30px;
    padding: 6px 20px;
    background-color: #349cd0;
    clear: both;
}

.store_title h2 {
    font-size: 16px;
    font-weight: 500;
    color: #FFF;
}

/* ===== プラン、ポイント切り替えタブ ===== */
.page_store .tab_stores {
    display: flex;
    justify-content: space-between;
    margin-bottom: 50px;
}

.page_store .tab_stores a {
    display: inline-block;
    width: 338px;
    margin: 0;
    border-radius: 90px;
    text-align: center;
    line-height: 45px;
    font-size: 15px;
    font-weight: 500;
    color: #bababa;
}

.page_store .tab_stores a.tab_store_on {
    background-color: #00c3f6;
    color: #fff;
}

/* ===== 購入ボタン ===== */
.page_store .buy_btn {
    display: block;
    margin: 0 auto;
    background-color: #ff7e00;
    border-radius: 30px;
    text-align: center;
    color: white;
}

/* ===== 備考 ===== */
.page_store .pd_note li {
    position: relative;
    padding-left: 15px;
    font-size: 13px;
    color: #989898;
    text-align:left;
}

.page_store .pd_note li::before {
    position: absolute;
    top: 0;
    left: 0;
    content: "※";
}

/* =============== プラン購入 =============== */

.page_plan .content_box.alert {
    margin: 0 0 2rem;
}

.page_plan .content_box.alert .c-btn {
    margin-bottom: 20px;
}

.page_plan .content_box.alert .c-btn.to_user_status {
    margin-bottom: 0;
    margin-top: 20px;
}

#payment,
#premium {
    margin-bottom: 70px;
}

/* ===== 特典 ===== */
.page_plan .note {
    margin-bottom: 40px;
    text-align: center;
}
h1.sp_cont {
    font-size: 25px;
    font-weight: 500;
}

.page_plan .note li {
    position: relative;
    padding-left: 15px;
    font-size: 14px;
    margin-bottom: 10px;
}

.page_plan .note li .strong {
    color: #079cd1;
}

/* 特典（無料会員） */
.page_plan .free {
    overflow: hidden;
    margin-bottom: 40px;
    border-radius: 8px;
}

.page_plan .free_head {
    padding: 4px 12px 6px;
}

.page_plan .free_head h2 {
    font-size: 16px;
    font-weight: 500;
    color: #fff;
}

.page_plan .free_cont {
    padding: 20px 0 35px 20px;
    background-color: #fff;
}

.page_plan .free_cont li {
    position: relative;
    padding-left: 24px;
    font-size: 15px;
    font-weight: 500;
    color: #636363;
    margin: 0 4px 18px 0;
}

.page_plan .free_cont li::before {
    position: absolute;
    top: 5px;
    left: 0;
    display: block;
    content: "";
    width: 16px;
    height: 16px;
    background-repeat: no-repeat;
    background-size: contain;
}

.page_plan .free_cont li span {
    font-size: 12px;
    color: #959595;
}

.page_plan #payment .free {
    border: 1px solid #B1B1B1;
    width: 48%;
    float: left;
    margin-right: 25px;
}

.page_plan #payment .free_head {
    background-color: #B1B1B1;
}

.page_plan #payment .free_cont li:nth-of-type(3n + 1) {
    text-align: left;
    width: 262px;
}

.page_plan #payment .free_cont li:nth-of-type(3n + 2) {
    text-align: left;
}

.page_plan #payment .free_cont li:nth-of-type(3n) {
    width: calc(100% - 262px - 233px);
}

.page_plan #payment .free_cont li:nth-of-type(-n + 3) {
    text-align: left;
}

.page_plan #payment .free_cont li::before {
    background-image: url(../img/store/line_dot_free.png);
}

.page_plan #payment .free_cont .annotation {
    font-size: 13px;
}

/* 特典（有料会員） */
.page_plan .privilege {
    overflow: hidden;
    margin-bottom: 80px;
    border-radius: 8px;
}

.page_plan .priv_head {
    padding: 4px 12px 6px;
}

.page_plan .priv_head h2 {
    font-size: 16px;
    font-weight: 500;
    color: #fff;
}

.page_plan .priv_cont {
    padding: 10px 0 24px 20px;
    background-color: #fff;
}

.page_plan .priv_cont li {
    position: relative;
    margin-top: 17px;
    padding-left: 24px;
    font-size: 14px;
    font-weight: 500;
    color: #636363;
}

.page_plan .priv_cont li::before {
    position: absolute;
    top: 5px;
    left: 0;
    display: block;
    content: "";
    width: 16px;
    height: 16px;
    background-repeat: no-repeat;
    background-size: contain;
}

.page_plan .priv_cont li span {
    padding-left: 5px;
    font-size: 12px;
    color: #959595;
}

/* 特典（有料会員） */
.page_plan #payment .privilege {
    border: 1px solid #079cd1;
}

.page_plan #payment .priv_head {
    background-color: #079cd1;
}

.page_plan #payment .priv_cont li:nth-of-type(3n + 1) {
    text-align: left;
    width: 300px;
}

.page_plan #payment .priv_cont li {
    text-align: left;
    width: 300px;
}


.page_plan #payment .priv_cont li::before {
    background-image: url(../img/store/list_dot_payment.png);
}

/* 特典（プレミアム会員） */
.page_plan #premium .privilege {
    border: 1px solid #178b90;
}

.page_plan #premium .priv_head {
    background-color: #178b90;
}

.page_plan #premium .priv_cont li:nth-of-type(2n + 1) {
    width: 364px;
}

.page_plan #premium .priv_cont li:nth-of-type(2n) {
    width: calc(100% - 364px);
}

.page_plan #premium .priv_cont li:nth-of-type(5) {
    width: 100%;
}

.page_plan #premium .priv_cont li:nth-of-type(-n + 2) {
    margin-top: 0;
}

.page_plan #premium .priv_cont li::before {
    background-image: url(../img/store/list_dot_premium.png);
}

/* ===== 料金表 ===== */
.page_plan .plan_list {
    justify-content: space-between;
    margin-bottom: 30px;
}

.page_plan .plan_product_srv {
    position: relative;
    width: 21.85%;
    border: 1px solid #dedede;
    border-radius: 8px;
}

.page_plan .plan_product {
    position: relative;
    width: 32%;
    height: 180px;
    border: 1px solid #dedede;
    border-radius: 8px;
}

.page_plan #payment .plan_product.st_pd_year {
    border: 1px solid #079cd1;
}

.page_plan #premium .plan_product.st_pd_year {
    border: 1px solid #178b90;
}

.page_plan .pl_pd_head {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    padding: 1px 0 2px;
    border-radius: 8px 8px 0 0;
    text-align: center;
    font-size: 14px;
    font-weight: 500;
    color: #fff;
}

.page_plan #payment .pl_pd_head {
    background-color: #079cd1;
}

.page_plan #premium .pl_pd_head {
    background-color: #178b90;
}

.page_plan .pl_pd_discount {
    position: absolute;
    top: -10px;
    left: -10px;
    display: block;
    width: 50px;
    height: 50px;
    padding-top: 9px;
    border-radius: 50%;
    text-align: center;
    line-height: 1.2;
    letter-spacing: 0;
    font-size: 14px;
    font-weight: 700;
    color: #fff;
}

.page_plan #payment .pl_pd_discount {
    background-color: #00c3f6;
}

.page_plan #premium .pl_pd_discount {
    background-color: #21a5ab;
}

.page_plan .pl_pd_col {
    text-align: center;
}

.page_plan .pl_pd_col:first-of-type {
    height: 152px;
    padding-top: 55px;
}

.page_plan .pl_pd_col p {
    text-align: center;
    line-height: 1.3;
    letter-spacing: 0;
}

.page_plan .pl_pd_month {
    margin-bottom: 29px;
    font-size: 15px;
    font-weight: 500;
    color: #636363;
    background: #ececec;
    border-radius: 4px 4px 0 0;
}

.page_plan .pl_pd_price {
    font-size: 16px;
    font-weight: 700;
    color: #636363;
    margin-bottom: -10px;
}

.page_plan .pl_pd_price span {
    font-size: 38px;
}

.page_plan .pl_pd_price_mnth {
    font-size: 13px;
    font-weight: 500;
    color: #636363;
}

.page_plan .buy_btn {
    width: 120px;
    line-height: 28px;
    font-size: 14px;
}

/* =============== ポイント購入 =============== */
#page_point .content_box.alert {
    margin: 0 0 2rem;
}

#page_point .content_box.alert .c-btn {
    margin-bottom: 20px;
}

/* ===== 料金表 ===== */
#page_point #point_list {
    justify-content: space-between;
    margin-bottom: 30px;
}

#page_point .point_product {
    width: 17.75%;
    height: 242px;
    border-radius: 8px;
    border: 1px solid #dedede;
}

#page_point .point_product .pt_col {
    height: 50%;
    text-align: center;
}

#page_point .point_product .pt_col:first-of-type {
    padding-top: 50px;
}

#page_point .pt_num {
    line-height: 1.2;
    font-size: 13px;
    font-weight: 700;
    color: #636363;
}

#page_point .pt_num span {
    display: block;
    font-size: 36px;
}

#page_point .point_product .pt_col:nth-of-type(2n) {
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    align-items: center;
    padding-bottom: 20px;
}

#page_point .pt_discount {
    margin-bottom: 7px;
    line-height: 1.2;
    font-size: 14px;
    font-weight: 700;
    color: #636363;
}

#page_point .pt_discount span {
    font-size: 16px;
}

#page_point .pt_buybtns {
    text-align: center;
}

#page_point .buy_btn {
    width: 90px;
    line-height: 28px;
    font-size: 10px;
    font-weight: 700;
}

#page_point .buy_btn span {
    font-size: 14px;
}

/* =============== 購入完了（共通） =============== */
.page_store_complete .str_fnsh_text {
    margin: 90px 0 55px;
    text-align: center;
    line-height: 1.9;
}
.page_store_complete .strfnsh_txt_b {
    margin-bottom: 10px;
    font-size: 26px;
}
.page_store_complete .strfnsh_txt_s {
    font-size: 14px;
}
.page_store_complete .buy_details {
    width: 100%;
    box-sizing: border-box;
    padding: 27px 30px 31px;
    background-color: #f6f6f6;
    margin-bottom: 55px;
}
.page_store_complete .buy_details > p {
    font-size: 17px;
    font-weight: bold;
}
.page_store_complete .buy_details > table {
    width: 100%;
    margin-top: 10px;
    font-size: 14px;
    font-weight: bold;
}
.page_store_complete .buy_details tr {
    border-bottom: 1px dotted #646464;
}
.page_store_complete .tr_nonborder {
    border-bottom: none !important;
}
.page_store_complete .buy_details th,
.page_store_complete .buy_details td {
    padding: 18px 0 20px;
}
.page_store_complete .tr_nonborder th,
.page_store_complete .buy_details td {
    padding-bottom: 0;
}
.page_store_complete .buy_details th {
    text-align: left;
}
.page_store_complete .buy_details td {
    text-align: right;
}
.page_store_complete .buy_details td span {
    font-size: 17px;
}
.page_store_complete .str_fnsh_btn {
    width: 100%;
    display: flex;
    justify-content: center;
}
.page_store_complete .str_fnsh_btn a {
    display: block;
    width: 280px;
    line-height: 60px;
    border-radius: 30px;
    background-color: #e4e4e4;
    text-align: center;
    font-size: 17px;
    color: #202020;
}

@media screen and (max-width: 834px) {
    /* --------------------- SP --------------------- */

    .page_plan #payment .free {
        border: 1px solid #B1B1B1;
        width: 100%;
        margin: 0 0 30px;
    }
    .page_plan .note {
        text-align: left;
    }

    /* =============== 共通 =============== */

    /* ===== タイトル、見出し ===== */
    .page_store .ttl_spui {
        margin-bottom: 32px !important;
    }

    .store_title {
        padding: 4px 0;
    }

    .store_title h2 {
        font-size: 13px;
    }

    /* ===== プラン、ポイント切り替えタブ ===== */
    .page_store .tab_stores {
        margin: 0 20px 80px;
    }

    .page_store .tab_stores a {
        width: 48.78%;
        border-radius: 18px;
        line-height: 30px;
        font-size: 13px;
    }

    /* =============== プラン購入 =============== */

    #payment,
    #premium {
        margin-bottom: 80px;
    }

    /* ===== 特典 ===== */
    .page_plan .priv_head {
        padding: 3px 18px 4px;
    }

    .page_plan .priv_cont {
        padding: 18px 20px;
    }

    .page_plan .priv_cont li {
        width: 100% !important;
        margin-top: 13px !important;
        padding-left: 22px;
    }

    .page_plan .priv_cont li:first-of-type {
        margin-top: 0 !important;
    }

    .page_plan .priv_cont li::before {
        top: 5px;
    }

    .page_plan .priv_cont li span {
        display: none;
    }

    /* ===== 料金表 ===== */
    .page_plan .plan_list {
        margin-bottom: 20px;
    }

    .page_plan .plan_product {
        display: inline-flex;
        width: 100%;
        height: auto;
        margin-top: 30px;
        border: 1px solid #ededed;
        border-radius: 0;
    }

    .page_plan .plan_list .plan_product:first-of-type {
        margin-top: 0;
    }

    .page_plan #payment .plan_product.st_pd_year {
        border: 1px solid #079cd1;
    }

    .page_plan #premium .plan_product.st_pd_year {
        border: 1px solid #21a5ab;
    }

    .page_plan .pl_pd_head {
        display: none;
    }

    .page_plan .pl_pd_discount {
        left: -7px;
    }

    .page_plan .pl_pd_col:first-of-type {
        width: 134px;
        height: auto;
        padding: 18px 0;
        border-right: 1px solid #ededed;
    }

    .page_plan .pl_pd_col2:first-of-type {
        width: 100%;
        height: auto;
        padding: 0 0 20px;
    }

    .page_plan #payment .st_pd_year .pl_pd_col:first-of-type {
        border-right: 1px solid #079cd1;
    }

    .page_plan #premium .st_pd_year .pl_pd_col:first-of-type {
        border-right: 1px solid #21a5ab;
    }

    .page_plan .pl_pd_col:nth-of-type(2) {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        align-content: center;
        width: calc(100% - 134px);
    }

    .page_plan .pl_pd_month {
        margin-bottom: 0;
        font-size: 15px;
        font-weight: 700;
        color: #39434e;
    }

    .page_plan .pl_pd_month span:nth-of-type(2) {
        display: none;
    }

    .page_plan .pl_pd_price {
        line-height: 2.2 !important;
        font-size: 17px;
        color: #39434e;
        margin-top: 14px;
    }

    .page_plan .pl_pd_price span {
        font-size: 27px;
    }

    .page_plan .pl_pd_price_mnth {
        font-weight: 700;
        color: #989898;
    }

    .page_plan .best_pl {
        width: 100%;
        margin-bottom: 8px;
        text-align: center;
        font-size: 13px;
        font-weight: 500;
    }

    .page_plan .best_pl::before,
    .page_plan .best_pl::after {
        position: relative;
        top: 3px;
        display: inline-block;
        content: "";
        width: 7px;
        height: 14px;
        background-repeat: no-repeat;
        background-size: contain;
    }

    .page_plan .best_pl::before {
        margin-right: 10px;
    }

    .page_plan .best_pl::after {
        margin-left: 10px;
    }

    .page_plan #payment .best_pl {
        color: #079cd1;
    }

    .page_plan #premium .best_pl {
        color: #178b90;
    }

    .page_plan #payment .best_pl::before {
        background-image: url(../img/store/line_left_payment.png);
    }

    .page_plan #payment .best_pl::after {
        background-image: url(../img/store/line_right_payment.png);
    }

    .page_plan #premium .best_pl::before {
        background-image: url(../img/store/line_left_premium.png);
    }

    .page_plan #premium .best_pl::after {
        background-image: url(../img/store/line_right_premium.png);
    }

    .page_plan .buy_btn {
        width: 148px;
        line-height: 30px;
        font-weight: 500;
    }

    /* =============== ポイント購入 =============== */

    /* ===== 料金表 ===== */
    #page_point #point_list {
        margin-bottom: 20px;
    }

    #page_point .point_product {
        display: flex;
        width: 100%;
        height: auto;
        margin-top: 20px;
        border-radius: 0;
        border: 1px solid #ededed;
    }

    #page_point .point_product:first-of-type {
        margin-top: 0;
    }

    #page_point .point_product .pt_col {
        display: flex;
        flex-wrap: wrap;
        justify-content: center !important;
        align-items: center;
        align-content: center;
        height: 80px;
    }

    #page_point .point_product .pt_col:first-of-type {
        width: 133px;
        padding-top: 0;
        border-right: 1px solid #ededed;
    }

    #page_point .point_product .pt_col:nth-of-type(2n) {
        width: calc(100% - 133px);
    }

    #page_point .pt_num {
        line-height: 1.1;
        font-size: 11px;
        color: #39434e;
    }

    #page_point .pt_num span {
        font-size: 27px;
    }

    #page_point .point_product .pt_col:nth-of-type(2n) {
        padding-bottom: 0;
    }

    #page_point .pt_discount {
        margin-bottom: 4px;
        font-size: 13px;
        color: #6e6e6e;
    }

    #page_point .pt_discount br {
        display: none;
    }

    #page_point .pt_discount span {
        font-size: 17px;
    }

    #page_point .buy_btn {
        width: 148px;
        line-height: 30px;
        font-size: 11px;
    }

    /* =============== 購入完了（共通） =============== */
    .page_store_complete .str_fnsh_text {
        margin: 0 0 30px;
    }
    .page_store_complete .strfnsh_txt_b {
        font-size: 20px;
    }
    .page_store_complete .buy_details {
        margin-bottom: 45px;
    }
    .page_store_complete .buy_details > p {
        font-size: 16px;
    }
    .page_store_complete .buy_details th,
    .page_store_complete .buy_details td {
        display: block;
    }
    .page_store_complete .buy_details th {
        padding: 15px 0 0;
    }
    .page_store_complete .buy_details td {
        text-align: left;
        padding: 15px 0 18px;
    }
    .page_store_complete .tr_nonborder td {
        padding: 15px 0 5px;
    }
    .page_store_complete .buy_details td span {
        font-size: 16px;
    }
    .page_store_complete .str_fnsh_btn a {
        width: 260px;
        line-height: 55px;
        font-size: 15px;
    }
}
