@charset "utf-8";

/*=== メインレイアウト ===*/
.main-section {
  padding: 70px 20px;
}
.main-section > *:first-child {
  margin-top: 0;
}
.main-cont {
  margin-top: 0;
}
.main-ttl {
  font-size: 36px;
  text-align: center;
}
.main-ttl .type-small {
  display: block;
  font-size: 24px;
}
.main-subttl {
  margin-top: 60px;
  font-weight: bold;
  font-size: 24px;
  text-align: center;
  line-height: 1.4;
}
.main-txt {
  margin-top: 20px;
  font-size: 20px;
  line-height: 2;
}
.main-note {
  margin-top: 30px;
  padding-left: 1em;
  color: #666;
  text-indent: -1em;
}
.type-accent {
  color: #dc3514;
  font-weight: bold;
}
.type-highlight {
  color: #dc3514;
}
.type-label {
  display: inline-block;
  margin: 0 5px;
  padding: 6px;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  line-height: 1;
  background-color: #dc3514;
}
.type-block {
  display: inline-block;
}


/*=== 遷移パターン ===*/
.transition {
  text-align: center;
}
.transition.pattern-wide {
  margin-top: 50px;
}
.transition-item {
  max-width: 500px;
  margin: 30px auto 0;
}
a.transition-link {
  color: #666;
  font-size: 20px;
}
a.transition-link:visited {
  color: #666;
}
a.transition-link:hover {
  text-decoration: none;
}
a.transition-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100%;
  min-height: 58px;
  padding: 10px 45px;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  line-height: 1.2;
  text-decoration: none;
  background-color: #ac2330;
  border-radius: 50px;
}
a.transition-btn:visited {
  color: #fff;
}
a.transition-btn:hover {
  text-decoration: none;
  opacity: 0.7;
}
a.transition-btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 15px;
  height: 20px;
  background-color: #fff;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}
/* キャッシュバック500円以上のショップ */
.pattern-over a.transition-btn {
  border: 2px solid #1f8278;
  color: #1f8278;
  background-color: #fefdec;
}
.pattern-over a.transition-btn:visited {
  color: #1f8278;
}
.pattern-over a.transition-btn::after {
  background-color: #1f8278;
}
/* その他のショップ */
.pattern-other a.transition-btn {
  border: 2px solid #dc3514;
  color: #dc3514;
  background-color: #fdf8e6;
}
.pattern-other a.transition-btn:visited {
  color: #dc3514;
}
.pattern-other a.transition-btn::after {
  background-color: #dc3514;
}
/* 詳しくはこちら */
.pattern-detail a.transition-btn {
  background-color: #e02500;
}
/* ショップを探す */
.pattern-shop a.transition-btn {
  min-height: 96px;
  font-size: 32px;
  background-color: #dc3514;
}
/* 参加する */
.pattern-event a.transition-btn {
  min-height: 96px;
  font-size: 32px;
  background-color: #043b88;
}


/*=== メインビジュアル ===*/
.mainvisual {
  margin: 20px auto;
}
.mainvisual-main {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  text-align: center;
}


/*=== 概要 ===*/
.intro {
  max-width: 1200px;
  margin: 40px auto 0;
  padding: 0 20px;
}
.intro-inner {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 30px 0;
  background: url(images/intro_bg_001.png) no-repeat top center / 100% auto;
}
.intro-thumb {
  flex-shrink: 0;
  margin-right: 40px;
}
.intro .main-txt {
  margin-top: 0;
}


/*=== 実施期間 ===*/
.period {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px;
  font-weight: bold;
  font-size: 24px;
  background-color: #f2b95a;
}
.period-head {
  flex-shrink: 0;
  width: 200px;
  margin-right: 20px;
  padding: 4px;
  text-align: center;
  background-color: #fff;
  border-radius: 50px;
}


