@charset "UTF-8";
:root {
  background-color: var(--color-project-base);
  color: var(--color-black);
}

html {
  font-size: clamp(1rem, 0.766rem + 1vw, 1.125rem);
  height: 100%;
  line-break: strict;
}

body {
  font-family: "inter", "Noto Sans JP", "Hiragino Kaku Gothic Pro", "Hiragino Sans", "游ゴシック体", YuGothic, "游ゴシック", Meiryo, sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  height: 100%;
}

h1, h2, h3, h4, h5, ul, dl {
  font-weight: normal;
  margin: 0;
  padding: 0;
}

ul, ol {
  padding: 0;
  margin: 0;
  list-style-type: none;
  overflow: hidden;
}

a {
  outline: 0;
  text-decoration: none;
}

p, dt, dd, li {
  line-height: 1.75;
  margin: 0;
  padding: 0;
}
p a, p span, dt a, dt span, dd a, dd span, li a, li span {
  color: inherit;
  font-size: inherit;
}

table {
  border-collapse: collapse;
  width: 100%;
}
table th, table td {
  padding: 0.5em 1em;
}
table th dt, table th dd, table th li, table th a, table th span, table td dt, table td dd, table td li, table td a, table td span {
  font-size: inherit;
}

figure {
  margin: 0;
}

.for-large {
  display: none;
}

.for-small {
  display: block;
}

.hover-fade {
  transition-property: opacity;
  transition-duration: var(--animate-duration);
  transition-timing-function: var(--animate-easing);
  transition-delay: 0s;
}
.hover-fade:hover {
  opacity: var(--animate-opacity);
}

.img-fit {
  height: auto;
  width: 100%;
}

.layout-max,
.layout-primary,
.layout-secondary {
  margin-right: var(--margin-side-small);
  margin-left: var(--margin-side-small);
  width: auto;
}

.ol-lower,
.ol-number,
.ol-upper {
  overflow: visible;
  padding-left: 2rem;
}

.ol-lower {
  list-style-type: lower-alpha;
}

.ol-number {
  list-style-type: decimal;
}

.ol-upper {
  list-style-type: upper-alpha;
}

.text-nowrap {
  display: inline-block;
  white-space: nowrap;
}

.ul-disc,
.ul-halfnote,
.ul-hyphen,
.ul-note {
  overflow: hidden;
}
.ul-disc li,
.ul-halfnote li,
.ul-hyphen li,
.ul-note li {
  padding-left: 1em;
}
.ul-disc li:before,
.ul-halfnote li:before,
.ul-hyphen li:before,
.ul-note li:before {
  margin-left: -1rem;
  width: 1rem;
}

.ul-disc li:before {
  content: "・";
}

.ul-halfnote li:before {
  content: "*";
}

.ul-hyphen li:before {
  content: "-";
}

.ul-note li:before {
  content: "※";
}

.site-article > .header {
  margin-bottom: 2.5rem;
}
.site-article > .header > .date {
  color: #b3b3b3;
  display: block;
  margin-bottom: 1rem;
}
.site-article > .content {
  margin-bottom: 3rem;
}

.site-block {
  margin: 4rem 0;
}
.site-block.-fill {
  background-color: var(--color-project-base);
  margin: 0;
  padding: 4rem 0;
}
.site-block.-fill.-blue {
  background-color: var(--color-project-blue);
  color: var(--color-white);
}
.site-block.-fill.-lavender {
  background-color: var(--color-project-lavender);
}
.site-block.-fill.-tite {
  margin: 0;
  padding: 4rem 0;
}
.site-block.-recruit {
  background: rgb(0, 86, 220);
  color: var(--color-white);
  margin: 0;
  padding: 4rem 0;
  position: relative;
}
.site-block.-recruit::before {
  background: url(../images/home/image_recruit.jpg) right top no-repeat;
  background-size: contain;
  content: "";
  position: absolute;
  inset: 0 0 auto auto;
  height: 100%;
  width: 100%;
  z-index: 1;
}
@supports (background-image: url("../images/home/image_recruit.webp")) {
  .site-block.-recruit::before {
    background-image: url("../images/home/image_recruit.webp");
  }
}
.site-block.-recruit > * {
  position: relative;
  z-index: 3;
}

