/*=======================================
	パンクズ
=======================================*/
.breadcrumbs {
  padding: 12px 0 0;
  color: #646464;
}
.breadcrumbs .breadcrumbs-list {
  width: 1241px;
  margin: 0 auto 10px auto;
  list-style-type: none;
  display: flex;
  align-items: center
}
.breadcrumbs .breadcrumbs-list li {
  color: #b4b4b4;
  font-size: 14px;
  position: relative
}
.breadcrumbs .breadcrumbs-list li.archive {
  padding-top: 0;
  padding-bottom: 0
}
.breadcrumbs .breadcrumbs-list li + li {
  padding-left: 12px
}
.breadcrumbs .breadcrumbs-list li + li:before {
  display: block;
  position: absolute;
  top: 50%;
  left: 0;
  width: 7px;
  height: 7px;
  margin-top: -4px;
  border-top: solid 1px #b4b4b4;
  border-right: solid 1px #b4b4b4;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  content: ""
}
.breadcrumbs .breadcrumbs-list li a {
  color: #b4b4b4
}
.breadcrumbs .breadcrumbs-list li a.home {
  color: #b4b4b4
}
@media (max-width:1024px) {
  .breadcrumbs {
    padding: 12px 20px 0
  }
  .breadcrumbs .breadcrumbs-list {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch
  }
  .breadcrumbs .breadcrumbs-list li, .breadcrumbs .breadcrumbs-list li a {
    white-space: nowrap;
    font-size: 12px
  }
}

/*=======================================
	コンテンツ
=======================================*/
/*
.rewards_program {
    padding-top: 18.11594vw;;
}
@media (min-width: 600px) {
    .rewards_program {
        padding-top: 12.5vw;
    }
}

@media (min-width: 900px) {
    .rewards_program {
        padding-top: 8.33333vw;
    }
}
@media (min-width: 1200px) {
    .rewards_program {
        padding-top: 75px;
    }
}
*/
.rewards_program * {
    box-sizing: border-box;
}
.rewards_program .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0,0,0,0);
  white-space: nowrap;
  border: 0;
}
.rewards_program section {
    padding: 80px 20px;
}
.rewards_program .inner {
    max-width: 980px;
    margin: auto;
}
.rewards_program .bgclr {
    background-color: #F8F8F4;
}

.rewards_program .sec_ttl {
    font-size: 2.4rem;
    font-weight: bold;
    max-width: max-content;
    margin: 0 auto 3.5rem;
}
.rewards_program .sec_ttl span::before {
    content: "";
    width: 0.8em;
    height: 0.8em;
    background-image: url(../img/kirari.png);
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: center;
    display: inline-block;
    padding-right: 0.5em;
}
.rewards_program .sec_ttl span::after {
    content: "";
    width: 0.8em;
    height: 0.8em;
    background-image: url(../img/kirari.png);
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: center;
    display: inline-block;
    padding-left: 0.5em;
}
.rewards_program .sp_br {
    display: none;
}
@media (max-width: 767px) {
    .rewards_program section {
        padding: 15vw 20px;
    }
    .rewards_program .sec_ttl {
        margin-bottom: 2rem;
    }
    .rewards_program .sp_br {
        display: block!important;
    }
    .rewards_program .sp_none {
        display: none!important;
    }
}


/* KV */
.rewards_program_kv img {
    width: 100%;
    display: block;
}