/*=== プレゼント ===*/
.present {
  text-align: center;
  background-color: #fdf8e6;
}
.present .main-section {
  background: url(images/present_bg_001.png) no-repeat top center / 100% auto;
}
@media print, screen and (max-width: 890px) {
  .present .main-section {
    background-image: none;
  }
}
.present-txt {
  margin-top: 40px;
}
.present-txt .type-line {
  display: inline;
  padding-bottom: 12px;
  border-bottom: 2px dotted #dc3514;
  font-size: 20px;
  line-height: 3.2;
}
.present-bnr {
  margin: 10px auto 0;
}
.present-bnr + .present-txt {
  margin-top: 0;
}


/*=== 賞品 ===*/
.award {
  margin-top: 50px;
}
.award-ttl {
  max-width: 360px;
  margin: 0 auto;
  position: relative;
}
.award-ttl::before,
.award-ttl::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -10px;
  width: 98px;
  height: 54px;
  background: url(images/award_bg_001.png) no-repeat 0 0 / 100% auto;
}
.award-ttl::before {
  left: -40px;
}
.award-ttl::after {
  right: -40px;
  transform: scale(-1, 1);
}
.award-ttl .type-txt {
  display: block;
  position: relative;
  padding: 8px 10px 12px;
  border: 2px solid #fff;
  color: #fff;
  font-weight: bold;
  font-size: 36px;
  text-align: center;
  line-height: 1;
  background-color: #dc3514;
  border-radius: 20px;
  z-index: 1;
}
.award-inner {
  margin-top: -25px;
  padding: 110px 30px 40px;
  border: 4px solid #dc3514;
  background-color: #fff;
  border-radius: 10px;
}
.award-list {
  display: flex;
  justify-content: space-between;
}
.award-item {
  position: relative;
  width: calc((100% - (20px * 2)) / 3);
  padding: 40px 0 20px;
  color: rgba(255, 255, 255, 0.95);
  font-weight: bold;
  line-height: 1.1;
  text-align: center;
  border-radius: 10px;
}
.award-item:nth-child(1) {
  background-color: #dc3514;
}
.award-item:nth-child(2) {
  background-color: #dc6914;
}
.award-item:nth-child(3) {
  background-color: #dc1464;
}
.award-name {
  position: absolute;
  top: -40px;
  left: 50%;
  width: 100%;
  transform: translateX(-50%);
}
.award-main {
  font-size: 36px;
}
.award-main .type-em {
  font-size: 56px;
}
.award-txt {
  margin-top: 5px;
  font-size: 26px;
}
.award-limit {
  margin: 20px 30px 0;
  padding: 5px 10px;
  font-weight: normal;
  font-size: 26px;
  border-radius: 10px;
}
.award-item:nth-child(1) .award-limit {
  color: #dc3514;
  background-color: #f8dccc;
}
.award-item:nth-child(2) .award-limit {
  color: #dc6914;
  background-color: #f8e4cc;
}
.award-item:nth-child(3) .award-limit {
  color: #dc1464;
  background-color: #f8ccde;
}
@media print, screen and (max-width: 915px) {
  .award-main {
    font-size: 26px;
  }
  .award-main .type-em {
    font-size: 42px;
  }
  .award-txt {
    font-size: 20px;
  }
  .award-limit {
    font-size: 20px;
  }
}


/*=== 登録 ===*/
.register {
  margin-top: 60px;
  padding: 30px 30px 40px;
  text-align: center;
  background-color: #fff;
  border-radius: 10px;
}
.register > *:first-child {
  margin-top: 0;
}


/*=== ご参加の流れ ===*/
.flow {
  background-color: #fdf8e6;
}
.flow-list {
  position: relative;
  margin-top: 30px;
}
.flow-list::before {
  content: "";
  display: block;
  position: absolute;
  top: -84px;
  left: calc(50% - 280px);
  width: 170px;
  height: 84px;
  background: url(images/flow_bg_001.png) no-repeat 0 0 / 100% auto;
  transform: translateX(-50%);
}
.flow-list::after {
  content: "";
  display: block;
  position: absolute;
  top: -99px;
  left: calc(50% + 230px);
  width: 120px;
  height: 142px;
  background: url(images/flow_bg_002.png) no-repeat 0 0 / 100% auto;
  transform: translateX(-50%);
}
.flow-item {
  position: relative;
  padding: 30px 30px 40px;
  border: 4px solid #dc3514;
  text-align: center;
  background-color: #fff;
  border-radius: 10px;
}
.flow-item:not(:last-child) {
  margin-bottom: 60px;
}
.flow-item:not(:last-child)::after {
  content: "";
  display: block;
  position: absolute;
  bottom: -45px;
  left: 50%;
  width: 60px;
  height: 20px;
  background-color: #dc3514;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  transform: translateX(-50%);
}
.flow .main-ttl .type-small {
  margin: 10px 0 0;
}


