@charset "UTF-8";
*,
*::before,
*::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
  padding: 0;
  margin: 0;
}

:where([hidden]:not([hidden=until-found])) {
  display: none !important;
}

:where(html) {
  line-height: 1.5;
  -moz-tab-size: 2;
    -o-tab-size: 2;
       tab-size: 2;
  color-scheme: dark light;
  -webkit-text-size-adjust: none;
     -moz-text-size-adjust: none;
      -ms-text-size-adjust: none;
          text-size-adjust: none;
  scrollbar-gutter: stable;
  interpolate-size: allow-keywords;
}

:where(html:has(dialog:modal[open])) {
  overflow: clip;
}

@media (prefers-reduced-motion: no-preference) {
  :where(html:focus-within) {
    scroll-behavior: smooth;
  }
}
:where(body) {
  font-family: system-ui, sans-serif;
  line-height: inherit;
  -webkit-font-smoothing: antialiased;
}

:where(button) {
  all: unset;
}

:where(input, button, textarea, select) {
  font: inherit;
  font-variation-settings: inherit;
  -webkit-font-feature-settings: inherit;
          font-feature-settings: inherit;
  color: inherit;
  letter-spacing: inherit;
  word-spacing: inherit;
}

:where(textarea) {
  resize: block;
}

:where(button, label, select, summary, [role=button], [role=option]) {
  cursor: pointer;
}

:where(:disabled, label:has(> :disabled, + disabled)) {
  cursor: not-allowed;
}

:where(a) {
  color: inherit;
  text-underline-offset: 0.2ex;
}

:where(ul, ol) {
  list-style: none;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: inline-block;
}

:where(img, picture, svg, video) {
  max-inline-size: 100%;
  block-size: auto;
}

:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}

:where(h1, h2, h3) {
  line-height: calc(1em + 0.5rem);
}

:where(hr) {
  block-size: 0;
  overflow: visible;
  color: inherit;
  border: none;
  -webkit-border-before: 1px solid;
          border-block-start: 1px solid;
}

:where(dialog, [popover]) {
  inset: unset;
  max-width: unset;
  max-height: unset;
  overflow: unset;
  color: inherit;
  background: none;
  border: none;
}

:where(dialog:not([open], [popover]), [popover]:not(:popover-open)) {
  display: none !important;
}

:where(:focus-visible) {
  outline: 3px solid CanvasText;
  outline-offset: 1px;
  -webkit-box-shadow: 0 0 0 5px Canvas;
          box-shadow: 0 0 0 5px Canvas;
}

:where(:focus-visible, :target) {
  scroll-margin-block: 8vh;
}

:where(.visually-hidden:not(:focus-within, :active)) {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip-path: inset(50%) !important;
  white-space: nowrap !important;
  -webkit-user-select: none !important;
     -moz-user-select: none !important;
      -ms-user-select: none !important;
          user-select: none !important;
  border: 0 !important;
}

html {
  font-size: var(--ja-text-base, 16px);
  color: var(--ja-color-black);
}

body {
  font-family: var(--ja-font-base);
  font-weight: 400;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
  word-break: normal;
  overflow-wrap: anywhere;
  background: #fff;
  line-break: strict;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
}

button {
  inset: 0;
  padding: 0;
  font: inherit;
  color: inherit;
  background: none;
  border: none;
  outline: none;
}

:where(a) {
  color: currentcolor;
  text-decoration: none;
}

:where(img) {
  vertical-align: top;
}

:root {
  --ja-container-base: 400px;
  --ja-width-ratio: calc(400 / var(--ja-container-base) * 100%);
  --ja-vw: calc(100vw / var(--ja-container-base));
  --ja-text-base: calc(16 / var(--ja-width-ratio));
  --ja-font-base: 'DNP 秀英丸ゴシック Std', 'DNP Shuei Mgothic Std', 'MFW-UDShinGoNTPr6N-Light', 'MFW-UDShinGoHangKoc-Lig', 'Zen Maru Gothic', 'Yu Gothic', 'YuGothic', 'Meiryo', sans-serif;
  --ja-font-en: 'New Hero', 'Outfit', 'Arial', sans-serif;
  --ja-color-black: #000;
  --ja-color-1: #503f20;
  --ja-color-2: #f4eed1;
  --ja-color-3: #78ca74;
  --ja-color-4: #f0af3b;
  --ja-color-5: #21a3bd;
  --ja-color-primary: #058673;
  --ja-z-header: 10;
  --ja-z-menu: 9;
  --ja-hover-opacity: 0.6;
}
@media (min-width: 768px) {
  :root {
    --ja-width-ratio: calc(375 / var(--ja-container-base) * 100%);
    --ja-vw: calc(400px / var(--ja-container-base));
  }
}
@media (min-width: 1500px) {
  :root {
    --ja-vw: calc(580px / var(--ja-container-base));
  }
}

.siteContainer {
  position: relative;
  display: grid;
  grid-template-areas: "main";
  grid-template-columns: 1fr;
  background: var(--ja-color-3);
}
@media (min-width: 768px) {
  .siteContainer {
    grid-template-areas: "nav main";
    grid-template-columns: 1fr auto;
  }
}
@media (min-width: 1160px) {
  .siteContainer {
    grid-template-areas: "nav main kv";
    grid-template-columns: 1fr auto 1fr;
  }
}
@media (min-width: 1500px) {
  .siteContainer {
    grid-template-columns: 1fr auto 1fr;
  }
}

.siteNav {
  position: sticky;
  top: 0;
  z-index: 3;
  display: none;
  grid-area: nav;
  height: 100dvh;
}
@media (min-width: 768px) {
  .siteNav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
        -ms-flex-align: center;
            align-items: center;
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
    padding: calc(75 / 1920 * 100vw) 0 calc(75 / 1920 * 100vw) calc(64 / 1920 * 100vw);
  }
}

.siteKv {
  position: sticky;
  top: 0;
  display: none;
  grid-area: kv;
  height: 100dvh;
}
@media (min-width: 1160px) {
  .siteKv {
    display: block;
  }
}

.siteMain {
  position: relative;
  z-index: 3;
  grid-area: main;
  width: 100%;
  opacity: 0;
  -webkit-transition: opacity 0.7s 0.5s ease;
  transition: opacity 0.7s 0.5s ease;
  container-type: main;
}
@media (min-width: 768px) {
  .siteMain {
    width: 400px;
    margin-inline: calc(64 / 1920 * 100vw);
  }
}
@media (min-width: 1500px) {
  .siteMain {
    width: 580px;
    margin-inline: calc(64 / 1920 * 100vw);
  }
}
body.is-ready .siteMain {
  opacity: 1;
}

.hover-opacity {
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
@media (any-hover: hover) {
  .hover-opacity:hover {
    opacity: var(--ja-hover-opacity);
  }
}

#top .page > *:not(.footerBefore):nth-last-child(2) {
  padding-bottom: calc(96 / 1920 * 100vw);
}

.c-section {
  position: relative;
}
.c-section::before {
  position: absolute;
  top: calc(20px * var(--ja-vw));
  left: 0;
  width: 100%;
  height: calc(100% - 20px * var(--ja-vw));
  content: "";
  background: var(--ja-color-3);
  border-radius: calc(40px * var(--ja-vw));
}
.c-section .c-section_container {
  position: relative;
  z-index: 1;
  padding-bottom: calc(36px * var(--ja-vw));
}

