@charset "UTF-8";
/*!
Theme Name: ユニオンペイントグループ
Theme URI: https://panarea.co.jp
Author: shogo yonetani
Author URI: https://panarea.co.jp
Description: ユニオンペイントグループ
*/
/*Color Management*/
:root {
  --sans: YakuHanJP_Narrow, "Inter", 游ゴシック, Yu Gothic, YuGothic, sans-serif;
  --s-font-noto: 'Noto Sans JP';
  --s-font-inter: Inter;
  --fontweight-5: 500;
  --fontweight-6: 600;
  --fontweight-7: 700;
  --fontweight-8: 800;
  --key1: #FEFCFB;
  --key2: #FFF5F1;
  --key3: #FFEAE0;
  --key4: #FFD7C6;
  --key5: #FFC9B3;
  --key6: #FFB89D;
  --key7: #FFA588;
  --key8: #F48C6A;
  --key9: #F45512;
  --key10: #E34B02;
  --key11: #D73F00;
  --key12: #5A2B1B;
  --gray1: #FCFCFC;
  --gray2: #F9F9F9;
  --gray3: #F0F0F0;
  --gray4: #E8E8E8;
  --gray5: #E1E1E1;
  --gray6: #D9D9D9;
  --gray7: #CECECE;
  --gray8: #BBB;
  --gray9: #8C8C8C;
  --gray10: #818181;
  --gray11: #636363;
  --gray12: #1F1F1F;
  --color-white: #fff;
  --color-gray: #757575;
  --color-lightgray: #ecedf0;
  --color-black: #171617;
  --border-light-black: rgba(31,69,94,.205);
  --border-light-white: rgba(255,255,255,.1025); }

/*!レスポンシブ*/
/*mouse-follower-dev*/
.mf-cursor {
  color: #555555;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10001 !important;
  direction: ltr;
  contain: layout style size;
  pointer-events: none;
  transition: opacity 0.3s, color 0.4s; }
  @media screen and (max-width: 768px) {
    .mf-cursor {
      display: none; } }
  .mf-cursor:before {
    content: "";
    position: absolute;
    top: -24px;
    left: -24px;
    display: block;
    width: 48px;
    height: 48px;
    transform: scale(0.2);
    background: currentColor;
    border-radius: 50%;
    transition: transform 0.25s ease-in-out, opacity 0.1s; }
  .mf-cursor.-inverse {
    color: #aaaaaa; }
  @supports (mix-blend-mode: exclusion) {
    .mf-cursor.-exclusion {
      mix-blend-mode: exclusion; }
      .mf-cursor.-exclusion:before {
        background: #aaaaaa; } }
  .mf-cursor.-pointer:before {
    transform: scale(0.15); }
  .mf-cursor.-text {
    white-space: nowrap; }
    .mf-cursor.-text:before {
      opacity: 0.85;
      transform: scale(1.7); }
    .mf-cursor.-text.-active:before {
      transform: scale(1.6);
      transition-duration: 0.2s; }
  .mf-cursor.-icon:before {
    transform: scale(1.5); }
  .mf-cursor.-icon.-active:before {
    transform: scale(1.4); }
  .mf-cursor.-hidden:before {
    transform: scale(0); }
  .mf-cursor.-image {
    border-radius: 16px;
    /* 50% で円 */
    overflow: hidden; }
  .mf-cursor-text {
    position: absolute;
    top: -18px;
    left: -18px;
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    transform: scale(0) rotate(10deg);
    opacity: 0;
    color: #fff;
    font-size: 16px;
    line-height: 20px;
    text-align: center;
    transition: opacity 0.4s, transform 0.3s; }
    .mf-cursor.-text .mf-cursor-text, .mf-cursor.-icon .mf-cursor-text {
      opacity: 1;
      transform: scale(1); }
  .mf-cursor-media {
    position: absolute;
    width: 300px !important;
    height: 200px !important;
    margin: -150px 0 0 -100px !important; }
    @media screen and (max-width: 768px) {
      .mf-cursor-media {
        width: 240px !important;
        height: 160px !important;
        margin: -120px 0 0 -80px !important; } }
    .mf-cursor-media .mf-cursor-media-box {
      border-radius: calc(8em / 32) !important; }
    .mf-cursor-media img, .mf-cursor-media video {
      position: absolute;
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%);
      border-radius: calc(8em / 32) !important; }
      @supports (object-fit: cover) {
        .mf-cursor-media img, .mf-cursor-media video {
          position: static;
          width: 100%;
          height: 100%;
          object-fit: cover;
          transform: translateZ(0); } }
    .mf-cursor-media-box {
      position: relative;
      width: 100%;
      height: 100%;
      overflow: hidden;
      transform: scale(0) translateZ(0);
      padding: 1px;
      opacity: 0;
      border-radius: 50%;
      transition: transform 0.35s, opacity 0.2s 0.2s; }
      .mf-cursor.-media .mf-cursor-media-box {
        opacity: 1;
        transform: scale(0.696);
        transition-duration: 0.4s, 0.4s;
        transition-delay: 0s, 0s; }

html {
  font-family: sans-serif;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%; }

body {
  margin: 0; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
  display: block; }

audio, canvas, progress, video {
  display: inline-block;
  vertical-align: baseline; }

audio:not([controls]) {
  display: none;
  height: 0; }

[hidden], template {
  display: none; }

a {
  background: transparent; }

a:active, a:hover {
  outline: 0; }

abbr[title] {
  border-bottom: 1px dotted; }

b, strong {
  font-weight: 700; }

dfn {
  font-style: italic; }

h1 {
  font-size: 2em;
  margin: .67em 0; }

mark {
  background: #ff0;
  color: #000; }

small {
  font-size: 80%; }

sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -.5em; }

sub {
  bottom: -.25em; }

img {
  border: 0; }

svg:not(:root) {
  overflow: hidden; }

figure {
  margin: 1em 40px; }

hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0; }

pre {
  overflow: auto; }

code, kbd, pre, samp {
  font-family: monospace;
  font-size: 1em; }

input, optgroup, select, textarea {
  color: inherit;
  font: inherit;
  margin: 0; }

button {
  overflow: visible; }

button, select {
  text-transform: none; }

button, html input[type="button"], input[type=reset], input[type=submit] {
  -webkit-appearance: button;
  /*cursor:pointer*/ }

button[disabled], html input[disabled] {
  /*cursor:default*/ }

button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0; }

input {
  line-height: normal; }

input[type=checkbox], input[type=radio] {
  box-sizing: border-box;
  padding: 0; }

input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button {
  height: auto; }

input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

fieldset {
  border: 1px solid silver;
  margin: 0 2px;
  padding: .35em .625em .75em; }

legend {
  border: 0;
  padding: 0; }

textarea {
  overflow: auto; }

optgroup {
  font-weight: 700; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

td, th {
  padding: 0; }

/*!//normalize.css*/
/*! locomotive-scroll v4.1.3 | MIT License | https://github.com/locomotivemtl/locomotive-scroll */
html.has-scroll-smooth {
  overflow: hidden; }

html.has-scroll-dragging {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none; }

.has-scroll-smooth body {
  overflow: hidden; }

.has-scroll-smooth [data-scroll-container] {
  min-height: 100vh; }

[data-scroll-direction=horizontal] [data-scroll-container] {
  display: inline-block;
  height: 100vh;
  white-space: nowrap; }

[data-scroll-direction=horizontal] [data-scroll-section] {
  display: inline-block;
  height: 100%;
  vertical-align: top;
  white-space: nowrap; }

.c-scrollbar {
  height: 100%;
  opacity: 0;
  position: absolute;
  right: 0;
  top: 0;
  transform-origin: center right;
  transition: transform .3s,opacity .3s;
  width: 11px; }

.c-scrollbar:hover {
  transform: scaleX(1.45); }

.c-scrollbar:hover, .has-scroll-dragging .c-scrollbar, .has-scroll-scrolling .c-scrollbar {
  opacity: 1; }

[data-scroll-direction=horizontal] .c-scrollbar {
  bottom: 0;
  height: 10px;
  top: auto;
  transform: scaleY(1);
  width: 100%; }

[data-scroll-direction=horizontal] .c-scrollbar:hover {
  transform: scaleY(1.3); }

.c-scrollbar_thumb {
  background-color: #000;
  border-radius: 10px;
  cursor: -webkit-grab;
  cursor: grab;
  margin: 2px;
  opacity: .5;
  position: absolute;
  right: 0;
  top: 0;
  width: 7px; }

.has-scroll-dragging .c-scrollbar_thumb {
  cursor: -webkit-grabbing;
  cursor: grabbing; }

[data-scroll-direction=horizontal] .c-scrollbar_thumb {
  bottom: 0;
  right: auto; }

/*!basic css*/
html {
  height: 100%;
  font-size: 1.2vw; }
  @media screen and (max-width: 768px) {
    html {
      font-size: 3.5vw; } }

body {
  margin: 0;
  position: relative;
  margin-left: auto;
  margin-right: auto;
  width: auto;
  height: auto;
  font-family: var(--sans);
  font-weight: 400;
  letter-spacing: 0;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  background: var(--color-white);
  color: var(--gray12);
  /*
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  opacity: 0;
  */
  transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  padding-bottom: 1px; }
  body::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    z-index: 15;
    display: block;
    width: 100%;
    height: 100%;
    background: url("images/noise.png");
    background-repeat: repeat;
    background-size: 100px;
    pointer-events: none;
    opacity: .5; }

* {
  color: var(--gray12);
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  font-feature-settings: "palt";
  -ms-overflow-style: none; }
  *::-webkit-scrollbar {
    display: none; }

::selection {
  background-color: rgba(0, 0, 0, 0.15);
  color: var(--gray12); }

/*!TEXT*/
p, h1, h2, h3, h4, h5 {
  display: block;
  -webkit-margin-before: 0em;
  -webkit-margin-after: 0em;
  -webkit-margin-start: 0px;
  -webkit-margin-end: 0px;
  margin: 0;
  font-size: 1em; }

h1, h2, h3, h4, h5 {
  position: relative;
  z-index: 15; }

p {
  letter-spacing: 0;
  font-weight: 400;
  line-height: 1.64; }

i {
  font-style: normal; }

