@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Funnel+Display:wght@300..800&family=Noto+Sans+JP:wght@100..900&display=swap");
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 {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

body {
  line-height: 1;
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

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

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title],
dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

input,
select {
  vertical-align: middle;
}

.screen-reader-text {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}

.alignleft {
  float: left;
  margin-right: 1rem;
  margin-bottom: 0.5rem;
}

.alignright {
  float: right;
  margin-left: 1rem;
  margin-bottom: 0.5rem;
}

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1rem;
}

.alignwide {
  max-width: calc(1200px + 3rem);
  margin-left: auto;
  margin-right: auto;
}

.alignfull {
  max-width: 100%;
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
  width: 100vw;
}

html {
  font-size: 1px;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  html {
    font-size: 0.78125vw;
  }
}
@media screen and (max-width: 768px) {
  html {
    font-size: 2.6666666667vw;
  }
}

body {
  overflow-x: hidden;
}

.h_f {
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: normal;
  letter-spacing: 0.05em;
  font-style: normal;
}

.h_r {
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 400;
  letter-spacing: 0.05em;
  font-style: normal;
}

.h_m {
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
  font-style: normal;
}

.h_b {
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 700;
  letter-spacing: 0.05em;
  font-style: normal;
}

* {
  box-sizing: border-box;
}

@media screen and (min-width: 769px) {
  .sp {
    display: none !important;
  }
}
@media screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
}
.main-container {
  width: 120rem;
  margin: 0;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .main-container {
    width: 33.7rem;
  }
}

.noto,
.font-ja {
  font-family: "Noto Sans JP", sans-serif;
}

.funnel,
.font-en {
  font-family: "Funnel Display", sans-serif;
}

a {
  text-decoration: none;
  color: inherit;
}

body {
  color: #000;
}

.bl {
  border-bottom: solid 1px #000;
}

.obs_dark {
  opacity: 0;
}

.loaded2 .obs_dark[data-observer=true] {
  transition: opacity 500ms cubic-bezier(0.825, 0.06, 0.015, 0.94); /* custom */
  transition-delay: 0ms;
  filter: none;
  opacity: 1;
}

body:not(.loaded3) .main-container div:nth-child(1) {
  transition-delay: 0ms;
}
body:not(.loaded3) .main-container div:nth-child(2) {
  transition-delay: 100ms;
}
body:not(.loaded3) .main-container div:nth-child(3) {
  transition-delay: 200ms;
}
body:not(.loaded3) .main-container div:nth-child(4) {
  transition-delay: 300ms;
}
body:not(.loaded3) .main-container div:nth-child(5) {
  transition-delay: 400ms;
}
body:not(.loaded3) .main-container div:nth-child(6) {
  transition-delay: 500ms;
}
body:not(.loaded3) .main-container div:nth-child(7) {
  transition-delay: 600ms;
}
body:not(.loaded3) .main-container div:nth-child(8) {
  transition-delay: 700ms;
}
body:not(.loaded3) .main-container div:nth-child(9) {
  transition-delay: 800ms;
}
body:not(.loaded3) .main-container div:nth-child(10) {
  transition-delay: 900ms;
}

.loader {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  z-index: 9999;
}
.loader__logo {
  width: 20rem;
  height: auto;
  opacity: 0;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px) {
  .loader__logo {
    width: 16rem;
  }
}

.loaded .loader__logo {
  transition: opacity 500ms cubic-bezier(0.825, 0.06, 0.015, 0.94); /* custom */
  opacity: 1;
}

.loaded1 .loader__logo {
  opacity: 0;
}

.loaded2 .loader {
  transition: opacity 1000ms cubic-bezier(0.825, 0.06, 0.015, 0.94); /* custom */
  opacity: 0;
  pointer-events: none;
}

body {
  background-color: #ccc;
}

