/******************************
    common 
******************************/
:root {
  --fc-base: #121212;
  --ff-base: "Noto Sans JP", sans-serif;
  --bgc-base: #2490E8;
  --bgc-alternate: #0273CF;
  --oval-height: calc(499 / 1920 * 100vw);
  --oval-width: calc(2436 / 1920 * 100vw);
  --oval-padding: calc(180 / 1920 * 100vw);
}
@media screen and (max-width: 767px) {
  :root {
    --oval-height: calc(159 / 375 * 100vw);
    --oval-width: calc(480 / 375 * 100vw);
    --oval-padding: calc(70 / 375 * 100vw);
  }
}
.pane-contents .container {
  width: 100%;
  padding: 0;
}

.pane-contents {
  padding: 0;
}

.pane-left-menu {
  display: none;
}

h1,
h2,
h3 {
  padding: 0;
  margin: 0;
  background: transparent;
}

.limitedMilesup_ttl {
  text-align: center;
}

.color-red {
  color: #CC0000;
}

.block-event-page--accessory {
  background-color: var(--bgc-base);
  font-family: var(--ff-base);
}

.block-event-page--goods {
  margin: 0;
}

.block-separat {
  display: none;
}

.js-block-header-fix-wrap {
  position: relative;
  z-index: 100;
}

.block-page-top {
  bottom: 16px;
  right: 40px;
  z-index: 101;
}

.separate-tab::after {
  content: '';
  width: 13px;
  height: 13px;
  display: inline-block;
  margin-left: 8px;
  background-image: url(/img/usr/event/shoparound/202410/icon_separate-tab-w.png);
  background-repeat: no-repeat;
  background-size: contain;
  background-position: center;
}

/* common pc */
[data-browse-mode="P"] .sp {
  display: none;
}

[data-browse-mode="P"] .wrapper {
  min-width: 1320px;
  overflow: hidden;
}

[data-browse-mode="P"] .pane-footer {
  min-width: 1320px;
}

[data-browse-mode="P"] .content_inner {
  width: 1080px;
  margin: 0 auto;
}

[data-browse-mode="P"] .block-event-page--accessory {
  position: relative;
}

[data-browse-mode="P"] .block-event-page--accessory::before {
  pointer-events: none;
  content: '';
  background-image: url('/img/usr/event/anapay/deco_left.png');
  background-size: 100%;
  background-repeat: no-repeat;
  height: 859px;
  width: 370px;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1;
}
@media screen and (max-width: 1790px) {
  [data-browse-mode="P"] .block-event-page--accessory::before {
    left: calc(50% - 900px);
  }
}

[data-browse-mode="P"] .block-event-page--accessory::after {
  pointer-events: none;
  content: '';
  background-image: url('/img/usr/event/anapay/deco_right.png');
  background-size: 100%;
  background-repeat: no-repeat;
  height: 862px;
  width: 370px;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 1;
}
@media screen and (max-width: 1790px) {
  [data-browse-mode="P"] .block-event-page--accessory::before {
    left: calc(50% - 900px);
  }
  [data-browse-mode="P"] .block-event-page--accessory::after {
    right: calc(50% - 900px);
  }
}

[data-browse-mode="P"] .pane-right-menu {
  margin-top: 0;
  width: 100%;
}

[data-browse-mode="P"]  #block_of_itemhistory {
  margin: 0 auto;
}

/* common sp */
[data-browse-mode="S"] .pc {
  display: none;
}

[data-browse-mode="S"] .content_inner {
  padding: 0 20px;
}

[data-browse-mode="S"] .separate-tab::after {
  content: '';
  width: 13px;
  height: 13px;
  margin-left: 10px;
}

[data-browse-mode="S"] main.pane-main {
  overflow: hidden;
  padding-top: 0;
}

[data-browse-mode="S"] .block-page-top {
  bottom: calc(74 / 375 * 100vw);
  right: calc(9 / 375 * 100vw);
}


