@charset "UTF-8";
/* unique
--------------------------------------------------------- */
.template_cp {
    /* list
  --------------------------------------------------------- */
    /* block
  --------------------------------------------------------- */
    /* text
  --------------------------------------------------------- */
}
.template_cp .cp_list_step_column:not(:last-child) {
    margin-bottom: 16px;
}
.template_cp .cp_list_step_column > li .cp_step_card {
    display: block;
    padding: 32px 8px 24px;
}
.template_cp .cp_list_step_column > li .cp_step_card .cp_step_text {
    min-height: 76px;
}
.template_cp .cp_list_step_column.step4 {
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px 24px;
}
.template_cp .cp_list_step_column.step4 > li {
    width: 352px;
}
.template_cp .block-important {
    padding: 16px;
}
.template_cp .list-member-merit {
    display: flex;
    justify-content: center;
    margin: 24px 0;
}
.template_cp .list-member-merit p {
    font-size: 16px;
}
.template_cp .list-member-merit .member-merit-image {
    display: flex;
    align-items: center;
    justify-content: center;
    height: auto;
    margin: 0 auto 24px;
}
.template_cp .list-member-merit .member-merit-image.pc_hide {
    margin-bottom: 0;
}
.template_cp .list-member-merit .member-merit-image-simply,
.template_cp .list-member-merit .member-merit-image-coin {
    width: 100%;
}
.template_cp .list-member-merit span {
    color: #c40404;
}
.template_cp .list-member-merit li {
    display: flex;
    align-items: center;
    flex-direction: column;
    justify-content: flex-end;
    width: 406px;
    border-right: 1px dotted #999;
    text-align: center;
}
.template_cp .list-member-merit li:first-of-type {
    padding-right: 40px;
}
.template_cp .list-member-merit li:last-child {
    padding-left: 40px;
    border-right: none;
}
.template_cp .list-note-num-roman {
    counter-reset: note_num_roman;
}
.template_cp .list-note-num-roman > li {
    counter-increment: note_num_roman;
    position: relative;
    margin-bottom: 4px;
    padding-left: 32px;
    font-size: 16px;
}
.template_cp .list-note-num-roman > li::before {
    content: "※" counter(note_num_roman, upper-roman);
    position: absolute;
    top: 0;
    left: 0;
}
.template_cp .list-onemore-banner {
    display: flex;
    justify-content: center;
    gap: 16px;
    margin: 24px 0 32px;
}
.template_cp .list-onemore-banner > li {
    width: 238px;
}
.template_cp .list-onemore-banner > li a {
    display: block;
}
.template_cp .list-onemore-banner > li a:hover figure img {
    opacity: .7;
}
.template_cp .list-onemore-banner > li a figure {
    text-align: center;
}
.template_cp .list-onemore-banner > li a figure img {
    width: 100%;
    margin-bottom: 8px;
    transition: opacity .3s ease-out;
}
.template_cp .list-step-onemore {
    display: flex;
    justify-content: center;
    gap: 40px;
    margin-bottom: 24px;
}
.template_cp .list-step-onemore li {
    position: relative;
    max-width: 304px;
}
.template_cp .list-step-onemore li:first-child::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: -31px;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    margin-top: -9px;
    border-width: 19px 0 19px 21px;
    border-style: solid;
    border-color: transparent transparent transparent #d5d5d5;
}
.template_cp .list-step-onemore li p {
    margin-bottom: 16px;
    font-size: 16px;
    font-weight: bold;
    text-align: center;
}
.template_cp .list-step-onemore li img {
    margin-bottom: 8px;
}
.template_cp .list-step-onemore li span {
    display: block;
    font-size: 12px;
    line-height: 1.6;
}
.template_cp .block-code-issuance .code-issuance-schedule {
    margin-bottom: 24px;
}
.template_cp .block-code-issuance .code-issuance-schedule:last-child {
    margin-bottom: 0;
}
.template_cp .block-code-issuance .code-issuance-schedule th {
    width: 276px;
}
.template_cp .block-code-issuance .code-issuance-schedule td:first-of-type {
    width: 705px;
    text-align: left;
}
.template_cp .block-code-issuance .text-about-campaign-subtitle {
    width: 982px;
    margin: 0 auto 8px;
    text-align: left;
}
.template_cp .block-about-campaign {
    flex-direction: column;
}
.template_cp .block-about-campaign .about-campaign-lead {
    font-size: 18px;
    text-align: center;
}
.template_cp .block-about-campaign .about-campaign-lead-sub {
    position: relative;
    width: fit-content;
    margin: 0 auto 4px;
    color: #ee6001;
    font-size: 16px;
    font-weight: bold;
    line-height: 1;
}
.template_cp .block-about-campaign .about-campaign-lead-sub::before {
    content: "＼";
    margin-right: 8px;
    font-size: 20px;
}
.template_cp .block-about-campaign .about-campaign-lead-sub::after {
    content: "／";
    margin-left: 8px;
    font-size: 20px;
}
.template_cp .block-about-campaign .about-campaign-image {
    display: flex;
    flex-wrap: wrap;
    max-width: unset;
    margin-bottom: 16px;
}
.template_cp .block-about-campaign .about-campaign-image > img:nth-child(-n+2) {
    width: 50%;
}
.template_cp .block-entry-website {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px 48px;
    padding: 16px 32px;
    background-image: url("../images/bg_entry_website.jpg");
    background-repeat: no-repeat;
    background-position: left center;
    background-size: cover;
}
.template_cp .block-entry-website .entry-website-cp-end {
    margin-bottom: 8px;
    color: #c40404;
    text-align: center;
}
.template_cp .block-entry-website .entry-website-lead {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}
.template_cp .block-entry-website .entry-website-lead span {
    color: #ff0060;
}
.template_cp .block-entry-website .entry-website-lead sup {
    position: relative;
    top: -8px;
    left: -16px;
    font-size: 12px;
}
.template_cp .block-entry-website .entry-website-links {
    display: flex;
    gap: 40px;
}
.template_cp .block-entry-website .entry-website-links > li {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 8px 16px;
}
.template_cp .block-entry-website .entry-website-links-qr {
    grid-column: 1/2;
    grid-row: 1/3;
}
.template_cp .block-entry-website .entry-website-links-text {
    padding-top: 8px;
    color: #666;
    font-size: 14px;
    font-weight: bold;
    text-align: left;
}
.template_cp .block-entry-website .entry-website-links-button {
    padding-bottom: 8px;
}
.template_cp .block-entry-website .entry-website-links-button:hover {
    opacity: .8;
}
.template_cp .block-entry-website .entry-website-links-button img {
    width: auto;
    height: 56px;
}
.template_cp .block-entry-website .entry-website-links-button:after {
    content: none;
}
.template_cp .block-onemore {
    position: relative;
    margin: 48px 0 24px;
    padding: 32px 40px;
    border: 2px solid #bbb;
    border-radius: 4px;
}
.template_cp .block-onemore > hr {
    margin-bottom: 24px;
    border-color: #bbb;
}
.template_cp .block-onemore .onemore-title {
    position: absolute;
    top: -16px;
    left: 50%;
    transform: translateX(-50%);
    padding: 0 12px;
    background: #fff;
    color: #000;
    white-space: nowrap;
}
.template_cp .block-about-tamaru-mall {
    width: 100%;
    max-width: 712px;
    margin: 0 auto 24px;
    padding: 16px 40px;
    background: #f9f7f1;
}
.template_cp .block-about-tamaru-mall .about-tamaru-mall-title {
    font-weight: bold;
    text-align: center;
}
.template_cp .block-about-tamaru-mall .about-tamaru-mall-text {
    text-align: center;
}
.template_cp .block-secondary.button-secondary-cp {
    max-width: 304px;
    color: #1c2b50;
    font-size: 16px;
}
.template_cp .block-secondary.button-secondary-cp:hover {
    text-decoration: none;
}
.template_cp .cp_block_entry .entry_notice {
    margin-top: 16px;
}
.template_cp .cp_block_entry.website {
    padding: 0;
    background: transparent;
}
.template_cp .text-notice-app-only {
    margin-bottom: 48px;
    color: #c80000;
    font-size: 20px;
    text-align: center;
}
.template_cp .text-about-campaign-subtitle {
    margin-bottom: 8px;
    color: #ee6001;
    font-weight: bold;
    line-height: 1.5;
}
.template_cp .text-onemore-bonus {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}
.template_cp .text-onemore-bonus.box {
    margin-top: 24px;
    padding: 16px;
    background-color: #fffed1;
}
.template_cp .text-onemore-bonus .onemore-bonus-number {
    margin-left: 4px;
    font-size: 24px;
}