@charset "UTF-8";
/*!
Theme Name: 金一重量｜採用サイト
Theme URI: https://kinichi-recruit.com/
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: #fffcfc;
  --key2: #fef8f7;
  --key3: #fdecea;
  --key4: #ffdeda;
  --key5: #fed0cc;
  --key6: #f7c1bc;
  --key7: #eeada8;
  --key8: #e3948f;
  --key9: #c03a3c;
  --key10: #b0292f;
  --key11: #c33d3f;
  --key12: #5f1f1e;
  --sub9: #76838e;
  --blue1: #fcfdff;
  --blue2: #f6f9fe;
  --blue3: #ecf2fe;
  --blue4: #dfeafe;
  --blue5: #cfe0fb;
  --blue6: #bdd3f7;
  --blue7: #a6c1ed;
  --blue8: #86a9e2;
  --blue9: #3d6ab6;
  --blue10: #305ca7;
  --blue11: #3966b1;
  --blue12: #203557;
  --gray1: #fcfcfc;
  --gray2: #f9f9f9;
  --gray3: #efefef;
  --gray4: #e8e8e8;
  --gray5: #e0e0e0;
  --gray6: #d9d9d9;
  --gray7: #cecece;
  --gray8: #bbb;
  --gray9: #8d8d8d;
  --gray10: #838383;
  --gray11: #646464;
  --gray12: #202020;
  --color-white: #fff;
  --color-gray: #757575;
  --color-lightgray: #ecedf0;
  --black: #171617;
  --border-light-black: rgba(31,69,94,.205);
  --border-light-white: rgba(255,255,255,.1025);
  --background: background-color:hsla(359,100%,50%,1);
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 1818 1818' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noiseFilter'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.65' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noiseFilter)'/%3E%3C/svg%3E"), radial-gradient(circle at 0% 99%, #ff2f00 0%, transparent 67%), radial-gradient(circle at 46% 94%, #5a0c12 0%, transparent 81%), radial-gradient(circle at 89% 8%, #a2111d 0%, transparent 150%), radial-gradient(circle at 89% 8%, #230608 0%, transparent 150%), radial-gradient(circle at 93% 95%, #790610 0%, transparent 66%), radial-gradient(circle at 89% 8%, snow 0%, transparent 150%), radial-gradient(circle at 89% 8%, #f8e61b 0%, transparent 150%);
  background-blend-mode: overlay,normal,normal,normal,normal,normal,normal,normal;
  --shadow: 0 1px 2px rgba(0, 0, 0, 0.04), 0 2px 6px rgba(0, 0, 0, 0.08); }

/*!レスポンシブ*/
/*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(--gray12);
  color: var(--gray1);
  /*
  -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(--gray1);
  -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;
  font-weight: 400;
  font-family: "Shippori Antique B1", sans-serif; }

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; }

.done.blur {
  opacity: 0;
  filter: blur(10px); }
  .done.blur.gone {
    opacity: 1;
    filter: blur(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;
    transition-delay: .328s;
    transition-duration: .82s; }

/*ベンダープレフィックス登録*/
/*!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-radius: calc(8em / 16);
  box-shadow: var(--shadow);
  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 .icon svg {
      transform: rotate(-90deg);
      fill: var(--gray1); }
  .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);
    border: solid 1px var(--gray2); }
    .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.key {
    background: var(--key9);
    border: solid 1px var(--key10); }
    .button.key * {
      color: var(--gray1); }
    .button.key .icon img {
      filter: brightness(0) invert(1); }
  .button.blue {
    justify-content: center;
    background: var(--blue9);
    border: solid 1px var(--blue10); }
    .button.blue * {
      color: var(--gray1); }
    .button.blue .text {
      padding: 0; }

.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 .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-left: auto;
    margin-right: 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 {
      flex: 1; }
      #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); } }
        #siteHead .wrapper > .left h1 img {
          filter: brightness(0) invert(1); }
    #siteHead .wrapper > .center {
      flex: 1;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: .75em;
      letter-spacing: .0205em; }
      @media screen and (max-width: 768px) {
        #siteHead .wrapper > .center {
          display: none; } }
      #siteHead .wrapper > .center * {
        color: var(--gray1); }
    #siteHead .wrapper > .right {
      flex: 1;
      display: flex;
      align-items: center;
      justify-content: flex-end; }
    #siteHead .wrapper nav {
      position: relative;
      z-index: 15;
      display: flex;
      align-items: center;
      gap: calc(8em / 8); }
      #siteHead .wrapper nav ul.switch-target {
        display: flex;
        align-items: center;
        flex-direction: row;
        border-radius: 8em; }
        @media screen and (max-width: 768px) {
          #siteHead .wrapper nav ul.switch-target {
            display: none; } }
        #siteHead .wrapper nav ul.switch-target > li .btn {
          display: flex;
          align-items: center;
          justify-content: center;
          min-width: 8.2em;
          height: 2.46em;
          border-radius: 8em;
          font-weight: 600; }
          #siteHead .wrapper nav ul.switch-target > li .btn.current {
            background: var(--key9);
            border: solid 1px var(--key10);
            box-shadow: var(--shadow); }
            #siteHead .wrapper nav ul.switch-target > li .btn.current * {
              color: var(--gray1); }
          #siteHead .wrapper nav ul.switch-target > li .btn * {
            color: var(--key9); }
  #siteHead ._menu {
    position: relative;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: center; }
    #siteHead ._menu p.humbNav {
      display: flex;
      align-items: center;
      justify-content: center;
      column-gap: calc(8em / 16);
      min-width: 8.2em;
      height: 2.46em;
      margin: 0 auto;
      padding: calc(8em / 32);
      background: var(--gray12);
      box-shadow: var(--shadow);
      border-radius: 8em;
      text-transform: uppercase; }
      @media screen and (max-width: 768px) {
        #siteHead ._menu p.humbNav {
          height: 2.05em;
          column-gap: calc(8em / 16); } }
      #siteHead ._menu p.humbNav > span {
        position: relative; }
        #siteHead ._menu p.humbNav > span.icon {
          display: flex;
          justify-content: center;
          align-items: center;
          gap: calc(8em / 32); }
          #siteHead ._menu p.humbNav > span.icon > i {
            display: block;
            width: calc(8em / 64);
            height: calc(8em / 64);
            background: var(--gray1);
            border-radius: 8em;
            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 > span.text > i {
          font-weight: 600;
          color: var(--gray1); }
      #siteHead ._menu p.humbNav.active > span {
        align-content: center; }
        #siteHead ._menu p.humbNav.active > span.icon > i {
          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.icon > i:first-child {
            opacity: 0;
            transform: translateX(-5px); }
          #siteHead ._menu p.humbNav.active > span.icon > i:last-child {
            opacity: 0;
            transform: translateX(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; }
  #siteHead.lower .wrapper > .center * {
    color: var(--gray11); }

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 .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 #siteHead .wrapper .center {
      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; }
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; }
  body.scroll.scrollUp #siteHead .wrapper .center {
    opacity: 1;
    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; }

/*!#aside*/
aside#float {
  position: fixed;
  right: 32px;
  bottom: 32px;
  z-index: 30;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: calc(8em / 16 * 4);
  background: var(--gray12);
  border-radius: calc(8em / 32 * 3);
  box-shadow: var(--shadow);
  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; }
  @media screen and (max-width: 768px) {
    aside#float {
      right: 8px;
      bottom: 8px; } }
  aside#float .float-callus {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 64 * 3); }
    aside#float .float-callus .title {
      display: flex;
      align-items: center;
      justify-content: center;
      min-height: 2em;
      margin-bottom: calc(8em / 16);
      background: var(--key9);
      border-radius: calc(8em);
      color: var(--key1);
      font-weight: 600;
      font-size: .9em; }
    aside#float .float-callus .tel {
      display: flex;
      align-items: center;
      margin: calc((8em / 32) * -1) 0;
      font-weight: 600;
      color: var(--gray1);
      font-size: 2.05em;
      letter-spacing: -.0201em;
      line-height: 1; }
      aside#float .float-callus .tel * {
        color: var(--gray1); }
    aside#float .float-callus .opening {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: calc(8em / 16);
      letter-spacing: -.0201em; }
      aside#float .float-callus .opening .attr {
        font-size: .9em;
        font-weight: 600;
        color: var(--gray4); }
      aside#float .float-callus .opening .time {
        font-weight: 900;
        color: var(--gray1); }
    aside#float .float-callus + * {
      margin-top: calc(8em / 32 * 4);
      padding-top: calc(8em / 32 * 4);
      border-top: dotted 1px var(--key7); }
  aside#float .float-request {
    width: 100%;
    font-weight: 600; }
  aside#float .float-close {
    position: absolute;
    top: calc((2.05em / 4) * -1);
    right: calc((2.05em / 4) * -1);
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.05em;
    height: 2.05em;
    border-radius: 2.05em;
    padding: calc(8em / 16);
    background: var(--gray1);
    box-shadow: var(--shadow);
    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; }
    aside#float .float-close svg {
      transform: rotate(45deg);
      fill: var(--gray12); }
    aside#float .float-close:hover {
      transform: scale(0.95);
      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; }
aside#menu {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100vw;
  height: 100vh;
  background: var(--gray12);
  background: url(images/noise.png), var(--gray12);
  background-size: 100px, cover;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  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; }
  @media screen and (max-width: 768px) {
    aside#menu {
      height: auto; } }
  aside#menu.open {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    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; }
    aside#menu.open .wrapper > .left figure {
      transform: scale(1);
      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; }
  aside#menu .wrapper {
    display: flex; }
    @media screen and (max-width: 768px) {
      aside#menu .wrapper {
        flex-direction: column-reverse; } }
    aside#menu .wrapper > div {
      flex: 1;
      height: 100vh; }
      @media screen and (max-width: 768px) {
        aside#menu .wrapper > div {
          height: auto;
          min-height: 100vh; } }
    aside#menu .wrapper > .left {
      position: relative;
      z-index: 15;
      background-color: #ff0004;
      background-image: url(images/noise.png), radial-gradient(circle at 0% 99%, #ff2f00 0%, transparent 67%), radial-gradient(circle at 46% 94%, #5a0c12 0%, transparent 81%), radial-gradient(circle at 89% 8%, #a2111d 0%, transparent 150%), radial-gradient(circle at 89% 8%, #230608 0%, transparent 150%), radial-gradient(circle at 93% 95%, #790610 0%, transparent 66%), radial-gradient(circle at 89% 8%, snow 0%, transparent 150%), radial-gradient(circle at 89% 8%, #f8e61b 0%, transparent 150%);
      background-size: 100px, cover, cover, cover, cover, cover, cover, cover, cover, cover;
      background-blend-mode: overlay, normal, normal, normal, normal, normal, normal, normal;
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        aside#menu .wrapper > .left {
          display: none; } }
      aside#menu .wrapper > .left figure {
        transform: scale(1.05);
        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;
        line-height: 0; }
        aside#menu .wrapper > .left figure.front {
          position: absolute;
          right: 15%;
          bottom: -60px;
          z-index: 5;
          width: 100%; }
          @media screen and (max-width: 768px) {
            aside#menu .wrapper > .left figure.front {
              bottom: -41px; } }
        aside#menu .wrapper > .left figure.back {
          position: absolute;
          left: 0;
          bottom: -30px;
          z-index: -5;
          width: 125%;
          opacity: .7175;
          filter: blur(8px); }
          @media screen and (max-width: 768px) {
            aside#menu .wrapper > .left figure.back {
              bottom: -20px; } }
        aside#menu .wrapper > .left figure.main {
          position: absolute;
          bottom: 0;
          width: 100%; }
        aside#menu .wrapper > .left figure.part {
          position: absolute; }
          aside#menu .wrapper > .left figure.part.part1 {
            top: 0;
            right: 0;
            top: -25%;
            right: 20%;
            z-index: -1;
            width: 85%;
            mix-blend-mode: color-burn; }
            @media screen and (max-width: 768px) {
              aside#menu .wrapper > .left figure.part.part1 {
                right: -21%;
                width: 72%; } }
          aside#menu .wrapper > .left figure.part.part2 {
            bottom: -6%;
            left: -0;
            z-index: -1;
            width: 180%;
            mix-blend-mode: color-burn; }
            @media screen and (max-width: 768px) {
              aside#menu .wrapper > .left figure.part.part2 {
                left: -24%;
                width: 110%; } }
      aside#menu .wrapper > .left .keyvisual-head {
        display: flex;
        align-items: center;
        justify-content: center;
        height: 50%;
        padding: 0 calc((100% / 16) / 2); }
    aside#menu .wrapper > .right {
      overflow: scroll; }
      aside#menu .wrapper > .right .global_navigation {
        padding: calc(8em / 8 * 7) calc(8em / 8 * 4); }
        @media screen and (max-width: 768px) {
          aside#menu .wrapper > .right .global_navigation {
            padding: calc(8em / 8 * 5) 24px; } }
        aside#menu .wrapper > .right .global_navigation ul.col {
          display: flex;
          flex-direction: column;
          border-top: dotted 1px var(--gray11); }
          aside#menu .wrapper > .right .global_navigation ul.col > li {
            padding: calc(8em / 16 * 3) 0;
            border-bottom: dotted 1px var(--gray11); }
            aside#menu .wrapper > .right .global_navigation ul.col > li dl > dt {
              font-size: 2.255em;
              font-weight: 600; }
              @media screen and (max-width: 768px) {
                aside#menu .wrapper > .right .global_navigation ul.col > li dl > dt {
                  font-size: 1.435em; } }
              aside#menu .wrapper > .right .global_navigation ul.col > li dl > dt + dd {
                margin-top: calc(8em / 16 * 2); }
            aside#menu .wrapper > .right .global_navigation ul.col > li dl > dd {
              font-weight: 500; }
              aside#menu .wrapper > .right .global_navigation ul.col > li dl > dd a {
                opacity: .5; }
                aside#menu .wrapper > .right .global_navigation ul.col > li dl > dd a:hover {
                  opacity: 1; }
              aside#menu .wrapper > .right .global_navigation ul.col > li dl > dd + dd {
                margin-top: calc(8em / 32 * 1); }
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; } }

