:root {
  --base_color_b: #111;
  --base_color_b2: #3e3a39;
  --base_color_w: #fff;
  --base_color_main: #2c90ca;
  --base_color_sub: #0b579f;
  --base_color_orange: #e94820;
  --base_color_green: #8eba69;
  --base_color_form_green: #7bb171;
  --base_color_required: #e60012;
  --base_color_green_sub: #a9ca69;
  --base_color_green_sub_2: #d1e474;
  --base_color_gray: #e6e6e6;
  --base_color_gray_sub: #b5b5b6;
  --base_color_gray_sub_2: #848484;
  --base_color_yellow: #f9eb2c;
  --base_color_cream: #fffcd8;
  --base_color_tshadow: #f9eb2c;
  --base_color_icn: #005381;
  --base_color_icn_sub: #00afec;
  --base_color_s_content_2: #f7c8ce;
  --base_color_text: #4d4c4c;
  --base_color_footer: #006397;
  --service-category-color-benefit: #C7E8FA;
  --service-category-color-application: #BEDFC2;
  --service-category-color-health: #F7C8CE;
  --service-category-color-bpo: #FDE0A5;
  --content_width_sp: calc(100% - 60px);
  --content_width_pc: 1120px;
  --content_width: min(var(--content_width_sp), var(--content_width_pc));
  --font_jp: "Kozuka Gothic Pr6N", "Kozuka Gothic Pro", "小塚ゴシック Pr6N", "小塚ゴシック Pro", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  --font_en: var(--font_jp);
}

@font-face {
  font-family: "Kozuka Gothic Pr6N";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/KozGoPr6N-Regular.otf") format("opentype");
}

@font-face {
  font-family: "Kozuka Gothic Pr6N";
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("../fonts/KozGoPr6N-Medium.otf") format("opentype");
}

@font-face {
  font-family: "Kozuka Gothic Pr6N";
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
}

@font-face {
  font-family: "Kozuka Gothic Pr6N";
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url("../fonts/KozGoPr6N-Bold.otf") format("opentype");
}

@font-face {
  font-family: "Orator Std";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/orator-std-medium.otf") format("opentype");
}

@font-face {
  font-family: "Jane Aust";
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url("../fonts/JaneAust.ttf") format("truetype");
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  color: var(--base_color_text);
  font-family: var(--font_jp);
  font-size: 15px;
  line-height: 1.8;
  background: var(--base_color_w);
}

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

a {
  color: inherit;
  text-decoration: none;
}

.pc {
  display: none !important;
}

.sp {
  display: block !important;
}

br.sp {
  display: none !important;
}

@media only screen and (max-width: 768px) {
  br.sp {
    display: initial !important;
  }
}

.sp-break {
  display: inline;
}

.sp-break::before {
  content: "\A";
  white-space: pre;
}

@media only screen and (min-width: 769px) {
  .pc {
    display: block !important;
  }

  .sp {
    display: none !important;
  }

  .sp-break {
    display: none;
  }

  .sp-break::before {
    content: none;
  }
}

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: var(--base_color_w);
}

.site-header__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0 18px;
  min-height: 84px;
  margin: 0 auto;
}

.site-logo {
  display: block;
  width: clamp(120px, 15vw, 150px);
}

.site-logo__image {
  width: 100%;
  height: auto;
}

.site-nav-toggle {
  display: inline-grid;
  gap: 2px;
  justify-items: center;
  min-width: 42px;
  padding: 0;
  color: var(--base_color_b2);
  background: transparent;
  border: 0;
}

.site-nav-toggle__bars {
  display: grid;
  gap: 6px;
}

.site-nav-toggle__bars span {
  display: block;
  width: 31px;
  height: 3px;
  background: var(--base_color_b2);
}

.site-nav-toggle__text {
  display: block;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.1;
}

.site-nav {
  position: fixed;
  top: 84px;
  right: 0;
  left: 0;
  display: none;
  padding: 20px;
  background: var(--base_color_w);
  box-shadow: 0 14px 20px rgba(0, 0, 0, 0.12);
}

.site-nav.is-open {
  display: block;
}

.site-nav__list,
.footer-nav__list {
  display: grid;
  gap: 14px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.site-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 36px;
  padding: 0 16px;
  color: var(--base_color_b2);
  font-size: 15px;
  font-weight: 400;
  border-radius: 999px;
  transform: none;
  transition: none;
}

.site-nav__list .current-menu-item>a,
.site-nav__list .current_page_item>a,
.site-nav__list .current-menu-ancestor>a,
.site-nav__list .current_page_parent>a {
  color: var(--base_color_w);
  font-weight: 700;
  background: var(--base_color_green_sub);
}

/* Common Components */
.section {
  padding: 50px 0;
}

.lower-section {
  padding: 80px 0;
}

.lower-section--light {
  background: #f7f7f7;
}

.lower-section--tint {
  background: #f4f4fa;
}

.narrow-content {
  width: min(720px, var(--content_width_sp));
  margin-right: auto;
  margin-left: auto;
}

@media (min-width: 768px) {
  .lower-section {
    padding: 150px 0;
  }

  .narrow-content {
    width: min(900px, var(--content_width));
  }
}

.section-heading {
  margin-bottom: 45px;
  text-align: center;
}

.section-heading.section-heading--compact {
  margin-bottom: 45px;
}

@media (min-width: 768px) {
  .section-heading.section-heading--compact {
    margin-bottom: 24px;
  }
}

.section-heading__en {
  display: block;
  color: var(--base_color_b2);
  font-family: "Courier New", Courier, monospace;
  font-size: 28px;
  font-style: normal;
  font-weight: 500;
  letter-spacing: 0.18em;
  line-height: 1.2;
  margin-bottom: 10px;
}

