@charset "UTF-8";
/* フォント */
@import url("https://fonts.googleapis.com/css2?family=Dela+Gothic+One&family=Noto+Serif+JP&family=Oswald:wght@200..700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@200..700&display=swap");
.bk_right_unit_red {
  background-color: #e51f1f;
}

.bk_right_unit_black {
  background-color: #181818;
}

html {
  height: 100%;
  scroll-behavior: smooth;
}

body {
  height: 100%;
  margin: 0;
}

h1, h3, h4, p, li, a, span, th, td, .display-1 {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-style: normal;
  color: #181818;
}

.display-2::first-letter {
  color: #e51f1f;
}

a {
  text-decoration: none;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  display: inline-block;
}
a:hover {
  transform: translateY(-2px);
}

ul {
  padding: 0;
  margin: 0;
}

li {
  list-style: none;
}

i {
  margin: 0 5px;
}

/* サブメニュー */
.menu-content {
  position: fixed;
  right: 0;
}
.menu-content li {
  display: inline;
  margin: 25px;
}
.menu-content li a {
  text-decoration: none;
  transition: 0.2s cubic-bezier(0.45, 0, 0.55, 1);
  display: inline-block;
  position: relative;
}

.recruit_btn {
  color: #e51f1f;
  border: 1px solid #e51f1f;
  border-radius: 0.5rem;
  padding: 5px 10px;
  background-color: #fff;
}
.recruit_btn:hover {
  color: #fff;
  background-color: #e51f1f;
}

/*ナビゲーション*/
#main_nav,
#comp_main_nav {
  width: 100%;
  border-bottom: 2px solid;
  z-index: 1;
  opacity: 0;
}
#main_nav .title_logo,
#comp_main_nav .title_logo {
  margin: 10px;
}
#main_nav.UpMove,
#comp_main_nav.UpMove {
  animation: upHead 0.5s forwards;
}
#main_nav.DownMove,
#comp_main_nav.DownMove {
  animation: downHead 0.5s forwards;
}
@keyframes upHead {
  from {
    opacity: 1;
    transform: translateY(0);
  }
  to {
    opacity: 0;
    transform: translateY(-100px);
  }
}
@keyframes downHead {
  from {
    opacity: 0;
    transform: translateY(-100px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

#comp_main_nav {
  opacity: 1;
}

#not_found_nav {
  width: 100%;
  border-bottom: 2px solid;
  z-index: 1;
}
#not_found_nav .title_logo {
  margin: 10px;
}

#hamburger_nav,
#not_found_hamburger_nav {
  width: 100%;
  border-bottom: 2px solid;
}

/* トップ画面 */
#top_section {
  display: flex;
  height: 100vh;
  align-items: center;
  justify-content: center;
  width: 100%;
  margin: 0;
}

section {
  text-align: center;
  margin: 65px 0 0 0;
}

/* トップ見出し */
#top_txt {
  position: absolute;
  text-align: left;
}
#top_txt .pc_title {
  display: block;
}
#top_txt .sumaho_title {
  display: none;
}
#top_txt div {
  font-size: 6vh;
}
#top_txt div span {
  color: #fff;
}

/* トップ背景 */
#top_img {
  width: 100%;
}
#top_img div {
  width: 100%;
  height: 90vh;
  filter: blur(3px);
  z-index: -100;
  position: sticky;
}

#back_art {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  height: 100%;
}
#back_art.fade {
  opacity: 0;
  transition: all 0.5s;
}
#back_art .back_art_icon {
  transition: all 0.5s;
  padding: 30px;
  border-radius: 100%;
  margin: 28vh 0 0 0;
}
#back_art .back_art_icon.move {
  transform: translateY(-40px);
  transition: all 0.5s;
}
#back_art .back_art_icon img {
  width: 25vh;
  height: 25vh;
}

#particles-js {
  opacity: 1;
  transition: all 0.5s;
}
#particles-js.fade {
  opacity: 0;
  transition: all 0.5s;
}

#denkyu {
  display: flex;
  position: absolute;
  width: 100%;
  height: 100%;
  justify-content: center;
  align-items: flex-start;
}
#denkyu img {
  width: 35vh;
  height: 35vh;
}

#back {
  position: fixed;
  width: 100%;
  min-height: 100%;
  z-index: -1;
  transition: all 0.5s;
}
#back.dark {
  background: #181818;
  transition: all 0.5s;
  z-index: -2;
}
#back img {
  opacity: 1;
  transition: all 0.5s;
}
#back img.fade {
  opacity: 0;
  transition: all 0.5s;
}

/* インフォメーションアイコンエリア */
.info_icon_area .icon_area {
  text-align: center;
}
.info_icon_area .icon_area h3 {
  position: relative;
  display: inline-block;
  padding: 0 55px;
  font-size: 5vw;
}
.info_icon_area .icon_area h3:before, .info_icon_area .icon_area h3:after {
  content: "";
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 45px;
  height: 1px;
  background-color: #181818;
}
.info_icon_area .icon_area h3:before {
  left: 0;
}
.info_icon_area .icon_area h3:after {
  right: 0;
}
.info_icon_area .icon_area p {
  padding: 25px;
  font-size: x-large;
  /* min-height: 300px; */
}
.info_icon_area .icon_area .carousel-item img {
  width: 20vw;
}

