@charset "UTF-8";
.new-footer {
  border-radius: 9rem 9rem 0 0;
  background-color: #41a9b1;
  padding: 11rem 0 6rem;
  overflow: hidden;
  position: relative;
}
@media (max-width: 767px) {
  .new-footer {
    padding: 2rem 1rem 6rem;
    border-radius: 6rem 6rem 0 0;
  }
}
.new-footer__row1 {
  display: grid;
  grid-template-columns: 27.8rem 1fr;
  gap: 10rem;
  justify-content: space-between;
  position: relative;
  z-index: 2;
}
@media (max-width: 767px) {
  .new-footer__row1 {
    display: block;
  }
}
.new-footer__logo {
  margin-bottom: 3rem;
}
@media (max-width: 767px) {
  .new-footer__logo {
    margin-bottom: 2rem;
  }
  .new-footer__logo img {
    width: 28.2rem;
  }
}
.new-footer__info {
  color: #fff;
}
@media (max-width: 767px) {
  .new-footer__info {
    margin: 0 -0.5rem 4rem;
  }
}
.new-footer__links {
  color: #fff;
  margin-top: 4rem;
}
.new-footer__links-title {
  font-size: 2.4rem;
  font-weight: bold;
  font-family: var(--font-en);
  margin-bottom: 1rem;
}
@media (max-width: 767px) {
  .new-footer__links-title {
    font-size: 2rem;
  }
}
.new-footer__links {
  display: flex;
  gap: 5.6rem;
}
@media (max-width: 767px) {
  .new-footer__links {
    display: grid;
    grid-template-columns: repeat(2, auto);
    gap: 2.5rem 2rem;
    margin: 0 -0.5rem;
  }
}
.new-footer__links-g li {
  font-size: 1.4rem;
}
.new-footer__links-g li + li {
  margin-top: 1em;
}
.new-footer__links-g ul + .new-footer__links-title {
  margin-top: 4rem;
}
.new-footer__row2 {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: "DIN 2014";
  font-weight: bold;
  margin-top: 12rem;
  position: relative;
  z-index: 2;
  color: #fff;
}
@media (max-width: 767px) {
  .new-footer__row2 {
    display: block;
    margin-top: 6rem;
  }
}
.new-footer__sublinks {
  display: flex;
}
.new-footer__copyright {
  font-size: 1.4rem;
  font-family: "DIN 2014";
}
@media (max-width: 767px) {
  .new-footer__copyright {
    font-size: 1.2rem;
    margin-top: 1rem;
  }
}
.new-footer__sublink {
  font-weight: bold;
  font-family: "DIN 2014";
}
.new-footer__sublink::after {
  content: "　/　";
}
.new-footer__sublink:last-child::after {
  display: none;
}
.new-footer__mark {
  position: absolute;
  width: 75.4rem;
  height: 75.4rem;
  border-radius: 100%;
}
@media (max-width: 767px) {
  .new-footer__mark {
    width: 28.2rem;
    height: 28.2rem;
    border-radius: 100%;
  }
}
.new-footer__mark--1 {
  background: #f08300;
  inset: -44.5rem auto auto -36rem;
}
@media (max-width: 767px) {
  .new-footer__mark--1 {
    inset: -16rem auto auto -15rem;
  }
}
.new-footer__mark--2 {
  background: #ed7fa4;
  inset: -26.6rem -37.7rem auto auto;
}
@media (max-width: 767px) {
  .new-footer__mark--2 {
    inset: -16rem -19rem auto auto;
  }
}
.new-footer__mark--3 {
  background: #4083c5;
  inset: auto auto -49rem -39.4rem;
}
@media (max-width: 767px) {
  .new-footer__mark--3 {
    inset: auto auto -23rem -15rem;
  }
}
.new-footer__mark--4 {
  background: #ed7fa4;
  inset: auto auto -54rem -15.3rem;
}
@media (max-width: 767px) {
  .new-footer__mark--4 {
    inset: auto auto -24rem -3rem;
  }
}
.new-footer__mark--5 {
  border: solid #f08300 5rem;
  inset: auto -34.5rem -45.3rem auto;
}
@media (max-width: 767px) {
  .new-footer__mark--5 {
    border: solid #f08300 2.5rem;
    width: 33.4rem;
    height: 33.4rem;
    border-radius: 100%;
    inset: auto -26rem -18rem auto;
  }
}
.new-footer__cta {
  position: relative;
  z-index: 2;
  height: 45.2rem;
  border-radius: 9rem;
  margin-bottom: 7.15rem;
  overflow: hidden;
  border: solid 3px #212121;
}
@media (max-width: 767px) {
  .new-footer__cta {
    height: 45.8rem;
    border-radius: 6rem;
    margin-bottom: 3rem;
  }
}
.new-footer__cta-buttons {
  z-index: 4;
  position: relative;
  display: grid;
  gap: 4rem;
  justify-content: center;
  grid-template-columns: repeat(2, 47.5rem);
  gap: 1.2rem;
}
@media (max-width: 767px) {
  .new-footer__cta-buttons {
    padding: 0 1.8rem;
    grid-template-columns: 1fr;
    gap: 2rem;
    margin-top: 3rem;
  }
}
.new-footer__cta-img {
  position: absolute;
  z-index: 1;
  rotate: -10deg;
  top: -14.2rem;
  top: -29.4rem;
  left: -14.6rem;
  display: grid;
  grid-template-columns: repeat(2, 172rem);
  --gall-gap: 1.3rem;
  gap: var(--gall-gap);
}
@media (max-width: 767px) {
  .new-footer__cta-img {
    --gall-gap: 0.37rem;
    grid-template-columns: repeat(2, 53rem);
    top: -6rem;
  }
}
@keyframes holizon-animation2 {
  0% {
    transform: translate(0%, 0);
  }
  100% {
    transform: translate(calc(-100% - var(--gall-gap)), 0);
  }
}
@keyframes holizon-animation2r {
  0% {
    transform: translate(0%, 0);
  }
  100% {
    transform: translate(calc(100% - var(--gall-gap)), 0);
  }
}
.new-footer__cta-img > img {
  width: 172rem;
  animation: holizon-animation2 20s linear infinite;
}
.new-footer__cta-img--2 {
  z-index: 2;
  top: 21.2rem;
  top: 6rem;
  left: -14.6rem;
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  .new-footer__cta-img--2 {
    top: 10.4rem;
  }
}
.new-footer__cta-img--2 > img {
  animation: holizon-animation2r 20s linear infinite;
}
.new-footer__cta-img--3 {
  z-index: 2;
}
@media (max-width: 767px) {
  .new-footer__cta-img--3 {
    top: 26.8rem;
  }
}
.new-footer__cta-img--3 > img {
  animation: holizon-animation2 20s linear infinite;
}
.new-footer__cta-image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}
.new-footer__cta-layer {
  background-color: rgba(33, 33, 33, 0.5);
  position: absolute;
  inset: 0;
  z-index: 3;
  width: 100%;
  height: 100%;
  border-radius: 8.6rem;
}
@media (max-width: 767px) {
  .new-footer__cta-layer {
    border-radius: 5.5rem;
  }
}
.new-footer__cta-titles {
  display: flex;
  color: #fff;
  position: relative;
  z-index: 4;
  align-items: center;
  gap: 4rem;
  margin-top: 2rem;
  justify-content: center;
}
@media (max-width: 767px) {
  .new-footer__cta-titles {
    display: block;
    padding: 0 2rem;
    margin-top: 1.5rem;
  }
}
.new-footer__cta-title {
  font-size: 15.7rem;
  font-family: var(--font-en);
}
@media (max-width: 767px) {
  .new-footer__cta-title {
    font-size: 8rem;
  }
}
.new-footer__cta-copy {
  z-index: 4;
  position: relative;
  top: 1rem;
  font-weight: bold;
  font-size: 4.8rem;
  letter-spacing: 0.05em;
  font-family: var(--font-primary);
}
@media (max-width: 767px) {
  .new-footer__cta-copy {
    font-size: 2.8rem;
  }
}

/*# sourceMappingURL=footer.css.map */