.section-heading__initial {
  display: inline-block;
  font-size: 1.28em;
  line-height: 0.85;
}

.section-heading h1,
.section-heading h2,
.section-heading h3 {
  margin: 0px;
  color: var(--base_color_main);
  font-size: 15px;
  font-weight: 400;
  letter-spacing: 0;
}

@media (min-width: 768px) {

  .section-heading h1,
  .section-heading h2,
  .section-heading h3 {
    font-size: 20px;
  }

}

.section-heading--white .section-heading__en,
.section-heading--white h1,
.section-heading--white h2,
.section-heading--white h3 {
  color: var(--base_color_w);
}

.heading-accent {
  --heading-accent-line-width: 60px;
  --heading-accent-line-height: 7px;
  --heading-accent-gap: 18px;

  display: inline-grid;
  justify-items: center;
  gap: var(--heading-accent-gap);
  margin: 0;
  color: var(--base_color_main);
  font-size: clamp(18px, 2.2vw, 26px);
  font-weight: 500;
  letter-spacing: 0.38em;
  line-height: 1.45;
  text-align: center;
}

.heading-accent::after {
  display: block;
  width: var(--heading-accent-line-width);
  height: var(--heading-accent-line-height);
  content: "";
  background: var(--base_color_yellow);
  border-radius: 999px 0 999px 0;
}

.heading-accent.is-line-motion-ready::after {
  opacity: 0;
  transform: translateY(14px);
  transition:
    opacity .52s ease .22s,
    transform .68s cubic-bezier(.22, 1, .36, 1) .22s;
}

.heading-accent.is-line-motion-ready.is-line-visible::after {
  opacity: 1;
  transform: translateY(0);
}

.heading-accent--compact {
  --heading-accent-line-width: 56px;
  --heading-accent-line-height: 5px;
  --heading-accent-gap: 14px;

  font-size: clamp(16px, 1.8vw, 22px);
}

@media (prefers-reduced-motion: reduce) {
  .heading-accent.is-line-motion-ready::after {
    opacity: 1;
    transform: none;
    transition: none;
  }
}

.scroll-down {
  position: absolute;
  right: 28px;
  top: 50%;
  bottom: auto;
  z-index: 2;
  display: none;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 212px;
  max-height: none;
  color: var(--base_color_w);
  font-family: "Orator Std", "Courier New", monospace;
  font-size: 14px;
  font-weight: 500;
  letter-spacing: 0.12em;
  line-height: 1;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.2);
  transform: translateY(-50%);
}

.scroll-down__text {
  display: block;
  transform: translate(-1px, 1px);
  writing-mode: vertical-rl;
}

.scroll-down::before,
.scroll-down::after {
  position: absolute;
  left: 50%;
  display: block;
  content: "";
  background: currentColor;
  transform: translateX(-50%);
}

.scroll-down::before {
  top: clamp(2px, 1.7%, 4px);
  width: 1px;
  height: clamp(26px, 16%, 36px);
}

.scroll-down::after {
  bottom: clamp(2px, 1.7%, 4px);
  width: 7px;
  height: clamp(24px, 15%, 34px);
  clip-path: polygon(3px 0, 4px 0, 4px 85%, 7px 85%, 3.5px 100%, 0 85%, 3px 85%);
}

@media only screen and (min-width: 769px) {
  .scroll-down {
    display: flex;
    top: 50%;
    bottom: auto;
    height: min(212px, calc(90% - 24px));
  }
}

.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: min(320px, calc(100% - 40px));
  min-height: 40px;
  padding: 8px 16px;
  color: var(--base_color_w);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.4;
  text-align: center;
  background: var(--base_color_main);
  border: 2px solid var(--base_color_w);
  box-shadow: 7px 7px 0 rgba(0, 83, 129, 0.22);
}

.button--primary {
  background: var(--base_color_sub);
}

.button--outline {
  color: var(--base_color_yellow);
}

.button--dark {
  background: var(--base_color_b2);
  box-shadow: none;
}

.intro-movie {
  position: relative;
  display: grid;
  justify-items: center;
  padding-top: 50px;
  background: url("../images/common/wave.webp") center bottom / cover no-repeat;
}

.intro-movie__media {
  position: relative;
  z-index: 1;
  width: min(900px, var(--content_width));
  margin: 0 auto 20px;
}

