@charset "UTF-8";
z *,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  font-size: 16px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  z *,
*::before,
*::after {
    font-size: 3.7333333333vw;
  }
}

/* Remove default padding */
ul,
ol {
  padding: 0;
}

/* Remove default margin */
body,
h1,
h2,
h3,
h4,
p,
ul,
ol,
li,
figure,
figcaption,
blockquote,
dl,
dd {
  margin: 0;
}

/* Set core body defaults */
body {
  min-height: 100vh;
  scroll-behavior: smooth;
  text-rendering: optimizeSpeed;
  line-height: 1.5;
}

/* Remove list styles on ul, ol elements with a class attribute */
ul,
ol {
  list-style: none;
}

/* Make images easier to work with */
img {
  max-width: 100%;
}

/* Inherit fonts for inputs and buttons */
input,
button,
textarea,
select {
  font: inherit;
}

/* Remove all animations and transitions for people that prefer not to see them */
@media (prefers-reduced-motion: reduce) {
  * {
    -webkit-animation-duration: 0.01ms !important;
            animation-duration: 0.01ms !important;
    -webkit-animation-iteration-count: 1 !important;
            animation-iteration-count: 1 !important;
    -webkit-transition-duration: 0.01ms !important;
         -o-transition-duration: 0.01ms !important;
            transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}
html {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
@media screen and (max-width: 767px) {
  html {
    font-size: 3.7333333333vw;
  }
}

body {
  min-width: 1240px;
  
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  letter-spacing: 0;
  color: #000;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  -webkit-print-color-adjust: exact;
   opacity: 1 !important;
  overflow: visible;
  -webkit-transition: opacity 0.3s;
  -o-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (max-width: 767px) {
  body {
    min-width: auto;
  }
  body.drawer_open {
    overflow: hidden;
  }
}
body.comp {
  opacity: 1 !important;
  overflow: visible;
  -webkit-transition: opacity 0.3s;
  -o-transition: opacity 0.3s;
  transition: opacity 0.3s;
}
@media screen and (max-width: 767px) {
  body.comp.drawer_open {
    overflow: hidden;
  }
}

div, th, td {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

p, span, b, small, big, strong, tr, th, td, dl, dt, dd, ol, ul, li, h1, h2, h3, h4 {
  font-size: 1rem;
  line-height: 1.8;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}
sup {
  font-size: 0.7em;
}

mark {
  background-color: rgba(0, 0, 0, 0);
}

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  font-family: "object-fit: cover;";
}

img {
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

a {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  text-decoration: none;
  color: #000;
  -webkit-transition: opacity 0.3s;
  -o-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

a:hover {
  opacity: 0.7;
}

a img {
  -webkit-transition: opacity 0.3s;
  -o-transition: opacity 0.3s;
  transition: opacity 0.3s;
}

a:hover img {
  opacity: 1;
}

::-webkit-input-placeholder {
  color: #C8C8C8;
}

::-moz-placeholder {
  color: #C8C8C8;
}

:-ms-input-placeholder {
  color: #C8C8C8;
}

::-ms-input-placeholder {
  color: #C8C8C8;
}

::placeholder {
  color: #C8C8C8;
}

/*◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇

  COMMON CLASS

◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇*/
#pageWrapper {
  min-height: 100vh;
  overflow: hidden;
}
.container {
  max-width: 1200px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .container {
    max-width: none;
    padding: 0 5.3333333333vw;
  }
}
.container_l {
  max-width: 1240px;
}
.container_m {
  max-width: 1080px;
}
.container_s {
  max-width: 1000px;
}
.container_col2 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  padding: 0;
  margin-top: 72px;
}
@media screen and (max-width: 767px) {
  .container_col2 {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    margin-top: 9.6vw;
  }
}
.container_col2 > div:nth-child(1) {
  width: 100%;
  max-width: 550px;
}
@media screen and (max-width: 767px) {
  .container_col2 > div:nth-child(1) {
    max-width: none;
  }
}
.container_col2 > div:nth-child(2) {
  width: 100%;
  max-width: 350px;
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  .container_col2 > div:nth-child(2) {
    max-width: none;
    margin-top: 13.3333333333vw;
    margin-left: 0;
  }
}
.container_col2 > div:nth-child(2) p {
  margin-top: 20px;
  font-size: 14px;
  line-height: 32px;
  letter-spacing: 0.06em;
}
.container_col2 > div:nth-child(2) p:first-child {
  margin-top: none;
}
.container_col2 > div:nth-child(2) img {
  display: block;
  margin-top: 30px;
}
.container_col2 > div:nth-child(2) img:first-child {
  margin-top: 0;
}

@media screen and (max-width: 767px) {
  .pc {
    display: none;
  }
}

.sp {
  display: none;
}
@media screen and (max-width: 767px) {
  .sp {
    display: block;
  }
}

.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  .row {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.ai_c {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.jc_c {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.ta_c {
  text-align: center;
}

/* COLOR
------------------------------ */
.red {
  color: #e11d1d;
}

.blue {
  color: #0c419a;
}

.color1 {
  color: #0c419a;
}
.color2 {
  color: #C8A063;
}
.color3 {
  color: #EFE2CF;
}
.color4 {
  color: #EA5E7B;
}

.b_color1 {
  background-color: #181C5C;
}
.b_color2 {
  background-color: #C8A063;
}
.b_color3 {
  background-color: #EFE2CF;
}
.b_color_gradient {
  background: -o-linear-gradient(315deg, rgb(207, 173, 121) 0%, rgb(207, 173, 121) 50%, rgb(200, 160, 99) 50%, rgb(200, 160, 99) 100%);
  background: linear-gradient(135deg, rgb(207, 173, 121) 0%, rgb(207, 173, 121) 50%, rgb(200, 160, 99) 50%, rgb(200, 160, 99) 100%);
}
.b_color_gradient1 {
  background: -o-linear-gradient(315deg, #2A2A2A 0%, #2A2A2A 50%, #161616 50%, #161616 100%);
  background: linear-gradient(135deg, #2A2A2A 0%, #2A2A2A 50%, #161616 50%, #161616 100%);
}

.maker {
  padding-bottom: 0.35em;
  background: -webkit-gradient(linear, left bottom, left top, from(#C8A063), color-stop(13%, #C8A063), color-stop(13%, rgba(0, 0, 0, 0)));
  background: -o-linear-gradient(bottom, #C8A063 0%, #C8A063 13%, rgba(0, 0, 0, 0) 13%);
  background: linear-gradient(0deg, #C8A063 0%, #C8A063 13%, rgba(0, 0, 0, 0) 13%);
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .maker {
    padding-bottom: 0.15em;
    background: -webkit-gradient(linear, left bottom, left top, from(#C8A063), color-stop(13%, #C8A063), color-stop(13%, rgba(0, 0, 0, 0)));
    background: -o-linear-gradient(bottom, #C8A063 0%, #C8A063 13%, rgba(0, 0, 0, 0) 13%);
    background: linear-gradient(0deg, #C8A063 0%, #C8A063 13%, rgba(0, 0, 0, 0) 13%);
  }
}

/* FONT
------------------------------ */
.dosis {
  font-family: "Dosis", sans-serif;
}

.notoSans {
  font-family: "Noto Sans JP", sans-serif;
}

.roboto {
  font-family: "Roboto", sans-serif;
}

.Yellowtail {
  font-family: "Yellowtail", cursive;
}

.serif {
  font-family: "Shippori Mincho", serif;
}

/* WEIGHT
------------------------------ */
.bold {
  font-weight: 700;
}

.medium {
  font-weight: 500;
}

.normal {
  font-weight: 400;
}

.thin {
  font-weight: 100;
}

/* margin-top
------------------------------ */
.mt-0 {
  margin-top: 0;
}

@media screen and (max-width: 767px) {
  .js-scrollable {
    margin-right: -5.3333333333vw !important;
  }
}
@media screen and (max-width: 767px) {
  .js-scrollable img {
    max-width: 160vw;
    width: auto;
    max-height: 133.3333333333vw;
  }
}

.scroll-hint-icon {
  padding: 20px 10px 10px 10px !important;
}

.scroll-hint-text {
  color: #fff !important;
}

/*◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇

  header

◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇*/
header {
  background: #fff;
}
@media screen and (max-width: 767px) {
  header {
    width: 100%;
    background: transparent;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 999;
  }
}
header .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  max-width: none;
  padding: 40px 0;
  padding-left: 40px;
  padding-right: 40px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  header .container {
    height: 14.6666666667vw;
    padding: 0;
    padding-left: 4vw;
  }
  header .container:after {
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    background: #fff;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
  }
}
@media screen and (max-width: 767px) {
  header .header_logo {
    width: 64vw;
  }
}
header .header_logo_wrap {
  position: relative;
  z-index: 3;
}
header .header_logo_wrap h1 {
  line-height: 1;
}
header .header_nav_wrap {
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  header .header_nav_wrap {
    width: 100%;
    max-height: calc(100vh - 14.6666666667vw);
    padding: 10.6666666667vw 10vw;
    background: #0c419a;
    position: absolute;
    top: 14.5333333333vw;
    left: 0;
    z-index: 1;
    -webkit-transform: translateY(-100%);
        -ms-transform: translateY(-100%);
            transform: translateY(-100%);
    -webkit-transition: -webkit-transform 0s;
    transition: -webkit-transform 0s;
    -o-transition: transform 0s;
    transition: transform 0s;
    transition: transform 0s, -webkit-transform 0s;
    overflow-y: scroll;
  }
  header .header_nav_wrap.drawer_close {
    -webkit-transition: -webkit-transform 0.5s;
    transition: -webkit-transform 0.5s;
    -o-transition: transform 0.5s;
    transition: transform 0.5s;
    transition: transform 0.5s, -webkit-transform 0.5s;
  }
  header .header_nav_wrap.drawer_open {
    -webkit-transform: translateY(0);
        -ms-transform: translateY(0);
            transform: translateY(0);
    -webkit-transition: -webkit-transform 0.5s;
    transition: -webkit-transform 0.5s;
    -o-transition: transform 0.5s;
    transition: transform 0.5s;
    transition: transform 0.5s, -webkit-transform 0.5s;
  }
}
header .header_nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  header .header_nav ul {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
header .header_nav li a {
  letter-spacing: 0.04em;
}
@media screen and (max-width: 767px) {
  header .header_nav li a {
    display: block;
    text-align: left;
  }
}
header .header_nav li .child {
  display: none;
}
@media screen and (max-width: 767px) {
  header .header_nav li .child {
    margin-top: 3.7333333333vw;
  }
  header .header_nav li .child li {
    padding: 0;
    margin-bottom: 3.7333333333vw;
    border: none;
  }
  header .header_nav li .child a {
    padding-left: 4.2666666667vw;
    font-size: 3.7333333333vw;
    font-weight: 400;
    position: relative;
  }
  header .header_nav li .child a:before {
    content: "";
    display: block;
    width: 2.1333333333vw;
    height: 1px;
    background: #fff;
    position: absolute;
    top: 12px;
    left: 0;
    z-index: 1;
  }
}
@media screen and (max-width: 767px) {
  header .header_nav li.parent {
    position: relative;
  }
  header .header_nav li.parent:after {
    content: "";
    display: block;
    width: 3.7333333333vw;
    height: 1.8666666667vw;
    background-image: url(../img/common/header_parent_arrow_close.png);
    background: url(../img/common/header_parent_arrow.png) 50%/cover;
    position: absolute;
    top: 6.9333333333vw;
    right: 2.6666666667vw;
    z-index: 1;
    -webkit-transition: background-image 0.5s;
    -o-transition: background-image 0.5s;
    transition: background-image 0.5s;
  }
  header .header_nav li.parent > a {
    pointer-events: none;
  }
  header .header_nav li.parent.open:after {
    background-image: url(../img/common/header_parent_arrow_close.png);
  }
}
header .header_nav li.recruit a {
  /*
  display: flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  height: 30px;
  border-radius: 15px;
  background: #626262;
  color: #fff;
  @media screen and ( max-width:767px){
    display: block;
    width: auto;
    height: auto;
    background: transparent;
  }
  */
}
header .header_nav .other_links li:after {
  content: "｜";
  margin: 0 1em;
  font-size: 12px;
  font-weight: 500;
}
header .header_nav .other_links li a {
  font-size: 12px;
  font-weight: 500;
}
header .header_nav .other_links li:last-child:after {
  content: none;
}
header .header_nav .language_links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-left: 40px;
}
header .header_nav .language_links:before {
  content: "";
  display: block;
  width: 20px;
  height: 20px;
  margin-right: 8px;
  background: url(../img/common/icon_global@2x.png) 50%/cover;
}
header .header_nav .language_links li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
header .header_nav .language_links li:after {
  content: "";
  display: block;
  width: 1px;
  height: 18px;
  margin: 0 11px;
  background: #a0a0a0;
  -webkit-transform: rotate(15deg);
      -ms-transform: rotate(15deg);
          transform: rotate(15deg);
}
header .header_nav .language_links li a {
  padding: 0 1px;
  border-bottom: 1px solid transparent;
  font-size: 14px;
  line-height: 1.3;
  font-weight: 500;
  color: #9fa0a0;
}
header .header_nav .language_links li:last-child:after {
  content: none;
}
header .header_nav .language_links li.active a {
  border-bottom: 1px solid #000;
  color: #000;
}
header .header_nav_top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  header .header_nav_top {
    display: none;
  }
}
header .header_nav_bottom li {
  margin-left: 2em;
}
@media screen and (max-width: 767px) {
  header .header_nav_bottom li {
    padding: 3.7333333333vw 0;
    margin-left: 0;
    border-bottom: 1px solid #2e73e7;
  }
  header .header_nav_bottom li:first-child {
    border-top: 1px solid #2e73e7;
  }
}
header .header_nav_bottom li a {
  font-size: 15px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  header .header_nav_bottom li a {
    font-size: 4.5333333333vw;
    color: #fff;
  }
}
@media screen and (max-width: 767px) {
  header .header_nav_btn {
    width: 14.6666666667vw;
    height: 14.6666666667vw;
    margin-left: auto;
    background-image: url(../img/common/header_nav_btn_close.jpg);
    background: url(../img/common/header_nav_btn.jpg) 50%/cover;
    position: relative;
    z-index: 2;
    -webkit-transition: background-image 0.5s;
    -o-transition: background-image 0.5s;
    transition: background-image 0.5s;
  }
  header .header_nav_btn.drawer_open {
    background-image: url(../img/common/header_nav_btn_close.jpg);
  }
}
header .contact_btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 180px;
  height: 120px;
  margin-left: 40px;
  background: #0c419a;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #fff;
}
header .contact_btn.sp {
  display: none;
}
@media screen and (max-width: 767px) {
  header .contact_btn.pc {
    display: none;
  }
}

body.event-news header .header_nav li.event-news a,
body.category-news header .header_nav li.event-news a,
body.category-event header .header_nav li.event-news a {
  color: #0c419a;
}
@media screen and (max-width: 767px) {
  body.event-news header .header_nav li.event-news a,
body.category-news header .header_nav li.event-news a,
body.category-event header .header_nav li.event-news a {
    color: #fff;
  }
}

body.company header .header_nav li.company a {
  color: #0c419a;
}
@media screen and (max-width: 767px) {
  body.company header .header_nav li.company a {
    color: #fff;
  }
}

body.business header .header_nav li.business a {
  color: #0c419a;
}
@media screen and (max-width: 767px) {
  body.business header .header_nav li.business a {
    color: #fff;
  }
}

body.material header .header_nav li.material a {
  color: #0c419a;
}
@media screen and (max-width: 767px) {
  body.material header .header_nav li.material a {
    color: #fff;
  }
}

body.dictionary header .header_nav li.dictionary a {
  color: #0c419a;
}
@media screen and (max-width: 767px) {
  body.dictionary header .header_nav li.dictionary a {
    color: #fff;
  }
}

body.contact header .header_nav li.contact a {
  color: #0c419a;
}
@media screen and (max-width: 767px) {
  body.contact header .header_nav li.contact a {
    color: #fff;
  }
}

body.recruit header .header_nav li.recruit a {
  color: #0c419a;
}
@media screen and (max-width: 767px) {
  body.recruit header .header_nav li.recruit a {
    color: #fff;
  }
}

/*◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇

  #close_cover

◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇*/
.close_cover {
  display: none;
}
@media screen and (max-width: 767px) {
  .close_cover {
    display: block;
    width: 100vw;
    height: 100vh;
    background: rgba(0, 0, 0, 0.5);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 998;
    opacity: 0;
    visibility: hidden;
    -webkit-transition: opacity 0.5s, visibility 0.5s;
    -o-transition: opacity 0.5s, visibility 0.5s;
    transition: opacity 0.5s, visibility 0.5s;
  }
}
@media screen and (max-width: 767px) {
  .close_cover.drawer_open {
    opacity: 1;
    visibility: visible;
  }
}

/*◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇

  footer

◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇*/
footer {
  background: #0c419a;
}
footer * {
  color: #fff;
}
footer .container {
  padding-top: 80px;
  padding-bottom: 60px;
}
@media screen and (max-width: 767px) {
  footer .container {
    padding-top: 13.3333333333vw;
    padding-bottom: 13.3333333333vw;
  }
}
footer .footer_top {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  footer .footer_top {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
@media screen and (max-width: 767px) {
  footer .footer_logo {
    width: 80vw;
  }
}
footer .footer_logo_wrap {
  margin-top: 8px;
  margin-bottom: 56px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  footer .footer_logo_wrap {
    margin: 0 auto;
    margin-bottom: 11.7333333333vw;
  }
}
footer .footer_nav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
@media screen and (max-width: 767px) {
  footer .footer_nav {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
  }
}
footer .footer_nav_wrap {
  margin-left: auto;
}
@media screen and (max-width: 767px) {
  footer .footer_nav_wrap {
    padding: 0 4.6666666667vw;
    margin-left: 0;
  }
}
footer .footer_nav + .footer_nav {
  margin-top: 44px;
}
@media screen and (max-width: 767px) {
  footer .footer_nav + .footer_nav {
    margin-top: 8.5333333333vw;
  }
}
@media screen and (max-width: 767px) {
  footer .footer_nav + .footer_nav li {
    margin-bottom: 6.4vw;
  }
}
footer .footer_nav li {
  width: 200px;
  margin-right: 40px;
}
@media screen and (max-width: 767px) {
  footer .footer_nav li {
    width: auto;
    margin-right: 0;
    margin-bottom: 8.5333333333vw;
  }
}
footer .footer_nav li:last-child {
  margin-right: 0;
}
@media screen and (max-width: 767px) {
  footer .footer_nav li:last-child {
    margin-bottom: 0;
  }
}
footer .footer_nav a {
  display: inline-block;
  width: 200px;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid #2e73e7;
  font-size: 15px;
  font-weight: 500;
}
@media screen and (max-width: 767px) {
  footer .footer_nav a {
    width: 100%;
    padding-bottom: 2.6666666667vw;
    margin-bottom: 3.2vw;
    font-size: 4vw;
  }
}
footer .footer_nav a:last-child {
  margin-bottom: 0;
}
footer .footer_nav ul li {
  padding: 0;
  margin: 0;
  margin-bottom: 4px;
}
@media screen and (max-width: 767px) {
  footer .footer_nav ul li {
    margin-bottom: 1.6vw;
  }
}
footer .footer_nav ul li:last-child {
  margin-bottom: 0;
}
footer .footer_nav ul a {
  width: auto;
  padding: 0;
  padding-left: 18px;
  margin: 0;
  border: none;
  font-size: 14px;
  font-weight: 400;
  position: relative;
}
@media screen and (max-width: 767px) {
  footer .footer_nav ul a {
    padding-left: 4.2666666667vw;
    font-size: 3.7333333333vw;
  }
}
footer .footer_nav ul a:before {
  content: "";
  display: block;
  width: 8px;
  height: 1px;
  background: #fff;
  position: absolute;
  top: 12px;
  left: 0;
  z-index: 1;
}
@media screen and (max-width: 767px) {
  footer .footer_nav ul a:before {
    width: 2.1333333333vw;
  }
}
footer .footer_bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: 48px;
}
@media screen and (max-width: 767px) {
  footer .footer_bottom {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
            flex-direction: column-reverse;
    margin-top: 11.7333333333vw;
  }
}
footer .copyright {
  font-size: 10px;
  font-weight: 300;
  letter-spacing: 0.06em;
  text-align: center;
  color: #ddd;
}
@media screen and (max-width: 767px) {
  footer .copyright {
    margin-top: 8.5333333333vw;
    font-size: 2.6666666667vw;
  }
}
footer .other_links {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin-left: 186px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  footer .other_links {
    padding: 0 4.6666666667vw;
    margin-left: 0;
  }
}
@media screen and (max-width: 767px) {
  footer .other_links li {
    margin-bottom: 2.1333333333vw;
  }
}
footer .other_links li:after {
  content: "｜";
  margin: 0 1em;
}
@media screen and (max-width: 767px) {
  footer .other_links li:nth-child(2n):after {
    content: none;
  }
}
footer .other_links li:last-child:after {
  content: none;
}
footer .other_links a {
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  footer .other_links a {
    font-size: 3.7333333333vw;
  }
}

/*◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇

  #pagetop

◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇*/
#pagetop {
  position: fixed;
  bottom: 173px;
  right: 0;
  z-index: 999;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity 0.3s, visibility 0.3s;
  -o-transition: opacity 0.3s, visibility 0.3s;
  transition: opacity 0.3s, visibility 0.3s;
}
@media screen and (max-width: 767px) {
  #pagetop {
    width: 10.6666666667vw;
    bottom: 30.6666666667vw;
  }
}
#pagetop.scrolled {
  opacity: 1;
  visibility: visible;
}

/*◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇

  COMMON

◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇◆◇*/
/*---------------------------------------
    アニメーション
---------------------------------------*/
.fadeIn,
.fadeInLeft,
.fadeInRight,
.fadeInListItem {
  opacity: 0;
  visibility: hidden;
  -webkit-transform: translateY(100px);
      -ms-transform: translateY(100px);
          transform: translateY(100px);
  -webkit-transition: opacity 1s, visibility 1s, -webkit-transform 1s;
  transition: opacity 1s, visibility 1s, -webkit-transform 1s;
  -o-transition: opacity 1s, visibility 1s, transform 1s;
  transition: opacity 1s, visibility 1s, transform 1s;
  transition: opacity 1s, visibility 1s, transform 1s, -webkit-transform 1s;
}
@media screen and (max-width: 767px) {
  .fadeIn,
.fadeInLeft,
.fadeInRight,
.fadeInListItem {
    -webkit-transform: translateY(13.3333333333vw);
        -ms-transform: translateY(13.3333333333vw);
            transform: translateY(13.3333333333vw);
  }
}
.fadeIn.scrollIn,
.fadeInLeft.scrollIn,
.fadeInRight.scrollIn,
.fadeInListItem.scrollIn {
  opacity: 1;
  visibility: visible;
  -webkit-transform: translate(0);
      -ms-transform: translate(0);
          transform: translate(0);
}

.fadeInLeft {
  -webkit-transform: translateX(-100px);
      -ms-transform: translateX(-100px);
          transform: translateX(-100px);
}
@media screen and (max-width: 767px) {
  .fadeInLeft {
    -webkit-transform: translateX(-13.3333333333vw);
        -ms-transform: translateX(-13.3333333333vw);
            transform: translateX(-13.3333333333vw);
  }
}

.fadeInRight {
  -webkit-transform: translateX(100px);
      -ms-transform: translateX(100px);
          transform: translateX(100px);
}
@media screen and (max-width: 767px) {
  .fadeInRight {
    -webkit-transform: translateX(13.3333333333vw);
        -ms-transform: translateX(13.3333333333vw);
            transform: translateX(13.3333333333vw);
  }
}

/*---------------------------------------
    .sec_heading
---------------------------------------*/
#recruit .recruit_list_item_img {
  height: 250px;
}

#recruit .recruit_list_item_text_block {
  height: 50px;
  padding-top: 0;
}

#recruit .recruit_list_item_text_block:after {
  top: 18px;
}

@media screen and (max-width: 767px) {
  #recruit .recruit_list_item_img {
    height: 54vw;
  }

  #recruit .recruit_list_item_text_block {
    height: 14vw;
  }

  #recruit .recruit_list_item_text_block:after {
    top: 6.3vw;
  }
}
#recruit .movie_link_title {
  text-align: center;
  font-size: 30px;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: 0.06em;
  margin-bottom: 40px;
  display: flex;
  justify-content: center;
  align-items: end;
  gap: 54px;
}
#recruit .movie_link_title::before,
#recruit .movie_link_title::after {
  content: "";
  width: 4px;
  height: 80px;
  display: block;
  background: #0C419A;
}
#recruit .movie_link_title::before {
  transform: rotate(150deg);
  margin-bottom: -4px;
}
#recruit .movie_link_title::after {
  transform: rotate(-150deg);
  margin-bottom: -4px;
}
#recruit .movie_link_title .-sp-only {
  display: none;
}
#recruit .movie_link_container {
  text-align: center;
  margin-bottom: 56px;
}
@media screen and (max-width: 767px) {
  #recruit .movie_link_title {
    font-size: 17px;
    line-height: 1.8;
    margin-bottom: 24px;
    gap: 40px;
  }
  #recruit .movie_link_title::before,
  #recruit .movie_link_title::after {
    width: 2px;
    height: 64px;
  }
  #recruit .movie_link_title::before {
    margin-bottom: -2px;
  }
  #recruit .movie_link_title::after {
    margin-bottom: -2px;
  }
  #recruit .movie_link_title .-sp-only {
    display: block;
  }
  #recruit .movie_link_container {
    text-align: center;
    margin-bottom: 40px;
  }
}
.entry_btn_block {
  background: none;
  margin-top: 0;
  margin-bottom: 80px;
}

.entry_btn_block_inner {
  height: 80px;
}

.entry_btn_block .entry_btn {
  color: #fff;
  background: #0b4fc1;
  border-bottom: 5px solid #0c419a;
}

.entry_btn_block .entry_btn:hover {
  margin-top: 3px;
  opacity: 1;
  color: #fff;
  background: #0c419a;
  border-bottom: 2px solid #0c419a;
}

.m20-t {
  margin-top: 20px !important;
}

.recruit .post {
  margin-bottom: 100px;
}