@charset "UTF-8";
.remodal {
  max-width: 100% !important;
  height: 100%;
  position: relative;
  width: 100%;
  padding-top: 56.25%;
  background: #000 !important; }
  .remodal iframe {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translateY(-50%) translateX(-50%);
    -ms-transform: translateY(-50%) translateX(-50%);
    transform: translateY(-50%) translateX(-50%);
    width: 90%;
    height: 90%;
    border-radius: 0; }

.remodal-close {
  right: 0 !important;
  left: auto !important;
  color: #fff !important; }
  .remodal-close::before {
    font-size: 50px !important; }

.mv_area {
  width: 100%;
  overflow: hidden; }
  .mv_area .inr .youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;
    background-color: #000; }
    @media only screen and (max-width: 767px) {
      .mv_area .inr .youtube {
        background: url(../img/mv.jpg) no-repeat 50% 50%/cover;
        background-color: none;
        padding-top: 0;
        padding-top: 0;
        height: 50vh; } }
    .mv_area .inr .youtube iframe {
      position: absolute;
        top: -8%;
        right: 0;
        width: 118%;
        height: 118%;
      border-radius: 0; }

.video-play-button {
  position: absolute;
  z-index: 10;
  top: 50%;
  left: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  display: block;
  width: 32px;
  height: 44px;
  /* background: #fa183d; */
  border-radius: 50%;
  padding: 18px 20px 18px 28px; }

.video-play-button:before {
  content: "";
  position: absolute;
  z-index: 0;
  left: 50%;
  top: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  display: block;
  width: 80px;
  height: 80px;
  background: #005BAC;
  border-radius: 50%;
  -webkit-animation: pulse-border 1500ms ease-out infinite;
  animation: pulse-border 1500ms ease-out infinite; }

.video-play-button:after {
  content: "";
  position: absolute;
  z-index: 1;
  left: 50%;
  top: 50%;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  display: block;
  width: 80px;
  height: 80px;
  background: #005BAC;
  border-radius: 50%;
  -webkit-transition: all 200ms;
  -o-transition: all 200ms;
  transition: all 200ms; }

.video-play-button:hover:after {
  background-color: #004079; }

.video-play-button img {
  position: relative;
  z-index: 3;
  max-width: 100%;
  width: auto;
  height: auto; }

.video-play-button span {
  display: block;
  position: relative;
  z-index: 3;
  width: 0;
  height: 0;
  border-left: 32px solid #fff;
  border-top: 22px solid transparent;
  border-bottom: 22px solid transparent; }

@-webkit-keyframes pulse-border {
  0% {
    -webkit-transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
    opacity: 1; }
  100% {
    -webkit-transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5);
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5);
    opacity: 0; } }

@keyframes pulse-border {
  0% {
    -webkit-transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1);
    opacity: 1; }
  100% {
    -webkit-transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5);
    transform: translateX(-50%) translateY(-50%) translateZ(0) scale(1.5);
    opacity: 0; } }

.video-overlay {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  background: rgba(0, 0, 0, 0.5);
  opacity: 1;
  -webkit-transition: all ease 500ms;
  -o-transition: all ease 500ms;
  transition: all ease 500ms;
  height: 100%;
  width: 100%; }

.video-overlay.open {
  position: fixed;
  z-index: 1000;
  opacity: 1; }

.video-overlay-close {
  position: absolute;
  z-index: 1000;
  top: 15px;
  right: 20px;
  font-size: 36px;
  line-height: 1;
  font-weight: 400;
  color: #fff;
  text-decoration: none;
  cursor: pointer;
  -webkit-transition: all 200ms;
  -o-transition: all 200ms;
  transition: all 200ms; }
  @media only screen and (max-width: 767px) {
    .video-overlay-close {
      display: none; } }

.video-overlay-close:hover {
  color: #fa183d; }

.video-overlay iframe {
  position: absolute;
  top: 50% !important;
  left: 50% !important;
  width: 95% !important;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%);
  -webkit-box-shadow: 0 0 15px rgba(0, 0, 0, 0.75);
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.75); }

