@charset "UTF-8";

/*** color ***/

html {
  font-size: 62.5%;
}

body {
  font-family: "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", メイリオ, Meiryo, sans-serif;
  font-size: 1.4rem;
  color: #282328;
}

img {
  width: 100%;
  vertical-align: bottom;
}

.p-accordion__body {
  position: relative;
  overflow: hidden;
  height: 140px;
}

.p-accordion__body::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0.1) 0%, rgb(255, 255, 255) 75%);
}

.p-accordion__body.is-open {
  height: auto;
}

.p-accordion__body.is-open::after {
  content: normal;
}

.p-accordion__btn {
  cursor: pointer;
  position: relative;
  display: flex;
  width: 272px;
  height: 52px;
  align-items: center;
  justify-content: center;
  border: 2px solid #111;
  background-color: #fff;
  font-weight: bold;
  border-radius: 26px;
  margin: 0 auto;
  margin-top: -30px;
}

.p-accordion__btn::after {
  content: "";
  position: absolute;
  display: block;
  width: 20px;
  height: 20px;
  top: 0;
  bottom: 0;
  right: 28px;
  margin: auto 0;
  background: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/circle_plus@2x.png") no-repeat center/contain;
}

.p-accordion__btn.is-open {
  margin-top: 28px;
}

.p-accordion__btn.is-open::after {
  background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/circle_minus@2x.png");
}

.p-annotation {
  padding-left: 1em;
  line-height: 1.6;
}

.p-annotation li::before {
  content: "・";
  display: inline-block;
  margin-left: -1em;
}

.p-annotation.is-asterisk li::before {
  content: "※";
}

.p-annotation.is-enum {
  padding-left: 1.4em;
}

.p-annotation.is-enum li::before {
  content: normal;
}

.p-annotation.is-enum li span {
  display: inline-block;
  margin-left: -1.4em;
}

.p-area {
  position: relative;
  z-index: 0;
}

.p-area__bg {
  width: 100%;
  overflow: hidden;
  position: absolute;
  left: 0;
  top: -49px;
  z-index: -1;
}

.p-area__bg-lane {
  position: relative;
  width: 300%;
  height: 65px; /* 画像高さに合わせる */
  background: repeat-x left center;
}

@keyframes moveLeft-howto {
  from {
    left: 0;
  }

  to {
    left: -640px; /* 画像幅に合わせる */
  }
}

@keyframes moveLeft-howto-sp {
  from {
    left: 0;
  }

  to {
    left: -344.6153846px; /* -0.53846153846 x 640 PCからの画像の縮小比率 x 画像の高さ */
  }
}

.p-area__bg-howto {
  background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_howto.png");
  background-image: -webkit-image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_howto.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_howto@2x.png") 2x);
  background-image: image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_howto.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_howto@2x.png") 2x);
  animation: moveLeft-howto 12.8s linear infinite; /* アニメーション秒計算 640/50x1s */
}

@keyframes moveLeft-entry {
  from {
    left: 0;
  }

  to {
    left: -294px;
  }
}

@keyframes moveLeft-entry-sp {
  from {
    left: 0;
  }

  to {
    left: -158.3076923px;
  }
}

.p-area__bg-entry {
  background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_entry.png");
  background-image: -webkit-image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_entry.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_entry@2x.png") 2x);
  background-image: image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_entry.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_entry@2x.png") 2x);
  animation: moveLeft-entry 5.88s linear infinite;
}

@keyframes moveLeft-pontarank {
  from {
    left: 0;
  }

  to {
    left: -499px;
  }
}

@keyframes moveLeft-pontarank-sp {
  from {
    left: 0;
  }

  to {
    left: -268.692307692px;
  }
}

.p-area__bg-pontarank {
  background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_pontarank.png");
  background-image: -webkit-image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_pontarank.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_pontarank@2x.png") 2x);
  background-image: image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_pontarank.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_pontarank@2x.png") 2x);
  animation: moveLeft-pontarank 9.98s linear infinite;
}

@keyframes moveLeft-pontaapp {
  from {
    left: 0;
  }

  to {
    left: -941px;
  }
}

@keyframes moveLeft-pontaapp-sp {
  from {
    left: 0;
  }

  to {
    left: -506.6923076px;
  }
}

.p-area__bg-pontaapp {
  background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_what.png");
  background-image: -webkit-image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_what.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_what@2x.png") 2x);
  background-image: image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_what.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_what@2x.png") 2x);
  animation: moveLeft-pontaapp 18.82s linear infinite;
}

@keyframes moveLeft-detail {
  from {
    left: 0;
  }

  to {
    left: -786px;
  }
}

@keyframes moveLeft-detail-sp {
  from {
    left: 0;
  }

  to {
    left: -423.2307692px;
  }
}

.p-area__bg-detail {
  background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_detail.png");
  background-image: -webkit-image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_detail.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_detail@2x.png") 2x);
  background-image: image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_detail.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_detail@2x.png") 2x);
  animation: moveLeft-detail 15.72s linear infinite;
}

@keyframes moveLeft-cp {
  from {
    left: 0;
  }

  to {
    left: -1374px;
  }
}

@keyframes moveLeft-cp-sp {
  from {
    left: 0;
  }

  to {
    left: -650.8421053px;
  }
}

.p-area__bg-cp {
  height: 95px;
  margin-top: 9px;
  background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_cp.png");
  background-image: -webkit-image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_cp.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_cp@2x.png") 2x);
  background-image: image-set(url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_cp.png") 1x, url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_text_cp@2x.png") 2x);
  animation: moveLeft-cp 27.48s linear infinite; /* アニメーション秒計算 1374/50x1s */
}


