@charset "utf-8";
/* ==========================================================================
   Foundation
   ========================================================================== */
:root {
  --color-text: #232323;
  --color-link: #052275;
  --color-primary: #052275;
  --color-secondary: #2637b3;
  --color-accent: #ffd800;
  --color-gray: #b5b5b6;
  --color-bg: #f3f4f7;
  --color-border: #efefef;
  --font: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  --font-en: "Jost", sans-serif;
  --font-mincho: "游明朝", "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", serif;
}
/*!
 * Sanitize 13.0.0 (https://github.com/csstools/sanitize.css)
 * Licensed under the CC0 1.0 Universal.
 */
*,:after,:before{-webkit-box-sizing:border-box;box-sizing:border-box}
:after,:before{text-decoration:inherit;vertical-align:inherit}
html{cursor:default;line-height:1.5;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-tap-highlight-color:rgba(0,0,0,0);-ms-text-size-adjust:100%;-webkit-text-size-adjust:100%;word-break:break-word}
body{margin:0}
h1{font-size:2em;margin:.67em 0}
dl dl,dl ol,dl ul,ol dl,ol ol,ol ul,ul dl,ul ol,ul ul{margin:0}
hr{height:0;overflow:visible}
main{display:block}
nav ol,nav ul{list-style:none;padding:0}
pre{font-family:monospace;font-size:1em}
a{background-color:transparent}
abbr[title]{text-decoration:underline;-webkit-text-decoration:underline;text-decoration:underline}
b,strong{font-weight:bolder}
code,kbd,samp{font-family:monospace;font-size:1em}
small{font-size:80%}
audio,canvas,iframe,img,svg,video{vertical-align:middle}
audio,video{display:inline-block}
audio:not([controls]){display:none;height:0}
iframe,img{border-style:none}
svg:not([fill]){fill:currentColor}
svg:not(:root){overflow:hidden}
table{border-collapse:collapse}
button,input,select{margin:0}
button{overflow:visible;text-transform:none}
[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}
fieldset{border:1px solid #a0a0a0;padding:.35em .75em .625em}
input{overflow:visible}
legend{color:inherit;display:table;max-width:100%;white-space:normal}
progress{display:inline-block;vertical-align:baseline}
select{text-transform:none}
textarea{margin:0;overflow:auto;resize:vertical}
[type=checkbox],[type=radio]{padding:0}
[type=search]{-webkit-appearance:textfield;outline-offset:-2px}
::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}
::-webkit-input-placeholder{color:inherit;opacity:.54}
::-webkit-search-decoration{-webkit-appearance:none}
::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}
::-moz-focus-inner{border-style:none;padding:0}
:-moz-focusring{outline:1px dotted ButtonText}
:-moz-ui-invalid{box-shadow:none}
details,dialog{display:block}
dialog{background-color:#fff;border:solid;color:#000;height:-moz-fit-content;height:-webkit-fit-content;height:fit-content;left:0;margin:auto;padding:1em;position:absolute;right:0;width:-moz-fit-content;width:-webkit-fit-content;width:fit-content}
dialog:not([open]){display:none}
summary{display:list-item}
canvas{display:inline-block}
template{display:none}
[tabindex],a,area,button,input,label,select,summary,textarea{-ms-touch-action:manipulation;touch-action:manipulation}
[hidden]{display:none}
[aria-busy=true]{cursor:progress}
[aria-controls]{cursor:pointer}
[aria-disabled=true],[disabled]{cursor:not-allowed}
[aria-hidden="false"][hidden]{display:inline}
[aria-hidden="false"][hidden]:not(:focus){clip:rect(0,0,0,0);position:absolute}
html {
  font-size: 62.5%;
}
body {
  overflow-x: hidden;
  background: #fff;
  color: #232323;
  font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  font-size: 1.5em;
  letter-spacing: 0.05em;
  line-height: 1.875;
}
a {
  color: #052275;
}
a:hover {
  -webkit-text-decoration: none;
  text-decoration: none;
}
/* Typography Base Setting */
h1,
h2,
h3,
h4,
h5,
h6 {
  margin: 0;
}
p,
ul,
ol {
  margin-top: 0;
  margin-bottom: 1em;
}
ol,
ul {
  padding-left: 2em;
}
ol {
  list-style: decimal outside none;
}
ul {
  list-style: disc outside none;
}
li ol,
li ul {
  margin-bottom: 0;
}
nav ol,
nav ul {
  list-style: none;
  padding-left: 0;
}
em {
  font-style: normal;
}
rp,
rt {
  line-height: 1;
  font-size: 0.688em;
}
table {
  empty-cells: show;
  font-size: 1em;
}
iframe {
  display: block;
  width: 100%;
}
img {
  height: auto;
}
img,
iframe,
button,
input,
select,
textarea {
  max-width: 100%;
}
figure {
  margin: 0;
}
textarea {
  height: auto;
  resize: vertical;
}
mark {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(55%, transparent), color-stop(55%, rgba(0, 61, 165, 0.3)));
  background: linear-gradient(transparent 55%, rgba(0, 61, 165, 0.3) 55%);
}
@font-face {
  font-family: 'icomoon';
  src:
    url('fonts/icomoon.ttf?8b7pho') format('truetype'),
    url('fonts/icomoon.woff?8b7pho') format('woff'),
    url('fonts/icomoon.svg?8b7pho#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
  font-display: block;
}
.icon {
  /* use !important to prevent issues with browser extensions that change fonts */
  font-family: 'icomoon' !important;
  speak: never;
  font-style: normal;
  font-weight: normal;
  -webkit-font-feature-settings: normal;
  font-feature-settings: normal;
  font-variant: normal;
  text-transform: none;
  line-height: 1;

  /* Better Font Rendering =========== */
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
.icon-tel:before {
  content: "\e906";
}
.icon-mail:before {
  content: "\e905";
}
.icon-instagram:before {
  content: "\e903";
}
.icon-youtube:before {
  content: "\e904";
}
.icon-arrow-next:before {
  content: "\e900";
}
.icon-arrow-prev:before {
  content: "\e902";
}
.icon-download:before {
  content: "\e901";
}
/* ==========================================================================
   Layout
   ========================================================================== */
body {
  position: relative;
  padding-top: 1px;
  z-index: 0;
}
body::after {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 101;
  width: 100%;
  height: 100%;
  background: #fff;
  pointer-events: none;
  content: "";
}
.is-loaded body::after {
  opacity: 0;
  -webkit-transition: opacity 0.5s 0.3s;
  transition: opacity 0.5s 0.3s;
}
.splash-screen {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  width: 100%;
  height: 100%;
  padding-bottom: 10%;
  background: #fff url("../images/splash@sp.png") no-repeat center center / cover;
}
.splash-content {
  opacity: 0;
  -webkit-filter: blur(15px);
  filter: blur(15px);
  -webkit-transform: scale(1.2);
  transform: scale(1.2);
  width: 30%;
  text-align: center;
}
.is-loaded .splash-content {
    opacity: 1;
    -webkit-filter: blur(0);
    filter: blur(0);
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-transition: all 0.6s 0.1s, -webkit-transform 1s 0.1s;
    transition: all 0.6s 0.1s, -webkit-transform 1s 0.1s;
    transition: all 0.6s 0.1s, transform 1s 0.1s;
    transition: all 0.6s 0.1s, transform 1s 0.1s, -webkit-transform 1s 0.1s;
  }
.wrap {
  overflow: hidden;
  position: relative;
}
.container {
  display: block;
  position: relative;
  width: calc(100% - 40px);
  margin: 0 auto;
}
.container .container {
    width: 100%;
  }
/* -----------------------------------
  Header
----------------------------------- */
.header {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100%;
  background: #fff;
}
.header__logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -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: 0;
  left: 0;
  width: 220px;
  height: 80px;
  border-radius: 0 0 6px 0;
  background: #fff;
}
.header__logo .logo {
    display: block;
    width: 80%;
  }
.header-navi-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.header-navi-list a {
    display: inline-block;
    position: relative;
    font-weight: 700;
    line-height: 1.5;
    -webkit-text-decoration: none;
    text-decoration: none;
  }
.sticky-contact {
  display: none;
}
@-webkit-keyframes headerAnim {
  0% { -webkit-transform: translateY(-100%); transform: translateY(-100%); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); }
}
@keyframes headerAnim {
  0% { -webkit-transform: translateY(-100%); transform: translateY(-100%); }
  100% { -webkit-transform: translateY(0); transform: translateY(0); }
}
/* -----------------------------------
  Content
----------------------------------- */
.wrap {
  padding-top: 90px;
}
.main-header {
  position: relative;
}
.main-header__title {
  position: relative;
  z-index: 0;
  width: 100%;
  padding: 70px 0 50px;
  background: #f3f4f7;
}
.main-header__title .text {
    margin: 0;
    color: #a2a9df;
    font-size: 1.6rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1.5;
    text-align: center;
  }
.main-header__title .text::before {
      display: block;
      margin-bottom: 10px;
      color: #052275;
      font-family: "Jost", sans-serif;
      font-size: 3rem;
      font-weight: 500;
      letter-spacing: 0.025em;
      line-height: 1;
      content: attr(data-en);
    }
.main-header__title .image {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
  }
.main-header__title .image img,
    .main-header__title .image video {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
      z-index: -1;
    }
.main-header__title .image + .text::before {
    color: #fff;
  }
.main-header__recruit-banner {
  position: absolute;
  top: 0;
  right: 0;
  width: 120px;
}
.main-header__recruit-banner a {
    display: block;
    border-radius: 0 0 0 20px;
    background: #ffd800;
  }