/*=== ショップ ===*/
.shop {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
}
.shop-item {
  width: calc((100% - (15px * 5)) / 6);
  border: 1px solid #666;
  border-radius: 10px;
  overflow: hidden;
}
a.shop-link {
  display: block;
  padding: 30px 5px;
  height: 100%;
  color: #dc3514;
  font-weight: bold;
  text-align: center;
  text-decoration: none;
  line-height: 1.4;
}
a.shop-link:visited {
  color: #dc3514;
}
a.shop-link:hover {
  text-decoration: none;
  opacity: 0.7;
}
.shop-txt {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 5px;
}
.shop-label {
  margin-top: 20px;
  padding: 4px 0;
  color: #fff;
  background-color: #dc3514;
  border-radius: 10px;
}


/*=== アコーディオン ===*/
@media print, screen and (min-width: 789px) {
  .accordion-cont {
    height: auto !important;
  }
  .accordion-more {
    display: none;
  }
}


/*=== 確認方法 ===*/
.method {
  margin-top: 30px;
}
.method-list {
  display: flex;
  justify-content: space-between;
}
.method-list.pattern-vertical {
  display: block;
}
.method-item {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: space-between;
  position: relative;
  width: calc((100% - 40px) / 2);
  padding: 30px 30px 20px;
  border: 2px solid #d7d7d7;
  border-radius: 10px;
}
.method-item:not(:last-child) {
  margin-right: 60px;
}
.method-item:not(:last-child)::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: -45px;
  width: 20px;
  height: 60px;
  background-color: #000;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}
.pattern-vertical .method-item {
  width: 100%;
}
.pattern-vertical .method-item:not(:last-child) {
  margin: 0 0 60px 0;
}
.pattern-vertical .method-item:not(:last-child)::after {
  top: auto;
  bottom: -42px;
  right: 50%;
  width: 60px;
  height: 20px;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  transform: translateX(50%);
}
.method-thumb {
  width: 100%;
  border: 1px solid #d7d7d7;
  border-radius: 10px;
  overflow: hidden;
}
.method-thumb.pattern-noborder {
  border: none;
}
.method-txt {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  margin-top: 20px;
  font-size: 20px;
}