.site-breadcrumbs {
  background-color: var(--color-border);
}
.site-breadcrumbs > .inner {
  margin-left: var(--margin-side-small);
  position: relative;
  width: auto;
}
.site-breadcrumbs > .inner::after {
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  right: 0;
  top: 0;
  z-index: 5;
  width: 2rem;
}

.site-breadcrumbs-list {
  display: flex;
  overflow-x: scroll;
  white-space: nowrap;
}
.site-breadcrumbs-list > .list {
  font-size: 0.8125rem;
  margin-right: 1em;
  padding-right: 2em;
  position: relative;
}
.site-breadcrumbs-list > .list::after {
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_right-secondary.svg);
  mask-image: url(../images/icon/arrow_right-secondary.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  position: absolute;
  top: 1em;
  right: 0;
  width: 0.875rem;
}
.site-breadcrumbs-list > .list:last-child::after {
  content: none;
}
.site-breadcrumbs-list > .list > .item {
  color: #666666;
  display: block;
  font-size: 0.8125rem;
  padding: 1em 0;
}

.site-button-primary {
  transition-property: background, border, color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-color: var(--color-project-blue);
  border: 1px solid var(--color-project-blue);
  border-radius: 100vw;
  color: var(--color-white);
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.2;
  padding: 0.75rem 2.5rem;
  text-decoration: none;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}
.site-button-primary::after {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  aspect-ratio: 1/1;
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 1.125rem;
  width: 1.125rem;
}
.site-button-primary:hover {
  background-color: var(--color-white);
  color: var(--color-project-blue);
}
.site-button-primary:hover::after {
  transform: translateX(0.25rem);
}
.site-button-primary.-popup::after {
  -webkit-mask-image: url(../images/icon/popup.svg);
  mask-image: url(../images/icon/popup.svg);
}

.site-button-text {
  transition-property: background-size;
  transition-duration: 0.6s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-image: linear-gradient(rgba(0, 36, 170, 0) 0%, rgb(0, 36, 170) 0%);
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: 0 1px;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-project-blue);
  font-size: 1.125rem;
  font-weight: 900;
  text-decoration: none;
}
.site-button-text::after {
  aspect-ratio: 1/1;
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 1.125rem;
  width: 1.125rem;
}
.site-button-text.-popup::after {
  -webkit-mask-image: url(../images/icon/popup.svg);
  mask-image: url(../images/icon/popup.svg);
}
.site-button-text.-light {
  background-image: linear-gradient(rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 0%);
  color: var(--color-white);
}
.site-button-text.-short {
  font-size: 1rem;
  font-weight: 500;
}
.site-button-text:hover {
  background-position: left bottom;
  background-size: 100% 1px;
}

.site-chapter {
  padding-top: 5rem;
}

.site-cms-pager {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  font-size: 1rem;
  margin-top: var(--spacing-two);
  text-align: center;
}
.site-cms-pager .page-numbers {
  transition-property: background-color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-color: var(--color-light-grey);
  border: none;
  font-size: inherit;
  margin: 0 1px;
  padding: 8px 10px;
  position: relative;
  text-decoration: none;
}
.site-cms-pager .page-numbers:hover, .site-cms-pager .page-numbers.current {
  background-color: var(--color-primary);
  color: var(--color-white);
}
.site-cms-pager .page-numbers.dots {
  padding: 0;
}
.site-cms-pager .page-numbers.dots:hover {
  color: var(--color-black);
}
.site-cms-pager .page-numbers.dots:after {
  content: none;
}
.site-cms-pager .page-numbers.prev {
  display: none;
}
.site-cms-pager .page-numbers.prev:before {
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_left-secondary.svg);
  mask-image: url(../images/icon/arrow_left-secondary.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  width: 0.875rem;
  line-height: 1;
}
.site-cms-pager .page-numbers.next {
  display: none;
}
.site-cms-pager .page-numbers.next:after {
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_right-secondary.svg);
  mask-image: url(../images/icon/arrow_right-secondary.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  width: 0.875rem;
  line-height: 1;
}