.main-content {
  position: relative;
  padding-top: 80px;
}
.main-content .breadcrumbs {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    position: absolute;
    top: 10px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: calc(100% - 40px);
    max-width: 1100px;
  }
.breadcrumbs-list {
  list-style: none;
  margin: 0;
  padding: 0;
  color: #818181;
  font-size: 1.2rem;
}
.breadcrumbs-list > li {
    display: inline-block;
  }
.breadcrumbs-list > li:nth-of-type(n+2)::before {
    display: inline-block;
    width: 5px;
    height: 0;
    border-top: 1px solid;
    margin: 0 10px;
    vertical-align: middle;
    content: "";
  }
.breadcrumbs-list a {
    color: inherit;
  }
/* -----------------------------------
  Footer
----------------------------------- */
.footer {
  position: relative;
  margin-top: min(170px, 20vw);
  border-top: 1px solid #052275;
}
#pagetop {
  display: block;
  position: fixed;
  bottom: 0;
  right: 18px;
  -webkit-transform: translateY(100%);
  transform: translateY(100%);
  -webkit-transition: -webkit-transform 0.3s ease-out;
  transition: -webkit-transform 0.3s ease-out;
  transition: transform 0.3s ease-out;
  transition: transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
#pagetop.is-fixed {
  -webkit-transform: translateY(0);
  transform: translateY(0);
}
#pagetop.is-stop {
  position: absolute;
  bottom: 100%;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}
.footer__content {
  padding: 40px 20px;
  background: #052275;
  color: #fff;
}
.footer__inner {
  max-width: 400px;
  margin: 0 auto;
}
.footer-address {
  padding: 30px 20px;
  color: #052275;
  font-size: 1.4rem;
  text-align: center;
}
.footer-logo {
  width: 100px;
  margin: 0 auto 15px;
}
.footer-map {
  position: relative;
  height: 350px;
  background: #f3f4f7;
}
.footer-map::after {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background: #2637b3;
    mix-blend-mode: screen;
    pointer-events: none;
    content: "";
  }
.footer-map iframe {
    width: 100%;
    height: 100%;
    -webkit-filter: grayscale(1);
    filter: grayscale(1);
  }
.footer-navi-list {
  display: none;
}
.footer-sns {
  margin-bottom: 20px;
  text-align: center;
}
.footer-sns a {
    display: inline-block;
    margin: 5px;
  }
.footer-tel {
  text-align: center;
}
.footer-tel .number {
    margin-bottom: 0.5em;
    font-family: "Jost", sans-serif;
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: 0.025em;
    line-height: 1;
  }
.footer-tel .number a {
      color: inherit;
      font-size: 3.4rem;
      -webkit-text-decoration: none;
      text-decoration: none;
    }
.footer-cta {
  margin-top: 20px;
}
.footer-cta .btn {
    width: 100%;
    height: 64px;
    border-radius: 32px;
    border: 1px solid;
    background: #fff;
    color: #2637b3;
  }
.footer-cta .btn:hover {
      background: #ffd800;
    }
.footer__copyright {
  margin-top: 40px;
  color: #bdc2e8;
  font-size: 1.2rem;
  text-align: center;
}
/* ==========================================================================
   Object
   ========================================================================== */
/* Component
   ----------------------------------------------------------------- */
/*------------------------------------*\
    spectre.css
    http://picturepan2.github.io/spectre
\*------------------------------------*/
.columns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin-left: -15px;
  margin-right: -15px;
}
.columns.col-gapless {
    margin-left: 0;
    margin-right: 0;
  }
.columns.col-gapless > .column {
      padding-left: 0;
      padding-right: 0;
    }
.columns.col-oneline {
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    overflow-x: auto;
  }
[class~="col-"],
.column {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  max-width: 100%;
  padding-left: 15px;
  padding-right: 15px;
}
.col-12[class~="col-"],
  .column.col-12,
  .col-11[class~="col-"],
  .column.col-11,
  .col-10[class~="col-"],
  .column.col-10,
  .col-9[class~="col-"],
  .column.col-9,
  .col-8[class~="col-"],
  .column.col-8,
  .col-7[class~="col-"],
  .column.col-7,
  .col-6[class~="col-"],
  .column.col-6,
  .col-5[class~="col-"],
  .column.col-5,
  .col-4[class~="col-"],
  .column.col-4,
  .col-3[class~="col-"],
  .column.col-3,
  .col-2[class~="col-"],
  .column.col-2,
  .col-1[class~="col-"],
  .column.col-1,
  .col-auto[class~="col-"],
  .column.col-auto {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
  }
.col-12 {
  width: 100%;
}
.col-11 {
  width: 91.66666667%;
}
.col-10 {
  width: 83.33333333%;
}
.col-9 {
  width: 75%;
}
.col-8 {
  width: 66.66666667%;
}
.col-7 {
  width: 58.33333333%;
}
.col-6 {
  width: 50%;
}
.col-5 {
  width: 41.66666667%;
}
.col-4 {
  width: 33.33333333%;
}
.col-3 {
  width: 25%;
}
.col-2 {
  width: 16.66666667%;
}
.col-1 {
  width: 8.33333333%;
}
.col-auto {
  -webkit-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto;
  max-width: none;
  width: auto;
}
.col-mx-auto {
  margin-left: auto;
  margin-right: auto;
}
.col-ml-auto {
  margin-left: auto;
}
.col-mr-auto {
  margin-right: auto;
}
/*------------------------------------*\
    Typography
\*------------------------------------*/
/* 見出し */
.h2 {
  position: relative;
  margin-bottom: 40px;
  padding-left: 0.75em;
  color: #052275;
  font-size: 3rem;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.05em;
}
.h2::before {
    position: absolute;
    left: 0;
    top: 0.15em;
    bottom: 0;
    width: 0;
    border-left: 2px solid #052275;
    content: "";
  }
.h2::after {
    display: block;
    margin-top: 10px;
    color: #868fd5;
    font-family: "Jost", sans-serif;
    font-size: 1.2rem;
    font-weight: 600;
    letter-spacing: 0.025em;
    content: attr(data-en);
  }
.h2--center {
  padding-left: 0;
  text-align: center;
}
.h2--center::before {
    display: none;
  }
.h3 {
  margin-bottom: 0.5em;
  color: #052275;
  font-size: 2.6rem;
  font-weight: 500;
  line-height: 1.6666;
}
.h3[data-number] {
    position: relative;
    padding-left: 1.33em;
  }
.h3[data-number]::before {
    position: absolute;
    top: 0.5em;
    left: 0;
    color: #868fd5;
    font-family: "Jost", sans-serif;
    font-size: 0.66em;
    font-weight: 600;
    content: attr(data-number);
  }
.h6 {
  font-size: 1.6rem;
  font-weight: 700;
}
/* リスト */
.list-inline,
.list-nostyle,
.list-note,
.list-checkpoint {
  list-style: none;
  padding: 0;
}
.list-inline > li {
    display: inline-block;
    margin-right: 1em;
  }
.list-inline > li:last-child {
    margin-right: 0;
  }
.list-note > li {
    position: relative;
    margin-bottom: 0.25em;
    padding-left: 1.2em;
    font-size: 1.4rem;
  }
.list-note > li::before {
      position: absolute;
      left: 0;
      content: "※";
    }
.list-checkpoint > li {
    position: relative;
    margin-bottom: 0.5em;
    padding-left: 1.375em;
    line-height: 1.714;
  }
.list-checkpoint > li::before {
      position: absolute;
      top: 0.4em;
      left: 0;
      width: 0.875em;
      height: 0.875em;
      background: url("../images/icon_check.svg") no-repeat center center / contain;
      content: "";
    }
/*------------------------------------*\
    Tables
\*------------------------------------*/
.table {
  width: 100%;
  border-top: 1px solid #efefef;
  line-height: 1.625;
}
.table th,
  .table td {
    padding: 1.125em 0;
    border-bottom: 1px solid #efefef;
    vertical-align: top;
  }
.table th {
    color: #052275;
    font-weight: 700;
    text-align: left;
  }
.table--stripe {
  border-top-color: #dcdddd;
}
.table--stripe tr:nth-of-type(odd) {
    background: #f7f8f8;
  }
.table--stripe th,
  .table--stripe td {
    padding: 1em;
    border-bottom-color: #dcdddd;
  }
.table--stripe th {
    color: inherit;
  }
/* レスポンシブ */
/*------------------------------------*\
    Buttons
\*------------------------------------*/
.btn {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  max-width: 100%;
  height: 56px;
  border-radius: 30px;
  border: none;
  margin: 10px 0;
  padding: 8px 50px 9px;
  border: none;
  background: #2637b3;
  color: #fff;
  font-size: 1.5rem;
  font-weight: 500;
  line-height: 1.333;
  text-align: center;
  -webkit-text-decoration: none;
  text-decoration: none;
  -webkit-transition: all 0.2s ease-out;
  transition: all 0.2s ease-out;
  vertical-align: middle;
  cursor: pointer;
}
.btn:hover {
    background: #ffd800;
    color: #2637b3;
  }
.btn--invert {
  border: 1px solid;
  background: #fff;
  color: #2637b3;
}
.btn--invert:hover {
    background: #ffd800;
  }
.btn--mini {
  height: auto;
  padding: 8px 10px 9px;
  border-radius: 6px;
  background: #052275;
  letter-spacing: 0;
}
/* 矢印アイコン */
.btn--arrow::before, .btn--back::before {
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    font-family: "icomoon";
    font-size: 20px;
    font-weight: normal;
    -webkit-transition: left 0.2s ease-out, right 0.2s ease-out;
    transition: left 0.2s ease-out, right 0.2s ease-out;
  }