.c-heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-bottom: calc(20px * var(--ja-vw));
}
.c-heading .c-heading_sub {
  position: relative;
  margin-bottom: calc(-4px * var(--ja-vw));
  font-size: calc(10px * var(--ja-vw));
  font-weight: bold;
  line-height: 1;
  color: var(--ja-color-5);
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.c-heading .c-heading_title {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: calc(138px * var(--ja-vw));
  height: calc(32px * var(--ja-vw));
  padding-inline: 1.5em;
  font-size: calc(16px * var(--ja-vw));
  font-weight: bold;
  letter-spacing: 0.1em;
  background: #fff;
  border-radius: 100vmax;
}

.c-buttonWrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: calc(6px * var(--ja-vw));
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.c-buttonWrapper:not(:first-child) {
  margin-top: calc(28px * var(--ja-vw));
}

.c-button {
  all: unset;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  min-width: calc(110px * var(--ja-vw));
  min-height: calc(28px * var(--ja-vw));
  padding: 0.5em 2em;
  font-size: calc(10px * var(--ja-vw));
  font-weight: bold;
  line-height: 1.3;
  color: #fff;
  letter-spacing: 0.03em;
  cursor: pointer;
  background: var(--ja-color-4);
  border-radius: 100vmax;
  -webkit-box-shadow: 3px 5px #fff;
          box-shadow: 3px 5px #fff;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
.c-button.--primary {
  background-color: var(--ja-color-primary);
}
@media (any-hover: hover) {
  .c-button:hover {
    -webkit-box-shadow: 0 0;
            box-shadow: 0 0;
    opacity: var(--ja-hover-opacity);
  }
}

.c-squereButton {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: calc(235 / 1920 * 100vw);
  aspect-ratio: 235/67;
  font-size: calc(20 / 1920 * 100vw);
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: var(--ja-color-4);
  border-radius: calc(25 / 1920 * 100vw);
  -webkit-transition: opacity 0.3s ease;
  transition: opacity 0.3s ease;
}
@media (any-hover: hover) {
  .c-squereButton:hover {
    opacity: var(--ja-hover-opacity);
  }
}
.c-squereButton.--primary {
  background-color: var(--ja-color-primary);
}

.c-link {
  color: var(--ja-color-5);
}
@media (any-hover: hover) {
  .c-link:hover {
    text-decoration: underline;
  }
}

.c-dot {
  margin-inline: -0.2em;
}

.nav {
  max-height: 100%;
  padding: 0;
}
.nav .container {
  width: 100%;
  max-height: calc(100dvh - 128 / 1920 * 100vw);
  padding: calc(24 / 1920 * 100vw) calc(45 / 1920 * 100vw);
  margin-inline: auto;
  overflow: auto;
  background: #fff;
  border-radius: min(20 / 1920 * 100vw, 20px);
}
.nav .heading > a,
.nav .heading {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 15px;
     -moz-column-gap: 15px;
          column-gap: 15px;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
}
.nav .heading > a .heading_logo,
.nav .heading .heading_logo {
  width: calc(320 / 1920 * 100vw);
}
.nav .heading > a .heading_text,
.nav .heading .heading_text {
  width: calc(200 / 1920 * 100vw);
}
.nav .navSection {
  display: grid;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.nav .navSection:not(:first-child) {
  margin-top: calc(40 / 1920 * 100vw);
}
.nav .navHeading {
  margin-bottom: calc(6 / 1920 * 100vw);
  font-size: max(18 / 1920 * 100vw, 16px);
  font-weight: bold;
  color: var(--ja-color-5);
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.nav .menu_list {
  display: grid;
  row-gap: min(30 / 1920 * 100vw, 20px);
}
.nav .menu_list li {
  line-height: 1;
}
.nav .menu_list a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 1.94em;
  padding-inline: 1em;
  font-size: clamp(14px, 18 / 1920 * 100vw, 18px);
  font-weight: bold;
  background: #fff;
  border: 2px solid #000;
  border-radius: 100vmax;
}
.nav .recruit .recruit_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: calc(19 / 1920 * 100vw);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.nav .recruit .recruit_button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 11.75em;
  aspect-ratio: 235/67;
  font-size: max(20 / 1920 * 100vw, 18px);
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: var(--ja-color-4);
  border-radius: calc(20 / 1920 * 100vw);
}
.nav .recruit .dp_button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 11.75em;
  aspect-ratio: 235/67;
  font-size: max(20 / 1920 * 100vw, 18px);
  font-weight: bold;
  color: #fff;
  text-align: center;
  background: var(--ja-color-primary);
  border-radius: calc(20 / 1920 * 100vw);
}
.nav .recruit .recruit_banner {
  width: calc(280 / 1920 * 100vw);
}
.nav .sns .sns_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: calc(8 / 1920 * 100vw);
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.nav .sns .sns_list a {
  display: block;
  width: 57px;
}
@media (min-width: 768px) {
  .nav {
    width: 100%;
    max-width: 417px;
  }
}
@media (min-width: 1160px) {
  .nav {
    width: auto;
  }
  .nav .heading .heading_logo {
    width: calc(185 / 1920 * 100vw);
  }
  .nav .heading .heading_text {
    width: calc(133 / 1920 * 100vw);
  }
  .nav .recruit .recruit_banner {
    width: calc(205 / 1920 * 100vw);
  }
  .nav .sns .sns_list a {
    width: calc(57 / 1920 * 100vw);
  }
}

.kv {
  position: relative;
  height: 100%;
}
.kv .kvImage {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.kv .kvImage::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  pointer-events: none;
  content: "";
  background: #000;
  mix-blend-mode: multiply;
  opacity: 0;
  -webkit-transition: 0.3s ease-in;
  transition: 0.3s ease-in;
}
.kv .kvImage:hover::before {
  opacity: 0.3;
}
.kv .kvImage_text {
  position: absolute;
  top: calc(30 / 1920 * 100vw);
  z-index: 8;
  width: 26.8656716418%;
  vertical-align: top;
  opacity: 0;
  -webkit-transition: 0.8s 0.8s ease-in-out;
  transition: 0.8s 0.8s ease-in-out;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: translateY(5px);
          transform: translateY(5px);
  will-change: transform;
}
.kv .kvImage_text:is(.kvImage.--left *) {
  left: calc(30 / 1920 * 100vw);
}
.kv .kvImage_text:is(.kvImage.--right *) {
  right: calc(30 / 1920 * 100vw);
}
.kv .kvImage_src {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  will-change: scale;
  -webkit-backface-visibility: hidden;
          backface-visibility: hidden;
}
.kv .kvLogo {
  position: absolute;
  bottom: calc(53 / 1920 * 100vw);
  left: 50%;
  z-index: 2;
  width: 82.7%;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
}
.kv .splide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
}
.kv .splide__slide {
  height: 100dvh;
}
.kv .splide__slide.is-active .kvImage .kvImage_text, .kv .splide__slide.is-prev .kvImage .kvImage_text, .kv .splide__slide .kvImage.is-prev .kvImage_text {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}
.kv .splide__slide.is-active .kvImage .kvImage_src, .kv .splide__slide.is-prev .kvImage .kvImage_src, .kv .splide__slide .kvImage.is-prev .kvImage_src {
  -webkit-animation: kv-scale 12s linear forwards;
          animation: kv-scale 12s linear forwards;
}
.kv .kvPointer {
  position: fixed;
  top: calc(-72.5 / 1920 * 100vw);
  left: calc(-72.5 / 1920 * 100vw);
  z-index: 2;
  pointer-events: none;
  opacity: 0;
  -webkit-transition: 0.2s ease-out;
  transition: 0.2s ease-out;
}
.kv .kvPointer img {
  display: block;
  width: calc(145 / 1920 * 100vw);
  height: calc(145 / 1920 * 100vw);
  -o-object-fit: contain;
     object-fit: contain;
}
.kv .kvPointer.is-active {
  opacity: 1;
  -webkit-transition: opacity 0.3s 0.5s ease-out, -webkit-transform 0.3s ease-out;
  transition: opacity 0.3s 0.5s ease-out, -webkit-transform 0.3s ease-out;
  transition: opacity 0.3s 0.5s ease-out, transform 0.3s ease-out;
  transition: opacity 0.3s 0.5s ease-out, transform 0.3s ease-out, -webkit-transform 0.3s ease-out;
}
@-webkit-keyframes kv-scale {
  0% {
    scale: 1;
  }
  0% {
    scale: 1.08;
  }
}
@keyframes kv-scale {
  0% {
    scale: 1;
  }
  0% {
    scale: 1.08;
  }
}

.kv-bottom {
  margin-top: calc(60 / 1920 * 100vw);
  text-align: center;
}
@media (min-width: 768px) {
  .kv-bottom {
    margin-top: calc(20 / 1920 * 100vw);
  }
}
.kv-bottom .c-squereButton {
  width: calc(800 / 1920 * 100vw);
  margin-inline: auto;
  font-size: calc(22 * var(--ja-vw));
}
@media (min-width: 768px) {
  .kv-bottom .c-squereButton {
    width: calc(300 / 1920 * 100vw);
  }
}