body.scroll aside#float {
  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; }
  @media screen and (max-width: 768px) {
    body.scroll aside#float {
      transform: scale(0.8);
      transform-origin: right; } }
body.scroll aside#top {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(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; }

/*!//#siteHeader------------------------------------------------------------------------------------------------*/
/*!#siteFooter------------------------------------------------------------------------------------------------*/
#siteFoot {
  position: relative;
  z-index: 15;
  width: 100%;
  padding: 0 32px;
  padding-top: calc(8em / 8 * 6);
  overflow: hidden;
  background-color: var(--gray12);
  background-image: url(images/noise.png), var(--gray12);
  background-size: 100px,cover; }
  @media screen and (max-width: 768px) {
    #siteFoot {
      padding: 0 24px;
      padding-top: calc(8em / 8 * 3); } }
  #siteFoot .wrapper {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 8 * 16);
    margin-left: auto;
    margin-right: auto;
    padding: 0 calc(8em / 16 * 5); }
    @media screen and (max-width: 768px) {
      #siteFoot .wrapper {
        gap: 0;
        padding: 0; } }
    #siteFoot .wrapper * {
      color: var(--gray1); }
  #siteFoot .copyright, #siteFoot .policy {
    font-size: .85em; }
  #siteFoot ._primary {
    display: flex;
    align-items: flex-start;
    gap: calc(8em / 8 * 4); }
    @media screen and (max-width: 768px) {
      #siteFoot ._primary {
        flex-direction: column-reverse;
        gap: calc(8em / 8 * 3); } }
    #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;
          padding: calc(8em / 8 * 1) 0; } }
      #siteFoot ._primary .corplate .logo {
        display: flex;
        align-items: center;
        gap: calc(8em / 32 * 3); }
        #siteFoot ._primary .corplate .logo img {
          filter: brightness(0) invert(1); }
        #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 ul {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 8); }
      #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: .85em;
          font-weight: 600;
          color: var(--gray9); }
        #siteFoot ._primary .corplate dl dd a {
          display: table;
          border-bottom: dotted 1px var(--gray9); }
    #siteFoot ._primary .navigation {
      flex: 2;
      display: flex; }
      @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;
        gap: calc(8em / 16 * 2); }
        @media screen and (max-width: 768px) {
          #siteFoot ._secondary .bottom ul {
            justify-content: center;
            flex-direction: column;
            gap: calc(8em / 32 * 3); } }
        #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 ._secondary .bottom ul > li a * {
          color: var(--gray9); }
  #siteFoot nav.footer_navigation ul.col {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 32 * 3); }
    @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 / 8 * 3); }
    @media screen and (max-width: 768px) {
      #siteFoot nav.footer_navigation ul.row {
        flex-direction: column;
        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 {
    display: flex;
    align-items: center;
    gap: calc(8em / 16);
    font-weight: 600;
    font-size: 1.1275em; }
    @media screen and (max-width: 768px) {
      #siteFoot nav.footer_navigation dl > dt::before {
        content: '';
        display: block;
        width: .5em;
        height: .5em;
        background: var(--key9);
        clip-path: polygon(0 0, 80% 50%, 0 100%); } }
    #siteFoot nav.footer_navigation dl > dt + dd {
      margin-top: calc(8em / 32 * 4); }
  #siteFoot nav.footer_navigation dl > dd {
    display: table;
    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 * 3); }

/*//!#siteFooter----------------------------------------------------------------------------------------------*/
/*!#index----------------------------------------------------------------------------------------------*/
/*!#siteContent*/
#siteContent {
  position: relative;
  z-index: 15;
  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;
  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); }

