@charset "UTF-8";
/*
カラー・フォント定義
*/
/* =========================== 汎用スタイル =========================== */
.section-title {
  font-size: 48px;
  text-align: center;
  line-height: 1;
  letter-spacing: 0em;
  font-weight: 600;
  margin: 0px 0px 8px 0px; }
  .section-title:first-letter {
    color: #f41d31; }

.section-title-sub {
  text-align: center;
  font-size: 16px;
  font-weight: 400;
  line-height: 1;
  margin: 0px 0px 64px 0px; }

.anchorlink {
  position: relative;
  top: -64px;
  display: block; }
  @media only screen and (max-width: 768px) {
    .anchorlink {
      top: -128px; } }

img {
  vertical-align: bottom; }

/* =========================== 共通 =========================== */
select::-ms-expand {
  display: none; }

a {
  color: #222;
  text-decoration: none; }
  a:hover {
    color: #bf0008;
    text-decoration: underline; }

ul {
  list-style-type: none; }

body {
  font-family: "Noto Sans JP", "Noto Sans JP", sans-serif;
  font-weight: 400;
  color: #fff;
  background-color: #6a6a6a;
  position: relative;
  font-size: 18px;
  background-image: url("../img/nav/bg.svg");
  background-repeat: no-repeat;
  background-size: 400px 800px;
  background-position: right -10px top 64px;
  background-attachment: fixed; }
  @media only screen and (max-width: 768px) {
    body {
      font-size: 14px;
      background-position: right -10px top 32px;
      background-size: 200px 400px; } }
  body.no_scroll {
    overflow: hidden; }
    body.no_scroll header {
      height: 100%;
      overflow-x: hidden;
      overflow-y: auto; }
      body.no_scroll header.subMenuOff {
        transform: translateY(-144px);
        -webkit-transform: translateY(-144px);
        transition: 0.5s;
        opacity: 0; }

.fadein {
  opacity: 1;
  transform: translate(0, 100px);
  transition: all 1000ms; }

/* 画面内に入った状態 */
.fadein.scrollin {
  opacity: 1;
  transform: translate(0, 0);
  transition-timing-function: ease-in-out; }

/* ------------------------------- ページ切替 ------------------------------ */
#page-animate::before {
  content: "";
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #333;
  z-index: 9999;
  pointer-events: none;
  right: 100%;
  -webkit-transition: right 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  transition: right 0.8s cubic-bezier(0.4, 0, 0.2, 1); }

#page-animate::after {
  content: "";
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #333;
  z-index: 9999;
  pointer-events: none;
  left: 100%;
  -webkit-transition: left 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  transition: left 0.8s cubic-bezier(0.4, 0, 0.2, 1); }

#page-animate.is-slide-in::before {
  right: 0; }

#page-animate.is-slide::after {
  left: 0; }

#load-out {
  content: "";
  position: fixed;
  width: 100%;
  height: 100%;
  pointer-events: none;
  left: 0px;
  top: 0px;
  z-index: 9999; }
  #load-out .bg {
    content: "";
    position: fixed;
    background-color: #333;
    width: 100%;
    height: 100%;
    -webkit-transition: 0.75s;
    transition: 0.75s;
    left: 0px;
    opacity: 0.9;
    background-image: url("../img/nav/bg-load.svg");
    background-size: 400px 800px;
    background-position: right -10px top 64px;
    background-attachment: fixed; }
    #load-out .bg.hidden {
      -webkit-transition: 0.75s;
      transition: 0.75s;
      left: 100%;
      background-image: none; }
  #load-out .parent-container {
    position: fixed;
    right: -12px;
    top: 64px; }

.index #load-out .bg {
  background-image: none; }
.index #recruit .employee-list {
  justify-content: center !important; }

#load-in {
  display: none;
  content: "";
  position: fixed;
  width: 100%;
  height: 100%;
  pointer-events: none;
  left: 0px;
  top: 0px;
  z-index: 9999; }
  #load-in .bg {
    content: "";
    position: fixed;
    background-color: #333;
    width: 100%;
    height: 100%;
    -webkit-transition: 0.75s;
    transition: 0.75s;
    left: -100%;
    opacity: 0.9; }
    #load-in .bg.view {
      -webkit-transition: 0.75s;
      transition: 0.75s;
      left: 0; }
  #load-in .parent-container {
    position: fixed;
    right: -12px;
    top: 64px; }
  #load-in.view {
    display: block; }