/******************************
  イベント名：anapay-mv
******************************/
.event-anapay-mv {
  color: #fff;
  padding-bottom: var(--oval-padding);
}
.anapay-mv {
  position: relative;
  z-index: 2;
}
.anapay-mv-image {
}
.anapay-mv-period {
  background-color: #00126A;
  color: #fff;
  display: flex;
  align-items: baseline;
  justify-content: center;
  font-feature-settings: "palt";
  font-weight: bold;
  letter-spacing: .05em;
  line-height: 1;
  text-align: center;
  padding-block: calc(7 / 1920 * 100vw) calc(16 / 1920 * 100vw);
}
.anapay-mv-period-sm {
  font-size: calc(36 / 1920 * 100vw);
}
.anapay-mv-period-md {
  font-size: calc(48 / 1920 * 100vw);
}
.anapay-mv-period-lg {
  font-size: calc(60 / 1920 * 100vw);
}
.anapay-mv-entry {
  display: flex;
  align-items: center;
  flex-direction: column;
  row-gap: 18px;
  margin-top: 38px;
}
.anapay-mv-entry .anapay-entrybtn {
  min-width: 500px;
}
.fixed-btm-area {
  background-color: rgba(0, 0, 0, .8);
  display: none;
  padding-block: 14px 16px;
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 2;
}
.fixed-btm-area .anapay-entrybtn {
  margin-inline: auto;
  min-width: 500px;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .event-anapay-mv {
    padding-bottom: var(--oval-padding);
  }
  .anapay-mv-period {
    display: block;
    font-size: 0;
    padding-block: calc(7 / 375 * 100vw) calc(11 / 375 * 100vw);
  }
  .anapay-mv-period-sm {
    font-size: calc(15 / 375 * 100vw);
  }
  .anapay-mv-period-md {
    font-size: calc(20 / 375 * 100vw);
  }
  .anapay-mv-period-lg {
    font-size: calc(27 / 375 * 100vw);
  }
  .anapay-mv-entry {
    row-gap: calc(11 / 375 * 100vw);
    padding-inline: calc(20 / 375 * 100vw);
    margin-top: calc(20 / 375 * 100vw);
  }
  .anapay-mv-entry .anapay-entrybtn {
    min-width: calc(280 / 375 * 100vw);
  }
  .fixed-btm-area {
    padding-block: calc(10 / 375 * 100vw);
  }
  .fixed-btm-area .anapay-entrybtn {
    min-width: calc(280 / 375 * 100vw);
    width: fit-content;
  }
}

/******************************
  背景楕円形
******************************/
.bg-oval-top {
  position: relative;
  z-index: 0;
}
.bg-oval-top::before {
  content: '';
  background-color: var(--bgc-base);
  border-radius: 50%;
  height: var(--oval-height);
  width: var(--oval-width);
  position: absolute;
  top: calc(-1 * (100 / 1920 * 100vw));
  left: calc(-1 * (258 / 1920 * 100vw));
  z-index: -1;
}
.bg-oval-bottom {
  position: relative;
  z-index: 0;
}
.bg-oval-bottom::after {
  content: '';
  background-color: var(--bgc-base);
  border-radius: 50%;
  height: var(--oval-height);
  width: var(--oval-width);
  position: absolute;
  bottom: calc(-1 * (390 / 1920 * 100vw));
  left: calc(-1 * (258 / 1920 * 100vw));
  z-index: -1;
}
@media screen and (max-width: 767px) {
  .bg-oval-top::before {
    top: calc(-1 * (34 / 375 * 100vw));
    left: calc(-1 * (52 / 375 * 100vw));
  }
  .bg-oval-bottom::after {
    bottom: calc(-1 * (390 / 375 * 100vw));
    left: calc(-1 * (52 / 375 * 100vw));
  }
}