.idx {
  position: relative;
  z-index: 15; }
  .idx hgroup:has(h2) {
    display: flex;
    align-items: center;
    flex-direction: row;
    gap: calc(8em / 32 * 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) h2 {
      font-size: 2.05em; }
      @media screen and (max-width: 768px) {
        .idx hgroup:has(h2) h2 {
          font-size: 1.7425em; } }
    .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; }
      @media screen and (max-width: 768px) {
        .idx hgroup:has(h3) h3 {
          font-size: 1.23em; } }
  .idx .content-section-subtitle {
    display: flex;
    align-items: center;
    gap: calc(8em / 16);
    font-weight: 600; }
    .idx .content-section-subtitle::before {
      content: '';
      display: block;
      width: calc(8em / 16);
      min-width: calc(8em / 16);
      height: calc(8em / 16);
      background: var(--key9);
      border-radius: 8em; }
  .idx.keyvisual {
    position: relative;
    z-index: 15;
    width: 100%;
    height: auto;
    padding-top: calc(8em / 8 * 5);
    background: var(--gray1);
    background-color: #ff0004;
    background-image: url(images/noise.png), radial-gradient(circle at 0% 99%, #ff2f00 0%, transparent 67%), radial-gradient(circle at 46% 94%, #5a0c12 0%, transparent 81%), radial-gradient(circle at 89% 8%, #a2111d 0%, transparent 150%), radial-gradient(circle at 89% 8%, #230608 0%, transparent 150%), radial-gradient(circle at 93% 95%, #790610 0%, transparent 66%), radial-gradient(circle at 89% 8%, snow 0%, transparent 150%), radial-gradient(circle at 89% 8%, #f8e61b 0%, transparent 150%);
    background-size: 100px,cover,cover,cover,cover,cover,cover,cover,cover,cover;
    background-blend-mode: overlay,normal,normal,normal,normal,normal,normal,normal;
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      .idx.keyvisual {
        padding-top: calc(8em / 8 * 3); } }
    .idx.keyvisual::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      display: block;
      width: 100%;
      height: calc(8em / 8 * 10);
      background: linear-gradient(to bottom, #01224047, transparent); }
    .idx.keyvisual > figure.part {
      position: absolute; }
      .idx.keyvisual > figure.part.part1 {
        top: 0;
        right: 0;
        top: -25%;
        right: -12%;
        z-index: -1;
        width: 62%;
        mix-blend-mode: color-burn; }
        @media screen and (max-width: 768px) {
          .idx.keyvisual > figure.part.part1 {
            right: -21%;
            width: 72%; } }
      .idx.keyvisual > figure.part.part2 {
        bottom: -6%;
        left: -12%;
        z-index: -1;
        width: 95%;
        mix-blend-mode: color-burn; }
        @media screen and (max-width: 768px) {
          .idx.keyvisual > figure.part.part2 {
            left: -24%;
            width: 110%; } }
    .idx.keyvisual .keyvisual-head {
      padding: 0 calc((100% / 16) / 2); }
      .idx.keyvisual .keyvisual-head + * {
        margin-top: calc(8em / 8 * 6 * -1); }
        @media screen and (max-width: 768px) {
          .idx.keyvisual .keyvisual-head + * {
            margin-top: calc(8em / 8 * 3 * -1); } }
    .idx.keyvisual .keyvisual-body {
      position: relative;
      z-index: 15; }
      .idx.keyvisual .keyvisual-body figure {
        line-height: 0; }
        .idx.keyvisual .keyvisual-body figure.main {
          display: block;
          width: 65%;
          margin-left: auto;
          margin-right: auto; }
          @media screen and (max-width: 768px) {
            .idx.keyvisual .keyvisual-body figure.main {
              width: 90%; } }
        .idx.keyvisual .keyvisual-body figure.front {
          position: absolute;
          right: 15%;
          bottom: -120px;
          z-index: 5;
          width: 100%; }
          @media screen and (max-width: 768px) {
            .idx.keyvisual .keyvisual-body figure.front {
              bottom: -41px; } }
        .idx.keyvisual .keyvisual-body figure.back {
          position: absolute;
          left: 0;
          bottom: -60px;
          z-index: -5;
          width: 125%;
          opacity: .7175;
          filter: blur(8px); }
          @media screen and (max-width: 768px) {
            .idx.keyvisual .keyvisual-body figure.back {
              bottom: -20px; } }
    .idx.keyvisual .wrapper {
      position: relative;
      z-index: 15;
      width: 100%;
      margin-left: auto;
      margin-right: auto;
      padding: 0 32px; }
      @media screen and (max-width: 768px) {
        .idx.keyvisual .wrapper {
          padding: 0 24px; } }
    .idx.keyvisual .copy-wrapper {
      display: flex;
      align-items: flex-start;
      width: calc(100% / 18 * 17);
      margin-left: auto;
      margin-right: auto;
      padding: calc(8em / 8 * 3) 0; }
      @media screen and (max-width: 768px) {
        .idx.keyvisual .copy-wrapper {
          width: 100%;
          flex-direction: column-reverse;
          gap: calc(8em / 8); } }
      .idx.keyvisual .copy-wrapper p {
        flex: 1; }
        .idx.keyvisual .copy-wrapper p.copy {
          font-weight: 600;
          font-size: 5.125em;
          line-height: 1.1275; }
          @media screen and (max-width: 768px) {
            .idx.keyvisual .copy-wrapper p.copy {
              font-size: 2.875em; } }
          .idx.keyvisual .copy-wrapper p.copy span {
            display: block;
            color: var(--key9); }
            .idx.keyvisual .copy-wrapper p.copy span:last-child {
              color: var(--gray1); }
        .idx.keyvisual .copy-wrapper p.tagline {
          display: flex;
          align-items: center;
          height: calc(5.125rem * 1.1275); }
          @media screen and (max-width: 768px) {
            .idx.keyvisual .copy-wrapper p.tagline {
              height: initial; } }
          .idx.keyvisual .copy-wrapper p.tagline span {
            font-weight: 600;
            font-size: 1.23em;
            color: var(--key1); }
            .idx.keyvisual .copy-wrapper p.tagline span strong {
              display: inline-flex;
              color: var(--key9);
              border-bottom: dotted 2px var(--key9); }
  .idx.statement {
    padding: 0 32px;
    background: var(--gray12);
    background-size: cover;
    background-repeat: repeat;
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      .idx.statement {
        padding: 0 24px; } }
    .idx.statement .wrapper {
      padding: calc(8em / 8 * 5) calc(100% / 16 * 1) calc(8em / 8 * 6); }
      @media screen and (max-width: 768px) {
        .idx.statement .wrapper {
          padding: calc(8em / 8 * 4) 0 calc(8em / 8 * 5); } }
      .idx.statement .wrapper p {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 16 * 3);
        text-align: center;
        font-size: 1.64em;
        font-family: "Shippori Antique B1", sans-serif;
        line-height: 1.8; }
        @media screen and (max-width: 768px) {
          .idx.statement .wrapper p {
            font-size: 1.1275em; } }
        .idx.statement .wrapper p * {
          color: var(--gray1); }
        .idx.statement .wrapper p span {
          display: block; }
          .idx.statement .wrapper p span:not(.idx.statement .wrapper p span:has(img)) {
            transform: scaleX(1.2); }
          .idx.statement .wrapper p span:has(img) {
            line-height: 0; }
  .idx.number .wrapper {
    padding: 0 32px; }
    @media screen and (max-width: 768px) {
      .idx.number .wrapper {
        padding: 0 12px; } }
    .idx.number .wrapper .inner {
      position: relative;
      z-index: 15;
      padding: calc(8em / 8 * 4);
      border-radius: calc(8em / 8);
      box-shadow: var(--shadow);
      background: var(--gray12);
      overflow: hidden; }
      @media screen and (max-width: 768px) {
        .idx.number .wrapper .inner {
          padding: calc(8em / 8 * 2) calc(8em / 16 * 3); } }
      .idx.number .wrapper .inner .background {
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100%;
        opacity: .5; }
      .idx.number .wrapper .inner .content-section-head {
        width: 100%; }
      .idx.number .wrapper .inner .content-section-body {
        padding-left: calc(8em / 8 * 10); }
        @media screen and (max-width: 768px) {
          .idx.number .wrapper .inner .content-section-body {
            padding-left: 0; } }
  .idx.number ul.grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: calc(8em / 8); }
    @media screen and (max-width: 768px) {
      .idx.number ul.grid {
        grid-template-columns: repeat(2, 1fr);
        gap: calc(8em / 16); } }
    .idx.number ul.grid > li {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 16 * 1);
      grid-template-columns: 1fr;
      aspect-ratio: 4/3;
      padding: calc(8em / 32 * 5);
      border-radius: calc(8em / 16);
      box-shadow: var(--shadow);
      background: var(--gray1); }
      @media screen and (max-width: 768px) {
        .idx.number ul.grid > li {
          align-items: center;
          padding: calc(8em / 32 * 3) 0;
          aspect-ratio: auto; } }
      .idx.number ul.grid > li .number-title {
        color: var(--key9);
        font-weight: 700;
        font-size: 1.1275em; }
        @media screen and (max-width: 768px) {
          .idx.number ul.grid > li .number-title {
            font-size: 1em;
            text-align: center; } }
      .idx.number ul.grid > li .number-item {
        display: flex;
        align-items: baseline; }
        @media screen and (max-width: 768px) {
          .idx.number ul.grid > li .number-item {
            justify-content: center; } }
        .idx.number ul.grid > li .number-item * {
          color: var(--gray12); }
        .idx.number ul.grid > li .number-item .num {
          font-size: 5.125em;
          line-height: 1;
          font-weight: 800;
          letter-spacing: -.041em; }
          @media screen and (max-width: 768px) {
            .idx.number ul.grid > li .number-item .num {
              font-size: 2.87em; } }
        .idx.number ul.grid > li .number-item .meta {
          font-size: 1.3325em;
          font-weight: 600; }
      .idx.number ul.grid > li .caption {
        flex: 1;
        display: flex;
        align-items: flex-end;
        color: var(--gray9); }
        @media screen and (max-width: 768px) {
          .idx.number ul.grid > li .caption {
            font-size: .8em;
            text-align: center; } }
  .idx.service .wrapper {
    padding: 0 32px; }
    @media screen and (max-width: 768px) {
      .idx.service .wrapper {
        padding: 0 24px; } }
    .idx.service .wrapper .middle {
      aspect-ratio: 2.35/1; }
      @media screen and (max-width: 768px) {
        .idx.service .wrapper .middle {
          aspect-ratio: initial; } }
      .idx.service .wrapper .middle ul {
        display: flex;
        gap: calc(8em / 8);
        height: 100%;
        counter-reset: num; }
        @media screen and (max-width: 768px) {
          .idx.service .wrapper .middle ul {
            flex-wrap: wrap;
            gap: calc(8em / 16); } }
        .idx.service .wrapper .middle ul > li {
          position: relative;
          z-index: 15;
          width: calc((100% / 4) - ((8em / 8) * 3 / 4));
          border-radius: calc(8em / 8);
          overflow: hidden;
          box-shadow: var(--shadow);
          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 / 16) * 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 img {
              filter: brightness(0.82); }
            .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::before {
              counter-increment: num;
              content: "0" counter(num);
              position: absolute;
              top: 0;
              left: 0;
              display: block;
              padding: calc(8rem / 8);
              color: var(--gray1);
              font-size: 3.28em;
              line-height: 1;
              font-weight: 600;
              pointer-events: none; }
              @media screen and (max-width: 768px) {
                .idx.service .wrapper .middle ul > li .card::before {
                  padding: calc(8rem / 16);
                  font-size: 2.87em; } }
            .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.recruit {
    position: relative;
    z-index: 15;
    padding: 0 32px; }
    @media screen and (max-width: 768px) {
      .idx.recruit {
        padding: 0 12px; } }
    .idx.recruit .wrapper {
      position: relative;
      z-index: 15;
      padding: calc(8em / 16 * 5) calc(8em / 16 * 5) calc(8em / 8 * 5);
      background: var(--gray12);
      border-radius: calc(8em / 32 * 4);
      overflow: hidden; }
      .idx.recruit .wrapper .content-section-head {
        width: 100%; }
    .idx.recruit .recruit-body {
      display: flex;
      align-items: flex-end;
      justify-content: space-between;
      gap: calc(8em / 8 * 4); }
      .idx.recruit .recruit-body > .left {
        order: 1;
        flex: 1;
        display: flex;
        align-items: flex-start;
        flex-direction: column; }
        .idx.recruit .recruit-body > .left * {
          color: var(--gray1); }
        .idx.recruit .recruit-body > .left p {
          display: flex;
          flex-direction: column;
          gap: calc(8em / 32 * 3);
          font-weight: 600;
          font-size: 1.075em;
          line-height: 1.8; }
          .idx.recruit .recruit-body > .left p span {
            display: block; }
          .idx.recruit .recruit-body > .left p + * {
            margin-top: calc(8em / 16 * 5); }
      .idx.recruit .recruit-body > .right {
        flex: 1; }
        @media screen and (max-width: 768px) {
          .idx.recruit .recruit-body > .right {
            display: none; } }
        .idx.recruit .recruit-body > .right figure {
          max-width: 256px;
          margin-right: auto;
          border-radius: calc(8em / 16);
          box-shadow: var(--shadow);
          overflow: hidden;
          line-height: 0; }
    .idx.recruit .recruit-foot {
      display: flex;
      align-items: center;
      flex-direction: column;
      gap: calc(8em / 8);
      font-weight: 600; }
      .idx.recruit .recruit-foot a {
        padding: 0 calc(8em / 16 * 4); }

/* Loading overlay */
#loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: #1A150E;
  background: url(images/noise.png), #1A150E;
  background-size: 100px,cover;
  background-repeat: repeat;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.8s; }

#loading-overlay.hidden {
  opacity: 0;
  pointer-events: none; }

#loading-text {
  font-family: 'Playfair Display', serif;
  font-size: 1rem;
  color: #B8956A;
  letter-spacing: 0.3em;
  text-transform: uppercase; }

#loading-image {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 25%;
  height: auto;
  filter: brightness(0) invert(1); }
  @media screen and (max-width: 768px) {
    #loading-image {
      width: 45%; } }

/* Dissolve Canvas */
#dissolve-canvas {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 0; }

#scroll-stage {
  position: relative;
  z-index: 1; }
  #scroll-stage::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    background: url(images/noise.png), rgba(0, 0, 0, 0.7);
    background-size: 100px, cover;
    background-repeat: repeat; }
  #scroll-stage .scene-panel {
    position: relative;
    height: 100vh;
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: center;
    padding: 3rem 6%;
    color: var(--gray1);
    pointer-events: none; }
    #scroll-stage .scene-panel * {
      color: var(--gray1); }
    #scroll-stage .scene-panel > * {
      pointer-events: auto; }
    #scroll-stage .scene-panel .scene-title {
      font-size: 4.1em;
      line-height: 1.23; }
      @media screen and (max-width: 768px) {
        #scroll-stage .scene-panel .scene-title {
          font-size: 2.255em; } }
      #scroll-stage .scene-panel .scene-title + * {
        margin-top: calc(8em / 32 * 3); }
    #scroll-stage .scene-panel p {
      max-width: 24.6em;
      font-size: 1.23em;
      font-weight: 600;
      line-height: 2; }
      @media screen and (max-width: 768px) {
        #scroll-stage .scene-panel p {
          font-size: 1.075em;
          line-height: 1.8;
          font-weight: 500; } }
      #scroll-stage .scene-panel p.scene-subtitle {
        display: flex;
        align-items: center;
        gap: calc(8em / 16);
        font-weight: 600; }
        #scroll-stage .scene-panel p.scene-subtitle::before {
          content: '';
          display: block;
          width: calc(8em / 16);
          min-width: calc(8em / 16);
          height: calc(8em / 16);
          background: var(--key9);
          border-radius: 8em; }
    #scroll-stage .scene-panel .button {
      margin-top: calc(8em / 16 * 5); }

.content-zone {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 8 * 6);
  padding: calc(8em / 8 * 8) 0;
  background: var(--gray1);
  background-color: #ff0004;
  background-image: url(images/noise.png), radial-gradient(circle at 0% 99%, #ff2f00 0%, transparent 67%), radial-gradient(circle at 46% 94%, #5a0c12 0%, transparent 81%), radial-gradient(circle at 89% 8%, #a2111d 0%, transparent 150%), radial-gradient(circle at 89% 8%, #230608 0%, transparent 150%), radial-gradient(circle at 93% 95%, #790610 0%, transparent 66%), radial-gradient(circle at 89% 8%, snow 0%, transparent 150%), radial-gradient(circle at 89% 8%, #f8e61b 0%, transparent 150%);
  background-size: 100px,cover,cover,cover,cover,cover,cover,cover,cover,cover;
  background-blend-mode: overlay,normal,normal,normal,normal,normal,normal,normal; }
  @media screen and (max-width: 768px) {
    .content-zone {
      gap: calc(8em / 8 * 2);
      padding: calc(8em / 16 * 3) 0; } }
  .content-zone .content-section .content-section-head {
    width: calc(100% / 32 * 30);
    margin-left: auto;
    margin-right: auto; }
    .content-zone .content-section .content-section-head * {
      color: var(--gray1); }
    .content-zone .content-section .content-section-head + * {
      margin-top: calc(8em / 8 * 2); }
      @media screen and (max-width: 768px) {
        .content-zone .content-section .content-section-head + * {
          margin-top: calc(8em / 16 * 3); } }

header#pageHeader {
  position: relative;
  z-index: 15;
  padding: 0 32px;
  padding-top: calc(8em / 8 * 5); }
  @media screen and (max-width: 768px) {
    header#pageHeader {
      padding: 0 24px;
      padding-top: calc(8em / 8 * 3); } }
  header#pageHeader .wrapper {
    display: block;
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto;
    padding: calc(8em / 8 * 6) 0; }
    @media screen and (max-width: 768px) {
      header#pageHeader .wrapper {
        width: 100%;
        padding: calc(8em / 16 * 8) 0; } }
    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.255em;
        font-weight: 600; }
      header#pageHeader .wrapper hgroup span {
        position: relative;
        z-index: 15;
        font-size: calc(8em / 8);
        font-weight: 400;
        letter-spacing: -.0205em;
        line-height: 1;
        text-transform: capitalize; }