.intro-movie__media img,
.intro-movie__media .image-placeholder,
.intro-movie__media iframe {
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.intro-movie__media iframe {
  display: block;
  height: auto;
  border: 0;
}

.intro-movie__play {
  position: absolute;
  inset: 50% auto auto 50%;
  width: 48px;
  height: 48px;
  background: var(--base_color_orange);
  border: 4px solid var(--base_color_w);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.intro-movie__play::after {
  position: absolute;
  top: 50%;
  left: 54%;
  width: 0;
  height: 0;
  content: "";
  border-top: 10px solid transparent;
  border-bottom: 10px solid transparent;
  border-left: 15px solid var(--base_color_w);
  transform: translate(-50%, -50%);
}

.intro-movie__note {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 6px;
  margin: 0 auto;
  padding-bottom: 72px;
  color: var(--base_color_sub);
  font-size: 15px;
  line-height: 1.45;
}

.intro-movie__note p {
  margin: 0;
  font-weight: 700;
}

.intro-movie__note p span {
  font-size: 1.15em;
}

.intro-movie__arrow {
  display: inline-block;
  width: 20px;
  height: 13px;
  color: var(--base_color_b2);
  font-size: 0;
  line-height: 1;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
}

.intro-movie__note small {
  color: var(--base_color_b2);
  font-size: 15px;
  line-height: 1;
}

.plain-page {
  width: var(--content_width);
  padding: 80px 0;
  margin: 0 auto;
}

/* Footer */
.footer-prefooter {
  display: grid;
  justify-items: center;
  padding: 20px 0px;
  background: var(--base_color_w);
}

.footer-prefooter__inner {
  display: grid;
  justify-items: center;
  gap: 32px;
  width: var(--content_width);
}

.footer-back-button {
  width: min(220px, calc(100% - 36px));
  padding: 20px 0 4px;
}

.footer-back-button__link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(26px, 4.2vw, 46px);
  width: 100%;
  color: var(--base_color_w);
  font-family: "Orator Std", "Courier New", monospace;
  min-height: 58px;
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0;
  text-decoration: none;
  background: #3E3A39;
  border: 1px solid #3E3A39;
  border-radius: 999px;
  transition: color .2s ease, background-color .2s ease;
}

.footer-back-button__link:hover,
.footer-back-button__link:focus-visible {
  color: #3E3A39;
  background: var(--base_color_w);
}

.footer-back-button__line {
  position: relative;
  flex: 0 1 38px;
  height: 2px;
  background: currentColor;
}

.footer-back-button__line--left::before {
  position: absolute;
  left: -5px;
  bottom: -0.2px;
  width: 15px;
  height: 10px;
  background: currentColor;
  clip-path: polygon(0 100%, 100% 0, 100% 100%);
  content: "";
}

.footer-back-button__label {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  line-height: 1;
  transform: translateY(3px);
}

.footer-page-top {
  position: fixed;
  bottom: 18px;
  left: 50%;
  z-index: 15;
  display: grid;
  justify-items: center;
  width: min(220px, calc(100% - 36px));
  opacity: 0;
  pointer-events: none;
  transform: translate(-50%, 12px);
  transition: opacity .25s ease, transform .25s ease;
}

.footer-page-top.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translate(-50%, 0);
}

.footer-page-top__link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 18px;
  width: 100%;
  min-height: 58px;
  color: #878787;
  font-family: "Orator Std", "Courier New", monospace;
  font-size: 20px;
  line-height: 1;
  letter-spacing: 0.08em;
  text-decoration: none;
  border: 1px solid currentColor;
  border-radius: 999px;
  background: var(--base_color_w);
}

.footer-page-top__icon {
  position: relative;
  flex: 0 0 auto;
  width: 38px;
  height: 24px;
}

.footer-page-top__icon::before,
.footer-page-top__icon::after {
  position: absolute;
  left: 50%;
  width: 15px;
  height: 15px;
  border-top: 2px solid currentColor;
  border-left: 2px solid currentColor;
  content: "";
  transform: translateX(-50%) rotate(45deg);
}

.footer-page-top__icon::before {
  top: 0;
}

.footer-page-top__icon::after {
  top: 10px;
}

.footer-badges {
  display: grid;
  justify-items: center;
  gap: 30px;
}

.footer-badges__privacy {
  display: grid;
  justify-items: center;
  gap: 10px;
  color: var(--base_color_main);
  font-size: 15px;
  font-weight: 900;
  line-height: 1.4;
}

.footer-badges__privacy-mark {
  width: 72px;
  height: auto;
}

.footer-badges__ssl {
  width: 178px;
  height: auto;
}

.site-footer {
  --footer-content-width: var(--content_width);

  padding: 42px 0 64px;
  overflow-x: clip;
  color: var(--base_color_w);
  background: var(--base_color_footer);
}

.site-footer__inner {
  display: grid;
  justify-items: center;
  gap: 28px;
  width: var(--content_width);
  margin: 0 auto;
}

.site-footer .site-logo--footer {
  width: 178px;
  justify-self: start;
  margin-top: 22px;
}

.site-footer .site-logo--footer .site-logo__image {
  width: 100%;
  filter: none;
}

.footer-nav__list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 12px;
  align-items: center;
  width: 100%;
  margin: 0 auto;
}

.site-footer .footer-nav {
  width: 100%;
}

.footer-nav__list li {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.35);
}

.footer-nav__list a {
  color: var(--base_color_w);
  font-size: 15px;
  font-weight: 700;
  line-height: 1.35;
  text-align: center;
}

.footer-nav__list .current-menu-item>a,
.footer-nav__list .current_page_item>a,
.footer-nav__list .current-menu-ancestor>a,
.footer-nav__list .current_page_parent>a {
  color: var(--base_color_green_sub_2);
}

.site-footer__address {
  display: grid;
  justify-self: stretch;
  gap: 6px;
  width: 100%;
  margin: 0;
  color: var(--base_color_w);
  font-style: normal;
  font-size: clamp(15px, 3.4vw, 18px);
  line-height: 1.65;
  text-align: left;
}

.site-footer__address span {
  white-space: normal;
}

.site-footer__tel-row {
  display: grid;
  grid-template-columns: 4em 1fr;
}

.site-footer__instagram {
  --footer-instagram-hover-color: var(--base_color_green_sub_2);
  --footer-instagram-hover-shift: -3px;
  --footer-instagram-easing: cubic-bezier(0.16, 1, 0.3, 1);

  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: flex-start;
  justify-self: end;
  gap: 10px;
  margin: 20px 0 40px;
  color: var(--base_color_w);
  font-size: 15px;
  font-weight: 400;
  line-height: 1;
  transition: color 0.3s var(--footer-instagram-easing);
}

.site-footer__instagram span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: transform 0.3s var(--footer-instagram-easing);
}

.site-footer__instagram span::before {
  display: none;
  width: 28px;
  height: 16px;
  background: currentColor;
  content: "";
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
}