a {
  color: #0099CC;
  text-decoration: underline;
}

.p-content {
  padding: 30px 0 60px;
  width: 100%;
  overflow: hidden;
}

.p-bg-grid {
  background: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/bg_grid.png") repeat left top;
}

.p-inner {
  box-sizing: border-box;
  width: 1000px;
  max-width: 100%;
  padding: 0 15px;
  margin: 0 auto;
}

.p-kv {
  z-index: 0;
  position: relative;
  width: 100%;
}

.p-kv__content {
  position: relative;
  width: 101.2371134021%;
  left: -12px;
  z-index: 0;
}

.p-kv__date {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
  margin: 0 auto;
  height: 46px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  font-size: 18px;
  font-weight: bold;
}

.p-kv__over {
  position: absolute;
  width: 107.2164948454%;
  left: -3.6082474227%;
  bottom: 10px;
  z-index: 1;
}

.p-kv__bg {
  position: absolute;
  width: 126.4948453608%;
  left: -13.1958762887%;
  top: 0;
  margin-top: 3.5567010309%;
  z-index: -1;
}

.p-emText {
  font-size: 24px;
  font-weight: bold;
  display: flex;
  justify-content: center;
  text-align: center;
  line-height: 1.4444444444;
}


.p-emText img {
  position: relative;
  width: auto;
  margin: 0 5px;
  vertical-align: middle;
  top: -0.1em;
}

.p-emText > span {
  position: relative;
  display: inline-block;
  padding: 0 10px;
}

.p-emText > span::before,
.p-emText > span::after {
  content: "";
  position: absolute;
  display: block;
  bottom: 0.2em;
  width: 2px;
  height: 30px;
  border-radius: 1px;
  background-color: #111;
  transform-origin: 50% 100%;
}

.p-emText > span::before {
  left: 0;
  transform: rotate(-30deg);
}

.p-emText > span::after {
  right: 0;
  transform: rotate(30deg);
}

.p-emText.is-large {
  line-height: 1.4444444444;
}

.p-emText.is-large span::before,
.p-emText.is-large span::after {
  bottom: 0.1em;
}

.p-appInfo {
  padding: 29px;
  border: 1px solid #ddd;
  margin-top: 20px;
}

.p-appInfo__title {
  margin-bottom: 10px;
}

.p-appInfo__title img {
  width: auto;
}

.p-appInfo__spLink {
  margin: 0 auto;
  margin-bottom: 20px;
  text-align: center;
}

.p-appInfo__spLink a img {
  height: 60px;
  width: auto;
}

.p-appInfo__links {
  display: flex;
  margin-top: 21px;
}

.p-appInfo__links img {
  width: auto;
}

.p-appInfo__links > a {
  display: block;
  margin-left: 10px;
}

.p-appInfo__links > a:first-child {
  margin-left: 0;
}

.p-appInfo__qr {
  width: 60px;
  margin-left: 25px;
}

.p-box {
  margin-top: 80px;
  border: 2px solid #111;
  background-color: #fff;
  padding: 50px 0;
  position: relative;
  z-index: 0;
}

.p-box__title {
  position: absolute;
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
  transform: translateY(-50%);
}

.p-box__title img {
  width: auto;
}

.p-box__inner {
  padding: 0 100px;
}

.p-box__footer {
  position: relative;
  z-index: 0;
  margin-top: 30px;
  padding-top: 5.3774560496%;
}

.p-box__footer::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  padding-bottom: 5.3774560496%;
  left: 0;
  top: 0;
  background: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/shape_tri.png") no-repeat center/100% auto;
}

.p-box__footer-label {
  position: relative;
  top: 0px;
  left: 0;
  margin: 0 auto;
  margin-top: -20px;
  margin-bottom: 10px;
  text-align: center;
}

.p-box__footer-label img {
  width: auto;
}

.p-description__title {
  margin-bottom: 15px;
  font-size: 18px;
  font-weight: bold;
  padding-left: 27px;
}

.p-description__title::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  position: relative;
  border: 2px solid #111;
  background-color: #FF9123;
  width: 17px;
  height: 17px;
  border-radius: 50%;
  margin-right: 8px;
  margin-top: -5px;
  margin-left: -27px;
}

.p-description + .p-description {
  margin-top: 30px;
}

.p-description p + ul {
  margin-top: 10px;
}

.p-entry {
  position: relative;
}

.p-entry__img {
  position: absolute;
  bottom: 0;
  right: 0;
}

.p-entry__img img {
  width: auto;
}

.p-entry__title {
  font-size: 24px;
  font-weight: bold;
  display: flex;
  justify-content: center;
  text-align: center;
  line-height: 1.4444444444;
}

.p-entry__title img {
  position: relative;
  width: auto;
  margin: 0 5px;
  vertical-align: middle;
  top: -0.1em;
}

.p-entry__title > span {
  position: relative;
  display: inline-block;
  padding: 0 10px;
}

.p-entry__title > span::before,
.p-entry__title > span::after {
  content: "";
  position: absolute;
  display: block;
  bottom: 0.2em;
  width: 2px;
  height: 30px;
  border-radius: 1px;
  background-color: #111;
  transform-origin: 50% 100%;
}

.p-entry__title > span::before {
  left: 0;
  transform: rotate(-30deg);
}

.p-entry__title > span::after {
  right: 0;
  transform: rotate(30deg);
}

.p-entry__btn {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 auto;
  margin-top: 20px;
  box-sizing: border-box;
  width: 370px;
  height: 82px;
  background-color: #FF9123;
  border: 2px solid #111;
  color: #FFF;
  font-weight: bold;
  font-size: 24px;
  border-radius: 41px;
  text-decoration: none;
}