/*=== ポイント ===*/
.point {
  margin-top: 40px;
}
.point-item {
  position: relative;
  padding: 20px 30px 25px;
  border: 1px solid #dc3514;
  background-color: #fdf8e6;
  border-radius: 10px;
}
.point-item.type-wide {
  padding: 30px;
}
.point-item:not(:first-child) {
  margin-top: 50px;
}
.point-label {
  position: absolute;
  top: -18px;
  left: 25px;
  width: 120px;
  padding: 10px;
  border: 1px solid #dc3514;
  color: #dc3514;
  font-weight: bold;
  font-size: 20px;
  line-height: 1;
  background-color: #fff;
  border-radius: 10px;
}
.point-column {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.point-cont {
  width: 100%;
  margin-right: 30px;
  text-align: center;
}
.point-lead {
  font-size: 24px;
}
.point .main-note {
  margin-top: 5px;
}
.point-thumb {
  width: 30%;
  max-width: 218px;
}


/*=== 例 ===*/
.example {
  margin-top: 40px;
  line-height: 1.4;
  border-radius: 10px;
  overflow: hidden;
}
.example-head {
  padding: 12px 30px;
  color: #fff;
  font-weight: bold;
  font-size: 24px;
  text-align: left;
  background-color: #dc3514;
}
.example-inner {
  padding: 30px;
  background-color: #fff;
}
.example-column {
  display: flex;
  align-items: center;
}
.example-list {
  flex-grow: 1;
}
.example-item {
  display: flex;
  align-items: center;
}
.example-item:not(:first-child) {
  margin-top: 30px;
}
.example-shop {
  width: 20%;
  max-width: 145px;
  min-width: 110px;
  margin-right: 30px;
}
.example-label {
  border: 1px solid #dc3514;
  color: #dc3514;
  font-size: 20px;
  background-color: #fdedb2;
  border-radius: 50px;
}
.example-thumb {
  margin: 15px auto 0;
  max-width: 96px;
}
.example-cashback {
  display: flex;
  align-items: center;
  width: 80%;
}
.example-detail {
  flex-grow: 1;
  border: 1px solid #dc3514;
  border-right: none;
  background-color: #fdedb2;
  border-radius: 10px 0 0 10px;
}
.example-detail_item {
  display: flex;
  align-items: center;
  position: relative;
  padding: 14px 10px 14px 65px;
}
.example-detail_item:not(:first-child) {
  border-top: 1px solid #dc3514;
}
.example-detail_item::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 30px;
  width: 15px;
  height: 20px;
  background-color: #dc3514;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}
.example-icon {
  flex-shrink: 0;
  margin-right: 10px;
}
.example-lead {
  font-size: 24px;
}
.example-subtotal {
  display: flex;
  justify-content: center;
  align-items: center;
  min-width: 125px;
  padding: 0 15px;
  border: 1px solid #dc3514;
  border-right: none;
  background-color: #fff;
}
.example-txt {
  font-size: 20px;
}
.example-txt .type-accent {
  font-size: 24px;
}
.example-total {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-content: center;
  width: 20%;
  max-width: 190px;
  min-width: 115px;
  padding: 0 10px;
  border: 1px solid #dc3514;
  border-radius: 0 10px 10px 0;
  overflow: hidden;
}
.example-mark {
  width: 100%;
  margin: 10px 0;
  color: #dc3514;
  font-weight: bold;
  font-size: 72px;
  line-height: 1;
}
@media print, screen and (max-width: 1200px) {
  .example-mark {
    font-size: 6vw;
  }
}
.example-mark.type-small {
  margin: 0;
  font-size: 42px;
}
.pattern-twoline .example-column {
  align-items: flex-start;
}
.pattern-twoline .example-detail_item {
  min-width: 406px;
}
.pattern-twoline .example-total {
  height: 268px;
}
@media print, screen and (max-width: 1090px) and (min-width: 769px) {
  .pattern-twoline .example-column {
    width: 860px;
  }
  .example-scroll {
    margin: 0 -30px;
    padding: 0 30px;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
  }
}


/*=== キャッシュバックUP ===*/
.cbup {
  margin-top: 50px;
  padding: 50px 30px 40px;
  border: 4px solid #dfbf86;
  background-color: #f2e6cf;
  border-radius: 10px;
}
.cbup-lead {
  font-weight: bold;
  font-size: 24px;
  line-height: 1.4;
}
.cbup .transition {
  margin-top: 40px;
}


/*=== 注意 ===*/
.attention {
  margin-top: 30px;
  padding: 30px 30px 40px;
  border: 2px solid #f2f2f2;
  color: #666;
  font-size: 20px;
  text-align: left;
  border-radius: 10px;
}
.attention > *:first-child {
  margin-top: 0;
}
.attention-list {
  margin-top: 10px;
}
.attention-item {
  margin-top: 5px;
  padding-left: 1em;
  text-indent: -1em;
}
.pattern-dots .attention-item {
  position: relative;
  text-indent: 0;
}
.pattern-dots .attention-item::before {
  content: "・";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
}


/*=== 概要 ===*/
.terms {
  background-color: #fdf8e6;
}
.terms-inner {
  max-height: 500px;
  margin-top: 30px;
  padding: 30px 30px 40px;
  border: 2px solid #f2f2f2;
  background-color: #fff;
  border-radius: 10px;
  overflow-x: scroll;
}
.terms-inner > *:first-child {
  margin-top: 0;
}
.terms-ttl {
  font-weight: bold;
  font-size: 18px;
  margin-top: 25px;
}
.terms-subttl {
  font-weight: bold;
  margin-top: 20px;
}
.terms-txt {
  margin-top: 10px;
}
.terms-note {
  margin-top: 10px;
  padding-left: 1em;
  color: #666;
  text-indent: -1em;
}
.terms-list {
  margin-top: 10px;
}
.terms-item {
  margin-top: 5px;
  padding-left: 1em;
  text-indent: -1em;
}


/*=== 特別キャッシュバックUP ===*/
.special {
  background-color: #fdebe6;
}
.special .main-section {
  padding-top: 20px;
}
.special-head {
  padding: 50px 0 40px;
  background: url(images/special_bg_001.png) no-repeat bottom center / 100% auto;
}
.special .main-ttl .type-small {
  margin: 0 0 10px;
}
.special-inner {
  padding: 50px 30px 40px;
  text-align: center;
  background-color: #fff;
  border-radius: 10px;
}
.special-inner > *:first-child {
  margin-top: 0;
}


/*=== 同時開催 ===*/
.event {
  background-color: #e6f1fd;
}
.event-inner {
  padding: 70px 30px;
  text-align: center;
  background-color: #fff;
  border-radius: 0 0 10px 10px;
}
.event .main-txt {
  margin-top: 30px;
}
.event .main-txt .type-accent {
  color: #043b88;
}
.event-bnr {
  margin: 10px auto 0;
}
.event .attention {
  max-height: 220px;
  margin-top: 50px;
  overflow-x: scroll;
}
.event .main-note {
  font-size: 20px;
}


/*=== キャンペーン期間 ===*/
.cpLimit {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 50px;
  color: #043b88;
  font-weight: bold;
  font-size: 24px;
}
.cpLimit-ttl {
  flex-shrink: 0;
  margin-right: 20px;
  padding: 2px 30px;
  border: 2px solid #043b88;
  font-weight: bold;
  text-align: center;
  background-color: #fff;
  border-radius: 10px;
}
.cpLimit-txt {
  text-align: left;
}


/*=== お問い合せ先 ===*/
.contact {
  margin-top: 50px;
  padding: 50px 30px 40px;
  background-color: #f2f2f2;
  border-radius: 10px;
}
.contact > *:first-child {
  margin-top: 0;
}
.contact .main-txt {
  text-align: left;
}
.contact .main-txt + .main-txt {
  margin-top: 5px;
}


/*=== 固定ナビ ===*/
.fixedNav {
  display: flex;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 100;
}
.fixedNav-item {
  width: 50%;
}
a.fixedNav-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 120px;
  padding: 10px 45px;
  color: #fff;
  font-weight: bold;
  font-size: 32px;
  text-align: center;
  line-height: 1.2;
  text-decoration: none;
  background-color: #dc3514;
}
a.fixedNav-btn.pattern-event {
  background-color: #043b88;
}
a.fixedNav-btn:visited {
  color: #fff;
}
a.fixedNav-btn:hover {
  text-decoration: none;
  opacity: 0.7;
}
a.fixedNav-btn::after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 20px;
  width: 15px;
  height: 20px;
  background-color: #fff;
  clip-path: polygon(0 0, 0 100%, 100% 50%);
  transform: translateY(-50%);
}


