@charset "UTF-8";
/* ======================================= *
 * Initialize
 * ======================================= */
/*---------- site color ----------*/
/*---------- size ----------*/
/*---------- mixin: break point ----------*/
/*---------- mixin: ignore 'hover' css style on touch devices ----------*/
/*---------- mixin: screen resolution ----------*/
/*---------- font ----------*/
/*---------- default settings ----------*/
html {
  font-size: 16px;
}

body {
  font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  letter-spacing: .05em;
  line-height: 1.5;
  word-break: normal;
}

a {
  color: #222;
  text-decoration: none;
}

* {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td, figure {
  margin: 0;
  padding: 0;
  font-size: 100%;
}

hr {
  height: 0;
}

button {
  border: none;
  cursor: pointer;
  outline: none;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  font-size: inherit;
}

:focus {
  outline: none;
}

@media screen and (max-width: 640px) {
  html {
    font-size: 16px;
  }
  img {
    max-width: 100%;
    height: auto;
  }
}

/* ======================================= *
 * Layout
 * ======================================= */
/*---------- display on PC or SmartPhone ----------*/
@media screen and (max-width: 640px) {
  .l-pc {
    display: none;
  }
}

.l-sp {
  display: none;
}

@media screen and (max-width: 640px) {
  .l-sp {
    display: block;
  }
  .l-sp.is-inline {
    display: inline;
  }
}

.l-content {
  display: block;
  width: 1280px;
  max-width: 100%;
  margin: 0 auto;
  padding: 0 20px;
}

@media screen and (max-width: 640px) {
  .l-content {
    padding: 0 15px;
  }
}

.l-content.is-max {
  width: 2200px;
}

.l-content.is-wide {
  width: 1600px;
}

.l-content.is-x-full {
  padding: 0;
}

.l-text-center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

/* ======================================= *
 * Project
 * ======================================= */
.p-link {
  color: #6695e0;
}

.p-link.is-invalid {
  cursor: not-allowed;
}

@media (hover: hover) {
  .p-link:hover {
    opacity: .8;
    -webkit-transition: .3s;
    transition: .3s;
  }
}

.p-rule {
  display: block;
  width: 100%;
  height: 1px;
  border: none;
  border-bottom: 1px solid #a7b0c0;
  margin: 10px 0;
}

.p-body {
  position: relative;
  min-width: 320px;
  margin: 0;
  padding: 0;
  color: #222;
  background: #45505d url(../img/common/background-noise-dark.png);
}

.p-main {
  background: #f9fbfc;
}

.p-main .p-main__gear {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 500px;
  overflow: hidden;
  opacity: .8;
  mix-blend-mode: multiply;
}

.p-main .p-main__gear .p-main__gear__position {
  position: absolute;
  top: -240px;
  right: -80px;
}

@media screen and (max-width: 640px) {
  .p-main .p-main__gear .p-main__gear__position {
    top: -140px;
    right: -120px;
    -webkit-transform: scale(0.9);
            transform: scale(0.9);
  }
}

.p-space-50 {
  height: .5em;
}

.p-top-space {
  height: 80px;
  background: #f9fbfc;
}

@media screen and (max-width: 840px) {
  .p-top-space {
    height: 60px;
  }
}

.p-top-button {
  position: fixed;
  z-index: 10;
  display: none;
  right: 30px;
  bottom: 30px;
}

@media screen and (max-width: 640px) {
  .p-top-button {
    right: 20px;
    bottom: 20px;
  }
}

.p-top-button .p-top-button__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  background: rgba(255, 255, 255, 0.85);
  width: 100px;
  height: 70px;
  padding: 5px 0 0;
  border-radius: 5px;
  color: #8899aa;
  border: 1px solid #8899aa;
  font-size: .7rem;
  font-weight: bold;
  -webkit-transition: .3s;
  transition: .3s;
  cursor: pointer;
}

@media screen and (max-width: 640px) {
  .p-top-button .p-top-button__content {
    width: 60px;
    height: 50px;
    padding: 7px 0 0;
    gap: 5px;
  }
}

@media (hover: hover) {
  .p-top-button .p-top-button__content:hover {
    color: #6a8095;
    border-color: #6a8095;
    background: #fff;
  }
  .p-top-button .p-top-button__content:hover::before {
    border-color: #6a8095;
    -webkit-transform: translateY(-3px) rotate(45deg);
            transform: translateY(-3px) rotate(45deg);
  }
}

@media screen and (hover: hover) and (max-width: 640px) {
  .p-top-button .p-top-button__content:hover::before {
    -webkit-transform: translateY(-2px) rotate(45deg);
            transform: translateY(-2px) rotate(45deg);
  }
}

.p-top-button .p-top-button__content::before {
  content: '';
  display: block;
  width: 10px;
  height: 10px;
  border-top: 1px solid #8899aa;
  border-left: 1px solid #8899aa;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 640px) {
  .p-top-button .p-top-button__content::before {
    width: 8px;
    height: 8px;
  }
}

.p-link-destionation {
  margin-top: -80px;
  padding-top: 80px;
  pointer-events: none;
}

@media screen and (max-width: 840px) {
  .p-link-destionation {
    margin-top: -60px;
    padding-top: 60px;
  }
}

.p-annotation {
  list-style: none;
}

.p-annotation .p-annotation__item {
  position: relative;
  padding-left: 1.5em;
  list-style: none;
  margin: 0 0 .3em;
}

.p-annotation .p-annotation__item::before {
  content: '※';
  display: inline;
  position: absolute;
  left: 0;
  top: 0;
}

.p-list.is-ordered {
  margin-left: 3.2em;
}

.p-list.is-ordered .p-list__item {
  list-style-type: none;
  counter-increment: cnt;
  position: relative;
}

.p-list.is-ordered .p-list__item::before {
  content: "（" counter(cnt) "）";
  display: inline;
  position: absolute;
  top: 0;
  left: 0;
  width: 3em;
  margin: 0 0 0 -3.2em;
  text-align: right;
}

.p-list .p-list__item {
  margin: 0 0 .3em;
}

.p-part-gear {
  position: relative;
  width: 600px;
  height: 600px;
}

@media screen and (max-width: 640px) {
  .p-part-gear {
    width: 350px;
    height: 350px;
  }
}

.p-part-gear.is-blue .p-part-gear__core,
.p-part-gear.is-blue .p-part-gear__circle::before,
.p-part-gear.is-blue .p-part-gear__circle::after, .p-part-gear.is-blue::before, .p-part-gear.is-blue::after {
  background-image: url(../img/mv/mv-gear.png);
}

.p-part-gear .p-part-gear__core,
.p-part-gear .p-part-gear__circle::before,
.p-part-gear .p-part-gear__circle::after, .p-part-gear::before, .p-part-gear::after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  width: 100%;
  height: 100%;
  margin: auto;
  background: url(../img/part/part-gear.png) left top/1200px 1200px no-repeat;
  opacity: .3;
  border-radius: 50%;
}

@media screen and (max-width: 640px) {
  .p-part-gear .p-part-gear__core,
  .p-part-gear .p-part-gear__circle::before,
  .p-part-gear .p-part-gear__circle::after, .p-part-gear::before, .p-part-gear::after {
    background-size: 700px 700px;
  }
}

.p-part-gear::before {
  background-position: right bottom;
  -webkit-animation: gear-rotate 24s linear infinite;
          animation: gear-rotate 24s linear infinite;
}

