@charset "UTF-8";
/*----------------------------------------------------------
  VARIABLES
----------------------------------------------------------*/
.special-content .box-note, .special-content .box-dl, .special-content .box-txt, .p-footer .btn-footer, .p-footer {
  font-family: Helvetica, "ゴシックMB101 M", "Gothic MB101 Medium", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}

.terms-accordion .accordion-head, .terms-head, .special-content .box-or span, .special-head .text, .txt-bold {
  font-family: Helvetica, "ゴシックMB101 DB", "Gothic MB101 DemiBold", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 600;
}

.special-content .box-subtitle {
  font-family: Helvetica, "ゴシックMB101 B", "Gothic MB101 Bold", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
}

/*----------------------------------------------------------
  MIXIN
----------------------------------------------------------*/
/*----------------------------------------------------------
  CUSTOM
----------------------------------------------------------*/
* {
  padding: 0;
  margin: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

.special-content .box-note, .special-content .box-dl, .special-content .box-txt, .p-footer .btn-footer, .p-footer {
  font-family: "ゴシックMB101 M", "Gothic MB101 Medium", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 500;
}

.terms-accordion .accordion-head, .terms-head, .special-content .box-or span, .special-head .text, .txt-bold {
  font-family: "ゴシックMB101 DB", "Gothic MB101 DemiBold", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 600;
}

.special-content .box-subtitle {
  font-family: "ゴシックMB101 B", "Gothic MB101 Bold", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-weight: 700;
}

html {
  font-size: 1rem;
}
@media (min-width: 769px) and (max-width: 1119px) {
  html {
    font-size: 1.4285714286vw;
  }
}
@media (max-width: 768px) {
  html {
    font-size: 2.1333333333vw;
  }
}

.page-amazon {
  --bright-red: #e60012;
  --yellow: #fff367;
  --bright-orange: #ef5431;
}
.page-amazon sup {
  line-height: 1;
}
.page-amazon img {
  max-width: 100%;
  height: auto;
  image-rendering: auto;
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transform-origin: 0 0;
          transform-origin: 0 0;
}
@media (max-width: 768px) {
  .page-amazon img {
    width: 100%;
  }
}
.page-amazon #wrapper {
  background-color: #fdedee;
}
.page-amazon a:focus:not(:active) {
  outline: -webkit-focus-ring-color auto 0.3125rem;
}
.page-amazon a:active {
  outline: none;
}

.p-container {
  position: relative;
}
@media (min-width: 769px) {
  .p-container {
    width: 60.625rem;
    margin: 0 auto;
  }
}

.txt-red {
  color: var(--bright-red);
}

.txt-orange {
  color: var(--bright-orange);
}

.txt-yellow {
  color: var(--yellow);
}

.note-list {
  list-style: none;
  font-size: 0.75rem;
  text-align: left;
}

@media (min-width: 769px) {
  .only-sp {
    display: none;
  }
}

@media (max-width: 768px) {
  .only-pc {
    display: none;
  }
}

