@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;600;700;800&;900display=swap");
.qx-mt5 {
  margin-top: 5px;
}

.qx-mt10 {
  margin-top: 10px;
}

.qx-mt15 {
  margin-top: 15px;
}

.qx-mt20 {
  margin-top: 20px;
}

.qx-mt25 {
  margin-top: 25px;
}

.qx-mt30 {
  margin-top: 30px;
}

.qx-mt35 {
  margin-top: 35px;
}

.qx-mt40 {
  margin-top: 40px;
}

.qx-mt45 {
  margin-top: 45px;
}

.qx-mt50 {
  margin-top: 50px;
}

.qx-mt55 {
  margin-top: 55px;
}

.qx-mt60 {
  margin-top: 60px;
}

.qx-mt65 {
  margin-top: 65px;
}

.qx-mt70 {
  margin-top: 70px;
}

.qx-mt75 {
  margin-top: 75px;
}

.qx-mt80 {
  margin-top: 80px;
}

.qx-mt85 {
  margin-top: 85px;
}

.qx-mt90 {
  margin-top: 90px;
}

.qx-mb5 {
  margin-bottom: 5px;
}

.qx-mb10 {
  margin-bottom: 10px;
}

.qx-mb15 {
  margin-bottom: 15px;
}

.qx-mb20 {
  margin-bottom: 20px;
}

.qx-mb25 {
  margin-bottom: 25px;
}

.qx-mb30 {
  margin-bottom: 30px;
}

.qx-mb35 {
  margin-bottom: 35px;
}

.qx-mb40 {
  margin-bottom: 40px;
}

.qx-mb45 {
  margin-bottom: 45px;
}

.qx-mb50 {
  margin-bottom: 50px;
}

.qx-mb55 {
  margin-bottom: 55px;
}

.qx-mb60 {
  margin-bottom: 60px;
}

.qx-mb65 {
  margin-bottom: 65px;
}

.qx-mb70 {
  margin-bottom: 70px;
}

.qx-mb75 {
  margin-bottom: 75px;
}

.qx-mb80 {
  margin-bottom: 80px;
}

.qx-mb85 {
  margin-bottom: 85px;
}

.qx-mb90 {
  margin-bottom: 90px;
}

@media (max-width: 768px) {
  .qx-spmt5 {
    margin-top: 1.28205vw;
  }
  .qx-spmt10 {
    margin-top: 2.5641vw;
  }
  .qx-spmt15 {
    margin-top: 3.84615vw;
  }
  .qx-spmt20 {
    margin-top: 5.12821vw;
  }
  .qx-spmt25 {
    margin-top: 6.41026vw;
  }
  .qx-spmt30 {
    margin-top: 7.69231vw;
  }
  .qx-spmt35 {
    margin-top: 8.97436vw;
  }
  .qx-spmt40 {
    margin-top: 10.25641vw;
  }
  .qx-spmt45 {
    margin-top: 11.53846vw;
  }
  .qx-spmt50 {
    margin-top: 12.82051vw;
  }
  .qx-spmt55 {
    margin-top: 14.10256vw;
  }
  .qx-spmt60 {
    margin-top: 15.38462vw;
  }
  .qx-spmt65 {
    margin-top: 16.66667vw;
  }
  .qx-spmt70 {
    margin-top: 17.94872vw;
  }
  .qx-spmt75 {
    margin-top: 19.23077vw;
  }
  .qx-spmt80 {
    margin-top: 20.51282vw;
  }
  .qx-spmt85 {
    margin-top: 21.79487vw;
  }
  .qx-spmt90 {
    margin-top: 23.07692vw;
  }
}

/* ------------------------------------
reset
------------------------------------*/
body {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "メイリオ", Meiryo, sans-serif;
  font-size: 14px;
  line-height: 1.35;
  letter-spacing: 0.01em;
  color: #1a1a1a;
  font-weight: 600;
}

@media (max-width: 768px) {
  body {
    font-size: 3.58974vw;
  }
}

@media (min-width: 769px) {
  body {
    min-width: 100%;
  }
}

h1,
h2,
h3,
h4,
h5,
p {
  margin: 0;
}

ul,
li {
  list-style: none;
}

a:hover,
button:hover {
  opacity: 0.4;
  transition: 0.5s ease-out;
}

img {
  max-width: 100%;
}

#contentMain * {
  box-sizing: border-box;
}

/* ------------------------------------
frame
------------------------------------*/
.o-header {
  border-bottom: 4px solid #2c3e8a;
}

@media (max-width: 768px) {
  .o-header {
    border-bottom: 0;
  }
}