.emphasis {
  background: linear-gradient(#ff1d9157, #ff1d9157) no-repeat;
  background-size: 100%;
  background-position: 0; }

.objc {
  width: 100% !important;
  height: 100% !important;
  object-fit: contain;
  font-family: 'object-fit: contain;'; }

img {
  max-width: 100%;
  height: auto; }

img.objf, video.objf, iframe.objf {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;'; }

/*!LINK*/
a {
  text-decoration: none; }

.noallow {
  cursor: not-allowed !important;
  pointer-events: none !important; }

/*!ul/dl*/
ul, dl {
  -webkit-margin-before: 0;
  -webkit-margin-after: 0;
  -webkit-margin-start: 0;
  -webkit-margin-end: 0;
  -webkit-padding-start: 0;
  -moz-margin-before: 0;
  -moz-margin-after: 0;
  -moz-margin-start: 0;
  -moz-margin-end: 0;
  -moz-padding-start: 0;
  -ms-margin-before: 0;
  -ms-margin-after: 0;
  -ms-margin-start: 0;
  -ms-margin-end: 0;
  -ms-padding-start: 0;
  -o-margin-before: 0;
  -o-margin-after: 0;
  -o-margin-start: 0;
  -o-margin-end: 0;
  -o-padding-start: 0;
  margin-before: 0;
  margin-after: 0;
  margin-start: 0;
  margin-end: 0;
  padding-start: 0;
  -webkit-padding-left: 0;
  -moz-padding-left: 0;
  -ms-padding-left: 0;
  -o-padding-left: 0;
  padding-left: 0;
  margin-top: 0;
  margin-bottom: 0; }

ul li {
  list-style-type: none; }

dl dd {
  margin-left: 0; }

.clear::after {
  content: '';
  display: block;
  clear: both; }

/*!fugure*/
figure {
  margin: 0; }
  figure figurecaption {
    font-size: .85em;
    margin-top: .41em;
    display: block; }

/*!Resposive*/
.hidden-xs {
  display: block !important; }
  @media screen and (max-width: 768px) {
    .hidden-xs {
      display: none !important; } }

.visible-xs {
  display: none !important; }
  @media screen and (max-width: 768px) {
    .visible-xs {
      display: block !important; } }

/*!.sticky*/
.sticky {
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 8999; }

/*!.inview*/
.inview {
  opacity: 0; }
  .inview.action {
    opacity: 1;
    transition: all cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.615s;
    -o-transition: all cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.615s;
    -moz-transition: all cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.615s;
    -webkit-transition: all cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.615s; }
  .inview.action[data-delay="1"] {
    transition-delay: 0.05s; }
  .inview.action[data-delay="2"] {
    transition-delay: 0.1s; }
  .inview.action[data-delay="3"] {
    transition-delay: 0.15s; }
  .inview.action[data-delay="4"] {
    transition-delay: 0.2s; }
  .inview.action[data-delay="5"] {
    transition-delay: 0.25s; }
  .inview.action[data-delay="6"] {
    transition-delay: 0.3s; }
  .inview.action[data-delay="7"] {
    transition-delay: 0.35s; }
  .inview.action[data-delay="8"] {
    transition-delay: 0.4s; }
  .inview.action[data-delay="9"] {
    transition-delay: 0.45s; }
  .inview.action[data-delay="10"] {
    transition-delay: 0.5s; }

/*ベンダープレフィックス登録*/
/*!input*/
select {
  outline: none;
  text-indent: 0.01px;
  text-overflow: '';
  background: #f8f8f8;
  vertical-align: middle;
  font-size: inherit;
  color: inherit;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
  border: none;
  width: 100%;
  height: 60px;
  font-size: 1.5rem; }
  select option {
    background-color: #fff;
    color: #333; }

/*!------------------------------------
css_assets(パーツ)
-------------------------------------*/
/*!button*/
.humbBtn {
  position: relative;
  z-index: 15;
  width: 3.28em;
  height: 3.28em;
  border-radius: 4.1em;
  transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
  @media screen and (max-width: 768px) {
    .humbBtn {
      display: block; } }
  .humbBtn::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    display: block;
    width: 100%;
    height: 100%;
    border-radius: 50%;
    background: var(--color-white);
    transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
    -o-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
    -moz-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
    -webkit-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s; }
  .humbBtn span.dots {
    display: block;
    width: 4px;
    height: 4px;
    border-radius: 4px;
    background: var(--gray12);
    position: absolute;
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    .humbBtn span.dots:nth-child(1) {
      top: calc(50% - 8px);
      left: calc(50% - 8px);
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(2) {
      top: calc(50% - 8px);
      left: 50%;
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(3) {
      top: calc(50% - 8px);
      left: calc(50% + 8px);
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(4) {
      top: 50%;
      left: calc(50% - 8px);
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(5) {
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(6) {
      top: 50%;
      left: calc(50% + 8px);
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(7) {
      top: calc(50% + 8px);
      left: calc(50% - 8px);
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(8) {
      top: calc(50% + 8px);
      left: 50%;
      transform: translate(-50%, -50%); }
    .humbBtn span.dots:nth-child(9) {
      top: calc(50% + 8px);
      left: calc(50% + 8px);
      transform: translate(-50%, -50%); }
  .humbBtn span.border {
    display: block;
    width: 30%;
    height: 1px;
    border-radius: 2px;
    background: var(--gray12);
    position: absolute;
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    .humbBtn span.border:nth-child(1) {
      top: 40%;
      left: 55%;
      transform: translate(-50%, -50%); }
    .humbBtn span.border:nth-child(2) {
      top: 50%;
      left: 45%;
      transform: translate(-50%, -50%); }
    .humbBtn span.border:nth-child(3) {
      top: 60%;
      left: 50%;
      transform: translate(-50%, -50%); }
  .humbBtn span.borders {
    display: block;
    width: 30%;
    height: 1px;
    border-radius: 2px;
    background: var(--gray12);
    position: absolute;
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    .humbBtn span.borders:nth-child(1) {
      top: 37.5%;
      left: 50%;
      transform: translate(-50%, -50%); }
    .humbBtn span.borders:nth-child(2) {
      top: 50%;
      left: 50%;
      transform: translate(-50%, -50%); }
    .humbBtn span.borders:nth-child(3) {
      top: 62.5%;
      left: 50%;
      transform: translate(-50%, -50%); }
  .humbBtn span.txt {
    position: absolute;
    bottom: 0;
    width: 100%;
    text-align: center;
    font-size: .7em;
    color: var(--color-white);
    letter-spacing: 3px; }
  .humbBtn:hover {
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    .humbBtn:hover::before {
      border-radius: 6px;
      transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
      -o-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
      -moz-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
      -webkit-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s; }
    .humbBtn:hover span.dots {
      background: var(--gray12);
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .humbBtn:hover span.dots:nth-child(1) {
        top: calc(50% - 6px);
        left: calc(50% - 6px); }
      .humbBtn:hover span.dots:nth-child(2) {
        top: calc(50% - 6px);
        left: 50%; }
      .humbBtn:hover span.dots:nth-child(3) {
        top: calc(50% - 6px);
        left: calc(50% + 6px); }
      .humbBtn:hover span.dots:nth-child(4) {
        top: 50%;
        left: calc(50% - 6px); }
      .humbBtn:hover span.dots:nth-child(5) {
        top: 50%;
        left: 50%; }
      .humbBtn:hover span.dots:nth-child(6) {
        top: 50%;
        left: calc(50% + 6px); }
      .humbBtn:hover span.dots:nth-child(7) {
        top: calc(50% + 6px);
        left: calc(50% - 6px); }
      .humbBtn:hover span.dots:nth-child(8) {
        top: calc(50% + 6px);
        left: 50%; }
      .humbBtn:hover span.dots:nth-child(9) {
        top: calc(50% + 6px);
        left: calc(50% + 6px); }
    .humbBtn:hover span.borders {
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .humbBtn:hover span.borders:nth-child(1) {
        top: 50%; }
      .humbBtn:hover span.borders:nth-child(3) {
        top: 50%; }
  .humbBtn.active {
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    .humbBtn.active::before {
      transform: scale(1);
      pointer-events: none;
      opacity: 0;
      transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
      -o-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
      -moz-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s;
      -webkit-transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s; }
    .humbBtn.active span.dots {
      background: var(--gray2);
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .humbBtn.active span.dots:nth-child(1) {
        top: 50%;
        left: calc(50% - 5px); }
      .humbBtn.active span.dots:nth-child(2) {
        top: 50%;
        left: 50%; }
      .humbBtn.active span.dots:nth-child(3) {
        top: 50%;
        left: calc(50% + 5px); }
      .humbBtn.active span.dots:nth-child(4) {
        top: 50%;
        left: calc(50% - 5px); }
      .humbBtn.active span.dots:nth-child(5) {
        top: 50%;
        left: 50%; }
      .humbBtn.active span.dots:nth-child(6) {
        top: 50%;
        left: calc(50% + 5px); }
      .humbBtn.active span.dots:nth-child(7) {
        top: 50%;
        left: calc(50% - 5px); }
      .humbBtn.active span.dots:nth-child(8) {
        top: 50%;
        left: 50%; }
      .humbBtn.active span.dots:nth-child(9) {
        top: 50%;
        left: calc(50% + 5px); }
    .humbBtn.active span.border {
      background: var(--gray10) !important;
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .humbBtn.active span.border:nth-child(1) {
        top: 50%; }
      .humbBtn.active span.border:nth-child(3) {
        top: 50%; }
    .humbBtn.active span.borders {
      background: var(--color-white) !important;
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .humbBtn.active span.borders:nth-child(1) {
        top: 50%;
        transform: translate(-50%, -50%) rotate(45deg); }
      .humbBtn.active span.borders:nth-child(2) {
        opacity: 0; }
      .humbBtn.active span.borders:nth-child(3) {
        top: 50%;
        transform: translate(-50%, -50%) rotate(-45deg); }
    .humbBtn.active span.txt {
      color: var(--color-white) !important; }
  .humbBtn.scroll span {
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }

.roll {
  display: block;
  height: 1.5em;
  overflow: hidden; }
  .roll > i {
    display: block;
    line-height: 1.5;
    white-space: nowrap;
    transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  .roll:hover > i {
    transform: translateY(-1.5em);
    transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }

.button {
  display: flex;
  align-items: center;
  column-gap: calc(8em / 32 * 6);
  min-height: 2.87em;
  background: var(--gray1);
  border: solid 1px var(--gray9);
  border-radius: calc(8em / 8);
  overflow: hidden; }
  .button .text {
    padding-left: calc(8em / 32 * 6); }
  .button .icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.87em;
    min-width: 2.87em;
    height: 2.87em;
    padding: calc(8em / 64 * 9);
    border-radius: calc(8em / 16);
    overflow: hidden;
    line-height: 0; }
  .button:hover .icon img {
    animation: arrowAnimation .328s 0s ease-in-out 1; }
  .button.left {
    justify-content: flex-start; }
  .button.center {
    justify-content: center; }
  .button.right {
    justify-content: flex-end; }
  .button.white {
    background: var(--gray1); }
    .button.white * {
      color: var(--gray12) !important; }
  .button.black {
    background: var(--gray12);
    border-color: var(--gray11); }
    .button.black .text, .button.black * {
      color: var(--gray1); }
    .button.black .icon img {
      filter: brightness(0) invert(1); }
  .button.red .icon {
    background: var(--key9); }
    .button.red .icon img {
      filter: brightness(0) invert(1); }

.hero-catch {
  position: relative;
  mask-size: contain;
  mask-repeat: no-repeat;
  mask-position: center;
  background: linear-gradient(135deg, var(--gray12) 40%, var(--key9) 50%, var(--gray9) 60%, var(--gray12) 70%);
  background-size: 250% 100%;
  animation: blue-light-sweep 10s alternate infinite;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent; }

@keyframes blue-light-sweep {
  0% {
    background-position: -150% 0; }
  100% {
    background-position: 150% 0; } }
/*!------------------------------------
css_sections(ブロック)
-------------------------------------*/
/*!#siteHeader------------------------------------------------------------------------------------------------*/
/*公式*/
#siteHead {
  position: fixed;
  left: 0;
  z-index: 8000;
  width: 100%;
  transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
  #siteHead::before {
    content: '';
    position: absolute;
    top: 0;
    z-index: -1;
    display: block;
    width: 100%;
    height: 0;
    background: var(--color-white);
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
  #siteHead .wrapper {
    position: relative;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: calc(100% / 32 * 31);
    height: calc(8em / 8 * 5);
    margin: 0 auto;
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    @media screen and (max-width: 768px) {
      #siteHead .wrapper {
        height: calc(8em / 8 * 3); } }
    #siteHead .wrapper > .left h1 {
      display: flex;
      align-items: center;
      gap: calc(8em / 32 * 3); }
      @media screen and (max-width: 768px) {
        #siteHead .wrapper > .left h1 {
          gap: calc(8em / 32 * 2); } }
      @media screen and (max-width: 768px) {
        #siteHead .wrapper > .left h1 img {
          width: 4.92em;
          height: auto; } }
      #siteHead .wrapper > .left h1 p {
        font-size: 1.23em;
        font-weight: 600;
        letter-spacing: -.0205em; }
        @media screen and (max-width: 768px) {
          #siteHead .wrapper > .left h1 p {
            font-size: 1.075em; } }
    #siteHead .wrapper nav {
      position: relative;
      z-index: 15;
      display: flex;
      align-items: center;
      gap: calc(8em / 32 * 8); }
      #siteHead .wrapper nav ul.navigation {
        display: flex;
        align-items: center;
        flex-direction: row;
        gap: calc(8em / 32 * 4); }
        @media screen and (max-width: 768px) {
          #siteHead .wrapper nav ul.navigation {
            display: none; } }
        #siteHead .wrapper nav ul.navigation > li a {
          font-weight: 500; }
      #siteHead .wrapper nav ul.recruit-cta {
        display: flex;
        align-items: center;
        flex-direction: row;
        gap: calc(8em / 32 * 2);
        font-size: .9em; }
        @media screen and (max-width: 768px) {
          #siteHead .wrapper nav ul.recruit-cta {
            display: none; } }
      #siteHead .wrapper nav [data-type="button"] {
        display: flex;
        align-items: center;
        justify-content: center;
        min-width: 8.2em;
        height: 2em;
        background: transparent;
        border-radius: calc(8em / 32 * 1);
        overflow: hidden;
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        @media screen and (max-width: 768px) {
          #siteHead .wrapper nav [data-type="button"] {
            min-width: 6.15em; } }
        #siteHead .wrapper nav [data-type="button"][data-action="navigation"] {
          background: var(--gray12);
          display: none; }
          @media screen and (max-width: 768px) {
            #siteHead .wrapper nav [data-type="button"][data-action="navigation"] {
              display: flex; } }
        #siteHead .wrapper nav [data-type="button"] * {
          color: var(--gray1); }
        #siteHead .wrapper nav [data-type="button"]:hover, #siteHead .wrapper nav [data-type="button"]:has(.active) {
          filter: brightness(0.8);
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      #siteHead .wrapper nav .lower {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 0;
        width: auto;
        min-width: 16.4em;
        padding-top: calc(8em / 16 * 5);
        opacity: 0;
        visibility: hidden;
        pointer-events: none;
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        #siteHead .wrapper nav .lower .lower-wrapper {
          display: flex;
          gap: calc(8em / 32);
          width: 100%;
          padding: calc(8em / 32);
          background: var(--gray12);
          border-radius: calc(8em / 32); }
          #siteHead .wrapper nav .lower .lower-wrapper > .text {
            flex: 1;
            padding: calc(8em / 8 * 2); }
            @media screen and (max-width: 768px) {
              #siteHead .wrapper nav .lower .lower-wrapper > .text {
                padding: calc(8em / 16 * 2); } }
            #siteHead .wrapper nav .lower .lower-wrapper > .text * {
              color: var(--gray1); }
          #siteHead .wrapper nav .lower .lower-wrapper ul {
            display: flex;
            flex-direction: column;
            gap: calc(8em / 16); }
            #siteHead .wrapper nav .lower .lower-wrapper ul > li {
              position: relative;
              top: 1em;
              display: flex;
              align-items: center;
              gap: calc(8em / 16);
              opacity: 0; }
              #siteHead .wrapper nav .lower .lower-wrapper ul > li::before {
                content: '';
                display: block;
                width: .7em;
                height: .7em;
                background: var(--key2);
                border-radius: 1em;
                overflow: hidden; }
              #siteHead .wrapper nav .lower .lower-wrapper ul > li.current::before {
                background: var(--key9); }
        #siteHead .wrapper nav .lower.open {
          opacity: 1;
          visibility: visible;
          pointer-events: auto;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
          #siteHead .wrapper nav .lower.open .lower-wrapper ul li {
            top: 0;
            opacity: 1;
            transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(0) {
              transition-delay: calc((0 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(1) {
              transition-delay: calc((1 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(2) {
              transition-delay: calc((2 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(3) {
              transition-delay: calc((3 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(4) {
              transition-delay: calc((4 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(5) {
              transition-delay: calc((5 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(6) {
              transition-delay: calc((6 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(7) {
              transition-delay: calc((7 * 0.041s) + .1025s); }
            #siteHead .wrapper nav .lower.open .lower-wrapper ul li:nth-child(8) {
              transition-delay: calc((8 * 0.041s) + .1025s); }
  #siteHead ._menu {
    position: relative;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%; }
    #siteHead ._menu p.humbNav {
      display: flex;
      align-items: center;
      column-gap: calc(8em / 16);
      text-transform: uppercase;
      font-size: .9em; }
      @media screen and (max-width: 768px) {
        #siteHead ._menu p.humbNav {
          column-gap: calc(8em / 32); } }
      #siteHead ._menu p.humbNav > span {
        position: relative;
        display: flex;
        align-content: space-between;
        flex-wrap: wrap;
        width: 1em;
        height: .5em;
        margin: 0 auto; }
        #siteHead ._menu p.humbNav > span > i {
          display: block;
          width: 1em;
          height: 1px;
          background: var(--color-white);
          border-radius: 1px;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      #siteHead ._menu p.humbNav.active > span {
        align-content: center; }
        #siteHead ._menu p.humbNav.active > span > i {
          width: 1.435em !important;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
          #siteHead ._menu p.humbNav.active > span > i:first-child {
            transform: rotate(18deg) translateY(0.5px); }
          #siteHead ._menu p.humbNav.active > span > i:last-child {
            transform: rotate(-18deg) translateY(-0.5px); }
  #siteHead.move {
    opacity: 0;
    pointer-events: none;
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }

body.scroll #siteHead {
  top: 0;
  transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
  -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
  -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
  -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  body.scroll #siteHead::before {
    height: 100%;
    transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  body.scroll #siteHead .wrapper {
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
body.scroll.scrollUp #siteHead {
  transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }

/*!#aside*/
aside#aside {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 7999;
  display: none;
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
  overflow: scroll;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px); }
  @media screen and (max-width: 768px) {
    aside#aside {
      padding-bottom: 4.1em;
      background: var(--border-light-black);
      -webkit-backdrop-filter: blur(10px);
      backdrop-filter: blur(10px); } }
  aside#aside .navigation_wrapper {
    display: flex;
    align-items: flex-end;
    flex-direction: column;
    width: calc(100% / 16* 15);
    margin: 0 auto;
    height: 100%;
    margin: 0 auto;
    padding-top: calc(8em / 8 * 5);
    overflow: scroll; }
    @media screen and (max-width: 768px) {
      aside#aside .navigation_wrapper {
        justify-content: flex-end;
        padding-bottom: calc(8em / 12 * 1); } }
    aside#aside .navigation_wrapper .navigation_body {
      position: relative;
      z-index: 15;
      min-width: calc(8em / 8 * 21);
      max-width: 100%;
      padding: calc(8em / 16 * 3);
      border: solid 1px var(--border-light-black);
      border-radius: calc(8em / 16 * 1);
      overflow: hidden;
      -webkit-backdrop-filter: blur(10px);
      backdrop-filter: blur(10px); }
      @media screen and (max-width: 768px) {
        aside#aside .navigation_wrapper .navigation_body {
          min-width: 100%; } }
      aside#aside .navigation_wrapper .navigation_body::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        display: block;
        width: 100%;
        height: 100%;
        background: linear-gradient(135deg, var(--color-black) 75%, var(--key12));
        opacity: .95;
        pointer-events: none; }
    aside#aside .navigation_wrapper ul.list {
      border-top: solid 1px var(--border-light-black); }
      aside#aside .navigation_wrapper ul.list * {
        color: var(--color-white); }
      aside#aside .navigation_wrapper ul.list > li {
        border-bottom: solid 1px var(--border-light-black); }
        aside#aside .navigation_wrapper ul.list > li:hover dl > dt::before {
          background: var(--color-white);
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        aside#aside .navigation_wrapper ul.list > li.current dl > dt::before {
          background: var(--color-white) !important;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        aside#aside .navigation_wrapper ul.list > li dl {
          display: flex;
          align-items: center;
          gap: 0 calc(8em / 3); }
          @media screen and (max-width: 768px) {
            aside#aside .navigation_wrapper ul.list > li dl {
              flex-direction: column;
              align-items: flex-start; } }
          aside#aside .navigation_wrapper ul.list > li dl > dt {
            display: flex;
            align-items: center;
            column-gap: calc(8em / 12); }
            aside#aside .navigation_wrapper ul.list > li dl > dt::before {
              content: '';
              display: block;
              width: .9em;
              min-width: .9em;
              height: .9em;
              border-radius: calc(8em / 48);
              background: rgba(255, 255, 255, 0.328);
              transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
            aside#aside .navigation_wrapper ul.list > li dl > dt a, aside#aside .navigation_wrapper ul.list > li dl > dt div {
              display: flex;
              align-items: center;
              justify-content: space-between;
              column-gap: .615em;
              padding: calc(8em / 32 * 3) 0;
              font-size: 1.1275em;
              letter-spacing: -.01025em;
              line-height: 1; }
              @media screen and (max-width: 768px) {
                aside#aside .navigation_wrapper ul.list > li dl > dt a, aside#aside .navigation_wrapper ul.list > li dl > dt div {
                  padding: calc(85px / 6) 0; } }
              aside#aside .navigation_wrapper ul.list > li dl > dt a > span, aside#aside .navigation_wrapper ul.list > li dl > dt div > span {
                position: relative;
                z-index: 15;
                display: flex;
                align-items: center;
                justify-content: center;
                width: 2em;
                height: 1em;
                border: solid 1px var(--color-white);
                border-radius: 50%; }
                aside#aside .navigation_wrapper ul.list > li dl > dt a > span i, aside#aside .navigation_wrapper ul.list > li dl > dt div > span i {
                  position: absolute;
                  top: calc(50% - (1px / 2));
                  left: calc(50% - (1em / 2));
                  display: block;
                  width: 1em;
                  height: 1px;
                  background: var(--color-white);
                  transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                  -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                  -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                  -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
                  aside#aside .navigation_wrapper ul.list > li dl > dt a > span i:nth-child(2), aside#aside .navigation_wrapper ul.list > li dl > dt div > span i:nth-child(2) {
                    left: calc(50% - (.5em / 2));
                    width: .5em;
                    transform: rotate(90deg); }
          @media screen and (max-width: 768px) {
            aside#aside .navigation_wrapper ul.list > li dl > dd {
              padding-bottom: calc(85px / 6); } }
          aside#aside .navigation_wrapper ul.list > li dl > dd ul.children {
            display: flex;
            align-items: center;
            flex-wrap: wrap;
            gap: calc(8em / 16); }
          aside#aside .navigation_wrapper ul.list > li dl > dd a, aside#aside .navigation_wrapper ul.list > li dl > dd div {
            display: flex;
            align-items: center;
            column-gap: .615em;
            padding: calc(85px/12) calc(85px/6);
            background: var(--border-light-white);
            border: solid 1px var(--color-white);
            border-radius: calc(85px / 24);
            font-size: 1em;
            font-weight: 600;
            letter-spacing: -.01025em;
            line-height: 1;
            transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
            @media screen and (max-width: 768px) {
              aside#aside .navigation_wrapper ul.list > li dl > dd a, aside#aside .navigation_wrapper ul.list > li dl > dd div {
                font-size: .9em; } }
            aside#aside .navigation_wrapper ul.list > li dl > dd a:hover, aside#aside .navigation_wrapper ul.list > li dl > dd div:hover {
              color: var(--color-black);
              background: var(--color-white);
              transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        aside#aside .navigation_wrapper ul.list > li.other {
          padding: calc(8em / 8) 0; }
          @media screen and (max-width: 768px) {
            aside#aside .navigation_wrapper ul.list > li.other {
              padding: calc(8em / 8) 0; } }
          aside#aside .navigation_wrapper ul.list > li.other a {
            display: flex;
            align-items: center;
            column-gap: .615em;
            padding: 0;
            font-size: 1.3325em;
            letter-spacing: -.01025em; }
            @media screen and (max-width: 768px) {
              aside#aside .navigation_wrapper ul.list > li.other a {
                padding: 5px 0;
                font-size: 1.3325em;
                line-height: 1; } }
            aside#aside .navigation_wrapper ul.list > li.other a > i {
              display: block;
              width: 1em;
              height: 1em; }
      aside#aside .navigation_wrapper ul.list.inview > li {
        opacity: 0; }
      aside#aside .navigation_wrapper ul.list.action > li {
        opacity: 1; }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(0) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((0 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(1) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((1 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(2) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((2 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(3) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((3 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(4) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((4 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(5) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((5 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(6) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((6 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(7) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((7 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(8) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((8 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(9) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((9 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(10) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((10 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(11) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((11 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(12) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((12 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(13) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((13 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(14) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((14 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(15) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((15 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(16) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((16 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(17) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((17 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(18) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((18 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(19) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((19 * 0.0615s) + 0.1025s); }
        aside#aside .navigation_wrapper ul.list.action > li:nth-child(20) {
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          transition-delay: calc((20 * 0.0615s) + 0.1025s); }
    aside#aside .navigation_wrapper ul.social {
      display: flex;
      align-items: center;
      justify-content: center;
      column-gap: calc(8em / 8);
      filter: brightness(0) invert(1); }
    aside#aside .navigation_wrapper .foot {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: calc(85px / 4);
      margin-top: calc(8em / 8 * 3); }
      @media screen and (max-width: 768px) {
        aside#aside .navigation_wrapper .foot {
          margin-top: calc(8em / 8 * 2); } }
      aside#aside .navigation_wrapper .foot * {
        color: var(--color-white); }
      aside#aside .navigation_wrapper .foot ul.basic {
        display: flex;
        align-items: center;
        gap: calc(8em / 8);
        font-size: .85em; }
        @media screen and (max-width: 768px) {
          aside#aside .navigation_wrapper .foot ul.basic {
            width: 100%;
            justify-content: center;
            text-align: center; } }
        aside#aside .navigation_wrapper .foot ul.basic > li {
          display: flex;
          align-items: center; }
          @media screen and (max-width: 768px) {
            aside#aside .navigation_wrapper .foot ul.basic > li:last-child {
              display: none; } }

/*!//#siteHeader------------------------------------------------------------------------------------------------*/
/*!#siteFooter------------------------------------------------------------------------------------------------*/
#siteFoot {
  position: relative;
  z-index: 15;
  width: 100%;
  background: var(--gray1);
  overflow: hidden; }
  #siteFoot .wrapper {
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto;
    border-top: solid 1px var(--gray10);
    margin-top: calc(100vw / 64);
    padding-top: calc(100vw / 64); }
  #siteFoot .copyright, #siteFoot .policy {
    font-size: .85em; }
  #siteFoot ._primary {
    display: flex;
    align-items: flex-start;
    gap: calc(8em / 8 * 4);
    padding: calc(8em / 32 * 1) 0; }
    @media screen and (max-width: 768px) {
      #siteFoot ._primary {
        flex-direction: column-reverse;
        padding: calc(8em / 16 * 3) 0; } }
    #siteFoot ._primary .corplate {
      flex: 1;
      display: flex;
      align-items: flex-start;
      flex-direction: column;
      gap: calc(8em / 16 * 3); }
      @media screen and (max-width: 768px) {
        #siteFoot ._primary .corplate {
          min-width: 100%;
          align-items: center; } }
      #siteFoot ._primary .corplate .logo {
        display: flex;
        align-items: center;
        gap: calc(8em / 32 * 3); }
        @media screen and (max-width: 768px) {
          #siteFoot ._primary .corplate .logo img {
            width: 5.74em;
            height: auto; } }
        #siteFoot ._primary .corplate .logo p {
          font-size: 1.23em;
          font-weight: 600;
          letter-spacing: -.0205em; }
          @media screen and (max-width: 768px) {
            #siteFoot ._primary .corplate .logo p {
              font-size: 1.1275em; } }
      #siteFoot ._primary .corplate dl {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32); }
        @media screen and (max-width: 768px) {
          #siteFoot ._primary .corplate dl {
            align-items: center; } }
        #siteFoot ._primary .corplate dl dt {
          font-size: 1.1275em;
          font-weight: 600; }
        #siteFoot ._primary .corplate dl dd {
          font-size: .85em; }
          @media screen and (max-width: 768px) {
            #siteFoot ._primary .corplate dl dd {
              font-size: 1em; } }
    #siteFoot ._primary .navigation {
      flex: 2;
      display: flex;
      justify-content: flex-end; }
      @media screen and (max-width: 768px) {
        #siteFoot ._primary .navigation {
          min-width: 100%;
          display: block;
          justify-content: flex-start; } }
  #siteFoot ._secondary {
    width: 100%; }
    #siteFoot ._secondary .bottom {
      padding: calc(8em / 8 * 2) 0; }
      #siteFoot ._secondary .bottom ul {
        display: flex;
        justify-content: flex-end;
        gap: calc(8em / 16 * 2); }
        @media screen and (max-width: 768px) {
          #siteFoot ._secondary .bottom ul {
            justify-content: center;
            flex-direction: column;
            gap: calc(8em / 16 * 2); } }
        #siteFoot ._secondary .bottom ul::before {
          content: '';
          display: block;
          flex: 1; }
          @media screen and (max-width: 768px) {
            #siteFoot ._secondary .bottom ul::before {
              display: none; } }
        #siteFoot ._secondary .bottom ul > li.center {
          display: flex;
          align-items: center;
          justify-content: center; }
        #siteFoot ._secondary .bottom ul > li.right {
          display: flex;
          align-items: flex-end;
          justify-content: center; }
  #siteFoot nav.footer_navigation ul.col {
    display: flex;
    align-items: flex-end;
    flex-direction: column;
    gap: calc(8em / 32 * 3);
    font-size: .85em; }
    @media screen and (max-width: 768px) {
      #siteFoot nav.footer_navigation ul.col {
        align-items: flex-start;
        font-size: 1em; } }
    #siteFoot nav.footer_navigation ul.col > li {
      flex: 1;
      display: flex;
      align-items: baseline;
      gap: calc(8em / 32 * 3); }
      #siteFoot nav.footer_navigation ul.col > li::before {
        content: attr(data-num) "";
        display: block; }
      #siteFoot nav.footer_navigation ul.col > li a {
        position: relative;
        z-index: 15;
        padding-bottom: calc(8em / 32);
        font-weight: 500; }
        #siteFoot nav.footer_navigation ul.col > li a::before, #siteFoot nav.footer_navigation ul.col > li a::after {
          content: '';
          position: absolute;
          right: 0;
          bottom: 0;
          display: block;
          height: 1px;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        #siteFoot nav.footer_navigation ul.col > li a::before {
          width: 100%;
          background: var(--border-light-white); }
        #siteFoot nav.footer_navigation ul.col > li a::after {
          width: 0;
          background: var(--color-white); }
        #siteFoot nav.footer_navigation ul.col > li a:hover::after {
          width: 100%;
          left: 0;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        #siteFoot nav.footer_navigation ul.col > li a.button {
          padding-bottom: 0; }
          #siteFoot nav.footer_navigation ul.col > li a.button::before, #siteFoot nav.footer_navigation ul.col > li a.button::after {
            display: none; }
  #siteFoot nav.footer_navigation ul.row {
    display: flex;
    flex-direction: row;
    gap: calc(8em / 32 * 4); }
    @media screen and (max-width: 768px) {
      #siteFoot nav.footer_navigation ul.row {
        flex-wrap: wrap;
        gap: calc(8em / 32 * 3); } }
    #siteFoot nav.footer_navigation ul.row > li {
      flex: 1; }
      @media screen and (max-width: 768px) {
        #siteFoot nav.footer_navigation ul.row > li {
          flex: initial; } }
  #siteFoot nav.footer_navigation dl > dt {
    font-size: 1.1275em; }
    #siteFoot nav.footer_navigation dl > dt + dd {
      margin-top: calc(8em / 32 * 3); }
  #siteFoot nav.footer_navigation dl > dd {
    font-size: .85em; }
    @media screen and (max-width: 768px) {
      #siteFoot nav.footer_navigation dl > dd {
        display: none; } }
    #siteFoot nav.footer_navigation dl > dd ~ dd {
      margin-top: calc(8em / 32 * 2); }
  #siteFoot ul.social {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 2);
    font-size: .85em; }
    #siteFoot ul.social > li a {
      display: flex;
      align-items: center;
      gap: calc(8em / 32 * 3); }
      #siteFoot ul.social > li a .icon {
        display: block;
        width: 1.1275em;
        min-width: 1.1275em;
        height: 1.1275em;
        line-height: 1.5; }