/******************************
  イベント名：anapay-1
******************************/
.event-anapay-1 {
  background-color: var(--bgc-alternate);
  color: #fff;
  padding-block: 20px var(--oval-padding);
}
.event-anapay-1.bg-oval-top::before {
  background-color: var(--bgc-alternate);
}
.anapay-1 {
  margin-inline: auto;
  width: 1180px;
}
.anapay-1-ttl {
  text-align: center;
  margin-bottom: 40px;
}
.anapay-1-lead {
  font-weight: bold;
  display: flex;
  flex-direction: column;
  row-gap: 6px;
  text-align: center;
  margin-bottom: 28px;
}
.anapay-1-lead em {
  color: #FEF009;
  font-style: inherit;
  font-weight: inherit;
}
.anapay-1-lead-main {
  font-size: 30px;
  line-height: calc(48 / 30);
}
.anapay-1-lead-main span {
  font-size: 40px;
}
.anapay-1-lead-sub {
  font-size: 22px;
  line-height: calc(38 / 22);
}
.anapay-1-img {
  display: flex;
  flex-direction: column;
  align-items: center;
  row-gap: 28px;
}
@media screen and (max-width: 767px) {
  .event-anapay-1 {
    padding-block: calc(16 / 375 * 100vw) var(--oval-padding);
  }
  .anapay-1 {
    position: relative;
    width: auto;
  }
  .anapay-1::before {
    content: '';
    background-image: url('/img/usr/event/anapay/deco_sp.png');
    background-size: 100%;
    background-repeat: no-repeat;
    position: absolute;
    height: calc(217 / 375 * 100vw);
    width: 100%;
    top: calc(-1 * (58 / 375 * 100vw));
    left: 0;
    z-index: 1;
  }
  .anapay-1-ttl {
    margin-bottom: calc(20 / 375 * 100vw);
  }
  .anapay-1-ttl img {
    width: calc(233 / 375 * 100vw);
  }
  .anapay-1-lead {
    row-gap: calc(8 / 375 * 100vw);
    padding-inline: calc(15 / 375 * 100vw);
    margin-bottom: calc(22 / 375 * 100vw);
  }
  .anapay-1-lead-main {
    font-size: calc(18 / 375 * 100vw);
    line-height: calc(30 / 24);
  }
  .anapay-1-lead-main span {
    font-size: calc(24 / 375 * 100vw);
  }
  .anapay-1-lead-sub {
    font-size: calc(14 / 375 * 100vw);
    line-height: calc(22 / 14);
  }
  .anapay-1-img {
    row-gap: calc(16 / 375 * 100vw);
  }
  .anapay-1-img .anapay-note-list {
    padding-inline: calc(20 / 375 * 100vw);
  }
}