.site-cms-pager-select {
  display: flex;
  flex-wrap: nowrap;
  justify-content: center;
  font-size: 1rem;
  margin-top: var(--spacing-two);
  text-align: center;
}
.site-cms-pager-select > a {
  transition-property: background-color, color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  border: 1px solid var(--color-border);
  display: block;
  font-size: inherit;
  margin: 0 0.5em;
  padding: 0.5em;
  position: relative;
  text-decoration: none;
}
.site-cms-pager-select > a:before {
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  line-height: 1;
  width: 0.875rem;
}
.site-cms-pager-select > a:hover {
  background-color: var(--color-light-grey);
  color: var(--color-grey);
}
.site-cms-pager-select > a:first-child {
  margin-right: 0.5rem;
}
.site-cms-pager-select > a:first-child:before {
  -webkit-mask-image: url(../images/icon/arrow_left-secondary.svg);
  mask-image: url(../images/icon/arrow_left-secondary.svg);
}
.site-cms-pager-select > a:last-child {
  margin-left: 0.5rem;
}
.site-cms-pager-select > a:last-child:before {
  -webkit-mask-image: url(../images/icon/arrow_right-secondary.svg);
  mask-image: url(../images/icon/arrow_right-secondary.svg);
}
.site-cms-pager-select > .select {
  position: relative;
}
.site-cms-pager-select > .select > .current {
  transition-property: background-color, color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  border: 1px solid var(--color-border);
  cursor: pointer;
  display: block;
  height: 100%;
  padding: 0.5em 2em 0.5em 0.5em;
  position: relative;
  width: 10rem;
}
.site-cms-pager-select > .select > .current::after {
  border-left: 1px solid var(--color-border);
  background-color: currentColor;
  content: "";
  display: block;
  -webkit-mask-image: url(../images/icon/select.svg);
  mask-image: url(../images/icon/select.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 1rem;
  margin-left: 0.5em;
  position: absolute;
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
  width: 1rem;
}
.site-cms-pager-select > .select > select {
  cursor: pointer;
  font-size: 16px;
  height: 100%;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}
.site-cms-pager-select > .select > select:hover + .current {
  background-color: var(--color-light-grey);
  color: var(--color-grey);
}

.site-contact > .item {
  color: var(--color-white);
  display: block;
  overflow: hidden;
  padding: 3rem var(--margin-side-small);
  position: relative;
  text-align: center;
  text-decoration: none;
}
.site-contact > .item::after {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: url(../images/common/image_contact.jpg) center center no-repeat;
  background-size: cover;
  content: "";
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 1;
}
.site-contact > .item > .inner {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  position: relative;
  z-index: 2;
}
.site-contact > .item > .inner > .icon {
  transition-property: transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  aspect-ratio: 1/1;
  border: 1px solid var(--color-white);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 1rem auto 0;
  width: 3rem;
}
.site-contact > .item > .inner > .icon::after {
  aspect-ratio: 1/1;
  background-color: currentColor;
  content: "";
  display: block;
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  width: 1rem;
}
.site-contact > .item:hover::after {
  transform: scale(1.05);
}
.site-contact > .item:hover > .inner > .icon {
  transform: translateX(0.25rem);
}

@supports (overflow: clip) {
  #site-container {
    overflow-x: clip;
  }
}
@supports not (overflow: clip) {
  #site-container {
    overflow: hidden;
  }
}
.site-footer {
  padding: 3rem 0 1.5rem;
}