.p-entry__btn::after {
  content: "";
  position: absolute;
  display: block;
  width: 26px;
  height: 26px;
  top: 0;
  bottom: 0;
  right: 28px;
  margin: auto 0;
  background: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/arrow_circle_right@2x.png") no-repeat center/contain;
}

.p-entry__attention {
  font-weight: bold;
  color: #F50028;
  margin-top: 20px;
  text-align: center;
  line-height: 1.6;
}

.p-entry__note {
  font-size: 14px;
  line-height: 1.6;
  margin-top: 20px;
}

.p-entry__anno {
  margin-top: 0;
  padding-right: 120px;
}

.p-entry__anno li {
  font-size: 14px;
  padding-left: 1em;
  line-height: 1.6;
}

.p-entry__anno li::before {
  content: "※";
  display: inline-block;
  margin-left: -1em;
  margin-right: 0;
}
.p-entry__text {
  margin-top: 15px;
  max-width: 600px;
}

.p-howto {
  position: relative;
  width: 100%;
  border: 2px solid #111111;
  background-color: #EBE3FF;
  z-index: 0;
  margin-top: 85px;
  padding: 55px 0 35px;
}

.p-howto__title {
  position: absolute;
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
  transform: translateY(-50%);
}

.p-howto__title img {
  width: auto;
}

.p-howto__img-ttl {
  max-width: 700px;
  width: 100%;
  margin: 0 auto;
}

.p-howto__subtitle--line {
  width: 100%;
  max-width: 620px;
  margin: 0 auto;
}

.p-howto__subtitle span {
  color: #F688BA;
}

.p-imgBox__ttl {
  text-align: center;
  font-size: 18px;
  margin-top: 20px;
  font-weight: bold;
}

.p-howto__inner {
  background-color: #fff;
  position: relative;
  border: 2px solid #111;
  width: calc(100% - 80px);
  margin: 0 auto;
}

.p-howto__inner::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100px;
  height: 40px;
  background-color: #EBE3FF;
  border-right: 2px solid #111111;
  border-bottom: 2px solid #111111;
}

.p-howto__inner + .p-howto__inner {
  margin-top: 40px;
}

.p-howto__label {
  position: absolute;
  left: -10px;
  top: -10px;
  width: 102px;
}

.p-howto__label img {
  width: auto;
}

.p-howto__box {
  position: relative;
  padding: 40px;
}
.p-howto__box:nth-child(3) {
  padding-bottom: 0;
}

.p-howto__box + .p-howto__box {
  border-top: 2px solid #111;
}
.p-howto__box + .p-howto__box:nth-last-child(1) {
  border-top: none;
}

.p-howto__box-img {
  position: absolute;
  bottom: 29px;
  right: 0;
  width: auto;
}

.p-howto__howtoimg {
  border: 1px solid #ddd;
  margin-top: 30px;
  padding: 30px;
}

.p-howto__howtoimg-inner {
  max-width: 590px;
  margin: 0 auto;
  display: flex;
  align-items: flex-start;
  justify-content: center;
}

.p-howto__howtoimg-title {
  text-align: center;
  font-size: 1.8rem;
  font-weight: bold;
  margin-bottom: 20px;
}

.p-howto__howtoimg-item {
  position: relative;
  text-align: center;
}

.p-howto__howtoimg-item + .p-howto__howtoimg-item {
  margin-left: 48px;
}

.p-howto__howtoimg-item + .p-howto__howtoimg-item::before {
  content: "";
  position: absolute;
  display: block;
  left: 1px;
  top: 100px;
  transform: translate(-100%, -50%);
  width: 52px;
  height: 52px;
  background: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/arrow_right.png") no-repeat center/contain;
}

.p-howto__footer {
  position: relative;
  z-index: 0;
  margin-top: 30px;
  padding-top: 5.3774560496%;
}

.p-howto__footer::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  padding-bottom: 5.3774560496%;
  left: 0;
  top: 0;
  background: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/shape_tri.png") no-repeat center/100% auto;
}

.p-howto__footer-img {
  position: relative;
  left: -3.9296794209%;
  width: 108.4798345398%;
}


/* Pontaランク -----------------------*/
.p-pontarank {
  position: relative;
  width: 100%;
  border: 2px solid #111111;
  background-color: #EBE3FF;
  z-index: 0;
  margin-top: 85px;
  padding: 55px 0 35px;
}
.p-pontarank__title {
  position: absolute;
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
  transform: translateY(-50%);
}
.p-pontarank__title img {
  width: auto;
}
.p-pontarank__inner {
  background-color: #fff;
  position: relative;
  border: 2px solid #111;
  width: calc(100% - 80px);
  margin: 0 auto;
}

.p-pontarank__inner::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100px;
  height: 40px;
  background-color: #EBE3FF;
  border-right: 2px solid #111111;
  border-bottom: 2px solid #111111;
}
.p-pontarank__box {
  position: relative;
  padding: 40px;
}
.p-pontarank__box:nth-child(3) {
  padding-bottom: 0;
}

.p-pontarank__box + .p-pontarank__box {
  border-top: 2px solid #111;
}
.p-pontarank__box + .p-pontarank__box:nth-last-child(1) {
  border-top: none;
}

.p-howto__box-img {
  position: absolute;
  bottom: 29px;
  right: 0;
  width: auto;
}

.p-pontarank__inner + .p-pontarank__inner {
  margin-top: 40px;
}

