@charset "UTF-8";
/* aタグ設定
------------------------------------- */
a, button {
  -webkit-transition-property: all;
  transition-property: all;
  -webkit-transition-duration: 0.3s;
          transition-duration: 0.3s;
  -webkit-transition-timing-function: ease;
          transition-timing-function: ease;
  -webkit-transition-delay: 0s;
          transition-delay: 0s;
  text-decoration: none;
  color: inherit;
}

/* 基本設定
------------------------------------- */
html {
  font-size: 62.5%;
  scroll-padding-top: 24vw;
}
@media screen and (min-width: 768px) {
  html {
    scroll-padding-top: 125px;
  }
}

body {
  -webkit-text-size-adjust: 100%;
  font-size: 1.4rem; /* =14px */
  font-family: "Noto sans JP", sans-serif;
}

ul {
  list-style: none;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
}

.privacy-link-container a {
  color: #0000FF;
  text-decoration: underline;
}

/* デフォルトの三角形アイコンを非表示にする */
summary {
  display: block;
  list-style: none;
}

summary::-webkit-details-marker,
summary::marker {
  display: none;
}

/* レスポンシブ設定
------------------------------------- */
.sp {
  display: none;
}
@media screen and (max-width: 768px) {
  .sp {
    display: block !important;
  }
}

@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
}
main {
  overflow: hidden;
}

.inner {
  padding-inline: 10px;
}

/* kv
------------------------------------- */
.kv {
  overflow: hidden;
  z-index: 1;
}

.top-line {
  position: absolute;
  top: 0;
  width: 100%;
  height: 3.0666666667vw;
  background: #810a19;
  z-index: 1;
}
@media screen and (min-width: 768px) {
  .top-line {
    height: 0.9722222222vw;
  }
}
@media screen and (min-width: 1440px) {
  .top-line {
    height: 14px;
  }
}

.kv-top__inner {
  max-width: 1440px;
  margin: 0 auto;
  padding-top: 13.7333333333vw;
  padding-bottom: 28vw;
  position: relative;
}
@media screen and (min-width: 768px) {
  .kv-top__inner {
    padding-top: 6.5277777778vw;
    padding-bottom: 2.0833333333vw;
  }
}
@media screen and (min-width: 1440px) {
  .kv-top__inner {
    padding-top: 94px;
    padding-bottom: 30px;
  }
}

.main-title {
  width: 53.0666666667vw;
  margin-left: 25.6vw;
}
@media screen and (min-width: 768px) {
  .main-title {
    width: 42.3611111111vw;
    margin-left: 30.9722222222vw;
  }
}
@media screen and (min-width: 1440px) {
  .main-title {
    width: 620px;
    margin-left: 446px;
  }
}