.site-footer__instagram span::after {
  display: block;
  width: 18px;
  height: 13px;
  background: currentColor;
  content: "";
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2018%2013%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%201L7.5%206.5L2%2012M8%201L13.5%206.5L8%2012%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2018%2013%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%201L7.5%206.5L2%2012M8%201L13.5%206.5L8%2012%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
}

.site-footer__instagram-icon {
  display: block;
  width: 52px;
  height: 52px;
  padding: 0;
  background: radial-gradient(circle, var(--base_color_b2) 0 68%, transparent 69%);
  object-fit: contain;
  transform-origin: center;
  transition: transform 0.3s var(--footer-instagram-easing);
}

.site-footer__instagram:hover,
.site-footer__instagram:focus-visible {
  color: var(--footer-instagram-hover-color);
}

.site-footer__instagram:hover span,
.site-footer__instagram:focus-visible span,
.site-footer__instagram:hover::after,
.site-footer__instagram:focus-visible::after {
  transform: translateX(3px);
}

.site-footer__instagram:hover .site-footer__instagram-icon,
.site-footer__instagram:focus-visible .site-footer__instagram-icon {
  transform: scale(1.12);
}

.site-footer__copy {
  margin: 0;
  color: var(--base_color_w);
  font-size: 11px;
  line-height: 1.45;
  text-align: center;
  overflow-wrap: anywhere;
}

@media (min-width: 481px) {
  .site-footer__inner {
    width: min(560px, var(--content_width));
  }

  .site-footer .site-logo--footer {
    width: 220px;
  }
}

@media (min-width: 768px) {
  :root {
    --content_width: min(var(--content_width_pc), calc(100% - 80px));
  }

  body {
    font-size: 16px;
  }



  .section {
    padding: 100px 0;
  }

  .section-heading {
    margin-bottom: 100px;
  }

  .section-heading__en {
    font-size: 40px;
    letter-spacing: 0.2em;
  }

  .heading-accent {
    --heading-accent-line-width: 120px;
  }

  .heading-accent--compact {
    --heading-accent-line-width: 80px;
  }

  .button {
    width: auto;
    min-width: 230px;
    min-height: 44px;
    padding: 8px 24px;
    font-size: 16px;
  }

  .footer-prefooter {
    padding: 40px 0px;
  }

  .footer-prefooter__inner {
    justify-items: center;
    gap: 42px;
  }

  .footer-back-button {
    width: min(360px, calc(100vw - 80px));
    padding: 20px 0 0;
  }

  .footer-prefooter__inner--news-back .footer-back-button {
    justify-self: start;
  }

  .footer-back-button__link {
    gap: 28px;
    min-height: 64px;
    font-size: 24px;
  }

  .footer-back-button__line {
    flex-basis: 56px;
    height: 2px;
  }

  .footer-back-button__line--left::before {
    bottom: 0px;
    right: calc(100% - 12px);
    left: auto;
    width: 16px;
    height: 10px;
  }

  .footer-badges {
    grid-template-columns: auto auto;
    align-items: start;
    gap: 52px;
    padding-top: 0;
  }

  .footer-page-top {
    right: max(16px, env(safe-area-inset-right));
    bottom: 40px;
    left: auto;
    width: auto;
    transform: translateY(12px);
  }

  .footer-page-top.is-visible {
    transform: translateY(0);
  }

  .footer-page-top__link {
    flex-direction: column;
    gap: 18px;
    width: 34px;
    height: 280px;
    min-height: 0;
    padding: 38px 0 34px;
    font-size: 16px;
    letter-spacing: .08em;
  }

  .footer-page-top__link::after {
    align-self: center;
    flex: 0 0 auto;
    width: 1px;
    height: 46px;
    background: currentColor;
    content: "";
  }

  .footer-page-top__icon {
    align-self: center;
    flex: 0 0 auto;
    width: 1px;
    height: 58px;
    background: currentColor;
  }

  .footer-page-top__icon::before {
    top: -3px;
    left: 50%;
    width: 0;
    height: 0;
    border-top: 0;
    border-right: 10px solid transparent;
    border-bottom: 13px solid currentColor;
    border-left: 0;
    transform: translateX(-0.5px);
  }

  .footer-page-top__icon::after {
    content: none;
  }

  .footer-page-top__label {
    display: block;
    align-self: center;
    flex: 0 0 auto;
    line-height: 1;
    writing-mode: vertical-rl;
    margin-right: 6px;
  }

  .footer-badges__privacy-mark {
    width: 64px;
  }

  .site-footer {
    padding-bottom: 52px;
  }

  .site-footer__inner {
    gap: 30px;
    width: var(--content_width);
  }

  .site-footer .footer-nav {
    width: var(--footer-content-width);
  }

  .site-footer .site-logo--footer {
    justify-self: center;
    width: 178px;
    margin-top: 0;
  }

  .site-footer__address {
    justify-self: auto;
    gap: 0;
    width: auto;
    font-size: 15px;
    line-height: 1.7;
  }

  .site-footer__instagram {
    margin: 4px 0 0;
  }

  .site-footer__instagram span {
    display: grid;
    justify-items: center;
    gap: 3px;
  }

  .site-footer__instagram span::before {
    display: block;
  }

  .site-footer__instagram span::after {
    display: none;
  }

  .site-footer__instagram:hover span,
  .site-footer__instagram:focus-visible span,
  .site-footer__instagram:hover::after,
  .site-footer__instagram:focus-visible::after {
    transform: translateY(var(--footer-instagram-hover-shift));
  }

  .site-footer__copy {
    font-size: 15px;
    line-height: 1.5;
  }

}