.p-pontarank .p-pontarank__inner::before {
  display: none;
}
.p-pontarank__wrap {
  max-width: 690px;
  width: 100%;
  margin: 0 auto;
}
.p-pontarank__text {
  margin: 30px auto 0;
  max-width: 720px;
  font-weight: bold;
}
.p-pontarank .p-entry__anno {
  padding-right: 0;
}
.p-pontarank__contentBox {
  background: #ffffff;
  border: 1px solid #DDDDDD;
  padding: 30px 40px;
  margin-top: 30px;
}
.p-pontarank__contentBox_bg {
  background: #F4F0FF;
  border: none;
}
.p-pontarank__contentBox_bg .p-pontarank__content__image {
  text-align: center;
}
.p-pontarank__contentBox_bg .p-pontarank__content__image img {
  max-width: 220px;
  width: 100%;
}
.p-pontarank__contentBox_bg .p-pontarank__content__text .u-bold {
  margin-bottom: 5px;
  display: inline-block;
}
.p-pontarank__subtitle {
  color: #F688BA;
  font-weight: bold;
  text-align: center;
  font-size: 18px;
  margin: 20px auto;
}
.p-pontarank__content__wrap {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
.p-pontarank__img-logo {
  max-width: 180px;
  width: 100%;
  margin: 30px auto;
}
.p-pontarank__img-ttl {
  max-width: 600px;
  width: 100%;
  margin: 30px auto;
}
.p-pontarank__subtitle {
  font-size: 20px;
  font-weight: bold;
  text-align: center;
  max-width: 220px;
  width: 100%;
  margin: 0 auto 30px;
}
.qr_txt {
  width: 100%;
  margin: 15px auto 5px;
  text-align: center;
  font-weight: bold;
}
.qr_img {
  text-align: center;
  margin: 0 auto;
  width: 100%;
}
.qr_img img {
  width: 100px;
}
.p-pontarank__content__text {
  max-width: 420px;
}
.p-pontarank__contentBox_bg .p-pontarank__content__text {
  max-width: 460px;
}

.p-pontarank__content__image {
  margin-left: 20px;
}


/* Pontaアプリ -----------------------*/
.p-pontaapp {
  position: relative;
  width: 100%;
  border: 2px solid #111111;
  background-color: #EBE3FF;
  z-index: 0;
  margin-top: 85px;
  padding: 55px 0 35px;
}
.p-pontaapp__title {
  position: absolute;
  margin: 0 auto;
  top: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
  text-align: center;
  transform: translateY(-50%);
}
.p-pontaapp__title img {
  width: auto;
}
.p-pontaapp__inner {
  background-color: #fff;
  position: relative;
  border: 2px solid #111;
  width: calc(100% - 80px);
  margin: 0 auto;
}

.p-pontaapp__inner::before {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100px;
  height: 40px;
  background-color: #EBE3FF;
  border-right: 2px solid #111111;
  border-bottom: 2px solid #111111;
}
.p-pontaapp__box {
  position: relative;
  padding: 40px;
}
.p-pontaapp__box:nth-child(3) {
  padding-bottom: 0;
}

.p-pontaapp__box + .p-pontaapp__box {
  border-top: 2px solid #111;
}
.p-pontaapp__box + .p-pontaapp__box:nth-last-child(1) {
  border-top: none;
}

.p-pontaapp__box-img {
  position: absolute;
  bottom: 29px;
  right: 0;
  width: auto;
}

.p-pontaapp__inner + .p-pontaapp__inner {
  margin-top: 40px;
}

.p-pontaapp .p-pontaapp__inner::before {
  display: none;
}


.p-pontaapp .p-pontaapp__inner::before {
  display: none;
}
.p-pontaapp__wrap {
  max-width: 690px;
  width: 100%;
  margin: 0 auto;
}
.p-pontaapp .p-entry__anno {
  padding-right: 0;
}
.p-pontaapp__contentBox {
  background: #F4F0FF;
  padding: 35px 45px;
  margin-top: 20px;
}
.p-pontaapp .p-emText > span::before, 
.p-pontaapp .p-emText > span::after {
  height: 70px;
}
.p-pontaapp__img-ttl {
  max-width: 335px;
  width: 100%;
  margin: 40px auto -5px;
}
.p-pontaapp__content__wrap {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.p-pontaapp__subtitle {
  font-size: 18px;
  font-weight: bold;
  text-align: center;
}
.p-pontaapp__contentBox01 .p-pontaapp__content__left,
.p-pontaapp__contentBox04 .p-pontaapp__content__left {
  width: 400px;
}
.p-pontaapp__contentBox01 .p-pontaapp__content__left .p-pontaapp__subtitle,
.p-pontaapp__contentBox04 .p-pontaapp__content__left .p-pontaapp__subtitle {
  max-width: initial;
  margin-bottom: 10px;
  text-align: left;
}
.p-pontaapp__contentBox02 .p-pontaapp__content__wrap {
  align-items: flex-start;
}
.p-pontaapp__contentBox02 .p-pontaapp__content__right,
.p-pontaapp__contentBox02 .p-pontaapp__content__left {
  flex-basis: 46%;
  margin-top: 20px;
  text-align: center;
}
.p-pontaapp__contentBox02 .p-pontaapp__content__image {
  margin-left: 0;
}
.p-pontaapp__contentBox02 .p-pontaapp__txt {
  text-align: left;
  margin-top: 20px;
}
.p-pontaapp__contentBox03 .p-pontaapp__subtitle {
  margin-bottom: 20px;
}
.p-pontaapp__contentBox03 .p-pontaapp__content__left, 
.p-pontaapp__contentBox03 .p-pontaapp__content__center, 
.p-pontaapp__contentBox03 .p-pontaapp__content__right {
  background: #fff;
  flex-basis: 32%;
  min-height: 151px;
  padding: 20px;
}
.p-pontaapp__contentBox03 .p-pontaapp__content__image {
  margin: 0 auto 10px;
  text-align: center;
}
.p-pontaapp__contentBox5 {
  background: #fff;
  border: 1px solid #dddddd;
}
.p-pontaapp__contentBox5 .p-appInfo {
  border: none;
  background: #F4F0FF;
}
.p-pontaapp__contentBox5 .p-pontaapp__box {
  padding: 0;
}
.p-pontaapp__box .p-pontaapp__contentBox5 {
  padding: 0 30px 20px;
}
.p-pontaapp__box .p-pontaapp__contentBox5 .p-imgBox__img {
  max-width: 205px;
  width: 100%;
}
.p-pontaapp .p-accordion__body {
  position: relative;
  overflow: hidden;
}
.p-pontaapp .p-accordion__btn {
  margin-top: -90px;
}
.p-pontaapp .p-accordion__btn.is-open {
    margin-top: 28px;
}
.qr_txt {
  width: 100%;
  margin: 15px auto 5px;
  text-align: center;
  font-weight: bold;
}
.qr_img {
  text-align: center;
  margin: 0 auto;
  width: 100%;
}
.qr_img img {
  width: 100px;
}
.p-pontaapp__content__text {
  max-width: 420px;
}
.p-pontaapp__contentBox_bg .p-pontaapp__content__text {
  max-width: 460px;
}
.p-pontaapp__content__image {
  margin-left: 30px;
}

.p-imgBox {
  margin-top: 15px;
}

.p-imgBox__img img {
  width: auto;
}

.p-imgBox__bold {
  font-weight: bold;
  margin-bottom: 10px;
}

.p-imgBox hr {
  border-top: 1px solid #ddd;
  margin: 15px 0;
}

span.u-bold {
  font-weight: bold;
}
.u-red {
  color: red!important;
  font-weight: normal;
}

.u-mt-0 {
  margin-top: 0px;
}

.u-mb-0 {
  margin-bottom: 0px;
}

.u-mt-5 {
  margin-top: 5px;
}

.u-mb-5 {
  margin-bottom: 5px;
}

.u-mt-10 {
  margin-top: 10px;
}

.u-mb-10 {
  margin-bottom: 10px;
}

.u-mt-15 {
  margin-top: 15px;
}

.u-mb-15 {
  margin-bottom: 15px;
}

.u-mt-20 {
  margin-top: 20px;
}

.u-mb--5 {
  margin-bottom: -5px;
}
.u-mb--10 {
  margin-bottom: -10px;
}

.u-mb-20 {
  margin-bottom: 20px;
}

.u-mt-25 {
  margin-top: 25px;
}

.u-mb-25 {
  margin-bottom: 25px;
}

.u-mt-30 {
  margin-top: 30px;
}

.u-mb-30 {
  margin-bottom: 30px;
}

.u-mt-35 {
  margin-top: 35px;
}

.u-mb-35 {
  margin-bottom: 35px;
}

.u-mt-40 {
  margin-top: 40px;
}

.u-mb-40 {
  margin-bottom: 40px;
}

.u-mt-45 {
  margin-top: 45px;
}

.u-mb-45 {
  margin-bottom: 45px;
}

.u-mt-50 {
  margin-top: 50px;
}

.u-mb-50 {
  margin-bottom: 50px;
}
.u-bb {
  border-bottom: 1px solid #dddddd;
  display: block;
  margin: 20px auto;
}
.end_txt {
  margin: 20px auto;
  font-weight: bold;
  color: #FF0004;
  font-size: 180%;
  text-align: center;
}
#contents .btn_close {
  pointer-events: none;
  position: relative;
}
#contents .btn_close::before {
  content: "※本キャンペーンは終了しました";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: flex;
  align-items: center;
  justify-content: center;
  width: 105%;
  height: 120%;
  background-color: rgba(0, 0, 0, 0.7);
  margin: 0 auto;
  z-index: 10;
  color: #fff;
  font-size: 2.2rem;
  font-weight: bold;
}

