@keyframes link-button-more-border-trace {
  0% {
    background-size: 0 1px, 1px 0, 0 1px, 1px 0;
  }
  25% {
    background-size: 100% 1px, 1px 0, 0 1px, 1px 0;
  }
  50% {
    background-size: 100% 1px, 1px 100%, 0 1px, 1px 0;
  }
  75% {
    background-size: 100% 1px, 1px 100%, 100% 1px, 1px 0;
  }
  100% {
    background-size: 100% 1px, 1px 100%, 100% 1px, 1px 100%;
  }
}
.site-footer__trial {
  position: fixed;
  right: 15px;
  bottom: max(16px, env(safe-area-inset-bottom, 0px));
  width: 150px;
  height: 150px;
  border-radius: 75px;
  background-image: linear-gradient(135deg, #16b3ff, #009de9);
  z-index: 40;
  outline-offset: 3px;
  outline: 1px solid #16b3ff;
  box-shadow: 0 4px 16px rgba(0, 157, 233, 0.12);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translate3d(0, 40px, 0) scale(0.92);
  filter: blur(2px);
  will-change: opacity, transform, filter;
  transition: opacity 0.62s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.62s linear, transform 0.62s cubic-bezier(0.22, 1, 0.36, 1), filter 0.62s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.62s cubic-bezier(0.22, 1, 0.36, 1);
}

.site-footer__trial.site-footer__trial--visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translate3d(0, 0, 0) scale(1);
  filter: blur(0);
  box-shadow: 0 10px 28px rgba(0, 157, 233, 0.2);
}

@media (hover: hover) {
  .site-footer__trial.site-footer__trial--visible:hover {
    transform: scale(1.1);
  }
}
@media (max-width: 768px) {
  .site-footer__trial {
    width: 120px;
    height: 120px;
    border-radius: 60px;
    right: 12px;
    bottom: max(12px, env(safe-area-inset-bottom, 0px));
  }
}
@media (prefers-reduced-motion: reduce) {
  .site-footer__trial {
    transition: none;
    filter: none;
  }
}
main section.scroll-reveal {
  transition: opacity 0.9s ease-out;
}

main section.scroll-reveal.scroll-reveal--pending {
  opacity: 0;
}

main section.scroll-reveal.scroll-reveal--pending > :not(.side-object):not(.section-concept-feature__logo-white):not(.main-visual__brand):not(.main-visual__main-text) {
  opacity: 0;
  margin-top: 72px;
  will-change: opacity, margin-top;
  transition: opacity 1.25s cubic-bezier(0.16, 1, 0.3, 1) 0.08s, margin-top 1.25s cubic-bezier(0.16, 1, 0.3, 1) 0.08s;
}

main section.scroll-reveal.scroll-reveal--visible {
  opacity: 1;
}

main section.scroll-reveal.scroll-reveal--visible > :not(.side-object):not(.section-concept-feature__logo-white):not(.main-visual__brand):not(.main-visual__main-text):not(.about-page__hero-heading) {
  opacity: 1;
  margin-top: 0;
}

@media (prefers-reduced-motion: reduce) {
  main section.scroll-reveal, main section.scroll-reveal.scroll-reveal--pending, main section.scroll-reveal.scroll-reveal--visible {
    opacity: 1;
    transition: none;
  }
  main section.scroll-reveal.scroll-reveal--pending > :not(.side-object):not(.section-concept-feature__logo-white):not(.main-visual__brand):not(.main-visual__main-text), main section.scroll-reveal.scroll-reveal--visible > :not(.side-object):not(.section-concept-feature__logo-white):not(.main-visual__brand):not(.main-visual__main-text) {
    opacity: 1;
    margin-top: 0;
    transition: none;
  }
}
@media print {
  main section.scroll-reveal, main section.scroll-reveal.scroll-reveal--pending {
    opacity: 1 !important;
  }
  main section.scroll-reveal.scroll-reveal--pending > :not(.side-object):not(.section-concept-feature__logo-white):not(.main-visual__brand):not(.main-visual__main-text), main section.scroll-reveal.scroll-reveal--visible > :not(.side-object):not(.section-concept-feature__logo-white):not(.main-visual__brand):not(.main-visual__main-text) {
    opacity: 1 !important;
    margin-top: 0 !important;
  }
}
html.js body:not(.home):not(.page-enter-ready) main {
  opacity: 0;
  margin-top: 20px;
}