.qx-kvcontent__frame {
  max-width: 680px;
  margin-inline: auto;
  padding-block: 25px;
}

@media (max-width: 768px) {
  .qx-kvcontent__frame {
    margin-inline: 5.12821vw;
    padding-block: 8.97436vw 10.25641vw;
  }
}

.qx-content__frame {
  max-width: 680px;
  margin-inline: auto;
  padding-block: 50px;
}

@media (max-width: 768px) {
  .qx-content__frame {
    margin-inline: 5.12821vw;
    padding-block: 10.25641vw 15.38462vw;
  }
}

/* ------------------------------------
unit
------------------------------------*/
.qx-note li {
  text-indent: -1em;
  margin-left: 1em;
  margin-top: 2px;
}

.qx-note--small {
  font-size: 11px;
}

@media (max-width: 768px) {
  .qx-note--small {
    font-size: 2.82051vw;
  }
}

.qx-apply__btn {
  color: #ffffff;
  text-align: center;
  font-size: 20px;
  margin-inline: auto;
  display: block;
  border-radius: 10px;
}

.qx-apply__btn--normal {
  background: url(/-/media/aeoncard/campaign/lp/jqcard/images/arrow_right.svg) no-repeat calc(100% - 17px) center, #FF8A24;
  min-width: 310px;
  width: 100%;
  padding-block: 10px;
}

@media (max-width: 768px) {
  .qx-apply__btn {
    font-size: 5.12821vw;
    border-radius: 2.5641vw;
  }
  .qx-apply__btn--normal {
    background: url(/-/media/aeoncard/campaign/lp/jqcard/images/arrow_right.svg) no-repeat calc(100% - vw(17)) center, #FF8A24;
    padding-block: 2.5641vw;
    max-width: 71.79487vw;
    min-width: 79.48718vw;
  }
}

.qx-title__h2 {
  font-size: 24px;
  padding: 8px 0 8px 12px;
  margin-bottom: 25px;
  border-left: 4px solid #d82d8b;
}

@media (max-width: 768px) {
  .qx-title__h2 {
    font-size: 5.89744vw;
    padding: 2.05128vw 0 2.30769vw 3.07692vw;
    margin-bottom: 7.69231vw;
    border-left: 1.28205vw solid #d82d8b;
  }
}

.qx-title__h3 {
  font-size: 20px;
  margin-bottom: 15px;
  font-weight: 800;
}

@media (max-width: 768px) {
  .qx-title__h3 {
    font-size: 5.12821vw;
    margin-bottom: 2.5641vw;
  }
}

.qx-txt__lead {
  font-weight: 800;
  text-align: center;
  font-size: 18px;
  margin-bottom: 20px;
  position: relative;
}

.qx-txt__lead--pink {
  color: #d82d8b;
}

.qx-txt__lead__line::before, .qx-txt__lead__line::after {
  content: "";
  width: 2px;
  background: #d82d8b;
  display: inline-block;
  position: absolute;
  top: 50%;
  height: 90%;
}

.qx-txt__lead__line::before {
  left: -10px;
  transform: translateY(-50%) rotate(140deg);
}

.qx-txt__lead__line::after {
  right: -10px;
  transform: translateY(-50%) rotate(40deg);
}

@media (max-width: 768px) {
  .qx-txt__lead {
    font-size: 4.61538vw;
    margin-bottom: 2.5641vw;
  }
  .qx-txt__lead::before, .qx-txt__lead::after {
    width: 0.25641vw;
  }
  .qx-txt__lead::before {
    left: -2.5641vw;
  }
  .qx-txt__lead::after {
    right: -2.5641vw;
  }
}

.qx-link {
  color: #015EC5;
  text-decoration: underline;
}

.qx-link.qx-link__icon--anchor::after {
  content: "";
  display: inline-block;
  width: 0.6em;
  height: 0.6em;
  border-top: 2px solid;
  border-right: 2px solid;
  transform: rotate(135deg);
  margin-bottom: 0.2em;
  margin-left: 0.2em;
}

.qx-color--red {
  color: #eb0015;
}

.qx-fontweight--bold {
  font-weight: 800;
}

.qx-flex {
  display: flex;
}

@media (max-width: 768px) {
  .qx-flex {
    flex-direction: column;
  }
}

.table_sp_overflow {
  margin-top: 30px;
}

.table_sp_overflow th {
  background-color: #FFF5FD;
}

.table_sp_overflow th:first-child,
.table_sp_overflow td:first-child {
  background-color: #FFF5FD;
}

.table_sp_overflow th,
.table_sp_overflow td {
  font-size: 12px;
  border: 1px solid #D82D8B;
  text-align: center;
}