.menu__button {
  width: 8rem;
  height: 8rem;
  background-color: #000;
  border: solid 1px #000;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 100;
  cursor: pointer;
  transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1); /* easeOutExpo */
}
@media screen and (max-width: 768px) {
  .menu__button {
    width: 3.8rem;
    height: 3.8rem;
  }
}
@media (hover: hover) and (pointer: fine) {
  .menu__button:hover .menu__button__inner {
    opacity: 0.8;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .menu__button:hover .menu__button__inner {
    opacity: 0.8;
  }
}
.menu__button__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform-origin: center;
  transform: translate(-50%, -50%);
  width: 3.3rem;
  height: 4rem;
  transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1); /* easeOutExpo */
}
@media screen and (max-width: 768px) {
  .menu__button__inner {
    transform: translate(-50%, -50%) scale(0.45);
  }
}
.menu__button__line {
  width: 100%;
  height: 0.45rem;
  background-color: #fff;
  position: absolute;
  left: 0;
  top: 50%;
  transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1); /* easeOutExpo */
  border-radius: 0.45rem;
}
.menu__button__line:nth-child(1) {
  transform: translateY(calc(-50% - 1rem));
  border-bottom-left-radius: 0;
  border-bottom-right-radius: 0;
}
.menu__button__line:nth-child(2) {
  transform: translateY(-50%);
  border-radius: 0;
}
.menu__button__line:nth-child(3) {
  transform: translateY(calc(-50% + 1rem));
  border-top-left-radius: 0;
  border-top-right-radius: 0;
}

.container {
  font-size: 10px;
}

.headpad {
  height: 8rem;
}
@media screen and (max-width: 768px) {
  .headpad {
    height: 3.8rem;
  }
}

.right-line {
  width: 8rem;
  height: 100%;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 40;
  background-color: #fff;
  border-left: solid 1px #000;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  .right-line {
    width: 3.8rem;
  }
}
.right-line__inner {
  width: 100%;
  height: calc(100% + 100rem);
  background-size: auto 50rem;
  background-position: center top;
  background-repeat: repeat-y;
  opacity: 0.1;
  animation: right-line-animation 10s linear infinite;
}
@media screen and (max-width: 768px) {
  .right-line__inner {
    background-size: auto 25rem;
    animation: right-line-animation-sp 10s linear infinite;
  }
}