body.page-enter-pending:not(.home) main {
  opacity: 0;
  margin-top: 20px;
  transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1), margin-top 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

body.page-enter-pending.page-enter-ready:not(.home) main {
  opacity: 1;
  margin-top: 0;
}

body.home.page-enter-pending:not(.has-front-opening) main {
  opacity: 0;
  margin-top: 20px;
  transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1), margin-top 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

body.home.page-enter-pending.page-enter-ready:not(.has-front-opening) main {
  opacity: 1;
  margin-top: 0;
}

body.has-front-opening {
  overflow: hidden;
  padding-right: var(--front-opening-scrollbar-gap, 0px);
}

.home.has-front-opening main {
  opacity: 0;
  margin-top: 20px;
  transition: opacity 0.6s cubic-bezier(0.22, 1, 0.36, 1), margin-top 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}

.home.has-front-opening.front-opening-main-visible main {
  opacity: 1;
  margin-top: 0;
}

.front-opening {
  position: fixed;
  inset: 0;
  z-index: 9999;
  pointer-events: none;
}

.front-opening::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: var(--front-line-length, 120vw);
  height: 5px;
  background: #464646;
  transform-origin: left center;
  transform: rotate(var(--front-line-angle, -45deg));
  opacity: 1;
  z-index: 1;
}

.front-opening.is-splitting::after {
  opacity: 0;
}

.front-opening__panel {
  position: absolute;
  inset: 0;
  background: #464646;
  transition: transform 0.9s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.9s ease;
  will-change: transform, opacity;
  z-index: 2;
}

.front-opening__panel--tl {
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

.front-opening__panel--br {
  clip-path: polygon(100% 0, 100% 100%, 0 100%);
}

.front-opening__logo {
  position: absolute;
  left: 50%;
  top: 50%;
  width: min(220px, 52vw);
  transform: translate(-50%, -50%);
  opacity: 0;
  transition: opacity 0.45s cubic-bezier(0.22, 1, 0.36, 1);
  will-change: opacity;
  z-index: 4;
}

.front-opening.is-logo-visible .front-opening__logo {
  opacity: 1;
}

.front-opening__line {
  position: absolute;
  left: 0;
  bottom: 0;
  width: var(--front-line-length, 120vw);
  height: 1px;
  background: #fff;
  opacity: 1;
  transform-origin: left center;
  transform: rotate(var(--front-line-angle, -45deg)) scaleX(0);
  transition: transform 0.8s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.16s linear;
  will-change: transform;
  z-index: 3;
}

.front-opening.is-line-running .front-opening__line {
  transform: rotate(var(--front-line-angle, -45deg)) scaleX(1);
}

.front-opening.is-splitting .front-opening__line {
  opacity: 0;
}

.front-opening.is-splitting .front-opening__logo {
  opacity: 0;
  transition-duration: 0.35s;
}

.front-opening.is-logo-hidden .front-opening__logo {
  opacity: 0;
  transition-duration: 0.35s;
}

.front-opening.is-splitting .front-opening__panel--tl {
  transform: translate(-18vw, -18vh);
  opacity: 0;
}

.front-opening.is-splitting .front-opening__panel--br {
  transform: translate(18vw, 18vh);
  opacity: 0;
}

@media (prefers-reduced-motion: reduce) {
  body.page-enter-pending:not(.home) main, body.page-enter-pending.page-enter-ready:not(.home) main {
    opacity: 1;
    margin-top: 0;
    transition: none;
  }
  body.home.page-enter-pending:not(.has-front-opening) main, body.home.page-enter-pending.page-enter-ready:not(.has-front-opening) main {
    opacity: 1;
    margin-top: 0;
    transition: none;
  }
  .front-opening {
    display: none;
  }
  body.has-front-opening {
    overflow: auto;
  }
  .home.has-front-opening main, .home.has-front-opening.front-opening-main-visible main {
    opacity: 1;
    margin-top: 0;
    transition: none;
  }
}
