@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; }

#maincontent {
  margin-top: 90px !important; }
  @media only screen and (max-width: 767px) {
    #maincontent {
      margin-top: 55px !important; } }

.mv_area {
  width: 100%;
  overflow: hidden; }
  .mv_area .inr {
    position: relative; }
    .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 {
          padding-top: 0; } }*/
      .mv_area .inr .youtube iframe {
        position: absolute;
        top: -8%;
        right: 0;
        width: 118%;
        height: 118%;
        border-radius: 0;
        z-index: 1; }
      .mv_area .inr .youtube .mv_video {
        position: fixed;
        top: 50%;
        left: 50%;
        min-width: 100%;
        min-height: 100%;
        width: auto;
        height: auto;
        z-index: -10000;
        -webkit-transform: translateX(-50%) translateY(-50%);
        -ms-transform: translateX(-50%) translateY(-50%);
        transform: translateX(-50%) translateY(-50%);
        background-size: cover;
        -webkit-transition: 1s opacity;
        -o-transition: 1s opacity;
        transition: 1s opacity; }
      .mv_area .inr .youtube video {
        height: 100%;
        width: 100%; }
    .mv_area .inr .pattern {
      background-image: url(../img/pattern.png);
      background-repeat: repeat;
      background-attachment: fixed;
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: 2; }
    .mv_area .inr img {
      max-width: 400px;
      width: 60%;
      position: absolute;
      z-index: 3;
      top: 50%;
      left: 50%;
      -webkit-transform: translateY(-50%) translateX(-50%);
      -ms-transform: translateY(-50%) translateX(-50%);
      transform: translateY(-50%) translateX(-50%); }