@keyframes right-line-animation {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-50rem);
  }
}
@keyframes right-line-animation-sp {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-25rem);
  }
}
/* header_menu */
.header_menu {
  width: calc(100% - 8rem);
  height: 8rem;
  border-bottom: solid 1px #000;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 300;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  .header_menu {
    width: calc(100% - 3.8rem);
    height: 3.8rem;
  }
}
.header_menu__logo {
  width: 24rem;
  height: 100%;
  display: block;
  margin: 0 auto;
  position: absolute;
  top: 0;
  left: 0;
  border-right: solid 1px #000;
  z-index: 300;
}
@media (hover: hover) and (pointer: fine) {
  .header_menu__logo:hover {
    opacity: 0.6;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .header_menu__logo:hover {
    opacity: 0.6;
  }
}
@media screen and (max-width: 768px) {
  .header_menu__logo {
    width: 11.4rem;
    height: 3.8rem;
  }
}
.header_menu__logo img {
  width: 70%;
  height: auto;
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.header_menu__nav {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  padding-right: 2rem;
}
@media screen and (max-width: 768px) {
  .header_menu__nav {
    justify-content: space-between;
    padding-right: 0;
    padding: 0 2rem;
  }
}
.header_menu__nav__item {
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 400;
  letter-spacing: 0.05em;
  font-style: normal;
  font-size: 2rem;
  color: #000;
  text-decoration: none;
  padding: 0 2rem;
}
@media screen and (max-width: 768px) {
  .header_menu__nav__item {
    font-size: 1rem;
    padding: 0;
  }
}
@media (hover: hover) and (pointer: fine) {
  .header_menu__nav__item:hover {
    opacity: 0.6;
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .header_menu__nav__item:hover {
    opacity: 0.6;
  }
}

.header_menu {
  transform: translateY(-100%);
  transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1); /* easeOutExpo */
}

.menu_open .header_menu {
  transform: translateY(0);
}
.menu_open .menu__button__line {
  transform: translateY(-50%) !important;
}

@media screen and (min-width: 769px) {
  body:not(.scrolled) .header_menu {
    transform: translateY(0);
  }
  body:not(.scrolled) .menu__button {
    pointer-events: none;
  }
  body:not(.scrolled) .menu__button__inner {
    opacity: 0;
  }
}
/* entry_button */
.entry_button {
  position: fixed;
  bottom: 2rem;
  right: 2rem;
  z-index: 1500;
  width: 18rem;
  transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1); /* easeOutExpo */
  transform-origin: center;
}
@media screen and (max-width: 768px) {
  .entry_button {
    width: 12rem;
    bottom: 1rem;
    right: 1rem;
  }
}
@media (hover: hover) and (pointer: fine) {
  .entry_button:hover {
    filter: brightness(1.3);
    transform: scale(1.05);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  .entry_button:hover {
    filter: brightness(1.3);
    transform: scale(1.05);
  }
}
.entry_button img {
  width: 100%;
  height: auto;
  display: block;
  transition: all 500ms cubic-bezier(0.19, 1, 0.22, 1); /* easeOutExpo */
  transform-origin: center;
  transform: scale(1.1);
  opacity: 0;
  transition-delay: 100ms;
}

.loaded .entry_button img {
  opacity: 1;
  transform: scale(1);
}

.is_entry .entry_button {
  opacity: 0;
  pointer-events: none;
}

.footer {
  background-color: #000;
  color: #fff;
  padding: 3rem 4rem;
  position: relative;
  z-index: 1210;
}
@media screen and (max-width: 768px) {
  .footer {
    padding: 2rem 2rem 4rem;
  }
}
.footer__inner {
  position: relative;
}
.footer__logo {
  width: auto;
  height: 10rem;
  display: block;
}
@media screen and (max-width: 768px) {
  .footer__logo {
    height: auto;
    width: 100%;
  }
}
.footer__text {
  font-size: 1.2rem;
  line-height: 1.4;
  text-align: center;
  margin-top: 2rem;
  position: absolute;
  right: 2rem;
  bottom: 2rem;
  position: absolute;
  right: 0;
  bottom: 0;
}
@media screen and (max-width: 768px) {
  .footer__text {
    font-family: "helvetica-neue-lt-pro", sans-serif;
    font-weight: 400;
    letter-spacing: 0.05em;
    font-style: normal;
    font-size: 0.9rem;
    bottom: -2rem;
    right: auto;
    left: 0;
  }
}

[temp="index.php"] {
  /*concept*/
  /*partner*/
  /* map */
}
[temp="index.php"] .kv {
  width: 120rem;
  height: 60rem;
  background-color: #efefef;
  position: relative;
  overflow: hidden;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .kv {
    width: calc(100vw - 3.8rem);
    height: calc(200vw - 7.6rem);
    transform-origin: center bottom;
    transform: scale(1.2);
  }
}
[temp="index.php"] .kv__canvas {
  opacity: 0.7;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  z-index: 2;
  width: 104.1666666667%;
  height: 108.3333333333%;
  transform: translate(-2.0833333333%, -4.1666666667%);
  transform-origin: center bottom;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .kv__canvas {
    width: 108.3333333333%;
    height: 104.1666666667%;
    transform: translate(-3.8461538462%, -2%);
    transform-origin: center bottom;
  }
}
[temp="index.php"] .kv__cover {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  z-index: 10;
  pointer-events: none;
}
[temp="index.php"] .kv__cover__1 {
  z-index: 1;
}
[temp="index.php"] .kv__cover__2 {
  z-index: 3;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .kv__cover {
    height: calc(100vw - 3.8rem);
    width: calc(200vw - 7.6rem);
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(90deg);
  }
}
[temp="index.php"] .kv__wrapper {
  width: 120rem;
  height: 60rem;
  background-color: #d9d9d9;
  position: relative;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .kv__wrapper {
    width: calc(100vw - 3.8rem);
    height: calc(200vw - 7.6rem);
    height: calc(200vw - 31.16rem);
  }
}
[temp="index.php"] .kv__text {
  position: absolute;
  top: 50%;
  left: 5.2rem;
  width: 70rem;
  height: auto;
  transform: translateY(-50%);
  display: block;
  z-index: 10;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .kv__text {
    left: 50%;
    width: calc(100% - 4rem);
    transform: translate(-50%, 0);
    top: 1.7rem;
  }
}
[temp="index.php"] .concept {
  background: #fff;
  position: relative;
  overflow: hidden;
}
[temp="index.php"] .concept__canvas {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  opacity: 1;
}
[temp="index.php"] .concept__text {
  position: relative;
  padding: 5.2rem;
  z-index: 10;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .concept__text {
    padding: 2rem;
  }
}
[temp="index.php"] .concept__text h2 {
  font-size: 1.8rem;
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
  font-style: normal;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .concept__text h2 {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
  }
}
[temp="index.php"] .concept__text h3 {
  font-size: 3.6rem;
  margin-bottom: 3.9rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .concept__text h3 {
    line-height: 1.4;
    font-size: 2.4rem;
    margin-bottom: 2rem;
  }
}
[temp="index.php"] .concept__text p {
  font-size: 1.8rem;
  line-height: 160%;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .concept__text p {
    font-size: 1.2rem;
  }
}
[temp="index.php"] .concept__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 101%;
  height: 100%;
  background-size: 81.7rem;
  background-repeat: no-repeat;
  background-position: center right;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .concept__bg {
    background-size: contain;
    background-position: center bottom;
    opacity: 0.5;
  }
}
[temp="index.php"] .partner {
  background: #fff;
  position: relative;
  display: flex;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner {
    flex-direction: column;
  }
}
[temp="index.php"] .partner__left {
  width: 40rem;
  height: 30rem;
  background-color: #000;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__left {
    width: 100%;
    height: auto;
    padding: 2rem;
  }
}
[temp="index.php"] .partner__left__texts {
  position: absolute;
  bottom: 4.1rem;
  left: 5.3rem;
  color: #fff;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__left__texts {
    position: relative;
    bottom: 0;
    left: 0;
  }
}
[temp="index.php"] .partner__left__texts h2 {
  font-size: 1.8rem;
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
  font-style: normal;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__left__texts h2 {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
  }
}
[temp="index.php"] .partner__left__texts h3 {
  font-size: 3.6rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__left__texts h3 {
    line-height: 1.4;
    font-size: 2.4rem;
  }
}
[temp="index.php"] .partner__right {
  width: calc(100% - 40rem);
  height: 30rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__right {
    width: 100%;
    height: auto;
    padding: 2rem;
  }
}
[temp="index.php"] .partner__right__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__right__inner {
    position: relative;
    top: 0;
    left: 0;
    transform: translate(0, 0);
  }
}
[temp="index.php"] .partner__right__inner__logo {
  display: block;
  margin: 0 auto;
  width: 30rem;
  height: auto;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__right__inner__logo {
    width: 15rem;
  }
}
[temp="index.php"] .partner__right__inner__lists {
  display: flex;
  flex-wrap: nowrap;
  gap: 1rem;
  margin-top: 3rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__right__inner__lists {
    flex-wrap: wrap;
    justify-content: center;
  }
}
[temp="index.php"] .partner__right__inner__lists a {
  display: block;
  width: 12rem;
  height: 6rem;
  overflow: hidden;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .partner__right__inner__lists a {
    width: 8rem;
    height: 4rem;
  }
}
[temp="index.php"] .partner__right__inner__lists a img {
  width: 100%;
  height: 100%;
  -o-object-fit: contain;
     object-fit: contain;
  display: block;
}
[temp="index.php"] .scroll_checker {
  position: absolute;
  top: calc(100vh + 200px);
  left: 0;
  width: 100px;
  height: 100px;
  pointer-events: none;
}
[temp="index.php"] .concept__white {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: linear-gradient(to right, #fff, rgba(255, 255, 255, 0));
}
[temp="index.php"] .x_loop {
  position: relative;
  height: 6.6rem;
  width: 100%;
  overflow: hidden;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .x_loop {
    height: 3.3rem;
  }
}
[temp="index.php"] .x_loop__inner {
  width: 100%;
  height: 100%;
  background-position: center left;
  background-repeat: repeat-x;
  position: absolute;
  top: 0;
  left: 0;
  width: calc(100% + 35rem);
  height: 100%;
}
[temp="index.php"] .x_loop__inner.loop_c {
  background-size: 35rem auto;
  animation: loop_c 10s linear infinite;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .x_loop__inner.loop_c {
    background-size: 17.5rem auto;
    animation: loop_c_sp 10s linear infinite;
  }
}
[temp="index.php"] .x_loop__inner.loop_a {
  background-size: 32rem auto;
  animation: loop_a 10s linear infinite;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .x_loop__inner.loop_a {
    background-size: 16rem auto;
    animation: loop_a_sp 10s linear infinite;
  }
}
[temp="index.php"] .x_loop__inner.loop_e {
  background-size: 28rem auto;
  animation: loop_e 10s linear infinite;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .x_loop__inner.loop_e {
    background-size: 14rem auto;
    animation: loop_e_sp 10s linear infinite;
  }
}
@keyframes loop_e {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-28rem);
  }
}
@keyframes loop_e_sp {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-14rem);
  }
}
@keyframes loop_c {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-35rem);
  }
}
@keyframes loop_c_sp {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-17.5rem);
  }
}
@keyframes loop_a {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-32rem);
  }
}
@keyframes loop_a_sp {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-16rem);
  }
}
[temp="index.php"] .map {
  position: relative;
}
[temp="index.php"] .map__bg {
  width: 100%;
  height: auto;
  display: block;
}
[temp="index.php"] .map__item {
  position: absolute;
}
@media (hover: hover) and (pointer: fine) {
  [temp="index.php"] .map__item:hover {
    filter: brightness(1.2);
  }
}
@media (-ms-high-contrast: none), (-ms-high-contrast: active) {
  [temp="index.php"] .map__item:hover {
    filter: brightness(1.2);
  }
}
[temp="index.php"] .map__item img {
  width: 100%;
  height: auto;
  display: block;
  pointer-events: none;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .map__item {
    width: 18.8rem;
    height: 3rem;
    overflow: visible;
  }
  [temp="index.php"] .map__item img {
    position: absolute;
    top: 0;
    left: 0;
  }
  [temp="index.php"] .map__item__2 {
    top: 2rem;
    left: 1.6rem;
  }
  [temp="index.php"] .map__item__3 {
    top: 5.9rem;
    right: 1.6rem;
  }
  [temp="index.php"] .map__item__1 {
    bottom: 5.9rem;
    left: 1.6rem;
  }
  [temp="index.php"] .map__item__1 img {
    top: auto;
    bottom: 0;
  }
  [temp="index.php"] .map__item__4 {
    bottom: 2rem;
    right: 1.6rem;
  }
  [temp="index.php"] .map__item__4 img {
    top: auto;
    bottom: 0;
  }
}
@media screen and (min-width: 769px) {
  [temp="index.php"] .map__item__2 {
    width: 38.65rem;
    top: 6.35rem;
    left: 10.05rem;
  }
  [temp="index.php"] .map__item__3 {
    width: 39.35rem;
    top: 6.35rem;
    right: 10.05rem;
  }
  [temp="index.php"] .map__item__1 {
    width: 41.1rem;
    bottom: 6.4rem;
    left: 10.1rem;
  }
  [temp="index.php"] .map__item__4 {
    width: 35.45rem;
    bottom: 6.4rem;
    right: 10.1rem;
  }
}
[temp="index.php"] .area {
  background: #aaa;
}
[temp="index.php"] .area__item {
  border: 1px solid #000;
  border-width: 1px 0;
  background: #000;
  color: #fff;
  position: relative;
}
@media screen and (min-width: 769px) {
  [temp="index.php"] .area__item + .area__item {
    margin-top: 1px;
  }
}
[temp="index.php"] .area__item-inner {
  position: relative;
  z-index: 2;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .area__item-inner {
    flex-direction: column;
    align-items: flex-start;
  }
}
[temp="index.php"] .area__item-img {
  width: 18rem;
  min-height: 18rem;
  height: 100%;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .area__item-img {
    width: 5rem;
    min-height: 5rem;
  }
}
[temp="index.php"] .area__item-img img {
  width: 18rem;
  height: 18rem;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  -o-object-fit: cover;
     object-fit: cover;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .area__item-img img {
    width: 5rem;
    height: 5rem;
  }
}
[temp="index.php"] .area__item-text {
  width: calc(100% - 18rem);
  padding: 3rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .area__item-text {
    width: 100%;
    padding: 2rem;
  }
}
[temp="index.php"] .area__item-title {
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 400;
  letter-spacing: 0.05em;
  font-style: normal;
  font-weight: normal;
  font-size: 2.5rem;
  line-height: 1;
  display: inline-block;
  color: #000;
  padding: 0.5rem 2rem;
  margin-bottom: 2.5rem;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  width: 36rem;
  text-align: center;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .area__item-title {
    width: calc(100% - 5rem);
    font-size: 1.7rem;
    padding: 0.2rem 1.6rem;
    margin-bottom: 1rem;
    position: absolute;
    top: 0;
    right: 0;
    height: 5rem;
    line-height: 4.6rem;
  }
}
[temp="index.php"] .area__item-desc {
  font-size: 1.6rem;
  font-weight: 500;
  line-height: 160%;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .area__item-desc {
    font-size: 1.2rem;
    line-height: 1.4;
  }
}
[temp="index.php"] .area__item-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center right;
  opacity: 0.6;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .area__item-bg {
    display: block;
    background-size: 100% auto;
    background-position: center bottom;
    opacity: 0.2;
  }
}
[temp="index.php"] .access__inner {
  display: flex;
  position: relative;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__inner {
    flex-direction: column;
  }
}
[temp="index.php"] .access__left {
  width: 56rem;
  padding: 8rem;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__left {
    width: 100%;
    padding: 2rem;
  }
}
[temp="index.php"] .access__left h2 {
  font-size: 1.8rem;
  font-family: "helvetica-neue-lt-pro", sans-serif;
  font-weight: 500;
  letter-spacing: 0.05em;
  font-style: normal;
  margin-bottom: 1rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__left h2 {
    font-size: 1.2rem;
    margin-bottom: 0.5rem;
  }
}
[temp="index.php"] .access__left h3 {
  font-size: 3.2rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__left h3 {
    font-size: 2.4rem;
  }
}
[temp="index.php"] .access__left h4 {
  margin-top: 5.4rem;
  font-size: 2.1rem;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__left h4 {
    margin-top: 3rem;
    font-size: 1.4rem;
  }
}
[temp="index.php"] .access__left p {
  font-size: 1.6rem;
  line-height: 1.6;
  margin-top: 1.9rem;
  font-weight: 500;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__left p {
    font-size: 1.2rem;
    margin-top: 1.4rem;
  }
}
[temp="index.php"] .access__right {
  width: calc(100% - 56rem);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__right {
    width: 100%;
    height: 30rem;
  }
}
[temp="index.php"] .access__map {
  width: 100%;
  height: 45rem;
  position: relative;
  filter: grayscale(100%);
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .access__map {
    height: 30rem;
  }
}
[temp="index.php"] .access__map iframe {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
[temp="index.php"] .form {
  padding: 8rem;
  background-color: #fff;
}
@media screen and (max-width: 768px) {
  [temp="index.php"] .form {
    padding: 2rem;
  }
}
/*# sourceMappingURL=main.css.map */
