@import url(https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;600;700;900&display=swap&time=21301283);
@import url(https://cdn.jsdelivr.net/npm/yakuhanjp@3.3.1/dist/css/yakuhanjp.min.css);
@import url(https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&display=swap);
@charset "UTF-8";
/**
 * Swiper 6.1.2
 * Most modern mobile touch slider and framework with hardware accelerated transitions
 * http://swiperjs.com
 *
 * Copyright 2014-2020 Vladimir Kharlampidi
 *
 * Released under the MIT License
 *
 * Released on: August 17, 2020
 */
@font-face {
  font-family: swiper-icons;
  font-weight: 400;
  font-style: normal;
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
}
:root {
  --swiper-theme-color: #007AFF;
}

.swiper-container {
  position: relative;
  z-index: 1;
  overflow: hidden;
  margin-right: auto;
  margin-left: auto;
  padding: 0;
  list-style: none;
}

.swiper-container-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  z-index: 1;
  display: flex;
  box-sizing: content-box;
  width: 100%;
  height: 100%;
  transition-property: transform;
}

.swiper-container-android .swiper-slide, .swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-container-multirow > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-container-multirow-column > .swiper-wrapper {
  flex-direction: column;
  flex-wrap: wrap;
}

.swiper-container-free-mode > .swiper-wrapper {
  margin: 0 auto;
  transition-timing-function: ease-out;
}

.swiper-slide {
  position: relative;
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

.swiper-container-autoheight, .swiper-container-autoheight .swiper-slide {
  height: auto;
}

.swiper-container-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

.swiper-container-3d {
  perspective: 1200px;
}

.swiper-container-3d .swiper-cube-shadow, .swiper-container-3d .swiper-slide, .swiper-container-3d .swiper-slide-shadow-bottom, .swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top, .swiper-container-3d .swiper-wrapper {
  transform-style: preserve-3d;
}

.swiper-container-3d .swiper-slide-shadow-bottom, .swiper-container-3d .swiper-slide-shadow-left, .swiper-container-3d .swiper-slide-shadow-right, .swiper-container-3d .swiper-slide-shadow-top {
  position: absolute;
  z-index: 10;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

.swiper-container-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0));
}

.swiper-container-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.swiper-container-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-container-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-container-horizontal.swiper-container-css-mode > .swiper-wrapper {
  -ms-scroll-snap-type: x mandatory;
  scroll-snap-type: x mandatory;
}

.swiper-container-vertical.swiper-container-css-mode > .swiper-wrapper {
  -ms-scroll-snap-type: y mandatory;
  scroll-snap-type: y mandatory;
}

:root {
  --swiper-navigation-size: 44px;
}

.swiper-button-next, .swiper-button-prev {
  position: absolute;
  z-index: 10;
  top: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc(var(--swiper-navigation-size) / 44 * 27);
  height: var(--swiper-navigation-size);
  margin-top: calc(-1 * var(--swiper-navigation-size) / 2);
  cursor: pointer;
  color: var(--swiper-navigation-color, var(--swiper-theme-color));
}

.swiper-button-next.swiper-button-disabled, .swiper-button-prev.swiper-button-disabled {
  cursor: auto;
  pointer-events: none;
  opacity: 0.35;
}

.swiper-button-next:after, .swiper-button-prev:after {
  font-family: swiper-icons;
  font-size: var(--swiper-navigation-size);
  font-variant: initial;
  line-height: 1;
  letter-spacing: 0;
  text-transform: none !important;
  text-transform: none;
}

.swiper-button-prev, .swiper-container-rtl .swiper-button-next {
  right: auto;
  left: 10px;
}

.swiper-button-prev:after, .swiper-container-rtl .swiper-button-next:after {
  content: "prev";
}

.swiper-button-next, .swiper-container-rtl .swiper-button-prev {
  right: 10px;
  left: auto;
}

.swiper-button-next:after, .swiper-container-rtl .swiper-button-prev:after {
  content: "next";
}

.swiper-button-next.swiper-button-white, .swiper-button-prev.swiper-button-white {
  --swiper-navigation-color: #FFF;
}

.swiper-button-next.swiper-button-black, .swiper-button-prev.swiper-button-black {
  --swiper-navigation-color: #000;
}

.swiper-button-lock {
  display: none;
}

.swiper-pagination {
  position: absolute;
  z-index: 10;
  transition: 0.3s opacity;
  transform: translate3d(0, 0, 0);
  text-align: center;
}

.swiper-pagination.swiper-pagination-hidden {
  opacity: 0;
}

.swiper-container-horizontal > .swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: 10px;
  left: 0;
  width: 100%;
}

.swiper-pagination-bullets-dynamic {
  font-size: 0;
  overflow: hidden;
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  position: relative;
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
  transform: scale(1);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
  transform: scale(0.33);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
  transform: scale(0.66);
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
  transform: scale(0.33);
}

.swiper-pagination-bullet {
  display: inline-block;
  width: 8px;
  height: 8px;
  opacity: 0.2;
  border-radius: 100%;
  background: #000;
}

button.swiper-pagination-bullet {
  margin: 0;
  padding: 0;
  border: none;
  box-shadow: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet {
  cursor: pointer;
}

.swiper-pagination-bullet-active {
  opacity: 1;
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-container-vertical > .swiper-pagination-bullets {
  top: 50%;
  right: 10px;
  transform: translate3d(0px, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
  display: block;
  margin: 6px 0;
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  top: 50%;
  width: 8px;
  transform: translateY(-50%);
}

.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  display: inline-block;
  transition: 0.2s transform, 0.2s top;
}

.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
  margin: 0 4px;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}

.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s left;
}

.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
  transition: 0.2s transform, 0.2s right;
}

.swiper-pagination-progressbar {
  position: absolute;
  background: rgba(0, 0, 0, 0.25);
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: scale(0);
  transform-origin: left top;
  background: var(--swiper-pagination-color, var(--swiper-theme-color));
}

.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
  transform-origin: right top;
}

.swiper-container-horizontal > .swiper-pagination-progressbar, .swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
  top: 0;
  left: 0;
  width: 100%;
  height: 4px;
}

.swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite, .swiper-container-vertical > .swiper-pagination-progressbar {
  top: 0;
  left: 0;
  width: 4px;
  height: 100%;
}

.swiper-pagination-white {
  --swiper-pagination-color: #FFF;
}

.swiper-pagination-black {
  --swiper-pagination-color: #000;
}

.swiper-pagination-lock {
  display: none;
}

.swiper-scrollbar {
  position: relative;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.1);
  -ms-touch-action: none;
}

.swiper-container-horizontal > .swiper-scrollbar {
  position: absolute;
  z-index: 50;
  bottom: 3px;
  left: 1%;
  width: 98%;
  height: 5px;
}

.swiper-container-vertical > .swiper-scrollbar {
  position: absolute;
  z-index: 50;
  top: 1%;
  right: 3px;
  width: 5px;
  height: 98%;
}

.swiper-scrollbar-drag {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.5);
}

.swiper-scrollbar-cursor-drag {
  cursor: move;
}

.swiper-scrollbar-lock {
  display: none;
}

.swiper-zoom-container {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  text-align: center;
}

.swiper-zoom-container > canvas, .swiper-zoom-container > img, .swiper-zoom-container > svg {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: contain;
  object-fit: contain;
}

.swiper-slide-zoomed {
  cursor: move;
}

.swiper-lazy-preloader {
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 50%;
  box-sizing: border-box;
  width: 42px;
  height: 42px;
  margin-top: -21px;
  margin-left: -21px;
  transform-origin: 50%;
  -webkit-animation: swiper-preloader-spin 1s infinite linear;
  animation: swiper-preloader-spin 1s infinite linear;
  border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
  border-top-color: transparent;
  border-radius: 50%;
}

.swiper-lazy-preloader-white {
  --swiper-preloader-color: #FFF;
}

.swiper-lazy-preloader-black {
  --swiper-preloader-color: #000;
}

@-webkit-keyframes swiper-preloader-spin {
  100% {
    transform: rotate(360deg);
  }
}
@keyframes swiper-preloader-spin {
  100% {
    transform: rotate(360deg);
  }
}
.swiper-container .swiper-notification {
  position: absolute;
  z-index: -1000;
  top: 0;
  left: 0;
  pointer-events: none;
  opacity: 0;
}

.swiper-container-fade.swiper-container-free-mode .swiper-slide {
  transition-timing-function: ease-out;
}

.swiper-container-fade .swiper-slide {
  transition-property: opacity;
  pointer-events: none;
}

.swiper-container-fade .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-fade .swiper-slide-active, .swiper-container-fade .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube {
  overflow: visible;
}