/******************************
  イベント名：anapay-2
******************************/
.event-anapay-2 {
  color: #fff;
  padding-block: 20px var(--oval-padding);
}
.anapay-2 {
  margin-inline: auto;
  width: 1080px;
}
.anapay-2-ttl {
  text-align: center;
  margin-bottom: 40px;
}
.anapay-2-shop {
  background-color: #fff;
  border: 4px solid #00126A;
  border-radius: 5px;
  box-shadow: 5px 5px 0px #001465;
  color: var(--fc-base);
  padding-block: 60px 50px;
  padding-inline: 91px;
  margin-inline: auto;
  margin-bottom: 20px;
  width: 1080px;
}
.anapay-2-shop-group {
  margin-bottom: 50px;
}
.anapay-2-shop-group-ttl {
  background-color: #00126A;
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: .04em;
  line-height: 1.5;
  text-align: center;
  padding-block: 13px 14px;
  padding-inline: 20px;
  margin-bottom: 40px;
  position: relative;
}
.anapay-2-shop-group-ttl::after {
  content: '';
  width: 0;
  height: 0;
  border-style: solid;
  border-right: 8px solid transparent;
  border-left: 8px solid transparent;
  border-top: 12px solid #00126A;
  border-bottom: 0;
  position: absolute;
  top: 100%;
  left: 50%;
  translate: -50%;
}
.anapay-2-shop-list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 32px 11px;
  word-break: break-all;
}
.anapay-2-shop-list > li {
  display: flex;
  flex-direction: column;
}
.anapay-2-shop-list a {
  text-decoration: none!important;
}
.anapay-2-shop-logo {
  background-color: #fff;
  border: 1px solid #DBDBDB;
  height: 51px;
  margin-bottom: 2px;
}
.anapay-2-shop-logo img {
  height: 100%;
  width: 100%;
  object-fit: contain;
}
.anapay-2-shop-name {
  font-size: 14px;
  letter-spacing: .03em;
  line-height: calc(26 / 14);
}
@media screen and (max-width: 767px) {
  .event-anapay-2 {
    padding-block: 20px var(--oval-padding);
    padding-inline: calc(16 / 375 * 100vw);
  }
  .anapay-2 {
    width: auto;
  }
  .anapay-2-ttl {
    margin-bottom: calc(20 / 375 * 100vw);
  }
  .anapay-2-ttl img {
    width: calc(349 / 375 * 100vw);
  }
  .anapay-2-shop {
    padding-block: calc(20 / 375 * 100vw);
    padding-inline: calc(20 / 375 * 100vw);
    margin-bottom: calc(20 / 375 * 100vw);
    width: auto;
  }
  .anapay-2-shop-group {
    margin-bottom: calc(20 / 375 * 100vw);
  }
  .anapay-2-shop-group + .anapay-2-shop-group {
    margin-top: calc(50 / 375 * 100vw);
  }
  .anapay-2-shop-group-ttl {
    font-size: calc(16 / 375 * 100vw);
    line-height: calc(22 / 16);
    padding-block: calc(6 / 375 * 100vw) calc(7 / 375 * 100vw);
    padding-inline: calc(16 / 375 * 100vw);
    margin-bottom: calc(12 / 375 * 100vw);
  }
  .anapay-2-shop-group-ttl::after {
    border-right: 7px solid transparent;
    border-left: 7px solid transparent;
    border-top: 9px solid #00126A;
  }
  .anapay-2-shop-list {
    grid-template-columns: repeat(2, 1fr);
    gap: calc(11 / 375 * 100vw) calc(10 / 375 * 100vw);
  }
  .anapay-2-shop-logo {
    height: 41px;
    margin-bottom: 2px;
  }
  .anapay-2-shop-name {
    font-size: calc(13 / 375 * 100vw);
    line-height: calc(26 / 13);
  }
}