.p-part-gear::after {
  background-position: left bottom;
  -webkit-animation: gear-rotate 60s linear infinite;
          animation: gear-rotate 60s linear infinite;
}

.p-part-gear .p-part-gear__circle::before {
  background-position: right top;
  animation: gear-rotate 30s linear infinite reverse;
}

.p-part-gear .p-part-gear__circle::after {
  background-position: left top;
}

.p-part-gear .p-part-gear__core {
  width: 30%;
  height: 30%;
  background-position: center;
  -webkit-animation: gear-core 2s ease-in-out alternate infinite;
          animation: gear-core 2s ease-in-out alternate infinite;
}

@-webkit-keyframes gear-rotate {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@keyframes gear-rotate {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}

@-webkit-keyframes gear-core {
  0% {
    opacity: .45;
  }
  100% {
    opacity: .25;
  }
}

@keyframes gear-core {
  0% {
    opacity: .45;
  }
  100% {
    opacity: .25;
  }
}

.p-navi {
  -webkit-transition: .5s;
  transition: .5s;
}

@media screen and (max-width: 840px) {
  .p-navi {
    position: fixed;
    top: 0;
    right: 0;
    width: 100vw;
    height: 100vh;
    padding: 60px 0 0;
  }
  .p-navi::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.9);
  }
}

.p-navi .p-navi__list {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 32px;
  -webkit-transition: gap .5s;
  transition: gap .5s;
}

@media screen and (max-width: 840px) {
  .p-navi .p-navi__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 0;
    border-top: 1px solid rgba(69, 80, 93, 0.5);
  }
}

.p-navi .p-navi__list .p-navi__list__item {
  position: relative;
  display: block;
  list-style: none;
}

@media screen and (max-width: 840px) {
  .p-navi .p-navi__list .p-navi__list__item {
    width: 100%;
  }
}

.p-navi .p-navi__list .p-navi__list__item::after {
  content: '';
  display: block;
  position: absolute;
  top: auto;
  bottom: -13px;
  left: 0;
  right: 0;
  width: 7px;
  height: 7px;
  margin: 0 auto;
  border-radius: 50%;
  background: transparent;
  -webkit-transition: .3s;
  transition: .3s;
}

@media screen and (max-width: 840px) {
  .p-navi .p-navi__list .p-navi__list__item::after {
    top: 0;
    bottom: 0;
    left: 30px;
    right: auto;
    margin: auto 0;
  }
}

.p-navi .p-navi__list .p-navi__list__item.is-active::after {
  background: #6695e0;
}

.p-navi .p-navi__list .p-navi__list__item .p-navi__list__item__link {
  display: block;
}

@media (hover: hover) {
  .p-navi .p-navi__list .p-navi__list__item .p-navi__list__item__link:hover {
    opacity: .6;
    -webkit-transition: .3s;
    transition: .3s;
  }
}

@media screen and (hover: hover) and (max-width: 840px) {
  .p-navi .p-navi__list .p-navi__list__item .p-navi__list__item__link:hover {
    opacity: 1;
    background: rgba(69, 80, 93, 0.2);
  }
}

@media screen and (max-width: 840px) {
  .p-navi .p-navi__list .p-navi__list__item .p-navi__list__item__link {
    width: 100%;
    padding: 20px 0;
    border-bottom: 1px solid rgba(69, 80, 93, 0.5);
  }
}

.p-navi .p-navi__list .p-navi__list__item .p-navi__list__item__link .p-navi__list__item__link__image {
  display: block;
  width: auto;
  height: 20px;
  margin: 0 auto;
  -webkit-filter: brightness(0) invert(1);
          filter: brightness(0) invert(1);
  -webkit-transition: .5s;
  transition: .5s;
}

.p-navi.is-scrolled .p-navi__list, .p-navi.is-fixed .p-navi__list {
  gap: 25px;
}

@media screen and (max-width: 840px) {
  .p-navi.is-scrolled .p-navi__list, .p-navi.is-fixed .p-navi__list {
    gap: 0;
  }
}

.p-navi.is-scrolled .p-navi__list .p-navi__list__item .p-navi__list__item__link .p-navi__list__item__link__image, .p-navi.is-fixed .p-navi__list .p-navi__list__item .p-navi__list__item__link .p-navi__list__item__link__image {
  height: 18px;
  -webkit-filter: none;
          filter: none;
}

@media screen and (max-width: 840px) {
  .p-navi.is-scrolled .p-navi__list .p-navi__list__item .p-navi__list__item__link .p-navi__list__item__link__image, .p-navi.is-fixed .p-navi__list .p-navi__list__item .p-navi__list__item__link .p-navi__list__item__link__image {
    height: 20px;
    -webkit-filter: brightness(0) invert(1);
            filter: brightness(0) invert(1);
  }
}

.p-header {
  position: fixed;
  z-index: 50;
  top: 0;
  width: 100%;
  min-width: 320px;
  height: 120px;
  -webkit-transition: .5s;
  transition: .5s;
}

@media screen and (max-width: 840px) {
  .p-header {
    height: 90px;
  }
}

.p-header.is-scrolled, .p-header.is-fixed {
  -webkit-box-shadow: 0 1px 0 rgba(167, 176, 192, 0.5);
          box-shadow: 0 1px 0 rgba(167, 176, 192, 0.5);
  background: #fff;
  height: 80px;
}

@media screen and (max-width: 840px) {
  .p-header.is-scrolled, .p-header.is-fixed {
    height: 60px;
  }
}

.p-header.is-scrolled .p-header__content, .p-header.is-fixed .p-header__content {
  padding: 0 30px 0 20px;
}

@media screen and (max-width: 840px) {
  .p-header.is-scrolled .p-header__content, .p-header.is-fixed .p-header__content {
    padding: 0 10px;
  }
}

@media screen and (max-width: 840px) {
  .p-header.is-scrolled .p-header__content .p-header__content__title, .p-header.is-fixed .p-header__content .p-header__content__title {
    margin: 0;
  }
}

.p-header.is-scrolled .p-header__content .p-header__content__title::after, .p-header.is-fixed .p-header__content .p-header__content__title::after {
  opacity: 1;
}

.p-header.is-scrolled .p-header__content .p-header__content__title .p-header__content__title__image, .p-header.is-fixed .p-header__content .p-header__content__title .p-header__content__title__image {
  height: 50px;
}

@media screen and (max-width: 840px) {
  .p-header.is-scrolled .p-header__content .p-header__content__title .p-header__content__title__image, .p-header.is-fixed .p-header__content .p-header__content__title .p-header__content__title__image {
    height: 48px;
  }
}

@media screen and (max-width: 350px) {
  .p-header.is-scrolled .p-header__content .p-header__content__title .p-header__content__title__image, .p-header.is-fixed .p-header__content .p-header__content__title .p-header__content__title__image {
    height: 40px;
  }
}

.p-header.is-scrolled .p-header__content__kebab, .p-header.is-fixed .p-header__content__kebab {
  margin: 0 5px;
}

.p-header .p-header__content__kebab {
  display: none;
  position: absolute;
  z-index: 2;
  top: 0;
  right: 0;
  width: auto;
  height: 60px;
  margin: 15px 5px 0;
  aspect-ratio: 1;
  -webkit-transition: .5s;
  transition: .5s;
}

@media screen and (max-width: 840px) {
  .p-header .p-header__content__kebab {
    display: block;
  }
}

.p-header .p-header__content__kebab.is-open {
  margin: 0 5px;
}

.p-header .p-header__content__kebab.is-open + .p-navi {
  width: 100%;
}