header#singleHeader {
  position: relative;
  z-index: 15;
  padding: 0 32px;
  padding-top: calc(8em / 8 * 5); }
  @media screen and (max-width: 768px) {
    header#singleHeader {
      padding-top: calc(8em / 8 * 3); } }
  header#singleHeader .wrapper {
    display: flex;
    gap: calc(8em / 16 * 3) calc(8em / 8 * 4);
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto;
    padding: calc(8em / 8 * 6) 0 calc(8em / 8 * 4); }
    @media screen and (max-width: 768px) {
      header#singleHeader .wrapper {
        flex-direction: column;
        width: 100%;
        padding: calc(8em / 16 * 8) 0 calc(8em / 16 * 5); } }
    header#singleHeader .wrapper::before {
      content: '';
      display: block;
      width: 272px;
      max-width: 100%; }
    header#singleHeader .wrapper .single-title {
      flex: 1;
      display: flex;
      flex-direction: column;
      gap: 1em; }
      header#singleHeader .wrapper .single-title h1 {
        font-size: 3.28em;
        line-height: 1.23;
        font-weight: 600; }
        @media screen and (max-width: 768px) {
          header#singleHeader .wrapper .single-title h1 {
            font-size: 2.255em; } }
      header#singleHeader .wrapper .single-title .publish {
        display: flex;
        align-items: center;
        gap: calc(8em / 16); }
        header#singleHeader .wrapper .single-title .publish .cat {
          display: flex;
          align-items: center;
          justify-content: center;
          padding: calc(8em / 32) calc(8em / 16);
          border: solid 1px var(--key9);
          border-radius: calc(8em / 16);
          color: var(--key9);
          font-size: .75em;
          line-height: 1; }
        header#singleHeader .wrapper .single-title .publish time {
          color: var(--sub9);
          font-size: .75em; }

.page-frame {
  padding: 0 32px;
  padding-bottom: 6em; }
  @media screen and (max-width: 768px) {
    .page-frame {
      padding: 0 24px;
      padding-bottom: 3em; } }
  .page-frame .wrapper {
    width: calc(100% / 64 * 62);
    margin-left: auto;
    margin-right: auto; }
    @media screen and (max-width: 768px) {
      .page-frame .wrapper {
        width: 100%; } }
  .page-frame.document .wrapper {
    width: 100%;
    max-width: 680px;
    margin-left: auto;
    margin-right: auto; }
  .page-frame.page-flex hgroup:has(h2) {
    padding: calc(8em / 8 * 4) 0 calc(8em / 8 * 3);
    border-top: dotted 1px var(--gray11); }
    .page-frame.page-flex hgroup:has(h2) h2 {
      font-size: 2.05em; }
      @media screen and (max-width: 768px) {
        .page-frame.page-flex hgroup:has(h2) h2 {
          font-size: 1.845em; } }
  .page-frame.page-flex hgroup:has(h3) {
    padding: calc(8em / 8 * 3) 0 calc(8em / 16 * 3);
    border-top: dotted 1px var(--gray11); }
    .page-frame.page-flex hgroup:has(h3) h3 {
      font-size: 1.5575em;
      line-height: 1.23; }
    .page-frame.page-flex hgroup:has(h3) + * {
      margin-top: calc(8em / 16 * 3); }
  .page-frame.page-flex hgroup:has(h4) {
    margin: 1em 0; }
    .page-frame.page-flex hgroup:has(h4) h4 {
      display: flex;
      align-items: center;
      gap: calc(8em / 32);
      font-size: 1.1275em;
      color: var(--key9); }
      .page-frame.page-flex hgroup:has(h4) h4::before {
        content: '';
        display: block;
        width: .7em;
        height: .7em;
        background: var(--key9);
        border-radius: 1em; }
  .page-frame.page-flex .wrapper {
    display: flex;
    gap: calc(8em / 16 * 3) calc(8em / 8 * 4); }
    @media screen and (max-width: 768px) {
      .page-frame.page-flex .wrapper {
        flex-direction: column; } }
  .page-frame.page-flex .flex-side {
    width: 272px;
    max-width: 100%; }
    @media screen and (max-width: 768px) {
      .page-frame.page-flex .flex-side {
        width: 100%; } }
    .page-frame.page-flex .flex-side .anker {
      top: calc(8em / 8 * 5);
      padding: calc(8em / 8 * 2) calc(16px / 2 * 3) calc(8em / 8 * 2); }
      .page-frame.page-flex .flex-side .anker dl {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32 * 3); }
        .page-frame.page-flex .flex-side .anker dl > dt {
          padding-bottom: calc(8em / 32 * 2);
          border-bottom: dotted 1px var(--gray11); }
          .page-frame.page-flex .flex-side .anker dl > dt p {
            font-size: 1.23em;
            font-weight: 600; }
        .page-frame.page-flex .flex-side .anker dl > dd {
          opacity: .205; }
          .page-frame.page-flex .flex-side .anker dl > dd a {
            display: flex;
            align-items: center;
            gap: calc(8em / 32);
            font-weight: 600; }
            .page-frame.page-flex .flex-side .anker dl > dd a span {
              display: block; }
              .page-frame.page-flex .flex-side .anker dl > dd a span.icon {
                display: flex;
                align-items: center;
                justify-content: center;
                width: 1em;
                height: 1em;
                padding: calc(8em / 64); }
                .page-frame.page-flex .flex-side .anker dl > dd a span.icon svg {
                  fill: var(--gray1); }
          .page-frame.page-flex .flex-side .anker dl > dd:hover {
            opacity: 1; }
          .page-frame.page-flex .flex-side .anker dl > dd.active {
            opacity: 1; }
            .page-frame.page-flex .flex-side .anker dl > dd.active * {
              color: var(--key9); }
            .page-frame.page-flex .flex-side .anker dl > dd.active span.icon svg {
              fill: var(--key9); }
  .page-frame.page-flex .flex-main {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: calc(8em / 8 * 6); }
    @media screen and (max-width: 768px) {
      .page-frame.page-flex .flex-main:has(.news-main) {
        order: -1; } }

.document-header {
  padding-top: calc(8em / 8 * 5); }
  @media screen and (max-width: 768px) {
    .document-header {
      padding-top: calc(8em / 8 * 3); } }
  .document-header .wrapper {
    padding-top: calc(8em / 8 * 4);
    padding-bottom: calc(8em / 8 * 4); }
    @media screen and (max-width: 768px) {
      .document-header .wrapper {
        padding-top: calc(8em / 8 * 3);
        padding-bottom: calc(8em / 8 * 3); } }
  .document-header h1 {
    text-align: center;
    font-size: 2.255em;
    font-weight: 900; }

.page-service .service-jobtype .jobtype-main {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 8 * 5); }
  .page-service .service-jobtype .jobtype-main .card {
    position: relative;
    z-index: 15;
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16 * 4); }
    .page-service .service-jobtype .jobtype-main .card .thumb {
      position: relative;
      z-index: 15;
      aspect-ratio: 3 / 2;
      border-radius: calc(8em / 16);
      box-shadow: var(--shadow);
      overflow: hidden;
      line-height: 0; }
      @media screen and (max-width: 768px) {
        .page-service .service-jobtype .jobtype-main .card .thumb {
          aspect-ratio: 2 / 2; } }
      .page-service .service-jobtype .jobtype-main .card .thumb img {
        filter: brightness(0.615); }
      .page-service .service-jobtype .jobtype-main .card .thumb h3 {
        position: absolute;
        top: 0;
        right: 0;
        z-index: 15;
        padding: calc(8em / 32 * 3) calc(8em / 8 * 1);
        font-size: 3.075em;
        line-height: 1;
        font-weight: 500;
        writing-mode: vertical-rl;
        text-orientation: mixed;
        transform: scaleX(1.25); }
        @media screen and (max-width: 768px) {
          .page-service .service-jobtype .jobtype-main .card .thumb h3 {
            font-size: 2.255em; } }
    .page-service .service-jobtype .jobtype-main .card .content dl > dt {
      font-size: 1.5575em; }
      .page-service .service-jobtype .jobtype-main .card .content dl > dt + * {
        margin-top: calc(8em / 32); }
    .page-service .service-jobtype .jobtype-main .card .content dl > dd strong {
      border-bottom: dotted 1px var(--gray11); }
    .page-service .service-jobtype .jobtype-main .card .content dl + * {
      margin-top: 1em; }
    .page-service .service-jobtype .jobtype-main .card .content a {
      display: table;
      color: var(--blue9);
      border-bottom: dotted 1px var(--blue9); }
.page-service .service-number {
  position: relative;
  z-index: 15;
  padding: calc(8em / 8 * 3);
  border-radius: calc(8em / 16);
  overflow: hidden;
  box-shadow: var(--shadow); }
  @media screen and (max-width: 768px) {
    .page-service .service-number {
      width: calc(100% + 48px);
      margin-left: -24px;
      padding: 24px; } }
  .page-service .service-number .background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    opacity: .5; }
  .page-service .service-number .number-main {
    padding-left: calc(8em / 8 * 10); }
    @media screen and (max-width: 768px) {
      .page-service .service-number .number-main {
        padding-left: 0; } }
  .page-service .service-number ul.grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: calc(8em / 8); }
    @media screen and (max-width: 768px) {
      .page-service .service-number ul.grid {
        grid-template-columns: repeat(2, 1fr);
        gap: calc(8em / 16); } }
    .page-service .service-number ul.grid > li {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 16 * 1);
      grid-template-columns: 1fr;
      aspect-ratio: 4/3;
      padding: calc(8em / 32 * 5);
      border-radius: calc(8em / 16);
      box-shadow: var(--shadow);
      background: var(--gray1); }
      @media screen and (max-width: 768px) {
        .page-service .service-number ul.grid > li {
          align-items: center;
          padding: calc(8em / 32 * 3) 0;
          aspect-ratio: auto; } }
      .page-service .service-number ul.grid > li .number-title {
        color: var(--key9);
        font-weight: 700;
        font-size: 1.1275em; }
        @media screen and (max-width: 768px) {
          .page-service .service-number ul.grid > li .number-title {
            font-size: 1em;
            text-align: center; } }
      .page-service .service-number ul.grid > li .number-item {
        display: flex;
        align-items: baseline; }
        @media screen and (max-width: 768px) {
          .page-service .service-number ul.grid > li .number-item {
            justify-content: center; } }
        .page-service .service-number ul.grid > li .number-item * {
          color: var(--gray12); }
        .page-service .service-number ul.grid > li .number-item .num {
          font-size: 5.125em;
          line-height: 1;
          font-weight: 800;
          letter-spacing: -.041em; }
          @media screen and (max-width: 768px) {
            .page-service .service-number ul.grid > li .number-item .num {
              font-size: 2.87em; } }
        .page-service .service-number ul.grid > li .number-item .meta {
          font-size: 1.3325em;
          font-weight: 600; }
      .page-service .service-number ul.grid > li .caption {
        flex: 1;
        display: flex;
        align-items: flex-end;
        color: var(--gray9); }
        @media screen and (max-width: 768px) {
          .page-service .service-number ul.grid > li .caption {
            font-size: .8em;
            text-align: center; } }
.page-service .service-careerstep .careerstep-main {
  counter-reset: num;
  display: flex;
  flex-direction: column;
  gap: calc(8em / 16 * 5); }
  .page-service .service-careerstep .careerstep-main .careerstep-main-item {
    display: flex;
    align-items: flex-start;
    gap: calc(8em / 16 * 5); }
    @media screen and (max-width: 768px) {
      .page-service .service-careerstep .careerstep-main .careerstep-main-item {
        gap: calc(8em / 32 * 5); } }
    .page-service .service-careerstep .careerstep-main .careerstep-main-item::before {
      counter-increment: num;
      content: counter(num);
      display: flex;
      align-items: center;
      justify-content: center;
      width: 4em;
      min-width: 4em;
      height: 4em;
      background: var(--black);
      border-radius: 3em;
      box-shadow: var(--shadow); }
    .page-service .service-careerstep .careerstep-main .careerstep-main-item .content {
      display: flex;
      align-items: flex-start;
      flex-direction: column;
      gap: calc(8em / 32); }
      .page-service .service-careerstep .careerstep-main .careerstep-main-item .content .spend {
        display: flex;
        align-items: center;
        justify-content: center;
        min-height: 1.5em;
        padding: 0 calc(8em / 8);
        background: var(--key10);
        border-radius: calc(8em);
        font-size: .8em; }
      .page-service .service-careerstep .careerstep-main .careerstep-main-item .content h3 {
        font-size: 1.5575em; }
        @media screen and (max-width: 768px) {
          .page-service .service-careerstep .careerstep-main .careerstep-main-item .content h3 {
            font-size: 1.3325em; } }
  .page-service .service-careerstep .careerstep-main + * {
    margin-top: calc(8em / 8 * 5); }
