*, :after, :before {
  box-sizing: border-box;
  background-repeat: no-repeat;
}

:after, :before {
  -webkit-text-decoration: inherit;
  text-decoration: inherit;
  vertical-align: inherit;
}

:where(:root) {
  cursor: default;
  tab-size: 4;
  -webkit-tap-highlight-color: transparent;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  text-size-adjust: 100%;
  line-height: 1.5;
}

:where(body) {
  margin: 0;
}

:where(hr) {
  color: inherit;
  height: 0;
}

:where(nav) :where(ol, ul) {
  padding: 0;
  list-style-type: none;
}

:where(pre) {
  font-family: monospace;
  font-size: 1em;
  overflow: auto;
}

:where(svg:not([fill])) {
  fill: currentColor;
}

:where(button, [type="button" i], [type="reset" i], [type="submit" i]) {
  appearance: button;
}

:where(textarea) {
  resize: vertical;
  margin: 0;
}

:where([type="search" i]) {
  appearance: textfield;
  outline-offset: -2px;
}

::-webkit-inner-spin-button {
  height: auto;
}

::-webkit-outer-spin-button {
  height: auto;
}

::placeholder {
  color: inherit;
  opacity: .54;
}

::-webkit-search-decoration {
  appearance: none;
}

::-webkit-file-upload-button {
  appearance: button;
  font: inherit;
}

:where(details > summary:first-of-type) {
  display: list-item;
}

:where([aria-busy="true" i]) {
  cursor: progress;
}

:where([aria-disabled="true" i], [disabled]) {
  cursor: not-allowed;
}

:where([aria-hidden="false" i][hidden]) {
  display: initial;
}

:where([aria-hidden="false" i][hidden]:not(:focus)) {
  clip: rect(0,0,0,0);
  position: absolute;
}

@media (prefers-reduced-motion: reduce) {
  *, :after, :before {
    background-attachment: initial !important;
    scroll-behavior: auto !important;
    transition-duration: 0s !important;
    transition-delay: 0s !important;
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    animation-delay: -1ms !important;
  }
}

*, :after, :before, html {
  box-sizing: border-box;
}

img {
  box-sizing: content-box;
}

.image-background > img, .image-background > img[width][height] {
  object-fit: cover;
}

.image-background {
  position: relative;
  overflow: hidden;
}