/*//!#siteFooter----------------------------------------------------------------------------------------------*/
/*!#index----------------------------------------------------------------------------------------------*/
/*!#siteContent*/
#siteContent {
  position: relative;
  z-index: 15;
  width: 100%;
  background: var(--key1);
  transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  transition-delay: .246s; }
  @media screen and (max-width: 768px) {
    #siteContent {
      width: 100%;
      margin-bottom: 0 !important; } }

.slider {
  display: flex;
  align-items: center; }
  .slider .slider__inner {
    display: flex;
    align-items: center; }
    .slider .slider__inner:first-child {
      animation: loop 180s linear infinite; }
    .slider .slider__inner:nth-child(2) {
      animation: loop2 180s -120s linear infinite; }
    .slider .slider__inner:last-child {
      animation: loop3 180s -60s linear infinite; }

@keyframes loop {
  0% {
    transform: translateX(200%); }
  to {
    transform: translateX(-100%); } }
@keyframes loop2 {
  0% {
    transform: translateX(100%); }
  to {
    transform: translateX(-200%); } }
@keyframes loop3 {
  0% {
    transform: translateX(0%); }
  to {
    transform: translateX(-300%); } }
.verticalslider {
  display: block; }
  .verticalslider .verticalslider__inner {
    display: block; }
    .verticalslider .verticalslider__inner:first-child {
      animation: loopV 180s linear infinite; }
    .verticalslider .verticalslider__inner:nth-child(2) {
      animation: loopV2 180s -120s linear infinite; }
    .verticalslider .verticalslider__inner:last-child {
      animation: loopV3 180s -60s linear infinite; }
    .verticalslider .verticalslider__inner .slider__item {
      width: 100%;
      padding: 5px 0; }
      .verticalslider .verticalslider__inner .slider__item .aspect {
        border-radius: 18px;
        overflow: hidden; }
        @media screen and (max-width: 768px) {
          .verticalslider .verticalslider__inner .slider__item .aspect {
            border-radius: 10px; } }

@keyframes loopV {
  0% {
    transform: translateY(200%); }
  to {
    transform: translateY(-100%); } }
@keyframes loopV2 {
  0% {
    transform: translateY(100%); }
  to {
    transform: translateY(-200%); } }
@keyframes loopV3 {
  0% {
    transform: translateY(0%); }
  to {
    transform: translateY(-300%); } }
@keyframes arrowAnimation {
  0% {
    transform: translateX(0);
    opacity: 1; }
  25% {
    transform: translateX(30px);
    opacity: 0; }
  55% {
    transform: translateX(-30px);
    opacity: 0; }
  80% {
    transform: translateX(0);
    opacity: 1; }
  100% {
    transform: translateX(0);
    opacity: 1; } }
.noentry {
  filter: opacity(0.41) !important;
  pointer-events: none !important;
  cursor: not-allowed; }

.comingsoon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 180px;
  background: var(--gray2);
  filter: opacity(0.5); }

.rainbow-bg {
  animation: rainbow-bg 2.5s linear;
  animation-iteration-count: infinite; }

