@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Jost:ital,wght@0,100..900;1,100..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Lato:wght@300;400;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Barlow:wght@700;800&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Ropa+Sans:ital@0;1&display=swap");
:root {
  /*color - base*/
  --color-site-main:#009541;
  --color-site-sub:#E60013;
  --color-bg-gray-base:#E6E6E7;
  --color-bg-gray-deep:#DCDDDD;
  --color-bg-gray-light:#EFEDDE;
  /*font - base*/
  --font-family-jp:"Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "Yu Gothic", yugothic, "メイリオ", meiryo, sans-serif;
  --font-family-jp2: "Noto Serif JP", serif;
  --font-family-en1:"Jost", sans-serif;
  --font-family-en2:"Montserrat", sans-serif;
  --font-family-en3:"Oswald", sans-serif;
  /*layout - base*/
  --layout-header-pc:9rem;
  --layout-header-sp:6.0rem;
  --layout-floating-sp:5rem;
  --layout-container:126rem;
  --layout-container-padding:3rem;
}

@media (max-width: 767px) {
  :root {
    /*layout - base*/
    --layout-container-padding:2rem;
  }
}
/**
 * Eric Meyer's Reset CSS v2.0 (http://meyerweb.com/eric/tools/css/reset/)
 * http://cssreset.com
 */
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  font: inherit;
  font-size: 100%;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
  border: 0;
}

/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block;
}

body {
  line-height: 1;
}

ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

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

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

/* form */
input, button, select, textarea {
  font: inherit;
  border: none;
  border-radius: 0;
  outline: none;
  background: transparent;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  appearance: none;
  appearance: none;
}

*, *:before, *:after {
  -webkit-box-sizing: inherit;
  -o-box-sizing: inherit;
  -ms-box-sizing: inherit;
  box-sizing: inherit;
}

