@charset "UTF-8";
:root {
  --distance-from-top: 0;
  --threshold-from-top: 400;
}

* {
  font-family: "OptimaLTStd", "Optima", "Yu Gothic", YuGothic, "Hiragino Kaku Gothic Pro", Meiryo, Osaka, "MS PGothic", serif;
  font-weight: 400;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-touch-callout: none;
  margin: 0;
  padding: 0;
  --base-width: min(1200px, 90vw);
  --half-width: min(900px, 85vw);
  --middle-width: min(750px, 82.5vw);
  --short-width: min(600px, 80vw);
  --very-short-width: min(500px, 80vw);
}

html, body {
  padding: 0;
  margin: 0;
  border: 0;
  overflow-x: hidden;
}

html {
  font-size: max(7pt + 1vw, 18px);
  color: rgba(0, 0, 0, 0.8);
}

html:focus-within {
  scroll-behavior: smooth;
}

.showUpObject {
  opacity: 0;
  transition: opacity 1600ms cubic-bezier(0.2, 0.2, 0.25, 1);
}

.showUpObject.screened {
  opacity: 1;
}

.hidden {
  display: none;
}

footer {
  width: min(90vw, 1080px);
  margin-left: auto;
  margin-right: auto;
}

footer > div:first-child {
  width: 100%;
  margin-top: 2rem;
  border-top: 1px rgba(0, 0, 0, 0.4) solid;
  padding-top: 2rem;
  display: flex;
  justify-content: flex-start;
}

footer > div:first-child > * {
  width: 20%;
  margin-right: 3%;
}

footer > div:first-child > *:first-child {
  margin-right: 6%;
}

footer > div:first-child > div {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  align-items: center;
}

footer > div:first-child > div > a > img {
  width: 1.5rem;
  margin-right: 0.8rem;
}

footer > div:first-child > div > img:first-child {
  width: 75%;
  margin-right: 25%;
  margin-bottom: 1rem;
}

footer > div:first-child > dl > dt {
  font-weight: bold;
  margin-bottom: 0.5rem;
}

footer > div:first-child > dl > dd {
  margin-bottom: 0.3rem;
}

footer > div:first-child > dl > dd > a {
  font-style: normal;
  text-decoration: none;
  color: rgba(0, 0, 0, 0.5);
}

footer > div:nth-child(2) {
  width: 100%;
  text-align: right;
  font-size: 0.9rem;
  margin-top: 2rem;
  margin-bottom: 1rem;
}

.hideandseek {
  max-height: 7.5rem;
  position: relative;
  overflow-y: hidden;
  transition: max-height 1000ms ease;
}

.hideandseek.shown {
  max-height: none;
  padding-bottom: 2rem;
}

.hideandseek::after {
  content: "▼";
  text-align: center;
  width: 100%;
  height: 1rem;
  padding-top: 1.75rem;
  padding-bottom: 0.25rem;
  background-image: linear-gradient(transparent, white);
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  cursor: pointer;
}

.hideandseek.shown::after {
  content: "▲";
  background-image: none;
}

.other-contents {
  width: 100vw;
  height: 25vw;
  --swiper-pagination-bottom: -5px;
  margin-bottom: 1.2rem;
}
.other-contents + a {
  display: block;
  text-align: center;
  background-color: orange;
  padding: 0.5rem 1rem;
  border-radius: 1rem;
  color: white;
  font-weight: bold;
  font-size: 1.1rem;
  margin: 0 auto;
  width: 10rem;
  text-decoration: none;
}

.other-contents > ul {
  width: 100vw;
  height: 22.2vw;
  list-style: none;
}

.other-contents > ul > li {
  position: relative;
}

.other-contents > ul > li > a > img {
  width: 33.3vw;
  height: 22.2vw;
}

.other-contents > ul > li > a > div {
  position: absolute;
  color: white;
  font-size: 1.2rem;
  font-weight: bold;
  bottom: 1.5rem;
  left: 1rem;
  width: calc(100% - 2rem);
}

a.service-logo {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 150px;
  left: 3vw;
  top: 3%;
  position: fixed;
}
a.service-logo > img:first-child {
  width: 28%;
}
a.service-logo > img:nth-child(2) {
  width: 62%;
  opacity: calc(1 - clamp(0, var(--distance-from-top) / var(--threshold-from-top), 1));
  transition: opacity 0.8s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

#contact-always {
  position: fixed;
  right: 0;
  top: 50vw;
  transform: rotate(90deg);
  transform-origin: top right;
  padding: 0.2rem 1rem;
  background-color: rgba(255, 157, 0, 0.8);
  border-radius: 0 0 0.5rem 0.5rem;
}

#contact-always > a {
  text-decoration: none;
  color: white;
}