/* ------------------------------- style ------------------------------ */
header {
  width: 250px;
  position: fixed;
  left: -300px;
  top: 96px;
  z-index: 3000; }
  @media only screen and (max-width: 1179px) {
    header {
      width: 100%;
      height: 64px;
      position: fixed;
      z-index: 4000;
      transition: 0.5s;
      overflow: hidden;
      background-color: rgba(0, 0, 0, 0.3);
      top: -64px;
      left: 0px; } }
  header h1 {
    margin: 0px 0px 96px 0px;
    opacity: 0; }
    @media only screen and (max-width: 1179px) {
      header h1 {
        opacity: 1;
        width: 36px;
        height: 64px;
        margin: 0px 0px 0px 0px;
        padding: 0px 0px 0px 0px;
        vertical-align: top; } }
    header h1 img {
      width: 96px;
      height: 129px; }
      @media only screen and (max-width: 1179px) {
        header h1 img {
          margin: 8px 0px 0px 16px;
          width: 36px;
          height: 48px;
          vertical-align: top; } }
  @media only screen and (min-width: 1180px) {
    header #spNavBtn {
      display: none; } }
  @media only screen and (max-width: 1179px) {
    header #spNavBtn {
      display: block;
      position: relative;
      cursor: pointer;
      float: right;
      margin: 31px 16px 0px 0px;
      width: 34px; } }
  header #spNavBtn span {
    position: absolute;
    transition: 0.3s opacity;
    width: 30px;
    height: 2px;
    background-color: #fff;
    display: block;
    left: calc(50% - 17px);
    top: 0px; }
    header #spNavBtn span.clickPoint {
      top: -14px;
      width: 30px;
      height: 30px;
      background-color: inherit; }
    header #spNavBtn span.top {
      animation: type6-top 0.5s;
      animation-fill-mode: forwards; }
    header #spNavBtn span.middle {
      transition: 0.5s opacity;
      transform: translateY(0px);
      opacity: 1; }
    header #spNavBtn span.bottom {
      animation: type6-bottom 0.5s;
      animation-fill-mode: forwards; }
  header #spNavBtn.on span.middle {
    opacity: 0;
    transition: 0.5s opacity; }
  header #spNavBtn.on span.top {
    animation: type6-top-close 0.5s;
    animation-fill-mode: forwards; }
  header #spNavBtn.on span.bottom {
    animation: type6-bottom-close 0.5s;
    animation-fill-mode: forwards; }
  header nav {
    transition: 0.5s; }
    header nav.on {
      opacity: 1; }
    @media only screen and (max-width: 1179px) {
      header nav {
        opacity: 0;
        width: 100%;
        height: calc(100% - 64px);
        top: 96px;
        /*background-color: #000;*/
        background-color: rgba(0, 0, 0, 0.3);
        padding: 0px 0px 0px 0px;
        margin: 0px 0px 0px 0px;
        background-image: none; } }
    header nav .main-nav {
      margin: 0px 0px 64px 0px; }
      @media only screen and (max-width: 768px) {
        header nav .main-nav {
          margin: 0px 0px 32px 0px; } }
      header nav .main-nav li {
        display: block;
        position: relative;
        margin: 0px 0px 16px 0px; }
        @media only screen and (max-width: 1179px) {
          header nav .main-nav li {
            border-bottom: 1px solid #fff;
            margin: 0px 0px 0px 0px;
            padding: 12px 16px 12px 16px; } }
        header nav .main-nav li a {
          font-size: 18px;
          font-weight: 600;
          color: #fff;
          letter-spacing: 6px;
          line-height: 1.4;
          position: relative;
          display: inline-block;
          padding: 0px 0px 2px 0px; }
          @media only screen and (max-width: 1179px) {
            header nav .main-nav li a {
              font-size: 16px; } }
          header nav .main-nav li a::after {
            content: "";
            position: absolute;
            width: 0px;
            height: 6px;
            background-color: #bf0008;
            left: 0;
            bottom: -6px;
            transition: all 300ms;
            transition-timing-function: ease-out; }
          header nav .main-nav li a:hover {
            text-decoration: none; }
            header nav .main-nav li a:hover::after {
              width: 100%;
              transition: all 300ms;
              transition-timing-function: ease-out; }
      header nav .main-nav li:last-child {
        margin: 32px 0px 0px 0px; }
        @media only screen and (max-width: 1179px) {
          header nav .main-nav li:last-child {
            margin: 0px 0px 0px 0px; } }
        header nav .main-nav li:last-child a {
          border-bottom: solid #fff 6px; }
          @media only screen and (max-width: 1179px) {
            header nav .main-nav li:last-child a {
              border-bottom: none; } }
    @media only screen and (max-width: 1179px) {
      header nav .social-nav {
        text-align: center; } }
    header nav .social-nav li {
      display: inline-block; }
      header nav .social-nav li a img {
        width: 48px;
        height: 48px; }
    header nav .social-nav li:last-child {
      margin: 0px 0px 0px 20px; }
      @media only screen and (max-width: 1179px) {
        header nav .social-nav li:last-child {
          margin: 0px 0px 0px 32px; } }

@keyframes type6-top {
  0% {
    transform: translateX(0px) rotate(-45deg); }
  50% {
    transform: translateY(0px) rotate(0deg); }
  100% {
    transform: translateY(-8px) rotate(0deg); } }
@keyframes type6-bottom {
  0% {
    transform: translateY(0px) rotate(45deg); }
  50% {
    transform: translateY(0px) rotate(0deg); }
  100% {
    transform: translateY(8px) rotate(0deg); } }
@keyframes type6-top-close {
  0% {
    transform: translateY(8px) rotate(0deg); }
  50% {
    transform: translateY(0px) rotate(0deg); }
  100% {
    transform: translateY(0px) rotate(-45deg); } }
@keyframes type6-bottom-close {
  0% {
    transform: translateY(8px) rotate(0deg); }
  50% {
    transform: translateY(0px) rotate(0deg); }
  100% {
    transform: translateY(0px) rotate(45deg); } }
#mv {
  position: relative;
  margin: 0px 0px 128px 0px;
  background-image: url("../img/mv/mv-2025.webp");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  overflow: hidden;
  height: 1000px; }
  @media only screen and (max-width: 768px) {
    #mv {
      background-image: url("../img/mv/mv-2025-sp.webp");
      margin: 0px 0px 64px 0px; } }
  #mv h2 {
    position: absolute;
    /*right: 96px;*/
    right: 0px;
    opacity: 0;
    top: 96px;
    width: 35%; }
    @media only screen and (max-width: 1179px) {
      #mv h2 {
        margin-right: 32px; } }
    @media only screen and (max-width: 768px) {
      #mv h2 {
        margin-right: 0px;
        width: 100%;
        top: inherit;
        bottom: 24px;
        opacity: 1;
        text-align: right;
        padding: 0 16px 0 0;
        box-sizing: border-box; } }
    #mv h2 img {
      width: 100%;
      height: auto; }
      @media only screen and (max-width: 1179px) {
        #mv h2 img {
          width: 100%; } }
      @media only screen and (max-width: 768px) {
        #mv h2 img {
          width: 240px; } }
  #mv .scene01 {
    z-index: 1000;
    position: absolute;
    width: 100%;
    height: 100%; }
    #mv .scene01 .bg {
      background-color: #fff;
      width: 100%;
      height: 100%;
      position: absolute;
      left: 0px;
      top: 0px; }
    #mv .scene01 .mask {
      position: absolute;
      overflow: hidden;
      width: 600px;
      height: 200px;
      left: calc(50% - 250px);
      top: calc(50% - 98px);
      width: 500px;
      height: 0px; }
      @media only screen and (max-width: 768px) {
        #mv .scene01 .mask {
          left: calc(50% - 125px);
          top: calc(50% - 50px); } }
    #mv .scene01 .text01,
    #mv .scene01 .text02 {
      position: absolute;
      width: 500px;
      height: auto;
      opacity: 1; }
      @media only screen and (max-width: 768px) {
        #mv .scene01 .text01,
        #mv .scene01 .text02 {
          width: 250px; } }
  #mv .scene02 {
    z-index: 2000;
    position: absolute;
    width: 100%;
    height: 100%; }
    #mv .scene02 .bg {
      background-color: #fff;
      width: calc(130%);
      height: 100%;
      position: absolute;
      left: calc(-130% - 100px);
      top: 0px; }
      #mv .scene02 .bg .right-bg {
        position: absolute;
        right: -150px;
        height: 100%;
        width: 300px; }
    #mv .scene02 .bg02 {
      background-color: #ededed;
      width: calc(130%);
      height: 100%;
      position: absolute;
      right: calc(-130% - 100px);
      top: 0px; }
      #mv .scene02 .bg02 .left-bg {
        position: absolute;
        left: -150px;
        height: 100%;
        width: 300px; }
    #mv .scene02 .logo-bg {
      position: absolute;
      right: 64px;
      top: 2%;
      height: 96%; }
      @media only screen and (max-width: 768px) {
        #mv .scene02 .logo-bg {
          right: 16px; } }
    #mv .scene02 .mask {
      position: absolute;
      left: calc(50% - 48px);
      top: calc(50% - 64px);
      width: 0px;
      height: 150px;
      overflow: hidden; }
      #mv .scene02 .mask .logo {
        width: 96px;
        height: 129px;
        position: absolute; }
  #mv .rec-btn {
    position: absolute;
    z-index: 3000;
    bottom: 64px;
    right: 64px;
    opacity: 0;
    visibility: hidden; }
    @media only screen and (max-width: 1179px) {
      #mv .rec-btn {
        bottom: 144px;
        right: 10px; } }
    #mv .rec-btn a {
      display: block;
      width: 320px;
      line-height: 1;
      background-color: #bf0008;
      color: #fff;
      font-size: 24px;
      text-align: left;
      border-radius: 500px;
      padding: 24px 32px 24px 32px;
      font-weight: 700;
      background-image: url("../img/mv/rec-btn-bg.svg");
      background-position: right 24px center;
      background-size: 50px auto;
      transition: all 300ms; }
      @media only screen and (max-width: 1179px) {
        #mv .rec-btn a {
          width: 230px;
          font-size: 16px;
          padding: 16px 24px;
          background-size: 40px auto; } }
      #mv .rec-btn a span {
        font-weight: 400;
        margin: 12px 0px 0px 0px;
        display: block;
        font-size: 12px; }
      #mv .rec-btn a:hover {
        text-decoration: none;
        box-shadow: 0 0 6px 6px rgba(255, 255, 255, 0.4);
        background-size: 56px auto; }