.page {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  min-height: var(--ja-vh);
  background: var(--ja-color-2);
}
.page .header {
  position: sticky;
  top: 0;
  z-index: var(--ja-z-header);
}
.page .header .container {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: calc(4px * var(--ja-vw));
     -moz-column-gap: calc(4px * var(--ja-vw));
          column-gap: calc(4px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
  padding: calc(12px * var(--ja-vw)) calc(8px * var(--ja-vw));
  background: #fff;
}
.page .header .logo {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: calc(4px * var(--ja-vw));
     -moz-column-gap: calc(4px * var(--ja-vw));
          column-gap: calc(4px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-inline: calc(8px * var(--ja-vw));
  margin-right: auto;
  margin-left: 0;
}
.page .header .logo_main {
  width: calc(120px * var(--ja-vw));
}
.page .header .logo_theme {
  width: calc(38px * var(--ja-vw));
}
.page .header .link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  height: calc(36px * var(--ja-vw));
  padding: calc(5px * var(--ja-vw)) calc(10px * var(--ja-vw));
  font-size: max(14px, 9px * var(--ja-vw));
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.075em;
  background: var(--ja-color-3);
  border-radius: calc(16px * var(--ja-vw));
}
.page .header .menu {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: calc(5px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: calc(40px * var(--ja-vw));
  aspect-ratio: 1/1;
  background: #000;
  border-radius: 100%;
}
@media (min-width: 768px) {
  .page .header .menu {
    display: none;
  }
}
.page .header .menu .menu_bar {
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(18px * var(--ja-vw));
  height: 2px;
  background: #fff;
  border-radius: 100vmax;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
.page .header .menu .menu_bar:nth-child(1) {
  top: calc(50% - 6px);
}
.page .header .menu .menu_bar:nth-child(3) {
  top: calc(50% + 6px);
}
body.is-open-menu .page .header .menu .menu_bar:nth-child(1) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(45deg);
          transform: translate(-50%, -50%) rotate(45deg);
}
body.is-open-menu .page .header .menu .menu_bar:nth-child(2) {
  opacity: 0;
}
body.is-open-menu .page .header .menu .menu_bar:nth-child(3) {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%) rotate(-45deg);
          transform: translate(-50%, -50%) rotate(-45deg);
}
.page .header .headerNav {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-height: 100dvh;
  overflow-y: auto;
  pointer-events: none;
  background: #fff;
  opacity: 0;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
  -webkit-transform: translateY(-10px);
          transform: translateY(-10px);
}
@media (min-width: 768px) {
  .page .header .headerNav {
    display: none !important;
  }
}
.page .header .headerNav .navList {
  padding: calc(80px * var(--ja-vw)) calc(26px * var(--ja-vw)) calc(40px * var(--ja-vw));
}
.page .header .headerNav .navList_item {
  padding-left: calc(26px * var(--ja-vw));
  border-bottom: 1px solid var(--ja-color-3);
}
.page .header .headerNav .navList_item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: 3.89em;
  padding: 0.25em 0;
  font-size: calc(18px * var(--ja-vw));
  font-weight: bold;
  line-height: 1.3;
}
.page .header .headerNav .navSubList {
  display: grid;
  row-gap: calc(10px * var(--ja-vw));
  padding-bottom: calc(28px * var(--ja-vw));
}
.page .header .headerNav .navSubList_item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: calc(14px * var(--ja-vw));
     -moz-column-gap: calc(14px * var(--ja-vw));
          column-gap: calc(14px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: max(14px, 9px * var(--ja-vw));
}
.page .header .headerNav .navSubList_item::before {
  width: 1.167em;
  aspect-ratio: 12/9;
  content: "";
  background: url("../images/icon_arrow.svg") 0 0 no-repeat;
  background-size: contain;
}
.page .header .headerNav .navSubList_item > a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-block: 0.25em;
  font-weight: bold;
  line-height: 1.3;
}
body.is-open-menu .page .header .headerNav {
  pointer-events: all;
  opacity: 1;
  -webkit-transition: 0.5s 0.2s ease;
  transition: 0.5s 0.2s ease;
  -webkit-transform: none;
          transform: none;
}
.page .footer {
  padding: calc(16px * var(--ja-vw));
  margin: auto 0 0;
  background: #fff;
}
.page .footer .head {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: calc(10px * var(--ja-vw));
     -moz-column-gap: calc(10px * var(--ja-vw));
          column-gap: calc(10px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-inline: calc(-4px * var(--ja-vw));
}
.page .footer .head_logo img {
  display: block;
  width: calc(166px * var(--ja-vw));
}
.page .footer .head_text {
  width: calc(110px * var(--ja-vw));
}
.page .footer .address {
  margin-top: calc(10px * var(--ja-vw));
  font-size: calc(10px * var(--ja-vw));
  font-style: normal;
  line-height: 1.4;
}
.page .footer .bottom {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}
.page .footer .copy {
  font-size: calc(10px * var(--ja-vw));
  letter-spacing: -0.025em;
}
.page .footer .sns {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: calc(8px * var(--ja-vw));
     -moz-column-gap: calc(8px * var(--ja-vw));
          column-gap: calc(8px * var(--ja-vw));
}
.page .footer .sns a {
  display: block;
  width: calc(50px * var(--ja-vw));
  aspect-ratio: 1/1;
}
.page .visual {
  width: 100%;
}
.page .visual video {
  display: block;
  width: 100%;
}

#news {
  margin-top: calc(36px * var(--ja-vw));
}
#news .container {
  padding-inline: calc(36px * var(--ja-vw));
}
#news .newsList {
  position: relative;
}
#news .newsList::after {
  position: absolute;
  bottom: calc(-2px * var(--ja-vw));
  left: calc(-4px * var(--ja-vw));
  display: inline-block;
  width: calc(100% + 8px * var(--ja-vw));
  height: calc(4px * var(--ja-vw));
  content: "";
  background: radial-gradient(circle farthest-side, var(--ja-color-5), var(--ja-color-5) 30%, transparent 30%, transparent);
  background-size: calc(8px * var(--ja-vw));
}
#news .newsList .newsList_item {
  position: relative;
  display: grid;
  grid-template-columns: calc(80px * var(--ja-vw)) 1fr;
  -webkit-column-gap: 0.25em;
     -moz-column-gap: 0.25em;
          column-gap: 0.25em;
  padding: calc(10px * var(--ja-vw)) calc(8px * var(--ja-vw)) calc(10px * var(--ja-vw)) calc(10px * var(--ja-vw));
  font-size: max(14px, 9px * var(--ja-vw));
  background: #fff;
}
#news .newsList .newsList_item::after {
  position: absolute;
  top: calc(-2px * var(--ja-vw));
  left: calc(-4px * var(--ja-vw));
  display: inline-block;
  width: calc(100% + 8px * var(--ja-vw));
  height: calc(4px * var(--ja-vw));
  content: "";
  background: radial-gradient(circle farthest-side, var(--ja-color-5), var(--ja-color-5) 30%, transparent 30%, transparent);
  background-size: calc(8px * var(--ja-vw));
}
#news .newsList .newsList_date,
#news .newsList .newsList_title {
  font-size: inherit;
  font-weight: 500;
  text-wrap: initial;
}

#intro {
  position: relative;
  padding-top: calc(40px * var(--ja-vw));
  margin-top: calc(40px * var(--ja-vw));
}
#intro::before {
  position: absolute;
  top: 0;
  left: 18%;
  width: 65%;
  aspect-ratio: 1/1;
  content: "";
  background: #fff;
  border-radius: 50%;
}
#intro .container {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  width: calc(312px * var(--ja-vw));
  margin-inline: auto;
}
#intro .heading {
  grid-column: span 2;
}
#intro .text {
  padding-top: calc(20px * var(--ja-vw));
  font-size: max(14px, 9px * var(--ja-vw));
  letter-spacing: 0.1em;
}
#intro .map {
  padding-top: calc(12px * var(--ja-vw));
  padding-left: calc(16px * var(--ja-vw));
}
#intro .map img {
  display: block;
  width: calc(110px * var(--ja-vw));
  aspect-ratio: 55.474/87.3515;
}