html {
  font-size: 62.5%;
  -webkit-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

@media screen and (max-width: 1500px) {
  html {
    font-size: 0.6666666667vw;
  }
}
@media screen and (max-width: 768px) {
  html {
    font-size: 2.6666666667vw;
  }
}
body {
  font-family: "Noto Sans JP", "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "Yu Gothic", yugothic, "メイリオ", meiryo, sans-serif;
  font-size: 1.6rem;
  font-weight: 400;
  position: relative;
  margin: 0 auto;
  line-height: 1.8;
  color: #000;
  letter-spacing: 0.1rem;
  overflow-x: hidden;
  word-wrap: break-word;
  -webkit-font-kerning: normal;
  font-kerning: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  height: 100%;
}
@media screen and (max-width: 768px) {
  body {
    font-size: 1.4rem;
  }
}
body.-menuOpen {
  overflow: hidden;
}

@supports (-webkit-touch-callout: none) {
  /*html{
    height: -webkit-fill-available;
  }

    body {
      min-height: 100vh;
      height: -webkit-fill-available;
    }*/
}
::-moz-selection {
  background: var(--color-site-main);
  color: #FFF;
}
::selection {
  background: var(--color-site-main);
  color: #FFF;
}

::-moz-selection {
  background: var(--color-site-main);
  color: #FFF;
}

li {
  list-style: none;
}

a, img {
  -webkit-transition: all 0.3s ease;
  transition: all 0.3s ease;
}

img {
  width: 100%;
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
  pointer-events: none;
}

a img {
  pointer-events: auto;
}

a,
a:link,
a:visited,
a:active {
  color: #000;
  text-decoration: none;
  outline: none;
}

a:hover {
  opacity: 1;
}
a:hover img {
  opacity: 1;
}

@media screen and (max-width: 768px) {
  .l-wrapper {
    padding-top: var(--layout-header-sp);
  }
}

.l-header {
  z-index: 10;
  width: 100%;
  background-color: #FFF;
}
@media screen and (min-width: 769px) {
  .l-header {
    height: var(--layout-header-pc);
    position: relative;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
}
@media screen and (max-width: 768px) {
  .l-header {
    height: var(--layout-header-sp);
    position: fixed;
    left: 0;
    top: 0;
  }
}
@media screen and (min-width: 769px) {
  .l-header::before {
    content: "";
    width: 100%;
    height: 0.5rem;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 10;
    background-color: var(--color-site-main);
  }
}
.l-header__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  gap: 0;
  height: 100%;
}
.l-header__logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
@media screen and (min-width: 769px) {
  .l-header__logo {
    width: 60rem;
    max-width: 44%;
    padding: 2rem 20rem 3rem 2rem;
  }
}
@media screen and (max-width: 768px) {
  .l-header__logo {
    width: 82%;
  }
}
.l-header__logo::before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 0;
}
@media screen and (min-width: 769px) {
  .l-header__logo::before {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 971.2 128.8'%3E%3Cpolygon fill='%23009541' points='784.6 0 679.7 128.8 0 128.8 0 0 784.6 0'/%3E%3Cpolygon fill='%23009541' points='765.3 128.8 870.1 0 813.8 0 708.9 128.8 765.3 128.8'/%3E%3Cpolygon fill='%23009541' points='815.8 128.8 920.7 0 899.3 0 794.4 128.8 815.8 128.8'/%3E%3Cpolygon fill='%23009541' points='866.4 128.8 971.2 0 949.8 0 844.9 128.8 866.4 128.8'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right top;
    background-size: auto 100%;
  }
}
@media screen and (max-width: 768px) {
  .l-header__logo::before {
    clip-path: polygon(0% 100%, calc(100% - 4rem) 100%, 100% 0%, 0% 0%);
    background-color: var(--color-site-main);
  }
}
@media screen and (max-width: 768px) {
  .l-header__logo::after {
    content: "";
    width: 5rem;
    height: 100%;
    position: absolute;
    top: 0;
    right: 1rem;
    background-color: #FFF;
    z-index: 99999;
    clip-path: polygon(0% 100%, calc(100% - 4rem) 100%, 100% 0%, calc(0% + 4rem) 0%);
  }
}
.l-header__logo-inner {
  position: relative;
  z-index: 1;
  display: block;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .l-header__logo-inner {
    width: 100%;
    max-width: 30rem;
    padding-right: 4.6rem;
    padding-left: 1rem;
    padding-bottom: 0.5rem;
  }
}
.l-header__logo-inner a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
.l-header__nav {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}
@media screen and (max-width: 768px) {
  .l-header__nav {
    display: none;
  }
}
.l-header__nav-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  gap: 2rem;
}
.l-header__nav-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2.5rem;
}
.l-header__nav-menu li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  font-weight: bold;
  font-size: clamp(0.6rem, 4vw, 1.6rem);
  line-height: 1.4;
  position: relative;
  padding: 0.5rem 0;
}
@media screen and (min-width: 769px) {
  .l-header__nav-menu li a::after {
    content: "";
    width: 100%;
    height: 1px;
    display: block;
    position: absolute;
    background-color: var(--color-site-main);
    left: 0;
    bottom: -1px;
    -webkit-animation: 2s;
            animation: 2s;
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
    -webkit-transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92), -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  }
  .l-header__nav-menu li a:hover::after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: left top;
            transform-origin: left top;
  }
}
.l-header__nav-menu li .-en {
  font-family: var(--font-family-en1);
  font-weight: 600;
  color: var(--color-site-main);
  font-size: 1.2rem;
}
.l-header__nav-recruit {
  position: relative;
  padding-right: 5rem;
}
.l-header__nav-recruit-link {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.l-header__nav-recruit-link .-text {
  border: 2px solid var(--color-site-sub);
  color: var(--color-site-sub);
  line-height: 1.2;
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 7.8rem;
  height: 7.8rem;
  border-radius: 50%;
  -webkit-transform: translateY(3rem);
          transform: translateY(3rem);
  background-color: #FFF;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.l-header__nav-recruit-link .-img {
  position: absolute;
  right: 0;
  top: 0;
  width: 6rem;
  height: auto;
  -webkit-transform: translateY(-1rem);
          transform: translateY(-1rem);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.l-header__nav-recruit-link:hover .-text {
  background: var(--color-site-sub);
  color: #FFF;
  -webkit-transform: translateY(3rem) scale(1.1);
          transform: translateY(3rem) scale(1.1);
}
.l-header__nav-recruit-link:hover .-img {
  -webkit-transform: translateY(0);
          transform: translateY(0);
}
@media screen and (min-width: 769px) {
  .l-header.-scroll {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
    opacity: 0;
    -webkit-transition: 0.3s;
    transition: 0.3s;
  }
  .l-header.-scroll.-show {
    position: fixed;
    left: 0;
    top: 0;
    -webkit-transform: translateY(0);
            transform: translateY(0);
    opacity: 1;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    -webkit-box-shadow: 0px 2px 20px -11px rgba(0, 0, 0, 0.3);
            box-shadow: 0px 2px 20px -11px rgba(0, 0, 0, 0.3);
  }
}

.l-container {
  padding: 0 var(--layout-container-padding);
  margin-left: auto;
  margin-right: auto;
}
@media screen and (min-width: 769px) {
  .l-container {
    max-width: var(--layout-container);
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .l-container {
    width: 100%;
  }
}

.l-contents__main {
  background-image: url("../../assets/images/concept/main.jpg");
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  width: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  overflow: hidden;
  position: relative;
}
@media screen and (min-width: 769px) {
  .l-contents__main {
    aspect-ratio: 8/3;
    -o-object-fit: cover;
       object-fit: cover;
    max-height: 62rem;
  }
}
@media screen and (max-width: 768px) {
  .l-contents__main {
    min-height: 24rem;
  }
}
.l-contents__main::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(0, 51, 23, 0.3);
  position: absolute;
  left: 0;
  top: 0;
}
.l-contents__main-title {
  color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
}
.l-contents__main-title .-title {
  font-weight: 900;
  text-shadow: 0 0 8px #999;
}
@media screen and (min-width: 769px) {
  .l-contents__main-title .-title {
    font-size: 6.2rem;
    letter-spacing: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .l-contents__main-title .-title {
    font-size: 3.4rem;
    letter-spacing: 0.5rem;
    text-shadow: 0 0 8px #666;
  }
}
.l-contents__main-title .-en {
  font-family: var(--font-family-en1);
  opacity: 0.5;
  font-weight: 500;
  position: absolute;
  line-height: 1;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  white-space: nowrap;
}
@media screen and (min-width: 769px) {
  .l-contents__main-title .-en {
    font-size: 14.8rem;
    top: -0.5em;
  }
}
@media screen and (max-width: 768px) {
  .l-contents__main-title .-en {
    top: -0.3em;
    font-size: 4.8rem;
  }
}
.l-contents__wrapper {
  background: var(--color-bg-gray-base);
  position: relative;
  z-index: 1;
}

@media screen and (min-width: 769px) {
  .l-footer {
    padding: 8rem 0 3rem;
    max-width: 160rem;
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .l-footer {
    padding: 5rem 0 6rem;
  }
}
.l-footer__wrapper {
  padding: 0 var(--layout-container-padding);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .l-footer__wrapper {
    gap: 2rem 3rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    min-width: var(--layout-container);
    max-width: 148rem;
    margin: 0 auto;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 3rem;
  }
}
.l-footer__logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .l-footer__logo {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__logo {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 2rem;
  }
}
@media screen and (min-width: 769px) {
  .l-footer__logo-mark {
    width: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__logo-mark {
    width: 12rem;
    margin: 0 auto;
  }
}
@media screen and (min-width: 769px) {
  .l-footer__logo-name {
    width: 38rem;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__logo-name {
    width: 28rem;
    max-width: 100%;
    margin: 0 auto;
  }
}
.l-footer__company {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .l-footer__company {
    gap: 2rem;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__company {
    -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: 2rem;
  }
}
.l-footer__company-info {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.l-footer__company-info-office {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .l-footer__company-info-office {
    gap: 2rem;
    margin-top: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__company-info-office {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1rem;
    margin-top: 2rem;
  }
}
.l-footer__company-info-office-box {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (min-width: 769px) {
  .l-footer__company-info-office-box {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__company-info-office-box {
    font-size: 1.2rem;
    width: 100%;
  }
}
.l-footer__company-info-office-box-title {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .l-footer__company-info-office-box-title {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__company-info-office-box-title {
    font-size: 1.4rem;
  }
}
.l-footer__company-info-office-box-address a {
  color: var(--color-site-main);
  font-size: 1.2rem;
}
.l-footer__company-info-office-box-address a::after {
  background-color: var(--color-site-main);
}
.l-footer__link {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 769px) {
  .l-footer__link {
    width: 30%;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__link {
    width: 100%;
  }
}
.l-footer__link-menu {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem 2rem;
}
.l-footer__link-menu li {
  width: calc((100% - 2rem) / 2);
}
.l-footer__link-menu li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  font-weight: bold;
  line-height: 1.4;
  position: relative;
  padding-bottom: 1rem;
  border-bottom: 0.2rem solid #EEE;
}
.l-footer__link-menu li a .-en {
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  font-size: 1.2rem;
}
.l-footer__link-menu li a::after {
  content: "";
  width: 100%;
  height: 0.2rem;
  display: block;
  position: absolute;
  background-color: var(--color-site-main);
  left: 0;
  bottom: -0.2rem;
  -webkit-animation: 2s;
          animation: 2s;
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
  -webkit-transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92), -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
}
@media screen and (min-width: 769px) {
  .l-footer__link-menu li a:hover::after {
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transform-origin: left top;
            transform-origin: left top;
  }
}
.l-footer__copy {
  font-family: var(--font-family-en1);
  text-align: center;
}
@media screen and (min-width: 769px) {
  .l-footer__copy {
    font-size: 1.2rem;
    margin-top: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .l-footer__copy {
    font-size: 1.1rem;
    margin-top: 4rem;
  }
}

@media screen and (min-width: 769px) {
  .l-nav {
    display: none;
    pointer-events: none;
  }
}
@media screen and (max-width: 768px) {
  .l-nav {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    overflow-y: scroll;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    opacity: 0;
    visibility: hidden;
    padding-top: var(--layout-header-sp);
    padding-bottom: 0;
    background: #FFF;
  }
  .l-nav__toggle {
    width: calc(18% + 3.6rem);
    height: 100%;
    background-color: var(--color-site-main);
    color: #FFF;
    position: absolute;
    top: 0;
    right: 0;
    cursor: pointer;
    padding: 0.2rem 1rem 0 4rem;
    -webkit-transition: 0.3s;
    transition: 0.3s;
    /*background-color: $hover_color;*/
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    z-index: 1000;
    gap: 0.5rem;
    transition: 0.3s;
    clip-path: polygon(0% 100%, calc(100% - 0rem) 100%, 100% 0%, calc(0% + 4rem) 0%);
  }
  .l-nav__toggle > div {
    position: relative;
    width: 2rem;
    height: 1rem;
    margin: 0 auto 0;
  }
  .l-nav__toggle span {
    width: 100%;
    height: 1px;
    left: 0;
    display: block;
    background: #FFF;
    position: absolute;
    -webkit-transition: top 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 300ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: top 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 300ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: top 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), transform 300ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: top 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), transform 300ms cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 300ms cubic-bezier(0.19, 1, 0.22, 1);
  }
  .l-nav__toggle span:nth-child(1) {
    top: 0;
  }
  .l-nav__toggle span:nth-child(2) {
    top: 50%;
    width: 80%;
  }
  .l-nav__toggle span:nth-child(3) {
    bottom: 0rem;
  }
  .l-nav__toggle::before {
    content: "MENU";
    font-weight: bold;
    color: #FFF;
    font-size: 0.9rem;
    letter-spacing: 0;
    display: block;
    font-family: var(--font-family-en1);
  }
  .l-nav__wrap {
    padding: 1rem 2rem 3rem;
  }
  .l-nav__contents {
    display: block;
    /*&-sns {
    	margin-top: 3rem;
    	&-list {
    		display: flex;
    		justify-content: center;
    		padding: 0 2rem;
    		gap: 1rem;
    		li {
    			width: 4rem;
    			height: auto;
    			a {
    				display: block;
    			}
    		}
    	}
    }*/
    /*&-about {
    	padding: 3rem 2rem;
    	&-logo {
    		display: flex;
    		flex-direction: column;
    		align-items: center;
    		gap:1rem;
    		padding: 0 2rem;
    		&-mark {
    			margin: 0 auto;
    			width: 40%;
    			max-width: 26rem;
    			img {
    				width: 100%;
    			}
    		}
    		&-name {
    			width: 100%;
    		}
    	}
    	&-detail {
    		margin-top: 2rem;
    		text-align: center;
    		font-size: 1.2rem;
    		small {
    			font-size: 1.2rem;
    		}
    		&-link {
    			display: flex;
    			flex-wrap: wrap;
    			justify-content: center;
    			margin-top: 2rem;
    			gap:0.5rem 2rem;
    			li {
    				a {
    					position: relative;
    					font-size: 1.2rem;
    					&::after {
    						content: "";
    						width: 100%;
    						height: 1px;
    						display: block;
    						position: absolute;
    						background-color: var(--color-site-sub);
    						left: 0;
    						bottom: -1px;
    						animation: 2s;
    						transform: scale(1, 1);

    						transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    						transform-origin: left top;
    						z-index: 1;
    					}
    				}
    			}
    		}
    	}
    }*/
  }
  .l-nav__contents-menu-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
  }
  .l-nav__contents-menu-list li {
    width: 100%;
  }
  .l-nav__contents-menu-list li a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    gap: 1rem;
    font-size: 1.6rem;
    font-weight: bold;
    line-height: 1.4;
    position: relative;
    padding: 1.8rem 1.5rem;
    border-bottom: 0.2rem solid #EEE;
  }
  .l-nav__contents-menu-list li a .-en {
    font-family: var(--font-family-en1);
    color: var(--color-site-main);
    font-size: 1.2rem;
    padding-top: 0.5rem;
  }
  .l-nav__contents-menu-list li a::before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    width: 0;
    height: 0;
    border-top: 0.5rem solid transparent;
    border-bottom: 0.5rem solid transparent;
    border-left: 0.5rem solid var(--color-site-main);
  }
  .l-nav__contents-menu-list li.-recruit, .l-nav__contents-menu-list li.-contact {
    margin-top: 2rem;
  }
  .l-nav__contents-menu-list li.-recruit a {
    background-color: var(--color-site-sub);
    color: #FFF;
  }
  .l-nav__contents-menu-list li.-recruit a .-en {
    color: #FFF;
  }
  .l-nav__contents-menu-list li.-recruit a::before {
    border-left-color: #FFF;
  }
  .l-nav__contents-menu-list li.-contact a {
    background-color: #000;
    color: #FFF;
  }
  .l-nav__contents-company {
    margin-top: 4rem;
    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: 2rem;
  }
  .l-nav__contents-company-logo {
    -ms-flex-negative: 0;
        flex-shrink: 0;
    width: 12rem;
  }
  .l-nav__contents-company-info {
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
  }
  .l-nav__contents-company-info-name {
    width: 28rem;
    max-width: 100%;
    margin: 0 auto;
  }
  .l-nav__contents-company-info-office {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1rem;
    margin-top: 2rem;
  }
  .l-nav__contents-company-info-office-box {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
    font-size: 1.2rem;
    width: 100%;
  }
  .l-nav__contents-company-info-office-box-title {
    font-weight: bold;
    font-size: 1.4rem;
  }
  body:not(.-menuOpen) .l-header.fixed {
    background: rgba(255, 255, 255, 0.95);
  }
  .-menuOpen .l-header {
    background-color: #FFF;
    z-index: 10000;
    border-radius: 0;
  }
  .-menuOpen .l-nav {
    opacity: 1;
    visibility: visible;
    z-index: 9998;
  }
  .-menuOpen .l-nav__toggle {
    border-bottom-right-radius: 0;
    background-color: #000;
  }
  .-menuOpen .l-nav__toggle span {
    background: #FFF;
    -webkit-transition: top 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: top 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: top 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms cubic-bezier(0.19, 1, 0.22, 1), transform 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1);
    transition: top 300ms cubic-bezier(0.19, 1, 0.22, 1), bottom 300ms cubic-bezier(0.19, 1, 0.22, 1), transform 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1), -webkit-transform 300ms 300ms cubic-bezier(0.19, 1, 0.22, 1);
  }
  .-menuOpen .l-nav__toggle span:nth-child(1) {
    top: 0.5rem;
    -webkit-transform: rotate(30deg);
            transform: rotate(30deg);
  }
  .-menuOpen .l-nav__toggle span:nth-child(2) {
    width: 0%;
  }
  .-menuOpen .l-nav__toggle span:nth-child(3) {
    bottom: 0.5rem;
    -webkit-transform: rotate(-30deg);
            transform: rotate(-30deg);
  }
  .-menuOpen .l-nav__toggle::before {
    content: "CLOSE";
    color: #FFF;
  }
  .-menuOpen .l-nav__wrap {
    visibility: visible;
    opacity: 1;
    overflow-y: scroll;
    display: block;
  }
  .-menuOpen .-open.l-nav__contents-menu-more {
    background-color: var(--color-site-sub);
  }
  .-menuOpen .-open.l-nav__contents-menu-more span::before, .-menuOpen .-open.l-nav__contents-menu-more span::after {
    background: #FFF;
  }
  .-menuOpen .-open.l-nav__contents-menu-more span::before {
    -webkit-transform: translate(-50%, -50%) rotate(-180deg);
            transform: translate(-50%, -50%) rotate(-180deg);
  }
  .-menuOpen .-open.-nolink span::before {
    -webkit-transform: translate(-50%, -50%) rotate(-180deg);
            transform: translate(-50%, -50%) rotate(-180deg);
  }
}
.c-shape__vertical, .c-shape__horizon {
  font-weight: bold;
  color: #FFF;
  line-height: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  font-size: 1.4rem;
  letter-spacing: 0;
  gap: 1.5rem;
  position: relative;
}
.c-shape__vertical svg, .c-shape__horizon svg {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  color: var(--color-site-main);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.c-shape__vertical .-jp, .c-shape__vertical .-en, .c-shape__horizon .-jp, .c-shape__horizon .-en {
  color: #FFF;
  position: relative;
  z-index: 1;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .c-shape__vertical .-jp, .c-shape__horizon .-jp {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical .-jp, .c-shape__horizon .-jp {
    font-size: 1.3rem;
  }
}
.c-shape__vertical .-en, .c-shape__horizon .-en {
  font-family: var(--font-family-en1);
  font-weight: 500;
  letter-spacing: 0;
}
@media screen and (min-width: 769px) {
  .c-shape__vertical .-en, .c-shape__horizon .-en {
    font-size: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical .-en, .c-shape__horizon .-en {
    font-size: 2rem;
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-title .-jp, .c-shape__horizon.-title .-jp {
    font-size: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical.-title .-jp, .c-shape__horizon.-title .-jp {
    font-size: 1.6rem;
  }
}
.c-shape__vertical.-btn, .c-shape__horizon.-btn {
  -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;
  width: 90%;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-btn, .c-shape__horizon.-btn {
    gap: 0.6rem;
    height: 6.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical.-btn, .c-shape__horizon.-btn {
    gap: 0.3rem;
    height: 5.4rem;
    -webkit-transform: translateX(-2.5%);
            transform: translateX(-2.5%);
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-btn .-jp, .c-shape__horizon.-btn .-jp {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical.-btn .-jp, .c-shape__horizon.-btn .-jp {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-btn .-en, .c-shape__horizon.-btn .-en {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical.-btn .-en, .c-shape__horizon.-btn .-en {
    font-size: 1rem;
  }
}
.c-shape__vertical.-btn::before, .c-shape__vertical.-btn::after, .c-shape__horizon.-btn::before, .c-shape__horizon.-btn::after {
  content: "";
  position: absolute;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.c-shape__vertical.-btn::before, .c-shape__horizon.-btn::before {
  width: 30%;
  height: 1px;
  right: -5%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: var(--color-site-main);
}
.c-shape__vertical.-btn::after, .c-shape__horizon.-btn::after {
  display: inline-block;
  vertical-align: middle;
  width: 0;
  height: 0;
  right: -5%;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  border-top: 0.5rem solid transparent;
  border-bottom: 0.5rem solid transparent;
  border-left: 2rem solid var(--color-site-main);
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-btn::after, .c-shape__horizon.-btn::after {
    border-top: 0.5rem solid transparent;
    border-bottom: 0.5rem solid transparent;
    border-left: 1.8rem solid var(--color-site-main);
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical.-btn::after, .c-shape__horizon.-btn::after {
    border-top: 0.5rem solid transparent;
    border-bottom: 0.5rem solid transparent;
    border-left: 1rem solid var(--color-site-main);
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-btn.-small .-jp, .c-shape__horizon.-btn.-small .-jp {
    font-size: 1.4rem;
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-btn.-small .-en, .c-shape__horizon.-btn.-small .-en {
    font-size: 1rem;
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-btn:hover svg, .c-shape__horizon.-btn:hover svg {
    color: #000;
  }
  .c-shape__vertical.-btn:hover .-jp, .c-shape__vertical.-btn:hover .-en, .c-shape__horizon.-btn:hover .-jp, .c-shape__horizon.-btn:hover .-en {
    color: var(--color-site-main);
  }
  .c-shape__vertical.-btn:hover::before, .c-shape__vertical.-btn:hover::after, .c-shape__horizon.-btn:hover::before, .c-shape__horizon.-btn:hover::after {
    -webkit-transform: translate(1rem, -50%);
            transform: translate(1rem, -50%);
  }
  .c-shape__vertical.-btn:hover::before, .c-shape__horizon.-btn:hover::before {
    background-color: #000;
  }
  .c-shape__vertical.-btn:hover::after, .c-shape__horizon.-btn:hover::after {
    border-top-width: 0.7rem;
    border-bottom-width: 0.7rem;
    border-left-color: #000;
  }
}
.c-shape__vertical.-gray svg, .c-shape__horizon.-gray svg {
  color: #656464;
}
.c-shape__vertical.-gray.-btn::before, .c-shape__horizon.-gray.-btn::before {
  background-color: #656464;
}
.c-shape__vertical.-gray.-btn::after, .c-shape__horizon.-gray.-btn::after {
  border-left-color: #656464;
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-gray.-btn:hover svg, .c-shape__horizon.-gray.-btn:hover svg {
    color: var(--color-site-main);
  }
  .c-shape__vertical.-gray.-btn:hover .-jp, .c-shape__vertical.-gray.-btn:hover .-en, .c-shape__horizon.-gray.-btn:hover .-jp, .c-shape__horizon.-gray.-btn:hover .-en {
    color: #FFF;
  }
  .c-shape__vertical.-gray.-btn:hover::before, .c-shape__vertical.-gray.-btn:hover::after, .c-shape__horizon.-gray.-btn:hover::before, .c-shape__horizon.-gray.-btn:hover::after {
    -webkit-transform: translate(1rem, -50%);
            transform: translate(1rem, -50%);
  }
  .c-shape__vertical.-gray.-btn:hover::before, .c-shape__horizon.-gray.-btn:hover::before {
    background-color: var(--color-site-main);
  }
  .c-shape__vertical.-gray.-btn:hover::after, .c-shape__horizon.-gray.-btn:hover::after {
    border-left-color: var(--color-site-main);
  }
}
.c-shape__horizon {
  aspect-ratio: 15/2;
}
@media screen and (min-width: 769px) {
  .c-shape__horizon {
    height: 7.6rem;
    padding: 0 0 0 12%;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__horizon {
    height: 4.6rem;
    padding: 0 0 0 12%;
  }
}
@media screen and (min-width: 769px) {
  .c-shape__horizon.-title .-jp {
    letter-spacing: 0.3rem;
  }
}
.c-shape__vertical {
  aspect-ratio: 2/15;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
@media screen and (min-width: 769px) {
  .c-shape__vertical {
    width: 7.6rem;
    padding: 6.5rem 0 0 0;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical {
    width: 4.6rem;
    padding: 5rem 0 0 0;
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical .-jp {
    letter-spacing: 0.3rem;
  }
}
@media screen and (max-width: 768px) {
  .c-shape__vertical .-jp {
    letter-spacing: 0.2rem;
  }
}
@media screen and (min-width: 769px) {
  .c-shape__vertical.-title .-jp {
    letter-spacing: 0.8rem;
  }
}
@media screen and (min-width: 769px) {
  .c-shape a.c-shape__vertical:hover svg, .c-shape a.c-shape__horizon:hover svg {
    color: #000;
  }
  .c-shape a.c-shape__vertical:hover .-jp, .c-shape a.c-shape__vertical:hover .-en, .c-shape a.c-shape__horizon:hover .-jp, .c-shape a.c-shape__horizon:hover .-en {
    color: var(--color-site-main);
  }
}

@media screen and (min-width: 769px) {
  .c-path {
    padding: 1.5rem 0;
  }
}
@media screen and (max-width: 768px) {
  .c-path {
    padding: 1rem 0;
  }
}
.c-path__list {
  width: 100%;
  display: block;
  overflow-x: hidden;
  white-space: nowrap;
  text-overflow: ellipsis;
}
.c-path__list li {
  display: inline;
}
@media screen and (min-width: 769px) {
  .c-path__list li {
    font-size: 1.5rem;
    padding: 0 1rem 0 0;
  }
}
@media screen and (max-width: 768px) {
  .c-path__list li {
    font-size: 1.3rem;
    padding: 0 0.3rem 0 0;
  }
}
.c-path__list li a {
  color: #009541;
}
.c-path__list li a:hover {
  color: #000;
}
.c-path__list li:not(:last-of-type)::after {
  content: "";
  background: url("../images/common/icon_arrow1.svg") no-repeat;
  background-size: contain;
  width: 1rem;
  height: 1rem;
  display: inline-block;
}
@media screen and (min-width: 769px) {
  .c-path__list li:not(:last-of-type)::after {
    margin-left: 1.3rem;
  }
}
@media screen and (max-width: 768px) {
  .c-path__list li:not(:last-of-type)::after {
    margin-left: 0.8rem;
  }
}

.c-recruit {
  background-color: var(--color-site-main);
  position: relative;
  display: block;
}
@media screen and (min-width: 769px) {
  .c-recruit {
    padding: 6rem 0 8rem;
    overflow: hidden;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit {
    padding: 4rem 2rem 0;
    margin-bottom: 2rem;
  }
}
.c-recruit::before {
  content: "";
  display: block;
  position: absolute;
  left: 0px;
  top: 0px;
  width: 100%;
  height: 100%;
  background-image: -webkit-gradient(linear, left top, left bottom, from(#000), to(#000));
  background-image: linear-gradient(#000, #000);
  background-size: 0px 100%;
  background-repeat: no-repeat;
  -webkit-box-decoration-break: slice;
          box-decoration-break: slice;
  background-position: right bottom;
  -webkit-transition: background-size 0.4s ease-out;
  transition: background-size 0.4s ease-out;
}
.c-recruit:hover::before {
  background-size: 100% 100%;
  background-position: left bottom;
}
.c-recruit__wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .c-recruit__wrapper {
    max-width: var(--layout-container);
    width: 100%;
    padding: 0 3rem;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.c-recruit__detail, .c-recruit__img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (min-width: 769px) {
  .c-recruit__detail, .c-recruit__img {
    width: 50%;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__detail, .c-recruit__img {
    width: 100%;
  }
}
.c-recruit__detail {
  color: #FFF;
}
.c-recruit__detail-title {
  font-weight: bold;
  line-height: 1.1;
}
@media screen and (min-width: 769px) {
  .c-recruit__detail-title {
    font-size: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__detail-title {
    font-size: 3.4rem;
  }
}
.c-recruit__detail-title span {
  font-family: var(--font-family-en1);
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .c-recruit__detail-title span {
    font-size: 8.6rem;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__detail-title span {
    font-size: 4.8rem;
  }
}
.c-recruit__detail-text {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .c-recruit__detail-text {
    font-size: 1.6rem;
    margin-top: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__detail-text {
    font-size: 1.4rem;
    margin-top: 2rem;
  }
}
.c-recruit__img {
  position: relative;
}
@media screen and (max-width: 768px) {
  .c-recruit__img {
    margin-top: 2rem;
  }
}
.c-recruit__img .-img01, .c-recruit__img .-img02, .c-recruit__img .-img03 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .c-recruit__img .-img01, .c-recruit__img .-img02, .c-recruit__img .-img03 {
    width: 55%;
    height: auto;
    position: absolute;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__img .-img01, .c-recruit__img .-img02, .c-recruit__img .-img03 {
    width: 55%;
  }
}
.c-recruit__img .-img01 {
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .c-recruit__img .-img01 {
    left: -12rem;
    bottom: -6rem;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__img .-img01 {
    margin-left: 20%;
  }
}
@media screen and (min-width: 769px) {
  .c-recruit__img .-img02 {
    left: 0;
    top: -4rem;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__img .-img02 {
    margin-top: -1rem;
    z-index: 2;
  }
}
@media screen and (min-width: 769px) {
  .c-recruit__img .-img03 {
    right: -3rem;
    top: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .c-recruit__img .-img03 {
    margin-top: -6rem;
    margin-bottom: -2rem;
    margin-left: 45%;
  }
}

.c-pagetop {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 12rem;
  height: 6rem;
  background-color: var(--color-site-main);
  position: fixed;
  right: 2rem;
  bottom: 2rem;
  z-index: 98;
  pointer-events: none;
  cursor: pointer;
  opacity: 0;
  clip-path: polygon(0% 100%, 70% 100%, 100% 0%, 30% 0%);
  -webkit-transform: scale(1.5);
          transform: scale(1.5);
  -webkit-transition: all 0.5s;
  transition: all 0.5s;
}
@media screen and (max-width: 768px) {
  .c-pagetop {
    width: 8rem;
    height: 4rem;
    bottom: 1rem;
    right: 1rem;
  }
}
.c-pagetop::before {
  content: "";
  display: block;
  position: absolute;
  top: 0.5rem;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  width: 1.3rem;
  height: 1.3rem;
  border-left: 0.2rem solid #FFF;
  border-top: 0.2rem solid #FFF;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
@media screen and (max-width: 768px) {
  .c-pagetop::before {
    width: 1rem;
    height: 1rem;
    border-left-width: 1px;
    border-top-width: 1px;
  }
}
.c-pagetop.-show {
  opacity: 1;
  -webkit-transform: scale(1);
          transform: scale(1);
  pointer-events: auto;
}
@media screen and (min-width: 769px) {
  .c-pagetop:hover {
    background-color: #000;
  }
  .c-pagetop:hover::before {
    border-left: 0.3rem solid var(--color-site-main);
    border-top: 0.3rem solid var(--color-site-main);
  }
}

@media screen and (min-width: 769px) {
  .c-single__section {
    padding: 2rem 0 8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__section {
    padding: 1rem 0 4rem;
  }
}
.c-single__body {
  background-color: #FFF;
}
@media screen and (min-width: 769px) {
  .c-single__body {
    padding: 6rem 8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body {
    padding: 2rem;
  }
}
.c-single__body-meta {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (min-width: 769px) {
  .c-single__body-meta {
    gap: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-meta {
    gap: 0.8rem 2rem;
  }
}
.c-single__body-meta-data {
  font-family: var(--font-family-en1);
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .c-single__body-meta-data {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-meta-data {
    font-size: 1.5rem;
  }
}
.c-single__body-meta-category {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (min-width: 769px) {
  .c-single__body-meta-category {
    gap: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-meta-category {
    gap: 0.7rem;
  }
}
.c-single__body-meta-category a {
  text-align: center;
  border: 1px solid var(--color-site-main);
  background-color: #FFF;
  color: var(--color-site-main);
  border-radius: 10rem;
  font-weight: bold;
  line-height: 1.2;
}
@media screen and (min-width: 769px) {
  .c-single__body-meta-category a {
    font-size: 1.2rem;
    padding: 0.3rem 2rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-meta-category a {
    font-size: 1rem;
    padding: 0.2rem 1.6rem;
  }
}
@media screen and (min-width: 769px) {
  .c-single__body-meta-category a:hover {
    background: var(--color-site-main);
    color: #FFF;
  }
}
.c-single__body-title {
  padding-bottom: 1.5rem;
  border-bottom: 1px solid #333;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .c-single__body-title {
    font-size: 2.8rem;
    margin-top: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-title {
    font-size: 1.8rem;
    margin-top: 1rem;
  }
}
.c-single__body-contents {
  word-wrap: break-word;
}
@media screen and (min-width: 769px) {
  .c-single__body-contents {
    margin-top: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-contents {
    margin-top: 2rem;
  }
}
.c-single__body-contents h2 {
  font-size: 2.2rem;
  font-weight: bold;
  background-color: var(--color-site-main);
  padding: 1rem 2rem;
  margin: 6rem 0 3rem;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents h2 {
    font-size: 1.6rem;
    padding: 1.2rem 1.2rem;
    margin: 4rem auto 1.5rem;
  }
}
.c-single__body-contents h3 {
  font-size: 2rem;
  font-weight: bold;
  border-bottom: 0.3rem solid #EEE;
  padding-bottom: 2rem;
  margin: 5rem 0 2rem;
  position: relative;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents h3 {
    font-size: 1.6rem;
    padding-bottom: 1.5rem;
    margin: 3rem auto 1.5rem;
  }
}
.c-single__body-contents h3:before {
  content: "";
  position: absolute;
  display: block;
  width: 10rem;
  height: 0.3rem;
  bottom: -0.3rem;
  left: 0;
  background-color: var(--color-site-main);
}
.c-single__body-contents p {
  margin: 2rem 0;
  line-height: 2;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents p {
    font-size: 1.3rem;
  }
}
.c-single__body-contents p a {
  color: var(--color-site-main);
  position: relative;
  display: inline;
}
.c-single__body-contents p a:hover {
  color: #000;
}
.c-single__body-contents p a[target=_blank]:after {
  content: url("../images/common/icon_blank.svg");
  width: 1.2rem;
  height: auto;
  display: inline-block;
  margin-left: 0.5rem;
}
.c-single__body-contents p a::before {
  content: "";
  width: 100%;
  height: 1px;
  display: block;
  position: absolute;
  background-color: var(--color-site-main);
  left: 0;
  bottom: -1px;
  -webkit-animation: 2s;
          animation: 2s;
  -webkit-transform: scale(1, 1);
          transform: scale(1, 1);
  -webkit-transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92), -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}
.c-single__body-contents p a:hover::before {
  -webkit-transform: scale(0, 1);
          transform: scale(0, 1);
  -webkit-transform-origin: right top;
          transform-origin: right top;
}
.c-single__body-contents .wp-block-image img, .c-single__body-contents img {
  max-width: 100%;
  display: block;
}
@media screen and (min-width: 769px) {
  .c-single__body-contents .wp-block-image img, .c-single__body-contents img {
    margin: 4rem auto;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-image img, .c-single__body-contents img {
    margin: 2rem auto;
    max-width: 100%;
  }
}
.c-single__body-contents .wp-block-image figcaption {
  font-size: 1.4rem;
  text-align: center;
  color: #777;
  margin-top: -3rem;
  margin-bottom: 4rem;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-image figcaption {
    font-size: 1.2rem;
  }
}
.c-single__body-contents .wp-block-group__inner-container {
  border: 1px solid #CCC;
  padding: 2rem;
  margin: 3rem auto;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-group__inner-container {
    padding: 1.5rem;
  }
}
.c-single__body-contents .wp-block-group ul {
  margin: 0;
}
.c-single__body-contents .wp-block-group p:first-child {
  margin-top: 0;
}
.c-single__body-contents .wp-block-group p:last-child {
  margin-bottom: 0;
}
.c-single__body-contents ul {
  margin: 3rem auto;
  background: var(--color-bg-gray-light);
  padding: 2rem;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents ul li {
    font-size: 1.3rem;
  }
}
.c-single__body-contents ul li:before {
  content: "・";
}
.c-single__body-contents .wp-block-my-plugin-gray-box {
  background-color: #EFEFEF;
  padding: 2rem;
  margin: 3rem auto;
}
.c-single__body-contents .wp-block-table table {
  margin: 3rem auto;
  width: 100%;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-table table {
    margin: 2rem auto;
  }
}
.c-single__body-contents .wp-block-table table thead {
  border: none;
}
.c-single__body-contents .wp-block-table table tr {
  border-top: 1px solid #CCC;
}
.c-single__body-contents .wp-block-table table tr:last-child {
  border-bottom: 1px solid #CCC;
}
.c-single__body-contents .wp-block-table table tr td, .c-single__body-contents .wp-block-table table tr th {
  padding: 2rem 1.5rem;
  border: none;
  border-left: 1px dotted #CCC;
  vertical-align: middle;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-table table tr td, .c-single__body-contents .wp-block-table table tr th {
    padding: 1.2rem 0.6rem;
    font-size: 1.2rem;
  }
}
.c-single__body-contents .wp-block-table table tr td:first-child {
  border-left: none;
  /*font-weight: bold;
  text-align: center;
  background-color: #F2F5F8;*/
}
.c-single__body-contents .wp-block-table table tr th {
  padding: 1rem;
  background-color: var(--color-site-main);
  font-weight: bold;
  color: #FFF;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-table table tr th {
    padding: 1rem 1rem;
  }
}
.c-single__body-contents .wp-block-table table tr th:first-child {
  border-left: none;
}
.c-single__body-contents .wp-block-embed-youtube {
  margin: 3rem auto;
}
@media screen and (min-width: 769px) {
  .c-single__body-contents .wp-block-embed-youtube {
    width: 100%;
  }
}
.c-single__body-contents .wp-block-embed-youtube .wp-block-embed__wrapper {
  width: 100%;
  aspect-ratio: 16/9;
}
.c-single__body-contents .wp-block-embed-youtube iframe {
  width: 100%;
  height: 100%;
}
.c-single__body-contents em {
  font-style: normal;
  background: -webkit-gradient(linear, left top, left bottom, color-stop(75%, transparent), color-stop(75%, #7cffcc));
  background: linear-gradient(transparent 75%, #7cffcc 75%);
}
.c-single__body-contents strong {
  font-weight: bold;
}
.c-single__body-contents figcaption {
  margin-top: -1rem;
  color: #777;
  font-size: 1.4rem;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents figcaption {
    font-size: 1.2rem;
  }
}
.c-single__body-contents .wp-embedded-content {
  width: 100%;
}
.c-single__body-contents .wp-embed-footer {
  display: none;
}
.c-single__body-contents .wp-block-buttons {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin: 4rem auto;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-buttons {
    margin: 3rem auto;
  }
}
.c-single__body-contents .wp-block-button {
  margin: 3rem auto;
  position: relative;
  text-align: center;
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-button {
    width: 100%;
    margin-top: 2rem;
    text-align: center;
  }
}
.c-single__body-contents .wp-block-button a {
  color: #FFF;
  font-size: 1.8rem;
  background-color: #000;
  border: 1px solid #000;
  line-height: 1.6;
  position: relative;
  /*border-radius: 5px;*/
  padding: 2.5rem 5rem;
  max-width: 60rem;
  width: 100%;
  /*-webkit-transition: all 0.5s;*/
  -webkit-transition: 0.01s 0.23s ease-out all;
  transition: 0.01s 0.23s ease-out all;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  display: inline-block;
  font-weight: 500;
  overflow: hidden;
  position: relative;
  border-radius: 0;
}
@media screen and (min-width: 769px) {
  .c-single__body-contents .wp-block-button a {
    min-width: 30rem;
  }
  .c-single__body-contents .wp-block-button a:hover {
    background-color: #FFF;
  }
}
@media screen and (max-width: 768px) {
  .c-single__body-contents .wp-block-button a {
    padding: 2rem 2rem;
    font-size: 1.4rem;
    width: 100%;
  }
}
.c-single__body-contents .wp-block-button a::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 2rem;
  margin: auto;
  width: 0.8rem;
  height: 0.8rem;
  border-left: 1px solid #FFF;
  border-top: 1px solid #FFF;
  -webkit-transform: translateY(-50%) rotate(135deg);
          transform: translateY(-50%) rotate(135deg);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .c-single__body-contents .wp-block-button a:hover {
    color: #000;
  }
  .c-single__body-contents .wp-block-button a:hover:before {
    border-color: #000;
    right: 1rem;
  }
}
.c-single__body-btn {
  margin-top: 6rem;
}

.c-pagenavi {
  margin-top: 6rem;
}
.c-pagenavi .wp-pagenavi {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .c-pagenavi .wp-pagenavi {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  .c-pagenavi .wp-pagenavi {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.c-pagenavi .wp-pagenavi .pages {
  display: none;
}
.c-pagenavi .wp-pagenavi a, .c-pagenavi .wp-pagenavi span {
  width: 5rem;
  height: 5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin: 0 0.5rem 0.5rem;
  border: 1px solid var(--color-bg-gray-base);
  font-family: var(--font-family-en1);
  -webkit-box-ordinal-group: 2;
      -ms-flex-order: 1;
          order: 1;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (max-width: 768px) {
  .c-pagenavi .wp-pagenavi a, .c-pagenavi .wp-pagenavi span {
    width: 4.6rem;
    height: 4.6rem;
  }
}
.c-pagenavi .wp-pagenavi a.current, .c-pagenavi .wp-pagenavi span.current {
  background: var(--color-site-main);
  border: 1px solid var(--color-site-main);
  color: #FFF;
}
.c-pagenavi .wp-pagenavi a {
  -webkit-box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.1);
          box-shadow: 1px 1px 5px rgba(0, 0, 0, 0.1);
  background-color: #FFF;
}
@media screen and (min-width: 769px) {
  .c-pagenavi .wp-pagenavi a:hover {
    background: #000;
    color: #FFF;
  }
}
@media screen and (max-width: 768px) {
  .c-pagenavi .wp-pagenavi a:hover {
    border: 1px solid var(--color-bg-gray-base);
  }
}
.c-pagenavi .wp-pagenavi .previouspostslink, .c-pagenavi .wp-pagenavi .nextpostslink, .c-pagenavi .wp-pagenavi .extend {
  border: none;
  font-size: 1.4rem;
}
.c-pagenavi .wp-pagenavi .previouspostslink, .c-pagenavi .wp-pagenavi .nextpostslink {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background: none;
  -webkit-box-shadow: none;
          box-shadow: none;
  border-bottom: 0.2rem solid #FFF;
}
.c-pagenavi .wp-pagenavi .previouspostslink::before, .c-pagenavi .wp-pagenavi .nextpostslink::before {
  content: "";
  display: inline-block;
  vertical-align: middle;
  color: #333;
  line-height: 1;
  width: 0.6rem;
  height: 0.6rem;
  border: 0.1em solid currentColor;
  border-left: 0;
  border-bottom: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-transform: translateX(-25%) rotate(225deg);
          transform: translateX(-25%) rotate(225deg);
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
.c-pagenavi .wp-pagenavi .previouspostslink:hover, .c-pagenavi .wp-pagenavi .nextpostslink:hover {
  background: none;
  border-bottom: 0.2rem solid var(--color-site-main);
}
.c-pagenavi .wp-pagenavi .previouspostslink:hover::before, .c-pagenavi .wp-pagenavi .nextpostslink:hover::before {
  border-color: var(--color-site-main);
  -webkit-transform: translateX(-40%) rotate(225deg) scale(1.4);
          transform: translateX(-40%) rotate(225deg) scale(1.4);
}
@media screen and (max-width: 768px) {
  .c-pagenavi .wp-pagenavi .previouspostslink, .c-pagenavi .wp-pagenavi .nextpostslink {
    display: none;
  }
}
.c-pagenavi .wp-pagenavi .extend {
  margin: 0;
  width: auto;
}
.c-pagenavi .wp-pagenavi .previouspostslink {
  -webkit-box-ordinal-group: 1;
      -ms-flex-order: 0;
          order: 0;
}
.c-pagenavi .wp-pagenavi .nextpostslink {
  -webkit-box-ordinal-group: 3;
      -ms-flex-order: 2;
          order: 2;
}
.c-pagenavi .wp-pagenavi .nextpostslink::before {
  -webkit-transform: translateX(-25%) rotate(45deg);
          transform: translateX(-25%) rotate(45deg);
}
.c-pagenavi .wp-pagenavi .nextpostslink:hover::before {
  border-color: var(--color-site-main);
  -webkit-transform: translateX(-5%) rotate(45deg) scale(1.4);
          transform: translateX(-5%) rotate(45deg) scale(1.4);
}

input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

textarea {
  resize: vertical;
}

input[type=checkbox],
input[type=radio] {
  display: none;
}

input[type=submit],
input[type=button],
label,
button,
select {
  cursor: pointer;
}

input:-webkit-autofill {
  -webkit-transition: background-color 5000s ease-in-out 0s !important;
  transition: background-color 5000s ease-in-out 0s !important;
}

input[type=text], textarea, select {
  background: #f5f5f5;
  font-size: 1.8rem;
  background-color: #f5f5f5;
  color: #000;
}

input[type=text], textarea {
  padding: 2rem;
  width: 100%;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
@media screen and (max-width: 768px) {
  input[type=text], textarea {
    font-size: 1.6rem;
    padding: 1.5rem;
  }
}
input[type=text]::-webkit-input-placeholder, textarea::-webkit-input-placeholder {
  color: #CCC;
  font-weight: normal;
}
input[type=text]::-moz-placeholder, textarea::-moz-placeholder {
  color: #CCC;
  font-weight: normal;
}
input[type=text]:-ms-input-placeholder, textarea:-ms-input-placeholder {
  color: #CCC;
  font-weight: normal;
}
input[type=text]::-ms-input-placeholder, textarea::-ms-input-placeholder {
  color: #CCC;
  font-weight: normal;
}
input[type=text]::placeholder, textarea::placeholder {
  color: #CCC;
  font-weight: normal;
}

input[type=checkbox] {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  display: none;
}

input[type=checkbox] + span, input[type=radio] + span {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: relative;
  cursor: pointer;
  padding: 0.5rem 0;
  margin-bottom: 0.5rem;
  margin-left: 1rem;
  font-size: 1.6rem;
}
@media screen and (max-width: 768px) {
  input[type=checkbox] + span, input[type=radio] + span {
    font-size: 1.4rem;
    text-align: left;
    margin-left: 0;
  }
}

input[type=checkbox] + span:before, input[type=radio] + span:before {
  content: "";
  display: inline-block;
  width: 3.5rem;
  height: 3.5rem;
  background-color: #FFF;
  border: 2px solid #CCC;
  margin-right: 1.5rem;
  font-weight: 400;
}
@media screen and (max-width: 768px) {
  input[type=checkbox] + span:before, input[type=radio] + span:before {
    width: 3rem;
    height: 3rem;
    margin-right: 1rem;
  }
}

input[type=checkbox]:checked + span:before, input[type=radio]:checked + span:before {
  background-color: var(--color-site-main);
  border: 2px solid #FFF;
}

input[type=checkbox]:checked + span:after, input[type=radio]:checked + span:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 0.8rem;
  width: 2rem;
  height: 1rem;
  border-left: 0.3rem solid #FFF;
  border-bottom: 0.3rem solid #FFF;
  -webkit-transform: translateY(-80%) rotate(-45deg);
          transform: translateY(-80%) rotate(-45deg);
}
@media screen and (max-width: 768px) {
  input[type=checkbox]:checked + span:after, input[type=radio]:checked + span:after {
    border-left: 0.2rem solid #FFF;
    border-bottom: 0.2rem solid #FFF;
    width: 1.6rem;
    height: 0.8rem;
    left: 0.6rem;
  }
}

select {
  width: 100%;
  display: block;
  padding: 2rem;
}
@media screen and (max-width: 768px) {
  select {
    font-size: 1.6rem;
    padding: 1.5rem;
  }
}

.c-contact__form {
  background-color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 769px) {
  .c-contact__form {
    margin-top: 0rem;
    padding: 6rem 8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form {
    margin-top: 0rem;
    padding: 2rem;
  }
}
.c-contact__form .select_box {
  position: relative;
}
.c-contact__form .select_box::after {
  position: absolute;
  content: "";
  vertical-align: middle;
  right: 5%;
  width: 0.8rem;
  height: 0.8rem;
  border-top: 1px solid #000;
  border-right: 1px solid #000;
  -webkit-transform: rotate(-225deg);
  transform: rotate(-225deg);
  margin-top: -0.4rem;
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}
@media screen and (min-width: 769px) {
  .c-contact__form .select_box::after {
    top: 3.5rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form .select_box::after {
    top: 2.5rem;
  }
}
.c-contact__form-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-bottom: 1px solid #EFEFEF;
}
@media screen and (min-width: 769px) {
  .c-contact__form-item {
    margin-bottom: 2rem;
    padding-bottom: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-item {
    margin-bottom: 1.5rem;
    padding-bottom: 1.5rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1rem;
  }
}
.c-contact__form-item-header {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .c-contact__form-item-header {
    width: 30%;
    padding-top: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-item-header {
    width: 100%;
  }
}
.c-contact__form-item-header p {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1rem;
  font-size: 1.8rem;
}
@media screen and (min-width: 769px) {
  .c-contact__form-item-header p {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-item-header p {
    font-size: 1.6rem;
  }
}
.c-contact__form-item-header p .-mandatory {
  border: 1px solid var(--color-site-sub);
  color: var(--color-site-sub);
  font-weight: bold;
  line-height: 1.2;
}
@media screen and (min-width: 769px) {
  .c-contact__form-item-header p .-mandatory {
    font-size: 1.2rem;
    padding: 0.2rem 1rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-item-header p .-mandatory {
    font-size: 1.1rem;
    padding: 0.3rem 1.5rem;
  }
}
.c-contact__form-item-body {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.c-contact__form-item-body p {
  margin-bottom: 1rem;
}
.c-contact__form-policy {
  text-align: center;
  margin-top: 2rem;
}
@media screen and (max-width: 768px) {
  .c-contact__form-policy {
    margin-top: 1rem;
  }
}
.c-contact__form-policy label {
  display: inline-block;
}
.c-contact__form-policy a {
  color: var(--color-site-main);
  margin-top: 1rem;
  display: inline-block;
}
.c-contact__form-policy a:hover {
  color: #000;
}
.c-contact__form-policy-body-frame {
  border: 1px solid #DDD;
  overflow-y: scroll;
  text-align: left;
}
@media screen and (min-width: 769px) {
  .c-contact__form-policy-body-frame {
    padding: 4rem;
    margin: 2rem 0 4rem;
    height: 30rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-policy-body-frame {
    padding: 2rem;
    margin: 0 0 2rem;
    height: 24rem;
  }
}
@media screen and (min-width: 769px) {
  .c-contact__form-policy-body-frame p + p {
    font-size: 1.4rem;
    margin-top: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-policy-body-frame p + p {
    font-size: 1.2rem;
    margin-top: 0.5rem;
  }
}
.c-contact__form-policy-body-frame .-border {
  border-bottom: 1px solid #CCC;
  padding-bottom: 0.6rem;
  margin-top: 2rem;
}
@media screen and (min-width: 769px) {
  .c-contact__form-policy-body-frame .-border {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-policy-body-frame .-border {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 769px) {
  .c-contact__form-policy-body-frame .u-font-bold {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-policy-body-frame .u-font-bold {
    font-size: 1.4rem;
  }
}
.c-contact__form-btn {
  margin-top: 5rem;
}
@media screen and (max-width: 768px) {
  .c-contact__form-btn {
    margin-top: 4rem;
    width: 100%;
  }
}
.c-contact__form-btn a, .c-contact__form-btn input {
  max-width: none;
  margin: 0 auto;
  background-color: #000;
  border: 1px solid #000;
  color: #FFF;
  display: block;
  font-family: var(--font-family-jp);
  font-weight: bold;
  width: 100%;
  padding: 2rem 0;
  letter-spacing: 2px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .c-contact__form-btn a, .c-contact__form-btn input {
    max-width: 60rem;
    height: 8rem;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .c-contact__form-btn a, .c-contact__form-btn input {
    font-size: 1.6rem;
  }
}
@media screen and (min-width: 769px) {
  .c-contact__form-btn a:hover, .c-contact__form-btn input:hover {
    background-color: #FFF;
    color: #000;
  }
}

.mw_wp_form .error {
  font-weight: bold;
  font-size: 1.6rem !important;
  color: var(--color-site-sub) !important;
  margin-top: 0.5rem;
}

.mw_wp_form_confirm .c-main {
  display: none;
}
.mw_wp_form_confirm .-input {
  display: none;
}
.mw_wp_form_confirm .select_box::after {
  content: none;
}
.mw_wp_form_confirm .c-contact__form-item-header {
  padding-top: 0;
}
@media screen and (min-width: 769px) {
  .mw_wp_form_confirm .c-contact__form-item-header {
    padding: 1rem 0;
  }
}
.mw_wp_form_confirm .c-contact__form-item-header p {
  font-weight: normal;
}
@media screen and (min-width: 769px) {
  .mw_wp_form_confirm .c-contact__form-item-header p {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .mw_wp_form_confirm .c-contact__form-item-header p {
    font-size: 1.2rem;
  }
}
.mw_wp_form_confirm .c-contact__form-item-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .mw_wp_form_confirm .c-contact__form-item-body {
    font-size: 1.8rem;
    padding: 1rem 0;
  }
}
@media screen and (max-width: 768px) {
  .mw_wp_form_confirm .c-contact__form-item-body {
    font-size: 1.6rem;
  }
}
.mw_wp_form_confirm .c-contact__form-policy {
  display: none;
}
.mw_wp_form_confirm input.back_input {
  width: auto;
  height: auto;
  background: none;
  margin-top: 3rem;
  padding: 0;
  cursor: pointer;
  font-family: var(--font-family-jp);
  font-size: 1.6rem;
  color: var(--color-site-main);
  -webkit-transition: 0.3s;
  transition: 0.3s;
  border: none;
  text-decoration: underline;
}
@media screen and (max-width: 768px) {
  .mw_wp_form_confirm input.back_input {
    font-size: 1.4rem;
    margin-top: 1.5rem;
  }
}
.form_complete .c-main {
  display: none;
}
@media screen and (min-width: 769px) {
  .form_complete .c-contact__form {
    text-align: center;
  }
}
.form_complete .c-contact__form .-title {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .form_complete .c-contact__form .-title {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 768px) {
  .form_complete .c-contact__form .-title {
    font-size: 1.8rem;
  }
}
.form_complete .c-contact__form .-text {
  margin-top: 2rem;
}

.-animation-fadeup {
  opacity: 0;
}
.-animation-fadeup.-inview {
  -webkit-animation: animation-fadeup 1.5s 0.3s cubic-bezier(0.19, 1, 0.22, 1) forwards;
          animation: animation-fadeup 1.5s 0.3s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

.-animation-fadeup-group .-animation-fadeup-group-item1, .-animation-fadeup-group .-animation-fadeup-group-item2, .-animation-fadeup-group .-animation-fadeup-group-item3, .-animation-fadeup-group .-animation-fadeup-group-item4 {
  opacity: 0;
}
.-animation-fadeup-group.-inview .-animation-fadeup-group-item1 {
  -webkit-animation: animation-fadeup 1.5s 0.3s cubic-bezier(0.19, 1, 0.22, 1) forwards;
          animation: animation-fadeup 1.5s 0.3s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}
.-animation-fadeup-group.-inview .-animation-fadeup-group-item2 {
  -webkit-animation: animation-fadeup 1.5s 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
          animation: animation-fadeup 1.5s 0.5s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}
.-animation-fadeup-group.-inview .-animation-fadeup-group-item3 {
  -webkit-animation: animation-fadeup 1.5s 0.7s cubic-bezier(0.19, 1, 0.22, 1) forwards;
          animation: animation-fadeup 1.5s 0.7s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}
.-animation-fadeup-group.-inview .-animation-fadeup-group-item4 {
  -webkit-animation: animation-fadeup 1.5s 0.9s cubic-bezier(0.19, 1, 0.22, 1) forwards;
          animation: animation-fadeup 1.5s 0.9s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

@-webkit-keyframes animation-fadeup {
  0% {
    -webkit-transform: translateY(5rem);
            transform: translateY(5rem);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0rem);
            transform: translateY(0rem);
    opacity: 1;
  }
}

@keyframes animation-fadeup {
  0% {
    -webkit-transform: translateY(5rem);
            transform: translateY(5rem);
    opacity: 0;
  }
  100% {
    -webkit-transform: translateY(0rem);
            transform: translateY(0rem);
    opacity: 1;
  }
}
.-animation-img-blur {
  overflow: hidden;
  -webkit-transform: scale(1.2);
          transform: scale(1.2);
  opacity: 1;
  -webkit-filter: blur(2rem);
          filter: blur(2rem);
}
.-animation-img-blur.-inview {
  -webkit-animation: animation-img-blur 1s 0.1s cubic-bezier(0.19, 1, 0.22, 1) forwards;
          animation: animation-img-blur 1s 0.1s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}
.-animation-img-blur.-center {
  -webkit-transform: translateX(-50%) scale(1.2);
          transform: translateX(-50%) scale(1.2);
}
.-animation-img-blur.-center.-inview {
  -webkit-animation: animation-img-blur-center 1s 0.1s cubic-bezier(0.19, 1, 0.22, 1) forwards;
          animation: animation-img-blur-center 1s 0.1s cubic-bezier(0.19, 1, 0.22, 1) forwards;
}

@-webkit-keyframes animation-img-blur {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
    -webkit-filter: blur(2rem);
            filter: blur(2rem);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}

@keyframes animation-img-blur {
  0% {
    -webkit-transform: scale(1.2);
            transform: scale(1.2);
    -webkit-filter: blur(2rem);
            filter: blur(2rem);
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
@-webkit-keyframes animation-img-blur-center {
  0% {
    -webkit-transform: translateX(-50%) scale(1.2);
            transform: translateX(-50%) scale(1.2);
    -webkit-filter: blur(2rem);
            filter: blur(2rem);
  }
  100% {
    -webkit-transform: translateX(-50%) scale(1);
            transform: translateX(-50%) scale(1);
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
@keyframes animation-img-blur-center {
  0% {
    -webkit-transform: translateX(-50%) scale(1.2);
            transform: translateX(-50%) scale(1.2);
    -webkit-filter: blur(2rem);
            filter: blur(2rem);
  }
  100% {
    -webkit-transform: translateX(-50%) scale(1);
            transform: translateX(-50%) scale(1);
    -webkit-filter: blur(0);
            filter: blur(0);
  }
}
@-webkit-keyframes loop {
  0% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes loop {
  0% {
    -webkit-transform: translateX(100%);
            transform: translateX(100%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes loop-next {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}
@keyframes loop-next {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0);
  }
  to {
    -webkit-transform: translateX(-200%);
            transform: translateX(-200%);
  }
}
@-webkit-keyframes animation-rotate {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@keyframes animation-rotate {
  0% {
    -webkit-transform: rotate(0deg);
            transform: rotate(0deg);
  }
  100% {
    -webkit-transform: rotate(360deg);
            transform: rotate(360deg);
  }
}
@-webkit-keyframes animation-loop-left {
  0% {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@keyframes animation-loop-left {
  0% {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
  }
  to {
    -webkit-transform: translateX(-100%);
            transform: translateX(-100%);
  }
}
@-webkit-keyframes animation-loop-up {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@keyframes animation-loop-up {
  0% {
    -webkit-transform: translateY(0%);
            transform: translateY(0%);
  }
  to {
    -webkit-transform: translateY(-100%);
            transform: translateY(-100%);
  }
}
@-webkit-keyframes animation-loop-down {
  0% {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  to {
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
}
@keyframes animation-loop-down {
  0% {
    -webkit-transform: translateY(-50%);
            transform: translateY(-50%);
  }
  to {
    -webkit-transform: translateY(50%);
            transform: translateY(50%);
  }
}
@-webkit-keyframes upDown {
  0%, 100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(1rem);
            transform: translateY(1rem);
  }
}
@keyframes upDown {
  0%, 100% {
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  50% {
    -webkit-transform: translateY(1rem);
            transform: translateY(1rem);
  }
}
.u-mt0 {
  margin-top: 0rem !important;
}

.u-mb0 {
  margin-bottom: 0rem !important;
}

.u-mr0 {
  margin-right: 0rem !important;
}

.u-ml0 {
  margin-left: 0rem !important;
}

.u-pt0 {
  padding-top: 0rem !important;
}

.u-pb0 {
  padding-bottom: 0rem !important;
}

.u-pr0 {
  padding-right: 0rem !important;
}

.u-pl0 {
  padding-left: 0rem !important;
}

.u-mt5 {
  margin-top: 0.5rem !important;
}

.u-mb5 {
  margin-bottom: 0.5rem !important;
}

.u-mr5 {
  margin-right: 0.5rem !important;
}

.u-ml5 {
  margin-left: 0.5rem !important;
}

.u-pt5 {
  padding-top: 0.5rem !important;
}

.u-pb5 {
  padding-bottom: 0.5rem !important;
}

.u-pr5 {
  padding-right: 0.5rem !important;
}

.u-pl5 {
  padding-left: 0.5rem !important;
}

.u-mt10 {
  margin-top: 1rem !important;
}

.u-mb10 {
  margin-bottom: 1rem !important;
}

.u-mr10 {
  margin-right: 1rem !important;
}

.u-ml10 {
  margin-left: 1rem !important;
}

.u-pt10 {
  padding-top: 1rem !important;
}

.u-pb10 {
  padding-bottom: 1rem !important;
}

.u-pr10 {
  padding-right: 1rem !important;
}

.u-pl10 {
  padding-left: 1rem !important;
}

.u-mt15 {
  margin-top: 1.5rem !important;
}

.u-mb15 {
  margin-bottom: 1.5rem !important;
}

.u-mr15 {
  margin-right: 1.5rem !important;
}

.u-ml15 {
  margin-left: 1.5rem !important;
}

.u-pt15 {
  padding-top: 1.5rem !important;
}

.u-pb15 {
  padding-bottom: 1.5rem !important;
}

.u-pr15 {
  padding-right: 1.5rem !important;
}

.u-pl15 {
  padding-left: 1.5rem !important;
}

.u-mt20 {
  margin-top: 2rem !important;
}

.u-mb20 {
  margin-bottom: 2rem !important;
}

.u-mr20 {
  margin-right: 2rem !important;
}

.u-ml20 {
  margin-left: 2rem !important;
}

.u-pt20 {
  padding-top: 2rem !important;
}

.u-pb20 {
  padding-bottom: 2rem !important;
}

.u-pr20 {
  padding-right: 2rem !important;
}

.u-pl20 {
  padding-left: 2rem !important;
}

.u-mt25 {
  margin-top: 2.5rem !important;
}

.u-mb25 {
  margin-bottom: 2.5rem !important;
}

.u-mr25 {
  margin-right: 2.5rem !important;
}

.u-ml25 {
  margin-left: 2.5rem !important;
}

.u-pt25 {
  padding-top: 2.5rem !important;
}

.u-pb25 {
  padding-bottom: 2.5rem !important;
}

.u-pr25 {
  padding-right: 2.5rem !important;
}

.u-pl25 {
  padding-left: 2.5rem !important;
}

.u-mt30 {
  margin-top: 3rem !important;
}

.u-mb30 {
  margin-bottom: 3rem !important;
}

.u-mr30 {
  margin-right: 3rem !important;
}

.u-ml30 {
  margin-left: 3rem !important;
}

.u-pt30 {
  padding-top: 3rem !important;
}

.u-pb30 {
  padding-bottom: 3rem !important;
}

.u-pr30 {
  padding-right: 3rem !important;
}

.u-pl30 {
  padding-left: 3rem !important;
}

.u-mt35 {
  margin-top: 3.5rem !important;
}

.u-mb35 {
  margin-bottom: 3.5rem !important;
}

.u-mr35 {
  margin-right: 3.5rem !important;
}

.u-ml35 {
  margin-left: 3.5rem !important;
}

.u-pt35 {
  padding-top: 3.5rem !important;
}

.u-pb35 {
  padding-bottom: 3.5rem !important;
}

.u-pr35 {
  padding-right: 3.5rem !important;
}

.u-pl35 {
  padding-left: 3.5rem !important;
}

.u-mt40 {
  margin-top: 4rem !important;
}

.u-mb40 {
  margin-bottom: 4rem !important;
}

.u-mr40 {
  margin-right: 4rem !important;
}

.u-ml40 {
  margin-left: 4rem !important;
}

.u-pt40 {
  padding-top: 4rem !important;
}

.u-pb40 {
  padding-bottom: 4rem !important;
}

.u-pr40 {
  padding-right: 4rem !important;
}

.u-pl40 {
  padding-left: 4rem !important;
}

.u-mt45 {
  margin-top: 4.5rem !important;
}

.u-mb45 {
  margin-bottom: 4.5rem !important;
}

.u-mr45 {
  margin-right: 4.5rem !important;
}

.u-ml45 {
  margin-left: 4.5rem !important;
}

.u-pt45 {
  padding-top: 4.5rem !important;
}

.u-pb45 {
  padding-bottom: 4.5rem !important;
}

.u-pr45 {
  padding-right: 4.5rem !important;
}

.u-pl45 {
  padding-left: 4.5rem !important;
}

.u-mt50 {
  margin-top: 5rem !important;
}

.u-mb50 {
  margin-bottom: 5rem !important;
}

.u-mr50 {
  margin-right: 5rem !important;
}

.u-ml50 {
  margin-left: 5rem !important;
}

.u-pt50 {
  padding-top: 5rem !important;
}

.u-pb50 {
  padding-bottom: 5rem !important;
}

.u-pr50 {
  padding-right: 5rem !important;
}

.u-pl50 {
  padding-left: 5rem !important;
}

.u-ft10 {
  font-size: 1rem;
}

.u-ft12 {
  font-size: 1.2rem;
}

.u-ft14 {
  font-size: 1.4rem;
}

.u-ft16 {
  font-size: 1.6rem;
}

.u-ft18 {
  font-size: 1.8rem;
}

.u-ft20 {
  font-size: 2rem;
}

.u-ft22 {
  font-size: 2.2rem;
}

.u-ft24 {
  font-size: 2.4rem;
}

.u-ft26 {
  font-size: 2.6rem;
}

.u-ft28 {
  font-size: 2.8rem;
}

.u-ft30 {
  font-size: 3rem;
}

.u-ft40 {
  font-size: 4rem;
}

.u-ft50 {
  font-size: 5rem;
}

.u-font-normal {
  font-weight: normal;
}

.u-font-bold {
  font-weight: bold;
}

.u-font-jp1 {
  font-family: var(--font-family-jp);
}

.u-font-jp2 {
  font-family: var(--font-family-jp2);
}

.u-font-en {
  font-family: var(--font-family-en);
}

.u-font-en2 {
  font-family: var(--font-family-en2);
}

.u-font-en3 {
  font-family: var(--font-family-en3);
}

.u-text-line {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(10%, transparent), color-stop(0%, #eaff03));
  background: linear-gradient(transparent 10%, #eaff03 0%);
}

.u-center {
  text-align: center !important;
}
@media screen and (min-width: 769px) {
  .u-center__pc {
    text-align: center !important;
  }
}

@media screen and (min-width: 769px) {
  .u-center-pc {
    text-align: center !important;
  }
}

@media screen and (min-width: 769px) {
  .u-display-pc {
    display: block;
  }
  .u-display-sp {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .u-display-pc {
    display: none;
  }
  .u-display-sp {
    display: block;
  }
}
.u-link {
  position: relative;
}
@media screen and (min-width: 769px) {
  .u-link::after {
    content: "";
    width: 100%;
    height: 1px;
    display: block;
    position: absolute;
    background-color: var(--color-site-main);
    left: 0;
    bottom: -1px;
    -webkit-animation: 2s;
            animation: 2s;
    -webkit-transform: scale(1, 1);
            transform: scale(1, 1);
    -webkit-transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    transition: -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    transition: transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92), -webkit-transform 600ms cubic-bezier(0.2, 0.8, 0.28, 0.92);
    -webkit-transform-origin: left top;
            transform-origin: left top;
  }
  .u-link:hover::after {
    -webkit-transform: scale(0, 1);
            transform: scale(0, 1);
    -webkit-transform-origin: right top;
            transform-origin: right top;
  }
}
@media screen and (max-width: 768px) {
  .u-link {
    text-decoration: underline;
  }
}

a.u-link {
  color: var(--color-site-main);
}
@media screen and (max-width: 768px) {
  a.u-link {
    text-decoration: underline;
  }
}

.u-icon {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.u-icon__blank {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border-radius: 50%;
  position: relative;
  margin: 0 0.5rem;
}
.u-icon__blank svg {
  width: 1.2rem;
  height: 1.2rem;
  fill: white;
}
.u-icon__blank[data-color=black] svg {
  fill: #000;
}
.u-icon__label {
  font-weight: bold;
  background: #009541;
  border-radius: 50rem;
  margin-right: 1rem !important;
  color: #FFF !important;
}
@media screen and (min-width: 769px) {
  .u-icon__label {
    font-size: 0.8rem;
    padding: 0.1rem 1rem;
  }
}
@media screen and (max-width: 768px) {
  .u-icon__label {
    font-size: 0.8rem !important;
    padding: 0.1rem 0.5rem;
  }
}
.u-icon__label.-en {
  font-family: var(--font-family-en);
}

.u-hover-img {
  display: inline-block;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media screen and (min-width: 769px) {
  .u-hover-img:hover img {
    opacity: 0.5;
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
}

/*.p-top {
	overflow: hidden;
	&.is-page-loaded, &.-visit {
    	overflow: visible;
	}
}*/
.p-opening {
  position: fixed;
  z-index: 100000;
  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-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: var(--color-site-main);
  -webkit-transition: opacity 10.2s ease-in-out;
  transition: opacity 10.2s ease-in-out;
  visibility: visible;
  opacity: 1;
}
@media screen and (min-width: 769px) {
  .p-opening {
    row-gap: 2rem;
    padding-bottom: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-opening {
    row-gap: 2rem;
    padding-bottom: 2rem;
  }
}
.p-opening .-logo {
  margin: 0 auto;
  opacity: 0;
  -webkit-animation: opening-logo 1s 0.2s forwards;
          animation: opening-logo 1s 0.2s forwards;
  -webkit-transform-origin: center;
          transform-origin: center;
}
@media screen and (min-width: 769px) {
  .p-opening .-logo {
    width: 80%;
    max-width: 64rem;
  }
}
@media screen and (max-width: 768px) {
  .p-opening .-logo {
    width: 90%;
    max-width: 32rem;
  }
}
.p-opening .-logo img {
  width: 100%;
  height: auto;
}
.-visit .p-opening {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: 0.3s 0.1s;
  transition: 0.3s 0.1s;
}
.is-page-loaded .p-opening {
  visibility: hidden;
  opacity: 0;
  -webkit-transition: 0.8s 1.5s;
  transition: 0.8s 1.5s;
}

@-webkit-keyframes opening-logo {
  0% {
    -webkit-transform: scale(2);
            transform: scale(2);
    -webkit-filter: blur(1rem);
            filter: blur(1rem);
    opacity: 0;
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-filter: blur(0);
            filter: blur(0);
    opacity: 1;
  }
}

@keyframes opening-logo {
  0% {
    -webkit-transform: scale(2);
            transform: scale(2);
    -webkit-filter: blur(1rem);
            filter: blur(1rem);
    opacity: 0;
  }
  to {
    -webkit-transform: scale(1);
            transform: scale(1);
    -webkit-filter: blur(0);
            filter: blur(0);
    opacity: 1;
  }
}
@-webkit-keyframes opening-logo-end {
  0% {
    -webkit-transform: translateY(0rem);
            transform: translateY(0rem);
    opacity: 1;
  }
  to {
    -webkit-transform: translateY(2rem);
            transform: translateY(2rem);
    opacity: 0;
  }
}
@keyframes opening-logo-end {
  0% {
    -webkit-transform: translateY(0rem);
            transform: translateY(0rem);
    opacity: 1;
  }
  to {
    -webkit-transform: translateY(2rem);
            transform: translateY(2rem);
    opacity: 0;
  }
}
.p-top__main {
  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;
}
@media screen and (min-width: 769px) {
  .p-top__main {
    padding-right: 2rem;
  }
}
@media screen and (min-width: 769px) {
  .p-top__main-side {
    width: 10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-side {
    width: 2rem;
    -ms-flex-negative: 0;
        flex-shrink: 0;
  }
}
.p-top__main-detail {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media screen and (min-width: 769px) {
  .p-top__main-detail {
    padding-bottom: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-detail {
    padding-bottom: 0;
  }
}
.p-top__main-video {
  width: 100%;
  line-height: 0;
  position: relative;
  overflow: hidden;
}
.p-top__main-video video {
  width: 100%;
  height: auto;
}
@media screen and (min-width: 769px) {
  .p-top__main-video::before, .p-top__main-video::after {
    content: "";
    background: #FFF;
    width: 2px;
    height: 100%;
    position: absolute;
    top: 0;
    z-index: 1;
  }
  .p-top__main-video::before {
    left: 0px;
  }
  .p-top__main-video::after {
    right: 0px;
  }
}
.p-top__main-news {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 769px) {
  .p-top__main-news {
    padding: 4rem 6rem 4rem 4rem;
    margin-left: 2rem;
    gap: 0;
    border-bottom: 1rem solid var(--color-bg-gray-base);
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    padding: 2.5rem 2.5rem 3rem;
    width: 100%;
  }
}
.p-top__main-news-title {
  font-weight: bold;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
      -ms-flex-direction: column-reverse;
          flex-direction: column-reverse;
  font-weight: 600;
  line-height: 1.4;
  min-width: 21rem;
}
@media screen and (min-width: 769px) {
  .p-top__main-news-title {
    font-size: 3.2rem;
    border-right: 1px solid #333;
    padding-right: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-title {
    font-size: 2rem;
    border-bottom: 1px solid #333;
    padding-bottom: 1.5rem;
  }
}
.p-top__main-news-title span {
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
}
@media screen and (min-width: 769px) {
  .p-top__main-news-title span {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-title span {
    font-size: 1.2rem;
  }
}
.p-top__main-news-body {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-top__main-news-body {
    gap: 4rem;
    padding: 2rem 2rem 2rem 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-body {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 0;
    padding: 0.5rem 0 2rem;
  }
}
.p-top__main-news-item {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
.p-top__main-news-item .-date {
  font-family: var(--font-family-en1);
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-top__main-news-item .-date {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-item .-date {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 769px) {
  .p-top__main-news-item .-text {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-item .-text {
    font-size: 1.3rem;
  }
}
.p-top__main-news-item .-label {
  border: 1px solid var(--color-site-main);
  color: var(--color-site-main);
  display: inline;
  line-height: 1;
  font-weight: 500;
  font-family: var(--font-family-en1);
  margin-right: 0.5rem;
  position: relative;
  top: -1px;
}
@media screen and (min-width: 769px) {
  .p-top__main-news-item .-label {
    padding: 0.1rem 1rem;
    font-size: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-item .-label {
    padding: 0.1rem 0.5rem;
    font-size: 0.8rem;
  }
}
.p-top__main-news-item a {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-top__main-news-item a {
    display: inline-block;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-item a {
    display: block;
    padding: 1.5rem 0;
    border-bottom: 1px #CCC dotted;
  }
}
.p-top__main-news-item a .-text {
  display: inline;
}
@media screen and (min-width: 769px) {
  .p-top__main-news-item a .-text {
    font-size: 1.4rem;
    padding: 0.3rem 0;
    background-image: -webkit-gradient(linear, left top, left bottom, from(var(--color-site-main)), to(var(--color-site-main)));
    background-image: linear-gradient(var(--color-site-main), var(--color-site-main)); /* 単色 */
    background-size: 0 1px; /* 幅(100%=文字の長さ) | 高さ(=線の太さ) */
    background-position: bottom right; /* 左下に配置 */
    background-repeat: no-repeat;
    padding-bottom: 5px;
    -webkit-transition: background-size 0.4s ease-out, color 0.3s ease-out;
    transition: background-size 0.4s ease-out, color 0.3s ease-out;
    box-decoration-break: slice; /* Firefox用に指定 */
    -webkit-box-decoration-break: slice; /* Firefox以外のブラウザ用に指定 */
  }
}
@media screen and (min-width: 769px) {
  .p-top__main-news-item a:hover .-text {
    color: var(--color-site-main);
    background-size: 100% 1px; /* 幅(0=見えない状態) | 高さ(=線の太さ) */
    background-position: bottom left; /* 右下に配置 */
  }
}
.p-top__main-news-more {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  /*a {
  	height: auto;
  	aspect-ratio: 300 / 54;
  	position: relative;
  	background: url("../images/top/news_more.svg");
  	background-repeat: no-repeat;
  	background-size: contain;
  	font-weight: bold;
  	display: flex;
  	flex-direction: column;
  	justify-content: center;
  	gap:0.5rem;

  	//width: 66rem;
  	//height: 7.6rem;
  	color: #FFF;
  	line-height: 1;
  	@include mq(pc) {
  		width: 34rem;
  		font-size: 1.4rem;
  		padding: 0rem 12rem 0rem 5rem;
  	}
  	@include mq(sp) {
  		width: 100%;
  		max-width: 30rem;
  		font-size: 1.2rem;
  		padding: 0rem 12rem 0rem 5rem;
  	}
  	.-en {
  		font-family: var(--font-family-en1);
  		font-weight: 600;
  		@include mq(pc) {
  			font-size: 1.2rem;
  		}
  		@include mq(sp) {
  			font-size: 1.0rem;
  		}
  	}

  	&::after {
  		content: "";
  		width: 7rem;
  		height: 1px;
  		background: #000;
  		position: absolute;
  		top: 50%;

  		@include mq(pc) {
  			right: -2rem;
  		}
  		@include mq(sp) {
  			right: 0;
  		}
  	}
  }*/
}
@media screen and (min-width: 769px) {
  .p-top__main-news-more a.-btn {
    height: 5.6rem;
    padding-left: 5rem;
    gap: 0.4rem;
    aspect-ratio: 11/2;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-news-more a.-btn {
    aspect-ratio: 11/2;
  }
}
.p-top__main-side {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  height: auto;
  background: url("../../assets/images/top/main_side.svg");
  background-repeat: no-repeat;
  background-size: auto 100%;
  background-position: center;
}
@media screen and (min-width: 769px) {
  .p-top__main-side {
    padding-top: 10%;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-side {
    padding-top: 25%;
  }
}
.p-top__main-side p {
  font-family: var(--font-family-en1);
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  font-weight: bold;
  background-color: #FFF;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
      -ms-flex-direction: row;
          flex-direction: row;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  position: sticky;
  font-weight: 600;
}
@media screen and (min-width: 769px) {
  .p-top__main-side p {
    font-size: 1.4rem;
    padding: 2rem 1rem 1rem;
    gap: 2rem;
    top: 9rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__main-side p {
    font-size: 0.8rem;
    padding: 2rem 0 0.5rem;
    line-height: 0;
    gap: 1rem;
    top: 6rem;
  }
}
.p-top__main-side p::after {
  content: "";
  display: inline-block;
  vertical-align: middle;
  width: 0;
  height: 0;
  border-left: 0.5rem solid transparent;
  border-right: 0.5rem solid transparent;
  border-top: 0.5rem solid var(--color-site-main); /* ▼の色と大きさ */
  -webkit-animation: upDown 2.2s ease-in-out infinite;
          animation: upDown 2.2s ease-in-out infinite;
}
.p-top__concept {
  overflow: hidden;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-top__concept {
    background: url("../images/top/concept_bg.jpg");
    background-repeat: no-repeat;
    background-size: cover;
    /*background-attachment: fixed;*/
    background-position: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    aspect-ratio: 240/135;
  }
}
@media screen and (max-width: 768px) {
  .p-top__concept {
    padding: 0 0 6rem;
  }
}
.p-top__concept-video {
  z-index: 1;
  width: 100%;
  line-height: 0;
}
@media screen and (min-width: 769px) {
  .p-top__concept-video {
    position: absolute;
    left: 0;
    top: 0;
  }
}
.p-top__concept-video video {
  width: 100%;
}
.p-top__concept-wrapper {
  color: #000;
  background: rgba(255, 255, 255, 0.8);
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .p-top__concept-wrapper {
    padding: 6rem 12rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__concept-wrapper {
    padding: 2.5rem 2.5rem;
  }
}
.p-top__concept-header-title {
  font-weight: 900;
  line-height: 1.4;
}
@media screen and (min-width: 769px) {
  .p-top__concept-header-title {
    font-size: 4.2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__concept-header-title {
    font-size: 2.2rem;
  }
}
.p-top__concept-body {
  margin-top: 2rem;
}
.p-top__concept-body-text {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-top__concept-body-text {
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 2;
  }
}
@media screen and (max-width: 768px) {
  .p-top__concept-body-text {
    font-size: 1.3rem;
  }
}
.p-top__concept-body-more {
  margin-top: 3rem;
  display: block;
  position: relative;
  /*a {
  	aspect-ratio: 300 / 54;
  	height: auto;
  	position: relative;
  	background: url("../images/top/concept_more.svg");
  	background-repeat: no-repeat;
  	background-size: contain;
  	font-weight: bold;
  	display: flex;
  	flex-direction: column;
  	justify-content: center;
  	gap:0.5rem;

  	//width: 66rem;
  	//height: 7.6rem;
  	color: #FFF;
  	line-height: 1;
  	@include mq(pc) {
  		width: 42rem;
  		font-size: 1.6rem;
  		padding: 0rem 12rem 0rem 6rem;
  	}
  	@include mq(sp) {
  		width: 100%;
  		max-width: 30rem;
  		font-size: 1.2rem;
  		padding: 0rem 12rem 0rem 5rem;
  	}
  	.-en {
  		font-family: var(--font-family-en1);
  		font-weight: 600;
  		font-size: 1.2rem;
  	}
  	&::after {
  		content: "";
  		width: 50%;
  		height: 2rem;
  		background: url("../images/top/concept_more_arrow.svg");
  		background-repeat: no-repeat;
  		background-size: contain;
  		background-position: center;
  		position: absolute;
  		top: 50%;
  		transform: translateY(-50%);
  		@include mq(pc) {
  			left:80%;
  		}
  		@include mq(sp) {
  			right:-2rem;
  		}
  	}
  }*/
}
.p-top__service {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-top__service {
    padding: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service {
    padding: 2rem 2rem 6rem;
  }
}
.p-top__service-wrapper {
  max-width: 160rem;
  margin: 0 auto;
}
.p-top__service-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-top__service-header {
    gap: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-header {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-top__service-header-main, .p-top__service-header-detail {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (min-width: 769px) {
  .p-top__service-header-main, .p-top__service-header-detail {
    width: calc((100% - 6rem) / 2);
  }
}
.p-top__service-header-main {
  position: relative;
}
.p-top__service-header-main-title {
  position: absolute;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-top__service-header-main-title {
    top: -14rem;
    left: 5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-header-main-title {
    top: -4rem;
    left: 1rem;
  }
}
.p-top__service-header-main-sub {
  position: absolute;
  z-index: 1;
  font-weight: bold;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  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;
}
@media screen and (min-width: 769px) {
  .p-top__service-header-main-sub {
    font-size: 2.2rem;
    top: 5rem;
    left: 18rem;
    gap: 1.5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-header-main-sub {
    font-size: 1.4rem;
    gap: 0.5rem;
    top: -2rem;
    right: 1rem;
  }
}
.p-top__service-header-main-sub span {
  display: inline-block;
  background-color: #FFF;
  line-height: 1;
  word-break: keep-all;
}
@media screen and (min-width: 769px) {
  .p-top__service-header-main-sub span {
    padding: 2rem 1rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-header-main-sub span {
    padding: 1rem 0.5rem;
  }
}
.p-top__service-header-main-img {
  overflow: hidden;
}
.p-top__service-header-main-img img {
  width: 100%;
}
.p-top__service-header-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 768px) {
  .p-top__service-header-detail {
    margin-top: 2rem;
  }
}
.p-top__service-header-detail-title {
  font-weight: 900;
  line-height: 1.4;
}
@media screen and (min-width: 769px) {
  .p-top__service-header-detail-title {
    font-size: 4.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-header-detail-title {
    font-size: 2.8rem;
  }
}
.p-top__service-header-detail-text {
  margin-top: 2rem;
}
.p-top__service-header-detail-img {
  margin-top: 2rem;
  width: 100%;
  height: 100%;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
  overflow: hidden;
  background: url("../images/top/service_sub01.jpg");
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 768px) {
  .p-top__service-header-detail-img {
    display: none;
  }
}
@media screen and (min-width: 769px) {
  .p-top__service-body {
    padding-top: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-body {
    padding-top: 4rem;
  }
}
.p-top__service-body-point {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-top__service-body-point {
    gap: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-body-point {
    gap: 3rem 1.5rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}
.p-top__service-body-point-box {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 769px) {
  .p-top__service-body-point-box {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-body-point-box {
    width: calc((100% - 1.5rem) / 2);
  }
}
.p-top__service-body-point-box .-num {
  font-family: var(--font-family-en1);
  position: absolute;
  top: -0.5em;
  color: var(--color-site-main);
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .p-top__service-body-point-box .-num {
    font-size: 10.8rem;
    left: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-body-point-box .-num {
    font-size: 5.8rem;
    left: 3rem;
  }
}
.p-top__service-body-point-box .-text {
  border: 1px solid #666565;
  margin-top: -1px;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
.p-top__service-body-point-box .-detail {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-top__service-body-point-box .-detail {
    padding: 2rem 2rem 2rem 6rem;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-body-point-box .-detail {
    padding: 1rem 1rem 1rem 3.6rem;
    font-size: 1.3rem;
    line-height: 1.6;
  }
}
.p-top__service-body-point-box .-side {
  background: #666565;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  font-family: var(--font-family-en1);
  color: #FFF;
  line-height: 1;
  clip-path: polygon(0% 100%, 100% calc(100% - 3rem), 100% 0%, 0% 0%);
  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-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
@media screen and (min-width: 769px) {
  .p-top__service-body-point-box .-side {
    font-size: 1.2rem;
    padding: 2rem 0.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__service-body-point-box .-side {
    width: 2.4rem;
    font-size: 1rem;
    padding: 1rem 0.4rem 2.5rem;
  }
}
.p-top__profile {
  background-color: var(--color-bg-gray-light);
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-top__profile {
    padding: 6rem 0 10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile {
    padding: 4rem 2rem 0;
  }
}
.p-top__profile-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 160rem;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .p-top__profile-wrapper {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
    gap: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 3rem;
  }
}
@media screen and (min-width: 769px) {
  .p-top__profile-header, .p-top__profile-body {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile-header, .p-top__profile-body {
    width: 100%;
  }
}
.p-top__profile-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-top__profile-header {
    gap: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile-header {
    gap: 2rem;
  }
}
.p-top__profile-header-main {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-top__profile-header-main-title {
    -webkit-transform: translateX(-20rem);
            transform: translateX(-20rem);
  }
}
.p-top__profile-header-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (max-width: 768px) {
  .p-top__profile-header-detail {
    padding: 0 1.5rem;
  }
}
.p-top__profile-header-detail-title {
  font-weight: 900;
  line-height: 1.4;
}
@media screen and (min-width: 769px) {
  .p-top__profile-header-detail-title {
    font-size: 4.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile-header-detail-title {
    font-size: 2.8rem;
  }
}
.p-top__profile-header-detail-text {
  margin-top: 2rem;
}
.p-top__profile-body {
  position: relative;
}
@media screen and (max-width: 768px) {
  .p-top__profile-body {
    margin-bottom: -3rem;
  }
}
.p-top__profile-body .-img01, .p-top__profile-body .-img02 {
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .p-top__profile-body .-img01, .p-top__profile-body .-img02 {
    width: 60%;
    height: auto;
    position: absolute;
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile-body .-img01, .p-top__profile-body .-img02 {
    width: 60%;
    height: auto;
    position: relative;
  }
}
.p-top__profile-body .-img01 {
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .p-top__profile-body .-img01 {
    left: 0;
    top: 0rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile-body .-img01 {
    left: 0;
    top: 0rem;
  }
}
@media screen and (min-width: 769px) {
  .p-top__profile-body .-img02 {
    left: 40%;
    top: calc(40% + 3rem);
  }
}
@media screen and (max-width: 768px) {
  .p-top__profile-body .-img02 {
    left: 40%;
    margin-top: -6rem;
  }
}
.p-top__company {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-top__company {
    padding: 8rem 6rem 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__company {
    padding: 12rem 2rem 6rem;
    overflow: hidden;
  }
}
.p-top__company-wrapper {
  max-width: 160rem;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-top__company-wrapper {
    gap: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__company-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 4rem;
  }
}
.p-top__company-img {
  position: absolute;
  height: auto;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (min-width: 769px) {
  .p-top__company-img {
    left: calc(50% - 14rem);
    top: -5rem;
    height: 16rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__company-img {
    left: 5.5rem;
    top: -4.5rem;
    height: 5.6rem;
  }
}
.p-top__company-img img {
  height: 100%;
  width: auto;
  max-width: none;
}
.p-top__company-office, .p-top__company-contact {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  position: relative;
}
.p-top__company-office-title {
  position: absolute;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-top__company-office-title {
    top: -14rem;
    left: 5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__company-office-title {
    top: -10rem;
    left: 2rem;
  }
  .p-top__company-office-title .c-shape__vertical {
    padding-top: 4rem;
    gap: 1rem;
  }
  .p-top__company-office-title .c-shape__vertical .-jp {
    letter-spacing: 0.1rem;
    font-size: 1.2rem;
  }
}
.p-top__company-office-img {
  overflow: hidden;
}
.p-top__company-contact {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 769px) {
  .p-top__company-contact {
    padding-top: 8rem;
  }
}
.p-top__company-contact-img {
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .p-top__company-contact-img {
    margin-top: 4rem;
    width: 90%;
    height: 100%;
    -webkit-box-flex: 1;
        -ms-flex-positive: 1;
            flex-grow: 1;
    overflow: hidden;
    background: url("../images/top/contact_img.jpg");
    background-repeat: no-repeat;
    background-size: cover;
  }
  .p-top__company-contact-img img {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .p-top__company-contact-img {
    margin-top: 2rem;
  }
}
.p-top__recruit {
  background-color: var(--color-bg-gray-light);
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-top__recruit {
    margin-top: 8rem;
    margin-bottom: 9rem;
    padding: 6rem 0 8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit {
    padding: 4rem 2rem 0;
    margin-bottom: 4rem;
  }
}
.p-top__recruit-wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  max-width: 160rem;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .p-top__recruit-wrapper {
    gap: 6rem;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-wrapper {
    gap: 3rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (min-width: 769px) {
  .p-top__recruit-header, .p-top__recruit-body {
    -webkit-box-flex: 1;
        -ms-flex: 1;
            flex: 1;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-header, .p-top__recruit-body {
    width: 100%;
  }
}
.p-top__recruit-header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-top__recruit-header {
    gap: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-header {
    gap: 2rem;
  }
}
@media screen and (min-width: 769px) {
  .p-top__recruit-header-title {
    -webkit-transform: translateX(-10rem);
            transform: translateX(-10rem);
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-header-title {
    -webkit-transform: translateX(-8rem);
            transform: translateX(-8rem);
  }
}
@media screen and (min-width: 769px) {
  .p-top__recruit-header-title a {
    padding-left: 14rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-header-title a {
    padding-left: 8rem;
  }
}
.p-top__recruit-header-sub {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  line-height: 1.2;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-top__recruit-header-sub {
    font-size: 6rem;
    padding-left: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-header-sub {
    font-size: 3.4rem;
  }
}
.p-top__recruit-header-sub span {
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .p-top__recruit-header-sub span {
    font-size: 9rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-header-sub span {
    font-size: 4.8rem;
  }
}
.p-top__recruit-body {
  position: relative;
}
.p-top__recruit-body .-img01, .p-top__recruit-body .-img02, .p-top__recruit-body .-img03 {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-top__recruit-body .-img01, .p-top__recruit-body .-img02, .p-top__recruit-body .-img03 {
    width: 55%;
    height: auto;
    position: absolute;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-body .-img01, .p-top__recruit-body .-img02, .p-top__recruit-body .-img03 {
    width: 55%;
  }
}
.p-top__recruit-body .-img01 {
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .p-top__recruit-body .-img01 {
    left: -12rem;
    bottom: -14rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-body .-img01 {
    margin-left: 20%;
  }
}
@media screen and (min-width: 769px) {
  .p-top__recruit-body .-img02 {
    left: 10%;
    top: -10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-body .-img02 {
    margin-top: -1rem;
    z-index: 2;
  }
}
@media screen and (min-width: 769px) {
  .p-top__recruit-body .-img03 {
    right: 0%;
    bottom: -10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-top__recruit-body .-img03 {
    margin-top: -6rem;
    margin-bottom: -3rem;
    margin-left: 45%;
  }
}

@media screen and (min-width: 769px) {
  .p-concept__contents {
    padding-bottom: 12rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__contents {
    padding-bottom: 6rem;
  }
}
.p-concept__policy, .p-concept__philosophy, .p-concept__message {
  position: relative;
}
.p-concept__policy-inner, .p-concept__philosophy-inner, .p-concept__message-inner {
  position: relative;
  background: rgba(255, 255, 255, 0.95);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-concept__policy-inner, .p-concept__philosophy-inner, .p-concept__message-inner {
    width: 90%;
    min-height: 46rem;
    padding: 10rem 0;
    -webkit-box-shadow: 4rem 4rem #DCDDDD;
            box-shadow: 4rem 4rem #DCDDDD;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-inner, .p-concept__philosophy-inner, .p-concept__message-inner {
    width: 100%;
    padding: 4rem;
    -webkit-box-shadow: 1rem 1rem #DCDDDD;
            box-shadow: 1rem 1rem #DCDDDD;
  }
}
.p-concept__policy-inner::before, .p-concept__philosophy-inner::before, .p-concept__message-inner::before {
  position: absolute;
  content: "";
}
@media screen and (min-width: 769px) {
  .p-concept__policy-inner::before, .p-concept__philosophy-inner::before, .p-concept__message-inner::before {
    width: calc(100% - 8rem);
    height: calc(100% - 8rem);
    border: 0.3rem solid var(--color-site-main);
    left: 4rem;
    top: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-inner::before, .p-concept__philosophy-inner::before, .p-concept__message-inner::before {
    width: calc(100% - 2rem);
    height: calc(100% - 2rem);
    border: 0.2rem solid var(--color-site-main);
    left: 1rem;
    top: 1rem;
  }
}
.p-concept__policy-detail, .p-concept__philosophy-detail, .p-concept__message-detail {
  position: relative;
  z-index: 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-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .p-concept__policy-detail, .p-concept__philosophy-detail, .p-concept__message-detail {
    gap: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-detail, .p-concept__philosophy-detail, .p-concept__message-detail {
    gap: 2rem;
  }
}
.p-concept__policy-detail-item-title, .p-concept__philosophy-detail-item-title, .p-concept__message-detail-item-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-concept__policy-detail-item-title, .p-concept__philosophy-detail-item-title, .p-concept__message-detail-item-title {
    font-size: 2.4rem;
    gap: 3rem;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-detail-item-title, .p-concept__philosophy-detail-item-title, .p-concept__message-detail-item-title {
    font-size: 1.4rem;
    gap: 1rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.p-concept__policy-detail-item-title .-num, .p-concept__philosophy-detail-item-title .-num, .p-concept__message-detail-item-title .-num {
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  font-weight: 500;
  font-style: italic;
}
@media screen and (min-width: 769px) {
  .p-concept__policy-detail-item-title .-num, .p-concept__philosophy-detail-item-title .-num, .p-concept__message-detail-item-title .-num {
    font-size: 10.2rem;
    line-height: 0;
    width: 10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-detail-item-title .-num, .p-concept__philosophy-detail-item-title .-num, .p-concept__message-detail-item-title .-num {
    font-size: 4.2rem;
    line-height: 1;
  }
}
@media screen and (min-width: 769px) {
  .p-concept__policy {
    top: -10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy {
    top: -4rem;
  }
}
@media screen and (min-width: 769px) {
  .p-concept__policy-detail {
    padding-left: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-inner {
    padding-left: 8rem;
  }
}
.p-concept__policy-title {
  position: absolute;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .p-concept__policy-title {
    left: 8rem;
    top: -8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-title {
    left: 2rem;
    top: -2rem;
  }
}
.p-concept__policy-title .c-shape__vertical {
  aspect-ratio: 2/14;
}
.p-concept__policy-img {
  position: absolute;
  z-index: 0;
}
@media screen and (min-width: 769px) {
  .p-concept__policy-img {
    bottom: -24rem;
    left: -31rem;
    width: 52rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__policy-img {
    top: calc(100% - 2rem);
    left: -2rem;
    width: 60%;
  }
}
.p-concept__policy-img img {
  width: 100%;
  height: auto;
}
.p-concept__philosophy {
  margin-top: 6rem;
}
@media screen and (min-width: 769px) {
  .p-concept__philosophy-inner {
    margin-left: 10%;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__philosophy-inner {
    padding-top: 5rem;
  }
}
.p-concept__philosophy-title {
  position: absolute;
  z-index: 1;
  top: -2rem;
}
@media screen and (min-width: 769px) {
  .p-concept__philosophy-title {
    left: calc(10% + 14rem);
  }
}
@media screen and (max-width: 768px) {
  .p-concept__philosophy-title {
    right: 0;
  }
}
.p-concept__philosophy-title .c-shape__horizon {
  aspect-ratio: 14/2;
}
@media screen and (min-width: 769px) {
  .p-concept__message {
    margin-top: 14rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__message {
    margin-top: 6rem;
  }
}
@media screen and (min-width: 769px) {
  .p-concept__message-inner {
    padding: 5rem 0 8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__message-inner {
    padding: 2rem 0 4rem;
  }
}
.p-concept__message-inner::before {
  content: none;
}
.p-concept__message-title {
  position: absolute;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .p-concept__message-title {
    top: -8rem;
    right: calc(10% + 8rem);
  }
}
@media screen and (max-width: 768px) {
  .p-concept__message-title {
    top: -4rem;
    right: 2rem;
  }
}
.p-concept__message-title .c-shape__vertical {
  aspect-ratio: 2/14;
}
.p-concept__message-detail {
  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;
}
.p-concept__message-detail-img {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-concept__message-detail-img {
    width: 120%;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__message-detail-img {
    width: 100%;
  }
}
.p-concept__message-detail-img-name {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-concept__message-detail-img-name {
    position: absolute;
    left: calc(50% + 3rem);
    top: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__message-detail-img-name {
    background: var(--color-bg-gray-base);
    padding: 2rem 8rem 2rem 2rem;
    font-size: 1.2rem;
  }
}
.p-concept__message-detail-img-name img {
  margin-top: 1rem;
}
@media screen and (min-width: 769px) {
  .p-concept__message-detail-img-name img {
    width: 18rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__message-detail-img-name img {
    width: 10rem;
  }
}
.p-concept__message-detail-text {
  font-family: "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  line-height: 2.2;
  font-weight: 400;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .p-concept__message-detail-text {
    font-size: 1.8rem;
    padding: 0 6rem;
    letter-spacing: 0.3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-concept__message-detail-text {
    font-size: 1.2rem;
    padding: 0 2rem;
  }
}

.p-service__main {
  background-image: url("../../assets/images/service/main.jpg");
}
.p-service__main-video {
  position: absolute;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
  height: 100%;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}
@media screen and (min-width: 769px) {
  .p-service__contents {
    padding-bottom: 12rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__contents {
    padding-bottom: 6rem;
  }
}
.p-service__guidance {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-service__guidance {
    top: -10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__guidance {
    top: -4rem;
  }
}
.p-service__guidance-inner {
  position: relative;
  background: rgba(255, 255, 255, 0.95);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-service__guidance-inner {
    width: 100%;
    margin: 0 auto;
    min-height: 46rem;
    padding: 10rem 8rem 10rem 22rem;
    -webkit-box-shadow: 4rem 4rem #DCDDDD;
            box-shadow: 4rem 4rem #DCDDDD;
  }
}
@media screen and (max-width: 768px) {
  .p-service__guidance-inner {
    width: 100%;
    padding: 4rem 4rem 4rem 8rem;
    -webkit-box-shadow: 1rem 1rem #DCDDDD;
            box-shadow: 1rem 1rem #DCDDDD;
  }
}
.p-service__guidance-inner::before {
  position: absolute;
  content: "";
}
@media screen and (min-width: 769px) {
  .p-service__guidance-inner::before {
    width: calc(100% - 8rem);
    height: calc(100% - 8rem);
    border: 0.3rem solid var(--color-site-main);
    left: 4rem;
    top: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__guidance-inner::before {
    width: calc(100% - 2rem);
    height: calc(100% - 2rem);
    border: 0.2rem solid var(--color-site-main);
    left: 1rem;
    top: 1rem;
  }
}
.p-service__guidance-title {
  position: absolute;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .p-service__guidance-title {
    left: 8rem;
    top: -8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__guidance-title {
    left: 2rem;
    top: -2rem;
  }
}
.p-service__guidance-title .c-shape__vertical {
  aspect-ratio: 2/14;
}
.p-service__guidance-detail {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.p-service__guidance-detail-text {
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .p-service__guidance-detail-text {
    font-size: 2rem;
    line-height: 2;
  }
}
@media screen and (max-width: 768px) {
  .p-service__guidance-detail-text {
    font-size: 1.4rem;
    line-height: 2;
  }
}
@media screen and (min-width: 769px) {
  .p-service__point {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point {
    margin-top: 2rem;
  }
}
.p-service__point-box .-bg {
  width: 100%;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background-position: top center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (min-width: 769px) {
  .p-service__point-box .-bg {
    padding-left: calc(50% - 40rem);
    padding-top: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point-box .-bg {
    padding-left: 2rem;
    padding-top: 2rem;
  }
}
.p-service__point-box .-bg::before {
  content: "";
  width: 100%;
  height: 100%;
  background-color: rgba(0, 51, 23, 0.6);
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (min-width: 769px) {
  .p-service__point-box:not(:first-of-type) {
    margin-top: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point-box:not(:first-of-type) {
    margin-top: 6rem;
  }
}
@media screen and (min-width: 769px) {
  .p-service__point-box:nth-child(2n) .-header {
    margin-left: 10%;
  }
}
@media screen and (min-width: 769px) {
  .p-service__point-box:nth-child(2n) .-bg {
    padding-left: calc(40% - 42rem);
  }
}
.p-service__point .-header {
  background-color: #666;
  position: relative;
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .p-service__point .-header {
    width: 90%;
    height: 42rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point .-header {
    width: 100%;
    height: 20rem;
  }
}
.p-service__point .-header .-title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  color: #FFF;
  font-weight: bold;
  line-height: 1.6;
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-service__point .-header .-title {
    font-size: 4.2rem;
    padding-bottom: 3rem;
    padding-left: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point .-header .-title {
    font-size: 2.2rem;
    padding-bottom: 2rem;
    padding-left: 4rem;
  }
}
.p-service__point .-header .-title span {
  font-family: var(--font-family-en1);
  font-weight: 500;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .p-service__point .-header .-title span {
    font-size: 7.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point .-header .-title span {
    font-size: 4.8rem;
  }
}
.p-service__point .-header .-title .-en {
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  white-space: nowrap;
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
}
@media screen and (min-width: 769px) {
  .p-service__point .-header .-title .-en {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point .-header .-title .-en {
    font-size: 1rem;
  }
}
.p-service__point .-header .-title .-en::before {
  content: "";
  width: 1px;
  height: 100%;
  background: #FFF;
  position: absolute;
  left: -0.5rem;
  top: 0;
}
.p-service__point .-body {
  position: relative;
  background: rgba(255, 255, 255, 0.95);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 769px) {
  .p-service__point .-body {
    width: 100%;
    margin: 0 auto;
    padding: 6rem 14rem;
    margin-top: -4rem;
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point .-body {
    width: calc(100% - 4rem);
    padding: 2rem;
    margin: -4rem auto 0;
    font-size: 1.4rem;
  }
}
.p-service__point .-body .-title {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-service__point .-body .-title {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point .-body .-title {
    font-size: 1.8rem;
  }
}
.p-service__point .-body .-text {
  line-height: 2;
}
@media screen and (min-width: 769px) {
  .p-service__point .-body .-text {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-service__point .-body .-text {
    margin-top: 1rem;
  }
}
.p-service__point .-point01 .-bg {
  background-image: url("../../assets/images/service/poing_bg01.jpg");
}
.p-service__point .-point02 .-bg {
  background-image: url("../../assets/images/service/poing_bg02.jpg");
}
.p-service__point .-point03 .-bg {
  background-image: url("../../assets/images/service/poing_bg03.jpg");
}
.p-service__point .-point04 .-bg {
  background-image: url("../../assets/images/service/poing_bg04.jpg");
}

.p-news__main {
  background-image: url("../../assets/images/news/main.jpg");
}
@media screen and (min-width: 769px) {
  .p-news__contents {
    padding: 6rem 0;
  }
}
@media screen and (max-width: 768px) {
  .p-news__contents {
    padding: 3rem 0;
  }
}
.p-news__category {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-news__category {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    gap: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__category {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1rem;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
  }
}
.p-news__category::before {
  content: "カテゴリ";
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-radius: 5rem;
  background-color: var(--color-site-main);
  color: #FFF;
  padding: 0.1rem 3rem;
  line-height: 1.8;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-news__category::before {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__category::before {
    font-size: 1.2rem;
  }
}
.p-news__category-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (min-width: 769px) {
  .p-news__category-list {
    gap: 1rem 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__category-list {
    gap: 1rem 1.5rem;
  }
}
.p-news__category-list li a {
  color: var(--color-site-main);
  display: inline;
  padding: 0.3rem 0;
  background-image: -webkit-gradient(linear, left top, left bottom, from(var(--color-site-main)), to(var(--color-site-main)));
  background-image: linear-gradient(var(--color-site-main), var(--color-site-main)); /* 単色 */
  background-size: 100% 1px;
  background-position: bottom left;
  background-repeat: no-repeat;
  padding-bottom: 5px;
  -webkit-transition: background-size 0.4s ease-out, color 0.3s ease-out;
  transition: background-size 0.4s ease-out, color 0.3s ease-out;
  box-decoration-break: slice; /* Firefox用に指定 */
  -webkit-box-decoration-break: slice; /* Firefox以外のブラウザ用に指定 */
}
@media screen and (min-width: 769px) {
  .p-news__category-list li a {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__category-list li a {
    font-size: 1.2rem;
  }
}
@media screen and (min-width: 769px) {
  .p-news__category-list li a:hover {
    color: var(--color-site-main);
    background-size: 0 1px;
    background-position: bottom right;
  }
}
@media screen and (min-width: 769px) {
  .p-news__body {
    padding: 6rem 0;
  }
}
@media screen and (max-width: 768px) {
  .p-news__body {
    padding: 4rem 0;
  }
}
.p-news__body-wrapper {
  display: grid;
}
@media screen and (min-width: 769px) {
  .p-news__body-wrapper {
    grid-template-columns: repeat(3, 1fr);
    gap: 4.6rem 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__body-wrapper {
    grid-template-columns: repeat(2, 1fr);
    gap: 2rem 1.5rem;
  }
}
.p-news__body-item-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  background-color: #FFF;
  height: 100%;
  -webkit-box-shadow: 0px 2px 20px -11px rgba(0, 0, 0, 0.3);
          box-shadow: 0px 2px 20px -11px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 768px) {
  .p-news__body-item-box {
    line-height: 1.6;
  }
}
.p-news__body-item-box .-img {
  overflow: hidden;
  line-height: 0;
}
.p-news__body-item-box .-img img {
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 3/2;
}
@media screen and (min-width: 769px) {
  .p-news__body-item-box .-detail {
    padding: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__body-item-box .-detail {
    padding: 1.5rem;
  }
}
.p-news__body-item-box .-date {
  font-family: var(--font-family-en1);
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-news__body-item-box .-date {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__body-item-box .-date {
    font-size: 1.2rem;
  }
}
.p-news__body-item-box .-title {
  color: var(--color-site-main);
  font-weight: bold;
  display: inline;
  padding: 0.3rem 0;
  background-image: -webkit-gradient(linear, left top, left bottom, from(var(--color-site-main)), to(var(--color-site-main)));
  background-image: linear-gradient(var(--color-site-main), var(--color-site-main)); /* 単色 */
  background-size: 0 1px;
  background-position: bottom right;
  background-repeat: no-repeat;
  padding-bottom: 5px;
  -webkit-transition: background-size 0.4s ease-out, color 0.3s ease-out;
  transition: background-size 0.4s ease-out, color 0.3s ease-out;
  box-decoration-break: slice; /* Firefox用に指定 */
  -webkit-box-decoration-break: slice; /* Firefox以外のブラウザ用に指定 */
}
@media screen and (min-width: 769px) {
  .p-news__body-item-box .-title {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__body-item-box .-title {
    font-size: 1.2rem;
  }
}
.p-news__body-item-box .-label {
  border: 1px solid var(--color-site-main);
  color: var(--color-site-main);
  display: inline;
  line-height: 1;
  font-weight: 500;
  font-family: var(--font-family-en1);
  margin-right: 0.5rem;
  position: relative;
  top: -1px;
}
@media screen and (min-width: 769px) {
  .p-news__body-item-box .-label {
    padding: 0.1rem 1rem;
    font-size: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .p-news__body-item-box .-label {
    padding: 0.1rem 0.5rem;
    font-size: 0.8rem;
  }
}
@media screen and (min-width: 769px) {
  .p-news__body-item-box:hover .-img img {
    -webkit-transform: scale(1.05);
            transform: scale(1.05);
  }
}
@media screen and (min-width: 769px) and (min-width: 769px) {
  .p-news__body-item-box:hover .-title {
    color: var(--color-site-main);
    background-size: 100% 1px;
    background-position: bottom left;
  }
}

.p-profile__main {
  background-image: url("../../assets/images/profile/main.jpg");
}
@media screen and (min-width: 769px) {
  .p-profile__contents {
    padding-bottom: 12rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__contents {
    padding-bottom: 6rem;
  }
}
.p-profile__box {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-profile__box {
    margin-top: 14rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box {
    margin-top: 6rem;
  }
}
.p-profile__box-title {
  position: absolute;
  z-index: 2;
  height: 100%;
}
@media screen and (min-width: 769px) {
  .p-profile__box-title {
    left: 8rem;
    top: -8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-title {
    left: 2rem;
    top: -2rem;
  }
}
.p-profile__box-title .-title {
  aspect-ratio: 2/14;
  position: sticky;
}
@media screen and (min-width: 769px) {
  .p-profile__box-title .-title {
    top: 11rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-title .-title {
    top: 7rem;
  }
}
.p-profile__box.-overview {
  margin-top: 0;
}
@media screen and (min-width: 769px) {
  .p-profile__box.-overview {
    top: -10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box.-overview {
    top: -4rem;
  }
}
@media screen and (min-width: 769px) {
  .p-profile__box.-history {
    margin-top: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box.-history {
    margin-top: 2rem;
  }
}
@media screen and (min-width: 769px) {
  .p-profile__box.-office .-jp {
    letter-spacing: 0.2rem;
    font-size: 2.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box.-office .c-shape__vertical {
    padding-top: 4rem;
  }
}
.p-profile__box .-inner {
  position: relative;
  background: rgba(255, 255, 255, 0.95);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-profile__box .-inner {
    width: 100%;
    min-height: 46rem;
    padding: 10rem 10rem 10rem 20rem;
    -webkit-box-shadow: 4rem 4rem #DCDDDD;
            box-shadow: 4rem 4rem #DCDDDD;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box .-inner {
    width: 100%;
    padding: 4rem 3rem 4rem 8rem;
    -webkit-box-shadow: 1rem 1rem #DCDDDD;
            box-shadow: 1rem 1rem #DCDDDD;
  }
}
.p-profile__box .-inner::before {
  position: absolute;
  content: "";
}
@media screen and (min-width: 769px) {
  .p-profile__box .-inner::before {
    width: calc(100% - 8rem);
    height: calc(100% - 8rem);
    border: 0.3rem solid var(--color-site-main);
    left: 4rem;
    top: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box .-inner::before {
    width: calc(100% - 2rem);
    height: calc(100% - 2rem);
    border: 0.2rem solid var(--color-site-main);
    left: 1rem;
    top: 1rem;
  }
}
@media screen and (min-width: 769px) {
  .p-profile__box .-text {
    font-weight: 500;
    font-size: 1.8rem;
  }
}
.p-profile__box .-detail {
  position: relative;
  z-index: 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-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  margin: 0 auto;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .p-profile__box .-detail {
    gap: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box .-detail {
    gap: 2rem;
  }
}
.p-profile__box-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 768px) {
  .p-profile__box-info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    border-top: 1px solid var(--color-bg-gray-deep);
  }
}
@media screen and (min-width: 769px) {
  .p-profile__box-info dt, .p-profile__box-info dd {
    border-bottom: 1px solid var(--color-bg-gray-deep);
    padding: 1.5rem 1rem;
  }
}
.p-profile__box-info dt {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-profile__box-info dt {
    width: 20%;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-info dt {
    width: 100%;
    padding-top: 1rem;
    font-size: 1.3rem;
  }
}
@media screen and (min-width: 769px) {
  .p-profile__box-info dd {
    width: 80%;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-info dd {
    width: 100%;
    border-bottom: 1px solid var(--color-bg-gray-deep);
    padding: 0rem 0 1rem;
    font-size: 1.2rem;
  }
}
.p-profile__box-info-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 0.5rem;
}
.p-profile__box-info-list li::before {
  content: "●";
  color: var(--color-site-main);
}
@media screen and (min-width: 769px) {
  .p-profile__box-info-list li::before {
    font-size: 1rem;
    padding-top: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-info-list li::before {
    font-size: 0.6rem;
    padding-top: 0.7rem;
  }
}
.p-profile__box-info-member {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
.p-profile__box-info-member-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-profile__box-info-member-item .-position {
    width: 14rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-info-member-item .-position {
    width: 12rem;
  }
}
.p-profile__box-info-note {
  margin-top: 1rem;
}
@media screen and (min-width: 769px) {
  .p-profile__box-info-note {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-info-note {
    font-size: 1rem;
  }
}
.p-profile__box-history {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
}
.p-profile__box-history::before {
  content: "";
  height: 100%;
  background: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, 0)), color-stop(1%, var(--color-bg-gray-deep)), to(var(--color-bg-gray-deep)));
  background: linear-gradient(to top, rgba(0, 0, 0, 0) 0%, var(--color-bg-gray-deep) 1%, var(--color-bg-gray-deep) 100%);
  position: absolute;
  display: block;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-profile__box-history::before {
    left: 4.75rem;
    top: 3rem;
    width: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-history::before {
    left: 3rem;
    top: 3rem;
    width: 0.5rem;
  }
}
.p-profile__box-history-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .p-profile__box-history-item {
    gap: 8rem;
    min-height: 13rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-history-item {
    gap: 2rem;
  }
}
.p-profile__box-history-item .-year {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  border-radius: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  background-color: var(--color-site-main);
  font-family: var(--font-family-en1);
  font-weight: 500;
  color: #FFF;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-profile__box-history-item .-year {
    width: 10rem;
    height: 10rem;
    font-size: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-history-item .-year {
    width: 6rem;
    height: 6rem;
    font-size: 1.6rem;
  }
}
.p-profile__box-history-item .-year::before {
  content: "";
  height: 1px;
  background-color: var(--color-bg-gray-deep);
  position: absolute;
  left: 100%;
  top: 50%;
  display: block;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-profile__box-history-item .-year::before {
    width: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-history-item .-year::before {
    width: 1rem;
  }
}
.p-profile__box-history-item .-section {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 1rem;
}
@media screen and (min-width: 769px) {
  .p-profile__box-history-item .-section {
    padding-top: 3.5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-history-item .-section {
    padding-top: 1.5rem;
    font-size: 1.2rem;
  }
}
.p-profile__box-history-item .-month {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 768px) {
  .p-profile__box-history-item .-month {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-profile__box-history-item .-month .-num {
  -ms-flex-negative: 0;
      flex-shrink: 0;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-profile__box-history-item .-month .-num {
    width: 5.6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-history-item .-month .-num {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    font-size: 1.4rem;
  }
}
.p-profile__box-history-item:nth-child(2n) .-year {
  background-color: #5E5F5F;
}
@media screen and (min-width: 769px) {
  .p-profile__box-history-item:nth-child(2n) .-year {
    -webkit-transform: translateX(1rem);
            transform: translateX(1rem);
  }
}
.p-profile__box-office {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-section:not(:first-of-type) {
    margin-top: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-section:not(:first-of-type) {
    margin-top: 4rem;
  }
}
.p-profile__box-office-header {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-header {
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-header {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-profile__box-office-header-title {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-header-title {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-header-title {
    font-size: 1.8rem;
    line-height: 1.2;
  }
}
.p-profile__box-office-header-en {
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  opacity: 0.3;
  font-weight: 500;
  line-height: 1;
  position: absolute;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-header-en {
    font-size: 8rem;
    top: 0;
    right: 0;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-header-en {
    font-size: 4rem;
    top: 100%;
    left: 0;
  }
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-img {
    margin-top: 1rem;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-img {
    margin-top: 2rem;
  }
}
.p-profile__box-office-img img {
  aspect-ratio: 6/4;
  -o-object-fit: cover;
     object-fit: cover;
}
.p-profile__box-office-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-inner {
    margin-top: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    gap: 1rem;
    margin-top: 1rem;
  }
}
.p-profile__box-office-detail {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-detail {
    width: 45%;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-detail {
    width: 100%;
    font-size: 1.3rem;
  }
}
.p-profile__box-office-detail-address {
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-detail-address {
    margin-bottom: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-detail-address {
    margin-bottom: 0.5rem;
  }
}
.p-profile__box-office-map {
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}
@media screen and (min-width: 769px) {
  .p-profile__box-office-map {
    aspect-ratio: 4/3;
  }
}
@media screen and (max-width: 768px) {
  .p-profile__box-office-map {
    aspect-ratio: 3/3;
  }
}
.p-profile__box-office-map iframe {
  width: 100%;
  height: 100%;
}

.p-recruit__main {
  background-image: url("../../assets/images/recruit/main.jpg");
}
@media screen and (min-width: 769px) {
  .p-recruit__contents {
    padding-bottom: 10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__contents {
    padding-bottom: 0;
  }
}
.p-recruit__message {
  position: relative;
  margin-top: 0;
}
@media screen and (min-width: 769px) {
  .p-recruit__message {
    top: -10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message {
    top: -4rem;
  }
}
.p-recruit__message-title {
  position: absolute;
  z-index: 2;
  height: 100%;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-title {
    left: calc(4% + 8rem);
    top: -8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-title {
    left: 2rem;
    top: -2rem;
  }
}
.p-recruit__message-title .-title {
  aspect-ratio: 2/14;
  position: sticky;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-title .-title {
    top: 11rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-title .-title {
    top: 7rem;
  }
}
.p-recruit__message-wrapper {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  background: rgba(255, 255, 255, 0.95) url("../images/recruit/message_bg.svg") no-repeat;
  background-size: contain;
  overflow: hidden;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-wrapper {
    width: 90%;
    margin: 0 auto;
    min-height: 46rem;
    padding: 9rem 10rem 10rem 20rem;
    -webkit-box-shadow: 4rem 4rem #DCDDDD;
            box-shadow: 4rem 4rem #DCDDDD;
    background-position: right 92%;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-wrapper {
    width: 100%;
    padding: 3rem 3rem 4rem 8rem;
    -webkit-box-shadow: 1rem 1rem #DCDDDD;
            box-shadow: 1rem 1rem #DCDDDD;
    background-position: right 98%;
  }
}
.p-recruit__message-wrapper::before {
  position: absolute;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-wrapper::before {
    width: calc(100% - 8rem);
    height: calc(100% - 8rem);
    border: 0.3rem solid var(--color-site-main);
    left: 4rem;
    top: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-wrapper::before {
    width: calc(100% - 2rem);
    height: calc(100% - 2rem);
    border: 0.2rem solid var(--color-site-main);
    left: 1rem;
    top: 1rem;
  }
}
.p-recruit__message-inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-inner {
    gap: 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-inner {
    gap: 1rem;
  }
}
.p-recruit__message-header {
  font-weight: bold;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-header {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-header {
    font-size: 1.8rem;
  }
}
.p-recruit__message-header .-en {
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  opacity: 0.1;
  font-weight: 500;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-header .-en {
    font-size: 8.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-header .-en {
    font-size: 4.2rem;
  }
}
.p-recruit__message-body {
  line-height: 2;
}
@media screen and (min-width: 769px) {
  .p-recruit__message-body {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__message-body {
    font-size: 1.4rem;
  }
}
.p-recruit__point {
  margin-top: 0;
}
.p-recruit__point-wrapper {
  background-color: #FFF;
}
@media screen and (min-width: 769px) {
  .p-recruit__point-wrapper {
    padding: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-wrapper {
    padding: 3rem 2rem;
  }
}
.p-recruit__point-header {
  text-align: center;
  font-weight: bold;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-recruit__point-header {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-header {
    font-size: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-header .-small {
    font-size: 1.4rem;
    display: block;
  }
}
.p-recruit__point-header .-en {
  position: absolute;
  left: 50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  opacity: 0.1;
  font-weight: 500;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .p-recruit__point-header .-en {
    font-size: 8.8rem;
    top: -50%;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-header .-en {
    font-size: 5.2rem;
    top: 32%;
  }
}
.p-recruit__point-body {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (min-width: 769px) {
  .p-recruit__point-body {
    margin-top: 5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-body {
    margin-top: 4rem;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-recruit__point-box {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
@media screen and (min-width: 769px) {
  .p-recruit__point-box {
    padding: 0 3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-box {
    padding: 2rem 3rem;
    border-top: 0.1rem solid var(--color-site-main);
  }
}
@media screen and (min-width: 769px) {
  .p-recruit__point-box:not(:first-of-type) {
    border-left: 0.3rem solid var(--color-site-main);
  }
}
.p-recruit__point-box-title {
  font-weight: bold;
  color: #FFF;
  background-color: var(--color-site-main);
  display: block;
  text-align: center;
  border-radius: 50rem;
  width: 80%;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .p-recruit__point-box-title {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-box-title {
    font-size: 1.4rem;
  }
}
.p-recruit__point-box-detail {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  font-weight: 500;
  font-size: 3.2rem;
  color: var(--color-site-main);
}
@media screen and (min-width: 769px) {
  .p-recruit__point-box-detail {
    padding: 2rem 0 0.2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-box-detail {
    padding: 1rem 0 0.2rem;
  }
}
.p-recruit__point-box-detail .-num {
  line-height: 1;
  font-family: var(--font-family-en1);
  letter-spacing: -3px;
}
@media screen and (min-width: 769px) {
  .p-recruit__point-box-detail .-num {
    font-size: 10.2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__point-box-detail .-num {
    font-size: 6.2rem;
  }
}
.p-recruit__point-box-note {
  text-align: center;
  font-size: 1.4rem;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .p-recruit__want {
    margin-top: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want {
    margin-top: 6rem;
  }
}
.p-recruit__want-wrapper {
  background-color: #FFF;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: stretch;
      -ms-flex-align: stretch;
          align-items: stretch;
}
@media screen and (max-width: 768px) {
  .p-recruit__want-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-recruit__want-detail, .p-recruit__want-img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 769px) {
  .p-recruit__want-detail, .p-recruit__want-img {
    width: 50%;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-detail, .p-recruit__want-img {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .p-recruit__want-detail {
    padding: 8rem 4rem 8rem 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-detail {
    padding: 4rem 3rem;
  }
}
.p-recruit__want-detail-inner {
  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-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
@media screen and (min-width: 769px) {
  .p-recruit__want-detail-inner {
    gap: 4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-detail-inner {
    gap: 2rem;
  }
}
.p-recruit__want-title {
  text-align: center;
  font-weight: bold;
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-recruit__want-title {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-title {
    font-size: 2.2rem;
  }
}
.p-recruit__want-title .-en {
  position: absolute;
  left: 50%;
  top: -50%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  opacity: 0.1;
  font-weight: 500;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .p-recruit__want-title .-en {
    font-size: 8.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-title .-en {
    font-size: 6.8rem;
  }
}
.p-recruit__want-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.5rem;
}
.p-recruit__want-list li {
  font-weight: 600;
  line-height: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5rem;
}
@media screen and (min-width: 769px) {
  .p-recruit__want-list li {
    font-size: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-list li {
    font-size: 1.6rem;
  }
}
.p-recruit__want-list li::before {
  content: "●";
  color: var(--color-site-main);
}
@media screen and (min-width: 769px) {
  .p-recruit__want-list li::before {
    font-size: 1rem;
    padding-top: 0.5rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-list li::before {
    font-size: 0.6rem;
    padding-top: 0.7rem;
  }
}
.p-recruit__want-text {
  font-weight: 500;
  line-height: 2;
}
@media screen and (min-width: 769px) {
  .p-recruit__want-text {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__want-text {
    font-size: 1.4rem;
  }
}
.p-recruit__want-img {
  background-image: url("../images/recruit/want_img.jpg");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}
@media screen and (max-width: 768px) {
  .p-recruit__want-img {
    height: 20rem;
  }
}
.p-recruit__interview-main {
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-main {
    padding: 6rem 0 0 12rem;
    max-width: 144rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-main {
    padding: 5rem 0 0 3rem;
  }
}
.p-recruit__interview-main-title {
  position: absolute;
  z-index: 1;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-main-title {
    left: 17rem;
    top: -2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-main-title {
    left: 5rem;
    top: -2rem;
    height: 100%;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-main-title .-title {
    position: sticky;
    top: 7rem;
  }
}
.p-recruit__interview-main-img {
  width: 100%;
  height: auto;
  position: relative;
}
.p-recruit__interview-main-img img {
  width: 100%;
  height: auto;
}
.p-recruit__interview-main-img-name {
  position: absolute;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-main-img-name {
    right: 15%;
    bottom: 20%;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-main-img-name {
    right: 3%;
    bottom: 3%;
    font-size: 1.2rem;
    background: rgba(255, 255, 255, 0.6);
    padding: 1rem;
  }
}
.p-recruit__interview-main-img-name strong {
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-main-img-name strong {
    font-size: 4.8rem;
    margin-right: 2rem;
    letter-spacing: -1rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-main-img-name strong {
    font-size: 1.8rem;
    margin-right: 1rem;
    letter-spacing: -0.3rem;
  }
}
.p-recruit__interview-main-img .-en {
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  white-space: nowrap;
  font-family: var(--font-family-en1);
  color: var(--color-site-main);
  opacity: 0.1;
  font-weight: 500;
  line-height: 1;
  position: absolute;
  left: 0;
  top: 0;
  -webkit-transform: translateX(-100%);
          transform: translateX(-100%);
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-main-img .-en {
    font-size: 9rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-main-img .-en {
    font-size: 4.2rem;
  }
}
.p-recruit__interview-main-comment {
  background-color: #FFF;
  font-weight: 500;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-main-comment {
    left: 2rem;
    bottom: 12rem;
    padding: 3rem 6rem;
    font-size: 1.8rem;
    position: absolute;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-main-comment {
    font-size: 1.4rem;
    padding: 2.5rem 2.5rem 9rem 8rem;
  }
}
.p-recruit__interview-contents {
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents {
    top: -5rem;
    padding: 0 6rem 0 0;
    max-width: 144rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents {
    top: -6rem;
    padding: 0 3rem 0 0;
  }
}
.p-recruit__interview-contents-wrapper {
  width: 100%;
  background: rgb(255, 255, 255) url("../images/recruit/message_bg.svg") no-repeat;
  background-size: contain;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-wrapper {
    padding: 8rem 0 10rem;
    background-position: right calc(100% - 5rem);
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-wrapper {
    padding: 0 0 4rem;
    background-position: right calc(100% - 3rem);
  }
}
.p-recruit__interview-contents-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
.p-recruit__interview-contents-box .-img, .p-recruit__interview-contents-box .-detail {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box .-img, .p-recruit__interview-contents-box .-detail {
    width: 50%;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box .-img, .p-recruit__interview-contents-box .-detail {
    width: 100%;
  }
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box .-detail {
    padding: 0 6rem 0 2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box .-detail {
    padding: 2rem;
  }
}
.p-recruit__interview-contents-box .-img {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box .-img {
    left: -4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box .-img {
    left: -2rem;
  }
}
.p-recruit__interview-contents-box .-q {
  font-weight: 600;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 2rem;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box .-q {
    font-size: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box .-q {
    font-size: 1.6rem;
  }
}
.p-recruit__interview-contents-box .-q::before {
  content: "";
  display: block;
  background: var(--color-site-main);
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box .-q::before {
    width: 6rem;
    height: 0.3rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box .-q::before {
    width: 4rem;
    height: 0.2rem;
  }
}
.p-recruit__interview-contents-box .-q:not(:first-of-type) {
  margin-top: 2rem;
}
.p-recruit__interview-contents-box .-a {
  margin-top: 1rem;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box:nth-child(2n) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
            flex-direction: row-reverse;
  }
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box:nth-child(2n) .-detail {
    padding: 0 2rem 0 6rem;
  }
}
.p-recruit__interview-contents-box:nth-child(2n) .-img {
  position: relative;
  left: inherit;
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box:nth-child(2n) .-img {
    right: -4rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box:nth-child(2n) .-img {
    right: -2rem;
  }
}
@media screen and (min-width: 769px) {
  .p-recruit__interview-contents-box:not(:first-of-type) {
    margin-top: 6rem;
  }
}
@media screen and (max-width: 768px) {
  .p-recruit__interview-contents-box:not(:first-of-type) {
    margin-top: 3rem;
  }
}

.p-contact__main {
  background-image: url("../../assets/images/contact/main.jpg");
}
@media screen and (min-width: 769px) {
  .p-contact__main {
    max-height: 52rem;
  }
}
.p-contact__contents {
  padding: 0 0 2rem;
}
.p-contact .c-contact__form {
  position: relative;
}
@media screen and (min-width: 769px) {
  .p-contact .c-contact__form {
    top: -10rem;
  }
}
@media screen and (max-width: 768px) {
  .p-contact .c-contact__form {
    top: -4rem;
  }
}

.p-404__main {
  background-image: url("../../assets/images/404/main.jpg");
}
@media screen and (min-width: 769px) {
  .p-404__main {
    max-height: 36rem;
  }
}
@media screen and (max-width: 768px) {
  .p-404__main {
    min-height: 16rem;
  }
}
@media screen and (min-width: 769px) {
  .p-404__main .-title {
    font-size: 4.2rem;
  }
}
@media screen and (max-width: 768px) {
  .p-404__main .-title {
    font-size: 2.2rem;
    letter-spacing: 0.2rem;
  }
}
@media screen and (min-width: 769px) {
  .p-404__main .-en {
    font-size: 7.8rem;
  }
}
@media screen and (max-width: 768px) {
  .p-404__main .-en {
    font-size: 3rem;
  }
}
.p-404__wrapper {
  padding: 0rem 0 2rem;
}
.p-404__inner {
  position: relative;
  background: #FFF;
}
@media screen and (min-width: 769px) {
  .p-404__inner {
    top: -6rem;
    padding: 6rem 8rem;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 2;
    text-align: center;
  }
}
@media screen and (max-width: 768px) {
  .p-404__inner {
    top: -3rem;
    padding: 2rem;
  }
}
.p-404__btn {
  max-width: 42rem;
}
@media screen and (min-width: 769px) {
  .p-404__btn {
    margin: 4rem auto 0;
  }
}
@media screen and (max-width: 768px) {
  .p-404__btn {
    margin: 2rem auto 0;
  }
}