.image-background-layer, .image-background > img, .image-background > img[width][height] {
  z-index: 0;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

:root {
  --color-black: #000;
  --color-white: #fff;
  --color-accent: var(--color-black);
  --color-heading: var(--color-black);
  --color-main: var(--color-black);
  --color-paragraph: var(--color-black);
  --color-link-text: var(--color-black);
  --color-link-text-hover: var(--color-black);
  --breakpoint-nav: 1029px;
  --typography-family-main: "Noto Sans JP","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
  --typography-family-paragraph: var(--typography-family-main);
  --typography-family-heading: var(--typography-family-main);
  --typography-size-hero: 52px;
  --typography-size-h1: 40px;
  --typography-size-h2: 30px;
  --typography-size-h3: 24px;
  --typography-size-h4: 20px;
  --typography-size-h5: 16px;
  --typography-size-h6: 14px;
  --typography-size-12: 12px;
  --typography-size-13: 13px;
  --typography-size-14: 14px;
  --typography-size-15: 15px;
  --typography-size-16: 16px;
  --typography-size-17: 17px;
  --typography-size-18: 18px;
  --typography-size-20: 20px;
  --typography-size-22: 22px;
  --typography-paragraph-size: var(--typography-size-18);
  --typography-nav-toggle-label-size: 15px;
  --typography-captions-size: 15px;
  --typography-heading-line-height: 1.5;
  --typography-heading-core-line-height: 1.23;
  --typography-paragraph-line-height: 1.7;
  --typography-weight-regular: 400;
  --typography-weight-medium: 500;
  --typography-weight-semibold: 600;
  --typography-weight-bold: 700;
  --typography-weight-paragraph: var(--typography-weight-regular);
  --typography-weight-heading: var(--typography-weight-bold);
}

@font-face {
  font-display: auto;
  font-family: Mona Sans;
  font-style: normal;
  font-weight: 1 999;
  src: url("monasansvf.15ee0aa1.woff2") format("woff2"), url("monasansvf.8f771461.woff") format("woff");
}

@media (width <= 600px) {
  :root {
    --typography-size-hero: 38px;
    --typography-size-h1: 32px;
    --typography-size-h2: 24px;
    --typography-size-h3: 21px;
    --typography-size-h4: 18px;
    --typography-size-h5: 14px;
    --typography-size-h6: 12px;
    --typography-paragraph-size: 16px;
  }
}

@media (width <= 420px) {
  :root {
    --typography-size-16: 14px;
    --typography-nav-toggle-label-size: 13px;
  }
}

:root {
  --spacing-grid-gap: 3rem;
  --spacing-container-padding-inline: 1.25rem;
  --spacing-container-padding-inline-large: 4rem;
  --spacing-container-padding-block: 4rem;
  --spacing-site-header-padding-block: 1.25rem;
  --spacing-content-padding-block: 5rem;
  --spacing-block-padding-m: 5rem;
  --spacing-block-padding-l: 8rem;
  --spacing-text-margin-block: 2.5rem;
  --spacing-wp-block-image-margin-block: 2.5rem;
  --spacing-paragraphs-margin-block: 1.6875rem;
}

@media (width <= 1590px) {
  :root {
    --spacing-container-padding-inline: 4rem;
  }
}

@media (width <= 700px) {
  :root {
    --spacing-container-padding-inline: 1.25rem;
  }
}

@media (width <= 1030px) {
  :root {
    --spacing-site-header-padding-block: 1.25rem;
  }
}

@media (width <= 1024px) {
  :root {
    --spacing-grid-gap: 2rem;
  }
}

@media (width <= 768px) {
  :root {
    --spacing-grid-gap: var(--spacing-container-padding-inline);
    --spacing-container-padding-block: 3.125rem;
  }
}

@media (width <= 600px) {
  :root {
    --spacing-content-padding-block: 3.75rem;
    --spacing-container-padding-block: 2.5rem;
  }
}

.screen-reader-text {
  clip: rect(1px,1px,1px,1px);
  clip-path: inset(50%);
  border: 0;
  width: 1px;
  height: 1px;
  margin: -1px;
  padding: 0;
  position: absolute;
  overflow: hidden;
  word-wrap: normal !important;
}

.screen-reader-text:focus {
  opacity: 0;
}

.screen-reader-text:focus-visible {
  background-color: var(--color-white);
  clip: auto;
  clip-path: none;
  font-size: 1.0625rem;
  font-weight: var(--typography-weight-bold);
  opacity: 1;
  z-index: 100000;
  border-radius: 0;
  width: auto;
  height: auto;
  padding: .9375rem 1.4375rem .875rem;
  line-height: normal;
  text-decoration: none;
  display: block;
  top: .3125rem;
  left: .3125rem;
  box-shadow: 0 0 2px 2px #17171799;
}

.skip-link {
  margin: .3125rem;
}

a:focus, button:focus, div[tabindex]:focus, input:focus, select:focus, textarea:focus {
  opacity: 1;
  outline-offset: .3125rem;
}

@media (prefers-reduced-motion: no-preference) {
  :focus {
    transition: outline-offset .25s;
  }
}

.external-link-icon {
  margin-left: .4375rem;
  margin-right: 2px;
}

@media (width <= 600px) {
  .external-link-icon {
    width: .75rem;
    height: .75rem;
    margin-left: 4px;
    transform: translateY(1px);
  }
}

.hamburger {
  --hamburger-layer-height: 2px;
  --hamburger-width: 2rem;
  --hamburger-color: var(--color-black);
  --hamburger-color-active: var(--color-white);
  flex-shrink: 0;
  position: relative;
}

.hamburger, .hamburger:after, .hamburger:before {
  background-color: var(--hamburger-color);
  height: var(--hamburger-layer-height);
  width: var(--hamburger-width);
  transition: all .2s;
}

.hamburger:after, .hamburger:before {
  content: "";
  display: block;
  position: absolute;
}

.hamburger:before {
  top: -.5625rem;
}

.hamburger:after {
  bottom: -.5625rem;
}

body:not(.js-nav-active) .nav-toggle .hamburger:after, body:not(.js-nav-active) .nav-toggle:focus .hamburger:after {
  width: 80%;
}

body:not(.js-nav-active) .nav-toggle:hover .hamburger:after {
  width: 100%;
}

.js-nav-active .hamburger:after, .js-nav-active .hamburger:before {
  background-color: var(--hamburger-color-active);
  top: 0;
  left: 0;
}

.js-nav-active .hamburger:before {
  transform: rotate(-45deg);
}

.js-nav-active .hamburger:after {
  transform: rotate(45deg);
}

.js-nav-active .hamburger, .nav-toggle {
  background-color: #0000;
}

.nav-toggle {
  cursor: pointer;
  font-weight: var(--typography-weight-semibold);
  opacity: 1;
  -webkit-user-select: none;
  user-select: none;
  z-index: 99999;
  border: 0;
  border-radius: 0;
  justify-content: center;
  align-items: center;
  width: 4rem;
  height: 4rem;
  margin: -.5rem -1rem 0 0;
  padding: 0;
  text-decoration: none;
  display: flex;
  position: relative;
  right: 0;
  overflow: visible;
}

:root {
  --color-background-nav-mobile-header: var(--color-white);
  --color-background-nav-mobile-header-active: var(--color-black);
  --width-navigation: 100vw;
  --color-background-menu-items: var(--color-main);
  --color-background-menu-items-active: var(--color-main);
  --color-separator-nav-mobile: #ffffff1a;
  --color-current-menu-item: var(--color-white);
  --color-dropdown-toggle-mobile: var(--color-white);
  --typography-size-main-level-mobile: .9375rem;
  --typography-weight-main-level-mobile: 600;
  --padding-main-level-vertical-mobile: .75rem;
  --color-main-level-menu-item-hover-focus-mobile: var(--color-white);
  --color-main-level-menu-item-mobile: var(--color-white);
  --typography-size-sub-menu-mobile: .9375rem;
  --typography-weight-sub-menu-mobile: 600;
  --margin-left-sub-menu: .625rem;
  --padding-sub-menu-vertical-mobile: .5rem;
  --padding-sub-menu-horizontal-mobile: var(--spacing-container-padding-inline);
  --color-sub-menu-mobile: #fffc;
}

@media only screen and (width <= 1030px) {
  .menu-items ul {
    display: none;
  }

  ul .sub-menu.toggled-on {
    display: block;
  }
}

@media screen and (width <= 1029px) {
  .site-header {
    background-color: var(--color-background-nav-mobile-header);
  }

  .nav-primary {
    align-self: center;
  }

  .site-header a, .site-header li, .site-header ul {
    position: relative;
  }

  .disable-scroll {
    overflow: hidden;
  }

  .menu-items-wrapper {
    backface-visibility: hidden;
    background-color: var(--color-background-menu-items);
    pointer-events: none;
    visibility: hidden;
    height: calc(100vh - 7.2rem);
    width: var(--width-navigation);
    z-index: 5;
    padding-bottom: 7.5rem;
    transition: opacity .18s ease-in-out;
    position: fixed;
    top: 0;
    right: 0;
    overflow: auto;
    transform: translate3d(100%, 0, 0);
  }

  .menu-items {
    margin: 16px 0 0;
  }

  .menu-item a {
    border-top: 1px solid var(--color-separator-nav-mobile);
    color: var(--color-main-level-menu-item-mobile);
    font-size: var(--typography-size-main-level-mobile);
    font-weight: var(--typography-weight-main-level-mobile);
    padding: var(--padding-main-level-vertical-mobile) var(--padding-sub-menu-horizontal-mobile);
    z-index: 0;
    margin-left: 0;
    margin-right: 0;
    text-decoration: none;
    display: block;
    position: relative;
  }

  .sub-menu a {
    color: var(--color-sub-menu-mobile);
    font-size: var(--typography-size-sub-menu-mobile);
    font-weight: var(--typography-weight-sub-menu-mobile);
    padding-bottom: var(--padding-sub-menu-vertical-mobile);
    padding-left: calc(var(--padding-sub-menu-horizontal-mobile) + var(--margin-left-sub-menu));
    padding-top: var(--padding-sub-menu-vertical-mobile);
  }

  .sub-menu {
    margin-left: 0;
    padding-left: 0;
  }

  .sub-menu .sub-menu a {
    padding-left: calc(var(--padding-sub-menu-horizontal-mobile) + var(--margin-left-sub-menu) + var(--margin-left-sub-menu));
  }

  .menu-item a:focus, .menu-item a:hover {
    color: var(--color-main-level-menu-item-hover-focus-mobile);
  }

  .menu-item.current-menu-item > a, .menu-item.current-menu-parent > a {
    color: var(--color-current-menu-item);
  }

  .dropdown-toggle {
    --dropdown-toggle-size: .75rem;
    color: var(--color-dropdown-toggle-mobile);
    height: 100%;
    padding: var(--padding-sub-menu-vertical-mobile) calc(var(--padding-sub-menu-horizontal-mobile) - var(--dropdown-toggle-size)/2) var(--padding-sub-menu-vertical-mobile) var(--padding-sub-menu-horizontal-mobile);
    z-index: 100;
    background-color: #0000;
    border: 0;
    align-items: center;
    margin-top: 0;
    display: inline-flex;
    position: absolute;
    top: 2px;
    left: auto;
    right: 0;
    overflow: hidden;
  }

  .dropdown-toggle svg {
    height: var(--dropdown-toggle-size);
    pointer-events: none;
    width: var(--dropdown-toggle-size);
    z-index: -1;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' style='width:var(--dropdown-toggle-size);height:var(--dropdown-toggle-size)' viewBox='0 0 10 10'%3E%3Cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M5 1.5v7M1.5 5h7'/%3E%3C/svg%3E");
    background-size: 100%;
    transition: all .15s;
    position: relative;
    transform: rotate(0);
  }

  .dropdown-toggle svg path {
    display: none;
  }

  .dropdown-toggle.toggled-on svg {
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' style='width:var(--dropdown-toggle-size);height:var(--dropdown-toggle-size)' viewBox='0 0 10 10'%3E%3Cpath fill='none' stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M1.5 5h7'/%3E%3C/svg%3E");
    transform: rotate(-180deg);
  }

  .dropdown-toggle:hover {
    cursor: pointer;
  }

  .dropdown-toggle:focus {
    cursor: pointer;
    z-index: 100;
  }

  .sub-menu .dropdown-toggle {
    color: var(--color-sub-menu-mobile);
  }

  .js-nav-active {
    overflow: hidden;
  }

  .js-nav-active .menu-items-wrapper {
    background-color: var(--color-background-menu-items-active);
    opacity: 1;
    pointer-events: all;
    visibility: visible;
    width: var(--width-navigation);
    transform: translateZ(0);
  }
}

@media screen and (width <= 782px) {
  .logged-in.admin-bar .menu-items-wrapper {
    margin-top: 46px;
  }
}

.site-header ul {
  --color-current: var(--color-black);
  --color-current-dropdown: var(--color-white);
  --dropdown-toggle-size: .75rem;
  --typography-size-main-level: var(--typography-size-16);
  --typography-weight-main-level: var(--typography-weight-semibold);
  --padding-main-level-horizontal: 0;
  --padding-main-level-vertical: .375rem;
  --color-main-level: var(--color-black);
  --color-hover-main-level: var(--color-link-text);
  --gap-between-dropdown-toggle: .9375rem;
  --gap-main-level-horizontal: 1.5625rem;
  --typography-size-sub-menu: var(--typography-size-16);
  --typography-weight-sub-menu: var(--typography-weight-semibold);
  --padding-sub-menu-vertical: .625rem;
  --padding-sub-menu-link-vertical: .5rem;
  --padding-sub-menu-link-horizontal: 1.25rem;
  --width-sub-menu: 12.5rem;
  --color-sub-menu: var(--color-white);
  --color-hover-sub-menu: var(--color-white);
  --color-background-sub-menu: var(--color-black);
  --gap-dropdown: 1.6rem;
  width: unset;
  list-style: none;
}

@media only screen and (width >= 1030px) {
  .nav-toggle {
    display: none;
  }

  .nav-primary {
    padding-top: 0;
    padding-bottom: 0;
    line-height: 0;
  }

  .menu-items {
    align-items: center;
    column-gap: var(--gap-main-level-horizontal);
    background-color: #0000;
    flex-wrap: wrap;
    justify-content: flex-end;
    row-gap: .625rem;
    padding: 0;
    display: flex;
  }

  .menu-item, .menu-items {
    margin: 0;
    position: relative;
  }

  .menu-item-clickable, .menu-item > a {
    color: var(--color-main-level);
    font-size: var(--typography-size-main-level);
    font-weight: var(--typography-weight-main-level);
    padding: var(--padding-main-level-vertical) var(--padding-main-level-horizontal);
    white-space: nowrap;
    align-items: center;
    margin-left: 0;
    margin-right: 0;
    display: inline-flex;
  }

  .menu-item .sub-menu a {
    font-size: var(--typography-size-sub-menu);
    font-weight: var(--typography-weight-sub-menu);
    padding: var(--padding-sub-menu-link-vertical) var(--padding-sub-menu-link-horizontal);
    white-space: normal;
    align-items: center;
    width: 100%;
    line-height: 1.5;
    display: inline-flex;
  }

  .menu-item .sub-menu a, .menu-item .sub-menu button {
    color: var(--color-sub-menu);
  }

  .menu-item .sub-menu {
    --color-current: var(--color-current-dropdown);
  }

  .menu-item.current-menu-item > a, .menu-item.current-menu-parent > a {
    color: var(--color-current);
  }

  .sub-menu .menu-item.current-menu-item > a {
    text-decoration: underline 2px;
  }

  .menu-item.menu-item-has-children a {
    transition: background-color .2s cubic-bezier(.19, 1, .22, 1);
  }

  .menu-item > a:focus, .menu-item > a:hover {
    color: var(--color-hover-main-level);
  }

  .menu-item .sub-menu a:focus, .menu-item .sub-menu a:hover {
    color: var(--color-hover-sub-menu);
    text-decoration: underline 2px;
  }

  .menu-item.menu-item-has-children.hover-intent .sub-menu a, .menu-item.menu-item-has-children:focus .sub-menu a {
    padding-bottom: var(--padding-sub-menu-link-vertical);
    padding-top: var(--padding-sub-menu-link-vertical);
  }

  .menu-item.menu-item-has-children.hover-intent .sub-menu, .menu-item.menu-item-has-children:focus .sub-menu {
    padding-bottom: var(--padding-sub-menu-vertical);
    padding-top: var(--padding-sub-menu-vertical);
  }

  .nav-primary > ul:first-of-type > .menu-item-has-children:focus:before, .nav-primary > ul:first-of-type > .menu-item-has-children:hover:before {
    transition: all .2s cubic-bezier(.19, 1, .22, 1);
    transform: scale(1);
  }

  .no-js .sub-menu {
    left: unset;
    display: none;
    right: 0;
  }

  .no-js .sub-menu .sub-menu {
    left: unset;
    right: 100%;
  }

  .no-js .menu-item-has-children:focus-within > .sub-menu, .no-js .menu-item-has-children:focus > .sub-menu, .no-js .menu-item-has-children:hover > .sub-menu {
    display: block;
  }

  .js .sub-menu {
    margin-top: var(--gap-dropdown);
    opacity: 0;
    visibility: hidden;
  }

  .js .sub-menu .sub-menu {
    margin-top: calc(var(--padding-sub-menu-vertical)*-1);
  }

  .sub-menu {
    background-color: var(--color-background-sub-menu);
    border: 1px solid var(--color-black);
    width: var(--width-sub-menu);
    z-index: 9;
    margin-left: 0;
    padding: 0;
    transition: all .2s cubic-bezier(.19, 1, .22, 1);
    position: absolute;
    top: 100%;
    left: 0;
  }

  .sub-menu.is-out-of-viewport {
    left: unset;
    right: 0;
  }

  .sub-menu .sub-menu.is-out-of-viewport, .sub-menu.is-out-of-viewport .sub-menu {
    left: unset;
    right: 100%;
  }

  .sub-menu .sub-menu {
    margin-left: 0;
    top: 0;
    left: 100%;
  }

  .sub-menu li {
    padding: 0;
  }

  .menu-item-has-children.hover-intent > .sub-menu, .menu-item-has-children:focus > .sub-menu {
    opacity: 1;
    visibility: visible;
    z-index: 12;
    transform: translateY(0);
  }

  .menu-item-has-children.hover-intent .sub-menu .sub-menu, .menu-item-has-children:focus .sub-menu .sub-menu {
    margin-top: calc(var(--padding-sub-menu-vertical)*-1);
    z-index: 10;
    top: 0;
  }

  .menu-item.menu-item-has-children {
    align-items: center;
    gap: var(--gap-between-dropdown-toggle);
    justify-content: space-between;
    display: flex;
    position: relative;
  }

  .menu-item.menu-item-has-children:after {
    content: "";
    height: var(--gap-dropdown);
    max-width: var(--width-sub-menu);
    visibility: hidden;
    width: 100%;
    display: block;
    position: absolute;
    top: 100%;
  }

  .menu-item.menu-item-has-children.hover-intent:after {
    visibility: visible;
    z-index: 100;
  }

  .dropdown-toggle svg {
    height: var(--dropdown-toggle-size);
    width: var(--dropdown-toggle-size);
    transition: all .35s cubic-bezier(.19, 1, .22, 1);
  }

  .hover-intent > .dropdown-toggle svg {
    transform: rotateX(180deg);
  }

  .dropdown-toggle {
    pointer-events: none;
    background-color: #0000;
    border: 0;
    justify-content: center;
    align-items: center;
    padding: 0;
    display: inline-flex;
  }

  .sub-menu .dropdown-toggle {
    width: 1.875rem;
  }

  .sub-menu .dropdown-toggle svg {
    transform: rotate(-90deg)rotateX(0);
  }

  .sub-menu .hover-intent > .dropdown-toggle > svg {
    transform: rotate(-90deg)rotateX(180deg);
  }

  .sub-menu .menu-item-has-children:after {
    display: none;
  }

  .menu-item.menu-item-has-children.hover-intent > .dropdown-toggle svg, .menu-item.menu-item-has-children:focus > .dropdown-toggle svg {
    transform: translateY(0)rotate(180deg);
  }

  .menu-item.menu-item-has-children .menu-item.menu-item-has-children.hover-intent > .dropdown-toggle svg, .menu-item.menu-item-has-children .menu-item.menu-item-has-children:focus > .dropdown-toggle svg {
    transform: translateY(0)rotate(90deg);
  }
}

@media only screen and (width >= 1030px) and (width <= 1030px) {
  ul li:focus > ul, ul li:hover > ul {
    display: block;
  }
}

.is-root-container, body:not(.wp-admin) {
  color: var(--color-paragraph);
  font-family: var(--typography-family-paragraph);
  font-size: var(--typography-paragraph-size);
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-weight: var(--typography-weight-paragraph);
  line-height: var(--typography-paragraph-line-height);
  text-rendering: geometricprecision;
}

.block {
  background-color: var(--color-white);
  margin: 0 auto;
  position: relative;
}

.global-link {
  z-index: 3;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.site {
  max-width: 100%;
  min-height: 100vh;
  margin-left: auto;
  margin-right: auto;
  overflow: hidden;
}

.container {
  max-width: var(--wp--custom--grid-base);
  padding: var(--spacing-container-padding-block) var(--spacing-container-padding-inline);
  margin: 0 auto;
}

.edit-link, .edit-link:last-child {
  --color-link-edit-border: #ddd;
  --color-link-edit-text: #555;
  --color-link-edit-text-hover: #fff;
  --color-link-edit-background-hover: #aaa;
  --color-link-edit-border-hover: #aaa;
  max-width: var(--wp--custom--grid-base);
  text-align: left;
  width: 100%;
  min-width: 0;
  margin: 1.25rem auto;
  transition: all .15s;
  display: block;
  overflow: hidden;
}

.edit-link a, .edit-link:last-child a {
  background-color: var(--color-white);
  border: 2px dashed var(--color-link-edit-border);
  clear: both;
  color: var(--color-link-edit-text);
  font-weight: var(--typography-weight-semibold);
  text-align: center;
  max-width: calc(100% - 2rem);
  margin: 0 auto;
  padding: 1rem;
  text-decoration: none;
  transition: all .15s;
  display: block;
}

.edit-link a:hover, .edit-link:focus, .edit-link:last-child a:hover, .edit-link:last-child:focus {
  background-color: var(--color-link-edit-background-hover);
  border-color: var(--color-link-edit-border-hover);
  color: var(--color-link-edit-text-hover);
}

.post-inner {
  max-width: var(--wp--style--global--content-size);
  padding: var(--spacing-block-padding-m) var(--spacing-container-padding-inline);
  margin-left: auto;
  margin-right: auto;
}

@media print {
  .side-nav, .site-footer, .site-header {
    display: none;
  }
}

.is-root-container, body {
  color: var(--color-paragraph);
  font-family: var(--typography-family-paragraph);
  font-size: var(--typography-paragraph-size);
  -moz-osx-font-smoothing: grayscale;
  -webkit-font-smoothing: antialiased;
  font-weight: var(--typography-weight-paragraph);
  line-height: var(--typography-paragraph-line-height);
  text-rendering: geometricprecision;
}

h1, h2, h3, h4, h5, h6 {
  color: var(--color-heading);
  font-family: var(--typography-family-heading);
  font-weight: var(--typography-weight-heading);
  margin-bottom: var(--spacing-paragraphs-margin-block);
  margin-top: var(--spacing-paragraphs-margin-block);
}

h2, h3, h4, h5, h6 {
  line-height: var(--typography-heading-line-height);
}

h1 {
  font-size: var(--typography-size-h1);
}

h2 {
  font-size: var(--typography-size-h2);
}

h3 {
  font-size: var(--typography-size-h3);
}

h4 {
  font-size: var(--typography-size-h4);
}

h5 {
  font-size: var(--typography-size-h5);
}

h6 {
  font-size: var(--typography-size-h6);
}

h1:first-child, h2:first-child, h3:first-child, h4:first-child, h5:first-child, h6:first-child {
  margin-top: 0;
}

b, strong {
  font-weight: var(--typography-weight-bold);
}

em, i {
  font-style: italic;
}

p {
  margin-top: 2rem;
  margin-bottom: 2rem;
}

p:last-child {
  margin-bottom: 0;
}

.wysiwyg li {
  margin-top: .6rem;
  margin-bottom: .6rem;
}

.wysiwyg li:first-child {
  margin-top: 0;
}

.wysiwyg li:last-child {
  margin-bottom: 0;
}

blockquote.wysiwyg {
  border-left: 2px solid var(--color-main);
  margin: 2.9rem 1rem;
  padding: .5rem 0 .5rem 1.5rem;
}

blockquote.wysiwyg > :first-child {
  margin-top: 0;
}

blockquote.wysiwyg > :last-child {
  margin-bottom: 0;
}

.site-header {
  background-color: var(--color-white);
}

@media screen and (width <= 1030px) {
  .site-header {
    background-color: var(--color-background-nav-mobile-header);
  }
}

.js-nav-active .site-header {
  background-color: var(--color-background-nav-mobile-header-active);
}

.site-header-inner {
  align-items: flex-start;
  column-gap: var(--spacing-grid-gap);
  max-width: var(--wp--custom--grid-base);
  padding-bottom: 0;
  padding-left: var(--spacing-container-padding-inline);
  padding-right: var(--spacing-container-padding-inline);
  z-index: 15;
  justify-content: space-between;
  margin-left: auto;
  margin-right: auto;
  padding-top: 2.5rem;
  display: flex;
  position: relative;
}

@media screen and (width <= 1030px) {
  .site-header-inner {
    padding-top: 1.25rem;
    padding-bottom: 0;
  }
}

.site-title {
  margin: 0;
  line-height: 0;
}

.site-title a {
  color: var(--color-black);
  align-items: center;
  display: flex;
}

.site-footer {
  background-color: var(--color-white);
  color: var(--color-paragraph);
  border-top: 1px solid #e3e3f0;
  padding: 3.75rem 1.25rem;
  overflow: hidden;
}

.site-footer .container {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.site-footer a, .site-footer p {
  color: var(--color-black);
}

.site-footer .site-info {
  justify-content: start;
  gap: 1rem;
  display: grid;
}

.site-footer .theme-info {
  font-size: var(--typography-size-16);
}

.site-footer .theme-info a {
  display: block;
}

.site-footer .powered-by-wordpress, .site-footer .theme-info {
  gap: 1rem;
  display: flex;
}

.site-footer .powered-by-wordpress {
  font-weight: var(--typography-weight-semibold);
}

.site-footer .powered-by-wordpress svg {
  width: 1.75rem;
  height: 1.75rem;
}

:root {
  --color-border-sticky: #d7e4f2;
  --color-bypostauthor: #2a2d3e80;
}

.sticky .post-inner {
  border: 2px dashed var(--color-border-sticky);
  margin-bottom: var(--spacing-container-padding-inline);
  padding: var(--spacing-container-padding-inline);
}

.bypostauthor, .comment-list li.bypostauthor {
  border: 1px dashed var(--color-bypostauthor);
  padding: var(--spacing-container-padding-inline);
}

.blog article:first-of-type {
  margin-top: var(--spacing-block-padding-m);
}

.wp-caption {
  max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
  margin: 0 auto;
  display: block;
}

.wp-caption .wp-caption-text {
  text-align: left;
  margin-bottom: 1.25rem;
  padding: .625rem 0;
  font-style: italic;
}

.top {
  --color-background-top: var(--color-black);
  --color-background-top-hover: var(--color-white);
  background-color: var(--color-background-top);
  border: 1px solid var(--color-black);
  bottom: var(--spacing-container-padding-inline);
  color: var(--color-white);
  cursor: pointer;
  font-size: var(--typography-size-16);
  opacity: 0;
  height: 1.875rem;
  right: var(--spacing-container-padding-inline);
  text-align: center;
  visibility: hidden;
  z-index: 1;
  border-radius: 0;
  width: 1.875rem;
  line-height: 1.875rem;
  text-decoration: none;
  transition: opacity .5s;
  position: fixed;
}

.top:hover {
  background-color: var(--color-background-top-hover);
}

.top:focus {
  background-color: var(--color-background-top);
}

.top.is-visible {
  opacity: 1;
  visibility: visible;
}

.gallery {
  grid-gap: 1.5em;
  margin-bottom: 1.5em;
  display: grid;
}

.gallery-item {
  text-align: center;
  width: 100%;
  display: inline-block;
}

.gallery-columns-2 {
  grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
  grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
  grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
  grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
  grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
  grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
  grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
  grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
  display: block;
}

.navigation:not(.post-navigation) .nav-links {
  font-family: var(--typography-family-heading);
  text-align: left;
  justify-content: flex-start;
  align-items: flex-start;
  width: 100%;
  margin-top: 2.5rem;
  font-size: .875rem;
  display: flex;
  overflow: hidden;
}

.navigation:not(.post-navigation) .nav-links a {
  text-decoration: none;
}

.page-numbers {
  --color-pagination-border: #ece6f2;
  --color-pagination-text: #2a2d3e;
  --color-pagination-background-hover: #2a2d3e;
  --color-pagination-border-hover: #2a2d3e;
  --color-pagination-text-hover: #2a2d3e;
  --color-pagination-background-current: #2a2d3e;
  --color-pagination-border-current: #2a2d3e;
  --color-pagination-text-current: var(--color-white);
  background-color: var(--color-white);
  border-bottom: 2px solid var(--color-pagination-border);
  border-left: 1px solid var(--color-pagination-border);
  border-right: 1px solid var(--color-pagination-border);
  border-top: 2px solid var(--color-pagination-border);
  color: var(--color-pagination-text);
  font-weight: var(--typography-weight-medium);
  justify-content: center;
  align-items: center;
  width: 2.1875rem;
  height: 2.1875rem;
  margin-left: 0;
  margin-right: 0;
  transition: all .15s;
  display: flex;
}

.page-numbers:last-child {
  border-radius: 0 4px 4px 0;
}

.page-numbers:first-child {
  border-radius: 4px 0 0 4px;
}

@media (width <= 600px) {
  .page-numbers {
    width: 1.625rem;
    height: 1.625rem;
  }
}

a.page-numbers:focus, a.page-numbers:hover {
  background-color: var(--color-pagination-background-hover);
  border-color: var(--color-pagination-border-hover);
  color: var(--color-pagination-text-hover);
}

.page-numbers.current {
  background-color: var(--color-pagination-background-current);
  border-color: var(--color-pagination-border-current);
  color: var(--color-pagination-text-current);
}

.page-numbers.next, .page-numbers.prev {
  width: auto;
  padding-left: 1.25rem;
  padding-right: 1.25rem;
}

@media (width <= 600px) {
  .page-numbers.next, .page-numbers.prev {
    padding-left: .625rem;
    padding-right: .625rem;
  }
}

.block-search, .block-search-results {
  background-color: var(--color-white);
}

.block-search form {
  grid-gap: .625rem;
  grid-template-columns: 9fr 1fr;
  display: grid;
}

.block-search form input, .block-search form label {
  width: 100%;
}

.block-search-results > .container {
  padding-top: 0;
}

@media (width >= 1024px) {
  .block-search-results > .container {
    display: grid;
  }
}

.block-search-results .row-result {
  border-top: 2px solid var(--color-black);
  padding: 1.25rem 0;
}

.block-search-results .row-result:last-of-type {
  border-bottom: 2px solid var(--color-black);
}

.block-search-results h3 {
  font-size: var(--typography-size-h4);
  margin-bottom: .625rem;
}

.block-search-results p {
  margin-top: .625rem;
}

@media (width >= 600px) {
  .block-error-404 .container {
    padding-top: 10%;
    padding-bottom: 10%;
  }
}

.block-error-404 .content {
  text-align: center;
}

.block-error-404 h1 {
  font-size: clamp(60px, 24px + 6vw, 120px);
  line-height: var(--typography-heading-core-line-height);
  margin-bottom: 1.25rem;
}

.categories, .entry-content .categories, .entry-content .tags, .tags {
  flex-wrap: wrap;
  padding-inline-start: 0;
  list-style: none;
  display: flex;
}

.categories, .entry-content .categories {
  gap: .75rem;
}

.categories a {
  font-size: var(--typography-size-14);
  border-radius: 0;
  margin: 0;
  padding: .3125rem .9375rem;
  transition: all .15s;
  display: inline-block;
}

.categories a, .categories a:focus, .categories a:hover {
  background-color: var(--color-black);
  color: var(--color-white);
}

.entry-content .tags, .tags {
  margin-bottom: var(--spacing-text-margin-block);
  flex-wrap: wrap;
  gap: .3125rem;
  margin-top: 0;
  display: flex;
}

.entry-content .tags a, .tags a {
  border: 1px solid var(--color-black);
  box-shadow: none;
  color: var(--color-paragraph);
  font-size: var(--typography-size-12);
  white-space: nowrap;
  background-color: #0000;
  border-radius: 0;
  margin-right: 4px;
  padding: .0625rem .5rem;
  transition: all .15s;
  display: inline-block;
}

.entry-content .tags a:focus, .entry-content .tags a:hover, .tags a:focus, .tags a:hover {
  background-color: var(--color-black);
  border-color: var(--color-black);
  color: var(--color-white);
}

.post-navigation .nav-links {
  flex-wrap: wrap;
  justify-content: space-between;
  display: flex;
}

.comments-area {
  --color-comment-text: var(--color-paragraph);
  --color-comment-author-text: var(--color-paragraph);
  --color-link-comment: var(--color-accent);
  --color-link-comment-time-anchor: var(--color-paragraph);
  margin-top: 3.125rem;
  margin-bottom: 0;
  overflow: visible;
}

.comment-list {
  margin: 0;
  padding: 0;
}

.comment-list, .comment-list .children {
  list-style: none;
}

.comment-list li {
  margin-top: 0;
  margin-bottom: 4.375rem;
  padding: 0;
}

.comment-list li, .comment-list p {
  font-size: var(--typography-size-14);
}

.comment-list p {
  color: var(--color-comment-text);
}

.comment-list .avatar {
  float: right;
  border-radius: 50%;
}

.comment-list .comment-author {
  color: var(--color-comment-author-text);
  font-size: var(--typography-size-h4);
  margin-top: 0;
  margin-bottom: .625rem;
  padding: 0;
}

.comment-list .comments-link a, .comment-list a {
  box-shadow: none;
  color: var(--color-link-comment);
}

.comment-list .comment-author a {
  color: var(--color-paragraph);
}

.comment-list .comment-time {
  font-size: var(--typography-size-14);
  margin: 0;
  padding: 0;
}

.comment-list .comment-time a {
  color: var(--color-link-comment-time-anchor);
}

.comment-list .comment-time:focus, .comment-list .comment-time:hover {
  opacity: 1;
}

.comment-list .comment-time svg {
  fill: var(--color-link-comment-time-anchor);
  margin-right: .3125rem;
  position: relative;
  top: 2px;
}

.comments-link {
  font-size: var(--typography-size-14);
  text-align: right;
  align-items: center;
  display: inline-flex;
}

.comments-link a {
  color: var(--color-link-comment);
}

.comments-link a:focus, .comments-link a:hover, .comments-link:focus, .comments-link:hover {
  color: var(--color-black);
}

.comments-link svg {
  margin-right: .4375rem;
  position: relative;
  top: -1px;
}

@media (width >= 600px) {
  .comment-form {
    grid-gap: 1em;
    grid-template-columns: 1fr 1fr;
    justify-content: center;
    display: grid;
  }

  .comment-form .comment-form-comment, .comment-form .comment-notes, .comment-form .form-submit {
    grid-column: 1 / span 2;
  }
}

.comment-respond {
  margin-bottom: 0;
  overflow: visible;
}

@media (width <= 600px) {
  .comment-respond input {
    width: 100%;
  }
}

.comment-respond .comment-form-author {
  margin-top: 0;
  margin-bottom: 1.25rem;
}

.comment-respond .comment-form-author input {
  border-width: 1px;
  width: 100%;
  padding: 1.5rem;
}

.comment-respond .comment-form-email {
  clear: right;
  margin-top: 0;
  margin-bottom: 1.25rem;
  margin-right: 0;
}

.comment-respond .comment-form-email input {
  border-width: 1px;
  width: 100%;
  padding: .9375rem;
}

.comment-respond .comment-form-url {
  margin-top: 0;
  margin-bottom: 1.875rem;
  position: relative;
}

.comment-respond .comment-form-url input {
  border-width: 1px;
  width: 100%;
  padding: .9375rem;
}

.comment-respond .form-submit {
  clear: both;
  margin-top: 0;
  margin-bottom: 0;
  display: block;
}

.comment-respond .comment-form-comment {
  margin-bottom: 1.25rem;
}

.comment-respond textarea {
  width: 100%;
}

.wp-block-media-text {
  gap: var(--spacing-grid-gap);
  padding-inline: var(--spacing-container-padding-inline);
}

.wp-block-media-text.has-background {
  background-color: #0000;
  position: relative;
}

.wp-block-media-text.has-background:before {
  background-color: var(--wp--preset--color--light);
  content: "";
  z-index: 0;
  width: 100vw;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
}

.wp-block-media-text.has-background > * {
  z-index: 1;
  position: relative;
}

.wp-block-media-text .wp-block-heading {
  margin: 0;
}

.wp-block-media-text .wp-block-media-text__media {
  aspect-ratio: 4 / 3;
  background-color: var(--color-placeholder, #f0f0f0);
}

.wp-block-media-text .wp-block-media-text__media img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.wp-block-media-text .wp-block-media-text__media:has(img), .wp-block-media-text .wp-block-media-text__media:has(video) {
  background-color: #0000;
}

.wp-block-media-text.is-image-fill-element > .wp-block-media-text__media {
  height: auto;
  min-height: 0;
}

.wp-block-media-text .editor-media-container__resizer {
  aspect-ratio: 4 / 3;
}

.wp-block-media-text .editor-media-container__resizer img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.wp-block-media-text .wp-block-media-text__content {
  padding: 2rem;
}

.wp-block-media-text .wp-block-media-text__content > :first-child {
  margin-top: 0;
}

.wp-block-media-text .wp-block-media-text__content > :last-child {
  margin-bottom: 0;
}

.editor-styles-wrapper .wp-block-media-text .wp-block-media-text__media:empty, .editor-styles-wrapper .wp-block-media-text .wp-block-media-text__media:has(.block-editor-media-placeholder) {
  background-color: var(--color-placeholder, #f0f0f0);
  min-height: 18.75rem;
}

[class*="wp-block"].is-style-has-m-padding {
  padding-bottom: var(--spacing-block-padding-m);
  padding-top: var(--spacing-block-padding-m);
}

[class*="wp-block"].is-style-has-l-padding {
  padding-bottom: var(--spacing-block-padding-l);
  padding-top: var(--spacing-block-padding-l);
}

[class*="wp-block"].is-style-no-padding {
  padding-top: 0;
  padding-bottom: 0;
}

.wp-block-buttons {
  justify-content: flex-start;
}

.wp-block-button {
  text-align: left;
}

.wp-block-button__link {
  appearance: none;
  background-color: var(--color-black);
  border: 1px solid var(--color-black);
  color: var(--color-white);
  cursor: pointer;
  font-family: var(--typography-family-paragraph);
  font-size: var(--typography-size-16);
  font-weight: var(--typography-weight-semibold);
  text-overflow: ellipsis;
  border-radius: 0;
  width: auto;
  max-width: 230px;
  margin-bottom: 0;
  padding: 14px 21px;
  line-height: 1.39;
  text-decoration: none;
  transition: all .15s cubic-bezier(.25, .46, .45, .94);
  position: relative;
  overflow: hidden;
  white-space: nowrap !important;
}

.wp-block-button__link.focus, .wp-block-button__link:focus, .wp-block-button__link:hover {
  background-color: var(--color-white);
  border-color: var(--color-black);
  color: var(--color-black);
}

.wp-block-button__link {
  text-align: center;
  display: inline-block;
}

.button {
  appearance: none;
  background-color: var(--color-black);
  border: 1px solid var(--color-black);
  color: var(--color-white);
  cursor: pointer;
  font-family: var(--typography-family-paragraph);
  font-size: var(--typography-size-16);
  font-weight: var(--typography-weight-semibold);
  text-overflow: ellipsis;
  border-radius: 0;
  width: auto;
  max-width: 230px;
  margin-bottom: 0;
  padding: 14px 21px;
  line-height: 1.39;
  text-decoration: none;
  transition: all .15s cubic-bezier(.25, .46, .45, .94);
  display: inline-block;
  position: relative;
  overflow: hidden;
  white-space: nowrap !important;
}

.button.focus, .button:focus, .button:hover {
  background-color: var(--color-white);
  border-color: var(--color-black);
  color: var(--color-black);
}

.button-small {
  appearance: none;
  background-color: var(--color-black);
  border: 1px solid var(--color-black);
  color: var(--color-white);
  cursor: pointer;
  font-family: var(--typography-family-paragraph);
  font-weight: var(--typography-weight-semibold);
  text-overflow: ellipsis;
  border-radius: 0;
  width: auto;
  max-width: 230px;
  margin-bottom: 0;
  padding: 14px 21px;
  line-height: 1.39;
  text-decoration: none;
  transition: all .15s cubic-bezier(.25, .46, .45, .94);
  display: inline-block;
  position: relative;
  overflow: hidden;
  white-space: nowrap !important;
}

.button-small.focus, .button-small:focus, .button-small:hover {
  background-color: var(--color-white);
  border-color: var(--color-black);
  color: var(--color-black);
}

.button-small {
  padding: 8px 19px;
  line-height: 20.9091px;
}

.button-large, .button-small {
  font-size: var(--typography-size-16);
}

.button-large {
  appearance: none;
  background-color: var(--color-black);
  border: 1px solid var(--color-black);
  color: var(--color-white);
  cursor: pointer;
  font-family: var(--typography-family-paragraph);
  font-weight: var(--typography-weight-semibold);
  text-overflow: ellipsis;
  border-radius: 0;
  width: auto;
  max-width: 230px;
  margin-bottom: 0;
  padding: 14px 21px;
  line-height: 1.39;
  text-decoration: none;
  transition: all .15s cubic-bezier(.25, .46, .45, .94);
  display: inline-block;
  position: relative;
  overflow: hidden;
  white-space: nowrap !important;
}

.button-large.focus, .button-large:focus, .button-large:hover {
  background-color: var(--color-white);
  border-color: var(--color-black);
  color: var(--color-black);
}

.button-large {
  font-size: var(--typography-size-18);
  padding: 15px 19px;
  line-height: 1.66;
}

.alignwide {
  max-width: var(--wp--style--global--wide-size);
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.alignfull {
  width: 100vw;
  max-width: none;
}

img {
  max-width: 100%;
}

img[width][height] {
  height: auto;
}

a {
  color: var(--color-link-text);
  text-decoration: underline;
  -webkit-text-decoration-color: var(--color-link-text);
  text-decoration-color: var(--color-link-text);
  text-underline-offset: .375rem;
  transition: all .15s;
}

a:focus, a:hover {
  color: var(--color-link-text-hover);
  -webkit-text-decoration-color: var(--color-link-text-hover);
  text-decoration-color: var(--color-link-text-hover);
}

.entry-footer a, .site-footer a, .site-header a {
  text-decoration: none;
}

p {
  color: var(--color-paragraph);
  line-height: var(--typography-paragraph-line-height);
}

body, html[lang="ja"] {
  font-family: Noto Sans JP, Hiragino Kaku Gothic ProN, Meiryo, sans-serif;
  font-size: 16px;
}

body.no-scroll {
  overflow: hidden;
}

p {
  font-size: 16px;
  line-height: 2rem;
}

.site {
  background-color: #e0f3d8;
}

.site, .site-header {
  z-index: 1;
  position: relative;
}

.site-header {
  background-color: #0000;
  width: 100%;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  top: 1rem;
}

.site-header .site-header-inner {
  background-image: url("site-header-bg.55089613.png");
  background-repeat: no-repeat;
  background-size: 1300px 142px;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  padding: 3rem 8rem .5rem 1rem;
}

@media (width <= 736px) {
  .site-header .site-header-inner {
    background-image: url("site-header-bg-sp.39aa370a.png");
    background-size: 370px 157px;
    max-width: 370px;
    height: 100%;
    max-height: 157px;
    padding-top: 2rem;
    padding-bottom: 0;
    padding-right: 6rem;
  }
}

@media (width <= 480px) {
  .site-header .site-header-inner {
    padding-right: 5rem;
  }
}

.site-header .site-branding {
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  width: 100%;
  display: flex;
}

@media (width <= 736px) {
  .site-header .site-branding {
    flex-direction: column;
    gap: .5rem;
  }
}

.site-header .site-branding .site-title {
  width: calc(100% - 5rem);
}

@media (width <= 736px) {
  .site-header .site-branding .site-title {
    width: 100%;
  }
}

.site-header .site-branding .site-title .screen-reader-text {
  border: none;
  padding: 0;
}

.site-header .site-branding .site-description {
  margin: 0;
}

@media (width <= 736px) {
  .site-header .site-branding .site-description {
    padding: 0 0 1rem 1rem;
    font-size: 13px;
    line-height: 1.2em;
  }
}

.fixed-background {
  z-index: 0;
  background-color: #e0f3d8;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  display: flex;
  position: relative;
  top: 1rem;
  left: 0;
  overflow: hidden;
}

.fixed-background div {
  text-align: center;
  width: 100%;
}

.fixed-background div.top-image-01 {
  background-color: #e0f3d8;
  padding: 0 1.5rem;
}

.fixed-background div.top-image-02 {
  background-color: #ffd174;
}

.fixed-background div.top-image-03 {
  background-color: #8cc468;
}

.fixed-background div img {
  margin: 0 auto;
  display: block;
}

.tag-line {
  position: fixed;
  top: 10rem;
  left: 4rem;
}

@media (width <= 736px) {
  .tag-line {
    left: 1rem;
  }
}

.mask-overlay, .slider-container {
  aspect-ratio: 2;
  border-radius: 100vw;
  width: 70vw;
  max-width: 1200px;
  position: absolute;
  top: 50%;
  left: 50%;
  overflow: hidden;
  transform: translate(-50%, -50%)rotate(-21deg);
}

.slide {
  opacity: 0;
  background-position: 50%;
  background-repeat: no-repeat;
  background-size: contain;
  width: 160%;
  height: 160%;
  animation-name: a;
  animation-duration: 12s;
  animation-iteration-count: infinite;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%)rotate(21deg)scale(1);
}

.slide-1 {
  background-image: url("header-image-01.93e7145c.png");
  animation-delay: 0s;
}

.slide-1, .slide-2 {
  transform: translate(-50%, -50%)rotate(21deg)scale(1.2);
}

.slide-2 {
  background-image: url("header-image-02.efa6287c.png");
  animation-delay: 4s;
}

.slide-3 {
  background-image: url("header-image-03.888c60b8.png");
  animation-delay: 8s;
  transform: translate(-50%, -50%)rotate(21deg)scale(1.2);
}

@keyframes a {
  0% {
    opacity: 0;
  }

  10% {
    opacity: 1;
  }

  33% {
    opacity: 1;
  }

  43% {
    opacity: 0;
  }

  to {
    opacity: 0;
  }
}

.hero-copy {
  position: fixed;
  top: 33rem;
  right: 3rem;
}

@media (width <= 736px) {
  .hero-copy {
    left: 3rem;
    right: 0;
  }
}

.nav-container {
  z-index: 10;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  position: fixed;
  top: 2rem;
  left: 0;
  right: 1rem;
}

@media (width <= 736px) {
  .nav-container {
    max-width: 370px;
    top: .5rem;
    right: .5rem;
  }
}

.menu-checkbox {
  display: none;
}

.menu-button {
  cursor: pointer;
  z-index: 10;
  flex-direction: column;
  justify-content: space-between;
  width: 62px;
  height: 35px;
  display: flex;
  position: absolute;
  top: 3rem;
  right: 42px;
}

@media (width <= 736px) {
  .menu-button {
    top: 6rem;
    right: 20px;
  }
}

@media (width <= 480px) {
  .menu-button {
    right: 33px;
  }
}

.menu-button span {
  background-color: #333;
  width: 100%;
  height: 3px;
  transition: all .3s;
  display: block;
}

.menu-items {
  background-color: #fff;
  border: 1px solid #707070;
  width: 234px;
  max-height: 0;
  padding: 62px 1rem 1rem;
  list-style: none;
  transition: max-height .4s ease-in-out;
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  overflow: hidden;
  box-shadow: 3px 3px 1px #00000040;
}

@media only screen and (width <= 1030px) {
  .menu-items ul {
    display: block;
  }

  .menu-items .menu-item.current-menu-item > a, .menu-items .menu-item.current-menu-parent > a {
    color: #000;
  }

  .menu-items .menu-item a {
    color: #000;
    padding: 0;
  }
}

.menu-items .menu-item-list li {
  text-align: left;
  border-bottom: 1px solid #707070;
  padding: .5rem 0;
}

.menu-items .menu-item-list li a {
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
}

.menu-checkbox:checked ~ .menu-items {
  max-height: 500px;
  display: block;
}

.menu-checkbox:checked + .menu-button span:first-child {
  transform: translateY(16px)rotate(45deg);
}

.menu-checkbox:checked + .menu-button span:nth-child(2) {
  opacity: 0;
}

.menu-checkbox:checked + .menu-button span:nth-child(3) {
  transform: translateY(-16px)rotate(-45deg);
}

ul.menu-contact-links {
  justify-content: space-around;
  align-items: center;
  margin: 1.5rem 0 0;
  display: flex;
}

@media only screen and (width <= 1030px) {
  ul.menu-contact-links {
    display: flex;
  }
}

.tab-recruiting {
  z-index: 10;
  background-color: #707070;
  border-radius: 10px 0 0 10px;
  width: 39px;
  padding: 1.2rem 5px;
  position: fixed;
  top: 282px;
  right: 0;
}

@media (width <= 736px) {
  .tab-recruiting {
    top: 10rem;
  }
}

.tab-recruiting p {
  margin: 0;
}

.tab-recruiting p a {
  color: #fff;
  letter-spacing: .1em;
  writing-mode: vertical-rl;
  font-size: 16px;
  line-height: 1.8;
  text-decoration: none;
}

.site-content {
  z-index: 4;
  background-color: #e0f3d8;
  width: 100%;
  padding: 4rem 1.5rem 0;
  position: relative;
}

.site-content .site-main {
  box-sizing: border-box;
  background-color: #fff;
  border-radius: 50px 50px 0 0;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  padding-top: 50px;
}

@media (width <= 736px) {
  .site-content .site-main {
    border-radius: 1rem 1rem 0 0;
    max-width: 370px;
    padding-top: 1rem;
  }
}

.site-content .site-main section {
  margin-bottom: 5rem;
}

.site-content .site-main h2 {
  color: #1e8a46;
  text-align: right;
  border-bottom: 1px solid #000;
  width: 50%;
  padding-bottom: 1rem;
  font-size: 16px;
  font-weight: 700;
}

@media (width <= 736px) {
  .site-content .site-main h2 {
    margin-bottom: 1rem;
  }
}

.section {
  height: 80rem;
}

.link-button a {
  width: 100%;
  text-decoration: none;
  display: inline-block;
}

.home .home-header-content {
  z-index: 1;
  background-color: #0000;
  padding: 0;
  position: relative;
}

.home .home-header-content h3 {
  font-size: 30px;
  font-weight: 700;
}

@media (width <= 736px) {
  .home .home-header-content h3 {
    margin-bottom: .5rem;
    font-size: 18px;
  }
}

.home .home-header-content p {
  font-size: 16px;
  font-weight: 400;
}

@media (width <= 736px) {
  .home .home-header-content p {
    margin-top: .5rem;
    font-size: 12px;
    line-height: 1.2rem;
  }
}

.home .home-header-content .section-01 {
  aspect-ratio: 2732 / 1928;
  background: #e0f3d8 url("front-section-01-bg.ed96ed8c.png") 0 0 / contain no-repeat;
  width: 100%;
  position: relative;
}

@media (width <= 736px) {
  .home .home-header-content .section-01 {
    padding-top: 42vw;
    padding-bottom: 1rem;
  }
}

.home .home-header-content .section-01 .section-01-text {
  width: 34rem;
  position: absolute;
  top: 33vw;
  left: 5vw;
}

@media (width <= 736px) {
  .home .home-header-content .section-01 .section-01-text {
    background-color: #fff9;
    width: 100%;
    padding: 0 .5rem;
    position: relative;
    top: auto;
    left: auto;
  }
}

.home .home-header-content .section-02, .home .home-header-content .section-03 {
  background-color: #e0f3d8;
  width: 100%;
  padding-bottom: 3rem;
}

@media (width <= 736px) {
  .home .home-header-content .section-02 {
    padding-bottom: 0;
  }

  .home .home-header-content .section-03 {
    padding: 0 1rem;
  }
}

.home .home-header-content .section-02-inner {
  background-color: #fff;
  border-radius: 60px;
  gap: 2rem;
  max-width: 980px;
  margin: -3rem auto 0;
  padding: 1.5rem 5rem 1.5rem 2rem;
  display: flex;
  position: relative;
}

@media (width <= 736px) {
  .home .home-header-content .section-02-inner {
    border-radius: 1rem;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: 0 1rem;
    padding: 1rem;
  }
}

.home .home-header-content .section-02-inner .section-02-image {
  text-align: center;
  flex: 286 0;
  position: relative;
}

.home .home-header-content .section-02-inner .section-02-image figure {
  margin-bottom: 0;
}

.home .home-header-content .section-02-inner .section-02-image .section-02-image-01 {
  text-align: right;
  margin-top: -5rem;
  position: relative;
  right: 0;
}

@media (width <= 736px) {
  .home .home-header-content .section-02-inner .section-02-image .section-02-image-01 {
    margin-top: 0;
  }
}

.home .home-header-content .section-02-inner .section-02-image .section-02-image-02 {
  margin-top: 1rem;
  position: relative;
  left: 0;
}

.home .home-header-content .section-02-inner .section-02-text {
  flex: 578;
}

@media (width <= 736px) {
  .home .home-header-content .section-03 {
    padding-bottom: 1rem;
  }
}

.home .home-header-content .section-03 .wpcp-all-captions {
  text-align: center;
  font-size: 13px;
}

.home .home-header-content .section-03 + p:empty {
  display: none;
}

.home .home-header-content .section-03 + p {
  margin: 0;
  padding: 0;
}

.home .home-header-content .section-03 + p:is(:empty, :has(br)) {
  display: none;
}

.home .site-content .site-main .section-image-full {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}

.home .site-content .site-main .section-image-full img {
  width: 100%;
}

.home .site-content .site-main .link-button {
  width: 100%;
  max-width: 405px;
  margin: 0 auto;
}

.home .site-content .site-main .link-button a {
  width: 100%;
  text-decoration: none;
  display: inline-block;
}

@media (width <= 736px) {
  .home .site-content .site-main .link-button {
    padding: 0 1rem;
  }
}

.home .site-content .site-main .link-button p {
  text-align: center;
  background-color: #daf3d9;
  border-radius: 100vh;
  margin: 0 auto;
  line-height: 3em;
  box-shadow: 2px 2px 0 1px #262727;
}

.home .site-content .site-main .section-inner-row {
  flex-direction: row;
  gap: 4rem;
  margin-bottom: 0;
  display: flex;
}

.home .site-content .site-main .section-inner-row:first-child {
  margin-bottom: 2rem;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-inner-row:first-child {
    margin-bottom: 6rem;
  }

  .home .site-content .site-main .section-inner-row {
    flex-direction: column;
  }
}

.home .site-content .site-main .section-inner-col {
  flex-direction: column;
  flex: 1;
  margin-bottom: 0;
  display: flex;
}

.home .site-content .site-main .section-inner-col h3 {
  border-bottom: 1px solid;
  margin-bottom: 1rem;
  padding-bottom: 1rem;
  font-size: 20px;
  font-weight: 700;
}

.home .site-content .site-main .section-inner-col p {
  margin-top: 0;
}

.home .site-content .site-main .section-01-greeting h3 {
  flex-direction: row;
  align-items: center;
  width: fit-content;
  margin: 4rem auto 1rem;
  display: flex;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-01-greeting h3 {
    flex-direction: column;
    margin: 0;
    padding: 1rem;
  }
}

.home .site-content .site-main .section-01-greeting p {
  width: 100%;
  max-width: 730px;
  margin: 0 auto 1rem;
  padding: 0 1rem;
  font-size: 16px;
  font-weight: 400;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-01-greeting p {
    line-height: 1.5rem;
  }
}

.home .site-content .site-main .section-01-greeting p.president-signature {
  text-align: right;
  margin-bottom: 2rem;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-01-greeting p.president-signature {
    flex-direction: column;
    display: flex;
  }
}

.home .site-content .site-main .section-01-greeting p.president-signature span.president-title {
  margin-left: 2rem;
  font-size: 13px;
  font-weight: 400;
}

.home .site-content .site-main .section-01-greeting p.president-signature span.president-name {
  margin-left: 2rem;
  font-size: 20px;
  font-weight: 400;
}

.home .site-content .site-main .section-02-services ul.section-02-service-list {
  flex-direction: row;
  justify-content: center;
  gap: 2rem;
  width: 100%;
  max-width: 980px;
  margin: 0 auto 2rem;
  padding: 0 1rem;
  list-style: none;
  display: flex;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-02-services ul.section-02-service-list {
    flex-direction: column;
    align-items: center;
  }
}

.home .site-content .site-main .section-02-services ul.section-02-service-list li {
  width: 100%;
  max-width: 259px;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-02-services ul.section-02-service-list li {
    padding: 0 1rem;
  }
}

.home .site-content .site-main .section-02-services ul.section-02-service-list li figure {
  text-align: center;
}

.home .site-content .site-main .section-02-services ul.section-02-service-list li h3 {
  text-align: center;
  font-size: 20px;
  font-weight: 700;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-02-services ul.section-02-service-list li h3 {
    margin: 1rem 0;
  }
}

.home .site-content .site-main .section-02-services ul.section-02-service-list li p {
  font-size: 16px;
  line-height: 2em;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-02-services ul.section-02-service-list li p {
    margin: 1rem 0;
  }
}

.home .site-content .site-main .section-03-dealers #section-03-dealers-inner {
  background-color: #fcfceb;
  border-radius: 20px;
  margin: 0 3rem;
  padding: 1.5rem 5rem 3rem;
  position: relative;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-03-dealers #section-03-dealers-inner {
    border-radius: 1rem;
    margin: 0 1rem;
    padding: 1rem;
  }
}

.home .site-content .site-main .section-03-dealers section {
  margin-bottom: 1rem;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-03-dealers section {
    margin-bottom: 2rem;
  }
}

.home .site-content .site-main .section-03-dealers ol {
  margin-bottom: 0;
  font-size: 16px;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-03-dealers ol {
    padding-left: 1rem;
  }
}

.home .site-content .site-main .section-03-dealers ol li {
  margin-bottom: 2rem;
}

.home .site-content .site-main .section-03-dealers ol li:last-child {
  margin-bottom: 0;
}

.home .site-content .site-main .section-03-dealers ol li h4 {
  margin-bottom: 0;
  font-size: 16px;
  font-weight: 400;
}

.home .site-content .site-main .section-03-dealers ol li p {
  margin-bottom: 0;
}

.home .site-content .site-main .section-03-dealers .section-inner-row {
  position: relative;
}

@media (width <= 1300px) {
  .home .site-content .site-main .section-03-dealers .section-inner-row {
    flex-direction: column;
    align-items: center;
  }
}

.home .site-content .site-main .section-03-dealers figure {
  position: absolute;
  bottom: 0;
  right: 0;
}

@media (width <= 1300px) {
  .home .site-content .site-main .section-03-dealers figure {
    position: relative;
    bottom: 0;
    right: 0;
  }
}

.home .site-content .site-main .section-03-dealers .link-button p {
  width: fit-content;
  padding: 0 2rem;
}

.home .site-content .site-main .section-03-dealers .link-button p a {
  text-decoration: none;
}

.home .site-content .site-main .section-03-dealers .overlay {
  z-index: 1000;
  -webkit-overflow-scrolling: touch;
  background-color: #0000;
  width: 100%;
  height: 100%;
  transition: background-color .3s;
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  overflow-y: auto;
}

.home .site-content .site-main .section-03-dealers .overlay.is-visible {
  background-color: #000c;
  display: block;
}

.home .site-content .site-main .section-03-dealers .popup-content {
  opacity: 0;
  justify-content: center;
  align-items: flex-start;
  min-height: 100%;
  padding: 40px 20px;
  transition: transform .4s cubic-bezier(.165, .84, .44, 1), opacity .4s;
  display: flex;
  transform: translateY(20px)scale(.95);
}

.home .site-content .site-main .section-03-dealers .overlay.is-visible .popup-content {
  opacity: 1;
  transform: translateY(0)scale(1);
}

.home .site-content .site-main .section-03-dealers .popup-content img {
  max-width: 90%;
  height: auto;
  box-shadow: 0 5px 15px #00000080;
}

.home .site-content .site-main .section-03-dealers .close-btn {
  color: #fff;
  cursor: pointer;
  background: none;
  border: none;
  font-size: 30px;
  position: fixed;
  top: 20px;
  right: 20px;
}

.home .site-content .site-main .section-04-aboutus .section-inner {
  padding: 2rem 5rem;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-04-aboutus .section-inner {
    padding: 1rem;
  }
}

.home .site-content .site-main .section-04-aboutus .section-04-image {
  text-align: center;
}

.home .site-content .site-main .section-04-aboutus h3 {
  border-bottom: none;
  padding: 0;
  font-size: 20px;
  font-weight: 700;
}

.home .site-content .site-main .section-04-aboutus dl {
  flex-wrap: wrap;
  width: 100%;
  max-width: 700px;
  margin: 0 auto;
  display: flex;
}

.home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-summary dt {
  width: 6em;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-summary dt {
    width: 5em;
  }
}

.home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-summary dd {
  flex: 1;
  min-width: calc(100% - 6em);
}

@media (width <= 736px) {
  .home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-summary dd {
    min-width: calc(100% - 5em);
  }

  .home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-history {
    flex-direction: column;
  }
}

.home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-history dt {
  width: 10em;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-history dt {
    border-bottom: none;
    width: 100%;
    font-weight: 700;
  }
}

.home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-history dd {
  flex: 1;
  min-width: calc(100% - 10em);
}

@media (width <= 736px) {
  .home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-history dd {
    width: 100%;
    min-width: auto;
    padding-left: 1rem;
    font-size: 14px;
  }
}

.home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-history dd .history-indent {
  margin-left: 3em;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-04-aboutus dl#section-04-aboutus-history dd .history-indent {
    margin-left: .5em;
    font-size: 13px;
  }
}

.home .site-content .site-main .section-04-aboutus dl dd, .home .site-content .site-main .section-04-aboutus dl dt {
  border-bottom: 1px solid #ccc;
  padding: .5rem;
  font-size: 16px;
}

.home .site-content .site-main .section-04-aboutus dl dt {
  font-weight: 400;
}

.home .site-content .site-main .section-04-aboutus dl dd {
  margin-left: 0;
}

.home .site-content .site-main .section-05-whats-new .section-inner {
  margin: 0 7rem;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-05-whats-new .section-inner {
    margin: 0 1rem;
  }
}

.home .site-content .site-main .section-06-access {
  margin-bottom: 0;
}

.home .site-content .site-main .section-06-access .section-inner {
  aspect-ratio: 1250 / 560;
  width: 100%;
  margin-bottom: 0;
  padding: 0 1rem 3rem;
}

@media (width <= 736px) {
  .home .site-content .site-main .section-06-access .section-inner {
    aspect-ratio: 4 / 3;
  }
}

.home .site-content .site-main .section-06-access iframe {
  width: 100%;
  height: 100%;
}

.home .site-content .site-main ul.news-index {
  flex-direction: column;
  margin: 0 0 2rem;
  padding: 0;
  list-style: none;
  display: flex;
}

@media (width <= 736px) {
  .home .site-content .site-main ul.news-index {
    gap: 1rem;
    margin-bottom: 1rem;
  }
}

.home .site-content .site-main ul.news-index li {
  width: 100%;
}

.home .site-content .site-main ul.news-index li a {
  flex-direction: row;
  gap: 3rem;
  width: 100%;
  text-decoration: none;
  display: flex;
}

@media (width <= 736px) {
  .home .site-content .site-main ul.news-index li a {
    flex-direction: column;
    gap: 1rem;
  }
}

.home .site-content .site-main ul.news-index li a figure {
  width: 150px;
}

@media (width <= 736px) {
  .home .site-content .site-main ul.news-index li a figure {
    text-align: center;
    width: 100%;
    margin-bottom: 0;
  }

  .home .site-content .site-main ul.news-index li a figure img {
    width: 100%;
    max-width: 150px;
  }
}

.home .site-content .site-main ul.news-index li a .news-text {
  flex: 1;
  min-width: 0;
}

.home .site-content .site-main ul.news-index li a .news-text .news-title {
  border-bottom: none;
  margin-bottom: 0;
  font-size: 20px;
  font-weight: 700;
}

.home .site-content .site-main ul.news-index li a .news-text .new-time {
  font-size: 16px;
  font-weight: 400;
}

.home .site-content .site-main ul.news-index li a .news-text p.news-excerpt {
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 100%;
  margin-top: 1rem;
  overflow: hidden;
}

.recruit .site-content {
  margin-top: 1rem;
  padding-top: 0;
}

.recruit .site-content .site-main {
  border-radius: unset;
  padding: 0 5rem;
}

@media (width <= 736px) {
  .recruit .site-content .site-main {
    padding: 0 1rem;
  }
}

.recruit .site-content #page-recruit-header {
  position: relative;
}

.recruit .site-content #page-recruit-header .recruit-header-tab {
  position: absolute;
  top: -10px;
  left: 7rem;
}