@media (min-width: 1024px) {
  .footer-page-top {
    right: clamp(18px, 2.2vw, 34px);
  }

  .footer-page-top__link {
    gap: 24px;
    width: 38px;
    height: 318px;
    padding: 48px 0 44px;
    font-size: 18px;
  }

  .footer-page-top__link::after {
    height: 58px;
  }

  .footer-page-top__icon {
    height: 72px;
  }

  .site-header__inner {
    width: 100%;
    max-width: 100%;
    padding: 0 32px;
    min-height: 100px;
  }

  .site-logo {
    flex: 0 1 auto;
    width: 210px;
  }

  .site-nav-toggle {
    display: none;
  }

  .site-nav {
    position: static;
    flex: 1 1 auto;
    display: block;
    min-width: 0;
    padding: 0;
    background: transparent;
    box-shadow: none;
  }

  .site-nav__list {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 28px;
    min-width: 0;
  }

  .site-nav__list .current-menu-item>a,
  .site-nav__list .current_page_item>a,
  .site-nav__list .current-menu-ancestor>a,
  .site-nav__list .current_page_parent>a {
    width: auto;
    min-width: 112px;
    min-height: 40px;
    color: var(--base_color_w);
  }

  .site-nav a {
    width: auto;
    min-width: 112px;
    min-height: 40px;
    font-size: 15px;
    font-weight: 400;
    white-space: nowrap;
  }
}

@media (min-width: 1024px) and (max-width: 1180px) {
  .site-header__inner {
    padding-right: 18px;
    padding-left: 18px;
  }

  .site-logo {
    width: 150px;
  }

  .site-nav__list {
    gap: 14px;
  }

  .site-nav__list .current-menu-item>a,
  .site-nav__list .current_page_item>a,
  .site-nav__list .current-menu-ancestor>a,
  .site-nav__list .current_page_parent>a {
    min-width: 82px;
    min-height: 36px;
  }

  .site-nav a {
    min-width: 82px;
    min-height: 36px;
    font-size: 15px;
  }
}

/* Restored Header / Footer */
.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  box-shadow: 0 3px 16px rgba(0, 0, 0, 0.08);
}

.site-header__inner {
  width: 100%;
  min-height: 84px;
  padding: 0 18px;
}

@media (min-width: 768px) and (max-width: 1199px) {
  .site-footer {
    --footer-content-width: min(560px, var(--content_width));

    min-height: 0;
    padding: 56px 0 64px;
    overflow: hidden;
  }

  .site-footer__inner {
    display: grid;
    grid-template-columns: 1fr;
    justify-items: center;
    gap: 34px;
    width: var(--content_width);
  }

  .site-footer .footer-nav,
  .site-logo--footer,
  .site-footer__address,
  .site-footer__instagram,
  .site-footer__copy {
    grid-column: auto;
    grid-row: auto;
  }

  .site-footer .footer-nav {
    width: var(--footer-content-width);
    padding-top: 0;
  }

  .footer-nav__list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 12px;
    width: 100%;
  }

  .footer-nav__list li,
  .footer-nav__list li:last-child {
    min-height: 38px;
    padding: 0 12px;
    border: 1px solid rgba(255, 255, 255, 0.35);
  }

  .footer-nav__list a {
    font-size: 15px;
    white-space: normal;
  }

  .site-footer .site-logo--footer {
    justify-self: center;
    width: var(--footer-content-width);
  }

  .site-footer .site-logo--footer .site-logo__image {
    width: 220px;
    max-width: 100%;
  }

  .site-footer__address {
    justify-self: center;
    width: var(--footer-content-width);
    gap: 8px;
    margin-top: 0;
    font-size: 15px;
    line-height: 1.7;
    text-align: left;
  }

  .site-footer__address span {
    white-space: normal;
  }

  .site-footer__instagram {
    flex-direction: column;
    align-self: center;
    justify-self: center;
    gap: 5px;
    margin: 0;
    font-size: 18px;
    font-weight: 400;
  }

  .site-footer__instagram::after {
    order: 2;
    display: block;
    width: 20px;
    height: 16px;
    margin-top: 10px;
    background: currentColor;
    content: "";
    -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
    transition: transform 0.3s var(--footer-instagram-easing);
  }

  .site-footer__instagram span {
    order: 3;
    margin-top: -1px;
  }

  .site-footer__instagram span::before,
  .site-footer__instagram span::after {
    display: none;
  }

  .site-footer__instagram-icon {
    order: 1;
    width: 52px;
    height: 52px;
  }

  .site-footer__copy {
    margin-top: 0;
    font-size: 15px;
    overflow-wrap: anywhere;
  }
}