#business {
  margin-top: calc(40px * var(--ja-vw));
}
#business .container {
  padding-inline: calc(20px * var(--ja-vw));
}
#business .lead {
  width: calc(246px * var(--ja-vw));
  margin-inline: auto;
  font-size: max(14px, 9px * var(--ja-vw));
  text-align: center;
  letter-spacing: 0.1em;
}
#business .businessList {
  display: grid;
  row-gap: calc(14px * var(--ja-vw));
  margin-top: calc(16px * var(--ja-vw));
}
#business .businessList .link {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  min-height: calc(138px * var(--ja-vw));
  padding: calc(5px * var(--ja-vw)) calc(28px * var(--ja-vw));
  background: #fff;
  border-radius: calc(40px * var(--ja-vw));
}
#business .businessList .left {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: calc(10px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#business .businessList .icon {
  position: relative;
  width: calc(76px * var(--ja-vw));
  aspect-ratio: 1/1;
}
#business .businessList .icon::before {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  background: var(--ja-color-3);
  border-radius: 50%;
}
#business .businessList .icon img {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 1;
  width: calc(80px * var(--ja-vw));
  height: calc(76px * var(--ja-vw));
  -o-object-fit: contain;
     object-fit: contain;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
#business .businessList .title {
  font-size: calc(16px * var(--ja-vw));
  line-height: 1.25;
  color: var(--ja-color-primary);
  text-align: center;
  letter-spacing: 0.05em;
}
#business .businessList .text {
  font-size: max(14px, 9px * var(--ja-vw));
  line-height: 1.5;
  letter-spacing: 0.1em;
}
#business .businessList .item.--item03 .icon img {
  top: calc(50% - 8px * var(--ja-vw));
}
#business .businessList .item.--item04 .left {
  row-gap: 0;
}

#job {
  margin-top: calc(40px * var(--ja-vw));
}
#job .jobList {
  display: grid;
  row-gap: calc(40px * var(--ja-vw));
  padding-inline: calc(32px * var(--ja-vw));
}
#job .jobList .item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: calc(10px * var(--ja-vw)) calc(24px * var(--ja-vw));
}
#job .jobList .item + .item {
  margin-top: calc(40px * var(--ja-vw));
}
#job .jobList .thumb img {
  width: calc(130px * var(--ja-vw));
  aspect-ratio: 1/1;
  border-radius: 20px;
}
#job .jobList .content {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
}
#job .jobList .title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: baseline;
      -ms-flex-align: baseline;
          align-items: baseline;
  margin-top: -0.25em;
  font-size: calc(24px * var(--ja-vw));
  font-weight: bold;
  line-height: 1.5;
  color: #fff;
  letter-spacing: 0.1em;
}
#job .jobList .title small {
  margin-left: -0.5em;
  font-size: max(14px, 9px * var(--ja-vw));
  letter-spacing: 0;
}
#job .jobList .text {
  font-size: max(14px, 14px * var(--ja-vw));
  line-height: 1.75;
}
#job .jobList .bottom {
  display: grid;
  grid-template-columns: 1fr 1fr;
  -webkit-column-gap: calc(24px * var(--ja-vw));
     -moz-column-gap: calc(24px * var(--ja-vw));
          column-gap: calc(24px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 100%;
}
#job .jobList .c-button {
  min-width: auto;
  font-size: calc(15px * var(--ja-vw));
}

#recruit {
  margin-top: calc(40px * var(--ja-vw));
}
#recruit .flow {
  display: grid;
  grid-template-columns: auto 1fr;
  -webkit-column-gap: calc(20px * var(--ja-vw));
     -moz-column-gap: calc(20px * var(--ja-vw));
          column-gap: calc(20px * var(--ja-vw));
  padding: 0 calc(14px * var(--ja-vw)) 0 calc(20px * var(--ja-vw));
  margin-top: calc(30px * var(--ja-vw));
}
#recruit .flow .flow_img {
  grid-row: 1/6;
  grid-column: 1/2;
  margin: auto 0 0;
}
#recruit .flow .flow_img img {
  width: calc(150px * var(--ja-vw));
}
#recruit .flow .flow_row {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  padding-block: calc(10px * var(--ja-vw));
  font-size: max(12px, 9.5px * var(--ja-vw));
  line-height: 1.5;
}
#recruit .flow .flow_row:not(:first-of-type)::after {
  position: absolute;
  top: calc(-2px * var(--ja-vw));
  left: calc(-4px * var(--ja-vw));
  display: inline-block;
  width: calc(100% + 8px * var(--ja-vw));
  height: calc(4px * var(--ja-vw));
  content: "";
  background: radial-gradient(circle farthest-side, #fff, #fff 30%, transparent 30%, transparent);
  background-size: calc(8px * var(--ja-vw));
}
#recruit .flow .flow_row.--row01 {
  grid-row: 1/2;
  margin-top: -3em;
}
#recruit .flow .flow_row.--row02 {
  grid-row: 2/5;
}
#recruit .flow .flow_row.--row03 {
  grid-row: 5/6;
}

#question {
  margin-top: calc(60px * var(--ja-vw));
}
#question .container {
  padding-inline: calc(32px * var(--ja-vw));
}
#question .qaList {
  position: relative;
  counter-reset: qa;
}
#question .qaList::after {
  position: absolute;
  bottom: calc(-2px * var(--ja-vw));
  left: calc(-4px * var(--ja-vw));
  display: inline-block;
  width: calc(100% + 8px * var(--ja-vw));
  height: calc(4px * var(--ja-vw));
  content: "";
  background: radial-gradient(circle farthest-side, var(--ja-color-5), var(--ja-color-5) 30%, transparent 30%, transparent);
  background-size: calc(8px * var(--ja-vw));
}
#question .qaList .item {
  position: relative;
  display: grid;
  row-gap: calc(12px * var(--ja-vw));
  padding: calc(10px * var(--ja-vw)) calc(32px * var(--ja-vw)) calc(10px * var(--ja-vw)) calc(20px * var(--ja-vw));
  font-size: max(14px, 9px * var(--ja-vw));
  counter-increment: qa;
  background: #fff;
}
#question .qaList .item::after {
  position: absolute;
  top: calc(-2px * var(--ja-vw));
  left: calc(-4px * var(--ja-vw));
  display: inline-block;
  width: calc(100% + 8px * var(--ja-vw));
  height: calc(4px * var(--ja-vw));
  content: "";
  background: radial-gradient(circle farthest-side, var(--ja-color-5), var(--ja-color-5) 30%, transparent 30%, transparent);
  background-size: calc(8px * var(--ja-vw));
}
#question .qaList .item .q,
#question .qaList .item .a {
  display: grid;
  grid-template-columns: calc(30px * var(--ja-vw)) 1fr;
  -webkit-column-gap: calc(16px * var(--ja-vw));
     -moz-column-gap: calc(16px * var(--ja-vw));
          column-gap: calc(16px * var(--ja-vw));
  line-height: 1.45;
}
#question .qaList .item .q::before,
#question .qaList .item .a::before {
  font-family: var(--ja-font-en);
  font-size: min(20px, 2em);
  font-weight: 600;
  line-height: 1;
}
#question .qaList .item .q::before {
  margin-left: -0.09em;
  color: var(--ja-color-primary);
  content: "Q" counter(qa);
}
#question .qaList .item .a::before {
  color: var(--ja-color-4);
  content: "A" counter(qa);
}
#question .qaButtons {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: calc(14px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  margin-top: calc(44px * var(--ja-vw));
}
#question .qaButtons .c-squereButton {
  width: calc(300px * var(--ja-vw));
  font-size: calc(20px * var(--ja-vw));
}
#question .qaButtons .banner {
  width: calc(162px * var(--ja-vw));
}

#ad {
  padding-bottom: calc(100px * var(--ja-vw));
  margin-top: calc(30px * var(--ja-vw));
}
#ad .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#ad .c-squereButton {
  width: calc(300px * var(--ja-vw));
  font-size: calc(20px * var(--ja-vw));
}