@media (width <= 736px) {
  .recruit .site-content #page-recruit-header .recruit-header-tab {
    text-align: center;
    position: relative;
    top: auto;
    left: auto;
  }

  .recruit .site-content #page-recruit-header .recruit-header-iamge {
    display: none;
  }
}

.recruit .site-content #page-recruit-header strong {
  font-size: 14px;
  font-weight: 700;
}

.recruit .site-content #page-recruit-header ul {
  gap: 1rem;
  margin-bottom: 0;
  list-style: none;
  display: flex;
}

@media (width <= 736px) {
  .recruit .site-content #page-recruit-header ul {
    justify-content: center;
    gap: 1rem;
    padding: 0 1rem;
  }
}

.recruit .site-content #page-recruit-header ul li {
  text-align: center;
  border-top: 1px solid #000;
  border-left: 1px solid #000;
  border-right: 1px solid #000;
  border-radius: 10px 10px 0 0;
  width: 142px;
}

.recruit .site-content #page-recruit-header ul li a {
  width: 100%;
  padding: 5px;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2rem;
  text-decoration: none;
  display: inline-block;
}

.recruit .site-content #page-recruit-header ul li span {
  white-space: nowrap;
}

.recruit .site-content #section-00-crosstalk {
  border-top: 1px solid #000;
  margin-bottom: 1rem;
  padding-top: 3rem;
}