@media (min-width: 1200px) {
  .site-footer {
    min-height: 724px;
    padding: 92px 0;
  }

  .site-footer__inner {
    display: grid;
    grid-template-columns: 430px minmax(0, 720px);
    justify-content: center;
    column-gap: 32px;
    row-gap: 0;
    width: var(--content_width);
  }

  .site-footer .footer-nav {
    grid-column: 2;
    grid-row: 1;
    align-self: start;
    justify-self: center;
    max-width: 100%;
    width: fit-content;
    padding-top: 16px;
  }

  .footer-nav__list {
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    gap: 0;
    width: 100%;
  }

  .footer-nav__list li {
    min-height: 28px;
    padding: 0 20px;
    border-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-left: 1px solid rgba(255, 255, 255, 0.35);
  }

  .footer-nav__list li:last-child {
    border-right: 1px solid rgba(255, 255, 255, 0.35);
  }

  .footer-nav__list a {
    font-size: 15px;
    white-space: nowrap;
  }

  .site-footer .site-logo--footer {
    grid-column: 1;
    grid-row: 1;
    justify-self: start;
    width: 305px;
  }

  .site-footer__address {
    grid-column: 1;
    grid-row: 2;
    justify-self: start;
    gap: 20px;
    margin-top: 78px;
    font-size: 18px;
    line-height: 1.5;
  }

  .site-footer__address span {
    white-space: nowrap;
  }

  .site-footer__instagram {
    grid-column: 2;
    grid-row: 2;
    flex-direction: column;
    align-self: start;
    align-items: center;
    justify-self: center;
    gap: 5px;
    margin: 78px 0 0;
    font-size: 15px;
    font-weight: 400;
  }

  .site-footer__instagram::after {
    order: 2;
    display: block;
    width: 28px;
    height: 16px;
    margin-top: 10px;
    background: currentColor;
    content: "";
    -webkit-mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
    mask: url("data:image/svg+xml,%3Csvg%20viewBox%3D%270%200%2028%2016%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M2%207.5L14%201.5L26%207.5M2%2014L14%208L26%2014%27%20fill%3D%27none%27%20stroke%3D%27black%27%20stroke-width%3D%272.4%27%20stroke-linecap%3D%27round%27%20stroke-linejoin%3D%27round%27/%3E%3C/svg%3E") center / contain no-repeat;
    transition: transform 0.3s var(--footer-instagram-easing);
  }

  .site-footer__instagram span {
    order: 3;
    margin-top: -1px;
  }

  .site-footer__instagram span::before,
  .site-footer__instagram span::after {
    display: none;
  }

  .site-footer__instagram-icon {
    order: 1;
    width: 52px;
    height: 52px;
  }

  .site-footer__copy {
    grid-column: 1 / -1;
    margin-top: 120px;
    font-size: 15px;
  }
}

@media (min-width: 1200px) and (max-width: 1320px) {
  .footer-nav__list li {
    padding-inline: 14px;
  }

  .footer-nav__list a {
    font-size: 14px;
  }
}

@media (max-width: 1023px) {
  .site-logo {
    width: 132px;
  }

  .site-footer .site-logo--footer {
    width: 178px;
  }

  .site-footer .footer-nav {
    width: 100%;
  }

  .footer-nav__list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px 10px;
    width: 100%;
  }

  .footer-nav__list li,
  .footer-nav__list li:last-child {
    min-height: 38px;
    padding: 0 12px;
    overflow: visible;
    background: transparent;
    border: 1px solid rgba(255, 255, 255, 0.35);
    border-radius: 0;
  }

  .footer-nav__list li:first-child {
    grid-column: 1 / -1;
  }

  .footer-nav__list a {
    display: grid;
    place-items: center;
    width: 100%;
    min-height: 38px;
    padding: 0;
    font-size: 14px;
    font-weight: 700;
    line-height: 1.35;
    letter-spacing: 0;
  }

  .footer-nav__list .current-menu-item>a,
  .footer-nav__list .current_page_item>a,
  .footer-nav__list .current-menu-ancestor>a,
  .footer-nav__list .current_page_parent>a {
    color: var(--base_color_green_sub_2);
  }
}

@media (min-width: 1024px) {
  .site-header__inner {
    min-height: 100px;
    padding-right: 32px;
    padding-left: 32px;
  }

  .site-logo {
    width: 210px;
  }

  .site-nav__list {
    gap: 18px;
  }

  .site-nav__list .current-menu-item>a,
  .site-nav__list .current_page_item>a,
  .site-nav__list .current-menu-ancestor>a,
  .site-nav__list .current_page_parent>a {
    min-width: 112px;
  }

  .site-nav a {
    min-width: 112px;
    font-size: 15px;
  }
}

@media (min-width: 1024px) and (max-width: 1180px) {
  .site-header__inner {
    padding-right: 18px;
    padding-left: 18px;
  }

  .site-logo {
    width: 150px;
  }

  .site-nav__list {
    gap: 14px;
  }

  .site-nav a {
    min-width: 82px;
  }
}