.newsDetail {
  padding: calc(24px * var(--ja-vw)) calc(20px * var(--ja-vw));
}
.newsDetail .newsDetail_container {
  padding: calc(16px * var(--ja-vw)) calc(30px * var(--ja-vw));
  background: #fff;
}
.newsDetail .newsDetail_container .head {
  margin-bottom: calc(20px * var(--ja-vw));
}
.newsDetail .newsDetail_container .head_date {
  display: block;
  padding-bottom: calc(8px * var(--ja-vw));
  font-size: calc(12px * var(--ja-vw));
  font-weight: 500;
  line-height: 1;
  border-bottom: 1px solid var(--ja-color-5);
}
.newsDetail .newsDetail_container .head_title {
  display: block;
  padding: calc(10px * var(--ja-vw)) calc(8px * var(--ja-vw));
  font-size: calc(16px * var(--ja-vw));
  font-weight: 500;
  line-height: 1.5;
  border-bottom: 1px solid var(--ja-color-5);
}
.newsDetail .newsDetail_container .text {
  font-size: calc(12px * var(--ja-vw));
  line-height: 1.86;
  word-break: inherit;
}
.newsDetail .newsDetail_container .text:not(:first-child) {
  margin-top: calc(20px * var(--ja-vw));
}
.newsDetail .newsDetail_container .image img {
  width: 100%;
  height: auto;
}
.newsDetail .newsDetail_container .image:not(:first-child) {
  margin-top: calc(20px * var(--ja-vw));
}
.newsDetail .newsDetail_container .c-buttonWrapper {
  margin-top: calc(40px * var(--ja-vw));
}
.newsDetail .newsDetail_container .c-button {
  width: calc(110px * var(--ja-vw));
}
.newsDetail a {
  color: #1eaedb;
  text-decoration: underline;
  text-underline-offset: 4px;
}
.newsDetail a:hover {
  color: #0fa0ce;
}
.newsDetail {
  /* 中面コンテンツ
  –––––––––––––––––––––––––––––––––––––––––––––––––– */
}
.newsDetail .subtitle {
  display: block;
  padding: 8px 20px;
  margin: 30px 0 20px;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  background-color: #399595;
  border-radius: 10px 10px 0 0;
}
@media screen and (width >= 768px), print {
  .newsDetail .subtitle {
    padding: 8px 30px;
    margin: 40px -10px 20px;
    font-size: 24px;
  }
}
.newsDetail .rinen {
  margin: 0 0 50px;
  font-family: "Noto Serif JP", serif;
  font-size: 20px;
}
@media screen and (width >= 768px), print {
  .newsDetail .rinen {
    font-size: 30px;
  }
}
.newsDetail .honbun {
  margin: 0 0 40px;
}
@media screen and (width >= 768px), print {
  .newsDetail .honbun {
    margin: 0 0 50px;
  }
}
.newsDetail .honbun ul {
  display: block;
  width: 70%;
  padding: 0;
  margin: 30px auto;
  list-style: none;
}
@media screen and (width >= 768px), print {
  .newsDetail .honbun ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
        -ms-flex-pack: justify;
            justify-content: space-between;
    width: auto;
    margin: 30px 0;
  }
}
.newsDetail .honbun li {
  display: block;
  margin: 0 0 20px;
  text-align: center;
}
@media screen and (width >= 768px), print {
  .newsDetail .honbun li {
    width: 45%;
    margin: 0 20px;
  }
}
.newsDetail .honbun li img {
  width: 100%;
  height: auto;
  padding: 0 0 5px;
}
.newsDetail .danraku1 {
  padding: 0;
  padding-left: 1em;
  margin: 0;
  text-indent: -1em;
}
.newsDetail .danraku2 {
  padding: 0;
  padding-left: 2em;
  margin: 0;
  text-indent: -1em;
}
.newsDetail .linkicon {
  display: inline-block;
  padding: 0 0 0 20px;
  background-image: url("/images/common/linkicon.png");
  background-repeat: no-repeat;
  background-position: left 2px top 5px;
  background-size: 14px 14px;
}
.newsDetail .blank {
  display: inline-block;
  padding: 0 20px 0 0;
  background-image: url("/images/common/blank.png");
  background-repeat: no-repeat;
  background-position: right top 3px;
  background-size: 16px 14px;
}
.newsDetail .pdficon {
  padding: 0 20px 0 0;
  background-image: url("/images/common/pdficon.jpg");
  background-repeat: no-repeat;
  background-position: right top 7px;
  background-size: 14px 14px;
}
.newsDetail .pdficon2::after {
  display: inline-block;
  width: 14px;
  height: 14px;
  padding: 0 20px 0 0;
  content: "";
  background-image: url("/images/common/pdficon.jpg");
  background-repeat: no-repeat;
  background-position: right top 7px;
  background-size: 14px 14px;
}
.newsDetail .xlsicon {
  display: inline-block;
  padding: 0 0 0 20px;
  background-image: url("/images/common/xlsicon.png");
  background-repeat: no-repeat;
  background-position: left 2px top 5px;
  background-size: 14px 14px;
}
.newsDetail .mapicon {
  display: inline-block;
  padding: 4px 10px 2px;
  margin: 0 0 0 10px;
  font-size: 12px;
  color: #fff;
  background-color: #22ac38;
  border-radius: 4px;
}
.newsDetail .text {
  display: block;
  margin: 0 0 40px;
}
@media screen and (width >= 768px), print {
  .newsDetail .text a {
    display: inline-block;
  }
}
.newsDetail .text .text_bold {
  font-weight: bold;
}
.newsDetail .text span.sub {
  display: block;
  margin: 0 0 10px;
  font-size: 20px;
  border-bottom: solid 2px #e9a128;
}
.newsDetail .text span.subtitle1 {
  display: block;
  margin: 0 0 10px;
  font-size: 20px;
  border-bottom: solid 2px #e9a128;
}
.newsDetail .text span.maru {
  color: #e9a128;
}
.newsDetail .rargetext {
  display: block;
  margin: 0 0 40px;
  font-size: 1.2em;
}
.newsDetail .bunner {
  display: block;
  margin: 10px 0 0;
}
.newsDetail .linkicon-line {
  margin: 10px auto;
}
.newsDetail .linkicon-line a {
  padding: 4px 0 4px 20px;
  background-image: url("/images/common/linkicon.png");
  background-repeat: no-repeat;
  background-position: left 2px top 5px;
  background-size: 14px 14px;
}
.newsDetail .linkicon-line a::after {
  display: inline-block;
  width: 16px;
  height: 14px;
  margin-left: 2px;
  content: "";
}
.newsDetail .linkicon-line a[target=_blank]::after {
  background-image: url("/images/common/blank.png");
  background-position: center;
  background-size: 16px 14px;
}
.newsDetail .linkicon-line a[href$=".pdf"]::after {
  background-image: url("/images/common/pdficon.jpg");
  background-position: center;
  background-size: 14px 14px;
}
.newsDetail .c-buttonWrapper .c-button {
  color: white;
  text-decoration: none;
}

#main:has(.kv),
.article {
  padding: calc(20px * var(--ja-vw)) calc(32px * var(--ja-vw)) calc(32px * var(--ja-vw));
  background: var(--ja-color-3);
}
#main:has(.kv) > *:last-child,
.article > *:last-child {
  padding-bottom: calc(86px * var(--ja-vw));
}
#main:has(.kv).--job04 .kv .title,
.article.--job04 .kv .title {
  font-size: calc(28px * var(--ja-vw));
  letter-spacing: 0.025em;
}

#main .kv {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
#main .kv .image {
  position: relative;
  width: calc(186px * var(--ja-vw));
}
#main .kv .image img {
  width: 100%;
}
#main .kv .content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: calc(4px * var(--ja-vw));
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 86.9%;
  padding: calc(40px * var(--ja-vw)) calc(16px * var(--ja-vw)) calc(10px * var(--ja-vw));
  margin-top: calc(-36px * var(--ja-vw));
  font-weight: bold;
  color: var(--ja-color-primary);
  text-align: center;
  background: var(--ja-color-2);
  border-radius: calc(60px * var(--ja-vw));
}
#main .kv .title {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  font-size: calc(32px * var(--ja-vw));
  line-height: 1.1;
  letter-spacing: 0.1em;
}
#main .kv .title small {
  font-size: 0.6em;
}
#main .kv .text {
  font-size: max(14px, 9px * var(--ja-vw));
  line-height: 1.428;
  letter-spacing: 0.1em;
}
#main .unitWrapper {
  display: grid;
  row-gap: calc(32px * var(--ja-vw));
  margin-top: calc(23px * var(--ja-vw));
}
#main .unit {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  row-gap: calc(10px * var(--ja-vw));
  padding-inline: calc(12px * var(--ja-vw));
}
#main .unit .unit_item {
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  padding: calc(10px * var(--ja-vw)) calc(20px * var(--ja-vw));
  text-align: center;
  border-radius: calc(12px * var(--ja-vw));
}
#main .unit .unit_item::before {
  position: absolute;
  top: calc(10px * var(--ja-vw));
  width: calc(15px * var(--ja-vw));
  aspect-ratio: 15/13;
  content: "";
  -webkit-mask-image: url("../images/job/job_attach_01.svg");
          mask-image: url("../images/job/job_attach_01.svg");
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
  -webkit-mask-size: contain;
          mask-size: contain;
}
#main .unit .unit_item.--right {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: calc(16px * var(--ja-vw));
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.1em;
  background: var(--ja-color-primary);
}
#main .unit .unit_item.--right::before {
  right: calc(-10px * var(--ja-vw));
  background: var(--ja-color-primary);
}
#main .unit .unit_item.--left {
  font-size: max(14px, 9px * var(--ja-vw));
  text-align: left;
  background: var(--ja-color-2);
}
#main .unit .unit_item.--left::before {
  left: calc(-10px * var(--ja-vw));
  background: var(--ja-color-2);
  -webkit-transform: rotateY(180deg);
          transform: rotateY(180deg);
}
#main .unit .unit_image {
  display: block;
  width: 83.3%;
  margin-inline: auto;
}
#main .schedule {
  margin-top: calc(60px * var(--ja-vw));
}
#main .schedule img {
  display: block;
}
#main .movie {
  margin-top: calc(80px * var(--ja-vw));
}
#main .movie iframe {
  display: block;
  width: calc(320px * var(--ja-vw));
  height: 100%;
  aspect-ratio: 16/9;
  margin-inline: auto;
}