.btn--arrow::before {
    right: 20px;
    content: "\e900";
  }
.btn--arrow:hover::before {
    right: 16px;
  }
.btn--back {
  width: 282px;
}
.btn--back::before {
    left: 20px;
    content: "\e902";
  }
.btn--back:hover::before {
    left: 16px;
  }
/* ページネーション */
.pagination {
  margin: 50px 0;
}
.pagination-list {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-flow: row wrap;
  flex-flow: row wrap;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  padding: 0;
}
.pagination-list li {
    padding: 5px;
  }
.pagination-list a,
  .pagination-list span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
    width: 40px;
    height: 40px;
    border-radius: 6px;
    background: #efefef;
    color: #232323;
    font-size: 1.6rem;
    font-weight: 600;
  }
.pagination-list a.is-active, .pagination-list span.is-active {
      background: #2637b3;
      color: #fff;
    }
.pagination-list a {
    -webkit-text-decoration: none;
    text-decoration: none;
  }
/* Project
   ----------------------------------------------------------------- */
/*------------------------------------*\
  共通
\*------------------------------------*/
/* セクション */
.section {
  padding: min(100px, 15vw) 0;
}
/* 画像 */
.img-rounded {
  border-radius: 8px;
}
/* スライダー */
.js-infinite-slider .splide__slide {
  padding: 0 11px;
}
/* アニメーション設定 */
.js .anim-mask {
	display: inline-block;
	-webkit-clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
	clip-path: polygon(0% 0%, 0% 0%, 0% 100%, 0% 100%);
  vertical-align: top;
}
.js .anim-mask.inview {
	--duration: 0.8s;
	--delay: 0.1s;
	-webkit-clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
	-webkit-transition: -webkit-clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay);
	transition: -webkit-clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay);
	transition: clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay);
	transition: clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay), -webkit-clip-path var(--duration) cubic-bezier(0.25, 1, 0.5, 1) var(--delay);
}
.card-more {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  opacity: 0;
  color: #fff;
  font-family: "Jost", sans-serif;
  font-weight: 600;
  -webkit-transition: all 0.3s 0.1s;
  transition: all 0.3s 0.1s;
}
.card-more::after {
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 0;
    border-bottom: 2px solid;
    content: "";
    -webkit-transition: all 0.3s 0.1s cubic-bezier(0.22, 0.61, 0.36, 1);
    transition: all 0.3s 0.1s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
/* ページ下部ボタン */
.main-cta a {
    display: block;
    padding: 30px 20px 33px;
    -webkit-box-shadow: inset 0 10px 5px -4px rgba(0, 0, 0, 0.2);
    box-shadow: inset 0 10px 5px -4px rgba(0, 0, 0, 0.2);
    background: #2637b3;
    color: #fff;
    text-align: center;
    -webkit-text-decoration: none;
    text-decoration: none;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
  }
.main-cta a b {
      font-size: 1.44em;
      font-weight: 500;
    }
@media (min-width: 45.001em) {
.main-cta a {
      font-size: 1.8rem;
  }
    }
@media (hover:hover) {
      .main-cta a:hover {
        background: #ffd800;
        color: #052275;
      }
    }
/*------------------------------------*\
  トップページ
\*------------------------------------*/
.top-hero {
  height: min(50vw, 675px);
  margin-bottom: min(10vw, 140px);
}
.top-hero video {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
.top-heading {
  position: relative;
  margin-bottom: 20px;
  font-size: max(2.7rem, min(calc(2.16rem + 1.5vw), 3.6rem));
  font-weight: bold;
  line-height: 1.4;
}
.top-heading[data-en-before]::before,
  .top-heading[data-en-after]::after {
    display: block;
    color: #052275;
    font-size: 1.4rem;
    font-weight: bold;
  }
.top-heading[data-en-before]::before {
    margin-bottom: 5px;
    content: attr(data-en-before);
  }
.top-heading[data-en-after]::after {
    margin-top: 5px;
    content: attr(data-en-after);
  }
/*------------------------------------*\
  NEWS・事例
\*------------------------------------*/
/* カテゴリ一覧 */
.category-list {
  list-style: none;
  margin: 20px 0 40px;
  padding: 0;
  text-align: center;
}
.category-list > li {
    display: inline-block;
    margin-right: 0.2em;
    margin-bottom: 0.5em;
  }
.category-list a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    min-width: 120px;
    padding: 0.1em 2em 0.2em;
    border-radius: 1.3rem;
    border: 1px solid #052275;
    background: #fff;
    color: #052275;
    font-size: 1.2rem;
    font-weight: 500;
    -webkit-text-decoration: none;
    text-decoration: none;
    line-height: 1.5;
    -webkit-transition: all 0.2s;
    transition: all 0.2s;
  }
.category-list a.is-current {
      border-color: #2637b3;
      background: #2637b3;
      color: #fff;
    }
/* お知らせ共通 */
.article-category {
  display: inline-block;
  padding: 0 1em 1px;
  border-radius: 1.5em;
  border: 1px solid #052275;
  background: #fff;
  color: #052275;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0;
}
.article-category--primary {
  background: #052275;
  color: #fff;
}
.article-date {
  color: #052275;
  font-weight: 500;
  font-size: 1.4rem;
  letter-spacing: 0.025em;
}
.article-view {
  display: inline-block;
  padding: 0 0.8em 1px;
  border-radius: 4px;
  background: #2637b3;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.025em;
}
/* お知らせ一覧 */
.article-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.article-list > li {
    margin-bottom: 30px;
  }
.article-card {
  display: block;
  position: relative;
  color: inherit;
  -webkit-text-decoration: none;
  text-decoration: none;
}
.article-card__thumb {
  overflow: hidden;
  position: relative;
  border-radius: 6px;
}
.article-card__thumb .article-thumb {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 66.886%;
  }
.article-card__thumb .article-thumb img {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }
.article-card__thumb .article-date {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    padding: 9px;
    border-radius: 0 0 6px;
    background: #f7f8f8;
    font-weight: 700;
    line-height: 1;
  }
.article-card__thumb .article-date .ym {
      display: block;
      margin-bottom: 0.2em;
      font-size: 1.2rem;
    }
.article-card__thumb .article-date .day {
      display: inline-block;
      margin-right: 0.1em;
      font-size: 1.8rem;
    }
.article-card__thumb .article-date .wd {
      font-size: 1.2rem;
    }
.article-card__thumb .article-category {
    position: absolute;
    bottom: 12px;
    left: 12px;
    z-index: 1;
    font-size: 1.3rem;
  }
.article-card__thumb .article-view {
    position: absolute;
    right: 12px;
    bottom: 12px;
    z-index: 1;
    font-size: 1.2rem;
  }
.article-card__body {
  margin-top: 20px;
  letter-spacing: 0.05em;
}
.article-card__body .article-title {
    overflow: hidden;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.714;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
.article-card__body .article-desc {
    overflow: hidden;
    display: -webkit-box;
    margin-top: 5px;
    font-size: 1.4rem;
    line-height: 1.714;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
/* 記事ページ */
.article-layout__main {
  margin-bottom: 60px;
}
.article__header {
  margin-bottom: 40px;
  padding-bottom: 40px;
  border-bottom: 1px solid #efefef;
}
.article__header .article-category {
    min-width: 140px;
    margin-right: 8px;
    padding: 0.1em 1.5em 0.2em;
    text-align: center;
  }
.article__header .article-title {
    margin: 1em 0 0.66em;
    font-size: 2.7rem;
    font-weight: 500;
  }
.article__header .article-date {
    margin-right: 1em;
  }
.article__body .image,
  .article__body .image2,
  .article__body .text {
    margin: 4rem 0;
  }
.article__body .image + .image, .article__body .image + .image2, .article__body .image2 + .image, .article__body .image2 + .image2 {
    margin-top: -1rem
  }
.article__body .image img {
      width: 100%;
      border-radius: 6px;
    }
.article__body .image2 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
.article__body .image2 img {
      -webkit-box-flex: 1;
      -ms-flex: 1;
      flex: 1;
      max-width: 48%;
      border-radius: 6px;
    }
.article__body .text h2 {
      font-size: 2.2rem;
      line-height: 1.7;
    }
.article__body .text h3 {
      font-size: 1.8rem;
      line-height: 1.7;
    }
.article__body > :first-child {
    margin-top: 0;
  }
/* 関連記事 */
.article-aside-list {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0;
  padding: 0;
}
.article-aside-list > li {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%;
    margin-bottom: 30px;
  }
/* お客様事例 */
.works-container {
  width: calc(100% - 40px);
  margin: 0 auto;
}
.works-list {
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 -8px;
  padding: 0;
}
.works-list > li {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    margin-bottom: 40px;
    padding: 0 8px;
  }
.works-card {
  display: block;
  color: inherit;
  -webkit-text-decoration: none;
  text-decoration: none;
}
.works-card__thumb {
  overflow: hidden;
  position: relative;
  z-index: 0;
  border-radius: 10px;
}
.works-card__thumb::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    opacity: 0;
    z-index: 1;
    background: rgba(38, 55, 179, 0.3);
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    content: "";
  }
.works-card__thumb .works-thumb {
    overflow: hidden;
    position: relative;
    z-index: 0;
    width: 100%;
    height: 0;
    padding-top: 136.97%;
  }
.works-card__thumb .works-thumb img {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }
.works-card__body {
  margin-top: 15px;
}
.works-card__body .works-category {
    position: relative;
    padding-left: 1.2rem;
    font-size: 1.8rem;
    font-weight: 700;
  }
.works-card__body .works-category::before {
      position: absolute;
      top: 0.8em;
      left: 0;
      width: 0.5rem;
      height: 0.5rem;
      border-radius: 50%;
      background: #2637b3;
      content: "";
    }
.works-card__body .works-title {
    font-size: 1.4rem;
  }
/*------------------------------------*\
  MIYOSHIについて
\*------------------------------------*/
.about01 {
  overflow: hidden;
  position: relative;
  z-index: 0;
  height: 500px;
  background: url("../../about/images/01.jpg") no-repeat center center / cover;
  margin: 0 5% min(170px, 20vw);
  padding: 50px 25px 30px 25px;
  border-radius: 10px;
}
.about01::before {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: -1;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    width: 100vw;
    height: 100vw;
    background: url("../../about/images/02.svg") no-repeat center center / contain;
    content: "";
  }
.about01__content {
  color: #052275;
}
.about01__content h2 {
    margin-bottom: 20px;
  }
.about01__content p {
    line-height: 2;
    font-weight: 500;
    font-size: 1.4rem;
  }
.about02 {
  position: relative;
  z-index: 0;
}
.about02::before {
    position: absolute;
    top: 12%;
    bottom: 10%;
    left: 50%;
    z-index: -1;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 60%;
    max-width: 600px;
    background: #f0f1fa;
    content: "";
  }
.about02-block {
  margin-bottom: 60px;
}
.about02-block__content {
  padding-bottom: 20px;
}
.about02-block__image .image {
    overflow: hidden;
    border-radius: 10px;
  }
.about02-block__image .image img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }
/* 特徴・事業紹介 */
.lineup__inner {
  position: relative;
  z-index: 0;
}
.lineup__inner::before {
    position: absolute;
    right: -20px;
    top: 0;
    z-index: -1;
    width: 100%;
    height: 12vw;
    max-height: 150px;
    content: "";
  }
.lineup--feature .lineup__inner::before {
  background: url("../../about/images/bg1.svg") no-repeat right top / contain;
}
.lineup--business {
  margin-top: min(60px, 15vw);
}
.lineup--business .lineup__inner::before {
  background: url("../../about/images/bg2.svg") no-repeat right top / contain;
}
.lineup__list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.lineup__list > li {
    margin-bottom: 50px;
  }
.lineup-card1__thumb,
.lineup-card2__thumb {
  position: relative;
  margin-bottom: 20px;
  overflow: hidden;
  border-radius: 10px;
}
.lineup-card1__thumb .image img, .lineup-card2__thumb .image img {
    width: 100%;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
.lineup-card1__thumb .text {
    position: absolute;
    right: 20px;
    bottom: 20px;
    color: #fff;
    font-family: "Jost", sans-serif;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1;
  }
.lineup-card2__thumb {
  display: block;
  overflow: hidden;
  -webkit-text-decoration: none;
  text-decoration: none;
  border-radius: 10px;
}
.lineup-card2__thumb::before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 1;
    background: #000;
    opacity: 0;
    -webkit-transition: opacity 0.3s ease;
    transition: opacity 0.3s ease;
    content: "";
  }
.lineup-card2__thumb .image {
    z-index: 0;
  }
.lineup-card2__thumb .heading {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -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: 0;
    left: 0;
    z-index: 2;
    padding: 5px 15px;
    border-radius: 0 0 6px 0;
    background: #fff;
    color: #052275;
    font-size: 1.8rem;
    font-weight: 500;
  }
.lineup-card2__thumb .heading b {
      display: block;
      padding-right: 10px;
      color: #868fd5;
      font-family: "Jost", sans-serif;
      font-size: 1.4rem;
      letter-spacing: 0.025em;
      line-height: 1;
      text-align: center;
      text-combine-upright: all;
    }
.lineup-card1__text .heading {
    color: #052275;
    font-size: 2rem;
  }
/*------------------------------------*\
  事業紹介
\*------------------------------------*/
.business-index__inner {
  width: 80%;
  max-width: 383px;
  margin: 0 auto;
  padding: 30px 0;
}
.business-index__inner .btn {
    width: 226px;
  }
.business-index__heading {
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #efefef;
  color: #052275;
  font-size: 2.7rem;
  font-weight: 400;
  letter-spacing: 0;
  text-align: center;
}
.business-index__heading span {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    margin: 0 auto 10px;
    border-radius: 50%;
    background: #f7f8f8;
    color: #868fd5;
    font-family: "Jost", sans-serif;
    font-weight: 500;
    font-size: 1.8rem;
  }
.business01 {
  position: relative;
}
.business01::before {
    position: absolute;
    top: -80px;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    background: url("../../business/images/bg.jpg") repeat center top;
    content: "";
  }
.business01__header {
  position: relative;
  margin-bottom: 80px;
  color: #052275;
  font-weight: 500;
  text-align: center;
}
.business01__header::before,
  .business01__header::after {
    position: absolute;
    top: 0;
    bottom: 0;
    width: 26px;
    border: 1px solid #052275;
    content: "";
  }
.business01__header::before {
    left: 0;
    border-right: none;
  }
.business01__header::after {
    right: 0;
    border-left: none;
  }
.business01__header > div {
    padding: 0.4em 0;
  }
.business01__header .label {
    display: inline-block;
    padding: 0 0.5em;
    border: 1px solid;
    background: #fff;
  }
.business01__heading {
  font-size: 3rem;
  font-weight: 400;
}
.business01__heading::before {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 43px;
    height: 43px;
    margin-right: 15px;
    border-radius: 50%;
    background: #052275;
    color: #fff;
    font-family: "Jost", sans-serif;
    font-weight: 500;
    font-size: 1.6rem;
    vertical-align: 0.4em;
    content: attr(data-number);
  }
.business01-01 {
  position: relative;
  z-index: 0;
  padding-bottom: 50px;
}
.business01-01::before {
    position: absolute;
    bottom: -10vw;
    left: 50%;
    z-index: -1;
    -webkit-transform: translateX(-50%) skewY(-8deg);
    transform: translateX(-50%) skewY(-8deg);
    width: 100vw;
    height: 20vw;
    background: #fff;
    content: "";
  }
.business01-01__content h2 {
    margin-bottom: 30px;
  }
.business01-01__content p {
    font-weight: 500;
  }
.business01-01__image2 {
  width: 41.125%;
  margin: -15% 0 0 5%;
}
.business01-01__image3 {
  width: 40.15625%;
  margin-top: -10%;
  margin-right: 5%;
  margin-left: auto;
}
.business01-02 {
  position: relative;
  z-index: 0;
  padding-bottom: 50px;
}
.business01-02::before {
    position: absolute;
    bottom: -10vw;
    left: 50%;
    z-index: -1;
    -webkit-transform: translateX(-50%) skewY(8deg);
    transform: translateX(-50%) skewY(8deg);
    width: 100vw;
    height: 20vw;
    background: #fff;
    content: "";
  }
.business01-02 h2,
  .business01-02 ul {
    margin-bottom: 30px;
  }
.business01-02__image2 {
  width: 40%;
  margin: -10% 0 0 10%;
}
.business02 {
  padding: 60px 0;
}
.business02__block {
  margin-bottom: 50px;
}
.business02__image {
  margin-bottom: 20px;
}
.business02__image .image {
    overflow: hidden;
    border-radius: 10px;
  }
.business02__image img {
    width: 100%;
  }
.business03__content p {
    font-weight: 500;
    font-size: 1.6rem;
  }
.business03__list {
  padding: 20px;
  background: #f0f1fa;
}
/* 施工対応エリア */
.business-area {
  padding: 60px 0 30px;
}
.business-area__map {
  width: 80%;
  max-width: 500px;
  margin: 0 auto;
}
/* よくあるご質問 */
.faq {
  background: #f7f8f8;
}
.faq__content {
  padding: 0 10px;
  background: #fff;
}
.faq__content dl {
    margin: 0;
    padding: 20px;
    border-radius: 6px;
  }
.faq__content dl:nth-of-type(even) {
    background: #f2f3fa;
  }
.faq__content dt,
  .faq__content dd {
    position: relative;
    margin: 0;
    padding: 20px 0 20px 40px;
  }
.faq__content dt::before, .faq__content dd::before {
      position: absolute;
      top: 0.6em;
      left: 0;
      font-family: "Jost", sans-serif;
      font-size: 3rem;
      font-weight: 500;
      line-height: 1.4;
    }
.faq__content dt {
    border-bottom: 1px solid #c9caca;
    color: #052275;
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.5;
  }
.faq__content dt::before {
      content: "Q.";
    }
.faq__content dd::before {
      color: #868fd5;
      content: "A.";
    }
/*------------------------------------*\
  企業情報
\*------------------------------------*/
.l-company {
  margin-bottom: 90px;
}
.l-company__image {
  direction: rtl;
  margin-bottom: 40px;
}
.l-company__image .image {
    overflow: hidden;
    position: relative;
    width: calc(100% + 20px);
    height: 60vw;
    border-radius: 0 10px 10px 0;
  }
.l-company__image .image img {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }
.l-company--reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
}
.l-company--reverse .l-company__image {
    direction: ltr;
  }