.section {
  background-repeat: no-repeat;
  background-position: 50% 50%;
  background-size: cover; }
  .section .inr {
    width: 100%;
    height: 100%; }
  .section a {
    padding: 80px 0;
    display: block;
    position: relative;
    overflow: hidden;
    height: 100%; }
    @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;
    position: relative; }
    @media only screen and (max-width: 767px) {
      .section h2 {
        font-size: 1.4em; } }
    .section h2::before {
      content: '';
      display: inline-block;
      width: 50px;
      height: 1px;
      background-color: #fff;
      background-size: contain;
      vertical-align: middle;
      position: absolute;
      bottom: -20px;
      left: 50%;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%); }
      @media only screen and (max-width: 767px) {
        .section h2::before {
          bottom: -10px; } }
    .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;
      bottom: -10px;
      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.about {
      background-color: #005BAC; }
    .col_two section.concept {
      background-image: url(../img/bg_concept.jpg); }
    .col_two section.works {
      background-image: url(../img/bg_works.jpg); }
    .col_two section.recruitment {
      background-color: #00664B; }
    .col_two section .inr a {
      text-align: center; }

.col_one section.business {
  background-image: url(../img/bg_business.jpg); }
  @media only screen and (max-width: 767px) {
    .col_one section.business {
      background-position: 65% 100%; } }

.col_one section.company {
  background-image: url(../img/bg_company.jpg); }
  .col_one section.company a {
    padding: 120px 0; }
    .col_one section.company a h2 {
      margin-left: 50%; }
      @media only screen and (max-width: 767px) {
        .col_one section.company a h2 {
          margin-left: 0; } }
    .col_one section.company a p {
      margin-left: 50%; }
      @media only screen and (max-width: 767px) {
        .col_one section.company a p {
          margin-left: 0; } }

.col_one section .inr {
  max-width: 100%; }
  .col_one section .inr a h2 {
    width: 50%;
    text-align: center;
    color: #fff; }
    @media only screen and (max-width: 767px) {
      .col_one section .inr a h2 {
        width: 100%; } }
  .col_one section .inr a .ano {
    color: #fff;
    margin: 80px 0 40px; }
    @media only screen and (max-width: 767px) {
      .col_one section .inr a .ano {
        margin: 40px auto 20px;
        font-size: .9em;
        width: 95%; } }
  .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: #fff; }
      .col_one section .inr a p span::before {
        background-image: url(../img/arrow_white.png); }

.about h3 {
  font-family: "EB Garamond", serif;
  color: #fff;
  font-size: 1.8em;
  letter-spacing: .25em;
  margin: 60px 0 40px; }
  @media only screen and (max-width: 767px) {
    .about h3 {
      font-size: 1.1em;
      margin: 30px 0 20px; } }
  .about h3 span {
    display: block;
    font-size: .7em;
    letter-spacing: .2rem; }

.concept .play_icon {
  margin: 80px 0; }
  @media only screen and (max-width: 767px) {
    .concept .play_icon {
      margin: 30px 0; } }
  .concept .play_icon img {
    max-width: 80px;
    width: 100%; }
    @media only screen and (max-width: 767px) {
      .concept .play_icon img {
        max-width: 50px; } }

.concept p {
  color: #fff;
  font-family: "EB Garamond", serif;
  font-size: .9em;
  letter-spacing: .2em;
  font-style: italic; }

.works .ano,
.recruitment .ano {
  color: #fff;
  margin: 80px 0 40px; }
  @media only screen and (max-width: 767px) {
    .works .ano,
    .recruitment .ano {
      margin: 40px auto 20px;
      font-size: .9em;
      width: 95%; } }

.company p {
  margin-top: 50px; }

.news {
  padding: 30px 0 40px 0;
  background-color: #fff; }
  @media only screen and (max-width: 767px) {
    .news {
      padding-top: 40px; } }
  .news .inr {
    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;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start; }
    .news .inr h2 {
      width: 50%;
      color: #231815 !important;
      text-align: center;
      position: relative; }
      @media only screen and (max-width: 767px) {
        .news .inr h2 {
          width: 100%; } }
      .news .inr h2::before {
        background-color: #231815; }
    .news .inr .news_list {
      width: 50%; }
      @media only screen and (max-width: 767px) {
        .news .inr .news_list {
          width: 90%;
          margin: 40px auto 0; } }
      .news .inr .news_list ul li {
        width: 90%;
        border-bottom: 1px solid; }
        @media only screen and (max-width: 767px) {
          .news .inr .news_list ul li {
            width: 100%; } }
        .news .inr .news_list ul li a {
          padding: 0;
          height: inherit;
          padding: 5px 0; }
          @media only screen and (max-width: 767px) {
            .news .inr .news_list ul li a {
              font-size: .9em; } }
          .news .inr .news_list ul li a .date {
            font-weight: bold;
            margin-right: 10px;
            font-size: .95em; }
            @media only screen and (max-width: 767px) {
              .news .inr .news_list ul li a .date {
                display: block; } }
      .news .inr .news_list p a {
        padding: 0;
        padding: 0;
        height: inherit;
        overflow: inherit; }
        .news .inr .news_list p a:hover span::before {
          left: 55%; }
        .news .inr .news_list p a span {
          display: block;
          margin-top: 10px;
          padding-top: 20px;
          position: relative;
          font-family: "EB Garamond", serif;
          font-style: italic;
          font-weight: bold;
          color: #231815;
          text-align: center; }
          @media only screen and (max-width: 767px) {
            .news .inr .news_list p a span {
              padding-top: 20px;
              margin-top: 5px; } }
          .news .inr .news_list p a span::before {
            content: '';
            display: inline-block;
            width: 160px;
            height: 15px;
            background-image: url(../img/arrow_black.png);
            background-size: contain;
            background-repeat: no-repeat;
            vertical-align: middle;
            position: absolute;
            bottom: -10px;
            left: 50%;
            -webkit-transform: translateX(-50%);
            -ms-transform: translateX(-50%);
            transform: translateX(-50%);
            -webkit-transition: 1s;
            -o-transition: 1s;
            transition: 1s; }
  @media only screen and (max-width: 767px) {
    .news {
      background-position: 65% 100%; } }
.award{
}
.award_box{
  width: 90%;
  max-width: 1000px;
  margin: 100px auto;
  border: 1px solid #E8E4DC;
  padding: 50px 20px;
}
@media only screen and (max-width: 767px) {
.award_box{
  margin: 60px auto;
  padding: 30px 20px;
}
}
.award_img{
  max-width: 160px;
  margin: 0 auto 30px;
}
.award_img img{
  width: 100%;
}
.award_txt{
  text-align: center;
}