/******************************
  イベント名：anapay-3
******************************/
.event-anapay-3 {
  background-color: var(--bgc-alternate);
  color: #fff;
  padding-block: 20px var(--oval-padding);
}
.event-anapay-3.bg-oval-top::before {
  background-color: var(--bgc-alternate);
}
.anapay-3 {
  margin-inline: auto;
  width: 1080px;
}
.anapay-3-ttl {
  text-align: center;
  margin-bottom: 40px;
}
.anapay-3-step {
  margin-inline: auto;
  margin-bottom: 30px;
  width: 400px;
}
.anapay-3-step-slick .slick-list {
  border-radius: 40px;
  overflow: hidden;
  position: relative;
}
.anapay-3-step-slick .slick-list::before {
  content: '';
  background-image: url('/img/usr/event/anapay/anapay-3_frame.png');
  background-size: 100% 100%;
  position: absolute;
  inset: 0;
  z-index: 1;
}
.anapay-3-step-slick .slick-prev,
.anapay-3-step-slick .slick-next {
  width: 40px;
  height: 40px;
}
.anapay-3-step-slick .slick-prev {
  left: -80px;
}
.anapay-3-step-slick .slick-next {
  right: -80px;
}
.anapay-3-step-slick .slick-prev::before,
.anapay-3-step-slick .slick-next::before {
  content: '';
  background-image: url('/img/usr/event/anapay/anapay-3_arrow.png');
  background-size: cover;
  display: block;
  height: 100%;
  width: 100%;
  opacity: 1;
}
.anapay-3-step-slick .slick-prev::before {
  rotate: 180deg;
}
.event-anapay-3 .anapay-note-list {
  margin-inline: auto;
  width: fit-content;
}
@media screen and (max-width: 767px) {
  .event-anapay-3 {
    padding-block: 20px var(--oval-padding);
    padding-inline: calc(15 / 375 * 100vw);
  }
  .anapay-3 {
    width: auto;
  }
  .anapay-3-ttl {
    margin-bottom: calc(20 / 375 * 100vw);
  }
  .anapay-3-ttl img {
    width: calc(288 / 375 * 100vw);
  }
  .anapay-3-step {
    margin-bottom: calc(20 / 375 * 100vw);
    width: calc(260 / 375 * 100vw);
  }
  .anapay-3-step-slick .slick-list {
    border-radius: 28px;
  }
  .anapay-3-step-slick .slick-prev,
  .anapay-3-step-slick .slick-next {
    width: calc(30 / 375 * 100vw);
    height: calc(30 / 375 * 100vw);
  }
  .anapay-3-step-slick .slick-prev {
    left: calc(-1 * (40 / 375 * 100vw));
  }
  .anapay-3-step-slick .slick-next {
    right: calc(-1 * (40 / 375 * 100vw));
  }
}

/******************************
  イベント名：anapay-4
******************************/
.event-anapay-4 {
  padding-block: 20px var(--oval-padding);
}
.anapay-4 {
  margin-inline: auto;
  width: 1080px;
}
.anapay-4-ttl {
  text-align: center;
  margin-bottom: 40px;
}
.event-anapay-4 .block-top-event--goods {
  background-color: #fff;
  border: 4px solid #00126A;
  border-radius: 5px;
  box-shadow: 5px 5px 0px #001465;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding-block: 50px 20px;
  margin-inline: auto;
  width: 1080px;
}
@media screen and (max-width: 767px) {
  .event-anapay-4 {
    padding-block: 20px var(--oval-padding);
  }
  .anapay-4 {
    width: auto;
  }
  .anapay-4-ttl {
    margin-bottom: calc(20 / 375 * 100vw);
  }
  .anapay-4-ttl img {
    width: calc(289 / 375 * 100vw);
  }
  .event-anapay-4 .block-top-event--goods {
    border: none;
    border-radius: 0;
    box-shadow: none;
    padding-block: calc(20 / 375 * 100vw);
    width: auto;
  }
  .event-anapay-4 .block-top-event--goods .block-reccomend-list--shop-info,
  .event-anapay-4 .block-top-event--goods .block-top-free1--bookmark-shop-name,
  .event-anapay-4 .block-top-event--goods .block-thumbnail-t--shop-info {
    display: block;
  }
}

/******************************
  イベント名：anapay-5
******************************/
.event-anapay-5 {
  background-color: var(--bgc-alternate);
  color: #fff;
  padding-bottom: 60px;
}
.event-anapay-5.bg-oval-top::before {
  background-color: var(--bgc-alternate);
}
.anapay-5 {
  margin-inline: auto;
  width: 1080px;
}
.anapay-5-ttl {
  text-align: center;
  margin-bottom: 40px;
}
.anapay-5-campaign-list {
  display: flex;
  gap: 20px;
  justify-content: center;
  margin-bottom: 40px;
}
.anapay-5-campaign-list > * {
  width: calc((100% - 60px) / 4);
}
.anapay-5-campaign-list img {
  width: 100%;
}
.anapay-5-link {
  display: grid;
  grid-template-columns: 390px;
  row-gap: 20px;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .event-anapay-5 {
    padding-inline: calc(20 / 375 * 100vw);
    padding-block: calc(20 / 375 * 100vw) calc(30 / 375 * 100vw);
  }
  .anapay-5 {
    width: auto;
  }
  .anapay-5-ttl {
    margin-bottom: calc(20 / 375 * 100vw);
  }
  .anapay-5-campaign-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 10px;
    margin-bottom: calc(25 / 375 * 100vw);
  }
  .anapay-5-campaign-list > * {
    width: auto;
  }
  .anapay-5-link {
    grid-template-columns: calc(270 / 375 * 100vw);
    row-gap: calc(12 / 375 * 100vw);
  }
}