.table_sp_overflow {
  overflow: hidden;
  overflow-x: scroll;
}

.table_sp_overflow table tr > th:first-of-type {
  width: 150px;
}

.table_sp_overflow table tr > td:first-of-type {
  width: 150px;
}

.table_sp_overflow table {
  table-layout: fixed;
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
}

.table_sp_overflow td,
.table_sp_overflow th {
  width: 150px;
  box-sizing: border-box;
  overflow: hidden;
  text-overflow: ellipsis;
  height: 36px;
}

.table_sp_overflow th:first-child,
.table_sp_overflow td:first-child {
  position: sticky;
  left: 0;
  text-align: center;
  right: 0px;
  width: 100px;
}

.table_sp_overflow th:first-child {
  z-index: 1;
}

.scroll-hint-icon {
  z-index: 3;
}

.table_sp_overflow .scroll-hint-icon {
  top: calc(50% - 40px);
  left: calc(50% - 60px);
}

/* ------------------------------------
kv
------------------------------------*/
.qx-kv {
  background: #CFE2F1;
  overflow: hidden;
}

.qx-kv__img01 {
  max-width: 610px;
  width: 100%;
}

.qx-kv__logos {
  text-align: center;
  margin-bottom: 25px;
}

.qx-kv__logos img {
  max-width: 300px;
}

.qx-kv__card {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 30px;
  margin-bottom: 35px;
}

.qx-kv__cardface {
  width: 240px;
}

.qx-kv__card__content {
  background: #ffffff;
}

.qx-kv__text {
  text-align: center;
}

.qx-kv__textinner {
  font-size: 36px;
  display: inline-block;
  padding: 0 20px;
  text-align: center;
  color: #d82d8b;
  font-weight: 800;
  position: relative;
}

.qx-kv__textinner::before, .qx-kv__textinner::after {
  content: "";
  width: 3px;
  background: #d82d8b;
  display: inline-block;
  position: absolute;
  top: 50%;
  height: 90%;
}

.qx-kv__textinner::before {
  left: 0;
  transform: translateY(-50%) rotate(140deg);
}

.qx-kv__textinner::after {
  right: 0;
  transform: translateY(-50%) rotate(40deg);
}

.qx-kv__content {
  position: relative;
  padding: 0 50px 25px;
  background: #ffffff;
  border-radius: 10px;
  margin-top: 50px;
  text-align: center;
}

.qx-kv__content__title {
  display: inline-block;
  font-size: 28px;
  color: #ffffff;
  text-align: center;
  background: #d82d8b;
  font-weight: 600;
  border-radius: 10px;
  padding: 8px 8px;
  transform: translateY(-50%);
  min-width: 360px;
}

.qx-kv__anchor {
  text-align: center;
  margin-top: 20px;
}

@media (max-width: 768px) {
  .qx-kv__logos {
    margin-bottom: 7.69231vw;
  }
  .qx-kv__logos img {
    max-width: 76.92308vw;
  }
  .qx-kv__card {
    gap: 5.12821vw;
    margin-bottom: 6.41026vw;
  }
  .qx-kv__cardface {
    width: 42.05128vw;
  }
  .qx-kv__textinner {
    font-size: 7.17949vw;
    padding: 0 4.61538vw;
  }
  .qx-kv__textinner::before, .qx-kv__textinner::after {
    content: "";
    width: 0.76923vw;
  }
  .qx-kv__content {
    padding: 0 5.12821vw 6.41026vw;
    background: #ffffff;
    border-radius: 2.5641vw;
    margin-top: 14.10256vw;
  }
  .qx-kv__content__title {
    font-size: 7.17949vw;
    border-radius: 2.5641vw;
    padding: 1.79487vw;
    min-width: 79.48718vw;
  }
  .qx-kv__date {
    flex-direction: column;
    gap: 2.5641vw;
    margin-block: 5.12821vw;
  }
  .qx-kv__dateitem {
    border-radius: 5.12821vw;
    width: 100%;
  }
  .qx-kv__dateitem__left {
    padding: 1.79487vw 2.5641vw;
  }
  .qx-kv__dateitem__right {
    font-size: 3.33333vw;
    padding-inline: 2.5641vw 0;
  }
  .qx-kv__anchor {
    text-align: right;
    margin-top: 3.58974vw;
  }
}

/* ------------------------------------
qx-period
------------------------------------*/
.qx-period {
  background: #d82d8b;
  color: #ffffff;
  text-align: center;
}

.qx-period__h2 {
  font-size: 24px;
}

.qx-period__text {
  font-size: 16px;
}

.qx-period__link {
  margin-top: 15px;
}