.l-company--reverse .l-company__image .image {
      border-radius: 10px 0 0 10px;
    }
/*------------------------------------*\
  採用情報
\*------------------------------------*/
.recruit01,
.recruit02,
.recruit03,
.recruit04 {
  position: relative;
  z-index: 0;
}
.recruit__en {
  position: absolute;
  top: 50%;
  left: 0;
  z-index: -1;
  width: 100%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
.recruit01 {
  padding-top: min(50px, 8vw);
  padding-bottom: min(100px, 15vw);
  font-weight: 500;
  text-align: center;
}
.recruit02 {
  margin-top: 15vw;
  padding-bottom: min(170px, 20vw);
  background: url("../../recruit/images/bg.jpg") no-repeat center center / cover;
  text-align: center;
}
.recruit02 .splide {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
.recruit02__content {
  position: relative;
  margin-top: -20px;
  padding-top: 40px;
  padding-bottom: min(80px, 8vw);
  color: #fff;
  font-weight: 500;
  text-align: center;
}
.recruit02__movie {
  display: inline-block;
  position: relative;
}
.recruit02__movie::before {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 1;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    width: 32%;
    height: 0;
    padding-top: 26%;
    background: url("../../recruit/images/icon_movie.svg") no-repeat center center / contain;
    -webkit-transition: all 0.4s;
    transition: all 0.4s;
    content: "";
  }
.recruit03 {
  padding-top: min(120px, 10vw);
  padding-bottom: min(80px, 6vw);
}
.recruit03__header {
  position: relative;
  padding: min(100px, 10vw) 0;
  text-align: center;
}
.recruit03-block {
  margin-bottom: min(65px, 10vw);
}
.recruit03-block__image {
  margin-bottom: 30px;
}
.recruit03-block__heading {
  position: relative;
  margin-bottom: 0.5em;
  padding-left: 1.5625em;
  color: #052275;
  font-size: 2.6rem;
  font-weight: 500;
  line-height: 1.6;
}
.recruit03-block__heading b {
    position: absolute;
    top: 0.33em;
    left: 0;
    color: #868fd5;
    font-family: "Jost", sans-serif;
    font-size: 0.75em;
    font-weight: 600;
    line-height: 1;
  }
.recruit03-block__heading b::before {
      display: block;
      margin-bottom: 0.3em;
      -webkit-transform: scale(0.9);
      transform: scale(0.9);
      font-size: 0.9rem;
      font-weight: 500;
      content: "POINT";
    }
.recruit04 {
  padding-top: 70px;
  padding-bottom: min(140px, 15vw);
  background: url("../../recruit/images/bg2.jpg") no-repeat center center / cover;
  color: #fff;
}
.recruit04__header {
  position: relative;
  padding-top: min(80px, 6vw);
  padding-bottom: min(120px, 10vw);
  text-align: center;
}
.recruit04__timeline {
  max-width: 300px;
  margin: 0 auto;
}
.recruit04__timeline ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }
.recruit04__timeline li:nth-of-type(n+2)::before {
    display: block;
    width: 4px;
    height: 25px;
    margin-left: 1.6em;
    background: #2637b3;
    content: "";
  }
.recruit04__timeline .time {
    float: left;
    width: 3em;
    font-family: "Jost", sans-serif;
    font-size: 1.8rem;
    text-align: center;
  }
.recruit04__timeline .text {
    font-size: 1.7rem;
  }
.recruit04__timeline .text::before {
      display: inline-block;
      width: 1em;
      height: 0;
      margin: 0 0.5em;
      border-bottom: 1px dotted;
      vertical-align: middle;
      content: "";
    }
.recruit05 {
  padding-bottom: min(100px, 15vw);
}
.recruit05__content {
  margin-top: -70px;
  padding: 40px 20px 0;
  background: #fff;
  font-weight: 500;
}
.recruit05__content h2 {
    margin-bottom: 30px;
  }
.recruit05__content p br {
    display: none;
  }
/* Utility
   ----------------------------------------------------------------- */
/* Responsive */
.video {
  position: relative;
  width: 100%;
  height: 0;
  padding-top: 56.25%;
}
.video iframe {
  position: absolute;
  outline: 0;
  right: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
/* Display */
.visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  overflow: hidden;
  clip: rect(1px, 1px, 1px, 1px);
  -webkit-clip-path: inset(0px 0px 99.9% 99.9%);
  clip-path: inset(0px 0px 99.9% 99.9%);
  border: 0;
}
.u-none {
  display: none;
}
.u-block {
  display: block;
}
.u-inline {
  display: inline;
}
.u-inline-block {
  display: inline-block;
}
.u-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}
/* Text Align & Font style */
.u-text-left {
  text-align: left !important;
}
.u-text-center {
  text-align: center !important;
}
.u-text-right {
  text-align: right !important;
}
.u-text-indent {
  padding-left: 1.5em;
  text-indent: -1.5em;
}
ul.u-text-indent {
  list-style: none;
}
.u-align-items-center {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
/* widths */
.u-w100 {
  width: 100%;
}
.u-w90 {
  width: 90%;
}
.u-w80 {
  width: 80%;
}
.u-w75 {
  width: 75%;
}
.u-w70 {
  width: 70%;
}
.u-w66 {
  width: 66%;
}
.u-w60 {
  width: 60%;
}
.u-w50 {
  width: 50%;
}
.u-w40 {
  width: 40%;
}
.u-w33 {
  width: 33%;
}
.u-w30 {
  width: 30%;
}
.u-w25 {
  width: 25%;
}
.u-w20 {
  width: 20%;
}
.u-w10 {
  width: 10%;
}
.u-w-auto {
  width: auto;
}
/* Margins */
.u-mt-0 {
  margin-top: 0 !important;
}
.u-mb-0 {
  margin-bottom: 0 !important;
}
.u-mr-0 {
  margin-right: 0 !important;
}
.u-ml-0 {
  margin-left: 0 !important;
}
.u-mt-1 {
  margin-top: 10px !important;
}
.u-mr-1 {
  margin-right: 10px !important;
}
.u-mb-1 {
  margin-bottom: 10px !important;
}
.u-ml-1 {
  margin-left: 10px !important;
}
.u-mt-2 {
  margin-top: 20px !important;
}
.u-mr-2 {
  margin-right: 20px !important;
}
.u-mb-2 {
  margin-bottom: 20px !important;
}
.u-ml-2 {
  margin-left: 20px !important;
}
.u-mt-3 {
  margin-top: 40px !important;
}
.u-mr-3 {
  margin-right: 40px !important;
}
.u-mb-3 {
  margin-bottom: 40px !important;
}
.u-ml-3 {
  margin-left: 40px !important;
}
.u-mt-4 {
  margin-top: 60px !important;
}
.u-mr-4 {
  margin-right: 60px !important;
}
.u-mb-4 {
  margin-bottom: 60px !important;
}
.u-ml-4 {
  margin-left: 60px !important;
}
.u-mt-5 {
  margin-top: 100px !important;
}
.u-mr-5 {
  margin-right: 100px !important;
}
.u-mb-5 {
  margin-bottom: 100px !important;
}
.u-ml-5 {
  margin-left: 100px !important;
}
.u-mr-auto,
.u-mx-auto {
  margin-right: auto !important;
}
.u-ml-auto,
.u-mx-auto {
  margin-left: auto !important;
}
/* Paddings */
.u-pt-0 {
  padding-top: 0 !important;
}
.u-pb-0 {
  padding-bottom: 0 !important;
}
.u-pr-0 {
  padding-right: 0 !important;
}
.u-pl-0 {
  padding-left: 0 !important;
}
.u-pt-1 {
  padding-top: 10px !important;
}
.u-pr-1 {
  padding-right: 10px !important;
}
.u-pb-1 {
  padding-bottom: 10px !important;
}
.u-pl-1 {
  padding-left: 10px !important;
}
.u-pt-2 {
  padding-top: 20px !important;
}
.u-pr-2 {
  padding-right: 20px !important;
}
.u-pb-2 {
  padding-bottom: 20px !important;
}
.u-pl-2 {
  padding-left: 20px !important;
}
.u-pt-3 {
  padding-top: 40px !important;
}
.u-pr-3 {
  padding-right: 40px !important;
}
.u-pb-3 {
  padding-bottom: 40px !important;
}
.u-pl-3 {
  padding-left: 40px !important;
}
.u-pt-4 {
  padding-top: 60px !important;
}
.u-pr-4 {
  padding-right: 60px !important;
}
.u-pb-4 {
  padding-bottom: 60px !important;
}
.u-pl-4 {
  padding-left: 60px !important;
}
.u-pt-5 {
  padding-top: 100px !important;
}
.u-pr-5 {
  padding-right: 100px !important;
}
.u-pb-5 {
  padding-bottom: 100px !important;
}
.u-pl-5 {
  padding-left: 100px !important;
}
/* Text Styles */
.u-font-l {
  font-size: 1.25em;
}
.u-font-m {
  font-size: 1.125em;
}
.u-font-s {
  font-size: 0.875em;
}
.u-weight-m {
  font-weight: 500;
}
@media (min-width: 35.001em) {
  .col-sm-12,
  .col-sm-11,
  .col-sm-10,
  .col-sm-9,
  .col-sm-8,
  .col-sm-7,
  .col-sm-6,
  .col-sm-5,
  .col-sm-4,
  .col-sm-3,
  .col-sm-2,
  .col-sm-1,
  .col-sm-auto {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
  }
  .col-sm-12 {
    width: 100%;
  }
  .col-sm-11 {
    width: 91.66666667%;
  }
  .col-sm-10 {
    width: 83.33333333%;
  }
  .col-sm-9 {
    width: 75%;
  }
  .col-sm-8 {
    width: 66.66666667%;
  }
  .col-sm-7 {
    width: 58.33333333%;
  }
  .col-sm-6 {
    width: 50%;
  }
  .col-sm-5 {
    width: 41.66666667%;
  }
  .col-sm-4 {
    width: 33.33333333%;
  }
  .col-sm-3 {
    width: 25%;
  }
  .col-sm-2 {
    width: 16.66666667%;
  }
  .col-sm-1 {
    width: 8.33333333%;
  }
  .col-sm-auto {
    width: auto;
  }
  .article-aside-list {
    margin: 0 -10px;
  }
    .article-aside-list > li {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 50%;
      flex: 0 0 50%;
      max-width: 50%;
      padding: 0 10px;
    }
  .u-sm-none {
    display: none !important;
  }
  .u-sm-block {
    display: block !important;
  }
  .u-sm-inline {
    display: inline !important;
  }
  .u-sm-inline-block {
    display: inline-block !important;
  }
  .u-sm-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }}