.swiper-container-cube .swiper-slide {
  z-index: 1;
  visibility: hidden;
  width: 100%;
  height: 100%;
  transform-origin: 0 0;
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-container-cube .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-cube.swiper-container-rtl .swiper-slide {
  transform-origin: 100% 0;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-cube .swiper-slide-active, .swiper-container-cube .swiper-slide-next, .swiper-container-cube .swiper-slide-next + .swiper-slide, .swiper-container-cube .swiper-slide-prev {
  visibility: visible;
  pointer-events: auto;
}

.swiper-container-cube .swiper-slide-shadow-bottom, .swiper-container-cube .swiper-slide-shadow-left, .swiper-container-cube .swiper-slide-shadow-right, .swiper-container-cube .swiper-slide-shadow-top {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-container-cube .swiper-cube-shadow {
  position: absolute;
  z-index: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.6;
  background: #000;
  filter: blur(50px);
}

.swiper-container-flip {
  overflow: visible;
}

.swiper-container-flip .swiper-slide {
  z-index: 1;
  pointer-events: none;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-container-flip .swiper-slide .swiper-slide {
  pointer-events: none;
}

.swiper-container-flip .swiper-slide-active, .swiper-container-flip .swiper-slide-active .swiper-slide-active {
  pointer-events: auto;
}

.swiper-container-flip .swiper-slide-shadow-bottom, .swiper-container-flip .swiper-slide-shadow-left, .swiper-container-flip .swiper-slide-shadow-right, .swiper-container-flip .swiper-slide-shadow-top {
  z-index: 0;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

/*!
  * animate.css -https://daneden.github.io/animate.css/
  * Version - 3.7.2
  * Licensed under the MIT license - http://opensource.org/licenses/MIT
  *
  * Copyright (c) 2019 Daniel Eden
  */
@-webkit-keyframes bounce {
  from, 20%, 53%, 80%, to {
    transform: translate3d(0, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  40%, 43% {
    transform: translate3d(0, -30px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  }
  70% {
    transform: translate3d(0, -15px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  }
  90% {
    transform: translate3d(0, -4px, 0);
  }
}
@keyframes bounce {
  from, 20%, 53%, 80%, to {
    transform: translate3d(0, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  40%, 43% {
    transform: translate3d(0, -30px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  }
  70% {
    transform: translate3d(0, -15px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
  }
  90% {
    transform: translate3d(0, -4px, 0);
  }
}
.bounce {
  transform-origin: center bottom;
  -webkit-animation-name: bounce;
  animation-name: bounce;
}

@-webkit-keyframes flash {
  from, 50%, to {
    opacity: 1;
  }
  25%, 75% {
    opacity: 0;
  }
}
@keyframes flash {
  from, 50%, to {
    opacity: 1;
  }
  25%, 75% {
    opacity: 0;
  }
}
.flash {
  -webkit-animation-name: flash;
  animation-name: flash;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes pulse {
  from {
    transform: scale3d(1, 1, 1);
  }
  50% {
    transform: scale3d(1.05, 1.05, 1.05);
  }
  to {
    transform: scale3d(1, 1, 1);
  }
}
@keyframes pulse {
  from {
    transform: scale3d(1, 1, 1);
  }
  50% {
    transform: scale3d(1.05, 1.05, 1.05);
  }
  to {
    transform: scale3d(1, 1, 1);
  }
}
.pulse {
  -webkit-animation-name: pulse;
  animation-name: pulse;
}

@-webkit-keyframes rubberBand {
  from {
    transform: scale3d(1, 1, 1);
  }
  30% {
    transform: scale3d(1.25, 0.75, 1);
  }
  40% {
    transform: scale3d(0.75, 1.25, 1);
  }
  50% {
    transform: scale3d(1.15, 0.85, 1);
  }
  65% {
    transform: scale3d(0.95, 1.05, 1);
  }
  75% {
    transform: scale3d(1.05, 0.95, 1);
  }
  to {
    transform: scale3d(1, 1, 1);
  }
}
@keyframes rubberBand {
  from {
    transform: scale3d(1, 1, 1);
  }
  30% {
    transform: scale3d(1.25, 0.75, 1);
  }
  40% {
    transform: scale3d(0.75, 1.25, 1);
  }
  50% {
    transform: scale3d(1.15, 0.85, 1);
  }
  65% {
    transform: scale3d(0.95, 1.05, 1);
  }
  75% {
    transform: scale3d(1.05, 0.95, 1);
  }
  to {
    transform: scale3d(1, 1, 1);
  }
}
.rubberBand {
  -webkit-animation-name: rubberBand;
  animation-name: rubberBand;
}

@-webkit-keyframes shake {
  from, to {
    transform: translate3d(0, 0, 0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translate3d(-10px, 0, 0);
  }
  20%, 40%, 60%, 80% {
    transform: translate3d(10px, 0, 0);
  }
}
@keyframes shake {
  from, to {
    transform: translate3d(0, 0, 0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translate3d(-10px, 0, 0);
  }
  20%, 40%, 60%, 80% {
    transform: translate3d(10px, 0, 0);
  }
}
.shake {
  -webkit-animation-name: shake;
  animation-name: shake;
}

@-webkit-keyframes headShake {
  0% {
    transform: translateX(0);
  }
  6.5% {
    transform: translateX(-6px) rotateY(-9deg);
  }
  18.5% {
    transform: translateX(5px) rotateY(7deg);
  }
  31.5% {
    transform: translateX(-3px) rotateY(-5deg);
  }
  43.5% {
    transform: translateX(2px) rotateY(3deg);
  }
  50% {
    transform: translateX(0);
  }
}
@keyframes headShake {
  0% {
    transform: translateX(0);
  }
  6.5% {
    transform: translateX(-6px) rotateY(-9deg);
  }
  18.5% {
    transform: translateX(5px) rotateY(7deg);
  }
  31.5% {
    transform: translateX(-3px) rotateY(-5deg);
  }
  43.5% {
    transform: translateX(2px) rotateY(3deg);
  }
  50% {
    transform: translateX(0);
  }
}
.headShake {
  -webkit-animation-name: headShake;
  animation-name: headShake;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
}

@-webkit-keyframes swing {
  20% {
    transform: rotate3d(0, 0, 1, 15deg);
  }
  40% {
    transform: rotate3d(0, 0, 1, -10deg);
  }
  60% {
    transform: rotate3d(0, 0, 1, 5deg);
  }
  80% {
    transform: rotate3d(0, 0, 1, -5deg);
  }
  to {
    transform: rotate3d(0, 0, 1, 0deg);
  }
}
@keyframes swing {
  20% {
    transform: rotate3d(0, 0, 1, 15deg);
  }
  40% {
    transform: rotate3d(0, 0, 1, -10deg);
  }
  60% {
    transform: rotate3d(0, 0, 1, 5deg);
  }
  80% {
    transform: rotate3d(0, 0, 1, -5deg);
  }
  to {
    transform: rotate3d(0, 0, 1, 0deg);
  }
}
.swing {
  transform-origin: top center;
  -webkit-animation-name: swing;
  animation-name: swing;
}

@-webkit-keyframes tada {
  from {
    transform: scale3d(1, 1, 1);
  }
  10%, 20% {
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }
  30%, 50%, 70%, 90% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }
  40%, 60%, 80% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }
  to {
    transform: scale3d(1, 1, 1);
  }
}
@keyframes tada {
  from {
    transform: scale3d(1, 1, 1);
  }
  10%, 20% {
    transform: scale3d(0.9, 0.9, 0.9) rotate3d(0, 0, 1, -3deg);
  }
  30%, 50%, 70%, 90% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, 3deg);
  }
  40%, 60%, 80% {
    transform: scale3d(1.1, 1.1, 1.1) rotate3d(0, 0, 1, -3deg);
  }
  to {
    transform: scale3d(1, 1, 1);
  }
}
.tada {
  -webkit-animation-name: tada;
  animation-name: tada;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes wobble {
  from {
    transform: translate3d(0, 0, 0);
  }
  15% {
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
  }
  30% {
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
  }
  45% {
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
  }
  60% {
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
  }
  75% {
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes wobble {
  from {
    transform: translate3d(0, 0, 0);
  }
  15% {
    transform: translate3d(-25%, 0, 0) rotate3d(0, 0, 1, -5deg);
  }
  30% {
    transform: translate3d(20%, 0, 0) rotate3d(0, 0, 1, 3deg);
  }
  45% {
    transform: translate3d(-15%, 0, 0) rotate3d(0, 0, 1, -3deg);
  }
  60% {
    transform: translate3d(10%, 0, 0) rotate3d(0, 0, 1, 2deg);
  }
  75% {
    transform: translate3d(-5%, 0, 0) rotate3d(0, 0, 1, -1deg);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.wobble {
  -webkit-animation-name: wobble;
  animation-name: wobble;
}

@-webkit-keyframes jello {
  from, 11.1%, to {
    transform: translate3d(0, 0, 0);
  }
  22.2% {
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }
  33.3% {
    transform: skewX(6.25deg) skewY(6.25deg);
  }
  44.4% {
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }
  55.5% {
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }
  66.6% {
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }
  77.7% {
    transform: skewX(0.39062deg) skewY(0.39062deg);
  }
  88.8% {
    transform: skewX(-0.19531deg) skewY(-0.19531deg);
  }
}
@keyframes jello {
  from, 11.1%, to {
    transform: translate3d(0, 0, 0);
  }
  22.2% {
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }
  33.3% {
    transform: skewX(6.25deg) skewY(6.25deg);
  }
  44.4% {
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }
  55.5% {
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }
  66.6% {
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }
  77.7% {
    transform: skewX(0.39062deg) skewY(0.39062deg);
  }
  88.8% {
    transform: skewX(-0.19531deg) skewY(-0.19531deg);
  }
}
.jello {
  transform-origin: center;
  -webkit-animation-name: jello;
  animation-name: jello;
}

@-webkit-keyframes heartBeat {
  0% {
    transform: scale(1);
  }
  14% {
    transform: scale(1.3);
  }
  28% {
    transform: scale(1);
  }
  42% {
    transform: scale(1.3);
  }
  70% {
    transform: scale(1);
  }
}
@keyframes heartBeat {
  0% {
    transform: scale(1);
  }
  14% {
    transform: scale(1.3);
  }
  28% {
    transform: scale(1);
  }
  42% {
    transform: scale(1.3);
  }
  70% {
    transform: scale(1);
  }
}
.heartBeat {
  -webkit-animation-name: heartBeat;
  animation-name: heartBeat;
  -webkit-animation-duration: 1.3s;
  animation-duration: 1.3s;
  -webkit-animation-timing-function: ease-in-out;
  animation-timing-function: ease-in-out;
}

@-webkit-keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
  20% {
    transform: scale3d(1.1, 1.1, 1.1);
  }
  40% {
    transform: scale3d(0.9, 0.9, 0.9);
  }
  60% {
    transform: scale3d(1.03, 1.03, 1.03);
    opacity: 1;
  }
  80% {
    transform: scale3d(0.97, 0.97, 0.97);
  }
  to {
    transform: scale3d(1, 1, 1);
    opacity: 1;
  }
}
@keyframes bounceIn {
  from, 20%, 40%, 60%, 80%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
  20% {
    transform: scale3d(1.1, 1.1, 1.1);
  }
  40% {
    transform: scale3d(0.9, 0.9, 0.9);
  }
  60% {
    transform: scale3d(1.03, 1.03, 1.03);
    opacity: 1;
  }
  80% {
    transform: scale3d(0.97, 0.97, 0.97);
  }
  to {
    transform: scale3d(1, 1, 1);
    opacity: 1;
  }
}
.bounceIn {
  -webkit-animation-name: bounceIn;
  animation-name: bounceIn;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
}

@-webkit-keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    transform: translate3d(0, -3000px, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(0, 25px, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(0, -10px, 0);
  }
  90% {
    transform: translate3d(0, 5px, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes bounceInDown {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    transform: translate3d(0, -3000px, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(0, 25px, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(0, -10px, 0);
  }
  90% {
    transform: translate3d(0, 5px, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.bounceInDown {
  -webkit-animation-name: bounceInDown;
  animation-name: bounceInDown;
}

@-webkit-keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    transform: translate3d(-3000px, 0, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(25px, 0, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(-10px, 0, 0);
  }
  90% {
    transform: translate3d(5px, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes bounceInLeft {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    transform: translate3d(-3000px, 0, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(25px, 0, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(-10px, 0, 0);
  }
  90% {
    transform: translate3d(5px, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.bounceInLeft {
  -webkit-animation-name: bounceInLeft;
  animation-name: bounceInLeft;
}

@-webkit-keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  from {
    transform: translate3d(3000px, 0, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(-25px, 0, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(10px, 0, 0);
  }
  90% {
    transform: translate3d(-5px, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes bounceInRight {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  from {
    transform: translate3d(3000px, 0, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(-25px, 0, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(10px, 0, 0);
  }
  90% {
    transform: translate3d(-5px, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.bounceInRight {
  -webkit-animation-name: bounceInRight;
  animation-name: bounceInRight;
}

@-webkit-keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  from {
    transform: translate3d(0, 3000px, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(0, -20px, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(0, 10px, 0);
  }
  90% {
    transform: translate3d(0, -5px, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes bounceInUp {
  from, 60%, 75%, 90%, to {
    -webkit-animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  from {
    transform: translate3d(0, 3000px, 0);
    opacity: 0;
  }
  60% {
    transform: translate3d(0, -20px, 0);
    opacity: 1;
  }
  75% {
    transform: translate3d(0, 10px, 0);
  }
  90% {
    transform: translate3d(0, -5px, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.bounceInUp {
  -webkit-animation-name: bounceInUp;
  animation-name: bounceInUp;
}

@-webkit-keyframes bounceOut {
  20% {
    transform: scale3d(0.9, 0.9, 0.9);
  }
  50%, 55% {
    transform: scale3d(1.1, 1.1, 1.1);
    opacity: 1;
  }
  to {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
}
@keyframes bounceOut {
  20% {
    transform: scale3d(0.9, 0.9, 0.9);
  }
  50%, 55% {
    transform: scale3d(1.1, 1.1, 1.1);
    opacity: 1;
  }
  to {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
}
.bounceOut {
  -webkit-animation-name: bounceOut;
  animation-name: bounceOut;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
}

@-webkit-keyframes bounceOutDown {
  20% {
    transform: translate3d(0, 10px, 0);
  }
  40%, 45% {
    transform: translate3d(0, -20px, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(0, 2000px, 0);
    opacity: 0;
  }
}
@keyframes bounceOutDown {
  20% {
    transform: translate3d(0, 10px, 0);
  }
  40%, 45% {
    transform: translate3d(0, -20px, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(0, 2000px, 0);
    opacity: 0;
  }
}
.bounceOutDown {
  -webkit-animation-name: bounceOutDown;
  animation-name: bounceOutDown;
}

@-webkit-keyframes bounceOutLeft {
  20% {
    transform: translate3d(20px, 0, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(-2000px, 0, 0);
    opacity: 0;
  }
}
@keyframes bounceOutLeft {
  20% {
    transform: translate3d(20px, 0, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(-2000px, 0, 0);
    opacity: 0;
  }
}
.bounceOutLeft {
  -webkit-animation-name: bounceOutLeft;
  animation-name: bounceOutLeft;
}

@-webkit-keyframes bounceOutRight {
  20% {
    transform: translate3d(-20px, 0, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(2000px, 0, 0);
    opacity: 0;
  }
}
@keyframes bounceOutRight {
  20% {
    transform: translate3d(-20px, 0, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(2000px, 0, 0);
    opacity: 0;
  }
}
.bounceOutRight {
  -webkit-animation-name: bounceOutRight;
  animation-name: bounceOutRight;
}

@-webkit-keyframes bounceOutUp {
  20% {
    transform: translate3d(0, -10px, 0);
  }
  40%, 45% {
    transform: translate3d(0, 20px, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(0, -2000px, 0);
    opacity: 0;
  }
}
@keyframes bounceOutUp {
  20% {
    transform: translate3d(0, -10px, 0);
  }
  40%, 45% {
    transform: translate3d(0, 20px, 0);
    opacity: 1;
  }
  to {
    transform: translate3d(0, -2000px, 0);
    opacity: 0;
  }
}
.bounceOutUp {
  -webkit-animation-name: bounceOutUp;
  animation-name: bounceOutUp;
}

@-webkit-keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes fadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.fadeIn {
  -webkit-animation-name: fadeIn;
  animation-name: fadeIn;
}

@-webkit-keyframes fadeInDown {
  from {
    transform: translate3d(0, -100%, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInDown {
  from {
    transform: translate3d(0, -100%, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInDown {
  -webkit-animation-name: fadeInDown;
  animation-name: fadeInDown;
}

@-webkit-keyframes fadeInDownBig {
  from {
    transform: translate3d(0, -2000px, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInDownBig {
  from {
    transform: translate3d(0, -2000px, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInDownBig {
  -webkit-animation-name: fadeInDownBig;
  animation-name: fadeInDownBig;
}

@-webkit-keyframes fadeInLeft {
  from {
    transform: translate3d(-100%, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInLeft {
  from {
    transform: translate3d(-100%, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInLeft {
  -webkit-animation-name: fadeInLeft;
  animation-name: fadeInLeft;
}

@-webkit-keyframes fadeInLeftBig {
  from {
    transform: translate3d(-2000px, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInLeftBig {
  from {
    transform: translate3d(-2000px, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInLeftBig {
  -webkit-animation-name: fadeInLeftBig;
  animation-name: fadeInLeftBig;
}

@-webkit-keyframes fadeInRight {
  from {
    transform: translate3d(100%, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInRight {
  from {
    transform: translate3d(100%, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInRight {
  -webkit-animation-name: fadeInRight;
  animation-name: fadeInRight;
}

@-webkit-keyframes fadeInRightBig {
  from {
    transform: translate3d(2000px, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInRightBig {
  from {
    transform: translate3d(2000px, 0, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInRightBig {
  -webkit-animation-name: fadeInRightBig;
  animation-name: fadeInRightBig;
}

@-webkit-keyframes fadeInUp {
  from {
    transform: translate3d(0, 100%, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInUp {
  from {
    transform: translate3d(0, 100%, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

@-webkit-keyframes fadeInUpBig {
  from {
    transform: translate3d(0, 2000px, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes fadeInUpBig {
  from {
    transform: translate3d(0, 2000px, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.fadeInUpBig {
  -webkit-animation-name: fadeInUpBig;
  animation-name: fadeInUpBig;
}

@-webkit-keyframes fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes fadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.fadeOut {
  -webkit-animation-name: fadeOut;
  animation-name: fadeOut;
}

@-webkit-keyframes fadeOutDown {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, 100%, 0);
    opacity: 0;
  }
}
@keyframes fadeOutDown {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, 100%, 0);
    opacity: 0;
  }
}
.fadeOutDown {
  -webkit-animation-name: fadeOutDown;
  animation-name: fadeOutDown;
}

@-webkit-keyframes fadeOutDownBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, 2000px, 0);
    opacity: 0;
  }
}
@keyframes fadeOutDownBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, 2000px, 0);
    opacity: 0;
  }
}
.fadeOutDownBig {
  -webkit-animation-name: fadeOutDownBig;
  animation-name: fadeOutDownBig;
}

@-webkit-keyframes fadeOutLeft {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(-100%, 0, 0);
    opacity: 0;
  }
}
@keyframes fadeOutLeft {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(-100%, 0, 0);
    opacity: 0;
  }
}
.fadeOutLeft {
  -webkit-animation-name: fadeOutLeft;
  animation-name: fadeOutLeft;
}

@-webkit-keyframes fadeOutLeftBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(-2000px, 0, 0);
    opacity: 0;
  }
}
@keyframes fadeOutLeftBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(-2000px, 0, 0);
    opacity: 0;
  }
}
.fadeOutLeftBig {
  -webkit-animation-name: fadeOutLeftBig;
  animation-name: fadeOutLeftBig;
}

@-webkit-keyframes fadeOutRight {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(100%, 0, 0);
    opacity: 0;
  }
}
@keyframes fadeOutRight {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(100%, 0, 0);
    opacity: 0;
  }
}
.fadeOutRight {
  -webkit-animation-name: fadeOutRight;
  animation-name: fadeOutRight;
}

@-webkit-keyframes fadeOutRightBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(2000px, 0, 0);
    opacity: 0;
  }
}
@keyframes fadeOutRightBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(2000px, 0, 0);
    opacity: 0;
  }
}
.fadeOutRightBig {
  -webkit-animation-name: fadeOutRightBig;
  animation-name: fadeOutRightBig;
}

@-webkit-keyframes fadeOutUp {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, -100%, 0);
    opacity: 0;
  }
}
@keyframes fadeOutUp {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, -100%, 0);
    opacity: 0;
  }
}
.fadeOutUp {
  -webkit-animation-name: fadeOutUp;
  animation-name: fadeOutUp;
}

@-webkit-keyframes fadeOutUpBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, -2000px, 0);
    opacity: 0;
  }
}
@keyframes fadeOutUpBig {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(0, -2000px, 0);
    opacity: 0;
  }
}
.fadeOutUpBig {
  -webkit-animation-name: fadeOutUpBig;
  animation-name: fadeOutUpBig;
}

@-webkit-keyframes flip {
  from {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 0) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  40% {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  50% {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  80% {
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95) translate3d(0, 0, 0) rotate3d(0, 1, 0, 0deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  to {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 0) rotate3d(0, 1, 0, 0deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}
@keyframes flip {
  from {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 0) rotate3d(0, 1, 0, -360deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  40% {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -190deg);
    -webkit-animation-timing-function: ease-out;
    animation-timing-function: ease-out;
  }
  50% {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 150px) rotate3d(0, 1, 0, -170deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  80% {
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95) translate3d(0, 0, 0) rotate3d(0, 1, 0, 0deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  to {
    transform: perspective(400px) scale3d(1, 1, 1) translate3d(0, 0, 0) rotate3d(0, 1, 0, 0deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
}
.animated.flip {
  -webkit-animation-name: flip;
  animation-name: flip;
  -webkit-backface-visibility: visible;
  backface-visibility: visible;
}

@-webkit-keyframes flipInX {
  from {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1;
  }
  80% {
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
  }
  to {
    transform: perspective(400px);
  }
}
@keyframes flipInX {
  from {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    transform: perspective(400px) rotate3d(1, 0, 0, 10deg);
    opacity: 1;
  }
  80% {
    transform: perspective(400px) rotate3d(1, 0, 0, -5deg);
  }
  to {
    transform: perspective(400px);
  }
}
.flipInX {
  -webkit-animation-name: flipInX;
  animation-name: flipInX;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@-webkit-keyframes flipInY {
  from {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1;
  }
  80% {
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
  }
  to {
    transform: perspective(400px);
  }
}
@keyframes flipInY {
  from {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotate3d(0, 1, 0, -20deg);
    -webkit-animation-timing-function: ease-in;
    animation-timing-function: ease-in;
  }
  60% {
    transform: perspective(400px) rotate3d(0, 1, 0, 10deg);
    opacity: 1;
  }
  80% {
    transform: perspective(400px) rotate3d(0, 1, 0, -5deg);
  }
  to {
    transform: perspective(400px);
  }
}
.flipInY {
  -webkit-animation-name: flipInY;
  animation-name: flipInY;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@-webkit-keyframes flipOutX {
  from {
    transform: perspective(400px);
  }
  30% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1;
  }
  to {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0;
  }
}
@keyframes flipOutX {
  from {
    transform: perspective(400px);
  }
  30% {
    transform: perspective(400px) rotate3d(1, 0, 0, -20deg);
    opacity: 1;
  }
  to {
    transform: perspective(400px) rotate3d(1, 0, 0, 90deg);
    opacity: 0;
  }
}
.flipOutX {
  -webkit-animation-name: flipOutX;
  animation-name: flipOutX;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@-webkit-keyframes flipOutY {
  from {
    transform: perspective(400px);
  }
  30% {
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1;
  }
  to {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0;
  }
}
@keyframes flipOutY {
  from {
    transform: perspective(400px);
  }
  30% {
    transform: perspective(400px) rotate3d(0, 1, 0, -15deg);
    opacity: 1;
  }
  to {
    transform: perspective(400px) rotate3d(0, 1, 0, 90deg);
    opacity: 0;
  }
}
.flipOutY {
  -webkit-animation-name: flipOutY;
  animation-name: flipOutY;
  -webkit-animation-duration: 0.75s;
  animation-duration: 0.75s;
  -webkit-backface-visibility: visible !important;
  backface-visibility: visible !important;
}

@-webkit-keyframes lightSpeedIn {
  from {
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }
  60% {
    transform: skewX(20deg);
    opacity: 1;
  }
  80% {
    transform: skewX(-5deg);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes lightSpeedIn {
  from {
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }
  60% {
    transform: skewX(20deg);
    opacity: 1;
  }
  80% {
    transform: skewX(-5deg);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.lightSpeedIn {
  -webkit-animation-name: lightSpeedIn;
  animation-name: lightSpeedIn;
  -webkit-animation-timing-function: ease-out;
  animation-timing-function: ease-out;
}

@-webkit-keyframes lightSpeedOut {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}
@keyframes lightSpeedOut {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}
.lightSpeedOut {
  -webkit-animation-name: lightSpeedOut;
  animation-name: lightSpeedOut;
  -webkit-animation-timing-function: ease-in;
  animation-timing-function: ease-in;
}

@-webkit-keyframes rotateIn {
  from {
    transform: rotate3d(0, 0, 1, -200deg);
    transform-origin: center;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: center;
    opacity: 1;
  }
}
@keyframes rotateIn {
  from {
    transform: rotate3d(0, 0, 1, -200deg);
    transform-origin: center;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: center;
    opacity: 1;
  }
}
.rotateIn {
  -webkit-animation-name: rotateIn;
  animation-name: rotateIn;
}

@-webkit-keyframes rotateInDownLeft {
  from {
    transform: rotate3d(0, 0, 1, -45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: left bottom;
    opacity: 1;
  }
}
@keyframes rotateInDownLeft {
  from {
    transform: rotate3d(0, 0, 1, -45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: left bottom;
    opacity: 1;
  }
}
.rotateInDownLeft {
  -webkit-animation-name: rotateInDownLeft;
  animation-name: rotateInDownLeft;
}

@-webkit-keyframes rotateInDownRight {
  from {
    transform: rotate3d(0, 0, 1, 45deg);
    transform-origin: right bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: right bottom;
    opacity: 1;
  }
}
@keyframes rotateInDownRight {
  from {
    transform: rotate3d(0, 0, 1, 45deg);
    transform-origin: right bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: right bottom;
    opacity: 1;
  }
}
.rotateInDownRight {
  -webkit-animation-name: rotateInDownRight;
  animation-name: rotateInDownRight;
}

@-webkit-keyframes rotateInUpLeft {
  from {
    transform: rotate3d(0, 0, 1, 45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: left bottom;
    opacity: 1;
  }
}
@keyframes rotateInUpLeft {
  from {
    transform: rotate3d(0, 0, 1, 45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: left bottom;
    opacity: 1;
  }
}
.rotateInUpLeft {
  -webkit-animation-name: rotateInUpLeft;
  animation-name: rotateInUpLeft;
}

@-webkit-keyframes rotateInUpRight {
  from {
    transform: rotate3d(0, 0, 1, -90deg);
    transform-origin: right bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: right bottom;
    opacity: 1;
  }
}
@keyframes rotateInUpRight {
  from {
    transform: rotate3d(0, 0, 1, -90deg);
    transform-origin: right bottom;
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    transform-origin: right bottom;
    opacity: 1;
  }
}
.rotateInUpRight {
  -webkit-animation-name: rotateInUpRight;
  animation-name: rotateInUpRight;
}

@-webkit-keyframes rotateOut {
  from {
    transform-origin: center;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, 200deg);
    transform-origin: center;
    opacity: 0;
  }
}
@keyframes rotateOut {
  from {
    transform-origin: center;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, 200deg);
    transform-origin: center;
    opacity: 0;
  }
}
.rotateOut {
  -webkit-animation-name: rotateOut;
  animation-name: rotateOut;
}

@-webkit-keyframes rotateOutDownLeft {
  from {
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, 45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
}
@keyframes rotateOutDownLeft {
  from {
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, 45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
}
.rotateOutDownLeft {
  -webkit-animation-name: rotateOutDownLeft;
  animation-name: rotateOutDownLeft;
}

@-webkit-keyframes rotateOutDownRight {
  from {
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, -45deg);
    transform-origin: right bottom;
    opacity: 0;
  }
}
@keyframes rotateOutDownRight {
  from {
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, -45deg);
    transform-origin: right bottom;
    opacity: 0;
  }
}
.rotateOutDownRight {
  -webkit-animation-name: rotateOutDownRight;
  animation-name: rotateOutDownRight;
}

@-webkit-keyframes rotateOutUpLeft {
  from {
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, -45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
}
@keyframes rotateOutUpLeft {
  from {
    transform-origin: left bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, -45deg);
    transform-origin: left bottom;
    opacity: 0;
  }
}
.rotateOutUpLeft {
  -webkit-animation-name: rotateOutUpLeft;
  animation-name: rotateOutUpLeft;
}

@-webkit-keyframes rotateOutUpRight {
  from {
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, 90deg);
    transform-origin: right bottom;
    opacity: 0;
  }
}
@keyframes rotateOutUpRight {
  from {
    transform-origin: right bottom;
    opacity: 1;
  }
  to {
    transform: rotate3d(0, 0, 1, 90deg);
    transform-origin: right bottom;
    opacity: 0;
  }
}
.rotateOutUpRight {
  -webkit-animation-name: rotateOutUpRight;
  animation-name: rotateOutUpRight;
}

@-webkit-keyframes hinge {
  0% {
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  20%, 60% {
    transform: rotate3d(0, 0, 1, 80deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  40%, 80% {
    transform: rotate3d(0, 0, 1, 60deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1;
  }
  to {
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}
@keyframes hinge {
  0% {
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  20%, 60% {
    transform: rotate3d(0, 0, 1, 80deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
  }
  40%, 80% {
    transform: rotate3d(0, 0, 1, 60deg);
    transform-origin: top left;
    -webkit-animation-timing-function: ease-in-out;
    animation-timing-function: ease-in-out;
    opacity: 1;
  }
  to {
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}
.hinge {
  -webkit-animation-name: hinge;
  animation-name: hinge;
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
}

@-webkit-keyframes jackInTheBox {
  from {
    transform: scale(0.1) rotate(30deg);
    transform-origin: center bottom;
    opacity: 0;
  }
  50% {
    transform: rotate(-10deg);
  }
  70% {
    transform: rotate(3deg);
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
@keyframes jackInTheBox {
  from {
    transform: scale(0.1) rotate(30deg);
    transform-origin: center bottom;
    opacity: 0;
  }
  50% {
    transform: rotate(-10deg);
  }
  70% {
    transform: rotate(3deg);
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.jackInTheBox {
  -webkit-animation-name: jackInTheBox;
  animation-name: jackInTheBox;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes rollIn {
  from {
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
@keyframes rollIn {
  from {
    transform: translate3d(-100%, 0, 0) rotate3d(0, 0, 1, -120deg);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
.rollIn {
  -webkit-animation-name: rollIn;
  animation-name: rollIn;
}

/* originally authored by Nick Pettit - https://github.com/nickpettit/glide */
@-webkit-keyframes rollOut {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    opacity: 0;
  }
}
@keyframes rollOut {
  from {
    opacity: 1;
  }
  to {
    transform: translate3d(100%, 0, 0) rotate3d(0, 0, 1, 120deg);
    opacity: 0;
  }
}
.rollOut {
  -webkit-animation-name: rollOut;
  animation-name: rollOut;
}

@-webkit-keyframes zoomIn {
  from {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
}
@keyframes zoomIn {
  from {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
}
.zoomIn {
  -webkit-animation-name: zoomIn;
  animation-name: zoomIn;
}

@-webkit-keyframes zoomInDown {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
@keyframes zoomInDown {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
.zoomInDown {
  -webkit-animation-name: zoomInDown;
  animation-name: zoomInDown;
}

@-webkit-keyframes zoomInLeft {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
@keyframes zoomInLeft {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
.zoomInLeft {
  -webkit-animation-name: zoomInLeft;
  animation-name: zoomInLeft;
}

@-webkit-keyframes zoomInRight {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
@keyframes zoomInRight {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
.zoomInRight {
  -webkit-animation-name: zoomInRight;
  animation-name: zoomInRight;
}

@-webkit-keyframes zoomInUp {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
@keyframes zoomInUp {
  from {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 0;
  }
  60% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 1;
  }
}
.zoomInUp {
  -webkit-animation-name: zoomInUp;
  animation-name: zoomInUp;
}

@-webkit-keyframes zoomOut {
  from {
    opacity: 1;
  }
  50% {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
  to {
    opacity: 0;
  }
}
@keyframes zoomOut {
  from {
    opacity: 1;
  }
  50% {
    transform: scale3d(0.3, 0.3, 0.3);
    opacity: 0;
  }
  to {
    opacity: 0;
  }
}
.zoomOut {
  -webkit-animation-name: zoomOut;
  animation-name: zoomOut;
}

@-webkit-keyframes zoomOutDown {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 1;
  }
  to {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 0;
  }
}
@keyframes zoomOutDown {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 1;
  }
  to {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 0;
  }
}
.zoomOutDown {
  -webkit-animation-name: zoomOutDown;
  animation-name: zoomOutDown;
}

@-webkit-keyframes zoomOutLeft {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    opacity: 1;
  }
  to {
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform-origin: left center;
    opacity: 0;
  }
}
@keyframes zoomOutLeft {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
    opacity: 1;
  }
  to {
    transform: scale(0.1) translate3d(-2000px, 0, 0);
    transform-origin: left center;
    opacity: 0;
  }
}
.zoomOutLeft {
  -webkit-animation-name: zoomOutLeft;
  animation-name: zoomOutLeft;
}

@-webkit-keyframes zoomOutRight {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    opacity: 1;
  }
  to {
    transform: scale(0.1) translate3d(2000px, 0, 0);
    transform-origin: right center;
    opacity: 0;
  }
}
@keyframes zoomOutRight {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
    opacity: 1;
  }
  to {
    transform: scale(0.1) translate3d(2000px, 0, 0);
    transform-origin: right center;
    opacity: 0;
  }
}
.zoomOutRight {
  -webkit-animation-name: zoomOutRight;
  animation-name: zoomOutRight;
}

@-webkit-keyframes zoomOutUp {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 1;
  }
  to {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 0;
  }
}
@keyframes zoomOutUp {
  40% {
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    -webkit-animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
    opacity: 1;
  }
  to {
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    transform-origin: center bottom;
    -webkit-animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
    opacity: 0;
  }
}
.zoomOutUp {
  -webkit-animation-name: zoomOutUp;
  animation-name: zoomOutUp;
}

@-webkit-keyframes slideInDown {
  from {
    visibility: visible;
    transform: translate3d(0, -100%, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes slideInDown {
  from {
    visibility: visible;
    transform: translate3d(0, -100%, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.slideInDown {
  -webkit-animation-name: slideInDown;
  animation-name: slideInDown;
}

@-webkit-keyframes slideInLeft {
  from {
    visibility: visible;
    transform: translate3d(-100%, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes slideInLeft {
  from {
    visibility: visible;
    transform: translate3d(-100%, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.slideInLeft {
  -webkit-animation-name: slideInLeft;
  animation-name: slideInLeft;
}

@-webkit-keyframes slideInRight {
  from {
    visibility: visible;
    transform: translate3d(100%, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes slideInRight {
  from {
    visibility: visible;
    transform: translate3d(100%, 0, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.slideInRight {
  -webkit-animation-name: slideInRight;
  animation-name: slideInRight;
}

@-webkit-keyframes slideInUp {
  from {
    visibility: visible;
    transform: translate3d(0, 100%, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
@keyframes slideInUp {
  from {
    visibility: visible;
    transform: translate3d(0, 100%, 0);
  }
  to {
    transform: translate3d(0, 0, 0);
  }
}
.slideInUp {
  -webkit-animation-name: slideInUp;
  animation-name: slideInUp;
}

@-webkit-keyframes slideOutDown {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(0, 100%, 0);
  }
}
@keyframes slideOutDown {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(0, 100%, 0);
  }
}
.slideOutDown {
  -webkit-animation-name: slideOutDown;
  animation-name: slideOutDown;
}

@-webkit-keyframes slideOutLeft {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(-100%, 0, 0);
  }
}
@keyframes slideOutLeft {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(-100%, 0, 0);
  }
}
.slideOutLeft {
  -webkit-animation-name: slideOutLeft;
  animation-name: slideOutLeft;
}

@-webkit-keyframes slideOutRight {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(100%, 0, 0);
  }
}
@keyframes slideOutRight {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(100%, 0, 0);
  }
}
.slideOutRight {
  -webkit-animation-name: slideOutRight;
  animation-name: slideOutRight;
}

@-webkit-keyframes slideOutUp {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(0, -100%, 0);
  }
}
@keyframes slideOutUp {
  from {
    transform: translate3d(0, 0, 0);
  }
  to {
    visibility: hidden;
    transform: translate3d(0, -100%, 0);
  }
}
.slideOutUp {
  -webkit-animation-name: slideOutUp;
  animation-name: slideOutUp;
}

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

.animated.infinite {
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}

.animated.delay-1s {
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
}

.animated.delay-2s {
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
}

.animated.delay-3s {
  -webkit-animation-delay: 3s;
  animation-delay: 3s;
}

.animated.delay-4s {
  -webkit-animation-delay: 4s;
  animation-delay: 4s;
}

.animated.delay-5s {
  -webkit-animation-delay: 5s;
  animation-delay: 5s;
}

.animated.fast {
  -webkit-animation-duration: 800ms;
  animation-duration: 800ms;
}

.animated.faster {
  -webkit-animation-duration: 500ms;
  animation-duration: 500ms;
}

.animated.slow {
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
}

.animated.slower {
  -webkit-animation-duration: 3s;
  animation-duration: 3s;
}

@media (print), (prefers-reduced-motion: reduce) {
  .animated {
    transition-duration: 1ms !important;
    -webkit-animation-duration: 1ms !important;
    animation-duration: 1ms !important;
    -webkit-animation-iteration-count: 1 !important;
    animation-iteration-count: 1 !important;
  }
}
.spi, .spib, .sp {
  display: none;
}

.pci {
  display: inline;
}

.pcib {
  display: inline-block;
}

.pc {
  display: block;
}

@media screen and (max-width: 765px) {
  .pci, .pcib, .pc {
    display: none;
  }

  .spi {
    display: inline;
  }

  .spib {
    display: inline-block;
  }

  .sp {
    display: block;
  }
}
html, body, div, span, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  border: 0;
  outline: 0;
  background: transparent;
}

article, main, details, aside, footer, header, nav, section, div, h1, h2, h3, h4, h5, h6, p, ul, li, ol, dl, dt, dd, address, article, main, details, aside, footer, header, nav, section, div, h1, h2, h3, h4, h5, h6, p, ul, li, ol, dl, dt, dd, address, small {
  display: block;
  box-sizing: border-box;
}

nav ul {
  list-style: none;
}

a, span {
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  background: transparent;
}

table {
  border-spacing: 0;
  border-collapse: collapse;
}

input, select {
  vertical-align: middle;
}

* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
  -webkit-overflow-scrolling: touch;
}

.sup {
  font-size: 0.5em;
  display: inline-block;
  transform: translate3d(0, -0.7em, 0);
}

body {
  font-family: YakuHanJP, "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 1;
  text-align: justify;
  color: #000;
  background: #FFF;
  -webkit-text-size-adjust: 100%;
}

@media screen and (max-width: 765px), print {
  body h1, body h2, body h3, body h4, body p, body ul, body li, body div, body section, body span, body nav, body main, body a, body header, body picture {
    max-width: none !important;
    max-height: none !important;
  }
}
a {
  transition: opacity 0.2s;
}
a:link, a:visited, a:hover, a:active {
  text-decoration: none;
  color: #000;
}
a:hover {
  opacity: 0.8;
}

#char, #tech, #earthplus, #doyouknow, #vs, #oilsmasher, #survey, #casestudy, #movie, #lineup, #faq, #instagram, #news, #about, #others, #parts, #care, #spec {
  margin-top: -84px;
  padding-top: 85px;
}

#other {
  margin-top: -85px;
  padding-top: 100px;
}

.pagetop {
  position: fixed;
  right: 42px;
  bottom: 86px;
  display: block;
  width: 46.58px;
  cursor: pointer;
  transition: all 600ms cubic-bezier(0.04, 0.51, 0.155, 0.985);
  transform: translate3d(0, 200px, 0);
  z-index: 50;
}
@media screen and (max-width: 765px), print {
  .pagetop {
    right: 15px;
    bottom: 69px;
    width: 59px;
    margin-right: 0;
  }
}

.docreq-fixed {
  position: fixed;
  right: -7px;
  bottom: 170px;
  display: block;
  width: 106px;
  cursor: pointer;
  z-index: 50;
}
@media screen and (max-width: 765px), print {
  .docreq-fixed {
    display: none;
  }
}

body.scroll .pagetop {
  transform: none;
}

.container {
  position: relative;
  overflow: hidden;
  width: 100%;
  height: 0;
  transition: all 800ms cubic-bezier(0.04, 0.51, 0.155, 0.985);
  pointer-events: none;
  opacity: 0;
}
@media screen and (max-width: 765px), print {
  .container.-top {
    padding-bottom: 62px;
  }
}

.container.ready {
  height: auto;
  pointer-events: auto;
  opacity: 1;
}

@keyframes fadeInUp {
  from {
    transform: translate3d(0, 10px, 0);
    opacity: 0;
  }
  to {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}
img {
  width: 100%;
}

.loading {
  position: fixed;
  z-index: 100;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 600ms cubic-bezier(0.04, 0.51, 0.155, 0.985);
  transform: translate3d(0, -10px, 0);
  background: #FFF;
}
.loading__img {
  width: 200px;
  transition: all 1000ms cubic-bezier(0.04, 0.51, 0.155, 0.985);
  transform: translate3d(0, -20px, 0);
  opacity: 0;
}
.loading__img.progress {
  transform: none;
  opacity: 0;
}
.loading__img.ready {
  transform: translate3d(0, -20px, 0) !important;
  opacity: 0 !important;
}

.loading.progress {
  transform: none;
}

.loading.ready {
  transform: translate3d(0, -1000px, 0);
  pointer-events: none;
  opacity: 0;
  filter: blur(10px, 10px);
}

.mv-lower {
  width: 100%;
  height: 295px;
  margin-top: 75px;
}
.mv-lower__h1 {
  padding-top: 146.3px;
  text-align: center;
}
.mv-lower__h1 span {
  font-size: 35px;
  font-weight: 900;
  letter-spacing: 1.4px;
  text-align: center;
  color: #FFF;
}
.mv-lower__h1 small {
  display: block;
  padding-top: 23px;
  font-size: 17px;
  font-weight: 300;
  line-height: 1;
  letter-spacing: 1.7px;
  text-align: center;
  color: #FFF;
}

@media screen and (max-width: 765px) {
  .mv-lower {
    height: 125px;
    margin-top: 63px;
  }
  .mv-lower__h1 {
    padding-top: 42.5px;
  }
  .mv-lower__h1 span {
    font-size: 17.5px;
    letter-spacing: 0.7px;
  }
  .mv-lower__h1 small {
    font-size: 12px;
    padding-top: 7px;
    letter-spacing: 1.2px;
  }

  /*---------------------------------
            .lower-h2 
    ---------------------------------*/
  .lower-h2 {
    font-size: 15px;
    line-height: 1.51;
    margin-bottom: 25px;
    padding-bottom: 13.2px;
    letter-spacing: 2.4px;
  }

  .lower-h2 img {
    display: none;
  }

  .lower-h2:after {
    width: 35px;
  }
}
.anime-split {
  position: relative;
  display: block;
  overflow: hidden;
  transform: translate3d(0, 0, 0);
  border-width: 0;
}

.anime-split.active {
  border-width: 1px;
}

.anime-split > * {
  position: relative;
  display: block;
  transition: all 0.5s;
  transform: translate3d(0, -100%, 0);
  transform-origin: 0 50%;
}

.anime-split.active > * {
  transform: none;
}

.anime-split--up > * {
  transition: all 1s;
  transform: translate3d(0, 100%, 0);
}

.lower-h2 {
  font-size: 27px;
  font-weight: 500;
  line-height: 1.67;
  position: relative;
  margin-bottom: 45px;
  padding-bottom: 30px;
  text-align: center;
  letter-spacing: 4.32px;
  color: #1896C8;
}

.lower-h2 img {
  width: 387.2px;
  margin-bottom: 15px;
}

.lower-h2:after {
  position: absolute;
  bottom: 0;
  left: 50%;
  display: block;
  width: 68px;
  height: 2px;
  content: "";
  transform: translateX(-50%);
  background-color: #1896C8;
}

.header {
  position: fixed;
  z-index: 50;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  width: 100%;
  height: 85px;
  transition: opacity, transform, background-color 1000ms cubic-bezier(0.04, 0.51, 0.155, 0.985);
  transform: translate3d(0, -50px, 0);
  transform-origin: center;
  opacity: 0;
}
.header.-on {
  z-index: 101;
}
.header.ready {
  transform: none;
  opacity: 1;
}
.header__logo {
  position: absolute;
  top: 28px;
  left: 33.8px;
  width: 129.2px;
  height: 35.7px;
}
.header__logo a {
  display: block;
  width: 100%;
  height: 100%;
  background: url("../img/logo-white.svg") no-repeat center/contain;
}
.header__nav {
  display: flex;
  align-items: center;
  justify-content: center;
}
.header__links {
  margin-right: 31px;
}
.header__links li {
  display: inline-block;
  margin-right: 26px;
  position: relative;
}
.header__links li:last-child {
  margin-right: 8px;
}
.header__links li.-active:after {
  position: absolute;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
  display: block;
  width: 6px;
  height: 6px;
  content: "";
  background-color: #1896C8;
}
.header__links a {
  font-size: 13px;
}
.header__links a:link, .header__links a:visited, .header__links a:hover, .header__links a:active {
  color: #FFF;
}
.header__square {
  display: flex;
}
.header__instagram {
  font-size: 10px;
  position: relative;
  display: block;
  width: 85px;
  height: 85px;
  text-align: center;
  color: #6B6B6B !important;
  background: #E8E8E8;
}
.header__instagram img {
  width: 28.7px;
  height: auto;
  padding-top: 19.8px;
}
.header__instagram span {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.header__doc {
  position: relative;
  display: none;
  width: 85px;
  height: 85px;
  text-align: center;
  color: #FFF !important;
  background: #1896C8;
  font-size: 9px;
  font-weight: 500;
  line-height: 1.22;
  letter-spacing: 0.68px;
}
.header__doc img {
  width: 32.805px;
  height: auto;
  padding-top: 17px;
}
.header__doc span {
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.header__request {
  position: relative;
  display: block;
  width: 85px;
  height: 85px;
  text-align: center;
  color: #FFF !important;
  background: #79C2DF;
  font-size: 9px;
  font-weight: 500;
  line-height: 1.22;
  letter-spacing: 0.68px;
}
.header__request img {
  width: 32.6px;
  height: auto;
  padding-top: 24.8px;
}
.header__request span {
  position: absolute;
  bottom: 8px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.header__contact {
  font-size: 9px;
  position: relative;
  display: block;
  width: 85px;
  height: 85px;
  text-align: center;
  color: #FFF !important;
  background: #1896C8;
}
.header__contact img {
  width: 34.4px;
  height: auto;
  padding-top: 16.5px;
}
.header__contact span {
  position: absolute;
  bottom: 12px;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
}
.header__close-btn {
  display: none;
}

.header.-lower .header__links a:link, .header.-lower .header__links a:visited, .header.-lower .header__links a:hover, .header.-lower .header__links a:active {
  color: #FFF;
}

.header.header_with_bg {
  background-color: #FFF;
}
.header.header_with_bg .header__links a:link, .header.header_with_bg .header__links a:visited, .header.header_with_bg .header__links a:hover, .header.header_with_bg .header__links a:active {
  color: #000;
}
.header.header_with_bg .header__logo a {
  background: url("../img/logo.svg") no-repeat center/contain;
}

.header.-black .header__logo a {
  background: url("../img/logo.svg") no-repeat center/contain !important;
}
.header.-black .header__links a:link, .header.-black .header__links a:visited, .header.-black .header__links a:hover, .header.-black .header__links a:active {
  color: #000;
}

.sp-menubar {
  display: none;
}

@media screen and (max-width: 1155px) {
  .header {
    height: 57.7px;
  }
  .header__logo {
    top: 21.4px;
    left: 17.2px;
    width: 106.3px;
    height: 29.4px;
  }
  .header__nav {
    position: fixed;
    display: block;
    z-index: 51;
    top: 0;
    left: 0;
    transform: translateX(100%);
    transition: all 0.2s;
    overflow-y: scroll;
    width: 100%;
    height: 100%;
    padding-top: 60px;
    background-color: #E8E8E8;
  }
  .header__nav.-on {
    transform: none;
  }
  .header__nav.-on .header__close-btn {
    display: block;
  }
  .header__close-btn {
    display: none;
    position: fixed;
    top: 17px;
    right: 17px;
    width: 25px;
    z-index: 2;
  }
  .header__instagram {
    display: none;
  }
  .header__links {
    width: 100%;
    margin-right: 0;
  }
  .header__links li {
    display: block;
    margin-right: 26px;
    margin-right: 0;
    text-align: center;
    border-top: solid 1px #C6C6C6;
  }
  .header__links li:first-child {
    border-top: none;
  }
  .header__links li:last-child {
    margin-right: 0;
  }
  .header__links li.-active:after {
    content: none;
  }
  .header__links a {
    font-size: 18.5px;
    font-weight: 500;
    letter-spacing: 1.67px;
    display: block;
    padding: 18px 0;
    color: #6B6B6B;
  }
  .header__links a:link, .header__links a:visited, .header__links a:hover, .header__links a:active {
    color: #6B6B6B;
  }
  .header__square {
    width: 100%;
  }
  .header__request, .header__contact, .header__doc {
    display: block;
    height: 97.3px;
    width: 33.3333%;
    text-align: center;
  }
  .header__request span, .header__contact span, .header__doc span {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.45;
    letter-spacing: 1.17px;
    bottom: 12px;
  }
  .header__request small, .header__contact small, .header__doc small {
    display: inline;
  }
  .header__request img {
    width: 41.9px;
  }
  .header__contact img {
    width: 37.9px;
  }

  .sp-menubar {
    display: flex;
    align-items: center;
    justify-content: flex-end;
  }
  .sp-menubar__instagram {
    display: block;
    height: 57.7px;
    width: 57.8px;
    background-color: #E8E8E8;
    text-align: center;
    padding-top: 10px;
    box-sizing: border-box;
  }
  .sp-menubar__instagram span {
    display: block;
    margin-top: 4px;
    font-size: 9.5px;
    font-weight: 500;
    letter-spacing: 0.33px;
    color: #6B6B6B;
  }
  .sp-menubar__instagram img {
    width: 26.5px;
  }
  .sp-menubar__burger {
    height: 57.7px;
    width: 57.8px;
    background-color: #1896C8;
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .sp-menubar__burger img {
    width: 26.8px;
    height: 26.8px;
  }
}
@media screen and (max-width: 765px) {
  .sup {
    font-size: 0.9em;
    transform: translate3d(0, -0.25em, 0);
    letter-spacing: 0;
  }
}
@media screen and (max-width: 765px) {
  .loading__img {
    width: 100px;
  }
}
.instafeed {
  width: 1000px;
  margin: 0 auto;
}
.instafeed__wrap {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.instafeed a {
  display: flex;
  overflow: hidden;
  align-items: center;
  justify-content: center;
  width: 235px;
  height: 235px;
  margin-right: 20px;
  margin-bottom: 20px;
}
.instafeed a:nth-child(4n) {
  margin-right: 0;
}
.instafeed__img {
  width: 100%;
  transition: 0.3s;
}
.instafeed__img:hover {
  transform: scale(1.08);
}

@media screen and (max-width: 765px) {
  .instafeed {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .instafeed__wrap {
    flex-wrap: wrap;
    justify-content: space-between;
  }
  .instafeed a {
    width: 48.5%;
    height: auto;
    margin-right: 1.5%;
    margin-bottom: 10px;
  }
  .instafeed a:nth-child(2n) {
    margin-right: 0;
  }
  .instafeed .pc {
    display: none !important;
  }
}
/*---------------------------------
            .mv-feature
---------------------------------*/
.mv-feature {
  background: url("../img/feature_mv.png") no-repeat center/cover;
}

/*---------------------------------
            .feature-inner
---------------------------------*/
.feature-inner {
  width: 980px;
  margin: 0 auto;
}

/*---------------------------------
            .scroll-link
---------------------------------*/
.scroll-link {
  line-height: 1;
  padding: 10px 0;
  text-align: center;
  border: solid 1px #000;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 1.1px;
  text-align: center;
  color: #000;
  box-shadow: 1px 1px 3px 0 rgba(0, 0, 0, 0.2);
}
.scroll-link:link, .scroll-link:visited, .scroll-link:hover, .scroll-link:active {
  color: #000;
}
.scroll-link span {
  line-height: 1;
  display: block;
  margin: 0 auto;
}
.scroll-link span img {
  width: 17.8px;
}

.scroll-link-wrapper {
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  width: 100%;
}

.scroll-link-wrapper > * {
  width: 49%;
}

@media screen and (max-width: 765px) {
  .scroll-link {
    font-size: 12px;
    font-weight: bold;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    padding-bottom: 18px;
  }
  .scroll-link span {
    position: absolute;
    bottom: 5px;
    left: 50%;
    transform: translateX(-50%);
  }
  .scroll-link span img {
    width: 10.35px;
  }

  .scroll-link-wrapper > * {
    width: 49.9%;
  }
}
.mv-casestudy {
  background: url("../img/casestudy_mv.png") no-repeat center/cover;
}

@media screen and (max-width: 765px) {
  .mv-casestudy {
    background: url("../img/casestudy_mv_sp.png") no-repeat center/cover;
  }
}
.mv-lineup {
  background: url("../img/lineup_mv.png") no-repeat center/cover;
}

.liu__main {
  padding-top: 73px;
  padding-bottom: 100px;
  background: linear-gradient(180deg, #FFFFE4 0%, rgb(255, 255, 255) 60%, rgb(201, 235, 235) 100%);
}
.liu__inner {
  width: 1000px;
  margin: 0 auto;
}
.liu__headmsg {
  font-size: 28px;
  font-weight: bold;
  line-height: 1.61;
  letter-spacing: 1.4px;
  text-align: center;
  color: #FFF;
  background-color: #000;
  padding: 22px 0 30.8px;
}
.liu__h2 {
  margin-bottom: 55px;
  text-align: center;
  font-size: 23px;
  font-weight: 500;
  letter-spacing: 2.3px;
  color: #000;
}
.liu__label-wrap {
  margin-bottom: 39px;
  text-align: center;
}
.liu__label-blue {
  display: inline-block;
  width: 231px;
  height: 45px;
  border: solid 1px #1896C8;
  line-height: 45px;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.5px;
  text-align: center;
  color: #1896C8;
}
.liu__label-blue:first-child {
  margin-right: 20px;
}
.liu__products {
  width: 921px;
  margin: 0 auto 105px auto;
  pointer-events: none;
}
.liu__products2 {
  display: block;
  width: 587px;
  margin: 0 auto 92px;
  pointer-events: none;
}
.liu__appearance {
  margin-bottom: 85px;
  text-align: center;
}
.liu__appearance img {
  width: 433.6px;
}

.lu-detail__table {
  width: 100%;
}
.lu-detail__table:first-child {
  margin-bottom: 99px;
}
.lu-detail__table th, .lu-detail__table td {
  font-size: 16px;
  font-weight: 300;
  line-height: 1.8;
  padding: 0.6em 1em;
  text-align: left;
  border: solid 1px #3E3A39;
  background-color: #CCC;
}
.lu-detail__table td:last-child {
  background-color: #FFF;
}
.lu-detail__table:first-child td:last-child {
  width: 540px;
}
.lu-detail__table .c-center {
  text-align: left;
}
.lu-detail__table .c-vcenter {
  vertical-align: middle;
}
.lu-detail__table--parts td {
  text-align: center;
}
.lu-detail__table--parts td:first-child {
  text-align: left;
}

.lu-detail__blue-cell td {
  font-weight: 500;
}
.lu-detail__blue-cell td:first-child {
  background-color: #95B2BE;
}
.lu-detail__blue-cell td:last-child {
  background-color: #BADFEE;
}

.lu-shoplink {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 55px 34px 30px;
  background-color: #FFF;
}
.lu-shoplink__caution {
  font-size: 17px;
  font-weight: 300;
  position: absolute;
  top: 13px;
  left: 13px;
  letter-spacing: 0.03em;
}
.lu-shoplink span {
  font-size: 15px;
  font-weight: 300;
  letter-spacing: 0.38px;
  color: #000;
}
.lu-shoplink img {
  width: 277px;
}
.lu-shoplink a {
  font-size: 19px;
  font-weight: 500;
  display: block;
  width: 420px;
  padding: 30px 0;
  text-align: center;
  letter-spacing: 0.48px;
  color: #FFF;
  background-color: #1896C8;
}

.lu-sticker {
  background-color: #FFF;
}
.lu-sticker__wrap {
  display: flex;
  align-items: stretch;
  justify-content: center;
}
.lu-sticker__left-img {
  display: flex;
  flex-grow: 0;
  flex-shrink: 0;
  justify-content: flex-end;
  width: 55%;
}
.lu-sticker__left-img img {
  width: 100%;
}
.lu-sticker__right-content {
  flex-grow: 0;
  flex-shrink: 0;
  width: 45%;
  text-align: center;
  background-color: #000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.lu-sticker__right-content > div {
  width: 408px;
}
.lu-sticker__ttl {
  font-size: 26px;
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 3.38px;
  text-align: center;
  color: #FFF;
  margin-bottom: 31.6px;
  white-space: nowrap;
}
.lu-sticker__img {
  width: 208px;
  margin-bottom: 30px;
}
.lu-sticker__text {
  margin-bottom: 32px;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.87;
  letter-spacing: 1.5px;
  text-align: justify;
  color: #FFF;
}

.lu-cost {
  padding-top: 54.2px;
  padding-bottom: 100px;
}
.lu-cost .liu__h2 {
  font-size: 24px;
  letter-spacing: 3.84px;
  margin-bottom: 30px;
}
.lu-cost__table-wrap {
  margin-bottom: 100px;
}
.lu-cost__table-wrap:last-child {
  margin-bottom: 0;
}
.lu-cost__footnote {
  font-size: 16px;
  font-weight: 300;
  margin-top: 12px;
  text-align: left;
  letter-spacing: 0.4px;
  color: #000;
}

.table-cost {
  width: 100%;
}
.table-cost th, .table-cost td {
  line-height: 1.8;
  text-align: center;
  padding: 17px 1em;
}
.table-cost th {
  font-size: 16px;
  font-weight: normal;
  letter-spacing: 1.68px;
  background-color: #CCCCCC;
  border: solid 1px #231815;
  border-bottom: none;
}
.table-cost td {
  font-size: 18px;
  font-weight: 300;
  color: #000;
  border: solid 1px #231815;
  border-top: none;
}
.table-cost .c-blue {
  background-color: #B2DDF1;
}
.table-cost--fixed-width th, .table-cost--fixed-width td {
  width: 25%;
}

@media screen and (max-width: 765px) {
  .mv-lineup {
    background: url("../img/lineup_mv_sp.png") no-repeat center/cover;
  }

  .liu {
    padding-top: 45px;
    padding-bottom: 38px;
  }
  .liu__inner {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }
  .liu__headmsg {
    font-size: 18px;
    line-height: 1.47;
    letter-spacing: 0.9px;
    padding: 17px 0 24.5px;
  }
  .liu__main {
    padding-top: 44.5px;
    padding-bottom: 45px;
    background: linear-gradient(180deg, #FFFFEA 0%, rgb(255, 255, 255) 60%, #E9F6F6 100%);
  }
  .liu__h2 {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.75;
    letter-spacing: 0.9px;
    margin-bottom: 20px;
  }
  .liu__label-wrap {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 30px;
  }
  .liu__label-blue {
    font-size: 12px;
    line-height: 25px;
    width: 120px;
    height: 25px;
    padding: 0;
    letter-spacing: 0.3px;
  }
  .liu__label-blue:first-child {
    margin-right: 17.5px;
  }
  .liu__appearance {
    margin-bottom: 40px;
  }
  .liu__appearance img {
    width: 240px;
  }
  .liu__products2 {
    width: 85%;
    margin-bottom: 40px;
  }

  .lu-detail__table th, .lu-detail__table td {
    font-size: 12px;
    font-weight: 300;
    line-height: 1.5;
    padding: 0.75em 0.3em;
    vertical-align: middle;
  }
  .lu-detail__table:first-child {
    margin-bottom: 50px;
  }
  .lu-detail__table .c-first {
    padding-left: 1em;
  }
  .lu-detail__table .c-center {
    text-align: center;
  }
  .lu-detail__table .c-vcenter {
    vertical-align: middle;
  }
  .lu-detail__table td:last-child {
    width: 114px !important;
    padding-left: 1em;
    vertical-align: middle;
  }
  .lu-detail__table--parts td {
    text-align: center;
    vertical-align: middle;
  }
  .lu-detail__table--parts td:first-child {
    padding-left: 1em;
    text-align: left;
  }
  .lu-detail__table--parts td:nth-child(2) {
    width: 70px;
  }
  .lu-detail__table--parts td:last-child {
    width: 108px !important;
    padding-left: 0.3em;
    text-align: left;
  }

  .lu-shoplink {
    flex-direction: column;
    justify-content: center;
    padding: 40px 0 25px;
    border: solid 1px #3E3A39;
    border-top: none;
  }
  .lu-shoplink__caution {
    top: 10px;
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap;
    font-size: 11px;
    font-weight: 300;
    line-height: 1.41;
    letter-spacing: 1.1px;
    text-align: left;
    color: #000;
  }
  .lu-shoplink span {
    font-size: 12px;
    font-weight: 500;
    display: block;
    margin-bottom: 11px;
    letter-spacing: 1.2px;
  }
  .lu-shoplink img {
    width: 236px;
    margin-bottom: 15px;
  }
  .lu-shoplink a {
    font-size: 15px;
    font-weight: normal;
    width: 232.5px;
    padding: 16px 0;
    letter-spacing: 1.5px;
  }

  .lu-sticker {
    padding-top: 0;
    padding-bottom: 0;
  }
  .lu-sticker__wrap {
    flex-direction: column-reverse;
  }
  .lu-sticker__left-img {
    display: block;
    width: 100%;
  }
  .lu-sticker__left-img img {
    width: 100%;
  }
  .lu-sticker__right-content {
    width: 100%;
    margin-bottom: 0;
    padding-top: 50px;
  }
  .lu-sticker__ttl {
    font-size: 15px;
    font-weight: 500;
    line-height: 1.3;
    letter-spacing: 1.95px;
  }
  .lu-sticker__img {
    width: 198.5px;
  }
  .lu-sticker__text {
    font-size: 12px;
    line-height: 1.92;
    letter-spacing: 1.2px;
    text-align: center;
  }

  .lu-cost {
    padding-top: 48px;
    padding-bottom: 75px;
  }
  .lu-cost .liu__h2 {
    font-size: 15px;
    line-height: 1.51;
    letter-spacing: 1.65px;
    white-space: nowrap;
    margin-bottom: 18px;
  }
  .lu-cost .lower-h2 {
    margin-right: -20px;
    margin-left: -20px;
  }
  .lu-cost__table-wrap {
    margin-bottom: 30px;
  }
  .lu-cost__footnote {
    font-size: 12px;
    font-weight: 300;
    line-height: 1.5;
    margin-top: 7px;
    letter-spacing: 0.7px;
  }

  .table-cost {
    width: 100%;
  }
  .table-cost.-ex {
    table-layout: fixed;
  }
  .table-cost th, .table-cost td {
    line-height: 1.34;
    vertical-align: middle;
  }
  .table-cost th {
    font-size: 11px;
    font-weight: 300;
    letter-spacing: 1.1px;
    padding: 0.75em 0.3em;
  }
  .table-cost th.-exsp {
    width: 85px;
  }
  .table-cost td {
    font-size: 11px;
    font-weight: 300;
    padding: 1.5em 0.3em;
  }
  .table-cost .c-blue {
    font-weight: 500;
  }
  .table-cost__txt-smaller {
    font-size: 8px;
  }

  .lineup__slider {
    position: relative;
    margin-bottom: 35px;
  }
  .lineup__item {
    width: 100%;
  }
  .lineup__bg {
    width: 50.26666667vw;
    width: 70vw;
    margin: 0 auto 16px;
    padding: 20px 0 12px;
  }
  .lineup__img {
    display: flex;
    justify-content: center;
    align-items: flex-end;
  }
  .lineup__img-pd {
    width: 20.26666667vw;
  }
  .lineup__btn {
    width: 24.8vw;
    margin-left: 5vw;
  }
  .lineup__label {
    font-size: 12px;
    font-weight: normal;
    width: 203px;
    margin: 0 auto 12px;
    padding: 7.5px 0;
    text-align: center;
    letter-spacing: 0.6px;
    color: #FFF;
    border-radius: 20px;
    background-color: #1896C8;
    box-shadow: 4px 3px 2px 0 rgba(0, 0, 0, 0.1);
  }
  .lineup__caption {
    font-size: 12px;
    font-weight: normal;
    line-height: 1.7;
    text-align: center;
  }
  .lineup__prev, .lineup__next {
    position: absolute;
    z-index: 49;
    top: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 50px;
    height: 50px;
    margin-top: -50px;
    cursor: pointer;
    transform-origin: center;
  }
  .lineup__prev:hover, .lineup__next:hover {
    opacity: 0.7;
  }
  .lineup__prev {
    left: 0;
  }
  .lineup__next {
    right: 0;
    transform: rotate(180deg);
  }
  .lineup__icon {
    width: 8.5px;
  }
}
.mv-qna {
  background: url("../img/qna_mv.png") no-repeat center/cover;
}

.qna-inner {
  width: 1000px;
  margin: 0 auto;
}

.qna-main {
  padding-top: 86px;
  padding-bottom: 125px;
  background-color: #FFF;
}

.qna-inner-links {
  margin-bottom: 52px;
}
.qna-inner-links .scroll-link-wrapper {
  margin-bottom: 10px;
}
.qna-inner-links .scroll-link {
  width: calc(50% - 5px);
  box-sizing: border-box;
}

.qna-h2 {
  margin-top: 60px;
  margin-bottom: 41.6px;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.39;
  letter-spacing: 1.4px;
  text-align: center;
  color: #000;
}

.qna-card {
  width: 100%;
  margin-bottom: 23.5px;
}
.qna-card__q {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 25px 10px 25px 22px;
  background-color: #1896C8;
}
.qna-card__label {
  width: 23px;
  margin-right: 30px;
}
.qna-card__ttl {
  font-size: 18px;
  font-weight: 500;
  letter-spacing: 2.16px;
  color: #FFF;
}
.qna-card__a {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 30px 10px 35px 22px;
  border-top: none;
  background-color: #E4E4E4;
}
.qna-card__text {
  font-size: 16px;
  font-weight: 300;
  line-height: 1.75;
  margin-top: -5px;
  letter-spacing: 0.8px;
  color: #231815;
}
.qna-card__text--flex {
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
}
.qna-card__text--flex > *:first-child {
  margin-right: 20px;
}
.qna-card__ex-space {
  display: inline-block;
  padding-right: 9px;
}

@media screen and (max-width: 765px) {
  .mv-qna {
    background: url("../img/qna_mv_sp.png") no-repeat center/cover;
  }

  .qna-inner {
    width: 100%;
    padding-right: 20px;
    padding-left: 20px;
  }

  .qna-main {
    padding-top: 23px;
    padding-bottom: 30px;
  }

  .qna-inner-links {
    margin-bottom: 25px;
  }
  .qna-inner-links .scroll-link-wrapper {
    margin-bottom: 0;
  }
  .qna-inner-links .scroll-link {
    width: 50%;
    padding: 19px 0 23px;
  }
  .qna-inner-links .scroll-link:first-child {
    border-right: none;
  }
  .qna-inner-links .scroll-link.-top {
    border-bottom: none;
  }

  .qna-h2 {
    font-size: 14px;
    line-height: 1.62;
    margin-top: 30px;
    margin-bottom: 15px;
    letter-spacing: 2.2px;
  }
  .qna-h2:before {
    display: inline-block;
    width: 10.5px;
    height: 10.5px;
  }

  .qna-card {
    margin-bottom: 8px;
  }
  .qna-card__q {
    padding: 15px 25px 15px 16px;
  }
  .qna-card__label {
    width: 14px;
    margin-right: 16px;
  }
  .qna-card__ttl {
    font-size: 12px;
    line-height: 1.46;
    letter-spacing: 1.08px;
    color: #FFF;
  }
  .qna-card__a {
    padding: 25px 20px 23px 16px;
  }
  .qna-card__text {
    font-size: 11px;
    line-height: 1.46;
    margin-top: -3px;
    letter-spacing: 0.6px;
  }
  .qna-card__text--flex {
    flex-direction: column;
  }
  .qna-card__text--flex > *:first-child {
    margin-right: 0;
  }
  .qna-card__ex-space {
    display: inline-block;
    padding-right: 9px;
  }
}
.mv-contact {
  background: url("../img/contact_mv.png") no-repeat center/cover;
}

.mv-docreq {
  background: url("../img/docreq_mv.png") no-repeat center/cover;
}

.contactFadeInUpTrigger {
  opacity: 0;
}

.contactFadeInUp {
  -webkit-animation-name: contactFadeInUpAnime;
          animation-name: contactFadeInUpAnime;
  -webkit-animation-duration: 0.7s;
          animation-duration: 0.7s;
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
  opacity: 0;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

@-webkit-keyframes contactFadeInUpAnime {
  from {
    transform: translateY(15px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}

@keyframes contactFadeInUpAnime {
  from {
    transform: translateY(15px);
    opacity: 0;
  }
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
.cs__main {
  padding-top: 69.3px;
  padding-bottom: 18.3px;
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .cs__main {
    padding-top: 42.1px;
    padding-bottom: 10px;
  }
}
.cs__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .cs__inner {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.cs__ttl {
  font-size: 30px;
  font-weight: bold;
  text-align: center;
}
@media screen and (max-width: 765px), print {
  .cs__ttl {
    font-size: 20px;
    line-height: 1.4;
  }
}

.cs-card-wrapper {
  margin-top: 69.8px;
  margin-bottom: 65px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media screen and (max-width: 765px), print {
  .cs-card-wrapper {
    display: block;
    margin-top: 25.5px;
    margin-bottom: 40px;
  }
}

.cs-card {
  width: 486.83px;
  height: 170px;
  display: flex;
  align-items: stretch;
  justify-content: center;
  margin-bottom: 25.4px;
}
@media screen and (max-width: 765px), print {
  .cs-card {
    width: 100%;
    height: 115px;
    margin-bottom: 16px;
  }
}
.cs-card__figure {
  width: 184px;
  flex-shrink: 0;
}
@media screen and (max-width: 765px), print {
  .cs-card__figure {
    width: 125px;
  }
}
.cs-card__figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.cs-card__info {
  position: relative;
  width: 302.83px;
  padding-top: 16px;
  padding-left: 25px;
  background-color: #E8E8E8;
}
@media screen and (max-width: 765px), print {
  .cs-card__info {
    width: auto;
    flex-grow: 1;
    padding-top: 13px;
    padding-left: 15px;
  }
}
.cs-card__ttl {
  font-size: 17px;
  font-weight: bold;
  margin-bottom: 7px;
  line-height: 1.4;
  letter-spacing: 0.5px;
}
@media screen and (max-width: 765px), print {
  .cs-card__ttl {
    font-size: 13px;
    margin-bottom: 2px;
    letter-spacing: 1px;
  }
}
.cs-card__address {
  font-size: 15px;
  font-weight: 500;
  letter-spacing: 1px;
  line-height: 1.45;
}
@media screen and (max-width: 765px), print {
  .cs-card__address {
    font-size: 12px;
    letter-spacing: 0.7px;
    line-height: 1.25;
  }
}
.cs-card__btn {
  position: absolute;
  right: 19.8px;
  bottom: 19.5px;
  width: 109px;
  height: 45px;
  line-height: 45px;
  border: solid 1px #8D8D8D;
  font-weight: 500;
  font-size: 16px;
  background-color: #FFF;
  text-align: center;
}
@media screen and (max-width: 765px), print {
  .cs-card__btn {
    right: 12.4px;
    bottom: 13.1px;
    width: 74.1px;
    height: 30.6px;
    line-height: 30.6px;
    font-size: 12px;
  }
}
.cs-card__btn:link, .cs-card__btn:visited, .cs-card__btn:hover, .cs-card__btn:active {
  color: #787878;
}
.cs-card__btn:after {
  position: absolute;
  top: 4.7px;
  right: 6.7px;
  display: block;
  width: 10px;
  height: 9.5px;
  background: url("../img/casestudy_new-window.svg") no-repeat center/contain;
  content: "";
}
@media screen and (max-width: 765px), print {
  .cs-card__btn:after {
    top: 3.2px;
    right: 4.6px;
    width: 7px;
    height: 6.5px;
  }
}

.footer {
  background-color: #000;
  padding: 17px 42px;
}
@media screen and (max-width: 765px), print {
  .footer {
    padding: 13px 10px;
  }
}
.footer__inner {
  width: 100%;
  max-width: 1500px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 765px), print {
  .footer__inner {
    max-width: 100%;
    display: block;
    text-align: center;
  }
}
.footer__link {
  font-size: 14px;
  letter-spacing: 0.7px;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 765px), print {
  .footer__link {
    text-align: center;
    display: block;
    font-size: 12px;
    letter-spacing: 0.6px;
  }
}
.footer__link a:link, .footer__link a:visited, .footer__link a:hover, .footer__link a:active {
  color: #FFF;
}
.footer__link a:after {
  margin-left: 5px;
  display: inline-block;
  width: 12px;
  height: 12px;
  content: "";
  background: url("../img/foot-new-window.svg") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .footer__link a:after {
    width: 8.5px;
    height: 8.5px;
    margin-left: 4.1px;
  }
}
.footer__copy {
  font-size: 11px;
  line-height: 3.55;
  letter-spacing: 1px;
  text-align: right;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .footer__copy {
    margin-top: 13.8px;
    text-align: center;
    font-size: 8px;
    letter-spacing: 0.4px;
    line-height: 1;
    color: #FFF;
  }
}

.mv-news {
  background: url("../img/news_mv.png") no-repeat center/cover;
}
@media screen and (max-width: 765px), print {
  .mv-news {
    background: url("../img/news_mv_sp.png") no-repeat center/cover;
  }
}

.news__main {
  padding-top: 75px;
  padding-bottom: 85px;
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .news__main {
    padding-top: 33px;
    padding-bottom: 42px;
  }
}
.news__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .news__inner {
    width: 100%;
    padding-left: 40px;
    padding-right: 40px;
  }
}

.news-article {
  margin-bottom: 38px;
}
@media screen and (max-width: 765px), print {
  .news-article {
    margin-bottom: 25px;
  }
}
.news-article:last-child {
  margin-bottom: 0;
}
.news-article a {
  display: block;
}
.news-article__date {
  font-family: "Roboto", sans-serif;
  font-size: 15px;
  letter-spacing: 2.1px;
  color: #1896C8;
  margin-bottom: 8px;
}
@media screen and (max-width: 765px), print {
  .news-article__date {
    font-size: 12.5px;
    line-height: 1.75;
    letter-spacing: 1.25px;
    margin-bottom: 0;
  }
}
.news-article__ttl {
  font-size: 17px;
  font-weight: 300;
  line-height: 1.65;
  letter-spacing: 1.7px;
  color: #4D4D4D;
}
@media screen and (max-width: 765px), print {
  .news-article__ttl {
    font-size: 13px;
    line-height: 1.62;
    letter-spacing: 1.3px;
  }
}

.news-d {
  margin-top: 85px;
  padding-top: 68px;
  padding-bottom: 55px;
}
@media screen and (max-width: 765px), print {
  .news-d {
    margin-top: 57.7px;
    padding-top: 30.5px;
    padding-bottom: 42px;
  }
}
.news-d__inner {
  width: 900px;
  margin: 0 auto;
  padding-left: 30px;
  padding-right: 30px;
}
@media screen and (max-width: 765px), print {
  .news-d__inner {
    width: 100%;
    padding-left: 35px;
    padding-right: 35px;
  }
}
.news-d__date {
  font-family: "Roboto", sans-serif;
  font-size: 14px;
  line-height: 1.79;
  letter-spacing: 1.96px;
  color: #1896C8;
  margin-bottom: 10px;
}
@media screen and (max-width: 765px), print {
  .news-d__date {
    font-size: 12.5px;
    line-height: 1.75;
    letter-spacing: 1.25px;
    margin-bottom: 5px;
  }
}
.news-d__ttl {
  padding-bottom: 36px;
  font-size: 25px;
  font-weight: 500;
  line-height: 1.28;
  letter-spacing: 3.5px;
  color: #4D4D4D;
}
@media screen and (max-width: 765px), print {
  .news-d__ttl {
    font-size: 13.5px;
    font-weight: 300;
    line-height: 1.52;
    letter-spacing: 1.35px;
    padding-bottom: 20px;
  }
}
.news-d__hr {
  height: 0;
  margin: 0 -30px;
  padding: 0;
  border: 0;
  border-top: 1px solid #CACACA;
}
@media screen and (max-width: 765px), print {
  .news-d__hr {
    margin-left: -15px;
    margin-right: -15px;
  }
}
.news-d__content {
  margin-top: 32px;
  margin-bottom: 50px;
  font-size: 14px;
  line-height: 1.79;
  letter-spacing: 1.96px;
  color: #4D4D4D;
}
@media screen and (max-width: 765px), print {
  .news-d__content {
    margin-top: 20px;
    margin-bottom: 25px;
    font-size: 12px;
    font-weight: 300;
    line-height: 1.75;
    letter-spacing: 0.96px;
  }
}
.news-d__content p, .news-d__content ol, .news-d__content ul {
  margin-bottom: 30px;
}
@media screen and (max-width: 765px), print {
  .news-d__content p, .news-d__content ol, .news-d__content ul {
    margin-bottom: 25px;
  }
}
.news-d__content ul, .news-d__content ol {
  padding-left: 1.5em;
}
.news-d__content li {
  display: list-item;
}
.news-d__content a {
  text-decoration: underline;
  transition: color 0.2s;
}
.news-d__content a:link, .news-d__content a:visited, .news-d__content a:hover, .news-d__content a:active {
  color: #1896C8;
}
.news-d__content a:hover {
  color: #79C2DF;
}
.news-d__content img {
  max-width: 100%;
}
.news-d__content > *:last-child {
  margin-bottom: 0;
}
.news-d__back {
  margin-top: 48.5px;
  font-family: "Roboto", sans-serif;
  font-size: 16px;
  letter-spacing: 2.24px;
  text-align: center;
}
@media screen and (max-width: 765px), print {
  .news-d__back {
    margin-top: 25.8px;
    font-size: 12px;
    letter-spacing: 1.68px;
  }
}
.news-d__back a {
  display: inline-flex;
  align-items: center;
  line-height: 1;
}
.news-d__back a:link, .news-d__back a:visited, .news-d__back a:hover, .news-d__back a:active {
  color: #4D4D4D;
}
.news-d__back a:before, .news-d__back a:after {
  position: relative;
  top: -1px;
  display: inline-block;
  width: 8px;
  height: 8px;
  transform: rotate(45deg);
  content: "";
}
@media screen and (max-width: 765px), print {
  .news-d__back a:before, .news-d__back a:after {
    width: 6px;
    height: 6px;
  }
}
.news-d__back a:before {
  margin-right: 5px;
  border-left: 1px solid #4D4D4D;
  border-bottom: 1px solid #4D4D4D;
}
@media screen and (max-width: 765px), print {
  .news-d__back a:before {
    margin-right: 3px;
  }
}
.news-d__back a:after {
  margin-left: 3px;
  border-top: 1px solid #4D4D4D;
  border-right: 1px solid #4D4D4D;
}
@media screen and (max-width: 765px), print {
  .news-d__back a:after {
    margin-left: 2px;
  }
}

.hojo-fv {
  padding: 160px 0 25px;
  background: url("../img/hj-fv-bg.png") no-repeat center/cover;
}
.hojo-fv__inner {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 860px;
  margin: 0 auto;
}
.hojo-fv__title {
  width: 100%;
  padding: 20px 0 30px;
}
.hojo-fv__product {
  flex: 0 0 274px;
  padding: 0 60px 60px 60px;
  text-align: center;
}
.hojo-fv__product img {
  width: 100%;
}
.hojo-fv__copy {
  flex: 0 0 550px;
}
.hojo-fv__bubble {
  width: 100%;
  margin-bottom: 20px;
}
.hojo-fv__text {
  font-size: 36px;
  line-height: 1.78;
  margin-bottom: 35px;
  letter-spacing: 2.16px;
  font-weight: bold;
}
.hojo-fv__text .-small {
  font-size: 27px;
  font-weight: bold;
  letter-spacing: 1.62px;
}
.hojo-fv__text .-blue {
  font-size: 41px;
  font-weight: 900;
  letter-spacing: 2.46px;
  color: #008CD0;
}
.hojo-fv__text .-yellow {
  display: inline-block;
  padding-bottom: 5px;
  background: url("../img/hj-fv-yellow.png") no-repeat bottom center/100% 7px;
}
.hojo-fv__text .-yellowsp {
  font-style: normal;
}
.hojo-fv__coco {
  width: 228px;
  margin-right: 8px;
}
.hojo-fv__btn {
  display: block;
  width: 480px;
}
.hojo-fv__btn.sp {
  display: none;
}
.hojo-fv__btn.pc {
  display: block;
}

.hojo-definition {
  padding: 40px 0 35px;
  text-align: center;
  background-color: #000;
}
.hojo-definition__text {
  font-size: 37px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 4.81px;
  text-align: center;
  color: #FFF;
}
.hojo-definition__text .-underbar {
  padding-bottom: 5px;
  border-bottom: solid 2px #FFF;
}
.hojo-definition__text .-blue {
  font-size: 26px;
  font-weight: 500;
  line-height: 1.64;
  letter-spacing: 3.12px;
  color: #1896C8;
}
.hojo-definition__coco {
  width: 177.6px;
  margin-right: 5px;
}
.hojo-definition__notes {
  margin-top: 20px;
  font-size: 14px;
  font-weight: 500;
  line-height: 4.29;
  letter-spacing: 3.36px;
  text-align: center;
  color: #FFF;
}

.hojo-benefit {
  padding: 5px 0 40px;
  background: url("../img/hj-def-bg2.png") no-repeat center/cover;
}
.hojo-benefit__inner {
  display: flex;
  align-items: center;
  justify-content: center;
}
.hojo-benefit__product {
  width: 370px;
  margin-right: 60px;
}
.hojo-benefit__product img {
  width: 100%;
}
.hojo-benefit__text {
  font-size: 26px;
  line-height: 1.58;
  margin-top: 88px;
  margin-right: 37px;
  margin-bottom: 28px;
  letter-spacing: 5.2px;
}
.hojo-benefit__sqr {
  display: block;
  width: 490px;
  margin-bottom: 25px;
}
.hojo-benefit__link {
  font-size: 26px;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: 2.6px;
}
.hojo-benefit__link:link, .hojo-benefit__link:visited, .hojo-benefit__link:hover, .hojo-benefit__link:active {
  color: #008CD0;
}

.hojo-ttl {
  margin-top: 85px;
  padding: 50px 0 50px;
  background-color: #000;
}
.hojo-ttl h1 {
  font-size: 37px;
  font-weight: bold;
  letter-spacing: 5.18px;
  color: #FFF;
  text-align: center;
}
.hojo-ttl .-blue {
  line-height: 1.64;
  display: inline-block;
  font-size: 26px;
  font-weight: bold;
  letter-spacing: 3.12px;
  color: #1896C8;
  margin-bottom: 21px;
}

.hojo-main {
  padding: 78.2px 0 100px;
  background-color: #FFF;
}
.hojo-main__inner {
  width: 1000px;
  margin: 0 auto;
}

.hojo-info {
  padding: 50px 35px 50px;
  background-color: #E2F0F7;
}
.hojo-info__ttl {
  font-size: 28px;
  font-weight: bold;
  line-height: 1.46;
  letter-spacing: 3.64px;
  text-align: center;
  margin-bottom: 36.8px;
}
.hojo-info__date {
  font-size: 22px;
  margin-bottom: 20px;
  text-align: center;
  letter-spacing: 3.08px;
}
.hojo-info__text {
  font-size: 20px;
  line-height: 1.82;
  margin-bottom: 7px;
  text-align: center;
  letter-spacing: 3.08px;
}
.hojo-info__notes {
  font-size: 18px;
  line-height: 2.11;
  margin-top: 40px;
  margin-bottom: 30px;
  text-align: center;
  letter-spacing: 2.52px;
}
.hojo-info__links {
  display: flex;
  align-items: center;
  justify-content: center;
}
.hojo-info__link-btn {
  font-size: 18px;
  font-weight: 500;
  display: block;
  width: 220px;
  margin-right: 23.7px;
  padding: 15px 0;
  text-align: center;
  letter-spacing: 1.62px;
  border: solid 1px #24A0C6;
  border-radius: 27px;
}
.hojo-info__link-btn:link, .hojo-info__link-btn:visited, .hojo-info__link-btn:hover, .hojo-info__link-btn:active {
  color: #24A0C6;
}
.hojo-info__link-btn:last-child {
  margin-right: 0;
}
.hojo-info__link-btn span {
  position: relative;
}
.hojo-info__link-btn span:after {
  position: absolute;
  top: 0;
  right: -12px;
  display: block;
  width: 9px;
  height: 9px;
  content: "";
  background: url("../img/hj-newtab.svg") no-repeat center/100% 100%;
}

.hojo-prefecture {
  margin-top: 82px;
}
.hojo-prefecture__ttl {
  font-size: 30px;
  font-weight: bold;
  margin-bottom: 20px;
  letter-spacing: 6px;
}

.hojo-table {
  width: 100%;
  table-layout: fixed;
}
.hojo-table tr:nth-child(2n) td {
  background-color: #FFF;
  border-right: 1px solid #E2F0F7;
}
.hojo-table tr:nth-child(2n+1) td {
  background-color: #E2F0F7;
  border-right: 1px solid #FFF;
}
.hojo-table tr.-onerow:nth-child(2n) td {
  background-color: #E2F0F7;
  border-right: 1px solid #FFF;
}
.hojo-table th, .hojo-table td {
  text-align: center;
  vertical-align: middle;
}
.hojo-table th {
  font-size: 17px;
  font-weight: bold;
  line-height: 1.2;
  padding: 25px 0;
  letter-spacing: 2.89px;
  color: #FFF;
  border-right: 1px solid #FFF;
  background-color: #1896C8;
}
.hojo-table th:nth-child(1) {
  width: 160.5px;
}
.hojo-table th:nth-child(2) {
  width: 321px;
}
.hojo-table th:nth-child(3) {
  width: 191px;
}
.hojo-table th:nth-child(4) {
  width: 190px;
}
.hojo-table th:nth-child(5) {
  width: 137.5px;
  border-right: none;
}
.hojo-table td {
  font-size: 15px;
  line-height: 1.2;
  padding: 5px 0;
  letter-spacing: 2.25px;
  min-height: 120px;
  height: 120px;
  box-sizing: border-box;
}
.hojo-table td:nth-child(1) {
  width: 160.5px;
}
.hojo-table td:nth-child(2) {
  width: 321px;
}
.hojo-table td:nth-child(3) {
  width: 191px;
}
.hojo-table td:nth-child(4) {
  width: 190px;
}
.hojo-table td:nth-child(5) {
  width: 137.5px;
  border-right: none;
}
.hojo-table__link {
  font-size: 14px;
  font-weight: 500;
}
.hojo-table__link:link, .hojo-table__link:visited, .hojo-table__link:hover, .hojo-table__link:active {
  color: #24A0C6;
}
.hojo-table__link span {
  position: relative;
}
.hojo-table__link span:after {
  position: absolute;
  top: -7px;
  right: -4px;
  display: block;
  width: 9px;
  height: 9px;
  content: "";
  background: url("../img/hj-newtab.svg") no-repeat center/100% 100%;
}

@media screen and (max-width: 765px) {
  .hojo-fv {
    padding: 88.5px 0 35px;
    background: url("../img/hj-fv-bg_sp.png") no-repeat center/cover;
  }
  .hojo-fv__inner {
    justify-content: center;
    width: 100%;
    padding-right: 15px;
    padding-left: 15px;
  }
  .hojo-fv__title {
    padding: 40px 0 0;
  }
  .hojo-fv__product {
    flex: 0 0 66px;
    margin-right: 20px;
    padding: 0;
  }
  .hojo-fv__copy {
    flex: 0 0 240px;
    margin-top: 12px;
  }
  .hojo-fv__bubble {
    width: 100%;
    margin-bottom: 0;
  }
  .hojo-fv__text {
    font-size: 16px;
    line-height: 1.83;
    margin-bottom: 0;
    letter-spacing: 0.96px;
  }
  .hojo-fv__text .-small {
    font-size: 11px;
    font-weight: bold;
    letter-spacing: 0.66px;
  }
  .hojo-fv__text .-blue {
    font-size: 24.5px;
    margin-right: 5px;
    letter-spacing: 1.47px;
  }
  .hojo-fv__text .-yellow {
    padding-bottom: 2px;
    background: url(../img/hj-fv-yellow.png) no-repeat bottom center/100% 3px;
  }
  .hojo-fv__coco {
    width: 92px;
    height: 12px;
    margin-right: 5px;
  }
  .hojo-fv__btn {
    width: 350px;
    margin: 30px auto 0;
  }
  .hojo-fv__btn.sp {
    display: block;
  }
  .hojo-fv__btn.pc {
    display: none;
  }

  .hojo-definition {
    padding: 15px 0 25px;
  }
  .hojo-definition__text {
    font-size: 19px;
    line-height: 1.47;
    margin-bottom: 17px;
    letter-spacing: 2.47px;
    font-weight: 900;
  }
  .hojo-definition__text .-underbar {
    padding-bottom: 2px;
    border-bottom: solid 1px #FFF;
  }
  .hojo-definition__text .-blue {
    font-size: 14px;
    display: inline-block;
    letter-spacing: 1.68px;
    margin-bottom: 9px;
  }
  .hojo-definition__coco {
    width: 94.8px;
  }
  .hojo-definition__notes {
    margin-top: 0;
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 1.2px;
    color: #FFF;
    line-height: 1;
  }

  .hojo-benefit {
    padding: 12.5px 0 34px;
    background: url("../img/hj-def-bg2_sp.png") no-repeat center/cover;
  }
  .hojo-benefit__inner {
    display: block;
  }
  .hojo-benefit__product {
    box-sizing: initial;
    width: 178.5px;
    margin: 0 auto;
    padding-right: 55px;
  }
  .hojo-benefit__product img {
    width: 100%;
  }
  .hojo-benefit__text {
    font-size: 14px;
    line-height: 1.64;
    margin-top: 10px;
    margin-right: 0;
    margin-bottom: 21px;
    text-align: center;
    letter-spacing: 2.8px;
  }
  .hojo-benefit__sqr {
    display: block;
    width: 350px;
    margin: 0 auto 13px;
  }
  .hojo-benefit__link {
    font-size: 17px;
    display: block;
    text-align: center;
    letter-spacing: 1.7px;
  }

  .hojo-ttl {
    margin-top: 52px;
    padding: 20px 0 25px;
  }
  .hojo-ttl h1 {
    font-size: 17.5px;
    letter-spacing: 2.45px;
  }
  .hojo-ttl .-blue {
    font-size: 14px;
    line-height: 1.62;
    letter-spacing: 1.68px;
    margin-bottom: 10px;
  }

  .hojo-main {
    padding: 25px 0 70px;
  }
  .hojo-main__inner {
    width: 100%;
    padding-right: 12px;
    padding-left: 12px;
  }

  .hojo-info {
    padding: 20px;
  }
  .hojo-info__ttl {
    font-size: 14px;
    line-height: 1.46;
    margin-bottom: 5px;
    padding-bottom: 11px;
    letter-spacing: 1.82px;
  }
  .hojo-info__date {
    font-size: 13px;
    margin-bottom: 14px;
    letter-spacing: 1.82px;
  }
  .hojo-info__text {
    font-size: 12px;
    line-height: 1.6;
    margin-bottom: 10px;
    letter-spacing: 1px;
  }
  .hojo-info__notes {
    font-size: 12px;
    line-height: 1.6;
    margin-top: 16.3px;
    margin-bottom: 20px;
    letter-spacing: 1.68px;
  }
  .hojo-info__links {
    display: block;
  }
  .hojo-info__link-btn {
    font-size: 14px;
    width: 275px;
    margin: 0 auto 9.4px;
    padding: 12px 0;
    letter-spacing: 1.26px;
    border-radius: 22.5px;
  }
  .hojo-info__link-btn:last-child {
    margin-right: auto;
  }
  .hojo-info__link-btn span:after {
    position: absolute;
    top: 0;
    right: -10px;
    display: block;
    width: 7px;
    height: 7px;
  }

  .hojo-prefecture {
    margin-top: 40.8px;
  }
  .hojo-prefecture__ttl {
    font-size: 15px;
    margin-bottom: 7px;
    letter-spacing: 3px;
  }

  .hojo-table th {
    font-size: 9px;
    line-height: 1.39;
    padding: 13px 0;
    letter-spacing: 1.53px;
  }
  .hojo-table th:nth-child(1) {
    width: 14.95%;
  }
  .hojo-table th:nth-child(2) {
    width: 23.5%;
  }
  .hojo-table th:nth-child(3) {
    width: 21.08%;
  }
  .hojo-table th:nth-child(4) {
    width: 21.25%;
  }
  .hojo-table th:nth-child(5) {
    width: 19.22%;
    border-right: none;
  }
  .hojo-table td {
    font-size: 9.5px;
    line-height: 1.16;
    padding: 15px 4px;
    white-space: nowrap;
    letter-spacing: 1.43px;
    height: 85px;
  }
  .hojo-table td:nth-child(1) {
    width: 14.95%;
  }
  .hojo-table td:nth-child(2) {
    width: 23.5%;
  }
  .hojo-table td:nth-child(3) {
    width: 21.08%;
  }
  .hojo-table td:nth-child(4) {
    width: 21.25%;
  }
  .hojo-table td:nth-child(5) {
    width: 19.22%;
    border-right: none;
  }
  .hojo-table__link {
    font-size: 9.5px;
  }
  .hojo-table__link span:after {
    top: 0;
    right: -5px;
    width: 5px;
    height: 5px;
  }
}
.pagination {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 100px;
}
@media screen and (max-width: 765px), print {
  .pagination {
    margin-top: 40px;
  }
}
.pagination__item {
  font-size: 18px;
  line-height: 1.4;
  padding: 0 15px;
  margin-bottom: 10px;
  text-align: center;
  color: #000;
}
.pagination__item:hover {
  color: #1896C8;
}
.pagination__item.-active {
  color: #1896C8;
}
.pagination__link {
  display: inline-block;
  width: 100%;
  height: 100%;
}
.pagination__link:link, .pagination__link:visited, .pagination__link:hover, .pagination__link:active {
  font-weight: 500;
  color: inherit;
}
.pagination__link.-arrow {
  display: block;
  margin-top: -1px;
}

.top__ttl-blk {
  padding: 48px 15px;
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .top__ttl-blk {
    padding: 25px 20px 25px 37.5px;
  }
}
.top__ttl {
  font-size: 37px;
  font-weight: 900;
  line-height: 1.43;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .top__ttl {
    font-size: 18.5px;
    letter-spacing: -0.4px;
    white-space: nowrap;
  }
}
.top__ttl .-blue {
  color: #1896C8;
}

.no-webp .fv {
  background: url("../img/fv-bg-replace-60.jpg") no-repeat center/cover;
}
@media screen and (max-width: 765px), print {
  .no-webp .fv {
    background: url("../img/fv-bg-replace_sp-60.jpg") no-repeat center/cover;
  }
}

.fv {
  position: relative;
  height: 100vh;
  width: 100%;
  background: url("../img/fv-bg-replace-60.webp") no-repeat center/cover;
}
@media screen and (max-width: 1099px), print {
  .fv {
    height: auto;
  }
}
@media screen and (max-width: 765px), print {
  .fv {
    background: url("../img/fv-bg-replace_sp-60.webp") no-repeat center/cover;
    height: calc(100vh - 62px);
  }
}
.fv__youtube-area {
  position: absolute;
  z-index: 1;
  /*最背面に設定*/
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  overflow: hidden;
  opacity: 0;
}
.fv__youtube-area.-appear {
  -webkit-animation-name: PageAnimeAppear;
          animation-name: PageAnimeAppear;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
@media screen and (max-width: 1099px), print {
  .fv__youtube-area {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    right: unset;
    bottom: unset;
  }
}
@media screen and (max-width: 765px), print {
  .fv__youtube-area {
    position: absolute;
    padding-top: 0;
    right: 0;
    bottom: 0;
  }
}
.fv__youtube {
  /*天地中央配置*/
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  /*縦横幅指定*/
  width: 177.77777778vh;
  /* 16:9 の幅→16 ÷ 9＝ 177.77% */
  height: 56.25vw;
  /* 16:9の幅 → 9 ÷ 16 = 56.25% */
  min-height: 100%;
  min-width: 100%;
}
@media screen and (max-width: 1099px), print {
  .fv__youtube {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: translate(0);
  }
}
@media screen and (max-width: 765px), print {
  .fv__youtube {
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 101%;
    height: 104%;
  }
}
.fv__youtube-mask {
  position: absolute;
  z-index: 2;
  /*下から2番目に表示*/
  top: 0;
  width: 100%;
  height: 100%;
}
.fv__copy {
  position: absolute;
  left: 112.9px;
  bottom: 81.7px;
  z-index: 3;
  display: none;
}
@media screen and (max-width: 765px), print {
  .fv__copy {
    width: 100%;
    left: 0;
    top: 95.1px;
    bottom: unset;
    text-align: center;
  }
}
.fv__copy.-animated {
  display: block;
  -webkit-animation: fvCopyAnime 1.9s;
          animation: fvCopyAnime 1.9s;
}
.fv__ttl {
  font-size: 23px;
  font-weight: bold;
  line-height: 1.83;
  letter-spacing: 0.92px;
  color: #FFF;
  margin-bottom: 27.5px;
}
@media screen and (max-width: 765px), print {
  .fv__ttl {
    margin-bottom: 17.5px;
    font-size: 16.5px;
    line-height: 1.78;
    letter-spacing: 0.66px;
  }
}
.fv__logo {
  width: 281.52px;
}
@media screen and (max-width: 765px), print {
  .fv__logo {
    width: 199.7px;
  }
}
.fv__banners {
  position: absolute;
  right: 50px;
  bottom: 20px;
  z-index: 3;
  width: 259px;
}
@media screen and (max-width: 765px), print {
  .fv__banners {
    left: 3vw;
    right: auto;
    bottom: 3vw;
    z-index: 1;
    width: 70vw;
  }
}
.fv__banners a {
  display: block;
  position: absolute;
  right: 0;
  bottom: 0;
  transition: all 0.3s;
}
.fv__banners a:hover {
  opacity: 0.8;
}
.fv__banners a:nth-child(1) {
  bottom: 112px;
}
@media screen and (max-width: 765px), print {
  .fv__banners a:nth-child(1) {
    bottom: 25vw;
  }
}
.fv__banners img {
  width: 100%;
  height: auto;
}
.fv__scroll {
  text-align: center;
  position: absolute;
  right: 32.6px;
  bottom: 39px;
  z-index: 3;
}
@media screen and (max-width: 765px), print {
  .fv__scroll {
    right: 21.1px;
    bottom: 10px;
  }
}
.fv__scroll img {
  width: 8.4px;
  -webkit-animation: scroll 2s infinite;
          animation: scroll 2s infinite;
}
@media screen and (max-width: 765px), print {
  .fv__scroll img {
    width: 7.7px;
    -webkit-animation: scrollSp 2s infinite;
            animation: scrollSp 2s infinite;
  }
}

@-webkit-keyframes fvCopyAnime {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
    opacity: 0;
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
    opacity: 1;
  }
}

@keyframes fvCopyAnime {
  0% {
    -webkit-clip-path: inset(0 100% 0 0);
            clip-path: inset(0 100% 0 0);
    opacity: 0;
  }
  100% {
    -webkit-clip-path: inset(0);
            clip-path: inset(0);
    opacity: 1;
  }
}
@-webkit-keyframes PageAnimeAppear {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes PageAnimeAppear {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes scroll {
  0% {
    transform: translate(0, -20px);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 0);
    opacity: 0;
  }
}
@keyframes scroll {
  0% {
    transform: translate(0, -20px);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 0);
    opacity: 0;
  }
}
@-webkit-keyframes scrollSp {
  0% {
    transform: translate(0, -5px);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 0);
    opacity: 0;
  }
}
@keyframes scrollSp {
  0% {
    transform: translate(0, -5px);
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  100% {
    transform: translate(0, 0);
    opacity: 0;
  }
}
.char__main1 {
  padding-top: 83px;
  padding-bottom: 50px;
}
.char__main1.lazyloaded {
  background: url("../img/char_bg-60.webp") no-repeat center/cover;
}
@media screen and (max-width: 765px), print {
  .char__main1 {
    position: relative;
    padding: 25px 0 0;
    height: 431px;
  }
  .char__main1.lazyloaded {
    background: url("../img/char_bg_sp-60.webp") no-repeat center/cover;
  }
}
.char__main1__inner {
  width: 925px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .char__main1__inner {
    width: 100%;
    padding-left: 37.5px;
    padding-right: 20px;
  }
}
.char__main1__img {
  width: 100%;
  display: block;
  margin-bottom: 135px;
}
@media screen and (max-width: 765px), print {
  .char__main1__img {
    width: 306px;
    margin-left: auto;
    margin-right: auto;
  }
}
.char__main1__text {
  position: relative;
  font-size: 13px;
  font-weight: 300;
  line-height: 1.62;
  letter-spacing: 0.52px;
  text-align: justify;
  color: #FFF;
  text-shadow: 0 0 24px #000;
}
@media screen and (max-width: 765px), print {
  .char__main1__text {
    position: absolute;
    width: calc(100% - 57.5px);
    bottom: 15px;
    left: calc(50% - (100% - 75.5px) / 2);
    font-size: 9px;
    font-weight: 300;
    line-height: 1.67;
    letter-spacing: 0.3px;
  }
}
.char__main2 {
  padding-top: 39.8px;
  height: 471px;
}
.char__main2.lazyloaded {
  background: url("../img/char_bg2.webp") no-repeat center/cover;
}
@media screen and (max-width: 765px), print {
  .char__main2 {
    height: 212px;
    padding-top: 19px;
  }
}
.char__main2__img {
  width: 590.21px;
  display: block;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .char__main2__img {
    width: 309px;
    padding-left: 17.5px;
  }
}
.char__video {
  position: relative;
  height: 100vh;
  width: 100%;
}
.char__video.lazyloaded {
  background: url("../img/char_bg-replace-60.webp") no-repeat;
  background-size: cover;
}
@media screen and (max-width: 765px), print {
  .char__video {
    height: auto;
  }
}
.char__video__youtube-area {
  position: absolute;
  z-index: 1;
  /*最背面に設定*/
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  overflow: hidden;
  opacity: 0;
}
@media screen and (max-width: 765px), print {
  .char__video__youtube-area {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    right: unset;
    bottom: unset;
  }
}
.char__video__youtube-area.-appear {
  -webkit-animation-name: PageAnimeAppear;
          animation-name: PageAnimeAppear;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.char__video__youtube {
  /*天地中央配置*/
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  /*縦横幅指定*/
  width: 177.77777778vh;
  /* 16:9 の幅→16 ÷ 9＝ 177.77% */
  height: 56.25vw;
  /* 16:9の幅 → 9 ÷ 16 = 56.25% */
  min-height: 100%;
  min-width: 100%;
}
@media screen and (max-width: 765px), print {
  .char__video__youtube {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: translate(0);
  }
}
.char__video__youtube-mask {
  position: absolute;
  z-index: 2;
  /*下から2番目に表示*/
  top: 0;
  width: 100%;
  height: 100%;
}

.no-webp .char__main1.lazyloaded {
  background: url("../img/char_bg-60.jpg") no-repeat center/cover;
}
@media screen and (max-width: 765px), print {
  .no-webp .char__main1.lazyloaded {
    background: url("../img/char_bg_sp-60.jpg") no-repeat center/cover;
  }
}
.no-webp .char__main2.lazyloaded {
  background: url("../img/char_bg2.jpg") no-repeat center/cover;
}
.no-webp .char__video.lazyloaded {
  background: url("../img/char_bg-replace-60.jpg") no-repeat;
}

.tech__video {
  position: relative;
  height: 100vh;
  width: 100%;
}
.tech__video.lazyloaded {
  background: url("../img/tech_bg-replace.webp") no-repeat;
  background-size: cover;
}
@media screen and (max-width: 765px), print {
  .tech__video {
    height: auto;
  }
}
.tech__video__youtube-area {
  position: absolute;
  z-index: 1;
  /*最背面に設定*/
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  overflow: hidden;
  opacity: 0;
}
@media screen and (max-width: 765px), print {
  .tech__video__youtube-area {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    right: unset;
    bottom: unset;
  }
}
.tech__video__youtube-area.-appear {
  -webkit-animation-name: PageAnimeAppear;
          animation-name: PageAnimeAppear;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.tech__video__youtube {
  /*天地中央配置*/
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  /*縦横幅指定*/
  width: 177.77777778vh;
  /* 16:9 の幅→16 ÷ 9＝ 177.77% */
  height: 56.25vw;
  /* 16:9の幅 → 9 ÷ 16 = 56.25% */
  min-height: 100%;
  min-width: 100%;
}
@media screen and (max-width: 765px), print {
  .tech__video__youtube {
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    transform: translate(0);
  }
}
.tech__video__youtube-mask {
  position: absolute;
  z-index: 2;
  /*下から2番目に表示*/
  top: 0;
  width: 100%;
  height: 100%;
}
.tech__graph {
  padding: 100px 15px 45px;
}
@media screen and (max-width: 765px), print {
  .tech__graph {
    padding: 20px;
  }
}
.tech__graph__wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-right: 101px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__wrap {
    display: block;
    margin-right: 0;
  }
}
.tech__graph__product {
  width: 131px;
  flex-shrink: 0;
  margin-right: 20px;
  transform: translateX(-50px);
  opacity: 0;
}
@media screen and (max-width: 765px), print {
  .tech__graph__product {
    text-align: center;
    width: 45px;
    margin: 10px auto 15px;
  }
}
.tech__graph__product img {
  width: 100%;
}
.tech__graph__product.animated {
  transition-timing-function: cubic-bezier(0.38, 0.81, 0.65, 1);
  transform: translateX(0px);
  opacity: 1;
  transition: 1.2s;
}
.tech__graph__main {
  position: relative;
  width: 790.76px;
  flex-shrink: 0;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main {
    width: calc(100% - 30px);
  }
}
.tech__graph__main .-base {
  width: 100%;
}
.tech__graph__main .-bar {
  width: 664px;
  position: absolute;
  left: 115px;
  top: 0;
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  transition: all 1s;
  transition-delay: 0.35s;
  opacity: 0.1;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-bar {
    width: 74.244%;
    left: 21%;
  }
}
.tech__graph__main .-bar.animated {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
  opacity: 1;
}
.tech__graph__main .-text.animated {
  transition-delay: 0.8s;
  transform: translate(0);
  opacity: 1;
}
.tech__graph__main .-abura {
  top: 58px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-abura {
    top: 14%;
  }
}
.tech__graph__main .-nioi {
  top: 141px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-nioi {
    top: 33%;
  }
}
.tech__graph__main .-virus {
  top: 219px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-virus {
    top: 52%;
  }
}
.tech__graph__main .-pm {
  top: 299px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-pm {
    top: 71%;
  }
}
.tech__graph__main .-yuugai {
  top: 376px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-yuugai {
    top: 90%;
  }
}
.tech__graph__main .-text {
  position: absolute;
  font-size: 32px;
  font-weight: 900;
  line-height: 1.2;
  text-align: center;
  color: #1896C8;
  opacity: 0;
  transform: translateX(-10px);
  transition: all 0.5s;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-text {
    font-size: 13.5px;
  }
}
.tech__graph__main .-text span {
  display: block;
  font-size: 15px;
  letter-spacing: 1px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-text span {
    font-size: 8.5px;
    letter-spacing: 0.5px;
  }
}
.tech__graph__main .-t90 {
  top: 41px;
  right: -99px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-t90 {
    right: -35px;
    top: 9%;
  }
  .tech__graph__main .-t90 .sup {
    font-size: 0.6em;
  }
}
.tech__graph__main .-t78 {
  top: 124px;
  right: -104px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-t78 {
    right: -37px;
    top: 27%;
  }
}
.tech__graph__main .-t994 {
  top: 202px;
  right: -104px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-t994 {
    right: -37px;
    top: 45%;
  }
}
.tech__graph__main .-t999_1 {
  top: 282px;
  right: -104px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-t999_1 {
    right: -37px;
    top: 63%;
  }
}
.tech__graph__main .-t999_2 {
  top: 359px;
  right: -104px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__main .-t999_2 {
    right: -37px;
    top: 80%;
  }
}
.tech__graph__notes {
  font-size: 13px;
  font-weight: 300;
  line-height: 1.62;
  letter-spacing: 0.52px;
  margin: 30px auto 0;
  width: 1030px;
}
@media screen and (max-width: 765px), print {
  .tech__graph__notes {
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: 0.36px;
    width: auto;
  }
}

.no-webp .tech__video.lazyloaded {
  background: url("../img/tech_bg-replace.png") no-repeat;
}

.earthplus__ttl-blk {
  background-color: #000;
  padding: 51.2px 15px 26.8px;
}
@media screen and (max-width: 765px), print {
  .earthplus__ttl-blk {
    padding: 25px 0 25px 17.5px;
  }
}
.earthplus__ttl {
  font-size: 36px;
  font-weight: 900;
  line-height: 1.47;
  letter-spacing: 1.8px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .earthplus__ttl {
    font-size: 19px;
    line-height: 1.47;
    letter-spacing: 0.95px;
  }
}
.earthplus__main {
  background-color: #FFF;
  padding-top: 71px;
  padding-bottom: 63px;
}
@media screen and (max-width: 765px), print {
  .earthplus__main {
    padding: 25px 20px 25px 37.5px;
  }
}
.earthplus__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .earthplus__inner {
    width: 100%;
  }
}
.earthplus__wrap {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
@media screen and (max-width: 765px), print {
  .earthplus__wrap {
    display: block;
  }
}
.earthplus__info {
  width: 445px;
}
@media screen and (max-width: 765px), print {
  .earthplus__info {
    width: 100%;
    text-align: center;
  }
}
.earthplus__logo {
  width: 365.89px;
  margin-bottom: 25px;
}
@media screen and (max-width: 765px), print {
  .earthplus__logo {
    width: 224.6px;
    display: block;
    margin: 0 auto 20px;
  }
}
.earthplus__text {
  margin-bottom: 10px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.88;
  letter-spacing: normal;
  color: #000;
  text-align: justify;
}
@media screen and (max-width: 765px), print {
  .earthplus__text {
    font-size: 11px;
    line-height: 1.73;
    letter-spacing: 0.83px;
    text-align: center;
    margin-bottom: 20px;
  }
}
.earthplus__text .-blue {
  color: #1896C8;
}
.earthplus__diagram {
  width: 280.57px;
}
@media screen and (max-width: 765px), print {
  .earthplus__diagram {
    display: block;
    margin: 20px auto 0;
    width: 272.725px;
  }
  .earthplus__diagram.pc {
    display: none;
  }
}
.earthplus__figure {
  width: 496.4px;
}
@media screen and (max-width: 765px), print {
  .earthplus__figure {
    width: 100%;
  }
}
.earthplus__video {
  width: 496.43px;
}
.earthplus__video.lazyloaded {
  background: url("../img/earthplus_bg-replace.webp") no-repeat;
  background-size: cover;
}
@media screen and (max-width: 765px), print {
  .earthplus__video {
    width: 100%;
  }
}
.earthplus__video__youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  opacity: 0;
}
.earthplus__video__youtube-area.-appear {
  -webkit-animation-name: PageAnimeAppear;
          animation-name: PageAnimeAppear;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.earthplus__video__youtube {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.earthplus__video__youtube-mask {
  position: absolute;
  z-index: 2;
  /*下から2番目に表示*/
  top: 0;
  width: 100%;
  height: 100%;
}
.earthplus__graph-ttl {
  margin-top: 30px;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.75;
  letter-spacing: 2.24px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph-ttl {
    font-size: 19px;
    line-height: 1.29;
    letter-spacing: 1.52px;
  }
}
.earthplus__graph-ttl .-blue {
  font-size: 48px;
  letter-spacing: 3.84px;
  color: #1896C8;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph-ttl .-blue {
    font-size: 29px;
    letter-spacing: 2.32px;
  }
}
.earthplus__graph-ttl .sup {
  font-size: 10px;
  transform: translate3d(-2px, -23px, 0);
}
.earthplus__graph-ttl .sup.sp {
  display: none;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph-ttl .sup.pc {
    display: none;
  }
  .earthplus__graph-ttl .sup.sp {
    display: inline-block;
    transform: translate3d(-2px, -16px, 0);
  }
}
.earthplus__graph {
  width: 777.48px;
  margin: 50px auto 0;
  position: relative;
  visibility: visible !important;
  opacity: 1;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph {
    width: 100%;
    margin-top: 15px;
  }
}
.earthplus__graph__base {
  width: 100%;
}
.earthplus__graph__g-line {
  position: absolute;
  top: 20px;
  left: 153px;
  width: 621.16px;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph__g-line {
    width: 83.547%;
    left: 15.5%;
    top: 6%;
  }
}
.earthplus__graph__b-line {
  position: absolute;
  top: 18.9px;
  left: 151.2px;
  width: 621.68px;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph__b-line {
    width: 83.547%;
    left: 15.5%;
    top: 6%;
  }
}
.earthplus__graph__g-text {
  position: absolute;
  width: 79.91px;
  top: 44px;
  left: 676px;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph__g-text {
    left: 80.5%;
    width: 15.85%;
    top: 11.5%;
  }
}
.earthplus__graph__b-text {
  position: absolute;
  width: 136.69px;
  left: 437px;
  top: 35px;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph__b-text {
    left: 53.8%;
    top: 10.2%;
    width: 25.5%;
  }
}
.earthplus__graph__square-text {
  position: absolute;
  width: 207.72px;
  left: 210px;
  top: 139px;
}
@media screen and (max-width: 765px), print {
  .earthplus__graph__square-text {
    width: 46.8%;
    left: 18%;
    top: 44%;
  }
}
.earthplus__graph .-line {
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  transition: all 1s;
}
.earthplus__graph .-label {
  opacity: 0;
  transition: all 0.7s;
  transition-delay: 1.1s;
}
.earthplus__graph .-arrow {
  opacity: 0;
  transform: translateY(-15px);
  transition: all 1s;
  transition-delay: 2s;
}
.earthplus__graph.animated .-line {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.earthplus__graph.animated .-label {
  opacity: 1;
}
.earthplus__graph.animated .-arrow {
  transform: translateY(0);
  opacity: 1;
}
.earthplus__notes {
  width: 785px;
  margin: 20px auto 0;
  font-size: 13px;
  font-weight: 300;
  line-height: 1.62;
  letter-spacing: 0.52px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .earthplus__notes {
    width: 100%;
    margin-top: 15px;
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: 0.2px;
  }
}

.no-webp .earthplus__video.lazyloaded {
  background: url("../img/earthplus_bg-replace.png") no-repeat;
}

.doyouknow__ttl-blk {
  background-color: #000;
  padding: 50px 0;
}
@media screen and (max-width: 765px), print {
  .doyouknow__ttl-blk {
    padding: 25px 0 25px 17.5px;
  }
}
.doyouknow__ttl {
  font-size: 37px;
  font-weight: bold;
  line-height: 1.43;
  letter-spacing: 1.85px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .doyouknow__ttl {
    font-size: 19px;
    line-height: 1.47;
    letter-spacing: 0.95px;
  }
}
.doyouknow__ttl .-smaller {
  font-size: 0.75em;
}
.doyouknow__video-wrap {
  background-color: #000;
  padding-bottom: 66.8px;
}
@media screen and (max-width: 765px), print {
  .doyouknow__video-wrap {
    padding-left: 37.5px;
    padding-right: 20px;
    padding-bottom: 30px;
  }
}
.doyouknow__video {
  width: 800px;
  margin: 0 auto;
  height: auto;
}
@media screen and (max-width: 765px), print {
  .doyouknow__video {
    width: 100%;
  }
}
.doyouknow__video.lazyloaded {
  background: url("../img/doyouknow_bg-replace-60.jpg") no-repeat;
  background-size: cover;
}
.doyouknow__video__youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  opacity: 0;
}
.doyouknow__video__youtube-area.-appear {
  -webkit-animation-name: PageAnimeAppear;
          animation-name: PageAnimeAppear;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.doyouknow__video__youtube {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.doyouknow__video__youtube-mask {
  position: absolute;
  z-index: 2;
  /*下から2番目に表示*/
  top: 0;
  width: 100%;
  height: 100%;
}
.doyouknow__main {
  background-image: linear-gradient(to bottom, #FFF 27%, #C5E7E7 63%);
  padding-top: 50px;
  padding-bottom: 75px;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main {
    padding: 27px 20px 25px 37.5px;
    background-image: linear-gradient(to bottom, #FFF 27%, #C5E7E7 76%);
  }
}
.doyouknow__main__inner {
  width: 1038px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__inner {
    width: 100%;
  }
}
.doyouknow__main__wrap {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__wrap {
    flex-direction: column-reverse;
    align-items: center;
  }
}
.doyouknow__main__left {
  width: 487px;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__left {
    width: 100%;
  }
}
.doyouknow__main__right {
  width: 487px;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__right {
    width: 100%;
    margin-bottom: 25px;
  }
}
.doyouknow__main__ttl {
  font-size: 25.2px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 1.26px;
  color: #000;
  margin-bottom: 34.2px;
  height: 47.19px;
  justify-content: center;
  align-items: flex-end;
  display: flex;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__ttl {
    font-size: 18.1px;
    letter-spacing: 0.91px;
    margin-bottom: 13.5px;
    height: auto;
  }
}
.doyouknow__main__logo {
  width: 310.96px;
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__logo {
    width: 223.88px;
  }
}
.doyouknow__main__label {
  margin-bottom: 15px;
  width: 487px;
  height: 52px;
  line-height: 52px;
  border-radius: 26px;
  font-size: 17px;
  font-weight: bold;
  letter-spacing: 1.53px;
  text-align: center;
  color: #FFF;
  box-shadow: 9px 9px 5px 0 rgba(0, 0, 0, 0.22);
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__label {
    margin: 10px auto 0;
    width: 320.5px;
    height: 61px;
    line-height: 61px;
    border-radius: 10px;
    box-shadow: 4.5px 4.5px 1.5px 0 rgba(0, 0, 0, 0.25);
    font-size: 14.5px;
    line-height: 1.62;
    letter-spacing: 0.73px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.doyouknow__main__label.-black1.lazyloaded {
  background: url("../img/doyouknow_label-bg1.webp") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__label.-black1.lazyloaded {
    background: url("../img/doyouknow_label-bg_sp.webp") no-repeat center/contain;
  }
}
.doyouknow__main__label.-black2.lazyloaded {
  background: url("../img/doyouknow_label-bg2.webp") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__label.-black2.lazyloaded {
    background: url("../img/doyouknow_label-bg_sp.webp") no-repeat center/contain;
  }
}
.doyouknow__main__label.-black3.lazyloaded {
  background: url("../img/doyouknow_label-bg3.webp") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__label.-black3.lazyloaded {
    background: url("../img/doyouknow_label-bg_sp.webp") no-repeat center/contain;
  }
}
.doyouknow__main__label.-blue {
  background-color: #1896C8;
}
.doyouknow__main__label.-letter-space {
  letter-spacing: normal;
}
.doyouknow__main__notes {
  margin-top: 20px;
  font-size: 13px;
  font-weight: 300;
  line-height: 1.54;
  letter-spacing: 0.52px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .doyouknow__main__notes {
    margin-top: 5px;
    font-size: 9px;
    line-height: 1.81;
    letter-spacing: 0.32px;
  }
}

.no-webp .doyouknow__video.lazyloaded {
  background: url("../img/doyouknow_bg-replace-60.jpg") no-repeat;
  background-size: cover;
}
.no-webp .doyouknow__main__label.-black1.lazyloaded {
  background: url("../img/doyouknow_label-bg1.png") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .no-webp .doyouknow__main__label.-black1.lazyloaded {
    background: url("../img/doyouknow_label-bg_sp.png") no-repeat center/contain;
  }
}
.no-webp .doyouknow__main__label.-black2.lazyloaded {
  background: url("../img/doyouknow_label-bg2.png") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .no-webp .doyouknow__main__label.-black2.lazyloaded {
    background: url("../img/doyouknow_label-bg_sp.png") no-repeat center/contain;
  }
}
.no-webp .doyouknow__main__label.-black3.lazyloaded {
  background: url("../img/doyouknow_label-bg3.png") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .no-webp .doyouknow__main__label.-black3.lazyloaded {
    background: url("../img/doyouknow_label-bg_sp.png") no-repeat center/contain;
  }
}

.vs__ttl-blk {
  background-color: #000;
  padding: 50px 0;
}
@media screen and (max-width: 765px), print {
  .vs__ttl-blk {
    padding: 25px 0 25px 17.5px;
  }
}
.vs__ttl {
  font-size: 37px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 1.85px;
  text-align: center;
  color: #FFF;
  align-items: flex-end;
  justify-content: center;
  display: flex;
}
@media screen and (max-width: 765px), print {
  .vs__ttl {
    font-size: 19px;
    line-height: 1.47;
    letter-spacing: 0.95px;
    display: block;
  }
}
.vs__ttl .-smaller {
  font-size: 0.75em;
}
.vs__logo {
  width: 269.53px;
  margin-left: 10px;
}
@media screen and (max-width: 765px), print {
  .vs__logo {
    margin-left: 0;
    width: 141.5px;
  }
}
.vs__inner {
  width: 808.01px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .vs__inner {
    width: 100%;
    padding-left: 37.5px;
    padding-right: 20px;
  }
}
.vs__main {
  padding-top: 57.4px;
  padding-bottom: 60px;
}
@media screen and (max-width: 765px), print {
  .vs__main {
    padding-top: 20px;
    padding-bottom: 25px;
  }
}
.vs__main__ttl {
  font-size: 28px;
  font-weight: bold;
  line-height: 1.39;
  letter-spacing: 1.4px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .vs__main__ttl {
    font-size: 15px;
    line-height: 1.53;
    letter-spacing: 0.75px;
  }
}
.vs__graph {
  margin: 50px auto 0;
  width: 764.74px;
  position: relative;
  visibility: visible !important;
}
@media screen and (max-width: 765px), print {
  .vs__graph {
    margin-top: 20px;
    width: 100%;
  }
}
.vs__graph__base {
  width: 100%;
  pointer-events: none;
}
.vs__graph .-gtext {
  position: absolute;
  width: 135.2px;
  left: 136px;
  top: 114px;
}
@media screen and (max-width: 765px), print {
  .vs__graph .-gtext {
    width: 29.2%;
    top: 25%;
    left: 16%;
  }
}
.vs__graph .-gline {
  position: absolute;
  width: 515.69px;
  top: 101px;
  left: 119px;
}
@media screen and (max-width: 765px), print {
  .vs__graph .-gline {
    width: 69.494%;
    left: 14.5%;
    top: 18%;
  }
}
.vs__graph .-btext {
  position: absolute;
  width: 158.53px;
  top: 56px;
  left: 138px;
}
@media screen and (max-width: 765px), print {
  .vs__graph .-btext {
    width: 29.2%;
    top: 8%;
    left: 16%;
  }
}
.vs__graph .-bline {
  position: absolute;
  width: 537.18px;
  top: 71px;
  left: 119px;
}
@media screen and (max-width: 765px), print {
  .vs__graph .-bline {
    width: 73%;
    left: 14.5%;
    top: 13%;
  }
}
.vs__graph .-text {
  opacity: 0;
  transition: all 0.5s;
}
.vs__graph .-line {
  -webkit-clip-path: inset(0 100% 0 0);
          clip-path: inset(0 100% 0 0);
  transition: all 1.3s;
  transition-delay: 0.5s;
}
.vs__graph .-arrow {
  position: absolute;
  width: 143.24px;
  top: 41px;
  left: 465px;
  opacity: 0;
  transform: translateY(-15px);
  transition: all 1s;
  transition-delay: 1.9s;
}
@media screen and (max-width: 765px), print {
  .vs__graph .-arrow {
    left: 56.5%;
    width: 23.79%;
    top: 3.5%;
  }
}
.vs__graph.animated .-text {
  opacity: 1;
}
.vs__graph.animated .-line {
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
}
.vs__graph.animated .-arrow {
  transform: translateY(0);
  opacity: 1;
}
.vs__bubble {
  margin-top: 34.3px;
  width: 100%;
  height: 133.85px;
  position: relative;
  font-size: 23px;
  font-weight: bold;
  line-height: 1.57;
  letter-spacing: 1.15px;
  text-align: center;
  color: #000;
  padding-top: 35px;
}
.vs__bubble.lazyloaded {
  background: #FFF url("../img/vs_bubble.svg") no-repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .vs__bubble {
    display: block;
    margin: 10px auto 0;
    width: 319.855px;
    height: 127.285px;
    font-size: 12.5px;
    line-height: 1.72;
    letter-spacing: 0.73px;
    padding-top: 28.5px;
  }
  .vs__bubble.lazyloaded {
    background: #FFF url("../img/vs_bubble_sp.svg") no-repeat center/contain;
  }
}
.vs__bubble .sup {
  transform: translate3d(0, -0.9em, 0);
}
@media screen and (max-width: 765px), print {
  .vs__bubble .sup {
    font-size: 7px;
  }
}
.vs__bubble:before {
  border-radius: 3px;
  position: absolute;
  z-index: -1;
  bottom: -12px;
  left: 12px;
  display: block;
  width: 100%;
  height: calc(100% - 15px);
  content: "";
  background-color: rgba(0, 0, 0, 0.05);
}
@media screen and (max-width: 765px), print {
  .vs__bubble:before {
    bottom: -6px;
    left: 6px;
  }
}
.vs__bubble span {
  position: relative;
  display: inline-block;
}
.vs__bubble span:after {
  position: absolute;
  bottom: -5px;
  left: 0;
  display: block;
  width: 100%;
  height: 3px;
  content: "";
  background: url("../img/vs_orange-line.svg") repeat center/contain;
}
@media screen and (max-width: 765px), print {
  .vs__bubble span:after {
    background: url("../img/vs_orange-line_sp.svg") repeat center/cover;
    bottom: -1px;
  }
}
.vs__notes {
  margin-top: 35px;
  font-size: 13px;
  font-weight: 300;
  line-height: 1.62;
  letter-spacing: 0.78px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .vs__notes {
    margin-top: 12.5px;
    letter-spacing: 0.32px;
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: 0.2px;
  }
}

.oilsmasher__ttl-blk {
  background-color: #000;
  padding: 50px 0;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__ttl-blk {
    padding: 25px 0 25px 17.5px;
  }
}
.oilsmasher__ttl {
  font-size: 37px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: 1.85px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__ttl {
    font-size: 19px;
    line-height: 1.58;
    letter-spacing: 0.95px;
  }
}
.oilsmasher__main {
  padding: 62.5px 0 100px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__main {
    padding: 20px 20px 20px 37.5px;
  }
}
.oilsmasher__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__inner {
    width: 100%;
  }
}
.oilsmasher__logo {
  margin-bottom: 46.8px;
  width: 368.84px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__logo {
    width: 230.8px;
    margin-bottom: 16px;
  }
}
.oilsmasher__first-block {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 70px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__first-block {
    display: block;
    margin-bottom: 22.5px;
  }
}
.oilsmasher__first-block__info {
  width: 447.74px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__first-block__info {
    width: 100%;
  }
}
.oilsmasher__first-block__ttl {
  margin-bottom: 29px;
  font-size: 26px;
  font-weight: bold;
  line-height: 1.42;
  letter-spacing: normal;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__first-block__ttl {
    margin-bottom: 20px;
    font-size: 15px;
    line-height: 1.53;
    letter-spacing: 0.75px;
  }
}
.oilsmasher__first-block__desc {
  margin-bottom: 10px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.88;
  letter-spacing: 0.3px;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__first-block__desc {
    margin-bottom: 25px;
    font-size: 11px;
    line-height: 1.82;
    letter-spacing: 0.83px;
  }
}
.oilsmasher__first-block__notes {
  font-size: 13px;
  font-weight: 300;
  line-height: 1.62;
  letter-spacing: normal;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__first-block__notes {
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: 0.3px;
  }
}
.oilsmasher__first-block__figure {
  width: 496.43px;
  margin-top: 7px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__first-block__figure {
    margin-top: 0;
    margin-bottom: 15px;
    width: 100%;
  }
}
.oilsmasher__first-block__video {
  width: 100%;
}
.oilsmasher__first-block__video.lazyloaded {
  background: url("../img/oilsmasher_bg-replace.webp") no-repeat;
  background-size: cover;
}
.oilsmasher__first-block__video__youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  opacity: 0;
}
.oilsmasher__first-block__video__youtube-area.-appear {
  -webkit-animation-name: PageAnimeAppear;
          animation-name: PageAnimeAppear;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.oilsmasher__first-block__video__youtube {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.oilsmasher__first-block__video__youtube-mask {
  position: absolute;
  z-index: 2;
  /*下から2番目に表示*/
  top: 0;
  width: 100%;
  height: 100%;
}
.oilsmasher__ttl-round {
  width: 100%;
  height: 62px;
  line-height: 62px;
  border-radius: 31px;
  border: solid 1px #000;
  font-size: 24px;
  font-weight: bold;
  letter-spacing: 3.12px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__ttl-round {
    height: 31px;
    line-height: 31px;
    font-size: 15px;
    letter-spacing: 0.75px;
  }
}
.oilsmasher__ttl-round sup {
  font-size: 13px;
  font-weight: 300;
  transform: translate3d(0, -13px, 0);
  letter-spacing: normal;
  margin-right: 3px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__ttl-round sup {
    font-size: 11px;
    font-weight: 500;
    transform: translate3d(0, -10px, 0);
  }
}
.oilsmasher__second-block {
  margin-bottom: 50px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__second-block {
    margin-bottom: 18px;
  }
}
.oilsmasher__second-block__text {
  margin-top: 30px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.88;
  letter-spacing: 0.5px;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__second-block__text {
    margin-top: 14px;
    font-size: 11px;
    line-height: 1.82;
    letter-spacing: 0.83px;
  }
}
.oilsmasher__second-block__notes {
  margin-top: 12px;
  font-size: 13px;
  font-weight: 300;
  line-height: 1.62;
  letter-spacing: 0.52px;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__second-block__notes {
    margin-top: 7.5px;
    font-weight: 300;
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: 0.3px;
  }
}
.oilsmasher__second-block__figure {
  margin-top: 20px;
  position: relative;
  margin-bottom: 15px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__second-block__figure {
    margin-top: 5px;
    margin-bottom: 7px;
  }
}
.oilsmasher__second-block__figure .-main {
  width: 100%;
}
.oilsmasher__second-block__figure .-b1 {
  position: absolute;
  left: -48px;
  top: 80px;
  width: 157.5px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__second-block__figure .-b1 {
    display: none;
  }
}
.oilsmasher__second-block__figure .-b2 {
  width: 157.5px;
  position: absolute;
  right: -20px;
  bottom: -62px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__second-block__figure .-b2 {
    display: none;
  }
}
.oilsmasher__third-block__text {
  margin: 30px 0 40px;
  font-size: 16px;
  font-weight: 500;
  line-height: 1.88;
  letter-spacing: 1.2px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__text {
    margin: 10px 0 15px;
    font-size: 11px;
    line-height: 1.82;
    letter-spacing: 0.83px;
  }
}
.oilsmasher__third-block__wrap {
  margin-bottom: 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__wrap {
    margin-bottom: 0;
    display: block;
  }
}
.oilsmasher__third-block__info {
  width: 407px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__info {
    width: 100%;
    margin-bottom: 5px;
  }
}
.oilsmasher__third-block__info__ttl {
  margin-bottom: 45px;
  font-size: 28.9px;
  font-weight: bold;
  line-height: 1.03;
  letter-spacing: 1.45px;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__info__ttl {
    margin-bottom: 15px;
    font-size: 14.5px;
    line-height: 1.72;
    letter-spacing: 0.73px;
    text-align: center;
    margin-bottom: 5px;
  }
}
.oilsmasher__third-block__info__text {
  margin-bottom: 20px;
  font-size: 18px;
  font-weight: 500;
  line-height: 2.22;
  letter-spacing: 1.35px;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__info__text {
    margin-bottom: 10px;
    font-size: 11px;
    line-height: 1.59;
    letter-spacing: 1.27px;
  }
}
.oilsmasher__third-block__info__desc {
  font-size: 16px;
  font-weight: 500;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__info__desc {
    font-weight: 300;
    margin-bottom: 20px;
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: 0.3px;
  }
}
.oilsmasher__third-block__figure {
  width: 527px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__figure {
    width: 100%;
    margin-bottom: 10px;
  }
}
.oilsmasher__third-block__video {
  width: 527px;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__video {
    width: 100%;
  }
}
.oilsmasher__third-block__video.-one.lazyloaded {
  background: url("../img/oilsmasher_bg2-replace.webp") no-repeat;
  background-size: cover;
}
.oilsmasher__third-block__video.-two.lazyloaded {
  background: url("../img/oilsmasher_bg3-replace.webp") no-repeat;
  background-size: cover;
}
.oilsmasher__third-block__video__youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  opacity: 0;
}
.oilsmasher__third-block__video__youtube-area.-appear {
  -webkit-animation-name: PageAnimeAppear;
          animation-name: PageAnimeAppear;
  -webkit-animation-duration: 0.5s;
          animation-duration: 0.5s;
  -webkit-animation-fill-mode: forwards;
          animation-fill-mode: forwards;
}
.oilsmasher__third-block__video__youtube {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.oilsmasher__third-block__video__youtube-mask {
  position: absolute;
  z-index: 2;
  /*下から2番目に表示*/
  top: 0;
  width: 100%;
  height: 100%;
}
.oilsmasher__third-block__notes {
  margin-top: 10px;
  font-size: 13px;
  font-weight: 500;
  letter-spacing: 0.98px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .oilsmasher__third-block__notes {
    font-size: 8px;
    font-weight: 300;
    line-height: 1.81;
    letter-spacing: 0.32px;
  }
}

.no-webp .oilsmasher__first-block__video {
  width: 100%;
}
.no-webp .oilsmasher__first-block__video.lazyloaded {
  background: url("../img/oilsmasher_bg-replace.png") no-repeat;
  background-size: cover;
}
.no-webp .oilsmasher__third-block__video.-one.lazyloaded {
  background: url("../img/oilsmasher_bg2-replace.png") no-repeat;
  background-size: cover;
}
.no-webp .oilsmasher__third-block__video.-two.lazyloaded {
  background: url("../img/oilsmasher_bg3-replace.png") no-repeat;
  background-size: cover;
}

.survey__ttl-blk {
  background-color: #000;
  padding: 50px 0;
}
@media screen and (max-width: 765px), print {
  .survey__ttl-blk {
    padding: 20px 20px 20px 37.5px;
  }
}
.survey__ttl {
  font-size: 37px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: 1.85px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .survey__ttl {
    font-size: 19px;
    line-height: 1.47;
    letter-spacing: 0.95px;
  }
}
.survey__main {
  background-color: #FFF;
}
.survey__first-block {
  padding-top: 68px;
  padding-left: 20px;
  padding-right: 20px;
  margin-bottom: 75px;
}
.survey__first-block.lazyloaded {
  background: url("../img/survey_bg1.webp") no-repeat top left/622px auto;
}
@media screen and (max-width: 765px), print {
  .survey__first-block {
    padding-top: 34px;
    background-size: 37% auto;
    margin-bottom: 20px;
    padding-left: 37.5px;
  }
}
.survey__first-block__ttl {
  margin-bottom: 12px;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.07;
  letter-spacing: 1.4px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .survey__first-block__ttl {
    font-size: 15px;
    line-height: 1.53;
    letter-spacing: 0.75px;
  }
}
.survey__first-block__notes {
  margin-bottom: 28px;
  font-size: 13px;
  font-weight: 300;
  line-height: 1.54;
  letter-spacing: 0.52px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .survey__first-block__notes {
    margin-bottom: 15px;
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: 0.3px;
    letter-spacing: normal;
    white-space: nowrap;
  }
}
.survey__first-block__figure {
  width: 869.97px;
  display: block;
  margin: 0 auto;
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .survey__first-block__figure {
    width: 100%;
  }
}
.survey__second-block {
  padding-bottom: 85px;
  padding-left: 20px;
  padding-right: 20px;
}
.survey__second-block.lazyloaded {
  background: url("../img/survey_bg2.webp") no-repeat top 68px right/731px auto;
}
@media screen and (max-width: 765px), print {
  .survey__second-block {
    position: relative;
    padding-bottom: 30px;
    background: none;
    padding-left: 37.5px;
  }
}
.survey__second-block__bg {
  width: 62%;
  position: absolute;
  top: -29px;
  right: 0;
}
.survey__second-block__ttl {
  margin-bottom: 64px;
  font-size: 28.9px;
  font-weight: bold;
  line-height: 1.03;
  letter-spacing: 1.45px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .survey__second-block__ttl {
    font-size: 15px;
    line-height: 1.53;
    letter-spacing: 0.75px;
    margin-bottom: 20px;
  }
}
.survey__second-block__figure {
  width: 869.97px;
  display: block;
  margin: 0 auto;
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .survey__second-block__figure {
    width: 100%;
  }
}
.survey__video-block {
  background-color: #000;
  padding-top: 110px;
  padding-bottom: 65px;
}
@media screen and (max-width: 765px), print {
  .survey__video-block {
    padding: 35px 20px 35px 37.5px;
  }
}
.survey__video-block__ttl {
  font-size: 37px;
  font-weight: 900;
  letter-spacing: 1.85px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .survey__video-block__ttl {
    font-size: 19px;
    line-height: 1.58;
    letter-spacing: 0.95px;
    white-space: nowrap;
  }
}
.survey__video {
  margin: 40px auto 0;
  width: 800px;
}
@media screen and (max-width: 765px), print {
  .survey__video {
    margin-top: 25px;
    width: 100%;
  }
}
.survey__video__youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.survey__video__youtube {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.no-webp .survey__first-block.lazyloaded {
  background: url("../img/survey_bg1.png") no-repeat top left/622px auto;
}
.no-webp .survey__second-block.lazyloaded {
  background: url("../img/survey_bg2.png") no-repeat top 68px right/731px auto;
}

.casestudy {
  padding-top: 60px;
  padding-bottom: 95px;
}
@media screen and (max-width: 765px), print {
  .casestudy {
    padding-top: 30px;
    padding-bottom: 25px;
  }
}
.casestudy__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .casestudy__inner {
    width: 100%;
    padding-left: 37.5px;
    padding-right: 20px;
  }
}
.casestudy__ttl {
  margin-bottom: 45px;
  font-size: 37px;
  font-weight: 900;
  line-height: 1.43;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .casestudy__ttl {
    margin-bottom: 30px;
    font-size: 19px;
    line-height: 1.58;
  }
}
.casestudy__wrap {
  display: flex;
  justify-content: center;
  margin: 0 30px;
}
@media screen and (max-width: 765px), print {
  .casestudy__wrap {
    display: block;
  }
}
.casestudy__item {
  width: 310px;
  margin: 0 20px;
}
@media screen and (max-width: 765px), print {
  .casestudy__item {
    width: 100%;
    margin: 0 0 20px 0;
  }
}
.casestudy__item__figure {
  padding-bottom: 15px;
  margin-bottom: 10px;
  height: 290px;
  position: relative;
  display: flex;
  align-items: flex-end;
  justify-content: center;
}
@media screen and (max-width: 765px), print {
  .casestudy__item__figure {
    padding-bottom: 8px;
    margin-bottom: 5px;
    height: 144.5px;
    padding-left: 9px;
    justify-content: flex-start;
  }
}
.casestudy__item__figure img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.casestudy__item__figure p {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: normal;
  text-shadow: 0 0 11px #000;
  color: #FFF;
  z-index: 1;
}
@media screen and (max-width: 765px), print {
  .casestudy__item__figure p {
    font-size: 17px;
    line-height: 1.26;
    letter-spacing: 0.85px;
  }
}
@media screen and (max-width: 765px), print {
  .casestudy__item__sp-wrap {
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    height: 73.5px;
  }
}
.casestudy__item__info {
  height: 147px;
  display: flex;
  margin-bottom: 10px;
}
@media screen and (max-width: 765px), print {
  .casestudy__item__info {
    width: 56.14%;
    height: 100%;
    margin-bottom: 0;
  }
}
.casestudy__item__person {
  width: 115px;
  flex-shrink: 0;
}
@media screen and (max-width: 765px), print {
  .casestudy__item__person {
    width: 57.5px;
  }
}
.casestudy__item__person img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.casestudy__item__text {
  flex-grow: 1;
  padding-left: 18.3px;
  display: flex;
  align-items: center;
  background-color: #E4E4E4;
}
@media screen and (max-width: 765px), print {
  .casestudy__item__text {
    padding-left: 10px;
  }
}
.casestudy__item__store-name {
  font-size: 16px;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 0.15px;
  color: #000;
  margin-bottom: 4px;
}
.casestudy__item__store-name.-tearoom {
  white-space: nowrap;
  letter-spacing: -1px;
  margin-bottom: 0;
}
@media screen and (max-width: 765px), print {
  .casestudy__item__store-name {
    font-size: 10px;
    line-height: 1.5;
    margin-bottom: 3px;
  }
}
.casestudy__item__person-name {
  font-size: 14px;
  font-weight: bold;
  line-height: 1.6;
  letter-spacing: 0.2px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .casestudy__item__person-name {
    font-size: 8px;
    line-height: 1.5;
  }
}
.casestudy__item__link {
  display: block;
  height: 55.48px;
  line-height: 55.48px;
  text-align: center;
  font-size: 17px;
  font-weight: 500;
  border: solid 1px #000;
  background-color: #FFF;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
}
@media screen and (max-width: 765px), print {
  .casestudy__item__link {
    box-sizing: border-box;
    width: 42.28%;
    height: 100%;
    line-height: 1;
    font-size: 13px;
    box-shadow: none;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.casestudy__item__link:link, .casestudy__item__link:visited, .casestudy__item__link:hover, .casestudy__item__link:active {
  color: #000;
}
.casestudy__item.-empty {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 17px;
  font-weight: bold;
  letter-spacing: 1.25px;
  background-color: #CED8D8;
}
@media screen and (max-width: 765px), print {
  .casestudy__item.-empty {
    height: 223px;
    font-size: 12px;
    letter-spacing: 1px;
  }
}
.casestudy__btn-wrap {
  margin-top: 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 765px), print {
  .casestudy__btn-wrap {
    margin-top: 0;
    display: block;
  }
}
.casestudy__btn {
  display: block;
  width: 487px;
  height: 80px;
  line-height: 80px;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 2.2px;
  text-align: center;
  background-color: #1896C8;
}
@media screen and (max-width: 765px), print {
  .casestudy__btn {
    margin-bottom: 8px;
    width: 100%;
    height: 52.4px;
    line-height: 52.4px;
    font-size: 14.4px;
    letter-spacing: 1.44px;
  }
  .casestudy__btn:last-child {
    margin-bottom: 0;
  }
}
.casestudy__btn:link, .casestudy__btn:visited, .casestudy__btn:hover, .casestudy__btn:active {
  color: #FFF;
}

.movie {
  padding: 80px 0 50px;
}
@media screen and (max-width: 765px), print {
  .movie {
    padding: 50px 0 40px 17.5px;
  }
}
.movie__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .movie__inner {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.movie__ttl {
  font-size: 37px;
  font-weight: 900;
  line-height: 1.05;
  letter-spacing: 1.85px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .movie__ttl {
    font-size: 19px;
    line-height: 1.58;
  }
}
.movie__wrap {
  margin-top: 41px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media screen and (max-width: 765px), print {
  .movie__wrap {
    margin-top: 30px;
    display: block;
  }
}
.movie__item {
  width: 480px;
  margin-bottom: 40px;
}
@media screen and (max-width: 765px), print {
  .movie__item {
    width: 100%;
    margin-bottom: 22px;
  }
}
.movie__youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow: hidden;
  height: 0;
}
.movie__youtube {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}
.movie__youtube-ttl {
  margin-top: 12px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.83;
  letter-spacing: 1.35px;
  text-align: center;
}
@media screen and (max-width: 765px), print {
  .movie__youtube-ttl {
    margin-top: 11px;
    font-size: 14px;
    line-height: 1.45;
    letter-spacing: 0.8px;
  }
}
.movie__item.-popup {
  width: calc(50% - 13.7px);
}
@media screen and (max-width: 765px), print {
  .movie__item.-popup {
    width: 100%;
  }
}
.movie__item.-popup .movie__youtube-ttl {
  font-size: 15px;
  font-weight: bold;
  line-height: 1.89;
  letter-spacing: 1.13px;
  text-align: left;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .movie__item.-popup .movie__youtube-ttl {
    font-size: 14px;
    line-height: 1.45;
    letter-spacing: 0.8px;
  }
}
.movie__other {
  margin-top: 35px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
@media screen and (max-width: 765px), print {
  .movie__other {
    margin-top: 15px;
    display: block;
    text-align: center;
  }
}
.movie__other__text {
  font-size: 24px;
  font-weight: bold;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .movie__other__text {
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.98px;
    margin-bottom: 15px;
  }
}
.movie__other__btn {
  margin-left: 10px;
  width: 231.5px;
  height: 68.5px;
  line-height: 68.5px;
  text-align: center;
  display: inline-block;
  font-size: 19px;
  font-weight: 600;
  border: 1px solid #000;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .movie__other__btn {
    margin-left: 0;
    width: 100%;
    height: 47.2px;
    line-height: 47.2px;
    font-size: 14px;
  }
}
.movie__other__btn:link, .movie__other__btn:visited, .movie__other__btn:hover, .movie__other__btn:active {
  color: #000;
}
.movie__popup-ttl {
  margin-bottom: 50px;
  font-size: 35px;
  font-weight: 900;
  line-height: 0.6;
  letter-spacing: 1.4px;
  text-align: center;
  color: #1896C8;
}
@media screen and (max-width: 765px), print {
  .movie__popup-ttl {
    font-size: 17px;
    margin-bottom: 15px;
    letter-spacing: 0.8px;
    line-height: 1;
  }
}

.top-liu__ttl-blk {
  background-color: #000;
  padding: 32px 0;
}
@media screen and (max-width: 765px), print {
  .top-liu__ttl-blk {
    padding: 30px 0 30px 17.5px;
  }
}
.top-liu__ttl {
  font-size: 36px;
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: 1.8px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .top-liu__ttl {
    font-size: 18px;
    font-weight: bold;
    line-height: 1.58;
    letter-spacing: 0.95px;
  }
}
.top-liu__main {
  padding: 44.8px 15px 62.6px;
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .top-liu__main {
    padding: 20px 20px 25px 37.5px;
  }
}
.top-liu__main__ttl {
  margin-bottom: 25px;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.39;
  letter-spacing: 1.4px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .top-liu__main__ttl {
    font-size: 15px;
    line-height: 1.53;
    letter-spacing: 0.75px;
    margin-bottom: 20px;
  }
}
.top-liu__product1 {
  display: block;
  margin: 0 auto 70px;
  width: 769.9px;
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .top-liu__product1 {
    width: 247.86px;
    margin-bottom: 30px;
  }
}
.top-liu__product2 {
  display: block;
  margin: 38.2px auto 0;
  width: 708px;
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .top-liu__product2 {
    margin-top: 15px;
    width: 101vw;
    margin-left: -37.5px;
  }
}
.top-liu__other {
  width: 1000px;
  margin: 77px auto 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
@media screen and (max-width: 765px), print {
  .top-liu__other {
    width: 100%;
    margin-top: 15px;
    display: block;
    text-align: center;
  }
}
.top-liu__other__text {
  font-size: 24px;
  font-weight: bold;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .top-liu__other__text {
    font-size: 13px;
    font-weight: 500;
    letter-spacing: 0.98px;
    margin-bottom: 15px;
  }
}
.top-liu__other__btn {
  margin-left: 10px;
  width: 231.5px;
  height: 68.5px;
  line-height: 68.5px;
  text-align: center;
  display: inline-block;
  font-size: 19px;
  font-weight: 600;
  border: 1px solid #000;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .top-liu__other__btn {
    margin-left: 0;
    width: 100%;
    height: 47.2px;
    line-height: 47.2px;
    font-size: 14px;
  }
}
.top-liu__other__btn:link, .top-liu__other__btn:visited, .top-liu__other__btn:hover, .top-liu__other__btn:active {
  color: #000;
}

.top-qna {
  background-color: #000;
}
.top-qna__img {
  width: 100%;
}
.top-qna__main {
  background-color: #000;
  padding: 40px 15px 70px;
  text-align: center;
}
@media screen and (max-width: 765px), print {
  .top-qna__main {
    padding: 20px 20px 30px 37.5px;
  }
}
.top-qna__ttl img {
  width: 86.79px;
}
@media screen and (max-width: 765px), print {
  .top-qna__ttl img {
    width: 62.16px;
  }
}
.top-qna__sub {
  margin-top: 15px;
  line-height: 1.63;
  font-size: 24px;
  font-weight: bold;
  color: #FFF;
  letter-spacing: 1.2px;
}
@media screen and (max-width: 765px), print {
  .top-qna__sub {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.54;
    letter-spacing: 0.98px;
  }
}
.top-qna__link {
  margin-top: 37.5px;
  width: 231.5px;
  height: 68.5px;
  line-height: 68.5px;
  text-align: center;
  display: inline-block;
  font-size: 19px;
  font-weight: 600;
  border: 1px solid #000;
  box-shadow: 2px 2px 5px rgba(0, 0, 0, 0.2);
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .top-qna__link {
    margin-top: 30px;
    width: 100%;
    height: 47.2px;
    line-height: 47.2px;
    font-size: 13px;
  }
}
.top-qna__link:link, .top-qna__link:visited, .top-qna__link:hover, .top-qna__link:active {
  color: #000;
}

.top-insta {
  padding: 65px 15px 79.2px;
  text-align: center;
}
@media screen and (max-width: 765px), print {
  .top-insta {
    padding: 30px 20px 20px 37.5px;
  }
}
.top-insta__ttl {
  margin-bottom: 17px;
  font-size: 33px;
  font-weight: bold;
  line-height: 1.18;
  letter-spacing: 1.65px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .top-insta__ttl {
    font-size: 19.8px;
    letter-spacing: 0.99px;
    margin-bottom: 8px;
  }
}
.top-insta__ttl span {
  display: block;
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.7px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .top-insta__ttl span {
    font-size: 8.4px;
    letter-spacing: 0.42px;
  }
}
.top-insta__logo {
  width: 141.05px;
}
@media screen and (max-width: 765px), print {
  .top-insta__logo {
    width: 129px;
  }
}
.top-insta__instafeed {
  width: 1000px;
  margin: 21px auto 0;
}
@media screen and (max-width: 765px), print {
  .top-insta__instafeed {
    width: 100%;
    padding-right: 0;
    padding-left: 0;
  }
}
.top-insta__instafeed__wrap {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-start;
}
@media screen and (max-width: 765px), print {
  .top-insta__instafeed__wrap {
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
.top-insta__instafeed a {
  display: flex;
  overflow: hidden;
  align-items: center;
  justify-content: center;
  width: 235px;
  height: 235px;
  margin-right: 20px;
  margin-bottom: 20px;
}
.top-insta__instafeed a:nth-child(4n) {
  margin-right: 0;
}
@media screen and (max-width: 765px), print {
  .top-insta__instafeed a {
    width: calc(33.3333% - 10px);
    height: auto;
    margin-right: 0;
    margin-bottom: 15px;
  }
  .top-insta__instafeed a:nth-child(2n) {
    margin-right: 0;
  }
}
.top-insta__instafeed__img {
  width: 100%;
  transition: 0.3s;
}
.top-insta__instafeed__img:hover {
  transform: scale(1.08);
}
.top-insta__instafeed .sp {
  display: none !important;
}
@media screen and (max-width: 765px), print {
  .top-insta__instafeed .sp {
    display: flex !important;
  }
}

.top-news {
  padding: 50px 15px 110px;
}
@media screen and (max-width: 765px), print {
  .top-news {
    padding: 40px 20px 20px 37.5px;
  }
}
.top-news__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .top-news__inner {
    width: 100%;
  }
}
.top-news__ttl {
  margin-bottom: 50px;
  font-size: 36px;
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: 1.8px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .top-news__ttl {
    margin-bottom: 30px;
    font-size: 19px;
    line-height: 1.47;
    letter-spacing: normal;
  }
}
.top-news__main {
  border-top: 1px solid #000;
  border-bottom: 1px solid #000;
  padding: 36.7px 20px 27.1px;
}
@media screen and (max-width: 765px), print {
  .top-news__main {
    border-bottom: 0;
    padding: 28px 0 0;
  }
}
.top-news__article {
  margin-bottom: 40.5px;
}
@media screen and (max-width: 765px), print {
  .top-news__article {
    margin-bottom: 25px;
  }
}
.top-news__article:last-child {
  margin-bottom: 0;
}
.top-news__article__link {
  display: block;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 765px), print {
  .top-news__article__link {
    display: block;
  }
}
.top-news__article__label {
  margin-right: 49.2px;
  flex-grow: 0;
  width: 100px;
  height: 40px;
  line-height: 40px;
  text-align: center;
  display: block;
  background-color: #000;
  font-size: 16.4px;
  letter-spacing: 1.64px;
  text-align: center;
  cursor: pointer;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .top-news__article__label {
    margin-bottom: 15px;
    margin-right: 0;
    height: 24.8px;
    width: 60.3px;
    line-height: 24.8px;
    font-size: 9.5px;
    letter-spacing: 0.95px;
  }
}
.top-news__article__body {
  flex-grow: 1;
}
.top-news__article__date {
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 1.1px;
  color: #000;
  margin-bottom: 5px;
}
@media screen and (max-width: 765px), print {
  .top-news__article__date {
    font-size: 12.5px;
    letter-spacing: 0.63px;
  }
}
.top-news__article__ttl {
  font-size: 22px;
  font-weight: bold;
  line-height: 1.77;
  letter-spacing: 1.1px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .top-news__article__ttl {
    font-size: 12.5px;
    line-height: 1.53;
    letter-spacing: 0.63px;
  }
}
.top-news__view-more {
  margin-top: 13px;
  text-align: right;
}
@media screen and (max-width: 765px), print {
  .top-news__view-more {
    margin-top: 0;
    text-align: center;
  }
}
.top-news__view-more a {
  display: inline-block;
  width: 148.7px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  background-color: #000;
  font-size: 16.1px;
  font-weight: 500;
  letter-spacing: 1.61px;
}
@media screen and (max-width: 765px), print {
  .top-news__view-more a {
    display: block;
    width: 100%;
    height: 47.2px;
    line-height: 47.2px;
    font-size: 13px;
    letter-spacing: 1px;
  }
}
.top-news__view-more a:link, .top-news__view-more a:visited, .top-news__view-more a:hover, .top-news__view-more a:active {
  color: #FFF;
}
.top-news__ad {
  margin-top: 50px;
  display: block;
}
@media screen and (max-width: 765px), print {
  .top-news__ad {
    margin-top: 12.5px;
  }
}
.top-news__ad img {
  width: 100%;
}

.about__ttl-blk {
  padding: 50px 0;
  background-color: #000;
}
@media screen and (max-width: 765px), print {
  .about__ttl-blk {
    padding: 25px 0 25px 17.5px;
  }
}
.about__sub {
  margin-bottom: 20px;
  font-size: 26px;
  font-weight: bold;
  line-height: 1.15;
  letter-spacing: 1.3px;
  text-align: center;
  color: #1896C8;
}
@media screen and (max-width: 765px), print {
  .about__sub {
    margin-bottom: 5.6px;
    font-size: 14px;
    line-height: 1.07;
    letter-spacing: 0.7px;
  }
}
.about__ttl {
  font-size: 37px;
  font-weight: bold;
  line-height: 1.43;
  letter-spacing: 1.85px;
  text-align: center;
  color: #FFF;
}
@media screen and (max-width: 765px), print {
  .about__ttl {
    font-size: 19px;
    line-height: 1.47;
    letter-spacing: 0.95px;
  }
}
.about__main {
  background-color: #FFF;
}
.about__top-block {
  width: 1060px;
  margin: 30px auto 0;
  padding-bottom: 70px;
}
@media screen and (max-width: 765px), print {
  .about__top-block {
    width: 100%;
    padding-left: 37.5px;
    padding-right: 20px;
    padding-bottom: 30px;
  }
}
.about__top-block__wrap {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 765px), print {
  .about__top-block__wrap {
    display: block;
  }
}
.about__top-block__item {
  padding-top: 20px;
  position: relative;
  width: 50%;
  height: 377px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__item {
    padding-top: 0;
    width: 100%;
    height: auto;
    text-align: center;
  }
}
.about__top-block__item:first-child {
  border-right: 1px solid #CACACA;
}
@media screen and (max-width: 765px), print {
  .about__top-block__item:first-child {
    border-right: none;
  }
}
.about__top-block__ttl {
  width: 100%;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 765px), print {
  .about__top-block__ttl {
    height: auto;
    display: block;
    text-align: center;
  }
}
.about__top-block__ttl.-one {
  margin-left: -15px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__ttl.-one {
    margin-left: 0;
  }
}
.about__top-block__ttl.-two {
  margin-left: 63px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__ttl.-two {
    margin-left: 0;
  }
}
.about__top-block__ttl p {
  color: #1896C8;
  font-size: 25px;
  font-weight: bold;
  text-align: center;
  line-height: 1.6;
  letter-spacing: 1.25px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__ttl p {
    font-size: 13.5px;
    letter-spacing: 0.5px;
  }
}
.about__top-block__ttl p .-large {
  font-size: 31px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__ttl p .-large {
    font-size: 19px;
  }
}
.about__top-block__ttl .sup {
  font-size: 10px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__ttl .sup {
    font-size: 8px;
  }
}
.about__top-block__figure {
  position: absolute;
  z-index: 0;
}
@media screen and (max-width: 765px), print {
  .about__top-block__figure {
    position: relative;
    margin-top: 20px;
    margin-bottom: 20px;
  }
}
.about__top-block__figure.-one {
  width: 496.8px;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}
@media screen and (max-width: 765px), print {
  .about__top-block__figure.-one {
    width: 303px;
    left: 0;
    transform: translateX(0);
  }
}
.about__top-block__figure.-two {
  width: 574px;
  bottom: -10px;
  right: -58px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__figure.-two {
    width: 318.75px;
    bottom: 0;
    right: 0;
  }
}
.about__top-block__notes {
  margin-top: 25px;
  font-size: 14px;
  line-height: 1.6;
  letter-spacing: 1px;
}
@media screen and (max-width: 765px), print {
  .about__top-block__notes {
    font-weight: 300;
    margin-top: 0;
    font-size: 9px;
    line-height: 1.67;
    letter-spacing: normal;
  }
}
.about__bottom-block__inner {
  width: 1000px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .about__bottom-block__inner {
    width: 100%;
    padding-left: 17.5px;
  }
}
.about__bottom-block__ttl {
  margin-bottom: 30px;
  font-size: 32px;
  font-weight: bold;
  letter-spacing: 1.6px;
  text-align: center;
  color: #1896C8;
}
@media screen and (max-width: 765px), print {
  .about__bottom-block__ttl {
    font-size: 17px;
    letter-spacing: 1px;
    line-height: 1.4;
    margin-bottom: 15px;
  }
}
.about__bottom-block__text {
  font-size: 18px;
  font-weight: 500;
  line-height: 1.61;
  letter-spacing: 1.26px;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .about__bottom-block__text {
    font-size: 11px;
    line-height: 1.82;
    padding-left: 30px;
    padding-right: 30px;
    letter-spacing: 0.83px;
  }
}
.about__bottom-block__wrap {
  max-width: 1500px;
  margin: 30px auto 0;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media screen and (max-width: 765px), print {
  .about__bottom-block__wrap {
    display: block;
    margin-top: 20px;
  }
}
.about__bottom-block__item {
  width: calc(50% - 2.5px);
  margin-bottom: 24px;
}
@media screen and (max-width: 765px), print {
  .about__bottom-block__item {
    width: 100%;
    margin-bottom: 15px;
  }
}
.about__bottom-block__figure {
  width: 100%;
  display: block;
  margin-bottom: 24.3px;
}
@media screen and (max-width: 765px), print {
  .about__bottom-block__figure {
    margin-bottom: 15px;
  }
}
.about__bottom-block__desc {
  font-size: 15px;
  line-height: 1.6;
  letter-spacing: 0.75px;
  text-align: center;
  color: #000;
}
@media screen and (max-width: 765px), print {
  .about__bottom-block__desc {
    font-size: 11px;
    line-height: 1.82;
    letter-spacing: 0.83px;
    padding-left: 17.5px;
  }
}

.cs-popup {
  position: fixed;
  z-index: 1000;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  visibility: hidden;
  transition: all 0.3s;
  pointer-events: none;
  opacity: 0;
  background-color: rgba(0, 0, 0, 0.9);
}
@media screen and (max-width: 765px), print {
  .cs-popup {
    z-index: 5;
    top: 57.69px;
  }
}
.cs-popup:target {
  visibility: visible;
  pointer-events: auto;
  opacity: 1;
}
.cs-popup__close {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  cursor: default;
}
.cs-popup__modal-close {
  position: absolute;
  top: 23px;
  right: 21px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__modal-close {
    top: 10px;
    right: 10.7px;
  }
}
.cs-popup__modal-close img {
  width: 40.8px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__modal-close img {
    width: 25.4px;
  }
}
.cs-popup__modal-close-bottom img {
  width: 25.4px;
  display: block;
  margin: 20px auto 0;
}
.cs-popup__content-wrap {
  position: absolute;
  top: 50%;
  left: 50%;
  display: block;
  overflow: hidden;
  width: 1000px;
  max-height: 98vh;
  transform: translate(-50%, -50%);
  border-bottom: solid 1px #CCC;
}
@media screen and (max-width: 765px), print {
  .cs-popup__content-wrap {
    overflow: scroll;
    width: calc(100% - 40px);
    max-width: 400px !important;
    max-height: 96% !important;
  }
}
.cs-popup__content {
  overflow: scroll;
  width: 100%;
  max-height: 98vh;
  background-color: #FFF;
  padding: 80px;
}
.cs-popup__content.-movie {
  padding-bottom: 0;
}
@media screen and (max-width: 765px), print {
  .cs-popup__content {
    max-height: 98% !important;
    padding: 30px 15px 15px;
  }
  .cs-popup__content.-movie {
    padding-bottom: 15px;
  }
}
.cs-popup__fv {
  width: 100%;
}
.cs-popup__fv.-two {
  margin-top: 70px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__fv.-two {
    margin-top: 40px;
  }
}
@media screen and (max-width: 765px), print {
  .cs-popup__fv {
    width: calc(100% + 30px);
    margin-left: -15px;
    margin-top: -30px;
  }
  .cs-popup__fv.-ex {
    margin-top: 0;
  }
}
.cs-popup__fv p {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.78;
  letter-spacing: 1.8px;
  color: #1896C8;
  margin-bottom: 5px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__fv p {
    font-size: 14px;
    line-height: 1.15;
    letter-spacing: 1.4px;
    padding-left: 1em;
  }
}
.cs-popup__wrap {
  margin-top: 50px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 765px), print {
  .cs-popup__wrap {
    margin-top: 15px;
    display: block;
    position: relative;
  }
}
.cs-popup__ownerpic {
  width: 429px;
  flex-shrink: 0;
  margin-left: -56px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__ownerpic {
    width: 131px;
    margin-left: 0;
    position: absolute;
    right: 0;
    bottom: 0;
  }
  .cs-popup__ownerpic.-ex {
    width: 124px;
  }
}
.cs-popup__info {
  background: #28323C;
  padding: 38px 15px 33px 65px;
  width: 467px;
  flex-shrink: 0;
  z-index: 1;
  color: #FFF;
}
.cs-popup__info.-three {
  padding-top: 27px;
  padding-bottom: 27px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__info {
    width: 100%;
    padding: 17.5px 15px 17.5px 17.5px;
  }
  .cs-popup__info.-three {
    padding-top: 17.5px;
    padding-bottom: 17.5px;
  }
}
.cs-popup__label {
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.42px;
  color: #1896C8;
  margin-bottom: 20px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__label {
    font-size: 11px;
    letter-spacing: 0.33px;
  }
}
.cs-popup__ttl {
  font-size: 23px;
  font-weight: bold;
  line-height: 1.62;
  letter-spacing: 2.3px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__ttl {
    font-size: 14.5px;
    line-height: 1.28;
    letter-spacing: 1.45px;
  }
}
.cs-popup__hr {
  margin: 24px 0;
  display: block;
  width: 31px;
  height: 1px;
  background-color: #FFF;
}
@media screen and (max-width: 765px), print {
  .cs-popup__hr {
    margin: 11px 0;
    width: 15.5px;
  }
}
.cs-popup__bottom-info {
  margin-bottom: 10px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__bottom-info {
    margin-bottom: 0;
  }
}
.cs-popup__storename {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.78;
  letter-spacing: 1.8px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__storename {
    font-size: 12px;
    line-height: 1.34;
    letter-spacing: 1.2px;
  }
}
.cs-popup__owner {
  margin-top: 7px;
  font-size: 16px;
  line-height: 1.31;
  letter-spacing: 1.6px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__owner {
    margin-top: 4px;
    font-size: 12px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 1.2px;
  }
  .cs-popup__owner.-ex {
    line-height: 1.2;
  }
}
.cs-popup__address {
  margin-top: 15px;
  font-size: 14px;
  line-height: 1.57;
  letter-spacing: 1.4px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__address {
    margin-top: 10px;
    font-size: 11px;
    line-height: 1.23;
    letter-spacing: 1.1px;
  }
  .cs-popup__address.-ex {
    letter-spacing: -0.5px;
  }
}
.cs-popup__wrap2 {
  margin-top: 50px;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
}
@media screen and (max-width: 765px), print {
  .cs-popup__wrap2 {
    margin-top: 35px;
    display: block;
  }
}
.cs-popup__figure {
  width: 439px;
  flex-shrink: 0;
}
@media screen and (max-width: 765px), print {
  .cs-popup__figure {
    width: 100%;
    margin-top: 25px;
  }
}
.cs-popup__figure img {
  width: 393.63px;
}
@media screen and (max-width: 765px), print {
  .cs-popup__figure img {
    width: 100%;
  }
}
.cs-popup__paragraph {
  flex-grow: 1;
}
.cs-popup__paragraph.-ex {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
@media screen and (max-width: 765px), print {
  .cs-popup__paragraph.-ex {
    display: block;
  }
}
.cs-popup__h3 {
  margin-bottom: 11px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1.4;
  letter-spacing: 1.8px;
  color: #1896C8;
}
@media screen and (max-width: 765px), print {
  .cs-popup__h3 {
    font-size: 13px;
    line-height: 1.27;
    letter-spacing: 0.98px;
  }
}
.cs-popup__text {
  margin-bottom: 22px;
  font-size: 15px;
  font-weight: 300;
  line-height: 1.47;
  letter-spacing: normal;
}
@media screen and (max-width: 765px), print {
  .cs-popup__text {
    font-size: 12px;
    line-height: 1.33;
    letter-spacing: 1.2px;
  }
}
.cs-popup__text:last-child {
  margin-bottom: 0;
}
.cs-popup__p-img {
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .cs-popup__p-img {
    margin-top: 20px;
  }
}
.cs-popup__video {
  width: 635.4px;
  margin: 70px auto 0;
}
@media screen and (max-width: 765px), print {
  .cs-popup__video {
    width: 100%;
    margin-top: 25px;
  }
  .cs-popup__video.-ex {
    margin-top: 14px;
  }
}
.cs-popup__youtube-area {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  overflow: hidden;
  height: 0;
}
.cs-popup__youtube {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

.navigation {
  position: fixed;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
}
@media screen and (max-width: 765px), print {
  .navigation {
    left: 13.25px;
    top: calc(50% - 35px);
  }
}
.navigation a {
  display: flex;
  align-items: center;
  margin-bottom: 23.7px;
  transition: background-color 0.2s;
}
@media screen and (max-width: 765px), print {
  .navigation a {
    margin-bottom: 15.7px;
  }
}
.navigation a:before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  background-color: #D0D0D0;
  border-radius: 50%;
  margin-right: 5px;
}
@media screen and (max-width: 765px), print {
  .navigation a:before {
    width: 9px;
    height: 9px;
  }
}
.navigation a.-active:before, .navigation a:hover:before {
  background-color: #1F8DBC;
}
.navigation a span {
  font-size: 13px;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.91px;
  color: #1F8DBC;
  display: none;
  height: 12px;
}
@media screen and (max-width: 765px), print {
  .navigation a span {
    display: none;
  }
}
.navigation a:hover span {
  display: block;
}
.navigation a:last-child {
  margin-bottom: 0;
}

.foot-menu {
  display: none;
}
@media screen and (max-width: 765px), print {
  .foot-menu {
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    z-index: 5;
  }
  .foot-menu a {
    width: 33.3333%;
    padding: 0;
    text-align: center;
    font-size: 12.4px;
    font-weight: 500;
    height: 52.5px;
    line-height: 52.5px;
    letter-spacing: 1.24px;
    background-color: #79C2DF;
  }
  .foot-menu a:link, .foot-menu a:visited, .foot-menu a:hover, .foot-menu a:active {
    color: #FFF;
  }
  .foot-menu a:first-child, .foot-menu a:last-child {
    background-color: #1896C8;
  }
}

@media screen and (max-width: 765px), print {
  .foot-menu--top {
    opacity: 0;
    pointer-events: none;
    transition: all 600ms cubic-bezier(0.04, 0.51, 0.155, 0.985);
  }
}

@media screen and (max-width: 765px), print {
  body.is-scroll .foot-menu--top {
    opacity: 1;
    pointer-events: auto;
  }
}

.contact {
  padding: 85px 0 80px;
}
.contact #gs-breadcrumb {
    padding-bottom: 54px;
}
.contact.-confirm {
  padding-top: 50px;
}
.contact input {
  box-sizing: border-box;
}
.contact input:focus {
  outline: 1px solid #1896C8;
}
.contact .ttl-line {
  margin-bottom: 47px;
  padding-bottom: 20px;
  color: #000;
}
.contact__ttl {
  font-size: 23px;
  font-weight: bold;
  line-height: 1.24;
  letter-spacing: 2.76px;
  text-align: center;
  color: #1896C8;
  margin-bottom: 20px;
}
.contact__subttl {
  text-align: center;
  margin-bottom: 40px;
  font-size: 18px;
  line-height: 2.17;
  letter-spacing: 1.57px;
  text-align: center;
  color: #000;
}
.contact__wrap {
  display: block;
  width: 1000px;
  margin: auto;
}
.contact__group {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.contact__input {
  margin-bottom: 15px;
}
.contact__input.-half {
  width: calc(50% - 14.8px);
}
.contact__input.-onethird {
  width: calc(33.333% - 18.36px);
}
.contact__input.-twothird {
  width: calc(66.6666% - 10px);
}
.contact__input.-confirm {
  display: flex;
  align-items: flex-start;
  margin-bottom: 0;
  border-bottom: 1px dashed #ABABAB;
}
.contact__err {
  width: 600px;
  margin: auto;
  padding: 50px;
}
.contact .error_messe {
  margin-bottom: 1em;
  color: #F00;
}
.contact__label {
  font-size: 16px;
  font-weight: 500;
  display: flex;
  align-items: center;
  height: 23px;
  margin-bottom: 10px;
}
.contact__label--check {
  height: 25px;
  cursor: pointer;
}
.contact__label--check a {
  text-decoration: underline !important;
  color: #1896C8 !important;
}
.contact__label.-confirm {
  padding: 15px;
  width: 275px;
  font-weight: bold;
  font-size: 17px;
  line-height: 1.5;
  margin: 5px 0;
  height: auto;
}
.contact__text {
  font-size: 16px;
  display: block;
  width: 100%;
  padding: 6px 9px;
  border: none;
  border-radius: 0;
  background: #D4D4D4;
  -webkit-appearance: none;
}
.contact__val {
  margin: 5px 0;
  padding: 15px;
  flex-grow: 1;
  font-size: 17px;
  line-height: 1.5;
  letter-spacing: 0.85px;
}
.contact__area {
  font-size: 16px;
  display: block;
  width: 100%;
  height: 157px;
  margin-bottom: 20px;
  padding: 9px;
  border: none;
  border-radius: 0;
  background: #D4D4D4;
  -webkit-appearance: none;
}
.contact__require {
  font-size: 14px;
  display: inline-block;
  display: inline-flex;
  align-items: center;
  height: 23px;
  margin-left: 17px;
  padding: 0 0.5em;
  color: #FFF;
  background: #1896C8;
}
.contact__privacy {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 10px;
  margin-top: 30px;
}
.contact__check {
  display: none;
}
.contact__check + label:before {
  display: block;
  width: 25px;
  height: 25px;
  margin-right: 10px;
  content: "";
  transform: translate3d(0, 2px, 0);
  background: #D4D4D4;
}
.contact__check:checked + label:before {
  background: #1896C8;
}
.contact__action {
  display: flex;
  justify-content: center;
}
.contact__action--confirm {
  margin-top: 50px;
}
.contact__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 10px;
  cursor: pointer;
  -webkit-appearance: none;
  width: 353.2px;
  height: 81.1px;
  box-shadow: 1px 1px 3px 0 rgba(0, 0, 0, 0.2);
  border: solid 1px #000;
  background-color: #FFF;
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 1.1px;
  text-align: center;
  color: #000;
}
.contact__btn--back {
  background: #DBDBDB;
}
.contact__btn[disabled=disabled] {
  background: #D4D4D4;
  border: none;
  color: #FFF;
  box-shadow: none;
}
.contact__input-group {
  display: flex;
  align-items: center;
  margin-bottom: 15px;
}
.contact__input-group.-first-row {
  width: 256.7px;
}
.contact__input-group.-second-row {
  width: 290.7px;
}
.contact__input-group.-third-row {
  width: 133.96px;
}
.contact__input-group.-fourth-row {
  width: 239.7px;
}
.contact__input-group.-sonota {
  width: 400px;
}
.contact__input-group .contact__label {
  margin-bottom: 0;
}
.contact__input-group.-sonota .contact__label {
  margin-right: 20px;
  white-space: nowrap;
}
.contact__description {
  font-size: 18px;
  line-height: 1.94;
  text-align: center;
  margin-bottom: 50px;
}

@media screen and (max-width: 765px) {
  .mv-contact {
    background: url("../img/contact_mv_sp.png") no-repeat center/cover;
  }
}
@media screen and (max-width: 1155px) {
  .contact {
    padding-top: 57.7px;
  }
}
@media screen and (max-width: 1050px) {
  .contact #gs-breadcrumb {
    padding-bottom: 34px;
  }
  .contact__tabs {
    width: 100%;
    margin-bottom: 32.2px;
    display: flex;
    justify-content: center;
  }
  .contact__tabs button {
    display: block;
    width: 50%;
    height: 62.5px;
    line-height: 62.5px;
    font-size: 17px;
    font-weight: normal;
    letter-spacing: 1.7px;
  }
  .contact__tabs button:first-child {
    margin-right: 0;
  }
  .contact__wrap {
    display: block;
    width: 100%;
    margin: auto;
    padding-left: 20px;
    padding-right: 20px;
  }
  .contact__group {
    display: block;
  }
  .contact__text {
    width: 100%;
  }
  .contact__input.-half {
    width: 100%;
  }
  .contact__input.-onethird {
    width: 100%;
  }
  .contact__input.-twothird {
    width: 100%;
  }
  .contact__input-group.-first-row {
    width: 100%;
  }
  .contact__input-group.-second-row {
    width: 100%;
  }
  .contact__input-group.-third-row {
    width: 100%;
  }
  .contact__input-group.-fourth-row {
    width: 100%;
  }
  .contact__input-group.-sonota {
    width: 100%;
  }
}
@media screen and (max-width: 765px) {
  .contact {
    padding-bottom: 60px;
  }
  .contact #gs-breadcrumb {
    padding-bottom: 34px;
  }
  .contact.-confirm {
    padding-top: 40px;
  }
  .contact .ttl-line {
    margin-bottom: 10px;
    padding-bottom: 10px;
  }
  .contact__ttl {
    font-size: 20px;
    line-height: 1.3;
    letter-spacing: 2px;
    margin-bottom: 18px;
  }
  .contact__subttl {
    font-size: 13px;
    font-weight: 500;
    line-height: 1.54;
    letter-spacing: 2.08px;
    margin-bottom: 22px;
  }
  .contact__wrap {
    width: 100%;
  }
  .contact__wrap.-confirm {
    margin-top: 40px;
  }
  .contact__err {
    width: 100%;
    margin: auto;
    padding: 50px 0;
  }
  .contact .error_messe {
    text-align: center;
  }
  .contact__input.-confirm {
    display: block;
    border-top: 1px dashed #ABABAB;
    border-bottom: none;
    width: 100%;
    box-sizing: border-box;
  }
  .contact__label {
    font-size: 12px;
    line-height: 1.2;
    height: 24px;
    margin-bottom: 6px;
  }
  .contact__label.-confirm {
    padding: 15px 10px 10px 0;
    font-size: 12px;
    margin: 0;
  }
  .contact__val {
    padding: 0 10px 15px 13px;
    font-size: 12px;
    margin: 0;
  }
  .contact__label--check {
    height: 24px;
    cursor: pointer;
  }
  .contact__text {
    font-size: 16px;
    box-sizing: border-box;
    width: 100%;
    padding: 9px;
  }
  .contact__area {
    font-size: 16px;
    box-sizing: border-box;
    height: 128px;
    margin-bottom: 30px;
    padding: 9px;
  }
  .contact__require {
    font-size: 10.5px;
    height: 24px;
    margin-left: 10px;
    padding: 0 0.5em;
  }
  .contact__privacy {
    margin-bottom: 40px;
    margin-top: 10px;
  }
  .contact__check + label:before {
    width: 12.5px;
    height: 12.5px;
    margin-right: 5px;
    transform: translate3d(0, 0, 0);
  }
  .contact__action--confirm {
    margin-top: 30px;
    display: block;
    text-align: center;
  }
  .contact__btn {
    font-size: 17px;
    width: 232.5px;
    height: 62.5px;
    font-weight: 500;
  }
  .contact__btn.-confirm {
    display: inline-block;
    margin-bottom: 14.5px;
  }
  .contact__input-group {
    margin-bottom: 12px;
  }
  .contact__input-group:first-of-type {
    margin-top: 15px;
  }
  .contact__input-group.-sonota .contact__label {
    margin-right: 10px;
  }
  .contact__description {
    font-size: 13px;
  }
}
.manga-fv {
  height: 432.8px;
  background: url("../img/manga-fv-bg.png") no-repeat center/100% 432.8px;
  position: relative;
}
@media screen and (max-width: 765px), print {
  .manga-fv {
    background-color: #FFF;
    height: auto;
  }
}
.manga-fv img {
  width: 1187px;
  position: absolute;
  bottom: 7px;
  left: 50%;
  transform: translateX(-50%);
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .manga-fv img {
    width: 100%;
    position: static;
    transform: none;
  }
}

.manga-main {
  padding-top: 48px;
  padding-bottom: 86px;
  background: rgb(204, 236, 236);
  background: linear-gradient(0deg, rgb(204, 236, 236) 0%, rgb(255, 255, 255) 60%, rgb(255, 255, 229) 100%);
}
@media screen and (max-width: 765px), print {
  .manga-main {
    padding-top: 20.5px;
    padding-bottom: 81px;
    background: linear-gradient(0deg, rgb(204, 236, 236) 0%, rgb(255, 255, 255) 40%, rgb(255, 255, 255) 55%, rgb(255, 255, 229) 100%);
  }
}
.manga-main__inner {
  width: 734px;
  margin: 0 auto;
}
@media screen and (max-width: 765px), print {
  .manga-main__inner {
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
  }
}
.manga-main img {
  width: 100%;
  vertical-align: middle;
}
.manga-main__notes {
  display: none;
}
@media screen and (max-width: 765px), print {
  .manga-main__notes {
    display: block;
    font-size: 9.5px;
    line-height: 1.26;
    text-align: left;
    color: #000;
    padding: 10px 6%;
    background-color: #FFF;
  }
}

.manga-links {
  width: 674px;
  margin: 68.6px auto 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media screen and (max-width: 765px), print {
  .manga-links {
    margin-top: 26.4px;
    width: 100%;
    padding: 0 20px;
  }
}
.manga-links a {
  width: 330px;
  height: 66px;
  background-color: #1896C8;
  text-decoration: none;
  font-size: 21.2px;
  font-weight: 500;
  line-height: 66px;
  letter-spacing: 2.12px;
  text-align: center;
  margin-bottom: 16px;
}
@media screen and (max-width: 765px), print {
  .manga-links a {
    width: calc(50% - 3.75px);
    height: 31.5px;
    margin-bottom: 7.5px;
    line-height: 31.5px;
    font-size: 12px;
    letter-spacing: 1.2px;
  }
}
.manga-links a:link, .manga-links a:visited, .manga-links a:hover, .manga-links a:active {
  color: #FFF;
}

.ar {
  width: 940px;
  margin: 0 auto 50px auto;
  padding: 0;
}
.ar__ttl {
  text-align: center;
  color: #1896c8;
  font-weight: bold;
  font-size: 26px;
  margin-bottom: 1em;
}
.ar__desc {
  text-align: center;
  font-size: 16px;
  margin-bottom: 1.5em;
}
.ar__desc .is-sp {
  display: none;
}
.ar__launch {
  display: flex;
  align-items: center;
  border-radius: 5px;
  border: solid 1px #1896c8;
  padding: 0;
  overflow: hidden;
  height: 80px;
  margin-bottom: 23px;
}
.ar__launch-ttl {
  display: flex;
  justify-content: center;
  align-items: center;
  background: #1896c8;
  height: 80px;
  width: 237px;
  overflow: hidden;
}
.ar__launch-ttl h3 {
  font-weight: 600;
  color: #fff;
  font-size: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
}
.ar__launch-ttl img {
  width: 20px;
  display: inline-block;
  margin-right: 10px;
}
.ar__launch-body {
  font-size: 16px;
  line-height: 1.25;
  padding: 1em 2em;
  color: #1896c8;
}
.ar__launch-body.is-sp {
  display: none;
}
.ar__env {
  border: solid 1px #000;
  padding: 1em;
}
.ar__env-ttl {
  font-weight: 600;
  font-size: 16px;
  text-align: center;
  margin-bottom: 1em;
}
.ar__env-body {
  font-size: 15px;
  line-height: 1.6;
}
@media screen and (max-width: 765px), print {
  .ar {
    width: 86.84210526vw;
    margin: 0 auto 10vw auto;
  }
  .ar__ttl {
    font-size: 4vw;
  }
  .ar__desc {
    line-height: 1.6;
    font-size: 3.2vw;
  }
  .ar__desc .is-sp {
    display: inline;
  }
  .ar__launch {
    display: block;
    height: auto;
    margin-bottom: 10vw;
  }
  .ar__launch-ttl {
    height: 8.93333333vw;
    width: auto;
  }
  .ar__launch-ttl h3 {
    font-size: 4vw;
  }
  .ar__launch-ttl img {
    width: 2.66666667vw;
    margin-right: 1.33333333vw;
  }
  .ar__launch-body {
    line-height: 1.54166667;
    font-size: 3.2vw;
    padding: 1.245em 1em;
    text-align: center;
  }
  .ar__launch-body.is-sp {
    display: block;
  }
  .ar__launch-body.is-pc {
    display: none;
  }
  .ar__env-ttl {
    font-size: 3.2vw;
  }
  .ar__env-body {
    font-size: 3.2vw;
    line-height: 1.7;
  }
}

body.is-fixed {
  position: fixed;
  width: 100%;
}

.cp202206 img {
  width: 100%;
}

.cp202206 {
  position: fixed;
  z-index: 999;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(0, 0, 0, 0.85);
  transition: all 600ms cubic-bezier(0.04, 0.51, 0.155, 0.985);
}
.cp202206.is-close {
  opacity: 0;
  pointer-events: none;
}
.cp202206__bottom {
  position: absolute;
  pointer-events: none;
  left: 0;
  right: 0;
  bottom: 0;
  height: 150px;
  /* FF3.6-15 */
  background: -webkit-linear-gradient(top, rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 100%);
  /* Chrome10-25,Safari5.1-6 */
  z-index: 99999;
}
.cp202206__close {
  cursor: pointer;
  position: absolute;
  top: 0;
  right: 0;
  width: 66px;
  height: 66px;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 99999;
}
.cp202206__close span {
  position: absolute;
  top: calc(50% - 2.5px);
  left: 10px;
  width: 46px;
  height: 5px;
  background-color: #fff;
  transform-origin: center;
}
.cp202206__close span:first-child {
  transform: rotate(45deg);
}
.cp202206__close span:last-child {
  transform: rotate(-45deg);
}
.cp202206__container {
  width: 100%;
  margin: 0vh 0;
  height: 100vh;
  padding-top: 60px;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
}
.cp202206__content {
  padding-bottom: 150px;
}
@media screen and (max-width: 765px), print {
  .cp202206 {
    height: 100%;
  }
  .cp202206__bottom {
    height: 0vh;
  }
  .cp202206__close {
    width: 15.733333vw;
    height: 15.733333vw;
  }
  .cp202206__close span {
    top: calc(50% - 0.26666666vw);
    left: 2.53333316vw;
    width: 10.66666667vw;
    height: 0.53333333vw;
  }
  .cp202206__container {
    height: 100%;
    padding-top: 15.33333333vw;
  }
  .cp202206__content {
    padding-bottom: 5vh;
  }
}

.cp202206-video.is-play .cp202206-video__click-area {
  opacity: 0;
  pointer-events: none;
}

.cp202206-video {
  width: 918px;
  max-width: 90vw;
  margin: 0 auto 60px;
}
.cp202206-video__ttl {
  margin: 0 auto 20px auto;
}
.cp202206-video__wrap {
  position: relative;
}
.cp202206-video__click-area {
  position: relative;
  z-index: 2;
  margin: auto;
  width: 918px;
  max-width: 90vw;
  height: 515px;
  max-height: 50.4901962vw;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  cursor: pointer;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
}
.cp202206-video__click-area:hover .cp202206-video__btn {
  transform: scale(1.2);
}
.cp202206-video__video-wrap {
  position: absolute;
  left: 0;
  top: 0;
}
.cp202206-video__video {
  margin: auto;
  width: 918px;
  max-width: 90vw;
  height: 515px;
  max-height: 50.4901962vw;
}
.cp202206-video__poster {
  position: absolute;
  top: 0;
  left: 0;
  width: 918px;
  max-width: 90vw;
  height: 515px;
  max-height: 50.4901962vw;
  z-index: 1;
  pointer-events: none;
}
.cp202206-video__btn {
  position: relative;
  z-index: 2;
  display: block;
  width: 89.8958px;
  transition: all 0.3s ease-in-out;
  pointer-events: none;
}
@media screen and (max-width: 765px), print {
  .cp202206-video {
    width: 88vw;
    max-width: none;
    margin-bottom: 8vw;
  }
  .cp202206-video__ttl {
    width: 68.4vw;
  }
  .cp202206-video__wrap {
    position: relative;
  }
  .cp202206-video__click-area {
    width: 88vw;
    max-width: none;
    height: 49.46666667vw;
    max-height: none;
  }
  .cp202206-video__click-area:hover .cp202206-video__btn {
    transform: none;
  }
  .cp202206-video__video {
    margin: auto;
    width: 88vw;
    max-width: none;
    height: 49.46666667vw;
    max-height: none;
  }
  .cp202206-video__poster {
    margin: auto;
    width: 88vw;
    max-width: none;
    height: 49.46666667vw;
    max-height: none;
  }
  .cp202206-video__btn {
    width: 18.13333333vw;
  }
}

.cp202206-info {
  width: 931px;
  margin: auto;
  max-width: 90vw;
}
.cp202206-info__ttl {
  width: 427.3667px;
  max-width: 41.31364573vw;
  margin: 0 auto 30px;
}
.cp202206-info__body {
  position: relative;
  width: 100%;
  height: 408px;
  max-height: 39.441462vw;
}
.cp202206-info__txt {
  width: 671.6221px;
  max-width: 64.92587631vw;
  position: absolute;
  left: 3px;
  top: 0;
}
.cp202206-info__img {
  width: 952px;
  max-width: 92.0300751vw;
  position: absolute;
  right: 0;
  top: 0;
}
@media screen and (max-width: 765px), print {
  .cp202206-info {
    width: 88vw;
    max-width: none;
  }
  .cp202206-info__ttl {
    display: none;
  }
  .cp202206-info__body {
    position: relative;
    width: 100%;
    height: auto;
    max-height: none;
  }
  .cp202206-info__txt {
    width: 88vw;
    max-width: none;
    position: static;
    margin-bottom: 1.33333333vw;
  }
  .cp202206-info__img {
    width: 91vw;
    max-width: none;
    position: static;
    margin-left: -3vw;
  }
}

.hojo-mv {
  background: url(../img/hj-fv-bg.png) no-repeat center/cover;
  padding-top: 160px;
}
.hojo-mv__wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 1280px;
  margin: auto;
  height: 293px;
}
.hojo-mv__mv {
  width: 50%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
.hojo-mv__mv img {
  width: 452px;
  display: block;
}
.hojo-mv__ttl {
  box-sizing: border-box;
  width: 50%;
  padding-left: 172px;
}
.hojo-mv__ttl h1 {
  width: 160px;
  text-align: center;
  font-weight: bold;
  line-height: 1;
  font-size: 37px;
  letter-spacing: 0.1em;
}
.hojo-mv__ttl h1 span {
  letter-spacing: 0.13em;
  display: block;
  text-align: center;
  color: #1896c8;
  margin-bottom: 17px;
  font-size: 21px;
}
@media screen and (max-width: 765px) {
  .hojo-mv {
    background: url("../img/hj-fv-bg_sp.png") no-repeat center/cover;
    padding-top: 32.267vw;
  }
  .hojo-mv__wrap {
    min-width: 100vw;
    flex-direction: column;
    height: 61.363vw;
  }
  .hojo-mv__mv {
    width: 100vw;
    justify-content: center;
    margin-bottom: 2.93333333vw;
  }
  .hojo-mv__mv img {
    width: 72.93333333vw;
  }
  .hojo-mv__ttl {
    width: 100vw;
    padding-left: 0;
  }
  .hojo-mv__ttl h1 {
    width: auto;
    font-size: 4.93333333vw;
  }
  .hojo-mv__ttl h1 span {
    margin-bottom: 1vw;
    font-size: 2.8vw;
  }
}

.hojo-info__ttl {
  font-size: 28px;
}
@media screen and (max-width: 765px) {
  .hojo-info__ttl {
    font-size: 4vw;
  }
}

.hojo-info__name {
  font-size: 29px;
  color: #1896c8;
  display: inline-block;
  position: relative;
  margin: 0 3px;
  letter-spacing: 0.05em;
}
.hojo-info__name:after {
  content: "";
  display: block;
  position: absolute;
  left: 0;
  bottom: -1px;
  right: 0;
  height: 3px;
  background: #1896c8;
}
@media screen and (max-width: 765px) {
  .hojo-info__name {
    font-size: 4.26666667vw;
    margin: 0 0.1em;
    letter-spacing: 0;
  }
  .hojo-info__name:after {
    bottom: 0.5vw;
    height: 0.26666667vw;
  }
}

.hojo-info__kana {
  position: absolute;
  letter-spacing: 0;
  top: -10px;
  left: 0;
  right: 0;
  text-align: center;
  font-size: 13px;
}
@media screen and (max-width: 765px) {
  .hojo-info__kana {
    top: -2vw;
    font-size: 1.73333333vw;
  }
}

.hojo-nav {
  position: fixed;
  right: 0;
  bottom: 170px;
  box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.2);
}
.hojo-nav a {
  display: block;
  width: 106px;
  height: 85px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #7dcae2;
  border: solid 1px #fff;
  border-style: solid none solid solid;
}
.hojo-nav a:nth-child(1) img {
  width: 63.6372px;
  height: 63px;
}
.hojo-nav a:nth-child(2) img {
  width: 63.6372px;
  height: 63px;
}
.hojo-nav a:nth-child(3) img {
  width: 64.4131px;
  height: 64.936px;
}
.hojo-nav a:nth-child(4) {
  background: #149cc6;
}
.hojo-nav a:nth-child(4) img {
  width: 61.8267px;
  height: 62.0918px;
}
@media screen and (max-width: 765px) {
  .hojo-nav {
    right: 0;
    bottom: 0;
    right: 0;
    box-shadow: none;
    display: flex;
  }
  .hojo-nav a {
    width: 25vw;
    height: 22.4vw;
  }
  .hojo-nav a:nth-child(1) {
    border-style: solid solid solid none;
  }
  .hojo-nav a:nth-child(1) img {
    width: 16.96992vw;
    height: 16.40156vw;
  }
  .hojo-nav a:nth-child(2) {
    border-style: solid solid solid none;
  }
  .hojo-nav a:nth-child(2) img {
    width: 16.96992vw;
    height: 16.33984vw;
  }
  .hojo-nav a:nth-child(3) {
    border-style: solid solid solid none;
  }
  .hojo-nav a:nth-child(3) img {
    width: 17.17682667vw;
    height: 16.67632vw;
  }
  .hojo-nav a:nth-child(4) {
    border-style: solid none solid none;
  }
  .hojo-nav a:nth-child(4) img {
    width: 15.85352vw;
    height: 16.02068vw;
  }
}