.footerBefore {
  width: 100%;
  overflow: hidden;
  background: var(--ja-color-3);
}
.footerBefore .splide {
  padding-inline: calc(8px * var(--ja-vw));
}
.footerBefore .splide .splide-wrapper {
  position: relative;
  padding-inline: calc(32px * var(--ja-vw));
}
.footerBefore .splide .splide__arrows {
  position: absolute;
  top: calc(36px * var(--ja-vw));
  left: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: 100%;
  pointer-events: none;
}
.footerBefore .splide .splide__arrow {
  width: calc(26px * var(--ja-vw));
  aspect-ratio: 26/56;
  pointer-events: all;
  background: center no-repeat;
  -webkit-transition: 0.3s ease;
  transition: 0.3s ease;
}
.footerBefore .splide .splide__arrow svg {
  display: none;
}
.footerBefore .splide .splide__arrow.splide__arrow--prev {
  background-image: url("../images/icon_prev.svg");
}
.footerBefore .splide .splide__arrow.splide__arrow--next {
  background-image: url("../images/icon_next.svg");
}
@media (any-hover: hover) {
  .footerBefore .splide .splide__arrow:hover {
    opacity: var(--ja-hover-opacity);
  }
}
.footerBefore .splide .splide__track {
  max-width: calc(100vw - 80px * var(--ja-vw));
}
.footerBefore .container {
  padding: calc(20px * var(--ja-vw)) 0 calc(32px * var(--ja-vw));
  background: var(--ja-color-2);
  border-radius: calc(44px * var(--ja-vw)) calc(44px * var(--ja-vw)) 0 0;
}
.footerBefore .link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}
.footerBefore .icon img {
  width: 100%;
  aspect-ratio: 69/64;
}
.footerBefore .title {
  margin-top: calc(10px * var(--ja-vw));
  font-size: calc(24px * var(--ja-vw));
  font-weight: bold;
  line-height: 1.2;
  color: var(--ja-color-primary);
  text-align: center;
  letter-spacing: 0.1em;
}
.footerBefore .title small {
  display: block;
  margin-top: calc(4px * var(--ja-vw));
  font-size: 0.7em;
  line-height: 1.3;
  letter-spacing: 0;
}

/* - コンテンツパーツヘッダー - */
[id=main] > h1,
[id=main] h2,
[id=main] h3,
[id=main] h4,
[id=main] h5,
[id=main] h6 {
  margin-top: inherit;
  margin-bottom: inherit;
}

.cnt-head_a h1,
.cnt-head_a h2,
.cnt-head_a h3,
.cnt-head_a h4,
.cnt-head_a h5,
.cnt-head_a h6 {
  display: block;
  padding: 10px 20px;
  margin: 20px 0;
  font-size: 18px;
  font-weight: bold;
  color: #fff;
  background-color: var(--ja-color-primary);
  border-radius: 10px;
}

@media screen and (width >= 768px), print {
  .cnt-head_a h1,
  .cnt-head_a h2,
  .cnt-head_a h3,
  .cnt-head_a h4,
  .cnt-head_a h5,
  .cnt-head_a h6 {
    margin: 40px 0 20px;
    font-size: 24px;
  }
}
.cnt-head_a span {
  float: right;
  padding-top: 5px;
  font-size: 16px;
  font-weight: normal;
}

.cnt-head_b h1,
.cnt-head_b h2,
.cnt-head_b h3,
.cnt-head_b h4,
.cnt-head_b h5,
.cnt-head_b h6 {
  display: block;
  padding: 4px;
  margin: 20px 0;
  font-size: 18px;
  font-weight: normal;
  border-bottom: solid 2px #e9a128;
}

@media screen and (width >= 768px), print {
  .cnt-head_b h1,
  .cnt-head_b h2,
  .cnt-head_b h3,
  .cnt-head_b h4,
  .cnt-head_b h5,
  .cnt-head_b h6 {
    margin: 30px 0 15px;
    font-size: 22px;
  }
}
.cnt-head_c h1,
.cnt-head_c h2,
.cnt-head_c h3,
.cnt-head_c h4,
.cnt-head_c h5,
.cnt-head_c h6 {
  display: block;
  padding: 4px;
  margin: 10px auto;
  font-size: 18px;
  font-weight: normal;
  background-color: #eee;
  border-left: solid 4px #e9a128;
}

@media screen and (width >= 768px), print {
  .cnt-head_c h1,
  .cnt-head_c h2,
  .cnt-head_c h3,
  .cnt-head_c h4,
  .cnt-head_c h5,
  .cnt-head_c h6 {
    padding: 6px 10px 6px 6px;
    margin: 20px auto 10px;
    font-size: 20px;
  }
}
.cnt-head_d h1,
.cnt-head_d h2,
.cnt-head_d h3,
.cnt-head_d h4,
.cnt-head_d h5,
.cnt-head_d h6 {
  display: block;
  padding: 4px 8px;
  margin: 10px auto;
  font-size: 18px;
  font-weight: bold;
}

@media screen and (width >= 768px), print {
  .cnt-head_d h1,
  .cnt-head_d h2,
  .cnt-head_d h3,
  .cnt-head_d h4,
  .cnt-head_d h5,
  .cnt-head_d h6 {
    padding: 6px 10px;
    margin: 20px auto 10px;
    font-size: 20px;
  }
}
.cnt-head_e h1,
.cnt-head_e h2,
.cnt-head_e h3,
.cnt-head_e h4,
.cnt-head_e h5,
.cnt-head_e h6 {
  position: relative;
  display: block;
  padding: 4px 8px 4px 20px;
  margin: 10px auto;
  font-size: 1em;
  font-weight: normal;
}

.cnt-head_e h1::before,
.cnt-head_e h2::before,
.cnt-head_e h3::before,
.cnt-head_e h4::before,
.cnt-head_e h5::before,
.cnt-head_e h6::before {
  position: absolute;
  top: 50%;
  left: 5px;
  display: block;
  width: 0.5em;
  height: 0.5em;
  content: "";
  background-color: #e9a128;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

@media screen and (width >= 768px), print {
  .cnt-head_e h1,
  .cnt-head_e h2,
  .cnt-head_e h3,
  .cnt-head_e h4,
  .cnt-head_e h5,
  .cnt-head_e h6 {
    padding: 6px 10px 6px 20px;
    margin: 20px auto 10px;
    font-size: 1.1em;
  }
}
.orange-list {
  margin: 1em 0;
}

.orange-list ul {
  padding: 0;
  margin: 0;
  list-style: none;
}

.orange-list li {
  position: relative;
  padding-left: 1em;
  margin: 4px 0;
}

.orange-list li::before {
  position: absolute;
  top: 0.5em;
  left: 0;
  display: block;
  width: 0.6em;
  height: 0.6em;
  content: "";
  background-color: #e9a128;
  border-radius: 30px;
}

/* - 中面お問い合わせ - */
.page-contact {
  display: block;
  width: 95%;
  padding: 0;
  margin: 20px auto 40px;
  line-height: 1.2em;
  text-align: center;
  background-color: #fff;
  border: solid 4px #e9a128;
}

@media screen and (width >= 768px), print {
  .page-contact {
    max-width: 800px;
    padding: 0;
    margin: 30px auto 50px;
  }
}
.page-contact .page-contact_label {
  display: block;
  padding: 8px 0;
  margin: 0;
  font-size: 1em;
  color: #fff;
  background-color: #e9a128;
}

.page-contact .page-contact_body {
  padding: 20px;
}

.page-contact ul {
  display: block;
  padding: 20px 0 0;
  margin: 0;
  list-style: none;
}

@media screen and (width >= 768px), print {
  .page-contact ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    padding: 20px 20px 0;
  }
}
.page-contact ul li {
  display: block;
  padding: 0;
  margin: 4px 10px;
  font-size: 14px;
  color: #555;
  text-align: left;
}