@keyframes rainbow-bg {
  100%,0% {
    background-color: #497ab7; }
  10% {
    background-color: #5e49b7; }
  20% {
    background-color: #a149b7; }
  30% {
    background-color: #b74984; }
  40% {
    background-color: #b7494f; }
  50% {
    background-color: #b78e49; }
  60% {
    background-color: #a8b749; }
  70% {
    background-color: #64b749; }
  80% {
    background-color: #49b773; }
  90% {
    background-color: #49b7b0; } }
.rainbow {
  animation: rainbow 2.5s linear;
  animation-iteration-count: infinite; }

@keyframes rainbow {
  100%,0% {
    color: #497ab7; }
  10% {
    color: #5e49b7; }
  20% {
    color: #a149b7; }
  30% {
    color: #b74984; }
  40% {
    color: #b7494f; }
  50% {
    color: #b78e49; }
  60% {
    color: #a8b749; }
  70% {
    color: #64b749; }
  80% {
    color: #49b773; }
  90% {
    color: #49b7b0; } }
.index-body {
  position: relative;
  z-index: 15;
  background: var(--gray1); }

.idx {
  position: relative;
  z-index: 15; }
  .idx hgroup:has(h2) {
    display: flex;
    align-items: center;
    flex-direction: row;
    gap: calc(8em / 64 * 3); }
    .idx hgroup:has(h2).left {
      justify-content: flex-start; }
    .idx hgroup:has(h2).center {
      justify-content: center; }
    .idx hgroup:has(h2).right {
      justify-content: flex-end; }
    .idx hgroup:has(h2).white::before {
      background: var(--gray1); }
    .idx hgroup:has(h2).white * {
      color: var(--gray1); }
    .idx hgroup:has(h2)::before {
      content: '';
      display: block;
      width: .8em;
      height: .8em;
      border-radius: 1em;
      background: var(--gray12); }
    .idx hgroup:has(h2) h2 {
      font-size: .85em; }
    .idx hgroup:has(h2) p {
      font-weight: 600;
      font-size: 1.1275em; }
    .idx hgroup:has(h2) + * {
      margin-top: calc(8em / 32 * 5); }
      @media screen and (max-width: 768px) {
        .idx hgroup:has(h2) + * {
          margin-top: calc(8em / 32 * 4); } }
  .idx hgroup:has(h3) {
    display: flex;
    align-items: baseline;
    flex-direction: row-reverse;
    flex-wrap: wrap;
    justify-content: space-between; }
    @media screen and (max-width: 768px) {
      .idx hgroup:has(h3) {
        justify-content: flex-end;
        flex-direction: row-reverse;
        gap: calc(8em / 32 * 2); } }
    .idx hgroup:has(h3) h3 {
      font-size: .95em; }
    .idx hgroup:has(h3) p {
      font-weight: 600;
      font-size: 1.23em;
      letter-spacing: -.041em;
      line-height: 1; }
      @media screen and (max-width: 768px) {
        .idx hgroup:has(h3) p {
          font-size: 1.23em; } }
    .idx hgroup:has(h3) + * {
      margin-top: calc(8em / 32 * 5); }
  .idx hgroup.white * {
    color: var(--color-white); }
  .idx .border-top {
    border-top: solid 1.5px; }
  .idx.keyvisual {
    width: 100%;
    height: auto; }
    .idx.keyvisual .scroll-area {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%; }
      .idx.keyvisual .scroll-area .sticky-wrapper {
        z-index: 0 !important; }
        .idx.keyvisual .scroll-area .sticky-wrapper video {
          top: 0;
          z-index: -1;
          width: 100vw;
          height: 100vh; }
        .idx.keyvisual .scroll-area .sticky-wrapper .heros {
          position: fixed;
          bottom: 0;
          left: 0;
          display: flex;
          flex-direction: column;
          align-items: flex-start;
          justify-content: center;
          width: 60%;
          height: 100vh; }
          @media screen and (max-width: 768px) {
            .idx.keyvisual .scroll-area .sticky-wrapper .heros {
              justify-content: flex-start;
              width: 100%;
              overflow: hidden; } }
          .idx.keyvisual .scroll-area .sticky-wrapper .heros .inner {
            width: 100%;
            height: 100%;
            margin-left: -7.5%; }
            @media screen and (max-width: 768px) {
              .idx.keyvisual .scroll-area .sticky-wrapper .heros .inner {
                height: 120vw;
                margin-left: -2.5%; } }
    .idx.keyvisual .wrapper {
      position: relative;
      z-index: 15;
      width: calc(100% / 32 * 30);
      margin-left: auto;
      margin-right: auto;
      padding-top: calc(8em / 8 * 8);
      padding-bottom: calc(8em / 8 * 12);
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .idx.keyvisual .wrapper {
          padding-top: 100vw;
          padding-bottom: calc(8em / 8 * 1); } }
      .idx.keyvisual .wrapper .inner {
        position: relative;
        z-index: 15;
        display: flex;
        flex-direction: column;
        gap: calc(8em / 64 * 24);
        min-width: 41em;
        width: 50%;
        max-width: 100%;
        margin-left: auto;
        padding: calc(8em / 16 * 7) calc(8em / 16 * 7) calc(8em / 16 * 10);
        -webkit-backdrop-filter: blur(25px);
        backdrop-filter: blur(25px);
        overflow: hidden; }
        @media screen and (max-width: 768px) {
          .idx.keyvisual .wrapper .inner {
            min-width: 100%;
            width: 100%;
            padding: calc(8em / 16 * 7) calc(8em / 16 * 4); } }
        .idx.keyvisual .wrapper .inner::before {
          content: '';
          position: absolute;
          top: 0;
          left: 0;
          z-index: -1;
          display: block;
          width: 100%;
          height: 100%;
          background: url(images/noise.png), rgba(0, 0, 0, 0.1025);
          background-size: 100px, cover;
          background-repeat: repeat;
          pointer-events: none;
          opacity: .5; }
        .idx.keyvisual .wrapper .inner .catchcopy {
          display: flex;
          align-items: flex-start;
          flex-direction: column; }
          .idx.keyvisual .wrapper .inner .catchcopy .tagline {
            width: auto;
            height: 8.2em;
            margin-left: auto;
            margin-right: 14.35%; }
            @media screen and (max-width: 768px) {
              .idx.keyvisual .wrapper .inner .catchcopy .tagline {
                height: 6.15em; } }
          .idx.keyvisual .wrapper .inner .catchcopy .copy {
            width: auto;
            height: 4.1em; }
            @media screen and (max-width: 768px) {
              .idx.keyvisual .wrapper .inner .catchcopy .copy {
                height: 2.87em; } }
        .idx.keyvisual .wrapper .inner .statement {
          display: flex;
          flex-direction: column;
          gap: calc(8em / 64 * 12); }
          .idx.keyvisual .wrapper .inner .statement ul.calusel {
            display: flex;
            align-items: center; }
            .idx.keyvisual .wrapper .inner .statement ul.calusel > li {
              width: calc(8em / 8 * 10);
              aspect-ratio: 1/1;
              padding: 0 calc(8em / 16 * 3);
              overflow: hidden; }
              @media screen and (max-width: 768px) {
                .idx.keyvisual .wrapper .inner .statement ul.calusel > li {
                  width: calc(8em / 8 * 6);
                  padding: 0 calc(8em / 16 * 1); } }
        .idx.keyvisual .wrapper .inner p {
          display: flex;
          flex-direction: column;
          font-weight: 600;
          font-size: 1.075em;
          line-height: 2.255; }
          @media screen and (max-width: 768px) {
            .idx.keyvisual .wrapper .inner p {
              align-items: flex-start;
              font-size: 1em;
              line-height: 1.8; } }
          .idx.keyvisual .wrapper .inner p span {
            display: block; }
            .idx.keyvisual .wrapper .inner p span i {
              position: relative;
              top: 0;
              display: inline-block;
              opacity: 0;
              font-style: normal;
              will-change: opacity; }
  .idx.interview {
    margin-top: calc(8em / 8 * 3); }
    @media screen and (max-width: 768px) {
      .idx.interview {
        margin-top: calc(8em / 8 * 4); } }
    .idx.interview .wrapper {
      width: calc(100% / 64 * 62);
      margin-left: auto;
      margin-right: auto; }
      .idx.interview .wrapper .middle ul {
        border-bottom: solid 1px var(--gray10); }
        .idx.interview .wrapper .middle ul > li {
          position: relative;
          z-index: 15;
          display: flex;
          align-items: center;
          border-top: solid 1px var(--gray10); }
          .idx.interview .wrapper .middle ul > li .image {
            position: absolute;
            top: 0;
            right: 0;
            aspect-ratio: 1/1;
            height: 100%;
            padding: calc(8em / 16) 0; }
          .idx.interview .wrapper .middle ul > li .card {
            flex: 1;
            opacity: 1;
            transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
          .idx.interview .wrapper .middle ul > li:hover .card {
            opacity: 1 !important;
            transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        .idx.interview .wrapper .middle ul:hover > li .card {
          opacity: .328;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .idx.interview .wrapper .middle .card {
        position: relative;
        z-index: 15;
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        padding: calc(8em / 16) 0; }
        @media screen and (max-width: 768px) {
          .idx.interview .wrapper .middle .card {
            flex-direction: column; } }
        .idx.interview .wrapper .middle .card .name {
          font-weight: 600;
          font-size: 4.92em;
          letter-spacing: -.0205em;
          line-height: 1; }
          @media screen and (max-width: 768px) {
            .idx.interview .wrapper .middle .card .name {
              font-size: 2.87em; } }
        .idx.interview .wrapper .middle .card .company {
          font-size: .9em;
          font-weight: 600; }
    .idx.interview + * {
      margin-top: calc(8em / 8 * 5); }
      @media screen and (max-width: 768px) {
        .idx.interview + * {
          margin-top: calc(8em / 8 * 4); } }
  .idx.service {
    margin-top: calc(8em / 8 * 3); }
    @media screen and (max-width: 768px) {
      .idx.service {
        margin-top: calc(8em / 8 * 4); } }
    .idx.service .wrapper {
      width: calc(100% / 64 * 62);
      margin-left: auto;
      margin-right: auto; }
      .idx.service .wrapper .middle {
        width: calc(100% / 16 * 11);
        margin-left: auto;
        margin-right: auto;
        aspect-ratio: 2.35/1; }
        @media screen and (max-width: 768px) {
          .idx.service .wrapper .middle {
            width: calc(100% / 16 * 15);
            aspect-ratio: initial; } }
        .idx.service .wrapper .middle ul {
          display: flex;
          gap: calc(8em / 32);
          height: 100%; }
          @media screen and (max-width: 768px) {
            .idx.service .wrapper .middle ul {
              flex-wrap: wrap; } }
          .idx.service .wrapper .middle ul > li {
            position: relative;
            z-index: 15;
            width: calc((100% / 4) - ((8em / 32) * 3 / 4));
            border-radius: calc(8em / 32);
            overflow: hidden;
            transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
            @media screen and (max-width: 768px) {
              .idx.service .wrapper .middle ul > li {
                width: calc((100% / 2) - ((8em / 32) * 1 / 2)); } }
            .idx.service .wrapper .middle ul > li .background {
              position: absolute;
              top: 0;
              left: 0;
              z-index: -1;
              width: 100%;
              height: 100%; }
              .idx.service .wrapper .middle ul > li .background::after {
                content: '';
                position: absolute;
                bottom: 0;
                display: block;
                width: 100%;
                height: 50%;
                background: linear-gradient(to bottom, transparent, var(--border-light-black)); }
            .idx.service .wrapper .middle ul > li .card {
              display: flex;
              align-items: flex-end;
              width: 100%;
              height: 100%;
              padding: calc(8em / 64 * 5) calc(8em / 64 * 7); }
              @media screen and (max-width: 768px) {
                .idx.service .wrapper .middle ul > li .card {
                  aspect-ratio: 1 / 1; } }
              .idx.service .wrapper .middle ul > li .card * {
                color: var(--gray1); }
              .idx.service .wrapper .middle ul > li .card hgroup {
                width: 100%; }
            .idx.service .wrapper .middle ul > li:hover {
              width: calc(((100% / 4 * 2) - ((8em / 32) * 3 / 4)));
              transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        .idx.service .wrapper .middle + * {
          margin-top: calc(8em / 8 * 2); }
      .idx.service .wrapper .foot {
        display: flex;
        align-items: center;
        flex-direction: column; }
        .idx.service .wrapper .foot p {
          text-align: center;
          font-size: 2.46em;
          font-weight: 600;
          line-height: 1.435; }
          @media screen and (max-width: 768px) {
            .idx.service .wrapper .foot p {
              font-size: 2.05em; } }
          .idx.service .wrapper .foot p + * {
            margin-top: 1em; }
    .idx.service + * {
      margin-top: calc(8em / 8 * 5); }
      @media screen and (max-width: 768px) {
        .idx.service + * {
          margin-top: calc(8em / 8 * 4); } }
  .idx.environement .wrapper {
    display: flex;
    align-items: center;
    flex-direction: column;
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto; }
    .idx.environement .wrapper .middle p {
      font-size: 3.69em;
      font-weight: 600;
      line-height: 1.3325; }
      @media screen and (max-width: 768px) {
        .idx.environement .wrapper .middle p {
          font-size: 2.665em; } }
    .idx.environement .wrapper .middle + * {
      margin-top: calc(8em / 32 * 5); }
    .idx.environement .wrapper .foot {
      width: 100%; }
      .idx.environement .wrapper .foot ul {
        display: flex;
        gap: calc(8em / 32); }
        @media screen and (max-width: 768px) {
          .idx.environement .wrapper .foot ul {
            flex-direction: column; } }
        .idx.environement .wrapper .foot ul > li {
          position: relative;
          z-index: 15;
          flex: 1;
          aspect-ratio: 2/1;
          border-radius: calc(8em / 32);
          overflow: hidden; }
          @media screen and (max-width: 768px) {
            .idx.environement .wrapper .foot ul > li {
              aspect-ratio: 2.35/1; } }
          .idx.environement .wrapper .foot ul > li .background {
            position: absolute;
            top: 0;
            left: 0;
            z-index: -1;
            width: 100%;
            height: 100%; }
            .idx.environement .wrapper .foot ul > li .background::after {
              content: '';
              position: absolute;
              bottom: 0;
              display: block;
              width: 100%;
              height: 50%;
              background: linear-gradient(to bottom, transparent, var(--border-light-black)); }
          .idx.environement .wrapper .foot ul > li .card {
            display: flex;
            align-items: flex-end;
            width: 100%;
            height: 100%;
            padding: calc(8em / 64 * 5) calc(8em / 64 * 7); }
            .idx.environement .wrapper .foot ul > li .card * {
              color: var(--gray1); }
            .idx.environement .wrapper .foot ul > li .card hgroup {
              width: 100%; }
  .idx.environement + * {
    margin-top: calc(8em / 8 * 5); }
    @media screen and (max-width: 768px) {
      .idx.environement + * {
        margin-top: calc(8em / 8 * 4); } }
  .idx.works {
    overflow: hidden; }
    .idx.works .wrapper {
      display: flex;
      align-items: center;
      flex-direction: column;
      width: calc(100% / 64 * 62);
      margin-left: auto;
      margin-right: auto; }
      .idx.works .wrapper .middle {
        display: flex;
        align-items: flex-end;
        flex-direction: column;
        gap: calc(8em / 8); }
        @media screen and (max-width: 768px) {
          .idx.works .wrapper .middle {
            width: calc(100% / 32 * 29); } }
        .idx.works .wrapper .middle p {
          font-size: 1.23em;
          font-weight: 600;
          line-height: 1.8; }
          @media screen and (max-width: 768px) {
            .idx.works .wrapper .middle p {
              font-size: 1.1275em; } }
        .idx.works .wrapper .middle + * {
          margin-top: calc(8em / 16 * 3); }
      .idx.works .wrapper .foot ul.calusel {
        display: flex;
        align-items: center; }
        .idx.works .wrapper .foot ul.calusel > li {
          width: calc(8em / 8 * 10);
          aspect-ratio: 1/1;
          padding: 0 calc(8em / 16 * 3);
          overflow: hidden; }
          @media screen and (max-width: 768px) {
            .idx.works .wrapper .foot ul.calusel > li {
              padding: 0 calc(8em / 16 * 2); } }
    .idx.works + * {
      margin-top: calc(8em / 8 * 8); }
      @media screen and (max-width: 768px) {
        .idx.works + * {
          margin-top: calc(8em / 8 * 6); } }
  .idx.others .wrapper {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32);
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto; }
    .idx.others .wrapper .primary {
      display: flex;
      gap: calc(8em / 32); }
      @media screen and (max-width: 768px) {
        .idx.others .wrapper .primary {
          flex-direction: column; } }
      .idx.others .wrapper .primary .card {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        flex-direction: column;
        background: var(--gray3); }
        .idx.others .wrapper .primary .card .middle {
          padding-left: calc((8em / 64 * 3) + .8em); }
        .idx.others .wrapper .primary .card .foot {
          display: flex;
          width: 100%;
          justify-content: flex-end; }
    .idx.others .wrapper .secondry .card {
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      flex-direction: column;
      background: #2d2d2d;
      background: url(images/noise.png), url(images/colorful.jpg);
      background-size: 100px,cover;
      background-repeat: repeat;
      /*
      &::before {
       content: '';
       position: absolute;
       top: 50%;
       right: -4em;
       z-index: -1;
       width: 41em;
       aspect-ratio: 113 / 40;
       background: url(images/logo-mark.png);
       background-size: cover;
       opacity: .123;
       mix-blend-mode: luminosity;
       transform: translateY(-50%);
      }
      */ }
      .idx.others .wrapper .secondry .card::before {
        content: '';
        position: absolute;
        top: 0;
        right: 0;
        z-index: -1;
        width: 100%;
        height: 100%;
        background: var(--gray12);
        opacity: .205;
        mix-blend-mode: multiply; }
      .idx.others .wrapper .secondry .card::after {
        content: '';
        display: block; }
      .idx.others .wrapper .secondry .card .middle {
        display: flex;
        align-items: center;
        justify-content: space-between;
        width: calc(100% - ((8em / 8 * 4) * 2));
        margin-left: auto;
        margin-right: auto;
        padding-left: calc((8em / 64 * 3) + .8em); }
        @media screen and (max-width: 768px) {
          .idx.others .wrapper .secondry .card .middle {
            align-items: flex-end;
            flex-direction: column;
            width: 100%; } }
        @media screen and (max-width: 768px) {
          .idx.others .wrapper .secondry .card .middle > .left {
            padding-top: calc(8em / 8 * 3); } }
        .idx.others .wrapper .secondry .card .middle > .left * {
          color: var(--gray1); }
        .idx.others .wrapper .secondry .card .middle > .left dl {
          display: flex;
          flex-direction: column;
          gap: calc(8em / 16 * 3); }
          @media screen and (max-width: 768px) {
            .idx.others .wrapper .secondry .card .middle > .left dl {
              gap: calc(8em / 16 * 2); } }
          .idx.others .wrapper .secondry .card .middle > .left dl > dt img {
            width: auto;
            height: 4.1em;
            filter: brightness(0) invert(1); }
            @media screen and (max-width: 768px) {
              .idx.others .wrapper .secondry .card .middle > .left dl > dt img {
                height: 2.87em; } }
          .idx.others .wrapper .secondry .card .middle > .left dl > dd p {
            font-size: 1.23em;
            font-weight: 600;
            line-height: 1.8; }
    .idx.others .wrapper .card {
      position: relative;
      z-index: 15;
      flex: 1;
      display: block;
      padding: calc(8em / 32 * 5);
      aspect-ratio: 3/1;
      border-radius: calc(8em / 32);
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .idx.others .wrapper .card {
          min-width: 100%;
          aspect-ratio: initial; } }
      @media screen and (max-width: 768px) {
        .idx.others .wrapper .card .foot {
          margin-top: calc(8em / 32 * 3); } }

.beltline {
  background: var(--gray3); }

.catch-slider {
  margin: 1em 0;
  overflow: hidden; }
  .catch-slider .slider__inner {
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    will-change: transform; }
    .catch-slider .slider__inner .slider__item {
      display: inline-flex;
      align-items: center;
      gap: calc(8em / 32 * 3);
      flex: 0 0 auto;
      width: auto;
      padding: 0 calc(8em / 32 * 3); }
      .catch-slider .slider__inner .slider__item > img {
        width: 5.125em;
        border-radius: calc(8em / 32); }
        @media screen and (max-width: 768px) {
          .catch-slider .slider__inner .slider__item > img {
            width: 3.28em; } }
      .catch-slider .slider__inner .slider__item .slider__text {
        white-space: nowrap; }
      .catch-slider .slider__inner .slider__item .catch {
        font-size: 2.46em;
        font-weight: 600; }
        @media screen and (max-width: 768px) {
          .catch-slider .slider__inner .slider__item .catch {
            font-size: 2.05em; } }

header#pageHeader {
  position: relative;
  z-index: 15;
  padding-top: calc(8em / 8 * 5); }
  @media screen and (max-width: 768px) {
    header#pageHeader {
      padding-top: calc(8em / 8 * 3); } }
  header#pageHeader .wrapper {
    position: relative;
    z-index: 15;
    display: block;
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto;
    padding: calc(8em / 8 * 6) 0;
    background: var(--gray3);
    background: url(images/noise.png), url(images/colorful.jpg);
    background-size: 100px, cover;
    background-repeat: repeat;
    border-radius: calc(8em / 32);
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      header#pageHeader .wrapper {
        padding: calc(8em / 16 * 8) 0; } }
    header#pageHeader .wrapper::before {
      content: '';
      display: block;
      position: absolute;
      top: 0;
      left: 0;
      z-index: -1;
      width: 100%;
      height: 100%;
      background: var(--gray12);
      opacity: .1025;
      mix-blend-mode: multiply; }
    header#pageHeader .wrapper hgroup {
      position: relative;
      z-index: 15;
      display: flex;
      flex-direction: column;
      align-items: center; }
      header#pageHeader .wrapper hgroup h1 {
        font-size: 2.46em;
        font-weight: 600;
        color: var(--color-white);
        text-shadow: 0 0px 8px rgba(0, 0, 0, 0.205); }
        @media screen and (max-width: 768px) {
          header#pageHeader .wrapper hgroup h1 {
            font-size: 2.05em; } }
      header#pageHeader .wrapper hgroup span {
        position: relative;
        z-index: 15;
        font-size: calc(8em / 8);
        font-weight: 600;
        letter-spacing: -.0205em;
        line-height: 1;
        text-transform: capitalize;
        color: var(--color-white);
        text-shadow: 0 0px 8px rgba(0, 0, 0, 0.41); }

.page-frame hgroup:has(h2) {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  border-top: solid 1px var(--gray10);
  margin-top: calc(100vw / 64);
  padding: calc(100vw / 64) 0; }
  @media screen and (max-width: 768px) {
    .page-frame hgroup:has(h2) {
      padding: calc(100vw / 32) 0; } }
  .page-frame hgroup:has(h2) h2 {
    display: flex;
    align-items: center;
    gap: calc(8em / 32);
    font-size: 1.1275em;
    font-weight: 600;
    line-height: 1; }
    .page-frame hgroup:has(h2) h2::before {
      content: '';
      display: block;
      width: .75em;
      height: .75em;
      border-radius: 1em;
      background: var(--gray12); }
  .page-frame hgroup:has(h2) p {
    font-size: .9em; }
.page-frame hgroup:has(h3) h3 {
  font-size: 2.255em;
  font-weight: 600;
  line-height: 1; }
.page-frame hgroup:has(h3) p {
  font-size: .9em;
  color: var(--gray9); }
.page-frame .wrapper {
  width: calc(100% / 64 * 62);
  margin-left: auto;
  margin-right: auto; }
.page-frame + .others {
  margin-top: calc(100vw / 64); }

.page-business .business-main .main-head {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: calc(8em / 32 * 3);
  padding: calc(8em / 8 * 6) 0;
  text-align: center; }
  @media screen and (max-width: 768px) {
    .page-business .business-main .main-head {
      padding: calc(8em / 8 * 4) 0; } }
  .page-business .business-main .main-head p.lead {
    font-size: 2.46em;
    font-weight: 600;
    line-height: 1.3325; }
  .page-business .business-main .main-head p.body {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 3);
    font-weight: 600; }
    .page-business .business-main .main-head p.body span {
      display: block; }
.page-business .business-main .main-body {
  display: flex;
  flex-direction: column;
  gap: calc(100vw / 64); }
  .page-business .business-main .main-body .card {
    display: flex;
    gap: calc(8em / 16 * 2) calc(8em / 16 * 6);
    padding: calc(8em / 16 * 6);
    background: var(--gray3);
    border-radius: calc(8em / 32);
    overflow: hidden;
    border-top: solid 8px;
    border-image: linear-gradient(to right, #e60000, #f39800, #fff100, #009944, #0068b7, #1d2088, #920783, #e60000);
    border-image-slice: 1; }
    @media screen and (max-width: 768px) {
      .page-business .business-main .main-body .card {
        border-width: 4px; } }
    @media screen and (max-width: 768px) {
      .page-business .business-main .main-body .card {
        flex-direction: column;
        padding: calc(8em / 16 * 3); } }
    .page-business .business-main .main-body .card > .image {
      flex: 1;
      aspect-ratio: 1/1;
      border-radius: calc(8em / 32);
      overflow: hidden; }
    .page-business .business-main .main-body .card > .text {
      flex: 1;
      display: flex;
      align-items: flex-start;
      justify-content: space-between;
      flex-direction: column;
      padding: calc(8em / 16 * 3) 0; }
      @media screen and (max-width: 768px) {
        .page-business .business-main .main-body .card > .text {
          gap: calc(8em / 16 * 2); } }
      .page-business .business-main .main-body .card > .text p.lead {
        font-size: 1.435em;
        font-weight: 600; }
        .page-business .business-main .main-body .card > .text p.lead + * {
          margin-top: calc(8em / 16); }
      .page-business .business-main .main-body .card > .text p.body {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32 * 3); }
        @media screen and (max-width: 768px) {
          .page-business .business-main .main-body .card > .text p.body {
            gap: calc(8em / 32 * 2); } }
        .page-business .business-main .main-body .card > .text p.body span {
          display: block; }

.page-culture .culture-training .training-body {
  display: flex;
  align-items: flex-end;
  gap: calc(8em / 16 * 2) calc(8em / 16 * 5); }
  @media screen and (max-width: 768px) {
    .page-culture .culture-training .training-body {
      flex-direction: column;
      padding: calc(8em / 16 * 3);
      background: var(--gray3);
      border-radius: calc(8em / 32);
      overflow: hidden; } }
  .page-culture .culture-training .training-body > .image {
    flex: 1;
    aspect-ratio: 1/1;
    border-radius: calc(8em / 32);
    overflow: hidden; }
  .page-culture .culture-training .training-body > .text {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: calc(8em / 8);
    padding: calc(8em / 16 * 3) 0; }
  @media screen and (max-width: 768px) {
    .page-culture .culture-training .training-body p {
      padding: 0 calc(8rem / 16 * 2); } }
  .page-culture .culture-training .training-body p.lead {
    font-size: 2.46em;
    font-weight: 600;
    line-height: 1.3325; }
    @media screen and (max-width: 768px) {
      .page-culture .culture-training .training-body p.lead {
        font-size: 2.255em; } }
  .page-culture .culture-training .training-body p.body {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 3); }
    @media screen and (max-width: 768px) {
      .page-culture .culture-training .training-body p.body {
        gap: calc(8em / 32 * 2); } }
    .page-culture .culture-training .training-body p.body span {
      display: block; }
  .page-culture .culture-training .training-body + * {
    margin-top: calc(8em / 16 * 3); }
    @media screen and (max-width: 768px) {
      .page-culture .culture-training .training-body + * {
        margin-top: calc(100vw / 64); } }
.page-culture .culture-training .training-foot ul.training-detail {
  display: flex;
  flex-wrap: wrap;
  gap: calc(100vw / 64);
  counter-reset: num; }
  .page-culture .culture-training .training-foot ul.training-detail > li {
    width: calc((100% / 3) - ((100vw / 64) * 2 /3));
    background: var(--key3);
    padding: calc(8em / 16 * 3);
    border-top: solid 8px;
    border-image: linear-gradient(to right, #e60000, #f39800, #fff100, #009944, #0068b7, #1d2088, #920783, #e60000);
    border-image-slice: 1;
    border-radius: calc(8em / 32);
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      .page-culture .culture-training .training-foot ul.training-detail > li {
        width: 100%;
        border-width: 4px; } }
    .page-culture .culture-training .training-foot ul.training-detail > li::before {
      counter-increment: num;
      content: counter(num);
      position: absolute;
      display: flex;
      align-items: center;
      justify-content: center;
      width: 2.05em;
      height: 2.05em;
      margin-bottom: calc(8em / 16 * 2);
      background: var(--key9);
      border-radius: calc(8em / 16);
      font-size: .9em;
      color: var(--gray1); }
    .page-culture .culture-training .training-foot ul.training-detail > li .image {
      position: relative;
      z-index: 0;
      display: block;
      max-width: calc(8em / 8 * 10);
      margin-left: auto;
      margin-bottom: calc(1.23em * -2); }
      @media screen and (max-width: 768px) {
        .page-culture .culture-training .training-foot ul.training-detail > li .image {
          margin-bottom: calc(1.23em * -3);
          margin-top: calc(1.23em * -1); } }
    .page-culture .culture-training .training-foot ul.training-detail > li .lead {
      position: relative;
      z-index: 15;
      padding-bottom: calc(8em / 32);
      margin-bottom: calc(8em / 16);
      border-bottom: solid 1px var(--key6);
      font-size: 1.23em;
      font-weight: 600;
      color: var(--key9); }
    .page-culture .culture-training .training-foot ul.training-detail > li .body {
      position: relative;
      z-index: 15;
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32 * 3); }
      .page-culture .culture-training .training-foot ul.training-detail > li .body p {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32 * 3); }
        .page-culture .culture-training .training-foot ul.training-detail > li .body p span {
          display: block; }
.page-culture .culture-training .training-foot ul.training-detail-child {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 64); }
  .page-culture .culture-training .training-foot ul.training-detail-child > li {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: calc(8em / 16);
    font-weight: 600; }
    .page-culture .culture-training .training-foot ul.training-detail-child > li::before {
      content: '';
      display: block;
      width: .5em;
      min-width: .5em;
      height: .5em;
      border-radius: 1em;
      background: var(--key9); }
    .page-culture .culture-training .training-foot ul.training-detail-child > li:last-child::after {
      content: 'など';
      font-weight: 500;
      display: inline-flex; }
.page-culture .culture-culture .culture-body {
  display: flex;
  align-items: flex-end;
  flex-direction: row-reverse;
  gap: calc(8em / 16 * 2) calc(8em / 16 * 5); }
  @media screen and (max-width: 768px) {
    .page-culture .culture-culture .culture-body {
      flex-direction: column;
      padding: calc(8em / 16 * 3);
      background: var(--gray3);
      border-radius: calc(8em / 32);
      overflow: hidden; } }
  .page-culture .culture-culture .culture-body > .image {
    flex: 1;
    aspect-ratio: 1/1;
    border-radius: calc(8em / 32);
    overflow: hidden; }
  .page-culture .culture-culture .culture-body > .text {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: calc(8em / 8);
    padding: calc(8em / 16 * 3) 0; }
  .page-culture .culture-culture .culture-body p {
    padding-left: calc(8rem / 16 * 3); }
    @media screen and (max-width: 768px) {
      .page-culture .culture-culture .culture-body p {
        padding: 0 calc(8rem / 16 * 2); } }
    .page-culture .culture-culture .culture-body p.lead {
      font-size: 2.46em;
      font-weight: 600;
      line-height: 1.3325; }
      @media screen and (max-width: 768px) {
        .page-culture .culture-culture .culture-body p.lead {
          font-size: 2.255em; } }
    .page-culture .culture-culture .culture-body p.body {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32 * 3); }
      @media screen and (max-width: 768px) {
        .page-culture .culture-culture .culture-body p.body {
          gap: calc(8em / 32 * 2); } }
      .page-culture .culture-culture .culture-body p.body span {
        display: block; }
.page-culture .culture-tour {
  overflow: hidden; }
  .page-culture .culture-tour .tour-body {
    display: flex;
    flex-direction: column;
    gap: calc(100vw / 64); }
    .page-culture .culture-tour .tour-body .slider {
      gap: calc(100vw / 64); }
      .page-culture .culture-tour .tour-body .slider > .slider__inner {
        gap: calc(100vw / 64); }
        .page-culture .culture-tour .tour-body .slider > .slider__inner > .slider__item {
          width: calc(8em / 8 * 24);
          height: auto;
          line-height: 0; }
          @media screen and (max-width: 768px) {
            .page-culture .culture-tour .tour-body .slider > .slider__inner > .slider__item {
              width: calc(8em / 8 * 16); } }
      .page-culture .culture-tour .tour-body .slider:nth-child(2n) > .slider__inner {
        animation-direction: reverse; }

.page-attraction {
  overflow: hidden; }
  .page-attraction .attraction-main .main-head {
    display: flex;
    align-items: center;
    flex-direction: column;
    gap: calc(8em / 16);
    text-align: center;
    padding: calc(8em / 8 * 6) 0; }
    @media screen and (max-width: 768px) {
      .page-attraction .attraction-main .main-head {
        padding: calc(8em / 8 * 4) 0; } }
    .page-attraction .attraction-main .main-head p.lead {
      font-size: 2.46em;
      font-weight: 600; }
    .page-attraction .attraction-main .main-head p.body {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32 * 3);
      font-weight: 600; }
      .page-attraction .attraction-main .main-head p.body span {
        display: block; }
    .page-attraction .attraction-main .main-head ul.calusel {
      display: flex;
      align-items: center; }
      .page-attraction .attraction-main .main-head ul.calusel > li {
        width: calc(8em / 8 * 14);
        aspect-ratio: 283/224;
        padding: 0 calc(8em / 16 * 3);
        overflow: hidden; }
        @media screen and (max-width: 768px) {
          .page-attraction .attraction-main .main-head ul.calusel > li {
            width: calc(8em / 8 * 10);
            padding: 0 calc(8em / 16 * 2); } }
    .page-attraction .attraction-main .main-head + * {
      margin-top: calc(8em / 8 * 6); }

.page-about .about-message .message-body {
  display: flex;
  gap: calc(8em / 16 * 1) calc(8em / 16 * 5); }
  @media screen and (max-width: 768px) {
    .page-about .about-message .message-body {
      flex-direction: column; } }
  .page-about .about-message .message-body > .side {
    flex: 1;
    z-index: -1; }
    @media screen and (max-width: 768px) {
      .page-about .about-message .message-body > .side {
        width: 100%; } }
    .page-about .about-message .message-body > .side .sticky {
      display: block;
      aspect-ratio: 5/6;
      border-radius: calc(8em / 32);
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .page-about .about-message .message-body > .side .sticky {
          aspect-ratio: 2.35/1; } }
      .page-about .about-message .message-body > .side .sticky .inner {
        width: calc(100% + 80px);
        height: 100%; }
  .page-about .about-message .message-body > .main {
    flex: 1;
    position: relative;
    z-index: 15;
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 5) calc(8em / 32 * 3);
    padding: calc(8em / 16 * 12) 0; }
    @media screen and (max-width: 768px) {
      .page-about .about-message .message-body > .main {
        order: 1;
        width: 100%;
        padding: calc(8em / 16 * 4) calc(8em / 16 * 3); } }
    .page-about .about-message .message-body > .main p {
      padding-left: calc(8rem / 16 * 7); }
      @media screen and (max-width: 768px) {
        .page-about .about-message .message-body > .main p {
          padding-left: 0; } }
      .page-about .about-message .message-body > .main p.lead {
        font-size: 2.46em;
        font-weight: 600;
        line-height: 1.3325; }
        @media screen and (max-width: 768px) {
          .page-about .about-message .message-body > .main p.lead {
            font-size: 1.845em; } }
      .page-about .about-message .message-body > .main p.body {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32 * 3);
        font-size: 1.1275em;
        line-height: 2; }
        @media screen and (max-width: 768px) {
          .page-about .about-message .message-body > .main p.body {
            line-height: 1.64; } }
        .page-about .about-message .message-body > .main p.body span {
          display: block; }
.page-about .about-philosophy .philosophy-body {
  position: relative;
  z-index: 15;
  padding: calc(8em / 16 * 12) calc(8em / 16 * 7);
  border-radius: calc(8em / 32);
  overflow: hidden; }
  @media screen and (max-width: 768px) {
    .page-about .about-philosophy .philosophy-body {
      padding: calc(8em / 16 * 10) 0; } }
  .page-about .about-philosophy .philosophy-body .background {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: -1; }
    .page-about .about-philosophy .philosophy-body .background::after {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      width: 100%;
      height: 100%;
      background: url(images/noise.png);
      background-size: 100px;
      background-repeat: repeat;
      -webkit-backdrop-filter: blur(15px);
      backdrop-filter: blur(15px); }
    .page-about .about-philosophy .philosophy-body .background img {
      filter: brightness(0.82); }
  .page-about .about-philosophy .philosophy-body p.body {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 3);
    font-size: 1.845em;
    line-height: 1.3325;
    font-weight: 600;
    text-align: center;
    letter-spacing: .041em; }
    .page-about .about-philosophy .philosophy-body p.body span {
      display: block;
      color: var(--gray1); }
.page-about .about-company .company-body {
  display: flex;
  justify-content: center;
  gap: calc(8em / 16 * 2) calc(8em / 16 * 5); }
  .page-about .about-company .company-body > .main {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 5) calc(8em / 32 * 3);
    width: 50%;
    margin-left: auto;
    margin-right: auto;
    padding: calc(8em / 16 * 12) 0; }
    @media screen and (max-width: 768px) {
      .page-about .about-company .company-body > .main {
        gap: calc(8em / 32 * 3);
        width: 100%;
        padding: calc(8em / 16 * 4) calc(8em / 16 * 3); } }
    .page-about .about-company .company-body > .main p.lead {
      font-size: 2.46em;
      font-weight: 600;
      line-height: 1.3325; }
      @media screen and (max-width: 768px) {
        .page-about .about-company .company-body > .main p.lead {
          font-size: 2.05em; } }
    .page-about .about-company .company-body > .main p.body {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32 * 3); }
      .page-about .about-company .company-body > .main p.body span {
        display: block; }
    .page-about .about-company .company-body > .main ul {
      display: flex;
      flex-wrap: wrap;
      gap: calc(8em / 16 * 3) calc(8em / 16);
      padding: 0 calc(8rem / 16 * 7); }
      @media screen and (max-width: 768px) {
        .page-about .about-company .company-body > .main ul {
          padding: 0; } }
      .page-about .about-company .company-body > .main ul > li {
        display: flex;
        align-items: center;
        flex-direction: column;
        gap: calc(8em / 32 * 3);
        width: calc((100% / 2) - (calc(8em / 16) * 1 / 2)); }
        .page-about .about-company .company-body > .main ul > li .image {
          display: block;
          width: 100%;
          aspect-ratio: 3/2;
          padding: calc(8em / 16 * 5) 0;
          border: solid 1px var(--gray3);
          border-radius: calc(8em / 32);
          overflow: hidden; }
          @media screen and (max-width: 768px) {
            .page-about .about-company .company-body > .main ul > li .image {
              padding: calc(8em / 16 * 3) 0; } }
        .page-about .about-company .company-body > .main ul > li .text {
          display: flex;
          align-items: center;
          flex-direction: column;
          gap: calc(8em / 64 * 1); }
          .page-about .about-company .company-body > .main ul > li .text .title {
            font-weight: 600; }
          .page-about .about-company .company-body > .main ul > li .text .category {
            font-size: .8em;
            color: var(--gray9); }
.page-about .about-company .company-foot {
  display: flex;
  flex-direction: column;
  gap: calc(100vw / 64); }
  .page-about .about-company .company-foot .block {
    position: relative;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: calc(100vh - ((8em / 8 * 5) + (100vw / 64)));
    padding: calc(100vw / 64) 0;
    border-radius: calc(8em / 32);
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      .page-about .about-company .company-foot .block {
        position: relative;
        top: 0;
        min-height: initial;
        padding: calc(100vw / 128); } }
    .page-about .about-company .company-foot .block .background {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      z-index: -1; }
      @media screen and (max-width: 768px) {
        .page-about .about-company .company-foot .block .background::after {
          content: '';
          position: absolute;
          top: 0;
          left: 0;
          display: block;
          width: 100%;
          height: 100%;
          background: url(images/noise.png);
          background-size: 100px;
          background-repeat: repeat;
          -webkit-backdrop-filter: blur(15px);
          backdrop-filter: blur(15px); }
        .page-about .about-company .company-foot .block .background img {
          filter: brightness(0.82); } }
    .page-about .about-company .company-foot .block .content {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32);
      width: 50%;
      margin-left: auto;
      margin-right: auto;
      padding: calc(8em / 16 * 7);
      background: var(--gray1);
      border-radius: calc(8em / 32);
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .page-about .about-company .company-foot .block .content {
          width: 100%;
          padding: calc(8em / 16 * 3); } }
      .page-about .about-company .company-foot .block .content .thumbnail {
        display: none;
        border-radius: calc(8em / 32);
        overflow: hidden; }
        @media screen and (max-width: 768px) {
          .page-about .about-company .company-foot .block .content .thumbnail {
            display: block; }
            .page-about .about-company .company-foot .block .content .thumbnail + * {
              margin-top: calc(8em / 16 * 2); } }
      .page-about .about-company .company-foot .block .content .company {
        font-weight: 600;
        color: var(--key9); }
      .page-about .about-company .company-foot .block .content p.lead {
        font-size: 2.05em;
        font-weight: 600;
        line-height: 1.3325; }
        @media screen and (max-width: 768px) {
          .page-about .about-company .company-foot .block .content p.lead {
            font-size: 1.845em; } }
        .page-about .about-company .company-foot .block .content p.lead + * {
          margin-top: calc(8em / 16); }
      .page-about .about-company .company-foot .block .content p.body {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32 * 3); }
        .page-about .about-company .company-foot .block .content p.body span {
          display: block; }
.page-about .about-history .history-body {
  display: flex;
  gap: calc(8em / 16 * 2) calc(8em / 16 * 5); }
  @media screen and (max-width: 768px) {
    .page-about .about-history .history-body {
      flex-direction: column-reverse; } }
  .page-about .about-history .history-body > .side {
    flex: 1;
    z-index: -1; }
    @media screen and (max-width: 768px) {
      .page-about .about-history .history-body > .side {
        display: none; } }
    .page-about .about-history .history-body > .side .sticky {
      display: flex;
      justify-content: flex-end;
      flex-direction: column;
      height: calc(100vh);
      padding: calc(100vw / 64) 0; }
      @media screen and (max-width: 768px) {
        .page-about .about-history .history-body > .side .sticky {
          height: initial; } }
      .page-about .about-history .history-body > .side .sticky .inner {
        width: calc(100% + ((8em / 16 * 5) * 3));
        border-radius: calc(8em / 32);
        overflow: hidden; }
        @media screen and (max-width: 768px) {
          .page-about .about-history .history-body > .side .sticky .inner {
            width: 100%; } }
  .page-about .about-history .history-body > .main {
    flex: 1; }
  .page-about .about-history .history-body ul.history-list {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 8 * 3); }
    @media screen and (max-width: 768px) {
      .page-about .about-history .history-body ul.history-list {
        gap: calc(8em / 8 * 2); } }
    .page-about .about-history .history-body ul.history-list > li .year-group {
      font-size: 2.255em;
      font-weight: 600;
      letter-spacing: -.041em;
      text-align: right; }
      @media screen and (max-width: 768px) {
        .page-about .about-history .history-body ul.history-list > li .year-group {
          text-align: left; } }
  .page-about .about-history .history-body ul.history-items {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16); }
    @media screen and (max-width: 768px) {
      .page-about .about-history .history-body ul.history-items {
        gap: 0; } }
    .page-about .about-history .history-body ul.history-items > li {
      display: flex;
      align-items: baseline;
      gap: calc(8em / 8 * 2);
      padding: calc(8em / 32 * 3);
      background: var(--border-light-white);
      border-radius: calc(8em / 32);
      overflow: hidden;
      opacity: 0;
      transform: translateY(16px);
      will-change: opacity, transform;
      backdrop-filter: blur(15px); }
      @media screen and (max-width: 768px) {
        .page-about .about-history .history-body ul.history-items > li {
          padding: calc(8em / 32 * 1) 0;
          padding-left: calc(8em / 16 * 3); } }
      .page-about .about-history .history-body ul.history-items > li .year {
        display: flex;
        align-items: baseline;
        gap: calc(8em / 64);
        font-weight: 600; }
        .page-about .about-history .history-body ul.history-items > li .year .num {
          font-size: 1.435em;
          letter-spacing: -.041em; }
        .page-about .about-history .history-body ul.history-items > li .year .attr {
          font-size: .85em; }

.page-numbers .numbers-main .main-body {
  display: flex;
  flex-wrap: wrap;
  gap: calc(100vw / 128);
  padding-top: calc(100vw / 64); }
  .page-numbers .numbers-main .main-body .block {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 64 * 3);
    padding: calc(8em / 16 * 3);
    background: var(--gray3);
    border-radius: calc(8em / 32);
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      .page-numbers .numbers-main .main-body .block {
        padding: calc(8em / 16 * 2); } }
    .page-numbers .numbers-main .main-body .block.col3 {
      width: calc((100% / 4) - ((100vw / 128) * 3 / 4)); }
      @media screen and (max-width: 768px) {
        .page-numbers .numbers-main .main-body .block.col3 {
          width: calc((100% / 2) - ((100vw / 128) * 1 / 2)); } }
    .page-numbers .numbers-main .main-body .block.col4 {
      width: calc((100% / 3) - ((100vw / 128) * 2 / 3)); }
      @media screen and (max-width: 768px) {
        .page-numbers .numbers-main .main-body .block.col4 {
          width: calc((100% / 2) - ((100vw / 128) * 1 / 2)); } }
    .page-numbers .numbers-main .main-body .block.col6 {
      width: calc((100% / 2) - ((100vw / 128) * 1 / 2)); }
    .page-numbers .numbers-main .main-body .block.col12 {
      width: calc(100% / 1); }
    @media screen and (max-width: 768px) {
      .page-numbers .numbers-main .main-body .block.spcol12 {
        width: calc(100% / 1); } }
    .page-numbers .numbers-main .main-body .block .head {
      display: flex;
      align-items: center;
      gap: calc(8em / 32);
      font-weight: 600;
      font-size: .9em; }
      @media screen and (max-width: 768px) {
        .page-numbers .numbers-main .main-body .block .head {
          justify-content: center; } }
      .page-numbers .numbers-main .main-body .block .head::before {
        content: '';
        display: block;
        width: .8em;
        min-width: .8em;
        height: .8em;
        background: var(--gray12);
        border-radius: 1em; }
    .page-numbers .numbers-main .main-body .block .body {
      position: relative;
      z-index: 15;
      flex: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      flex-direction: column; }
      .page-numbers .numbers-main .main-body .block .body:has(.background) {
        min-height: 10.25em; }
      .page-numbers .numbers-main .main-body .block .body .background {
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100%; }
      .page-numbers .numbers-main .main-body .block .body .chart {
        width: 100%;
        height: 410px; }
        @media screen and (max-width: 768px) {
          .page-numbers .numbers-main .main-body .block .body .chart {
            height: 287px; } }
      .page-numbers .numbers-main .main-body .block .body .gender-chart, .page-numbers .numbers-main .main-body .block .body .job-chart {
        position: relative;
        width: 205px;
        height: 205px; }
      .page-numbers .numbers-main .main-body .block .body .number {
        display: flex;
        justify-content: center;
        gap: calc(8em / 64);
        font-weight: 600;
        line-height: 1; }
        .page-numbers .numbers-main .main-body .block .body .number .num {
          color: var(--key9);
          font-size: 3.28em; }
          @media screen and (max-width: 768px) {
            .page-numbers .numbers-main .main-body .block .body .number .num {
              font-size: 2.46em; } }
        .page-numbers .numbers-main .main-body .block .body .number .attr {
          display: flex;
          align-items: flex-end;
          padding-bottom: .2em;
          font-size: 1.435em; }
          @media screen and (max-width: 768px) {
            .page-numbers .numbers-main .main-body .block .body .number .attr {
              font-size: 1.1275em; } }
        .page-numbers .numbers-main .main-body .block .body .number .num-col {
          display: flex;
          align-items: center;
          flex-direction: column; }
          .page-numbers .numbers-main .main-body .block .body .number .num-col > .num {
            font-size: 3.28em; }
          .page-numbers .numbers-main .main-body .block .body .number .num-col > .attr {
            font-size: 1em; }
      .page-numbers .numbers-main .main-body .block .body .caption {
        font-size: max(12px, 0.7em);
        color: var(--gray11); }

.archive_joblist .search-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between; }
  .archive_joblist .search-head h3 {
    font-size: 1.1285em;
    font-weight: 600; }
  .archive_joblist .search-head .total {
    display: flex;
    align-items: baseline; }
    .archive_joblist .search-head .total .num {
      font-size: 1.845em;
      color: var(--key); }
    .archive_joblist .search-head .total .text {
      font-size: .8em; }
  .archive_joblist .search-head + * {
    margin-top: calc(8em / 8); }