.qx-period__link a {
  color: #ffffff;
  font-size: 12px;
}

.qx-period__frame {
  padding-block: 20px;
}

@media (max-width: 768px) {
  .qx-period__h2 {
    font-size: 6.15385vw;
  }
  .qx-period__text {
    font-size: 4.10256vw;
    margin-top: 0.51282vw;
  }
  .qx-period__link {
    text-align: right;
    margin-top: 0.51282vw;
  }
  .qx-period__link a {
    font-size: 3.07692vw;
  }
  .qx-period__frame {
    padding-block: 5.12821vw;
  }
}

/* ------------------------------------
qx-summary
------------------------------------*/
.qx-summary__condition {
  margin-block: 30px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}

.qx-summary__condition span {
  font-size: 26px;
  font-weight: 800;
  padding: 0 20px;
  background: #f3f8fb;
}

.qx-summary__condition::before {
  content: "";
  width: 100%;
  height: 2px;
  background: #1a1a1a;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  z-index: -1;
}

@media (max-width: 768px) {
  .qx-summary__condition {
    margin-block: 12.82051vw 6.41026vw;
  }
  .qx-summary__condition span {
    font-size: 6.66667vw;
    padding: 0 2.5641vw;
  }
}

.qx-summary__item {
  overflow: hidden;
  border: 2px solid #d82d8b;
  margin-block: 20px;
  background: #ffffff;
}

.qx-summary__itemlab {
  background: #d82d8b;
  color: #ffffff;
  text-align: center;
  font-weight: 600;
  padding: 3px;
  font-size: 20px;
}

.qx-summary__itemcont {
  padding: 20px 65px 30px;
}

.qx-summary__itemcont__txt {
  font-size: 16px;
  text-align: center;
  margin-bottom: 10px;
  font-weight: 600;
}

.qx-summary__itemcont__graph {
  text-align: center;
}

.qx-summary__itemparts {
  border-bottom: 2px solid #d82d8b;
  font-weight: 600;
  background: #FFF5FD;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.qx-summary__itemparts__left {
  padding-inline: 18px;
  color: #ffffff;
  background: #d82d8b;
  padding-block: 8px;
  position: relative;
}

.qx-summary__itemparts__left::after {
  content: "";
  display: inline-block;
  width: 0;
  height: 0;
  border-right: 20px solid transparent;
  border-bottom: 40px solid #d82d8b;
  position: absolute;
  right: 0;
  bottom: 0;
  transform: translateX(100%);
}

.qx-summary__item:last-of-type {
  margin-bottom: 0;
}

@media (max-width: 768px) {
  .qx-summary__item {
    margin-block: 3.84615vw;
    border: 0.76923vw solid #d82d8b;
  }
  .qx-summary__itemlab {
    padding: 0.76923vw;
    font-size: 5.12821vw;
  }
  .qx-summary__itemcont {
    padding: 6.41026vw 5.12821vw;
  }
  .qx-summary__itemcont__txt {
    font-size: 4.10256vw;
    margin-bottom: 2.5641vw;
  }
  .qx-summary__itemcont__graph {
    text-align: center;
  }
  .qx-summary__itemparts {
    border-bottom: 0.76923vw solid #d82d8b;
  }
  .qx-summary__itemparts__left {
    padding-block: 2.30769vw;
    padding-inline: 5.12821vw;
  }
  .qx-summary__itemparts__left::after {
    content: "";
    border-right: 5.12821vw solid transparent;
    border-bottom: 12.82051vw solid #d82d8b;
  }
}

@media (max-width: 768px) {
  .qx-summary__flow {
    width: 8.97436vw;
  }
}

/* ------------------------------------
qx-card
------------------------------------*/
.qx-card {
  background-color: #E7F1F8;
}

.qx-card__item {
  padding: 35px 20px;
  background: #ffffff;
}

.qx-card__item ~ .qx-card__item {
  margin-top: 20px;
}

.qx-card__item__inner {
  max-width: 310px;
  margin-inline: auto;
}

.qx-card__cardface {
  max-width: 240px;
  margin-top: 5px;
  margin-bottom: 20px;
}

.qx-card__logo {
  max-width: 38px;
}

@media (max-width: 768px) {
  .qx-card__item {
    padding: 7.69231vw 5.12821vw;
  }
  .qx-card__item ~ .qx-card__item {
    margin-top: 5.12821vw;
  }
  .qx-card__item__inner {
    max-width: 79.48718vw;
  }
  .qx-card__cardface {
    max-width: 63.58974vw;
    margin-top: 3.07692vw;
    margin-bottom: 5.12821vw;
  }
  .qx-card__logo {
    max-width: 9.74359vw;
  }
}