#business .last_word {
  font-size: 4vw;
  margin: 20px 0;
}

.dellitexp a {
  text-decoration: underline;
}
.dellitexp img {
  width: 60vw !important;
  margin-top: 10px;
}

/* 会社案内 */
#company_info div {
  margin: 10px 0 0 0;
}
#company_info h3 {
  font-weight: bold;
}
#company_info li {
  border-bottom: dotted;
  border-color: #181818;
  border-width: 1px;
  width: 30vw;
  margin: 0 auto;
}

/* コンタクトエリア */
#contact .display-2::first-letter {
  color: #fff;
}

#cont_icon {
  display: inline-flex;
}
#cont_icon span {
  margin: 10px;
}
#cont_icon img {
  width: 50px;
}

/* マップ */
#map {
  width: 50vw;
  height: 50vh;
  margin: 50px;
}

#map_area {
  display: flex;
  justify-content: center;
  align-items: center;
}

#access_info {
  text-align: left;
  margin: 20px;
}

/* コンプライアンス */
#compliance {
  margin: 10px;
}
#compliance a {
  color: #fff;
}

/* フッター */
#footerBottom {
  width: 100%;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  background-color: #e51f1f;
}
#footerBottom h2, #footerBottom p {
  color: #fff;
}

#not_found_footerBottom {
  width: 100%;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  background-color: #e51f1f;
  position: fixed;
  bottom: 0;
}
#not_found_footerBottom h2, #not_found_footerBottom p {
  color: #fff;
}

/* 別ページ */
#compliance_area,
#recruit_area {
  padding: 60px 30px;
}
#compliance_area h1,
#recruit_area h1 {
  padding: 8px 10px;
  border-left: 8px solid #181818;
  border-bottom: 1px solid #181818;
  font-size: 20px;
  line-height: 22px;
  margin: 35px 0 0 0;
}
#compliance_area h2,
#recruit_area h2 {
  background-color: #e51f1f;
  font-size: 14px;
  line-height: 30px;
  color: #fff;
  padding: 0 0 0 15px;
  margin: 35px 0;
}
#compliance_area h3,
#recruit_area h3 {
  clear: both;
  border-left: 3px solid #181818;
  padding: 0 0 0 7px;
  font-size: 14px;
  line-height: 25px;
  font-weight: bold;
  margin: 20px 0;
}

.hide {
  display: none !important;
}

#not_found {
  padding: 130px 0 0 0;
}
#not_found div {
  text-align: center;
}
#not_found #not_found_code {
  font-size: 13vh;
}

/*スマホ対応*/
/*下に書かないと適用されない*/
@media not all and (min-width: 1024px) {
  .offcanvas ul {
    margin: 40px 0 0 0;
  }
  .offcanvas ul li {
    margin: 10px 0;
  }
  .offcanvas ul a {
    display: block;
    width: 100%;
    font-size: 15px;
    box-sizing: border-box;
    color: #ffffff;
    text-decoration: none;
    padding: 9px 15px 10px 0;
    position: relative;
    border-bottom: 1px solid #ffffff;
  }
  .offcanvas ul a::before {
    content: "";
    width: 7px;
    height: 7px;
    border-top: solid 2px #ffffff;
    border-right: solid 2px #ffffff;
    transform: rotate(45deg);
    position: absolute;
    right: 11px;
    top: 16px;
  }
  .title_logo img {
    width: 55vw;
  }
  /* トップ見出し */
  #top_txt {
    width: 100%;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    bottom: auto;
    display: flex;
    /* 左右中央揃え */
    align-items: center;
    left: auto;
    bottom: auto;
  }
  #top_txt .pc_title {
    display: none;
  }
  #top_txt .sumaho_title {
    display: block;
  }
  #top_txt div {
    font-size: 7vmax;
    margin: 16vh 0 0 0;
    white-space: normal;
  }
  #back_art {
    display: none;
  }
  #denkyu {
    display: none;
  }
  /* トップ画面 */
  #top_section {
    display: flex;
    height: 100vh;
    padding: 0;
    margin: 0;
    justify-content: center;
    align-items: center;
  }
  .info_icon_area .icon_area p {
    font-size: small;
  }
  .info_icon_area .icon_area .carousel-item img {
    width: 60vw;
  }
  .navbar-toggler {
    border: none;
  }
  #company_info li {
    width: auto;
    font-size: small;
  }
  /* マップ */
  #map {
    width: -webkit-fill-available;
  }
  #map_area {
    display: block;
    background-color: rgba(255, 255, 255, 0);
  }
  #access_info {
    text-align: center;
  }
}/*# sourceMappingURL=style.css.map */