@media screen and (min-width: 768px) {
  .p-accordion__btn::after {
    transition: transform 0.2s ease-in-out;
  }

  .p-accordion__btn:hover::after {
    transform: translateX(5px);
  }

  a:hover {
    text-decoration: none;
  }

  .p-emText.is-large span::before,
  .p-emText.is-large span::after {
    height: 70px;
  }

  .p-entry__btn::after {
    transition: transform 0.2s ease-in-out;
  }

  .p-entry__btn:hover::after {
    transform: translateX(5px);
  }

  .p-imgBox {
    margin-top: 20px;
    display: flex;
    align-items: flex-start;
  }

  .p-imgBox__text {
    width: 520px;
    flex-shrink: 1;
  }

  .p-imgBox__img {
    width: 33.3333333333%;
    text-align: right;
    flex-shrink: 0;
    margin-left: 15px;
  }

  .u-pc-none {
    display: none !important;
  }

  .u-pc-mt-0 {
    margin-top: 0px;
  }

  .u-pc-mb-0 {
    margin-bottom: 0px;
  }

  .u-pc-mt-5 {
    margin-top: 5px;
  }

  .u-pc-mb-5 {
    margin-bottom: 5px;
  }

  .u-pc-mt-10 {
    margin-top: 10px;
  }

  .u-pc-mb-10 {
    margin-bottom: 10px;
  }

  .u-pc-mt-15 {
    margin-top: 15px;
  }

  .u-pc-mb-15 {
    margin-bottom: 15px;
  }

  .u-pc-mt-20 {
    margin-top: 20px;
  }

  .u-pc-mb-20 {
    margin-bottom: 20px;
  }

  .u-pc-mt-25 {
    margin-top: 25px;
  }

  .u-pc-mb-25 {
    margin-bottom: 25px;
  }

  .u-pc-mt-30 {
    margin-top: 30px;
  }

  .u-pc-mb-30 {
    margin-bottom: 30px;
  }

  .u-pc-mt-35 {
    margin-top: 35px;
  }

  .u-pc-mb-35 {
    margin-bottom: 35px;
  }

  .u-pc-mt-40 {
    margin-top: 40px;
  }

  .u-pc-mb-40 {
    margin-bottom: 40px;
  }

  .u-pc-mt-45 {
    margin-top: 45px;
  }

  .u-pc-mb-45 {
    margin-bottom: 45px;
  }

  .u-pc-mt-50 {
    margin-top: 50px;
  }

  .u-pc-mb-50 {
    margin-bottom: 50px;
  }
}