@media (max-width: 45em) {
  .table-scroller {
    display: block;
    width: 100%;
    overflow-x: auto;
  }
    .table-scroller table {
      width: 800px;
      font-size: 1.5rem;
    }
  .lineup-card2__thumb .image {
    height: 300px;
  }}
@media (min-width: 45.001em) {
  .splash-screen {
    padding-bottom: 5%;
    background-image: url("../images/splash.png");
  }
  .container {
    width: calc(100% - 60px);
    max-width: 1100px;
  }
  .container--narrow {
    max-width: 850px;
  }
  .container--wide {
    max-width: 1300px;
  }
    .main-header__title .text[data-en]::before {
      font-size: 4rem;
    }
  .footer__inner {
    max-width: 400px;
    margin: 0 auto;
  }
  .footer-navi {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
    margin-bottom: 40px;
    padding-bottom: 30px;
    border-bottom: 1px solid #2637b3;
  }
  .footer-navi-list {
    display: block;
    page-break-inside: avoid;
  }
    .footer-navi-list > li {
      position: relative;
      margin-bottom: 0.5em;
      padding-left: 15px;
    }
      .footer-navi-list > li::before {
        position: absolute;
        top: 0.8em;
        left: 0;
        width: 6px;
        height: 6px;
        background: #868fd5;
        content: "";
      }
    .footer-navi-list > li > ul {
      margin-top: 0.5em;
    }
    .footer-navi-list > li > ul > li {
      position: relative;
      margin-bottom: 0.5em;
      padding-left: 10px;
    }
      .footer-navi-list > li > ul > li::before {
        position: absolute;
        top: 1em;
        left: 0;
        width: 4px;
        height: 1px;
        background: #fff;
        content: "";
      }
    .footer-navi-list a {
      color: #fff;
      font-size: 1.5rem;
      font-weight: 500;
      -webkit-text-decoration: none;
      text-decoration: none;
    }
  .footer-sns {
    margin: 40px 0 0;
    text-align: left;
  }
    .footer-tel .number {
      font-size: 2.7rem;
    }
      .footer-tel .number a {
        font-size: 4.2rem;
      }
  .col-md-12,
  .col-md-11,
  .col-md-10,
  .col-md-9,
  .col-md-8,
  .col-md-7,
  .col-md-6,
  .col-md-5,
  .col-md-4,
  .col-md-3,
  .col-md-2,
  .col-md-1,
  .col-md-auto {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
  }
  .col-md-12 {
    width: 100%;
  }
  .col-md-11 {
    width: 91.66666667%;
  }
  .col-md-10 {
    width: 83.33333333%;
  }
  .col-md-9 {
    width: 75%;
  }
  .col-md-8 {
    width: 66.66666667%;
  }
  .col-md-7 {
    width: 58.33333333%;
  }
  .col-md-6 {
    width: 50%;
  }
  .col-md-5 {
    width: 41.66666667%;
  }
  .col-md-4 {
    width: 33.33333333%;
  }
  .col-md-3 {
    width: 25%;
  }
  .col-md-2 {
    width: 16.66666667%;
  }
  .col-md-1 {
    width: 8.33333333%;
  }
  .col-md-auto {
    width: auto;
  }
  .btn {
    font-size: 1.6rem;
  }
  .category-list {
    margin: 30px 0 60px;
  }
    .category-list a {
      min-width: 140px;
      font-size: 1.4rem;
    }
  .article-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-right: -13px;
    margin-left: -13px;
  }
    .article-list > li {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 33.3333%;
      flex: 0 0 33.3333%;
      max-width: 33.3333%;
      margin-bottom: 60px;
      padding-right: 13px;
      padding-left: 13px;
    }
    .article-aside-list > li {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 33.3333%;
      flex: 0 0 33.3333%;
      max-width: 33.3333%;
    }
    .works-list > li {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 33.3333%;
      flex: 0 0 33.3333%;
    }
  .about01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 595px;
  }
    .about01::before {
      width: 690px;
      height: 690px;
    }
  .about01__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
    .about01__content h2 {
      margin: 0 0 0 20px;
    }
    .about01__content p {
      margin-bottom: -1em;
      font-size: 1.7rem;
      line-height: 2.235;
    }
  .lineup__inner {
    width: max(calc(100% + 30px), calc(100% + 50vw - 550px));
  }
    .lineup__inner::before {
      right: 0;
    }
    .lineup__inner .h2 {
      margin-bottom: 60px;
    }
  .lineup__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
    .lineup__list > li {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 calc(33.3333% - 2px);
      flex: 0 0 calc(33.3333% - 2px);
      margin-bottom: 0;
    }
    .lineup-card2__thumb .heading {
      width: 48px;
      padding: 15px 0;
      -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
    }
      .lineup-card2__thumb .heading b {
        margin-bottom: 10px;
        padding-right: 3px;
      }
  .lineup-card1__text,
  .lineup-card2__text {
    padding-right: 20px;
  }
  .business-index {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
  }
    .business-index:nth-of-type(even) {
      -webkit-box-orient: horizontal;
      -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
      flex-direction: row-reverse;
    }
  .business-index__content,
  .business-index__image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    width: 50%;
  }
  .business-index__content {
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self: center;
  }
  .business-index__inner {
    padding: 50px 0;
  }
    .business-index__image img {
      width: 100%;
      height: 100%;
      -o-object-fit: cover;
      object-fit: cover;
    }
  .business01__heading {
    font-size: 4rem;
  }
    .business01__heading::before {
      vertical-align: 0.6em;
    }
  .business03 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  .business03__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
  }
    .business03__content p {
      font-size: 1.8rem;
    }
  .business03__image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 39.6363%;
    flex: 0 0 39.6363%;
    direction: rtl;
  }
    .business03__image .image {
      overflow: hidden;
      border-radius: 0 10px 10px 0;
      width: max(calc(100% + 30px), calc(100% + 50vw - 550px));
    }
  .business-area {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    z-index: -1;
  }
  .business-area__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
  }
  .business-area__map {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 49%;
    flex: 0 0 49%;
    position: relative;
    width: 49%;
    max-width: 49%;
  }
    .business-area__map img {
      position: absolute;
      top: 60%;
      left: 0;
      -webkit-transform: translateY(-50%);
      transform: translateY(-50%);
      width: 100%;
    }
    .l-company__image .image {
      width: calc(100% + 30px);
    }
  .recruit02 {
    margin-top: 10vw;
  }
  .recruit03-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
    .recruit03-block:nth-of-type(even) {
      -webkit-box-orient: horizontal;
      -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
      flex-direction: row-reverse;
    }
  .recruit03-block__image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    margin-bottom: 0;
  }
  .recruit03-block__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45.4545%;
    flex: 0 0 45.4545%;
  }
  .recruit05__content {
    margin-top: -150px;
    padding-top: 60px;
    text-align: center;
  }
    .recruit05__content p br {
      display: block;
    }
  .u-md-none {
    display: none !important;
  }
  .u-md-block {
    display: block !important;
  }
  .u-md-inline {
    display: inline !important;
  }
  .u-md-inline-block {
    display: inline-block !important;
  }
  .u-md-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
  .u-md-text-left {
    text-align: left !important;
  }
  .u-md-text-center {
    text-align: center !important;
  }
  .u-md-text-right {
    text-align: right !important;
  }}
