@charset "utf-8";
/* ============================================================
 ▼▼base▼▼
============================================================ */
.en {
  font-family: 'Verdana', sans-serif;
}
/* ============================================================
 clearfix
============================================================ */
.clearfix {
  zoom: 1;
}
.clearfix:after {
  content: "";
  display: block;
  clear: both;
}
/* ============================================================
 リンク矢印
============================================================ */
.anc-arrow:before {
  content: "＞";
}
#main {
  margin-top: 0;
  margin-bottom: 100px;
}
#header-pc {
  border-bottom: none;
}
/* ============================================================
 メインビジュアル
============================================================ */
#mv {
  background: #f0f0f0;
  margin-bottom: 20px;
  width: 100%;
  max-height: 90vh;
  overflow: hidden;
  position: relative;
  padding-top: 170px;
  /* ICONIC WORKER用 */
}
#mv video {
  max-width: 100%;
  max-height: 100%;
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}
#mv.mv-iconic {
  max-height: 108vh;
  background: #000;
}
#mv.mv-iconic video {
  width: 86%;
  margin-top: -1%;
}
#mv .mv-border {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(/images/top/mv_dot.png) repeat 0 0;
  opacity: 1.0;
}
#mv .mv-thumb-box {
  position: absolute;
  left: 20px;
  bottom: 9%;
}
#mv .mv-thumb-box.mv-thumb-box-left {
  left: 20px;
  bottom: 9%;
  right: auto;
}
/* ============================================================
 info/news
============================================================ */
.info-news .info-ttl {
  float: left;
  padding: 0 55px 0 0;
  margin-top: 10px;
  width: 11.4%;
  white-space: nowrap;
  font-size: 1.6rem;
}
.info-news .info-txt {
  float: left;
  width: 88.6%;
  padding: 0 0 10px 40px;
  border-left: 1px solid #666;
  font-size: 1.4rem;
}
#info {
  border-bottom: 1px solid #666;
  padding: 0 60px 20px;
  zoom: 1;
}
#info:after {
  content: "";
  display: block;
  clear: both;
}
#info .info-txt {
  padding-top: 10px;
}
#news {
  margin-top: 20px;
  margin-bottom: 30px;
  padding: 0 60px;
  zoom: 1;
}
#news:after {
  content: "";
  display: block;
  clear: both;
}
#news .news-line {
  zoom: 1;
  margin-bottom: 10px;
}
#news .news-line:after {
  content: "";
  display: block;
  clear: both;
}
#news .news-line:last-child {
  margin-bottom: 0;
}
#news .news-date {
  float: left;
  width: 11%;
  white-space: nowrap;
  padding: 3px 0;
}
#news .news-cat {
  float: left;
  width: 13%;
  margin-right: 3%;
  white-space: nowrap;
  background: #e9e9e9;
  padding: 3px;
  text-align: center;
  font-size: 1.2rem;
}
#news .news-cat,
#news .news-cat a {
  color: #fff;
  display: block;
}
#news .news-cat.news-cat-press,
#news .news-cat a.news-cat-press {
  background: #e56a54;
}
#news .news-cat.news-cat-ir,
#news .news-cat a.news-cat-ir {
  background: #007672;
}
#news .news-cat.news-cat-info,
#news .news-cat a.news-cat-info {
  background: #c6858f;
}
#news .news-txt {
  float: left;
  width: 73%;
}
/* ============================================================
 service
============================================================ */
#service-wrap {
  margin: 50px 0;
  padding: 45px 0.78125% 40px;
  background: #a3a3a3;
}
.service-list {
  zoom: 1;
}
.service-list:after {
  content: "";
  display: block;
  clear: both;
}
.service-list li {
  margin-right: 1%;
  margin-bottom: 15px;
  position: relative;
}
.service-list li img,
.service-list li a {
  display: block;
}
.service-list li a {
  color: #fff;
}
.service-list li .txt {
  position: absolute;
  top: 50%;
  text-align: center;
  margin-top: -0.25em;
  width: 100%;
  color: #fff;
  font-weight: bold;
  font-size: 2rem;
  line-height: 1;
}
.service-list li.temporary-item {
  opacity: .7;
}
.service-list .brand,
.service-list .staff {
  width: 49.5%;
}
.service-list .corporate,
.service-list .recruit {
  width: 24.2%;
}
.service-list .ir,
.service-list .service {
  width: 24.3%;
}
.service-list .brand,
.service-list .service,
.service-list .recruit,
.service-list .corporate {
  float: left;
}
.service-list .staff,
.service-list .ir {
  float: right;
}
.service-list .staff,
.service-list .ir {
  margin-right: 0;
}
/* ============================================================
 group-corp
============================================================ */
#group-corp {
  text-align: center;
  zoom: 1;
}
#group-corp:after {
  content: "";
  display: block;
  clear: both;
}
#group-corp li {
  float: left;
  width: calc(33.33333333%);
}
#group-corp a {
  display: inline-block;
  text-align: center;
}
#group-corp img {
  width: auto!important;
  height: 30px;
}
/* ============================================================
 special
============================================================ */
#special-wrap {
  margin-top: 50px;
}
/* ============================================================
 appeal-list
============================================================ */
#appeal-list {
  width: 86%;
  margin: 40px auto 0 auto;
  zoom: 1;
}
#appeal-list:after {
  content: "";
  display: block;
  clear: both;
}
#appeal-list a {
  display: block;
}
#appeal-list .slide {
  float: left;
  margin: 0 30px;
}
#appeal-list .pht img {
  display: block;
}
#appeal-list .txt {
  margin-top: 30px;
  font-size: 1.4rem;
  line-height: 1.6;
}
#appeal-list .anc {
  margin-top: 10px;
  font-size: 1.4rem;
  line-height: 1;
  font-weight: bold;
  text-align: right;
}
#appeal-list .anc:before {
  content: "＞";
}
/* ============================================================
 tablet
============================================================ */
@media only screen and (min-width: 768px) and (max-width: 1199px) {
  .info-news .info-ttl {
    float: left;
    padding: 0 55px 0 0;
    margin-top: 10px;
    width: 20%;
    white-space: nowrap;
    font-size: 1.6rem;
  }
  .info-news .info-txt {
    float: left;
    width: 75%;
    padding: 0 0 10px 40px;
    border-left: 1px solid #666;
    font-size: 1.4rem;
  }
  #news .news-date {
    float: none;
    display: inline-block;
    width: auto;
    margin-right: 10px;
    margin-bottom: 5px;
    padding-top: 2px;
  }
  #news .news-cat {
    float: none;
    display: inline-block;
    width: auto;
  }
  #news .news-txt {
    float: none;
    width: 100%;
    display: inline-block;
    padding: 3px 0;
  }
}
@media only screen and (max-width: 991px) {
  /* ============================================================
 メインビジュアル
============================================================ */
  #mv-sp {
    max-height: initial;
    margin-bottom: 20px;
    position: relative;
  }
  #mv-sp a {
    display: block;
    position: relative;
  }
  #mv-sp a:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -34px;
    margin-left: -34px;
    width: 68px;
    height: 68px;
    background: url(../images/top/movie_play.png) no-repeat center center;
    background-size: contain;
  }
}
/* ============================================================
 SP
============================================================ */
@media only screen and (max-width: 767px) {
  /* ============================================================
 メインビジュアル
============================================================ */
  #mv-sp {
    max-height: auto;
    margin-bottom: 20px;
    position: relative;
  }
  #mv-sp a {
    display: block;
  }
  #mv-sp a:before {
    content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -34px;
    margin-left: -34px;
    width: 68px;
    height: 68px;
    background: url(../images/top/movie_play.png) no-repeat center center;
    background-size: contain;
  }
  /* ============================================================
 info/news
============================================================ */
  .info-news .info-ttl {
    padding: 0 12px 0 0;
    margin-top: 5px;
    width: 100%;
    font-size: 1.4rem;
    float: none;
  }
  .info-news .info-txt {
    width: 100%;
    padding: 0 0 10px 0;
    font-size: 1.3rem;
    float: none;
    border-left: none;
  }
  #info {
    border-bottom: none;
    padding: 0 20px 0;
    zoom: 1;
  }
  #info:after {
    content: "";
    display: block;
    clear: both;
  }
  #news {
    margin-top: 15px;
    margin-bottom: 20px;
    padding: 0 20px;
  }
  #news .news-line {
    display: none;
  }
  #news .news-line:first-child {
    display: block;
  }
  #news .news-date {
    float: none;
    display: inline-block;
    width: auto;
    margin-right: 20px;
    margin-bottom: 5px;
    padding-top: 2px;
  }
  #news .news-cat {
    float: none;
    display: inline-block;
    width: auto;
  }
  #news .news-txt {
    float: none;
    width: 100%;
    display: inline-block;
    padding: 3px 0;
  }
  /* ============================================================
 service
============================================================ */
  #service-wrap {
    margin: 30px 0;
    padding: 20px 1%;
  }
  .service-list {
    zoom: 1;
  }
  .service-list:after {
    content: "";
    display: block;
    clear: both;
  }
  .service-list li {
    margin-right: 1%;
    margin-bottom: 1%;
  }
  .service-list li a {
    font-size: 1rem;
  }
  .service-list .brand,
  .service-list .staff {
    width: 100%;
  }
  .service-list .corporate,
  .service-list .recruit {
    width: 49.5%;
  }
  .service-list .ir,
  .service-list .service {
    width: 49.5%;
  }
  .service-list .brand,
  .service-list .staff,
  .service-list .recruit,
  .service-list .corporate,
  .service-list .service {
    float: left;
  }
  .service-list .service,
  .service-list .ir {
    float: right;
  }
  .service-list .ir,
  .service-list .service {
    margin-right: 0;
  }
  /* ============================================================
 group-corp
============================================================ */
  #group-corp img {
    width: auto!important;
    height: 20px;
  }
  /* ============================================================
 special
============================================================ */
  #special-wrap {
    margin-top: 30px;
  }
  /* ============================================================
 appeal-list
============================================================ */
  #appeal-list {
    width: 83%;
    margin: 30px auto 0 auto;
  }
  #appeal-list .slide {
    margin: 0 7px;
  }
  #appeal-list .txt {
    margin-top: 10px;
    font-size: 1rem;
  }
}