.site-footer-inner {
  display: flex;
  flex-direction: column;
  padding-right: var(--margin-side-small);
  padding-left: var(--margin-side-small);
  width: 100%;
}
.site-footer-inner > .above {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1.5rem;
  margin-bottom: 1.5rem;
}
.site-footer-inner > .above > .info {
  display: flex;
  align-items: flex-end;
  flex-wrap: wrap;
  gap: 0.5rem 2.5rem;
  margin-bottom: 0.5rem;
}
.site-footer-inner > .above > .info > .address, .site-footer-inner > .above > .info > .contact {
  display: block;
  font-style: normal;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.3;
}
.site-footer-inner > .below {
  display: flex;
  gap: 2rem;
  flex-direction: column;
  justify-content: space-between;
}
.site-footer-inner > .below > nav {
  margin: 0 calc(var(--margin-side-small) * -1);
  width: calc(100% + var(--margin-side-small) * 2);
}
.site-footer-inner > .below > .copyright {
  display: block;
  font-style: normal;
  font-size: 0.875rem;
  font-weight: 700;
  line-height: 1;
}

.site-footer-nav {
  border-top: 1px solid var(--color-border);
  display: flex;
  align-items: center;
  flex-direction: column;
  width: 100%;
}
.site-footer-nav > .list {
  display: flex;
  align-items: center;
  width: 100%;
}
.site-footer-nav > .list > .item {
  transition-property: color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-black);
  display: flex;
  align-items: center;
  gap: 1.5rem;
  justify-content: space-between;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1;
  outline: none;
  padding: 1.5rem var(--margin-side-small);
  position: relative;
  text-align: left;
  text-decoration: none;
  text-transform: uppercase;
  width: 100%;
}
.site-footer-nav > .list > .item::after {
  transition-property: background, transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-color: currentColor;
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  content: "";
  height: 1rem;
  width: 1rem;
}

.site-hamburger {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  display: block;
  height: 55px;
  outline: none;
  position: relative;
  width: 55px;
  z-index: 100;
}
.site-hamburger > .icon {
  transition-property: background;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.76, 0, 0.24, 1);
  transition-delay: 0s;
  background-color: var(--color-project-blue);
  display: block;
  height: 2px;
  position: absolute;
  top: 26px;
  left: 17px;
  width: 20px;
}
.site-hamburger > .icon::before, .site-hamburger > .icon::after {
  transition-property: background, top, transform;
  transition-duration: 0.3s;
  transition-timing-function: cubic-bezier(0.76, 0, 0.24, 1);
  transition-delay: 0s;
  background-color: var(--color-project-blue);
  content: "";
  display: block;
  height: 100%;
  position: absolute;
  width: 100%;
}
.site-hamburger > .icon::before {
  top: -7px;
}
.site-hamburger > .icon::after {
  top: 7px;
}
.site-hamburger.-open > .icon {
  background: transparent;
}
.site-hamburger.-open > .icon::before, .site-hamburger.-open > .icon::after {
  top: 0;
}
.site-hamburger.-open > .icon::before {
  transform: rotate(-45deg);
}
.site-hamburger.-open > .icon::after {
  transform: rotate(45deg);
}