.archive_joblist .searchandfilter {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  flex-wrap: wrap; }
  @media screen and (max-width: 768px) {
    .archive_joblist .searchandfilter {
      padding: calc(8em / 16 * 3);
      background: var(--color-lightgray);
      border-radius: calc(8em / 16); } }
  .archive_joblist .searchandfilter ul {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16);
    width: 100%; }
    .archive_joblist .searchandfilter ul > li {
      display: flex;
      flex-direction: column;
      padding: 0;
      border-radius: 6px;
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .archive_joblist .searchandfilter ul > li label {
          flex: 1; } }
      .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] {
        margin-top: calc(8em / 8); }
        .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] ul {
          display: flex;
          flex-direction: row;
          flex-wrap: wrap;
          gap: calc(8em / 24);
          font-size: .9em; }
          .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] ul > li {
            display: table;
            border-radius: 4px;
            transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
            .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] ul > li:hover {
              opacity: .5;
              transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] {
        margin-top: calc(8em / 64 * 3); }
        .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] ul {
          max-height: 210px;
          overflow: scroll;
          background: var(--background3);
          padding: .75em;
          border: 1px solid rgba(0, 0, 0, 0.1025);
          border-radius: 6px; }
          .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] ul > li {
            position: relative;
            align-items: center;
            flex-direction: row;
            font-size: 16px; }
            .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] ul > li input {
              width: 1px;
              opacity: 0; }
            .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] ul > li::before {
              content: '';
              display: block;
              width: 1.23em;
              height: 1.23em;
              background: url(images/icon/check.svg);
              background-size: cover;
              filter: grayscale(1); }
            .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] ul > li:has(input[type="checkbox"]:checked)::before {
              filter: grayscale(0); }
      .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="link"] a {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 2.87em;
        background: var(--color-text);
        border-radius: calc(8em / 32);
        overflow: hidden;
        color: var(--color-white);
        transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
        .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="link"] a:hover {
          filter: brightness(0.8);
          transform: scale(0.985);
          transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  .archive_joblist .searchandfilter h4 {
    min-width: 5.575em;
    padding: 0;
    margin-bottom: calc(8em / 16); }
  .archive_joblist .searchandfilter label {
    flex: 1; }
    @media screen and (max-width: 768px) {
      .archive_joblist .searchandfilter label {
        display: block; } }
  .archive_joblist .searchandfilter select {
    display: block;
    min-width: 184.5px;
    max-width: 100%;
    height: calc(8em / 8 * 3);
    background-color: var(--color-white);
    border: 1px solid var(--border-light-black);
    border-radius: 6px;
    font-size: 16px;
    padding: 0 40px 0 20px;
    background-image: url(../images/common/icon-chevron-bottom.svg);
    background-position: calc(100% - 0.28rem) center;
    background-size: 0.08rem 0.14rem; }
    @media screen and (max-width: 768px) {
      .archive_joblist .searchandfilter select {
        height: 41px; } }
  .archive_joblist .searchandfilter input[type="radio"] {
    display: none; }
    .archive_joblist .searchandfilter input[type="radio"] + label {
      padding: calc(8em / 24) calc(8em / 12);
      background: var(--color-white);
      border: solid 1px var(--border-light-black);
      border-radius: 4px; }
    .archive_joblist .searchandfilter input[type="radio"]:checked + label {
      background: var(--key9);
      color: var(--color-white); }
  .archive_joblist .searchandfilter input[type="submit"] {
    display: block;
    min-width: 100%;
    height: calc(8em / 8 * 3);
    background-color: var(--color-white);
    border: 1px solid var(--border-light-black);
    border-radius: 6px;
    font-size: 16px;
    padding: 0 20px;
    background: var(--gray1);
    background: url(images/noise.png), var(--gray1);
    background-repeat: repeat;
    background-size: 100px;
    color: var(--color-white); }
    @media screen and (max-width: 768px) {
      .archive_joblist .searchandfilter input[type="submit"] {
        width: 100%;
        height: 51.25px; } }
  .archive_joblist .searchandfilter + * {
    margin-top: calc(8em / 16 * 3); }

@media screen and (max-width: 768px) {
  .joblist_archive {
    width: calc(100% / 30 * 28);
    margin: 0 auto; } }
.joblist_archive ul.list {
  padding-bottom: calc(8em / 8 * 3);
  border-bottom: solid 1px var(--border-light-black); }
  .joblist_archive ul.list > li ~ li {
    margin-top: calc(8em / 8 * 3);
    padding-top: calc(8em / 8 * 3);
    border-top: solid 1px var(--border-light-black); }
  .joblist_archive ul.list > li .card > ._head h2 {
    font-size: 1.845em;
    line-height: 1.435;
    font-weight: 600; }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .card > ._head h2 {
        font-size: 1.64em; } }
  .joblist_archive ul.list > li .card > ._head + * {
    margin-top: calc(8em / 8); }
  .joblist_archive ul.list > li .card > ._body {
    display: flex;
    align-items: flex-start;
    gap: calc(8em / 16) calc(8em / 8 * 3); }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .card > ._body {
        gap: calc(8em / 16) calc(8em / 8 * 1); } }
    .joblist_archive ul.list > li .card > ._body > .text {
      flex: 3; }
      .joblist_archive ul.list > li .card > ._body > .text ul {
        border-top: solid 1px var(--border-light-black);
        font-size: .9em; }
        .joblist_archive ul.list > li .card > ._body > .text ul li {
          display: flex;
          align-items: baseline;
          padding: calc(8em / 16 * 1) 0;
          border-bottom: solid 1px var(--border-light-black); }
          .joblist_archive ul.list > li .card > ._body > .text ul li span {
            flex: 1;
            font-weight: 600; }
          .joblist_archive ul.list > li .card > ._body > .text ul li p {
            flex: 3; }
        .joblist_archive ul.list > li .card > ._body > .text ul + * {
          margin-top: calc(8em / 8); }
    .joblist_archive ul.list > li .card > ._body > .thumbnail {
      flex: 1;
      border-radius: calc(8em / 24);
      overflow: hidden; }
      .joblist_archive ul.list > li .card > ._body > .thumbnail img {
        transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  .joblist_archive ul.list > li .card:hover > ._body > .thumbnail img {
    transform: scale(1.05);
    transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  .joblist_archive ul.list > li .linker {
    display: flex;
    align-items: center;
    gap: calc(8em / 8 * 1);
    width: 100%;
    margin-top: calc(8em / 16 * 3); }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .linker {
        gap: calc(8em / 16 * 1); } }
    .joblist_archive ul.list > li .linker > li {
      flex: 1; }
      .joblist_archive ul.list > li .linker > li a {
        display: flex;
        align-items: center;
        justify-content: center;
        height: calc(8em / 8* 3);
        background: var(--color-black);
        border: 1px solid rgba(0, 0, 0, 0.1025);
        border-radius: 6px;
        font-size: 16px;
        padding: 0 20px;
        color: var(--color-white);
        transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
        .joblist_archive ul.list > li .linker > li a:hover {
          transform: scale(0.985);
          filter: brightness(0.9);
          transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
      .joblist_archive ul.list > li .linker > li[data-type="entry"] a {
        background: var(--key); }
.joblist_archive nav.pagination {
  margin-top: calc(8em / 8 * 3); }
  .joblist_archive nav.pagination .screen-reader-text {
    display: none; }
  .joblist_archive nav.pagination .nav-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: calc(8em / 12); }
    .joblist_archive nav.pagination .nav-links .page-numbers {
      display: flex;
      align-items: center;
      justify-content: center;
      width: calc(8em / 3);
      height: calc(8em / 3);
      background: var(--gray3);
      border-radius: 8em;
      overflow: hidden; }
      .joblist_archive nav.pagination .nav-links .page-numbers:hover {
        filter: brightness(0.9); }
      .joblist_archive nav.pagination .nav-links .page-numbers.current {
        filter: brightness(1);
        background: var(--gray1);
        background: url(images/noise.png), var(--gray1);
        background-repeat: repeat;
        background-size: 100px;
        color: var(--color-white); }
      .joblist_archive nav.pagination .nav-links .page-numbers.dots {
        background: none; }

.single_joblist {
  position: relative;
  z-index: 15; }
  .single_joblist .wrapper {
    width: calc(100% / 32 * 28);
    max-width: 980px;
    margin-left: auto;
    margin-right: auto;
    padding-top: calc(8em / 8 * 4);
    padding-bottom: calc(8em / 8 * 6); }
    @media screen and (max-width: 768px) {
      .single_joblist .wrapper {
        padding-top: calc(8em / 16 * 4);
        padding-bottom: calc(8em / 16 * 6); } }
  .single_joblist .flex_wrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 2em 60px; }
    .single_joblist .flex_wrapper > .main {
      width: 640px;
      max-width: 100%; }
    .single_joblist .flex_wrapper > .side {
      width: 280px;
      max-width: 100%; }
      @media screen and (max-width: 768px) {
        .single_joblist .flex_wrapper > .side {
          width: 100%; } }
      .single_joblist .flex_wrapper > .side .sticky {
        top: calc(8em / 8 * 6);
        display: flex;
        flex-direction: column; }
      .single_joblist .flex_wrapper > .side .block ~ .block {
        margin-top: calc(8em / 16 * 3);
        padding-top: calc(8em / 16 * 3);
        border-top: solid 1px var(--border-light-black); }
  .single_joblist .single_head {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 2); }
    .single_joblist .single_head .locaiton {
      display: flex;
      align-items: center;
      justify-content: flex-start;
      font-size: .8em; }
      .single_joblist .single_head .locaiton p {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 2.05em;
        padding: 0 calc(8em / 32 * 3);
        background: var(--key2);
        border-radius: 2.05em;
        color: var(--white); }
    .single_joblist .single_head h1 {
      font-size: 2.05em;
      font-weight: 600;
      line-height: 1.23; }
      @media screen and (max-width: 768px) {
        .single_joblist .single_head h1 {
          font-size: 1.845em; } }
    .single_joblist .single_head ul.terms {
      display: flex;
      align-items: center;
      flex-wrap: wrap;
      gap: calc(8em / 16) calc(8em / 8);
      font-size: .9em; }
      .single_joblist .single_head ul.terms > li {
        display: flex;
        align-items: center;
        gap: calc(8em / 32); }
        .single_joblist .single_head ul.terms > li .icon {
          display: block;
          width: 1em;
          height: 1em; }
          .single_joblist .single_head ul.terms > li .icon img {
            filter: brightness(0) opacity(0.6); }
    .single_joblist .single_head + * {
      margin-top: calc(8em / 16 * 3); }
  .single_joblist .single_thumbnail {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    border-radius: calc(8em / 32);
    overflow: hidden; }
    .single_joblist .single_thumbnail + * {
      margin-top: calc(8em / 8 * 3); }
      @media screen and (max-width: 768px) {
        .single_joblist .single_thumbnail + * {
          margin-top: calc(8em / 8 * 2); } }
  .single_joblist .single_body hgroup:has(h2) h2 {
    display: flex;
    align-items: center;
    gap: calc(8em / 64 * 3);
    font-size: 1.5575em; }
    @media screen and (max-width: 768px) {
      .single_joblist .single_body hgroup:has(h2) h2 {
        font-size: 1.3325em; } }
    .single_joblist .single_body hgroup:has(h2) h2::before {
      content: '';
      display: block;
      width: .7em;
      height: .7em;
      background: var(--key9);
      border-radius: .7em; }
  .single_joblist .single_body hgroup:has(h2) + * {
    margin-top: calc(8em / 8); }
  .single_joblist .single_body hgroup:has(h3) h3 {
    font-size: 1em; }
  .single_joblist .single_body hgroup:has(h3) + * {
    margin-top: calc(8em / 32 * 3); }
  .single_joblist .single_body .single_block ~ .single_block {
    margin-top: calc(8em / 8 * 4); }
    @media screen and (max-width: 768px) {
      .single_joblist .single_body .single_block ~ .single_block {
        margin-top: calc(8em / 8 * 3); } }
  .single_joblist .requirements_wrapper ul.list {
    font-size: .9em;
    border-top: solid 1px var(--border-light-black); }
    @media screen and (max-width: 768px) {
      .single_joblist .requirements_wrapper ul.list {
        font-size: 1em; } }
    .single_joblist .requirements_wrapper ul.list > li {
      padding: calc(8em / 32 * 3) 0;
      border-bottom: solid 1px var(--border-light-black); }
      @media screen and (max-width: 768px) {
        .single_joblist .requirements_wrapper ul.list > li {
          padding: calc(8em / 32 * 2) 0 calc(8em / 32 * 3); } }
      .single_joblist .requirements_wrapper ul.list > li dl {
        display: flex;
        flex-wrap: wrap;
        gap: calc(8em / 32 * 2) 18px; }
        @media screen and (max-width: 768px) {
          .single_joblist .requirements_wrapper ul.list > li dl {
            flex-direction: column; } }
        .single_joblist .requirements_wrapper ul.list > li dl > dt {
          flex: 1; }
          @media screen and (max-width: 768px) {
            .single_joblist .requirements_wrapper ul.list > li dl > dt {
              padding-bottom: 0;
              border-right: 0;
              line-height: 1;
              font-size: .85em; } }
          .single_joblist .requirements_wrapper ul.list > li dl > dt span {
            font-weight: 600; }
        .single_joblist .requirements_wrapper ul.list > li dl > dd {
          flex: 3; }
          .single_joblist .requirements_wrapper ul.list > li dl > dd span {
            display: block; }
            .single_joblist .requirements_wrapper ul.list > li dl > dd span ~ span {
              margin-top: 1em; }
  .single_joblist .requirements_wrapper ul.table {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16);
    font-size: .9em; }
    .single_joblist .requirements_wrapper ul.table > li dl {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 128); }
      .single_joblist .requirements_wrapper ul.table > li dl > dt {
        font-weight: 600;
        font-size: .8em; }
      .single_joblist .requirements_wrapper ul.table > li dl > dd span {
        display: block; }
  .single_joblist .requirements_wrapper .form_wrapper {
    border: solid 1px var(--border-light-black);
    border-radius: calc(8em / 32);
    font-size: .9em; }
  .single_joblist .requirements_wrapper .formWrap > .title {
    display: none; }