.confetti-center {
  position: absolute;
  width: 92vw;
  height: 35.3333333333vw;
  top: 30.1333333333vw;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .confetti-center {
    width: 75.8333333333vw;
    height: 24.4444444444vw;
    top: 16.7361111111vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-center {
    width: 1092px;
    height: 352px;
    top: 241px;
  }
}

.confetti-top-left01 {
  position: absolute;
  width: 25.7333333333vw;
  height: 50.1333333333vw;
  top: 4.8vw;
  left: 3.2vw;
}
@media screen and (min-width: 768px) {
  .confetti-top-left01 {
    width: 12.2916666667vw;
    top: 0.6944444444vw;
    left: 0.1388888889vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-top-left01 {
    width: 177px;
    top: 10px;
    left: 2px;
  }
}

.confetti-top-left02 {
  position: absolute;
  width: 23.0666666667vw;
  height: 41.4666666667vw;
  top: 6.1333333333vw;
  left: 1.6vw;
}
@media screen and (min-width: 768px) {
  .confetti-top-left02 {
    width: 16.7361111111vw;
    left: 0;
    top: 4.5138888889vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-top-left02 {
    width: 241px;
    top: 64px;
  }
}

.confetti-top-right01 {
  position: absolute;
  width: 20.2666666667vw;
  height: 30vw;
  top: 5.8666666667vw;
  right: 2.6666666667vw;
}
@media screen and (min-width: 768px) {
  .confetti-top-right01 {
    width: 16.5972222222vw;
    top: 3.6111111111vw;
    right: 2.5vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-top-right01 {
    width: 239px;
    top: 52px;
    right: 36px;
  }
}

.confetti-top-right02 {
  position: absolute;
  width: 21.6vw;
  height: 35.0666666667vw;
  top: 4vw;
  right: 3.2vw;
}
@media screen and (min-width: 768px) {
  .confetti-top-right02 {
    width: 4.9305555556vw;
    top: 1.8055555556vw;
    right: 3.125vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-top-right02 {
    width: 71px;
    top: 26px;
    right: 45px;
  }
}

.confetti-bottom-left01 {
  position: absolute;
  width: 19.2vw;
  top: 60.6666666667vw;
  left: 2.2666666667vw;
}
@media screen and (min-width: 768px) {
  .confetti-bottom-left01 {
    width: 25.5555555556vw;
    top: 14.5138888889vw;
    left: 4.5138888889vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-bottom-left01 {
    width: 368px;
    top: 209px;
    left: 65px;
  }
}

.confetti-bottom-left02 {
  position: absolute;
  width: 16.6666666667vw;
  top: 68.4vw;
  left: 5.2vw;
}
@media screen and (min-width: 768px) {
  .confetti-bottom-left02 {
    width: 26.9444444444vw;
    top: 14.5138888889vw;
    left: 0.625vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-bottom-left02 {
    width: 388px;
    top: 209px;
    left: 9px;
  }
}

.confetti-bottom-right01 {
  position: absolute;
  width: 14.1333333333vw;
  top: 64.4vw;
  right: 1.0666666667vw;
}
@media screen and (min-width: 768px) {
  .confetti-bottom-right01 {
    width: 31.8055555556vw;
    top: 11.8055555556vw;
    right: 0.2083333333vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-bottom-right01 {
    width: 458px;
    top: 170px;
    right: 3px;
  }
}

.confetti-bottom-right02 {
  position: absolute;
  width: 16.1333333333vw;
  top: 70.8vw;
  right: 3.4666666667vw;
}
@media screen and (min-width: 768px) {
  .confetti-bottom-right02 {
    width: 28.75vw;
    top: 15.0694444444vw;
    right: 1.5972222222vw;
  }
}
@media screen and (min-width: 1440px) {
  .confetti-bottom-right02 {
    width: 414px;
    top: 217px;
    right: 23px;
  }
}

.kv-left-flag {
  position: absolute;
  top: 3.0666666667vw;
  left: 0;
  width: 24vw;
}
@media screen and (min-width: 768px) {
  .kv-left-flag {
    top: 0;
    width: 91.5277777778vw;
    left: calc(50% - 943px);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@media screen and (min-width: 1440px) {
  .kv-left-flag {
    width: 1318px;
  }
}

.kv-right-flag {
  position: absolute;
  top: 3.0666666667vw;
  right: 0;
  width: 24vw;
}
@media screen and (min-width: 768px) {
  .kv-right-flag {
    top: 0;
    width: 91.5277777778vw;
    left: calc(50% + 943px);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
@media screen and (min-width: 1440px) {
  .kv-right-flag {
    width: 1318px;
  }
}

.kv-right-character {
  position: absolute;
  width: 30.8vw;
  right: 23.6vw;
  top: 71.7333333333vw;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  .kv-right-character {
    width: 20.625vw;
    right: 1.6666666667vw;
    top: 33.4722222222vw;
  }
}
@media screen and (min-width: 1440px) {
  .kv-right-character {
    width: 297px;
    right: 24px;
    top: 482px;
  }
}

.kv-left-character {
  position: absolute;
  width: 18.2666666667vw;
  left: 27.3333333333vw;
  top: 80vw;
  z-index: 6;
}
@media screen and (min-width: 768px) {
  .kv-left-character {
    width: 12.1527777778vw;
    left: 3.9583333333vw;
    top: 38.6111111111vw;
  }
}
@media screen and (min-width: 1440px) {
  .kv-left-character {
    width: 175px;
    left: 57px;
    top: 556px;
  }
}

.kv__bottom {
  position: relative;
}

.kv-bottom__inner {
  max-width: 1440px;
  margin-inline: auto;
  position: relative;
  padding-top: 10vw;
  padding-bottom: 7.3333333333vw;
  z-index: 10;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 768px) {
  .kv-bottom__inner {
    padding-top: 6.25vw;
    padding-bottom: 2.4305555556vw;
  }
}
@media screen and (min-width: 1440px) {
  .kv-bottom__inner {
    padding-top: 90px;
    padding-bottom: 35px;
  }
}
.kv-bottom__inner h1 {
  width: 85.6vw;
  position: relative;
  z-index: 10;
}
@media screen and (min-width: 768px) {
  .kv-bottom__inner h1 {
    width: 73.6111111111vw;
  }
}
@media screen and (min-width: 1440px) {
  .kv-bottom__inner h1 {
    width: 1060px;
  }
}
.kv-bottom__inner h1 img {
  width: 100%;
}

.kv-bottom__bg {
  position: absolute;
  inset: 0;
  background: url(../images/kv-bottom-bg_sp.webp) center bottom/contain no-repeat;
}
@media screen and (min-width: 768px) {
  .kv-bottom__bg {
    background: url(../images/kv-bottom_bg.webp) center bottom/contain no-repeat;
  }
}
@media screen and (min-width: 1440px) {
  .kv-bottom__bg {
    background-image: url(../images/kv-bottom_bg2.webp);
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: 3440px auto;
    overflow: hidden;
  }
}

.hand-left-t {
  position: absolute;
  width: 22vw;
  left: -9.2vw;
  top: -2.9333333333vw;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .hand-left-t {
    width: 18.8888888889vw;
    left: -7.0833333333vw;
    bottom: 1.25vw;
    top: auto;
  }
}
@media screen and (min-width: 1440px) {
  .hand-left-t {
    width: 272px;
    left: -102px;
    bottom: 18px;
  }
}

.hand-left-b {
  position: absolute;
  width: 17.7333333333vw;
  left: -6.6666666667vw;
  top: 3.8666666667vw;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .hand-left-b {
    width: 15.2083333333vw;
    left: -2.1527777778vw;
    bottom: -5.625vw;
    top: auto;
  }
}
@media screen and (min-width: 1440px) {
  .hand-left-b {
    width: 219px;
    left: -31px;
    bottom: -81px;
  }
}

.hand-right-t {
  position: absolute;
  width: 22vw;
  right: -8.4vw;
  top: -2.2666666667vw;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .hand-right-t {
    width: 18.8888888889vw;
    right: -5.6944444444vw;
    bottom: 2.2222222222vw;
    top: auto;
  }
}
@media screen and (min-width: 1440px) {
  .hand-right-t {
    width: 272px;
    right: -82px;
    bottom: 32px;
  }
}

.hand-right-b {
  position: absolute;
  width: 17.7333333333vw;
  right: -7.2vw;
  top: 6.1333333333vw;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .hand-right-b {
    width: 15.2083333333vw;
    right: -4.6527777778vw;
    bottom: -4.8611111111vw;
    top: auto;
  }
}
@media screen and (min-width: 1440px) {
  .hand-right-b {
    width: 219px;
    right: -67px;
    bottom: -70px;
  }
}

/* nav
------------------------------------- */
.nav {
  padding-top: 12.8vw;
  padding-bottom: 8vw;
  background-image: url("../images/nav-bg_sp.svg");
  background-position: center center;
  background-repeat: repeat;
  background-size: cover;
  position: relative;
  border-top: 6px solid #FBEB52;
  border-bottom: 6px solid #FBEB52;
}
@media screen and (min-width: 768px) {
  .nav {
    padding-top: 9.5138888889vw;
    padding-bottom: 4.8611111111vw;
    background-image: url("../images/nav-bg.svg");
    border-top: 10px solid #FBEB52;
    border-bottom: 10px solid #FBEB52;
  }
}
@media screen and (min-width: 1440px) {
  .nav {
    padding-top: 137px;
    padding-bottom: 70px;
  }
}

.page-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 2.1333333333vw;
  position: relative;
  z-index: 11;
}
@media screen and (min-width: 768px) {
  .page-nav {
    gap: 2.6388888889vw;
  }
}
@media screen and (min-width: 1440px) {
  .page-nav {
    gap: 38px;
  }
}

.page-nav-link {
  display: block;
  background: #FFFFFF;
  -webkit-box-shadow: 4px 4px 0px rgb(0, 0, 0);
          box-shadow: 4px 4px 0px rgb(0, 0, 0);
  border-radius: 8px;
  width: 30.4vw;
  height: 20.8vw;
  position: relative;
  -webkit-transition: background 0.4s ease-in-out, -webkit-box-shadow 0.4s ease-in-out;
  transition: background 0.4s ease-in-out, -webkit-box-shadow 0.4s ease-in-out;
  transition: background 0.4s ease-in-out, box-shadow 0.4s ease-in-out;
  transition: background 0.4s ease-in-out, box-shadow 0.4s ease-in-out, -webkit-box-shadow 0.4s ease-in-out;
}
.page-nav-link img,
.page-nav-link picture, .page-nav-link::after {
  -webkit-transition: opacity 0.4s ease-in-out, background 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
  transition: opacity 0.4s ease-in-out, background 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
  transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out, background 0.4s ease-in-out;
  transition: opacity 0.4s ease-in-out, transform 0.4s ease-in-out, background 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
}
.page-nav-link img {
  margin: 0 auto;
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  display: block;
}
.page-nav-link picture {
  display: block;
}
@media screen and (min-width: 768px) {
  .page-nav-link {
    width: 26.3888888889vw;
    height: 11.8055555556vw;
    -webkit-box-shadow: 6px 6px 0px rgb(0, 0, 0);
            box-shadow: 6px 6px 0px rgb(0, 0, 0);
    border-radius: 30px;
  }
}
@media screen and (min-width: 1440px) {
  .page-nav-link {
    width: 380px;
    height: 170px;
  }
}
.page-nav-link::after {
  position: absolute;
  content: "";
  width: 3.4666666667vw;
  height: 2.6666666667vw;
  background: url(../images/nav-arrow.svg) center center no-repeat;
  background-size: contain;
  bottom: 4px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .page-nav-link::after {
    width: 2.0833333333vw;
    height: 1.6666666667vw;
    bottom: 0.8333333333vw;
  }
}
@media screen and (min-width: 1440px) {
  .page-nav-link::after {
    width: 30px;
    height: 20px;
    bottom: 12px;
  }
}
.page-nav-link.comic img {
  width: 25.0666666667vw;
  top: 1.8666666667vw;
}
@media screen and (min-width: 768px) {
  .page-nav-link.comic img {
    top: 0.8333333333vw;
    width: 14.1666666667vw;
  }
}
@media screen and (min-width: 1440px) {
  .page-nav-link.comic img {
    top: 12px;
    width: 204px;
  }
}
.page-nav-link.card {
  position: relative;
}
.page-nav-link.card img {
  width: 28.5333333333vw;
  top: 2.1333333333vw;
}
@media screen and (min-width: 768px) {
  .page-nav-link.card img {
    top: 1.3888888889vw;
    width: 20vw;
  }
}
@media screen and (min-width: 1440px) {
  .page-nav-link.card img {
    top: 20px;
    width: 288px;
  }
}
.page-nav-link.card::before {
  position: absolute;
  content: "";
  width: 36.5333333333vw;
  height: 10.9333333333vw;
  background: url(../images/nav-deco-text_sp.svg) center center/contain;
  top: -10.1333333333vw;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 768px) {
  .page-nav-link.card::before {
    width: 32.8472222222vw;
    height: 9.0972222222vw;
    top: -7.5694444444vw;
    background: url(../images/nav-deco-text_pc.svg) center center/contain;
  }
}
@media screen and (min-width: 1440px) {
  .page-nav-link.card::before {
    width: 473px;
    height: 131px;
    top: -109px;
  }
}
.page-nav-link.video img {
  width: 21.8666666667vw;
  top: 1.6vw;
}
@media screen and (min-width: 768px) {
  .page-nav-link.video img {
    width: 12.8472222222vw;
    top: 1.3888888889vw;
  }
}
@media screen and (min-width: 1440px) {
  .page-nav-link.video img {
    width: 185px;
    top: 20px;
  }
}
.page-nav-link:hover {
  background: -webkit-gradient(linear, left top, right top, from(#AC9041), to(#94710C));
  background: linear-gradient(90deg, #AC9041 0%, #94710C 100%);
}
.page-nav-link:hover::after {
  background: url(../images/nav-arrow-hover.svg) center center no-repeat;
  background-size: contain;
}
.page-nav-link:hover img:nth-of-type(2),
.page-nav-link:hover picture:nth-of-type(2) {
  opacity: 0;
}

/* トップ固定nav
------------------------------------- */
.nav.is-fixed {
  display: none;
  position: fixed;
  top: 0;
  z-index: 100;
  width: 100%;
  border-top: none;
  padding-top: 10px;
  padding-bottom: 15px;
}
.nav.is-fixed .fixed-nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 13px;
}
@media screen and (min-width: 768px) {
  .nav.is-fixed .page-nav__item {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    max-width: 388px;
    height: 92px;
  }
}
.nav.is-fixed .page-nav__item .page-nav-link {
  height: 18.6666666667vw;
}
@media screen and (min-width: 768px) {
  .nav.is-fixed .page-nav__item .page-nav-link {
    width: 100%;
    height: 100%;
    border-radius: 20px;
  }
  .nav.is-fixed .page-nav__item .page-nav-link img {
    height: 49px;
    top: 10px;
  }
  .nav.is-fixed .page-nav__item .page-nav-link::after {
    width: 20px;
    height: 16px;
    bottom: 10px;
  }
}
@media screen and (min-width: 768px) {
  .nav.is-fixed .page-nav__item .page-nav-link.comic img {
    width: 19.5833333333vw;
  }
}
.nav.is-fixed .page-nav__item .page-nav-link.card::before {
  display: none;
}
@media screen and (min-width: 768px) {
  .nav.is-fixed .page-nav__item .page-nav-link.card img {
    width: 20.8333333333vw;
  }
}
@media screen and (min-width: 768px) {
  .nav.is-fixed .page-nav__item .page-nav-link.video img {
    width: 17.7083333333vw;
  }
}

/* 共通パーツ
------------------------------------- */
.section__heading {
  width: 328px;
  height: 81px;
  background: url(../images/title-label.svg) no-repeat center center/contain;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 1;
}
@media screen and (min-width: 900px) {
  .section__heading {
    width: 52.7777777778vw;
    max-width: 760px;
    height: 12.9861111111vw;
    max-height: 187px;
  }
}

@media screen and (min-width: 900px) {
  .title-text {
    width: 40.6944444444vw;
    max-width: 586px;
  }
}
.title-text img {
  width: 100%;
}

.section__inner {
  padding-inline: 14px;
}

.section__content {
  background: #FFFFFF;
  border-radius: 16px;
  -webkit-box-shadow: 8px 8px 0px rgb(0, 0, 0);
          box-shadow: 8px 8px 0px rgb(0, 0, 0);
  padding: 20px 14px 44px 14px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 16px;
  position: relative;
}
@media screen and (min-width: 900px) {
  .section__content {
    max-width: 1240px;
    position: relative;
    z-index: 1;
    margin-inline: auto;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    padding: 60px;
    gap: 20px;
  }
}
@media screen and (min-width: 1440px) {
  .section__content {
    gap: 35px;
  }
}

.section-content__label {
  position: absolute;
  top: -34px;
  left: 12px;
  padding-top: 14px;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0;
  width: 64px;
  height: 75px;
  background: url(../images/section-content-label.svg) center center/contain no-repeat;
}
@media screen and (min-width: 768px) {
  .section-content__label {
    width: 110px;
    height: 129px;
    padding-top: 17px;
  }
}

.text {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1;
  margin-bottom: -0.4em; /* 数字に近づける */
}
@media screen and (min-width: 768px) {
  .text {
    font-size: 2rem;
  }
}

.number {
  font-size: 3rem;
  font-weight: 700;
  line-height: 1;
}
@media screen and (min-width: 768px) {
  .number {
    font-size: 5.6rem;
  }
}

.content__img {
  width: 100%;
}
@media screen and (min-width: 900px) {
  .content__img {
    width: 46.875%;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}
.content__img img {
  width: 100%;
}

.content__discription {
  position: relative;
}

.discription__title {
  font-size: 2.4rem;
  color: #C50019;
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (min-width: 900px) {
  .discription__title {
    font-size: 2.2222222222vw;
  }
}
@media screen and (min-width: 1440px) {
  .discription__title {
    font-size: 3.2rem;
  }
}

.discription__text {
  margin-top: 10px;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.6;
  letter-spacing: -0.02em;
}
@media screen and (min-width: 900px) {
  .discription__text {
    margin-top: 15px;
    font-size: 1.6rem;
    letter-spacing: 0;
  }
}
@media screen and (min-width: 1440px) {
  .discription__text {
    margin-top: 24px;
    font-size: 1.8rem;
  }
}
.discription__text .underline {
  background: -webkit-gradient(linear, left top, left bottom, from(#FFEEB7), to(#FFEEB7)) no-repeat;
  background: linear-gradient(#FFEEB7, #FFEEB7) no-repeat;
  background-size: 100% 0.5em;
  background-position: 0 90%;
}
.discription__text .note {
  font-size: 1.4rem;
  font-weight: 400;
}

.discription__date {
  margin-top: 20px;
  font-size: 2.1rem;
  line-height: 1.6;
  font-weight: 500;
  text-align: end;
  position: relative;
  z-index: 0;
}
@media screen and (min-width: 900px) {
  .discription__date {
    margin-top: 1vw;
    font-size: 2.0833333333vw;
   /* position: absolute;*/
    bottom: 0;
    right: 0;
  }
}
@media screen and (min-width: 1440px) {
  .discription__date {
    margin-top: 0px;
    font-size: 3rem;
  }
}
.discription__date::after {
  position: absolute;
  content: "";
  width: 277px;
  height: 48px;
  background: url(../images/yellow-border.svg) center center/contain no-repeat;
  top: 10px;
  right: 0;
  z-index: -1;
}
@media screen and (min-width: 900px) {
  .discription__date::after {
    width: 26.0416666667vw;
    height: 4.5138888889vw;
  }
}
@media screen and (min-width: 1440px) {
  .discription__date::after {
    width: 375px;
    height: 65px;
  }
}

/* ショート読切
------------------------------------- */
.anniversary-comic {
  background: url(../images/comic-bg.svg) center center/cover;
  position: relative;
  padding-top: 80px;
  padding-bottom: 80px;
}
@media screen and (min-width: 900px) {
  .anniversary-comic {
    padding-top: 150px;
    padding-bottom: 120px;
  }
}

.comic-flag-left {
  position: absolute;
  width: 20.8vw;
  top: 0;
  left: 0;
}
@media screen and (min-width: 900px) {
  .comic-flag-left {
    width: 1066px;
    top: 0px;
    left: calc(50% - 935px);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.comic-flag-left img {
  width: 100%;
}

.comic-flag-right {
  position: absolute;
  width: 20.8vw;
  top: 0;
  right: 0;
}
@media screen and (min-width: 900px) {
  .comic-flag-right {
    width: 1066px;
    top: 0px;
    left: calc(50% + 935px);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}
.comic-flag-right img {
  width: 100%;
}

.comic__title {
  position: relative;
}

.comic-deco {
  position: absolute;
  width: 76px;
  bottom: -40px;
  right: -21px;
}
@media screen and (min-width: 900px) {
  .comic-deco {
    width: 9.6527777778vw;
    top: -4.8611111111vw;
    right: -3.2638888889vw;
  }
}
@media screen and (min-width: 1440px) {
  .comic-deco {
    width: 139px;
    top: -70px;
    right: -47px;
  }
}

.comic__content {
  margin-top: 50px;
}
@media screen and (min-width: 900px) {
  .comic__content {
    position: relative;
    margin-top: 56px;
  }
}

/* スタンプカードキャンペーン
------------------------------------- */
.stamp-card-campaign {
  padding-top: 80px;
  padding-bottom: 80px;
  position: relative;
  z-index: 10;
  background: #800A18;
  border-top: 6px solid #FBEB52;
  border-bottom: 6px solid #FBEB52;
  position: relative;
}
@media screen and (min-width: 900px) {
  .stamp-card-campaign {
    border-top: 10px solid #FBEB52;
    border-bottom: 10px solid #FBEB52;
    padding-bottom: 120px;
    padding-top: 150px;
  }
}
.stamp-card-campaign .section__inner {
  position: relative;
}

.card-deco-center {
  position: absolute;
  width: 233px;
  top: 46px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: 0;
}
@media screen and (min-width: 900px) {
  .card-deco-center {
    width: 31.1111111111vw;
    top: 4.5833333333vw;
  }
}
@media screen and (min-width: 1440px) {
  .card-deco-center {
    width: 448px;
    top: 66px;
  }
}

.card-deco1 {
  position: absolute;
  width: 143px;
  top: 178px;
  left: calc(50% - 115px);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  z-index: -1;
}
@media screen and (min-width: 900px) {
  .card-deco1 {
    width: 20.7638888889vw;
    top: 9.7222222222vw;
    left: 5.6944444444vw;
    -webkit-transform: none;
            transform: none;
  }
}
@media screen and (min-width: 1440px) {
  .card-deco1 {
    width: 299px;
    top: 140px;
    left: calc(50% - 500px);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
  }
}

.card-deco2 {
  display: none;
}
@media screen and (min-width: 900px) {
  .card-deco2 {
    display: block;
    position: absolute;
    width: 23.9583333333vw;
    top: 8.125vw;
    right: 0vw;
    z-index: 0;
  }
}
@media screen and (min-width: 1440px) {
  .card-deco2 {
    width: 345px;
    top: 117px;
    left: calc(50% + 550px);
    -webkit-transform: translateX(-50%);
            transform: translateX(-50%);
    right: auto;
  }
}

.card-deco3 {
  position: absolute;
  width: 291px;
  top: 41px;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 900px) {
  .card-deco3 {
    width: 40.4166666667vw;
    top: 8.8194444444vw;
  }
}
@media screen and (min-width: 1440px) {
  .card-deco3 {
    width: 582px;
    top: 127px;
  }
}

.card__title {
  position: relative;
}
@media screen and (min-width: 900px) {
  .card__title {
    height: 13.6111111111vw;
    max-height: 196px;
  }
}
@media screen and (min-width: 900px) {
  .card__title .title-text {
    width: 37.8472222222vw;
    max-width: 545px;
  }
}

.card-title-deco1 {
  position: absolute;
  width: 63px;
  height: 57px;
  top: -33px;
  left: -13px;
}
@media screen and (min-width: 900px) {
  .card-title-deco1 {
    width: 8.8888888889vw;
    height: 7.9861111111vw;
    left: -2.5694444444vw;
    top: -4.0277777778vw;
  }
}
@media screen and (min-width: 1440px) {
  .card-title-deco1 {
    width: 128px;
    height: 115px;
    left: -37px;
    top: -58px;
  }
}

.card-title-deco2 {
  position: absolute;
  width: 63px;
  height: 57px;
  right: -7px;
  bottom: -37px;
  -webkit-transform: rotate(13deg);
          transform: rotate(13deg);
}
@media screen and (min-width: 900px) {
  .card-title-deco2 {
    width: 8.8888888889vw;
    height: 7.9861111111vw;
    right: -3.125vw;
    bottom: -3.75vw;
  }
}
@media screen and (min-width: 1440px) {
  .card-title-deco2 {
    width: 128px;
    height: 115px;
    right: -45px;
    bottom: -54px;
  }
}

.card__content {
  margin-top: 50px;
  position: relative;
}
@media screen and (min-width: 900px) {
  .card__content {
    margin-top: 56px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}
.card__content .section-content__label {
  left: auto;
  right: 14px;
}
@media screen and (min-width: 1440px) {
  .card__content .content__discription .discription__date {
    margin-top: 7px;
  }
}

.card__details {
  margin-top: 50px;
}
@media screen and (min-width: 900px) {
  .card__details {
    margin-top: 100px;
  }
}

.howto-apply {
  padding-top: 50px;
  position: relative;
  max-width: 1240px;
  margin: 0 auto;
}
@media screen and (min-width: 900px) {
  .howto-apply {
    padding-top: 100px;
  }
}
.howto-apply::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background: #FBEB52;
}

h3 {
  padding-top: 15.5px;
  width: 224px;
  height: 66px;
  margin: 0 auto;
  color: #FFFFFF;
  text-align: center;
  font-size: 2.4rem;
  font-weight: 700;
  background: url(../images/title-label2.svg) center center/contain no-repeat;
}
@media screen and (min-width: 900px) {
  h3 {
    width: 294px;
    height: 86px;
    font-size: 4rem;
  }
}

.howto-steps {
  margin-top: 50px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 55px;
}
@media screen and (min-width: 900px) {
  .howto-steps {
    margin-top: 73px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 80px;
    position: relative;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
  }
  .howto-steps::after {
    position: absolute;
    content: "";
    width: 43px;
    height: 60px;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%);
    background: url(../images/howto-apply-arrow-right.svg) center center/contain no-repeat;
  }
}
@media screen and (min-width: 1440px) {
  .howto-steps {
    gap: 120px;
  }
}

.howto-step {
  background-color: #fff;
  border-radius: 20px;
  padding: 30px 19px;
  position: relative;
  max-width: 560px;
  width: 100%;
}
@media screen and (min-width: 900px) {
  .howto-step {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    padding: 90px 40px 60px 40px;
  }
}

.howto-step-label {
  position: absolute;
  width: 62px;
  height: 60px;
  top: -34px;
  left: 10px;
}
@media screen and (min-width: 900px) {
  .howto-step-label {
    width: 104px;
    height: 101px;
    top: -30px;
    left: 20px;
  }
}

.howto-step-arrow-down {
  width: 24px;
  height: 17px;
  margin-top: 20px;
  margin-inline: auto;
}
@media screen and (min-width: 900px) {
  .howto-step-arrow-down {
    width: 40px;
    height: 28px;
    margin-top: 30px;
  }
}

.step__text-img {
  margin-top: 20px;
  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;
  gap: 10px;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.3;
}
@media screen and (min-width: 900px) {
  .step__text-img {
    font-size: 2.6rem;
    margin-top: 30px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 14px;
  }
}

.step__wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 6px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 900px) {
  .step__wrap {
    font-size: 5rem;
    gap: 16px;
  }
}
.step__wrap img {
  width: 62px;
}
@media screen and (min-width: 900px) {
  .step__wrap img {
    width: 93px;
  }
}

.step__note {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.5;
  margin-top: 20px;
  padding: 30px 24px;
  background: #EDEDED;
  border-radius: 20px;
  text-align: center;
}
@media screen and (min-width: 900px) {
  .step__note {
    font-size: 2.8rem;
    margin-top: 59px;
    padding: 83px 20px;
  }
}
.step__note span {
  display: inline-block;
  position: relative;
}
.step__note span::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  background-color: #000;
}

.step__text {
  text-align: center;
  font-size: 1.6rem;
  font-weight: 700;
  line-height: 1.3;
}
 .step__text02 {
    font-size: 1.3rem;
	 text-align: center;
	 margin-top: 15px;
  }
@media screen and (min-width: 900px) {
  .step__text {
    font-size: 2.6rem;
  }
  .step__text02 {
    font-size: 1.9rem;
	 text-align: center;
	  margin-top: 15px;
  }
}

.step__img {
  margin: 20px auto 0;
}
.step__img img {
  width: 308px;
  margin-inline: auto;
}
@media screen and (min-width: 900px) {
  .step__img {
    height: 481px;
  }
  .step__img img {
    width: auto;
    display: block;
    margin: 0 auto;
    height: 100%;
  }
}

.apply-size__contents {
  margin: 50px auto 0;
  background: #FFFFFF;
  border-radius: 20px;
  padding: 30px 20px;
  max-width: 1240px;
}
@media screen and (min-width: 900px) {
  .apply-size__contents {
    padding-top: 50px;
    padding-bottom: 60px;
    margin-top: 73px;
  }
}
.apply-size__contents p {
  text-align: center;
  font-size: 2rem;
  line-height: 1.3;
}
.apply-size__contents p:nth-of-type(2) {
  font-weight: 700;
  font-size: 1.4rem;
  margin-top: 16px;
}
@media screen and (min-width: 900px) {
  .apply-size__contents p:nth-of-type(2) {
    margin-top: 20px;
    font-size: 2rem;
  }
}
.apply-size__contents p:nth-of-type(3) {
  font-weight: 700;
  font-size: 1.4rem;
  margin-top: 8px;
}
@media screen and (min-width: 900px) {
  .apply-size__contents p:nth-of-type(3) {
    margin-top: 12px;
    font-size: 2rem;
  }
}

.apply-requirements {
  margin-top: 50px;
  position: relative;
}
@media screen and (min-width: 900px) {
  .apply-requirements {
    margin-top: 100px;
  }
}

.apply-requirements__contents {
  margin: 50px auto 0;
  background: #FFFFFF;
  border-radius: 20px;
  padding: 30px 20px;
  max-width: 1240px;
}
@media screen and (min-width: 900px) {
  .apply-requirements__contents {
    padding-top: 50px;
    padding-bottom: 60px;
    margin-top: 73px;
  }
}

.requirements-content__title {
  font-size: 2.2rem;
  font-weight: 500;
  line-height: 1.3;
  text-align: center;
}
@media screen and (min-width: 900px) {
  .requirements-content__title {
    font-size: 2.6rem;
  }
}

.apply-requirements__note {
  margin-top: 20px;
  background: #EDEDED;
  border-radius: 20px;
  padding: 30px 20px;
  font-size: 1.2rem;
  line-height: 1.6;
}
@media screen and (min-width: 900px) {
  .apply-requirements__note {
    max-width: 1000px;
    margin-inline: auto;
    padding: 40px 30px;
    font-size: 1.6rem;
  }
}

.content__02 {
  margin-top: 24px;
}
@media screen and (min-width: 900px) {
  .content__02 {
    margin-top: 50px;
  }
}
.content__02 p:nth-of-type(2) {
  margin-top: 10px;
  font-weight: 500;
  font-size: 1.2rem;
  line-height: 1.3;
}
@media screen and (min-width: 900px) {
  .content__02 p:nth-of-type(2) {
    font-size: 1.6rem;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 20px auto 0;
  }
}
@media screen and (min-width: 900px) {
  .content__02 .requirements-content__title {
    font-size: 2rem;
    font-weight: 500;
  }
}

/* 動画で応援
------------------------------------- */
.video-support-campaign {
  background: url(../images/vido-bg.svg) center top/cover no-repeat;
  position: relative;
  padding-top: 80px;
  padding-bottom: 80px;
  border-bottom: 6px solid #FBEB52;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 900px) {
  .video-support-campaign {
    padding-top: 10.4166666667vw;
    padding-bottom: 120px;
    border-bottom: 10px solid #FBEB52;
  }
}
@media screen and (min-width: 1440px) {
  .video-support-campaign {
    padding-top: 150px;
  }
}

@media screen and (min-width: 900px) {
  .video__title {
    height: 12.9861111111vw;
  }
}
.video__title .title-text {
  width: 215px;
}
@media screen and (min-width: 900px) {
  .video__title .title-text {
    width: 33.8194444444vw;
  }
}
@media screen and (min-width: 1440px) {
  .video__title .title-text {
    max-width: 487px;
  }
}

.video-title-deco {
  position: absolute;
  width: 73px;
  bottom: -20px;
  right: -19px;
}
@media screen and (min-width: 900px) {
  .video-title-deco {
    width: 11.8055555556vw;
    top: -3.8194444444vw;
    right: -2.1527777778vw;
    left: auto;
  }
}
@media screen and (min-width: 1440px) {
  .video-title-deco {
    width: 170px;
    top: -55px;
    right: -31px;
  }
}

.video__content {
  margin-top: 50px;
  position: relative;
  z-index: 3;
}
@media screen and (min-width: 900px) {
  .video__content {
    margin-top: 56px;
  }
}

.btn {
  display: block;
  max-width: 319px;
  padding: 16px;
  text-align: center;
  color: white;
  background: #000000;
  border-radius: 100px;
  font-size: 1.6rem;
  line-height: 1.4;
  margin-top: 30px;
  position: relative;
  margin-inline: auto;
  -webkit-transition: color 0.4s ease-in-out, background 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
  transition: color 0.4s ease-in-out, background 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
  transition: transform 0.4s ease-in-out, color 0.4s ease-in-out, background 0.4s ease-in-out;
  transition: transform 0.4s ease-in-out, color 0.4s ease-in-out, background 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
}
@media screen and (min-width: 900px) {
  .btn {
    max-width: 325px;
    margin-right: 0;
  }
}
.btn::after {
  position: absolute;
  content: "";
  width: 12px;
  height: 14px;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  right: 20px;
  background: url(../images/btn-arrow.svg) center center/contain no-repeat;
}
.btn:hover {
  background: -webkit-gradient(linear, left top, right top, from(#AC9041), to(#94710C));
  background: linear-gradient(90deg, #AC9041 0%, #94710C 100%);
}
.btn:hover::after {
  background: url(../images/btn-arrow-hover.svg) center center/contain no-repeat;
}

/* SHARE
------------------------------------- */
.share {
  position: relative;
}

.share__inner {
  padding: 23px 30px;
  max-width: 375px;
  margin: 0 auto;
}
@media screen and (min-width: 900px) {
  .share__inner {
    max-width: none;
  }
}

.share-deco {
  position: absolute;
  width: 123px;
  height: 123px;
  bottom: 0;
  left: calc(50% - 100px);
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
@media screen and (min-width: 900px) {
  .share-deco {
    width: 225px;
    height: 224px;
    left: calc(50% - 380px);
  }
}

.share__contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 900px) {
  .share__contents {
    gap: 40px;
  }
}

.share__text {
  font-size: 2.4rem;
  font-weight: 700;
  letter-spacing: -0.05em;
}
@media screen and (min-width: 900px) {
  .share__text {
    font-size: 4rem;
  }
}

.share__icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 20px;
}
@media screen and (min-width: 900px) {
  .share__icon {
    gap: 30px;
  }
}
.share__icon li {
  width: 44px;
  height: 44px;
}
@media screen and (min-width: 900px) {
  .share__icon li {
    width: 60px;
    height: 60px;
  }
}
.share__icon li a:hover {
  opacity: 0.6;
}

/* footer
------------------------------------- */
.footer__top {
  background: #000;
  padding: 60px 14px;
}
@media screen and (min-width: 900px) {
  .footer__top {
    padding-block: 100px;
  }
}

.footer-top__contents {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 20px;
}
@media screen and (min-width: 900px) {
  .footer-top__contents {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: end;
    gap: 40px;
  }
}
.footer-top__contents a:hover {
  opacity: 0.6;
}

.logo {
  width: 170px;
}
@media screen and (min-width: 900px) {
  .logo {
    width: 373px;
  }
}

.DL__text {
  font-size: 1.6rem;
  color: #ffffff;
  font-weight: 500;
  letter-spacing: -0.05em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: end;
  gap: 2px;
  line-height: 1;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  position: relative;
}
@media screen and (min-width: 900px) {
  .DL__text {
    font-size: 2.6rem;
  }
}
.DL__text .number {
  font-size: 2.4rem;
  color: #FF0000;
  position: relative;
  top: 2px;
}
@media screen and (min-width: 900px) {
  .DL__text .number {
    font-size: 4rem;
  }
}
.DL__text .number .small {
  font-size: 1.5rem;
}
@media screen and (min-width: 900px) {
  .DL__text .number .small {
    font-size: 2.4rem;
  }
}
.DL__text::before {
  content: "";
  position: absolute;
  width: 19.2px;
  height: 1.2px;
  background: #fff;
  top: 19px;
  left: -20px;
  -webkit-transform: rotate(60deg);
          transform: rotate(60deg);
  border-radius: 9999px;
}
@media screen and (min-width: 900px) {
  .DL__text::before {
    width: 32px;
    height: 2px;
    -webkit-transform: rotate(-120deg);
            transform: rotate(-120deg);
    top: 28px;
    left: -34px;
  }
}
.DL__text::after {
  content: "";
  position: absolute;
  width: 19.2px;
  height: 1.2px;
  background: #fff;
  top: 19px;
  bottom: 0;
  right: -20px;
  -webkit-transform: rotate(-60deg);
          transform: rotate(-60deg);
  border-radius: 9999px;
}
@media screen and (min-width: 900px) {
  .DL__text::after {
    width: 32px;
    height: 2px;
    -webkit-transform: rotate(120deg);
            transform: rotate(120deg);
    top: 28px;
    right: -34px;
  }
}

.DL__links {
  background: #ffffff;
  border-radius: 24px;
  border: 2.4px solid #FF0000;
  padding: 20px 28px;
  margin-top: 10px;
}
@media screen and (min-width: 900px) {
  .DL__links {
    padding: 25px 87px;
    border-radius: 40px;
    border: 4px solid #FF0000;
  }
}
.DL__links ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 24px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 900px) {
  .DL__links ul {
    gap: 40px;
  }
}

@media screen and (min-width: 900px) {
  .App_link {
    width: 209px;
  }
  .App_link img {
    width: 100%;
  }
}

@media screen and (min-width: 900px) {
  .Google_link {
    width: 236px;
  }
  .Google_link img {
    width: 100%;
  }
}

.footer__bottom {
  background: #800A18;
  color: #ffffff;
  padding: 10px;
  text-align: center;
  font-size: 1.2rem;
  letter-spacing: -0.05em;
  line-height: 1.3;
}
@media screen and (min-width: 900px) {
  .footer__bottom {
    font-size: 1.8rem;
  }
}

.pagetop {
  position: fixed;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 1.6rem;
  font-weight: 700;
  right: 10px;
  bottom: 10px;
  width: 60px;
  height: 60px;
  background: #fff;
  border-radius: 50%;
  z-index: 1000;
  -webkit-box-shadow: 4px 4px 0px rgb(0, 0, 0);
          box-shadow: 4px 4px 0px rgb(0, 0, 0);
  -webkit-transition: color 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
  transition: color 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
  transition: transform 0.4s ease-in-out, color 0.4s ease-in-out;
  transition: transform 0.4s ease-in-out, color 0.4s ease-in-out, -webkit-transform 0.4s ease-in-out;
}
@media screen and (min-width: 900px) {
  .pagetop {
    right: 16px;
    bottom: 30px;
  }
}
.pagetop::before {
  content: "";
  display: block;
  width: 9px;
  height: 10px;
  background: url(../images/top-arrow.svg) center center/contain no-repeat;
  -webkit-transition: background 0.4s ease-in-out;
  transition: background 0.4s ease-in-out;
}
.pagetop::after {
  content: "";
  position: absolute;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: -webkit-gradient(linear, left top, right top, from(#AC9041), to(#94710C));
  background: linear-gradient(90deg, #AC9041 0%, #94710C 100%);
  z-index: -1;
  opacity: 0;
  -webkit-transition: opacity 0.4s ease-in-out;
  transition: opacity 0.4s ease-in-out;
}
.pagetop:hover {
  color: #ffffff;
}
.pagetop:hover::before {
  background: url(../images/top-arrow-hover.svg) center center no-repeat;
}
.pagetop:hover::after {
  opacity: 1;
}