/* legacy */
.view_productsList > dl > dt {
  font-size: calc(5pt + 1vw);
  line-height: calc(5pt + 1vw);
  margin-bottom: 2vw;
}
.view_productsList > dl > dd > ul {
  list-style: none;
}
.view_productsList > dl > dd > ul > li {
  font-size: calc(5pt + 1vw);
  line-height: calc(5pt + 1vw);
  margin-bottom: 2vw;
  color: #A5A5A5;
  margin-left: calc(10px + 0.5vw);
}
.view_productsList > dl > dd > ul > li.displaying {
  color: #515151;
  border-bottom: 1px solid #515151;
  position: relative;
}
.view_productsList > dl > dd > ul > li.displaying:before {
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: calc(3px + 0.2vw) 0 calc(3px + 0.2vw) calc(5.2px + 0.3vw);
  border-color: transparent transparent transparent #515151;
  position: absolute;
  left: calc(-10px - 0.5vw);
  top: calc(1.5px + 0.3vw);
}
.view_productsList > dl > dd > ul > li > a {
  font-size: calc(4pt + 0.8vw);
  text-decoration: none;
  color: inherit;
}

.view_process {
  list-style: none;
}
.view_process > li {
  margin: 4vw 0;
}
.view_process > li > h5 {
  font-size: calc(7pt + 1.4vw);
  font-weight: bold;
  display: inline-block;
  color: #0088FF;
  margin-bottom: 1vw;
}
.view_process > li > div {
  display: flex;
  justify-content: space-between;
}
.view_process > li > div > p {
  font-size: calc(5.5pt + 1.1vw);
  width: 40%;
  margin: 0 10% 0 0;
  white-space: pre-wrap;
}
.view_process > li > div > div {
  width: 50%;
}
.view_process > li > div > div > img {
  width: 100%;
}
.view_process > li > div > div > div {
  width: 100%;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-wrap: wrap;
}
.view_process > li > div > div > div > img {
  width: 18%;
  height: 18%;
  margin-right: 2.5%;
  -o-object-fit: contain;
     object-fit: contain;
}

.coworkingPictures > div:first-child {
  position: relative;
  /* WIDTH 90vw or 1200px => calc(90% - 100px) => 60% */
  width: calc(48.6vw - 60px);
  max-width: 588px;
  /* HEIGHT WIDTH * 3/4 */
  height: calc(36.45vw - 45px);
  max-height: 441px;
  margin: 2vw auto 0 auto;
  -o-object-fit: contain;
     object-fit: contain;
}
.coworkingPictures > div:first-child .slick-slide {
  -o-object-fit: contain;
     object-fit: contain;
}
.coworkingPictures > div:nth-child(2) {
  height: 10vw;
  margin: 2vw 8vw;
}
.coworkingPictures > div:nth-child(2) .slick-slide {
  margin: 0 1vw;
}
.coworkingPictures > div:nth-child(2) img:not(.slick-center) {
  opacity: 0.4;
  -webkit-backdrop-filter: contrast(0.5);
          backdrop-filter: contrast(0.5);
}
.coworkingPictures .slick-list, .coworkingPictures .slick-track {
  height: 100%;
}
.coworkingPictures .slick-prev:before, .coworkingPictures .slick-next:before {
  color: black;
}

@media screen and (max-width: 768px) {
  footer > div:first-child {
    flex-wrap: wrap;
  }
  footer > div:first-child > * {
    width: 100%;
    margin: 1rem 0;
    text-align: center;
  }
  footer > div:first-child > div {
    margin-right: 0;
  }
  footer > div:first-child > *:first-child {
    justify-content: center;
  }
  footer > div:first-child > div > img:first-child {
    width: 10rem;
    height: auto;
    margin: 2.5rem calc(50% - 5rem);
  }
  footer > div:first-child > div > a > img {
    height: 2.2rem;
    width: auto;
    margin-left: 0.8rem;
    margin-bottom: 2.5rem;
  }
  footer > div:first-child > dl > dt {
    font-size: 1.8rem;
  }
  footer > div:first-child > dl > dd {
    margin-bottom: 0.5rem;
  }
  footer > div:first-child > dl > dd > a {
    margin-bottom: 1.3rem;
  }
  footer > div:nth-child(2) {
    text-align: center;
  }
  .other-contents {
    height: 70vw;
  }
  .other-contents > ul {
    height: 66vw;
  }
  .other-contents > ul > li > a > img {
    width: 100vw;
    height: 66vw;
  }
  .view_process > li > h5 {
    font-size: calc(9pt + 1.8vw);
  }
  .view_process > li > div {
    flex-wrap: wrap;
  }
  .view_process > li > div > div {
    width: 100%;
    margin-top: 3%;
  }
  .view_process > li > div > p {
    width: 100%;
    font-size: calc(7pt + 1.4vw);
  }
  .coworkingPictures {
    margin-top: 10vw;
    margin-bottom: 10vw;
  }
  .coworkingPictures > div:first-child {
    width: 90vw;
    height: 67.5vw;
  }
}/*# sourceMappingURL=common.css.map */