@media (width <= 736px) {
  .recruit .site-content #section-00-crosstalk {
    padding-top: 0;
  }
}

.recruit .site-content #section-00-crosstalk section {
  margin-bottom: 1rem;
}

.recruit .site-content #section-00-crosstalk .crosstalk-theme .crosstalk-row {
  flex-direction: row;
  gap: 4rem;
  display: flex;
}

.recruit .site-content #section-00-crosstalk .crosstalk-theme .crosstalk-row .crosstalk-col {
  flex-direction: column;
  display: flex;
}

.recruit .site-content #section-00-crosstalk .crosstalk-theme .crosstalk-row .crosstalk-col h3 {
  font-size: 26px;
  font-weight: 700;
}

.recruit .site-content #section-00-crosstalk .crosstalk-theme .crosstalk-row .crosstalk-col .crosstalk-talk {
  flex-direction: row;
  gap: 1rem;
  margin-bottom: 2rem;
  display: flex;
}

.recruit .site-content #section-00-crosstalk .crosstalk-theme .crosstalk-row .crosstalk-col .crosstalk-talk .crosstalk-talk-icon {
  flex-shrink: 0;
  width: 84px;
}

.recruit .site-content #section-00-crosstalk .crosstalk-theme .crosstalk-row .crosstalk-col .crosstalk-talk .crosstalk-talk-text {
  margin-top: 0;
}