.page-service .service-careerstep .careerstep-foot .title {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 4em;
  font-size: 1.3325em;
  letter-spacing: .082em; }
  .page-service .service-careerstep .careerstep-foot .title strong {
    font-weight: 600;
    border-bottom: dotted 1px var(--gray11); }
.page-service .service-careerstep .careerstep-foot ul.grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(8em / 16 * 4); }
  @media screen and (max-width: 768px) {
    .page-service .service-careerstep .careerstep-foot ul.grid {
      gap: 0;
      border-radius: calc(8em / 8);
      box-shadow: var(--shadow);
      overflow: hidden; } }
  .page-service .service-careerstep .careerstep-foot ul.grid > li {
    grid-template-columns: 1fr;
    position: relative;
    z-index: 15;
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 4/5;
    border-radius: calc(8em / 8);
    box-shadow: var(--shadow);
    overflow: hidden; }
    @media screen and (max-width: 768px) {
      .page-service .service-careerstep .careerstep-foot ul.grid > li {
        border-radius: 0;
        aspect-ratio: 9/21; } }
    .page-service .service-careerstep .careerstep-foot ul.grid > li .thumb {
      position: absolute;
      top: 0;
      left: 0;
      z-index: -5;
      width: 100%;
      height: 100%; }
      .page-service .service-careerstep .careerstep-foot ul.grid > li .thumb img {
        filter: brightness(0.7175); }
    .page-service .service-careerstep .careerstep-foot ul.grid > li h4 {
      font-weight: 500;
      font-size: 1.5575em;
      writing-mode: vertical-rl;
      text-orientation: mixed;
      transform: scaleX(1.25); }
      @media screen and (max-width: 768px) {
        .page-service .service-careerstep .careerstep-foot ul.grid > li h4 {
          font-size: 1.435em;
          letter-spacing: .082em; } }

.page-team ul.grid {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 8 * 2); }
  @media screen and (max-width: 768px) {
    .page-team ul.grid {
      gap: calc(8em / 8 * 2); } }
  .page-team ul.grid > li .card {
    display: grid;
    align-items: center;
    grid-template-columns: 1fr 3fr;
    gap: calc(8em / 16 * 3);
    padding: calc(8em / 16);
    border-radius: calc(8em / 64 * 8);
    overflow: hidden;
    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; }
    @media screen and (max-width: 768px) {
      .page-team ul.grid > li .card {
        grid-template-columns: 1fr; } }
    .page-team ul.grid > li .card .thumb {
      aspect-ratio: 1/1;
      box-shadow: var(--shadow);
      border-radius: calc(8em / 32 * 3);
      overflow: hidden;
      grid-template-columns: 1fr; }
      .page-team ul.grid > li .card .thumb img {
        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; }
    .page-team ul.grid > li .card .content {
      grid-template-columns: 3fr;
      display: flex;
      flex-direction: column;
      gap: calc(8em / 16 * 3); }
      .page-team ul.grid > li .card .content dl > dt {
        font-size: 1.845em; }
        @media screen and (max-width: 768px) {
          .page-team ul.grid > li .card .content dl > dt {
            font-size: 1.5575em; } }
        .page-team ul.grid > li .card .content dl > dt + * {
          margin-top: calc(8em / 32); }
      .page-team ul.grid > li .card .content h3 {
        display: flex;
        align-items: baseline;
        justify-content: flex-end;
        flex-direction: row-reverse;
        gap: calc(8em / 32); }
        .page-team ul.grid > li .card .content h3 span.meta {
          font-size: .8em; }
    .page-team ul.grid > li .card:hover {
      background: var(--black);
      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; }
      .page-team ul.grid > li .card:hover .thumb 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; }

.page-environment .environment-main .environment-philosophy {
  position: relative;
  z-index: 15;
  border-radius: calc(8em / 16);
  box-shadow: var(--shadow);
  overflow: hidden; }
  @media screen and (max-width: 768px) {
    .page-environment .environment-main .environment-philosophy {
      width: calc(100% + 48px);
      margin-left: -24px;
      margin-right: -24px;
      padding: 0 28px; } }
  .page-environment .environment-main .environment-philosophy .background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%; }
    .page-environment .environment-main .environment-philosophy .background img {
      filter: brightness(0.328); }
  .page-environment .environment-main .environment-philosophy hgroup {
    text-align: center;
    border-top: none; }
  .page-environment .environment-main .environment-philosophy .philosophy-main {
    display: flex;
    align-items: center;
    flex-direction: column;
    padding-bottom: calc(8em / 8 * 5); }
    .page-environment .environment-main .environment-philosophy .philosophy-main p {
      position: relative;
      z-index: 15;
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32 * 3);
      line-height: 2.255;
      font-family: "Shippori Antique B1", sans-serif;
      transform: scaleX(1.125);
      text-align: center;
      white-space: normal;
      word-break: keep-all;
      overflow-wrap: break-word;
      line-break: strict; }
      @media screen and (max-width: 768px) {
        .page-environment .environment-main .environment-philosophy .philosophy-main p {
          align-items: flex-start;
          line-height: 1.8;
          transform: scaleX(1.025); } }
      .page-environment .environment-main .environment-philosophy .philosophy-main p span {
        position: relative;
        z-index: 15;
        display: block;
        width: 100%; }
        .page-environment .environment-main .environment-philosophy .philosophy-main p span.svg-wrap {
          display: flex;
          align-items: center;
          justify-content: center;
          aspect-ratio: 376/178; }
          .page-environment .environment-main .environment-philosophy .philosophy-main p span.svg-wrap svg {
            position: absolute;
            top: 0;
            left: 50%;
            stroke-width: 1px;
            transform: translateX(-50%);
            width: 100%;
            opacity: .6; }
.page-environment .environment-main .environment-benefit .benefit-main {
  counter-reset: num;
  display: flex;
  flex-direction: column;
  gap: calc(8em / 16 * 4); }
  .page-environment .environment-main .environment-benefit .benefit-main .main-item {
    display: flex;
    gap: calc(8em / 16 * 5);
    padding-bottom: calc(8em / 16 * 3); }
    @media screen and (max-width: 768px) {
      .page-environment .environment-main .environment-benefit .benefit-main .main-item {
        gap: calc(8em / 16 * 3); } }
    .page-environment .environment-main .environment-benefit .benefit-main .main-item::before {
      counter-increment: num;
      content: counter(num);
      display: flex;
      align-items: center;
      justify-content: center;
      width: 4em;
      min-width: 4em;
      height: 4em;
      background: var(--black);
      border-radius: 3em;
      box-shadow: var(--shadow); }
      @media screen and (max-width: 768px) {
        .page-environment .environment-main .environment-benefit .benefit-main .main-item::before {
          width: 3em;
          min-width: 3em;
          height: 3em; } }
    .page-environment .environment-main .environment-benefit .benefit-main .main-item dl > dt {
      padding-bottom: calc(8em / 32);
      border-bottom: dotted 1px var(--gray11);
      font-size: 1.3325em; }
      .page-environment .environment-main .environment-benefit .benefit-main .main-item dl > dt + dd {
        margin-top: calc(8em / 32 * 3); }
.page-environment .environment-main .environment-dailyflow .dailyflow-main {
  position: relative;
  z-index: 15; }
  .page-environment .environment-main .environment-dailyflow .dailyflow-main::before {
    content: '';
    position: absolute;
    top: 0;
    left: calc(50% - ((8em / 32) / 2));
    z-index: -1;
    width: calc(8em / 32);
    height: 100%;
    background: var(--gray11); }
  .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16 * 3); }
    .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li {
      position: relative;
      z-index: 15;
      display: flex;
      gap: calc(8em / 8 * 6); }
      @media screen and (max-width: 768px) {
        .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li {
          gap: calc(8em / 8 * 4); } }
      .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li::before {
        content: '';
        position: absolute;
        top: calc(2em + .4em);
        left: calc(50% - (1em / 2));
        display: block;
        width: 1em;
        height: 1em;
        border-radius: 1em;
        background: var(--gray2);
        box-shadow: var(--shadow); }
        @media screen and (max-width: 768px) {
          .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li::before {
            top: calc(1.5em + .4em); } }
      .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li .thumb {
        flex: 1;
        aspect-ratio: 3/2;
        background: var(--black);
        border-radius: calc(8em / 16);
        box-shadow: var(--shadow);
        overflow: hidden;
        line-height: 0; }
      .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li .content {
        flex: 1;
        padding: calc(8em / 16 * 4) 0; }
        @media screen and (max-width: 768px) {
          .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li .content {
            padding: calc(8em / 16 * 3) 0; } }
        .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li .content .term {
          color: var(--gray4); }
        .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li .content p {
          font-size: 1.3325em; }
          @media screen and (max-width: 768px) {
            .page-environment .environment-main .environment-dailyflow .dailyflow-main ul.col > li .content p {
              font-size: 1.23em; } }
.page-environment .environment-main .environment-faq .faq-main {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 8 * 6); }
  @media screen and (max-width: 768px) {
    .page-environment .environment-main .environment-faq .faq-main {
      gap: calc(8em / 8 * 4); } }
  .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item {
    white-space: normal;
    word-break: break-all;
    overflow-wrap: break-word;
    line-break: strict;
    border-bottom: dotted 1px var(--gray11); }
    .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .question {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: calc(8em / 32 * 5) 0;
      cursor: pointer; }
      .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .question p {
        display: flex;
        align-items: baseline;
        gap: calc(8em / 32);
        font-size: 1.075em;
        font-weight: 600; }
        .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .question p::before {
          content: 'Q.';
          display: block;
          color: var(--key9);
          white-space: nowrap; }
      .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .question .icon {
        display: block;
        width: 1em;
        height: 1em;
        filter: brightness(0) invert(1);
        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; }
      .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .question.open .icon {
        transform: rotate(-180deg);
        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; }
    .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .answer {
      display: flex;
      align-items: baseline;
      gap: calc(8em * 1.23 / 32);
      padding-bottom: calc(8em / 32 * 6); }
      .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .answer::before {
        content: 'A.';
        display: block;
        font-size: 1.23em;
        font-weight: 600;
        color: var(--gray);
        white-space: nowrap; }
      .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .answer p {
        color: var(--gray2); }
        .page-environment .environment-main .environment-faq .faq-main .main-item .qa-item .answer p strong {
          color: var(--gray2);
          border-bottom: dotted 2px var(--gray11); }