/******************************
  イベント名：anapay-99
******************************/
.event-anapay-99 {
  background-color: var(--bgc-alternate);
  color: #fff;
  padding-block: 60px var(--oval-padding);
  overflow: hidden;
}
.event-anapay-99.bg-oval-bottom::after {
  background-color: #fff;
}
.anapay-99 {
  margin-inline: auto;
  width: 1080px;
}
.anapay-99-ttl {
  text-align: center;
  margin-bottom: 40px;
}
.anapay-99-detail {
  background-color: #fff;
  border: 4px solid #00126A;
  border-radius: 5px;
  box-shadow: 5px 5px 0px #001465;
  color: var(--fc-base);
  padding-block: 50px;
  padding-inline: 42px;
  margin-inline: auto;
  width: 1080px;
}
.anapay-99-dl {
  display: flex;
  flex-direction: column;
  row-gap: 29px;
}
.anapay-99-dl dt {
  font-size: 20px;
  font-weight: bold;
  line-height: calc(30 / 20);
  margin-bottom: 7px;
}
.anapay-99-dl dd {
  font-size: 16px;
  line-height: calc(30 / 16);
}
.anapay-99-dl dd + dd {
  margin-top: 20px;
}
.anapay-99-dl a {
  text-decoration: underline;
}
.anapay-99-dl a:hover {
  text-decoration: none;
}
.anapay-99-dl strong {
  color: red;
}
@media screen and (max-width: 767px) {
  .event-anapay-99 {
    padding-block: calc(30 / 375 * 100vw) var(--oval-padding);
    padding-inline: calc(20 / 375 * 100vw);
  }
  .anapay-99 {
    width: auto;
  }
  .anapay-99-ttl {
    margin-bottom: calc(20 / 375 * 100vw);
  }
  .anapay-99-ttl img {
    width: calc(233 / 375 * 100vw);
  }
  .anapay-99-detail {
    padding-block: calc(16 / 375 * 100vw);
    padding-inline: calc(16 / 375 * 100vw);
    width: auto;
  }
  .anapay-99-dl {
    row-gap: calc(16 / 375 * 100vw);
  }
  .anapay-99-dl dt {
    font-size: calc(16 / 375 * 100vw);
    line-height: calc(30 / 16);
    margin-bottom: calc(2 / 375 * 100vw);
  }
  .anapay-99-dl dd {
    font-size: calc(14 / 375 * 100vw);
    line-height: calc(22 / 14);
  }
  .anapay-99-dl dd + dd {
    margin-top: calc(16 / 375 * 100vw);
  }
}