@media (max-width: 60em) {}
@media (min-width: 60.001em) {
  body {
    font-size: 1.6rem;
  }
  .columns {
    margin-left: -28px;
    margin-right: -28px;
  }
  [class~="col-"],
  .column {
    padding-left: 28px;
    padding-right: 28px;
  }
  .columns--condensed {
    margin-left: -12px;
    margin-right: -12px;
  }
    .columns--condensed [class~="col-"],
    .columns--condensed .column {
      padding-left: 12px;
      padding-right: 12px;
    }
  .col-lg-12,
  .col-lg-11,
  .col-lg-10,
  .col-lg-9,
  .col-lg-8,
  .col-lg-7,
  .col-lg-6,
  .col-lg-5,
  .col-lg-4,
  .col-lg-3,
  .col-lg-2,
  .col-lg-1,
  .col-lg-auto {
    -webkit-box-flex: 0;
    -ms-flex: none;
    flex: none;
  }
  .col-lg-12 {
    width: 100%;
  }
  .col-lg-11 {
    width: 91.66666667%;
  }
  .col-lg-10 {
    width: 83.33333333%;
  }
  .col-lg-9 {
    width: 75%;
  }
  .col-lg-8 {
    width: 66.66666667%;
  }
  .col-lg-7 {
    width: 58.33333333%;
  }
  .col-lg-6 {
    width: 50%;
  }
  .col-lg-5 {
    width: 41.66666667%;
  }
  .col-lg-4 {
    width: 33.33333333%;
  }
  .col-lg-3 {
    width: 25%;
  }
  .col-lg-2 {
    width: 16.66666667%;
  }
  .col-lg-1 {
    width: 8.33333333%;
  }
  .col-lg-auto {
    width: auto;
  }
    .pagination-list a {
      width: 45px;
      height: 45px;
      font-size: 1.8rem;
    }
  .u-lg-none {
    display: none !important;
  }
  .u-lg-block {
    display: block !important;
  }
  .u-lg-inline {
    display: inline !important;
  }
  .u-lg-inline-block {
    display: inline-block !important;
  }
  .u-lg-flex {
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
  }
  .u-lg-text-left {
    text-align: left !important;
  }
  .u-lg-text-center {
    text-align: center !important;
  }
  .u-lg-text-right {
    text-align: right !important;
  }
}
@media (max-width: 64em) {
  .header {
    height: 90px;
    background: #fff;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-transition: all 0.2s cubic-bezier(0.45, 0.05, 0.55, 0.95);
    transition: all 0.2s cubic-bezier(0.45, 0.05, 0.55, 0.95);
  }
    .header.is-fixed {
      height: 60px;
    }
  .header__logo {
    -webkit-transition: all 0.2s cubic-bezier(0.45, 0.05, 0.55, 0.95);
    transition: all 0.2s cubic-bezier(0.45, 0.05, 0.55, 0.95);
  }
  .header-navi-btn {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: fixed;
    top: 5px;
    right: 10px;
    z-index: 100;
    width: 50px;
    height: 50px;
    border-radius: 6px;
    border: 0;
    background: #2637b3;
    color: #fff;
    cursor: pointer;
    -webkit-transition: all 0.3s ease-out;
    transition: all 0.3s ease-out;
  }
    .header-navi-btn > .icon {
      display: block;
      position: absolute;
      top: 50%;
      left: 50%;
      width: 18px;
      height: 2px;
      background: #fff;
      margin-left: -9px;
    }
      .header-navi-btn > .icon::before,
      .header-navi-btn > .icon::after {
        display: block;
        position: absolute;
        left: 0;
        width: 18px;
        height: 2px;
        background: #fff;
        content: "";
      }
      .header-navi-btn > .icon::before {
        top: -6px;
      }
      .header-navi-btn > .icon::after {
        bottom: -6px;
      }
  .header-navi {
    opacity: 0;
    overflow: auto;
    visibility: hidden;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 99;
    width: 100%;
    height: 100vh;
    padding: 20px;
    background: rgba(255, 255, 255, 0.95);
    -webkit-transition: opacity 0.2s;
    transition: opacity 0.2s;
  }
  .header-navi-list {
    text-align: center;
  }
    .header-navi-list > li {
      margin: 1em 0;
    }
    .header-navi-list a {
      padding: 0.5rem 0;
      font-size: 1.8rem;
    }
  .header-navi__contact {
    margin-top: 30px;
  }
    .header-navi__contact a {
      display: block;
      width: 200px;
      padding: 15px 15px 17px;
      background: #2637b3;
      color: #fff;
      font-size: 1.6rem;
      font-weight: 700;
      text-align: center;
      -webkit-text-decoration: none;
      text-decoration: none;
    }
      .header-navi__contact a::before {
        margin-right: 5px;
        font-family: "icomoon";
        font-weight: normal;
        content: "\e905";
      }
    .navi-open .header-navi-btn {
      color: #fff;
    }
      .navi-open .header-navi-btn > .icon {
        background: transparent;
      }
        .navi-open .header-navi-btn > .icon::before {
          top: 0;
          -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
        }
        .navi-open .header-navi-btn > .icon::after {
          bottom: 0;
          -webkit-transform: rotate(-135deg);
          transform: rotate(-135deg);
        }
    .navi-open .header-navi {
      opacity: 1;
      visibility: visible;
      -webkit-transition: all 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), visibility 0s;
      transition: all 0.3s cubic-bezier(0.22, 0.61, 0.36, 1), visibility 0s;
    }
    .navi-open .wrap {
      pointer-events: none;
    }
    .header.is-fixed .header__logo {
      width: 200px;
      height: 60px;
    }
      .header.is-fixed .header__logo .logo {
        -webkit-transform: translateY(-30%);
        transform: translateY(-30%);
        -webkit-clip-path: inset(32% 0 0 0);
        clip-path: inset(32% 0 0 0);
      }
    .about02-block__image .image {
      height: 56vw;
    }}