.base-container {
  width: 100%;
  box-sizing: border-box;
  padding: 0px 96px 0px 384px;
  margin: 0px 0px 128px 0px; }
  @media only screen and (max-width: 1179px) {
    .base-container {
      padding: 0px 64px 0px 64px; } }
  @media only screen and (max-width: 768px) {
    .base-container {
      padding: 0px 16px 0px 16px;
      margin: 0px 0px 64px 0px; } }

.base-ttl, .base-ttl2 {
  color: #fff;
  font-size: 96px;
  display: inline-block;
  margin: 0px 0px 20px 0px;
  letter-spacing: 8px;
  position: relative;
  z-index: 100; }
  @media only screen and (max-width: 1179px) {
    .base-ttl, .base-ttl2 {
      font-size: 64px; } }
  @media only screen and (max-width: 768px) {
    .base-ttl, .base-ttl2 {
      font-size: 26px;
      letter-spacing: 4px;
      margin: 0px 0px 10px 0px; } }
  .base-ttl::after, .base-ttl2::after {
    content: "";
    position: absolute;
    width: 0px;
    height: 5px;
    left: 0px;
    bottom: -5px;
    background-color: #bf0008;
    z-index: 101; }
    @media only screen and (max-width: 768px) {
      .base-ttl::after, .base-ttl2::after {
        height: 4px; } }
  .base-ttl::before, .base-ttl2::before {
    content: "";
    position: absolute;
    width: 0px;
    height: 5px;
    left: 0px;
    bottom: -5px;
    background-color: #fff;
    z-index: 102; }
    @media only screen and (max-width: 768px) {
      .base-ttl::before, .base-ttl2::before {
        height: 4px; } }
  .base-ttl.fadein, .fadein.base-ttl2 {
    opacity: 1;
    transform: translate(0, 100px);
    transition: all 1000ms;
    color: #bf0008; }
  .base-ttl.fadein.scrollin, .fadein.scrollin.base-ttl2 {
    opacity: 1;
    transform: translate(0, 0);
    color: #fff; }
    .base-ttl.fadein.scrollin::after, .fadein.scrollin.base-ttl2::after {
      z-index: 101;
      content: "";
      position: absolute;
      width: calc(100% - 8px);
      transition: all 500ms;
      -moz-transition-delay: 0.8s;
      -webkit-transition-delay: 0.8s;
      -o-transition-delay: 0.8s;
      -ms-transition-delay: 0.8s; }
      @media only screen and (max-width: 768px) {
        .base-ttl.fadein.scrollin::after, .fadein.scrollin.base-ttl2::after {
          width: calc(100% - 4px); } }
    .base-ttl.fadein.scrollin::before, .fadein.scrollin.base-ttl2::before {
      z-index: 102;
      content: "";
      position: absolute;
      width: calc(100% - 8px);
      transition: all 500ms;
      -moz-transition-delay: 1.2s;
      -webkit-transition-delay: 1.2s;
      -o-transition-delay: 1.2s;
      -ms-transition-delay: 1.2s; }
      @media only screen and (max-width: 768px) {
        .base-ttl.fadein.scrollin::before, .fadein.scrollin.base-ttl2::before {
          width: calc(100% - 4px); } }

.base-ttl2 {
  font-size: 24px;
  margin: 0px 0px 0px 0px; }
  @media only screen and (max-width: 768px) {
    .base-ttl2 {
      font-size: 14px; } }
  .base-ttl2.fadein.scrollin::after {
    display: none; }
  .base-ttl2.fadein.scrollin::before {
    display: none; }

.ttl-container {
  margin: 0px 0px 64px 0px; }
  @media only screen and (max-width: 768px) {
    .ttl-container {
      margin: 0px 0px 32px 0px; } }

.base-link {
  font-size: 24px;
  line-height: 23px;
  color: #fff;
  text-decoration: none;
  display: inline-block;
  vertical-align: bottom;
  position: relative;
  z-index: 100;
  overflow: hidden;
  border-radius: 100px;
  padding: 8px 24px;
  border: solid 2px #bf0008;
  background: #bf0008;
  transition: 1000ms ease-in-out; }
  @media only screen and (max-width: 768px) {
    .base-link {
      font-size: 16px;
      line-height: 17px;
      padding: 8px 24px; } }
  .base-link img {
    width: 14px;
    height: auto;
    margin: 0px 32px 4px 0px; }
    @media only screen and (max-width: 768px) {
      .base-link img {
        width: 12px;
        margin: 0px 24px 2px 0px; } }
  .base-link:hover {
    color: #fff;
    text-decoration: none;
    opacity: 1;
    transform: translate(0, 0);
    border: solid 2px #fff;
    background: none; }

.entry-container {
  text-align: center; }
  .entry-container h5 {
    font-size: 24px;
    letter-spacing: 6px;
    margin: 0px 0px 32px 0px; }
    @media only screen and (max-width: 768px) {
      .entry-container h5 {
        font-size: 16px; } }
  .entry-container a {
    display: block;
    width: 80%;
    box-sizing: border-box;
    border: 4px solid #fff;
    margin: 0px auto 0px auto;
    padding: 32px;
    color: #fff;
    font-size: 26px;
    letter-spacing: 8px;
    position: relative;
    z-index: 10001;
    overflow: hidden;
    background-color: #bf0008; }
    @media only screen and (max-width: 768px) {
      .entry-container a {
        padding: 16px;
        font-size: 16px; } }
    .entry-container a::after {
      content: "";
      position: absolute;
      width: 100%;
      height: 100%;
      background-color: #fff;
      left: 0;
      bottom: -100%;
      transition: all 200ms;
      z-index: 1200;
      opacity: 0.2;
      transition-timing-function: ease-out; }
    .entry-container a:hover {
      text-decoration: none; }
      .entry-container a:hover::after {
        transition: all 200ms;
        bottom: 0px;
        transition-timing-function: ease-out; }

.hupro-container {
  text-align: left;
  margin: 0px 0px 64px 0px; }
  .hupro-container a {
    display: block;
    width: 80%;
    box-sizing: border-box;
    border: 4px solid #fff;
    margin: 0px auto 0px auto;
    padding: 32px 32px 32px 154px;
    color: #fff;
    font-size: 26px;
    letter-spacing: 8px;
    position: relative;
    z-index: 10001;
    overflow: hidden;
    background-color: #bf0008; }
    @media only screen and (max-width: 768px) {
      .hupro-container a {
        padding: 16px 16px 16px 77px;
        font-size: 16px; } }
    .hupro-container a::before {
      content: "";
      position: absolute;
      width: 124px;
      height: 100%;
      background-color: #fff;
      left: 0;
      bottom: 0;
      z-index: 1199;
      background-image: url("../img/entry/hupro-btn.svg");
      background-size: 80px 80px;
      background-position: center center;
      background-repeat: no-repeat;
      background-color: inherit !important;
      border-right: 1px solid #fff; }
      @media only screen and (max-width: 768px) {
        .hupro-container a::before {
          width: 62px;
          background-size: 40px 40px; } }
    .hupro-container a::after {
      content: "";
      position: absolute;
      width: 100%;
      height: 100%;
      background-color: #fff;
      left: 0;
      bottom: -100%;
      transition: all 200ms;
      z-index: 1200;
      opacity: 0.2;
      transition-timing-function: ease-out; }
    .hupro-container a:hover {
      text-decoration: none; }
      .hupro-container a:hover::after {
        transition: all 200ms;
        bottom: 0px;
        transition-timing-function: ease-out; }

#about .ttl-container {
  margin: 0px 0px 0px 32px;
  z-index: 101;
  position: relative;
  display: inline-block; }
  @media only screen and (max-width: 768px) {
    #about .ttl-container {
      margin: 0px 0px 32px 0px; } }
#about .mb {
  margin: 0px 0px 0px 0px; }
  @media only screen and (max-width: 768px) {
    #about .mb {
      margin: 0px 0px 10px 0px; } }
#about .movie-play {
  opacity: 0.3; }
  @media only screen and (max-width: 768px) {
    #about .movie-play {
      opacity: 1; } }