.section {
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover; }
  .section .inr {
    width: 100%; }
  .section a {
    padding: 200px 0;
    display: block;
    position: relative;
    overflow: hidden; }
    @media only screen and (max-width: 767px) {
      .section a {
        padding: 50px 0; } }
    .section a::after {
      position: absolute;
      -webkit-transition: .8s;
      -o-transition: .8s;
      transition: .8s;
      content: '';
      width: 0;
      left: 50%;
      bottom: 0;
      height: 3px;
      background-color: rgba(255, 255, 255, 0.2);
      height: 140%;
      left: -20%;
      -webkit-transform: skewX(15deg);
      -ms-transform: skewX(15deg);
      transform: skewX(15deg); }
    .section a:hover {
      width: 100%;
      left: 0; }
      .section a:hover::after {
        left: -20%;
        width: 140%; }
  .section h2 {
    font-size: 2em;
    font-family: "EB Garamond", serif;
    letter-spacing: .2em;
    color: #fff; }
    @media only screen and (max-width: 767px) {
      .section h2 {
        font-size: 1.4em; } }
    .section h2 span {
      display: block;
      margin-top: 5px;
      font-family: "Noto Sans", sans-serif;
      font-size: .4em;
      letter-spacing: .1em; }
      @media only screen and (max-width: 767px) {
        .section h2 span {
          font-size: .6em; } }
  .section p span {
    display: block;
    margin-top: 10px;
    padding-top: 35px;
    position: relative;
    font-family: "EB Garamond", serif;
    font-style: italic;
    font-weight: bold;
    color: #fff; }
    @media only screen and (max-width: 767px) {
      .section p span {
        padding-top: 20px;
        margin-top: 5px; } }
    .section p span::before {
      content: '';
      display: inline-block;
      width: 160px;
      height: 15px;
      background-image: url(../img/arrow_white.png);
      background-size: contain;
      background-repeat: no-repeat;
      vertical-align: middle;
      position: absolute;
      top: 0;
      left: 50%;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%); }

.col_two {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .col_two section {
    width: 50%; }
    @media only screen and (max-width: 767px) {
      .col_two section {
        width: 100%; } }
    .col_two section.message {
      background-image: url(../img/bg_message.jpg); }
    .col_two section.seminar {
      background-image: url(../img/bg_seminar.jpg); }
    .col_two section.gallery {
      background-image: url(../img/bg_gallery.jpg); }
    .col_two section.story {
      background-image: url(../img/bg_story.jpg); }
    .col_two section.questionnaire {
      background-image: url(../img/bg_question.jpg); }
    .col_two section.numbers {
      background-image: url(../img/bg_numbers.jpg); }
    .col_two section.employees {
      background-image: url(../img/bg_employees.jpg); }
    .col_two section .inr a {
      text-align: center; }

.col_one section.employees {
  background-image: url(../img/bg_employees.jpg); }
.col_one section.branch {
  background-image: url(../img/bg_branch.jpg); }
.col_one section.message {
  background-image: url(../img/bg_message.jpg); }

.col_one section .inr {
  max-width: 100%; }
  .col_one section .inr a h2 {
    width: 50%;
    text-align: center;
    color: #231815; }
    @media only screen and (max-width: 767px) {
      .col_one section .inr a h2 {
        width: 100%; } }
  .col_one section .inr a p {
    width: 50%;
    text-align: center; }
    @media only screen and (max-width: 767px) {
      .col_one section .inr a p {
        width: 100%; } }
    .col_one section .inr a p span {
      color: #231815; }
      .col_one section .inr a p span::before {
        background-image: url(../img/arrow_black.png); }

.col_one section.branch .inr a h2,
.col_one section.branch .inr a p,
.col_one section.branch .inr a p span{
  margin: 0 auto;
  color: #fff;
}
.col_one section .inr a p span::before{
  background-image: url(../img/arrow_white.png); 
}
section.employees .inr a p span::before{
  background-image: url(../img/arrow_black.png); 
}
.col_three {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }
  .col_three section {
    width: 33.33%; }
    @media only screen and (max-width: 767px) {
      .col_three section {
        width: 100%; } }
    .col_three section.recruitment {
      background-color: #005BAC; }
    .col_three section.growth {
      background-image: url(../img/bg_grows.jpg); }
    .col_three section.faq {
      background-image: url(../img/bg_faq.jpg); }
    .col_three section .inr a {
      text-align: center; }

.sp_copy{
  display: none;
}
@media only screen and (max-width: 767px) {
.sp_copy{
  display: block;
  position: absolute;
  left: 50%;
  bottom: 18%;
  transform: translateX(-50%);
  font-size: 18px;
  color: #fff;
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.1em;
  font-family: "EB Garamond", serif;
  width: 100%;
  display: block;
}
.sp_copy span{
  font-size: 35px;

}
}