.interview-article {
  --ia-text: #0b0f14;
  --ia-muted: rgba(11, 15, 20, 0.62);
  --ia-border: rgba(15, 23, 42, 0.12);
  --ia-surface: rgba(15, 23, 42, 0.04);
  --ia-surface-2: rgba(15, 23, 42, 0.06);
  --ia-accent: #111827;
  --ia-radius-sm: 12px;
  --ia-radius-md: 16px;
  --ia-radius-lg: 22px;
  --ia-shadow-soft: 0 10px 28px rgba(0, 0, 0, 0.08);
  --ia-shadow-hover: 0 16px 40px rgba(0, 0, 0, 0.12);
  --ia-container: 1120px;
  --ia-measure: 760px;
  --ia-gutter: 24px; }
  .interview-article .objf {
    width: 100%;
    height: 100%;
    object-fit: cover; }
  .interview-article .interview-hero {
    padding: calc(8em / 8 * 2) 32px 0; }
    @media (max-width: 900px) {
      .interview-article .interview-hero {
        padding: calc(8em / 8 * 2) 24px 0; } }
    .interview-article .interview-hero .wrapper {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 16 * 1);
      max-width: var(--ia-measure);
      margin: 0 auto; }
      .interview-article .interview-hero .wrapper h1 {
        font-size: 2.05em;
        line-height: 1.3325; }
      .interview-article .interview-hero .wrapper .text {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 32); }
        .interview-article .interview-hero .wrapper .text .name p {
          font-weight: 600;
          font-size: 1.1275em;
          line-height: 1; }
        .interview-article .interview-hero .wrapper .text .attr {
          display: flex;
          align-items: center;
          gap: calc(8em / 8);
          font-size: .8em;
          color: var(--gray-6); }
      .interview-article .interview-hero .wrapper + * {
        margin-top: calc(8em / 8 * 2); }
    .interview-article .interview-hero__media {
      max-width: var(--ia-container);
      margin: 0 auto;
      background: var(--ia-surface);
      border-radius: calc(8em / 16);
      box-shadow: var(--shadow);
      overflow: hidden; }
      .interview-article .interview-hero__media img {
        display: block;
        width: 100%;
        height: auto; }
    @media (max-width: 640px) {
      .interview-article .interview-hero__media {
        border-radius: var(--ia-radius-md);
        padding: 0 16px; } }
  .interview-article .interview-shell {
    padding: calc(8em / 16 * 8) 0 calc(8em / 8 * 5); }
    @media (max-width: 640px) {
      .interview-article .interview-shell {
        padding: 22px 0 56px; } }
  .interview-article .interview-container {
    max-width: var(--ia-container);
    margin: 0 auto;
    padding: 0 var(--ia-gutter); }
    @media (max-width: 640px) {
      .interview-article .interview-container {
        padding: 0 24px; } }
  .interview-article .interview-header {
    max-width: var(--ia-measure);
    margin: 0 auto 22px; }
    @media (max-width: 900px) {
      .interview-article .interview-header {
        max-width: 100%; } }
  .interview-article .interview-kicker {
    margin: 0 0 10px;
    font-size: 0.92rem;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--ia-muted); }
  .interview-article .interview-title {
    margin: 0;
    font-size: clamp(1.6rem, 2.3vw, 2.35rem);
    line-height: 1.25;
    letter-spacing: -0.01em; }
  .interview-article .interview-meta {
    margin-top: 14px;
    display: flex;
    gap: 12px;
    align-items: center; }
    .interview-article .interview-meta__time {
      font-size: 0.95rem;
      color: var(--ia-muted); }
  .interview-article .interview-profile {
    max-width: var(--ia-measure);
    margin: 0 auto 26px; }
    @media (max-width: 900px) {
      .interview-article .interview-profile {
        max-width: 100%; } }
    .interview-article .interview-profile__card {
      padding: 16px 18px;
      border: 1px solid var(--ia-border);
      border-radius: var(--ia-radius-md);
      background: rgba(15, 23, 42, 0.025); }
    .interview-article .interview-profile__name, .interview-article .interview-profile__org, .interview-article .interview-profile__track {
      margin: 0;
      display: grid;
      grid-template-columns: 140px 1fr;
      gap: 10px;
      padding: 10px 0; }
      .interview-article .interview-profile__name:not(:last-child), .interview-article .interview-profile__org:not(:last-child), .interview-article .interview-profile__track:not(:last-child) {
        border-bottom: 1px solid rgba(15, 23, 42, 0.08); }
      @media (max-width: 640px) {
        .interview-article .interview-profile__name, .interview-article .interview-profile__org, .interview-article .interview-profile__track {
          grid-template-columns: 1fr;
          gap: 6px; } }
      .interview-article .interview-profile__name .label, .interview-article .interview-profile__org .label, .interview-article .interview-profile__track .label {
        font-size: 0.85rem;
        color: var(--ia-muted);
        letter-spacing: 0.06em; }
      .interview-article .interview-profile__name .value, .interview-article .interview-profile__org .value, .interview-article .interview-profile__track .value {
        font-size: 1rem;
        color: var(--ia-text);
        font-weight: 600; }
  .interview-article .interview-body {
    max-width: var(--ia-measure);
    margin: 0 auto 34px; }
    @media (max-width: 900px) {
      .interview-article .interview-body {
        max-width: 100%; } }
  .interview-article .interview-prose {
    font-size: 1.05rem;
    line-height: 1.95;
    letter-spacing: 0.01em; }
    @media (max-width: 640px) {
      .interview-article .interview-prose {
        font-size: 1rem;
        line-height: 1.9; } }
    .interview-article .interview-prose p {
      margin: 0 0 1.2em;
      color: var(--ia-text); }
    .interview-article .interview-prose h2, .interview-article .interview-prose h3, .interview-article .interview-prose h4 {
      margin: 1.9em 0 0.7em;
      line-height: 1.35;
      letter-spacing: -0.005em;
      color: var(--ia-text); }
    .interview-article .interview-prose h2 {
      font-size: 1.45rem; }
      @media (max-width: 640px) {
        .interview-article .interview-prose h2 {
          font-size: 1.25rem; } }
    .interview-article .interview-prose h3 {
      font-size: 1.2rem;
      color: rgba(11, 15, 20, 0.92); }
    .interview-article .interview-prose h4 {
      font-size: 1.05rem;
      color: rgba(11, 15, 20, 0.86); }
    .interview-article .interview-prose a {
      color: var(--ia-text);
      text-decoration: underline;
      text-underline-offset: 3px;
      text-decoration-thickness: 1px;
      transition: color 150ms ease, background 150ms ease; }
      .interview-article .interview-prose a:focus-visible {
        outline: 2px solid rgba(17, 24, 39, 0.35);
        outline-offset: 3px;
        border-radius: 10px; }
      .interview-article .interview-prose a:hover {
        color: rgba(11, 15, 20, 0.65);
        background: rgba(15, 23, 42, 0.06);
        border-radius: 6px; }
    .interview-article .interview-prose ul, .interview-article .interview-prose ol {
      margin: 0 0 1.4em 1.2em;
      padding: 0; }
      .interview-article .interview-prose ul li, .interview-article .interview-prose ol li {
        margin: 0.35em 0; }
    .interview-article .interview-prose blockquote {
      margin: 1.7em 0;
      padding: 16px 18px;
      border-left: 3px solid rgba(17, 24, 39, 0.55);
      background: rgba(15, 23, 42, 0.035);
      border-radius: var(--ia-radius-md); }
      .interview-article .interview-prose blockquote p {
        margin: 0;
        color: rgba(11, 15, 20, 0.92); }
      .interview-article .interview-prose blockquote cite {
        display: block;
        margin-top: 10px;
        font-size: 0.92rem;
        color: var(--ia-muted);
        font-style: normal; }
    .interview-article .interview-prose hr {
      margin: 2.2em 0;
      border: none;
      height: 1px;
      background: var(--ia-border); }
    .interview-article .interview-prose img {
      max-width: 100%;
      height: auto;
      border-radius: var(--ia-radius-md); }
    .interview-article .interview-prose code {
      font-size: 0.95em;
      background: rgba(15, 23, 42, 0.06);
      padding: 0.15em 0.35em;
      border-radius: 8px; }
    .interview-article .interview-prose pre {
      margin: 1.6em 0;
      padding: 14px 16px;
      background: rgba(15, 23, 42, 0.06);
      border: 1px solid rgba(15, 23, 42, 0.1);
      border-radius: var(--ia-radius-md);
      overflow: auto; }
      .interview-article .interview-prose pre code {
        background: transparent;
        padding: 0;
        border-radius: 0;
        font-size: 0.95rem;
        line-height: 1.7; }
  .interview-article .interview-introduction {
    max-width: var(--ia-measure);
    margin: 0 auto 3em;
    text-align: center; }
    .interview-article .interview-introduction p {
      font-size: .8em;
      color: var(--gray9); }
  .interview-article .interview-qa {
    max-width: var(--ia-measure);
    margin: 0 auto 34px; }
    @media (max-width: 900px) {
      .interview-article .interview-qa {
        max-width: 100%; } }
    .interview-article .interview-qa__title {
      margin: 0 0 14px;
      font-size: 1.25rem;
      letter-spacing: -0.005em; }
    .interview-article .interview-qa__list {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 8 * 3); }
  .interview-article .qa-block {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16 * 3); }
    @media (max-width: 900px) {
      .interview-article .qa-block {
        gap: calc(8em / 16 * 2); } }
    .interview-article .qa-block__theme {
      font-size: 1.3325em;
      line-height: 1.435; }
  .interview-article .qa-item__grid {
    display: flex;
    align-items: start;
    flex-direction: column;
    gap: calc(8em / 16 * 3); }
    @media (max-width: 900px) {
      .interview-article .qa-item__grid {
        grid-template-columns: 1fr; } }
  .interview-article .qa-item__media {
    border-radius: calc(8em / 16);
    overflow: hidden;
    background: var(--ia-surface);
    box-shadow: var(--shadow); }
    .interview-article .qa-item__media img {
      display: block;
      width: 100%;
      height: auto; }
  .interview-article .qa-item__answer {
    font-size: 1.02rem;
    line-height: 1.9;
    color: var(--gray3); }
    @media (max-width: 900px) {
      .interview-article .qa-item__answer {
        line-height: 1.64; } }
    .interview-article .qa-item__answer p {
      margin: 0 0 1.1em; }
    .interview-article .qa-item__answer p:last-child {
      margin-bottom: 0; }
  .interview-article .interview-nav {
    max-width: var(--ia-measure);
    margin: 46px auto 0;
    padding-top: 18px;
    border-top: 1px solid var(--ia-border);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px; }
    @media (max-width: 640px) {
      .interview-article .interview-nav {
        grid-template-columns: 1fr; } }
    .interview-article .interview-nav__prev:empty, .interview-article .interview-nav__next:empty {
      display: none; }
    .interview-article .interview-nav__prev a, .interview-article .interview-nav__next a {
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: 10px;
      padding: 14px 14px;
      border-radius: var(--ia-radius-md);
      text-decoration: none;
      color: var(--ia-text);
      background: rgba(15, 23, 42, 0.035);
      border: 1px solid rgba(15, 23, 42, 0.08);
      transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease; }
      .interview-article .interview-nav__prev a:focus-visible, .interview-article .interview-nav__next a:focus-visible {
        outline: 2px solid rgba(17, 24, 39, 0.35);
        outline-offset: 3px;
        border-radius: 10px; }
      .interview-article .interview-nav__prev a:hover, .interview-article .interview-nav__next a:hover {
        transform: translateY(-1px);
        box-shadow: var(--ia-shadow-soft);
        background: rgba(15, 23, 42, 0.05); }
  @media (prefers-reduced-motion: reduce) {
    .interview-article * {
      transition: none !important; } }