#about .movie-container {
  z-index: 50;
  width: 100%;
  position: relative;
  margin: -120px 0px 0px 0px; }
  #about .movie-container.fadein {
    -moz-transition-delay: 0.1s;
    -webkit-transition-delay: 0.1s;
    -o-transition-delay: 0.1s;
    -ms-transition-delay: 0.1s; }
  @media only screen and (max-width: 768px) {
    #about .movie-container {
      margin: 0px 0px 0px 0px; } }
  #about .movie-container .movie-box {
    position: relative; }
    @media only screen and (max-width: 768px) {
      #about .movie-container .movie-box {
        margin: 0px 0px 32px 0px; } }
    #about .movie-container .movie-box video {
      width: 100%;
      z-index: 99; }
    #about .movie-container .movie-box .play {
      display: block;
      margin: 12px 0px 0px 0px; }
      @media only screen and (max-width: 768px) {
        #about .movie-container .movie-box .play {
          margin: 12px 0px 0px 0px;
          position: inherit;
          bottom: inherit;
          text-align: right; } }
    #about .movie-container .movie-box p.play {
      cursor: pointer;
      position: absolute;
      right: 50px;
      vertical-align: bottom; }
      @media only screen and (max-width: 768px) {
        #about .movie-container .movie-box p.play {
          right: 32px; } }
      #about .movie-container .movie-box p.play img {
        width: 50px;
        height: 35px;
        margin: 0px 16px 0px 0px; }
        @media only screen and (max-width: 768px) {
          #about .movie-container .movie-box p.play img {
            width: 32px;
            height: 23px; } }
    #about .movie-container .movie-box .bgm-button {
      position: absolute;
      cursor: pointer;
      background-image: url("../img/about/bgm-off.svg");
      background-position: center center;
      background-size: 50px 36px;
      width: 50px;
      height: 36px;
      right: 0px;
      text-align: center;
      z-index: 100;
      margin: 12px 0px 0px 0px; }
      @media only screen and (max-width: 768px) {
        #about .movie-container .movie-box .bgm-button {
          background-size: 32px 23px;
          width: 32px;
          height: 23px; } }
      #about .movie-container .movie-box .bgm-button.on {
        background-image: url("../img/about/bgm-on.svg"); }
  #about .movie-container .text-area {
    position: absolute;
    bottom: 32px;
    left: 32px;
    z-index: 102; }
    @media only screen and (max-width: 1179px) {
      #about .movie-container .text-area {
        bottom: 24px;
        left: 24px; } }
    @media only screen and (max-width: 768px) {
      #about .movie-container .text-area {
        position: relative;
        bottom: inherit;
        left: inherit; } }
    #about .movie-container .text-area h3 {
      width: 100%;
      margin: 0px 0px 24px 0px; }
      @media only screen and (max-width: 768px) {
        #about .movie-container .text-area h3 {
          margin: 0px 0px 32px 0px; } }
      #about .movie-container .text-area h3 img {
        width: 600px;
        height: auto; }
        @media only screen and (max-width: 768px) {
          #about .movie-container .text-area h3 img {
            width: 300px; } }
    #about .movie-container .text-area h4 {
      font-size: 18px;
      margin: 0px 0px 16px 0px; }
      @media only screen and (max-width: 1179px) {
        #about .movie-container .text-area h4 {
          font-size: 18px; } }
    #about .movie-container .text-area strong {
      display: block;
      font-size: 16px;
      font-weight: bold; }
      @media only screen and (max-width: 1179px) {
        #about .movie-container .text-area strong {
          font-size: 16px; } }
    #about .movie-container .text-area p {
      display: block;
      font-size: 14px;
      margin: 0px 0px 24px 0px; }
      @media only screen and (max-width: 1179px) {
        #about .movie-container .text-area p {
          font-size: 14px; } }
    #about .movie-container .text-area p:last-of-type {
      margin: 0px 0px 0px 0px; }

#greeting .ttl-container {
  text-align: right; }
#greeting .parent-container {
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-align-items: stretch;
  /* Safari */
  align-items: stretch;
  justify-content: flex-end;
  position: relative; }
  #greeting .parent-container span {
    /*transform:rotate(-90deg);*/
    display: block;
    position: absolute;
    left: 0;
    top: 0; }
    @media only screen and (max-width: 768px) {
      #greeting .parent-container span {
        display: none; } }
    #greeting .parent-container span img {
      width: 300px;
      height: auto;
      opacity: 0.3; }
      @media only screen and (max-width: 1179px) {
        #greeting .parent-container span img {
          width: 200px; } }
  #greeting .parent-container dl {
    box-sizing: border-box;
    width: 70%;
    padding: 0px 0px 0px 0px;
    margin: 0px 0px 64px 0px; }
    @media only screen and (max-width: 768px) {
      #greeting .parent-container dl {
        width: 100%;
        padding: 0px 0px 0px 0px;
        margin: 0px 0px 32px 0px; } }
    #greeting .parent-container dl dt {
      margin: 0px 0px 32px 0px;
      position: relative; }
      #greeting .parent-container dl dt p {
        z-index: 100;
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        top: 12px;
        left: 12px;
        background-color: #bf0008; }
        @media only screen and (max-width: 768px) {
          #greeting .parent-container dl dt p {
            width: calc(100% - 12px); } }
      #greeting .parent-container dl dt img {
        position: relative;
        z-index: 101;
        width: 100%; }
        @media only screen and (max-width: 768px) {
          #greeting .parent-container dl dt img {
            width: calc(100% - 12px); } }
    #greeting .parent-container dl dd {
      font-size: 24px;
      line-height: 33px;
      letter-spacing: 4px;
      position: relative; }
      @media only screen and (max-width: 768px) {
        #greeting .parent-container dl dd {
          font-size: 20px; } }
      #greeting .parent-container dl dd a {
        display: block;
        position: absolute;
        right: 0px;
        top: 0px; }
        #greeting .parent-container dl dd a img {
          width: 48px;
          height: 48px; }
  #greeting .parent-container div {
    width: 70%;
    box-sizing: border-box;
    line-height: 30px; }
    #greeting .parent-container div.fadein {
      -moz-transition-delay: 0.1s;
      -webkit-transition-delay: 0.1s;
      -o-transition-delay: 0.1s;
      -ms-transition-delay: 0.1s; }
    @media only screen and (max-width: 768px) {
      #greeting .parent-container div {
        width: 100%;
        line-height: 24px; } }
    #greeting .parent-container div .right-link {
      margin-top: 32px;
      text-align: right; }

