@charset "UTF-8";
/*!
 * ress.css • v1.2.2
 * MIT License
 * github.com/filipelinhares/ress
 */
/* # =================================================================
   # Global selectors
   # ================================================================= */
html {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  overflow-y: scroll;
  /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%;
  /* iOS 8+ */ }

*,
::before,
::after {
  background-repeat: no-repeat;
  /* Set `background-repeat: no-repeat` to all elements and pseudo elements */
  -webkit-box-sizing: inherit;
          box-sizing: inherit; }

::before,
::after {
  text-decoration: inherit;
  /* Inherit text-decoration and vertical align to ::before and ::after pseudo elements */
  vertical-align: inherit; }

* {
  padding: 0;
  /* Reset `padding` and `margin` of all elements */
  margin: 0; }

/* # =================================================================
     # General elements
     # ================================================================= */
/* Add the correct display in iOS 4-7.*/
audio:not([controls]) {
  display: none;
  height: 0; }

hr {
  overflow: visible;
  /* Show the overflow in Edge and IE */ }

/*
  * Correct `block` display not defined for any HTML5 element in IE 8/9
  * Correct `block` display not defined for `details` or `summary` in IE 10/11
  * and Firefox
  * Correct `block` display not defined for `main` in IE 11
  */
article,
aside,
details,
figcaption,
figure,
footer,
header,
main,
menu,
nav,
section,
summary {
  display: block; }

summary {
  display: list-item;
  /* Add the correct display in all browsers */ }

small {
  font-size: 80%;
  /* Set font-size to 80% in `small` elements */ }

[hidden],
template {
  display: none;
  /* Add the correct display in IE */ }

abbr[title] {
  border-bottom: 1px dotted;
  /* Add a bordered underline effect in all browsers */
  text-decoration: none;
  /* Remove text decoration in Firefox 40+ */ }

a {
  background-color: transparent;
  /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects;
  /* Remove gaps in links underline in iOS 8+ and Safari 8+ */
  text-decoration: none; }

a:active,
a:hover {
  outline-width: 0;
  /* Remove the outline when hovering in all browsers */
  opacity: 0.7;
  text-decoration: none; }

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  /* Specify the font family of code elements */ }

b,
strong {
  font-weight: bolder;
  /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */ }

dfn {
  font-style: italic;
  /* Address styling not present in Safari and Chrome */ }

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000; }

/* https://gist.github.com/unruthless/413930 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

/* # =================================================================
     # Forms
     # ================================================================= */
input {
  border-radius: 0; }

/* Apply cursor pointer to button elements */
button,
[type="button"],
[type="reset"],
[type="submit"],
[role="button"] {
  cursor: pointer; }

/* Replace pointer cursor in disabled elements */
[disabled] {
  cursor: default; }

[type="number"] {
  width: auto;
  /* Firefox 36+ */ }

[type="search"] {
  -webkit-appearance: textfield;
  /* Safari 8+ */ }

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
  /* Safari 8 */ }

textarea {
  overflow: auto;
  /* Internet Explorer 11+ */
  resize: vertical;
  /* Specify textarea resizability */ }

button,
input,
optgroup,
select,
textarea {
  font: inherit;
  /* Specify font inheritance of form elements */ }

optgroup {
  font-weight: bold;
  /* Restore the font weight unset by the previous rule. */ }

button {
  overflow: visible;
  /* Address `overflow` set to `hidden` in IE 8/9/10/11 */ }

/* Remove inner padding and border in Firefox 4+ */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: 0;
  padding: 0; }

/* Replace focus style removed in the border reset above */
button:-moz-focusring,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  outline: 1px dotted ButtonText; }

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS */ }

button,
select {
  text-transform: none;
  /* Firefox 40+, Internet Explorer 11- */ }

/* Remove the default button styling in all browsers */
button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
  color: inherit; }

/* Style select like a standard input */
select {
  -moz-appearance: none;
  /* Firefox 36+ */
  -webkit-appearance: none;
  /* Chrome 41+ */ }

select::-ms-expand {
  display: none;
  /* Internet Explorer 11+ */ }

select::-ms-value {
  color: currentColor;
  /* Internet Explorer 11+ */ }

legend {
  border: 0;
  /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit;
  /* Correct the color inheritance from `fieldset` elements in IE */
  display: table;
  /* Correct the text wrapping in Edge and IE */
  max-width: 100%;
  /* Correct the text wrapping in Edge and IE */
  white-space: normal;
  /* Correct the text wrapping in Edge and IE */ }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS and Safari */
  font: inherit;
  /* Change font properties to `inherit` in Chrome and Safari */ }

[type="search"] {
  -webkit-appearance: textfield;
  /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px;
  /* Correct the outline style in Safari */ }

/* # =================================================================
     # Specify media element style
     # ================================================================= */
img {
  border-style: none;
  /* Remove border when inside `a` element in IE 8/9/10 */
  width: 100%;
  height: auto; }

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline; }

svg:not(:root) {
  overflow: hidden;
  /* Internet Explorer 11- */ }

audio,
canvas,
progress,
video {
  display: inline-block;
  /* Internet Explorer 11+, Windows Phone 8.1+ */ }

/* # =================================================================
     # Accessibility
     # ================================================================= */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~="screen"] {
    display: inherit; }
  [hidden~="screen"]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important; } }

/* Specify the progress cursor of updating elements */
[aria-busy="true"] {
  cursor: progress; }

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer; }

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default; }

/* # =================================================================
     # Selection
     # ================================================================= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }

::selection {
  background-color: #b3d4fc;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }

/*--@mixin 定義 --*/
.pc {
  display: block; }
  @media (max-width: 1024px) {
    .pc {
      display: none; } }
  @media (max-width: 767px) {
    .pc {
      display: none; } }
  @media (max-width: 480px) {
    .pc {
      display: none; } }

.sp {
  display: none; }
  @media (max-width: 1024px) {
    .sp {
      display: block; } }
  @media (max-width: 767px) {
    .sp {
      display: block; } }
  @media (max-width: 480px) {
    .sp {
      display: block; } }

.width_1350_visible {
  display: block; }
  @media screen and (max-width: 1349px) {
    .width_1350_visible {
      display: none; } }
  @media (max-width: 1024px) {
    .width_1350_visible {
      display: none; } }
  @media (max-width: 767px) {
    .width_1350_visible {
      display: none; } }
  @media (max-width: 480px) {
    .width_1350_visible {
      display: none; } }

.width_1350_invisible {
  display: none; }
  @media screen and (max-width: 1349px) {
    .width_1350_invisible {
      display: block; } }
  @media (max-width: 1024px) {
    .width_1350_invisible {
      display: block; } }
  @media (max-width: 767px) {
    .width_1350_invisible {
      display: block; } }
  @media (max-width: 480px) {
    .width_1350_invisible {
      display: block; } }

.width_1200_visible {
  display: block; }
  @media screen and (max-width: 1200px) {
    .width_1200_visible {
      display: none; } }
  @media (max-width: 1024px) {
    .width_1200_visible {
      display: none; } }
  @media (max-width: 767px) {
    .width_1200_visible {
      display: none; } }
  @media (max-width: 480px) {
    .width_1200_visible {
      display: none; } }

.width_1200_invisible {
  display: none; }
  @media screen and (max-width: 1200px) {
    .width_1200_invisible {
      display: block; } }
  @media (max-width: 1024px) {
    .width_1200_invisible {
      display: block; } }
  @media (max-width: 767px) {
    .width_1200_invisible {
      display: block; } }
  @media (max-width: 480px) {
    .width_1200_invisible {
      display: block; } }

.tab_invisible {
  display: block; }
  @media (max-width: 1024px) {
    .tab_invisible {
      display: block; } }
  @media (max-width: 767px) {
    .tab_invisible {
      display: none; } }
  @media (max-width: 480px) {
    .tab_invisible {
      display: none; } }

.tab_visible {
  display: none; }
  @media (max-width: 1024px) {
    .tab_visible {
      display: none; } }
  @media (max-width: 767px) {
    .tab_visible {
      display: block; } }
  @media (max-width: 480px) {
    .tab_visible {
      display: block; } }

.tab_only {
  display: none; }
  @media (max-width: 1024px) {
    .tab_only {
      display: block; } }
  @media (max-width: 767px) {
    .tab_only {
      display: none; } }
  @media (max-width: 480px) {
    .tab_only {
      display: none; } }

.sp_invisible {
  display: block; }
  @media (max-width: 1024px) {
    .sp_invisible {
      display: block; } }
  @media (max-width: 767px) {
    .sp_invisible {
      display: block; } }
  @media (max-width: 480px) {
    .sp_invisible {
      display: none; } }

.sp_visible {
  display: none; }
  @media (max-width: 1024px) {
    .sp_visible {
      display: none; } }
  @media (max-width: 767px) {
    .sp_visible {
      display: none; } }
  @media (max-width: 480px) {
    .sp_visible {
      display: block; } }

li {
  list-style: none; }

.center {
  text-align: center; }

.white {
  color: #fff; }

.blue {
  color: #2C479E; }

.blue_bg {
  background: #2C479E; }

.GoogleMap {
  height: 0;
  overflow: hidden;
  padding-bottom: 40%;
  position: relative; }

.GoogleMap iframe {
  position: absolute;
  left: 0;
  top: 0;
  height: 100%;
  width: 100%; }

.under_360 {
  display: none; }
  @media screen and (max-width: 360px) {
    .under_360 {
      display: block; } }

body {
  overflow: hidden !important; }
  body.fixed {
    position: fixed;
    width: 100%;
    height: 100%; }

#wrap {
  margin-top: 80px; }
  @media screen and (max-width: 1024px) {
    #wrap {
      margin-top: 50px; } }

.sp_width_92 {
  width: 92% !important; }

@media (max-width: 1024px) {
  .pcunder_width_92 {
    width: 92% !important; } }

/*-- loading --*/
#loader-bg {
  display: none;
  position: fixed;
  width: 100vw;
  height: 100vh;
  top: 0px;
  left: 0px;
  background: #fff;
  z-index: 10000; }
  #loader-bg #loader {
    display: none;
    position: fixed;
    top: 0%;
    left: 0%;
    width: 100%;
    height: 100%;
    z-index: 10000;
    outline: none !important;
    text-shadow: none; }
    #loader-bg #loader video {
      position: absolute;
      top: 50%;
      left: 50%;
      -o-object-fit: fill;
         object-fit: fill;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%);
      aspect-ratio: 1920/1080;
      width: 100%;
      outline: none !important;
      text-shadow: none;
      background-color: #fff;
      border: none;
      -webkit-filter: drop-shadow(0px 0px rgba(0, 0, 0, 0));
              filter: drop-shadow(0px 0px rgba(0, 0, 0, 0)); }
      @media (max-width: 767px) {
        #loader-bg #loader video {
          aspect-ratio: 478/850; } }
    #loader-bg #loader #lottie {
      background-color: #fff;
      aspect-ratio: 478/850;
      display: block;
      overflow: hidden;
      -webkit-transform: translate3d(0, 0, 0);
              transform: translate3d(0, 0, 0);
      margin: 0 auto;
      opacity: 1;
      position: absolute;
      top: 50%;
      left: 50%;
      -o-object-fit: fill;
         object-fit: fill;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%);
      width: 100%;
      outline: none !important;
      text-shadow: none; }

.index__page {
  display: none; }

.page_index header,
.page_index .page-top,
.page_index footer {
  opacity: 0; }

.page_index header.addOpacity,
.page_index .page-top.addOpacity,
.page_index footer.addOpacity {
  opacity: 1; }

/*--TOP アニメーション --*/
.effect-fade {
  opacity: 0;
  -webkit-transform: translate(0, 45px);
          transform: translate(0, 45px);
  -webkit-transition: all .5s;
  transition: all .5s; }

.effect-fade.effect-scroll {
  opacity: 1 !important;
  -webkit-transform: translate(0, 0);
          transform: translate(0, 0); }

.title_effect_fade {
  opacity: 1 !important;
  transition: opacity 1.5s, transform 1.5s, -webkit-transform 1.5s; }

/*-- header --*/
header {
  height: 80px;
  width: 100%;
  position: fixed;
  z-index: 1000;
  background: #fff; }
  @media screen and (max-width: 1024px) {
    header {
      height: 50px;
      background: #fff; } }
  header .header_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between; }
    header .header_flex .img_logo {
      margin: 14px 0 0 40px; }
      @media screen and (max-width: 1024px) {
        header .header_flex .img_logo {
          margin-left: 16px;
          margin-top: 6px; } }
      header .header_flex .img_logo img {
        width: 98px;
        height: 53px; }
        @media (max-width: 1024px) {
          header .header_flex .img_logo img {
            width: 70px;
            height: 39px; } }
  header .menu_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; }
    header .menu_flex li {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      width: 180px;
      height: 76px;
      text-align: center; }
      header .menu_flex li a {
        color: #333333;
        cursor: pointer; }
        header .menu_flex li a span:first-of-type {
          font-size: 12px;
          line-height: 17px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; }
        header .menu_flex li a span:nth-of-type(2) {
          display: block;
          font-size: 16px;
          line-height: 21px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          color: #E20401; }
      header .menu_flex li:first-of-type span, header .menu_flex li:nth-of-type(2) span {
        position: relative;
        z-index: 1; }
      header .menu_flex li:first-of-type span.rotate:before, header .menu_flex li:nth-of-type(2) span.rotate:before {
        -webkit-transform: rotate(180deg);
                transform: rotate(180deg); }
    header .menu_flex .dropdown {
      position: relative;
      z-index: 1; }
      header .menu_flex .dropdown:before {
        position: absolute;
        background: url(../img/TOP/red_right_arrow.svg) no-repeat;
        -webkit-transform: rotate(-45deg);
                transform: rotate(-45deg);
        background-size: cover;
        width: 8px;
        height: 4px;
        content: "";
        bottom: 10px; }
      header .menu_flex .dropdown a {
        width: 100%;
        height: 100%;
        padding-top: 15px; }
        header .menu_flex .dropdown a:hover {
          opacity: 1;
          background: #EEEEEE; }
      header .menu_flex .dropdown:hover ul {
        display: block; }
      header .menu_flex .dropdown .pd_top_calc {
        padding-top: 350px;
        padding-top: calc((100vh - 80px - 342px) / 2);
        position: relative; }
        header .menu_flex .dropdown .pd_top_calc:before {
          position: absolute;
          content: "COMPANY";
          color: #fff;
          opacity: 0.1;
          font-size: 120px;
          line-height: 160px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          letter-spacing: 0.08em;
          bottom: 280px;
          left: 0;
          z-index: 0; }
      header .menu_flex .dropdown:nth-of-type(2) .dropdown_menu {
        left: -856px;
        left: calc(-0.495 * 100vw + 190.323px);
        left: calc(-0.495 * 100vw + 191.323px); }
        header .menu_flex .dropdown:nth-of-type(2) .dropdown_menu .pd_top_calc {
          padding-top: 380px;
          padding-top: calc((100vh - 80px - 270px) / 2); }
          header .menu_flex .dropdown:nth-of-type(2) .dropdown_menu .pd_top_calc:before {
            position: absolute;
            content: "WORKS";
            bottom: 165px; }
    header .menu_flex .dropdown_menu {
      display: none;
      width: 100vw;
      height: calc(100vh - 80px);
      background: #333333;
      position: absolute;
      margin-top: 80px;
      z-index: 0;
      left: -676px;
      left: calc(-0.494 * 100vw + 368.382px);
      left: calc(-0.494 * 100vw + 372.382px);
      top: -2px;
      z-index: 0; }
      @media (max-width: 1280px) {
        header .menu_flex .dropdown_menu {
          left: calc(-0.478 * 100vw + 352.392px);
          left: calc(-0.478 * 100vw + 356.392px); } }
    header .menu_flex .dropdown_menu li {
      width: 100%;
      height: 118px;
      list-style-type: none;
      margin-left: 0;
      margin: 0 auto;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      justify-content: flex-start;
      border-bottom: 1px solid #fff;
      text-align: left; }
      header .menu_flex .dropdown_menu li a {
        padding-top: 0;
        padding-top: 14px;
        padding-bottom: 14px; }
        header .menu_flex .dropdown_menu li a:hover {
          background: inherit;
          opacity: 0.7; }
        header .menu_flex .dropdown_menu li a span:first-of-type {
          font-size: 48px;
          line-height: 63px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          letter-spacing: 0.08em;
          color: #fff; }
        header .menu_flex .dropdown_menu li a span:nth-of-type(2) {
          font-size: 16px;
          line-height: 32px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.08em;
          color: #fff;
          display: block; }
    header .menu_flex .dropdown_menu.open {
      display: block; }

#menu {
  list-style-type: none;
  width: 180px;
  height: 80px;
  margin: 0 auto;
  padding: 0;
  background: #E20401; }

#menu li {
  position: relative;
  width: 100%;
  margin: 0;
  padding: 0;
  text-align: center; }

#menu li a {
  display: block;
  margin: 0;
  padding: 27px 0;
  color: #fff;
  text-decoration: none; }

#menu li a > span {
  color: #fff;
  font-size: 20px;
  line-height: 26px;
  font-family: roboto, sans-serif;
  font-weight: 900;
  letter-spacing: 0.08em; }

#menu li ul {
  list-style: none;
  position: absolute;
  top: 100%;
  left: 0;
  margin: 0;
  padding: 0; }

#menu li:last-child ul {
  left: 0%;
  width: 100%; }

#menu li ul li {
  overflow: hidden;
  width: 100%;
  height: 0;
  color: #fff;
  -webkit-transition: .2s;
  transition: .2s; }

#menu li ul li a {
  background: #E20401;
  text-align: center;
  font-weight: normal;
  padding: 11px 0; }

#menu li:hover > a {
  background: #E20401;
  color: white;
  opacity: 0.7; }

#menu li:hover ul li {
  overflow: visible;
  height: 44px;
  border-bottom: 1px solid #fff; }

#menu li:hover ul li span.entry_content {
  font-size: 14px;
  line-height: 19px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  letter-spacing: 0.08em; }

#menu li:hover ul li:first-child {
  border-top: 0;
  border-top: 1px solid #fff; }

#menu li:hover ul li:last-child {
  border-bottom: 0;
  border-top: 1px solid #fff; }

.drawer-hamburger {
  width: 24px; }