@media screen and (max-width: 767px) {
  .p-accordion__btn::after {
    right: 20px;
  }
.p-accordion__body {
  height: 130px;
}
  .p-accordion__btn.is-open {
    margin-top: 20px;
  }
  .p-annotation span.u-bold {
    font-weight: bold;
  }

  .p-area__kv {
    top: -25px;
  }

  .p-area__bg-lane {
    width: 600%;
    transform-origin: 0 0;
    transform: scale(0.53846153846); /* 35/65 SPで表示したい高さ/画像の高さ */
  }

  .p-area__bg-howto {
    animation-name: moveLeft-howto-sp;
  }

  .p-area__bg-entry {
    animation-name: moveLeft-entry-sp;
  }

  .p-area__bg-detail {
    animation-name: moveLeft-detail-sp;
  }

  .p-area__bg-pontarank {
    animation-name: moveLeft-pontarank-sp;
  }
  .p-area__bg-pontaapp {
    animation-name: moveLeft-pontaapp-sp;
  }

  .p-area__bg-cp {
    transform: scale(0.4736842105) /* 45/95 */;
    margin-top: 45px;
    animation-name: moveLeft-cp-sp;
  }

  .breadcrumb {
    flex-wrap: nowrap;
    white-space: nowrap;
    overflow-x: auto;
  }

  .breadcrumb::-webkit-scrollbar {
    display: none;
  }

  .p-content {
    padding: 0 0 60px;
  }

  .p-inner.is-onlyPC {
    padding: 0;
    width: auto;
  }

  .p-kv__content {
    width: 100%;
    left: 0;
    margin-top: -18px;
  }

  .p-kv__date {
    display: flex;
    flex-direction: column;
    font-size: 3.7333333333vw;
    gap: 0;
    height: 18.6666666667vw;
    line-height: 1.6;
    padding-top: 10px;
  }

  .p-emText {
    font-size: 18px;
  }

  .p-emText img {
    width: 108px;
    margin: 0 4px;
  }

  .p-emText > span::before,
  .p-emText > span::after {
    height: 50px;
  }

  .p-emText.is-large {
    font-size: 14px;
  }

  .p-emText.is-large > span {
    padding: 0 5px;
  }

  .p-appInfo {
    padding: 20px;
  }

  .p-appInfo__title {
    margin-bottom: 20px;
  }

  .p-box {
    margin-top: 68px;
    padding: 30px 20px;
  }

  .p-box__title {
    max-width: 375px;
  }

  .p-box__inner {
    padding: 0 15px;
  }

  .p-box__footer {
    margin-top: 14px;
    padding-top: 8.5333333333vw;
  }

  .p-box__footer::before {
    padding-bottom: 8.5333333333vw;
    background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/shape_tri_sp.png");
  }

  .p-box__footer-label {
    width: 102px;
    margin-top: -30px;
  }

  .p-description__title {
    font-size: 16px;
    margin-bottom: 10px;
  }

  .p-description__title::before {
    width: 15px;
    height: 15px;
    margin-left: -25px;
  }

  .p-description + .p-description {
    margin-top: 20px;
  }

  .p-entry__title {
    font-size: 18px;
  }

  .p-entry__title img {
    width: 108px;
    margin: 0 4px;
  }

  .p-entry__title > span::before,
  .p-entry__title > span::after {
    height: 50px;
  }

  .p-entry__btn {
    font-size: 18px;
    width: 285px;
    height: 60px;
    margin-top: 10px;
  }

  .p-entry__btn::after {
    width: 18px;
    height: 18px;
    right: 20px;
  }

  .p-entry__attention {
    margin-top: 15px;
  }

  .p-entry__anno {
    padding: 0;
  }
 .p-entry__text {
  max-width: initial;
 } 

  .p-howto {
    margin-top: 67px;
    padding: 40px 0 30px;
  }

  .p-howto__title {
    max-width: 375px;
  }

  .p-howto__subtitle {
    font-size: 16px;
    max-width: 490px;
  }
  .p-imgBox__ttl {
    font-size: 16px;
  }
   span.u-bold {
    font-weight: normal;
  }


  .p-howto__inner {
    width: calc(100% - 26px);
  }

  .p-howto__inner::before {
    width: 67px;
    height: 22px;
  }

  .p-howto__label {
    top: -14px;
    left: -4px;
    width: 67px;
  }

  .p-howto__box {
    padding: 40px 15px;
  }

  .p-howto__box:nth-child(3) {
    padding-bottom: 0;
    margin-bottom: -23px;
}

  .p-howto__howtoimg {
    margin-top: 20px;
    padding: 20px;
  }
  .p-howto__howtoimg-inner {
    display: block;
  }
  .p-howto__howtoimg-title {
    font-size: 1.6rem;
    margin-bottom: 16px;
  }
  .p-howto__howtoimg-item + .p-howto__howtoimg-item {
    margin: 0 auto;
    margin-top: 60px;
  }
  .p-howto__howtoimg-item + .p-howto__howtoimg-item::before {
    left: 50%;
    top: -11px;
    width: 42px;
    height: 42px;
    transform: translate(-50%, -100%);
    background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/arrow_bottom.png");
  }
  .p-howto__footer {
    margin-top: 14px;
    padding-top: 8.5333333333vw;
  }

  .p-howto__footer::before {
    padding-bottom: 8.5333333333vw;
    background-image: url("https://pntc.sslcs.cdngc.net/cdn/campaign/app_login202506/img/shape_tri_sp.png");
  }
  .p-howto__footer-img {
    width: 100vw;
    left: -4.6666666667vw;
    margin-bottom: -20px;
  }
  .p-howto__subtitle--line {
    margin: 0 auto -5px;
  }
    .p-howto__howtoimg-item {
        max-width: 420px;
        margin: 20px auto;
    }
  .p-imgBox__text img {
    max-width: 490px;
    margin: 0 auto;
    width: 100%;
    display: block;
  }
     .p-appInfo__title {
        text-align: center;
        max-width: 290px;
    }
    .end_txt {
      font-size: 150%;
    }
    #contents .btn_close::before {
      font-size: 1.8rem;
    }

  /* Pontaランク------------------------------------- */
    .p-pontarank {
    margin-top: 67px;
    padding: 40px 0 30px;
  }
  .p-pontarank__title {
    max-width: 375px;
  }
    .p-pontarank__inner {
    width: calc(100% - 26px);
  }
  .p-pontarank__inner::before {
    width: 67px;
    height: 22px;
  }
  .p-pontarank__box {
    padding: 40px 15px;
  }
  .p-pontarank__box:nth-child(3) {
    padding-bottom: 0;
    margin-bottom: -23px;
}
  .p-pontarank .p-pontarank__box {
    padding: 30px 15px;
  }
  .p-pontarank .p-p-emText__title > span::before, 
  .p-pontarank .p-p-emText__title > span::after {
    height: 48px;
  }
  .p-pontarank .p-p-emText__title img {
    width: 100%;
    margin: 0 auto;
  }
  .p-pontarank__contentBox {
    padding: 20px;
    margin-top: 20px;
  }
  .p-pontarank__title {
    font-size: 16px;
    max-width: initial;
    margin-bottom: 20px;
  }
  .p-pontarank__subtitle {
    font-size: 14px;
    margin: 10px auto;
  }
  .p-pontarank__content__wrap {
    flex-direction: column;
  }
  .p-pontarank__img-logo {
  max-width: 250px;
  margin: 20px auto;
}
.p-pontarank__img-ttl {
  max-width: initial;
  margin: 20px auto;
}
  .qr {
    display: none;
  }
  .p-pontarank__content__text span.u-bold {
    font-weight: bold;
  }
  .p-pontarank__content__text {
    max-width: initial;
  }
  .p-pontarank__content__image {
    margin: 20px auto;
    text-align: center;
    width: 100%;
    min-width: initial;
  }
  .p-pontarank__img-ttl {
    max-width: 490px;
  }
    .p-pontarank__content__txt {
    font-size: 14px;
  }
  .p-pontarank .p-pontarank__content__text {
      font-feature-settings: "palt";
  letter-spacing: 0.05em;
  }
  .p-pontarank__content__image {
    max-width: 490px;
  }
  .p-pontarank__title {
    max-width: 490px;
  }
  .p-pontarank__contentBox_bg .p-pontarank__content__text {
    max-width: initial;
  }


   /* Pontaアプリ------------------------------------- */
 .p-pontaapp {
    margin-top: 67px;
    padding: 40px 0 30px;
  }

  .p-pontaapp__title {
    max-width: 375px;
  }
  .p-pontaapp__inner {
    width: calc(100% - 26px);
  }

  .p-pontaapp__inner::before {
    width: 67px;
    height: 22px;
  }
  .p-pontaapp__box {
    padding: 40px 15px;
  }

  .p-pontaapp__box:nth-child(3) {
    padding-bottom: 0;
    margin-bottom: -23px;
}
  .p-pontaapp {
    padding: 40px 0 10px;
  }
    .p-pontaapp .p-pontaapp__box {
    padding: 30px 15px 40px;
  }
  .p-pontaapp .p-pontaapp__title {
    max-width: 230px;
 }
  .p-pontaapp .p-emText > span::before, 
  .p-pontaapp .p-emText > span::after {
    height: 75px;
  }
    .p-pontaapp .p-emText > span::before {
      transform: rotate(-12deg);
  }
    .p-pontaapp .p-emText > span::after {
      transform: rotate(12deg);
  }
  .p-pontaapp  .p-emText > span {
    padding: 0;
  }

  .p-pontaapp__contentBox01 .p-pontaapp__content__left,
  .p-pontaapp__contentBox04 .p-pontaapp__content__left {
    width: 100%;
  }
  .p-pontaapp__contentBox01 .p-pontaapp__content__left .p-pontaapp__subtitle,
  .p-pontaapp__contentBox04 .p-pontaapp__content__left .p-pontaapp__subtitle {
    text-align: center;
  }
  .p-pontaapp__contentBox02 .p-pontaapp__txt {
    margin-top: 5px;
  }
  .p-pontaapp__contentBox02 .p-pontaapp__content__left {
    margin-bottom: 20px;
  }
  .p-pontaapp__contentBox03 .p-pontaapp__content__left, 