.formbutton {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: calc(8em / 32 * 2);
  min-height: 3.28em;
  padding: 0 calc(8em / 32 * 3);
  background: var(--key9);
  border-radius: calc(8em / 32);
  overflow: hidden;
  transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
  -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
  .formbutton * {
    color: var(--gray1); }
  .formbutton .icon {
    display: block;
    width: 1em;
    height: 1em; }
    .formbutton .icon img {
      filter: brightness(0) invert(1); }
  .formbutton:hover {
    transform: scale(0.95);
    filter: brightness(0.95);
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }

.-page {
  position: relative;
  z-index: 25; }
  .-page > .wrapper {
    display: block;
    width: calc(100% / 16 * 15);
    margin: 0 auto;
    padding: calc(8em / 8 * 4) 0 calc(8em / 8 * 8); }
    @media screen and (max-width: 768px) {
      .-page > .wrapper {
        padding: calc(8em / 16 * 4) 0 calc(8em / 16 * 6); } }
    .-page > .wrapper.flex_wrapper {
      display: flex;
      flex-wrap: wrap;
      gap: calc(8em / 8 * 2) calc(8em / 8 * 2); }
      @media screen and (max-width: 768px) {
        .-page > .wrapper.flex_wrapper {
          flex-direction: column; } }
      .-page > .wrapper.flex_wrapper > .left_side {
        width: calc(8em / 8 * 14); }
        @media screen and (max-width: 768px) {
          .-page > .wrapper.flex_wrapper > .left_side {
            display: none; } }
        .-page > .wrapper.flex_wrapper > .left_side .sticky {
          top: calc(8em / 1); }
          .-page > .wrapper.flex_wrapper > .left_side .sticky h5 {
            display: flex;
            align-items: center;
            column-gap: calc(8em / 24);
            font-size: 1em;
            font-weight: 500;
            text-transform: uppercase; }
            .-page > .wrapper.flex_wrapper > .left_side .sticky h5::before {
              content: '';
              display: block;
              width: 1em;
              height: 1em;
              background: url(images/icon/menu.svg); }
            .-page > .wrapper.flex_wrapper > .left_side .sticky h5 + * {
              margin-top: calc(8em / 8); }
          .-page > .wrapper.flex_wrapper > .left_side .sticky > ul {
            counter-reset: num;
            display: flex;
            flex-direction: column;
            gap: calc(8em / 12); }
            @media screen and (max-width: 768px) {
              .-page > .wrapper.flex_wrapper > .left_side .sticky > ul {
                padding: calc(8em / 16 * 3);
                background: var(--gray2);
                border-radius: calc(8em / 16 * 1); } }
            .-page > .wrapper.flex_wrapper > .left_side .sticky > ul > li {
              display: flex;
              align-items: center;
              opacity: .5; }
              .-page > .wrapper.flex_wrapper > .left_side .sticky > ul > li a {
                display: flex;
                align-items: center;
                gap: calc(8em / 16);
                font-weight: 600;
                font-size: .9em; }
                .-page > .wrapper.flex_wrapper > .left_side .sticky > ul > li a::before {
                  counter-increment: num;
                  content: "0" counter(num);
                  display: flex;
                  align-items: center;
                  justify-content: center;
                  width: 2.05em;
                  min-width: 2.05em;
                  height: 2.05em;
                  background: linear-gradient(135deg, var(--color-black) 75%, var(--key12));
                  border-radius: calc(8em / 32);
                  overflow: hidden;
                  font-weight: 500;
                  color: var(--color-white); }
              .-page > .wrapper.flex_wrapper > .left_side .sticky > ul > li.active, .-page > .wrapper.flex_wrapper > .left_side .sticky > ul > li:hover {
                opacity: 1; }
            .-page > .wrapper.flex_wrapper > .left_side .sticky > ul.anker > li a::before {
              content: '';
              width: .41em;
              min-width: .41em;
              height: .615em;
              clip-path: polygon(0 0, 100% 50%, 0 100%); }
      .-page > .wrapper.flex_wrapper > .right_side {
        width: calc(100% - ((8em / 8 * 14) + (8em / 8 * 2)));
        min-width: 767px; }
        @media screen and (max-width: 768px) {
          .-page > .wrapper.flex_wrapper > .right_side {
            width: 100%;
            min-width: 100%; } }
    .-page > .wrapper.document_wrapper {
      width: calc(100% / 16 * 12); }
      @media screen and (max-width: 768px) {
        .-page > .wrapper.document_wrapper {
          width: calc(100% / 16 * 14); } }
  .-page .page_main .page_body .page_block hgroup {
    display: flex;
    align-items: center;
    flex-direction: column-reverse; }
    .-page .page_main .page_body .page_block hgroup span {
      position: relative;
      z-index: 15;
      font-size: calc(8em / 16 * 10);
      font-weight: 400;
      letter-spacing: -.0205em;
      color: var(--color-black);
      background: linear-gradient(135deg, var(--color-black) 75%, var(--key9));
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent; }
      @media screen and (max-width: 768px) {
        .-page .page_main .page_body .page_block hgroup span {
          font-size: calc(8em / 16 * 5); } }
    .-page .page_main .page_body .page_block hgroup h2 {
      display: flex;
      align-items: center;
      gap: calc(8em / 64* 3);
      font-size: 1em;
      font-weight: var(--fontweight-8);
      color: var(--color-black); }
    .-page .page_main .page_body .page_block hgroup h3 {
      font-size: 1.5525em;
      font-weight: var(--fontweight-8); }
    .-page .page_main .page_body .page_block hgroup .sub {
      color: var(--key9); }
    .-page .page_main .page_body .page_block hgroup + * {
      margin-top: calc(8.5rem / 16 * 5); }
      @media screen and (max-width: 768px) {
        .-page .page_main .page_body .page_block hgroup + * {
          margin-top: calc(8.5rem / 16 * 3); } }
  .-page .page_main .page_body .page_block ~ .page_block {
    margin-top: calc(8em / 8 * 10); }
    @media screen and (max-width: 768px) {
      .-page .page_main .page_body .page_block ~ .page_block {
        margin-top: calc(8em / 8 * 5); } }
  .-page .page_main .page_body .page_block .page_cell ~ .page_cell {
    margin-top: calc(8em / 8 * 6); }
    @media screen and (max-width: 768px) {
      .-page .page_main .page_body .page_block .page_cell ~ .page_cell {
        margin-top: calc(8em / 8 * 4); } }

header#singleHeader {
  position: relative;
  z-index: 15;
  margin-top: calc(30px + (8em / 32 * 22)); }
  @media screen and (max-width: 768px) {
    header#singleHeader {
      margin-top: calc(25px + (8em / 32 * 14)); } }
  header#singleHeader .wrapper {
    display: flex;
    align-items: flex-start;
    flex-direction: column;
    gap: calc(8em / 8 * 1);
    width: calc(100% / 32 * 27);
    margin: 0 auto;
    padding-top: calc(8em / 2); }
    @media screen and (max-width: 768px) {
      header#singleHeader .wrapper {
        width: calc(100% / 32 * 28);
        padding-top: calc(8em / 8 * 2); } }
    header#singleHeader .wrapper hgroup {
      position: relative;
      z-index: 15; }
      header#singleHeader .wrapper hgroup h1 {
        font-size: 2.46em;
        font-weight: normal;
        line-height: 1.435; }
        @media screen and (max-width: 768px) {
          header#singleHeader .wrapper hgroup h1 {
            font-size: 1.64em; } }
    header#singleHeader .wrapper .publish {
      display: flex;
      align-items: center;
      column-gap: calc(8em / 12); }
      header#singleHeader .wrapper .publish p {
        display: flex;
        align-items: center;
        justify-content: center;
        padding: calc(8em / 64 * 1) calc(8em / 64 * 5);
        background: var(--color-lightgray);
        border-radius: 8em;
        overflew: hidden; }
      header#singleHeader .wrapper .publish time {
        color: var(--color-gray); }