/* リード文 */
.rewards_program .read {
    padding: 100px 20px 40px;
    text-align: center;
    line-height: 2;
}
.rewards_program .read .read_point {
    font-size: 1.8rem;
    font-weight: bold;
    background-color: #F8F8F4;
    border-radius: 4px;
    padding: 0.3em 1em;
    margin: 1em auto;
    max-width: max-content;
    position: relative;
}
.rewards_program .read .read_point::before {
    content: "";
    width: 1em;
    height: 1em;
    background-image: url(../img/kirari.png);
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    top: -0.3em;
    right: -0.3em;
}
.rewards_program .read .read_point::after {
    content: "";
    width: 1em;
    height: 1em;
    background-image: url(../img/kirari.png);
    background-size: auto 100%;
    background-repeat: no-repeat;
    background-position: center;
    position: absolute;
    bottom: -0.3em;
    left: -0.3em;
}
.rewards_program .read .read_point span {
    color: #F44242;
}
.rewards_program .read .read_point strong {
    font-size: 2.4rem;
    color: #F44242;
}
@media (max-width: 767px) {
    .rewards_program .read {
        padding: 15vw 20px 2vw;
    }
    .rewards_program .read .read_point {
        padding: 1em 0.5em;
    }
    .rewards_program .read .read_point p {
        line-height: 1.3;
    }
}


/* メリット */
.rewards_program .merit_list ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 25px 12px;
}
.rewards_program .merit_list ul:not(:last-child) {
    margin-bottom: 25px;
}
.rewards_program .merit_list li {
    width: calc(33.333% - 8px);
    background-color: #F9F9F9;
    border-radius: 4px;
    box-sizing: border-box;
    padding: 3.5rem 2rem 3rem;
}
.rewards_program .merit_list .ttl_wrap {
    min-height: max-content;
}
.rewards_program .merit_list h3 {
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    letter-spacing: 0;
    line-height: 1.6;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 2.5rem auto 2rem;
}
.rewards_program .merit_list img {
    max-width: 100px;
    display: block;
    margin: auto;
}
.rewards_program .merit_list .sml_txt {
    font-size: 1.4rem;
    line-height: 1.6;
    margin-top: .5rem;
}
@media (max-width: 767px) {
    .rewards_program .merit_list ul {
        gap: inherit;
    }
    .rewards_program .merit_list ul:not(:last-child) {
        margin-bottom: max(15px, 3.75vw);
    }
    .rewards_program .merit_list li {
        width: 100%;
        padding: 2rem;
        margin-bottom: max(15px, 3.75vw);
    }
    .rewards_program .merit_list li:last-child {
        margin-bottom: 0;
    }
    .rewards_program .merit_list .ttl_wrap {
        display: flex;
        align-items: center;
        margin-bottom: 1rem;
    }
    .rewards_program .merit_list img {
        min-width: 47px;
        width: 10vw;
        margin: 0 1.2rem 0 0;
        
    }
    .rewards_program .merit_list h3 {
        text-align: left;
        margin: 0;
    }
}


/* ポイントを貯める方法 使う方法 */
@media (min-width: 768px) {
    .rewards_program .point_howto .howtoSlider {
        display: flex;
        justify-content: space-between;
    }
    .rewards_program .point_howto .howtoSlider > div {
        width: calc(33.333% - 17px);
    }
}
.rewards_program .point_save {
    padding-bottom: 60px;
    margin-bottom: 60px;
    border-bottom: 1px solid #D9D9D9;
}
.rewards_program .point_save_box {
    background-color: #fff;
    padding: 3rem 2rem;
    border-radius: 4px;
    position: relative;
}
.rewards_program .point_save_box::before {
    content: "";
    width: 40px;
    height: 5px;
    background-color: #F44242;
    position: absolute;
    top: 0;
    left: calc(50% - 20px);
    border-radius: 0 0 3px 3px;
}
.rewards_program .point_save_box h3 {
    font-size: 1.8rem;
    font-weight: bold;
    text-align: center;
    margin-bottom: 1rem;
}