.site-header {
  transition-property: background;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-color: var(--color-project-base);
  padding: 0 0 0 var(--margin-side-small);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 20;
  width: 100%;
}
.site-header::after {
  transition-property: opacity, visibility;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: linear-gradient(var(--color-project-base), var(--color-project-base) 50%, rgba(245, 246, 248, 0) 100%);
  content: "";
  display: block;
  height: var(--header-height-small);
  opacity: 0;
  position: fixed;
  top: 0;
  left: 0;
  visibility: hidden;
  z-index: 40;
  width: 100vw;
}
.site-header > .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: var(--header-height-small);
  width: 100%;
}
.site-header > .inner > .logo {
  transition-property: opacity, visibility;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  align-self: center;
  position: relative;
  z-index: 50;
}
.site-header > .inner > .nav {
  transition-property: opacity, visibility;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.site-header.-open::after {
  opacity: 1;
  visibility: visible;
}

.site-heading-simple {
  font-feature-settings: "palt" 1;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.55;
}
.site-heading-simple.-factor-half {
  font-size: 1rem;
}
.site-heading-simple.-factor-1 {
  font-size: 1.125rem;
}
.site-heading-simple.-factor-2 {
  font-size: 1.25rem;
}
.site-heading-simple.-factor-3 {
  font-size: 1.5rem;
}
.site-heading-simple.-factor-4 {
  font-size: 1.75rem;
}
.site-heading-simple.-center-all {
  text-align: center;
}
.site-heading-simple.-light {
  color: var(--color-white);
}
.site-heading-simple.-blue {
  color: var(--color-project-blue);
}
.site-heading-simple.-light-blue {
  color: var(--color-project-light-blue);
}
.site-heading-simple.-keep {
  line-break: strict;
  overflow-wrap: anywhere;
  word-break: keep-all;
}
.site-heading-simple > .accent {
  color: var(--color-project-blue);
  font-style: normal;
}
.site-heading-simple > .text {
  background-color: var(--color-white);
  display: inline;
}

.site-heading-ornament {
  color: var(--color-project-blue);
  display: block;
  font-size: 1.125rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  line-height: 1;
}
.site-heading-ornament.-small {
  font-weight: 500;
  font-size: 0.875rem;
}
.site-heading-ornament.-short {
  font-size: 0.875rem;
}
.site-heading-ornament.-light {
  color: var(--color-white);
}

.site-heading-combi {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.site-heading-combi.-center-all {
  align-items: center;
}
.site-heading-combi.-wide {
  gap: 0.5rem;
}
.site-heading-combi.-xtite {
  gap: 0.25rem;
}

.site-link {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
}
.site-link > .content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  padding: 0;
}
.site-link > .content:first-child {
  border-bottom: 1px solid var(--color-border);
  padding-bottom: 2.5rem;
}

.site-logo {
  color: var(--color-project-blue);
  display: flex;
  align-items: flex-end;
  gap: 0.75rem;
  text-decoration: none;
}
.site-logo > img {
  height: 2.063rem;
  width: 3.75rem;
}
.site-logo > .text {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: 0.75rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  margin-bottom: 0.125rem;
  white-space: nowrap;
}
.site-logo > .text > .name {
  font-size: 1.125rem;
}

.site-main {
  display: block;
  padding-top: var(--header-height-small);
}

.site-nav-drawer {
  transition-property: opacity, visibility, transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0;
  background-color: var(--color-white);
  display: block;
  height: 100svh;
  opacity: 0;
  overflow-x: hidden;
  overflow-y: scroll;
  padding: var(--header-height-small) 0 5rem;
  position: fixed;
  top: 0;
  left: 0;
  transform: translateX(100%);
  visibility: hidden;
  width: 100%;
  z-index: 30;
}
.site-nav-drawer.-open {
  opacity: 1;
  transform: translateX(0);
  visibility: visible;
}

.site-nav-global {
  border-top: 1px solid var(--color-border);
  display: flex;
  flex-wrap: wrap;
}
.site-nav-global > .list {
  width: 100%;
}
.site-nav-global > .list > .item {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: 0;
  border-bottom: 1px solid var(--color-border);
  color: var(--color-project-blue);
  display: flex;
  align-items: center;
  gap: 1.5rem;
  justify-content: space-between;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.3;
  outline: none;
  padding: 1.5rem var(--margin-side-small);
  position: relative;
  text-align: left;
  text-decoration: none;
  text-transform: uppercase;
  width: 100%;
}
.site-nav-global > .list > .item::after {
  transition-property: background, transform;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-color: currentColor;
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  content: "";
  height: 1rem;
  width: 1rem;
}
.site-nav-global > .list > .item.-contact {
  transition-property: background, color;
  transition-duration: 0.3s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-color: var(--color-project-blue);
  border: 1px solid var(--color-project-blue);
  border-radius: 100vw;
  color: var(--color-white);
  margin: 1.5rem var(--margin-side-small) 0;
  padding: 1rem 1.5rem;
  width: calc(100% - var(--margin-side-small) * 2);
}
.site-nav-global > .list > .item.-contact:hover {
  background-color: var(--color-white);
  color: var(--color-project-blue);
}

.site-normalize-content.-block {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.site-normalize-content.-block p {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.75;
}
.site-normalize-content.-block strong {
  font-weight: bold;
}
.site-normalize-content.-block em {
  font-style: italic;
}
.site-normalize-content.-block a {
  transition-property: background-size;
  transition-duration: 0.6s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background-image: linear-gradient(rgba(0, 36, 170, 0) 0%, rgb(0, 36, 170) 0%);
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: 0 1px;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-project-blue);
  font-size: 1rem;
  font-weight: 500;
  text-decoration: none;
}
.site-normalize-content.-block a::after {
  aspect-ratio: 1/1;
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 0.875rem;
  width: 0.875rem;
}
.site-normalize-content.-block a[target=_blank]::after {
  -webkit-mask-image: url(../images/icon/popup.svg);
  mask-image: url(../images/icon/popup.svg);
}
.site-normalize-content.-block a:hover {
  background-position: left bottom;
  background-size: 100% 1px;
}
.site-normalize-content.-block h2 {
  color: var(--color-project-blue);
  font-feature-settings: "palt" 1;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.55;
}
.site-normalize-content.-block h3 {
  font-feature-settings: "palt" 1;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.55;
}
.site-normalize-content.-block h4 {
  color: var(--color-project-blue);
  font-feature-settings: "palt" 1;
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.55;
}
.site-normalize-content.-block ul, .site-normalize-content.-block ol {
  list-style-position: outside;
}
.site-normalize-content.-block li {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.75;
}
.site-normalize-content.-block ul {
  overflow: hidden;
}
.site-normalize-content.-block ul li {
  padding-left: 1em;
}
.site-normalize-content.-block ul li:last-child {
  margin-bottom: 0;
}
.site-normalize-content.-block ul li:before {
  content: "・";
  margin-left: -1rem;
  width: 1rem;
}
.site-normalize-content.-block ol {
  list-style-type: decimal;
  overflow: visible;
  padding-left: 2rem;
}
.site-normalize-content.-block ol li:last-child {
  margin-bottom: 0;
}
.site-normalize-content.-block .wp-block-quote {
  border-left: 0.25rem solid var(--color-border);
  font-style: italic;
  margin-right: 0;
  margin-left: 0;
  padding-left: 1rem;
}
.site-normalize-content.-block .wp-block-quote cite {
  font-size: 0.8125rem;
}
.site-normalize-content.-block .wp-block-table thead,
.site-normalize-content.-block .wp-block-table tfoot {
  border: 0;
}
.site-normalize-content.-block .wp-block-table th,
.site-normalize-content.-block .wp-block-table td {
  border: 0;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.5;
  padding: 1em 0 1em 0;
  text-align: left;
}
.site-normalize-content.-block .wp-block-table th {
  border-bottom: 1px solid #cccccc;
  color: var(--color-project-blue);
  min-width: 7.5rem;
}
.site-normalize-content.-block .wp-block-table td {
  border-bottom: 1px solid #cccccc;
}
.site-normalize-content.-block .wp-block-table figcaption {
  font-size: 0.8125rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.site-normalize-content.-block .wp-block-table .has-fixed-layout {
  table-layout: fixed;
}
.site-normalize-content.-block img {
  display: block;
  height: auto;
  max-width: 100%;
}
.site-normalize-content.-block .wp-block-image figcaption {
  font-size: 0.8125rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.site-normalize-content.-block .wp-block-image a {
  transition-property: opacity;
  transition-duration: var(--animate-duration);
  transition-timing-function: var(--animate-easing);
  transition-delay: 0s;
  background: transparent;
  border-bottom: 0;
  display: block;
}
.site-normalize-content.-block .wp-block-image a:after {
  content: none;
}
.site-normalize-content.-block .wp-block-image a:hover {
  opacity: var(--animate-opacity);
}
.site-normalize-content.-block .wp-block-image a[target=_blank]::after {
  content: none;
}
.site-normalize-content.-block .wp-block-image.is-style-rounded {
  border-radius: 50%;
}
.site-normalize-content.-block .wp-block-separator {
  background-color: var(--color-border);
  border: 0;
  height: 1px;
}
.site-normalize-content.-block .wp-block-media-text {
  gap: 2rem;
}
.site-normalize-content.-block .wp-block-media-text > .wp-block-media-text__media, .site-normalize-content.-block .wp-block-media-text > .wp-block-media-text__content {
  padding: 0;
}
.site-normalize-content.-block .wp-block-media-text > .wp-block-media-text__content {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.site-normalize-content.-block .wp-block-media-text.has-media-on-the-right {
  flex-direction: row-reverse;
}
.site-normalize-content.-block .wp-block-media-text.is-stacked-on-mobile {
  flex-wrap: wrap;
}
.site-normalize-content.-block .wp-block-media-text.is-vertically-aligned-top {
  align-items: start;
}
.site-normalize-content.-block .wp-block-media-text.is-vertically-aligned-center {
  align-items: center;
}
.site-normalize-content.-block .wp-block-media-text.is-vertically-aligned-bottom {
  align-items: end;
}
.site-normalize-content.-block .wp-block-media-text.is-image-fill {
  align-items: stretch;
}
.site-normalize-content.-block .wp-block-media-text.is-image-fill > .wp-block-media-text__media {
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
}
.site-normalize-content.-block .wp-block-media-text.is-image-fill > .wp-block-media-text__media img {
  visibility: hidden;
}
.site-normalize-content.-block .wp-block-columns {
  gap: 2rem;
}
.site-normalize-content.-block .wp-block-columns .wp-block-column:empty {
  display: none;
}
.site-normalize-content.-block .wp-block-button > .wp-block-button__link {
  transition-property: background-size;
  transition-duration: 0.6s;
  transition-timing-function: ease;
  transition-delay: 0s;
  background: linear-gradient(rgba(0, 0, 0, 0) 0%, rgb(0, 0, 0) 0%);
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: 0 1px;
  border-radius: 0;
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  color: var(--color-project-blue);
  font-size: 1.125rem;
  font-weight: 900;
  line-height: 1.2;
  padding: 0;
  text-decoration: none;
}
.site-normalize-content.-block .wp-block-button > .wp-block-button__link::after {
  aspect-ratio: 1/1;
  background-color: currentColor;
  content: "";
  display: inline-block;
  -webkit-mask-image: url(../images/icon/arrow_right.svg);
  mask-image: url(../images/icon/arrow_right.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  height: 1.125rem;
  width: 1.125rem;
}
.site-normalize-content.-block .wp-block-button > .wp-block-button__link.-popup::after {
  -webkit-mask-image: url(../images/icon/popup.svg);
  mask-image: url(../images/icon/popup.svg);
}
.site-normalize-content.-block .wp-block-button > .wp-block-button__link:hover {
  background-position: left bottom;
  background-size: 100% 1px;
}
.site-normalize-content.-block .wp-block-embed-youtube .wp-block-embed__wrapper {
  aspect-ratio: 16/9;
  height: auto;
  overflow: hidden;
  position: relative;
  width: 100%;
}
.site-normalize-content.-block .wp-block-embed-youtube .wp-block-embed__wrapper iframe {
  height: 100%;
  width: 100%;
}
.site-normalize-content.-block .wp-block-embed-youtube figcaption {
  font-size: 0.8125rem;
  letter-spacing: 0.05em;
  line-height: 1.3;
}
.site-normalize-content.-block .has-text-align-left {
  text-align: left;
}
.site-normalize-content.-block .has-text-align-center {
  text-align: center;
}
.site-normalize-content.-block .has-text-align-right {
  text-align: right;
}
.site-normalize-content.-block .aligncenter {
  text-align: center;
}
.site-normalize-content.-block .aligncenter img,
.site-normalize-content.-block .aligncenter .wp-block-file__button {
  margin-right: auto;
  margin-left: auto;
}
.site-normalize-content.-block .alignleft {
  text-align: left;
}
.site-normalize-content.-block .alignleft img,
.site-normalize-content.-block .alignleft .wp-block-file__button {
  margin-right: auto;
  margin-left: 0;
}
.site-normalize-content.-block .alignleft .wp-block-file__button {
  text-align: center;
}
.site-normalize-content.-block .alignright {
  text-align: right;
}
.site-normalize-content.-block .alignright img,
.site-normalize-content.-block .alignright .wp-block-file__button {
  margin-right: 0;
  margin-left: auto;
}
.site-normalize-content.-block figcaption {
  margin-top: var(--spacing-break);
}
.site-normalize-content.-block *:first-child {
  margin-top: 0;
}
.site-normalize-content.-block *:last-child {
  margin-bottom: 0;
}

.site-post-list > .item {
  border-bottom: 1px solid var(--color-border);
  padding: 1.5rem 0;
  display: flex;
  align-items: flex-start;
}
.site-post-list > .item > .link {
  display: flex;
  gap: 0.5rem;
  flex-direction: column;
  font-weight: 700;
  text-decoration: none;
  width: 100%;
}
.site-post-list > .item > .link > .date {
  color: var(--color-project-blue);
  font-size: 1rem;
  flex-shrink: 0;
  width: 9.375rem;
}
.site-post-list > .item > .link > .title {
  color: var(--color-black);
  font-size: 1rem;
}

.site-post {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}
.site-post > .header {
  border-bottom: 1px solid var(--color-border);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  padding-bottom: 1rem;
}
.site-post > .header > .date {
  color: var(--color-project-blue);
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1;
}
.site-post > .header > .title {
  font-feature-settings: "palt" 1;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.55;
}
.site-post > .footer {
  border-top: 1px solid var(--color-border);
  padding-top: 3rem;
}

.site-recruit {
  padding-top: calc(46.13vw - 4rem + 2rem);
}
.site-recruit > .content {
  display: flex;
  flex-direction: column;
  gap: 1rem;
  max-width: 32.125rem;
}

.site-table-standard th,
.site-table-standard td {
  display: block;
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.5;
  padding: 1em 0 1em 0;
  vertical-align: top;
  text-align: left;
}
.site-table-standard th {
  color: var(--color-project-blue);
  min-width: 7.5rem;
  padding-bottom: 0;
}
.site-table-standard td {
  border-bottom: 1px solid #cccccc;
  padding-top: 0.25em;
}

.site-text-standard {
  font-size: 1rem;
  font-weight: 500;
  line-height: 1.75;
}
.site-text-standard.-center-all {
  text-align: center;
}
.site-text-standard.-lead {
  font-size: 1.125rem;
}
.site-text-standard.-tite {
  line-height: 1.333;
}
.site-text-standard.-blue {
  color: var(--color-project-blue);
}
.site-text-standard.-keep {
  line-break: strict;
  overflow-wrap: anywhere;
  word-break: keep-all;
}
.site-text-standard > .marker {
  background-color: #fcee21;
}
.site-text-standard + .site-text-standard {
  margin-top: 2em;
}
.site-text-standard .large {
  font-size: 1.25em;
}
@media screen and (min-width: 821px) and (max-width: 1024px) {
  .site-breadcrumbs > .inner {
    padding-right: calc(var(--margin-side) * 0.5);
    padding-left: calc(var(--margin-side) * 0.5);
  }
  .site-nav-global {
    gap: 1em !important;
  }
  .site-nav-global > .list > .item {
    font-size: 1rem !important;
  }
}
@media screen and (min-width: 1023px) {
  .site-breadcrumbs > .inner {
    padding-right: var(--margin-side);
    padding-left: var(--margin-side);
  }
}