.interview-other-post {
  padding-bottom: calc(8em / 8 * 6); }
  @media screen and (max-width: 768px) {
    .interview-other-post {
      padding-bottom: calc(8em / 16 * 6); } }
  .interview-other-post .wrapper {
    margin-left: auto;
    margin-right: auto;
    padding: 0 32px; }
    @media screen and (max-width: 768px) {
      .interview-other-post .wrapper {
        padding: 0 24px; } }
    .interview-other-post .wrapper .interview-other-post-main {
      aspect-ratio: 2.35 / 1; }
      @media screen and (max-width: 768px) {
        .interview-other-post .wrapper .interview-other-post-main {
          aspect-ratio: initial; } }
  .interview-other-post ul.cards {
    display: flex;
    gap: calc(8em / 8);
    height: 100%;
    counter-reset: num; }
    @media screen and (max-width: 768px) {
      .interview-other-post ul.cards {
        flex-wrap: wrap;
        gap: calc(8em / 16); } }
    .interview-other-post ul.cards > li {
      position: relative;
      z-index: 15;
      width: calc((100% / 4) - ((8em / 8) * 3 / 4));
      border-radius: calc(8em / 8);
      overflow: hidden;
      box-shadow: var(--shadow);
      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) {
        .interview-other-post ul.cards > li {
          width: calc((100% / 2) - ((8em / 16) * 1 / 2)); } }
      .interview-other-post ul.cards > li.board {
        display: flex;
        align-items: center;
        justify-content: center;
        min-width: calc((100% / 4) - ((8em / 8) * 3 / 4));
        pointer-events: none;
        background: var(--key10); }
        .interview-other-post ul.cards > li.board .title {
          font-weight: 500;
          font-size: 1.5575em;
          writing-mode: vertical-rl;
          text-orientation: mixed;
          transform: scaleX(1.25);
          line-height: 1; }
          @media screen and (max-width: 768px) {
            .interview-other-post ul.cards > li.board .title {
              font-size: 1.3325em; } }
      .interview-other-post ul.cards > li .background {
        position: absolute;
        top: 0;
        left: 0;
        z-index: -1;
        width: 100%;
        height: 100%; }
        .interview-other-post ul.cards > li .background img {
          filter: brightness(0.82); }
        .interview-other-post ul.cards > li .background::after {
          content: '';
          position: absolute;
          bottom: 0;
          display: block;
          width: 100%;
          height: 50%;
          background: linear-gradient(to bottom, transparent, var(--border-light-black)); }
      .interview-other-post ul.cards > 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) {
          .interview-other-post ul.cards > li .card {
            aspect-ratio: 1 / 1; } }
        .interview-other-post ul.cards > li .card * {
          color: var(--gray1); }
        .interview-other-post ul.cards > li .card::before {
          counter-increment: num;
          content: "0" counter(num);
          position: absolute;
          top: 0;
          left: 0;
          display: block;
          padding: calc(8rem / 8);
          color: var(--gray1);
          font-size: 3.28em;
          line-height: 1;
          font-weight: 600;
          pointer-events: none; }
          @media screen and (max-width: 768px) {
            .interview-other-post ul.cards > li .card::before {
              padding: calc(8rem / 16);
              font-size: 2.87em; } }
        .interview-other-post ul.cards > li .card hgroup {
          width: 100%; }
      .interview-other-post ul.cards > 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; }

.archive_joblist {
  padding-top: calc(8em / 8 * 10);
  padding-bottom: calc(8em / 8 * 12); }
  @media screen and (max-width: 768px) {
    .archive_joblist {
      padding-top: calc(8em / 8 * 5);
      padding-bottom: calc(8em / 8 * 6); } }
  .archive_joblist .joblist-body {
    display: flex;
    gap: calc(8em / 8 * 3); }
    .archive_joblist .joblist-body > .left_side {
      width: 300px; }
      .archive_joblist .joblist-body > .left_side .sticky {
        top: calc(8em / 8 * 8); }
    .archive_joblist .joblist-body > .right_side {
      flex: 1; }
  .archive_joblist .search-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between; }
    @media screen and (max-width: 768px) {
      .archive_joblist .search-head {
        align-items: center;
        min-height: 4.1em;
        padding: 0 calc(8em / 32 * 5);
        background: var(--key);
        border-radius: calc(8em / 32);
        overflow: hidden; }
        .archive_joblist .search-head * {
          color: var(--white); } }
    .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); }
      @media screen and (max-width: 768px) {
        .archive_joblist .search-head + * {
          display: none;
          margin-top: calc(8em / 16); } }
  .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(--gray1);
        border: solid 1px var(--gray5);
        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 {
            gap: calc(8em / 32);
            max-height: 210px;
            overflow: scroll;
            background: var(--white);
            padding: .75em;
            border: 1px solid var(--gray3);
            border-radius: calc(8em / 32);
            font-size: .9em; }
            .archive_joblist .searchandfilter ul > li[data-sf-field-type="tag"] ul > li {
              position: relative;
              align-items: center;
              flex-direction: row; }
              .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;
                min-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(--gray3);
          border-radius: calc(8em / 32);
          overflow: hidden;
          color: var(--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(--black);
      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(--white);
        border: solid 1px var(--border-light-black);
        border-radius: 4px; }
      .archive_joblist .searchandfilter input[type="radio"]:checked + label {
        background: var(--key);
        color: var(--white); }
    .archive_joblist .searchandfilter input[type="submit"] {
      display: block;
      min-width: 100%;
      height: calc(8em / 8 * 3);
      background-color: var(--gray12);
      border: none;
      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(--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); }

.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 * 2);
    padding-top: calc(8em / 8 * 2);
    border-top: solid 1px var(--border-light-black); }
  .joblist_archive ul.list > li .card {
    display: block;
    padding: calc(8em / 16 * 4);
    background: var(--black);
    border-radius: calc(8em / 32 * 3);
    overflow: hidden;
    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; }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .card {
        padding: 0;
        background: transparent; } }
    @media screen and (max-width: 768px) {
      .joblist_archive ul.list > li .card > ._head {
        padding: calc(8em / 16 * 2) 0; } }
    .joblist_archive ul.list > li .card > ._head h2 {
      font-size: 1.64em;
      line-height: 1.435;
      font-weight: 600;
      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; }
      @media screen and (max-width: 768px) {
        .joblist_archive ul.list > li .card > ._head h2 {
          font-size: 1.5525em; } }
    .joblist_archive ul.list > li .card > ._head + * {
      margin-top: calc(8em / 8); }
      @media screen and (max-width: 768px) {
        .joblist_archive ul.list > li .card > ._head + * {
          margin-top: 0; } }
    .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 {
          background: var(--black);
          flex-direction: column-reverse;
          gap: calc(8em / 16) calc(8em / 8 * 1); } }
      .joblist_archive ul.list > li .card > ._body > .text {
        flex: 3; }
        @media screen and (max-width: 768px) {
          .joblist_archive ul.list > li .card > ._body > .text {
            width: 100%;
            padding: calc(8em / 16 * 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 / 32);
        overflow: hidden;
        line-height: 0; }
        @media screen and (max-width: 768px) {
          .joblist_archive ul.list > li .card > ._body > .thumbnail {
            width: 100%; } }
        .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 {
      background: var(--black);
      box-shadow: var(--shadow);
      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; }
      .joblist_archive ul.list > li .card:hover > ._head h2 {
        color: var(--key);
        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; }
      .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 * 2); }
    @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 * 4);
        background: var(--black);
        border: 1px solid rgba(0, 0, 0, 0.1025);
        border-radius: calc(8em / 32);
        font-size: 16px;
        padding: 0 24px;
        color: var(--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; }
        @media screen and (max-width: 768px) {
          .joblist_archive ul.list > li .linker > li a {
            height: calc(8em / 8 * 3); } }
        .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);
        color: var(--gray1); }
.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(--white); }
      .joblist_archive nav.pagination .nav-links .page-numbers.dots {
        background: none; }

.jobpost-article .jobpost-main.flex-main {
  gap: calc(8em / 8 * 2); }
.jobpost-article .jobpost-main .main-head {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 32 * 3); }
  .jobpost-article .jobpost-main .main-head h1 {
    font-weight: 400;
    font-size: 1.845em; }
  .jobpost-article .jobpost-main .main-head ul.meta {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: calc(8em / 16 * 3);
    font-size: .85em;
    color: var(--gray9); }
    .jobpost-article .jobpost-main .main-head ul.meta > li {
      display: flex;
      align-items: center;
      gap: calc(8em / 64 * 3); }
      .jobpost-article .jobpost-main .main-head ul.meta > li .icon {
        width: calc(8em / 32 * 5);
        height: auto; }
        .jobpost-article .jobpost-main .main-head ul.meta > li .icon img {
          filter: brightness(0) invert(1); }
.jobpost-article .jobpost-main .main-thumb {
  border-radius: calc(8em / 16);
  box-shadow: var(--shadow);
  overflow: hidden;
  line-height: 0; }
.jobpost-article .jobpost-side .side-main {
  top: calc(8em / 8 * 7);
  display: flex;
  flex-direction: column;
  gap: calc(8em / 16 * 3); }
.jobpost-article .requirements_wrapper ul.table > li {
  border-top: dotted 1px var(--gray11); }
.jobpost-article .requirements_wrapper ul.table.mini {
  font-size: .8em; }
  @media screen and (max-width: 768px) {
    .jobpost-article .requirements_wrapper ul.table.mini {
      background: var(--black);
      padding: calc(8em / 16 * 3);
      box-shadow: var(--shadow);
      border-radius: calc(8em / 16); } }
  .jobpost-article .requirements_wrapper ul.table.mini dl {
    flex-direction: column;
    padding: calc(8em / 16 * 2) 0; }
    @media screen and (max-width: 768px) {
      .jobpost-article .requirements_wrapper ul.table.mini dl {
        padding: calc(8em / 32 * 3) 0; } }
.jobpost-article .requirements_wrapper dl.list {
  display: flex;
  align-items: baseline;
  padding: calc(8em / 16 * 3) 0; }
  @media screen and (max-width: 768px) {
    .jobpost-article .requirements_wrapper dl.list {
      padding: calc(8em / 32 * 3) 0; } }
  .jobpost-article .requirements_wrapper dl.list > dt {
    flex: 1;
    min-width: 12.3em; }
  .jobpost-article .requirements_wrapper dl.list > dd {
    flex: 5; }

.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; }

dl.listDocForm {
  display: flex;
  flex-wrap: wrap; }
  dl.listDocForm dt {
    width: 100%; }
    dl.listDocForm dt p {
      display: flex;
      align-items: baseline;
      column-gap: calc(8.5em /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; }
  @media screen and (max-width: 768px) {
    .mw_wp_form {
      padding: 0 12px; } }
  .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: 4em; }
  .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: 4em;
    border: none;
    font-weight: bold;
    text-align: center;
    line-height: 4em;
    font-size: 1em;
    background: var(--black);
    color: var(--gray1);
    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: 4em;
        line-height: 4em; } }
    .mw_wp_form input[type="submit"]:hover {
      background: var(--key10);
      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: 1.23em 2.46em;
    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; }

.page-entry .wrapper {
  display: flex;
  max-width: 1280px;
  gap: calc(8em / 16 * 3) calc(8em / 8 * 8); }
  @media screen and (max-width: 768px) {
    .page-entry .wrapper {
      flex-direction: column; } }
.page-entry .entry-side {
  flex: 1;
  max-width: 352px; }
  @media screen and (max-width: 768px) {
    .page-entry .entry-side {
      max-width: 100%; } }
  .page-entry .entry-side .entry-guide {
    top: calc(8em / 8 * 5);
    display: flex;
    flex-direction: column;
    gap: calc(8em / 8); }
    .page-entry .entry-side .entry-guide p {
      font-size: .8em; }
    .page-entry .entry-side .entry-guide .privacy {
      font-size: .8em; }
      .page-entry .entry-side .entry-guide .privacy a {
        color: var(--gray9);
        border-bottom: solid 1px var(--gray9); }
    .page-entry .entry-side .entry-guide figure {
      border-radius: calc(8em / 16);
      box-shadow: var(--shadow);
      overflow: hidden;
      line-height: 0; }
    .page-entry .entry-side .entry-guide .callus-wrapper {
      display: flex;
      align-items: center;
      flex-direction: column;
      padding: calc(8em / 16 * 4);
      background: var(--black);
      border-radius: calc(8em / 32 * 3);
      box-shadow: var(--shadow); }
      .page-entry .entry-side .entry-guide .callus-wrapper .callus {
        display: flex;
        flex-direction: column;
        gap: calc(8em / 64 * 3); }
        .page-entry .entry-side .entry-guide .callus-wrapper .callus .title {
          display: flex;
          align-items: center;
          justify-content: center;
          min-height: 2em;
          margin-bottom: calc(8em / 16);
          background: var(--key9);
          border-radius: calc(8em);
          color: var(--key3);
          font-weight: 600;
          font-size: .9em; }
        .page-entry .entry-side .entry-guide .callus-wrapper .callus .tel {
          display: flex;
          align-items: center;
          margin: calc((8em / 32) * -1) 0;
          font-weight: 600;
          color: var(--key9);
          font-size: 2.05em;
          letter-spacing: -.0201em;
          line-height: 1; }
        .page-entry .entry-side .entry-guide .callus-wrapper .callus .opening {
          display: flex;
          align-items: center;
          justify-content: center;
          gap: calc(8em / 16);
          letter-spacing: -.0201em; }
          .page-entry .entry-side .entry-guide .callus-wrapper .callus .opening .attr {
            font-size: .9em;
            font-weight: 600;
            color: var(--gray9); }
          .page-entry .entry-side .entry-guide .callus-wrapper .callus .opening .time {
            font-weight: 900;
            color: var(--gray3); }
  .page-entry .entry-side .caption {
    font-size: .7em;
    color: var(--sub9); }
  .page-entry .entry-side .anker {
    top: calc(8em / 8 * 5);
    padding: calc(8em / 8 * 2) calc(16px / 2 * 3) calc(8em / 8 * 2);
    background: var(--key2);
    background: url(images/noise.png), var(--key2);
    background-size: 100px, cover;
    background-repeat: repeat;
    box-shadow: var(--shadow);
    border: solid 1px var(--key4);
    border-radius: calc(8em / 32 * 4);
    overflow: hidden; }
    .page-entry .entry-side .anker dl {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32 * 3); }
      .page-entry .entry-side .anker dl > dt {
        padding-bottom: calc(8em / 32 * 2);
        border-bottom: dotted 2px var(--key6); }
        .page-entry .entry-side .anker dl > dt p {
          font-size: 1.23em;
          font-weight: 600; }
      .page-entry .entry-side .anker dl > dd {
        opacity: .205; }
        .page-entry .entry-side .anker dl > dd a {
          font-weight: 600; }
        .page-entry .entry-side .anker dl > dd:hover {
          opacity: 1; }
        .page-entry .entry-side .anker dl > dd.active {
          opacity: 1; }
          .page-entry .entry-side .anker dl > dd.active * {
            color: var(--key9); }
