@charset "UTF-8";
/* 設定
******************************************************************************************** */
/* txt-maker */
/* btn */
/* $width-pc: 1281px; */
/* $width-smartphone: 600px; */
/* $width-scrollbar: 20px; */
/* shine */
/* index CONFIG
******************************************************************************************** */
.slider {
  max-width: 1100px;
  margin: 0 auto;
  /*  Smartphone */
  margin: 10px auto;
}
@media only screen and (max-width: 640px) {
  .slider {
    width: 100%;
  }
}

.home__btn {
  text-align: center;
  margin: 40px 0;
}
.home__btn::after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
.home__btn a {
  min-width: 300px;
  color: #fff;
  background: #f39800;
  display: inline-block;
  padding: 6px 20px;
  text-shadow: none;
  position: relative;
  font-style: italic;
  background: #4a6bae;
}
.home__btn a i {
  margin-right: 1em;
}
.home__btn a:hover {
  transition: 0.5s ease-in-out;
  opacity: 0.8;
  filter: alpha(opacity=80);
  text-decoration: none;
}
.home__btn a:hover i {
  transition: 0.5s ease-in-out;
  transform: scale(1.5);
}
.home__btn a i {
  float: right;
  margin: 0;
  vertical-align: sub;
}
.home__ttl {
  text-align: center;
  margin-bottom: 20px;
}
.home__ttl--en {
  color: #4a6bae;
  font-size: 24px;
  font-size: 2.4rem;
  margin: 0;
}
.home__ttl--ja {
  font-size: 32px;
  font-size: 3.2rem;
  margin: 0;
  font-weight: normal;
}

/* company
******************************************************************************************** */
.company {
  padding: 60px 0;
}
.company__inner {
  max-width: 1100px;
  margin: 0 auto;
  /*  Smartphone */
  margin: 0 auto;
  display: flex;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
}
@media only screen and (max-width: 640px) {
  .company__inner {
    width: 100%;
  }
}
.company__ttl {
  font-family: "A1 Mincho", "Noto Serif JP", "ヒラギノ明朝 ProN W3", "Yu Mincho Medium", "游游明朝 Medium", "YuMincho", "游游明朝体", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "serif";
  font-size: 32px;
  font-size: 3.2rem;
}
.company__left {
  width: 65%;
}
.company__right {
  width: 33%;
  margin-top: 20px;
}

/* movie
******************************************************************************************** */
.movie {
  padding: 60px 0;
}
.movie__inner {
  text-align: center;
}
/* works
******************************************************************************************** */
.works {
  padding: 60px 0;
}
.works__inner {
  max-width: 1100px;
  margin: 0 auto;
  /*  Smartphone */
  margin: 0 auto;
}
@media only screen and (max-width: 640px) {
  .works__inner {
    width: 100%;
  }
}
.works__txt {
  text-align: center;
  margin-bottom: 40px;
}
.works__over {
  position: absolute;
  z-index: 2;
  padding: 40px;
}
.works__filter {
  width: 100%;
  height: 100%;
  display: block;
  box-sizing: border-box;
  background: rgba(0, 0, 0, 0.4);
  position: absolute;
  z-index: 1;
}
.works__list {
  display: flex;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
  padding: 0;
  list-style: none;
  margin-bottom: 60px;
}
.works__list li {
  width: 49%;
  position: relative;
  margin-bottom: 20px;
  background: #fff;
}
.works__list--ttl {
  font-size: 32px;
  font-size: 3.2rem;
  font-family: "A1 Mincho", "Noto Serif JP", "ヒラギノ明朝 ProN W3", "Yu Mincho Medium", "游游明朝 Medium", "YuMincho", "游游明朝体", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "serif";
  text-align: center;
}
.works__list--ttl i {
  display: block;
}
.works__list--txt {
  font-size: 16px;
  font-size: 1.6rem;
}
.works__list--txt br {
  display: none;
}
.works__list a {
  color: #fff;
}
.works__list a img {
  opacity: 0.6;
  filter: alpha(opacity=60);
}
.works__list a:hover {
  color: #333;
  text-shadow: 3px 3px 4px rgba(255, 255, 255, 0.91), -3px 3px 4px rgba(255, 255, 255, 0.91), 3px -3px 4px rgba(255, 255, 255, 0.91), -3px -3px 4px rgba(255, 255, 255, 0.91), 3px 0 4px rgba(255, 255, 255, 0.91), 0 3px 4px rgba(255, 255, 255, 0.91), -3px 0 4px rgba(255, 255, 255, 0.91), 0 -3px 4px rgba(255, 255, 255, 0.91), 2px 2px 10px #000, -2px 2px 10px #000;
}
.works__list a:hover img {
  opacity: 1;
  filter: alpha(opacity=100);
}
.works__list a:hover .works__filter {
  display: none;
}

/* news
******************************************************************************************** */
.news {
  padding: 60px 0;
}
.news__inner {
  max-width: 1100px;
  margin: 0 auto;
  /*  Smartphone */
  margin: 0 auto;
}
@media only screen and (max-width: 640px) {
  .news__inner {
    width: 100%;
  }
}
.news__txt {
  text-align: center;
}
.news__list {
  display: flex;
  -o-flex-wrap: wrap;
  flex-wrap: wrap;
  -moz-justify-content: space-between;
  -ms-justify-content: space-between;
  -o-justify-content: space-between;
  justify-content: space-between;
  padding: 0;
  list-style: none;
}
.news__list::before {
  display: block;
  content: "";
  width: 23%;
  height: 0;
  -moz-order: 1;
  -ms-order: 1;
  -o-order: 1;
  order: 1;
}
.news__list::after {
  display: block;
  content: "";
  width: 23%;
  height: 0;
}
.news__list li {
  width: 23%;
  position: relative;
  background: #fff;
  padding: 10px;
}
.news__list--date {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 10px 0;
}
.news__list--ttl {
  margin: 0;
  font-size: 20px;
  font-size: 2rem;
  font-style: italic;
}
.news__img {
  position: relative;
  display: block;
  margin: 0 0 10px 0;
}
.news__img::before {
  content: "";
  display: block;
  padding-top: 100%;
}
.news__img img {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  -o-object-fit: cover;
     object-fit: cover;
}

/* map
******************************************************************************************** */
.map iframe {
  border: 0;
  width: 100%;
}

/* fc
******************************************************************************************** */
.fc {
  padding: 40px 0;
  background: #c70102;
}
.fc__ttl {
  text-align: center;
  font-size: 20px;
  font-size: 2rem;
  color: #fff;
  font-family: "A1 Mincho", "Noto Serif JP", "ヒラギノ明朝 ProN W3", "Yu Mincho Medium", "游游明朝 Medium", "YuMincho", "游游明朝体", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "serif";
}
.fc__img {
  text-align: center;
}
.fc__img img {
  max-width: 240px;
}
.fc.sun {
  background: #fa6706;
  padding: 60px 0;
}
.fc.ota {
  background: #3e8b23;
  padding: 60px 0;
}
.fc.ota .fc__img img {
  max-width: 340px;
}

/* bnr_sdgs
******************************************************************************************** */
.bnr_sdgs {
  padding: 60px 0;
  max-width: 1100px;
  margin: 0 auto;
  /*  Smartphone */
  margin: 0 auto;
}
@media only screen and (max-width: 640px) {
  .bnr_sdgs {
    width: 100%;
  }
}/*# sourceMappingURL=index.css.map */