.recruit .site-content #section-00-crosstalk .crosstalk-theme .crosstalk-row .crosstalk-image {
  flex-shrink: 0;
  width: 361px;
}

.recruit .site-content #section-01-carriers {
  margin-bottom: 0;
  padding-top: 2rem;
  padding-bottom: 2rem;
}

@media (width <= 736px) {
  .recruit .site-content #section-01-carriers {
    padding-top: 1rem;
  }

  .recruit .site-content .section-01-carriers-item {
    margin-bottom: 0;
  }
}

.recruit .site-content .section-01-carriers-item header {
  background-color: #e0f3d8;
  margin-bottom: 2rem;
  padding: .5rem;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item header {
    margin-bottom: 1rem;
  }
}

.recruit .site-content .section-01-carriers-item header h3 {
  text-align: center;
  margin-bottom: 0;
  font-size: 26px;
  font-weight: 700;
}

.recruit .site-content .section-01-carriers-item header p {
  text-align: center;
  margin-top: 0;
  font-size: 16px;
  font-weight: 400;
}

.recruit .site-content .section-01-carriers-item p.message-strong {
  color: #e50303;
  text-align: center;
  margin: .5rem 0 1rem;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.2em;
}

.recruit .site-content .section-01-carriers-item h4 {
  margin-bottom: .5rem;
  font-size: 16px;
  font-weight: 700;
}