@media (min-width: 1024px) {
  .site-nav__list>li>a {
    flex-shrink: 0;
  }

  .site-nav__list>li {
    position: relative;
  }

  .site-nav__list>.site-nav__service-parent.is-service-menu-open {
    display: flex;
    align-items: center;
    min-height: var(--js-header-height, 100px);
  }

  .site-nav__list .menu-item-has-children>a,
  .site-nav__list .page_item_has_children>a {
    position: relative;
    padding-right: 16px;
    padding-left: 16px;
  }

  .site-nav__list .menu-item-has-children>a::after,
  .site-nav__list .page_item_has_children>a::after {
    content: none;
  }

  .site-nav__list .sub-menu,
  .site-nav__list .children {
    position: absolute;
    top: 100%;
    left: 50%;
    z-index: 5;
    display: grid;
    gap: 4px;
    width: max-content;
    min-width: 190px;
    padding: 12px;
    margin: 0;
    list-style: none;
    pointer-events: none;
    background: var(--base_color_w);
    border: 1px solid rgba(0, 0, 0, 0.08);
    border-radius: 0;
    box-shadow: 0 8px 18px rgba(0, 0, 0, 0.08);
    opacity: 0;
    transform: translateX(-50%);
    transition: none;
    visibility: hidden;
  }

  .site-nav a:hover,
  .site-nav a:focus,
  .site-nav a:focus-visible {
    padding-top: 0;
    padding-bottom: 0;
    transform: none;
    transition: none;
  }

  .site-nav__list .menu-item-has-children:hover>.sub-menu,
  .site-nav__list .menu-item-has-children:focus-within>.sub-menu,
  .site-nav__list .page_item_has_children:hover>.children,
  .site-nav__list .page_item_has_children:focus-within>.children {
    pointer-events: auto;
    opacity: 1;
    transform: translateX(-50%);
    visibility: visible;
  }

  .site-nav__list .sub-menu a,
  .site-nav__list .children a {
    justify-content: flex-start;
    width: 100%;
    min-width: 0;
    min-height: 34px;
    padding: 0;
    font-size: 14px;
    font-weight: 400;
    border-radius: 0;
  }

  .site-nav__list .sub-menu .current-menu-item>a,
  .site-nav__list .children .current-menu-item>a,
  .site-nav__list .sub-menu .current_page_item>a,
  .site-nav__list .children .current_page_item>a {
    min-width: 0;
    font-weight: 700;
  }

  .site-nav__list>.site-nav__service-parent>.sub-menu {
    position: fixed;
    top: calc(var(--js-header-height, 100px) - 1px);
    right: auto;
    left: var(--js-service-menu-center, 50%);
    display: none;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 14px;
    width: min(960px, calc(100vw - 40px));
    max-width: none;
    max-height: calc(var(--js-viewport-height, 100vh) - var(--js-header-height, 100px) - 20px);
    margin: 0;
    padding: 18px;
    overflow-y: auto;
    border: 1px solid rgba(0, 120, 150, 0.15);
    border-top: 3px solid var(--base_color_green_sub);
    border-radius: 10px;
    box-shadow: 0 18px 36px rgba(0, 50, 70, 0.16);
    transform: translateX(-50%);
  }

  .site-nav__list>.site-nav__service-parent:hover>.sub-menu,
  .site-nav__list>.site-nav__service-parent:focus-within>.sub-menu {
    display: none;
    pointer-events: none;
    opacity: 0;
    transform: translateX(-50%);
    visibility: hidden;
  }

  .site-nav__list>.site-nav__service-parent.is-service-menu-open>.sub-menu,
  .site-nav__list>.site-nav__service-parent>.sub-menu:focus-within {
    display: grid;
    pointer-events: auto;
    opacity: 1;
    transform: translateX(-50%);
    visibility: visible;
  }

  .site-nav__list>.site-nav__service-parent>.sub-menu::before {
    position: absolute;
    top: -8px;
    left: 50%;
    width: 16px;
    height: 16px;
    content: "";
    background: var(--base_color_w);
    border-top: 1px solid rgba(0, 120, 150, 0.15);
    border-left: 1px solid rgba(0, 120, 150, 0.15);
    transform: translateX(-50%) rotate(45deg);
  }

  .site-nav__service-category {
    min-width: 0;
  }

  .site-nav__list .site-nav__service-category>a {
    justify-content: flex-start;
    min-width: 0;
    min-height: 0;
    padding: 0 0 9px;
    color: var(--base_color_b2);
    font-size: 15px;
    font-weight: 700;
    line-height: 1.45;
    background: transparent;
    border-bottom: 1px solid rgba(0, 0, 0, 0.13);
    border-radius: 0;
    cursor: pointer;
    pointer-events: auto;
  }

  .site-nav__list .site-nav__service-category>a:hover,
  .site-nav__list .site-nav__service-category>a:focus-visible {
    color: var(--base_color_main);
    text-decoration: underline;
    text-underline-offset: 4px;
  }

  .site-nav__list .site-nav__service-category>a::after {
    content: none;
  }

  .site-nav__list .site-nav__service-category>.sub-menu {
    position: static;
    display: grid;
    gap: 0;
    width: 100%;
    min-width: 0;
    padding: 8px 0 0;
    margin: 0;
    pointer-events: auto;
    background: transparent;
    border: 0;
    box-shadow: none;
    opacity: 1;
    transform: none;
    visibility: visible;
  }

  .site-nav__list .site-nav__service-category:hover>.sub-menu,
  .site-nav__list .site-nav__service-category:focus-within>.sub-menu {
    transform: none;
  }

  .site-nav__list .site-nav__service-detail>a {
    justify-content: flex-start;
    width: 100%;
    min-height: 31px;
    padding: 0;
    color: var(--base_color_b2);
    font-size: 13px;
    line-height: 1.35;
    white-space: normal;
  }

  .site-nav__list .site-nav__service-detail>a:hover,
  .site-nav__list .site-nav__service-detail>a:focus-visible {
    color: var(--base_color_b2);
    background: transparent;
    text-decoration: underline;
    text-underline-offset: 4px;
  }

  .site-nav__list .site-nav__service-detail.current-menu-item>a,
  .site-nav__list .site-nav__service-detail.current_page_item>a {
    color: var(--base_color_main);
    font-weight: 700;
    background: transparent;
  }
}

@media (min-width: 1024px) and (max-width: 1100px) {
  .site-nav__list>.site-nav__service-parent>.sub-menu {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: min(640px, calc(100vw - 40px));
  }
}

.site-nav .site-nav__heading,
.site-nav .site-nav__privacy,
.site-nav .site-nav__copy {
  display: none;
}