.p-pontaapp__contentBox03 .p-pontaapp__content__center {
 margin-bottom: 15px;
}
  .p-pontaapp__contentBox03 .p-pontaapp__content__left, 
  .p-pontaapp__contentBox03 .p-pontaapp__content__right, 
.p-pontaapp__contentBox03 .p-pontaapp__content__center {
 padding: 15px 20px;
 min-height: 145px;
}
.p-pontaapp__contentBox5 .p-appInfo {
  background: none;
  padding: 0;
}
.p-howto__box .p-pontaapp__contentBox5 {
  padding: 5px 20px 20px;
}
  .p-pontaapp__content__image {
    margin: 0 auto;
  }
  .p-pontaapp .p-emText img {
    width: 100%;
    margin: 0 auto;
  }
  .p-pontaapp__title {
    font-size: 16px;
  }
  .p-pontaapp__contentBox {
    padding: 30px 20px;
    margin-top: 20px;
  }

  .p-pontaapp__subtitle {
    font-size: 16px;
    margin: 10px auto;
  }
  .p-pontaapp__content__wrap {
    flex-direction: column;
  }
  .p-pontaapp__img-logo {
  max-width: 280px;
  margin: 20px auto;
}
.p-pontaapp__img-ttl {
  max-width: initial;
  margin: 20px auto 0;
}
  .qr {
    display: none;
  }
  .p-pontaapp__content__text span.u-bold {
    font-weight: bold;
  }

    .p-pontaapp__content__txt {
    font-size: 14px;
  }
  .p-pontaapp__img-ttl {
    max-width: 490px;
  }
  
  .p-pontaapp__contentBox02 .p-pontaapp__content__right, 
  .p-pontaapp__contentBox02 .p-pontaapp__content__left {
  flex-basis: initial;
  width: 100%;
  max-width: 490px;
  margin: 0 auto;
}
  .p-pontaapp__contentBox02 .p-pontaapp__content__left {
  margin: 20px auto 35px;
}
.p-pontaapp__contentBox03 .p-pontaapp__content__left,
.p-pontaapp__contentBox03 .p-pontaapp__content__center,
.p-pontaapp__contentBox03 .p-pontaapp__content__right {
  flex-basis: initial;
  width: 100%;
}
.p-pontaapp__contentBox03 .p-pontaapp__content__image {
  max-width: 390px;
}