#recruit > h3 {
  margin: 0px 0px 64px 0px; }
  @media only screen and (max-width: 768px) {
    #recruit > h3 {
      margin: 0px 0px 32px 0px; } }
  #recruit > h3 img {
    width: 80%;
    height: auto; }
    @media only screen and (max-width: 768px) {
      #recruit > h3 img {
        width: 100%; } }
#recruit .recruitーimage {
  width: 100%;
  margin: 0 0 64px 0; }
  @media only screen and (max-width: 768px) {
    #recruit .recruitーimage {
      margin: 0 0 32px 0; } }
  #recruit .recruitーimage img {
    position: relative;
    z-index: 101;
    width: 100%;
    box-shadow: 16px 16px #bf0008; }
    @media only screen and (max-width: 768px) {
      #recruit .recruitーimage img {
        box-shadow: 12px 12px #bf0008;
        width: calc(100% - 12px); } }
#recruit .recruit-button__wrapper {
  display: flex;
  justify-content: right;
  align-items: center;
  flex-direction: column-reverse; }
#recruit a {
  text-decoration: none; }
  #recruit a .mynabi-button {
    width: 420px;
    margin-bottom: 64px; }
    @media only screen and (max-width: 1500px) {
      #recruit a .mynabi-button {
        width: 320px; } }
    @media only screen and (max-width: 1179px) {
      #recruit a .mynabi-button {
        width: 300px; } }
    @media only screen and (max-width: 768px) {
      #recruit a .mynabi-button {
        width: 340px;
        margin-bottom: 32px; } }
    @media (max-width: 400px) {
      #recruit a .mynabi-button {
        width: 250px;
        margin-right: 0; } }
  #recruit a .mynabi-button img {
    width: 100%; }
  #recruit a .mynabi-text {
    color: #fff;
    font-weight: bold;
    text-align: center;
    margin-bottom: 5px; }
  #recruit a .recruit-buttom {
    padding: 16px 30px 16px 200px;
    background: #d51518;
    width: 500px;
    height: auto;
    margin-left: auto;
    position: relative;
    border-radius: 100px;
    margin-bottom: 32px;
    border: #d51518 solid 4px;
    transition: 1000ms ease-in-out; }
    @media only screen and (max-width: 1500px) {
      #recruit a .recruit-buttom {
        padding: 8px 40px 8px 130px;
        width: 373px; } }
    @media only screen and (max-width: 1179px) {
      #recruit a .recruit-buttom {
        padding: 16px 50px 16px 70px;
        margin: 0 auto 32px auto;
        width: 300px; } }
    @media only screen and (max-width: 768px) {
      #recruit a .recruit-buttom {
        width: 380px;
        padding: 8px 40px 8px 130px;
        margin: 0 auto 32px auto; } }
    @media (max-width: 400px) {
      #recruit a .recruit-buttom {
        padding: 8px 24px 8px 96px;
        width: 280px; } }
    #recruit a .recruit-buttom:hover {
      background: #6a6a6a;
      border: #fff solid 4px; }
    #recruit a .recruit-buttom .recruit-buttom-text {
      text-align: left; }
      #recruit a .recruit-buttom .recruit-buttom-text h3 {
        font-size: 24px;
        border-bottom: solid #fff 3px;
        padding-bottom: 4px;
        color: #fff; }
        @media only screen and (max-width: 1179px) {
          #recruit a .recruit-buttom .recruit-buttom-text h3 {
            font-size: 20px; } }
        @media only screen and (max-width: 768px) {
          #recruit a .recruit-buttom .recruit-buttom-text h3 {
            font-size: 14px;
            border-bottom: solid #fff 3px; } }
      #recruit a .recruit-buttom .recruit-buttom-text p {
        color: #fff;
        font-size: 16px; }
        @media only screen and (max-width: 1179px) {
          #recruit a .recruit-buttom .recruit-buttom-text p {
            font-size: 12px; } }
        @media only screen and (max-width: 768px) {
          #recruit a .recruit-buttom .recruit-buttom-text p {
            font-size: 8px; } }
    #recruit a .recruit-buttom img {
      width: 32px;
      position: absolute;
      top: 50%;
      left: 12%;
      -webkit-transform: translate(-50%, -50%);
      transform: translate(-50%, -50%);
      display: block;
      -webkit-transition: 1000ms ease-in-out;
      transition: 1000ms ease-in-out; }
      @media only screen and (max-width: 768px) {
        #recruit a .recruit-buttom img {
          width: 24px;
          left: 12%; } }
    #recruit a .recruit-buttom:hover img:nth-of-type(2) {
      opacity: 0; }
#recruit h4 {
  font-size: 18px;
  line-height: 2;
  display: inline-block;
  position: relative;
  margin: 0px 0px 64px 0px;
  padding: 0px 0px 0px 0px; }
  @media only screen and (max-width: 768px) {
    #recruit h4 {
      display: block;
      font-size: 14px;
      line-height: 24px;
      font-weight: normal;
      padding: 0px 0px 0px 0px; } }
#recruit > figure {
  width: 100%;
  margin: -128px 0px 128px 0px;
  text-align: right; }
  @media only screen and (max-width: 1179px) {
    #recruit > figure {
      margin: 0px 0px 128px 0px; } }
  @media only screen and (max-width: 768px) {
    #recruit > figure {
      text-align: center; } }
  #recruit > figure img {
    width: 400px;
    height: auto; }
    @media only screen and (max-width: 768px) {
      #recruit > figure img {
        width: 80%; } }
#recruit .point3-list {
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-align-items: stretch;
  /* Safari */
  align-items: stretch;
  margin: 0px 0px 64px 0px; }
  @media only screen and (max-width: 768px) {
    #recruit .point3-list {
      margin: 0px 0px 0px 0px; } }
  #recruit .point3-list li {
    width: 33%;
    text-align: center;
    margin: 0px 0px 64px 0px; }
    @media only screen and (max-width: 1179px) {
      #recruit .point3-list li {
        width: 50%; } }
    @media only screen and (max-width: 768px) {
      #recruit .point3-list li {
        width: 50%; } }
    #recruit .point3-list li img {
      width: 75%;
      height: auto; }
      @media only screen and (max-width: 1179px) {
        #recruit .point3-list li img {
          width: 80%; } }
      @media only screen and (max-width: 768px) {
        #recruit .point3-list li img {
          width: 80%; } }