@media (min-width: 64.001em) {
  .header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: absolute;
    height: 92px;
  }
  .header__logo {
    width: 342px;
    height: 160px;
  }
    .header__logo .logo {
      width: 73.68%;
    }
    .header__logo .corner {
      overflow: hidden;
      position: absolute;
      left: 100%;
      bottom: 62px;
      width: 6px;
      height: 6px;
    }
      .header__logo .corner::before {
        display: block;
        width: 12px;
        height: 12px;
        -webkit-box-shadow: -6px -6px 0 0 #fff;
        box-shadow: -6px -6px 0 0 #fff;
        border-radius: 50%;
        content: "";
      }
  .header-navi-btn {
    display: none;
  }
  .header-navi {
    display: block;
    width: 100%;
  }
  .header-navi-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-right: 25px;
    border-top: 5px solid #052275;
  }
    .header-navi-list > li:nth-of-type(n+2) {
      margin-left: 20px;
    }
    .header-navi-list a {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      position: relative;
      height: 92px;
      font-size: 1.4rem;
    }
      .header-navi-list a::before {
        position: absolute;
        top: -5px;
        right: 0;
        left: auto;
        width: 0;
        height: 5px;
        background: #ffd800;
        content: "";
      }
  .header-navi__contact {
    display: none;
  }
  .sticky-contact {
    display: block;
    position: fixed;
    top: 35%;
    right: 0;
    z-index: 1000;
  }
    .sticky-contact a {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
      width: 54px;
      height: 186px;
      padding: 10px;
      border-radius: 10px 0 0 10px;
      background: #2637b3;
      color: #fff;
      font-size: 1.6rem;
      font-weight: 700;
      -webkit-text-decoration: none;
      text-decoration: none;
      -webkit-writing-mode: vertical-lr;
      -ms-writing-mode: tb-lr;
      writing-mode: vertical-lr;
      -webkit-transition: all 0.2s;
      transition: all 0.2s;
    }
      .sticky-contact a::before {
        margin-bottom: 3px;
        font-family: "icomoon";
        font-weight: normal;
        content: "\e905";
      }
      .sticky-contact a:hover {
        background: #ffd800;
        color: #2637b3;
      }
  .header.is-fixed {
    position: fixed;
    -webkit-animation: headerAnim 0.4s ease-out both;
    animation: headerAnim 0.4s ease-out both;
  }
    .header.is-fixed .header__logo {
      height: 92px;
    }
      .header.is-fixed .header__logo .logo {
        width: 61%;
        -webkit-transform: translateY(-20%);
        transform: translateY(-20%);
        -webkit-clip-path: inset(28% 0 0 0);
        clip-path: inset(28% 0 0 0);
      }
  #index .header-navi-list > li:nth-of-type(1) a::before,
  #news .header-navi-list > li:nth-of-type(2) a::before,
  #about .header-navi-list > li:nth-of-type(3) a::before,
  #business .header-navi-list > li:nth-of-type(4) a::before,
  #works .header-navi-list > li:nth-of-type(5) a::before,
  #company .header-navi-list > li:nth-of-type(6) a::before,
  #recruit .header-navi-list > li:nth-of-type(7) a::before {
    width: 100%;
  }
  .wrap {
    padding-top: 92px;
  }
  .main-header__title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -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;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    height: 390px;
  }
    .main-header__title .text {
      font-size: 1.7rem;
    }
      .main-header__title .text[data-en]::before {
        font-size: 7rem;
      }
  .main-header__recruit-banner {
    width: 174px;
  }
  .main-content {
    padding-top: 145px;
  }
    .main-content .breadcrumbs {
      top: 20px;
    }
  .footer {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 800px;
  }
  .footer__info,
  .footer__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
  }
  .footer__info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
  .footer-address,
  .footer-map {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
  .footer-logo {
    width: 174px;
  }
  .footer-map {
    height: auto;
  }
  .footer__content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background: #052275;
    color: #fff;
  }
  .footer__copyright {
    position: fixed;
    top: 50%;
    left: 10px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    margin-top: 0;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
  .h2 {
    margin-bottom: 50px;
    font-size: 4rem;
  }
    .h2::after {
      font-size: 1.4rem;
    }
  .h3 {
    font-size: 3.6rem;
  }
  .section {
    padding: 140px 0;
  }
  .card-more {
    font-size: 1.8rem;
  }
    .top-heading[data-en-before]::before,
    .top-heading[data-en-after]::after {
      font-size: 1.6rem;
    }
  .article-list {
    margin-right: -20px;
    margin-left: -20px;
  }
    .article-list > li {
      padding-right: 20px;
      padding-left: 20px;
    }
      .article-list .article-card__thumb .article-date {
        padding: 14px 12px;
      }
        .article-list .article-card__thumb .article-date .ym {
          font-size: 1.4rem;
        }
        .article-list .article-card__thumb .article-date .day {
          font-size: 2.4rem;
        }
        .article-list .article-card__thumb .article-date .wd {
          font-size: 1.5rem;
        }
    .article-list .article-card__body .article-title {
        font-size: 1.7rem;
      }
      .article-list .article-card__body .article-desc {
        font-size: 1.5rem;
      }
  .article-layout {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .article-layout__main {
    -webkit-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    margin-bottom: 0;
    padding-right: 60px;
  }
  .article-layout__aside {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 270px;
    flex: 0 0 270px;
    max-width: 270px;
  }
    .article__header .article-title {
      margin: 1.2em 0 1em;
      font-size: 3.4rem;
    }
  .article__body {
    margin-bottom: 80px;
  }
  .article-aside-list {
    margin: 0;
  }
    .article-aside-list > li {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 100%;
      flex: 0 0 100%;
      max-width: 100%;
      padding: 0;
    }
      .article-aside-list .article-card__thumb .article-category {
        bottom: 9px;
        left: 9px;
        font-size: 1rem;
      }
      .article-aside-list .article-card__thumb .article-view {
        bottom: 9px;
        right: 9px;
        font-size: 1rem;
      }
    .article-aside-list .article-card__body {
      margin-top: 12px;
      letter-spacing: 0;
    }
  .works-container {
    width: 92%;
    max-width: 1600px;
  }
  .works-list {
    margin: 0 -12px;
  }
    .works-list > li {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 25%;
      flex: 0 0 25%;
      padding: 0 12px;
    }
  .about02-block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin-bottom: 90px;
  }
  .about02-block__content,
  .about02-block__image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45.4545%;
    flex: 0 0 45.4545%;
  }
  .about02-block__content {
    -ms-flex-item-align: center;
    -ms-grid-row-align: center;
    align-self: center;
    padding: 60px 0;
  }
    .about02-block__image .image {
      height: 100%;
      max-height: 430px;
      border-radius: 10px 0 0 10px;
      width: max(calc(100% + 30px), calc(100% + 50vw - 550px));
    }
    .about02-block--first .about02-block__content {
      -ms-flex-item-align: start;
      align-self: flex-start;
      padding-top: 0;
    }
      .about02-block--first .about02-block__image .image {
        max-height: 500px;
      }
  .about02-block--reverse {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
    .about02-block--reverse .about02-block__image {
      direction: rtl;
    }
      .about02-block--reverse .about02-block__image .image {
        border-radius: 0 10px 10px 0;
      }
  .lineup--business {
    margin-top: 130px;
  }
    .lineup-card2__thumb .heading {
      font-size: 2.2rem;
    }
  .business-index__heading {
    font-size: 3.3rem;
  }
    .business-index__image img {
      max-height: 525px;
    }
  .business01::before {
    top: -145px;
  }
  .business01__header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    min-height: 118px;
    margin-bottom: 150px;
  }
    .business01__header > div {
      margin-left: 30px;
    }
  .business01__heading {
    font-size: 5rem;
  }
    .business01__heading::before {
      vertical-align: 0.8em;
    }
  .business01-01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .business01-01__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 54.5454%;
    flex: 0 0 54.5454%;
    padding: 0 50px 0 0;
    line-height: 2.25;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
    .business01-01__content h2 {
      margin: 0 0 0 40px;
    }
    .business01-01__content p {
      margin-top: 50px;
    }
  .business01-01__image1 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 41.8181%;
    flex: 0 0 41.8181%;
    position: relative;
    direction: rtl;
  }

    .business01-01__image1 .image {
      width: max(calc(100% + 30px), calc(100% + 50vw - 550px));
    }
  .business01-01__image2 {
    position: absolute;
    left: 0;
    width: 66.9565%;
    margin: -15% auto 0 0;
  }
  .business01-01__image3 {
    width: 23.3636%;
    margin-top: 0;
    margin-right: 10%;
  }
  .business01-02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .business01-02__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45.4545%;
    flex: 0 0 45.4545%;
    padding: 0 0 0 4.5454%;
  }
    .business01-02__content h2 {
      margin: 0 0 40px 0;
    }
  .business01-02__image1 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    -ms-flex-item-align: end;
    align-self: flex-end;
  }

    .business01-02__image1 .image {
      width: max(calc(100% + 30px), calc(100% + 50vw - 550px));
    }
  .business01-02__image2 {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 28.4545%;
    flex: 0 0 28.4545%;
    margin: 0 50% 0 auto;
  }
  .business02 {
    padding: 120px 0;
  }
  .business02__block {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    position: relative;
    margin-bottom: 1px;
  }
  .business02__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 45.45%;
    flex: 0 0 45.45%;
  }
    .business02__content h3 {
      background: #fff;
    }
    .business02__content p {
      padding-left: 50px;
    }
  .business02__image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%;
    margin-bottom: 0;
  }
    .business02__image .image {
      width: max(calc(100% + 30px), calc(100% + 50vw - 550px));
      height: 100%;
      border-radius: 0;
    }
  .business02__block:first-of-type .business02__image img {
    overflow: hidden;
    border-radius: 10px 0 0 0;
  }
  .business02__block:last-of-type .business02__image img {
    overflow: hidden;
    border-radius: 0 0 0 10px;
  }
      .business02__block:nth-last-of-type(n+2)::before {
        position: absolute;
        top: 40%;
        left: 14px;
        width: 0;
        height: 90%;
        border-left: 1px solid #b7bce6;
        content: "";
      }
    .business03__content p {
      font-size: 2.2rem;
    }
  .business03__list {
    padding: 40px 45px;
  }
    .business03__list ul {
      -webkit-columns: 2;
      -moz-columns: 2;
      columns: 2;
    }
  .business-area {
    padding: 150px 0 140px;
  }
  .faq__content {
    padding: 0 5.4%;
  }
    .faq__content dl {
      padding: 30px 40px;
    }
    .faq__content dt {
      font-size: 2.2rem;
    }
  .l-company {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .l-company__image {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 35.6363%;
    flex: 0 0 35.6363%;
    direction: rtl;
    margin-bottom: 0;
  }
    .l-company__image .image {
      width: max(calc(100% + 30px), calc(100% + 50vw - 550px));
      height: 100%;
    }
  .l-company__content {
    -webkit-box-flex: 0;
    -ms-flex: 0 0 54.5454%;
    flex: 0 0 54.5454%;
    padding: 60px 0;
  }
  .recruit03-block__heading {
    font-size: 3.2rem;
  }
  .recruit04__timeline {
    max-width: none;
  }
    .recruit04__timeline ul {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-pack: center;
      -ms-flex-pack: center;
      justify-content: center;
    }
    .recruit04__timeline li {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
      -webkit-box-orient: vertical;
      -webkit-box-direction: normal;
      -ms-flex-direction: column;
      flex-direction: column;
      -webkit-box-align: center;
      -ms-flex-align: center;
      align-items: center;
      position: relative;
      padding-left: 35px;
    }
    .recruit04__timeline li:nth-of-type(n+2)::before {
      position: absolute;
      top: 5px;
      left: 5px;
      width: 25px;
      height: 4px;
      margin-left: 0;
    }
    .recruit04__timeline .time {
      width: auto;
      line-height: 1;
      white-space: nowrap;
    }
    .recruit04__timeline .text {
      -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
      writing-mode: vertical-rl;
      line-height: 1;
    }
      .recruit04__timeline .text::before {
        width: 0;
        height: 17px;
        margin: 10px 0.5em 10px 0;
        border-bottom: none;
        border-left: 1px dotted;
      }
  .recruit05 {
    padding-bottom: 140px;
  }
  .recruit05__content {
    margin-top: -230px;
    padding-top: 100px;
  }}