@media (max-width: 1023px) {
  body.is-nav-open {
    overflow: hidden;
  }

  body.is-nav-open::before {
    position: fixed;
    top: var(--js-header-height, 85px);
    right: 0;
    bottom: 0;
    left: 0;
    z-index: 18;
    display: block;
    content: "";
    background: rgba(132, 132, 132, 0.83);
  }

  .site-header {
    z-index: 30;
    box-shadow: none;
  }

  .site-header__inner {
    width: auto;
    min-height: 60px;
    margin-right: clamp(18px, 8vw, 50px);
    margin-left: clamp(18px, 8vw, 50px);
    padding-right: 0;
    padding-left: 0;
  }

  .site-logo {
    width: 120px;
  }

  .site-nav-toggle {
    min-width: 38px;
  }

  .site-nav-toggle__bars {
    gap: 5px;
  }

  .site-nav-toggle__bars span {
    width: 28px;
    height: 3px;
  }

  .site-nav-toggle__text {
    margin-top: -1px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
  }

  .site-nav {
    top: var(--js-header-height, 85px);
    right: 0;
    left: clamp(64px, 17.3vw, 180px);
    width: auto;
    z-index: 25;
    max-height: calc(var(--js-viewport-height, 100vh) - var(--js-header-height, 85px));
    padding: 34px clamp(34px, 9vw, 76px) 50px clamp(30px, 6vw, 43px);
    overflow-y: auto;
    color: var(--base_color_w);
    background: var(--base_color_main);
    box-shadow: none;
  }

  .site-nav .site-nav__heading {
    position: relative;
    display: block;
    margin-bottom: 25px;
    padding-left: 20px;
    color: var(--base_color_w);
    font-family: var(--font_jp);
    font-size: 20px;
    font-weight: 500;
    line-height: 1.2;
  }

  .site-nav .site-nav__heading::before {
    position: absolute;
    top: 1px;
    bottom: 0;
    left: 0;
    width: 7px;
    height: 43px;
    margin: auto 0;
    content: "";
    background: var(--base_color_yellow);
    border-radius: 999px;
  }

  .site-nav__list {
    gap: 0;
  }

  .site-nav__list li {
    position: relative;
  }

  .site-nav__list>li {
    width: 100%;
    border-bottom: 1px solid rgba(255, 255, 255, 0.42);
  }

  .site-nav a {
    justify-content: flex-start;
    min-height: 50px;
    padding: 0;
    color: var(--base_color_w);
    font-size: 16px;
    font-weight: 400;
    line-height: 1.35;
    border-radius: 0;
  }

  .site-nav__list .current-menu-item>a,
  .site-nav__list .current_page_item>a,
  .site-nav__list .current-menu-ancestor>a,
  .site-nav__list .current_page_parent>a {
    color: var(--base_color_w);
    font-weight: 700;
    background: transparent;
  }

  .site-nav__list .menu-item-has-children>a,
  .site-nav__list .page_item_has_children>a {
    position: relative;
    padding-right: 44px;
  }

  .site-nav__list .menu-item-has-children>a::before,
  .site-nav__list .page_item_has_children>a::before {
    position: absolute;
    top: 50%;
    right: 16px;
    width: 14px;
    height: 1px;
    content: "";
    background: rgba(255, 255, 255, 0.78);
  }

  .site-nav__list .menu-item-has-children>a::after,
  .site-nav__list .page_item_has_children>a::after {
    position: absolute;
    top: 50%;
    right: 22px;
    width: 1px;
    height: 14px;
    content: "";
    background: rgba(255, 255, 255, 0.78);
    border: 0;
    transform: translateY(-50%);
    transition: none;
  }

  .site-nav__list .menu-item-has-children.is-submenu-open>a::after,
  .site-nav__list .page_item_has_children.is-submenu-open>a::after {
    content: none;
  }

  .site-nav__list .sub-menu,
  .site-nav__list .children {
    display: none;
    padding: 0 0 14px 18px;
    margin: -6px 0 0;
    list-style: none;
  }

  .site-nav__list .is-submenu-open>.sub-menu,
  .site-nav__list .is-submenu-open>.children {
    display: grid;
    gap: 0;
  }

  .site-nav__list .sub-menu a,
  .site-nav__list .children a {
    min-height: 42px;
    color: rgba(255, 255, 255, 0.92);
    font-size: 17px;
    font-weight: 400;
  }

  .site-nav__list .site-nav__service-category>a {
    position: relative;
    min-height: 44px;
    padding-right: 44px;
    color: var(--base_color_w);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    pointer-events: auto;
  }

  .site-nav__list .site-nav__service-category>a::before {
    top: 50%;
    right: 16px;
    transform: translateY(-50%);
  }

  .site-nav__list .site-nav__service-category>a::after {
    top: 50%;
    right: 22px;
    transform: translateY(-50%);
  }

  .site-nav__list .site-nav__service-category.is-submenu-open>a::after {
    content: none;
  }

  .site-nav__list .site-nav__service-category>.sub-menu {
    padding: 0 0 12px 12px;
    margin: -2px 0 0;
  }

  .site-nav__list .site-nav__service-detail>a {
    min-height: 36px;
    color: rgba(255, 255, 255, 0.82);
    font-size: 13px;
    line-height: 1.45;
  }

  .site-nav__list .site-nav__service-detail>a::before,
  .site-nav__list .site-nav__service-detail>a::after {
    content: none;
  }

  .site-nav .site-nav__privacy {
    display: inline-flex;
    width: auto;
    min-height: 40px;
    margin-top: 24px;
    color: var(--base_color_green_sub_2);
    font-size: 14px;
    text-decoration: underline;
    text-underline-offset: 4px;
  }

  .site-nav .site-nav__copy {
    display: block;
    margin: 48px 0 0;
    color: var(--base_color_w);
    font-size: 10px;
    font-weight: 400;
    line-height: 1.4;
    white-space: normal;
  }
}

@media (max-width: 374px) {
  .site-header__inner {
    margin-right: 18px;
    margin-left: 18px;
  }

  .site-logo {
    width: 150px;
  }

  .site-nav {
    padding-right: 36px;
    padding-left: 30px;
  }

  .site-nav__copy {
    font-size: 10px;
  }
}