.page-entry .entry-main {
  position: relative;
  z-index: 15;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: calc(8em / 8 * 6); }
  .page-entry .entry-main::after {
    content: '';
    position: absolute;
    top: 0;
    left: -4em;
    width: 1px;
    height: 100%;
    background: var(--gray11); }
  .page-entry .entry-main .block-main .block-item {
    white-space: normal;
    word-break: break-all;
    overflow-wrap: break-word;
    line-break: strict; }
    .page-entry .entry-main .block-main .block-item .question {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: calc(8em / 32 * 5) 0;
      cursor: pointer; }
      .page-entry .entry-main .block-main .block-item .question p {
        display: flex;
        align-items: baseline;
        gap: calc(8em / 32);
        font-size: 1.23em;
        font-weight: 600; }
        .page-entry .entry-main .block-main .block-item .question p::before {
          content: 'Q.';
          display: block;
          color: var(--key9);
          white-space: nowrap; }
      .page-entry .entry-main .block-main .block-item .question .icon {
        display: block;
        width: 1em;
        height: 1em;
        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; }
      .page-entry .entry-main .block-main .block-item .question.open .icon {
        transform: rotate(-180deg);
        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; }
    .page-entry .entry-main .block-main .block-item .answer {
      padding-bottom: calc(8em / 32 * 6); }
      .page-entry .entry-main .block-main .block-item .answer p {
        display: flex;
        align-items: baseline;
        gap: calc(8em * 1.23 / 32);
        color: var(--gray11); }
        .page-entry .entry-main .block-main .block-item .answer p strong {
          color: var(--gray12);
          border-bottom: dotted 2px var(--gray12); }
        .page-entry .entry-main .block-main .block-item .answer p::before {
          content: 'A.';
          display: block;
          font-size: 1.23em;
          font-weight: 600;
          color: var(--gray);
          white-space: nowrap; }

ul.form-table {
  display: flex;
  flex-direction: column;
  gap: calc(8em / 16 * 3); }
  ul.form-table > li .label {
    display: flex;
    align-items: baseline;
    gap: calc(8em / 16);
    font-weight: 600;
    font-size: 15px;
    color: var(--gray11); }
    ul.form-table > li .label .required {
      color: #aa4222; }
  ul.form-table > li .input:has(.horizontal-item) {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: calc(8em / 16); }
  ul.form-table > li .input p {
    font-size: 16px; }
  ul.form-table > li .input label {
    font-size: 14px;
    font-weight: 600;
    color: var(--gray11); }
  ul.form-table > li .input .tel-group {
    display: flex;
    flex-direction: column;
    gap: calc(8em / 16); }
  ul.form-table > li .inline-group {
    display: inline-flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: calc(8em / 16); }
  ul.form-table > li .horizontal-item {
    display: inline-flex; }
  ul.form-table + .required-note {
    font-size: 16px;
    color: #aa4222; }

.page-faq hgroup:has(h2) {
  padding: calc(8em / 8 * 4) 0 calc(8em / 8 * 3);
  border-top: dotted 2px var(--key9); }
  .page-faq hgroup:has(h2) h2 {
    font-size: 2.05em; }
.page-faq .wrapper {
  display: flex;
  gap: calc(8em / 16 * 3) calc(8em / 8 * 4); }
  @media screen and (max-width: 768px) {
    .page-faq .wrapper {
      flex-direction: column; } }
.page-faq .faq-side {
  width: 272px;
  max-width: 100%; }
  @media screen and (max-width: 768px) {
    .page-faq .faq-side {
      width: 100%; } }
  .page-faq .faq-side .anker {
    top: calc(8em / 8 * 5);
    padding: calc(8em / 8 * 2) calc(16px / 2 * 3) calc(8em / 8 * 2);
    background: var(--key2);
    background: url(images/noise.png), var(--key2);
    background-size: 100px, cover;
    background-repeat: repeat;
    box-shadow: var(--shadow);
    border: solid 1px var(--key4);
    border-radius: calc(8em / 32 * 4);
    overflow: hidden; }
    .page-faq .faq-side .anker dl {
      display: flex;
      flex-direction: column;
      gap: calc(8em / 32 * 3); }
      .page-faq .faq-side .anker dl > dt {
        padding-bottom: calc(8em / 32 * 2);
        border-bottom: dotted 2px var(--key6); }
        .page-faq .faq-side .anker dl > dt p {
          font-size: 1.23em;
          font-weight: 600; }
      .page-faq .faq-side .anker dl > dd {
        opacity: .205; }
        .page-faq .faq-side .anker dl > dd a {
          font-weight: 600; }
        .page-faq .faq-side .anker dl > dd:hover {
          opacity: 1; }
        .page-faq .faq-side .anker dl > dd.active {
          opacity: 1; }
          .page-faq .faq-side .anker dl > dd.active * {
            color: var(--key9); }
.page-faq .faq-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: calc(8em / 8 * 6); }
  .page-faq .faq-main .block-main .block-item {
    white-space: normal;
    word-break: break-all;
    overflow-wrap: break-word;
    line-break: strict; }
    .page-faq .faq-main .block-main .block-item .question {
      display: flex;
      align-items: center;
      justify-content: space-between;
      padding: calc(8em / 32 * 5) 0;
      cursor: pointer; }
      .page-faq .faq-main .block-main .block-item .question p {
        display: flex;
        align-items: baseline;
        gap: calc(8em / 32);
        font-size: 1.23em;
        font-weight: 600; }
        .page-faq .faq-main .block-main .block-item .question p::before {
          content: 'Q.';
          display: block;
          color: var(--key9);
          white-space: nowrap; }
      .page-faq .faq-main .block-main .block-item .question .icon {
        display: block;
        width: 1em;
        height: 1em;
        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; }
      .page-faq .faq-main .block-main .block-item .question.open .icon {
        transform: rotate(-180deg);
        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; }
    .page-faq .faq-main .block-main .block-item .answer {
      display: flex;
      align-items: baseline;
      gap: calc(8em * 1.23 / 32);
      padding-bottom: calc(8em / 32 * 6); }
      .page-faq .faq-main .block-main .block-item .answer::before {
        content: 'A.';
        display: block;
        font-size: 1.23em;
        font-weight: 600;
        color: var(--gray);
        white-space: nowrap; }
      .page-faq .faq-main .block-main .block-item .answer p {
        color: var(--gray11); }
        .page-faq .faq-main .block-main .block-item .answer p strong {
          color: var(--gray12);
          border-bottom: dotted 2px var(--gray12); }

.page-policy .policy-main {
  font-family: monospace; }
  .page-policy .policy-main .policy-head {
    margin-bottom: calc(8em / 8 * 3);
    padding-bottom: calc(8em / 8 * 2);
    border-bottom: solid 1px var(--gray4); }
    @media screen and (max-width: 768px) {
      .page-policy .policy-main .policy-head {
        margin-bottom: calc(8em / 8 * 2);
        padding-bottom: calc(8em / 8 * 1); } }
    .page-policy .policy-main .policy-head h2 {
      font-size: 1.5575em; }
  .page-policy .policy-main .policy-body {
    padding: 0 16px; }
    @media screen and (max-width: 768px) {
      .page-policy .policy-main .policy-body {
        padding: 0; } }
    .page-policy .policy-main .policy-body h2 {
      font-size: 1.5575em; }
      @media screen and (max-width: 768px) {
        .page-policy .policy-main .policy-body h2 {
          font-size: 1.435em; } }
      .page-policy .policy-main .policy-body h2 ~ h2 {
        margin-top: 1.5em; }
    .page-policy .policy-main .policy-body ul {
      margin: 1em 0; }
      .page-policy .policy-main .policy-body ul.disc {
        padding-left: 1.23em; }
        .page-policy .policy-main .policy-body ul.disc > li {
          list-style-type: disc; }
      .page-policy .policy-main .policy-body ul.decimal {
        padding-left: 1.23em; }
        .page-policy .policy-main .policy-body ul.decimal > li {
          list-style-type: decimal; }
      .page-policy .policy-main .policy-body ul.contact {
        background: var(--black);
        padding: calc(8em / 16 * 3);
        border-radius: calc(8em / 32); }
    .page-policy .policy-main .policy-body a {
      color: var(--key10);
      text-decoration: underline; }
  .page-policy .policy-main .policy-foot {
    border-top: solid 1px var(--gray11);
    margin: calc(8em / 8 * 3) 0;
    padding: calc(8em / 8 * 3) 0; }
    @media screen and (max-width: 768px) {
      .page-policy .policy-main .policy-foot {
        margin: calc(8em / 8 * 2) 0;
        padding: calc(8em / 8 * 2) 0; } }
    .page-policy .policy-main .policy-foot p {
      display: table;
      margin-left: auto;
      font-size: .8em;
      color: var(--gray9); }

pre {
  white-space: normal;
  word-break: keep-all;
  overflow-wrap: break-word;
  line-break: strict; }

.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; } }

.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; }

/*//!#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; } }
/*ヘッダー調整*/
nav.globalNav ul.listGlobal li span.en {
  white-space: nowrap; }

/*page_csr*/
.card_text ._body > img {
  margin-bottom: 0.82em; }

/*page_career*/
.careerImg {
  margin-bottom: 2.05em; }

/*page_csr*/
dl.listSDGs dt > span {
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding-left: 0;
  margin: 0 1.23em; }

dl.listSDGs dt > span img {
  width: calc(50% - 2px); }

dl.listSDGs dt > span img:nth-child(n+3) {
  margin-top: 4px; }

/*page_business/~*/
p.writer {
  text-align: right;
  font-size: 1em;
  margin-top: 0.82em; }
  p.writer > span {
    display: block;
    font-size: .8em;
    margin-bottom: .205em; }

/*page_movie*/
.secPage.lp.movie h2.pageTtl {
  background: #fff; }

/*single-events*/
body.single-events .flexLower {
  margin-bottom: 6.15em; }

.secPage.basic.eventForm .wrapper {
  padding-bottom: 0; }

/*page_about 事業紹介 画像調整*/
@media screen and (max-width: 768px) {
  .type_wrapper ._stokerImg {
    position: absolute;
    right: 0;
    left: auto; } }
/*crosstalk 調整*/
.interview_wrapper ._body p.box ~ p.box {
  margin-top: 1.125em; }

.interview_wrapper ._body p.box span {
  font-size: 0.625em;
  font-weight: 600; }