.p-header .p-header__content__kebab.is-open .p-header__content__kebab__button::before {
  width: 30px;
  -webkit-transform: translateY(10px) rotate(135deg);
          transform: translateY(10px) rotate(135deg);
}

.p-header .p-header__content__kebab.is-open .p-header__content__kebab__button::after {
  width: 30px;
  -webkit-transform: translateY(-10px) rotate(-135deg);
          transform: translateY(-10px) rotate(-135deg);
}

.p-header .p-header__content__kebab.is-open .p-header__content__kebab__button .p-header__content__kebab__button__icon {
  opacity: 0;
}

@media screen and (max-width: 840px) {
  .p-header .p-header__content__kebab + .p-navi {
    width: 0;
  }
}

.p-header .p-header__content__kebab .p-header__content__kebab__button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 5px;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

@media (hover: hover) {
  .p-header .p-header__content__kebab .p-header__content__kebab__button:hover {
    opacity: .6;
    -webkit-transition: .5s;
    transition: .5s;
  }
}

.p-header .p-header__content__kebab .p-header__content__kebab__button::before, .p-header .p-header__content__kebab .p-header__content__kebab__button::after,
.p-header .p-header__content__kebab .p-header__content__kebab__button .p-header__content__kebab__button__icon {
  display: block;
  width: 5px;
  height: 5px;
  background: #a7b0c0;
  border-radius: 9999px;
  -webkit-transition: .5s;
  transition: .5s;
}

.p-header .p-header__content__kebab .p-header__content__kebab__button::before, .p-header .p-header__content__kebab .p-header__content__kebab__button::after {
  content: '';
}

.p-header .p-header__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  height: 100%;
  padding: 0 50px;
  -webkit-transition: padding .5s;
  transition: padding .5s;
}

@media screen and (max-width: 840px) {
  .p-header .p-header__content {
    padding: 0 10px;
  }
}

.p-header .p-header__content .p-header__content__title {
  display: block;
  position: relative;
  -webkit-transition: .5s;
  transition: .5s;
}

@media screen and (max-width: 840px) {
  .p-header .p-header__content .p-header__content__title {
    margin: 0;
  }
}

.p-header .p-header__content .p-header__content__title::after {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/brand/brand-logo.png) center/cover no-repeat;
  opacity: 0;
  -webkit-transition: .5s;
  transition: .5s;
}

.p-header .p-header__content .p-header__content__title .p-header__content__title__image {
  display: block;
  position: relative;
  width: auto;
  height: 60px;
  -webkit-transition: .5s;
  transition: .5s;
}

@media screen and (max-width: 840px) {
  .p-header .p-header__content .p-header__content__title .p-header__content__title__image {
    height: 48px;
  }
}

@media screen and (max-width: 350px) {
  .p-header .p-header__content .p-header__content__title .p-header__content__title__image {
    height: 40px;
  }
}

.p-mv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  height: 720px;
  max-height: 100vh;
  overflow: hidden;
  background: #000;
}

@media screen and (max-width: 1600px) {
  .p-mv {
    height: 650px;
  }
}

@media screen and (max-width: 640px) {
  .p-mv {
    height: 500px;
  }
}

.p-mv::before {
  content: '';
  display: block;
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0.8)), color-stop(50%, transparent));
  background: linear-gradient(to top, rgba(0, 0, 0, 0.8), transparent 50%);
  mix-blend-mode: multiply;
}

.p-mv::after {
  content: '';
  display: block;
  position: absolute;
  z-index: 1;
  width: 100%;
  height: 100%;
  background: repeating-linear-gradient(transparent, rgba(69, 80, 93, 0.4) 1px, transparent 4px);
  mix-blend-mode: multiply;
}