.p-pontaapp__contentBox04 .p-pontaapp__txt {
  margin-top: 5px;
}

.p-pontaapp__box .p-pontaapp__contentBox5 .p-pontaapp__box {
  padding: 0;
}
  .p-area .p-box__inner {
    padding: 0;
  }
  .u-sp-none {
    display: none !important;
  }

  .u-sp-mt-0 {
    margin-top: 0px;
  }

  .u-sp-mb-0 {
    margin-bottom: 0px;
  }

  .u-sp-mt-5 {
    margin-top: 5px;
  }

  .u-sp-mb-5 {
    margin-bottom: 5px;
  }

  .u-sp-mt-10 {
    margin-top: 10px;
  }

  .u-sp-mb-10 {
    margin-bottom: 10px;
  }

  .u-sp-mt-15 {
    margin-top: 15px;
  }

  .u-sp-mb-15 {
    margin-bottom: 15px;
  }

  .u-sp-mt-20 {
    margin-top: 20px;
  }

  .u-sp-mb-20 {
    margin-bottom: 20px;
  }

  .u-sp-mt-25 {
    margin-top: 25px;
  }

  .u-sp-mb-25 {
    margin-bottom: 25px;
  }

  .u-sp-mt-30 {
    margin-top: 30px;
  }

  .u-sp-mb-30 {
    margin-bottom: 30px;
  }

  .u-sp-mt-35 {
    margin-top: 35px;
  }

  .u-sp-mb-35 {
    margin-bottom: 35px;
  }

  .u-sp-mt-40 {
    margin-top: 40px;
  }

  .u-sp-mb-40 {
    margin-bottom: 40px;
  }

  .u-sp-mt-45 {
    margin-top: 45px;
  }

  .u-sp-mb-45 {
    margin-bottom: 45px;
  }

  .u-sp-mt-50 {
    margin-top: 50px;
  }

  .u-sp-mb-50 {
    margin-bottom: 50px;
  }
}


/* PC画面小～タブレット調整ーーーーーーーーーーーーーーーーーーーー */
@media screen and (max-width: 1000px) and (min-width: 768px) {
  .p-kv__date {
    height: 4.6vw;
  }
}
@media screen and (max-width: 960px) and (min-width: 768px) {
  .p-mainichidouga__content__wrap {
    align-items: center;
}
.p-pontarank__content__image img {
  min-width: 200px;
  width: 100%;
}
.p-pontarank__contentBox_bg .p-pontarank__content__image img {
  min-width: 180px;
}
.p-pontaapp__contentBox03 .p-pontaapp__content__left,
.p-pontaapp__contentBox03 .p-pontaapp__content__center,
.p-pontaapp__contentBox03 .p-pontaapp__content__right {
  min-height: 183px;
}
.p-appInfo__qr {
    width: 60px;
    margin-left: 10px;
    min-width: 60px;
}
}
/* 「Pontaアプリとは？」最後のモック調整　PC画面小 */
@media screen and (max-width: 790px) and (min-width: 768px) {
  .p-pontaapp__contentBox5 .p-imgBox__text {
  width: 100%;
}
}
@media screen and (max-width: 900px) {
  .p-howto__box-img,
  .p-entry__img {
    display: none;
  }
}

@media screen and (max-width: 835px) {
.p-appInfo__title {
  text-align: center;
  margin: 0 auto 20px;
}

.p-imgBox__text img {
  margin-top: 20px;
}
}