.recruit .site-content .section-01-carriers-item section {
  margin-bottom: 1rem;
}

.recruit .site-content .section-01-carriers-item ul {
  margin: 0;
  padding: 0;
  list-style: none;
  display: block;
}

.recruit .site-content .section-01-carriers-item ul li:before {
  color: #000;
  content: "・";
  margin-right: 5px;
}

.recruit .site-content .section-01-carriers-item ul li {
  font-size: 16px;
}

.recruit .site-content .section-01-carriers-item .job-description, .recruit .site-content .section-01-carriers-item .job-points {
  padding: 1rem;
  line-height: 1.5em;
}

.recruit .site-content .section-01-carriers-item .job-description {
  background-color: #fee;
}

.recruit .site-content .section-01-carriers-item .job-description p.message-strong {
  text-align: left;
  font-size: 16px;
  line-height: 1.5em;
}

.recruit .site-content .section-01-carriers-item .job-points {
  background-color: #fbf9ce;
  border: 1px solid #e50303;
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-header {
  background-color: #fff;
  padding: 0;
  display: flex;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item .job-points .job-points-header {
    flex-direction: column;
  }
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-header .job-points-header-title {
  color: #fff;
  background-color: #e50303;
  flex: 1;
  width: 100%;
  padding: 5px .5rem;
  font-size: 20px;
  font-weight: 700;
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-header .job-points-header-description {
  color: #e50303;
  background-color: #fff;
  flex: 3;
  width: 100%;
  padding: 5px .5rem;
  font-size: 20px;
  font-weight: 700;
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail {
  grid-template-columns: max-content 1fr;
  gap: 2rem 1rem;
  margin-top: 1.5rem;
  display: grid;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item .job-points .job-points-detail {
    grid-template-columns: 1fr;
    gap: 1rem;
  }
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column {
  flex-direction: column;
  display: flex;
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-header {
  justify-content: center;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-header {
    text-align: center;
  }
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-header .font-large {
  color: #e50303;
  font-size: 26px;
  font-weight: 700;
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-header .font-normal {
  color: #e50303;
  font-size: 18px;
  font-weight: 700;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-text {
    margin-bottom: 1rem;
  }
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-text.ul-star ul li:before {
  content: "★";
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-text p {
    margin-top: 0;
  }
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-text .font-strong {
  font-weight: 700;
}

.recruit .site-content .section-01-carriers-item .job-points .job-points-detail .job-points-detail-column.job-points-detail-column-text .font-red {
  color: #e50303;
}

.recruit .site-content .section-01-carriers-item dl {
  grid-template-columns: max-content 1fr;
  gap: 0;
  margin: 0;
  display: grid;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item dl {
    grid-template-columns: 1fr;
  }
}

.recruit .site-content .section-01-carriers-item dl dt {
  background-color: #f2f2f2;
  border-bottom: 1px solid #ccc;
  width: 10rem;
  margin: 0;
  padding: 0 1rem;
  font-size: 16px;
  font-weight: 700;
  line-height: 3em;
}

.recruit .site-content .section-01-carriers-item dl dt:first-child {
  border-top: 1px solid #ccc;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item dl dt {
    border-top: 1px solid #ccc;
    border-bottom: none;
    width: 100%;
    line-height: 2em;
  }
}

.recruit .site-content .section-01-carriers-item dl dd {
  border-top: 1px solid #ccc;
  margin: 0;
  padding: 0 1rem;
  font-size: 16px;
  line-height: 3em;
}

.recruit .site-content .section-01-carriers-item dl dd:last-child {
  border-bottom: 1px solid #ccc;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item dl dd {
    border-top: none;
    border-bottom: 1px solid #ccc;
    line-height: 2em;
  }
}

.recruit .site-content .section-01-carriers-item p.message-contactus {
  text-align: center;
  font-size: 18px;
  font-weight: 700;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item p.message-contactus {
    font-size: 14px;
  }
}

.recruit .site-content .section-01-carriers-item p.message-contactus span {
  white-space: nowrap;
}

.recruit .site-content .section-01-carriers-item .link-button {
  width: 100%;
  max-width: 18em;
  margin: 0 auto 3rem;
}

@media (width <= 736px) {
  .recruit .site-content .section-01-carriers-item .link-button {
    mrgin-bottom: 1rem;
    padding: 0 1rem;
  }
}

.recruit .site-content .section-01-carriers-item .link-button p {
  text-align: center;
  background-color: #daf3d9;
  border-radius: 100vh;
  margin: 0 auto;
  font-size: 18px;
  font-weight: 700;
  line-height: 3em;
  box-shadow: 2px 2px 0 1px #262727;
}

.edit-link, .edit-link:last-child {
  margin-bottom: 0;
}

.site-footer {
  z-index: 1;
  background-color: #e0f3d8;
  width: 100%;
  padding: 0 1.5rem 1.5rem;
  position: relative;
}

.site-footer .container {
  box-sizing: border-box;
  background-color: #fff;
  border-radius: 0 0 50px 50px;
  width: 100%;
  max-width: 1300px;
  margin: 0 auto;
  padding: 0 0 25px;
}

@media (width <= 736px) {
  .site-footer .container {
    border-radius: 0 0 1rem 1rem;
    max-width: 370px;
    padding: 0 1rem 1rem;
  }
}

.site-footer .container .site-info {
  text-align: center;
  justify-content: center;
  align-items: center;
}

.site-footer .container .site-info address {
  font-size: 16px;
  font-style: normal;
}

@media (width <= 736px) {
  .site-footer .container .site-info address {
    font-size: 14px;
  }
}