#recruit .employee-ttl {
  font-size: 38px;
  margin: 0px 0px 128px 0px;
  text-align: center; }
  @media only screen and (max-width: 768px) {
    #recruit .employee-ttl {
      font-size: 24px;
      margin: 0px 0px 48px 0px; } }
  #recruit .employee-ttl span {
    position: relative;
    display: inline-block;
    overflow: hidden; }
    #recruit .employee-ttl span::after {
      content: "";
      position: absolute;
      width: 0px;
      height: 5px;
      left: 0px;
      bottom: 0px;
      background-color: #bf0008;
      z-index: 101; }
      @media only screen and (max-width: 768px) {
        #recruit .employee-ttl span::after {
          height: 4px; } }
    #recruit .employee-ttl span::before {
      content: "";
      position: absolute;
      width: 0px;
      height: 5px;
      left: 0px;
      bottom: 0px;
      background-color: #fff;
      z-index: 102; }
      @media only screen and (max-width: 768px) {
        #recruit .employee-ttl span::before {
          height: 4px; } }
    #recruit .employee-ttl span.fadein {
      opacity: 1;
      transform: translate(0, 100px);
      transition: all 1000ms;
      color: #bf0008; }
    #recruit .employee-ttl span.fadein.scrollin {
      opacity: 1;
      transform: translate(0, 0);
      color: #fff; }
      #recruit .employee-ttl span.fadein.scrollin::after {
        z-index: 101;
        content: "";
        position: absolute;
        width: calc(100%);
        transition: all 1000ms;
        left: 100%;
        -moz-transition-delay: 0.5s;
        -webkit-transition-delay: 0.5s;
        -o-transition-delay: 0.5s;
        -ms-transition-delay: 0.5s; }
        @media only screen and (max-width: 768px) {
          #recruit .employee-ttl span.fadein.scrollin::after {
            width: calc(100% - 4px); } }
      #recruit .employee-ttl span.fadein.scrollin::before {
        z-index: 102;
        content: "";
        position: absolute;
        width: calc(100%);
        transition: all 1000ms;
        left: 100%;
        -moz-transition-delay: 0.9s;
        -webkit-transition-delay: 0.9s;
        -o-transition-delay: 0.9s;
        -ms-transition-delay: 0.9s; }
        @media only screen and (max-width: 768px) {
          #recruit .employee-ttl span.fadein.scrollin::before {
            width: calc(100% - 4px); } }
#recruit .employee-list {
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-align-items: stretch;
  /* Safari */
  align-items: stretch;
  margin: 0px 0px 64px 0px; }
  @media only screen and (max-width: 768px) {
    #recruit .employee-list {
      margin: 0px 0px 0px 0px; } }
  #recruit .employee-list li {
    width: calc(33.3% - 16px);
    margin: 0px 0px 0px 16px;
    z-index: 50; }
    @media only screen and (max-width: 768px) {
      #recruit .employee-list li {
        width: 100%;
        margin: 0px 0px 32px 0px; } }
    #recruit .employee-list li figure {
      overflow: hidden;
      position: relative; }
      #recruit .employee-list li figure .photoOn {
        position: absolute;
        width: 100%;
        transition: 0.5s;
        opacity: 0; }
        #recruit .employee-list li figure .photoOn.inViewOn {
          opacity: 1 !important;
          transform: scale(1.1, 1.1) !important;
          -moz-transition-delay: 1s !important;
          -webkit-transition-delay: 1s !important;
          -o-transition-delay: 1s !important;
          -ms-transition-delay: 1s !important; }
        #recruit .employee-list li figure .photoOn:hover {
          opacity: 1;
          transform: scale(1.1, 1.1); }
      #recruit .employee-list li figure .photoOff {
        width: 100%;
        transition: 0.5s;
        opacity: 1; }
        #recruit .employee-list li figure .photoOff.inViewOn {
          opacity: 0 !important;
          transform: scale(1.1, 1.1) !important;
          -moz-transition-delay: 1s !important;
          -webkit-transition-delay: 1s !important;
          -o-transition-delay: 1s !important;
          -ms-transition-delay: 1s !important; }
        #recruit .employee-list li figure .photoOff:hover {
          opacity: 0;
          transform: scale(1.1, 1.1); }
    #recruit .employee-list li dl {
      box-sizing: border-box;
      padding: 16px 32px 16px 32px;
      font-size: 12px;
      line-height: 23px;
      letter-spacing: 2px; }
      @media only screen and (max-width: 1179px) {
        #recruit .employee-list li dl {
          padding: 16px; } }
    #recruit .employee-list li div {
      background-color: #fff;
      padding: 32px;
      color: #6c6c6c; }
      @media only screen and (max-width: 1100px) {
        #recruit .employee-list li div {
          padding: 24px; } }
      @media only screen and (max-width: 1000px) {
        #recruit .employee-list li div {
          padding: 16px; } }
      #recruit .employee-list li div strong {
        font-size: 24px;
        line-height: 38px;
        margin: 0px 0px 32px 0px;
        display: block;
        letter-spacing: 6px; }
        @media only screen and (max-width: 1100px) {
          #recruit .employee-list li div strong {
            font-size: 20px;
            line-height: 1.4; } }
        @media only screen and (max-width: 1000px) {
          #recruit .employee-list li div strong {
            font-size: 16px;
            line-height: 1.4; } }
        @media only screen and (max-width: 768px) {
          #recruit .employee-list li div strong {
            font-size: 16px;
            line-height: 24px;
            margin: 0px 0px 16px 0px; } }
      #recruit .employee-list li div p {
        font-size: 16px;
        line-height: 26px; }
        @media only screen and (max-width: 768px) {
          #recruit .employee-list li div p {
            font-size: 14px;
            line-height: 20px; } }
#recruit .right-link {
  text-align: right;
  margin: 0px 0px 128px 0px; }
  @media only screen and (max-width: 768px) {
    #recruit .right-link {
      margin: 0px 0px 64px 0px; } }
#recruit .overview-container {
  margin: 0px 0px 96px 0px; }
  @media only screen and (max-width: 768px) {
    #recruit .overview-container {
      margin: 0px 0px 64px 0px; } }
  @media only screen and (max-width: 768px) {
    #recruit .overview-container h3 {
      font-size: 18px; } }
  #recruit .overview-container > strong {
    font-size: 18px;
    display: block;
    font-weight: normal;
    margin: 0px 0px 64px 0px; }
    @media only screen and (max-width: 768px) {
      #recruit .overview-container > strong {
        font-size: 16px;
        margin: 0px 0px 32px 0px; } }
  #recruit .overview-container dl {
    display: -webkit-flex;
    /* Safari */
    display: flex;
    -webkit-flex-direction: row;
    /* Safari */
    flex-direction: row;
    -webkit-flex-wrap: wrap;
    /* Safari */
    flex-wrap: wrap;
    -webkit-align-items: stretch;
    /* Safari */
    align-items: stretch;
    line-height: 1.8; }
    #recruit .overview-container dl dt {
      width: 200px;
      box-sizing: border-box;
      margin: 0px 0px 32px 0px;
      border-right: 1px solid #fff;
      text-align: right;
      padding: 0px 32px 0px 0px;
      font-weight: bold; }
      @media only screen and (max-width: 768px) {
        #recruit .overview-container dl dt {
          width: 100%;
          padding: 0px 0px 0px 0px;
          margin: 0px 0px 4px 0px;
          text-align: left;
          border-right: none; } }
    #recruit .overview-container dl dd {
      width: calc(100% - 200px);
      box-sizing: border-box;
      padding: 0px 0px 0px 32px;
      margin: 0px 0px 32px 0px; }
      #recruit .overview-container dl dd em {
        font-style: normal;
        font-size: 14px; }
      @media only screen and (max-width: 768px) {
        #recruit .overview-container dl dd {
          width: 100%;
          padding: 0px 0px 16px 0px;
          margin: 0px 0px 16px 0px;
          border-bottom: 1px solid #fff; } }

#recruit.detail {
  padding-top: 128px; }
  #recruit.detail .employee-list li {
    margin-bottom: 64px; }