article.-single {
  position: relative;
  z-index: 25; }
  article.-single > .wrapper {
    display: block;
    width: calc(100% / 16 * 14);
    margin: 0 auto;
    padding: calc(8em / 8 * 4) 0 calc(8em / 8 * 8); }
    article.-single > .wrapper.flex_wrapper {
      display: flex;
      flex-wrap: wrap;
      gap: calc(8em / 8 * 2) calc(8em / 8 * 4); }
      @media screen and (max-width: 768px) {
        article.-single > .wrapper.flex_wrapper {
          flex-direction: column; } }
      article.-single > .wrapper.flex_wrapper > .left_side {
        flex: 2;
        min-width: calc(8em / 8 * 8); }
        @media screen and (max-width: 768px) {
          article.-single > .wrapper.flex_wrapper > .left_side {
            display: none; } }
        article.-single > .wrapper.flex_wrapper > .left_side .sticky {
          top: calc(8em / 1); }
          article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation {
            display: flex;
            flex-direction: column;
            gap: calc(8em / 12); }
            @media screen and (max-width: 768px) {
              article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation {
                padding: calc(8em / 16 * 3);
                background: var(--gray2);
                border-radius: calc(8em / 16 * 1); } }
            article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation > li {
              display: flex;
              align-items: center;
              column-gap: calc(8em / 16);
              opacity: .5; }
              article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation > li::after {
                content: '';
                display: block;
                width: 1.23em;
                height: 1.23em;
                background: url(images/icon/arrow.svg);
                opacity: 0;
                transform: translateX(calc(8em / -16));
                transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
              article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation > li a {
                font-weight: 700;
                font-size: 1.435em; }
                @media screen and (max-width: 768px) {
                  article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation > li a {
                    font-size: 1.23em; } }
              article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation > li.current, article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation > li:hover {
                opacity: 1; }
              article.-single > .wrapper.flex_wrapper > .left_side .sticky > ul.navigation > li:hover::after {
                opacity: 1;
                transform: translateX(0);
                transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
                -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
          article.-single > .wrapper.flex_wrapper > .left_side .sticky .title {
            display: flex;
            align-items: center;
            gap: calc(8em / 16);
            margin-top: calc(8em / 16 * 4); }
            article.-single > .wrapper.flex_wrapper > .left_side .sticky .title::before {
              content: '';
              display: block;
              width: calc(8em / 32);
              height: 1em;
              background: linear-gradient(to bottom, var(--key9) 50%, var(--key11) 50%); }
            article.-single > .wrapper.flex_wrapper > .left_side .sticky .title + * {
              margin-top: calc(8em / 8); }
      article.-single > .wrapper.flex_wrapper > .right_side {
        flex: 7; }
      article.-single > .wrapper.flex_wrapper::after {
        content: '';
        flex: 2;
        display: block; }
        @media screen and (max-width: 768px) {
          article.-single > .wrapper.flex_wrapper::after {
            display: none; } }
  article.-single .single_main .thumbnail + * {
    margin-top: calc(8em / 16 * 3); }
  article.-single .single_main .single_body {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16 * 1); }
    article.-single .single_main .single_body + * {
      margin-top: calc(8em / 16 * 3); }
  article.-single .single_main a {
    color: var(--key9);
    text-decoration: underline; }
    article.-single .single_main a * {
      color: var(--key9); }

nav.pageanker {
  width: calc(100% / 32 * 30);
  margin: 0 auto;
  padding: calc(8em / 8) 0 calc(8em / 8 * 3); }
  nav.pageanker ul {
    display: flex;
    justify-content: flex-end;
    flex-wrap: wrap;
    gap: calc(8em / 16) calc(8em / 8); }
    nav.pageanker ul > li a {
      display: flex;
      align-items: center;
      gap: calc(8em / 64 * 3); }
      nav.pageanker ul > li a i {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 1em;
        height: 1em;
        background: var(--color-white);
        border: solid 1px var(--border-light-black);
        border-radius: calc(8em / 64);
        overflow: hidden;
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        nav.pageanker ul > li a i::after {
          content: '';
          display: block;
          width: 1em;
          height: 1em;
          background: url(images/icon/arrowb.svg);
          background-size: .5em;
          background-repeat: no-repeat;
          background-position: center;
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      nav.pageanker ul > li a:hover i {
        background: var(--key9);
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
        nav.pageanker ul > li a:hover i::after {
          filter: invert(1);
          transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
          -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }

.page_navigation {
  position: relative;
  z-index: 15;
  padding: calc(8em / 8 * 2) 0 calc(8em / 8 * 2);
  background: var(--gray3); }
  .page_navigation a {
    display: block; }
  .page_navigation .wrapper {
    position: relative;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    width: calc(100% / 32 * 29);
    margin: 0 auto; }
    .page_navigation .wrapper > span {
      font-size: 1.075em; }
    .page_navigation .wrapper .nextpage {
      display: flex;
      align-items: center;
      column-gap: calc(8em / 8 * 4); }
      @media screen and (max-width: 768px) {
        .page_navigation .wrapper .nextpage {
          align-items: flex-end;
          justify-content: space-between;
          column-gap: calc(8em / 8 * 2);
          width: 100%; } }
      .page_navigation .wrapper .nextpage > .text {
        display: flex;
        align-items: center;
        column-gap: calc(8em / 16 * 3); }
        .page_navigation .wrapper .nextpage > .text hgroup p {
          line-height: 1.3325; }
          .page_navigation .wrapper .nextpage > .text hgroup p.en {
            font-size: 2.05em; }
        .page_navigation .wrapper .nextpage > .text i {
          display: flex;
          align-items: center;
          min-height: 1.64em;
          padding: 0 calc(8em / 10);
          background: var(--color-black);
          border-radius: 8em; }
          .page_navigation .wrapper .nextpage > .text i img {
            display: block;
            width: .9em;
            height: .9em;
            filter: brightness(0) invert(1); }
      .page_navigation .wrapper .nextpage > .image {
        width: calc(8em / 8 * 8); }
        @media screen and (max-width: 768px) {
          .page_navigation .wrapper .nextpage > .image {
            width: calc(8em / 8 * 7); } }
        .page_navigation .wrapper .nextpage > .image div {
          aspect-ratio: 1/1;
          border-radius: calc(8em / 16);
          overflow: hidden; }

.archive_interview {
  padding-bottom: calc(8em / 8 * 4); }
  .archive_interview ul.list {
    display: flex;
    flex-wrap: wrap;
    gap: calc(8em / 16 * 3) calc(8em / 32 * 3); }
    .archive_interview ul.list > li {
      width: calc((100% / 4) - ((8em / 32 * 3) * 3 / 4));
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      @media screen and (max-width: 768px) {
        .archive_interview ul.list > li {
          width: calc((100% / 2) - ((8em / 32 * 3) * 1 / 2)); } }
      .archive_interview ul.list > li:hover {
        filter: brightness(1) !important;
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .archive_interview ul.list > li .card {
        position: relative;
        z-index: 15;
        display: flex;
        flex-direction: column;
        gap: calc(8em / 8); }
        .archive_interview ul.list > li .card .image {
          position: relative;
          z-index: 15;
          aspect-ratio: 5 / 6;
          line-height: 0;
          border-radius: calc(8em / 32);
          overflow: hidden; }
          .archive_interview ul.list > li .card .image img {
            transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
            -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
            -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
            -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
        .archive_interview ul.list > li .card .text {
          display: flex;
          flex-direction: column; }
          .archive_interview ul.list > li .card .text p {
            font-weight: 600; }
            .archive_interview ul.list > li .card .text p.name {
              font-size: 1.3325em; }
            .archive_interview ul.list > li .card .text p.section {
              color: var(--key9); }
        .archive_interview ul.list > li .card:hover .image img {
          transform: scale(1.025);
          transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
    .archive_interview ul.list:hover > li {
      filter: brightness(0.615);
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }

.post_interview > .wrapper {
  width: calc(100% / 64 * 62);
  margin-left: auto;
  margin-right: auto; }
  .post_interview > .wrapper .interview-wrapper {
    display: flex;
    align-items: flex-start;
    gap: calc(8em / 8 * 3) calc(8em / 8 * 4); }
    @media screen and (max-width: 768px) {
      .post_interview > .wrapper .interview-wrapper {
        flex-direction: column; } }
    .post_interview > .wrapper .interview-wrapper > .interview_thumbnail {
      flex: 1;
      display: flex;
      justify-content: flex-start; }
      @media screen and (max-width: 768px) {
        .post_interview > .wrapper .interview-wrapper > .interview_thumbnail {
          display: none; } }
      .post_interview > .wrapper .interview-wrapper > .interview_thumbnail.sticky {
        top: calc(8em / 8 * 6); }
    .post_interview > .wrapper .interview-wrapper > .interview_body {
      flex: 2; }
      @media screen and (max-width: 768px) {
        .post_interview > .wrapper .interview-wrapper > .interview_body {
          padding: 0 calc(8em / 16 * 3); } }
      .post_interview > .wrapper .interview-wrapper > .interview_body .thumbnail {
        width: 100%;
        aspect-ratio: 2/1;
        border-radius: calc(8em / 32);
        overflow: hidden; }
        .post_interview > .wrapper .interview-wrapper > .interview_body .thumbnail + * {
          margin-top: calc(8em / 8 * 4); }
          @media screen and (max-width: 768px) {
            .post_interview > .wrapper .interview-wrapper > .interview_body .thumbnail + * {
              margin-top: calc(8em / 8 * 3); } }
      .post_interview > .wrapper .interview-wrapper > .interview_body .profile hgroup h2 {
        font-size: 1.845em;
        font-weight: 600;
        text-transform: uppercase;
        color: var(--key9);
        letter-spacing: -.0205em; }
      .post_interview > .wrapper .interview-wrapper > .interview_body .profile hgroup + * {
        margin-top: calc(8em / 16 * 3); }
      .post_interview > .wrapper .interview-wrapper > .interview_body .profile ul::before {
        content: '';
        display: block;
        width: 100%;
        height: 1px;
        background: linear-gradient(to right, var(--key9) 16.667%, var(--gray5) 16.667%); }
      .post_interview > .wrapper .interview-wrapper > .interview_body .profile ul > li::after {
        content: '';
        display: block;
        width: 100%;
        height: 1px;
        background: linear-gradient(to right, var(--key9) 16.667%, var(--gray5) 16.667%); }
      .post_interview > .wrapper .interview-wrapper > .interview_body .profile ul > li dl {
        display: flex;
        align-items: center;
        padding: calc(8em / 32 * 3) 0;
        font-size: 1.1275em; }
        @media screen and (max-width: 768px) {
          .post_interview > .wrapper .interview-wrapper > .interview_body .profile ul > li dl {
            padding: calc(8em / 32 * 2) 0; } }
        .post_interview > .wrapper .interview-wrapper > .interview_body .profile ul > li dl > dt {
          flex: 1;
          font-weight: 600;
          color: var(--key9); }
        .post_interview > .wrapper .interview-wrapper > .interview_body .profile ul > li dl > dd {
          flex: 5; }
          @media screen and (max-width: 768px) {
            .post_interview > .wrapper .interview-wrapper > .interview_body .profile ul > li dl > dd {
              flex: 3; } }
      .post_interview > .wrapper .interview-wrapper > .interview_body .profile + * {
        margin-top: calc(8em / 8 * 4); }
        @media screen and (max-width: 768px) {
          .post_interview > .wrapper .interview-wrapper > .interview_body .profile + * {
            margin-top: calc(8em / 8 * 3); } }
      .post_interview > .wrapper .interview-wrapper > .interview_body .qa hgroup h2 {
        font-size: 1.845em;
        font-weight: 600;
        text-transform: uppercase;
        color: var(--key9);
        letter-spacing: -.0205em; }
      .post_interview > .wrapper .interview-wrapper > .interview_body .qa hgroup + * {
        margin-top: calc(8em / 16 * 3); }
      .post_interview > .wrapper .interview-wrapper > .interview_body .qa ul.list {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 16 * 5);
        counter-reset: num; }
        @media screen and (max-width: 768px) {
          .post_interview > .wrapper .interview-wrapper > .interview_body .qa ul.list {
            gap: calc(8em / 16 * 3); } }
        @media screen and (max-width: 768px) {
          .post_interview > .wrapper .interview-wrapper > .interview_body .qa ul.list > li {
            background: var(--white);
            border-radius: calc(8em / 32);
            overflow: hidden; } }
        .post_interview > .wrapper .interview-wrapper > .interview_body .qa ul.list > li::before {
          counter-increment: num;
          content: "Question0" counter(num);
          display: block;
          margin-bottom: calc(8em / 32);
          font-size: 1.23em;
          font-weight: 600;
          text-transform: uppercase;
          color: var(--key9);
          letter-spacing: -.0205em; }
        .post_interview > .wrapper .interview-wrapper > .interview_body .qa ul.list > li dl > dt {
          font-size: 1.3325em;
          font-weight: var(--fontweight-7); }
          .post_interview > .wrapper .interview-wrapper > .interview_body .qa ul.list > li dl > dt + dd {
            margin-top: calc(8em / 32 * 3); }

.other_post {
  position: relative;
  z-index: 20;
  overflow: hidden; }
  .other_post .wrapper {
    display: block;
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto; }
    .other_post .wrapper.other_post_interview .other-container {
      position: relative;
      z-index: 15;
      --swiper-navigation-size: 2em; }
      .other_post .wrapper.other_post_interview .other-container ul.list > li .card {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32 * 4); }
        .other_post .wrapper.other_post_interview .other-container ul.list > li .card .image {
          display: block;
          aspect-ratio: 5/6;
          border-radius: calc(8em / 32);
          overflow: hidden;
          line-height: 0; }
        .other_post .wrapper.other_post_interview .other-container ul.list > li .card .text p {
          font-weight: 600; }
          .other_post .wrapper.other_post_interview .other-container ul.list > li .card .text p.name {
            font-size: 1.3325em; }
          .other_post .wrapper.other_post_interview .other-container ul.list > li .card .text p.section {
            color: var(--key9); }
      .other_post .wrapper.other_post_interview .other-container ul.list + * {
        margin-top: calc(8em / 16 * 3); }
      .other_post .wrapper.other_post_interview .other-container .swiper-button-wrapper {
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: calc(8em / 32); }
        .other_post .wrapper.other_post_interview .other-container .swiper-button-wrapper .swiper-button-prev, .other_post .wrapper.other_post_interview .other-container .swiper-button-wrapper .swiper-button-next {
          position: relative;
          top: initial;
          left: initial;
          right: initial;
          bottom: initial;
          margin: 0;
          padding: 0;
          padding: calc(8em / 16);
          background: var(--key9);
          border-radius: calc(8em / 16); }
          .other_post .wrapper.other_post_interview .other-container .swiper-button-wrapper .swiper-button-prev *, .other_post .wrapper.other_post_interview .other-container .swiper-button-wrapper .swiper-button-next * {
            color: var(--gray1); }
  .other_post + .idx.recruit {
    margin-top: calc(8em / 8 * 8); }
    @media screen and (max-width: 768px) {
      .other_post + .idx.recruit {
        margin-top: calc(8em / 8 * 4); } }

.page_entry .wrapper {
  padding-top: calc(8em / 8 * 2) !important; }
  @media screen and (max-width: 768px) {
    .page_entry .wrapper {
      width: calc(100% / 16 * 15) !important; } }

.archive_joblist .searchandfilter {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  flex-wrap: wrap; }
  @media screen and (max-width: 768px) {
    .archive_joblist .searchandfilter {
      padding: calc(8em / 16 * 3);
      background: var(--border-light-black);
      border-radius: calc(8em / 16); } }
  .archive_joblist .searchandfilter ul {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16);
    width: 100%; }
    .archive_joblist .searchandfilter ul > li {
      display: flex;
      flex-direction: column;
      padding: 0;
      border-radius: 6px;
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .archive_joblist .searchandfilter ul > li label {
          flex: 1; } }
      .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] {
        margin-top: calc(8em / 8); }
        .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] ul {
          display: flex;
          flex-direction: row;
          flex-wrap: wrap;
          gap: calc(8em / 24);
          font-size: .9em; }
          .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] ul > li {
            display: table;
            border-radius: 4px;
            transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
            -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
            .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="radio"] ul > li:hover {
              opacity: .5;
              transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
              -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
      .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] ul > li:first-child {
        display: none; }
      .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="link"] a {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 2.87em;
        background: var(--gray12);
        border-radius: calc(8em / 32);
        overflow: hidden;
        color: var(--color-white);
        transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
        .archive_joblist .searchandfilter ul > li[data-sf-field-input-type="link"] a:hover {
          filter: brightness(0.8);
          transform: scale(0.985);
          transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  .archive_joblist .searchandfilter h4 {
    min-width: 5.575em;
    padding: 0;
    margin-bottom: calc(8em / 16); }
  .archive_joblist .searchandfilter label {
    flex: 1; }
    @media screen and (max-width: 768px) {
      .archive_joblist .searchandfilter label {
        display: block; } }
  .archive_joblist .searchandfilter select {
    display: block;
    min-width: 184.5px;
    max-width: 100%;
    height: calc(8em / 8 * 3);
    background-color: var(--color-white);
    border: 1px solid var(--border-light-black);
    border-radius: 6px;
    font-size: 16px;
    padding: 0 40px 0 20px;
    background-image: url(../images/common/icon-chevron-bottom.svg);
    background-position: calc(100% - 0.28rem) center;
    background-size: 0.08rem 0.14rem; }
    @media screen and (max-width: 768px) {
      .archive_joblist .searchandfilter select {
        height: 41px; } }
  .archive_joblist .searchandfilter input[type="radio"] {
    display: none; }
    .archive_joblist .searchandfilter input[type="radio"] + label {
      padding: calc(8em / 24) calc(8em / 12);
      background: var(--color-white);
      border: solid 1px var(--border-light-black);
      border-radius: 4px; }
    .archive_joblist .searchandfilter input[type="radio"]:checked + label {
      background: var(--key9);
      color: var(--color-white); }
  .archive_joblist .searchandfilter input[type="submit"] {
    display: block;
    min-width: 100%;
    height: calc(8em / 8 * 3);
    background-color: var(--color-white);
    border: 1px solid var(--border-light-black);
    border-radius: 6px;
    font-size: 16px;
    padding: 0 20px;
    background: var(--gray12);
    background: url(images/noise.png), var(--gray12);
    background-repeat: repeat;
    background-size: 100px;
    color: var(--color-white); }
    @media screen and (max-width: 768px) {
      .archive_joblist .searchandfilter input[type="submit"] {
        width: 100%;
        height: 51.25px; } }
  .archive_joblist .searchandfilter + * {
    margin-top: calc(8em / 16 * 3); }

@media screen and (max-width: 768px) {
  .joblist_archive {
    width: calc(100% / 30 * 28);
    margin: 0 auto; } }
.joblist_archive ul.list {
  padding-bottom: calc(8em / 8 * 3);
  border-bottom: solid 1px var(--border-light-black); }
  .joblist_archive ul.list > li ~ li {
    margin-top: calc(8em / 8 * 3);
    padding-top: calc(8em / 8 * 3);
    border-top: solid 1px var(--border-light-black); }
  .joblist_archive ul.list > li .card > ._head h2 {
    font-size: 1.845em;
    line-height: 1.435;
    font-weight: 600; }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .card > ._head h2 {
        font-size: 1.64em; } }
  .joblist_archive ul.list > li .card > ._head + * {
    margin-top: calc(8em / 8); }
  .joblist_archive ul.list > li .card > ._body {
    display: flex;
    align-items: flex-start;
    gap: calc(8em / 16) calc(8em / 8 * 3); }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .card > ._body {
        gap: calc(8em / 16) calc(8em / 8 * 1); } }
    .joblist_archive ul.list > li .card > ._body > .text {
      flex: 3; }
      .joblist_archive ul.list > li .card > ._body > .text ul {
        border-top: solid 1px var(--border-light-black);
        font-size: .9em; }
        .joblist_archive ul.list > li .card > ._body > .text ul li {
          display: flex;
          align-items: baseline;
          padding: calc(8em / 16 * 1) 0;
          border-bottom: solid 1px var(--border-light-black); }
          .joblist_archive ul.list > li .card > ._body > .text ul li span {
            flex: 1;
            font-weight: 600; }
          .joblist_archive ul.list > li .card > ._body > .text ul li p {
            flex: 3; }
        .joblist_archive ul.list > li .card > ._body > .text ul + * {
          margin-top: calc(8em / 8); }
    .joblist_archive ul.list > li .card > ._body > .thumbnail {
      flex: 1;
      border-radius: calc(8em / 24);
      overflow: hidden; }
      .joblist_archive ul.list > li .card > ._body > .thumbnail img {
        transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  .joblist_archive ul.list > li .card:hover > ._body > .thumbnail img {
    transform: scale(1.05);
    transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
    -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
  .joblist_archive ul.list > li .linker {
    display: flex;
    align-items: center;
    gap: calc(8em / 8 * 1);
    width: 100%;
    margin-top: calc(8em / 16 * 3); }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .linker {
        gap: calc(8em / 16 * 1); } }
    .joblist_archive ul.list > li .linker > li {
      flex: 1; }
      .joblist_archive ul.list > li .linker > li a {
        display: flex;
        align-items: center;
        justify-content: center;
        height: calc(8em / 8* 3);
        background: var(--color-black);
        border: 1px solid rgba(0, 0, 0, 0.1025);
        border-radius: 6px;
        font-size: 16px;
        padding: 0 20px;
        color: var(--color-white);
        transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
        -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
        .joblist_archive ul.list > li .linker > li a:hover {
          transform: scale(0.985);
          filter: brightness(0.9);
          transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -o-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -moz-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s;
          -webkit-transition: all cubic-bezier(0.28, 1.52, 0.73, 1.25) 0.41s; }
      .joblist_archive ul.list > li .linker > li[data-type="entry"] a {
        background: var(--key10); }
.joblist_archive nav.pagination {
  margin-top: calc(8em / 8 * 3); }
  .joblist_archive nav.pagination .screen-reader-text {
    display: none; }
  .joblist_archive nav.pagination .nav-links {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: calc(8em / 12); }
    .joblist_archive nav.pagination .nav-links .page-numbers {
      display: flex;
      align-items: center;
      justify-content: center;
      width: calc(8em / 3);
      height: calc(8em / 3);
      background: var(--gray3);
      border-radius: 8em;
      overflow: hidden; }
      .joblist_archive nav.pagination .nav-links .page-numbers:hover {
        filter: brightness(0.9); }
      .joblist_archive nav.pagination .nav-links .page-numbers.current {
        filter: brightness(1);
        background: var(--gray12);
        background: url(images/noise.png), var(--gray12);
        background-repeat: repeat;
        background-size: 100px;
        color: var(--color-white); }
      .joblist_archive nav.pagination .nav-links .page-numbers.dots {
        background: none; }

.page_privacy .page_head p {
  font-size: 0.9em !important; }
.page_privacy .page_head nav {
  margin: calc(8em / 16 * 3) calc(8em / 8 * 2);
  padding: calc(8em / 8 * 2);
  background: var(--gray2); }
  @media screen and (max-width: 768px) {
    .page_privacy .page_head nav {
      margin: calc(8em / 16 * 3) 0;
      padding: calc(8em / 16 * 2); } }
  .page_privacy .page_head nav > span {
    display: block;
    color: var(--color-gray);
    margin-bottom: calc(8em / 16 * 1); }
  .page_privacy .page_head nav ul > li a {
    display: block;
    padding: calc(8em / 32 * 1) 0;
    transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
    -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    @media screen and (max-width: 768px) {
      .page_privacy .page_head nav ul > li a {
        padding: calc(8em / 64 * 1) 0; } }
    .page_privacy .page_head nav ul > li a:hover {
      opacity: .5;
      transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
      -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
.page_privacy ul.list {
  padding: calc(8em / 16 * 4) 0;
  border-top: solid 1px var(--border-light-black);
  border-bottom: solid 1px var(--border-light-black); }
  .page_privacy ul.list > li ~ li {
    margin-top: calc(8em / 16 * 3); }
  .page_privacy ul.list > li[data-number] {
    display: flex;
    align-items: flex-start;
    justify-content: center; }
    .page_privacy ul.list > li[data-number]::before {
      content: attr(data-number) "";
      display: block;
      width: 3rem;
      font-weight: 600;
      font-size: 1.3325em;
      color: var(--key9);
      line-height: 1.64; }
  .page_privacy ul.list + p {
    margin-top: calc(85px / 8 * 3); }
.page_privacy dl._list {
  margin: 0 calc(8em / 16 * 4); }
  @media screen and (max-width: 768px) {
    .page_privacy dl._list {
      margin: 0; } }
  .page_privacy dl._list > dt {
    font-size: 1.3325em;
    font-weight: 600; }
    .page_privacy dl._list > dt + dd {
      margin-top: 12px; }
  .page_privacy dl._list > dd {
    padding-left: 1em;
    font-size: .9em; }
    .page_privacy dl._list > dd > * + * {
      margin-top: calc(8em / 16); }
.page_privacy ul.disc {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 32); }
  .page_privacy ul.disc > li {
    display: flex;
    align-items: baseline;
    column-gap: calc(8em / 16);
    line-height: 1.5; }
    .page_privacy ul.disc > li::before {
      content: '';
      width: 1em;
      min-width: 1em;
      height: 1em;
      background: var(--color-black);
      border-radius: 50%;
      transform: scale(0.41); }
.page_privacy ul.number {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 32);
  counter-reset: num; }
  .page_privacy ul.number > li {
    display: flex;
    align-items: baseline;
    column-gap: calc(8em / 16);
    line-height: 1.5; }
    .page_privacy ul.number > li::before {
      counter-increment: num;
      content: counter(num);
      width: 1em;
      min-width: 1em;
      height: 1em; }
.page_privacy .contactus > ul {
  display: flex;
  flex-direction: column;
  padding: calc(8em / 16 * 2) 0;
  background: var(--color-lightgray); }
  .page_privacy .contactus > ul > li {
    padding: calc(8em / 16 * 2);
    border-bottom: solid 1px var(--border-light-black); }
    .page_privacy .contactus > ul > li > dl {
      display: flex; }
      @media screen and (max-width: 768px) {
        .page_privacy .contactus > ul > li > dl {
          flex-direction: column;
          row-gap: calc(8em / 32); } }
      .page_privacy .contactus > ul > li > dl > dt {
        flex: 1;
        font-weight: 600; }
      .page_privacy .contactus > ul > li > dl > dd {
        flex: 3; }

.-page.entry header {
  background: var(--key10);
  background: url(images/noise.png), var(--key10);
  background-repeat: repeat;
  background-size: 100px; }
  .-page.entry header * {
    color: var(--color-white); }
  .-page.entry header + .thumbnail {
    margin-bottom: calc(100% / 32 * -3); }
    @media screen and (max-width: 768px) {
      .-page.entry header + .thumbnail {
        margin-bottom: calc(100% / 32 * -4); } }
.-page.entry section {
  background: var(--color-white); }
  .-page.entry section.nul {
    background: initial; }

.formWrap {
  position: relative;
  z-index: 15; }
  .formWrap .caption {
    border-bottom: solid 1px var(--border-light-black);
    padding-bottom: 2.05em;
    margin-bottom: 2.46em; }
    @media screen and (max-width: 768px) {
      .formWrap .caption {
        padding: 0;
        padding-bottom: 1.23em;
        margin-bottom: 2.05em; } }

ul.listDocForm li {
  margin-bottom: 1.23em; }
  @media screen and (max-width: 768px) {
    ul.listDocForm li {
      margin-bottom: 1.64em; } }
  ul.listDocForm li.hidden {
    display: none; }
  ul.listDocForm li:last-child {
    margin-bottom: 0; }
  ul.listDocForm li > a {
    text-decoration: underline;
    color: royalblue; }

dl.listDocForm {
  display: flex;
  flex-wrap: wrap; }
  dl.listDocForm dt {
    width: 100%; }
    dl.listDocForm dt p {
      display: flex;
      align-items: baseline;
      column-gap: calc(8em /32);
      font-weight: 600; }
      dl.listDocForm dt p small[data-type="必須"] {
        color: #e04645; }
      dl.listDocForm dt p small[data-type="任意"] {
        color: #aaa; }
      dl.listDocForm dt p small::before {
        content: attr(data-type) "";
        display: block; }
      dl.listDocForm dt p.must {
        position: relative;
        z-index: 15;
        display: table; }
  dl.listDocForm dd {
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    column-gap: calc(85px / 4);
    width: 100%;
    margin-top: 5px; }
    @media screen and (max-width: 768px) {
      dl.listDocForm dd {
        column-gap: calc(85px / 8);
        margin-top: 3px; } }
    dl.listDocForm dd > br {
      display: none; }
    dl.listDocForm dd span.caption {
      display: block;
      width: 100%;
      margin-top: .41em;
      font-size: .85em; }

.mw_wp_form {
  max-width: 768px;
  margin: 0 auto;
  padding: calc(8em / 8 * 3);
  background: var(--color-white);
  border-radius: calc(8em / 32);
  overflow: hidden; }
  @media screen and (max-width: 768px) {
    .mw_wp_form {
      padding: calc(100% / 44 * 3);
      border-radius: calc(8em / 32); } }
  .mw_wp_form .horizontal-item + .horizontal-item {
    margin: 0 !important; }
  .mw_wp_form span.mwform-checkbox-field {
    position: relative;
    z-index: 15;
    margin-right: 6px; }
    .mw_wp_form span.mwform-checkbox-field input {
      position: absolute;
      top: 0;
      left: 0;
      opacity: 0;
      pointer-events: none; }
      .mw_wp_form span.mwform-checkbox-field input:checked + span.mwform-checkbox-field-text::after {
        transform: scale(1);
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    .mw_wp_form span.mwform-checkbox-field span.mwform-checkbox-field-text {
      display: block;
      border: solid 1px var(--gray4);
      background: #f8f8f8;
      padding: 8px 18px 8px 44px;
      border-radius: 5px; }
      .mw_wp_form span.mwform-checkbox-field span.mwform-checkbox-field-text::before {
        content: '';
        position: absolute;
        left: 12px;
        top: calc(50% - 10px);
        display: block;
        width: 20px;
        height: 20px;
        border-radius: 3px;
        background: var(--color-white);
        border: solid 1px var(--border-light-black); }
      .mw_wp_form span.mwform-checkbox-field span.mwform-checkbox-field-text::after {
        content: '';
        position: absolute;
        left: 16px;
        top: calc(50% - 6px);
        display: block;
        width: 14px;
        height: 14px;
        border-radius: 2px;
        background: var(--key9);
        transform: scale(0);
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
  .mw_wp_form span.mwform-radio-field {
    position: relative;
    z-index: 15; }
    .mw_wp_form span.mwform-radio-field input {
      position: absolute;
      top: 0;
      left: 0;
      opacity: 0;
      pointer-events: none; }
      .mw_wp_form span.mwform-radio-field input:checked + span.mwform-radio-field-text::after {
        transform: scale(1);
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
    .mw_wp_form span.mwform-radio-field span.mwform-radio-field-text {
      display: block;
      border: solid 1px var(--gray4);
      background: var(--color-white);
      padding: 8px 18px 8px 44px;
      border-radius: 5px; }
      .mw_wp_form span.mwform-radio-field span.mwform-radio-field-text::before {
        content: '';
        position: absolute;
        left: 12px;
        top: calc(50% - 10px);
        display: block;
        width: 20px;
        height: 20px;
        border-radius: 20px;
        background: var(--color-white);
        border: solid 1px var(--border-light-black); }
      .mw_wp_form span.mwform-radio-field span.mwform-radio-field-text::after {
        content: '';
        position: absolute;
        left: 16px;
        top: calc(50% - 6px);
        display: block;
        width: 14px;
        height: 14px;
        border-radius: 14px;
        background: var(--key9);
        transform: scale(0);
        transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -o-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -moz-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s;
        -webkit-transition: cubic-bezier(0.55, 0.05, 0.22, 0.99) 0.328s; }
  .mw_wp_form form > p {
    display: none; }
  .mw_wp_form input::placeholder {
    color: #aaa; }
  .mw_wp_form input:focus::-webkit-input-placeholder {
    color: transparent; }
  .mw_wp_form input:focus::-moz-placeholder {
    color: transparent; }
  .mw_wp_form input:focus::-ms-input-placeholder {
    color: transparent; }
  .mw_wp_form input:focus::placeholder {
    color: transparent; }
  .mw_wp_form input[type="text"], .mw_wp_form textarea {
    width: 100%;
    height: auto;
    border: solid 1px var(--border-light-black);
    background: var(--color-white);
    border-radius: 0;
    line-height: 1.5;
    color: var(--gray12);
    font-size: 16px;
    border-radius: 6px;
    -webkit-appearance: none;
    appearance: none; }
  .mw_wp_form select {
    width: 100%;
    height: auto;
    border: solid 1px var(--border-light-black);
    background: var(--color-white);
    border-radius: 0;
    line-height: 1.5;
    color: var(--gray12);
    font-size: 16px;
    border-radius: 6px; }
  .mw_wp_form input[type="text"], .mw_wp_form textarea {
    padding: .82em; }
  .mw_wp_form select {
    position: relative;
    z-index: 15;
    padding: 0 .82em; }
    .mw_wp_form select::after {
      content: '';
      position: absolute;
      right: .82em;
      top: calc(50% - .5em);
      display: block;
      width: 1em;
      height: 1em;
      background: url(images/icn-arrow-p.svg);
      background-size: cover; }
  .mw_wp_form input[type="radio"] + span {
    color: #252525; }
  .mw_wp_form input[type="text"]#namehead, .mw_wp_form input[type="text"]#kanahead {
    flex: 1; }
  .mw_wp_form input[type="text"]#namebody, .mw_wp_form input[type="text"]#kanabody {
    flex: 1; }
  .mw_wp_form input[type="text"]#postcode {
    width: 10em; }
  .mw_wp_form input[type="text"]#address1, .mw_wp_form input[type="text"]#address2 {
    flex: 1;
    margin-right: 1em; }
  .mw_wp_form input[type="text"]#address3 {
    flex: 2; }
  .mw_wp_form input[type="text"]#old {
    width: 10em;
    margin-right: 1em; }
  .mw_wp_form input[type="text"]#date2, .mw_wp_form input[type="text"]#date3 {
    margin-top: 1em; }
  .mw_wp_form input[type="text"]#year, .mw_wp_form input[type="text"]#month, .mw_wp_form input[type="text"]#date {
    width: 8.2em; }
    .mw_wp_form input[type="text"]#year + span, .mw_wp_form input[type="text"]#month + span, .mw_wp_form input[type="text"]#date + span {
      margin: 0 .82em 0 .41em; }
  .mw_wp_form input[type="text"].address {
    margin-top: 7px; }
  .mw_wp_form select {
    height: 3.28em; }
  .mw_wp_form label {
    /*line-height: 4em;*/ }
  .mw_wp_form input[type="text"]:focus, .mw_wp_form textarea:focus, .mw_wp_form select:focus {
    outline: none;
    border: solid 1px #a0a0a0; }
  .mw_wp_form input[type="submit"] {
    width: 100%;
    max-width: 18rem;
    height: 3.28em;
    border: none;
    font-weight: bold;
    text-align: center;
    line-height: 3.28em;
    font-size: 1em;
    background: var(--key9);
    color: var(--color-white);
    position: relative;
    margin: 0 auto;
    border-radius: 6px;
    overflow: hidden;
    display: block;
    transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s; }
    @media screen and (max-width: 768px) {
      .mw_wp_form input[type="submit"] {
        height: 3.28em;
        line-height: 3.28em; } }
    .mw_wp_form input[type="submit"]:hover {
      background: var(--gray12);
      transition: cubic-bezier(0.22, 0.61, 0.36, 1) 0.3s; }
  .mw_wp_form.mw_wp_form_confirm ul.listDocForm li.entryBtnWrap {
    display: flex; }
    .mw_wp_form.mw_wp_form_confirm ul.listDocForm li.entryBtnWrap input[type="submit"].back {
      order: 1;
      background: #252525; }
  .mw_wp_form.mw_wp_form_confirm dl.listDocForm dd {
    background: #f7f7f7;
    padding: .615em .82em;
    border-radius: 4px;
    border: solid 1px #eee;
    color: #777; }
  .mw_wp_form.mw_wp_form_confirm dl.listDocForm dl.listComplete {
    font-weight: 500; }
  .mw_wp_form.mw_wp_form_complete .completeWrap > * ~ * {
    margin-top: .82em; }
  .mw_wp_form.mw_wp_form_complete .completeWrap dl.listComplete dt p {
    font-weight: 500;
    font-size: 1.41em;
    margin-top: .82em; }

/*//!#index----------------------------------------------------------------------------------------------*/
/* ie hack */
@media all and (-ms-high-contrast: none) {
  .headerLogo img {
    width: 100%;
    height: 4.5vw; }

  a.btn > span.circle {
    border: solid 2px rgba(240, 95, 64, 0.2); }

  ul.listFooterNav > li span.circle {
    border: solid 2px rgba(240, 95, 64, 0.2); }

  .careerstepWrap .flexWrap > .flexCenter .inner {
    border: solid 2px rgba(240, 95, 64, 0.8); }

  .secIndex.sec1 .kv_leadcopy .kv_leadcopy_inner {
    width: 100%; }

  .secIndex.sec3 .indexService .swiper-button-prev {
    left: auto;
    bottom: auto; }

  dl.listFootnav dt a {
    display: inline-block; }

  .secPage.root .flexWrap > .flexItem {
    width: calc((100% / 3) - 0.01px); }

  ul.listPhilosophy {
    justify-content: space-around; }

  .member_wrapper .f_wrapper .__left {
    position: relative; }

  header.pageHeader {
    height: 31.5em; }

  ul.listLGBtn a.btn {
    width: 100%; }

  ul.listLogos li img {
    width: 8em; }

  ul.listLogos {
    justify-content: space-between; } }
.post_interview > .wrapper .interview-wrapper > .interview_body .qa ul.list .image {
  margin-top: calc(8em / 32 * 3); }