.p-mv .p-mv__background {
  position: absolute;
  z-index: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-mv .p-mv__gear {
  position: absolute;
  z-index: 1;
  width: 600px;
  height: 600px;
  overflow: hidden;
  border-radius: 50%;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__gear {
    width: 350px;
    height: 350px;
  }
}

.p-mv .p-mv__gear.is-main {
  top: -120px;
  right: -140px;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__gear.is-main {
    top: -100px;
    right: -80px;
  }
}

.p-mv .p-mv__gear.is-sub {
  bottom: -370px;
  left: -120px;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__gear.is-sub {
    bottom: -200px;
    left: -110px;
  }
}

.p-mv .p-mv__purpose {
  position: relative;
  z-index: 2;
  width: 100%;
  margin: 0 0 5%;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose {
    margin: 0 0 10%;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 100%;
  margin: 30px 0;
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-1 {
  margin-right: auto;
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-1::before {
  bottom: -60px;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part.is-1::before {
    bottom: -30px;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-1 .p-mv__purpose__part__line::before {
  left: 0;
  bottom: -60px;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part.is-1 .p-mv__purpose__part__line::before {
    bottom: -30px;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-1 .p-mv__purpose__part__message {
  -webkit-transform: translateX(-15px);
          transform: translateX(-15px);
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-2 {
  margin-left: auto;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-2::before {
  bottom: calc(100% - 30px);
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part.is-2::before {
    bottom: 100%;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-2 .p-mv__purpose__part__line::before {
  right: 0;
  bottom: calc(100% - 30px);
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part.is-2 .p-mv__purpose__part__line::before {
    bottom: 100%;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-2 .p-mv__purpose__part__message {
  -webkit-transform: translateX(15px);
          transform: translateX(15px);
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-animated::before {
  -webkit-animation: line-stretch 1s linear forwards;
          animation: line-stretch 1s linear forwards;
}

.p-mv .p-mv__purpose .p-mv__purpose__part.is-fade-out::before {
  width: 100%;
  -webkit-animation: line-fade-out .5s linear forwards, line-move .6s linear forwards;
          animation: line-fade-out .5s linear forwards, line-move .6s linear forwards;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part.is-fade-out::before {
    -webkit-animation: line-fade-out .4s .6s linear forwards, line-move .6s linear forwards;
            animation: line-fade-out .4s .6s linear forwards, line-move .6s linear forwards;
  }
}

@-webkit-keyframes line-stretch {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}

@keyframes line-stretch {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}

@-webkit-keyframes line-move {
  100% {
    bottom: 0%;
  }
}

@keyframes line-move {
  100% {
    bottom: 0%;
  }
}

@-webkit-keyframes line-fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

@keyframes line-fade-out {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part::before {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  right: 0;
  width: 0;
  height: 1px;
  margin: 0 auto;
  background: #fff;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part::before {
    bottom: -15px;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__line {
  min-width: 50px;
  position: relative;
  width: calc((100% - 640px) / 2 - 100px);
  opacity: .7;
}

@media screen and (max-width: 1200px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__line {
    width: calc((100% - 520px) / 2 - 100px);
  }
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__line {
    visibility: hidden;
    min-width: 20px;
    width: 20px;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__line.is-animated::before {
  display: block;
  -webkit-animation: line-move .6s linear forwards;
          animation: line-move .6s linear forwards;
}

.p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__line::before {
  content: '';
  display: none;
  position: absolute;
  width: 100%;
  height: 1px;
  background: #fff;
}

.p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__message {
  display: block;
  width: 640px;
  max-width: 90%;
  height: auto;
  opacity: 0;
}

@media screen and (max-width: 1200px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__message {
    width: 520px;
    max-width: 85%;
  }
}

@media screen and (max-width: 840px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__message {
    width: 480px;
    max-width: 75%;
  }
}

.p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__message.is-animated {
  -webkit-animation: purpose-display .3s ease-in forwards;
          animation: purpose-display .3s ease-in forwards;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__purpose .p-mv__purpose__part .p-mv__purpose__part__message.is-animated {
    -webkit-animation: purpose-display-sp .3s ease-in forwards;
            animation: purpose-display-sp .3s ease-in forwards;
  }
}

@-webkit-keyframes purpose-display {
  to {
    opacity: 1;
    -webkit-filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 6px rgba(21, 52, 101, 0.2));
            filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 6px rgba(21, 52, 101, 0.2));
    -webkit-transform: none;
            transform: none;
  }
}

@keyframes purpose-display {
  to {
    opacity: 1;
    -webkit-filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 6px rgba(21, 52, 101, 0.2));
            filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 6px rgba(21, 52, 101, 0.2));
    -webkit-transform: none;
            transform: none;
  }
}

@-webkit-keyframes purpose-display-sp {
  to {
    opacity: 1;
    -webkit-filter: drop-shadow(0 0 3px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 5px rgba(21, 52, 101, 0.2));
            filter: drop-shadow(0 0 3px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 5px rgba(21, 52, 101, 0.2));
    -webkit-transform: none;
            transform: none;
  }
}

@keyframes purpose-display-sp {
  to {
    opacity: 1;
    -webkit-filter: drop-shadow(0 0 3px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 5px rgba(21, 52, 101, 0.2));
            filter: drop-shadow(0 0 3px rgba(255, 255, 255, 0.9)) drop-shadow(0 0 5px rgba(21, 52, 101, 0.2));
    -webkit-transform: none;
            transform: none;
  }
}

.p-mv .p-mv__company {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.p-mv .p-mv__company .p-mv__company__background {
  position: absolute;
  z-index: 2;
  right: -30px;
  bottom: -10px;
  width: auto;
  height: 120px;
  opacity: .2;
  -webkit-filter: drop-shadow(0 0 6px white);
          filter: drop-shadow(0 0 6px white);
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__company .p-mv__company__background {
    bottom: -5px;
    height: 60px;
  }
}

.p-mv .p-mv__company .p-mv__company__name {
  position: absolute;
  z-index: 2;
  right: 50px;
  bottom: 40px;
  width: 320px;
  height: auto;
  opacity: 0;
}

@media screen and (max-width: 640px) {
  .p-mv .p-mv__company .p-mv__company__name {
    right: 20px;
    bottom: 20px;
    width: 200px;
  }
}

.p-mv .p-mv__company .p-mv__company__name.is-visible {
  -webkit-animation: name-fadein .5s 1s linear forwards;
          animation: name-fadein .5s 1s linear forwards;
}

@-webkit-keyframes name-fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: .9;
    -webkit-filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.8));
            filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.8));
  }
}

@keyframes name-fadein {
  0% {
    opacity: 0;
  }
  100% {
    opacity: .9;
    -webkit-filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.8));
            filter: drop-shadow(0 0 5px rgba(255, 255, 255, 0.8));
  }
}

.p-section {
  position: relative;
  padding: 150px 0;
  background: linear-gradient(to top, rgba(167, 176, 192, 0.15), transparent 240px);
}

@media screen and (max-width: 640px) {
  .p-section {
    padding: 70px 0 50px;
  }
}

.p-section.is-page-title {
  padding-bottom: 0;
  background: none;
}

.p-section.is-page-title .p-section__title {
  margin: 0 0 100px;
}

@media screen and (max-width: 640px) {
  .p-section.is-page-title .p-section__title {
    margin: 0 0 60px;
  }
}

.p-section.is-top-fit {
  padding-top: 0;
}

.p-section .p-section__title {
  margin: 0 0 150px;
  text-align: center;
  font-size: 2rem;
  font-weight: normal;
}

.p-section .p-section__title.is-sub {
  margin: 0 0 70px;
  font-size: 1.7rem;
}

@media screen and (max-width: 640px) {
  .p-section .p-section__title.is-sub {
    margin: 0 0 50px;
    font-size: 1.5rem;
  }
}

@media screen and (max-width: 640px) {
  .p-section .p-section__title {
    font-size: 1.6rem;
    margin: 0 0 60px;
  }
}

.p-section .p-section__title .p-section__title__image {
  display: block;
  width: auto;
  max-width: 100%;
  height: 50px;
  margin: 0 auto;
  mix-blend-mode: multiply;
}

@media screen and (max-width: 640px) {
  .p-section .p-section__title .p-section__title__image {
    height: 36px;
  }
}

.p-section-philosophy {
  padding-bottom: 30px;
}

.p-section-philosophy .p-section-philosophy__block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  z-index: 1;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 80px;
  width: calc(50% + $content-width / 2);
  min-height: 300px;
  margin: 0 0 80px auto;
  padding: 15px 0;
}

@media screen and (max-width: 1400px) {
  .p-section-philosophy .p-section-philosophy__block {
    gap: 50px;
  }
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block {
    gap: 30px;
    display: block;
    width: auto;
    min-height: auto;
    margin: 0;
    padding: 0 0 50px;
  }
}

.p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  margin: 0 auto 80px 0;
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) {
    margin: 0;
  }
}

.p-section-philosophy .p-section-philosophy__block:nth-child(2n+1)::before {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) .p-section-philosophy__block__space {
  -webkit-transform: scale(-1, 1);
          transform: scale(-1, 1);
}

.p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) .p-section-philosophy__block__title {
  text-align: right;
}

@media screen and (max-width: 1200px) {
  .p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) .p-section-philosophy__block__title {
    min-width: 38%;
  }
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) .p-section-philosophy__block__title {
    margin: 0 0 30px 30px;
    text-align: left;
  }
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) .p-section-philosophy__block__title {
    margin: 0 0 25px 20px;
  }
}

@media screen and (max-width: 640px) {
  .p-section-philosophy .p-section-philosophy__block:nth-child(2n+1) .p-section-philosophy__block__title {
    margin: 0 0 20px 15px;
    padding: 15px 25px;
  }
}

.p-section-philosophy .p-section-philosophy__block::before {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 300px;
  background: url(../img/philosophy/philosophy-background.png) left center/100px 300px no-repeat;
  -webkit-animation: ripple 2.5s ease-in-out infinite;
          animation: ripple 2.5s ease-in-out infinite;
  mix-blend-mode: multiply;
}

@-webkit-keyframes ripple {
  0% {
    opacity: 1;
  }
  50% {
    opacity: .5;
  }
  100% {
    opacity: 1;
  }
}

@keyframes ripple {
  0% {
    opacity: 1;
  }
  50% {
    opacity: .5;
  }
  100% {
    opacity: 1;
  }
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block::before {
    display: none;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__space {
  -webkit-transition: .5s;
  transition: .5s;
  width: 10%;
}

@media screen and (max-width: 1800px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__space {
    width: 8%;
  }
}

@media screen and (max-width: 1600px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__space {
    width: 5%;
  }
}

@media screen and (max-width: 1400px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__space {
    width: 0%;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title {
  position: relative;
  min-width: 35%;
  padding: 40px 40px;
  color: #fff;
  background: #a7b0c0 url(../img/common/background-noise.png);
  text-align: left;
  white-space: nowrap;
  font-size: 1.8rem;
  font-weight: normal;
  overflow: hidden;
}

@media screen and (max-width: 1600px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title {
    min-width: 35%;
  }
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title {
    font-size: 1.5rem;
    padding: 20px 30px;
    margin: 0 0 30px 30px;
    text-align: left;
  }
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title {
    margin: 0 0 25px 20px;
  }
}

@media screen and (max-width: 640px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title {
    margin: 0 0 20px 20px;
    padding: 15px 25px;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title.is-origin::before {
  background-image: url(../img/philosophy/philosophy-title-origin.png);
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title.is-purpose::before {
  background-image: url(../img/philosophy/philosophy-title-purpose.png);
  background-position: left -5px bottom;
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title.is-purpose::before {
    background-position: right -5px bottom;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title.is-value::before {
  background-image: url(../img/philosophy/philosophy-title-value.png);
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title .p-section-philosophy__block__title__sub {
  margin: 5px 0;
  font-size: 35%;
  font-weight: bold;
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__title::before {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: right -5px bottom / contain no-repeat;
  opacity: .3;
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  gap: 30px;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  line-height: 1.8;
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content {
    padding: 0 40px;
  }
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content {
    padding: 0 30px;
  }
}

@media screen and (max-width: 640px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 0 20px;
    gap: 10px;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content.is-origin .p-section-philosophy__block__content__main .p-section-philosophy__block__content__main__leading {
  font-size: 1.3rem;
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content.is-origin .p-section-philosophy__block__content__main .p-section-philosophy__block__content__main__leading {
    font-size: 1.2rem;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content.is-value {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content.is-purpose .p-section-philosophy__block__content__main .p-section-philosophy__block__content__main__leading {
  font-size: 1.7rem;
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content.is-purpose .p-section-philosophy__block__content__main .p-section-philosophy__block__content__main__leading {
    font-size: 1.5rem;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content .p-section-philosophy__block__content__image {
  display: block;
  width: 240px;
  height: auto;
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content .p-section-philosophy__block__content__image {
    width: 200px;
  }
}

.p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content .p-section-philosophy__block__content__main .p-section-philosophy__block__content__main__leading {
  margin: 0 0 20px;
  font-size: 1.7rem;
  font-weight: bold;
  line-height: 1.6;
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__block .p-section-philosophy__block__content .p-section-philosophy__block__content__main .p-section-philosophy__block__content__main__leading {
    font-size: 1.5rem;
  }
}

.p-section-philosophy .p-section-philosophy__value {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__value {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 40px;
    width: 300px;
    margin: 30px 0 0;
  }
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding: 0 40px;
  border-right: 1px solid rgba(167, 176, 192, 0.5);
  white-space: nowrap;
  line-height: 1;
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item:last-child {
  border-right: none;
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item.is-o {
  color: #1c9de3;
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item.is-p {
  color: #6a51eb;
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item.is-s {
  color: #ee2f54;
}

@media screen and (max-width: 1400px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item {
    padding: 0 20px;
  }
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    gap: 30px;
    padding: 0;
    border-right: none;
  }
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__initial .p-section-philosophy__value__item__initial__image {
  font-size: 1.3rem;
  display: block;
  width: 125px;
  height: auto;
}

@media screen and (max-width: 1600px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__initial .p-section-philosophy__value__item__initial__image {
    width: 115px;
  }
}

@media screen and (max-width: 1400px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__initial .p-section-philosophy__value__item__initial__image {
    width: 100px;
  }
}

@media screen and (max-width: 640px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__initial .p-section-philosophy__value__item__initial__image {
    width: 80px;
    min-width: 80px;
  }
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__label {
  text-align: center;
  font-size: 1.3rem;
}

@media screen and (max-width: 1400px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__label {
    font-size: 1rem;
  }
}

@media screen and (max-width: 1024px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__label {
    font-size: 1.3rem;
  }
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__label {
    text-align: left;
    font-size: 1.1rem;
  }
}

.p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__label .p-section-philosophy__value__item__label__image {
  display: block;
  margin: 10px auto;
}

@media screen and (max-width: 840px) {
  .p-section-philosophy .p-section-philosophy__value .p-section-philosophy__value__item .p-section-philosophy__value__item__label .p-section-philosophy__value__item__label__image {
    margin: 0 auto 8px 0;
    text-align: left;
    width: auto;
    height: 45px;
  }
}

.p-section-service .p-section-service__content {
  position: relative;
}

.p-section-service .p-section-service__content::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 500px;
  margin: auto 0;
  background: url(../img/common/background-dot.png) 0 0/350px 350px repeat;
  -webkit-animation: bg-dot 1.2s steps(5) infinite;
          animation: bg-dot 1.2s steps(5) infinite;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content::before {
    height: 640px;
    background-size: 280px 280px;
    -webkit-animation-name: bg-dot-sp;
            animation-name: bg-dot-sp;
  }
}

@-webkit-keyframes bg-dot {
  to {
    background-position: -350px 0;
  }
}

@keyframes bg-dot {
  to {
    background-position: -350px 0;
  }
}

@-webkit-keyframes bg-dot-sp {
  to {
    background-position: -280px 0;
  }
}

@keyframes bg-dot-sp {
  to {
    background-position: -280px 0;
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item {
  display: block;
  position: relative;
  z-index: 1;
  width: 90%;
  max-width: 1800px;
  margin: 0 auto 0 20px;
  padding: 60px;
  color: #fff;
  background: #fff repeating-linear-gradient(transparent, rgba(0, 0, 0, 0.2) 1px, transparent, transparent 4px);
  -webkit-box-shadow: 0 4px 4px rgba(0, 0, 0, 0.1);
          box-shadow: 0 4px 4px rgba(0, 0, 0, 0.1);
  overflow: hidden;
  -webkit-transition: .5s;
  transition: .5s;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item {
    width: calc(100% - 30px);
    padding: 40px 25px 30px;
    margin: 0 auto 0 0;
  }
}

@media (hover: hover) {
  .p-section-service .p-section-service__content .p-section-service__content__item:hover:not(.is-soon) {
    background-color: rgba(69, 80, 93, 0.3);
  }
  .p-section-service .p-section-service__content .p-section-service__content__item:hover:not(.is-soon)::before {
    -webkit-transform: scale(1.03);
            transform: scale(1.03);
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item.is-soon {
  cursor: not-allowed;
}

.p-section-service .p-section-service__content .p-section-service__content__item:nth-child(1)::before {
  background-image: url(../img/service/service-opsdata-background.jpg);
  background-position: center bottom;
}

.p-section-service .p-section-service__content .p-section-service__content__item:nth-child(2)::before {
  background-image: url(../img/service/service-normalizer-background.jpg);
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item:nth-child(2)::before {
    background-position: left +25% center;
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item::before {
  content: '';
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: center / cover no-repeat;
  mix-blend-mode: multiply;
  -webkit-transition: .5s;
  transition: .5s;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item::before {
    -webkit-filter: brightness(0.9);
            filter: brightness(0.9);
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item:nth-child(2n) {
  z-index: 0;
  margin: -40px 20px 0 auto;
  padding: 70px 60px 60px;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item:nth-child(2n) {
    margin: -30px 0 0 auto;
    padding: 55px 25px 30px;
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content {
  position: relative;
  z-index: 1;
}

.p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__title {
  margin: 0 0 30px;
  font-weight: bold;
  font-size: 2rem;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__title {
    margin: 10px 0 20px;
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__title .p-section-service__content__item__content__title__image {
  max-width: 100%;
  height: auto;
  -webkit-filter: drop-shadow(0 0 5px #fff);
          filter: drop-shadow(0 0 5px #fff);
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__title .p-section-service__content__item__content__title__image {
    -webkit-filter: drop-shadow(0 0 3px #fff);
            filter: drop-shadow(0 0 3px #fff);
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin: 200px -20px -30px;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__link {
    margin: 60px 0 0;
  }
}

.p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__link .p-section-service__content__item__content__link__image {
  -webkit-filter: drop-shadow(0 0 6px #fff);
          filter: drop-shadow(0 0 6px #fff);
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__content .p-section-service__content__item .p-section-service__content__item__content .p-section-service__content__item__content__link .p-section-service__content__item__content__link__image {
    -webkit-filter: drop-shadow(0 0 3px #fff);
            filter: drop-shadow(0 0 3px #fff);
  }
}

.p-section-service .p-section-service__annotation {
  margin: 12px 0 0;
  text-align: right;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__annotation {
    margin: 20px 0 0;
    text-align: left;
  }
}

.p-section-service .p-section-service__annotation .p-section-service__annotation__content {
  display: inline-block;
  text-align: left;
}

@media screen and (max-width: 640px) {
  .p-section-service .p-section-service__annotation .p-section-service__annotation__content {
    display: block;
  }
}

.p-section-company {
  position: relative;
  padding-bottom: 160px;
  background: transparent;
}

@media screen and (max-width: 1024px) {
  .p-section-company {
    background: url(../img/common/background-logo.png) right -20px top 280px/280px 280px no-repeat;
  }
}

@media screen and (max-width: 840px) {
  .p-section-company {
    background-size: 240px 240px;
    background-position: right -20px top 280px;
  }
}

@media screen and (max-width: 640px) {
  .p-section-company {
    padding-bottom: 60px;
    background-size: 180px 180px;
    background-position: right -15px top 140px;
  }
}

.p-section-company::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 360px;
  background: url(../img/common/background-rainbow.png) right bottom/600px 360px no-repeat;
}

@media screen and (max-width: 640px) {
  .p-section-company::before {
    height: 240px;
    background-position: right -100px bottom;
    background-size: 400px 240px;
  }
}

@media screen and (max-width: 640px) and (max-width: 640px) {
  .p-section-company::before {
    background-size: 320px 192px;
  }
}

.p-section-company::after {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 160px;
  background: url(../img/common/background-town.png) center bottom/1200px 150px repeat-x;
}

@media screen and (max-width: 640px) {
  .p-section-company::after {
    background-size: 960px 120px;
  }
}

.p-section-company .p-section-company__background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(../img/company/company-background-opsdata.png) right -10px top 40%/180px 1300px no-repeat;
  opacity: .6;
}

@media screen and (max-width: 1200px) {
  .p-section-company .p-section-company__background {
    background-size: 144px 1040px;
  }
}

@media screen and (max-width: 840px) {
  .p-section-company .p-section-company__background {
    display: none;
  }
}

.p-section-company .p-section-company__background::before {
  content: '';
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: url(../img/company/company-background-sdgs.png) left -10px bottom 200px/180px 700px no-repeat;
}

@media screen and (max-width: 1200px) {
  .p-section-company .p-section-company__background::before {
    background-size: 144px 560px;
  }
}

.p-section-company .p-section-company__overview {
  position: relative;
  margin: 0 0 120px;
  overflow-y: visible;
}

@media screen and (max-width: 640px) {
  .p-section-company .p-section-company__overview {
    margin: 0 0 65px;
    overflow-x: hidden;
  }
}

.p-section-company .p-section-company__overview::before {
  content: '';
  display: block;
  position: -webkit-sticky;
  position: sticky;
  width: 380px;
  height: 600px;
  top: 0;
  left: 0;
  margin: -200px 0 0;
  background: url(../img/common/background-logo.png) center/contain no-repeat;
  -webkit-transform: translateX(-120px);
          transform: translateX(-120px);
}

@media screen and (max-width: 1400px) {
  .p-section-company .p-section-company__overview::before {
    width: 300px;
    height: 450px;
    -webkit-transform: translateX(-40px);
            transform: translateX(-40px);
  }
}

@media screen and (max-width: 1200px) {
  .p-section-company .p-section-company__overview::before {
    -webkit-transform: translateX(-80px);
            transform: translateX(-80px);
  }
}

@media screen and (max-width: 1024px) {
  .p-section-company .p-section-company__overview::before {
    display: none;
  }
}

.p-section-company .p-section-company__overview .p-section-company__overview__spacer {
  margin: -450px 0 0;
}

@media screen and (max-width: 1400px) {
  .p-section-company .p-section-company__overview .p-section-company__overview__spacer {
    margin: -300px 0 0;
  }
}

@media screen and (max-width: 1024px) {
  .p-section-company .p-section-company__overview .p-section-company__overview__spacer {
    margin: -50px 0 0;
  }
}

@media screen and (max-width: 640px) {
  .p-section-company .p-section-company__overview .p-section-company__overview__spacer {
    margin: 0;
  }
}

.p-section-company .p-section-company__overview .p-section-company__overview__content {
  max-width: 900px;
  margin: 50px auto;
  padding: 50px 0;
  border-top: 1px solid #a7b0c0;
  border-bottom: 1px solid #a7b0c0;
}

@media screen and (max-width: 640px) {
  .p-section-company .p-section-company__overview .p-section-company__overview__content {
    margin: 0;
    padding: 10px 0;
  }
}

.p-section-company .p-section-company__overview .p-section-company__overview__ask {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 8px;
  height: 40px;
  margin: 10px 0 0;
  padding: 0 15px 0 12px;
  color: #fff;
  background: #a7b0c0;
  white-space: nowrap;
  line-height: 1;
}

@media screen and (max-width: 840px) {
  .p-section-company .p-section-company__overview .p-section-company__overview__ask {
    width: 100%;
    height: 50px;
    max-width: 260px;
    margin: 10px 0 0;
  }
}

.p-section-company .p-section-company__overview .p-section-company__overview__ask::before {
  content: '';
  display: block;
  width: 25px;
  height: 25px;
  background: url(../img/common/icon-ask.svg) center/cover no-repeat;
}

@media screen and (max-width: 840px) {
  .p-section-company .p-section-company__overview .p-section-company__overview__ask::before {
    width: 30px;
    height: 30px;
  }
}

.p-section-company .p-section-company__overview .p-section-company__overview__ask::after {
  content: '';
  display: block;
  width: 24px;
  height: 16px;
  background: url(../img/common/icon-arrow-right.svg) center/cover no-repeat;
}

.p-section-company .p-section-company__overview .p-section-company__overview__ask .p-section-company__overview__ask__label {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  text-align: center;
}

@media (hover: hover) {
  .p-section-company .p-section-company__overview .p-section-company__overview__ask:hover {
    background: #6695e0;
    -webkit-transition: .3s;
    transition: .3s;
  }
  .p-section-company .p-section-company__overview .p-section-company__overview__ask:hover::after {
    -webkit-transform: translateX(4px);
            transform: translateX(4px);
    -webkit-transition: .3s;
    transition: .3s;
  }
}

.p-section-company .p-section-company__sdgs {
  position: relative;
  margin: 0 0 100px;
}

.p-section-company .p-section-company__sdgs .p-section-company__sdgs__title {
  margin: 50px auto;
}

@media screen and (max-width: 640px) {
  .p-section-company .p-section-company__sdgs .p-section-company__sdgs__title {
    margin: 30px auto;
  }
}

.p-section-company .p-section-company__sdgs .p-section-company__sdgs__title .p-section-company__sdgs__title__image {
  display: block;
  width: 380px;
  height: auto;
  margin: 0 auto;
}

@media screen and (max-width: 640px) {
  .p-section-company .p-section-company__sdgs .p-section-company__sdgs__title .p-section-company__sdgs__title__image {
    width: 290px;
    max-width: 90%;
  }
}

.p-section-company .p-section-company__sdgs .p-section-company__sdgs__goal {
  position: relative;
  z-index: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 20px;
  margin: 50px 0;
}

@media screen and (max-width: 640px) {
  .p-section-company .p-section-company__sdgs .p-section-company__sdgs__goal {
    max-width: 320px;
    gap: 10px;
    margin: 30px auto 25px;
  }
}

.p-section-company .p-section-company__sdgs .p-section-company__sdgs__goal .p-section-company__sdgs__goal__image {
  display: block;
  width: 200px;
  height: auto;
}

@media screen and (max-width: 1024px) {
  .p-section-company .p-section-company__sdgs .p-section-company__sdgs__goal .p-section-company__sdgs__goal__image {
    width: 160px;
  }
}

@media screen and (max-width: 640px) {
  .p-section-company .p-section-company__sdgs .p-section-company__sdgs__goal .p-section-company__sdgs__goal__image {
    width: calc(50% - 20px);
  }
}

.p-table-company {
  width: 100%;
  border-collapse: collapse;
  border: none;
}

@media screen and (max-width: 640px) {
  .p-table-company {
    width: auto;
    margin: 0;
    font-size: 0.9em;
  }
}

.p-table-company .p-table-company__row.is-map {
  display: none;
}

@media screen and (max-width: 640px) {
  .p-table-company .p-table-company__row.is-map {
    display: table-row;
  }
}

.p-table-company .p-table-company__row.is-map .p-table-company__data {
  padding: 5px 0;
}

.p-table-company .p-table-company__row.is-map .p-table-company__data .p-table-company__data__map {
  display: block;
}

.p-table-company .p-table-company__header,
.p-table-company .p-table-company__data {
  position: relative;
  padding: 30px 25px;
  font-weight: normal;
  vertical-align: top;
}

.p-table-company .p-table-company__header {
  width: 20%;
  white-space: nowrap;
  text-align: right;
  color: #8995ab;
  border-right: 1px solid #e2e5eb;
}

@media screen and (max-width: 640px) {
  .p-table-company .p-table-company__header {
    padding: 15px 15px 15px 5px;
    font-weight: bold;
  }
}

.p-table-company .p-table-company__header::after {
  content: '';
  display: block;
  position: absolute;
  top: calc(30px + .4rem - 2px);
  right: -8px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  border: 3px solid #f9fbfc;
  background: #6695e0;
}

@media screen and (max-width: 640px) {
  .p-table-company .p-table-company__header::after {
    top: calc(15px + .35em - 2px);
  }
}

@media screen and (max-width: 640px) {
  .p-table-company .p-table-company__data {
    padding: 15px 5px 15px 15px;
  }
}

.p-table-company .p-table-company__data .p-table-company__data__map {
  width: 100%;
  margin: 1em 0 0;
  border: 1px solid #a7b0c0;
  background: #d4d8e0;
}

@media screen and (max-width: 640px) {
  .p-table-company .p-table-company__data .p-table-company__data__map {
    margin: 0;
    height: 200px;
  }
}

.p-table-company .p-table-company__data .p-table-company__data__table {
  display: table;
  border: none;
  border-spacing: 0;
}

@media screen and (max-width: 840px) {
  .p-table-company .p-table-company__data .p-table-company__data__table {
    display: block;
  }
}

@media screen and (max-width: 840px) {
  .p-table-company .p-table-company__data .p-table-company__data__table .p-table-company__data__table__row {
    display: block;
    margin: 0 0 5px;
  }
}

.p-table-company .p-table-company__data .p-table-company__data__table .p-table-company__data__table__cell {
  padding: 0 20px 0 0;
}

.p-table-company .p-table-company__data .p-table-company__data__table .p-table-company__data__table__cell.is-no-space {
  padding: 0;
}

@media screen and (max-width: 840px) {
  .p-table-company .p-table-company__data .p-table-company__data__table .p-table-company__data__table__cell {
    display: inline;
    padding: 0;
  }
}

.p-section-default {
  background: transparent;
}

.p-section-default::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 360px;
  background: url(../img/common/background-rainbow.png) right bottom/600px 360px no-repeat;
}

@media screen and (max-width: 640px) {
  .p-section-default::before {
    height: 240px;
    background-position: right -100px bottom;
    background-size: 400px 240px;
  }
}

@media screen and (max-width: 640px) and (max-width: 640px) {
  .p-section-default::before {
    background-size: 320px 192px;
  }
}

.p-section-default::after {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  width: 100%;
  height: 160px;
  background: url(../img/common/background-town.png) center bottom/1200px 150px repeat-x;
}

@media screen and (max-width: 640px) {
  .p-section-default::after {
    background-size: 960px 120px;
  }
}

.p-section-default .p-section-default__content {
  position: relative;
  margin: 0 0 120px;
  overflow-y: visible;
}

@media screen and (max-width: 640px) {
  .p-section-default .p-section-default__content {
    margin: 0 0 65px;
    overflow-x: hidden;
  }
}

.p-section-default .p-section-default__content::before {
  content: '';
  display: block;
  position: -webkit-sticky;
  position: sticky;
  width: 380px;
  height: 380px;
  top: 0;
  left: 0;
  margin: -50px 0 0;
  background: url(../img/common/background-logo.png) center/contain no-repeat;
  -webkit-transform: translateX(-240px);
          transform: translateX(-240px);
}

@media screen and (max-width: 1400px) {
  .p-section-default .p-section-default__content::before {
    width: 300px;
    -webkit-transform: translateX(-30px);
            transform: translateX(-30px);
  }
}

@media screen and (max-width: 1024px) {
  .p-section-default .p-section-default__content::before {
    display: none;
  }
}

.p-section-default .p-section-default__content .p-section-default__content__spacer {
  margin: -340px 0 0;
}

@media screen and (max-width: 1024px) {
  .p-section-default .p-section-default__content .p-section-default__content__spacer {
    margin: 0;
  }
}

.p-privacy {
  position: relative;
}

.p-privacy .p-privacy__index {
  margin: 0 0 .5em;
  font-weight: bold;
}

.p-privacy .p-privacy__body {
  margin: 0 0 3em;
}

@media screen and (max-width: 640px) {
  .p-privacy .p-privacy__body {
    margin: 0 0 2em;
  }
}

.p-contact {
  position: relative;
  margin: 0 0 100px;
}

@media screen and (max-width: 640px) {
  .p-contact {
    margin: 0 0 100px;
  }
}

.p-contact .p-contact__description {
  margin: 0 0 30px;
}

.p-contact .p-contact__form {
  position: relative;
  text-align: center;
  margin: 30px auto;
}

@media screen and (max-width: 640px) {
  .p-contact .p-contact__form {
    width: 100%;
    max-width: 640px;
  }
}

.p-recruit {
  position: relative;
}

.p-recruit .p-recruit__description {
  margin: 0 0 30px;
}

.p-recruit .p-recruit__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 10px;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 50px 0;
}

@media screen and (max-width: 1200px) {
  .p-recruit .p-recruit__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-recruit .p-recruit__list .p-recruit__list__item {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  margin: 0 0 10px;
  background: white;
  border-radius: 5px;
  border: 1px solid #8899aa;
  overflow: hidden;
}

@media screen and (max-width: 640px) {
  .p-recruit .p-recruit__list .p-recruit__list__item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}

.p-recruit .p-recruit__list .p-recruit__list__item:hover {
  background: #fff;
  -webkit-transform: translateY(-3px);
          transform: translateY(-3px);
  -webkit-transition: .3s;
  transition: .3s;
  -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.12);
          box-shadow: 0 3px 6px rgba(0, 0, 0, 0.12);
}

.p-recruit .p-recruit__list .p-recruit__list__item:hover .p-recruit__list__item__visual::after {
  -webkit-transition: 1s;
  transition: 1s;
  -webkit-transform: translateX(40%);
          transform: translateX(40%);
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__visual {
  position: relative;
  width: 200px;
  overflow: hidden;
}

@media screen and (max-width: 640px) {
  .p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__visual {
    width: 100%;
    aspect-ratio: 16 / 9;
  }
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__visual::after {
  content: '';
  display: block;
  position: absolute;
  width: 300%;
  height: 100%;
  left: 0;
  top: 0;
  background: linear-gradient(-55deg, transparent 35%, rgba(255, 255, 255, 0.3) 36%, transparent 55%);
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__visual .p-recruit__list__item__visual__image {
  display: block;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 20px;
}

@media screen and (max-width: 640px) {
  .p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info {
    padding: 15px;
  }
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__title {
  font-size: 1.3em;
  font-weight: normal;
  margin: 0 0 .5em;
  padding: 0 5px;
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__condition {
  position: relative;
  margin: 5px 0;
  padding: 0 5px 0 40px;
  font-weight: normal;
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__condition.is-place::before {
  background-image: url(../img/recruit/recruit-icon-place.svg);
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__condition.is-state::before {
  background-image: url(../img/recruit/recruit-icon-state.svg);
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__condition::before {
  content: '';
  display: block;
  position: absolute;
  left: 6px;
  top: 0;
  bottom: 0;
  width: 1.4em;
  height: 1.4em;
  margin: auto 0;
  background: #8899aa center/1em 1em no-repeat;
  border-radius: 3px;
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__ask {
  position: relative;
  margin: 5px 0 0;
  padding: 20px 0 0;
  text-align: right;
  font-size: .9em;
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__ask::before {
  content: '';
  display: block;
  position: absolute;
  left: 0;
  top: 0;
  width: calc(100% - 24px);
  height: 16px;
  background: #a7b0c0;
  -webkit-mask-image: url(../img/common/icon-arrow-right-extend.svg);
          mask-image: url(../img/common/icon-arrow-right-extend.svg);
}

.p-recruit .p-recruit__list .p-recruit__list__item .p-recruit__list__item__info .p-recruit__list__item__info__ask::after {
  content: '';
  display: block;
  position: absolute;
  right: 0;
  top: 0;
  width: 24px;
  height: 16px;
  background: #a7b0c0;
  -webkit-mask-image: url(../img/common/icon-arrow-right.svg);
          mask-image: url(../img/common/icon-arrow-right.svg);
}

.p-footer {
  color: #fff;
  background: #45505d url(../img/common/background-noise-dark.png);
}

.p-footer .p-footer__content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
  padding: 40px 50px;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content {
    display: block;
    padding: 20px 25px;
  }
}

.p-footer .p-footer__content .p-footer__content__menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 50px;
  margin: 10px 0;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__menu {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    gap: 15px;
  }
}

.p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set {
  font-size: .8rem;
  color: #fff;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    margin: 0;
    max-width: 200px;
    font-size: .9rem;
  }
}

.p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set .p-footer__content__menu__set__title {
  margin: 0 0 .7em;
  color: #8995ab;
  font-size: 90%;
  font-weight: bold;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set .p-footer__content__menu__set__title {
    margin: 0 0 .5em;
  }
}

.p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set .p-footer__content__menu__set__list .p-footer__content__menu__set__list__item {
  list-style: none;
}

.p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set .p-footer__content__menu__set__list .p-footer__content__menu__set__list__item .p-footer__content__menu__set__list__item__link {
  display: inline-block;
  padding: 3px 0;
  color: #fff;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set .p-footer__content__menu__set__list .p-footer__content__menu__set__list__item .p-footer__content__menu__set__list__item__link {
    padding: 6px 0;
  }
}

.p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set .p-footer__content__menu__set__list .p-footer__content__menu__set__list__item .p-footer__content__menu__set__list__item__link.is-invalid {
  cursor: not-allowed;
}

@media (hover: hover) {
  .p-footer .p-footer__content .p-footer__content__menu .p-footer__content__menu__set .p-footer__content__menu__set__list .p-footer__content__menu__set__list__item .p-footer__content__menu__set__list__item__link:not(.is-invalid):hover {
    color: #6695e0;
    -webkit-transition: .3s;
    transition: .3s;
  }
}

.p-footer .p-footer__content .p-footer__content__company {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.4em;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin: 0 0 10px;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__logo::after {
  content: '';
  display: block;
  width: 1px;
  height: 100px;
  margin: 0 25px 0 20px;
  background: rgba(167, 176, 192, 0.4);
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__logo::after {
    display: none;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__logo .p-footer__content__company__logo__image {
  width: 130px;
  height: auto;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__logo .p-footer__content__company__logo__image {
    width: 160px;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.4em;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 10px;
  margin: 0 0 10px;
  height: 36px;
  padding: 0 15px;
  color: #fff;
  background: rgba(167, 176, 192, 0.4);
  border: 1px solid #d3d8e0;
  white-space: nowrap;
  line-height: 1;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask {
    width: 240px;
    height: 50px;
    width: 100%;
    max-width: 500px;
    margin: 20px 0 50px;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask::before {
  content: '';
  display: block;
  width: 25px;
  height: 25px;
  background: url(../img/common/icon-ask.svg) center/cover no-repeat;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask::before {
    width: 30px;
    height: 30px;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask::after {
  content: '';
  display: block;
  width: 24px;
  height: 16px;
  background: url(../img/common/icon-arrow-right.svg) center/cover no-repeat;
  opacity: .7;
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask .p-footer__content__company__info__ask__label {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  text-align: center;
}

@media (hover: hover) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask:hover {
    border-color: #99b8ea;
    background: #6695e0;
    -webkit-transition: .3s;
    transition: .3s;
  }
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__ask:hover::after {
    -webkit-transform: translateX(4px);
            transform: translateX(4px);
    -webkit-transition: .3s;
    transition: .3s;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__name {
  font-size: 1.1rem;
  font-weight: bold;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__name {
    font-size: 1.2rem;
  }
}

.p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__description {
  margin: 2px 0;
  font-size: 0.7rem;
  pointer-events: none;
  color: #d3d8e0;
}

@media screen and (max-width: 840px) {
  .p-footer .p-footer__content .p-footer__content__company .p-footer__content__company__info .p-footer__content__company__info__description {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 8px 0 4px;
  }
}

.p-footer .p-footer__copyright {
  padding: 25px;
  background: #6695e0;
  font-size: 0.75rem;
  text-align: center;
}

/* ======================================= *
 * Utility
 * ======================================= */
.u-text-sm {
  font-size: 80%;
}

.u-text-right {
  text-align: right;
}

.u-text-nowrap {
  white-space: nowrap;
}

.u-opacity-50 {
  opacity: .5;
}
/*# sourceMappingURL=opsdata.css.map */