.qx-card-detail__btn {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-top: 15px;
  font-size: 16px;
}

.qx-card-detail__btn img {
  margin-left: 3px;
}

.qx-card__content {
  max-width: 274px;
  margin-inline: auto;
}

.qx-card__list {
  font-size: 16px;
  margin-top: 20px;
  font-weight: 600;
}

.qx-card__detail {
  margin-top: 20px;
  font-size: 12px;
}

.qx-card__detail th,
.qx-card__detail td {
  border: 1px solid #000;
  padding-top: 12px;
  padding-bottom: 12px;
  text-align: left;
}

.qx-card__detail th {
  width: 110px;
  padding: 15px 8px;
  background: #edebe4;
}

.qx-card__detail td {
  padding-inline: 10px;
  padding: 10px 10px 15px;
}

.qx-card__labcontent {
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 6px;
}

.qx-card__detail span {
  font-size: 12px;
  padding: 4px 5px;
  border-radius: 4px;
  display: inline-block;
  min-width: 63px;
  text-align: center;
}

.qx-card__lab01 {
  background: #edebe4;
  color: #77746d;
}

.qx-card__lab02 {
  background: #d8d5d0;
  color: #ffffff;
}

.qx-card__lab03 {
  background: #a6a298;
  color: #ffffff;
}

@media (max-width: 768px) {
  .qx-card-detail__btn {
    margin-top: 2.5641vw;
    font-size: 4.10256vw;
  }
  .qx-card-detail__btn img {
    margin-left: 0.76923vw;
  }
  .qx-card__content {
    max-width: 70.25641vw;
  }
  .qx-card__list {
    font-size: 4.10256vw;
    margin-top: 5.12821vw;
  }
  .qx-card__detail {
    margin-top: 5.12821vw;
    font-size: 3.07692vw;
  }
  .qx-card__detail th,
  .qx-card__detail td {
    padding-block: 3.84615vw;
  }
  .qx-card__detail th {
    width: 28.20513vw;
    padding-inline: 1.28205vw;
    background: #edebe4;
  }
  .qx-card__detail td {
    padding-inline: 2.05128vw;
  }
  .qx-card__labcontent {
    gap: 1.53846vw;
  }
  .qx-card__detail span {
    font-size: 3.07692vw;
    padding: 1.02564vw 1.28205vw;
    border-radius: 1.02564vw;
    display: inline-block;
    min-width: 16.15385vw;
  }
}

/* ------------------------------------
karute
------------------------------------*/
.rule__title {
  background-color: #e5e5e5;
  padding: 11px 20px;
  font-size: 18px;
  font-weight: 700;
  line-height: 1;
}

.rule__contents {
  margin-bottom: 40px;
}

.rule__texts {
  padding-top: 20px;
}

.tos_campaign-number-container {
  display: flex;
  justify-content: flex-end;
}

.tos_campaign-number {
  border: 1px solid #1a1a1a;
  padding: 4px 10px;
  font-size: 16px;
}

@media (max-width: 768px) {
  .rule__title {
    padding: 2.82051vw 5.12821vw;
    font-size: 4.61538vw;
    font-weight: 700;
    line-height: 1;
  }
  .rule__contents {
    margin-bottom: 10.25641vw;
  }
  .rule__texts {
    padding-top: 5.12821vw;
  }
  .rule p {
    font-size: 3.58974vw;
  }
  .tos_campaign-number {
    padding: 1.02564vw 2.5641vw;
    font-size: 4.10256vw;
  }
}

/* ------------------------------------
float
------------------------------------*/
.float-link__container {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: rgba(255, 255, 255, 0.8);
  z-index: 9;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.float-link__contents {
  margin-top: 10px;
  margin-bottom: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  gap: 15px;
}

.float-link__contents img {
  max-width: 240px;
}

.rule__table th {
  font-weight: normal;
  vertical-align: top;
  text-align: left;
}

@media (max-width: 768px) {
  .rule__table th {
    width: 23.07692vw;
  }
}

@media (min-width: 769px) {
  .float-link__contents {
    max-width: 600px;
  }
}

.float-top__container {
  position: fixed;
  bottom: 140px;
  right: 20px;
  width: 65px;
  z-index: 11;
}

@media (max-width: 768px) {
  .float-link__contents {
    margin-top: 2.5641vw;
    margin-bottom: 2.5641vw;
    gap: 2.5641vw;
  }
  .float-link__contents img {
    max-width: 43.58974vw;
  }
  .float-top__container {
    width: 45px;
    bottom: 110px;
    right: 15px;
  }
}