/* HEADER
----------------------------- */
.header {
  position: relative;
  padding: 0.3125rem 0;
  background: url("../images/header_bg.jpg") top center no-repeat;
  background-size: cover;
  height: 5rem;
}
@media (max-width: 768px) {
  .header {
    background-image: url("../images/header_bg_sp.jpg");
    padding: 0 1.25rem;
    height: 5rem;
  }
}
.header .p-container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-flow: row wrap;
          flex-flow: row wrap;
  height: 100%;
}
.header .col-left {
  width: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.header .col-left img {
  width: 12.8125rem;
  margin-right: 0.3125rem;
}
@media (min-width: 769px) {
  .header .col-left img {
    margin-right: 1rem;
  }
}
.header .col-right {
  width: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.header .col-right .logo-02 {
  width: 15.375rem;
  margin-left: 1.25rem;
}
@media (min-width: 769px) {
  .header .col-right .logo-02 {
    margin-left: 5.375rem;
  }
}
@media (min-width: 769px) {
  .header-logo {
    display: block;
    width: 14.1875rem;
    margin: 0 auto;
  }
}
/* FOOTER
----------------------------- */
#footer {
  display: none !important;
}

.p-footer {
  position: relative;
  padding: 2.3125rem 0;
  height: 6.25rem;
  color: #fff;
  background-color: var(--bright-red);
}
@media (min-width: 769px) {
  .p-footer {
    padding: 1.625rem 0;
    height: 4.375rem;
  }
}
.p-footer .copy-right {
  letter-spacing: 0.05em;
  font-size: 1.25rem;
  text-align: center;
}
@media (min-width: 769px) {
  .p-footer .copy-right {
    font-size: 0.875rem;
  }
}
.p-footer .btn-footer {
  position: absolute;
  bottom: 8.4375rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  text-align: center;
  font-size: 1.25rem;
  color: var(--bright-red);
  width: 3.0625rem;
  height: 2.625rem;
  padding-top: 2.375rem;
  text-decoration: none;
  background: url(../images/btn_totop_sp.png) no-repeat;
  background-size: 100% auto;
}
@media (min-width: 769px) {
  .p-footer .btn-footer {
    font-size: 0.875rem;
    bottom: 5.75rem;
    width: 2.125rem;
    height: 2.625rem;
    padding-top: 1.625rem;
    background-image: url(../images/btn_totop.png);
  }
}

.title-page {
  text-align: center;
}
@media (min-width: 769px) {
  .title-page {
    height: 7.9375rem;
    background-color: #fff;
    margin-bottom: 2.375rem;
  }
  .title-page img {
    max-width: 60.625rem;
  }
}
@media (max-width: 768px) {
  .title-page {
    margin-bottom: 2.625rem;
  }
}

.special {
  background-color: #bceffa;
  padding-block: 0 2.5625rem;
  position: relative;
}
@media (max-width: 768px) {
  .special {
    padding-block: 0 6.25rem;
  }
}
@media (max-width: 768px) {
  .special .p-container {
    z-index: 1;
    padding-inline: 1.875rem;
  }
}
.special-head .text {
  margin-top: 1.875rem;
  font-size: 1.5rem;
  color: #179fd8;
  letter-spacing: 0.06em;
  text-align: center;
}
.special-head .text span {
  margin-left: 0.625rem;
  font-size: 1.125rem;
}
@media (max-width: 768px) {
  .special-head .text {
    font-size: 2.25rem;
    line-height: 1.3333333333;
  }
  .special-head .text span {
    display: block;
    margin-top: 0.4375rem;
    margin-left: 0;
    font-size: 1.5rem;
  }
}
.special-content {
  margin-top: 1.75rem;
}
@media (max-width: 768px) {
  .special-content {
    margin-top: 1.75rem;
  }
}
.special-content .box {
  background-color: #fff;
  border-radius: 1.875rem;
}
@media (min-width: 769px) {
  .special-content .box {
    padding: 1.6875rem 10.3125rem 1.875rem;
  }
}
@media (max-width: 768px) {
  .special-content .box {
    padding: 3rem 1.875rem 3.125rem;
  }
}
.special-content .box-inner {
  margin-inline: auto;
}
@media (max-width: 768px) {
  .special-content .box-title {
    max-width: 36.25rem;
    margin-inline: auto;
  }
}
.special-content .box-subtitle {
  font-size: 1.5rem;
  line-height: 2.1666666667;
  letter-spacing: 0.06em;
  text-align: center;
}
@media (max-width: 768px) {
  .special-content .box-subtitle {
    margin-top: 0.25rem;
    font-size: 1.875rem;
    line-height: 1.7333333333;
  }
}
.special-content .box-img {
  margin-top: 0.3125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media (min-width: 769px) {
  .special-content .box-img {
    margin-inline: -0.0625rem;
  }
  .special-content .box-img.--img01 {
    margin-bottom: 1.125rem;
  }
  .special-content .box-img.--img02 {
    margin-top: 1.125rem;
    margin-bottom: 1.125rem;
  }
  .special-content .box-img.--img03 {
    margin-top: 0.8125rem;
    margin-right: -1.5625rem;
  }
}
@media (max-width: 768px) {
  .special-content .box-img {
    margin-top: 1.6875rem;
    margin-right: -0.25rem;
  }
  .special-content .box-img.--img01 {
    margin-bottom: 1.375rem;
  }
  .special-content .box-img.--img02 {
    margin-top: 2.3125rem;
    margin-bottom: 1.375rem;
  }
  .special-content .box-img.--img03 {
    margin-top: 0.0625rem;
    margin-left: 3.4375rem;
    max-width: 36.9375rem;
  }
}
.special-content .box-txt {
  font-size: 0.875rem;
  line-height: 1.5;
  letter-spacing: 0.06em;
  color: #000;
}
@media (max-width: 768px) {
  .special-content .box-txt {
    font-size: 1.5rem;
    line-height: 1.5625;
  }
}
.special-content .box-dl {
  font-size: 0.625rem;
  line-height: 1.5;
  color: #747474;
  letter-spacing: 0.06em;
  font-weight: 500;
}
@media (max-width: 768px) {
  .special-content .box-dl {
    font-size: 1rem;
    line-height: 1.5625;
  }
}
.special-content .box-dl.box-dl01 {
  font-size: 0.875rem;
  line-height: 1.5;
}
@media (max-width: 768px) {
  .special-content .box-dl.box-dl01 {
    font-size: 1.5rem;
    line-height: 1.5;
  }
}
.special-content .box-dl.box-dl02 {
  margin-top: 0.5rem;
}
@media (max-width: 768px) {
  .special-content .box-dl.box-dl02 {
    margin-top: 0;
  }
}
.special-content .box-note {
  font-size: 0.625rem;
  line-height: 1.5;
  color: #747474;
  letter-spacing: 0.06em;
}
@media (max-width: 768px) {
  .special-content .box-note {
    margin: 1.25rem 1.875rem 0 1.875rem;
    font-size: 1rem;
    line-height: 1.5625;
    letter-spacing: 0.06em;
  }
}
.special-content .box-note.--center {
  text-align: center;
}
.special-content .box-or {
  position: relative;
  background: url("../images/special_bg_dot.png") repeat-x left center/0.5625rem;
  text-align: center;
  margin-top: 0.875rem;
}
@media (max-width: 768px) {
  .special-content .box-or {
    margin-top: 1.125rem;
  }
}
.special-content .box-or span {
  display: inline-block;
  background-color: #fff;
  padding-inline: 10px;
  font-size: 1.75rem;
  letter-spacing: 0.06em;
  color: #179fd8;
}
@media (max-width: 768px) {
  .special-content .box-or span {
    font-size: 2.5rem;
  }
}
.special-content .box-button {
  max-width: 32.5625rem;
  margin-top: 1rem;
  margin-inline: auto;
  display: block;
}
@media (min-width: 769px) {
  .special-content .box-button--02 {
    margin-top: 1rem;
  }
}
@media (max-width: 768px) {
  .special-content .box-button {
    max-width: inherit;
    margin-top: 1.375rem;
  }
  .special-content .box-button--02 {
    margin-top: 1.5rem;
  }
}
.special-content .box.--box01 {
  margin-bottom: 5rem;
  position: relative;
}
@media (max-width: 768px) {
  .special-content .box.--box01 {
    margin-bottom: 9.125rem;
  }
}
.special-content .box.--box01:after {
  content: "";
  position: absolute;
  bottom: -4.0625rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 3.0625rem;
  height: 3.0625rem;
  background: url("../images/special_ico_plus.png") no-repeat center/100% 100%;
}
@media (max-width: 768px) {
  .special-content .box.--box01:after {
    width: 5.5rem;
    height: 5.5rem;
    bottom: -7.5rem;
  }
}
.special-content .box.--box02 {
  padding-block: 1.625rem 1.5625rem;
}
@media (max-width: 768px) {
  .special-content .box.--box02 {
    padding: 3rem 0 3.25rem;
  }
}
.special-content .box.--box02 .box-note {
  position: relative;
}
@media (min-width: 769px) {
  .special-content .box.--box02 .box-note {
    margin-inline: 7.1875rem -1.5625rem;
    margin-top: -0.75rem;
  }
}
.special-note {
  text-align: center;
  font-size: 0.625rem;
  color: #179fd8;
  margin-top: 1.625rem;
  letter-spacing: 0.04em;
}
@media (max-width: 768px) {
  .special-note {
    font-size: 1rem;
    line-height: 1.5;
    margin-top: 2.375rem;
  }
}
.special .btn-block {
  margin-top: 2.1875rem;
}
@media (max-width: 768px) {
  .special .btn-block {
    margin-top: 4rem;
  }
}
.special.--other:before {
  background-color: #dcf7d8;
}

/* TERMS SECTION
----------------------------- */
.terms-head {
  font-size: 2.25rem;
  text-align: center;
  letter-spacing: 0.06em;
  color: #1f2d58;
}
.terms-head:after {
  content: "";
  display: block;
  margin: 1.125rem auto 0;
  width: 18.75rem;
  border-bottom: 0.25rem solid var(--bright-red);
}
@media (min-width: 769px) {
  .terms-head {
    font-size: 1.5rem;
  }
  .terms-head:after {
    content: "";
    display: block;
    margin: 0.625rem auto 0;
    width: 11.25rem;
    border-bottom: 0.1875rem solid var(--bright-red);
  }
}

.terms-sec {
  background-color: #fff;
  padding: 2.5rem 0 6.8125rem;
  font-family: "ゴシックMB101 M", "Gothic MB101 Medium", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
@media (max-width: 768px) {
  .terms-sec {
    padding: 6.25rem 1.875rem 9.8125rem;
  }
}
.terms-sec p, .terms-sec li {
  font-size: 0.8125rem;
  line-height: 1.5384615385;
  letter-spacing: 0.1em;
}
@media (min-width: 769px) {
  .terms-sec p, .terms-sec li {
    font-size: 0.875rem;
    line-height: 1.5;
  }
}
.terms-sec .txt-01 {
  padding-left: 1em;
}
.terms-sec .txt-01:is(ul) {
  padding-left: 2em;
}
.terms-sec .terms-txt {
  font-family: "ゴシックMB101 M", "Gothic MB101 Medium", "A-OTF Gothic MB101 Pro", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  margin: 1.625rem 0 1.5rem;
  text-align: center;
  color: #1f2d58;
}
@media (max-width: 768px) {
  .terms-sec .terms-txt {
    margin: 3.5rem 0rem 2.3125rem;
    font-size: 1.5rem;
    line-height: 1.5;
  }
}
.terms-sec .terms-accordion .rect-list {
  list-style: none;
}
.terms-sec .terms-accordion .rect-list li {
  position: relative;
}
@media (max-width: 768px) {
  .terms-sec .terms-accordion .rect-list li {
    word-break: break-word;
  }
}
.terms-sec .terms-accordion .rect-list li:before {
  content: "■";
  display: inline-block;
  margin-right: 0.4375rem;
  position: absolute;
  top: 0;
  left: 0;
  line-height: 2.25rem;
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion .rect-list li:before {
    line-height: 1.3125rem;
  }
}
.terms-sec .terms-accordion .rect-list li + li {
  margin-top: 2.25rem;
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion .rect-list li + li {
    margin-top: 1.3125rem;
  }
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion .rect-list li {
    font-size: 0.875rem;
    line-height: 1.5;
  }
}
@media (max-width: 768px) {
  .terms-sec .terms-accordion .rect-list li {
    padding-left: 1.5625rem;
    font-size: 1.5rem;
    line-height: 1.5;
  }
}
.terms-sec .terms-accordion .circle-list {
  list-style: none;
}
.terms-sec .terms-accordion .circle-list li:before {
  content: "⚫︎";
  display: inline-block;
  margin-right: 0.4375rem;
  font-size: 1.125rem;
}
@media (max-width: 768px) {
  .terms-sec .terms-accordion .circle-list li:before {
    position: relative;
    top: 0.1875rem;
  }
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion .circle-list li:before {
    margin: 0.125rem 0.5rem 0 0;
    font-size: 0.75rem;
  }
}
@media (max-width: 768px) {
  .terms-sec .terms-accordion .circle-list li {
    font-size: 1.5rem;
    line-height: 1.5;
  }
}
.terms-sec .terms-accordion .circle-list .txt-indent {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.terms-sec .terms-accordion .list__item + .list__item {
  margin-top: 2.25rem;
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion .list__item + .list__item {
    margin-top: 1.3125rem;
  }
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion h3 {
    font-size: 0.875rem;
    line-height: 1.5;
  }
}
@media (max-width: 768px) {
  .terms-sec .terms-accordion h3 {
    font-size: 1.5rem;
    line-height: 1.5;
  }
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion p {
    font-size: 0.875rem;
    line-height: 1.5;
  }
}
@media (max-width: 768px) {
  .terms-sec .terms-accordion p {
    font-size: 1.5rem;
    line-height: 1.5;
  }
}
.terms-sec .terms-accordion a {
  color: inherit;
  word-break: break-all;
}
.terms-sec .terms-accordion .mt36 {
  margin-top: 2.25rem;
}
@media (min-width: 769px) {
  .terms-sec .terms-accordion .mt36 {
    margin-top: 1.3125rem;
  }
}

.terms-accordion {
  width: 43.125rem;
  margin: 0 auto;
  border: solid 0.0625rem #666;
  background-color: #eee;
}
@media (min-width: 769px) {
  .terms-accordion {
    width: 60.625rem;
  }
}
.terms-accordion.is-open .accordion-head .icon-arrow {
  -webkit-transform: rotate(-180deg);
          transform: rotate(-180deg);
}
.terms-accordion button {
  width: 100%;
  background: transparent;
  border: none;
}
.terms-accordion .accordion-head {
  padding-block: 0.9375rem 0.6875rem;
  padding-left: 3.125rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: 1.125rem;
  line-height: 1;
  letter-spacing: 0.06em;
  color: #666;
}
@media (max-width: 768px) {
  .terms-accordion .accordion-head {
    padding: 1.8125rem 0 1.375rem 0.75rem;
    font-size: 1.75rem;
    line-height: 1;
  }
}
@media (min-width: 769px) {
  .terms-accordion .accordion-head:hover {
    cursor: pointer;
  }
}
.terms-accordion .accordion-head .icon-arrow {
  display: block;
  margin-left: 1.75rem;
  width: 1.4375rem;
  height: 0.9375rem;
  -webkit-transform: rotate(0deg);
          transform: rotate(0deg);
  background: url(../images/terms_arrow.png) center no-repeat;
  background-size: 100% auto;
  -webkit-transition: -webkit-transform 0.1s ease;
  transition: -webkit-transform 0.1s ease;
  transition: transform 0.1s ease;
  transition: transform 0.1s ease, -webkit-transform 0.1s ease;
}
@media (max-width: 768px) {
  .terms-accordion .accordion-head .icon-arrow {
    width: 2rem;
    height: 1.1875rem;
    margin-left: 1.25rem;
    background-image: url(../images/terms_arrow_sp.png);
  }
}
.terms-accordion .accordion-body {
  display: none;
}
.terms-accordion .accordion-inner {
  position: relative;
  padding: 1.625rem 3.75rem 2.3125rem;
}
@media (max-width: 768px) {
  .terms-accordion .accordion-inner {
    padding: 1.875rem 1.25rem 2rem 1.6875rem;
  }
}
.terms-accordion .accordion-inner:before {
  content: "";
  position: absolute;
  top: 0;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  width: 37.8125rem;
  height: 0.1875rem;
  background: url(../images/terms_dot.png) bottom left repeat-x;
  background-size: auto 100%;
}
@media (max-width: 768px) {
  .terms-accordion .accordion-inner:before {
    width: 39.375rem;
  }
}