/******************************
  エントリーボタン
******************************/
.anapay-entrybtn {
  background-color: #FEF009;
  border: 2px solid #fff;
  border-radius: 9999px;
  color: #00126A;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: bold;
  filter: drop-shadow(0px 6px 0px rgba(0, 0, 0, 0.21));
  letter-spacing: .05em;
  line-height: calc(30 / 22);
  text-align: center;
  text-decoration: none!important;
  padding-block: 7px 9px;
  position: relative;
}
.anapay-entrybtn::before {
  content: '';
  background-color: currentColor;
  border-radius: 9999px;
  height: 2px;
  width: 17px;
  position: absolute;
  top: 50%;
  left: calc(100% - 24px);
  translate: -100% -50%;
  transition: left .3s, width .3s;
}
.anapay-entrybtn::after {
  content: '';
  background-image: url('/img/usr/event/anapay/icon_entrybtn_arrow.png');
  background-size: 100%;
  background-repeat: no-repeat;
  height: 12px;
  width: 17px;
  position: absolute;
  top: 50%;
  left: calc(100% - 24px);
  translate: -100% -50%;
  transition: left .3s;
}
.anapay-entrybtn:hover {
  background-color: #fff;
  border-color: currentColor;
}
.anapay-entrybtn:hover::before {
  left: calc(100% - 16px);
  width: 24px;
}
.anapay-entrybtn:hover::after {
  left: calc(100% - 16px);
}
.anapay-entrybtn-inner {
  padding-inline: 12px 20px;
  position: relative;
}
.anapay-entrybtn-inner::after {
  content: '';
  background-image: url('/img/usr/event/anapay/icon_entrybtn_blank.png');
  background-size: 100%;
  background-repeat: no-repeat;
  height: 16px;
  width: 16px;
  position: absolute;
  top: 50%;
  right: 0;
  translate: 0 -50%;
}
@media screen and (max-width: 767px) {
  .anapay-entrybtn {
    font-size: calc(16 / 375 * 100vw);
    letter-spacing: .02em;
    line-height: calc(30 / 16);
    padding-block: calc(4 / 375 * 100vw) calc(6 / 375 * 100vw);
  }
  .anapay-entrybtn::before {
    left: calc(100% - (11 / 375 * 100vw));
  }
  .anapay-entrybtn::after {
    left: calc(100% - (11 / 375 * 100vw));
  }
  .anapay-entrybtn:hover::before {
    left: calc(100% - (16 / 375 * 100vw));
  }
  .anapay-entrybtn:hover::after {
    left: calc(100% - (16 / 375 * 100vw));
  }
  .anapay-entrybtn-inner {
    padding-inline: calc(12 / 375 * 100vw) calc(20 / 375 * 100vw);
  }
  .anapay-entrybtn-inner::after {
    height: calc(16 / 375 * 100vw);
    width: calc(16 / 375 * 100vw);
  }
}

/******************************
  リンクボタン
******************************/
.anapay-linkbtn {
  background-color: #00126A;
  background-image: url('/img/usr/event/anapay/icon_linkbtn_arrow.png');
  background-position: right 20px center;
  background-repeat: no-repeat;
  background-size: 9px 14px;
  border-radius: 9999px;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 500;
  filter: drop-shadow(0px 4px 0px rgba(0, 0, 0, 0.16));
  letter-spacing: .05em;
  line-height: calc(26 / 18);
  text-align: center;
  text-decoration: none!important;
  padding-block: 17px;
  position: relative;
  transition: opacity .3s;
}
.anapay-linkbtn:hover {
  opacity: .8;
}
@media screen and (max-width: 767px) {
  .anapay-linkbtn {
    background-position: right calc(12 / 375 * 100vw) center;
    background-size: calc(6 / 375 * 100vw) calc(10 / 375 * 100vw);
    font-size: calc(14 / 375 * 100vw);
    line-height: calc(20 / 14);
    padding-block: calc(12 / 375 * 100vw) calc(13 / 375 * 100vw);
  }
}

/******************************
  注釈
******************************/
.anapay-note-list {
  font-size: 14px;
  line-height: calc(22 / 14);
}
.anapay-note-list a {
  color: inherit;
  text-decoration: underline;
}
.anapay-note-list a:hover {
  text-decoration: none;
}
.anapay-note-list > li.note-important {
  font-size: 16px;
  font-weight: bold;
}
.anapay-note-list > li + li {
  margin-top: .4em;
}
@media screen and (max-width: 767px) {
  .anapay-note-list {
    font-size: calc(13 / 375 * 100vw);
    line-height: calc(20 / 13);
  }
  .anapay-note-list > li.note-important {
    font-size: calc(14 / 375 * 100vw);
  }
}