@media screen and (width >= 768px), print {
  .page-contact ul li {
    width: calc(50% - 10px);
    margin: 0 20px 0 0;
  }
  .page-contact ul li:nth-of-type(2n) {
    margin: 0;
  }
}
.page-contact ul li span {
  padding-right: 4px;
  color: #e9a128;
}

.page-contact .naming {
  display: block;
  padding: 10px 0 0;
  margin: 0 10px;
}

@media screen and (width >= 768px), print {
  .page-contact .naming {
    margin: 0 20px 0 10px;
  }
}
.page-contact .naming span {
  padding-right: 4px;
  color: #e9a128;
}

.gray_waku {
  display: block;
  padding: 20px;
  margin: 30px 0;
  background-color: #fff;
  border: solid 2px #bfbfbf;
}

.separater {
  padding: 20px 0;
}

@media screen and (width >= 768px), print {
  .separater {
    padding: 30px 0;
    margin: 30px 0;
  }
}
.separater::after {
  display: block;
  clear: both;
  content: "";
}

.separater hr {
  border: none;
}

.separater .style1 {
  border-top: solid 1px #2a9897;
}

.separater .style2 {
  width: 20%;
  margin-right: auto;
  margin-left: auto;
  border-top: solid 1px #2a9897;
}

.separater .style3 {
  border-top: double 3px #2a9897;
}

.separater .style4 {
  border-top: dashed 1px #2a9897;
  border-bottom: dashed 1px #fff;
}

.separater .style5 {
  border: none;
}

.noattach-images {
  margin: 40px 0;
  text-align: center;
}

@media screen and (width >= 768px), print {
  .noattach-images {
    margin: 30px 0;
  }
}
.noattach-images img {
  max-width: 100%;
  height: auto;
}

.attached-images {
  margin: 40px 0;
  text-align: center;
}

@media screen and (width >= 768px), print {
  .attached-images {
    margin: 30px 0;
  }
}
.attached-images img {
  width: 100%;
  height: auto;
}

.textcopy {
  margin: 40px auto;
  font-family: "Noto Serif JP", "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;
  font-size: 1.1rem;
  line-height: 1.4;
  color: #555;
  text-align: left;
}

@media screen and (width >= 768px), print {
  .textcopy {
    font-size: 1.2rem;
  }
}
.textcopy-big {
  font-size: 2rem;
}

@media screen and (width >= 768px), print {
  .textcopy-big {
    font-size: 2.2rem;
  }
}
.textcopy-theme {
  color: #2a9897;
}

.textcopy p {
  margin-top: 0.5em;
}

.normal-txt {
  margin: 10px 0 20px;
}