.rewards_program .point_use_box .point_use_step {
    background-color: #f34142;
    font-size: 1.4rem;
    text-align: center;
    color: #fff;
    line-height: 1.6;
    border-radius: 3px 3px 0 0;
}
.rewards_program .point_use_image {
    position: relative;
}
.rewards_program .point_use_image::after {
    content: "";
    width: 25px;
    height: 100%;
    background-image: url(../img/icon_arw_pointuse.png);
    background-position: center;
    background-repeat: no-repeat;
    background-size: 15px auto;
    position: absolute;
    top: 0;
    right: -25px;
}
.rewards_program .point_use_box:last-child .point_use_image::after {
    content: none;
}
.rewards_program .point_use_image img {
    width: 100%;
    display: block;
    border: 1px solid #ccc;
    margin-bottom: 2rem;
}
@media (max-width: 767px) {
    .rewards_program .point_howto {
        padding-left: 0;
        padding-right: 0;
    }
    .rewards_program .point_use_image::after {
        content: none;
    }
    .rewards_program .howtoSlider.slick-initialized .slick-slide {
        margin: 0 max(10px, 2vw);
    }
    .rewards_program .howtoSlider .slick-dots {
        position: relative;
        bottom: 0;
    }
    .rewards_program .howtoSlider .slick-dots li button:before {
        font-size: 10px;
    }
}



/* 会員登録の流れ */
.rewards_program .flow .sec_ttl + p {
    text-align: center;
}
.rewards_program .flow_pattern {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    margin: 4rem auto;
}
.rewards_program .flow_pattern_box {
    width: calc(50% - 20px);
    border-radius: 10px;
    border: 1px solid #CCC;
    overflow: hidden;
    display: flex;
    flex-wrap: wrap;
}
.rewards_program .flow_pattern_box h3 {
    font-size: 2rem;
    font-weight: bold;
    padding: 1rem;
    background-color: #F9F9F9;
    display: flex;
    justify-content: center;
    align-items: center;
    max-height: max-content;
    width: 100%;
}
.rewards_program .flow_pattern_box h3::before {
    content: "";
    width: 1.3em;
    height: 1.3em;
    display: inline-block;
    margin-right: .3em;
    background-size: 90%;
    background-repeat: no-repeat;
    background-position: center;
}
.rewards_program .pattern_web h3::before {
    background-image: url(../img/icon_pc.png);
}
.rewards_program .pattern_tel h3::before {
    background-image: url(../img/icon_tel.png);
}
.rewards_program .flow_pattern_box h3 + div {
    width: 100%;
    padding: 2rem 2.5rem;
}
.rewards_program .flow_pattern_box p {
    text-align: center;
    line-height: 1.6;
}
.rewards_program .flow_pattern_box .sml_txt {
    font-size: 1.4rem;
}
.rewards_program .flow_pattern_box .link {
    margin-top: 1rem;
}
.rewards_program .flow_pattern_box a {
    font-weight: bold;
    color: #f34142;
    align-items: center;
    letter-spacing: .05em;
    text-decoration: none;
    display: flex;
    justify-content: center;
    max-width: max-content;
    margin: auto;
    position: relative;
    padding: 0 10px;
    border: 1px solid #fff;
    border-radius: 4px;
    transition: .3s;
}
.rewards_program .flow_pattern_box a::after {
    content: "";
    width: calc(100% - 1.5em - 20px);
    height: 1px;
    background-color: #f34142;
    position: absolute;
    bottom: 2px;
    left: 10px;
    transition: .1s;
}
.rewards_program .icon_link {
    width: 1em;
    height: 1em;
    background-color: #f34142;
    border-radius: 50%;
    margin-left: .5em;
    position: relative;
    transition: .3s;
}
.rewards_program .icon_link::after {
    content: "";
    width: 0.26em;
    height: 0.26em;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
    position: absolute;
    top: calc(50% - 0.13em);
    left: calc(50% - 0.22em);
    transform: rotate(45deg);
    transition: .3s;
}
.rewards_program .btn a {
    font-size: 1.8rem;
    font-weight: bold;
    text-decoration: none;
    letter-spacing: .05em;
    color: #fff;
    max-width: max-content;
    margin: auto;
    padding: 2rem 4rem;
    background-color: #f34142;
    border: 2px solid #f34142;
    display: flex;
    justify-content: center;
    align-items: center;
    border-radius: 4px;
    transition: .3s;
}
.rewards_program .btn .icon_link {
    background-color: #fff;
}
.rewards_program .btn .icon_link::after {
    border-color: #f34142;
}
@media (min-width: 768px) {
    .rewards_program .flow_pattern_box a:hover {
        border-color: #f34142;
    }
    .rewards_program .flow_pattern_box a:hover::after {
        opacity: 0;
    }
    .rewards_program .btn a:hover {
        color: #f34142;
        background-color: #fff;
    }
    .rewards_program .btn a:hover .icon_link {
        background-color: #f34142;
    }
    .rewards_program .btn a:hover .icon_link::after {
        border-color: #fff;
    }
}
@media (max-width: 767px) {
    .rewards_program .flow_pattern_box {
        width: 100%;
    }
    .rewards_program .flow_pattern_box.pattern_web {
        margin-bottom: max(20px, 5vw);
    }
}


