:root {
  --body-width: calc(100vw - var(--scrollbar));
  --fz-3: 0.625rem;
  --fz-2: 0.75rem;
  --fz-1: 0.875rem;
  --fz0: clamp(1rem, 1rem + 0vw, 1rem);
  --fz1: clamp(1.125rem, 1.0708rem + 0.2312vw, 1.25rem);
  --fz2: clamp(1.2656rem, 1.1369rem + 0.5491vw, 1.5625rem);
  --fz3: clamp(1.4238rem, 1.1944rem + 0.979vw, 1.9531rem);
  --fz4: clamp(1.6018rem, 1.2378rem + 1.553vw, 2.4414rem);
  --fz5: clamp(1.802rem, 1.2602rem + 2.3116vw, 3.0518rem);
  --fz6: clamp(2.0273rem, 1.2524rem + 3.3062vw, 3.8147rem);
  --fz7: clamp(2.2807rem, 1.2022rem + 4.6015vw, 4.7684rem);
}

/* =========================================================
 top
========================================================= */
@media screen and (max-width: 575px) {
  .p-top-mv {
    margin-top: 60px;
  }
}
@media screen and (max-width: 767px) {
  .p-top-mv {
    display: -ms-grid;
    display: grid;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: end;
  }
}
@media screen and (min-width: 576px) {
  .p-top-mv {
    margin-top: 80px;
  }
}
@media screen and (min-width: 992px) {
  .p-top-mv {
    margin-top: 100px;
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv__img {
    width: 50%;
  }
}
.p-top-mv__main {
  display: -ms-grid;
  display: grid;
  gap: 30px;
}
@media screen and (max-width: 767px) {
  .p-top-mv__main {
    padding-inline: min(40px, 5vw);
    padding-block: min(60px, 8vw);
  }
}
@media screen and (min-width: 768px) {
  .p-top-mv__main {
    position: absolute;
    top: 50%;
    left: 0;
    padding-inline: min(40px, 5vw);
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
}
@media screen and (min-width: 1280px) {
  .p-top-mv__main {
    left: 50%;
    width: 1200px;
    margin-left: -600px;
    padding: 0;
  }
}
.p-top-mv__main .btn {
  width: 250px;
  margin-left: 0;
  margin-right: auto;
}

.l-footer-link {
  display: -ms-grid;
  display: grid;
}
@media screen and (min-width: 576px) {
  .l-footer-link {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }
}
.l-footer-link ul {
  display: -ms-grid;
  display: grid;
  -ms-flex-line-pack: start;
      align-content: start;
  gap: 1.3em;
}
.l-footer-link li {
  line-height: 1;
}
.l-footer-link ul + div {
  margin-top: 1.3em;
}
.l-footer-link ul + dl {
  margin-top: 2em;
}
.l-footer-link dt {
  margin-bottom: 0.8em;
  font-weight: 500;
  line-height: 1;
}
.l-footer-link dt:not(:first-child) {
  margin-top: 1.5em;
}
.l-footer-link a {
  text-decoration: none;
}
.l-footer-link a:has(i) {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
}
.l-footer-link__win svg {
  width: 12px;
  aspect-ratio: 1/1;
  fill: #b0b0b0;
}
.l-footer-credit {
  border-top: 1px solid #e3e3e3;
}
@media screen and (max-width: 767px) {
  .l-footer-credit {
    display: -ms-grid;
    display: grid;
    gap: 20px;
    margin-top: 30px;
    padding-top: 30px;
  }
}
@media screen and (min-width: 768px) {
  .l-footer-credit {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    margin-top: 40px;
    padding-top: 40px;
  }
}
.l-footer-credit a {
  text-decoration: none;
}
.l-footer-credit__logo a {
  display: block;
  line-height: 0;
  text-decoration: none;
}
.l-footer-credit__logo span {
  display: block;
  margin-top: 15px;
  font-size: 11px;
  letter-spacing: 0.05em;
  line-height: 1;
}
.l-footer-credit__logo img {
  height: 25px;
}
.l-footer-credit .site-credits {
  margin: 0;
  padding: 0;
  border-top: none;
}
@media screen and (max-width: 767px) {
  .l-footer-credit .site-credits {
    text-align: left;
    letter-spacing: 0.05em;
  }
}
.l-footer-credit div {
  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: end;
      -ms-flex-align: end;
          align-items: end;
  gap: 15px;
}
.l-footer-credit__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  font-size: var(--fz-2);
}
.l-footer-credit__link i {
  line-height: 0;
}