@media screen and (width >= 768px), print {
  .normal-txt {
    margin: 30px 0 50px;
  }
}
@media screen and (width >= 768px), print {
  .inline-linkbtns {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}
.inline-linkbtns a {
  display: inline-block;
  padding: 10px 20px;
  color: #fff;
  background-color: #e9a128;
  border: solid 1px #e9a128;
  border-radius: 4px;
}

@media screen and (width >= 768px), print {
  .inline-linkbtns a {
    padding: 10px 30px;
    margin: 10px;
  }
}
.linkbutton {
  display: block;
  width: 100%;
  padding: 0;
  margin: 30px 0;
}

@media screen and (width >= 768px), print {
  .linkbutton {
    display: inline-block;
    width: 50%;
    margin: 0 -0.3em 0 0;
    vertical-align: top;
  }
}
.linkbutton_wrap {
  padding: 0 25px;
}

@media screen and (width >= 768px), print {
  .linkbutton_wrap {
    padding: 20px;
  }
}
.linkbutton a {
  position: relative;
  display: block;
  padding: 20px 15px;
  font-size: 18px;
  color: #555;
  text-align: center;
  text-decoration: none;
  background-color: #fff;
  border: solid 1px #2a9897;
  border-radius: 4px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

@media screen and (width >= 768px), print {
  .linkbutton a {
    padding: 10px 35px 10px 15px;
    text-align: left;
  }
}
.linkbutton a:hover {
  color: #2a9897;
  background-color: #f6f6f6;
  border-color: #2a9897;
}

.linkbutton a::after {
  position: absolute;
  top: 50%;
  right: 10px;
  display: block;
  width: 0.5em;
  height: 0.5em;
  content: "";
  border-top: solid 2px #2a9897;
  border-right: solid 2px #2a9897;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.linkbutton a.blank::after {
  width: 1em;
  height: 1em;
  background-image: url("../assets/images/icon-blank_b.svg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton a[target=_blank]::after {
  width: 1em;
  height: 1em;
  background-image: url("../assets/images/icon-blank_b.svg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton a[href$=".pdf"]::after {
  width: 14px;
  height: 14px;
  background-image: url("../../../images/common/pdficon.jpg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton.gray a {
  color: #fff;
  background-color: #666;
  border: solid 1px #666;
}

.linkbutton.gray a:hover {
  color: #666;
  background-color: #fff;
  border-color: #666;
}

.linkbutton-three {
  display: block;
  width: 100%;
  padding: 0;
  margin: 30px 0;
}

@media screen and (width >= 768px), print {
  .linkbutton-three {
    display: inline-block;
    width: 33.33%;
    margin: 0 -0.3em 0 0;
    vertical-align: top;
  }
}
.linkbutton-three_wrap {
  padding: 0 25px;
}

@media screen and (width >= 768px), print {
  .linkbutton-three_wrap {
    padding: 20px;
  }
}
.linkbutton-three a {
  position: relative;
  display: block;
  padding: 20px 15px;
  font-size: 18px;
  color: #555;
  text-align: center;
  text-decoration: none;
  background-color: #fff;
  border: solid 1px #2a9897;
  border-radius: 4px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

@media screen and (width >= 768px), print {
  .linkbutton-three a {
    padding: 10px 35px 10px 15px;
    text-align: left;
  }
}
.linkbutton-three a:hover {
  color: #2a9897;
  background-color: #f6f6f6;
  border-color: #2a9897;
}

.linkbutton-three a::after {
  position: absolute;
  top: 50%;
  right: 10px;
  display: block;
  width: 0.5em;
  height: 0.5em;
  content: "";
  border-top: solid 2px #2a9897;
  border-right: solid 2px #2a9897;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.linkbutton-three a.blank::after {
  width: 1em;
  height: 1em;
  background-image: url("../assets/images/icon-blank_b.svg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton-three a[target=_blank]::after {
  width: 1em;
  height: 1em;
  background-image: url("../assets/images/icon-blank_b.svg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton-three a[href$=".pdf"]::after {
  width: 14px;
  height: 14px;
  background-image: url("../../../images/common/pdficon.jpg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton-three.gray a {
  color: #fff;
  background-color: #666;
  border: solid 1px #666;
}

.linkbutton-three.gray a:hover {
  color: #666;
  background-color: #fff;
  border-color: #666;
}

.linkbutton-free {
  display: block;
  width: auto;
  padding: 0;
  margin: 30px 0;
}

@media screen and (width >= 768px), print {
  .linkbutton-free {
    display: inline-block;
    width: auto;
    margin: 0 -0.3em 0 0;
    vertical-align: top;
  }
}
.linkbutton-free_wrap {
  padding: 0 25px;
}

@media screen and (width >= 768px), print {
  .linkbutton-free_wrap {
    padding: 20px;
  }
}
.linkbutton-free a {
  position: relative;
  display: block;
  padding: 20px 15px;
  font-size: 18px;
  color: #555;
  text-align: center;
  text-decoration: none;
  background-color: #fff;
  border: solid 1px #2a9897;
  border-radius: 4px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

@media screen and (width >= 768px), print {
  .linkbutton-free a {
    padding: 10px 35px 10px 15px;
    text-align: left;
  }
}
.linkbutton-free a:hover {
  color: #2a9897;
  background-color: #f6f6f6;
  border-color: #2a9897;
}

.linkbutton-free a::after {
  position: absolute;
  top: 50%;
  right: 10px;
  display: block;
  width: 0.5em;
  height: 0.5em;
  content: "";
  border-top: solid 2px #2a9897;
  border-right: solid 2px #2a9897;
  -webkit-transform: translateY(-50%) rotate(45deg);
          transform: translateY(-50%) rotate(45deg);
}

.linkbutton-free a.blank::after {
  width: 1em;
  height: 1em;
  background-image: url("../assets/images/icon-blank_b.svg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton-free a[target=_blank]::after {
  width: 1em;
  height: 1em;
  background-image: url("../assets/images/icon-blank_b.svg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton-free a[href$=".pdf"]::after {
  width: 14px;
  height: 14px;
  background-image: url("../../../images/common/pdficon.jpg");
  background-repeat: no-repeat;
  background-size: contain;
  border: none;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.linkbutton-free.gray a {
  color: #fff;
  background-color: #666;
  border: solid 1px #666;
}

.linkbutton-free.gray a:hover {
  color: #666;
  background-color: #fff;
  border-color: #666;
}

.set3images {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 60px auto;
}

.set3images_box {
  width: 33.33%;
}

.set3images_img img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media screen and (width <= 767px) {
  .sbys-images {
    display: block;
    width: 100%;
    margin: 40px 0;
    letter-spacing: -0.5em;
  }
  .sbys-images.block4 {
    padding-right: 20px;
  }
  .sbys-images_box {
    display: inline-block;
    letter-spacing: normal;
    vertical-align: top;
  }
  .block2 .sbys-images_box,
  .block3 .sbys-images_box {
    width: 100%;
  }
  .block2 .sbys-images_box:nth-of-type(n + 2),
  .block3 .sbys-images_box:nth-of-type(n + 2) {
    margin-top: 20px;
  }
  .block4 .sbys-images_box {
    width: 50%;
    margin-right: 20px;
  }
  .block4 .sbys-images_box:nth-of-type(2n) {
    margin-right: -20px;
  }
  .block4 .sbys-images_box:nth-of-type(n + 3) {
    margin-top: 20px;
  }
  .sbys-images_img {
    text-align: center;
  }
  .sbys-images_img img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
  }
  .sbys-images_txt {
    margin-top: 0.5em;
    text-align: center;
    letter-spacing: normal;
  }
  .imgbox {
    display: inline-block;
    margin: 20px -0.3em 0 0;
    vertical-align: top;
  }
  .imgbox.block2 {
    width: 100%;
  }
  .imgbox.block3 {
    width: 100%;
  }
  .imgbox.block4 {
    width: 50%;
  }
  .imgbox_wrap {
    padding: 0 15px;
  }
  .imgbox_img img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
  }
  .imgbox_txt {
    margin-top: 0.5em;
    font-size: medium;
  }
  .imgbox_txt p ~ p {
    margin-top: 0;
  }
  .imgbox a {
    color: #555;
    text-decoration: none;
  }
  .linkbutton_ledge {
    margin: 40px auto;
  }
  .linkbutton_ledge a {
    position: relative;
    display: block;
    height: 50px;
    margin: 0 auto;
    margin-top: 4px;
    font-size: 14px;
    color: #fff;
    text-align: center;
    text-decoration: none;
    border-radius: 6px;
    -webkit-transform: translateY(-4px);
            transform: translateY(-4px);
  }
  .linkbutton_ledge a span {
    position: absolute;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    padding-top: 12px;
    border-radius: 6px;
  }
  .linkbutton_ledge a::before {
    position: absolute;
    top: calc(50% - 9px);
    right: 20px;
    z-index: 10;
    display: block;
    width: 10px;
    height: 10px;
    content: "";
    border-top: solid 4px #fff;
    border-right: solid 4px #fff;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .linkbutton_ledge a::after {
    position: absolute;
    bottom: -4px;
    display: block;
    width: 100%;
    height: 100%;
    content: "";
    border-radius: 6px;
  }
  .linkbutton_ledge a:active {
    background-color: #fff;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  .linkbutton_ledge a:active::after {
    bottom: 0;
  }
  .linkbutton_ledge .middle {
    width: 260px;
  }
  .linkbutton_ledge .large {
    width: 100%;
  }
  .linkbutton_ledge .red span {
    background-color: #d84914;
  }
  .linkbutton_ledge .red::after {
    background-color: #ab3707;
  }
  .linkbutton_ledge .green span {
    background-color: #3c7639;
  }
  .linkbutton_ledge .green::after {
    background-color: #275423;
  }
}
@media screen and (width >= 768px), print {
  .sbys-images {
    display: block;
    width: 100%;
    margin: 40px 0;
    letter-spacing: -0.5em;
  }
  .sbys-images.block2 {
    padding-right: 40px;
  }
  .sbys-images.block3 {
    padding-right: 80px;
  }
  .sbys-images.block4 {
    padding-right: 120px;
  }
  .sbys-images_box {
    display: inline-block;
    letter-spacing: normal;
    vertical-align: top;
  }
  .block2 .sbys-images_box {
    width: 50%;
    margin-right: 40px;
  }
  .block2 .sbys-images_box:nth-of-type(2n) {
    margin-right: -40px;
  }
  .block3 .sbys-images_box {
    width: 33.33%;
    margin-right: 40px;
  }
  .block3 .sbys-images_box:nth-of-type(3n) {
    margin-right: -80px;
  }
  .block4 .sbys-images_box {
    width: 25%;
    margin-right: 40px;
  }
  .block4 .sbys-images_box:nth-of-type(4n) {
    margin-right: -120px;
  }
  .sbys-images_img {
    text-align: center;
  }
  .sbys-images_img img {
    max-width: 100%;
    height: auto;
    vertical-align: bottom;
  }
  .sbys-images_txt {
    margin-top: 0.5em;
    text-align: center;
    letter-spacing: normal;
  }
  .imgbox {
    display: inline-block;
    margin: 40px -0.3em 0 0;
    vertical-align: top;
  }
  .imgbox.block2 {
    width: 50%;
  }
  .imgbox.block3 {
    width: 33.33%;
  }
  .imgbox.block4 {
    width: 25%;
  }
  .imgbox_wrap {
    padding: 0 15px;
  }
  .imgbox_img img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
  }
  .imgbox_txt {
    margin-top: 0.5em;
    font-size: medium;
  }
  .imgbox_txt p ~ p {
    margin-top: 0;
  }
  .imgbox a {
    color: #555;
    text-decoration: none;
  }
  .linkbutton_ledge {
    margin: 40px auto;
  }
  .linkbutton_ledge a {
    position: relative;
    display: block;
    height: 60px;
    margin: 0 auto;
    margin-top: 4px;
    font-size: 18px;
    color: #fff;
    text-align: center;
    text-decoration: none;
    border-radius: 6px;
    -webkit-transform: translateY(-4px);
            transform: translateY(-4px);
  }
  .linkbutton_ledge a span {
    position: absolute;
    z-index: 1;
    display: block;
    width: 100%;
    height: 100%;
    padding-top: 15px;
    border-radius: 6px;
  }
  .linkbutton_ledge a::before {
    position: absolute;
    top: calc(50% - 9px);
    right: 20px;
    z-index: 10;
    display: block;
    width: 10px;
    height: 10px;
    content: "";
    border-top: solid 4px #fff;
    border-right: solid 4px #fff;
    -webkit-transform: rotate(45deg);
            transform: rotate(45deg);
  }
  .linkbutton_ledge a::after {
    position: absolute;
    bottom: -4px;
    display: block;
    width: 100%;
    height: 100%;
    content: "";
    border-radius: 6px;
  }
  .linkbutton_ledge a:active {
    background-color: #fff;
    -webkit-transform: translateY(0);
            transform: translateY(0);
  }
  .linkbutton_ledge a:active::after {
    bottom: 0;
  }
  .linkbutton_ledge .middle {
    width: 260px;
  }
  .linkbutton_ledge .large {
    width: 360px;
  }
  .linkbutton_ledge .red span {
    background-color: #d84914;
  }
  .linkbutton_ledge .red::after {
    background-color: #ab3707;
  }
  .linkbutton_ledge .green span {
    background-color: #3c7639;
  }
  .linkbutton_ledge .green::after {
    background-color: #275423;
  }
}