@media print, screen and (max-width: 768px) {
  /*=== メインレイアウト ===*/
  .main-section {
    display: block;
    width: 100%;
    padding: 30px 15px 40px;
  }
  .main-ttl {
    font-size: 22px;
  }
  .main-ttl .type-small {
    font-weight: bold;
    font-size: 14px;
  }
  .main-subttl {
    margin-top: 40px;
    font-size: 14px;
  }
  .main-txt {
    margin-top: 20px;
    font-size: 16px;
    line-height: 1.7;
  }
  .main-note {
    margin-top: 20px;
  }
  .type-label {
    margin: 0;
    padding: 4px 10px 6px;
    font-size: 18px;
  }
  /*=== 遷移パターン ===*/
  .transition.pattern-wide {
    margin-top: 30px;
  }
  .transition-item {
    margin-top: 25px;
  }
  a.transition-link {
    font-size: 16px;
  }
  a.transition-btn {
    min-height: 48px;
    padding: 10px 35px;
    font-size: 18px;
  }
  .pattern-shop a.transition-btn,
  .pattern-event a.transition-btn {
    min-height: 54px;
    padding: 10px 35px;
    font-size: 20px;
  }
  a.transition-btn::after {
    right: 15px;
    width: 10px;
    height: 15px;
  }
  /*=== メインビジュアル ===*/
  .mainvisual {
    margin-top: 0;
  }
  .mainvisual-main {
    max-width: 550px;
    padding: 0 10px;
  }
  /*=== 概要 ===*/
  .intro {
    margin-top: 35px;
    padding: 0 15px;
  }
  .intro-inner {
    display: block;
    padding: 20px 0 25px;
    text-align: center;
    background-image: url(images/intro_bg_002.png);
  }
  .intro-thumb {
    max-width: 100px;
    margin: 0 auto;
  }
  .intro .main-txt {
    margin-top: 15px;
  }
  /*=== 実施期間 ===*/
  .period {
    padding: 10px 15px;
    font-size: 16px;
  }
  .period-head {
    width: 120px;
    margin-right: 10px;
  }
  /*=== プレゼント ===*/
  .present .main-section {
    background-image: url(images/present_bg_002.png);
  }
  .present-txt {
    margin-top: 15px;
  }
  .present-txt .type-line {
    padding-bottom: 6px;
    font-size: 16px;
    line-height: 2.6;
  }
  .present-bnr {
    margin-top: 10px;
  }
  .present-bnr {
    max-width: 550px;
  }
  .present-bnr + .present-txt {
    margin-top: 15px;
  }
  /*=== 賞品 ===*/
  .award {
    margin-top: 30px;
  }
  .award-ttl {
    max-width: 180px;
  }
  .award-ttl::before,
  .award-ttl::after {
    bottom: -5px;
    width: 47px;
    height: 25px;
  }
  .award-ttl::before {
    left: -20px;
  }
  .award-ttl::after {
    right: -20px;
  }
  .award-ttl .type-txt {
    padding: 4px 10px 6px;
    border-width: 1px;
    font-size: 18px;
    border-radius: 10px;
  }
  .award-inner {
    margin-top: -15px;
    padding: 60px 15px 25px;
    border-width: 3px;
  }
  .award-list {
    display: block;
  }
  .award-item {
    width: 100%;
    padding: 20px 0 15px;
    font-size: 0;
  }
  .award-item:not(:first-child) {
    margin-top: 40px;
  }
  .award-name {
    top: -20px;
    max-width: 126px;
  }
  .award-main {
    display: inline-block;
    font-size: 18px;
  }
  .award-main .type-em {
    font-size: 28px;
  }
  .award-txt {
    display: inline-block;
    font-size: 16px;
  }
  .award-limit {
    margin: 10px 15px 0;
    padding: 8px 10px;
    font-size: 16px;
    border-radius: 5px;
  }
  /*=== 登録 ===*/
  .register {
    margin-top: 40px;
    padding: 20px 15px 25px;
  }
  /*=== ご参加の流れ ===*/
  .flow-list {
    margin-top: 20px;
  }
  .flow-list::before {
    top: -42px;
    left: calc(50% - 130px);
    width: 85px;
    height: 42px;
  }
  .flow-list::after {
    top: -49px;
    left: calc(50% + 125px);
    width: 60px;
    height: 71px;
  }
  .flow-item {
    padding: 20px 15px 25px;
    border-width: 2px;
  }
  .flow-item:not(:last-child) {
    margin-bottom: 40px;
  }
  .flow-item:not(:last-child)::after {
    bottom: -30px;
    width: 45px;
    height: 15px;
  }
  .flow .main-ttl .type-small {
    margin: 5px 0 0;
  }
  .flow > .main-note {
    text-align: left;
  }
  /*=== ショップ ===*/
  .shop {
    display: none;
  }
  .accordion {
    position: relative;
  }
  /*=== アコーディオン ===*/
  .accordion-cont {
    overflow: hidden;
  }
  .accordion-more {
    display: flex;
    align-items: flex-end;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 100px;
    background: linear-gradient(to bottom, rgb(255, 255, 255,0) 0%, rgb(255, 255, 255) 50%);
  }
  .is-AcorShow + .accordion-more {
    background: transparent;
  }
  .accordion-btn {
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    width: 100%;
    min-height: 48px;
    margin-top: 30px;
    padding: 0;
    color: #666;
    font-weight: bold;
    font-size: 18px;
    text-align: center;
    line-height: 1.2;
    text-decoration: none;
    background-color: #fff;
    border-radius: 50px;
    cursor: pointer;
  }
  .accordion-txt {
    display: block;
    width: 100%;
    height: 100%;
    padding: 10px 35px;
    position: relative;
  }
  .accordion-txt::after {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: 15px;
    width: 15px;
    height: 10px;
    background-color: #666;
    clip-path: polygon(0 0, 100% 0%, 50% 100%);
    transform: translateY(-50%);
  }
  .is-AcorActive .accordion-txt::after {
    top: 47%;
    clip-path: polygon(0 100%, 50% 0, 100% 100%);
  }
  /*=== 確認方法 ===*/
  .method {
    margin-top: 20px;
  }
  .method-list {
    display: block;
  }
  .method-item {
    display: block;
    width: 100%;
    padding: 15px 15px 20px;
    border-width: 1px;
  }
  .pattern-vertical .method-item:not(:last-child) {
    margin: 0 0 40px 0;
  }
  .pattern-vertical .method-item:not(:last-child)::after {
    bottom: -25px;
    width: 25px;
    height: 10px;
  }
  .method-thumb {
    max-width: 500px;
    margin: 0 auto;
  }
  .method-txt {
    margin-top: 20px;
    font-size: 16px;
  }
  /*=== ポイント ===*/
  .point {
    margin-top: 30px;
  }
  .point-item {
    position: relative;
    margin-left: 5px;
    padding: 25px 15px;
  }
  .point-item.type-wide {
    padding: 25px 15px;
  }
  .point-item:not(:first-child) {
    margin-top: 30px;
  }
  .point-label {
    left: -6px;
    width: 83px;
    padding: 6px 10px 8px;
    font-size: 16px;
  }
  .point-column {
    display: block;
  }
  .point-cont {
    margin-right: 0;
  }
  .point-lead {
    font-size: 16px;
  }
  .point-thumb {
    width: 100%;
    max-width: 125px;
    margin: 20px auto 0;
  }
  .point-thumb.pattarn-shop {
    max-width: 82px;
  }
  /*=== 例 ===*/
  .example {
    margin-top: 20px;
  }
  .example-head {
    padding: 12px 20px;
    font-size: 14px;
  }
  .example-inner {
    padding: 20px 15px 25px;
    background-color: #fff;
  }
  .example-column {
    display: block;
    max-width: 500px;
    margin: 0 auto;
  }
  .example-item {
    display: block;
  }
  .example-item:not(:first-child) {
    margin-top: 25px;
  }
  .example-shop {
    width: 100%;
    max-width: none;
    min-width: auto;
    margin-right: 0;
  }
  .example-label {
    display: inline-block;
    padding: 2px 15px;
    font-size: 12px;
  }
  .example-thumb {
    max-width: 60px;
    margin-top: 10px;
  }
  .example-cashback {
    display: block;
    width: 100%;
    margin-top: 15px;
  }
  .example-detail {
    border: 1px solid #dc3514;
    border-bottom: none;
    border-radius: 10px 10px 0 0;
  }
  .example-detail_item {
    padding-left: 30px;
  }
  .example-detail_item::before {
    left: 15px;
    width: 8px;
    height: 12px;
  }
  .example-icon {
    max-width: 19px;
    margin-right: 5px;
  }
  .example-lead {
    font-size: 14px;
  }
  .example-subtotal {
    min-width: auto;
    padding: 10px;
    border: 1px solid #dc3514;
    border-radius: 0 0 10px 10px;
  }
  .example-txt {
    font-size: 14px;
  }
  .example-txt .type-accent {
    font-size: 14px;
  }
  .example-total {
    width: 100%;
    max-width: none;
    min-width: auto;
    padding: 10px;
    border-radius: 0 0 10px 10px;
  }
  .example-mark {
    margin: 0 0 5px;
    font-size: 36px;
  }
  .example-mark.type-small {
    margin-bottom: 5px;
    font-size: 36px;
  }
  .pattern-twoline .example-detail_item {
    min-width: auto;
  }
  .pattern-twoline .example-total {
    align-items: center;
    flex-wrap: nowrap;
    height: auto;
    margin-top: 25px;
    border-radius: 10px;
  }
  .example-multiple {
    display: flex;
    justify-content: space-around;
    align-items: center;
    width: 60%;
    max-width: 125px;
  }
  .example-multiple .example-thumb {
    margin: 0;
    max-width: 86px;
  }
  .example-equal {
    margin: 0 15px;
  }
  /*=== キャッシュバックUP ===*/
  .cbup {
    margin-top: 25px;
    padding: 20px 15px 25px;
    border-width: 2px;
  }
  .cbup-lead {
    font-size: 16px;
  }
  .cbup .transition {
    margin-top: 25px;
  }
  /*=== 注意 ===*/
  .attention {
    margin-top: 20px;
    padding: 20px 15px 25px;
    font-size: 14px;
  }
  /*=== 概要 ===*/
  .terms-inner {
    max-height: 345px;
    margin-top: 20px;
    padding: 20px 15px 25px;
  }
  .terms-ttl {
    font-size: 16px;
  }
  /*=== 特別キャッシュバックUP ===*/
  .special .main-section {
    padding-top: 0;
  }
  .special-head {
    margin: 0 -15px;
    padding: 30px 0;
    background-image: url(images/special_bg_002.png);
  }
  .special .main-ttl .type-small {
    margin: 0 0 5px;
  }
  .special-inner {
    margin-top: -10px;
    padding: 20px 15px 25px;
  }
  /*=== 同時開催 ===*/
  .event-wrap {
    max-width: 690px;
    margin: -10px auto 0;
  }
  .event-note {
    padding: 10px;
    background-color: #f2f2f2;
  }
  .event .event-note .main-note {
    margin-top: 0;
    font-size: 10px;
  }
  .event-inner {
    padding: 30px 15px 40px;
  }
  .event .main-txt {
    margin-top: 30px;
  }
  .event-bnr {
    max-width: 550px;
  }
  .event-bnr + .main-txt {
    margin-top: 20px;
  }
  .event .attention {
    max-height: 135px;
    margin-top: 30px;
  }
  .event .main-note {
    font-size: 14px;
  }
  /*=== キャンペーン期間 ===*/
  .cpLimit {
    display: block;
    margin-top: 40px;
    font-size: 16px;
  }
  .cpLimit-ttl {
    margin-right: 0;
    display: inline-block;
    padding: 4px 15px;
    border-width: 1px;
  }
  .cpLimit-txt {
    margin-top: 10px;
    text-align: center;
  }
  /*=== お問い合せ先 ===*/
  .contact {
    margin-top: 30px;
    padding: 20px 15px 25px;
  }
  .contact .main-txt {
    margin-top: 15px;
    font-size: 14px;
  }
  .contact .main-txt + .main-txt {
    margin-top: 20px;
  }
  /*=== 固定ナビ ===*/
  a.fixedNav-btn {
    min-height: 90px;
    padding: 5px;
    font-size: 15px;
  }
  a.fixedNav-btn::after {
    right: 10px;
    width: 6px;
    height: 10px;
  }
}