@media (min-width: 75.001em) {
  .header-navi-list {
    margin-right: 33px;
  }
    .header-navi-list > li:nth-of-type(n+2) {
      margin-left: 30px;
    }
    .header-navi-list a {
      font-size: 1.6rem;
    }}
@media (hover:hover) {
  .header-navi-list a::before {
    -webkit-transition: all 0.3s cubic-bezier(0.65, 0.05, 0.36, 1);
    transition: all 0.3s cubic-bezier(0.65, 0.05, 0.36, 1);
  }
  .header-navi-list a:hover::before {
    right: auto;
    left: 0;
    width: 100%;
  }
  /* リンク */
  .hover-scale {
    overflow: hidden;
    position: relative;
    z-index: 1;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
  }
  .hover-scale img {
    -webkit-transition: all 1s cubic-bezier(0.22, 0.61, 0.36, 1);
    transition: all 1s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
  .hover-scale:hover img,
  a:hover .hover-scale img {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
  .hover-fade {
    -webkit-transition: all 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
    transition: all 0.3s cubic-bezier(0.22, 0.61, 0.36, 1);
  }
  .hover-fade:hover {
    opacity: 0.7;
  }
    a:hover .card-more {
      opacity: 1;
    }
      a:hover .card-more::after {
        width: 100%;
      }
    .category-list a:hover {
      border-color: #ffd800;
      background: #ffd800;
      color: #2637b3;
    }
    .works-card:hover .works-card__thumb::before {
      opacity: 1;
    }
    .lineup-card2__thumb:hover::before {
      opacity: 0.26;
    }
}
@media (hover: hover) {
    .pagination-list a:hover {
      opacity: 0.7;
    }
  .recruit02__movie:hover::before {
    -webkit-transform: translate(-50%, -50%) scale(0.9);
    transform: translate(-50%, -50%) scale(0.9);
  }
}
@media (max-width: 35em) {
    .article-aside-list--sm-h .article-card {
      display: -webkit-box;
      display: -ms-flexbox;
      display: flex;
    }
    .article-aside-list--sm-h .article-card__thumb {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 25%;
      flex: 0 0 25%;
    }
    .article-aside-list--sm-h .article-card__body {
      -webkit-box-flex: 0;
      -ms-flex: 0 0 75%;
      flex: 0 0 75%;
      margin-top: 0;
      padding-left: 12px;
    }
      .article-aside-list--sm-h .article-card__body .article-title,
      .article-aside-list--sm-h .article-card__body .article-desc {
        text-overflow: inherit;
        white-space: normal;
      }
      .article-aside-list--sm-h .article-card__body .article-title {
        font-size: 1.5rem;
      }
      .article-aside-list--sm-h .article-card__body .article-desc {
        font-size: 1.2rem;
      }
}
/*# sourceMappingURL=maps/main.css.map */