#company .parent-container {
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-align-items: stretch;
  /* Safari */
  align-items: stretch; }
  #company .parent-container div.left {
    box-sizing: border-box;
    width: calc(35% - 44px);
    padding: 0px 0px 0px 0px;
    margin: 0px 44px 0px 0px;
    position: relative; }
    @media only screen and (max-width: 768px) {
      #company .parent-container div.left {
        width: 100%;
        padding: 0px 0px 0px 0px;
        margin: 0px 0px 32px 0px; } }
    #company .parent-container div.left div {
      position: relative; }
      #company .parent-container div.left div p {
        z-index: 100;
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        top: 12px;
        left: 12px;
        background-color: #bf0008; }
        #company .parent-container div.left div p.fadein {
          -moz-transition-delay: 0.1s;
          -webkit-transition-delay: 0.1s;
          -o-transition-delay: 0.1s;
          -ms-transition-delay: 0.1s; }
        @media only screen and (max-width: 768px) {
          #company .parent-container div.left div p {
            width: calc(100% - 12px); } }
      #company .parent-container div.left div img {
        width: 100%;
        position: relative;
        z-index: 101; }
        @media only screen and (max-width: 768px) {
          #company .parent-container div.left div img {
            width: calc(100% - 12px); } }
  #company .parent-container div.right {
    width: calc(65%); }
    @media only screen and (max-width: 768px) {
      #company .parent-container div.right {
        width: 100%; } }
    #company .parent-container div.right dl {
      width: 100%;
      box-sizing: border-box;
      font-size: 18px;
      line-height: 30px;
      text-align: left;
      letter-spacing: 4px;
      display: -webkit-flex;
      /* Safari */
      display: flex;
      -webkit-flex-direction: row;
      /* Safari */
      flex-direction: row;
      -webkit-flex-wrap: wrap;
      /* Safari */
      flex-wrap: wrap;
      -webkit-align-items: stretch;
      /* Safari */
      align-items: stretch;
      margin: 0px 0px 12px 0px; }
      #company .parent-container div.right dl.fadein {
        -moz-transition-delay: 0.1s;
        -webkit-transition-delay: 0.1s;
        -o-transition-delay: 0.1s;
        -ms-transition-delay: 0.1s; }
      @media only screen and (max-width: 768px) {
        #company .parent-container div.right dl {
          width: 100%;
          font-size: 14px;
          letter-spacing: 2px; } }
      #company .parent-container div.right dl dt {
        width: 180px;
        display: block;
        vertical-align: top;
        margin: 0px 0px 0px 0px; }
        @media only screen and (max-width: 768px) {
          #company .parent-container div.right dl dt {
            width: 120px; } }
      #company .parent-container div.right dl dd {
        width: calc(100% - 180px);
        display: block;
        vertical-align: top;
        margin: 0px 0px 0px 0px; }
        @media only screen and (max-width: 768px) {
          #company .parent-container div.right dl dd {
            width: calc(100% - 120px); } }
        #company .parent-container div.right dl dd a {
          color: #fff; }
        #company .parent-container div.right dl dd a:hover {
          color: #fff; }
  #company .parent-container .right-link {
    text-align: right; }

#topics ul {
  margin: 0px 0px 32px 0px; }
  #topics ul li {
    margin: 0px 0px 16px 0px; }
    @media only screen and (max-width: 768px) {
      #topics ul li {
        border-bottom: 1px solid #fff;
        padding: 0px 0px 16px 0px; } }
    #topics ul li a {
      color: #fff;
      text-decoration: none;
      font-size: 18px;
      display: -webkit-flex;
      /* Safari */
      display: flex;
      -webkit-flex-direction: row;
      /* Safari */
      flex-direction: row;
      -webkit-flex-wrap: wrap;
      /* Safari */
      flex-wrap: wrap;
      -webkit-align-items: stretch;
      /* Safari */
      align-items: stretch; }
      @media only screen and (max-width: 768px) {
        #topics ul li a {
          font-size: 14px; } }
      #topics ul li a:hover {
        text-decoration: underline; }
      #topics ul li a em {
        display: block;
        width: 180px;
        font-style: normal; }
        #topics ul li a em.news {
          display: block;
          width: 220px;
          font-style: normal; }
        @media only screen and (max-width: 768px) {
          #topics ul li a em {
            width: 100%;
            font-size: 12px; } }
      #topics ul li a span {
        display: block;
        width: 180px;
        font-weight: 600; }
        #topics ul li a span.topics {
          width: 80px; }
        @media only screen and (max-width: 768px) {
          #topics ul li a span {
            width: 100%;
            font-size: 12px; } }
      #topics ul li a strong {
        display: block;
        width: calc(100% - 360px);
        font-weight: 400; }
        @media only screen and (max-width: 768px) {
          #topics ul li a strong {
            width: 100%; } }
#topics .right-link {
  text-align: right; }

footer {
  z-index: 4000;
  position: relative;
  background-color: #bf0008;
  padding: 96px 64px 64px 64px;
  margin: 200px 0px 0px 0px;
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-align-items: stretch;
  /* Safari */
  align-items: stretch; }
  @media only screen and (max-width: 1179px) {
    footer {
      padding: 96px 64px 64px 64px; } }
  @media only screen and (max-width: 768px) {
    footer {
      padding: 32px 16px 32px 16px;
      margin: 0px 0px 0px 0px; } }
  footer::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 200px;
    top: -200px;
    left: 0px;
    background: linear-gradient(rgba(0, 0, 0, 0) 0%, #6a6a6a 40%) no-repeat 50% 50%/100% 100%; }
    @media only screen and (max-width: 768px) {
      footer::after {
        display: none; } }
  footer a {
    color: #fff; }
  footer a:hover {
    color: #fff; }
  footer .left-container {
    box-sizing: border-box;
    width: 20%;
    padding: 0px 16px 0px 0px; }
    @media only screen and (max-width: 1179px) {
      footer .left-container {
        width: 33%; } }
    @media only screen and (max-width: 768px) {
      footer .left-container {
        width: 100%;
        margin: 0px 0px 48px 0px;
        padding: 0px 0px 0px 0px; } }
    footer .left-container h2 {
      margin: 0px 0px 64px 0px; }
      @media only screen and (max-width: 768px) {
        footer .left-container h2 {
          margin: 0px 0px 32px 0px;
          text-align: center; } }
      footer .left-container h2 img {
        width: 80px;
        height: 107px; }
    footer .left-container h3 {
      font-size: 14px;
      text-align: center; }
  footer .right-container {
    width: 80%;
    letter-spacing: 2px; }
    @media only screen and (max-width: 1179px) {
      footer .right-container {
        width: 66%; } }
    @media only screen and (max-width: 768px) {
      footer .right-container {
        width: 100%;
        letter-spacing: inherit; } }
    footer .right-container ul {
      display: -webkit-flex;
      /* Safari */
      display: flex;
      -webkit-flex-direction: row;
      /* Safari */
      flex-direction: row;
      -webkit-flex-wrap: wrap;
      /* Safari */
      flex-wrap: wrap;
      -webkit-align-items: stretch;
      /* Safari */
      align-items: stretch;
      margin: 0px 0px 0px 0px;
      font-size: 13px; }
      footer .right-container ul li {
        width: 50%;
        margin: 0px 0px 32px 0px;
        box-sizing: border-box;
        padding: 0px 32px 0px 0px; }
        @media only screen and (max-width: 1179px) {
          footer .right-container ul li {
            width: 50%; } }
        @media only screen and (max-width: 768px) {
          footer .right-container ul li {
            width: 100%;
            padding: 0px 0px 0px 0px; } }
        footer .right-container ul li h3 {
          font-weight: 600;
          margin: 0px 0px 8px 0px; }
        footer .right-container ul li p {
          line-height: 24px; }
        footer .right-container ul li.social-container {
          position: relative;
          width: 66.6%; }
          @media only screen and (max-width: 1179px) {
            footer .right-container ul li.social-container {
              width: 100%;
              padding: 0px 0px 0px 0px; } }
          @media only screen and (max-width: 768px) {
            footer .right-container ul li.social-container {
              width: 100%; } }
          footer .right-container ul li.social-container div {
            position: absolute;
            bottom: 0px;
            right: 0px; }
            @media only screen and (max-width: 1179px) {
              footer .right-container ul li.social-container div {
                position: inherit;
                bottom: inherit;
                right: inherit;
                text-align: right; } }
            @media only screen and (max-width: 768px) {
              footer .right-container ul li.social-container div {
                position: inherit;
                bottom: inherit;
                right: inherit;
                text-align: right; } }
            footer .right-container ul li.social-container div a.fb {
              margin: 0px 16px 0px 0px; }
            footer .right-container ul li.social-container div a img {
              width: 40px;
              height: 40px; }
  footer small {
    display: block;
    width: 100%;
    text-align: right;
    font-size: 12px; }

#second .base-container {
  position: relative; }
#second .ttl {
  padding-top: 96px; }
#second .back-btn {
  background-color: #bf0008;
  display: inline-block;
  padding: 6px 12px;
  color: #fff;
  font-size: 16px;
  letter-spacing: 2px;
  font-weight: bold;
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 8000; }
  @media only screen and (max-width: 768px) {
    #second .back-btn {
      bottom: 8px;
      right: 8px;
      font-size: 12px; } }
  #second .back-btn span {
    position: relative;
    z-index: 8002; }
  #second .back-btn::after {
    z-index: 8001;
    content: "";
    position: absolute;
    width: 0px;
    height: 100%;
    background-color: #fff;
    right: 0;
    bottom: 0px;
    transition: all 300ms;
    transition-timing-function: ease-out; }
  #second .back-btn:hover {
    text-decoration: none;
    color: #bf0008; }
    #second .back-btn:hover::after {
      width: 100%;
      transition: all 300ms;
      transition-timing-function: ease-out; }