.drawer--top .drawer-hamburger, .drawer--top.drawer-open .drawer-hamburger {
  right: 0;
  background-color: #fff; }

.drawer-hamburger {
  padding: 15px 9px 23px !important; }

.drawer-hamburger-icon,
.drawer-hamburger-icon:after,
.drawer-hamburger-icon:before {
  background-color: #333333 !important;
  height: 1px !important;
  width: 20px !important; }

.drawer-open .drawer-hamburger-icon:before {
  -webkit-transform: rotate(30deg) !important;
          transform: rotate(30deg) !important; }

.drawer-open .drawer-hamburger-icon:after {
  -webkit-transform: rotate(-30deg) !important;
          transform: rotate(-30deg) !important; }

.drawer-hamburger-icon {
  margin: 0 auto;
  margin-top: 11px !important; }

.drawer-hamburger:hover {
  cursor: pointer;
  opacity: 0.9; }

.drawer-hamburger-icon:before {
  top: -5px !important; }

.drawer-hamburger-icon:after {
  top: 5px !important; }

.drawer-open header .header_flex .drawer-hamburger-icon {
  background-color: transparent !important; }

.drawer-open .drawer-hamburger-icon {
  margin-top: 0 !important; }

.drawer-open .drawer-hamburger-icon:after,
.drawer-open .drawer-hamburger-icon:before {
  top: 7px !important;
  top: 10px !important; }

.drawer-nav {
  display: none; }

.drawer--top.drawer-open .drawer-nav {
  display: block;
  height: 100vh;
  background: #333333; }
  .drawer--top.drawer-open .drawer-nav .sp_entry_btn {
    position: absolute;
    right: 0px;
    top: 11px; }

.img_logo_nav {
  background: #fff;
  height: 50px;
  padding-top: 6px;
  padding-left: 16px; }
  .img_logo_nav img {
    width: 70px;
    height: 39px; }

.drawer-menu {
  padding-top: 34px !important;
  background: #333333;
  margin-top: 13px; }
  .drawer-menu li {
    width: 100% !important;
    background: inherit !important;
    display: block !important; }
    .drawer-menu li:first-of-type, .drawer-menu li:nth-of-type(2) {
      position: relative;
      height: auto; }
  .drawer-menu .menu_title {
    border-bottom: 1px solid rgba(255, 255, 255, 0.3);
    padding-left: 0;
    padding-top: 34px;
    position: relative;
    cursor: pointer; }
    .drawer-menu .menu_title:before {
      position: absolute;
      content: 'COMPANY';
      font-size: 32px;
      line-height: 43px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.08em;
      color: #fff;
      opacity: 0.1;
      top: 30px;
      top: 14px;
      left: 0; }
    .drawer-menu .menu_title:hover:before {
      opacity: 0.2; }
    .drawer-menu .menu_title:hover {
      opacity: 1; }
    .drawer-menu .menu_title:nth-of-type(2):before {
      content: 'WORKS'; }
    .drawer-menu .menu_title:nth-of-type(3):before {
      content: 'EDUCATION'; }
    .drawer-menu .menu_title:nth-of-type(4):before {
      content: 'CAREER'; }
    .drawer-menu .menu_title a {
      padding: 0;
      cursor: pointer; }
      .drawer-menu .menu_title a:hover {
        opacity: 1; }
  .drawer-menu .drawer-menu-item {
    color: #fff;
    font-size: 16px;
    line-height: 32px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    display: block !important;
    letter-spacing: 0.08em; }
    .drawer-menu .drawer-menu-item:hover {
      text-decoration: none;
      color: #fff;
      opacity: 0.7; }
  .drawer-menu .toggle {
    position: relative; }
    .drawer-menu .toggle:after {
      position: absolute;
      background: url(../img/TOP/plus.svg) no-repeat;
      background-size: cover;
      width: 16px;
      height: 16px;
      content: "";
      right: 0px;
      bottom: 10px; }
  .drawer-menu .open_child:after {
    background: url(../img/TOP/minus.svg) no-repeat;
    width: 16px;
    height: 1px;
    bottom: 18px; }
  .drawer-menu ul.child {
    display: none; }
    .drawer-menu ul.child li {
      margin-left: 10px;
      margin-bottom: 8px;
      height: inherit; }
      .drawer-menu ul.child li:first-of-type {
        margin-top: 24px; }
      .drawer-menu ul.child li:last-of-type {
        margin-bottom: 24px; }
      .drawer-menu ul.child li a {
        font-size: 12px;
        line-height: 18px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        color: #fff;
        text-align: left;
        display: block;
        letter-spacing: 0.08em; }

.sp_entry_btn {
  width: 96px;
  height: 28px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: #E20401;
  margin-right: 50px; }
  .sp_entry_btn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    height: 100%; }
    .sp_entry_btn a span {
      font-size: 12px;
      line-height: 16px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.08em;
      color: #fff; }

.transform {
  background-color: #fff;
  -webkit-box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
          box-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2); }

/*-- 共通 --*/
.inner {
  max-width: 1080px;
  width: 92%;
  margin: 0 auto; }

.inner_960 {
  max-width: 960px;
  width: 100%;
  margin: 0 auto; }

.inner_sp_img {
  max-width: 1000px;
  width: 80%;
  margin: 0 auto; }

.inner_sp_ttl {
  max-width: 1000px;
  width: 100%;
  margin: 0 auto; }

.inner_1280 {
  max-width: 1280px;
  width: 85.3%;
  margin: 0 auto; }

@media (max-width: 767px) {
  .tab_100 {
    width: 100% !important; } }

.mg_top_24 {
  margin-top: 24px !important; }
  @media (max-width: 480px) {
    .mg_top_24 {
      margin-top: 20px !important; } }

.title .ttl_ja {
  font-size: 16px;
  line-height: 28px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  letter-spacing: 0.08em; }
  @media (max-width: 480px) {
    .title .ttl_ja {
      font-size: 14px;
      line-height: 28px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400; } }

.title .ttl_en {
  font-size: 60px;
  line-height: 70px;
  font-family: roboto, sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  font-style: italic; }
  @media (max-width: 1024px) {
    .title .ttl_en {
      font-size: 48px; } }
  @media (max-width: 480px) {
    .title .ttl_en {
      font-size: 40px;
      line-height: 70px;
      font-family: roboto, sans-serif;
      font-weight: 700; } }

.sec_title {
  font-size: 24px;
  line-height: 24px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  padding-bottom: 40px;
  padding-top: 8px; }
  @media (max-width: 767px) {
    .sec_title {
      font-size: 18px;
      line-height: 31.5px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      padding-bottom: 20px; } }

.content, .form_area .form_flex {
  font-size: 14px;
  line-height: 28px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  letter-spacing: 0.04em; }
  @media (max-width: 767px) {
    .content, .form_area .form_flex {
      font-size: 14px;
      line-height: 30px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 300; } }

.catch {
  font-size: 30px;
  line-height: 52px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  letter-spacing: 0.08em; }
  @media (max-width: 1024px) {
    .catch {
      font-size: 28px;
      line-height: 1.6em;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400; } }
  @media (max-width: 767px) {
    .catch {
      font-size: 20px;
      line-height: 32px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400; } }

.btn {
  width: 220px;
  height: 40px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative;
  border: 2px solid #E20401;
  -webkit-transition: ease .2s;
  transition: ease .2s;
  margin: 0 auto;
  border-radius: 100vh; }
  .btn:after {
    position: absolute;
    right: 30px;
    top: 40%;
    content: "";
    background: url(../img/TOP/red_right_arrow.svg) no-repeat;
    width: 4px;
    height: 8px; }
  .btn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    height: 100%;
    border-radius: 100vh; }
    .btn a:hover span {
      color: #fff; }
  .btn span {
    font-size: 18px;
    line-height: 24px;
    font-family: roboto, sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #E20401;
    position: relative;
    z-index: 3; }
    @media (max-width: 767px) {
      .btn span {
        font-size: 14px;
        line-height: 19px;
        font-family: roboto, sans-serif;
        font-weight: 500;
        letter-spacing: 0.08em; } }
  .btn.white_btn:after {
    background: url(../img/TOP/white_right_icon.svg) no-repeat;
    background-size: cover; }
  .btn:hover a span {
    color: #fff;
    z-index: 3; }
  .btn:hover:after {
    position: absolute;
    right: 30px;
    top: 40%;
    content: "";
    background: url(../img/TOP/white_right_icon.svg) no-repeat;
    width: 4px;
    height: 8px; }

.bgleft {
  overflow: hidden; }
  .bgleft:before {
    content: "";
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: -100%;
    background: white;
    -webkit-animation: move-out 0.3s;
            animation: move-out 0.3s;
    will-change: transform; }
  .bgleft:hover:before {
    -webkit-animation: move-in 0.3s forwards;
            animation: move-in 0.3s forwards; }

/*-- TOP --*/
#fv {
  position: relative;
  width: 100vw;
  height: calc(0.5625 * 100vw);
  height: calc(100vh - 80px);
  height: calc(100vh - 236px); }
  @media (max-width: 767px) {
    #fv {
      height: calc(1.77777778 * 100vw);
      height: calc(100vh - 50px); } }
  #fv .fv_title_area {
    position: absolute;
    top: 50%;
    top: 55%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
            transform: translate(-50%, -50%); }
    @media (max-width: 767px) {
      #fv .fv_title_area {
        top: 80%;
        top: 75%;
        left: 40%; } }
    #fv .fv_title_area .en_subtitle {
      text-align: center; }
      @media (max-width: 767px) {
        #fv .fv_title_area .en_subtitle {
          text-align: left; } }
      #fv .fv_title_area .en_subtitle span {
        color: #fff;
        font-size: 24px;
        line-height: 32px;
        font-family: roboto, sans-serif;
        font-weight: 300;
        letter-spacing: 0.075em;
        opacity: 0;
        -webkit-transform: translateY(-100px);
                transform: translateY(-100px); }
        @media (max-width: 480px) {
          #fv .fv_title_area .en_subtitle span {
            font-size: 16px;
            line-height: 21px; } }
        #fv .fv_title_area .en_subtitle span.leftmove {
          opacity: 1;
          -webkit-transform: translateY(0px);
                  transform: translateY(0px);
          -webkit-transition-duration: 600ms;
                  transition-duration: 600ms;
          -webkit-transition-property: opacity,-webkit-transform;
          transition-property: opacity,-webkit-transform;
          transition-property: transform,opacity;
          transition-property: transform,opacity,-webkit-transform;
          -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1); }
        #fv .fv_title_area .en_subtitle span:nth-child(1) {
          -webkit-transition-delay: 1025ms;
                  transition-delay: 1025ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(2) {
          -webkit-transition-delay: 1050ms;
                  transition-delay: 1050ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(3) {
          -webkit-transition-delay: 1075ms;
                  transition-delay: 1075ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(4) {
          -webkit-transition-delay: 1100ms;
                  transition-delay: 1100ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(5) {
          -webkit-transition-delay: 1125ms;
                  transition-delay: 1125ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(6) {
          -webkit-transition-delay: 1150ms;
                  transition-delay: 1150ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(7) {
          -webkit-transition-delay: 1175ms;
                  transition-delay: 1175ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(8) {
          -webkit-transition-delay: 1200ms;
                  transition-delay: 1200ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(9) {
          -webkit-transition-delay: 1225ms;
                  transition-delay: 1225ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(10) {
          -webkit-transition-delay: 1250ms;
                  transition-delay: 1250ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(11) {
          -webkit-transition-delay: 1275ms;
                  transition-delay: 1275ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(12) {
          -webkit-transition-delay: 1300ms;
                  transition-delay: 1300ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(13) {
          -webkit-transition-delay: 1325ms;
                  transition-delay: 1325ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(14) {
          -webkit-transition-delay: 1350ms;
                  transition-delay: 1350ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(15) {
          -webkit-transition-delay: 1375ms;
                  transition-delay: 1375ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(16) {
          -webkit-transition-delay: 1400ms;
                  transition-delay: 1400ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(17) {
          -webkit-transition-delay: 1425ms;
                  transition-delay: 1425ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(18) {
          -webkit-transition-delay: 1450ms;
                  transition-delay: 1450ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(19) {
          -webkit-transition-delay: 1475ms;
                  transition-delay: 1475ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(20) {
          -webkit-transition-delay: 1500ms;
                  transition-delay: 1500ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(21) {
          -webkit-transition-delay: 1525ms;
                  transition-delay: 1525ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(22) {
          -webkit-transition-delay: 1550ms;
                  transition-delay: 1550ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(23) {
          -webkit-transition-delay: 1575ms;
                  transition-delay: 1575ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(24) {
          -webkit-transition-delay: 1600ms;
                  transition-delay: 1600ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(25) {
          -webkit-transition-delay: 1625ms;
                  transition-delay: 1625ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(26) {
          -webkit-transition-delay: 1650ms;
                  transition-delay: 1650ms; }
        #fv .fv_title_area .en_subtitle span:nth-child(27) {
          -webkit-transition-delay: 1675ms;
                  transition-delay: 1675ms; }
        @media (max-width: 1024px) {
          #fv .fv_title_area .en_subtitle span:nth-child(1) {
            -webkit-transition-delay: 1040ms;
                    transition-delay: 1040ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(2) {
            -webkit-transition-delay: 1080ms;
                    transition-delay: 1080ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(3) {
            -webkit-transition-delay: 1120ms;
                    transition-delay: 1120ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(4) {
            -webkit-transition-delay: 1160ms;
                    transition-delay: 1160ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(5) {
            -webkit-transition-delay: 1200ms;
                    transition-delay: 1200ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(6) {
            -webkit-transition-delay: 1240ms;
                    transition-delay: 1240ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(7) {
            -webkit-transition-delay: 1280ms;
                    transition-delay: 1280ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(8) {
            -webkit-transition-delay: 1320ms;
                    transition-delay: 1320ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(9) {
            -webkit-transition-delay: 1360ms;
                    transition-delay: 1360ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(10) {
            -webkit-transition-delay: 1400ms;
                    transition-delay: 1400ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(11) {
            -webkit-transition-delay: 1440ms;
                    transition-delay: 1440ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(12) {
            -webkit-transition-delay: 1480ms;
                    transition-delay: 1480ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(13) {
            -webkit-transition-delay: 1520ms;
                    transition-delay: 1520ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(14) {
            -webkit-transition-delay: 1560ms;
                    transition-delay: 1560ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(15) {
            -webkit-transition-delay: 1600ms;
                    transition-delay: 1600ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(16) {
            -webkit-transition-delay: 1640ms;
                    transition-delay: 1640ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(17) {
            -webkit-transition-delay: 1680ms;
                    transition-delay: 1680ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(18) {
            -webkit-transition-delay: 1720ms;
                    transition-delay: 1720ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(19) {
            -webkit-transition-delay: 1760ms;
                    transition-delay: 1760ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(20) {
            -webkit-transition-delay: 1800ms;
                    transition-delay: 1800ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(21) {
            -webkit-transition-delay: 1840ms;
                    transition-delay: 1840ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(22) {
            -webkit-transition-delay: 1880ms;
                    transition-delay: 1880ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(23) {
            -webkit-transition-delay: 1920ms;
                    transition-delay: 1920ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(24) {
            -webkit-transition-delay: 1960ms;
                    transition-delay: 1960ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(25) {
            -webkit-transition-delay: 2000ms;
                    transition-delay: 2000ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(26) {
            -webkit-transition-delay: 2040ms;
                    transition-delay: 2040ms; }
          #fv .fv_title_area .en_subtitle span:nth-child(27) {
            -webkit-transition-delay: 2080ms;
                    transition-delay: 2080ms; } }
    #fv .fv_title_area h1 {
      margin-top: 18px;
      white-space: nowrap; }
      @media (max-width: 480px) {
        #fv .fv_title_area h1 {
          margin-top: 8px; } }
      #fv .fv_title_area h1 span {
        color: #fff;
        font-size: 56px;
        line-height: 83px;
        font-family: shippori mincho, sans-serif;
        font-family: 'Shippori Mincho', serif;
        font-weight: 700;
        letter-spacing: 0.08em;
        opacity: 0;
        -webkit-transform: translateY(-100px);
                transform: translateY(-100px); }
        @media (max-width: 480px) {
          #fv .fv_title_area h1 span {
            font-size: 40px;
            line-height: 59px; } }
        #fv .fv_title_area h1 span.leftmove {
          opacity: 1;
          -webkit-transform: translateY(0px);
                  transform: translateY(0px);
          -webkit-transition-duration: 600ms;
                  transition-duration: 600ms;
          -webkit-transition-property: opacity,-webkit-transform;
          transition-property: opacity,-webkit-transform;
          transition-property: transform,opacity;
          transition-property: transform,opacity,-webkit-transform;
          -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                  transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1); }
        #fv .fv_title_area h1 span:nth-child(1) {
          -webkit-transition-delay: 1040ms;
                  transition-delay: 1040ms; }
        #fv .fv_title_area h1 span:nth-child(2) {
          -webkit-transition-delay: 1080ms;
                  transition-delay: 1080ms; }
        #fv .fv_title_area h1 span:nth-child(3) {
          -webkit-transition-delay: 1120ms;
                  transition-delay: 1120ms; }
        #fv .fv_title_area h1 span:nth-child(4) {
          -webkit-transition-delay: 1160ms;
                  transition-delay: 1160ms; }
        #fv .fv_title_area h1 span:nth-child(5) {
          -webkit-transition-delay: 1200ms;
                  transition-delay: 1200ms; }
        #fv .fv_title_area h1 span:nth-child(6) {
          -webkit-transition-delay: 1240ms;
                  transition-delay: 1240ms; }
        #fv .fv_title_area h1 span:nth-child(7) {
          -webkit-transition-delay: 1280ms;
                  transition-delay: 1280ms; }
        #fv .fv_title_area h1 span:nth-child(8) {
          -webkit-transition-delay: 1320ms;
                  transition-delay: 1320ms; }
        #fv .fv_title_area h1 span:nth-child(9) {
          -webkit-transition-delay: 1360ms;
                  transition-delay: 1360ms; }
        #fv .fv_title_area h1 span:nth-child(10) {
          -webkit-transition-delay: 1400ms;
                  transition-delay: 1400ms; }
        #fv .fv_title_area h1 span:nth-child(11) {
          -webkit-transition-delay: 1440ms;
                  transition-delay: 1440ms; }
        #fv .fv_title_area h1 span:nth-child(12) {
          -webkit-transition-delay: 1480ms;
                  transition-delay: 1480ms; }
        #fv .fv_title_area h1 span:nth-child(13) {
          -webkit-transition-delay: 1520ms;
                  transition-delay: 1520ms; }
        @media (max-width: 1024px) {
          #fv .fv_title_area h1 span:nth-child(1) {
            -webkit-transition-delay: 1055ms;
                    transition-delay: 1055ms; }
          #fv .fv_title_area h1 span:nth-child(2) {
            -webkit-transition-delay: 1110ms;
                    transition-delay: 1110ms; }
          #fv .fv_title_area h1 span:nth-child(3) {
            -webkit-transition-delay: 1165ms;
                    transition-delay: 1165ms; }
          #fv .fv_title_area h1 span:nth-child(4) {
            -webkit-transition-delay: 1220ms;
                    transition-delay: 1220ms; }
          #fv .fv_title_area h1 span:nth-child(5) {
            -webkit-transition-delay: 1275ms;
                    transition-delay: 1275ms; }
          #fv .fv_title_area h1 span:nth-child(6) {
            -webkit-transition-delay: 1330ms;
                    transition-delay: 1330ms; }
          #fv .fv_title_area h1 span:nth-child(7) {
            -webkit-transition-delay: 1385ms;
                    transition-delay: 1385ms; }
          #fv .fv_title_area h1 span:nth-child(8) {
            -webkit-transition-delay: 1440ms;
                    transition-delay: 1440ms; }
          #fv .fv_title_area h1 span:nth-child(9) {
            -webkit-transition-delay: 1495ms;
                    transition-delay: 1495ms; }
          #fv .fv_title_area h1 span:nth-child(10) {
            -webkit-transition-delay: 1550ms;
                    transition-delay: 1550ms; }
          #fv .fv_title_area h1 span:nth-child(11) {
            -webkit-transition-delay: 1605ms;
                    transition-delay: 1605ms; }
          #fv .fv_title_area h1 span:nth-child(12) {
            -webkit-transition-delay: 1660ms;
                    transition-delay: 1660ms; }
          #fv .fv_title_area h1 span:nth-child(13) {
            -webkit-transition-delay: 1715ms;
                    transition-delay: 1715ms; } }
    #fv .fv_title_area img {
      margin-top: -60px;
      opacity: 0;
      -webkit-transform: translateX(-100px);
              transform: translateX(-100px); }
      @media (max-width: 767px) {
        #fv .fv_title_area img {
          margin-top: -15px; } }
      #fv .fv_title_area img.leftmove {
        opacity: 1;
        -webkit-transform: translateX(0px);
                transform: translateX(0px);
        -webkit-transition-duration: 200ms;
                transition-duration: 200ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transition-delay: 2.5s;
                transition-delay: 2.5s; }
  #fv #video-area {
    position: fixed;
    z-index: -1;
    top: 0;
    top: 80px;
    right: 0;
    left: 0;
    bottom: 0;
    overflow: hidden; }
    @media (max-width: 1024px) {
      #fv #video-area {
        top: 50px; } }
    #fv #video-area #video {
      position: absolute;
      z-index: -1;
      top: 50%;
      left: 50%;
      -webkit-transform: translate(-50%, -50%);
              transform: translate(-50%, -50%);
      width: 177.77777778vh;
      height: 56.25vw;
      min-height: 100%;
      min-width: 100%; }

/*-- movie_popup_area --*/
.movie_popup_area {
  background: #EEEEEE;
  padding: 40px 0; }
  @media (max-width: 480px) {
    .movie_popup_area {
      padding: 16px 0; } }
  .movie_popup_area .movie_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-column-gap: 32px;
            column-gap: 32px; }
    @media (max-width: 480px) {
      .movie_popup_area .movie_flex {
        -webkit-column-gap: 13px;
                column-gap: 13px; } }
  .movie_popup_area .movie_photo {
    width: 200px;
    height: 200px;
    overflow: hidden;
    border-radius: 100vh; }
    @media (max-width: 480px) {
      .movie_popup_area .movie_photo {
        width: 106px;
        height: 106px; } }
  .movie_popup_area .manufacture {
    background: url(../img/TOP/manufacturing_thumb@2x.png) no-repeat;
    background-size: cover;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    content: "";
    position: relative;
    display: block;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out; }
    .movie_popup_area .manufacture:hover {
      -webkit-transform: scale(1.05);
              transform: scale(1.05); }
  .movie_popup_area .enginnering {
    background: url(../img/TOP/engineering_thumb@2x.png) no-repeat;
    background-size: cover;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    content: "";
    position: relative;
    display: block;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out; }
    .movie_popup_area .enginnering:hover {
      -webkit-transform: scale(1.05);
              transform: scale(1.05); }
  .movie_popup_area .quality_management {
    background: url(../img/TOP/quality_management_thumb@2x.png) no-repeat;
    background-size: cover;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    content: "";
    position: relative;
    display: block;
    -webkit-transition: .3s ease-in-out;
    transition: .3s ease-in-out; }
    .movie_popup_area .quality_management:hover {
      -webkit-transform: scale(1.05);
              transform: scale(1.05); }

/*-- modal --*/
.js-modal-open {
  cursor: pointer; }

.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  z-index: 100; }

.modal__bg {
  background: rgba(0, 0, 0, 0.5);
  height: 100vh;
  position: absolute;
  width: 100%; }

.popup-inner {
  width: 56vw;
  padding: 45px 0; }

@media (max-width: 1024px) {
  .popup-inner {
    padding: 60px 0; } }

@media (max-width: 767px) {
  .popup-inner {
    width: 80vw;
    padding: 25px 0; } }

.modal__content {
  background: transparent;
  left: 50%;
  position: absolute;
  top: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 56vw;
  background: #000; }
  @media (max-width: 767px) {
    .modal__content {
      width: 80vw; } }

.modal__content video {
  width: 100%;
  display: block;
  height: auto; }

.close-btn {
  position: absolute;
  right: -3%;
  top: -4%;
  background: url("../img/TOP/modal_close.svg") no-repeat;
  background-size: cover;
  content: "";
  width: 48px;
  height: 48px;
  text-align: center;
  cursor: pointer; }

@media (max-width: 1024px) {
  .close-btn {
    right: -5%;
    top: -7%; } }

@media (max-width: 767px) {
  .close-btn {
    right: -10px;
    top: -10px;
    width: 30px;
    height: 30px; } }

@media (max-width: 767px) and (max-width: 480px) {
  .close-btn {
    right: -15px;
    top: -15px;
    right: -5%;
    top: -6%; } }

/*-- message --*/
.message {
  padding: 24px 0 200px;
  background: #fff; }
  @media (max-width: 1024px) {
    .message {
      padding-bottom: 320px; } }
  @media (max-width: 767px) {
    .message {
      padding-bottom: calc(0.524 * 100vw - 165.273px); } }
  @media (max-width: 480px) {
    .message {
      padding-bottom: 0; } }
  .message h2 {
    font-size: 36px;
    line-height: 52px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #333333;
    position: relative;
    text-align: center;
    padding-top: 100px;
    z-index: 1; }
    @media (max-width: 480px) {
      .message h2 {
        font-size: 24px;
        line-height: 35px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-top: 72px; } }
    .message h2:before {
      position: absolute;
      content: "MESSAGE";
      color: #EEEEEE;
      opacity: 0.5;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -30px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: -1; }
      @media (max-width: 480px) {
        .message h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          bottom: -15px; } }
  .message h3 {
    margin-top: 25px;
    color: #E20401;
    font-size: 32px;
    line-height: 1.5em;
    font-family: shippori mincho, sans-serif;
    font-family: 'Shippori Mincho', serif;
    font-weight: 700;
    letter-spacing: 0.075em; }
    @media (max-width: 767px) {
      .message h3 {
        font-size: 22px;
        line-height: 1.5em;
        font-family: shippori mincho, sans-serif;
        font-family: 'Shippori Mincho', serif;
        font-weight: 700; } }
    @media (max-width: 480px) {
      .message h3 {
        margin-top: 22px;
        font-size: 17px;
        line-height: 1.5em;
        font-family: shippori mincho, sans-serif;
        font-family: 'Shippori Mincho', serif;
        font-weight: 700;
        letter-spacing: 0.02em; } }
    .message h3:last-of-type {
      margin-top: 7px; }
      @media (max-width: 480px) {
        .message h3:last-of-type {
          margin-top: 5px;
          white-space: nowrap; } }
  .message .message_details {
    margin-top: 22px;
    font-size: 14px;
    line-height: 24px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: #111111;
    text-align: center; }
    @media (max-width: 1024px) {
      .message .message_details {
        text-align: left; } }
    @media (max-width: 480px) {
      .message .message_details {
        font-size: 13px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 400; } }
  .message .factory_project {
    margin-top: 56px;
    background: url(../img/TOP/smart_factory_pj_bg@2x.png) no-repeat center center;
    background-size: cover;
    width: 100vw;
    height: 778px;
    padding-top: 80px;
    position: relative; }
    @media (max-width: 767px) {
      .message .factory_project {
        background: url(../img/TOP/smart_factory_pj_bg_sp@2x.png) no-repeat center center;
        height: calc(1.30917874 * 100vw);
        padding-top: 104px;
        padding-top: 0;
        height: 1140px; } }
    @media (max-width: 480px) {
      .message .factory_project {
        height: 1200px;
        height: 1085px; } }
    .message .factory_project .smart_more_btn a {
      z-index: 1; }
      .message .factory_project .smart_more_btn a:hover {
        opacity: 1; }
    .message .factory_project .factory_project_subtitle {
      margin: 0 auto;
      max-width: 810px;
      padding: 4px 0;
      text-align: center;
      position: relative; }
      .message .factory_project .factory_project_subtitle.is-animated:before {
        -webkit-animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
                animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
        background: #333333;
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        -webkit-transform-origin: left center;
                transform-origin: left center; }
      .message .factory_project .factory_project_subtitle span {
        color: #fff;
        font-size: 20px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        letter-spacing: 0.04em;
        opacity: 0;
        -webkit-transform: translate(-45px, 0px);
                transform: translate(-45px, 0px);
        position: relative;
        z-index: 1; }
      .message .factory_project .factory_project_subtitle.is-animated span {
        opacity: 1;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 600ms;
                transition-duration: 600ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(1) {
          -webkit-transition-delay: 1025ms;
                  transition-delay: 1025ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(2) {
          -webkit-transition-delay: 1050ms;
                  transition-delay: 1050ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(3) {
          -webkit-transition-delay: 1075ms;
                  transition-delay: 1075ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(4) {
          -webkit-transition-delay: 1100ms;
                  transition-delay: 1100ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(5) {
          -webkit-transition-delay: 1125ms;
                  transition-delay: 1125ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(6) {
          -webkit-transition-delay: 1150ms;
                  transition-delay: 1150ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(7) {
          -webkit-transition-delay: 1175ms;
                  transition-delay: 1175ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(8) {
          -webkit-transition-delay: 1200ms;
                  transition-delay: 1200ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(9) {
          -webkit-transition-delay: 1225ms;
                  transition-delay: 1225ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(10) {
          -webkit-transition-delay: 1250ms;
                  transition-delay: 1250ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(11) {
          -webkit-transition-delay: 1275ms;
                  transition-delay: 1275ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(12) {
          -webkit-transition-delay: 1300ms;
                  transition-delay: 1300ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(13) {
          -webkit-transition-delay: 1325ms;
                  transition-delay: 1325ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(14) {
          -webkit-transition-delay: 1350ms;
                  transition-delay: 1350ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(15) {
          -webkit-transition-delay: 1375ms;
                  transition-delay: 1375ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(16) {
          -webkit-transition-delay: 1400ms;
                  transition-delay: 1400ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(17) {
          -webkit-transition-delay: 1425ms;
                  transition-delay: 1425ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(18) {
          -webkit-transition-delay: 1450ms;
                  transition-delay: 1450ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(19) {
          -webkit-transition-delay: 1475ms;
                  transition-delay: 1475ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(20) {
          -webkit-transition-delay: 1500ms;
                  transition-delay: 1500ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(21) {
          -webkit-transition-delay: 1525ms;
                  transition-delay: 1525ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(22) {
          -webkit-transition-delay: 1550ms;
                  transition-delay: 1550ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(23) {
          -webkit-transition-delay: 1575ms;
                  transition-delay: 1575ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(24) {
          -webkit-transition-delay: 1600ms;
                  transition-delay: 1600ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(25) {
          -webkit-transition-delay: 1625ms;
                  transition-delay: 1625ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(26) {
          -webkit-transition-delay: 1650ms;
                  transition-delay: 1650ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(27) {
          -webkit-transition-delay: 1675ms;
                  transition-delay: 1675ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(28) {
          -webkit-transition-delay: 1700ms;
                  transition-delay: 1700ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(29) {
          -webkit-transition-delay: 1725ms;
                  transition-delay: 1725ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(30) {
          -webkit-transition-delay: 1750ms;
                  transition-delay: 1750ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(31) {
          -webkit-transition-delay: 1775ms;
                  transition-delay: 1775ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(32) {
          -webkit-transition-delay: 1800ms;
                  transition-delay: 1800ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(33) {
          -webkit-transition-delay: 1825ms;
                  transition-delay: 1825ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(34) {
          -webkit-transition-delay: 1850ms;
                  transition-delay: 1850ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(35) {
          -webkit-transition-delay: 1875ms;
                  transition-delay: 1875ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(36) {
          -webkit-transition-delay: 1900ms;
                  transition-delay: 1900ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(37) {
          -webkit-transition-delay: 1925ms;
                  transition-delay: 1925ms; }
        .message .factory_project .factory_project_subtitle.is-animated span:nth-child(38) {
          -webkit-transition-delay: 1950ms;
                  transition-delay: 1950ms; }
      @media (max-width: 767px) {
        .message .factory_project .factory_project_subtitle {
          max-width: inherit;
          width: 100%;
          padding: 0; }
          .message .factory_project .factory_project_subtitle span {
            font-size: 17px;
            line-height: 39px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700; }
          .message .factory_project .factory_project_subtitle.first {
            width: 92%;
            margin-bottom: 4px; } }
    .message .factory_project .factory_project_title {
      margin: 0 auto;
      margin-top: 16px;
      max-width: 960px;
      text-align: center;
      position: relative; }
      .message .factory_project .factory_project_title.is-animated:before {
        -webkit-animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
                animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
        background: #333333;
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        -webkit-transform-origin: left center;
                transform-origin: left center; }
      .message .factory_project .factory_project_title span {
        color: #fff;
        font-size: 48px;
        line-height: 63px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        letter-spacing: 0.075em;
        position: relative;
        z-index: 1;
        opacity: 0;
        -webkit-transform: translate(-45px, 0px);
                transform: translate(-45px, 0px); }
        @media (max-width: 1024px) {
          .message .factory_project .factory_project_title span {
            line-height: 1.15;
            margin-bottom: 0;
            margin-top: 16px;
            display: inline-block; } }
        @media (max-width: 767px) {
          .message .factory_project .factory_project_title span {
            margin-top: 0px;
            display: inline; } }
      .message .factory_project .factory_project_title.is-animated span {
        opacity: 1;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 600ms;
                transition-duration: 600ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
        .message .factory_project .factory_project_title.is-animated span:nth-child(1) {
          -webkit-transition-delay: 1025ms;
                  transition-delay: 1025ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(2) {
          -webkit-transition-delay: 1050ms;
                  transition-delay: 1050ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(3) {
          -webkit-transition-delay: 1075ms;
                  transition-delay: 1075ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(4) {
          -webkit-transition-delay: 1100ms;
                  transition-delay: 1100ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(5) {
          -webkit-transition-delay: 1125ms;
                  transition-delay: 1125ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(6) {
          -webkit-transition-delay: 1150ms;
                  transition-delay: 1150ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(7) {
          -webkit-transition-delay: 1175ms;
                  transition-delay: 1175ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(8) {
          -webkit-transition-delay: 1200ms;
                  transition-delay: 1200ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(9) {
          -webkit-transition-delay: 1225ms;
                  transition-delay: 1225ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(10) {
          -webkit-transition-delay: 1250ms;
                  transition-delay: 1250ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(11) {
          -webkit-transition-delay: 1275ms;
                  transition-delay: 1275ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(12) {
          -webkit-transition-delay: 1300ms;
                  transition-delay: 1300ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(13) {
          -webkit-transition-delay: 1325ms;
                  transition-delay: 1325ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(14) {
          -webkit-transition-delay: 1350ms;
                  transition-delay: 1350ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(15) {
          -webkit-transition-delay: 1375ms;
                  transition-delay: 1375ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(16) {
          -webkit-transition-delay: 1400ms;
                  transition-delay: 1400ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(17) {
          -webkit-transition-delay: 1425ms;
                  transition-delay: 1425ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(18) {
          -webkit-transition-delay: 1450ms;
                  transition-delay: 1450ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(19) {
          -webkit-transition-delay: 1475ms;
                  transition-delay: 1475ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(20) {
          -webkit-transition-delay: 1500ms;
                  transition-delay: 1500ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(21) {
          -webkit-transition-delay: 1525ms;
                  transition-delay: 1525ms; }
        .message .factory_project .factory_project_title.is-animated span:nth-child(22) {
          -webkit-transition-delay: 1550ms;
                  transition-delay: 1550ms; }
        @media (max-width: 1024px) {
          .message .factory_project .factory_project_title.is-animated span:nth-child(15) {
            -webkit-transition-delay: 1375ms;
                    transition-delay: 1375ms;
            margin-bottom: 16px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(16) {
            -webkit-transition-delay: 1400ms;
                    transition-delay: 1400ms;
            margin-bottom: 16px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(17) {
            -webkit-transition-delay: 1425ms;
                    transition-delay: 1425ms;
            margin-bottom: 16px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(18) {
            -webkit-transition-delay: 1450ms;
                    transition-delay: 1450ms;
            margin-bottom: 16px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(19) {
            -webkit-transition-delay: 1475ms;
                    transition-delay: 1475ms;
            margin-bottom: 16px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(20) {
            -webkit-transition-delay: 1500ms;
                    transition-delay: 1500ms;
            margin-bottom: 16px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(21) {
            -webkit-transition-delay: 1525ms;
                    transition-delay: 1525ms;
            margin-bottom: 16px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(22) {
            -webkit-transition-delay: 1550ms;
                    transition-delay: 1550ms;
            margin-bottom: 16px;
            margin-top: 0; } }
        @media (max-width: 767px) {
          .message .factory_project .factory_project_title.is-animated span:nth-child(15) {
            margin-bottom: 0px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(16) {
            margin-bottom: 0px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(17) {
            margin-bottom: 0px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(18) {
            margin-bottom: 0px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(19) {
            margin-bottom: 0px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(20) {
            margin-bottom: 0px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(21) {
            margin-bottom: 0px;
            margin-top: 0; }
          .message .factory_project .factory_project_title.is-animated span:nth-child(22) {
            margin-bottom: 0px;
            margin-top: 0; } }
      @media (max-width: 767px) {
        .message .factory_project .factory_project_title {
          width: 100%;
          padding: 12px; }
          .message .factory_project .factory_project_title span {
            font-size: 28px;
            line-height: 32px;
            font-family: roboto, sans-serif;
            font-weight: 900; } }
    .message .factory_project .bg_white {
      background: #fff;
      z-index: 1;
      max-width: 1080px;
      width: 100%;
      width: 92%;
      margin: 0 auto;
      margin-top: 32px; }
      @media (max-width: 767px) {
        .message .factory_project .bg_white {
          width: 92%; } }
      @media (max-width: 480px) {
        .message .factory_project .bg_white {
          margin-top: 24px; } }
      .message .factory_project .bg_white h2 {
        position: relative;
        padding-top: 75px;
        z-index: 2; }
        @media (max-width: 480px) {
          .message .factory_project .bg_white h2 {
            padding-top: 46px;
            white-space: nowrap; } }
        .message .factory_project .bg_white h2 span {
          font-size: 16px;
          line-height: 24px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em;
          display: block; }
          @media (max-width: 480px) {
            .message .factory_project .bg_white h2 span {
              font-size: 14px;
              line-height: 19px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 900; } }
        .message .factory_project .bg_white h2:before {
          position: absolute;
          content: "BUSSINESS";
          color: #EEEEEE;
          opacity: 0.5;
          font-size: 120px;
          line-height: 160px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          letter-spacing: 0.04em;
          bottom: -30px;
          left: 50%;
          -webkit-transform: translateX(-50%);
                  transform: translateX(-50%);
          z-index: -1; }
          @media (max-width: 767px) {
            .message .factory_project .bg_white h2:before {
              font-size: 64px;
              line-height: 84px;
              font-family: roboto, sans-serif;
              font-weight: 900;
              bottom: -15px; } }
        .message .factory_project .bg_white h2.num_glico {
          color: #fff;
          font-size: 24px;
          line-height: 35px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em;
          padding-top: 0px;
          margin-left: 24px;
          margin-right: 12px; }
          .message .factory_project .bg_white h2.num_glico:before {
            content: "DATA";
            opacity: 0.2;
            bottom: -65px; }
          @media (max-width: 1024px) {
            .message .factory_project .bg_white h2.num_glico {
              white-space: nowrap; } }
          @media (max-width: 767px) {
            .message .factory_project .bg_white h2.num_glico {
              text-align: left;
              margin-left: 13px;
              font-size: 22px; } }
          @media (max-width: 480px) {
            .message .factory_project .bg_white h2.num_glico {
              font-size: 17px;
              line-height: 25px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700;
              margin-left: 13px;
              margin-right: 13px;
              padding-top: 10px; }
              .message .factory_project .bg_white h2.num_glico:before {
                left: 78px;
                bottom: -8px;
                bottom: 0px; } }
      .message .factory_project .bg_white .num_com_title_flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        padding-top: 32px; }
        @media (max-width: 767px) {
          .message .factory_project .bg_white .num_com_title_flex {
            -webkit-box-pack: start;
                -ms-flex-pack: start;
                    justify-content: flex-start; }
            .message .factory_project .bg_white .num_com_title_flex .icon_flex {
              display: -webkit-box;
              display: -ms-flexbox;
              display: flex;
              -webkit-box-pack: start;
                  -ms-flex-pack: start;
                      justify-content: flex-start;
              -webkit-box-align: center;
                  -ms-flex-align: center;
                      align-items: center;
              -webkit-box-pack: end;
                  -ms-flex-pack: end;
                      justify-content: flex-end;
              position: absolute;
              top: 14px;
              right: 0; }
            .message .factory_project .bg_white .num_com_title_flex .worker_icon {
              margin-left: 14px;
              margin-right: 17px; } }
      .message .factory_project .bg_white .bussiness_details {
        font-size: 13px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 500;
        letter-spacing: 0.04em;
        color: #333333;
        text-align: center !important;
        margin-bottom: 12px; }
        @media (max-width: 480px) {
          .message .factory_project .bg_white .bussiness_details {
            font-size: 12px;
            padding: 0;
            margin-bottom: 25px; } }
      .message .factory_project .bg_white .num_com {
        background: url(../img/TOP/number_company_btn.svg) no-repeat;
        background: url(../img/TOP/number_factory_btn.jpg) no-repeat;
        background-size: cover;
        width: 100%;
        height: 280px;
        content: ""; }
        @media (max-width: 767px) {
          .message .factory_project .bg_white .num_com {
            background: url(../img/TOP/number_company_btn_sp.svg) no-repeat;
            background: url(../img/TOP/number_factory_btn_sp@2x.jpg) no-repeat;
            height: 70.144928%;
            height: calc(92vw * 0.7);
            background-position: center bottom;
            height: calc(-0.07 * 100vw + 293.636px);
            background-size: cover;
            -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
                    box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); } }
        @media (max-width: 480px) {
          .message .factory_project .bg_white .num_com {
            background-position: inherit;
            height: calc(-0.25 * 100vw + 340px); } }
        .message .factory_project .bg_white .num_com .bgleft {
          border: 2px solid white; }
          .message .factory_project .bg_white .num_com .bgleft span {
            color: #fff; }
          .message .factory_project .bg_white .num_com .bgleft:before {
            background: #fff;
            content: "";
            width: 100%;
            height: 100%;
            position: absolute;
            top: 0;
            left: -100%;
            background: #fff;
            -webkit-animation: move-out 0.3s;
                    animation: move-out 0.3s;
            will-change: transform; }
          .message .factory_project .bg_white .num_com .bgleft:after {
            background: url(../img/TOP/white_right_icon.svg) no-repeat; }
      .message .factory_project .bg_white .office_icon {
        width: 150px;
        height: 115px; }
        @media (max-width: 1024px) {
          .message .factory_project .bg_white .office_icon {
            width: 100px;
            height: 77px; } }
        @media (max-width: 767px) {
          .message .factory_project .bg_white .office_icon {
            width: 55px;
            height: 40px; } }
      .message .factory_project .bg_white .worker_icon {
        width: 140px;
        height: 95px; }
        @media (max-width: 1024px) {
          .message .factory_project .bg_white .worker_icon {
            width: 100px;
            height: 69px; } }
        @media (max-width: 767px) {
          .message .factory_project .bg_white .worker_icon {
            width: 65px;
            height: 44px; } }
      .message .factory_project .bg_white p {
        font-size: 14px;
        line-height: 20px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 400;
        letter-spacing: 0.04em;
        color: #fff;
        text-align: center; }
        @media (max-width: 1024px) {
          .message .factory_project .bg_white p {
            margin-top: 24px; } }
        @media (max-width: 767px) {
          .message .factory_project .bg_white p {
            text-align: left;
            padding: 0 13px;
            margin-top: 16px; } }
        @media (max-width: 480px) {
          .message .factory_project .bg_white p {
            font-size: 12px;
            line-height: 20px; } }
      .message .factory_project .bg_white .factory_project_btn_flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-column-gap: 30px;
                column-gap: 30px;
        margin-top: 32px;
        margin-bottom: 48px; }
        @media (max-width: 1024px) {
          .message .factory_project .bg_white .factory_project_btn_flex {
            padding-bottom: 48px; } }
        @media (max-width: 767px) {
          .message .factory_project .bg_white .factory_project_btn_flex {
            display: block;
            padding-bottom: inherit; } }
        @media (max-width: 480px) {
          .message .factory_project .bg_white .factory_project_btn_flex {
            margin-top: 28px;
            margin-bottom: 40px; } }
        .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn {
          width: 33.3333%;
          height: 157px;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-pack: start;
              -ms-flex-pack: start;
                  justify-content: flex-start;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          border: 4px solid #E20401;
          background: #fff; }
          @media (max-width: 767px) {
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn {
              position: relative;
              width: 66.135vw;
              height: calc(66.135vw * 0.3);
              margin: 0 auto;
              margin-top: 16px;
              -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
                      box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }
              .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn:first-of-type {
                margin-top: 28px; } }
          @media (max-width: 480px) {
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn {
              height: 100px; } }
          .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn:hover {
            border: 4px solid rgba(226, 4, 1, 0.2); }
          .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a {
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-pack: start;
                -ms-flex-pack: start;
                    justify-content: flex-start;
            -webkit-box-align: center;
                -ms-flex-align: center;
                    align-items: center;
            -webkit-box-pack: center;
                -ms-flex-pack: center;
                    justify-content: center;
            -webkit-box-orient: vertical;
            -webkit-box-direction: normal;
                -ms-flex-direction: column;
                    flex-direction: column;
            width: 100%;
            height: 100%; }
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a .bgleft:before {
              content: "";
              width: 100%;
              height: 100%;
              position: absolute;
              top: 0;
              left: -100%;
              background: #E20401;
              -webkit-animation: move-out 0.3s;
                      animation: move-out 0.3s;
              will-change: transform; }
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a:hover .bgleft:before {
              -webkit-animation: move-in 0.3s forwards;
                      animation: move-in 0.3s forwards; }
              @media (max-width: 767px) {
                .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a:hover .bgleft:before {
                  display: none; } }
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a:hover .bgleft:after {
              background: url(../img/TOP/white_right_icon.svg) no-repeat; }
              @media (max-width: 767px) {
                .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a:hover .bgleft:after {
                  background: url(../img/TOP/red_right_arrow.svg) no-repeat; } }
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a:hover .bgleft span {
              color: #fff; }
              @media (max-width: 767px) {
                .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn a:hover .bgleft span {
                  color: #E20401; } }
          .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .pj_ja {
            font-size: 16px;
            line-height: 24px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            letter-spacing: 0.04em;
            color: #333333; }
            @media (max-width: 1024px) {
              .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .pj_ja {
                white-space: nowrap; } }
            @media (max-width: 480px) {
              .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .pj_ja {
                font-size: 12px;
                line-height: 17px;
                font-family: noto-sans-cjk-jp, sans-serif;
                font-family: 'Noto Sans JP', sans-serif;
                font-weight: 700;
                letter-spacing: 0em; } }
          .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .pj_en {
            font-size: 32px;
            line-height: 43px;
            font-family: roboto, sans-serif;
            font-weight: 900;
            letter-spacing: 0.04em;
            color: #E20401; }
            @media (max-width: 480px) {
              .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .pj_en {
                font-size: 20px;
                line-height: 26px;
                font-family: roboto, sans-serif;
                font-weight: 900; } }
          .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small {
            width: 120px;
            height: 32px;
            margin-top: 10px; }
            @media (max-width: 767px) {
              .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small {
                border: none;
                -webkit-box-pack: end;
                    -ms-flex-pack: end;
                        justify-content: flex-end;
                width: 41px;
                height: 15px;
                border-radius: 0;
                position: absolute;
                bottom: 8px;
                right: 9px;
                overflow: inherit; }
                .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small:before {
                  display: none; } }
            @media (max-width: 480px) {
              .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small {
                position: absolute;
                bottom: 8px;
                right: 9px; } }
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small:after {
              right: 16px;
              top: 34%; }
              @media (max-width: 767px) {
                .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small:after {
                  right: 0px;
                  top: 20%; } }
            .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small span {
              font-size: 14px;
              line-height: 19px;
              font-family: roboto, sans-serif;
              font-weight: 700;
              margin-left: -8px; }
              @media (max-width: 767px) {
                .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small span {
                  border-bottom: 1px solid #E20401;
                  margin-left: 0;
                  margin-right: 9px; } }
              @media (max-width: 480px) {
                .message .factory_project .bg_white .factory_project_btn_flex .factory_project_btn .btn_small span {
                  font-size: 11px;
                  line-height: 15px;
                  font-family: roboto, sans-serif;
                  font-weight: 700; } }
      .message .factory_project .bg_white a:hover {
        opacity: 1; }
        .message .factory_project .bg_white a:hover .num_com {
          background: url(../img/TOP/number_company_btn_hover.svg) no-repeat;
          background: url(../img/TOP/number_factory_btn_hover.jpg) no-repeat;
          background-size: cover; }
          @media (max-width: 767px) {
            .message .factory_project .bg_white a:hover .num_com {
              background: url(../img/TOP/number_factory_btn_sp_hover@2x.jpg) no-repeat; } }
          .message .factory_project .bg_white a:hover .num_com .worker_icon {
            -webkit-transform: rotate(10deg);
                    transform: rotate(10deg); }
          .message .factory_project .bg_white a:hover .num_com .bgleft {
            background: #fff;
            border-radius: 100vh; }
            .message .factory_project .bg_white a:hover .num_com .bgleft span {
              color: #E20401; }
            .message .factory_project .bg_white a:hover .num_com .bgleft:before {
              -webkit-animation: move-in 0.3s forwards;
                      animation: move-in 0.3s forwards; }
            .message .factory_project .bg_white a:hover .num_com .bgleft:after {
              background: url(../img/TOP/red_right_arrow.svg) no-repeat; }
    .message .factory_project .bgleft:before {
      z-index: 0;
      background: #E20401; }

/* -- works --*/
.works {
  background: url(../img/TOP/top_works_bg@2x.jpg) no-repeat center center;
  background-size: cover;
  width: 100vw;
  height: 493px;
  content: ""; }
  @media (max-width: 767px) {
    .works {
      background: url(../img/TOP/top_works_bg_sp@2x.jpg) no-repeat center center;
      background-size: cover;
      height: calc(1.487923 * 100vw);
      height: 684px; } }
  @media (max-width: 480px) {
    .works {
      height: calc(1.7 * 100vw);
      height: 612px; } }
  .works h2 {
    font-size: 36px;
    line-height: 52px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #fff;
    position: relative;
    text-align: center;
    padding-top: 133px;
    z-index: 1; }
    @media (max-width: 480px) {
      .works h2 {
        font-size: 24px;
        line-height: 35px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-top: 80px; } }
    .works h2:before {
      position: absolute;
      content: "WORKS";
      color: #EEEEEE;
      opacity: 0.2;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -40px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: -1; }
      @media (max-width: 480px) {
        .works h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          bottom: -20px; } }
  .works .works_btn_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 30px;
            column-gap: 30px;
    margin-top: 16px;
    margin-bottom: 80px; }
    @media (max-width: 767px) {
      .works .works_btn_flex {
        display: block;
        width: 92%;
        margin: 0 auto;
        margin-top: 16px; } }
    .works .works_btn_flex .works_btn {
      width: 33.3333%;
      height: 212px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      background: #fff; }
      @media (max-width: 767px) {
        .works .works_btn_flex .works_btn {
          width: 100%;
          height: 140px;
          position: relative;
          margin-top: 16px; } }
      .works .works_btn_flex .works_btn a {
        padding-top: 50px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-align: start;
            -ms-flex-align: start;
                align-items: flex-start;
        justify-self: center;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        width: 100%;
        height: 100%; }
        @media (max-width: 767px) {
          .works .works_btn_flex .works_btn a {
            padding-top: 40px;
            padding-top: 35px; } }
        .works .works_btn_flex .works_btn a:hover {
          background: #EEEEEE;
          opacity: 1; }
          .works .works_btn_flex .works_btn a:hover .bgleft:before {
            -webkit-animation: move-in 0.3s forwards;
                    animation: move-in 0.3s forwards;
            border-radius: 100vh; }
            @media (max-width: 767px) {
              .works .works_btn_flex .works_btn a:hover .bgleft:before {
                display: none; } }
          .works .works_btn_flex .works_btn a:hover .bgleft:after {
            background: url(../img/TOP/white_right_icon.svg) no-repeat; }
            @media (max-width: 767px) {
              .works .works_btn_flex .works_btn a:hover .bgleft:after {
                background: url(../img/TOP/red_right_arrow.svg) no-repeat; } }
          .works .works_btn_flex .works_btn a:hover .bgleft span {
            color: #fff; }
            @media (max-width: 767px) {
              .works .works_btn_flex .works_btn a:hover .bgleft span {
                color: #E20401; } }
      .works .works_btn_flex .works_btn .pj_ja {
        font-size: 14px;
        line-height: 20px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        letter-spacing: 0.04em;
        color: #fff;
        background: #E20401;
        padding: 2px 16px;
        margin: 0 auto; }
        @media (max-width: 1024px) {
          .works .works_btn_flex .works_btn .pj_ja {
            white-space: nowrap; } }
        @media (max-width: 480px) {
          .works .works_btn_flex .works_btn .pj_ja {
            font-size: 13px;
            line-height: 19px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700; } }
      .works .works_btn_flex .works_btn .pj_title {
        font-size: 20px;
        line-height: 29px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 900;
        letter-spacing: 0.04em;
        color: #333333;
        text-align: center;
        margin: 0 auto;
        margin-top: 8px; }
        @media (max-width: 480px) {
          .works .works_btn_flex .works_btn .pj_title {
            font-size: 17px;
            line-height: 25px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700; } }
        @media (max-width: 1024px) {
          .works .works_btn_flex .works_btn .pj_title.eng {
            font-size: 18px; } }
      .works .works_btn_flex .works_btn .btn_small {
        width: 120px;
        height: 32px;
        margin-top: 8px;
        overflow: hidden; }
        @media (max-width: 767px) {
          .works .works_btn_flex .works_btn .btn_small {
            border: none;
            -webkit-box-pack: end;
                -ms-flex-pack: end;
                    justify-content: flex-end;
            width: 41px;
            height: 15px;
            border-radius: 0;
            position: absolute;
            bottom: 8px;
            right: 9px;
            overflow: inherit; }
            .works .works_btn_flex .works_btn .btn_small:before {
              display: none; } }
        @media (max-width: 480px) {
          .works .works_btn_flex .works_btn .btn_small {
            position: absolute;
            bottom: 8px;
            right: 9px; } }
        .works .works_btn_flex .works_btn .btn_small.first {
          margin-top: 37px; }
        .works .works_btn_flex .works_btn .btn_small:after {
          right: 16px;
          top: 33%;
          top: 34%; }
          @media (max-width: 767px) {
            .works .works_btn_flex .works_btn .btn_small:after {
              right: 0px;
              top: 20%; } }
        .works .works_btn_flex .works_btn .btn_small span {
          font-size: 14px;
          line-height: 19px;
          font-family: roboto, sans-serif;
          font-weight: 700;
          margin-left: -8px; }
          @media (max-width: 767px) {
            .works .works_btn_flex .works_btn .btn_small span {
              border-bottom: 1px solid #E20401;
              margin-left: 0;
              margin-right: 9px; } }
          @media (max-width: 480px) {
            .works .works_btn_flex .works_btn .btn_small span {
              font-size: 11px;
              line-height: 15px;
              font-family: roboto, sans-serif;
              font-weight: 700; } }
      .works .works_btn_flex .works_btn .bgleft:before {
        content: "";
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: -100%;
        background: #E20401;
        -webkit-animation: move-out 0.3s;
                animation: move-out 0.3s;
        will-change: transform; }

/*-- seven_workers --*/
.seven_workers {
  background: #fff;
  padding-bottom: 90px; }
  @media (max-width: 480px) {
    .seven_workers {
      padding-bottom: 45px; } }
  .seven_workers h2 {
    font-size: 36px;
    line-height: 52px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #333333;
    position: relative;
    text-align: center;
    padding-top: 110px;
    z-index: 1; }
    @media (max-width: 480px) {
      .seven_workers h2 {
        font-size: 24px;
        line-height: 35px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-top: 64px; } }
    .seven_workers h2:before {
      position: absolute;
      content: "OUR SEVEN PRINCIPLES";
      color: #EEEEEE;
      opacity: 0.5;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -40px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: -1;
      width: 100%;
      white-space: nowrap; }
      @media (max-width: 480px) {
        .seven_workers h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          padding-top: 64px;
          bottom: -20px;
          left: 0; } }
  .seven_workers .swiper {
    margin-top: 42px;
    height: 280px; }
    @media (max-width: 480px) {
      .seven_workers .swiper {
        margin-top: 24px;
        height: 186px !important; } }
  .seven_workers .swiper-button-prev,
  .seven_workers .slick-prev {
    background: url(../img/TOP/slider_right_arrow.svg) no-repeat;
    background-size: cover;
    width: 77px;
    height: 77px;
    content: ""; }
    .seven_workers .swiper-button-prev:before,
    .seven_workers .slick-prev:before {
      content: ""; }
    .seven_workers .swiper-button-prev:after,
    .seven_workers .slick-prev:after {
      content: ""; }
    @media (max-width: 480px) {
      .seven_workers .swiper-button-prev,
      .seven_workers .slick-prev {
        width: 54px;
        height: 54px; } }
  .seven_workers .slick-prev {
    left: 10px;
    z-index: 1; }
    @media (max-width: 480px) {
      .seven_workers .slick-prev {
        left: 0; } }
  .seven_workers .swiper-button-next,
  .seven_workers .slick-next {
    background: url(../img/TOP/slider_left_arrow.svg) no-repeat;
    background-size: cover;
    width: 77px;
    height: 77px;
    content: ""; }
    .seven_workers .swiper-button-next:before,
    .seven_workers .slick-next:before {
      content: ""; }
    .seven_workers .swiper-button-next:after,
    .seven_workers .slick-next:after {
      content: ""; }
    @media (max-width: 480px) {
      .seven_workers .swiper-button-next,
      .seven_workers .slick-next {
        width: 54px;
        height: 54px; } }
  .seven_workers .slick-next {
    right: 10px;
    z-index: 1; }
    @media (max-width: 480px) {
      .seven_workers .slick-next {
        right: 0; } }
  .seven_workers .swiper-wrapper,
  .seven_workers .slick-list {
    height: 280px; }
    @media (max-width: 480px) {
      .seven_workers .swiper-wrapper,
      .seven_workers .slick-list {
        height: 186px; } }
  .seven_workers .swiper-slide {
    width: 100%;
    height: 0;
    overflow: hidden;
    width: 460px !important;
    height: 280px !important;
    position: relative;
    margin: 0 20px; }
    @media (max-width: 480px) {
      .seven_workers .swiper-slide {
        padding-bottom: 0;
        width: 307px !important;
        height: 186px !important;
        margin: 0 4px; } }
    .seven_workers .swiper-slide img {
      -webkit-transition: 0.3s ease-in-out;
      transition: 0.3s ease-in-out;
      width: 460px !important;
      height: 280px !important; }
      @media (max-width: 480px) {
        .seven_workers .swiper-slide img {
          width: 307px !important;
          height: 186px !important; } }
    .seven_workers .swiper-slide:hover img {
      -webkit-transform: scale(1.05);
              transform: scale(1.05); }
    .seven_workers .swiper-slide a:hover {
      opacity: 1; }
    .seven_workers .swiper-slide .workers_details {
      position: absolute;
      color: #fff;
      top: 80px;
      left: 24px;
      width: calc(100% - 48px); }
      @media (max-width: 480px) {
        .seven_workers .swiper-slide .workers_details {
          top: 100px;
          left: 16px;
          width: calc(100% - 32px); } }
      .seven_workers .swiper-slide .workers_details .workers_details_flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center; }
        .seven_workers .swiper-slide .workers_details .workers_details_flex .num {
          margin-right: 8px; }
          .seven_workers .swiper-slide .workers_details .workers_details_flex .num span {
            font-size: 80px;
            line-height: 106px;
            font-family: roboto, sans-serif;
            font-weight: 900;
            letter-spacing: 0.02em; }
            @media (max-width: 480px) {
              .seven_workers .swiper-slide .workers_details .workers_details_flex .num span {
                font-size: 42px;
                line-height: 55px;
                font-family: roboto, sans-serif;
                font-weight: 900; } }
        .seven_workers .swiper-slide .workers_details .workers_details_flex .instruction .en {
          font-size: 14px;
          line-height: 19px;
          font-family: roboto, sans-serif;
          font-weight: 900; }
          @media (max-width: 480px) {
            .seven_workers .swiper-slide .workers_details .workers_details_flex .instruction .en {
              font-size: 10px;
              line-height: 11px;
              font-family: roboto, sans-serif;
              font-weight: 900;
              -webkit-transform: scale(0.9);
                      transform: scale(0.9);
              -webkit-transform-origin: left top;
                      transform-origin: left top; } }
        .seven_workers .swiper-slide .workers_details .workers_details_flex .instruction .ja {
          font-size: 34px;
          line-height: 49px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; }
          @media (max-width: 480px) {
            .seven_workers .swiper-slide .workers_details .workers_details_flex .instruction .ja {
              font-size: 17px;
              line-height: 25px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700; } }
      .seven_workers .swiper-slide .workers_details .details_message {
        font-size: 20px;
        line-height: 29px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-bottom: 16px;
        border-bottom: 2px solid #fff; }
        @media (max-width: 480px) {
          .seven_workers .swiper-slide .workers_details .details_message {
            font-size: 12px;
            line-height: 17px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            border-bottom: none; } }
      .seven_workers .swiper-slide .workers_details .details_career {
        padding-top: 8px;
        font-size: 13px;
        line-height: 19px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 500; }
        @media (max-width: 480px) {
          .seven_workers .swiper-slide .workers_details .details_career {
            display: none; } }

/*-- recruit --*/
.recruit {
  background: #f5f5f5;
  padding-bottom: 64px; }
  @media (max-width: 767px) {
    .recruit {
      padding-bottom: 40px; } }
  .recruit h2 {
    font-size: 36px;
    line-height: 52px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #333333;
    position: relative;
    text-align: center;
    padding-top: 95px;
    z-index: 1; }
    @media (max-width: 767px) {
      .recruit h2 {
        padding-top: 56px; } }
    @media (max-width: 480px) {
      .recruit h2 {
        font-size: 24px;
        line-height: 35px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-top: 64px; } }
    .recruit h2:before {
      position: absolute;
      content: "RECRUIT";
      color: #EEEEEE;
      opacity: 0.5;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -40px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: -1;
      width: 100%; }
      @media (max-width: 767px) {
        .recruit h2:before {
          bottom: -50px;
          width: 100%;
          white-space: nowrap; } }
      @media (max-width: 480px) {
        .recruit h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          bottom: -20px; } }
  .recruit .recruit_btn_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 40px;
            column-gap: 40px;
    margin-top: 42px; }
    @media (max-width: 767px) {
      .recruit .recruit_btn_flex {
        display: block; } }
    .recruit .recruit_btn_flex .recruit_btn {
      width: 50%;
      height: 120px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      background: #fff;
      border: 4px solid #E20401;
      -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
              box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }
      @media (max-width: 767px) {
        .recruit .recruit_btn_flex .recruit_btn {
          width: 92%;
          margin: 0 auto; }
          .recruit .recruit_btn_flex .recruit_btn:last-of-type {
            margin-top: 20px; } }
      .recruit .recruit_btn_flex .recruit_btn:hover {
        border: 4px solid rgba(226, 4, 1, 0.2); }
      .recruit .recruit_btn_flex .recruit_btn a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: 100%;
        height: 100%; }
        .recruit .recruit_btn_flex .recruit_btn a:hover {
          opacity: 1; }
      .recruit .recruit_btn_flex .recruit_btn .pj_ja {
        font-size: 16px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        letter-spacing: 0.04em;
        color: #333333;
        text-align: center; }
        @media (max-width: 480px) {
          .recruit .recruit_btn_flex .recruit_btn .pj_ja {
            font-size: 12px;
            line-height: 17px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700; } }
      .recruit .recruit_btn_flex .recruit_btn .pj_en {
        font-size: 32px;
        line-height: 43px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        letter-spacing: 0.04em;
        color: #E20401;
        text-align: center; }
        @media (max-width: 480px) {
          .recruit .recruit_btn_flex .recruit_btn .pj_en {
            font-size: 24px;
            line-height: 32px;
            font-family: roboto, sans-serif;
            font-weight: 900; } }

@-webkit-keyframes move-in {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0); }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%); } }

@keyframes move-in {
  from {
    -webkit-transform: translateX(0);
            transform: translateX(0); }
  to {
    -webkit-transform: translateX(100%);
            transform: translateX(100%); } }

@-webkit-keyframes move-out {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%); }
  to {
    -webkit-transform: translateX(200%);
            transform: translateX(200%); } }

@keyframes move-out {
  from {
    -webkit-transform: translateX(100%);
            transform: translateX(100%); }
  to {
    -webkit-transform: translateX(200%);
            transform: translateX(200%); } }

/*-------------------------------　ここまでTOP　-------------------------------------*/
/*-------------------------------　ここから下層　-------------------------------------*/
/*-- recuruit_mv --*/
.recruit_mv {
  background: url(../img/recruit_page_mv.jpg) no-repeat center center; }
  @media (max-width: 480px) {
    .recruit_mv {
      background: url(../img/recruit_page_mv_sp.jpg) no-repeat center center;
      background-size: cover; } }

/*-- breadcrumb --*/
.breadcrumb {
  margin-top: 80px;
  height: 40px;
  background: #333333;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center; }
  @media (max-width: 1024px) {
    .breadcrumb {
      margin-top: 50px; } }
  .breadcrumb .breadcrumbs {
    color: #fff; }
  .breadcrumb span span {
    font-size: 13px;
    line-height: 19px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: #fff; }
    @media (max-width: 480px) {
      .breadcrumb span span {
        font-size: 11px;
        line-height: 16px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 400; } }

/*-- footer要素 -- */
/*-- others--*/
.others_more {
  background: url(../img/COMPANY/other_area_pc@2x.jpg) no-repeat;
  background-size: cover;
  height: 639px;
  content: ""; }
  @media (max-width: 1024px) {
    .others_more {
      background: url(../img/COMPANY/other_area_sp@2x.jpg) no-repeat;
      height: auto; } }
  .others_more h2 {
    font-size: 36px;
    line-height: 52px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #333333;
    position: relative;
    text-align: center;
    padding-top: 106px;
    z-index: 1; }
    @media (max-width: 480px) {
      .others_more h2 {
        font-size: 17px;
        line-height: 25px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-top: 58px; } }
    .others_more h2:before {
      position: absolute;
      content: "OTHERS";
      color: #EEEEEE;
      opacity: 0.5;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -55px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: -1; }
      @media (max-width: 480px) {
        .others_more h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          bottom: -35px; } }
  .others_more .others_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    row-gap: 40px;
    margin-top: 48px; }
    @media (max-width: 1024px) {
      .others_more .others_flex {
        padding-bottom: 48px;
        -webkit-column-gap: 4.347826%;
                column-gap: 4.347826%; } }
    @media (max-width: 767px) {
      .others_more .others_flex {
        margin-top: 24px;
        row-gap: 15px; } }
    .others_more .others_flex h3 {
      font-size: 20px;
      line-height: 29px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: #fff;
      margin-bottom: 8px; }
      @media (max-width: 767px) {
        .others_more .others_flex h3 {
          margin-bottom: 0px; } }
      @media (max-width: 480px) {
        .others_more .others_flex h3 {
          font-size: 13px;
          line-height: 19px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }
    .others_more .others_flex .box {
      width: 460px;
      height: 157px;
      overflow: hidden; }
      @media (max-width: 1024px) {
        .others_more .others_flex .box {
          width: 47.536232%;
          height: 34.130435%; } }
      @media (max-width: 480px) {
        .others_more .others_flex .box {
          width: 44vw;
          height: calc(0.255 * 100vw); } }
    .others_more .others_flex .other_box {
      width: 460px;
      height: 157px;
      content: "";
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      overflow: hidden;
      -webkit-transition: 0.5s ease-in-out;
      transition: 0.5s ease-in-out; }
      @media (max-width: 1024px) {
        .others_more .others_flex .other_box {
          width: 100%;
          height: calc(0.34130435 * 50vw); } }
      @media (max-width: 480px) {
        .others_more .others_flex .other_box {
          height: inherit;
          width: 100%; } }
      .others_more .others_flex .other_box:hover {
        -webkit-transform: scale(1.05);
                transform: scale(1.05); }
      .others_more .others_flex .other_box a {
        width: 100%;
        height: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column; }
        .others_more .others_flex .other_box a:hover {
          opacity: 1; }
          .others_more .others_flex .other_box a:hover .btn_small {
            border: 2px solid #E20401; }
            @media (max-width: 767px) {
              .others_more .others_flex .other_box a:hover .btn_small {
                border: none; } }
            .others_more .others_flex .other_box a:hover .btn_small:before {
              -webkit-animation: move-in 0.3s forwards;
                      animation: move-in 0.3s forwards; }
              @media (max-width: 767px) {
                .others_more .others_flex .other_box a:hover .btn_small:before {
                  display: none;
                  -webkit-animation: none;
                          animation: none; } }
            .others_more .others_flex .other_box a:hover .btn_small span {
              color: #fff; }
      .others_more .others_flex .other_box .btn_small {
        width: 92px;
        height: 24px;
        border: 2px solid #fff;
        border-radius: 12px; }
        @media (max-width: 767px) {
          .others_more .others_flex .other_box .btn_small {
            border: none; } }
        .others_more .others_flex .other_box .btn_small:before {
          background: #E20401;
          content: "";
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: -100%;
          -webkit-animation: move-out 0.3s;
                  animation: move-out 0.3s;
          will-change: transform;
          border-radius: 100vh; }
          @media (max-width: 767px) {
            .others_more .others_flex .other_box .btn_small:before {
              -webkit-animation: none;
                      animation: none;
              border-radius: none; } }
        .others_more .others_flex .other_box .btn_small:after {
          right: 16px;
          top: 30%;
          width: 6px;
          height: 8px;
          background: url(../img/TOP/white_right_icon.svg) no-repeat;
          background-size: cover;
          -webkit-transform: rotate(-140deg);
                  transform: rotate(-140deg); }
        .others_more .others_flex .other_box .btn_small span {
          color: #fff;
          font-size: 12px;
          line-height: 16px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          letter-spacing: 0.04em;
          margin-left: -4px; }
    .others_more .others_flex .about_works_link {
      background: url(../img/COMPANY/about_us_photo@2x.jpg) no-repeat;
      background-size: cover; }
      @media (max-width: 1024px) {
        .others_more .others_flex .about_works_link {
          background: url(../img/COMPANY/about_us_photo_sp@2x.jpg) no-repeat;
          background-size: 100% auto; } }
    .others_more .others_flex .seven_workers_link {
      background: url(../img/COMPANY/seven_workers_photo@2x.jpg) no-repeat;
      background-size: cover; }
      @media (max-width: 1024px) {
        .others_more .others_flex .seven_workers_link {
          background: url(../img/COMPANY/seven_workers_photo_sp@2x.jpg) no-repeat;
          background-size: 100% auto; } }
    .others_more .others_flex .education_link {
      background: url(../img/COMPANY/education_photo@2x.jpg) no-repeat;
      background-size: cover; }
      @media (max-width: 1024px) {
        .others_more .others_flex .education_link {
          background: url(../img/COMPANY/education_photo_sp@2x.jpg) no-repeat;
          background-size: 100% auto; } }
    .others_more .others_flex .career_link {
      background: url(../img/COMPANY/career_photo@2x.jpg) no-repeat;
      background-size: cover; }
      @media (max-width: 1024px) {
        .others_more .others_flex .career_link {
          background: url(../img/COMPANY/career_photo_sp@2x.jpg) no-repeat;
          background-size: 100% auto; } }

/*-- top_entry --*/
.top_entry {
  background: url(../img/TOP/top_recriut_bg@2x.jpg) no-repeat center center;
  background-size: cover;
  width: 100vw;
  height: 320px; }
  @media (max-width: 767px) {
    .top_entry {
      background: url(../img/TOP/top_recruit_bg_sp@2x.jpg) no-repeat center center;
      background-size: cover; } }
  @media (max-width: 480px) {
    .top_entry {
      height: calc(0.8 * 100vw); } }
  .top_entry h2 {
    font-size: 32px;
    line-height: 46px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #fff;
    position: relative;
    text-align: center;
    padding-top: 105px; }
    @media (max-width: 480px) {
      .top_entry h2 {
        font-size: 24px;
        line-height: 35px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-top: 56px; } }
    .top_entry h2:before {
      position: absolute;
      content: "ENTRY";
      color: #fff;
      opacity: 0.2;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -50px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: 0; }
      @media (max-width: 480px) {
        .top_entry h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          bottom: -20px; } }
  .top_entry .btn_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-top: 32px;
    -webkit-column-gap: 20px;
            column-gap: 20px; }
    @media screen and (max-width: 600px) {
      .top_entry .btn_flex {
        -webkit-column-gap: 15px;
                column-gap: 15px;
        width: 92%;
        margin: 0 auto;
        margin-top: 16px; } }
    .top_entry .btn_flex .entry_btn {
      width: 280px;
      height: 72px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      background: #fff;
      position: relative; }
      @media screen and (max-width: 600px) {
        .top_entry .btn_flex .entry_btn {
          -webkit-box-pack: justify;
              -ms-flex-pack: justify;
                  justify-content: space-between;
          width: 47.536232%;
          height: 117px; } }
      .top_entry .btn_flex .entry_btn a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: 100%;
        height: 100%; }
        .top_entry .btn_flex .entry_btn a:hover {
          opacity: 1; }
          .top_entry .btn_flex .entry_btn a:hover .entry_ttl_btn:after {
            right: 20px; }
        .top_entry .btn_flex .entry_btn a .entry_ttl_btn {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          border: 2px solid red;
          padding: 10px 60px;
          position: relative; }
          @media screen and (max-width: 600px) {
            .top_entry .btn_flex .entry_btn a .entry_ttl_btn {
              display: block;
              text-align: center;
              padding: 11px calc(0.218 * 100vw - 50.092px); } }
          @media (max-width: 480px) {
            .top_entry .btn_flex .entry_btn a .entry_ttl_btn {
              padding: 7px calc(0.225 * 100vw - 78px); } }
          .top_entry .btn_flex .entry_btn a .entry_ttl_btn:after {
            position: absolute;
            content: "";
            background: url(../img/TOP/black_right_arrow.svg) no-repeat;
            background-size: cover;
            width: 6px;
            height: 12px;
            right: 24px;
            -webkit-transition-duration: 1s;
                    transition-duration: 1s;
            -webkit-transition: -webkit-transform .3s;
            transition: -webkit-transform .3s;
            transition: transform .3s;
            transition: transform .3s, -webkit-transform .3s; }
            @media screen and (max-width: 600px) {
              .top_entry .btn_flex .entry_btn a .entry_ttl_btn:after {
                left: 50%;
                right: 0;
                bottom: 0px; } }
            @media (max-width: 480px) {
              .top_entry .btn_flex .entry_btn a .entry_ttl_btn:after {
                left: 50%;
                right: 0;
                bottom: 6px; } }
        .top_entry .btn_flex .entry_btn a .mynavi_icon {
          width: 48px;
          height: 42px;
          aspect-ratio: 48/42;
          margin-right: 12px; }
          @media screen and (max-width: 600px) {
            .top_entry .btn_flex .entry_btn a .mynavi_icon {
              margin-top: -5px; } }
          @media (max-width: 480px) {
            .top_entry .btn_flex .entry_btn a .mynavi_icon {
              margin-top: 0;
              margin-bottom: 4px;
              margin-right: 0; } }
        .top_entry .btn_flex .entry_btn a span {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em;
          color: #111111; }
          @media screen and (max-width: 600px) {
            .top_entry .btn_flex .entry_btn a span {
              display: block;
              text-align: center; } }
          @media (max-width: 480px) {
            .top_entry .btn_flex .entry_btn a span {
              font-size: 12px;
              line-height: 17px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700;
              white-space: nowrap;
              padding-bottom: 20px; } }
      .top_entry .btn_flex .entry_btn:nth-of-type(2) a .entry_ttl_btn {
        padding: 10px 83px; }
        @media screen and (max-width: 600px) {
          .top_entry .btn_flex .entry_btn:nth-of-type(2) a .entry_ttl_btn {
            padding: 32px calc(0.21 * 100vw - 53.05px); } }
        @media (max-width: 480px) {
          .top_entry .btn_flex .entry_btn:nth-of-type(2) a .entry_ttl_btn {
            padding: 35px calc(0.225 * 100vw - 53px);
            padding: 30px calc(0.225 * 100vw - 53px); } }
        @media (max-width: 480px) {
          .top_entry .btn_flex .entry_btn:nth-of-type(2) a .entry_ttl_btn span {
            padding-bottom: 10px; } }
  .top_entry p {
    color: #fff;
    font-size: 14px;
    line-height: 20px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    margin-top: 12px; }
    @media screen and (max-width: 600px) {
      .top_entry p {
        font-size: 12px;
        line-height: 17px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }

/*--page-top --*/
.page-top {
  height: 52px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  background: #111111; }
  .page-top a {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center; }
  .page-top div {
    text-align: center; }
  .page-top img {
    width: 10px;
    height: 4px;
    margin-bottom: -2px; }
  .page-top p {
    text-align: center;
    font-size: 16px;
    line-height: 32px;
    font-family: roboto, sans-serif;
    font-weight: 900;
    line-height: inherit;
    letter-spacing: 0.04em;
    color: #fff;
    padding-bottom: 13px; }

/*-- footer --*/
footer {
  background: #fff; }
  footer .footer_logo {
    width: 150px;
    height: 81px; }
    @media (max-width: 1024px) {
      footer .footer_logo {
        margin: 0 auto; } }
  footer .foot_menu_area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-align: baseline;
        -ms-flex-align: baseline;
            align-items: baseline; }
    @media (max-width: 1024px) {
      footer .foot_menu_area {
        display: none; } }
  footer .menu_flex:nth-of-type(2) {
    margin-left: 82px; }
  footer .menu_flex:nth-of-type(3) {
    margin-left: 58px; }
  footer .menu_flex ul {
    margin-top: 16px; }
  @media screen and (max-width: 1350px) {
    footer .menu_flex li a {
      width: 100%;
      height: 100%;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
          -ms-flex-direction: column;
              flex-direction: column;
      justify-content: flex-start;
      -webkit-box-align: start;
          -ms-flex-align: start;
              align-items: flex-start; } }
  footer .menu_flex li a span {
    font-size: 14px;
    line-height: 28px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: #333333; }
  footer .menu_flex li.foot_link_title a span:first-of-type {
    font-size: 10px;
    line-height: 13px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 900;
    color: #EEEEEE; }
  footer .menu_flex li.foot_link_title a span:nth-of-type(2) {
    font-size: 16px;
    line-height: 24px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    display: block !important;
    margin-top: -5px; }
    @media screen and (max-width: 1350px) {
      footer .menu_flex li.foot_link_title a span:nth-of-type(2) {
        margin-top: 0; } }
  footer .menu_flex li.corporate_site {
    position: relative; }
    footer .menu_flex li.corporate_site:after {
      position: absolute;
      background: url(../img/TOP/external_icon.svg) no-repeat;
      background-size: cover;
      width: 10px;
      height: 10px;
      content: "";
      top: 35%;
      right: -16px; }
  footer .foot_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding-top: 40px;
    padding-bottom: 40px; }
    @media (max-width: 1024px) {
      footer .foot_flex {
        display: block;
        padding-top: 24px; } }
    @media (max-width: 1024px) {
      footer .foot_flex .logo_area {
        text-align: center; } }
    footer .foot_flex p {
      font-size: 14px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400; }
      @media (max-width: 1024px) {
        footer .foot_flex p {
          text-align: center;
          padding-top: 20px; } }
      @media (max-width: 767px) {
        footer .foot_flex p {
          font-size: 12px;
          line-height: 24px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 400; } }
  footer .copyright {
    padding-top: 14px;
    padding-bottom: 36px; }
    @media (max-width: 1024px) {
      footer .copyright {
        width: 92%;
        margin: 0 auto;
        padding-top: 24px;
        padding-bottom: 16px; } }
    footer .copyright .copyright_flex {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center; }
      @media (max-width: 1024px) {
        footer .copyright .copyright_flex {
          display: block; } }
      footer .copyright .copyright_flex p {
        margin-right: 26px; }
        @media (max-width: 1024px) {
          footer .copyright .copyright_flex p:first-of-type {
            padding-bottom: 12px;
            margin-right: 0; } }
      footer .copyright .copyright_flex small {
        font-size: 12px;
        line-height: 28px;
        font-family: roboto, sans-serif;
        font-weight: 500;
        color: #999999; }
      footer .copyright .copyright_flex a {
        text-decoration: underline;
        color: #333333;
        font-size: 14px;
        line-height: 28px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 400; }
  @media (max-width: 1024px) {
    footer .google_terms {
      width: 92%;
      margin: 0 auto; } }
  footer .google_terms p {
    font-size: 12px;
    line-height: 28px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    line-height: inherit;
    letter-spacing: 0.04em;
    color: #999999; }
    footer .google_terms p a {
      color: #999999; }

.grecaptcha-badge {
  visibility: hidden; }

/*-------------------------------　ここから　-------------------------------------*/
/*-- mv-- */
.mv {
  background-size: cover;
  padding-top: 80px;
  margin-top: -2px;
  height: 524px;
  position: relative; }
  @media (max-width: 480px) {
    .mv {
      height: 200px;
      padding-top: 50px; } }
  .mv .mv_ttl {
    position: absolute;
    top: 40%;
    left: 0;
    right: 0;
    margin: auto;
    text-align: center; }
    .mv .mv_ttl img {
      width: 240px; }
    .mv .mv_ttl p {
      font-size: 16px;
      line-height: 32px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 500;
      letter-spacing: 0.04em;
      text-align: center; }

/*-- company --*/
.company_mv {
  background: url(../img/COMPANY/company_mv_pc@2x.jpg) no-repeat center center;
  background-size: cover;
  width: 100vw;
  height: 524px;
  position: relative;
  margin-bottom: 660px; }
  @media (max-width: 1024px) {
    .company_mv {
      background: url(../img/COMPANY/company_mv_sp@2x.jpg) no-repeat center center;
      background-size: cover;
      width: 100vw;
      height: calc(0.37439614 * 100vw);
      margin-bottom: 817px;
      margin-bottom: 825px; } }
  @media (max-width: 767px) {
    .company_mv {
      margin-bottom: 737px;
      margin-bottom: 770px; } }
  @media (max-width: 480px) {
    .company_mv {
      margin-bottom: calc(0.519 * 100vw + 876px);
      margin-bottom: calc(0.925 * 100vw + 802px); } }
  @media (max-width: 1024px) {
    .company_mv .mv_ttl {
      z-index: 2; } }
  @media screen and (max-width: 600px) {
    .company_mv .mv_ttl {
      top: 60%; } }
  .company_mv .mv_ttl h1 {
    position: relative; }
    .company_mv .mv_ttl h1.is-animated:before {
      -webkit-animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
              animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
      background: #333333;
      content: "";
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      -webkit-transform-origin: left center;
              transform-origin: left center; }
    .company_mv .mv_ttl h1.is-animated span {
      opacity: 1;
      -webkit-transform: translateY(0px);
              transform: translateY(0px);
      -webkit-transition-duration: 600ms;
              transition-duration: 600ms;
      -webkit-transition-property: opacity,-webkit-transform;
      transition-property: opacity,-webkit-transform;
      transition-property: transform,opacity;
      transition-property: transform,opacity,-webkit-transform;
      -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
              transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
      -webkit-transition-delay: 500ms;
              transition-delay: 500ms;
      -webkit-transform: translate(0px, 0px);
              transform: translate(0px, 0px); }
      .company_mv .mv_ttl h1.is-animated span:nth-child(1) {
        -webkit-transition-delay: 525ms;
                transition-delay: 525ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(2) {
        -webkit-transition-delay: 550ms;
                transition-delay: 550ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(3) {
        -webkit-transition-delay: 575ms;
                transition-delay: 575ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(4) {
        -webkit-transition-delay: 600ms;
                transition-delay: 600ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(5) {
        -webkit-transition-delay: 625ms;
                transition-delay: 625ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(6) {
        -webkit-transition-delay: 650ms;
                transition-delay: 650ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(7) {
        -webkit-transition-delay: 675ms;
                transition-delay: 675ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(8) {
        -webkit-transition-delay: 700ms;
                transition-delay: 700ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(9) {
        -webkit-transition-delay: 725ms;
                transition-delay: 725ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(10) {
        -webkit-transition-delay: 750ms;
                transition-delay: 750ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(11) {
        -webkit-transition-delay: 775ms;
                transition-delay: 775ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(12) {
        -webkit-transition-delay: 800ms;
                transition-delay: 800ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(13) {
        -webkit-transition-delay: 825ms;
                transition-delay: 825ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(14) {
        -webkit-transition-delay: 850ms;
                transition-delay: 850ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(15) {
        -webkit-transition-delay: 875ms;
                transition-delay: 875ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(16) {
        -webkit-transition-delay: 900ms;
                transition-delay: 900ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(17) {
        -webkit-transition-delay: 925ms;
                transition-delay: 925ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(18) {
        -webkit-transition-delay: 950ms;
                transition-delay: 950ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(19) {
        -webkit-transition-delay: 975ms;
                transition-delay: 975ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(20) {
        -webkit-transition-delay: 1000ms;
                transition-delay: 1000ms; }
      .company_mv .mv_ttl h1.is-animated span:nth-child(21) {
        -webkit-transition-delay: 1025ms;
                transition-delay: 1025ms; }
      @media (max-width: 1024px) {
        .company_mv .mv_ttl h1.is-animated span:nth-child(15) {
          -webkit-transition-delay: 1375ms;
                  transition-delay: 1375ms;
          margin-bottom: 16px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(16) {
          -webkit-transition-delay: 1400ms;
                  transition-delay: 1400ms;
          margin-bottom: 16px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(17) {
          -webkit-transition-delay: 1425ms;
                  transition-delay: 1425ms;
          margin-bottom: 16px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(18) {
          -webkit-transition-delay: 1450ms;
                  transition-delay: 1450ms;
          margin-bottom: 16px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(19) {
          -webkit-transition-delay: 1475ms;
                  transition-delay: 1475ms;
          margin-bottom: 16px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(20) {
          -webkit-transition-delay: 1500ms;
                  transition-delay: 1500ms;
          margin-bottom: 16px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(21) {
          -webkit-transition-delay: 1525ms;
                  transition-delay: 1525ms;
          margin-bottom: 16px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(22) {
          -webkit-transition-delay: 1550ms;
                  transition-delay: 1550ms;
          margin-bottom: 16px;
          margin-top: 0; } }
      @media (max-width: 767px) {
        .company_mv .mv_ttl h1.is-animated span:nth-child(15) {
          margin-bottom: 0px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(16) {
          margin-bottom: 0px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(17) {
          margin-bottom: 0px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(18) {
          margin-bottom: 0px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(19) {
          margin-bottom: 0px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(20) {
          margin-bottom: 0px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(21) {
          margin-bottom: 0px;
          margin-top: 0; }
        .company_mv .mv_ttl h1.is-animated span:nth-child(22) {
          margin-bottom: 0px;
          margin-top: 0; } }
    .company_mv .mv_ttl h1 span {
      opacity: 0;
      -webkit-transform: translate(-45px, 0px);
              transform: translate(-45px, 0px);
      font-size: 64px;
      line-height: 84px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      text-align: center;
      color: #fff;
      position: relative;
      z-index: 1; }
      @media (max-width: 1024px) {
        .company_mv .mv_ttl h1 span {
          line-height: 1.15;
          margin-bottom: 0;
          margin-top: 16px;
          display: inline-block; } }
      @media (max-width: 767px) {
        .company_mv .mv_ttl h1 span {
          margin-top: 0px;
          display: inline; } }
    @media (max-width: 1024px) {
      .company_mv .mv_ttl h1 {
        width: 92%;
        margin: 0 auto; } }
    @media screen and (max-width: 600px) {
      .company_mv .mv_ttl h1 {
        padding: 12px 0; }
        .company_mv .mv_ttl h1 span {
          font-size: 28px;
          line-height: 32px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          letter-spacing: 0.075em; } }
  .company_mv .mv_ttl .subtitle {
    font-size: 14px;
    line-height: 24px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    text-align: center;
    color: #fff;
    background: #333333;
    margin: 0 auto;
    position: relative;
    opacity: 0; }
    .company_mv .mv_ttl .subtitle span {
      -webkit-transform: translate(-45px, 0px);
              transform: translate(-45px, 0px);
      font-size: 14px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      letter-spacing: 0.04em;
      color: #fff;
      position: relative;
      z-index: 1; }
    .company_mv .mv_ttl .subtitle:first-of-type {
      padding: 8px;
      margin-top: 16px;
      width: 330px; }
    .company_mv .mv_ttl .subtitle:nth-of-type(2) {
      padding: 8px 16px;
      margin-top: 8px;
      width: 590px; }
    @media (max-width: 1024px) {
      .company_mv .mv_ttl .subtitle:nth-of-type(3) {
        width: 184px;
        margin-top: 8px;
        padding: 5px 18px; } }
    @media screen and (max-width: 600px) {
      .company_mv .mv_ttl .subtitle {
        padding: 3px; }
        .company_mv .mv_ttl .subtitle span {
          font-size: 12px;
          line-height: 24px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 400; }
        .company_mv .mv_ttl .subtitle:first-of-type {
          padding: 3px; }
        .company_mv .mv_ttl .subtitle:nth-of-type(2) {
          width: 92%;
          white-space: nowrap;
          padding-left: 0;
          padding-right: 0; } }
  .company_mv .white_bg {
    position: absolute;
    top: 417px;
    left: 50%;
    -webkit-transform: translate(-50%);
            transform: translate(-50%);
    background: #fff;
    z-index: 1;
    max-width: 1080px;
    width: 100%;
    margin: 0 auto; }
    @media (max-width: 1024px) {
      .company_mv .white_bg {
        width: 92%; } }
    @media (max-width: 480px) {
      .company_mv .white_bg {
        margin-top: 24px;
        top: calc(0.225 * 100vw + 204px); } }
    .company_mv .white_bg h2 {
      position: relative;
      padding-top: 75px;
      z-index: 2;
      text-align: center;
      font-size: 36px;
      line-height: 52px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em; }
      @media (max-width: 1024px) {
        .company_mv .white_bg h2 {
          padding-top: 115px; } }
      @media (max-width: 767px) {
        .company_mv .white_bg h2 {
          padding-top: 54px; } }
      @media (max-width: 480px) {
        .company_mv .white_bg h2 {
          padding-top: 46px;
          white-space: nowrap;
          font-size: 24px;
          line-height: 35px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }
      .company_mv .white_bg h2 span {
        font-size: 16px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        letter-spacing: 0.04em;
        display: block; }
        @media (max-width: 480px) {
          .company_mv .white_bg h2 span {
            font-size: 14px;
            line-height: 19px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 900; } }
      .company_mv .white_bg h2:before {
        position: absolute;
        content: "BUSSINESS";
        color: #EEEEEE;
        opacity: 0.5;
        font-size: 120px;
        line-height: 160px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        letter-spacing: 0.04em;
        bottom: -30px;
        left: 50%;
        -webkit-transform: translateX(-50%);
                transform: translateX(-50%);
        z-index: -1; }
        @media (max-width: 767px) {
          .company_mv .white_bg h2:before {
            font-size: 64px;
            line-height: 84px;
            font-family: roboto, sans-serif;
            font-weight: 900;
            bottom: -15px; } }
    .company_mv .white_bg .bussiness_details {
      font-size: 13px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 500;
      letter-spacing: 0.04em;
      color: #333333;
      text-align: center !important;
      margin-top: 13px; }
      .company_mv .white_bg .bussiness_details.details_content {
        margin-top: 20px;
        margin-bottom: 44px; }
        @media (max-width: 767px) {
          .company_mv .white_bg .bussiness_details.details_content {
            margin-bottom: 24px; } }
        @media (max-width: 480px) {
          .company_mv .white_bg .bussiness_details.details_content {
            margin-top: 10px;
            margin-bottom: 40px;
            text-align: left !important; } }
      @media (max-width: 480px) {
        .company_mv .white_bg .bussiness_details {
          font-size: 12px;
          padding: 0;
          margin-bottom: 25px; } }

.num_data {
  background: #E20401;
  padding-bottom: 65px; }
  .num_data h2 {
    color: #fff;
    font-size: 24px;
    line-height: 35px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding-top: 50px;
    text-align: center;
    position: relative; }
    .num_data h2:before {
      position: absolute;
      content: "DATA";
      color: #fff;
      opacity: 0.2;
      bottom: -65px;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -70px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: 0; }
      @media (max-width: 1024px) {
        .num_data h2:before {
          bottom: -45px; } }
      @media (max-width: 767px) {
        .num_data h2:before {
          bottom: -70px; } }
      @media (max-width: 480px) {
        .num_data h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          top: 30%;
          -webkit-transform: translateX(50%, -50%);
                  transform: translateX(50%, -50%); } }
    @media (max-width: 1024px) {
      .num_data h2 {
        white-space: nowrap; } }
    @media (max-width: 767px) {
      .num_data h2 {
        font-size: 22px; } }
    @media (max-width: 480px) {
      .num_data h2 {
        font-size: 17px;
        line-height: 25px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        text-align: center; }
        .num_data h2:before {
          left: 78px;
          left: 50%; } }
  .num_data .num_data_explain {
    font-size: 14px;
    line-height: 20px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    color: #fff;
    text-align: center;
    margin-top: 34px; }
    @media (max-width: 1024px) {
      .num_data .num_data_explain {
        padding-bottom: 20px; } }
    @media (max-width: 767px) {
      .num_data .num_data_explain {
        padding: 0 13px;
        margin-top: 16px;
        margin-bottom: 16px; } }
    @media (max-width: 480px) {
      .num_data .num_data_explain {
        text-align: left;
        font-size: 12px;
        line-height: 20px; } }
  .num_data .num_data_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-column-gap: 35px;
            column-gap: 35px;
    margin-top: 32px; }
    @media (max-width: 1024px) {
      .num_data .num_data_flex {
        -ms-flex-wrap: wrap;
            flex-wrap: wrap;
        width: 92vw;
        margin: 0 auto;
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
        row-gap: 20px; } }
    @media (max-width: 480px) {
      .num_data .num_data_flex {
        -webkit-column-gap: 15px;
                column-gap: 15px; } }
    .num_data .num_data_flex .num_data_content {
      text-align: center; }
      .num_data .num_data_flex .num_data_content:first-of-type .num_data_title {
        margin-bottom: 22px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content:first-of-type .num_data_title {
            margin-bottom: 12px; } }
      .num_data .num_data_flex .num_data_content:nth-of-type(2) .num_data_title {
        margin-bottom: 18px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content:nth-of-type(2) .num_data_title {
            margin-bottom: 16px; } }
      .num_data .num_data_flex .num_data_content:nth-of-type(3) .num_data_title {
        margin-bottom: 32px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content:nth-of-type(3) .num_data_title {
            margin-bottom: 12px; } }
      .num_data .num_data_flex .num_data_content:nth-of-type(4) .num_data_title {
        margin-bottom: 22px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content:nth-of-type(4) .num_data_title {
            margin-bottom: 16px; } }
      .num_data .num_data_flex .num_data_content .num_data_title {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: 180px;
        height: 40px;
        background: rgba(51, 51, 51, 0.2);
        color: #fff;
        font-size: 20px;
        line-height: 29px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; }
        @media (max-width: 1024px) {
          .num_data .num_data_flex .num_data_content .num_data_title {
            width: 42vw; } }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content .num_data_title {
            width: 41vw;
            width: 43.735vw;
            font-size: 14px;
            line-height: 20px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            height: 32px; } }
        @media screen and (max-width: 360px) {
          .num_data .num_data_flex .num_data_content .num_data_title {
            width: 40vw; } }
      .num_data .num_data_flex .num_data_content .office_icon {
        width: 150px;
        height: 115px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content .office_icon {
            width: 115px;
            height: 88px; } }
      .num_data .num_data_flex .num_data_content .workers_icon {
        width: 106px;
        height: 123px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content .workers_icon {
            width: 68px;
            height: 79px; } }
      .num_data .num_data_flex .num_data_content .capital_icon {
        width: 123px;
        height: 93px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content .capital_icon {
            width: 100px;
            height: 75px; } }
      .num_data .num_data_flex .num_data_content .founded_icon {
        width: 156px;
        height: 114px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_content .founded_icon {
            width: 102px;
            height: 74px; } }
    .num_data .num_data_flex .num_data_detail {
      color: #fff;
      font-size: 16px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em; }
      .num_data .num_data_flex .num_data_detail.capital_detail {
        margin-top: 14px; }
        @media (max-width: 1024px) {
          .num_data .num_data_flex .num_data_detail.capital_detail {
            margin-top: 0; } }
      @media (max-width: 480px) {
        .num_data .num_data_flex .num_data_detail {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }
      .num_data .num_data_flex .num_data_detail span {
        font-size: 64px;
        line-height: 84px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        padding-right: 8px; }
        @media (max-width: 480px) {
          .num_data .num_data_flex .num_data_detail span {
            font-size: 40px;
            line-height: 53px;
            font-family: roboto, sans-serif;
            font-weight: 900; } }
        .num_data .num_data_flex .num_data_detail span.one_bilion {
          padding-right: 8px; }
          @media (max-width: 480px) {
            .num_data .num_data_flex .num_data_detail span.one_bilion {
              padding-right: 0; } }
        .num_data .num_data_flex .num_data_detail span.bilion {
          font-size: 32px;
          line-height: 46px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          padding-right: 0;
          padding-right: 4px; }
          @media (max-width: 480px) {
            .num_data .num_data_flex .num_data_detail span.bilion {
              font-size: 20px;
              line-height: 29px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700;
              padding-right: 0; } }

.welfare {
  background: #fff; }
  .welfare h2 {
    position: relative;
    padding-top: 90px;
    z-index: 2;
    text-align: center; }
    @media (max-width: 480px) {
      .welfare h2 {
        padding-top: 46px;
        white-space: nowrap; } }
    .welfare h2 span {
      font-size: 16px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em;
      display: block; }
      @media (max-width: 480px) {
        .welfare h2 span {
          font-size: 14px;
          line-height: 19px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 900; } }
    .welfare h2:before {
      position: absolute;
      content: "WELFARE";
      color: #EEEEEE;
      opacity: 0.5;
      font-size: 120px;
      line-height: 160px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      bottom: -65px;
      left: 50%;
      -webkit-transform: translateX(-50%);
              transform: translateX(-50%);
      z-index: -1; }
      @media (max-width: 767px) {
        .welfare h2:before {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          bottom: -15px; } }
  .welfare .welfare_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 30px;
            column-gap: 30px;
    margin-top: 28px;
    row-gap: 24px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap; }
    @media (max-width: 1024px) {
      .welfare .welfare_flex {
        -webkit-column-gap: 3.125%;
                column-gap: 3.125%; } }
    @media (max-width: 767px) {
      .welfare .welfare_flex {
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-column-gap: 3%;
                column-gap: 3%; } }
    @media (max-width: 480px) {
      .welfare .welfare_flex {
        -webkit-column-gap: 15px;
                column-gap: 15px;
        row-gap: 15px; } }
    .welfare .welfare_flex .welfare_content {
      max-width: 300px;
      width: 31.25%;
      height: 160px;
      border: 3px solid #EEEEEE;
      border-radius: 8px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      -webkit-box-align: start;
          -ms-flex-align: start;
              align-items: flex-start;
      padding-top: 20px; }
      @media (max-width: 1024px) {
        .welfare .welfare_flex .welfare_content {
          max-width: inherit;
          width: 31.25%; } }
      @media (max-width: 767px) {
        .welfare .welfare_flex .welfare_content {
          height: 185px; } }
      @media (max-width: 767px) {
        .welfare .welfare_flex .welfare_content {
          max-width: inherit;
          width: 48.44%; } }
      @media (max-width: 480px) {
        .welfare .welfare_flex .welfare_content {
          width: 48%;
          height: 120px; } }
      @media screen and (max-width: 411px) {
        .welfare .welfare_flex .welfare_content {
          width: 47.75%; } }
      @media screen and (max-width: 361px) {
        .welfare .welfare_flex .welfare_content {
          width: 47%; } }
      .welfare .welfare_flex .welfare_content .welfare_title {
        font-size: 16px;
        line-height: 32px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 900;
        letter-spacing: 0.08em; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .welfare_title {
            font-size: 13px;
            line-height: 18px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 900; } }
        @media (max-width: 1024px) {
          .welfare .welfare_flex .welfare_content .welfare_title.sp_mg_top_8 {
            margin-top: -8px;
            line-height: 24px; } }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .welfare_title.sp_mg_top_8 {
            margin-top: -8px;
            line-height: 18px; } }
      .welfare .welfare_flex .welfare_content .telwork_icon {
        width: 79px;
        height: 71px;
        margin-top: 8px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .telwork_icon {
            width: 55px;
            height: 49px; } }
      .welfare .welfare_flex .welfare_content .coretimeflex_icon {
        width: 70px;
        height: 70px;
        margin-top: 8px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .coretimeflex_icon {
            width: 44px;
            height: 44px; } }
      .welfare .welfare_flex .welfare_content .one_hour_icon {
        width: 72px;
        height: 78px;
        margin-top: 4px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .one_hour_icon {
            width: 51px;
            height: 56px; } }
      .welfare .welfare_flex .welfare_content .childcare_time_icon {
        width: 71px;
        height: 81px;
        margin-top: 4px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .childcare_time_icon {
            width: 49px;
            height: 56px; } }
      .welfare .welfare_flex .welfare_content .childcare_work_icon {
        width: 82px;
        height: 81px;
        margin-top: 4px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .childcare_work_icon {
            width: 58px;
            height: 57px; } }
      .welfare .welfare_flex .welfare_content .nursing_icon {
        width: 108px;
        height: 86px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .nursing_icon {
            width: 67px;
            height: 55px; } }
      .welfare .welfare_flex .welfare_content .refresh_icon {
        width: 90px;
        height: 87px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .refresh_icon {
            width: 54px;
            height: 53px; } }
      .welfare .welfare_flex .welfare_content .volunteer_icon {
        width: 76px;
        height: 75px;
        margin-top: 8px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .volunteer_icon {
            width: 50px;
            height: 49px; } }
      .welfare .welfare_flex .welfare_content .house_icon {
        width: 77px;
        height: 76px;
        margin-top: 6px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .house_icon {
            width: 49px;
            height: 48px; } }
      .welfare .welfare_flex .welfare_content .cosodate_icon {
        width: 71px;
        height: 74px;
        margin-top: 7px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .cosodate_icon {
            width: 47px;
            height: 48px; } }
      .welfare .welfare_flex .welfare_content .nursery_school_icon {
        width: 80px;
        height: 72px;
        margin-top: 5px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .nursery_school_icon {
            width: 55px;
            height: 50px; } }
      .welfare .welfare_flex .welfare_content .fureai_icon {
        width: 76px;
        height: 91px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .fureai_icon {
            width: 48px;
            height: 58px; } }
      .welfare .welfare_flex .welfare_content .distance_learning_icon {
        width: 95px;
        height: 70px;
        margin-top: 8px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .distance_learning_icon {
            width: 63px;
            height: 46px; } }
      .welfare .welfare_flex .welfare_content .language_icon {
        width: 81px;
        height: 79px;
        margin-top: 5px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .language_icon {
            width: 52px;
            height: 51px; } }
      .welfare .welfare_flex .welfare_content .certification_icon {
        width: 86px;
        height: 82px;
        margin-top: 4px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .certification_icon {
            width: 52px;
            height: 49px; } }
      .welfare .welfare_flex .welfare_content .seminar_icon {
        width: 81px;
        height: 79px;
        margin-top: 6px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .seminar_icon {
            width: 54px;
            height: 52px; } }
      .welfare .welfare_flex .welfare_content .savings_icon {
        width: 86px;
        height: 80px;
        margin-top: 4px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .savings_icon {
            width: 54px;
            height: 50px; } }
      .welfare .welfare_flex .welfare_content .holding_icon {
        width: 87px;
        height: 88px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .holding_icon {
            width: 51px;
            height: 51px; } }
      .welfare .welfare_flex .welfare_content .housing_loan_icon {
        width: 84px;
        height: 75px;
        margin-top: 4px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .housing_loan_icon {
            width: 55px;
            height: 49px; } }
      .welfare .welfare_flex .welfare_content .sportsclub_icon {
        width: 83px;
        height: 72px;
        margin-top: 6px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .sportsclub_icon {
            width: 58px;
            height: 51px; } }
      .welfare .welfare_flex .welfare_content .comeback_icon {
        width: 100px;
        height: 80px; }
        @media (max-width: 480px) {
          .welfare .welfare_flex .welfare_content .comeback_icon {
            width: 66px;
            height: 53px; } }
  .welfare .cautions {
    text-align: right;
    font-size: 12px;
    line-height: 32px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #333333;
    margin-top: 30px; }
  .welfare .bunner_area {
    margin-top: 64px;
    margin-bottom: 64px;
    position: relative; }
    .welfare .bunner_area a:hover {
      opacity: 1; }
      .welfare .bunner_area a:hover .bgleft:before {
        -webkit-animation: move-in 0.3s forwards;
                animation: move-in 0.3s forwards; }
        @media (max-width: 767px) {
          .welfare .bunner_area a:hover .bgleft:before {
            display: none; } }
      .welfare .bunner_area a:hover .bgleft:after {
        background: url(../img/TOP/white_right_icon.svg) no-repeat; }
        @media (max-width: 767px) {
          .welfare .bunner_area a:hover .bgleft:after {
            background: url(../img/TOP/red_right_arrow.svg) no-repeat; } }
      .welfare .bunner_area a:hover .bgleft span {
        color: #fff; }
        @media (max-width: 767px) {
          .welfare .bunner_area a:hover .bgleft span {
            color: #E20401; } }
    .welfare .bunner_area .btn_small {
      width: 220px;
      height: 48px;
      position: absolute;
      right: 32px;
      bottom: 40px;
      background: #fff; }
      @media (max-width: 767px) {
        .welfare .bunner_area .btn_small {
          border: none;
          -webkit-box-pack: end;
              -ms-flex-pack: end;
                  justify-content: flex-end;
          width: 41px;
          height: 15px;
          border-radius: 0;
          position: absolute;
          bottom: 8px;
          right: 9px; } }
      @media (max-width: 480px) {
        .welfare .bunner_area .btn_small {
          position: absolute;
          bottom: 8px;
          right: 9px;
          width: 100%;
          background: inherit; } }
      .welfare .bunner_area .btn_small:before {
        background: #E20401;
        content: "";
        width: 100%;
        height: 100%;
        position: absolute;
        top: 0;
        left: -100%;
        -webkit-animation: move-out 0.3s;
                animation: move-out 0.3s;
        will-change: transform; }
      .welfare .bunner_area .btn_small:after {
        right: 32px;
        top: 43%; }
        @media (max-width: 767px) {
          .welfare .bunner_area .btn_small:after {
            right: 0px;
            top: 20%; } }
      .welfare .bunner_area .btn_small span {
        font-size: 16px;
        line-height: 32px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        letter-spacing: 0.04em;
        margin-left: -8px; }
        @media (max-width: 767px) {
          .welfare .bunner_area .btn_small span {
            border-bottom: 1px solid #E20401;
            margin-left: 0;
            margin-right: 9px; } }
        @media (max-width: 480px) {
          .welfare .bunner_area .btn_small span {
            font-size: 11px;
            line-height: 15px;
            font-family: roboto, sans-serif;
            font-weight: 700; } }
    .welfare .bunner_area .bgleft:before {
      z-index: 0; }

/*-- WORKS --*/
.works_mv {
  background: url(../img/WORKS/works_mv_bg@2x.jpg) no-repeat center center;
  background-size: cover;
  width: 100vw;
  height: 460px;
  position: relative;
  margin-bottom: 150px; }
  @media (max-width: 767px) {
    .works_mv {
      background: url(../img/WORKS/works_mv_bg_sp@2x.jpg) no-repeat center center;
      background-size: cover;
      height: 194px;
      height: calc(0.51733333 * 100vw);
      margin-bottom: 290px; } }
  .works_mv a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%; }
  .works_mv .mv_ttl {
    top: 25%; }
    .works_mv .mv_ttl h1 {
      font-size: 56px;
      line-height: 74px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      color: #fff; }
      @media (max-width: 480px) {
        .works_mv .mv_ttl h1 {
          font-size: 32px;
          line-height: 32px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          margin-bottom: 2px; } }
    .works_mv .mv_ttl .subtitle {
      font-size: 20px;
      line-height: 29px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: #fff; }
      @media (max-width: 480px) {
        .works_mv .mv_ttl .subtitle {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }
    .works_mv .mv_ttl .play_icon {
      width: 121px;
      height: 121px;
      margin-top: 16px; }
      @media (max-width: 480px) {
        .works_mv .mv_ttl .play_icon {
          width: 49px;
          height: 49px;
          margin-top: 0px; } }
  .works_mv .anker_link {
    position: absolute;
    bottom: -225px;
    width: 100%; }
    @media (max-width: 767px) {
      .works_mv .anker_link {
        bottom: -340px;
        width: 53.333vw;
        left: 30%;
        -webkit-transform: translate(-30px);
                transform: translate(-30px); } }
    @media (max-width: 480px) {
      .works_mv .anker_link {
        bottom: -264px; } }
    .works_mv .anker_link .anker_flex {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-column-gap: 30px;
              column-gap: 30px;
      margin-top: 16px;
      margin-bottom: 80px; }
      @media (max-width: 767px) {
        .works_mv .anker_link .anker_flex {
          display: block;
          width: 100%;
          margin: 0 auto;
          margin-top: 16px; } }
      .works_mv .anker_link .anker_flex .anker_btn {
        width: 33.3333%;
        height: 212px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column;
        background: #fff;
        -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
                box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16); }
        @media (max-width: 767px) {
          .works_mv .anker_link .anker_flex .anker_btn {
            width: 100%;
            height: 116px;
            position: relative;
            margin-top: 22px; }
            .works_mv .anker_link .anker_flex .anker_btn:first-of-type {
              height: 87px;
              margin-top: 0; } }
        @media (max-width: 480px) {
          .works_mv .anker_link .anker_flex .anker_btn {
            height: 87px; }
            .works_mv .anker_link .anker_flex .anker_btn:first-of-type {
              height: 69px; } }
        .works_mv .anker_link .anker_flex .anker_btn a {
          padding-top: 50px;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-pack: start;
              -ms-flex-pack: start;
                  justify-content: flex-start;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-box-align: start;
              -ms-flex-align: start;
                  align-items: flex-start;
          justify-self: center;
          -webkit-box-orient: vertical;
          -webkit-box-direction: normal;
              -ms-flex-direction: column;
                  flex-direction: column;
          width: 100%;
          height: 100%; }
          @media (max-width: 767px) {
            .works_mv .anker_link .anker_flex .anker_btn a {
              padding-top: 16px; } }
          .works_mv .anker_link .anker_flex .anker_btn a:hover {
            background: #EEEEEE;
            opacity: 1; }
            .works_mv .anker_link .anker_flex .anker_btn a:hover .btn_small:before {
              display: none; }
            .works_mv .anker_link .anker_flex .anker_btn a:hover .btn_small:after {
              background: url(../img/TOP/red_right_arrow.svg) no-repeat; }
        .works_mv .anker_link .anker_flex .anker_btn .pj_ja {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em;
          color: #fff;
          background: #E20401;
          padding: 2px 16px;
          margin: 0 auto; }
          @media (max-width: 1024px) {
            .works_mv .anker_link .anker_flex .anker_btn .pj_ja {
              white-space: nowrap; } }
          @media (max-width: 767px) {
            .works_mv .anker_link .anker_flex .anker_btn .pj_ja {
              position: absolute;
              top: -10px;
              left: 50%;
              -webkit-transform: translate(-50%);
                      transform: translate(-50%); } }
          @media (max-width: 480px) {
            .works_mv .anker_link .anker_flex .anker_btn .pj_ja {
              font-size: 11px;
              line-height: 16px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700;
              padding: 4px 9px; } }
        .works_mv .anker_link .anker_flex .anker_btn .pj_title {
          font-size: 20px;
          line-height: 29px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 900;
          letter-spacing: 0.04em;
          color: #333333;
          text-align: center;
          margin: 0 auto;
          margin-top: 8px; }
          @media (max-width: 767px) {
            .works_mv .anker_link .anker_flex .anker_btn .pj_title {
              white-space: nowrap;
              margin-top: 6px; } }
          @media (max-width: 480px) {
            .works_mv .anker_link .anker_flex .anker_btn .pj_title {
              font-size: 14px;
              line-height: 18px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700; } }
        @media (max-width: 1024px) {
          .works_mv .anker_link .anker_flex .anker_btn:nth-of-type(2) .pj_title {
            font-size: 18px; } }
        @media (max-width: 480px) {
          .works_mv .anker_link .anker_flex .anker_btn:nth-of-type(2) .pj_title {
            font-size: 14px; } }
        .works_mv .anker_link .anker_flex .anker_btn .btn_small {
          width: 120px;
          height: 32px;
          margin-top: 8px;
          border: none; }
          @media (max-width: 767px) {
            .works_mv .anker_link .anker_flex .anker_btn .btn_small {
              margin-top: 0px; } }
          @media (max-width: 480px) {
            .works_mv .anker_link .anker_flex .anker_btn .btn_small {
              height: 28px; } }
          .works_mv .anker_link .anker_flex .anker_btn .btn_small.first {
            margin-top: 37px; }
            @media (max-width: 767px) {
              .works_mv .anker_link .anker_flex .anker_btn .btn_small.first {
                margin-top: 0px; } }
          .works_mv .anker_link .anker_flex .anker_btn .btn_small:before {
            display: none; }
          .works_mv .anker_link .anker_flex .anker_btn .btn_small:after {
            right: 50%;
            -webkit-transform: rotate(90deg);
                    transform: rotate(90deg);
            top: inherit;
            bottom: 1px; }
          .works_mv .anker_link .anker_flex .anker_btn .btn_small span {
            font-size: 14px;
            line-height: 19px;
            font-family: roboto, sans-serif;
            font-weight: 700;
            margin-left: -8px; }
            @media (max-width: 480px) {
              .works_mv .anker_link .anker_flex .anker_btn .btn_small span {
                font-size: 11px;
                line-height: 15px;
                font-family: roboto, sans-serif;
                font-weight: 700; } }
        .works_mv .anker_link .anker_flex .anker_btn .bgleft:before {
          z-index: 0;
          display: none; }

.works_manufacture,
.works_engineering,
.works_quality {
  padding-top: 88px; }
  @media (max-width: 767px) {
    .works_manufacture,
    .works_engineering,
    .works_quality {
      padding-top: 44px; } }
  @media (max-width: 767px) {
    .works_manufacture.manu,
    .works_engineering.manu,
    .works_quality.manu {
      padding-top: 75px; } }
  @media (max-width: 480px) {
    .works_manufacture.manu,
    .works_engineering.manu,
    .works_quality.manu {
      padding-top: 44px; } }
  .works_manufacture h3,
  .works_engineering h3,
  .works_quality h3 {
    font-size: 20px;
    line-height: 29px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #333333;
    text-align: center; }
    @media (max-width: 480px) {
      .works_manufacture h3,
      .works_engineering h3,
      .works_quality h3 {
        font-size: 14px;
        line-height: 20px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .works_manufacture h2,
  .works_engineering h2,
  .works_quality h2 {
    font-size: 40px;
    line-height: 58px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #333333;
    text-align: center;
    margin-top: 3px; }
    @media (max-width: 480px) {
      .works_manufacture h2,
      .works_engineering h2,
      .works_quality h2 {
        font-size: 28px;
        line-height: 38px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .works_manufacture video,
  .works_engineering video,
  .works_quality video {
    width: 452px;
    height: 255px;
    margin: 0 auto;
    margin-top: 16px; }
    @media (max-width: 480px) {
      .works_manufacture video,
      .works_engineering video,
      .works_quality video {
        width: 92vw;
        height: calc(0.5625 * 92vw);
        margin-top: 8px; } }
  .works_manufacture .swiper_manufacture,
  .works_engineering .swiper_manufacture,
  .works_quality .swiper_manufacture {
    margin-top: 55px;
    height: 240px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-animation: move-left 35s linear -5s infinite;
            animation: move-left 35s linear -5s infinite;
    overflow: hidden;
    width: 340%; }
    @media (max-width: 767px) {
      .works_manufacture .swiper_manufacture,
      .works_engineering .swiper_manufacture,
      .works_quality .swiper_manufacture {
        height: 120px;
        -webkit-animation: move-left 20s linear -10s infinite;
                animation: move-left 20s linear -10s infinite; } }
    .works_manufacture .swiper_manufacture .slide,
    .works_engineering .swiper_manufacture .slide,
    .works_quality .swiper_manufacture .slide {
      width: 360px;
      height: 240px; }
      @media (max-width: 767px) {
        .works_manufacture .swiper_manufacture .slide,
        .works_engineering .swiper_manufacture .slide,
        .works_quality .swiper_manufacture .slide {
          width: 180px;
          height: 120px; } }
      .works_manufacture .swiper_manufacture .slide img,
      .works_engineering .swiper_manufacture .slide img,
      .works_quality .swiper_manufacture .slide img {
        width: 360px;
        height: 240px; }
        @media (max-width: 767px) {
          .works_manufacture .swiper_manufacture .slide img,
          .works_engineering .swiper_manufacture .slide img,
          .works_quality .swiper_manufacture .slide img {
            width: 180px;
            height: 120px; } }
    @media (max-width: 480px) {
      .works_manufacture .swiper_manufacture,
      .works_engineering .swiper_manufacture,
      .works_quality .swiper_manufacture {
        margin-top: 20px; } }
    .works_manufacture .swiper_manufacture.slide_eng,
    .works_engineering .swiper_manufacture.slide_eng,
    .works_quality .swiper_manufacture.slide_eng {
      width: 450%; }

@-webkit-keyframes move-left {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0); }
  100% {
    -webkit-transform: translateX(-25%);
            transform: translateX(-25%); } }

@keyframes move-left {
  0% {
    -webkit-transform: translateX(0);
            transform: translateX(0); }
  100% {
    -webkit-transform: translateX(-25%);
            transform: translateX(-25%); } }
  .works_manufacture .works_contents,
  .works_engineering .works_contents,
  .works_quality .works_contents {
    background: url(../img/WORKS/work_content_bg@2x.jpg) no-repeat center center;
    background-size: cover;
    width: 100vw;
    height: 704px;
    content: "";
    margin-top: -8px; }
    @media (max-width: 1024px) {
      .works_manufacture .works_contents,
      .works_engineering .works_contents,
      .works_quality .works_contents {
        height: auto;
        padding-bottom: 32px; } }
    .works_manufacture .works_contents.qual,
    .works_engineering .works_contents.qual,
    .works_quality .works_contents.qual {
      height: 808px; }
      @media (max-width: 1024px) {
        .works_manufacture .works_contents.qual,
        .works_engineering .works_contents.qual,
        .works_quality .works_contents.qual {
          height: auto; } }
    .works_manufacture .works_contents h4,
    .works_engineering .works_contents h4,
    .works_quality .works_contents h4 {
      text-align: center;
      font-size: 32px;
      line-height: 46px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em;
      padding-top: 64px; }
      @media (max-width: 767px) {
        .works_manufacture .works_contents h4,
        .works_engineering .works_contents h4,
        .works_quality .works_contents h4 {
          padding-top: 32px; } }
      @media (max-width: 480px) {
        .works_manufacture .works_contents h4,
        .works_engineering .works_contents h4,
        .works_quality .works_contents h4 {
          font-size: 24px;
          line-height: 35px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }
    .works_manufacture .works_contents .work_tab_flex,
    .works_engineering .works_contents .work_tab_flex,
    .works_quality .works_contents .work_tab_flex {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: justify;
          -ms-flex-pack: justify;
              justify-content: space-between;
      margin-top: 33px; }
      @media (max-width: 1024px) {
        .works_manufacture .works_contents .work_tab_flex,
        .works_engineering .works_contents .work_tab_flex,
        .works_quality .works_contents .work_tab_flex {
          display: block; } }
      @media (max-width: 767px) {
        .works_manufacture .works_contents .work_tab_flex,
        .works_engineering .works_contents .work_tab_flex,
        .works_quality .works_contents .work_tab_flex {
          margin-top: 16px; } }
      .works_manufacture .works_contents .work_tab_flex .tab_area,
      .works_engineering .works_contents .work_tab_flex .tab_area,
      .works_quality .works_contents .work_tab_flex .tab_area {
        background: #fff;
        width: 47.9%;
        height: 497px; }
        @media (max-width: 1024px) {
          .works_manufacture .works_contents .work_tab_flex .tab_area,
          .works_engineering .works_contents .work_tab_flex .tab_area,
          .works_quality .works_contents .work_tab_flex .tab_area {
            width: 100%;
            height: auto; } }
        .works_manufacture .works_contents .work_tab_flex .tab_area.qual,
        .works_engineering .works_contents .work_tab_flex .tab_area.qual,
        .works_quality .works_contents .work_tab_flex .tab_area.qual {
          height: 600px; }
          @media (max-width: 1024px) {
            .works_manufacture .works_contents .work_tab_flex .tab_area.qual,
            .works_engineering .works_contents .work_tab_flex .tab_area.qual,
            .works_quality .works_contents .work_tab_flex .tab_area.qual {
              height: auto; } }
        .works_manufacture .works_contents .work_tab_flex .tab_area .caution,
        .works_engineering .works_contents .work_tab_flex .tab_area .caution,
        .works_quality .works_contents .work_tab_flex .tab_area .caution {
          color: #E20401;
          font-size: 12px;
          line-height: 17px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em;
          text-align: center;
          margin-top: 64px; }
          @media (max-width: 1024px) {
            .works_manufacture .works_contents .work_tab_flex .tab_area .caution,
            .works_engineering .works_contents .work_tab_flex .tab_area .caution,
            .works_quality .works_contents .work_tab_flex .tab_area .caution {
              margin-top: 0;
              padding-top: 22px; } }
          .works_manufacture .works_contents .work_tab_flex .tab_area .caution.engineering_caution,
          .works_engineering .works_contents .work_tab_flex .tab_area .caution.engineering_caution,
          .works_quality .works_contents .work_tab_flex .tab_area .caution.engineering_caution {
            margin-top: 40px; }
            @media (max-width: 1024px) {
              .works_manufacture .works_contents .work_tab_flex .tab_area .caution.engineering_caution,
              .works_engineering .works_contents .work_tab_flex .tab_area .caution.engineering_caution,
              .works_quality .works_contents .work_tab_flex .tab_area .caution.engineering_caution {
                margin-top: 0;
                padding-top: 22px; } }
        .works_manufacture .works_contents .work_tab_flex .tab_area .ilust,
        .works_engineering .works_contents .work_tab_flex .tab_area .ilust,
        .works_quality .works_contents .work_tab_flex .tab_area .ilust {
          width: 100%;
          height: 238px;
          margin-top: 30px; }
          @media (max-width: 1024px) {
            .works_manufacture .works_contents .work_tab_flex .tab_area .ilust,
            .works_engineering .works_contents .work_tab_flex .tab_area .ilust,
            .works_quality .works_contents .work_tab_flex .tab_area .ilust {
              width: inherit;
              height: inherit; } }
          .works_manufacture .works_contents .work_tab_flex .tab_area .ilust .engineering_illust,
          .works_engineering .works_contents .work_tab_flex .tab_area .ilust .engineering_illust,
          .works_quality .works_contents .work_tab_flex .tab_area .ilust .engineering_illust {
            margin-top: 15px; }
        .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex,
        .works_engineering .works_contents .work_tab_flex .tab_area .button_flex,
        .works_quality .works_contents .work_tab_flex .tab_area .button_flex {
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-pack: start;
              -ms-flex-pack: start;
                  justify-content: flex-start;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center;
          -webkit-column-gap: 8px;
                  column-gap: 8px;
          margin-top: 30px; }
          .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex.engineering_btn,
          .works_engineering .works_contents .work_tab_flex .tab_area .button_flex.engineering_btn,
          .works_quality .works_contents .work_tab_flex .tab_area .button_flex.engineering_btn {
            margin-top: 13px; }
          .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex.qual_btn,
          .works_engineering .works_contents .work_tab_flex .tab_area .button_flex.qual_btn,
          .works_quality .works_contents .work_tab_flex .tab_area .button_flex.qual_btn {
            margin-top: 16px; }
          .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex .button,
          .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button,
          .works_quality .works_contents .work_tab_flex .tab_area .button_flex .button {
            width: 200px;
            height: 40px;
            border-radius: 100vh;
            background: black;
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-pack: start;
                -ms-flex-pack: start;
                    justify-content: flex-start;
            -webkit-box-align: center;
                -ms-flex-align: center;
                    align-items: center;
            -webkit-box-pack: center;
                -ms-flex-pack: center;
                    justify-content: center;
            cursor: pointer; }
            .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex .button#quality_guarantee,
            .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button#quality_guarantee,
            .works_quality .works_contents .work_tab_flex .tab_area .button_flex .button#quality_guarantee {
              margin: 0 auto;
              margin-bottom: 8px; }
            @media (max-width: 767px) {
              .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex .button,
              .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button,
              .works_quality .works_contents .work_tab_flex .tab_area .button_flex .button {
                width: 47%; } }
            .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex .button span,
            .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button span,
            .works_quality .works_contents .work_tab_flex .tab_area .button_flex .button span {
              color: #fff;
              font-size: 16px;
              line-height: 24px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700;
              letter-spacing: 0.04em; }
              @media (max-width: 480px) {
                .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex .button span,
                .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button span,
                .works_quality .works_contents .work_tab_flex .tab_area .button_flex .button span {
                  font-size: 13px;
                  line-height: 20px;
                  font-family: noto-sans-cjk-jp, sans-serif;
                  font-family: 'Noto Sans JP', sans-serif;
                  font-weight: 700; } }
            .works_manufacture .works_contents .work_tab_flex .tab_area .button_flex .button.bg_red,
            .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button.bg_red,
            .works_quality .works_contents .work_tab_flex .tab_area .button_flex .button.bg_red {
              background: #E20401; }
      .works_manufacture .works_contents .work_tab_flex .arrows img,
      .works_engineering .works_contents .work_tab_flex .arrows img,
      .works_quality .works_contents .work_tab_flex .arrows img {
        width: 12px;
        height: 28px; }
      @media (max-width: 1024px) {
        .works_manufacture .works_contents .work_tab_flex .arrows,
        .works_engineering .works_contents .work_tab_flex .arrows,
        .works_quality .works_contents .work_tab_flex .arrows {
          text-align: center; }
          .works_manufacture .works_contents .work_tab_flex .arrows img,
          .works_engineering .works_contents .work_tab_flex .arrows img,
          .works_quality .works_contents .work_tab_flex .arrows img {
            -webkit-transform: rotate(90deg);
                    transform: rotate(90deg);
            height: 12px;
            width: 28px;
            height: 64px; } }
      @media (max-width: 767px) {
        .works_manufacture .works_contents .work_tab_flex .arrows img,
        .works_engineering .works_contents .work_tab_flex .arrows img,
        .works_quality .works_contents .work_tab_flex .arrows img {
          height: 36px; } }
      .works_manufacture .works_contents .work_tab_flex .tab_content_area,
      .works_engineering .works_contents .work_tab_flex .tab_content_area,
      .works_quality .works_contents .work_tab_flex .tab_content_area {
        width: 47.9%;
        height: 497px;
        background: #E20401; }
        @media (max-width: 1024px) {
          .works_manufacture .works_contents .work_tab_flex .tab_content_area,
          .works_engineering .works_contents .work_tab_flex .tab_content_area,
          .works_quality .works_contents .work_tab_flex .tab_content_area {
            width: 100%;
            height: auto;
            padding-bottom: 1px; } }
        .works_manufacture .works_contents .work_tab_flex .tab_content_area.qual,
        .works_engineering .works_contents .work_tab_flex .tab_content_area.qual,
        .works_quality .works_contents .work_tab_flex .tab_content_area.qual {
          height: 600px; }
          @media (max-width: 1024px) {
            .works_manufacture .works_contents .work_tab_flex .tab_content_area.qual,
            .works_engineering .works_contents .work_tab_flex .tab_content_area.qual,
            .works_quality .works_contents .work_tab_flex .tab_content_area.qual {
              width: 100%;
              height: auto; } }
        .works_manufacture .works_contents .work_tab_flex .tab_content_area .contents,
        .works_engineering .works_contents .work_tab_flex .tab_content_area .contents,
        .works_quality .works_contents .work_tab_flex .tab_content_area .contents {
          display: none; }
        .works_manufacture .works_contents .work_tab_flex .tab_content_area .show,
        .works_engineering .works_contents .work_tab_flex .tab_content_area .show,
        .works_quality .works_contents .work_tab_flex .tab_content_area .show {
          display: block; }
        .works_manufacture .works_contents .work_tab_flex .tab_content_area h5,
        .works_engineering .works_contents .work_tab_flex .tab_content_area h5,
        .works_quality .works_contents .work_tab_flex .tab_content_area h5 {
          font-size: 24px;
          line-height: 35px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em;
          color: #fff;
          text-align: center;
          margin-top: 33px; }
          @media (max-width: 1024px) {
            .works_manufacture .works_contents .work_tab_flex .tab_content_area h5,
            .works_engineering .works_contents .work_tab_flex .tab_content_area h5,
            .works_quality .works_contents .work_tab_flex .tab_content_area h5 {
              margin-top: 0;
              padding-top: 32px; } }
          @media (max-width: 480px) {
            .works_manufacture .works_contents .work_tab_flex .tab_content_area h5,
            .works_engineering .works_contents .work_tab_flex .tab_content_area h5,
            .works_quality .works_contents .work_tab_flex .tab_content_area h5 {
              font-size: 17px;
              line-height: 23px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700;
              padding-top: 16px; } }
        .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_pic,
        .works_engineering .works_contents .work_tab_flex .tab_content_area .content_pic,
        .works_quality .works_contents .work_tab_flex .tab_content_area .content_pic {
          margin-left: 15px;
          margin-right: 15px;
          margin-top: 16px; }
        .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details,
        .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details,
        .works_quality .works_contents .work_tab_flex .tab_content_area .content_details {
          background: #fff;
          padding: 30px 20px;
          margin-bottom: 40px;
          margin-left: 15px;
          margin-right: 15px;
          margin-top: -8px;
          height: 172px; }
          @media (max-width: 1024px) {
            .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details,
            .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details,
            .works_quality .works_contents .work_tab_flex .tab_content_area .content_details {
              height: auto;
              margin-bottom: 16px; } }
          .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details.qual_details,
          .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details.qual_details,
          .works_quality .works_contents .work_tab_flex .tab_content_area .content_details.qual_details {
            height: 274px;
            display: -webkit-box;
            display: -ms-flexbox;
            display: flex;
            -webkit-box-pack: start;
                -ms-flex-pack: start;
                    justify-content: flex-start;
            -webkit-box-align: center;
                -ms-flex-align: center;
                    align-items: center;
            -webkit-box-pack: center;
                -ms-flex-pack: center;
                    justify-content: center;
            -webkit-box-orient: vertical;
            -webkit-box-direction: normal;
                -ms-flex-direction: column;
                    flex-direction: column; }
            @media (max-width: 1024px) {
              .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details.qual_details,
              .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details.qual_details,
              .works_quality .works_contents .work_tab_flex .tab_content_area .content_details.qual_details {
                height: auto;
                margin-bottom: 16px; } }
          .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details ul li,
          .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details ul li,
          .works_quality .works_contents .work_tab_flex .tab_content_area .content_details ul li {
            background: url(../img/WORKS/list_circle.svg) left 0px top 6px no-repeat;
            background-size: 16px auto;
            font-size: 16px;
            line-height: 24px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            letter-spacing: 0.04em;
            padding-left: 28px; }
            @media (max-width: 1024px) {
              .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details ul li,
              .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details ul li,
              .works_quality .works_contents .work_tab_flex .tab_content_area .content_details ul li {
                background-position: left 0px top 3px; } }
            @media (max-width: 480px) {
              .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details ul li,
              .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details ul li,
              .works_quality .works_contents .work_tab_flex .tab_content_area .content_details ul li {
                font-size: 13px;
                line-height: 20px;
                font-family: noto-sans-cjk-jp, sans-serif;
                font-family: 'Noto Sans JP', sans-serif;
                font-weight: 700; } }
            .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details ul li:not(:first-of-type),
            .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details ul li:not(:first-of-type),
            .works_quality .works_contents .work_tab_flex .tab_content_area .content_details ul li:not(:first-of-type) {
              margin-top: 16px; }
            .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details ul li span,
            .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details ul li span,
            .works_quality .works_contents .work_tab_flex .tab_content_area .content_details ul li span {
              font-size: 14px;
              line-height: 20px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 500; }
              @media (max-width: 480px) {
                .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details ul li span,
                .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details ul li span,
                .works_quality .works_contents .work_tab_flex .tab_content_area .content_details ul li span {
                  font-size: 12px;
                  line-height: 19px;
                  font-family: noto-sans-cjk-jp, sans-serif;
                  font-family: 'Noto Sans JP', sans-serif;
                  font-weight: 700; } }
          .works_manufacture .works_contents .work_tab_flex .tab_content_area .content_details .details_caution,
          .works_engineering .works_contents .work_tab_flex .tab_content_area .content_details .details_caution,
          .works_quality .works_contents .work_tab_flex .tab_content_area .content_details .details_caution {
            font-size: 12px;
            line-height: 17px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 400;
            margin-top: 20px; }

.works_engineering .works_contents .work_tab_flex .tab_area .button_flex {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column; }
  .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button {
    width: 332px !important;
    height: 40px !important; }
    .works_engineering .works_contents .work_tab_flex .tab_area .button_flex .button:not(:first-of-type) {
      margin-top: 8px; }

.voice {
  background: url(../img/WORKS/voices_bg@2x.jpg) no-repeat center center;
  background-size: cover;
  width: 100vw;
  height: 658px;
  content: ""; }
  @media (max-width: 767px) {
    .voice {
      height: auto;
      padding-bottom: 50px;
      background-position: center left 30%; } }
  .voice h2 {
    color: #fff;
    text-align: center;
    font-size: 32px;
    line-height: 48px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    padding-top: 100px; }
    @media (max-width: 767px) {
      .voice h2 {
        padding-top: 50px; } }
    @media (max-width: 480px) {
      .voice h2 {
        font-size: 24px;
        line-height: 35px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .voice .voice_flex {
    margin-top: 33px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    row-gap: 47px;
    -webkit-column-gap: 30px;
            column-gap: 30px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap; }
    @media (max-width: 1024px) {
      .voice .voice_flex {
        -webkit-column-gap: 3.125%;
                column-gap: 3.125%; } }
    .voice .voice_flex .bg_bubble {
      position: relative;
      width: 31.25%;
      height: 160px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      color: #333333;
      background: #fff;
      text-align: center; }
      @media (max-width: 767px) {
        .voice .voice_flex .bg_bubble {
          width: 47%; } }
      .voice .voice_flex .bg_bubble:before {
        position: absolute;
        background: url(../img/WORKS/bubble_arrow.svg) no-repeat;
        background-size: cover;
        width: 62px;
        height: 66px;
        content: "";
        bottom: -40px;
        right: 20px; }
      .voice .voice_flex .bg_bubble span {
        font-size: 16px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        letter-spacing: 0.04em; }
        @media (max-width: 480px) {
          .voice .voice_flex .bg_bubble span {
            font-size: 13px;
            line-height: 20px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            padding: 0 5px; } }

/*-- education --*/
.education_mv {
  background: url(../img/EDUCATION/education_mv_bg@2x.jpg) no-repeat center left 20%;
  background-size: cover;
  width: 100vw;
  height: 290px;
  content: ""; }
  @media (max-width: 767px) {
    .education_mv {
      background: url(../img/EDUCATION/education_mv_bg_sp@2x.jpg) no-repeat center center;
      background-size: cover;
      height: calc(0.565333333 * 100vw); } }
  .education_mv .mv_ttl {
    top: 35%; }
    .education_mv .mv_ttl h1 {
      font-size: 56px;
      line-height: 74px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      color: #fff; }
      @media (max-width: 480px) {
        .education_mv .mv_ttl h1 {
          font-size: 32px;
          line-height: 32px;
          font-family: roboto, sans-serif;
          font-weight: 900; } }
    .education_mv .mv_ttl .subtitle {
      font-size: 20px;
      line-height: 29px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: #fff; }
      @media (max-width: 480px) {
        .education_mv .mv_ttl .subtitle {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }

.edu_anker_area {
  padding: 40px 0; }
  @media (max-width: 767px) {
    .edu_anker_area {
      padding: 16px 0; } }
  .edu_anker_area .anker_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 30px;
            column-gap: 30px;
    row-gap: 17px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap; }
    @media (max-width: 1024px) {
      .edu_anker_area .anker_flex {
        -webkit-column-gap: 3.125%;
                column-gap: 3.125%; } }
    @media (max-width: 767px) {
      .edu_anker_area .anker_flex {
        -webkit-column-gap: 4.347826%;
                column-gap: 4.347826%; } }
    .edu_anker_area .anker_flex .anker_btn {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      width: 31.25%;
      height: 64px;
      border: 2px solid #111111; }
      @media (max-width: 767px) {
        .edu_anker_area .anker_flex .anker_btn {
          width: 47%; } }
      .edu_anker_area .anker_flex .anker_btn a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: 100%;
        height: 100%; }
        .edu_anker_area .anker_flex .anker_btn a .anker_title {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em;
          color: #333333; }
        .edu_anker_area .anker_flex .anker_btn a .btn_small {
          width: 100%;
          height: auto;
          border: none;
          border-radius: 0;
          overflow: inherit; }
          .edu_anker_area .anker_flex .anker_btn a .btn_small:before {
            display: none; }
          .edu_anker_area .anker_flex .anker_btn a .btn_small:after {
            right: 50%;
            -webkit-transform: rotate(90deg);
                    transform: rotate(90deg);
            top: inherit;
            bottom: -5px; }
          .edu_anker_area .anker_flex .anker_btn a .btn_small span {
            font-size: 14px;
            line-height: 19px;
            font-family: roboto, sans-serif;
            font-weight: 700;
            margin-left: -8px; }
            @media (max-width: 480px) {
              .edu_anker_area .anker_flex .anker_btn a .btn_small span {
                font-size: 11px;
                line-height: 15px;
                font-family: roboto, sans-serif;
                font-weight: 700; } }

.training:not(:first-of-type) {
  margin-top: 48px; }
  @media (max-width: 767px) {
    .training:not(:first-of-type) {
      margin-top: 24px; } }

.training .training_title {
  background: #E20401;
  width: 100%;
  height: 56px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  color: #fff;
  font-size: 24px;
  line-height: 35px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  padding: 0 32px; }
  @media (max-width: 480px) {
    .training .training_title {
      font-size: 17px;
      line-height: 25px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      padding: 0 16px;
      height: 40px; } }

.training .training_role {
  font-size: 18px;
  line-height: 26px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-align: left;
  position: relative;
  margin-top: 24px; }
  @media (max-width: 480px) {
    .training .training_role {
      font-size: 16px;
      line-height: 22px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      margin-top: 12px; } }
  .training .training_role:nth-of-type(2) {
    margin-top: 40px; }
  .training .training_role:before {
    position: absolute;
    border-bottom: 2px solid #EEEEEE;
    max-width: 885px;
    width: 90%;
    height: 2px;
    content: "";
    right: 0px;
    top: 45%; }
    @media (max-width: 480px) {
      .training .training_role:before {
        width: 82%; } }

.training .training_flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-column-gap: 30px;
          column-gap: 30px;
  row-gap: 16px;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 9px; }
  @media (max-width: 1024px) {
    .training .training_flex {
      -webkit-column-gap: 3.125%;
              column-gap: 3.125%; } }
  @media (max-width: 767px) {
    .training .training_flex {
      -webkit-column-gap: 4.347826%;
              column-gap: 4.347826%; } }
  .training .training_flex .training_content {
    width: 31.25%;
    height: 64px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    border: 2px solid #dddddd;
    text-align: center; }
    @media (max-width: 767px) {
      .training .training_flex .training_content {
        width: 47%; } }
    .training .training_flex .training_content span {
      color: #333333;
      font-size: 16px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em; }
      @media (max-width: 480px) {
        .training .training_flex .training_content span {
          font-size: 13px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }

#skill .training_flex:first-of-type,
#self-enlightenment .training_flex:first-of-type,
#occupation .training_flex:first-of-type,
#theme .training_flex:first-of-type {
  margin-top: 24px; }

.edu_link {
  padding: 40px 0 80px; }
  @media (max-width: 480px) {
    .edu_link {
      padding: 20px 0 40px; } }
  .edu_link .link_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 20px;
            column-gap: 20px; }
    @media (max-width: 767px) {
      .edu_link .link_flex {
        display: block; } }
    @media (max-width: 480px) {
      .edu_link .link_flex {
        -webkit-column-gap: 10px;
                column-gap: 10px; } }
    .edu_link .link_flex .pamphlet {
      width: 380px;
      height: 200px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      border: 4px solid #DDDDDD; }
      @media (max-width: 1024px) {
        .edu_link .link_flex .pamphlet {
          padding: 0 3px; } }
      @media (max-width: 767px) {
        .edu_link .link_flex .pamphlet {
          padding: 0;
          width: 100%; } }
      .edu_link .link_flex .pamphlet:hover {
        border: 4px solid rgba(221, 221, 221, 0.16); }
      .edu_link .link_flex .pamphlet a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: 100%;
        height: 100%; }
        .edu_link .link_flex .pamphlet a:hover {
          opacity: 1; }
          .edu_link .link_flex .pamphlet a:hover .bgleft:before {
            -webkit-animation: move-in 0.3s forwards;
                    animation: move-in 0.3s forwards; }
            @media (max-width: 767px) {
              .edu_link .link_flex .pamphlet a:hover .bgleft:before {
                display: none; } }
          .edu_link .link_flex .pamphlet a:hover .bgleft:after {
            background: url(../img/TOP/white_right_icon.svg) no-repeat; }
            @media (max-width: 767px) {
              .edu_link .link_flex .pamphlet a:hover .bgleft:after {
                background: url(../img/TOP/red_right_arrow.svg) no-repeat; } }
          .edu_link .link_flex .pamphlet a:hover .bgleft span {
            color: #fff; }
            @media (max-width: 767px) {
              .edu_link .link_flex .pamphlet a:hover .bgleft span {
                color: #E20401; } }
      .edu_link .link_flex .pamphlet .pamph_flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        -webkit-column-gap: 20px;
                column-gap: 20px; }
        @media (max-width: 480px) {
          .edu_link .link_flex .pamphlet .pamph_flex {
            -webkit-column-gap: 10px;
                    column-gap: 10px;
            padding: 0 10px; } }
        .edu_link .link_flex .pamphlet .pamph_flex img {
          width: 115px;
          height: 162px; }
        .edu_link .link_flex .pamphlet .pamph_flex p {
          font-size: 13px;
          line-height: 19px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          color: #111111; }
      .edu_link .link_flex .pamphlet .btn_small {
        width: 200px;
        height: 48px;
        margin-top: 12px; }
        .edu_link .link_flex .pamphlet .btn_small:before {
          content: "";
          width: 100%;
          height: 100%;
          position: absolute;
          top: 0;
          left: -100%;
          background: #E20401;
          -webkit-animation: move-out 0.3s;
                  animation: move-out 0.3s;
          will-change: transform; }
          @media (max-width: 767px) {
            .edu_link .link_flex .pamphlet .btn_small:before {
              display: none; } }
        .edu_link .link_flex .pamphlet .btn_small:after {
          right: 24px;
          top: 45%; }
          @media (max-width: 767px) {
            .edu_link .link_flex .pamphlet .btn_small:after {
              top: 45%; } }
        @media (max-width: 767px) {
          .edu_link .link_flex .pamphlet .btn_small {
            border: none;
            width: 150px;
            position: absolute;
            right: 25px; } }
        @media (max-width: 480px) {
          .edu_link .link_flex .pamphlet .btn_small {
            right: 10px; } }
        .edu_link .link_flex .pamphlet .btn_small span {
          font-size: 16px;
          line-height: 32px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          letter-spacing: 0.04em; }
          @media (max-width: 767px) {
            .edu_link .link_flex .pamphlet .btn_small span {
              font-size: 11px;
              line-height: 20px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700; } }
    .edu_link .link_flex .mynavi_2023 {
      border: 4px solid #00A9EA;
      width: 560px;
      height: 200px;
      position: relative; }
      @media (max-width: 767px) {
        .edu_link .link_flex .mynavi_2023 {
          width: 100%;
          margin-top: 20px; } }
      @media (max-width: 480px) {
        .edu_link .link_flex .mynavi_2023 {
          height: 140px; } }
      .edu_link .link_flex .mynavi_2023:before {
        position: absolute;
        content: "";
        background: url(../img/TOP/black_right_arrow.svg) no-repeat;
        background-size: cover;
        width: 12px;
        height: 24px;
        top: 45%;
        right: 48px; }
        @media (max-width: 1024px) {
          .edu_link .link_flex .mynavi_2023:before {
            right: 24px; } }
        @media (max-width: 480px) {
          .edu_link .link_flex .mynavi_2023:before {
            width: 6px;
            height: 12px;
            right: 16px; } }
      .edu_link .link_flex .mynavi_2023:hover {
        border: 4px solid rgba(0, 169, 234, 0.16); }
      .edu_link .link_flex .mynavi_2023 a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: 100%;
        height: 100%;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
            -ms-flex-direction: column;
                flex-direction: column; }
        .edu_link .link_flex .mynavi_2023 a:hover {
          opacity: 1; }
      .edu_link .link_flex .mynavi_2023 p {
        font-size: 20px;
        line-height: 29px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        color: #111111;
        margin-top: 6px; }
        @media (max-width: 1024px) {
          .edu_link .link_flex .mynavi_2023 p {
            font-size: 16px;
            line-height: 24px; } }
        @media (max-width: 480px) {
          .edu_link .link_flex .mynavi_2023 p {
            font-size: 12px;
            line-height: 17px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700; } }
      .edu_link .link_flex .mynavi_2023 img {
        width: 305px;
        height: 57px; }
        @media (max-width: 1024px) {
          .edu_link .link_flex .mynavi_2023 img {
            width: 230px;
            height: 43px; } }
        @media (max-width: 480px) {
          .edu_link .link_flex .mynavi_2023 img {
            width: 240px;
            height: 60px; } }

/*-- our seven prionciples --*/
.our_seven_principles {
  padding-top: 100px;
  padding-bottom: 80px; }
  @media (max-width: 767px) {
    .our_seven_principles {
      padding-top: 50px;
      padding-bottom: 40px; } }
  .our_seven_principles .subtitle {
    font-size: 20px;
    line-height: 29px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-align: center;
    color: #333333; }
    @media (max-width: 480px) {
      .our_seven_principles .subtitle {
        font-size: 17px;
        line-height: 39px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .our_seven_principles h2 {
    font-size: 56px;
    line-height: 74px;
    font-family: roboto, sans-serif;
    font-weight: 900;
    letter-spacing: 0.04em;
    text-align: center;
    color: #333333; }
    @media (max-width: 767px) {
      .our_seven_principles h2 {
        font-size: 40px;
        line-height: 50px; } }
    @media (max-width: 480px) {
      .our_seven_principles h2 {
        font-size: 32px;
        line-height: 34px; } }
  .our_seven_principles .worksers_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    row-gap: 40px;
    -webkit-column-gap: 40px;
            column-gap: 40px;
    -webkit-column-gap: 4.166667%;
            column-gap: 4.166667%;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-top: 40px; }
    @media (max-width: 767px) {
      .our_seven_principles .worksers_flex {
        margin-top: 20px;
        row-gap: 15px; } }
  .our_seven_principles .workers_photo {
    width: 47.916667%;
    max-height: 280px;
    height: 100%;
    position: relative;
    overflow: hidden;
    aspect-ratio: 331/202; }
    .our_seven_principles .workers_photo img {
      -webkit-transition: 0.3s ease-in-out;
      transition: 0.3s ease-in-out;
      max-width: 460px;
      width: 100%;
      max-height: 280px;
      height: 100%;
      height: auto; }
    .our_seven_principles .workers_photo:hover img {
      -webkit-transform: scale(1.05);
              transform: scale(1.05);
      overflow: hidden; }
    .our_seven_principles .workers_photo a:hover {
      opacity: 1; }
    .our_seven_principles .workers_photo .workers_details {
      position: absolute;
      color: #fff;
      top: 80px;
      left: 24px;
      width: calc(100% - 48px); }
      @media (max-width: 1024px) {
        .our_seven_principles .workers_photo .workers_details {
          top: 50px;
          top: calc(0.215 * 100vw - 100px);
          left: 16px;
          width: calc(100% - 32px); } }
      @media (max-width: 767px) {
        .our_seven_principles .workers_photo .workers_details {
          top: inherit;
          left: 16px;
          bottom: 16px; } }
      @media (max-width: 480px) {
        .our_seven_principles .workers_photo .workers_details {
          left: 8px;
          width: calc(100% - 16px);
          bottom: 12px; } }
      .our_seven_principles .workers_photo .workers_details .workers_details_flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center; }
        .our_seven_principles .workers_photo .workers_details .workers_details_flex .num {
          margin-right: 8px; }
          @media (max-width: 480px) {
            .our_seven_principles .workers_photo .workers_details .workers_details_flex .num {
              margin-right: 3px;
              margin-bottom: -12px; } }
          .our_seven_principles .workers_photo .workers_details .workers_details_flex .num span {
            font-size: 80px;
            line-height: 106px;
            font-family: roboto, sans-serif;
            font-weight: 900;
            letter-spacing: 0.02em; }
            @media (max-width: 1024px) {
              .our_seven_principles .workers_photo .workers_details .workers_details_flex .num span {
                font-size: 42px;
                line-height: 55px;
                font-family: roboto, sans-serif;
                font-weight: 900; } }
            @media (max-width: 767px) {
              .our_seven_principles .workers_photo .workers_details .workers_details_flex .num span {
                font-size: 42px;
                line-height: 55px;
                font-family: roboto, sans-serif;
                font-weight: 900; } }
            @media (max-width: 480px) {
              .our_seven_principles .workers_photo .workers_details .workers_details_flex .num span {
                font-size: 24px;
                line-height: 24px; } }
        .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .en {
          font-size: 14px;
          line-height: 19px;
          font-family: roboto, sans-serif;
          font-weight: 900; }
          @media (max-width: 1024px) {
            .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .en {
              font-size: 9px;
              line-height: 11px;
              font-family: roboto, sans-serif;
              font-weight: 900; } }
          @media (max-width: 767px) {
            .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .en {
              font-size: 9px;
              line-height: 11px;
              font-family: roboto, sans-serif;
              font-weight: 900;
              -webkit-transform: scale(0.9);
                      transform: scale(0.9);
              -webkit-transform-origin: left top;
                      transform-origin: left top; } }
          @media (max-width: 480px) {
            .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .en {
              font-size: 10px;
              line-height: 10px;
              -webkit-transform: scale(0.8);
                      transform: scale(0.8);
              -webkit-transform-origin: left top;
                      transform-origin: left top; } }
        .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .ja {
          font-size: 34px;
          line-height: 49px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; }
          @media (max-width: 1024px) {
            .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .ja {
              font-size: 17px;
              line-height: 25px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700; } }
          @media (max-width: 767px) {
            .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .ja {
              font-size: 17px;
              line-height: 25px;
              font-family: noto-sans-cjk-jp, sans-serif;
              font-family: 'Noto Sans JP', sans-serif;
              font-weight: 700; } }
          @media (max-width: 480px) {
            .our_seven_principles .workers_photo .workers_details .workers_details_flex .instruction .ja {
              font-size: 16px;
              line-height: 16px; } }
      .our_seven_principles .workers_photo .workers_details .details_message {
        font-size: 20px;
        line-height: 29px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-bottom: 16px;
        border-bottom: 2px solid #fff; }
        @media (max-width: 1024px) {
          .our_seven_principles .workers_photo .workers_details .details_message {
            font-size: 14px;
            line-height: 22px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            padding-bottom: 8px; } }
        @media (max-width: 767px) {
          .our_seven_principles .workers_photo .workers_details .details_message {
            display: block;
            font-size: 10px;
            border-bottom: 0;
            line-height: 17px;
            padding-bottom: 0;
            margin-top: 0px; } }
        @media (max-width: 767px) {
          .our_seven_principles .workers_photo .workers_details .details_message {
            margin-top: 6px; } }
        @media (max-width: 480px) {
          .our_seven_principles .workers_photo .workers_details .details_message {
            display: none; } }
      .our_seven_principles .workers_photo .workers_details .details_career {
        padding-top: 8px;
        font-size: 13px;
        line-height: 19px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 500; }
        @media (max-width: 1024px) {
          .our_seven_principles .workers_photo .workers_details .details_career {
            white-space: nowrap;
            font-size: 10px;
            padding-top: 4px; } }
        @media (max-width: 767px) {
          .our_seven_principles .workers_photo .workers_details .details_career {
            display: none; } }

.our_seven_principles_details {
  background: #f5f5f5;
  padding-top: 72px;
  padding-bottom: 80px; }
  @media (max-width: 480px) {
    .our_seven_principles_details {
      padding-top: 32px;
      padding-bottom: 40px; } }
  .our_seven_principles_details .title_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    padding-bottom: 14px;
    border-bottom: 1px solid #DDDDDD; }
    @media (max-width: 767px) {
      .our_seven_principles_details .title_flex {
        position: relative;
        border-bottom: none; } }
    @media (max-width: 767px) {
      .our_seven_principles_details .title_flex .num {
        position: absolute;
        right: 0;
        top: 15%;
        z-index: 0; } }
    .our_seven_principles_details .title_flex .num span {
      font-size: 120px;
      line-height: 120px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      color: #333333;
      opacity: 0.05; }
      @media (max-width: 767px) {
        .our_seven_principles_details .title_flex .num span {
          font-size: 64px;
          line-height: 84px;
          font-family: roboto, sans-serif;
          font-weight: 900;
          letter-spacing: 0.04em; } }
  .our_seven_principles_details .subtitle {
    font-size: 14px;
    line-height: 20px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    color: #333333; }
    @media (max-width: 480px) {
      .our_seven_principles_details .subtitle {
        font-size: 12px;
        line-height: 17px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .our_seven_principles_details h2 {
    font-size: 40px;
    line-height: 53px;
    font-family: roboto, sans-serif;
    font-weight: 900;
    letter-spacing: 0.04em;
    color: #333333; }
    @media (max-width: 767px) {
      .our_seven_principles_details h2 {
        font-size: 24px;
        line-height: 34px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        letter-spacing: 0.075em;
        white-space: nowrap; } }
  .our_seven_principles_details .principles_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    margin-top: 48px; }
    @media (max-width: 767px) {
      .our_seven_principles_details .principles_flex {
        margin-top: 32px; } }
    @media (max-width: 480px) {
      .our_seven_principles_details .principles_flex {
        -webkit-box-pack: justify;
            -ms-flex-pack: justify;
                justify-content: space-between;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center; } }
    .our_seven_principles_details .principles_flex .instruction {
      max-width: 144px;
      width: 15%;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      opacity: 0;
      -webkit-transform: translate(-100px, 0px);
              transform: translate(-100px, 0px); }
      .our_seven_principles_details .principles_flex .instruction.is-animated {
        opacity: 1;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 300ms;
                transition-duration: 300ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transition-delay: 500ms;
                transition-delay: 500ms;
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
      .our_seven_principles_details .principles_flex .instruction .ja {
        font-size: 56px;
        line-height: 66px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        letter-spacing: 0.084em;
        -ms-writing-mode: tb-rl;
        -webkit-writing-mode: vertical-rl;
                writing-mode: vertical-rl;
        color: #E20401;
        margin-right: 12px; }
        @media (max-width: 767px) {
          .our_seven_principles_details .principles_flex .instruction .ja {
            font-size: 32px;
            line-height: 40px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            margin-right: 6px;
            letter-spacing: 0.2em; } }
      .our_seven_principles_details .principles_flex .instruction .en {
        font-size: 20px;
        line-height: 26px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        -webkit-writing-mode: vertical-rl;
            -ms-writing-mode: tb-rl;
                writing-mode: vertical-rl;
        color: #E20401; }
        @media (max-width: 767px) {
          .our_seven_principles_details .principles_flex .instruction .en {
            font-size: 12px;
            line-height: 16px;
            font-family: roboto, sans-serif;
            font-weight: 900; } }
    .our_seven_principles_details .principles_flex .principles_content {
      max-width: 816px;
      width: 85%;
      opacity: 0;
      -webkit-transform: translate(-100px, 0px);
              transform: translate(-100px, 0px); }
      .our_seven_principles_details .principles_flex .principles_content.is-animated {
        opacity: 1;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 300ms;
                transition-duration: 300ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transition-delay: 500ms;
                transition-delay: 500ms;
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
      @media (max-width: 480px) {
        .our_seven_principles_details .principles_flex .principles_content {
          max-width: inherit;
          width: 75.736%; } }
  .our_seven_principles_details .principles_message {
    border: 1px solid #E20401;
    padding: 24px;
    margin-top: 40px;
    background: #fff; }
    @media (max-width: 480px) {
      .our_seven_principles_details .principles_message {
        margin-top: 20px; } }
    .our_seven_principles_details .principles_message .principles_title {
      font-size: 20px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      color: #E20401; }
    .our_seven_principles_details .principles_message p {
      font-size: 14px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      margin-top: 16px; }
      .our_seven_principles_details .principles_message p span {
        font-weight: 700; }
  .our_seven_principles_details .people_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-align: end;
        -ms-flex-align: end;
            align-items: flex-end;
    margin-top: 32px; }
    .our_seven_principles_details .people_flex .photo {
      max-width: 160px; }
      @media (max-width: 480px) {
        .our_seven_principles_details .people_flex .photo {
          max-width: 80px; } }
    .our_seven_principles_details .people_flex .rightbox {
      margin-left: 35px;
      max-width: 623px;
      width: 76.161369%; }
      @media (max-width: 767px) {
        .our_seven_principles_details .people_flex .rightbox {
          margin-left: 20px; } }
      .our_seven_principles_details .people_flex .rightbox .role {
        font-size: 13px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 500; }
        @media (max-width: 480px) {
          .our_seven_principles_details .people_flex .rightbox .role {
            font-size: 11px; } }
      .our_seven_principles_details .people_flex .rightbox h3 {
        font-size: 32px;
        line-height: 32px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        padding-bottom: 10px;
        border-bottom: 1px solid #DDDDDD; }
        @media (max-width: 480px) {
          .our_seven_principles_details .people_flex .rightbox h3 {
            font-size: 24px;
            line-height: 24px;
            font-family: roboto, sans-serif;
            font-weight: 900;
            padding-bottom: 5px; } }
      .our_seven_principles_details .people_flex .rightbox .year {
        font-size: 12px;
        line-height: 24px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 400;
        margin-top: 16px;
        color: #666666; }
        @media (max-width: 480px) {
          .our_seven_principles_details .people_flex .rightbox .year {
            font-size: 10px;
            margin-top: 10px; } }
  @media (max-width: 767px) {
    .our_seven_principles_details .tab_mg_right {
      width: 96vw;
      margin: inherit;
      margin-left: auto; } }

.interview_area {
  background: #fff;
  padding-top: 82px;
  padding-bottom: 100px; }
  @media (max-width: 767px) {
    .interview_area {
      padding-top: 40px;
      padding-bottom: 50px; } }
  .interview_area .principles_content {
    margin-left: 15%; }
    @media (max-width: 767px) {
      .interview_area .principles_content {
        margin-left: 0; } }
    .interview_area .principles_content .title {
      font-size: 48px;
      line-height: 80px;
      font-family: shippori mincho, sans-serif;
      font-family: 'Shippori Mincho', serif;
      font-weight: 700;
      color: #E20401;
      opacity: 0;
      -webkit-transform: translate(-100px, 0px);
              transform: translate(-100px, 0px); }
      .interview_area .principles_content .title.is-animated {
        opacity: 1;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 300ms;
                transition-duration: 300ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transition-delay: 500ms;
                transition-delay: 500ms;
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
      @media (max-width: 480px) {
        .interview_area .principles_content .title {
          font-size: 28px;
          line-height: 1.7em;
          font-family: shippori mincho, sans-serif;
          font-family: 'Shippori Mincho', serif;
          font-weight: 700; } }
    .interview_area .principles_content .title_details {
      font-size: 20px;
      line-height: 40px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 500;
      margin-top: 45px; }
      @media (max-width: 480px) {
        .interview_area .principles_content .title_details {
          font-size: 16px;
          line-height: 34px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 500;
          font-size: 14px;
          line-height: 1.5;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 500;
          letter-spacing: 0.04em;
          margin-top: 22px; } }
    .interview_area .principles_content .interview_photo {
      margin-top: 72px; }
      @media (max-width: 480px) {
        .interview_area .principles_content .interview_photo {
          margin-top: 36px; } }
    .interview_area .principles_content .interview_details h4 {
      font-size: 14px;
      line-height: 28px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      color: #333333;
      position: relative;
      padding-left: 45px;
      margin-top: 72px;
      opacity: 0;
      -webkit-transform: translate(-100px, 0px);
              transform: translate(-100px, 0px); }
      .interview_area .principles_content .interview_details h4.is-animated {
        opacity: 1;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 300ms;
                transition-duration: 300ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transition-delay: 500ms;
                transition-delay: 500ms;
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
      @media (max-width: 480px) {
        .interview_area .principles_content .interview_details h4 {
          font-size: 12px;
          line-height: 17px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700;
          margin-top: 36px;
          padding-left: 35px; } }
      .interview_area .principles_content .interview_details h4:before {
        position: absolute;
        content: "#Q1";
        font-size: 64px;
        line-height: 84px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        color: #333333;
        opacity: 0.05;
        left: 0;
        top: -35px;
        opacity: 0;
        -webkit-transform: translate(-50px, 0px);
                transform: translate(-50px, 0px); }
        @media (max-width: 480px) {
          .interview_area .principles_content .interview_details h4:before {
            font-size: 40px;
            line-height: 53px;
            font-family: roboto, sans-serif;
            font-weight: 900;
            top: -20px; } }
      .interview_area .principles_content .interview_details h4.is-animated:before {
        opacity: 0.05;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 300ms;
                transition-duration: 300ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transition-delay: 500ms;
                transition-delay: 500ms;
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
      .interview_area .principles_content .interview_details h4.second:before {
        content: "#Q2"; }
      .interview_area .principles_content .interview_details h4.third:before {
        content: "#Q3"; }
      .interview_area .principles_content .interview_details h4.forth:before {
        content: "#Q4"; }
    .interview_area .principles_content .interview_details .interview_title {
      width: -webkit-fit-content;
      width: -moz-fit-content;
      width: fit-content;
      font-size: 24px;
      line-height: 48px;
      font-family: shippori mincho, sans-serif;
      font-family: 'Shippori Mincho', serif;
      font-weight: 700;
      color: #fff;
      padding: 4px 30px 5px 24px;
      margin-top: 16px;
      position: relative; }
      .interview_area .principles_content .interview_details .interview_title:nth-of-type(3) {
        margin-top: 0px; }
      .interview_area .principles_content .interview_details .interview_title.is-animated:before {
        -webkit-animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
                animation: bg 3s cubic-bezier(0.22, 1, 0.36, 1) forwards;
        background: #E20401;
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        -webkit-transform-origin: left center;
                transform-origin: left center; }
      .interview_area .principles_content .interview_details .interview_title span {
        font-size: 20px;
        line-height: 1.5em;
        font-family: shippori mincho, sans-serif;
        font-family: 'Shippori Mincho', serif;
        font-weight: 700;
        color: #fff;
        opacity: 0;
        -webkit-transform: translate(-45px, 0px);
                transform: translate(-45px, 0px);
        position: relative;
        z-index: 1; }
      .interview_area .principles_content .interview_details .interview_title.is-animated span {
        opacity: 1;
        -webkit-transform: translateY(0px);
                transform: translateY(0px);
        -webkit-transition-duration: 600ms;
                transition-duration: 600ms;
        -webkit-transition-property: opacity,-webkit-transform;
        transition-property: opacity,-webkit-transform;
        transition-property: transform,opacity;
        transition-property: transform,opacity,-webkit-transform;
        -webkit-transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
                transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
        -webkit-transition-delay: 500ms;
                transition-delay: 500ms;
        -webkit-transform: translate(0px, 0px);
                transform: translate(0px, 0px); }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(1) {
          -webkit-transition-delay: 525ms;
                  transition-delay: 525ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(2) {
          -webkit-transition-delay: 550ms;
                  transition-delay: 550ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(3) {
          -webkit-transition-delay: 575ms;
                  transition-delay: 575ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(4) {
          -webkit-transition-delay: 600ms;
                  transition-delay: 600ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(5) {
          -webkit-transition-delay: 625ms;
                  transition-delay: 625ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(6) {
          -webkit-transition-delay: 650ms;
                  transition-delay: 650ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(7) {
          -webkit-transition-delay: 675ms;
                  transition-delay: 675ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(8) {
          -webkit-transition-delay: 700ms;
                  transition-delay: 700ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(9) {
          -webkit-transition-delay: 725ms;
                  transition-delay: 725ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(10) {
          -webkit-transition-delay: 750ms;
                  transition-delay: 750ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(11) {
          -webkit-transition-delay: 775ms;
                  transition-delay: 775ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(12) {
          -webkit-transition-delay: 800ms;
                  transition-delay: 800ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(13) {
          -webkit-transition-delay: 825ms;
                  transition-delay: 825ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(14) {
          -webkit-transition-delay: 850ms;
                  transition-delay: 850ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(15) {
          -webkit-transition-delay: 875ms;
                  transition-delay: 875ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(16) {
          -webkit-transition-delay: 900ms;
                  transition-delay: 900ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(17) {
          -webkit-transition-delay: 925ms;
                  transition-delay: 925ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(18) {
          -webkit-transition-delay: 950ms;
                  transition-delay: 950ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(19) {
          -webkit-transition-delay: 975ms;
                  transition-delay: 975ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(20) {
          -webkit-transition-delay: 1000ms;
                  transition-delay: 1000ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(21) {
          -webkit-transition-delay: 1025ms;
                  transition-delay: 1025ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(22) {
          -webkit-transition-delay: 1050ms;
                  transition-delay: 1050ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(23) {
          -webkit-transition-delay: 1075ms;
                  transition-delay: 1075ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(24) {
          -webkit-transition-delay: 1100ms;
                  transition-delay: 1100ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(25) {
          -webkit-transition-delay: 1125ms;
                  transition-delay: 1125ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(26) {
          -webkit-transition-delay: 1150ms;
                  transition-delay: 1150ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(27) {
          -webkit-transition-delay: 1175ms;
                  transition-delay: 1175ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(28) {
          -webkit-transition-delay: 1200ms;
                  transition-delay: 1200ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(29) {
          -webkit-transition-delay: 1225ms;
                  transition-delay: 1225ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(30) {
          -webkit-transition-delay: 1250ms;
                  transition-delay: 1250ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(31) {
          -webkit-transition-delay: 1275ms;
                  transition-delay: 1275ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(32) {
          -webkit-transition-delay: 1300ms;
                  transition-delay: 1300ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(33) {
          -webkit-transition-delay: 1325ms;
                  transition-delay: 1325ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(34) {
          -webkit-transition-delay: 1350ms;
                  transition-delay: 1350ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(35) {
          -webkit-transition-delay: 1375ms;
                  transition-delay: 1375ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(36) {
          -webkit-transition-delay: 1400ms;
                  transition-delay: 1400ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(37) {
          -webkit-transition-delay: 1425ms;
                  transition-delay: 1425ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(38) {
          -webkit-transition-delay: 1450ms;
                  transition-delay: 1450ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(39) {
          -webkit-transition-delay: 1475ms;
                  transition-delay: 1475ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(40) {
          -webkit-transition-delay: 1500ms;
                  transition-delay: 1500ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(41) {
          -webkit-transition-delay: 1525ms;
                  transition-delay: 1525ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(42) {
          -webkit-transition-delay: 1550ms;
                  transition-delay: 1550ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(43) {
          -webkit-transition-delay: 1575ms;
                  transition-delay: 1575ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(44) {
          -webkit-transition-delay: 1600ms;
                  transition-delay: 1600ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(45) {
          -webkit-transition-delay: 1625ms;
                  transition-delay: 1625ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(46) {
          -webkit-transition-delay: 1650ms;
                  transition-delay: 1650ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(47) {
          -webkit-transition-delay: 1675ms;
                  transition-delay: 1675ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(48) {
          -webkit-transition-delay: 1700ms;
                  transition-delay: 1700ms; }
        .interview_area .principles_content .interview_details .interview_title.is-animated span:nth-child(49) {
          -webkit-transition-delay: 1725ms;
                  transition-delay: 1725ms; }
      @media (max-width: 480px) {
        .interview_area .principles_content .interview_details .interview_title {
          font-size: 20px;
          line-height: 1.5em;
          font-family: shippori mincho, sans-serif;
          font-family: 'Shippori Mincho', serif;
          font-weight: 700;
          padding: 2px 12px; }
          .interview_area .principles_content .interview_details .interview_title.smaller {
            font-size: 18px; } }
    .interview_area .principles_content .interview_details p {
      font-size: 16px;
      line-height: 28px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      color: #111111;
      margin-top: 32px; }
      @media (max-width: 480px) {
        .interview_area .principles_content .interview_details p {
          font-size: 14px;
          line-height: 24px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 400;
          margin-top: 16px; } }
    .interview_area .principles_content .back_interview_btn {
      width: 280px;
      height: 50px;
      background: #fff;
      border: 1px solid #111111;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      margin-top: 100px;
      margin-bottom: 80px; }
      @media (max-width: 480px) {
        .interview_area .principles_content .back_interview_btn {
          margin-top: 50px;
          margin-bottom: 40px; } }
      .interview_area .principles_content .back_interview_btn a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-pack: center;
            -ms-flex-pack: center;
                justify-content: center;
        width: 100%;
        height: 100%; }
        .interview_area .principles_content .back_interview_btn a span {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 500;
          letter-spacing: 0.08em;
          color: #333333;
          position: relative;
          padding-left: 16px; }
          .interview_area .principles_content .back_interview_btn a span:before {
            position: absolute;
            background: url(../img/PRINCIPLES/black_back_arrow.svg) no-repeat;
            background-size: cover;
            width: 6px;
            height: 12px;
            content: "";
            left: 0px;
            top: 5px; }

/*-- phase2_ carrer --*/
.career_mv {
  background: url(../img/CAREER/recruit_mv_bg@2x.jpg) no-repeat center left 20%;
  background-size: cover;
  width: 100vw;
  height: 290px;
  content: ""; }
  @media (max-width: 767px) {
    .career_mv {
      background: url(../img/EDUCATION/education_mv_bg_sp@2x.jpg) no-repeat center center;
      background-size: cover;
      height: calc(0.565333333 * 100vw); } }
  .career_mv .mv_ttl {
    top: 35%; }
    .career_mv .mv_ttl h1 {
      font-size: 56px;
      line-height: 74px;
      font-family: roboto, sans-serif;
      font-weight: 900;
      letter-spacing: 0.04em;
      color: #fff; }
      @media (max-width: 480px) {
        .career_mv .mv_ttl h1 {
          font-size: 32px;
          line-height: 32px;
          font-family: roboto, sans-serif;
          font-weight: 900; } }
    .career_mv .mv_ttl .subtitle {
      font-size: 20px;
      line-height: 29px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em;
      color: #fff; }
      @media (max-width: 480px) {
        .career_mv .mv_ttl .subtitle {
          font-size: 14px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }

.career_recruit {
  padding-top: 64px; }
  @media (max-width: 480px) {
    .career_recruit {
      padding-top: 24px; } }
  .career_recruit h2 {
    font-size: 48px;
    line-height: 63px;
    font-family: roboto, sans-serif;
    font-weight: 900;
    color: #E20401;
    letter-spacing: 0.04em; }
    @media (max-width: 480px) {
      .career_recruit h2 {
        font-size: 28px;
        line-height: 1.5;
        font-family: roboto, sans-serif;
        font-weight: 900; } }
  .career_recruit .subtitle {
    font-size: 16px;
    line-height: 24px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-align: center;
    color: #333333; }
    @media (max-width: 480px) {
      .career_recruit .subtitle {
        font-size: 14px;
        line-height: 20px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .career_recruit h3.recruit_areas {
    color: #E20401;
    font-size: 24px;
    line-height: 1.5;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    padding-bottom: 12px;
    border-bottom: 2px solid #E20401; }
    .career_recruit h3.recruit_areas:not(:first-of-type) {
      margin-top: 64px; }
      @media (max-width: 480px) {
        .career_recruit h3.recruit_areas:not(:first-of-type) {
          margin-top: 40px; } }
    .career_recruit h3.recruit_areas:first-of-type {
      margin-top: 35px; }
      @media (max-width: 480px) {
        .career_recruit h3.recruit_areas:first-of-type {
          margin-top: 24px; } }
    @media (max-width: 480px) {
      .career_recruit h3.recruit_areas {
        font-size: 16px;
        line-height: 20px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .career_recruit .recruit_details__box {
    display: none; }
  .career_recruit .recruit_content_box {
    border: 1px solid #DDDDDD;
    padding: 24px;
    margin-top: 20px; }
    @media (max-width: 480px) {
      .career_recruit .recruit_content_box {
        padding: 16px;
        margin-top: 8px; } }
    .career_recruit .recruit_content_box.open {
      padding: 24px 24px 40px 24px; }
      @media (max-width: 480px) {
        .career_recruit .recruit_content_box.open {
          padding: 16px 16px 32px 16px; } }
    .career_recruit .recruit_content_box .plant_name {
      font-size: 20px;
      line-height: 1.5;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em;
      position: relative;
      cursor: pointer; }
      @media (max-width: 480px) {
        .career_recruit .recruit_content_box .plant_name {
          font-size: 15px;
          line-height: 20px;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; } }
      .career_recruit .recruit_content_box .plant_name:after {
        position: absolute;
        right: 0;
        top: 25%;
        background: url(../img/CAREER/plus.svg) no-repeat;
        background-size: cover;
        width: 16px;
        height: 16px;
        content: ""; }
        @media (max-width: 480px) {
          .career_recruit .recruit_content_box .plant_name:after {
            width: 12px;
            height: 12px; } }
      .career_recruit .recruit_content_box .plant_name.open {
        padding-bottom: 8px;
        border-bottom: 1px solid #DDDDDD; }
        .career_recruit .recruit_content_box .plant_name.open:after {
          position: absolute;
          right: 0;
          top: 40%;
          background: url(../img/CAREER/minus.svg) no-repeat;
          background-size: cover;
          width: 16px;
          height: 2px;
          content: ""; }
          @media (max-width: 480px) {
            .career_recruit .recruit_content_box .plant_name.open:after {
              top: 30%;
              width: 12px; } }
  .career_recruit .recruit__content {
    padding-top: 16px; }
  .career_recruit .recruit__content--flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    padding: 16px 0;
    border-top: 1px solid #DDDDDD; }
    .career_recruit .recruit__content--flex:first-of-type {
      border-top: none; }
    .career_recruit .recruit__content--flex:last-of-type {
      border-bottom: 1px solid #DDDDDD; }
    .career_recruit .recruit__content--flex dt {
      width: 178px;
      font-size: 14px;
      line-height: 20px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 500;
      letter-spacing: 0.04em;
      color: #666666; }
      @media (max-width: 480px) {
        .career_recruit .recruit__content--flex dt {
          font-size: 12px;
          line-height: 1.4;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 500; } }
    .career_recruit .recruit__content--flex dd {
      font-size: 14px;
      line-height: 20px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      letter-spacing: 0.04em;
      width: 734px; }
      @media (max-width: 480px) {
        .career_recruit .recruit__content--flex dd {
          font-size: 12px;
          line-height: 1.4;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 500; } }

.career_interview {
  padding-top: 100px;
  padding-bottom: 80px; }
  @media (max-width: 480px) {
    .career_interview {
      padding-top: 64px;
      padding-bottom: 40px; } }
  .career_interview h2 {
    font-size: 48px;
    line-height: 63px;
    font-family: roboto, sans-serif;
    font-weight: 900;
    color: #E20401;
    letter-spacing: 0.04em; }
    @media (max-width: 480px) {
      .career_interview h2 {
        font-size: 28px;
        line-height: 1.5;
        font-family: roboto, sans-serif;
        font-weight: 900; } }
  .career_interview .subtitle {
    font-size: 16px;
    line-height: 24px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-align: center;
    color: #333333; }
    @media (max-width: 480px) {
      .career_interview .subtitle {
        font-size: 14px;
        line-height: 20px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .career_interview .interview_content_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-column-gap: 40px;
            column-gap: 40px;
    row-gap: 40px;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    margin-top: 32px; }
    @media (max-width: 1024px) {
      .career_interview .interview_content_flex {
        -webkit-column-gap: 4.166667%;
                column-gap: 4.166667%; } }
    @media (max-width: 480px) {
      .career_interview .interview_content_flex {
        display: block; } }
  .career_interview .interview_details__box {
    max-width: 460px;
    width: 47.916667%;
    max-height: 280px;
    height: 100%;
    overflow: hidden; }
    @media (max-width: 480px) {
      .career_interview .interview_details__box {
        max-width: inherit;
        width: 100%; }
        .career_interview .interview_details__box:not(:first-of-type) {
          margin-top: 24px; } }
  .career_interview .interview--bg {
    background-size: contain;
    width: 100%;
    aspect-ratio: 460/280;
    content: "";
    position: relative; }
    @media (max-width: 480px) {
      .career_interview .interview--bg {
        width: 92vw; } }
    .career_interview .interview--bg img {
      -webkit-transition: 0.3s ease-in-out;
      transition: 0.3s ease-in-out; }
      .career_interview .interview--bg img:hover {
        -webkit-transform: scale(1.05);
                transform: scale(1.05); }
        @media (max-width: 480px) {
          .career_interview .interview--bg img:hover {
            -webkit-transform: scale(1);
                    transform: scale(1); } }
    .career_interview .interview--bg:after {
      position: absolute;
      background: url(../img/CAREER/white_plus.svg) no-repeat;
      background-size: cover;
      width: 24px;
      height: 24px;
      content: "";
      right: 24px;
      top: 24px; }
      @media (max-width: 767px) {
        .career_interview .interview--bg:after {
          width: 16px;
          height: 16px;
          right: 16px;
          top: 16px; } }
    .career_interview .interview--bg .factory_badge {
      background: #E20401;
      width: 120px;
      height: 32px;
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      position: absolute;
      top: 20px;
      left: 0; }
      @media (max-width: 767px) {
        .career_interview .interview--bg .factory_badge {
          width: 100px;
          height: 24px;
          top: 12px; } }
      .career_interview .interview--bg .factory_badge span {
        color: #fff;
        font-size: 13px;
        line-height: 19px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 500; }
        @media (max-width: 767px) {
          .career_interview .interview--bg .factory_badge span {
            font-size: 12px; } }
    .career_interview .interview--bg .interview_title_area {
      color: #fff;
      width: calc(100% - 48px);
      position: absolute;
      bottom: 20px;
      left: 50%;
      transform: translateX(-50%);
      -webkit-transform: translateX(-50%); }
      @media (max-width: 767px) {
        .career_interview .interview--bg .interview_title_area {
          width: calc(100% - 24px);
          bottom: 24px; } }
      .career_interview .interview--bg .interview_title_area .interview_en--name {
        font-size: 11px;
        line-height: 15px;
        font-family: roboto, sans-serif;
        font-weight: 700; }
      .career_interview .interview--bg .interview_title_area .interview_name {
        font-size: 20px;
        line-height: 1.5;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        padding-bottom: 8px;
        border-bottom: 2px solid #fff; }
        @media (max-width: 767px) {
          .career_interview .interview--bg .interview_title_area .interview_name {
            font-size: 17px;
            line-height: 1.5;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 700;
            padding-bottom: 4px; } }
        @media (max-width: 480px) {
          .career_interview .interview--bg .interview_title_area .interview_name {
            border-bottom: 1px solid #fff; } }
      .career_interview .interview--bg .interview_title_area .interview_career {
        padding-top: 8px;
        font-size: 13px;
        line-height: 19px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 500; }
        @media (max-width: 767px) {
          .career_interview .interview--bg .interview_title_area .interview_career {
            font-size: 12px;
            padding-top: 4px; } }
  .career_interview .modal {
    height: 100vh; }
    .career_interview .modal .modal__content {
      background: #fff;
      max-width: 760px;
      width: 80vw;
      max-height: 900px;
      height: 80vh; }
      @media (max-width: 480px) {
        .career_interview .modal .modal__content {
          width: 89.333vw;
          top: 45%; } }
      .career_interview .modal .modal__content .popup-inner {
        width: 100%;
        padding: 40px;
        overflow: scroll;
        max-height: 828px;
        height: 100%; }
        @media (max-width: 1024px) {
          .career_interview .modal .modal__content .popup-inner {
            max-height: inherit; } }
        @media (max-width: 480px) {
          .career_interview .modal .modal__content .popup-inner {
            padding: 32px 16px; } }
      .career_interview .modal .modal__content .popup_flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: start;
            -ms-flex-pack: start;
                justify-content: flex-start;
        -webkit-box-align: center;
            -ms-flex-align: center;
                align-items: center;
        -webkit-box-align: start;
            -ms-flex-align: start;
                align-items: flex-start;
        -webkit-column-gap: 20px;
                column-gap: 20px;
        padding-bottom: 20px;
        border-bottom: 1px solid #DDD; }
        @media (max-width: 480px) {
          .career_interview .modal .modal__content .popup_flex {
            display: block;
            padding-bottom: 8px; } }
        .career_interview .modal .modal__content .popup_flex .right__box {
          max-width: 360px;
          width: 55%; }
          @media (max-width: 480px) {
            .career_interview .modal .modal__content .popup_flex .right__box {
              max-width: inherit;
              width: 100%; } }
        .career_interview .modal .modal__content .popup_flex .factory_badge {
          background: #E20401;
          width: 120px;
          height: 32px;
          display: -webkit-box;
          display: -ms-flexbox;
          display: flex;
          -webkit-box-pack: start;
              -ms-flex-pack: start;
                  justify-content: flex-start;
          -webkit-box-align: center;
              -ms-flex-align: center;
                  align-items: center;
          -webkit-box-pack: center;
              -ms-flex-pack: center;
                  justify-content: center; }
          @media (max-width: 767px) {
            .career_interview .modal .modal__content .popup_flex .factory_badge {
              width: 100px;
              height: 24px; } }
          .career_interview .modal .modal__content .popup_flex .factory_badge span {
            color: #fff;
            font-size: 13px;
            line-height: 24px;
            font-family: noto-sans-cjk-jp, sans-serif;
            font-family: 'Noto Sans JP', sans-serif;
            font-weight: 500; }
            @media (max-width: 767px) {
              .career_interview .modal .modal__content .popup_flex .factory_badge span {
                font-size: 12px; } }
        .career_interview .modal .modal__content .popup_flex .interview_catch {
          margin-top: 8px;
          font-size: 20px;
          line-height: 1.6;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 700; }
          @media (max-width: 767px) {
            .career_interview .modal .modal__content .popup_flex .interview_catch {
              font-size: 16px; } }
      .career_interview .modal .modal__content .left__img {
        width: 45%;
        max-width: 300px; }
        @media (max-width: 480px) {
          .career_interview .modal .modal__content .left__img {
            width: 100%;
            max-width: inherit; } }
        .career_interview .modal .modal__content .left__img img {
          width: 100%;
          aspect-ratio: 300/200;
          -o-object-fit: cover;
             object-fit: cover; }
          @media (max-width: 480px) {
            .career_interview .modal .modal__content .left__img img {
              width: 100%; } }
      .career_interview .modal .modal__content .interview_en--name {
        font-size: 11px;
        line-height: 15px;
        font-family: roboto, sans-serif;
        font-weight: 900;
        margin-top: 20px; }
      .career_interview .modal .modal__content .interview_name {
        font-size: 20px;
        line-height: 1.5;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; }
      .career_interview .modal .modal__content .interview_career {
        font-size: 13px;
        line-height: 19px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 500;
        margin-top: 8px; }
      .career_interview .modal .modal__content .questions {
        font-size: 17px;
        line-height: 1.5;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        margin-top: 25px; }
      .career_interview .modal .modal__content .answers {
        font-size: 14px;
        line-height: 1.75;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 400;
        margin-top: 12px; }
      .career_interview .modal .modal__content .close-btn {
        background: url(../img/CAREER/black_close_btn.svg) no-repeat;
        width: 72px;
        height: 72px;
        z-index: 100;
        top: -3%; }
        @media (max-width: 480px) {
          .career_interview .modal .modal__content .close-btn {
            width: 48px;
            height: 48px;
            background-size: cover; } }

.entry__btn {
  width: 272px;
  height: 64px;
  margin: 0 auto;
  margin-top: 40px;
  border: 2px solid #E20401;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  position: relative; }
  @media (max-width: 480px) {
    .entry__btn {
      height: 48px;
      margin-top: 24px; } }
  .entry__btn:after {
    position: absolute;
    right: 24px;
    top: 46%;
    content: "";
    background: url(../img/TOP/red_right_arrow.svg) no-repeat;
    width: 6px;
    height: 12px; }
    @media (max-width: 480px) {
      .entry__btn:after {
        top: 40%; } }
  .entry__btn a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    width: 100%;
    height: 100%; }
    .entry__btn a span {
      color: #E20401;
      font-size: 18px;
      line-height: 1.5;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 700;
      letter-spacing: 0.04em; }
      @media (max-width: 480px) {
        .entry__btn a span {
          font-size: 14px;
          line-height: 1.5;
          font-family: noto-sans-cjk-jp, sans-serif;
          font-family: 'Noto Sans JP', sans-serif;
          font-weight: 500; } }

/*-- entry --*/
.entry_inquire,
.entry_confirm {
  padding-top: 64px;
  padding-bottom: 100px; }
  @media (max-width: 480px) {
    .entry_inquire,
    .entry_confirm {
      padding-top: 24px;
      padding-bottom: 40px; } }
  .entry_inquire h1,
  .entry_confirm h1 {
    font-size: 48px;
    line-height: 63px;
    font-family: roboto, sans-serif;
    font-weight: 900;
    color: #E20401;
    letter-spacing: 0.04em; }
    @media (max-width: 480px) {
      .entry_inquire h1,
      .entry_confirm h1 {
        font-size: 28px;
        line-height: 1.5;
        font-family: roboto, sans-serif;
        font-weight: 900; } }
  .entry_inquire .subtitle,
  .entry_confirm .subtitle {
    font-size: 16px;
    line-height: 24px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-align: center;
    color: #333333; }
    @media (max-width: 480px) {
      .entry_inquire .subtitle,
      .entry_confirm .subtitle {
        font-size: 14px;
        line-height: 20px;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700; } }
  .entry_inquire h3,
  .entry_confirm h3 {
    font-size: 20px;
    line-height: 2.5;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-align: center;
    margin-top: 32px;
    color: #333333; }
    @media (max-width: 767px) {
      .entry_inquire h3,
      .entry_confirm h3 {
        font-size: 17px;
        line-height: 1.5;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 700;
        margin-top: 16px; } }
  .entry_inquire p,
  .entry_confirm p {
    text-align: center;
    margin-top: 20px; }
    .entry_inquire p small,
    .entry_confirm p small {
      font-size: 14px;
      line-height: 2;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      letter-spacing: 0.04em;
      color: #333333; }
      @media (max-width: 480px) {
        .entry_inquire p small,
        .entry_confirm p small {
          font-size: 12px; } }

.entry_confirm .form_area .form_flex {
  padding: 45px 0; }
  @media (max-width: 767px) {
    .entry_confirm .form_area .form_flex {
      line-height: 1em; } }
  @media (max-width: 1024px) {
    .entry_confirm .form_area .form_flex {
      padding: 24px 0; } }
  @media (max-width: 480px) {
    .entry_confirm .form_area .form_flex.btn_area {
      display: block;
      margin-top: 32px; } }
  @media (max-width: 767px) {
    .entry_confirm .form_area .form_flex .hankaku {
      color: #E20401;
      font-size: 12px;
      line-height: 1em; } }
  @media (max-width: 767px) {
    .entry_confirm .form_area .form_flex .right_box.form_flex {
      line-height: 1rem; } }
  @media (max-width: 767px) {
    .entry_confirm .form_area .form_flex .right_box div {
      line-height: 1rem; } }

.form_area {
  margin-top: 40px; }
  @media (max-width: 480px) {
    .form_area {
      margin-top: 32px; } }
  .form_area .form_flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    align-items: center;
    text-align: left;
    padding: 30px 0;
    border-top: 1px solid #DDDDDD;
    margin-bottom: 0; }
    @media (max-width: 1024px) {
      .form_area .form_flex {
        display: block;
        padding: 20px 0; } }
    .form_area .form_flex .left_box {
      width: 23.7%;
      position: relative;
      padding-left: 20px; }
      .form_area .form_flex .left_box .item {
        color: #333333;
        font-weight: 700; }
      @media (max-width: 1024px) {
        .form_area .form_flex .left_box {
          width: 100%;
          margin-bottom: 8px;
          padding-left: 0; } }
      @media (max-width: 480px) {
        .form_area .form_flex .left_box {
          margin-bottom: 15px; } }
    .form_area .form_flex input[type="text"],
    .form_area .form_flex input[type="email"],
    .form_area .form_flex input[type="tel"],
    .form_area .form_flex textarea {
      width: 400px;
      background: #f5f5f5;
      padding: 15px 20px;
      color: #333333;
      font-size: 14px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 500;
      letter-spacing: 0.04em;
      border: 1px solid #DDDDDD; }
      @media (max-width: 480px) {
        .form_area .form_flex input[type="text"],
        .form_area .form_flex input[type="email"],
        .form_area .form_flex input[type="tel"],
        .form_area .form_flex textarea {
          padding: 12px; } }
      .form_area .form_flex input[type="text"]::-webkit-input-placeholder,
      .form_area .form_flex input[type="email"]::-webkit-input-placeholder,
      .form_area .form_flex input[type="tel"]::-webkit-input-placeholder,
      .form_area .form_flex textarea::-webkit-input-placeholder {
        color: #999999; }
      .form_area .form_flex input[type="text"]:-ms-input-placeholder,
      .form_area .form_flex input[type="email"]:-ms-input-placeholder,
      .form_area .form_flex input[type="tel"]:-ms-input-placeholder,
      .form_area .form_flex textarea:-ms-input-placeholder {
        color: #999999; }
      .form_area .form_flex input[type="text"]::-ms-input-placeholder,
      .form_area .form_flex input[type="email"]::-ms-input-placeholder,
      .form_area .form_flex input[type="tel"]::-ms-input-placeholder,
      .form_area .form_flex textarea::-ms-input-placeholder {
        color: #999999; }
      .form_area .form_flex input[type="text"]::placeholder,
      .form_area .form_flex input[type="email"]::placeholder,
      .form_area .form_flex input[type="tel"]::placeholder,
      .form_area .form_flex textarea::placeholder {
        color: #999999; }
      @media (max-width: 1024px) {
        .form_area .form_flex input[type="text"],
        .form_area .form_flex input[type="email"],
        .form_area .form_flex input[type="tel"],
        .form_area .form_flex textarea {
          width: 100%; } }
    .form_area .form_flex input[name="your-last-name"],
    .form_area .form_flex input[name="your-first-name"],
    .form_area .form_flex input[name="your-last-name-kana"],
    .form_area .form_flex input[name="your-first-name-kana"] {
      width: 140px;
      border: 1px solid #DDDDDD; }
      @media (max-width: 1024px) {
        .form_area .form_flex input[name="your-last-name"],
        .form_area .form_flex input[name="your-first-name"],
        .form_area .form_flex input[name="your-last-name-kana"],
        .form_area .form_flex input[name="your-first-name-kana"] {
          width: 37vw; } }
      @media screen and (max-width: 805px) {
        .form_area .form_flex input[name="your-last-name"],
        .form_area .form_flex input[name="your-first-name"],
        .form_area .form_flex input[name="your-last-name-kana"],
        .form_area .form_flex input[name="your-first-name-kana"] {
          width: 36.5vw; } }
      @media (max-width: 767px) {
        .form_area .form_flex input[name="your-last-name"],
        .form_area .form_flex input[name="your-first-name"],
        .form_area .form_flex input[name="your-last-name-kana"],
        .form_area .form_flex input[name="your-first-name-kana"] {
          width: calc(0.894 * 100vw - 50px); } }
    .form_area .form_flex select[name="your-occupation"] {
      width: 282px;
      background: #f5f5f5;
      padding: 15px 0 15px 20px;
      background-image: url(../img/CAREER/select_arrow.svg);
      background-repeat: no-repeat;
      background-size: 11px 5px;
      background-position: right 20px center;
      color: #333333;
      border: 1px solid #DDDDDD; }
      @media (max-width: 480px) {
        .form_area .form_flex select[name="your-occupation"] {
          padding: 12px 0 12px 12px; } }
      .form_area .form_flex select[name="your-occupation"] option {
        color: #333333; }
      @media (max-width: 1024px) {
        .form_area .form_flex select[name="your-occupation"] {
          width: calc(89.3vw); } }
      @media (max-width: 767px) {
        .form_area .form_flex select[name="your-occupation"] {
          width: 100%; } }
    .form_area .form_flex textarea {
      max-width: 825px;
      width: 100%;
      height: 240px;
      border: 1px solid #DDDDDD; }
    .form_area .form_flex .name {
      padding-right: 30px;
      color: #333333; }
      @media (max-width: 1024px) {
        .form_area .form_flex .name {
          padding-right: 10px;
          padding-right: 30px; } }
    .form_area .form_flex .kana-name {
      padding-right: 15px;
      color: #333333; }
    .form_area .form_flex .f-name {
      padding-left: 40px; }
      @media (max-width: 767px) {
        .form_area .form_flex .f-name {
          padding-left: 0; } }
    .form_area .form_flex .hankaku {
      padding-left: 20px;
      font-size: 14px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 0.04em;
      color: #333333; }
      @media (max-width: 1024px) {
        .form_area .form_flex .hankaku {
          padding-left: 0;
          display: block;
          margin-top: 8px; } }
    .form_area .form_flex .right_box {
      width: 76.3%; }
      @media (max-width: 1024px) {
        .form_area .form_flex .right_box {
          width: 100%;
          margin-bottom: 0px; } }
      @media (max-width: 480px) {
        .form_area .form_flex .right_box {
          margin-bottom: 5px; } }
      @media (max-width: 767px) {
        .form_area .form_flex .right_box .firstname {
          padding-top: 20px; } }
  .form_area .form_flex.btn_area {
    padding: 0;
    border: none;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    -webkit-column-gap: 30px;
            column-gap: 30px; }
    @media (max-width: 1024px) {
      .form_area .form_flex.btn_area {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex; } }
    @media (max-width: 480px) {
      .form_area .form_flex.btn_area .submit_btn {
        margin-top: 0;
        margin-top: 32px; } }
    .form_area .form_flex.btn_area .submit_btn.back {
      margin-right: 20px; }
      @media (max-width: 480px) {
        .form_area .form_flex.btn_area .submit_btn.back {
          margin-right: inherit;
          margin: 0 auto;
          margin-bottom: 16px; } }
      .form_area .form_flex.btn_area .submit_btn.back:before {
        top: 43%;
        right: inherit;
        left: 30px;
        -webkit-transform: rotate(180deg);
                transform: rotate(180deg); }
  .form_area .right_box.form_flex {
    border-top: none;
    padding: 0; }
    @media (max-width: 1024px) {
      .form_area .right_box.form_flex {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        padding: 0;
        margin-bottom: 0; } }
    @media (max-width: 767px) {
      .form_area .right_box.form_flex {
        display: block; } }
  .form_area .handling_title {
    text-align: center;
    font-size: 16px;
    line-height: 32px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 500;
    letter-spacing: 0.04em;
    margin-top: 60px;
    margin-bottom: 20px;
    color: #333333; }
    @media (max-width: 767px) {
      .form_area .handling_title {
        margin-top: 30px;
        margin-bottom: 15px; } }
  .form_area .handling {
    width: 100%;
    height: 200px;
    overflow: visible scroll;
    background: #fff;
    color: #333333;
    padding: 30px 50px 30px 30px;
    border: 2px solid #ddd; }
    @media (max-width: 767px) {
      .form_area .handling {
        padding: 10px; } }
    .form_area .handling p {
      font-size: 12px;
      line-height: 24px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      letter-spacing: 0.04em;
      text-align: left; }
      .form_area .handling p:first-of-type {
        margin-top: 0; }
  .form_area .form_flex.last {
    -webkit-box-align: start;
        -ms-flex-align: start;
            align-items: flex-start;
    border-bottom: 1px solid #DDDDDD; }
  .form_area .agreement {
    text-align: center;
    font-size: 14px;
    line-height: 32px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    margin-top: 48px; }
    .form_area .agreement input[type=checkbox] {
      margin-right: 12px;
      vertical-align: baseline; }
      @media (max-width: 480px) {
        .form_area .agreement input[type=checkbox] {
          margin-right: 6px; } }
    .form_area .agreement a {
      color: #333333;
      font-weight: bold;
      text-decoration: underline; }
    .form_area .agreement span {
      color: #333333; }
  .form_area .chapcha_detail {
    text-align: center;
    font-size: 14px;
    line-height: 24px;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    margin-top: 25px; }
  .form_area .back_btn {
    position: relative;
    width: 240px;
    height: 50px;
    margin-top: 50px; }
    .form_area .back_btn:before {
      position: absolute;
      background: url(../img/CAREER/white_arrow.svg) no-repeat;
      background-size: cover;
      width: 4px;
      height: 9px;
      content: "";
      top: 42%;
      left: 30px;
      -webkit-transform: rotate(180deg);
              transform: rotate(180deg); }
    .form_area .back_btn input[type="submit"] {
      width: 240px;
      height: 50px;
      background: #f5f5f5;
      color: #fff;
      margin: 0 auto;
      font-size: 14px;
      line-height: 20px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      letter-spacing: 0.08em; }
  .form_area .submit_btn {
    position: relative;
    width: 240px;
    height: 50px;
    margin-top: 64px; }
    @media (max-width: 480px) {
      .form_area .submit_btn {
        margin: 0 auto;
        margin-top: 32px; } }
    .form_area .submit_btn:before {
      position: absolute;
      top: 43%;
      right: 30px;
      background: url(../img/CAREER/white_arrow.svg) no-repeat;
      background-size: cover;
      content: "";
      width: 5px;
      height: 10px; }
    .form_area .submit_btn input[type="submit"] {
      width: 240px;
      height: 50px;
      background: #E20401;
      color: #fff;
      margin: 0 auto;
      font-size: 14px;
      line-height: 20px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      letter-spacing: 0.08em; }
    .form_area .submit_btn input[type="button"].back,
    .form_area .submit_btn input[type="submit"].input_back_btn {
      width: 240px;
      height: 50px;
      background: #666666;
      color: #fff;
      margin: 0 auto;
      font-size: 14px;
      line-height: 20px;
      font-family: noto-sans-cjk-jp, sans-serif;
      font-family: 'Noto Sans JP', sans-serif;
      font-weight: 400;
      letter-spacing: 0.08em;
      display: block !important; }

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.payment-required .wpcf7-response-output,
.wpcf7 form.failed .wpcf7-response-output,
.wpcf7 form.aborted .wpcf7-response-output {
  border: none;
  color: red;
  font-size: 14px;
  line-height: 24px;
  font-family: noto-sans-cjk-jp, sans-serif;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
  letter-spacing: 0.04em;
  padding: 0; }

.wpcf7-not-valid {
  border: 2px solid #E20401 !important;
  background: #FFD8D8 !important; }

.wpcf7-not-valid-tip {
  display: none !important; }

.mw_wp_form .error {
  display: none !important; }

.mw_wp_form_input .btn_area .submit_btn:first-of-type {
  display: none; }

.mw_wp_form_input .form_area .form_flex .error_red {
  border: 2px solid #E20401 !important;
  background: #FFD8D8 !important; }

.entry_complete {
  padding: 80px 0; }
  @media (max-width: 480px) {
    .entry_complete {
      padding: 40px 0; } }
  .entry_complete h1 {
    font-size: 20px;
    line-height: 2.5;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 700;
    letter-spacing: 0.08em; }
  .entry_complete p {
    font-size: 14px;
    line-height: 2;
    font-family: noto-sans-cjk-jp, sans-serif;
    font-family: 'Noto Sans JP', sans-serif;
    font-weight: 400;
    letter-spacing: 0.04em;
    margin-top: 24px; }
    @media (max-width: 480px) {
      .entry_complete p {
        text-align: left;
        margin-top: 16px;
        font-size: 12px; } }
  .entry_complete .toTop__btn {
    width: 240px;
    height: 50px;
    background: #666666;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin: 0 auto;
    margin-top: 48px;
    position: relative; }
    .entry_complete .toTop__btn:after {
      background: url(../img/CAREER/white_arrow.svg) no-repeat;
      background-size: cover;
      position: absolute;
      left: 30px;
      top: 40%;
      width: 4px;
      height: 9px;
      content: "";
      -webkit-transform: rotate(180deg);
              transform: rotate(180deg); }
    @media (max-width: 480px) {
      .entry_complete .toTop__btn {
        margin-top: 24px; } }
    .entry_complete .toTop__btn a {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: start;
          -ms-flex-pack: start;
              justify-content: flex-start;
      -webkit-box-align: center;
          -ms-flex-align: center;
              align-items: center;
      -webkit-box-pack: center;
          -ms-flex-pack: center;
              justify-content: center;
      width: 100%;
      height: 100%; }
      .entry_complete .toTop__btn a span {
        color: #fff;
        font-size: 14px;
        line-height: 1.7;
        font-family: noto-sans-cjk-jp, sans-serif;
        font-family: 'Noto Sans JP', sans-serif;
        font-weight: 400;
        letter-spacing: 0.08em; }

@-webkit-keyframes bg {
  0% {
    opacity: 0;
    -webkit-transform: scaleX(0) translateX(-5%);
            transform: scaleX(0) translateX(-5%); }
  30% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0); }
  100% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0); }
  30%, 100% {
    opacity: 1; } }

@keyframes bg {
  0% {
    opacity: 0;
    -webkit-transform: scaleX(0) translateX(-5%);
            transform: scaleX(0) translateX(-5%); }
  30% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0); }
  100% {
    -webkit-transform: scaleX(1) translateX(0);
            transform: scaleX(1) translateX(0); }
  30%, 100% {
    opacity: 1; } }
/*# sourceMappingURL=style.css.map */