/* よくある質問 */
.rewards_program .accordion {
    background-color: #fff;
    border-radius: 4px;
    box-shadow: 0 0 20px rgb(0, 0, 0, .05);
    margin-bottom: 2rem;
}
.rewards_program .accordion:last-child {
    margin-bottom: 0;
}
.rewards_program .accordion dt {
    cursor: pointer;
    position: relative;
    padding: 2rem 5rem  2rem 5.5rem;
    transition: .3s;
    line-height: 1.6;
}
.rewards_program .accordion dt::before {
    content: "Q";
    font-size: 2rem;
    font-weight: bold;
    color: #f34142;
    position: absolute;
    top: 50%;
    left: 2rem;
    transform: translateY(-50%);
}

.rewards_program .icon_acc {
    width: 1.3em;
    height: 1.3em;
    background-color: #f34142;
    border-radius: 50%;
    position: absolute;
    top: 50%;
    right: 2rem;
    transform: translateY(-50%);
}
.rewards_program .icon_acc::before {
    content: "";
    width: .7em;
    height: 2px;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
.rewards_program .icon_acc::after {
    content: "";
    width: .7em;
    height: 2px;
    background-color: #fff;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(-90deg);
    transition: .3s;
}
.rewards_program .accordion .active .icon_acc::after {
    transform: translate(-50%, -50%) rotate(0deg);
}
.rewards_program .accordion dd {
    display: none;
    border-top: 1px solid #E5E5E5;
    padding: 2rem 2rem 2rem 5.5rem;
    position: relative;
    line-height: 1.6;
}
.rewards_program .accordion dd::before {
    content: "A";
    font-size: 2rem;
    font-weight: bold;
    color: #f34142;
    position: absolute;
    top: 1.5rem;
    left: 2rem;
}
@media (min-width: 768px) {
    .rewards_program .fqa .sec_ttl span::before,
    .rewards_program .fqa .sec_ttl span::after {
        content: none;
    }
    .rewards_program .fqa .sec_ttl::before {
        content: "";
        width: 0.8em;
        height: 0.8em;
        background-image: url(../img/kirari.png);
        background-size: auto 100%;
        background-repeat: no-repeat;
        background-position: center;
        display: inline-block;
        padding-right: 0.5em;
    }
    .rewards_program .fqa .sec_ttl::after {
        content: "";
        width: 0.8em;
        height: 0.8em;
        background-image: url(../img/kirari.png);
        background-size: auto 100%;
        background-repeat: no-repeat;
        background-position: center;
        display: inline-block;
        padding-left: 0.5em;
    }
    .rewards_program .accordion dt:hover {
        color: #f34142;
    }
}
@media (max-width: 767px) {
    .rewards_program .fqa .sec_ttl span {
        display: block;
        text-align: center;
    }
}


/* おすすめ特集 */
.rewards_program .feature {
    padding-bottom: 100px;
}
.rewards_program .featureBnrSlider a {
    transition: .3s;
}
.rewards_program .featureBnrSlider img {
    width: 100%;
}
.rewards_program .featureBnrSlider.slick-dotted.slick-slider {
    width: calc(100% + 24px);
    margin-left: -12px;
}
.rewards_program .featureBnrSlider .slick-slide {
    margin: 0 12px;
}
.rewards_program .featureBnrSlider .slick-prev {
    width: 4rem;
    height: 4rem;
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    z-index: 10;
    left: calc(-2rem + 12px);
    transition: .3s;
    font-size: 0;
}
.rewards_program .featureBnrSlider .slick-prev::before {
    content: "";
    width: 0.4em;
    height: 0.4em;
    border-top: 2px solid #f34142;
    border-left: 2px solid #f34142;
    position: absolute;
    top: calc(50% - .2em);
    left: calc(50% - .15em);
    transform: rotate(-45deg);
    transition: .3s;
}
.rewards_program .featureBnrSlider .slick-next {
    width: 4rem;
    height: 4rem;
    background-color: #fff;
    box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
    border-radius: 50%;
    z-index: 10;
    right: calc(-2rem + 12px);
    transition: .3s;
    font-size: 0;
}
.rewards_program .featureBnrSlider .slick-next::before {
    content: "";
    width: 0.4em;
    height: 0.4em;
    border-top: 2px solid #f34142;
    border-right: 2px solid #f34142;
    position: absolute;
    top: calc(50% - .2em);
    right: calc(50% - .15em);
    transform: rotate(45deg);
    transition: .3s;
}
.rewards_program .featureBnrSlider .slick-dots {
    line-height: 1;
    bottom: -40px;
}
.rewards_program .slick-dots li {
    margin: 0 2px;
}
.rewards_program .slick-dots li button:before {
    font-size: 10px;
}
@media (min-width: 768px) {
    .rewards_program .featureBnrSlider .slick-prev:hover,
    .rewards_program .featureBnrSlider .slick-next:hover {
        background-color: #f34142;
    }
    .rewards_program .featureBnrSlider .slick-prev:hover::before,
    .rewards_program .featureBnrSlider .slick-next:hover::before {
        border-color: #fff;
    }
    .rewards_program .featureBnrSlider a:hover {
        opacity: .6;
    }
}
@media (max-width: 767px) {
    .rewards_program .feature {
        padding-left: 0;
        padding-right: 0;
        padding-bottom: 20vw;
    }
    .rewards_program .featureBnrSlider .slick-slide {
        margin: 0 max(10px, 2vw);
    }
    .rewards_program .featureBnrSlider.slick-dotted.slick-slider {
        width: 100%;
        margin-left: 0;
    }
}




@media (max-width: 767px) {
    .rewards_program * {
        font-size: 4vw;
    }
    .rewards_program .sec_ttl,
    .rewards_program .sec_ttl span {
        font-size: 5vw;
    }
    .rewards_program .read .read_point {
        font-size: 4.5vw;
    }
    .rewards_program .read .read_point strong {
        font-size: 6vw;
    }
    .rewards_program .merit_list h3 {
        font-size: 4vw;
    }
    .rewards_program .merit_list .sml_txt {
        font-size: 3.5vw;
    }
    .rewards_program .point_save_box h3 {
        font-size: 4vw;
    }
    .rewards_program .point_use_box .point_use_step {
        font-size: 3.5vw;
    }
    .rewards_program .flow_pattern_box h3 {
        font-size: 5vw;
    }
    .rewards_program .flow_pattern_box .sml_txt {
        font-size: 3.5vw;
    }
    .rewards_program .btn a {
        font-size: 4.5vw;
        line-height: 1;
    }
    .rewards_program .accordion dt::before {
        font-size: 5vw;
    }
    .rewards_program .accordion dd::before {
        font-size: 5vw;
    }
}