#second.employee .base-container .box-number {
  position: absolute;
  right: 0px;
  font-size: 200px;
  font-weight: 600;
  color: #fff;
  line-height: 1; }
  @media only screen and (max-width: 768px) {
    #second.employee .base-container .box-number {
      font-size: 96px; } }
#second.employee #employee-movie .box-number {
  top: -110px; }
#second.employee #employee-movie .movie-container {
  position: relative; }
  #second.employee #employee-movie .movie-container > img {
    width: 100%; }
  #second.employee #employee-movie .movie-container p {
    position: absolute;
    right: 32px;
    bottom: 32px;
    font-size: 60px;
    color: #bf0008;
    font-weight: 600;
    line-height: 55px;
    letter-spacing: 12px; }
    @media only screen and (max-width: 768px) {
      #second.employee #employee-movie .movie-container p {
        font-size: 32px;
        line-height: 32px;
        right: 16px;
        bottom: 16px; } }
    #second.employee #employee-movie .movie-container p img {
      width: 55px;
      height: auto;
      margin: 0px 16px 0px 0px; }
      @media only screen and (max-width: 768px) {
        #second.employee #employee-movie .movie-container p img {
          width: 32px; } }
#second.employee #corporate-text .box-number {
  top: -30px; }
#second.employee #corporate-text .right-container {
  position: relative;
  padding-left: 256px;
  min-height: 680px; }
  @media only screen and (max-width: 768px) {
    #second.employee #corporate-text .right-container {
      min-height: inherit;
      padding-left: 0px; } }
  #second.employee #corporate-text .right-container .bg-text {
    position: absolute;
    bottom: 0px;
    left: 0px;
    opacity: 0.3; }
    @media only screen and (max-width: 768px) {
      #second.employee #corporate-text .right-container .bg-text {
        display: none; } }
    #second.employee #corporate-text .right-container .bg-text img {
      width: 207px;
      height: auto; }
  #second.employee #corporate-text .right-container h3 {
    font-size: 36px;
    margin: 0px 0px 32px 0px; }
    @media only screen and (max-width: 768px) {
      #second.employee #corporate-text .right-container h3 {
        font-size: 24px; } }
  #second.employee #corporate-text .right-container p {
    background-color: #333333;
    color: #fff;
    padding: 50px;
    line-height: 30px; }
    @media only screen and (max-width: 768px) {
      #second.employee #corporate-text .right-container p {
        padding: 16px; } }
#second.employee #recruit {
  padding-top: 0px; }
  #second.employee #recruit .box-number {
    z-index: 1;
    top: 90px; }
    @media only screen and (max-width: 768px) {
      #second.employee #recruit .box-number {
        top: -20px; } }
  #second.employee #recruit .employee-list li {
    z-index: 50; }
    #second.employee #recruit .employee-list li figure {
      overflow: hidden;
      position: relative; }
      #second.employee #recruit .employee-list li figure .photoOn {
        position: absolute;
        width: 100%;
        transition: 0.5s;
        opacity: 0; }
        #second.employee #recruit .employee-list li figure .photoOn:hover {
          opacity: 1;
          transform: scale(1.1, 1.1); }
      #second.employee #recruit .employee-list li figure .photoOff {
        width: 100%;
        transition: 0.5s;
        opacity: 1; }
        #second.employee #recruit .employee-list li figure .photoOff:hover {
          opacity: 0;
          transform: scale(1.1, 1.1); }
#second.topics .base-container {
  margin-bottom: 64px; }
  @media only screen and (max-width: 768px) {
    #second.topics .base-container {
      margin-bottom: 32px; } }
#second.topics .topics-base h3 {
  font-size: 36px;
  margin: 0px 0px 16px 0px;
  color: #222; }
  @media only screen and (max-width: 768px) {
    #second.topics .topics-base h3 {
      font-size: 18px; } }
#second.topics .topics-base em {
  margin: 0px 0px 32px 0px;
  display: block; }
#second.topics .topics-base p {
  line-height: 1.8; }

.modaal-content-container .modal-center-container {
  max-width: 1180px;
  width: 100%;
  margin: 0px auto;
  display: -webkit-flex;
  /* Safari */
  display: flex;
  -webkit-flex-direction: row;
  /* Safari */
  flex-direction: row;
  -webkit-flex-wrap: wrap;
  /* Safari */
  flex-wrap: wrap;
  -webkit-align-items: stretch;
  /* Safari */
  align-items: stretch; }
  .modaal-content-container .modal-center-container .map-container {
    box-sizing: border-box;
    width: 100%;
    height: 600px;
    background-color: #fff;
    padding: 32px 32px;
    position: relative; }
    @media only screen and (max-width: 1179px) {
      .modaal-content-container .modal-center-container .map-container {
        height: 500px; } }
    @media only screen and (max-width: 768px) {
      .modaal-content-container .modal-center-container .map-container {
        width: 100%;
        height: 500px;
        padding: 16px 16px; } }
    .modaal-content-container .modal-center-container .map-container .md-close {
      position: absolute;
      right: 0;
      top: 0;
      display: block;
      width: 55px;
      height: 55px;
      background-image: url("../img/company/close.svg");
      background-size: 29px 29px;
      background-position: center center;
      background-repeat: no-repeat;
      cursor: pointer; }
