@charset "UTF-8";
/* ==============================================================================
# メディアクエリのmixin
============================================================================== */
/* ==============================================================================
# メディアクエリのmixin
============================================================================== */
@media screen and (max-width: 767px) {
  .is-sp-up {
    display: none !important;
  }
}

@media screen and (min-width: 768px) {
  .is-sp {
    display: none !important;
  }
}

@media screen and (max-width: 1350px) {
  .is-lg-header-up {
    display: none !important;
  }
}

@media screen and (min-width: 1351px) {
  .is-lg-header-down {
    display: none !important;
  }
}

@media screen and (max-width: 1000px) {
  .is-1000-up {
    display: none !important;
  }
}

@media screen and (min-width: 1001px) {
  .is-1000-down {
    display: none !important;
  }
}

/* ==============================================================================
# vw変換（vwベース変換）
============================================================================== */
/* ==============================================================================
# marquee（横スクロールアニメーション）
============================================================================= */
/*==========================================================================
# reset - ブラウザの差異や不要なスタイルを無くすためのスタイル
========================================================================== */
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

html,
body,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
dl,
li,
dt,
dd,
p,
div,
span,
img,
a,
table,
tr,
th,
td,
small,
button,
time,
figure {
  border: 0;
  font: inherit;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  font-size: 10px;
  scroll-behavior: smooth;
  scroll-padding-top: 120px;
  color: #000;
}
@media screen and (max-width: 767px) {
  html {
    scroll-padding-top: 80px;
  }
}

ol,
ul {
  list-style: none;
}

li,
dd {
  list-style-type: none;
}

header,
footer,
nav,
section,
article,
aside,
figure,
figcaption {
  display: block;
}

img {
  border: none;
  vertical-align: bottom;
  width: 100%;
  object-fit: cover;
  height: auto;
}

a {
  cursor: pointer;
  text-decoration: none;
  transition: all 0.3s;
}

a,
span {
  color: inherit;
}

/* ==============================================================================
# font-familyの定義
============================================================================== */
body {
  font-family: "Inter", sans-serif;
}

.inter {
  font-family: "Inter", sans-serif;
}

.oswald {
  font-family: "Oswald", sans-serif;
}

.body {
  position: relative;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 115px;
  z-index: 100;
  background: rgba(255, 255, 255, 0.8);
  box-shadow: 0 36.216px 45.27px -9.054px rgba(0, 0, 0, 0.1), 0 14.486px 18.108px -10.865px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(7.2432432175px);
}
@media screen and (max-width: 900px) {
  .header {
    height: 80px;
  }
}
.header .inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  height: -webkit-fill-available;
  max-width: 1392px;
}
.header .header__brand {
  height: 100%;
  display: flex;
  align-items: center;
}
.header .header__logo {
  width: 100%;
  max-width: 192px;
}
@media screen and (max-width: 1399px) {
  .header .header__logo {
    max-width: 180px;
  }
}
.header .header__logo.header__logo--for-seo {
  max-width: 296px;
  width: 100%;
}
@media screen and (max-width: 1399px) {
  .header .header__logo.header__logo--for-seo {
    max-width: 240px;
  }
}
.header {
  /* ------------------ Right ------------------ */
}
.header .header__right {
  display: flex;
  gap: 40px;
  align-items: center;
}
@media screen and (max-width: 900px) {
  .header .header__right {
    gap: 0;
  }
}
.header {
  /* ------------------ Meta ------------------ */
}
.header .header__meta {
  width: 100%;
  margin-bottom: 12px;
}
@media screen and (max-width: 900px) {
  .header .header__meta {
    display: none;
  }
}
@media screen and (max-width: 900px) {
  .header .header__right-inner {
    display: none;
  }
}
.header .header__meta-inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 14px;
  font-size: 12px;
  color: #4b5563;
}
.header .header__lang {
  display: flex;
  align-items: center;
  gap: 0;
  border: none;
  background: transparent;
  color: #1e3a8a;
  font-weight: 700;
  cursor: pointer;
  padding: 2px 0;
  position: relative;
}
.header .header__lang::after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 12px;
  background: rgba(30, 58, 138, 0.2);
  margin-left: 14px;
}
.header .header__lang-text {
  margin: 0 10px 0 8px;
}
.header .header__lang:hover .header__lang-tooltip, .header .header__lang:focus-visible .header__lang-tooltip {
  opacity: 1;
}
.header .header__lang-tooltip {
  position: absolute;
  top: 100%;
  right: 0;
  margin-top: 8px;
  background: #1f2937;
  color: #fff;
  font-size: 10px;
  line-height: 1;
  padding: 4px 8px;
  border-radius: 4px;
  opacity: 0;
  transition: opacity 0.2s ease;
  pointer-events: none;
  white-space: nowrap;
  z-index: 1;
}
.header .header__meta-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #1C2438;
  font-size: 16px;
  font-weight: 400;
  line-height: 1;
}
.header .header__meta-link:hover {
  color: #1e3a8a;
}
.header .header__meta-link:not(:first-of-type)::before {
  content: "";
  display: inline-block;
  width: 1px;
  height: 10px;
  background: rgba(30, 58, 138, 0.2);
  margin-right: 14px;
}
.header .header__tel {
  display: flex;
  align-items: center;
  gap: 8px;
}
.header .header__tel-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #1e3a8a;
  font-weight: 700;
  text-decoration: none;
  color: #1C2438;
}
.header .header__tel-number {
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}
.header .header__tel-note {
  font-size: 12px;
  font-weight: 300;
}
.header {
  /* ------------------ Main ------------------ */
}
.header .header__main {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 46px;
}
.header {
  /* ------------------ List ------------------ */
}
.header .header__list {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.header .header__item {
  position: relative;
}
.header .header__item.is-active .header__link::after {
  content: "";
  position: absolute;
  bottom: -4px;
  left: 50%;
  transform: translateX(-50%);
  width: calc(100% + 20px);
  height: 1px;
  background: #fbc600;
}
.header .header__item.has-dropdown .header__dropdown-wrapper {
  position: relative;
}
.header .header__item.has-dropdown:hover .header__dropdown {
  opacity: 1;
  visibility: visible;
  transform: translateY(30px);
}
.header .header__link {
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #1e3a8a;
  font-family: Inter;
  font-size: 14px;
  font-weight: 700;
  transition: color 0.2s ease;
  padding: 4px 4px;
}
.header .header__link:hover {
  color: #2563eb;
}
.header .header__dropdown-caret {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 10px;
  height: 10px;
  opacity: 0.5;
  transition: opacity 0.2s ease;
}
.header .header__dropdown-caret svg {
  display: block;
  width: 100%;
  height: 100%;
}
.header .header__item.has-dropdown:hover .header__dropdown-caret {
  opacity: 1;
}
.header .header__dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  width: 288px;
  background: #fff;
  border-radius: 12px;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
  border: 1px solid rgb(226, 232, 240);
  opacity: 0;
  visibility: hidden;
  transform: translateY(34px);
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  z-index: 1000;
}
.header .header__dropdown::before {
  content: "";
  position: absolute;
  top: -34px;
  left: -10px;
  width: calc(100% + 20px);
  height: 34px;
  background: transparent;
}
.header .header__dropdown-inner {
  padding: 8px;
  border-radius: 12px;
  overflow: hidden;
}
.header .header__dropdown-item {
  display: block;
  padding: 16px;
  border-radius: 8px;
  text-decoration: none;
  transition: background-color 0.2s ease;
  color: inherit;
}
.header .header__dropdown-item:hover {
  background-color: rgb(248, 250, 252);
}
.header .header__dropdown-item:hover .header__dropdown-title {
  color: #2563eb;
}
.header .header__dropdown-title {
  font-weight: 700;
  font-size: 14px;
  color: #1e293b;
  margin-bottom: 4px;
  transition: color 0.2s ease;
}
.header .header__dropdown-desc {
  font-size: 12px;
  color: #94a3b8;
  margin: 0;
  line-height: 1.4;
}
.header {
  /* ------------------ Actions ------------------ */
}
.header .header__actions {
  display: flex;
  align-items: center;
  gap: 9px;
}
@media screen and (max-width: 900px) {
  .header .header__actions {
    display: none;
  }
}
@media screen and (max-width: 900px) {
  .header .header__mobile-menu .header__actions {
    display: flex;
  }
}
.header .header__action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 64px;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.16);
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  white-space: nowrap;
  width: 144px;
  transition: all 0.2s ease;
}
.header .header__action:hover {
  opacity: 0.7;
  transform: translateY(-2px);
}
.header .header__action--outline {
  background: #FFF;
  color: #1e3a8a;
}
.header .header__action--primary {
  background: #1E3A8A;
  color: #fff;
}
.header .header__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.header .header__icon svg {
  display: block;
  width: 100%;
  height: 100%;
}
.header .header__icon--meta {
  width: 13px;
  height: 13px;
}
.header .header__icon--action {
  width: 12px;
  height: 12px;
}

/* ==============================================================================
# Hamburger Menu
============================================================================== */
.header__hamburger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 6px;
  width: 42px;
  height: 42px;
  background: transparent;
  border: none;
  cursor: pointer;
  padding: 0;
  z-index: 91;
  background: #1e3a8a;
  border-radius: 5px;
}
@media screen and (max-width: 1399px) {
  .header__hamburger {
    display: flex;
  }
}
.header__hamburger-line {
  width: 57.1428571429%;
  height: 2px;
  margin: 0 auto;
  background: #fff;
  border-radius: 3px;
  transition: all 0.3s ease;
}
.header__hamburger.is-active .header__hamburger-line:nth-child(1) {
  transform: translateY(8px) rotate(45deg);
}
.header__hamburger.is-active .header__hamburger-line:nth-child(2) {
  opacity: 0;
  transform: translateX(-10px);
}
.header__hamburger.is-active .header__hamburger-line:nth-child(3) {
  transform: translateY(-8px) rotate(-45deg);
}
@media screen and (max-width: 1399px) {
  .header__nav {
    display: none;
  }
}
.header__mobile-menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: #fff;
  backdrop-filter: blur(7.2432432175px);
  z-index: 90;
  opacity: 0;
  transform: translateY(20px);
  visibility: hidden;
  transition: opacity 0.35s ease, transform 0.45s cubic-bezier(0.22, 1, 0.36, 1), visibility 0.35s ease;
  overflow-y: auto;
  display: none;
}
@media screen and (max-width: 1399px) {
  .header__mobile-menu {
    display: block;
    height: 100vh;
  }
}
.header__mobile-menu.is-active {
  opacity: 1;
  transform: translateY(0);
  visibility: visible;
}
.header__mobile-menu-inner {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  padding: 100px 20px 34px;
}
.header__mobile-menu-logo {
  display: flex;
  align-items: center;
  gap: 12px;
}
.header__mobile-menu-logo img {
  width: 40px;
  height: auto;
}
.header__mobile-menu-logo-text {
  color: #333;
  font-size: 12px;
  line-height: 1.6;
  margin: 0;
}
.header__mobile-menu-nav {
  width: 100%;
  max-width: 300px;
  margin: 0 auto;
  padding: 0;
  order: 1;
}
.header__mobile-menu-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.header__mobile-menu-item {
  border-bottom: none;
}
.header__mobile-menu-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0;
  color: #1e3a8a;
  text-decoration: none;
  transition: none;
}
.header__mobile-menu-icon {
  width: 30px;
  aspect-ratio: 1/1;
}
.header__mobile-menu-text {
  color: #1e3a8a;
  font-size: 16px;
  font-weight: 700;
}
.header__mobile-menu-dash {
  display: inline-block;
  font-weight: 700;
  opacity: 0.9;
}
.header__mobile-menu-meta {
  max-width: 300px;
  margin: 24px auto 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  order: 3;
}
.header__mobile-menu-meta-link {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid rgba(30, 58, 138, 0.15);
  color: #1c2438;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  cursor: pointer;
}
.header__mobile-menu-meta-link svg {
  width: 14px;
  height: 14px;
}
.header__mobile-menu-meta-text {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.header__mobile-menu-tel-number {
  font-weight: 700;
}
.header__mobile-menu-tel-note {
  font-size: 11px;
  font-weight: 400;
  color: #4b5563;
}
.header__mobile-menu-footer {
  margin-top: 40px;
  order: 2;
}
.header__mobile-menu-footer .header__actions {
  max-width: 300px;
  margin: 0 auto;
  flex-direction: column;
  gap: 10px;
}
.header__mobile-menu-footer .header__action {
  width: 100%;
  font-size: 12px;
  padding: 10px 14px;
}
.header__mobile-menu-footer .header__icon--action {
  width: 10px;
  height: 10px;
}
.header__mobile-menu-cta {
  max-width: 300px;
  margin: 0 auto;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  background: #fff;
  border-radius: 999px;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.25);
  color: #1e3a8a;
  font-weight: 800;
  text-decoration: none;
}
.header__mobile-menu-cta-text {
  font-size: 16px;
  letter-spacing: 0.02em;
}
.header__mobile-menu-close-btn {
  width: 56px;
  height: 56px;
  margin: 0 auto 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  border-radius: 12px;
  border: none;
  box-shadow: 0 4px 10px 0 rgba(0, 0, 0, 0.2);
  cursor: pointer;
  color: #4b8dd2;
  font-weight: 700;
  line-height: 1;
}
.header__mobile-menu-close-btn:focus-visible {
  outline: 2px solid #4b8dd2;
  outline-offset: 4px;
}
.header__mobile-menu-close-btn-icon {
  font-size: 28px;
  line-height: 1;
}

/* ==============================================================================
# Footer
============================================================================== */
.footer {
  /* --------------------------------------------------
   * Footer Main
   * -------------------------------------------------- */
}
.footer__main {
  padding: 80px 0;
}
@media screen and (max-width: 767px) {
  .footer__main {
    padding: 48px 0;
  }
}
.footer__logo {
  display: block;
  max-width: 220px;
}
.footer__grid {
  display: flex;
  gap: 20px;
  justify-content: space-between;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .footer__grid {
    flex-direction: column;
    gap: 32px;
  }
}
.footer__left {
  flex-shrink: 0;
  min-width: 260px;
}
@media screen and (max-width: 767px) {
  .footer__left {
    min-width: 0;
    width: 100%;
  }
}
.footer__slogan {
  color: #000;
  font-size: 28px;
  line-height: 140%;
}
.footer {
  /* --------------------------------------------------
   * Footer Nav
   * -------------------------------------------------- */
}
.footer__nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
  justify-content: flex-start;
  max-width: 770px;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .footer__nav {
    grid-template-columns: 1fr;
    gap: 28px;
    max-width: none;
  }
}
.footer__col {
  flex: 1;
}
.footer__col-title {
  color: #666;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: 22px;
}
@media screen and (max-width: 767px) {
  .footer__col-title {
    margin-bottom: 12px;
  }
}
.footer__col-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.footer__col--info .footer__col-title {
  color: #666;
}
.footer__col--info .footer__col-link {
  color: #2A58B3;
  font-weight: 700;
}
.footer__col--info .footer__col-link--cta {
  color: #000;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-weight: 700;
  line-height: 1.5;
  gap: 0;
  border-bottom: 2px solid #0056B3;
  padding-bottom: 4px;
  width: fit-content;
}
.footer__col--info .footer__col-link-arrow {
  color: #0056B3;
  margin-left: 4px;
}
.footer__col-link {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
  transition: all 0.2s ease;
}
.footer__col-link:hover, .footer__col-link:focus-visible {
  opacity: 0.7;
}
.footer__col-link {
  /* ニュース・コラム（★付きハイライト） */
}
.footer__col-link--highlight {
  font-weight: 500;
}
.footer__col-link-star {
  color: #fbc600;
  margin-right: 4px;
}
.footer__col-link {
  /* 翻訳サービス診断（CTA風リンク） */
}
.footer__col-link--cta {
  font-weight: 700;
  font-size: 14px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
}
.footer__col-link-arrow {
  font-size: 14px;
  transition: transform 0.3s ease;
}
.footer__col-link--cta:hover .footer__col-link-arrow {
  transform: translateX(4px);
}
.footer {
  /* --------------------------------------------------
   * Footer Bottom
   * -------------------------------------------------- */
}
.footer__bottom {
  border-top: 1px solid #EAEAEA;
  padding: 30px 0;
}
.footer__bottom-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .footer__bottom-inner {
    flex-direction: column;
    gap: 16px;
    text-align: center;
  }
}
.footer__bottom-links {
  display: flex;
  align-items: center;
  gap: 30px;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .footer__bottom-links {
    justify-content: center;
    gap: 16px;
  }
}
.footer__bottom-link {
  font-size: 12px;
  font-weight: 400;
  transition: color 0.3s ease;
  text-decoration: none;
}
.footer__bottom-copyright {
  font-size: 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
}
.footer__bottom-company {
  color: #036;
  font-size: 12px;
  font-weight: 700;
}
.footer__bottom-copy {
  color: #666;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-style: normal;
  font-weight: 350;
  line-height: 18px;
}

.main {
  position: relative;
}

/* ==============================================================================
# Inner
============================================================================== */
.inner {
  max-width: 1200px;
  padding: 0 32px;
  box-sizing: content-box;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .inner {
    padding: 0 32px;
  }
}

@keyframes c-marquee-rtl {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-50%);
  }
}
@keyframes c-marquee-ltr {
  from {
    transform: translateX(-50%);
  }
  to {
    transform: translateX(0);
  }
}
.splide__track {
  overflow: visible;
}

.splide__pagination {
  position: static;
  margin-top: 30px;
  display: flex;
  justify-content: center;
  gap: 32px;
}
@media screen and (max-width: 767px) {
  .splide__pagination {
    gap: 8px;
  }
}

.splide__pagination__page {
  width: 15px;
  height: 15px;
  border-radius: 999px;
  background: #c1e2fe;
  opacity: 1;
  margin: 0;
}
@media screen and (max-width: 767px) {
  .splide__pagination__page {
    width: 8px;
    height: 8px;
  }
}
.splide__pagination__page.is-active {
  background: #3984c3;
  transform: none;
}

.breadcrumb {
  padding: 16px 0;
  color: rgba(0, 0, 0, 0.87);
  font-feature-settings: "liga" off, "clig" off;
  font-size: 16px;
  line-height: 150%;
  letter-spacing: 0.15px;
}
.breadcrumb__list {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.breadcrumb__item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.breadcrumb__item:not(:last-child)::after {
  content: "/";
  color: #a7b0c2;
}
.breadcrumb__link, .breadcrumb__current {
  display: flex;
  align-items: center;
}
.breadcrumb__link:hover {
  text-decoration: underline;
}
.breadcrumb__item:first-child .breadcrumb__link::before {
  content: "";
  display: inline-block;
  width: 16px;
  height: 16px;
  margin-right: 8px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2216%22%20height%3D%2216%22%20viewBox%3D%220%200%2016%2016%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M6.66732%2013.3333V9.33333H9.33398V13.3333H12.6673V8H14.6673L8.00065%202L1.33398%208H3.33398V13.3333H6.66732Z%22%20fill%3D%22black%22%20fill-opacity%3D%220.56%22%2F%3E%3C%2Fsvg%3E");
}

.under-hero {
  background: center/cover no-repeat url("../img/under/hero.webp");
  padding: 165px 0 50px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .under-hero {
    padding: 120px 0 40px;
  }
}
.under-hero__title {
  color: #D7DCE3;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  padding-bottom: 16px;
  border-bottom: 4px solid #FBC600;
  margin-bottom: 16px;
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .under-hero__title {
    font-size: 48px;
    padding-bottom: 4px;
  }
}
.under-hero__lead {
  color: #FFF;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .under-hero__lead {
    font-size: 24px;
  }
}

.faq {
  padding: 80px 0;
  color: #1f2a3c;
}
@media screen and (max-width: 767px) {
  .faq {
    padding: 64px 0;
  }
}
.faq .inner {
  max-width: 862px;
}
.faq .gray-title {
  width: fit-content;
  margin: 0 auto;
  color: #D7DCE3;
  text-align: center;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  padding-bottom: 10px;
  border-bottom: 4px solid #FBC600;
}
@media screen and (max-width: 767px) {
  .faq .gray-title {
    font-size: min(64px, min(40px, 40 / 415 * 100vw));
    padding-bottom: 10px;
    border-bottom: 2px solid #FBC600;
  }
}
.faq .gray-title-set {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
@media screen and (max-width: 767px) {
  .faq .gray-title-set {
    gap: 8px;
  }
}
.faq .gray-label {
  margin: 0;
  color: #374E71;
  text-align: center;
  font-size: 24px;
}
.faq .gray-description {
  color: #64748B;
  text-align: center;
  font-size: 16px;
  line-height: 1.5;
}
.faq__body {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .faq__body {
    margin-top: 32px;
  }
}

.faq-accordion {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.faq-accordion__item {
  border: 1px solid #E2E8F0;
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}
.faq-accordion__item.is-open .faq-accordion__q-icon::before {
  content: "−";
}
.faq-accordion__q {
  background: transparent;
  border: none;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 16px 20px;
  cursor: pointer;
  font-size: 16px;
  font-weight: 700;
  color: #1f2a3c;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .faq-accordion__q {
    padding: 14px 16px;
    gap: 12px;
  }
}
.faq-accordion__q-text {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  min-width: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.56;
}
.faq-accordion__q-text::before {
  content: "Q.";
  color: #2563EB;
  font-size: 20px;
  font-weight: 700;
  flex: 0 0 auto;
}
@media screen and (max-width: 767px) {
  .faq-accordion__q-text::before {
    font-size: 18px;
  }
}
@media screen and (max-width: 767px) {
  .faq-accordion__q-text {
    gap: 8px;
    font-size: 15px;
  }
}
.faq-accordion__q-icon {
  width: 24px;
  height: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #8c9bb0;
  font-size: 0;
  font-weight: 700;
  line-height: 1;
  flex: 0 0 auto;
}
.faq-accordion__q-icon::before {
  content: "+";
  font-size: 18px;
}
.faq-accordion__a {
  padding: 0 20px 18px;
}
.faq-accordion__a-inner {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: start;
  column-gap: 10px;
  row-gap: 8px;
  color: #273344;
  font-size: 16px;
  line-height: 1.8;
}
.faq-accordion__a-inner::before {
  content: "A.";
  color: #273344;
  font-weight: 700;
  font-size: 20px;
  flex: 0 0 auto;
}
@media screen and (max-width: 767px) {
  .faq-accordion__a-inner::before {
    font-size: 18px;
  }
}
.faq-accordion__a-inner > * {
  grid-column: 2;
}
.faq-accordion__a-inner p {
  margin: 0;
  color: #1E293B;
  font-size: 18px;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .faq-accordion__a-inner p {
    font-size: 15px;
  }
}
.faq-accordion__a-inner p + p {
  margin-top: 12px;
}
@media screen and (max-width: 767px) {
  .faq-accordion__a-inner {
    font-size: 15px;
  }
}
@media screen and (max-width: 767px) {
  .faq-accordion__a {
    padding: 0 16px 16px;
  }
}

.faq__empty {
  margin: 0;
  padding: 18px 20px;
  border: 1px solid #d8dee8;
  border-radius: 12px;
  background: #fff;
  color: #5e6b7c;
  font-size: 14px;
}

.faq__contact {
  margin-top: 64px;
  color: #64748B;
  text-align: center;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .faq__contact {
    margin-top: 40px;
  }
}
.faq__contact a {
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-skip-ink: auto;
  text-decoration-thickness: auto;
  text-underline-offset: auto;
  text-underline-position: from-font;
}

.header-diagnosis-modal {
  position: fixed;
  inset: 0;
  z-index: 2000;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.25s ease, visibility 0.25s ease;
}
.header-diagnosis-modal.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.header-diagnosis-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.6);
}
.header-diagnosis-modal__dialog {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(1295px, 80vw);
  height: min(1280px, 80svh);
  transform: translate(-50%, -50%);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 30px 60px rgba(0, 0, 0, 0.3);
}
@media screen and (max-width: 767px) {
  .header-diagnosis-modal__dialog {
    width: 91.5vw;
    height: 80svh;
    border-radius: 12px;
  }
}
.header-diagnosis-modal__close {
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(50%, -50%);
  width: 69px;
  height: 69px;
  border: none;
  border-radius: 999px;
  background: transparent;
  padding: 0;
  cursor: pointer;
  z-index: 2;
}
.header-diagnosis-modal__close svg {
  display: block;
  width: 100%;
  height: 100%;
}
.header-diagnosis-modal__close:focus-visible {
  outline: 2px solid #1e3a8a;
  outline-offset: 2px;
}
@media screen and (max-width: 767px) {
  .header-diagnosis-modal__close {
    top: 6px;
    right: 16px;
    width: 50px;
    height: 50px;
  }
}
.header-diagnosis-modal__iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
}

.diagnosis-tool {
  width: 100%;
  height: 100%;
  padding: 48px 64px;
  color: #1c2438;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool {
    padding: min(16px, 16 / 415 * 100vw);
    padding-bottom: min(60px, 60 / 415 * 100vw);
  }
}
.diagnosis-tool__screen {
  display: none;
  width: 100%;
  min-height: 100%;
}
.diagnosis-tool__screen.is-active {
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__screen {
    border-radius: 10px;
  }
}
.diagnosis-tool__screen--intro {
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__screen--intro {
    padding: 0;
  }
}
.diagnosis-tool__intro-content {
  width: 100%;
  max-height: 100%;
  margin: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 50px;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__intro-content {
    gap: 24px;
  }
}
.diagnosis-tool__intro-illust {
  width: min(523px, 523 / 1240 * 100vw);
  height: auto;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__intro-illust {
    width: 53.5897435897vw;
  }
}
.diagnosis-tool__intro-title {
  margin: 0;
  color: #3E3A39;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(24px, 3.6vmin, 64px);
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__intro-title {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.diagnosis-tool__intro-button, .diagnosis-tool__next {
  border: 0;
  border-radius: 999px;
  background: #fbc600;
  color: #1e3a8a;
  font-weight: 700;
  cursor: pointer;
  transition: transform 0.2s ease, opacity 0.2s ease;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__intro-button, .diagnosis-tool__next {
    border-radius: 32px;
  }
}
.diagnosis-tool__intro-button:hover, .diagnosis-tool__next:hover, .diagnosis-tool__result-btn:hover {
  transform: translateY(-1px);
  opacity: 0.9;
}
.diagnosis-tool__intro-button {
  margin-top: 0;
  display: inline-flex;
  min-height: clamp(40px, 3.7vmin, 66px);
  padding: clamp(10px, 1.05vmin, 19px) clamp(24px, 2.7vmin, 48px);
  align-items: center;
  justify-content: center;
  border-radius: 76px;
  box-shadow: 0 4.8px 4.8px rgba(0, 0, 0, 0.16);
  color: #374E71;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(18px, 2.4vmin, 43px);
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__intro-button {
    min-height: 52px;
    padding: 16px 28px;
    font-size: min(25px, 25 / 415 * 100vw);
  }
}
.diagnosis-tool__progress {
  width: 100%;
  height: 6px;
  flex: 0 0 6px;
  background: #f4e9b8;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__progress {
    height: 4px;
    flex: 0 0 4px;
  }
}
.diagnosis-tool__progress-bar {
  width: 0%;
  height: 100%;
  background: #fbc600;
  transition: width 0.4s ease;
}
.diagnosis-tool__question-head {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__question-head {
    margin-top: 10px;
  }
}
.diagnosis-tool__question-copy {
  margin-top: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid #f4d874;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__question-copy {
    padding-bottom: 10px;
  }
}
.diagnosis-tool__question-label {
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
  color: #fbc600;
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: 37.6px;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__question-label {
    gap: 6px;
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.diagnosis-tool__question-number {
  display: inline-block;
  color: #fbc600;
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(60px, 8vmin, 90.24px);
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__question-number {
    font-size: min(55px, 55 / 415 * 100vw);
  }
}
.diagnosis-tool__question-total {
  display: none;
}
.diagnosis-tool__question-title {
  margin: 0;
  font-size: clamp(24px, 2.4vmin, 32px);
  font-weight: 700;
  line-height: 1;
  color: #333;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__question-title {
    font-size: min(24px, 24 / 415 * 100vw);
    line-height: 1.4;
  }
}
.diagnosis-tool__question-note {
  margin: 8px 0 0;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.4;
  color: #555;
  display: none;
}
.diagnosis-tool__question-note.is-visible {
  display: block;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__question-note {
    margin-top: 6px;
  }
}
.diagnosis-tool__question-options {
  display: grid;
  gap: 16px;
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__question-options {
    gap: 10px;
    margin-top: 12px;
  }
}
.diagnosis-tool__option {
  border: 1px solid #FBC600;
  background: #FFF1BF;
  border-radius: 64px;
  box-shadow: 4px 4px 11px 0 rgba(0, 0, 0, 0.1);
  padding: 16px 32px;
  text-align: left;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: clamp(10px, 1.8vmin, 32px);
  color: #333;
  cursor: pointer;
  min-height: clamp(64px, 8vmin, 144px);
}
.diagnosis-tool__option.is-active {
  background: #fbc600;
  color: #1f1f1f;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option {
    min-height: 64px;
    border-radius: 32px;
    padding: min(16px, 16 / 415 * 100vw) min(24px, 24 / 415 * 100vw);
    gap: 10px;
  }
}
.diagnosis-tool__option-main {
  display: flex;
  align-items: center;
  gap: clamp(10px, 1.8vmin, 32px);
  min-width: 0;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option-main {
    gap: 16px;
  }
}
.diagnosis-tool__option-mark {
  width: clamp(32px, 6.2vmin, 112px);
  height: clamp(32px, 6.2vmin, 112px);
  border: 1px solid #cfbe82;
  border-radius: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  font-size: clamp(18px, 3.5vmin, 64px);
  line-height: 1;
  color: #d2aa14;
  flex: 0 0 auto;
}
.diagnosis-tool__option-mark svg {
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option-mark {
    width: 32px;
    height: 32px;
    font-size: 18px;
  }
}
.diagnosis-tool__option-icon {
  display: block;
  width: 100%;
  height: 100%;
}
.diagnosis-tool__option-text {
  min-width: 0;
  display: grid;
  gap: 0;
}
.diagnosis-tool__option-title {
  margin: 0;
  font-size: clamp(14px, 2vmin, 36px);
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option-title {
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 1.35;
  }
}
.diagnosis-tool__option-sub {
  margin: 0;
  font-size: clamp(14px, 2vmin, 36px);
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option-sub {
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 1.35;
  }
}
.diagnosis-tool__option-arrow {
  flex: 0 0 auto;
  width: clamp(20px, 2.6vmin, 48px);
  height: clamp(20px, 2.6vmin, 48px);
}
.diagnosis-tool__option-arrow svg {
  display: block;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option-arrow {
    width: 20px;
    height: 20px;
  }
}
.diagnosis-tool__option--multiple {
  min-height: clamp(56px, 4.9vmin, 88px);
  border-radius: 999px;
  padding: 12px 24px;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option--multiple {
    border-radius: 32px;
  }
}
.diagnosis-tool__option--multiple .diagnosis-tool__option-mark {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: 0;
  font-size: 0;
  color: transparent;
}
.diagnosis-tool__option--multiple .diagnosis-tool__option-title {
  font-size: clamp(14px, 2.7vmin, 49px);
  line-height: 1.2;
}
.diagnosis-tool__option--multiple .diagnosis-tool__option-sub {
  display: none;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__option--multiple .diagnosis-tool__option-mark {
    width: 20px;
    height: 20px;
  }
}
.diagnosis-tool[data-current-question="1"] .diagnosis-tool__option-mark {
  border: 0;
  background: transparent;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool[data-current-question="1"] .diagnosis-tool__option-mark {
    display: none;
  }
}
.diagnosis-tool[data-current-question="1"] .diagnosis-tool__option-title {
  font-weight: 400;
}
.diagnosis-tool[data-current-question="1"] .diagnosis-tool__option-sub {
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool[data-current-question="1"] .diagnosis-tool__option-text {
    display: block;
  }
  .diagnosis-tool[data-current-question="1"] .diagnosis-tool__option-title,
  .diagnosis-tool[data-current-question="1"] .diagnosis-tool__option-sub {
    display: inline;
  }
}
.diagnosis-tool[data-current-question="2"] .diagnosis-tool__option-mark {
  width: clamp(28px, 7vmin, 128px);
  height: clamp(28px, 7vmin, 128px);
  border: 0;
  border-radius: 0;
  background: transparent;
  color: transparent;
}
.diagnosis-tool[data-current-question="2"] .diagnosis-tool__option-title {
  font-weight: 700;
  line-height: 1.25;
}
.diagnosis-tool[data-current-question="2"] .diagnosis-tool__option-sub {
  font-size: clamp(11px, 1.45vmin, 26px);
  font-weight: 700;
  line-height: 1.35;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool[data-current-question="2"] .diagnosis-tool__option-sub {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .diagnosis-tool[data-current-question="2"] .diagnosis-tool__option-mark {
    width: min(48px, 48 / 415 * 100vw);
    height: min(48px, 48 / 415 * 100vw);
  }
}
.diagnosis-tool[data-current-question="3"] .diagnosis-tool__option-title {
  font-size: clamp(14px, 2.8vmin, 36px);
  line-height: 1.3;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool[data-current-question="3"] .diagnosis-tool__option-title {
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 1.4;
  }
}
@media screen and (max-width: 767px) {
  .diagnosis-tool[data-current-question="3"] .diagnosis-tool__option-sub {
    font-size: min(16px, 16 / 415 * 100vw);
    line-height: 1.4;
  }
}
.diagnosis-tool[data-current-question="3"] .diagnosis-tool__option-main {
  gap: 20px;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool[data-current-question="3"] .diagnosis-tool__option-mark {
    width: min(20px, 20 / 415 * 100vw);
    height: min(20px, 20 / 415 * 100vw);
  }
}
.diagnosis-tool__footer {
  margin-top: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 20px;
  padding-top: 32px;
  min-height: 60px;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__footer {
    padding-top: 16px;
    min-height: 46px;
    gap: 0;
  }
}
.diagnosis-tool__back {
  border: 0;
  background: transparent;
  color: #b2bed4;
  font-size: clamp(12px, 1.8vmin, 20px);
  font-weight: 700;
  cursor: pointer;
  visibility: hidden;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__back {
    font-size: 12px;
  }
}
.diagnosis-tool__next {
  width: min(clamp(220px, 23.52vmin, 301px), 100%);
  min-height: clamp(46px, 4.69vmin, 60px);
  padding: 0;
  font-size: clamp(18px, 1.88vmin, 24px);
  line-height: 1.675;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  visibility: hidden;
  opacity: 0.6;
  pointer-events: none;
  border-radius: clamp(41.08px, 4.19vmin, 53.6px);
  background: #1e3a8a;
  color: #fff;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-weight: 700;
  box-shadow: 0 clamp(5.13px, 0.52vmin, 6.7px) clamp(5.13px, 0.52vmin, 6.7px) rgba(0, 0, 0, 0.16);
}
.diagnosis-tool__next.is-visible {
  visibility: visible;
  opacity: 0.6;
  pointer-events: none;
}
.diagnosis-tool__next.is-ready {
  opacity: 1;
  pointer-events: auto;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__next {
    line-height: 1.4;
    font-size: min(16px, 16 / 415 * 100vw);
    width: fit-content;
    min-height: 41px;
    padding: 12px 18px;
  }
}
.diagnosis-tool__result-head {
  width: min(1167px, 100%);
  margin: 0 auto clamp(14px, 1.8vmin, 23px);
  padding: 0 clamp(56px, 8.52vmin, 109px);
  position: relative;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-head {
    margin-bottom: 14px;
    padding: 0 0 0 8px;
  }
}
.diagnosis-tool__result-kicker {
  margin: 0 auto;
  width: fit-content;
  color: #fbc600;
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(24px, 2.4vmin, 37.6px);
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-kicker {
    font-size: min(20px, 20 / 415 * 100vw);
  }
}
.diagnosis-tool__result-title {
  margin: clamp(28px, 3.75vmin, 48px) 0 0;
  color: #333;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-size: clamp(24px, 2.81vmin, 48px);
  font-weight: 700;
  line-height: 1;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-title {
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 2.05;
    margin-top: 0;
  }
}
.diagnosis-tool__result-card-wrap {
  width: min(1005px, 100%);
  margin: 0 auto;
  position: relative;
  z-index: 0;
}
.diagnosis-tool__result-human {
  position: absolute;
  right: 0;
  top: 0;
  transform: translate(0, -44%);
  width: clamp(70px, 8.52vmin, 109px);
  height: auto;
  pointer-events: none;
  z-index: 0;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-human {
    display: none;
  }
}
.diagnosis-tool__result-card {
  width: 100%;
  margin: 0;
  position: relative;
  z-index: 1;
  border: 1px solid #e6e6e6;
  border-radius: clamp(12px, 1.25vmin, 16px);
  background: #fff;
  box-shadow: 0 0 11px 0 rgba(0, 0, 0, 0.08);
  padding: clamp(30px, 4vmin, 60px) 20px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-card {
    padding: 16px;
    border-radius: 12px;
    box-shadow: none;
    padding: 0;
    border: 0;
  }
}
.diagnosis-tool__result-main {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(10px, 1.25vmin, 16px);
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-main {
    padding: 20px 8px 0;
    gap: 10px;
  }
}
.diagnosis-tool__result-plan {
  margin: 0;
  text-align: center;
  color: #333;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(40px, 4.84vmin, 88px);
  line-height: 1.1;
  font-weight: 900;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-plan {
    font-size: min(40px, 40 / 415 * 100vw);
    line-height: 1.2;
  }
}
.diagnosis-tool__result-sub {
  display: none;
}
.diagnosis-tool__result-sub.is-visible {
  display: block;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-sub {
    font-size: 64px;
    color: #3b82f6;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
  }
}
.diagnosis-tool__result-option {
  display: none;
  margin: 0;
  text-align: center;
  color: #3b82f6;
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  line-height: 1.4;
}
.diagnosis-tool__result-option.is-visible {
  display: block;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-option {
    font-size: min(40px, 40 / 415 * 100vw);
  }
}
.diagnosis-tool__result-plus {
  display: block;
  font-size: 64px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-plus {
    font-size: min(64px, 64 / 415 * 100vw);
  }
}
.diagnosis-tool__result-option-text {
  display: block;
  font-size: clamp(40px, 4.84vmin, 48px);
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-option-text {
    font-size: min(40px, 40 / 415 * 100vw);
  }
}
.diagnosis-tool__result-message {
  margin: 0;
  color: #1e293b;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(18px, 2.11vmin, 36px);
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-message {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.diagnosis-tool__result-addon {
  display: none;
  width: fit-content;
  margin: 30px auto 0;
  text-align: left;
  padding: clamp(16px, 2.11vmin, 27px) clamp(20px, 2.34vmin, 40px);
  border-top: 1px solid #1e3a8a;
  border-bottom: 1px solid #1e3a8a;
}
.diagnosis-tool__result-addon.is-visible {
  display: block;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-addon {
    width: 100%;
    margin-top: 24px;
  }
  .diagnosis-tool__result-addon.is-visible {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    padding: 27px 0;
  }
}
.diagnosis-tool__result-addon-title {
  margin: 0;
  color: #2563eb;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(18px, 1.88vmin, 24px);
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-addon-title {
    font-size: min(20px, 20 / 415 * 100vw);
  }
}
.diagnosis-tool__result-options {
  margin: 0;
  padding: 0;
  list-style: none;
  color: #666;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(18px, 1.88vmin, 24px);
  font-weight: 700;
  line-height: 1.4;
  display: none;
}
.diagnosis-tool__result-options.is-visible {
  display: block;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-options {
    font-size: min(20px, 20 / 415 * 100vw);
  }
}
.diagnosis-tool__result-actions {
  margin-top: clamp(18px, 2.34vmin, 30px);
  display: flex;
  gap: clamp(16px, 2.5vmin, 32px);
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-actions {
    flex-direction: column;
    align-items: flex-start;
    gap: 32px;
    padding: 30px 0;
    margin-top: 0;
  }
}
.diagnosis-tool__result-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: clamp(220px, 23.52vmin, 301px);
  min-height: clamp(46px, 4.69vmin, 60px);
  border-radius: clamp(41.08px, 4.19vmin, 53.6px);
  border: clamp(1.28px, 0.13vmin, 1.675px) solid #1e3a8a;
  box-shadow: 0 clamp(5.13px, 0.52vmin, 6.7px) clamp(5.13px, 0.52vmin, 6.7px) rgba(0, 0, 0, 0.16);
  padding: 0;
  color: #fff;
  text-align: center;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-size: clamp(18px, 1.88vmin, 24px);
  font-weight: 700;
  line-height: 1.675;
  text-decoration: none;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__result-btn {
    width: min(301px, 100%);
    min-height: min(60px, 60 / 415 * 100vw);
    padding: 0;
    font-size: min(24px, 24 / 415 * 100vw);
    border-radius: 53.6px;
    margin: 0 auto;
  }
}
.diagnosis-tool__result-btn--primary {
  background: #1e3a8a;
  color: #fff;
}
.diagnosis-tool__result-btn--secondary {
  background: #fff;
  color: #1e3a8a;
}
.diagnosis-tool__restart {
  border: 0;
  background: transparent;
  margin: clamp(18px, 2.19vmin, 28px) auto 0;
  color: #94a3b8;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(14px, 1.56vmin, 20px);
  font-weight: 700;
  line-height: 1.4;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .diagnosis-tool__restart {
    margin-top: 20px;
    font-size: 14px;
  }
}

.translation-trial-modal {
  position: fixed;
  inset: 0;
  z-index: 2100;
  display: grid;
  place-items: center;
  padding: 12px;
  overflow-x: clip;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.25s ease, visibility 0.25s ease;
}
.translation-trial-modal.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.translation-trial-modal__backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 24, 39, 0.72);
}
.translation-trial-modal__dialog {
  position: relative;
  width: min(1295px, 80vw);
  height: min(1280px, 80svh);
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 clamp(20px, 2.19vmin, 28px) clamp(48px, 5.63vmin, 72px) rgba(0, 0, 0, 0.28);
  overflow: visible;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__dialog {
    width: 91.5vw;
    height: 80svh;
    border-radius: 12px;
  }
}
.translation-trial-modal__scroll {
  overflow-x: hidden;
  overflow-y: auto;
  height: 100%;
  border-radius: inherit;
}
.translation-trial-modal__close {
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(50%, -50%);
  width: 69px;
  height: 69px;
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
}
.translation-trial-modal__close svg {
  display: block;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__close {
    top: 6px;
    width: 50px;
    height: 50px;
    right: 16px;
    z-index: 2;
  }
}
.translation-trial-modal__inner {
  width: min(1295px, 100%);
  margin: 0 auto;
  padding: clamp(40px, 6vmin, 159px) 32px;
  max-width: 924px;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__inner {
    width: 100%;
    padding: 64px 16px 56px;
  }
}
.translation-trial-modal__title {
  margin: 0;
  color: #3d3d43;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(40px, 5vmin, 64px);
  line-height: 1.4;
  letter-spacing: 0.02em;
  font-weight: 700;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__title {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.translation-trial-modal__form {
  margin-top: clamp(32px, 3.98vmin, 51px);
  display: flex;
  flex-direction: column;
  gap: clamp(32px, 3.98vmin, 51px);
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__form {
    margin-top: 24px;
    gap: 24px;
  }
}
.translation-trial-modal__field-block {
  border-bottom: 1px solid #edd78e;
  padding-bottom: 40px;
}
.translation-trial-modal__label {
  margin-bottom: 12px;
  display: flex;
  align-items: baseline;
  gap: clamp(8px, 0.94vmin, 12px);
  color: #35353a;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-size: clamp(18px, 2.5vmin, 32px);
  line-height: 1;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__label {
    margin-bottom: 6px;
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 1.6;
  }
}
.translation-trial-modal__step {
  color: #fbc600;
  font-family: "Oswald", "Noto Sans JP", sans-serif;
  font-size: clamp(60px, 7vmin, 90.24px);
  line-height: 1.0417;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__step {
    font-size: min(40px, 40 / 415 * 100vw);
    line-height: 1;
  }
}
.translation-trial-modal__input, .translation-trial-modal__select-trigger {
  width: 100%;
  height: clamp(72px, 7.19vmin, 92px);
  border-radius: clamp(12px, 1.25vmin, 16px);
  border: 1px solid #cfcfcf;
  background: #fff;
  color: #1e293b;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-size: clamp(12px, 1.1vmin, 14px);
  font-weight: 400;
  line-height: 1.43;
  padding: 0 clamp(14px, 1.56vmin, 20px) 0 clamp(12px, 1.25vmin, 16px);
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__input, .translation-trial-modal__select-trigger {
    height: 48px;
    font-size: 14px;
    padding: 0 14px;
    border-radius: 16px;
  }
}
.translation-trial-modal__input::placeholder {
  color: #9ca3af;
}
.translation-trial-modal__select-wrap {
  position: relative;
}
.translation-trial-modal__select-wrap::after {
  content: "";
  position: absolute;
  top: 50%;
  right: clamp(14px, 1.56vmin, 20px);
  width: clamp(7px, 0.7vmin, 9px);
  height: clamp(5px, 0.47vmin, 6px);
  transform: translateY(-50%);
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url("data:image/svg+xml,%3Csvg%20width%3D%279%27%20height%3D%276%27%20viewBox%3D%270%200%209%206%27%20fill%3D%27none%27%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%3E%3Cpath%20d%3D%27M3.98438%205.07812L0.175781%201.28906C0%201.09375%200%200.800781%200.175781%200.625L0.625%200.175781C0.800781%200%201.09375%200%201.28906%200.175781L4.31641%203.18359L7.32422%200.175781C7.51953%200%207.8125%200%207.98828%200.175781L8.4375%200.625C8.61328%200.800781%208.61328%201.09375%208.4375%201.28906L4.62891%205.07812C4.45312%205.25391%204.16016%205.25391%203.98438%205.07812Z%27%20fill%3D%27%231C2438%27/%3E%3C/svg%3E");
  pointer-events: none;
}
.translation-trial-modal__select-wrap.is-open::after {
  transform: translateY(-50%) rotate(180deg);
}
.translation-trial-modal__select {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
  padding: 0;
  border: 0;
}
.translation-trial-modal__select-trigger {
  text-align: left;
  cursor: pointer;
  padding-right: clamp(40px, 4.38vmin, 56px);
}
.translation-trial-modal__select-trigger-text {
  display: block;
}
.translation-trial-modal__select-list {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  margin: 0;
  padding: 8px;
  list-style: none;
  border: 1px solid #cfcfcf;
  border-radius: clamp(12px, 1.25vmin, 16px);
  background: #fff;
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.16);
  max-height: min(42svh, 360px);
  overflow-y: auto;
  z-index: 5;
  display: none;
}
.translation-trial-modal__select-wrap.is-open .translation-trial-modal__select-list {
  display: block;
}
.translation-trial-modal__select-option {
  width: 100%;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: #1e293b;
  text-align: left;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-size: clamp(12px, 1.1vmin, 14px);
  font-weight: 400;
  line-height: 1.43;
  padding: 10px 12px;
  cursor: pointer;
}
.translation-trial-modal__select-option:hover, .translation-trial-modal__select-option:focus-visible, .translation-trial-modal__select-option.is-selected {
  background: #eff6ff;
  outline: 0;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__select-option {
    font-size: 14px;
  }
}
.translation-trial-modal__notes {
  width: 100%;
  max-width: fit-content;
  margin: 0 auto;
  color: #000;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.43;
  padding-left: 2.2em;
}
.translation-trial-modal__notes li {
  list-style: disc;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__notes {
    max-width: 100%;
    margin: 0;
  }
}
.translation-trial-modal__submit {
  margin: 0 auto;
  width: auto;
  min-height: clamp(72px, 8.13vmin, 104px);
  padding: clamp(14px, 1.5vmin, 19.143px) clamp(36px, 3.74vmin, 47.857px);
  border: 0;
  border-radius: clamp(56px, 5.98vmin, 76.571px);
  background: #fbc600;
  box-shadow: 0 clamp(3.5px, 0.37vmin, 4.786px) clamp(3.5px, 0.37vmin, 4.786px) 0 rgba(71, 85, 105, 0.2);
  color: #374e71;
  font-weight: 700;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-size: clamp(30px, 3.4vmin, 43.071px);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: clamp(8px, 0.94vmin, 11.964px);
  cursor: pointer;
  transition: filter 0.2s ease;
}
.translation-trial-modal__submit:hover {
  filter: brightness(0.97);
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__submit {
    min-height: 62px;
    padding: 11px 28px;
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 1.436;
    gap: 7px;
    border-radius: 46px;
  }
}
.translation-trial-modal__submit-icon {
  display: inline-flex;
  line-height: 0;
}
.translation-trial-modal__submit-icon svg {
  width: clamp(46px, 4.47vmin, 57.233px);
  height: auto;
  display: block;
}
@media screen and (max-width: 767px) {
  .translation-trial-modal__submit-icon svg {
    width: min(34px, 34 / 415 * 100vw);
  }
}

.index-page {
  /** ------------------------------------------------------------
   * SECTION: COMMON
   * ------------------------------------------------------------ */
}
.index-page .gray-title {
  width: fit-content;
  margin: 0 auto;
  color: #d7dce3;
  text-align: center;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  padding-bottom: 10px;
  border-bottom: 4px solid #fbc600;
}
@media screen and (max-width: 767px) {
  .index-page .gray-title {
    font-size: min(64px, min(40px, 40 / 415 * 100vw));
    padding-bottom: 10px;
    border-bottom: 2px solid #fbc600;
  }
}
.index-page .gray-title-set {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
@media screen and (max-width: 767px) {
  .index-page .gray-title-set {
    gap: 8px;
  }
}
.index-page .gray-label {
  margin: 0;
  color: #374E71;
  text-align: center;
  font-size: 24px;
}
.index-page .gray-description {
  color: #64748B;
  text-align: center;
  font-size: 16px;
  line-height: 1.5;
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Hero
   * ------------------------------------------------------------ */
}
.index-page .hero {
  min-height: 730px;
  position: relative;
  padding: 130px 0 25px;
  overflow: hidden;
  background: url("../img/top/hero.webp") left center/cover no-repeat;
}
@media screen and (max-width: 767px) {
  .index-page .hero {
    background: url("../img/top/hero_sp.webp") top center/cover no-repeat;
    min-height: auto;
    padding: 92px 0 46px;
    height: clamp(700px, 100vh, 950px);
  }
}
.index-page .hero .inner {
  max-width: 1360px;
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  align-items: start;
}
@media screen and (max-width: 767px) {
  .index-page .hero .inner {
    height: 100%;
    flex-direction: column;
  }
}
.index-page .hero__switcher {
  position: relative;
  min-height: 38px;
  z-index: 3;
}
@media screen and (max-width: 767px) {
  .index-page .hero__switcher {
    min-height: 44px;
  }
}
.index-page .hero__switch {
  appearance: none;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: #1E293B;
  padding: 8px 16px;
  font-size: 14px;
  font-weight: 400;
  border-radius: 12px;
  border: 1px solid rgba(241, 245, 249, 0.5);
  background: rgba(255, 255, 255, 0.45);
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(4px);
  transition: filter 0.2s ease, box-shadow 0.2s ease;
  cursor: pointer;
}
.index-page .hero__switch:hover {
  filter: brightness(1.02);
  box-shadow: 0 14px 34px rgba(15, 32, 57, 0.2);
}
@media screen and (max-width: 767px) {
  .index-page .hero__switch {
    width: min(292px, 100vw - 24px);
    padding: 12px 16px;
    font-size: min(18px, 18 / 415 * 100vw);
    border-radius: 18px;
  }
}
.index-page .hero__switch-caret {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 1;
  transform-origin: center;
  transition: transform 0.2s ease;
}
@media screen and (max-width: 767px) {
  .index-page .hero__switch-caret {
    font-size: 14px;
  }
}
.index-page .hero__switch-menu {
  position: absolute;
  top: 100%;
  right: 0;
  width: 128px;
  margin: 0;
  padding: 14px 0;
  list-style: none;
  border-radius: 16px;
  background: #f8fafc;
  box-shadow: 0 12px 32px rgba(15, 23, 42, 0.18);
  overflow: hidden;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s linear 0.2s;
}
.index-page .hero__switch-menu-item + .index-page .hero__switch-menu-item {
  margin-top: 6px;
}
.index-page .hero__switch-option {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  min-height: 0;
  padding: 4px 20px;
  color: #000;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.3;
  text-decoration: none;
  transition: background 0.2s ease;
}
.index-page .hero__switch-option:hover {
  background: #e2e8f0;
}
@media screen and (max-width: 767px) {
  .index-page .hero__switch-option {
    min-height: 0;
    padding: 6px 16px;
    font-size: min(18px, 18 / 415 * 100vw);
  }
}
.index-page .hero__switcher.is-open .hero__switch-menu {
  opacity: 1;
  visibility: visible;
  transform: translate(0, 0);
  transition: opacity 0.2s ease, transform 0.2s ease, visibility 0s;
}
.index-page .hero__switcher.is-open .hero__switch-caret {
  transform: rotate(180deg);
}
.index-page .hero__layout {
  max-width: 537px;
  width: 100%;
  margin-top: 16px;
  display: flex;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .index-page .hero__layout {
    margin-top: 0;
    display: block;
  }
}
.index-page .hero__panel {
  width: 100%;
  margin-inline: auto;
  padding: 24px 32px;
  border-radius: 20.223px;
  border-radius: 20.223px;
  background: rgba(255, 255, 255, 0.4);
  box-shadow: 0 33.706px 42.132px -8.426px rgba(0, 0, 0, 0.1), 0 13.482px 16.853px -10.112px rgba(0, 0, 0, 0.1);
  backdrop-filter: blur(6.7411546707px);
}
@media screen and (max-width: 767px) {
  .index-page .hero__panel {
    max-width: none;
    padding: 22px 18px 14px;
    border-radius: 18px;
  }
}
.index-page .hero__title {
  display: grid;
  color: #1E3A8A;
}
.index-page .hero__title-kicker {
  width: fit-content;
  color: #1E3A8A;
  font-size: min(27px, 27 / 1240 * 100vw);
  font-weight: 800;
  line-height: 136%;
  text-decoration-line: underline;
  text-decoration-style: solid;
  text-decoration-color: var(--pri_Yellow, #F1BD36);
  text-decoration-thickness: 12%;
  text-underline-offset: 22%;
  text-decoration-skip-ink: none;
}
@media screen and (max-width: 767px) {
  .index-page .hero__title-kicker {
    font-size: min(40px, 26 / 415 * 100vw);
    text-decoration-thickness: 8%;
  }
}
.index-page .hero__title-line {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  line-height: 1;
  margin-top: -10px;
}
@media screen and (max-width: 767px) {
  .index-page .hero__title-line {
    margin-top: 10px;
    gap: 0;
  }
}
.index-page .hero__title-main {
  font-size: min(95px, 95 / 1240 * 100vw);
  font-weight: 900;
  line-height: 1.2;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .index-page .hero__title-main {
    font-size: min(74px, 64 / 415 * 100vw);
  }
}
.index-page .hero__title-rest {
  font-size: min(53px, 53 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: -0.02em;
  display: inline-block;
  margin-left: -6px;
}
@media screen and (max-width: 767px) {
  .index-page .hero__title-rest {
    font-size: min(44px, 36 / 415 * 100vw);
    margin-left: -2px;
  }
}
.index-page .hero__lead {
  margin-top: -10px;
  color: #1E3A8A;
  font-size: 26.891px;
  font-weight: 800;
  line-height: 120%;
  letter-spacing: -0.538px;
}
@media screen and (max-width: 767px) {
  .index-page .hero__lead {
    margin-top: -4px;
    font-size: min(22px, 18 / 415 * 100vw);
  }
}
.index-page .hero__copy {
  margin-top: 12px;
  display: grid;
  gap: 2px;
  color: #1e3a8a;
  font-family: "Inter";
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 136%;
  letter-spacing: -0.16px;
}
@media screen and (max-width: 767px) {
  .index-page .hero__copy {
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.5;
  }
}
.index-page .hero__stats {
  margin-top: 24px;
  display: block;
  line-height: 0;
  width: calc(100% + 28px);
  margin-left: -14px;
}
@media screen and (max-width: 767px) {
  .index-page .hero__stats {
    margin-top: 10px;
    width: 100%;
    margin-left: 0;
  }
}
.index-page .hero__stats img {
  display: block;
  width: 100%;
  max-width: 604px;
  margin-inline: auto;
}
@media screen and (max-width: 767px) {
  .index-page .hero__stats img {
    max-width: 350px;
  }
}
.index-page .hero__actions {
  margin-top: 30px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  width: calc(100% + 28px);
  margin-left: -14px;
}
@media screen and (max-width: 767px) {
  .index-page .hero__actions {
    width: 100%;
    margin-left: 0;
    grid-template-columns: 1fr;
    gap: 30px;
  }
}
.index-page .hero__action {
  min-width: 0;
  display: grid;
  grid-template-rows: auto 1fr;
  justify-items: center;
}
.index-page .hero__action-badge {
  margin: 0;
  z-index: 2;
  padding: 10px 20px;
  line-height: 1;
  letter-spacing: -0.02em;
  white-space: nowrap;
  border-radius: 76.792px;
  background: #fff;
  color: #1E3A8A;
  text-align: center;
  font-size: 14px;
  margin-bottom: -14px;
}
@media screen and (max-width: 767px) {
  .index-page .hero__action-badge {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.index-page .hero__action-badge--accent {
  border-color: rgba(241, 189, 54, 0.92);
  background: #f1bd36;
  color: #5a3f03;
  box-shadow: 0 8px 16px rgba(181, 131, 26, 0.24);
}
.index-page .hero__cta {
  width: 100%;
  height: 70px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 0 20px;
  border-radius: 70px;
  font-size: 20px;
  font-weight: 700;
  box-shadow: 0 8px 16px rgba(39, 58, 96, 0.3);
  transition: transform 0.3s ease, box-shadow 0.3s ease;
  white-space: nowrap;
}
.index-page .hero__cta:hover {
  transform: translateY(-2px);
}
@media screen and (max-width: 767px) {
  .index-page .hero__cta {
    height: min(70px, 70 / 415 * 100vw);
    font-size: min(20px, 20 / 415 * 100vw);
    padding: 0 10px;
    width: min(100%, 321px);
  }
}
.index-page .hero__cta--primary {
  color: #fff;
  border: 2.233px solid #fff;
  background: #1E3A8A;
}
.index-page .hero__cta--secondary {
  color: #475569;
  border: 2px solid #FBC600;
  background: #fff;
}
.index-page .hero__cta-icon {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
.index-page .hero__cta-icon svg {
  display: block;
}
@media screen and (max-width: 767px) {
  .index-page .hero__cta-icon {
    transform: scale(0.9);
    transform-origin: center;
  }
}
.index-page .hero__download {
  margin-top: 18px;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  color: #1E3A8A;
  font-size: 13px;
  font-weight: 600;
  line-height: 1.6;
  text-decoration: none;
}
.index-page .hero__download-icon {
  flex: 0 0 10px;
  line-height: 0;
}
.index-page .hero__download-icon svg {
  display: block;
  width: 10px;
  height: 15px;
}
.index-page {
  /** ------------------------------------------------------------
     * SECTION: Hero Casestudy
     * ------------------------------------------------------------ */
}
.index-page .hero__casestudy {
  overflow: hidden;
  width: 100%;
}
.index-page .hero__casestudy-track {
  display: flex;
  width: max-content;
  line-height: 0;
  will-change: transform;
  will-change: transform;
  animation: c-marquee-ltr 80s linear infinite;
}
@media (prefers-reduced-motion: reduce) {
  .index-page .hero__casestudy-track {
    animation: none;
    transform: none;
  }
}
.index-page .hero__casestudy-track img {
  width: 4845px;
  flex: 0 0 4845px;
  height: auto;
  object-fit: contain;
}
@media screen and (max-width: 767px) {
  .index-page .hero__casestudy-track img {
    width: 4000px;
    flex: 0 0 4000px;
  }
}
.index-page .fv-news {
  padding-top: 20px;
}
.index-page .fv-news__list {
  display: grid;
  width: fit-content;
  margin: 0 auto;
}
.index-page .fv-news__link {
  display: grid;
  grid-template-columns: auto auto 1fr;
  grid-template-areas: "tag date title";
  align-items: center;
  column-gap: 24px;
  color: #000;
  transition: opacity 0.3s;
  padding: 16px 0;
  font-size: 16px;
}
@media screen and (max-width: 767px) {
  .index-page .fv-news__link {
    min-height: 64px;
    grid-template-columns: auto 1fr;
    grid-template-areas: "tag date" "title title";
    column-gap: 10px;
    row-gap: 6px;
    padding: 10px 0;
    font-size: 14px;
  }
}
.index-page .fv-news__link:hover {
  opacity: 0.72;
}
.index-page .fv-news__tag {
  grid-area: tag;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 1px 8px;
  border-radius: 8px;
  background: #EA580C;
  color: #fff;
  font-size: 12px;
  white-space: nowrap;
}
.index-page .fv-news__date {
  grid-area: date;
  white-space: nowrap;
}
.index-page .fv-news__title {
  grid-area: title;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
@media screen and (max-width: 767px) {
  .index-page .fv-news__title {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Problem & Solution
   * ------------------------------------------------------------ */
}
.index-page .problem {
  padding: 72px 0 88px;
}
@media screen and (max-width: 767px) {
  .index-page .problem {
    padding: 44px 0 56px;
  }
}
.index-page .problem .inner {
  max-width: 1312px;
}
.index-page .problem__overview {
  width: min(420px, 100%);
  margin: 0 auto;
  position: relative;
  padding-top: 14px;
}
@media screen and (max-width: 767px) {
  .index-page .problem__overview {
    padding-top: 0;
    width: min(350px, 100%);
  }
}
.index-page .problem__person {
  width: min(260px, 52vw);
  margin: 0 auto;
}
.index-page .problem__chips {
  margin: 0;
  padding: 0;
  list-style: none;
}
@media screen and (max-width: 767px) {
  .index-page .problem__chips {
    margin-bottom: 12px;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
}
.index-page .problem__chip {
  position: absolute;
  border-radius: 64px;
  background: #1E3A8A;
  color: #EBF6FF;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 140%;
  padding: 24px 32px 24px 24px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
}
.index-page .problem__chip:nth-child(1) {
  top: 0;
  left: 18%;
  transform: translateX(-50%);
}
.index-page .problem__chip:nth-child(2) {
  top: 0;
  right: 14%;
  transform: translateX(50%);
}
.index-page .problem__chip:nth-child(3) {
  top: 74%;
  left: -18%;
  transform: translateY(-50%);
}
.index-page .problem__chip:nth-child(4) {
  top: 74%;
  right: -15%;
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .index-page .problem__chip {
    position: static;
    transform: none;
    justify-content: center;
    min-height: 30px;
    width: 100%;
    transform: none !important;
    padding: 12px;
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.index-page .problem__chip-icon {
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .index-page .problem__chip-icon {
    width: 24px;
    height: 24px;
  }
}
.index-page .problem__chip-icon svg {
  width: 100%;
  height: 100%;
  display: block;
}
.index-page .problem__title {
  width: fit-content;
  margin: 48px auto 35px;
  padding-bottom: 8px;
  border-bottom: 3px solid #FBC600;
  color: #374E71;
  text-align: center;
  font-size: 36px;
  font-weight: 900;
}
@media screen and (max-width: 1200px) {
  .index-page .problem__title {
    font-size: 36px;
  }
}
@media screen and (max-width: 767px) {
  .index-page .problem__title {
    margin-top: 24px;
    font-size: min(24px, 24 / 415 * 100vw);
    padding-bottom: 6px;
  }
}
.index-page .problem__subcopy {
  margin-top: 42px;
  text-align: center;
  color: #475569;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .index-page .problem__subcopy {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.index-page .problem__lead {
  text-align: center;
  color: #475569;
  font-size: 36px;
  font-weight: 700;
  line-height: 140%;
}
@media screen and (max-width: 1200px) {
  .index-page .problem__lead {
    font-size: 38px;
  }
}
@media screen and (max-width: 767px) {
  .index-page .problem__lead {
    font-size: min(24px, 24 / 415 * 100vw);
    margin-top: 8px;
  }
}
.index-page .problem__grid {
  margin-top: 28px;
  display: grid;
  grid-template-columns: 290fr 290fr 290fr 320fr;
  gap: 40px;
}
@media screen and (max-width: 1200px) {
  .index-page .problem__grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media screen and (max-width: 767px) {
  .index-page .problem__grid {
    max-width: 320px;
    margin-inline: auto;
    margin-top: 22px;
    grid-template-columns: 1fr;
    gap: 60px;
  }
}
.index-page .problem__column {
  display: grid;
  grid-template-rows: 1fr auto 1fr;
  gap: 10px;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
@media screen and (max-width: 767px) {
  .index-page .problem__column {
    gap: 0;
  }
}
.index-page .problem__column.is-visible {
  opacity: 1;
  transform: translateY(0);
}
.index-page .problem__arrow {
  text-align: center;
  color: #333;
  font-size: 28px;
  line-height: 1;
}
.index-page .problem-card,
.index-page .solution-card {
  border: 1px solid #E2E8F0;
  background: #fff;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
}
.index-page .problem-card.is-accent,
.index-page .solution-card.is-accent {
  border-color: #FFF8DD;
  background: #FFF8DD;
  border-radius: 16px;
}
@media screen and (max-width: 767px) {
  .index-page .problem-card,
  .index-page .solution-card {
    min-height: auto;
    padding: 12px;
  }
}
.index-page .problem-card__label {
  text-align: center;
  color: #1E3A8A;
  font-family: "Oswald", sans-serif;
  font-size: 20px;
  font-weight: 700;
  line-height: 2;
  padding-bottom: 8px;
  border-bottom: 1px solid #FBC600;
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .index-page .problem-card__label {
    font-size: min(20px, 20 / 415 * 100vw);
  }
}
.index-page .problem-card__icon {
  width: 140px;
  margin: 0 auto 10px;
}
.index-page .problem-card__text {
  color: #334155;
  font-size: 20px;
  line-height: 140%;
}
@media screen and (max-width: 767px) {
  .index-page .problem-card__text {
    font-size: min(18px, 18 / 415 * 100vw);
  }
}
.index-page .solution-card {
  padding-top: 0;
}
.index-page .solution-card.is-accent .solution-card__title {
  color: #1E3A8A;
  background: #fff;
  font-size: 24px;
}
@media screen and (max-width: 767px) {
  .index-page .solution-card.is-accent .solution-card__title {
    font-size: min(22px, 22 / 415 * 100vw);
  }
}
.index-page .solution-card.is-accent .solution-card__title * {
  color: inherit !important;
  -webkit-text-fill-color: currentColor;
}
.index-page .solution-card.is-accent .solution-card__title .solution-card__title-line:nth-child(2) {
  color: #FBC600 !important;
  -webkit-text-fill-color: currentColor;
}
.index-page .solution-card__label {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 8px;
  text-align: center;
  color: #1E3A8A;
  font-family: "Oswald", sans-serif;
  font-size: 24px;
  font-weight: 700;
  line-height: 2;
  padding-bottom: 0px;
  border-bottom: 1px solid #FBC600;
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .index-page .solution-card__label {
    font-size: min(22px, 22 / 415 * 100vw);
  }
}
.index-page .solution-card__label-number {
  font-size: 32px;
  line-height: 40px;
}
@media screen and (max-width: 767px) {
  .index-page .solution-card__label-number {
    font-size: min(28px, 28 / 415 * 100vw);
  }
}
.index-page .solution-card__title {
  margin: 12px auto 0;
  min-height: 62px;
  width: 100%;
  border-radius: 32px;
  background: #FFF8DD;
  color: #1E3A8A;
  font-size: 20px;
  font-weight: 700;
  line-height: 140%;
  text-align: center;
  padding: 16px 0;
}
@media screen and (max-width: 767px) {
  .index-page .solution-card__title {
    font-size: min(18px, 18 / 415 * 100vw);
    min-height: 54px;
  }
}
.index-page .solution-card__title-line {
  display: block;
}
.index-page .solution-card__text {
  margin-top: 16px;
  color: #475569;
  font-size: 12px;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .index-page .solution-card__text {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.index-page .solution-card__link {
  margin-top: auto;
  min-height: 32px;
  border-radius: 32px;
  background: var(--classicBlue, #1E3A8A);
  box-shadow: 0 2px 4px 0 rgba(0, 0, 0, 0.25);
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.4;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
  padding: 0 14px;
  transition: opacity 0.3s;
}
.index-page .solution-card__link:hover {
  opacity: 0.85;
}
@media screen and (max-width: 767px) {
  .index-page .solution-card__link {
    min-height: 36px;
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.index-page .solution-card__link-label {
  line-height: 1;
}
.index-page .solution-card__link-icon {
  width: 6px;
  height: 9px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
.index-page .solution-card__link-icon svg {
  width: 100%;
  height: auto;
  display: block;
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Dashboard
   * ------------------------------------------------------------ */
}
.index-page .dashboard {
  padding: 50px 0 100px;
  background: #EBF6FF;
}
@media screen and (max-width: 767px) {
  .index-page .dashboard {
    padding: 48px 0 56px;
  }
}
.index-page .dashboard .inner {
  max-width: 1200px;
}
.index-page .dashboard__en {
  color: rgba(30, 58, 138, 0.1);
  text-align: center;
  font-size: 128px;
  font-style: italic;
  font-weight: 900;
  line-height: 1;
  margin-bottom: -35px;
}
@media screen and (max-width: 767px) {
  .index-page .dashboard__en {
    font-size: min(60px, 60 / 415 * 100vw);
    margin-bottom: -20px;
  }
}
.index-page .dashboard__title {
  color: #1E3A8A;
  text-align: center;
  font-size: 36px;
  font-weight: 900;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .index-page .dashboard__title {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.index-page .dashboard__body {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .index-page .dashboard__body {
    grid-template-columns: 1fr;
    gap: 32px;
    margin-top: 28px;
  }
}
.index-page .dashboard__lead {
  color: #1E3A8A;
  font-size: 20px;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .index-page .dashboard__lead {
    font-size: min(18px, 18 / 415 * 100vw);
  }
}
.index-page .dashboard__features {
  margin-top: 24px;
  list-style: none;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px 32px;
}
@media screen and (max-width: 767px) {
  .index-page .dashboard__features {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}
.index-page .dashboard__feature {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.index-page .dashboard__feature-icon {
  flex-shrink: 0;
}
.index-page .dashboard__feature-body {
  display: flex;
  flex-direction: column;
}
.index-page .dashboard__feature-title {
  color: #1E3A8A;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}
.index-page .dashboard__feature-text {
  color: #1E3A8A;
  font-size: 12px;
  line-height: 1.34;
}
.index-page .dashboard__media img {
  border-radius: 8px;
  background: #1E293B;
  box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 8px 10px -6px rgba(0, 0, 0, 0.1);
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Reasons
   * ------------------------------------------------------------ */
}
.index-page .reasons {
  padding: 80px 0 96px;
  background: #f5f6f8;
}
@media screen and (max-width: 767px) {
  .index-page .reasons {
    padding: 48px 0 56px;
  }
}
.index-page .reasons .inner {
  max-width: 1200px;
}
.index-page .reasons__lead {
  margin-top: 20px;
}
.index-page .reasons__grid {
  margin-top: 48px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
}
@media screen and (max-width: 767px) {
  .index-page .reasons__grid {
    grid-template-columns: 1fr;
    gap: 32px;
    margin-top: 32px;
  }
}
.index-page .reasons__card {
  text-align: center;
  opacity: 0;
  transform: translateY(30px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.index-page .reasons__card.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media (hover: hover) and (pointer: fine) {
  .index-page .reasons__card:hover .reasons__card-media img {
    transform: scale(1.08);
  }
}
.index-page .reasons__card:focus-within .reasons__card-media img {
  transform: scale(1.08);
}
.index-page .reasons__card-media {
  position: relative;
  overflow: hidden;
  aspect-ratio: 363/358;
  border-radius: 16px;
  background: linear-gradient(0deg, rgba(43, 47, 60, 0.2) 0%, rgba(43, 47, 60, 0.2) 100%), url(<path-to-image>) lightgray -116.855px -18.315px/164.366% 111.122% no-repeat;
  box-shadow: 0 0 9px 0 rgba(0, 0, 0, 0.38);
}
.index-page .reasons__card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transform: scale(1);
  transform-origin: center;
  transition: transform 0.45s ease;
}
@media (prefers-reduced-motion: reduce) {
  .index-page .reasons__card-media img {
    transition: none;
  }
}
.index-page .reasons__card-title {
  margin-top: 20px;
  font-size: 28px;
  font-weight: 900;
  line-height: 1.5;
  color: #1f1f1f;
}
.index-page .reasons__card-title strong {
  color: #1A85CA;
}
@media screen and (max-width: 767px) {
  .index-page .reasons__card-title {
    font-size: 18px;
  }
}
.index-page .reasons__card-text {
  margin-top: 12px;
  font-size: 14px;
  line-height: 1.7;
  color: #475569;
  text-align: left;
}
.index-page .reasons__card-list {
  margin-top: 8px;
  padding-left: 2.2em;
  font-size: 14px;
  line-height: 1.7;
  color: #475569;
  text-align: left;
}
.index-page .reasons__card-list li {
  list-style: disc;
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Case Study
   * ------------------------------------------------------------ */
}
.index-page .case-study {
  padding: 96px 0;
}
@media screen and (max-width: 767px) {
  .index-page .case-study {
    padding: 64px 0;
  }
}
.index-page .case-study .inner {
  max-width: 1200px;
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Flow
   * ------------------------------------------------------------ */
}
.index-page .flow {
  padding: 96px 0;
  background: #F8FAFC;
}
@media screen and (max-width: 767px) {
  .index-page .flow {
    padding: min(60px, 60 / 415 * 100vw) 0;
  }
}
.index-page .flow .inner {
  max-width: 1248px;
}
.index-page .flow__lead {
  margin-top: 16px;
}
.index-page .flow {
  /* ---- Grid ---- */
}
.index-page .flow__grid {
  margin-top: 40px;
  display: grid;
  grid-template-columns: 227fr 12px 227fr 12px 227fr 12px 227fr 12px 227fr;
  gap: 16px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .index-page .flow__grid {
    grid-template-columns: 1fr;
    gap: min(20px, 20 / 415 * 100vw);
    margin-top: min(28px, 28 / 415 * 100vw);
  }
}
.index-page .flow__grid .flow__step.is-first {
  box-shadow: 0 20px 25px -5px #DBEAFE, 0 8px 10px -6px #DBEAFE;
  transform: scale(1.1);
  border-color: transparent;
}
.index-page .flow__grid .flow__step.is-first .flow__step-note.is-badge {
  color: #2563EB;
}
@media screen and (max-width: 767px) {
  .index-page .flow__grid .flow__step.is-first {
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    transform: none;
    border-color: #E2E8F0;
  }
  .index-page .flow__grid .flow__step.is-first .flow__step-note.is-badge {
    color: #64748B;
  }
}
.index-page .flow__grid:has(.flow__step:not(.is-first):hover) .flow__step.is-first, .index-page .flow__grid:has(.flow__step:not(.is-first):focus-within) .flow__step.is-first {
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  transform: none;
  border-color: #E2E8F0;
}
.index-page .flow__grid:has(.flow__step:not(.is-first):hover) .flow__step.is-first .flow__step-note.is-badge, .index-page .flow__grid:has(.flow__step:not(.is-first):focus-within) .flow__step.is-first .flow__step-note.is-badge {
  color: #64748B;
}
.index-page .flow {
  /* ---- Arrow ---- */
}
.index-page .flow__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
}
.index-page .flow__arrow svg {
  display: block;
}
@media screen and (max-width: 767px) {
  .index-page .flow__arrow {
    display: none;
  }
}
.index-page .flow {
  /* ---- Step card ---- */
}
.index-page .flow__step {
  border-radius: 16px;
  padding: 40px 14px;
  text-align: center;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  min-height: 375px;
  border-radius: 12px;
  border: 1px solid #E2E8F0;
  background: #FFF;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .index-page .flow__step {
    min-height: auto;
    padding: min(30px, 30 / 415 * 100vw) min(14px, 14 / 415 * 100vw);
  }
}
.index-page .flow__step:hover, .index-page .flow__step:focus-within {
  box-shadow: 0 20px 25px -5px #DBEAFE, 0 8px 10px -6px #DBEAFE;
  transform: scale(1.1);
  border-color: transparent;
}
.index-page .flow__step:hover .flow__step-note.is-badge, .index-page .flow__step:focus-within .flow__step-note.is-badge {
  color: #2563EB;
}
@media screen and (max-width: 767px) {
  .index-page .flow__step:hover, .index-page .flow__step:focus-within {
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    transform: none;
    border-color: #E2E8F0;
  }
  .index-page .flow__step:hover .flow__step-note.is-badge, .index-page .flow__step:focus-within .flow__step-note.is-badge {
    color: #64748B;
  }
}
.index-page .flow__step-badge {
  background: #2563EB;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 3px 14px;
  border-radius: 999px;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .index-page .flow__step-badge {
    font-size: min(11px, 11 / 415 * 100vw);
  }
}
.index-page .flow__step-no {
  color: #2563EB;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -1.2px;
}
@media screen and (max-width: 767px) {
  .index-page .flow__step-no {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.index-page .flow__step-icon {
  width: 72px;
  height: 72px;
}
.index-page .flow__step-icon img {
  width: 100%;
  height: 100%;
}
.index-page .flow__step-title {
  color: #1E293B;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .index-page .flow__step-title {
    font-size: min(18px, 18 / 415 * 100vw);
  }
}
.index-page .flow__step-text {
  font-size: 12px;
  line-height: 163%;
  color: #475569;
  text-align: center;
}
.index-page .flow__step-text strong {
  color: #2563EB;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .index-page .flow__step-text {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.index-page .flow__step-note {
  margin-top: auto;
  color: #94A3B8;
  font-size: 10px;
  padding: 4px 8px;
}
.index-page .flow__step-note.is-badge {
  color: #64748B;
  border-radius: 4px;
  background: #F1F5F9;
  font-family: Inter;
  font-size: 10.5px;
  font-style: normal;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .index-page .flow__step-note.is-badge {
    font-size: min(10.5px, 10.5 / 415 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .index-page .flow__step-note {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.index-page .flow {
  /* ---- CTA ---- */
}
.index-page .flow__cta {
  margin-top: 48px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .index-page .flow__cta {
    margin-top: min(32px, 32 / 415 * 100vw);
  }
}
.index-page .flow__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 282px;
  min-height: 60px;
  box-sizing: border-box;
  gap: 16px;
  background: #1E3A8A;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  color: #fff;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 28px;
  padding: 16px 32px;
  border-radius: 64px;
  transition: opacity 0.3s;
}
.index-page .flow__cta-btn:hover {
  opacity: 0.85;
}
@media screen and (max-width: 767px) {
  .index-page .flow__cta-btn {
    min-width: auto;
    min-height: min(56px, 56 / 415 * 100vw);
    font-size: min(18px, 18 / 415 * 100vw);
    line-height: min(28px, 28 / 415 * 100vw);
    padding: min(14px, 14 / 415 * 100vw) min(24px, 24 / 415 * 100vw);
  }
}
.index-page .flow__cta-note {
  margin-top: 12px;
  color: #64748B;
  text-align: center;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .index-page .flow__cta-note {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Case Studies
   * ------------------------------------------------------------ */
}
.index-page .case-studies {
  padding: 80px 0 96px;
}
@media screen and (max-width: 767px) {
  .index-page .case-studies {
    padding: 48px 0 56px;
  }
}
.index-page .case-studies .inner {
  max-width: 1200px;
}
.index-page .case-studies__lead {
  margin-top: 16px;
}
.index-page .case-studies {
  /* ---- Sub header (お客様の声) ---- */
}
.index-page .case-studies__sub-header {
  margin-top: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  padding-bottom: 12px;
  border-bottom: 2px solid #FFE585;
}
@media screen and (max-width: 767px) {
  .index-page .case-studies__sub-header {
    margin-top: 28px;
  }
}
.index-page .case-studies__sub-title-wrap {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-direction: column;
}
.index-page .case-studies__sub-icon {
  width: 73px;
  height: 57px;
}
.index-page .case-studies__sub-title {
  font-size: 18px;
  font-weight: 700;
  color: #1f1f1f;
}
@media screen and (max-width: 767px) {
  .index-page .case-studies__sub-title {
    font-size: 16px;
  }
}
.index-page .case-studies__sub-link {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 14px;
  font-weight: 700;
  color: #2563EB;
  position: absolute;
  right: 0;
  bottom: 12px;
  transition: opacity 0.3s;
}
.index-page .case-studies__sub-link:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .index-page .case-studies__sub-link {
    font-size: 12px;
    bottom: -25px;
  }
}
.index-page .case-studies {
  /* ---- Card grid ---- */
}
.index-page .case-studies__grid {
  margin-top: 32px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
@media screen and (max-width: 767px) {
  .index-page .case-studies__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.index-page .case-studies .js-case-studies-card.is-hidden {
  display: none !important;
}
.index-page .case-studies__pagination {
  margin-top: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
@media screen and (max-width: 767px) {
  .index-page .case-studies__pagination {
    margin-top: min(24px, 24 / 415 * 100vw);
    gap: min(6px, 6 / 415 * 100vw);
  }
}
.index-page .case-studies__page-list {
  display: flex;
  align-items: center;
  gap: 6px;
}
.index-page .case-studies__page-ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  font-size: 10px;
  font-weight: 700;
  color: #77B1E1;
}
.index-page .case-studies__page-arrow, .index-page .case-studies__page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  padding: 0;
  color: #2563EB;
  font-weight: 700;
  cursor: pointer;
}
.index-page .case-studies__page-arrow {
  width: 18px;
  height: 18px;
  border-radius: 999px;
}
.index-page .case-studies__page-arrow:disabled {
  opacity: 0.45;
  cursor: default;
}
.index-page .case-studies__page-btn {
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  font-size: 10px;
  line-height: 1;
  color: #77B1E1;
}
.index-page .case-studies__page-btn.is-active {
  background: #CFE4FA;
  color: #1F2937;
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: Client
   * ------------------------------------------------------------ */
}
.index-page .client {
  padding-top: 40px;
}
.index-page .client__header {
  border-bottom: 2px solid #FFE585;
  padding-bottom: 16px;
}
.index-page .client__header-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
.index-page .client__header-title-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-direction: column;
}
.index-page .client__header-icon {
  width: 40px;
  height: 40px;
}
@media screen and (max-width: 767px) {
  .index-page .client__header-icon {
    width: 32px;
    height: 32px;
  }
}
.index-page .client__header-title {
  font-size: 20px;
  font-weight: 700;
  color: #1f1f1f;
  letter-spacing: 0.05em;
}
@media screen and (max-width: 767px) {
  .index-page .client__header-title {
    font-size: 16px;
  }
}
.index-page .client__header-link {
  display: flex;
  align-items: center;
  gap: 4px;
  color: #2563EB;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4;
  position: absolute;
  right: 0;
  bottom: 0;
  transition: opacity 0.3s;
}
.index-page .client__header-link:hover {
  opacity: 0.7;
}
@media screen and (max-width: 767px) {
  .index-page .client__header-link {
    font-size: 12px;
    bottom: -40px;
  }
}
.index-page .client__logos {
  padding-top: 50px;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .index-page .client__logos {
    padding-top: 30px;
  }
}
.index-page .client__logos-row {
  overflow: hidden;
  width: 100%;
  height: 65px;
}
.index-page .client__logos-track {
  display: flex;
  width: max-content;
  height: 100%;
}
.index-page .client__logos-track--ltr {
  will-change: transform;
  animation: c-marquee-ltr 80s linear infinite;
}
@media (prefers-reduced-motion: reduce) {
  .index-page .client__logos-track--ltr {
    animation: none;
    transform: none;
  }
}
.index-page .client__logos-track--rtl {
  will-change: transform;
  animation: c-marquee-rtl 80s linear infinite;
}
@media (prefers-reduced-motion: reduce) {
  .index-page .client__logos-track--rtl {
    animation: none;
    transform: none;
  }
}
.index-page .client__logos-track img {
  width: auto;
  flex: 0 0 auto;
  max-width: none;
  height: 100%;
  display: block;
  object-fit: contain;
}
.index-page .client .client__logos-row:nth-child(3) .client__logos-track {
  animation-duration: 30s;
}
.index-page {
  /** ------------------------------------------------------------
   * SECTION: News & Column
   * ------------------------------------------------------------ */
}
.index-page .news-column {
  padding: 80px 0 96px;
  background: #f5f6f8;
}
@media screen and (max-width: 767px) {
  .index-page .news-column {
    padding: 48px 0 56px;
  }
}
.index-page .news-column .inner {
  max-width: 1200px;
}
.index-page .news-column__lead {
  margin-top: 16px;
}
.index-page .news-column {
  /* ---- Card grid ---- */
}
.index-page .news-column__grid {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}
@media screen and (max-width: 767px) {
  .index-page .news-column__grid {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 28px;
  }
}
.index-page .news-column .js-news-column-card.is-hidden {
  display: none !important;
}
.index-page .news-column {
  /* ---- Badge (TOP page only) ---- */
}
.index-page .news-column__badge {
  position: absolute;
  top: 10px;
  left: 10px;
  z-index: 1;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 9999px;
}
.index-page .news-column__badge.is-news {
  background: #2563EB;
}
.index-page .news-column__badge.is-column {
  background: #F97316;
}
.index-page .news-column {
  /* ---- CTA ---- */
}
.index-page .news-column__cta {
  margin-top: 40px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .index-page .news-column__cta {
    margin-top: 28px;
  }
}
.index-page .news-column__pagination {
  margin-top: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
@media screen and (max-width: 767px) {
  .index-page .news-column__pagination {
    margin-top: min(24px, 24 / 415 * 100vw);
    gap: min(6px, 6 / 415 * 100vw);
  }
}
.index-page .news-column__page-list {
  display: flex;
  align-items: center;
  gap: 6px;
}
.index-page .news-column__page-ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  font-size: 10px;
  font-weight: 700;
  color: #77B1E1;
}
.index-page .news-column__page-arrow, .index-page .news-column__page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  padding: 0;
  color: #2563EB;
  font-weight: 700;
  cursor: pointer;
}
.index-page .news-column__page-arrow {
  width: 18px;
  height: 18px;
  border-radius: 999px;
}
.index-page .news-column__page-arrow:disabled {
  opacity: 0.45;
  cursor: default;
}
.index-page .news-column__page-btn {
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  font-size: 10px;
  line-height: 1;
  color: #77B1E1;
}
.index-page .news-column__page-btn.is-active {
  background: #CFE4FA;
  color: #1F2937;
}
.index-page .news-column__cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #1E3A8A;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  padding: 14px 36px;
  border-radius: 999px;
  transition: opacity 0.3s;
}
.index-page .news-column__cta-btn:hover {
  opacity: 0.85;
}
@media screen and (max-width: 767px) {
  .index-page .news-column__cta-btn {
    font-size: 14px;
    padding: 12px 28px;
  }
}

.archive-card {
  overflow: hidden;
  border-radius: 12px;
  border: 1px solid #e2e8f0;
  background: #fff;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.25s ease;
}
.archive-card.is-hidden {
  display: none;
}
.archive-card.is-hoverable:hover, .archive-card.is-hoverable:focus-within {
  border-color: #bfdbfe;
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.12);
  transform: translateY(-2px);
}
.archive-card__link {
  background: #F8FAFC;
  display: flex;
  flex-direction: column;
  height: 100%;
  color: inherit;
  text-decoration: none;
}
.archive-card.is-hoverable .archive-card__link:hover .archive-card__thumb img,
.archive-card.is-hoverable .archive-card__link:focus-visible .archive-card__thumb img {
  transform: scale(1.05);
}
.archive-card.is-hoverable .archive-card__link:hover .archive-card__title,
.archive-card.is-hoverable .archive-card__link:focus-visible .archive-card__title {
  color: #2563eb;
}
.archive-card.is-hoverable .archive-card__link:hover .archive-card__readmore-arrow,
.archive-card.is-hoverable .archive-card__link:focus-visible .archive-card__readmore-arrow {
  transform: translateX(2px);
}
.archive-card__thumb {
  position: relative;
  display: block;
  aspect-ratio: 398/195;
  background: #f0f5f8;
  overflow: hidden;
}
.archive-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  transition: transform 0.5s ease;
}
.archive-card__thumb--logo {
  background: #fff;
}
.archive-card__thumb-placeholder {
  display: block;
  width: 100%;
  height: 100%;
  background: #e1e6ef;
}
.archive-card__body {
  padding: 24px 24px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  flex: 1;
}
.archive-card__meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.archive-card__meta-label {
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.34;
}
.archive-card__date {
  overflow: hidden;
  color: #475569;
  text-overflow: ellipsis;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.62;
}
.archive-card__tag {
  display: inline-flex;
  align-items: center;
  padding: 4px 12px;
  border-radius: 48px;
  background: #1E3A8A;
  color: #FFF;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.34;
}
.archive-card__title {
  margin: 0;
  color: #1E293B;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.55;
  transition: color 0.2s ease;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.archive-card__excerpt {
  margin: 0;
  overflow: hidden;
  color: #475569;
  text-overflow: ellipsis;
  font-size: 14px;
  line-height: 1.62;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}
.archive-card__excerpt--full {
  display: none;
  overflow: visible;
  -webkit-line-clamp: unset;
  -webkit-box-orient: unset;
}
.archive-card__readmore {
  margin-top: auto;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  width: fit-content;
  color: #3b82f6;
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  opacity: 1;
  transform: translateY(0);
  transition: color 0.25s ease, transform 0.25s ease;
}
.archive-card__readmore-label--close {
  display: none;
}
.archive-card__readmore--toggle {
  margin-top: 0;
  margin-left: auto;
  border: none;
  background: transparent;
  padding: 0;
  cursor: pointer;
  font-size: 11px;
}
.archive-card__readmore-arrow {
  display: inline-block;
  transition: transform 0.2s ease;
}
.archive-card__expand {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.archive-card__expand-categories {
  display: none;
  flex-direction: column;
  gap: 6px;
}
.archive-card__expand-category-item {
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px;
}
.archive-card__expand-category-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #A7B5D4;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}
.archive-card__expand-category-value {
  min-width: 0;
  overflow: hidden;
  color: #1E293B;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  line-height: 1.45;
}
.archive-card.is-expanded .archive-card__excerpt--preview {
  display: none;
}
.archive-card.is-expanded .archive-card__excerpt--full {
  display: block;
}
.archive-card.is-expanded .archive-card__readmore-label--open {
  display: none;
}
.archive-card.is-expanded .archive-card__readmore-label--close {
  display: inline;
}
.archive-card.is-expanded .archive-card__expand-categories {
  display: flex;
}
.archive-card__action {
  margin-top: auto;
  width: 100%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 999px;
  background: #1E3A8A;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.34;
  text-decoration: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.archive-card__action:hover, .archive-card__action:focus-visible {
  opacity: 0.92;
  transform: translateY(-1px);
}
.archive-card__action svg {
  flex-shrink: 0;
}
.archive-card--voice .archive-card__thumb {
  aspect-ratio: 398/190;
}
.archive-card--voice .archive-card__logo {
  height: 92px;
  min-height: 92px;
  padding: 0 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-top: 1px solid #E8EEF7;
  border-bottom: 1px solid #E8EEF7;
}
.archive-card--voice .archive-card__logo img {
  width: 100%;
  height: 100%;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
  object-position: center;
}
.archive-card--voice .archive-card__body {
  padding: 16px 18px 14px;
  gap: 8px;
}
.archive-card--voice .archive-card__category-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.archive-card--voice .archive-card__category-item {
  margin: 0;
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: center;
  gap: 10px;
}
.archive-card--voice .archive-card__category-label {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  border-radius: 999px;
  background: #A7B5D4;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  line-height: 1;
  white-space: nowrap;
}
.archive-card--voice .archive-card__category-value {
  min-width: 0;
  overflow: hidden;
  color: #1E293B;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  line-height: 1.45;
}
.archive-card--voice .archive-card__excerpt {
  font-size: 11px;
  line-height: 1.5;
  -webkit-line-clamp: 1;
}
.archive-card--voice .archive-card__readmore {
  font-size: 11px;
}

.archive .content {
  max-width: 1000px;
  margin: 0 auto;
  box-sizing: content-box;
}
.archive .archive-news {
  padding: 48px 0 120px;
}
@media screen and (max-width: 767px) {
  .archive .archive-news {
    padding: 32px 0 80px;
  }
}
.archive .archive-news .inner {
  max-width: 1248px;
}
.archive .archive-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 48px;
  margin-bottom: 54px;
}
@media screen and (max-width: 767px) {
  .archive .archive-tabs {
    gap: 36px;
    padding-bottom: 12px;
    margin-bottom: 30px;
  }
}
.archive .archive-tabs__button {
  position: relative;
  background: transparent;
  border: 0;
  padding-bottom: 22px;
  color: rgba(30, 58, 138, 0.5);
  font-size: 36px;
  font-style: italic;
  font-weight: 900;
  cursor: pointer;
  opacity: 0.4;
}
@media screen and (max-width: 767px) {
  .archive .archive-tabs__button {
    font-size: 18px;
    padding-bottom: 10px;
  }
}
.archive .archive-tabs__button::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background: #fbc600;
  transition: opacity 0.2s ease;
}
.archive .archive-tabs__button.is-active {
  opacity: 1;
}
.archive .archive-tabs__button.is-active::after {
  opacity: 1;
}
.archive .archive-tabs__panels {
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .archive .archive-tabs__panels {
    margin-top: 24px;
  }
}
.archive .archive-filters {
  display: grid;
  gap: 20px;
}
.archive .archive-filters__group {
  display: grid;
  grid-template-columns: 130px 1fr;
  align-items: baseline;
}
@media screen and (max-width: 767px) {
  .archive .archive-filters__group {
    grid-template-columns: 1fr;
    gap: 8px;
  }
}
.archive .archive-filters__group.is-hidden {
  display: none;
}
.archive .archive-filters__label {
  color: #000;
  font-size: 16px;
  font-weight: 700;
}
.archive .archive-filters__label--category.is-hidden {
  display: none;
}
.archive .archive-filters__list {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
.archive .archive-filters__category-group {
  display: none;
  flex-wrap: wrap;
  gap: 10px;
}
.archive .archive-filters__category-group.is-active {
  display: flex;
}
.archive .archive-filters__submit {
  display: block;
  margin: 0 auto;
  width: auto;
  border: none;
  padding: 9px 24px;
  color: #fff;
  border-radius: 128px;
  background: #1E3A8A;
  box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
  font-size: 18px;
  font-weight: 700;
  line-height: 1.556;
  cursor: pointer;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.archive .archive-filters__submit:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}
.archive .archive-filters .archive-filter {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px;
  border-radius: 999px;
  background: rgba(30, 58, 138, 0.4);
  border-color: rgba(30, 58, 138, 0.4);
  color: #fff;
  text-align: center;
  font-size: 9.743px;
  font-weight: 400;
  cursor: pointer;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease;
}
.archive .archive-filters .archive-filter.is-active, .archive .archive-filters .archive-filter:hover {
  border-radius: 64px;
  background: #1E3A8A;
  border-color: #1E3A8A;
}
.archive .archive-filters .archive-filter__icon {
  width: 16px;
  height: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.archive .archive-filters .archive-filter__icon svg {
  width: 100%;
  height: 100%;
  display: block;
}
.archive .archive-filters .archive-filter__arrow {
  width: 9px;
  height: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.archive .archive-filters .archive-filter__arrow svg {
  width: 100%;
  height: 100%;
  display: block;
}
.archive .archive-tab-panel {
  display: none;
}
.archive .archive-tab-panel.is-active {
  display: block;
}
.archive .archive-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px 24px;
}
@media screen and (max-width: 767px) {
  .archive .archive-grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.archive .archive-grid--external {
  align-items: stretch;
}
.archive .archive-grid--external .archive-card {
  height: 100%;
}
.archive .archive-grid--external .archive-card__link {
  height: 100%;
}
.archive .archive-grid--external .archive-card__body {
  flex: 1;
}
.archive .archive-grid--external .archive-card__action {
  margin-top: auto;
}
.archive .archive-pagination {
  margin-top: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 14px;
}
@media screen and (max-width: 767px) {
  .archive .archive-pagination {
    margin-top: 28px;
    gap: 10px;
  }
}
.archive .archive-pagination[hidden] {
  display: none;
}
.archive .archive-pagination__number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  padding: 0 8px;
  color: #3984C3;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease;
}
@media screen and (max-width: 767px) {
  .archive .archive-pagination__number {
    min-width: 28px;
    height: 28px;
    padding: 0 6px;
    font-size: 16px;
  }
}
.archive .archive-pagination__number:hover, .archive .archive-pagination__number:focus-visible, .archive .archive-pagination__number.is-active {
  background: #C1E2FE;
  color: #000;
}
.archive .archive-pagination__ellipsis {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 32px;
  height: 32px;
  color: #3984C3;
  font-size: 20px;
  font-weight: 700;
  line-height: 1;
  user-select: none;
}
@media screen and (max-width: 767px) {
  .archive .archive-pagination__ellipsis {
    min-width: 28px;
    height: 28px;
    font-size: 16px;
  }
}
.archive .archive-pagination__arrow {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  color: #7CB8E7;
  text-decoration: none;
  border-radius: 999px;
  transition: background-color 0.2s ease, color 0.2s ease;
}
@media screen and (max-width: 767px) {
  .archive .archive-pagination__arrow {
    width: 28px;
    height: 28px;
  }
}
.archive .archive-pagination__arrow:hover {
  background: rgba(193, 226, 254, 0.35);
  color: #3984C3;
}
.archive .archive-pagination__arrow:focus-visible {
  outline: 2px solid #3984C3;
  outline-offset: 2px;
}
.archive .archive-pagination__arrow.is-disabled {
  opacity: 0.4;
  pointer-events: none;
}
.archive {
  /* --- 汎用フィルターセクション（case, voice 等） --- */
}
.archive .archive-filterable {
  padding: 20px 0 50px;
}
.archive .archive-filterable .archive-grid {
  margin-top: 32px;
}
@media screen and (max-width: 767px) {
  .archive .archive-filterable .archive-grid {
    margin-top: 24px;
  }
}
.archive .archive-download-cta {
  margin-top: 32px;
  display: flex;
  justify-content: right;
}
@media screen and (max-width: 767px) {
  .archive .archive-download-cta {
    margin-top: 28px;
  }
}
.archive .archive-download-cta__button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 144px;
  padding: 10px 0;
  border-radius: 64px;
  background: #fff;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.08);
  color: #1e3a8a;
  text-align: center;
  font-family: "Inter", "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.333;
  text-decoration: none;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.archive .archive-download-cta__button:hover, .archive .archive-download-cta__button:focus-visible {
  opacity: 0.92;
  transform: translateY(-1px);
}
.archive .archive-download-cta__button svg {
  flex: 0 0 auto;
  display: block;
}
.archive {
  /* --- カードのロゴエリア（ACF logo フィールド） --- */
}
.archive .archive-card__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 16px 20px;
  background: #fff;
  min-height: 72px;
}
.archive .archive-card__logo img {
  max-width: 180px;
  max-height: 48px;
  width: auto;
  height: auto;
  object-fit: contain;
}
.archive .archive-default {
  padding: 48px 0 120px;
}
@media screen and (max-width: 767px) {
  .archive .archive-default {
    padding: 32px 0 80px;
  }
}
.archive .archive-default__list {
  display: grid;
  gap: 16px;
}
.archive .archive-default__link {
  color: #374e71;
  font-weight: 700;
}
.archive .archive-default__link:hover {
  text-decoration: underline;
}
.archive .archive-empty {
  text-align: center;
  color: #6d7a90;
}

/* ==============================================================================
# Single (詳細ページ共通)
============================================================================== */
.single {
  /* -------------------------------------------------------
   * 記事セクション
   * ----------------------------------------------------- */
}
.single .single-article {
  padding: 48px 0 80px;
}
@media screen and (max-width: 767px) {
  .single .single-article {
    padding: 32px 0 56px;
  }
}
.single .single-article .inner {
  max-width: 1024px;
}
.single .single-article .inner.is-voice {
  max-width: 1246px;
}
.single {
  /* -------------------------------------------------------
   * ヘッダー（タグ・タイトル・日付）
   * ----------------------------------------------------- */
}
.single .single-article__header {
  margin-bottom: 32px;
}
@media screen and (max-width: 767px) {
  .single .single-article__header {
    margin-bottom: 24px;
  }
}
.single .single-article__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 16px;
}
.single .single-article__tag {
  display: inline-flex;
  align-items: center;
  padding: 4px 14px;
  border-radius: 999px;
  background: #374e71;
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  letter-spacing: 0.02em;
  line-height: 1.5;
}
.single .single-article__title {
  color: #1E3A8A;
  font-size: 36px;
  font-weight: 900;
  margin-bottom: 64px;
}
@media screen and (max-width: 767px) {
  .single .single-article__title {
    font-size: 26px;
    margin-bottom: 40px;
  }
}
.single .single-article__meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
}
.single .single-article__date {
  display: inline-block;
  margin-bottom: 10px;
  color: #94A3B8;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.34;
}
.single .single-article__updated {
  font-size: 13px;
  color: #94a3b8;
}
.single {
  /* -------------------------------------------------------
   * 一覧カード風の概要ブロック
   * ----------------------------------------------------- */
}
.single .single-summary-card {
  display: grid;
  grid-template-columns: minmax(0, 1.6fr) minmax(0, 1fr);
  margin-bottom: 40px;
  border-radius: 12px;
  border: 1px solid #d6dde8;
  overflow: hidden;
  background: #f8fafc;
}
@media screen and (max-width: 767px) {
  .single .single-summary-card {
    grid-template-columns: 1fr;
    margin-bottom: 28px;
    border-radius: 8px;
  }
}
.single .single-summary-card__media {
  min-height: 340px;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .single .single-summary-card__media {
    min-height: 220px;
  }
}
.single .single-summary-card__media img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}
.single .single-summary-card__media.is-contain img {
  object-fit: contain;
  padding: 28px 34px;
}
@media screen and (max-width: 767px) {
  .single .single-summary-card__media.is-contain img {
    padding: 20px;
  }
}
.single .single-summary-card__body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 26px 26px 30px;
  background: #f1f5f9;
}
@media screen and (max-width: 767px) {
  .single .single-summary-card__body {
    gap: 12px;
    padding: 20px 18px 22px;
  }
}
.single .single-summary-card__badges {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.single .single-summary-card__badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  border-radius: 999px;
  background: #94a3b8;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.2;
}
.single .single-summary-card__badge.is-primary {
  background: #22c55e;
}
.single .single-summary-card__meta {
  margin: 0;
  color: #475569;
  font-size: 13px;
  line-height: 1.7;
}
.single .single-summary-card__title {
  margin: 0;
  color: #1e293b;
  font-size: 46px;
  font-weight: 900;
  line-height: 1.2;
}
@media screen and (max-width: 767px) {
  .single .single-summary-card__title {
    font-size: 30px;
  }
}
.single .single-summary-card__excerpt {
  margin: 0;
  color: #475569;
  font-size: 15px;
  line-height: 1.8;
}
.single {
  /* -------------------------------------------------------
   * アイキャッチ
   * ----------------------------------------------------- */
}
.single .single-article__thumbnail {
  margin-bottom: 32px;
  border-radius: 12px;
  overflow: hidden;
}
@media screen and (max-width: 767px) {
  .single .single-article__thumbnail {
    margin-bottom: 24px;
  }
}
.single .single-article__thumbnail img {
  max-width: 100%;
  width: auto;
  height: auto;
  margin: 0 auto;
  display: block;
  object-fit: contain;
}
.single .single-article__content.is-voice {
  max-width: 100%;
}
.single .single-article .inner.is-voice .single-article__header {
  max-width: 1024px;
  margin-left: auto;
  margin-right: auto;
}
.single .single-article .inner.is-voice .single-article__header .single-article__title {
  text-align: center;
}
.single .single-voice {
  max-width: 100%;
}
.single .single-voice__hero {
  display: grid;
  grid-template-columns: 800px minmax(0, 1fr);
  height: 400px;
  margin-bottom: 56px;
  border-radius: 12px;
  border: 1px solid #d6dde8;
  overflow: hidden;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .single .single-voice__hero {
    grid-template-columns: 1fr;
    height: auto;
    margin-bottom: 40px;
    border-radius: 8px;
  }
}
.single .single-article__content.is-voice .single-voice__hero-media {
  height: 400px;
}
.single .single-article__content.is-voice .single-voice__hero-media img {
  width: 100%;
  height: 100%;
  margin: 0;
  border-radius: 0;
  object-fit: cover;
}
.single .single-article__content.is-voice .single-voice__hero-media.is-contain img {
  object-fit: contain;
  padding: 28px 36px;
}
@media screen and (max-width: 767px) {
  .single .single-article__content.is-voice .single-voice__hero-media.is-contain img {
    padding: 20px;
  }
}
.single .single-voice__hero-side {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 20px;
  padding: 26px 22px;
  background: #f1f5f9;
}
@media screen and (max-width: 767px) {
  .single .single-voice__hero-side {
    gap: 16px;
    padding: 20px 16px;
  }
}
.single .single-voice__hero-side .single-article__site-link {
  margin: 0;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .single .single-voice__hero-side .single-article__site-link {
    text-align: center;
  }
}
.single .single-voice__meta-list {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.single .single-voice__meta-item {
  display: grid;
  grid-template-columns: 116px minmax(0, 1fr);
  align-items: center;
  gap: 10px;
}
.single .single-voice__meta-label {
  margin: 0;
  display: inline-flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  padding: 5px 12px;
  border-radius: 999px;
  background: #a7b3d1;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
  white-space: nowrap;
}
.single .single-voice__meta-value {
  margin: 0;
  color: #334155;
  font-size: 13px;
  line-height: 1.7;
}
.single .single-voice__section {
  max-width: 1024px;
  margin: 0 auto 56px;
}
@media screen and (max-width: 767px) {
  .single .single-voice__section {
    margin-bottom: 40px;
  }
}
.single .single-voice__section:last-child {
  margin-bottom: 0;
}
.single .single-voice__section h2 {
  margin-top: 0;
}
.single .single-voice__section.is-interview {
  max-width: 1024px;
}
.single .single-voice__interview-grid {
  display: grid;
  grid-template-columns: minmax(0, 300px) minmax(0, 1fr);
  gap: 24px;
  align-items: start;
}
@media screen and (max-width: 767px) {
  .single .single-voice__interview-grid {
    grid-template-columns: 1fr;
    gap: 18px;
  }
}
.single .single-article__content.is-voice .single-voice__interview-media img,
.single .single-article__content.is-voice .single-voice__interview-media figure {
  margin: 0;
}
.single .single-voice__interview-body > *:first-child {
  margin-top: 0;
}
.single .single-back-link {
  margin: 56px 0 0;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .single .single-back-link {
    margin-top: 40px;
  }
}
.single .single-article__content.is-voice .single-back-link {
  max-width: 1024px;
  margin-left: auto;
  margin-right: auto;
}
.single {
  /* -------------------------------------------------------
   * 本文エリア (the_content / WYSIWYG)
   * ----------------------------------------------------- */
}
.single .single-article__content {
  color: #475569;
  font-size: 16px;
  font-weight: 400;
  word-break: break-word;
  overflow-wrap: break-word;
}
@media screen and (max-width: 767px) {
  .single .single-article__content {
    font-size: 15px;
    line-height: 1.8;
  }
}
.single .single-article__content {
  /* ---- 見出し ---- */
}
.single .single-article__content h2 {
  margin: 56px 0 20px;
  color: #1E3A8A;
  font-size: 32px;
  font-weight: 700;
  line-height: 120%;
  padding-bottom: 16px;
  border-bottom: 1px solid #FBC600;
}
@media screen and (max-width: 767px) {
  .single .single-article__content h2 {
    margin: 40px 0 16px;
    font-size: 24px;
  }
}
.single .single-article__content h3 {
  margin: 40px 0 16px;
  color: #3B82F6;
  font-size: 24px;
  font-weight: 700;
  line-height: 120%;
}
@media screen and (max-width: 767px) {
  .single .single-article__content h3 {
    margin: 32px 0 12px;
    font-size: 20px;
  }
}
.single .single-article__content h4 {
  margin: 32px 0 12px;
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .single .single-article__content h4 {
    margin: 24px 0 10px;
    font-size: 18px;
  }
}
.single .single-article__content {
  /* ---- 段落 ---- */
}
.single .single-article__content p {
  margin: 0 0 1.6em;
  color: #475569;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.6;
}
.single .single-article__content {
  /* ---- リンク ---- */
}
.single .single-article__content a {
  color: #3B82F6;
  text-decoration: underline;
  transition: all 0.2s ease;
}
.single .single-article__content a:hover {
  opacity: 0.8;
}
.single .single-article__content .single-article__site-link {
  margin-bottom: 1.6em;
  text-align: center;
}
.single .single-article__content .single-article__btn,
.single .single-article__content .wp-block-button .wp-block-button__link,
.single .single-article__content a.wp-block-button__link {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  max-width: 320px;
  width: 100%;
  height: 56px;
  border-radius: 32px;
  border: 0;
  background: var(--classicBlue, #1e3a8a);
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  color: #fff;
  text-decoration: none;
  font-weight: 700;
  font-size: 18px;
  line-height: 1;
  transition: all 0.2s ease;
}
.single .single-article__content .single-article__btn::after,
.single .single-article__content .wp-block-button .wp-block-button__link::after,
.single .single-article__content a.wp-block-button__link::after {
  content: "";
  width: 15px;
  height: 16px;
  flex: 0 0 15px;
  background: url("data:image/svg+xml,%3Csvg width='15' height='16' viewBox='0 0 15 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M5.9375 2.09375L6.625 1.40625C6.9375 1.125 7.40625 1.125 7.6875 1.40625L13.7812 7.46875C14.0625 7.78125 14.0625 8.25 13.7812 8.53125L7.6875 14.625C7.40625 14.9062 6.9375 14.9062 6.625 14.625L5.9375 13.9375C5.65625 13.625 5.65625 13.1562 5.9375 12.8438L9.71875 9.25H0.75C0.3125 9.25 0 8.9375 0 8.5V7.5C0 7.09375 0.3125 6.75 0.75 6.75H9.71875L5.9375 3.1875C5.65625 2.875 5.625 2.40625 5.9375 2.09375Z' fill='white'/%3E%3C/svg%3E") center/contain no-repeat;
}
.single .single-article__content .single-article__btn:hover,
.single .single-article__content .wp-block-button .wp-block-button__link:hover,
.single .single-article__content a.wp-block-button__link:hover {
  color: #fff;
  filter: brightness(1.06);
  transform: translateY(-1px);
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .single .single-article__content .single-article__btn,
  .single .single-article__content .wp-block-button .wp-block-button__link,
  .single .single-article__content a.wp-block-button__link {
    width: 100%;
    max-width: 320px;
    min-width: 0;
    height: 56px;
    padding: 14px 24px;
  }
}
.single .single-article__content .single-article__btn--back::before {
  content: "";
  width: 15px;
  height: 14px;
  flex: 0 0 15px;
  background: url("data:image/svg+xml,%3Csvg width='15' height='14' viewBox='0 0 15 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8.125 12.8125L7.4375 13.5C7.125 13.7812 6.65625 13.7812 6.375 13.5L0.281251 7.4375C6.80258e-07 7.125 7.21238e-07 6.65625 0.281251 6.375L6.375 0.281249C6.65625 -6.47475e-07 7.125 -6.06496e-07 7.4375 0.281249L8.125 0.968749C8.40625 1.28125 8.40625 1.75 8.125 2.0625L4.34375 5.65625L13.3125 5.65625C13.75 5.65625 14.0625 5.96875 14.0625 6.40625L14.0625 7.40625C14.0625 7.8125 13.75 8.15625 13.3125 8.15625L4.34375 8.15625L8.125 11.7187C8.40625 12.0312 8.4375 12.5 8.125 12.8125Z' fill='white'/%3E%3C/svg%3E") center/contain no-repeat;
}
.single .single-article__content .single-article__btn--back::after {
  content: none;
}
.single .single-article__content {
  /* ---- 画像 ---- */
}
.single .single-article__content img {
  max-width: 100%;
  width: auto;
  height: auto;
  display: block;
  margin: 24px auto;
  border-radius: 8px;
}
.single .single-article__content figure {
  margin: 32px 0;
}
.single .single-article__content figure img {
  margin: 0 auto;
}
.single .single-article__content figure figcaption {
  margin-top: 8px;
  font-size: 13px;
  color: #94a3b8;
  text-align: center;
}
.single .single-article__content {
  /* ---- リスト ---- */
}
.single .single-article__content ul,
.single .single-article__content ol {
  margin: 0 0 1.8em;
  padding-left: 1.6em;
  list-style-position: outside;
}
.single .single-article__content ul > li {
  display: list-item;
  list-style-type: disc;
}
.single .single-article__content ol > li {
  display: list-item;
  list-style-type: decimal;
}
.single .single-article__content ul ul > li {
  list-style-type: circle;
}
.single .single-article__content ul ul ul > li {
  list-style-type: square;
}
.single .single-article__content ol ol > li {
  list-style-type: lower-alpha;
}
.single .single-article__content ol ol ol > li {
  list-style-type: lower-roman;
}
.single .single-article__content ul li:last-child,
.single .single-article__content ol li:last-child {
  margin-bottom: 0;
}
.single .single-article__content ul li::marker {
  color: #475569;
  font-size: 0.9em;
}
.single .single-article__content ol li::marker {
  color: #475569;
  font-weight: 700;
}
.single .single-article__content ul ul,
.single .single-article__content ul ol,
.single .single-article__content ol ul,
.single .single-article__content ol ol {
  margin-top: 0.5em;
  margin-bottom: 0.6em;
}
.single .single-article__content li > p {
  margin: 0.2em 0 0.6em;
}
.single .single-article__content li > p:last-child {
  margin-bottom: 0;
}
.single .single-article__content {
  /* ---- 定義リスト ---- */
}
.single .single-article__content dl:not(.single-voice__meta-list) {
  margin: 0 0 1.8em;
  display: grid;
  grid-template-columns: max-content minmax(0, 1fr);
  column-gap: 16px;
  row-gap: 8px;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .single .single-article__content dl:not(.single-voice__meta-list) {
    grid-template-columns: 1fr;
    row-gap: 8px;
    margin-bottom: 1.6em;
  }
}
.single .single-article__content dl:not(.single-voice__meta-list) > dt {
  margin: 0;
  width: auto;
  min-width: 96px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px;
  border-radius: 64px;
  background: rgba(30, 58, 138, 0.4);
  color: #FFF;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  white-space: nowrap;
}
.single .single-article__content dl:not(.single-voice__meta-list) > dt strong {
  color: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}
.single .single-article__content dl:not(.single-voice__meta-list) > dd {
  color: #000;
  font-size: 14px;
  font-weight: 400;
}
@media screen and (max-width: 767px) {
  .single .single-article__content dl:not(.single-voice__meta-list) > dd {
    font-size: 16px;
    line-height: 1.7;
  }
}
.single .single-article__content dl:not(.single-voice__meta-list) > dd a {
  color: #1f2937;
  text-decoration: underline;
  text-underline-offset: 2px;
}
.single .single-article__content li {
  line-height: 1.625;
}
.single .single-article__content {
  /* ---- 引用 ---- */
}
.single .single-article__content blockquote {
  margin: 32px 0;
  padding: 16px 16px 16px 160px;
  position: relative;
  border-radius: 16px;
  background: #F8FAFC;
  color: #475569;
  font-style: normal;
  overflow: hidden;
}
.single .single-article__content blockquote::before {
  content: "";
  position: absolute;
  left: 34px;
  top: 24px;
  width: 79px;
  height: 59px;
  background: url("data:image/svg+xml,%3Csvg width='79' height='59' viewBox='0 0 79 59' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M22.6957 0H11.0235C4.93571 0 0 4.93571 0 11.0235V22.6957C0 28.7835 4.93571 33.7191 11.0235 33.7191H12.1783C13.1465 33.7191 14.0534 34.1969 14.6026 34.9965C15.1493 35.796 15.2694 36.814 14.9194 37.7173L8.33587 54.7784C7.98589 55.6828 8.10596 56.7008 8.65269 57.4991C9.20187 58.2987 10.1088 58.7765 11.077 58.7765H18.8278C19.9211 58.7765 20.9252 58.1684 21.431 57.2003L30.7887 39.3227C32.7149 35.6427 33.7214 31.5501 33.7214 27.3963V11.0234C33.7217 4.93571 28.7835 0 22.6957 0Z' fill='%23EAEAEA'/%3E%3Cpath d='M67.1879 0H55.5154C49.4276 0 44.4922 4.93571 44.4922 11.0235V22.6957C44.4922 28.7835 49.4277 33.7191 55.5154 33.7191H56.6677C57.6359 33.7191 58.5453 34.1969 59.092 34.9965C59.6413 35.796 59.7588 36.814 59.4114 37.7173L52.8255 54.7786C52.4755 55.6829 52.5956 56.7009 53.1447 57.4993C53.6915 58.2988 54.5984 58.7767 55.5692 58.7767H63.3175C64.4109 58.7767 65.415 58.1685 65.9233 57.2005L75.2784 39.3228C77.2046 35.6427 78.2111 31.5502 78.2111 27.3963V11.0234C78.2111 4.93571 73.2756 0 67.1879 0Z' fill='%23EAEAEA'/%3E%3C/svg%3E") center/contain no-repeat;
}
.single .single-article__content blockquote::after {
  content: "";
  position: absolute;
  top: 20px;
  bottom: 20px;
  left: 135px;
  width: 1px;
  background: #dbe3ed;
}
.single .single-article__content blockquote h4 {
  margin: 0;
  padding: 0;
  border: 0;
  color: #475569;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.35;
}
.single .single-article__content blockquote p {
  margin: 0 0 1em;
  line-height: 1.8;
}
@media screen and (max-width: 767px) {
  .single .single-article__content blockquote {
    padding: 72px 16px 18px;
    margin: 24px 0;
    border-radius: 10px;
  }
  .single .single-article__content blockquote::before {
    left: 16px;
    top: 16px;
    width: 56px;
    height: 42px;
  }
  .single .single-article__content blockquote::after {
    display: none;
  }
  .single .single-article__content blockquote h4 {
    margin-bottom: 10px;
    font-size: 22px;
  }
}
.single .single-article__content blockquote p:last-child {
  margin-bottom: 0;
}
.single .single-article__content {
  /* ---- テーブル ---- */
}
.single .single-article__content table {
  width: 100%;
  margin: 24px 0;
  border-collapse: collapse;
  font-size: 14px;
}
@media screen and (max-width: 767px) {
  .single .single-article__content table {
    font-size: 13px;
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}
.single .single-article__content table th,
.single .single-article__content table td {
  padding: 12px 16px;
  border: 1px solid #e2e8f0;
  text-align: left;
  vertical-align: top;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .single .single-article__content table th,
  .single .single-article__content table td {
    padding: 10px 12px;
  }
}
.single .single-article__content table th {
  background: #f1f5f9;
  font-weight: 700;
  color: #1e293b;
}
.single .single-article__content table td {
  background: #fff;
}
.single .single-article__content {
  /* ---- 水平線 ---- */
}
.single .single-article__content hr {
  margin: 40px 0;
  border: 0;
  border-top: 1px solid #e2e8f0;
}
.single .single-article__content {
  /* ---- iframe / 埋め込み ---- */
}
.single .single-article__content iframe {
  max-width: 100%;
  margin: 24px auto;
  display: block;
}
.single .single-article__content .wp-block-embed {
  margin: 32px 0;
}
.single .single-article__content .wp-block-embed__wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
}
.single .single-article__content .wp-block-embed__wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  margin: 0;
}
.single {
  /* -------------------------------------------------------
   * 前後の記事ナビゲーション
   * ----------------------------------------------------- */
}
.single .single-nav {
  margin-top: 64px;
  padding-top: 32px;
  border-top: 1px solid #e2e8f0;
}
@media screen and (max-width: 767px) {
  .single .single-nav {
    margin-top: 48px;
    padding-top: 24px;
  }
}
.single .single-nav__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .single .single-nav__inner {
    gap: 12px;
  }
}
.single .single-nav__link {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 700;
  color: #1e3a8a;
  background: #f1f5f9;
  text-decoration: none;
  transition: background-color 0.2s ease, color 0.2s ease, transform 0.2s ease;
}
@media screen and (max-width: 767px) {
  .single .single-nav__link {
    padding: 10px 14px;
    font-size: 13px;
  }
}
.single .single-nav__link:hover {
  background: #e2e8f0;
  transform: translateY(-1px);
}
.single .single-nav__link--prev:hover .single-nav__arrow svg {
  transform: translateX(-3px);
}
.single .single-nav__link--next:hover .single-nav__arrow svg {
  transform: translateX(3px);
}
.single .single-nav__link--archive {
  background: #1e3a8a;
  color: #fff;
}
.single .single-nav__link--archive:hover {
  background: #1e40af;
  color: #fff;
}
.single .single-nav__link.is-disabled {
  visibility: hidden;
  pointer-events: none;
}
.single .single-nav__arrow {
  display: inline-flex;
  align-items: center;
}
.single .single-nav__arrow svg {
  display: block;
  transition: transform 0.2s ease;
}
.single .single-nav__grid-icon {
  display: inline-flex;
  align-items: center;
}
.single .single-nav__grid-icon svg {
  display: block;
}
.single .single-nav__label {
  white-space: nowrap;
}

.flow-plan-page .inner {
  max-width: 1248px;
}
.flow-plan-page .flow-plan-pricing {
  padding: 10px 0 100px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-pricing {
    padding: 10px 0 60px;
  }
}
.home .flow-plan-page .flow-plan-pricing {
  padding: 60px 0 0;
}
.flow-plan-page .flow-plan-pricing__head {
  text-align: center;
  margin-bottom: 26px;
}
.flow-plan-page .flow-plan-pricing__head .gray-title-set + .flow-plan-pricing__copy {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-pricing__head .gray-title-set + .flow-plan-pricing__copy {
    margin-top: 14px;
  }
}
.flow-plan-page .flow-plan-pricing__copy {
  color: #475569;
  text-align: center;
  font-size: 18px;
  line-height: 1.8;
}
.flow-plan-page .flow-plan-pricing__copy span {
  border-radius: 4px;
  background: #F1F5F9;
  padding: 2px 8px;
  color: #64748B;
  text-align: center;
  font-size: 14px;
  line-height: 1.4;
}
.flow-plan-page .flow-plan-pricing__copy--compact {
  line-height: 1;
  font-size: 0;
}
.flow-plan-page .flow-plan-pricing__plan-intro {
  text-align: center;
  margin: 40px 0 24px;
}
.flow-plan-page .flow-plan-pricing__plan-intro h3 {
  margin: 0;
  color: #1E293B;
  font-size: 40px;
  font-weight: 700;
  line-height: 1.2;
}
.flow-plan-page .flow-plan-pricing__plan-intro p {
  margin: 10px 0 0;
  color: #64748B;
  font-size: 16px;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-pricing__plan-intro {
    margin: 36px 0 20px;
  }
  .flow-plan-page .flow-plan-pricing__plan-intro h3 {
    font-size: min(36px, 36 / 415 * 100vw);
  }
  .flow-plan-page .flow-plan-pricing__plan-intro p {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}

.flow-plan-page .flow-plan-pricing__toggle {
  min-width: var(--flow-plan-table-min-width);
  border-top: 1px solid #dfe5f0;
  background: #f8fafc;
}
.flow-plan-page .flow-plan-pricing__toggle-btn {
  width: 100%;
  min-height: 58px;
  padding: 0 24px;
  border: 0;
  background: transparent;
  color: #1f3f93;
  font-size: 14px;
  font-weight: 700;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-align: left;
  gap: 10px;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-pricing__toggle-btn {
    justify-content: flex-start;
  }
}
.flow-plan-page .flow-plan-pricing__toggle-btn:hover {
  background: #f1f5f9;
}
.flow-plan-page .flow-plan-pricing__toggle-icon {
  width: 10px;
  height: 10px;
  border-right: 2px solid #1f3f93;
  border-bottom: 2px solid #1f3f93;
  transform: rotate(45deg) translateY(-1px);
  transition: transform 0.25s ease;
}
.flow-plan-page .flow-plan-pricing__toggle-btn[aria-expanded=true] .flow-plan-pricing__toggle-icon {
  transform: rotate(-135deg) translateY(-1px);
}

.flow-plan-page {
  --flow-plan-stub-width: 170px;
  --flow-plan-plan-width: 250px;
  --flow-plan-featured-width: 250px;
  --flow-plan-table-min-width: calc(var(--flow-plan-stub-width) + var(--flow-plan-plan-width) * 4);
}
@media screen and (max-width: 767px) {
  .flow-plan-page {
    --flow-plan-stub-width: 145px;
    --flow-plan-plan-width: 200px;
    --flow-plan-featured-width: 200px;
  }
}
.flow-plan-page .flow-plan-pricing__table-wrap {
  overflow-x: auto;
  border-radius: 16px;
  border: 1px solid #E2E8F0;
  background: #FFF;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}
.flow-plan-page .flow-plan-table {
  width: 100%;
  min-width: var(--flow-plan-table-min-width);
  border-collapse: collapse;
}
.flow-plan-page .flow-plan-table__col--stub {
  width: var(--flow-plan-stub-width);
}
.flow-plan-page .flow-plan-table__col--plan {
  width: var(--flow-plan-plan-width);
}
.flow-plan-page .flow-plan-table__col--plan-featured {
  width: var(--flow-plan-featured-width);
}
.flow-plan-page .flow-plan-table__stub {
  width: var(--flow-plan-stub-width);
  border-bottom: 1px solid #dfe5f0;
  color: #334155;
  font-size: 14px;
  font-weight: 700;
  text-align: left;
  padding: 14px 20px;
  vertical-align: middle;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__stub {
    padding: 8px 16px;
    position: sticky;
    left: 0;
    z-index: 1;
    background: #fff;
    box-shadow: 2px 0 4px -1px rgba(0, 0, 0, 0.06);
  }
}
.flow-plan-page .flow-plan-table__stub--header {
  background: transparent;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__stub--header {
    background: #fff;
  }
}
.flow-plan-page .flow-plan-table__plan {
  width: var(--flow-plan-plan-width);
  padding: 18px 24px 18px;
  border-bottom: 1px solid #dfe5f0;
  text-align: center;
  vertical-align: top;
  position: relative;
  background: #fff;
}
.flow-plan-page .flow-plan-table__plan.is-featured {
  width: var(--flow-plan-featured-width);
}
.flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__plan-name {
  color: #1D4ED8;
  font-size: 24px;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__plan-name {
    font-size: min(22px, 22 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__plan-tagline {
  color: #2b6adf;
}
.flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__price {
  color: #2b6adf;
  font-size: 30px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__price {
    font-size: min(27px, 27 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__monthly {
  color: #2b6adf;
  font-size: 11px;
  border-bottom: 1px solid #DBEAFE;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__monthly {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__plan.is-featured .flow-plan-table__setup {
  color: #60A5FA;
}
.flow-plan-page .flow-plan-table__plan-name {
  color: #334155;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  min-height: 34px;
  margin-bottom: -2px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__plan-name {
    font-size: min(18px, 18 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__plan-tagline {
  color: #64748B;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.34;
  min-height: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__plan-tagline {
    font-size: min(11px, 11 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__price-box {
  padding: 14px;
  min-height: 140px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  border-radius: 8px;
  border: 1px solid #F1F5F9;
  background: #F8FAFC;
  max-width: 210px;
  margin-inline: auto;
}
.flow-plan-page .flow-plan-table__price-label {
  color: #64748B;
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  line-height: 1.4;
  margin-bottom: 4px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__price-label {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__price {
  color: #1E293B;
  display: flex;
  align-items: baseline;
  justify-content: center;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.34;
  height: 40px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__price {
    font-size: min(22px, 22 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__price span {
  color: #94A3B8;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__price span {
    font-size: min(11px, 11 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__monthly {
  color: #94a3b8;
  font-size: 10px;
  height: 27px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__monthly {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__setup {
  color: #64748B;
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__setup {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__price-row td {
  vertical-align: middle;
  padding: 12px;
}
.flow-plan-page .flow-plan-table__price-row td.is-featured .flow-plan-table__price-box--cell .flow-plan-table__price {
  color: #2b6adf;
  font-size: 30px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__price-row td.is-featured .flow-plan-table__price-box--cell .flow-plan-table__price {
    font-size: min(22px, 22 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__price-row td.is-featured .flow-plan-table__price-box--cell .flow-plan-table__monthly {
  color: #2b6adf;
  font-size: 11px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__price-row td.is-featured .flow-plan-table__price-box--cell .flow-plan-table__monthly {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__price-box--cell {
  margin: 0 auto;
  min-height: auto;
}
.flow-plan-page .flow-plan-table tbody th,
.flow-plan-page .flow-plan-table tbody td {
  text-align: center;
  vertical-align: middle;
}
.flow-plan-page .flow-plan-table tbody th {
  width: var(--flow-plan-stub-width);
  color: #334155;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.42;
  padding: 14px 20px;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table tbody th {
    font-size: min(13px, 13 / 415 * 100vw);
    padding: 8px 16px;
    position: sticky;
    left: 0;
    z-index: 1;
    background: #fff;
    box-shadow: 2px 0 4px -1px rgba(0, 0, 0, 0.06);
  }
}
.flow-plan-page .flow-plan-table tbody td {
  color: #334155;
  text-align: center;
  font-size: 14px;
  line-height: 1.4;
  padding: 16px 10px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table tbody td {
    font-size: min(13px, 13 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table tbody td span {
  display: block;
  margin-top: 2px;
  font-size: 10px;
  font-weight: 500;
  color: #94a3b8;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table tbody td span {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table tbody td.is-featured {
  color: #2b6adf;
  font-weight: bold;
}
.flow-plan-page .flow-plan-table__label {
  color: #334155;
  font-size: 14px;
  font-weight: 700;
  line-height: 20px;
}
.flow-plan-page .flow-plan-table__label span {
  display: block;
  color: #334155;
  font-size: 12px;
  font-weight: 400;
  line-height: 20px;
  margin-top: 4px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__label span {
    font-size: min(11px, 11 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__group-row td {
  border-top: 1px solid #dfe5f0;
  border-right: 0;
  padding: 0;
  background: #fff;
  color: #334155;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.45;
  text-align: center;
  vertical-align: top;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__group-row td {
    font-size: min(13px, 13 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__group-row.is-gray td {
  background: #F8FAFC;
}
.flow-plan-page .flow-plan-table__group-cell {
  padding: 0 !important;
  border-top: 1px solid #dfe5f0;
}
.flow-plan-page .flow-plan-table__common-block {
  padding: 24px 24px 32px;
  border-top: 1px solid #dfe5f0;
}
.flow-plan-page .flow-plan-table__common-block:first-child {
  border-top: none;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__common-block {
    padding: 20px 16px 24px;
  }
}
.flow-plan-page .flow-plan-table__common-title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 0 0 16px;
  font-size: 14px;
  font-weight: 700;
  color: #334155;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__common-title {
    font-size: min(13px, 13 / 415 * 100vw);
    margin-bottom: 12px;
  }
}
.flow-plan-page .flow-plan-table__common-badge {
  background: #E2E8F0;
  color: #64748B;
  font-size: 12px;
  font-weight: 600;
  padding: 4px 8px;
  border-radius: 4px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__common-badge {
    font-size: min(11px, 11 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__common-list {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px 32px;
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 13px;
  font-weight: 400;
  color: #475569;
  text-align: left;
}
.flow-plan-page .flow-plan-table__common-list li {
  display: flex;
  align-items: center;
  gap: 8px;
  line-height: 1.5;
}
.flow-plan-page .flow-plan-table__common-list li::before {
  content: "";
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg width='16' height='16' viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.3333 4L6 11.3333L2.66667 8' stroke='%232563eb' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat center;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-table__common-list {
    grid-template-columns: repeat(2, 1fr);
    gap: 10px 16px;
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.flow-plan-page .flow-plan-table__common-list--single {
  grid-template-columns: 1fr;
}

.flow-plan-page .flow-plan-table__cta-row th {
  background: #f8fafc;
  border-top: 1px solid #dfe5f0;
}
.flow-plan-page .flow-plan-table__cta-row td {
  padding: 16px 14px;
  border-top: 1px solid #dfe5f0;
}
.flow-plan-page .flow-plan-table__cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  max-width: 180px;
  width: 100%;
  margin: 0 auto;
  min-height: 40px;
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  border-radius: 32px;
  background: #1E3A8A;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
}
.flow-plan-page .flow-plan-table__cta:hover {
  opacity: 0.85;
}

.flow-plan-page .flow-plan-seo-card {
  border-radius: 24px;
  background: #FFFCF4;
  padding: 60px 24px;
  display: flex;
  flex-direction: column;
  align-items: center;
  margin: 0 0 8px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card {
    border-radius: 16px;
    padding: 28px 20px 32px;
  }
}
.flow-plan-page .flow-plan-seo-card__heading {
  margin-bottom: 24px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__heading {
    margin-bottom: 20px;
  }
}
.flow-plan-page .flow-plan-seo-card__title {
  margin: 0;
  color: #1E293B;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.34;
  position: relative;
  display: inline-block;
  padding-left: 22px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__title {
    font-size: 24px;
    line-height: 1.34;
  }
}
.flow-plan-page .flow-plan-seo-card__new {
  position: absolute;
  left: 0;
  top: -6px;
  color: #FBC600;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.42;
  transform: rotate(-22deg);
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__new {
    font-size: 14px;
    top: -6px;
  }
}
.flow-plan-page .flow-plan-seo-card__desc {
  margin: 8px 0 0;
  color: #475569;
  text-align: center;
  font-size: 14px;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__desc {
    font-size: 14px;
    line-height: 1.62;
  }
}
.flow-plan-page .flow-plan-seo-card__note {
  margin: 2px 0 0;
  color: #94A3B8;
  text-align: center;
  font-size: 10px;
  line-height: 1.5;
}
.flow-plan-page .flow-plan-seo-card__badge {
  margin: 0 0 20px;
  border-radius: 16px;
  background: #FBC600;
  color: #000;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 2;
  padding: 8px 16px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__badge {
    margin-bottom: 16px;
    font-size: 16px;
    line-height: 2;
  }
}
.flow-plan-page .flow-plan-seo-card__features {
  list-style: none;
  margin: 0 0 24px;
  padding: 20px 0;
  width: 100%;
  max-width: 907px;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  gap: 12px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__features {
    margin-bottom: 20px;
    padding: 0;
    flex-wrap: wrap;
    gap: 12px 24px;
    justify-content: flex-start;
  }
}
.flow-plan-page .flow-plan-seo-card__feature {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  min-width: 250px;
  flex: 1;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__feature {
    flex: none;
    min-width: calc(50% - 12px);
  }
}
.flow-plan-page .flow-plan-seo-card__feature-icon {
  width: 14px;
  height: 14px;
  margin-top: 3px;
  flex-shrink: 0;
  background: url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.5625 6.78125C13.5625 10.5273 10.5 13.5625 6.78125 13.5625C3.03516 13.5625 0 10.5273 0 6.78125C0 3.0625 3.03516 0 6.78125 0C10.5 0 13.5625 3.0625 13.5625 6.78125ZM5.98828 10.3906L11.0195 5.35938C11.1836 5.19531 11.1836 4.89453 11.0195 4.73047L10.3906 4.12891C10.2266 3.9375 9.95312 3.9375 9.78906 4.12891L5.6875 8.23047L3.74609 6.31641C3.58203 6.125 3.30859 6.125 3.14453 6.31641L2.51562 6.91797C2.35156 7.08203 2.35156 7.38281 2.51562 7.54688L5.35938 10.3906C5.52344 10.5547 5.82422 10.5547 5.98828 10.3906Z' fill='%23FBC600'/%3E%3C/svg%3E") no-repeat center/contain;
}
.flow-plan-page .flow-plan-seo-card__feature-title,
.flow-plan-page .flow-plan-seo-card__feature-text {
  display: block;
}
.flow-plan-page .flow-plan-seo-card__feature-title {
  color: #334155;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.43;
}
.flow-plan-page .flow-plan-seo-card__feature-text {
  color: #64748B;
  font-size: 12px;
  line-height: 1.34;
}
.flow-plan-page .flow-plan-seo-card__price-wrap {
  text-align: center;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__price-wrap {
    margin-bottom: 14px;
  }
}
.flow-plan-page .flow-plan-seo-card__price {
  margin: 0;
  color: #1E3A8A;
  display: inline-flex;
  align-items: flex-end;
  gap: 6px;
}
.flow-plan-page .flow-plan-seo-card__price > span:first-child {
  font-size: 48px;
  font-weight: 700;
  line-height: 0.67;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__price > span:first-child {
    font-size: 48px;
    line-height: 0.67;
  }
}
.flow-plan-page .flow-plan-seo-card__price-unit {
  color: #94A3B8;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.34;
  margin-bottom: 4px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__price-unit {
    font-size: 12px;
    margin-bottom: 4px;
  }
}
.flow-plan-page .flow-plan-seo-card__yearly {
  margin: 0;
  color: #94A3B8;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 2.29;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__yearly {
    font-size: 14px;
    line-height: 2.28;
  }
}
.flow-plan-page .flow-plan-seo-card__price-note {
  margin: -2px 0 0;
  color: #94A3B8;
  text-align: center;
  font-size: 11px;
  line-height: 2.91;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__price-note {
    font-size: 11px;
    line-height: 2.9;
  }
}
.flow-plan-page .flow-plan-seo-card__button {
  border-radius: 32px;
  background: #1E3A8A;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  color: #FFF;
  display: inline-flex;
  width: 193px;
  padding: 16px;
  justify-content: center;
  align-items: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  transition: all 0.2s;
}
.flow-plan-page .flow-plan-seo-card__button:hover {
  color: #fff;
  filter: brightness(1.06);
  transform: translateY(-1px);
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo-card__button {
    width: 193px;
    padding: 16px;
    font-size: 16px;
    line-height: 1.5;
  }
}
.flow-plan-page .flow-plan-seo {
  margin-top: 60px;
  background: #fff;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid #E2E8F0;
  box-shadow: 0 4px 6px 0 rgba(255, 237, 213, 0.5);
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo {
    grid-template-columns: 1fr;
  }
}
.flow-plan-page .flow-plan-seo__left,
.flow-plan-page .flow-plan-seo__middle,
.flow-plan-page .flow-plan-seo__right {
  padding: 38px 32px;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo__left,
  .flow-plan-page .flow-plan-seo__middle,
  .flow-plan-page .flow-plan-seo__right {
    padding: 24px 16px;
  }
}
.flow-plan-page .flow-plan-seo__middle,
.flow-plan-page .flow-plan-seo__right {
  border-left: 1px solid #e2e8f0;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-seo__middle,
  .flow-plan-page .flow-plan-seo__right {
    border-left: 0;
    border-top: 1px solid #e2e8f0;
  }
}
.flow-plan-page .flow-plan-seo__title {
  color: #1E293B;
  text-align: center;
  font-size: 24px;
  font-weight: 700;
  line-height: 1.34;
}
.flow-plan-page .flow-plan-seo__lead {
  color: #FBC600;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.34;
  margin-bottom: 24px;
}
.flow-plan-page .flow-plan-seo__text {
  color: #475569;
  font-size: 14px;
  line-height: 1.6;
}
.flow-plan-page .flow-plan-seo__middle {
  display: flex;
  align-items: center;
}
.flow-plan-page .flow-plan-seo__middle ul {
  display: grid;
  gap: 12px;
  width: 100%;
}
.flow-plan-page .flow-plan-seo__middle li {
  position: relative;
  padding-left: 24px;
}
.flow-plan-page .flow-plan-seo__middle li::before {
  content: "";
  width: 14px;
  height: 14px;
  background: url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M13.5625 6.78125C13.5625 10.5273 10.5 13.5625 6.78125 13.5625C3.03516 13.5625 0 10.5273 0 6.78125C0 3.0625 3.03516 0 6.78125 0C10.5 0 13.5625 3.0625 13.5625 6.78125ZM5.98828 10.3906L11.0195 5.35938C11.1836 5.19531 11.1836 4.89453 11.0195 4.73047L10.3906 4.12891C10.2266 3.9375 9.95312 3.9375 9.78906 4.12891L5.6875 8.23047L3.74609 6.31641C3.58203 6.125 3.30859 6.125 3.14453 6.31641L2.51562 6.91797C2.35156 7.08203 2.35156 7.38281 2.51562 7.54688L5.35938 10.3906C5.52344 10.5547 5.82422 10.5547 5.98828 10.3906Z' fill='%23FBC600'/%3E%3C/svg%3E") no-repeat center/contain;
  position: absolute;
  top: 2.5px;
  left: 0;
}
.flow-plan-page .flow-plan-seo__middle span,
.flow-plan-page .flow-plan-seo__middle strong {
  display: block;
  line-height: 1.4;
}
.flow-plan-page .flow-plan-seo__middle strong {
  color: #334155;
  font-size: 14px;
  font-weight: 700;
}
.flow-plan-page .flow-plan-seo__middle span {
  color: #64748B;
  font-size: 12px;
}
.flow-plan-page .flow-plan-seo__right {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.flow-plan-page .flow-plan-seo__label {
  color: #64748B;
  font-size: 12px;
  font-weight: 700;
}
.flow-plan-page .flow-plan-seo__quote {
  color: #1E293B;
  font-size: 24px;
  font-weight: 700;
}
.flow-plan-page .flow-plan-seo__button {
  margin-top: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 56px;
  width: 100%;
  border-radius: 32px;
  background: #1E3A8A;
  color: #fff;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  font-size: 16px;
  font-weight: 700;
  padding: 0 4px;
  transition: all 0.2s;
}
.flow-plan-page .flow-plan-seo__button:hover {
  color: #fff;
  filter: brightness(1.06);
  transform: translateY(-1px);
  opacity: 0.85;
}
.flow-plan-page .flow-plan-seo__note {
  margin-top: 12px;
  color: #94A3B8;
  font-size: 10px;
}
.flow-plan-page .flow-plan-diagnosis-copy {
  width: min(641px, 100% - 32px);
  margin: 65px auto 0;
  text-align: center;
}
.flow-plan-page .flow-plan-diagnosis-copy__title {
  margin: 0;
  color: #000;
  font-size: 32px;
  font-weight: 700;
  line-height: 100%;
}
.flow-plan-page .flow-plan-diagnosis-copy__desc {
  margin: 30px 0 50px;
  color: #000;
  font-size: 16px;
  font-weight: 400;
  line-height: 140%;
}
.flow-plan-page .flow-plan-diagnosis {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 30px;
  padding: 16px 32px;
  border-radius: 32px;
  background: #FBC600;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.16);
  transition: all 0.2s;
  width: min(321px, 100% - 32px);
  min-height: 80px;
  position: relative;
  margin: 30px auto 60px;
}
.flow-plan-page .flow-plan-diagnosis:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
}
.flow-plan-page .flow-plan-diagnosis__icon {
  position: absolute;
  right: 30px;
  bottom: 12px;
  width: 40px;
  height: auto;
  pointer-events: none;
}
.flow-plan-page .flow-plan-diagnosis__body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 0;
  line-height: 1;
}
.flow-plan-page .flow-plan-diagnosis__title {
  color: #1E3A8A;
  font-size: 12px;
  font-weight: 400;
  line-height: 200%;
}
.flow-plan-page .flow-plan-diagnosis__desc {
  color: #1E3A8A;
  font-size: 16px;
  font-weight: 700;
  line-height: 150%;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-diagnosis-copy__title {
    font-size: 28px;
  }
  .flow-plan-page .flow-plan-diagnosis-copy__desc {
    margin-top: 18px;
    font-size: 14px;
  }
}

.flow-plan-page .flow-plan-flow {
  padding: 80px 0 92px;
  border-top: 1px solid #e2e8f0;
  background: #f8fafc;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-flow {
    padding: 56px 0 64px;
  }
}
.flow-plan-page .flow-plan-flow__head {
  text-align: center;
  margin-bottom: 38px;
}
.flow-plan-page .flow-plan-flow__head h2 {
  color: #1e3a8a;
  font-size: 38px;
  font-weight: 900;
  line-height: 1.3;
}
.flow-plan-page .flow-plan-flow__head p {
  margin-top: 8px;
  color: #64748b;
  font-size: 15px;
  line-height: 1.7;
}
.flow-plan-page .flow-plan-flow__steps {
  display: flex;
  align-items: stretch;
  gap: 8px;
}
.flow-plan-page .flow-plan-flow__step {
  flex: 1;
  border: 1px solid #dbe2ee;
  border-radius: 14px;
  background: #fff;
  padding: 20px 16px 18px;
  text-align: center;
  position: relative;
}
.flow-plan-page .flow-plan-flow__step.is-start {
  border: 2px solid #2b6adf;
  box-shadow: 0 8px 18px rgba(43, 106, 223, 0.14);
}
.flow-plan-page .flow-plan-flow__start {
  position: absolute;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 22px;
  padding: 0 10px;
  border-radius: 999px;
  background: #2b6adf;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
}
.flow-plan-page .flow-plan-flow__number {
  color: #2b6adf;
  font-size: 30px;
  font-weight: 900;
  line-height: 1.2;
}
.flow-plan-page .flow-plan-flow__step h3 {
  margin-top: 6px;
  color: #1f2937;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
}
.flow-plan-page .flow-plan-flow__text {
  margin-top: 8px;
  color: #475569;
  font-size: 13px;
  line-height: 1.7;
}
.flow-plan-page .flow-plan-flow__note {
  margin-top: 8px;
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.5;
}
.flow-plan-page .flow-plan-flow__arrow {
  width: 20px;
  min-width: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.flow-plan-page .flow-plan-flow__arrow::before {
  content: "";
  width: 8px;
  height: 8px;
  border-top: 2px solid #94a3b8;
  border-right: 2px solid #94a3b8;
  transform: rotate(45deg);
}
.flow-plan-page .flow-plan-flow__cta {
  text-align: center;
  margin-top: 36px;
}
.flow-plan-page .flow-plan-flow__cta a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 54px;
  padding: 0 28px;
  border-radius: 999px;
  background: #1f3f93;
  color: #fff;
  font-size: 17px;
  font-weight: 700;
}
.flow-plan-page .flow-plan-flow__cta a:hover {
  opacity: 0.85;
}
.flow-plan-page .flow-plan-flow__cta p {
  margin-top: 10px;
  color: #94a3b8;
  font-size: 12px;
  line-height: 1.5;
}
@media screen and (max-width: 767px) {
  .flow-plan-page .flow-plan-flow__head {
    margin-bottom: 24px;
  }
  .flow-plan-page .flow-plan-flow__head h2 {
    font-size: 28px;
  }
  .flow-plan-page .flow-plan-flow__head p {
    font-size: 14px;
  }
  .flow-plan-page .flow-plan-flow__steps {
    flex-direction: column;
    gap: 10px;
  }
  .flow-plan-page .flow-plan-flow__arrow {
    width: 100%;
    min-width: 0;
    height: 16px;
  }
  .flow-plan-page .flow-plan-flow__arrow::before {
    transform: rotate(135deg);
  }
  .flow-plan-page .flow-plan-flow__cta a {
    width: 100%;
    font-size: 16px;
  }
}

.features-page .features {
  padding-top: 40px;
}
.features-page .features .inner {
  max-width: 1120px;
}
.features-page .features__head {
  text-align: center;
  margin-bottom: 56px;
}
.features-page .features-section-title {
  text-align: center;
}
.features-page .features-section-title__en {
  display: block;
  color: #1E3A8A;
  opacity: 0.1;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .features-page .features-section-title__en {
    font-size: min(46px, 46 / 415 * 100vw);
  }
}
.features-page .features-section-title__ja {
  display: block;
  color: #1E3A8A;
  font-size: 36px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  margin-top: -5px;
}
@media screen and (max-width: 767px) {
  .features-page .features-section-title__ja {
    font-size: min(28px, 28 / 415 * 100vw);
  }
}

.features-page .features__list {
  display: flex;
  flex-direction: column;
  gap: 80px;
}
.features-page .features-item {
  display: grid;
  grid-template-columns: 524px 572px;
  gap: 24px;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 1200px) {
  .features-page .features-item {
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  }
}
@media screen and (max-width: 767px) {
  .features-page .features-item {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.features-page .features-item .features-item__media {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.features-page .features-item .features-item__content {
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.6s ease 0.2s, transform 0.6s ease 0.2s;
}
.features-page .features-item.is-visible .features-item__media,
.features-page .features-item.is-visible .features-item__content {
  opacity: 1;
  transform: translateY(0);
}
.features-page .features-item.is-reverse .features-item__media {
  order: 2;
}
.features-page .features-item.is-reverse .features-item__content {
  order: 1;
}
.features-page .features-item.is-reverse .features-item__label {
  justify-content: end;
}
@media screen and (max-width: 767px) {
  .features-page .features-item.is-reverse .features-item__label {
    justify-content: start;
  }
}
.features-page .features-item.is-reverse .features-item__title,
.features-page .features-item.is-reverse .features-item__lead,
.features-page .features-item.is-reverse .features-item__text {
  text-align: right;
}
@media screen and (max-width: 767px) {
  .features-page .features-item.is-reverse .features-item__title,
  .features-page .features-item.is-reverse .features-item__lead,
  .features-page .features-item.is-reverse .features-item__text {
    text-align: left;
  }
}
@media screen and (max-width: 767px) {
  .features-page .features-item.is-reverse .features-item__media,
  .features-page .features-item.is-reverse .features-item__content {
    order: initial;
  }
}
.features-page .features-item__media {
  width: 100%;
  border-radius: 8px;
  overflow: hidden;
}
.features-page .features-item__media img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}
.features-page .features-item__media--sp {
  display: none;
}
.features-page .features-item__label {
  display: flex;
  align-items: baseline;
  gap: 10px;
}
.features-page .features-item__label-text {
  color: #3B82F6;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 2.5;
}
@media screen and (max-width: 767px) {
  .features-page .features-item__label-text {
    font-size: min(20px, 20 / 415 * 100vw);
  }
}
.features-page .features-item__label-number {
  color: #3B82F6;
  font-size: 48px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.0416666667;
}
@media screen and (max-width: 767px) {
  .features-page .features-item__label-number {
    font-size: min(48px, 48 / 415 * 100vw);
  }
}
.features-page .features-item__title {
  color: #1E3A8A;
  font-size: 32px;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  padding-bottom: 12px;
  border-bottom: 1px solid #FBC600;
}
@media screen and (max-width: 767px) {
  .features-page .features-item__title {
    font-size: min(26px, 26 / 415 * 100vw);
  }
}
.features-page .features-item__lead {
  color: #1E3A8A;
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.5555555556;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .features-page .features-item__lead {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.features-page .features-item__intro {
  display: none;
}
.features-page .features-item__text {
  color: #475569;
  font-size: 16px;
  font-style: normal;
  font-weight: 400;
  line-height: 1.6;
  margin-top: 14px;
}
@media screen and (max-width: 767px) {
  .features-page .features-item__text {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .features-page .features-item > .features-item__media {
    display: none;
  }
  .features-page .features-item__intro {
    display: grid;
    grid-template-columns: 140px 1fr;
    gap: 14px;
    align-items: center;
    margin-top: 12px;
  }
  .features-page .features-item__media--sp {
    display: block;
    width: 100%;
    border-radius: 8px;
    overflow: hidden;
  }
  .features-page .features-item__lead--intro {
    margin-top: 0;
    font-size: min(16px, 16 / 415 * 100vw);
    line-height: 1.5;
  }
  .features-page .features-item__lead--main {
    display: none;
  }
}
@media (prefers-reduced-motion: reduce) {
  .features-page .features-item .features-item__media,
  .features-page .features-item .features-item__content {
    transition: none;
    transform: none;
    opacity: 1;
  }
}

.features-page .features-security {
  padding: 64px 0 80px;
}
.features-page .features-security .inner {
  max-width: 1120px;
}
.features-page .features-security__panel {
  border-radius: 16px;
  background: #1E3A8A;
  padding: 46px 48px 48px;
}
@media screen and (max-width: 767px) {
  .features-page .features-security__panel {
    padding: 40px 20px;
  }
}
.features-page .features-security__head {
  text-align: center;
  position: relative;
  margin-bottom: 36px;
}
.features-page .features-security__en {
  color: #FFF;
  opacity: 0.1;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .features-page .features-security__en {
    font-size: min(36px, 36 / 415 * 100vw);
  }
}
.features-page .features-security__ja {
  color: #FFF;
  font-size: 36px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  margin-top: -12px;
}
@media screen and (max-width: 767px) {
  .features-page .features-security__ja {
    font-size: min(28px, 28 / 415 * 100vw);
  }
}
.features-page .features-security__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  column-gap: 48px;
  row-gap: 24px;
}
@media screen and (max-width: 767px) {
  .features-page .features-security__grid {
    grid-template-columns: 1fr;
  }
}
.features-page .features-security-card {
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: rgba(255, 255, 255, 0.1);
  padding: 16px;
  min-height: 178px;
  color: #FFF;
}
.features-page .features-security-card__title-row {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 8px;
}
.features-page .features-security-card__badge {
  border-radius: 16px;
  background: #FBC600;
  color: #333;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4285714286;
  padding: 2px 8px;
}
.features-page .features-security-card__title {
  color: #FFF;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}
.features-page .features-security-card__label {
  color: #FFF;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4285714286;
  margin-top: 10px;
}
.features-page .features-security-card__text,
.features-page .features-security-card__list {
  color: #FFF;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.4285714286;
  margin-top: 0;
}
.features-page .features-security-card__list {
  margin-left: 1.3em;
}
.features-page .features-security-card__list li {
  list-style: disc;
}
.features-page .features-security-card strong {
  font-weight: 700;
}

.features-page .features-services {
  padding: 64px 0 80px;
  background: #F8FAFC;
}
.features-page .features-services .inner {
  max-width: 1248px;
}
.features-page .features-services__head {
  text-align: center;
}
.features-page .features-services__lead {
  color: #475569;
  text-align: center;
  font-size: 16px;
  font-style: normal;
  font-weight: 350;
  line-height: 1.625;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .features-page .features-services__lead {
    text-align: left;
  }
}
.features-page .features-services__grid {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 400px));
  grid-template-rows: auto auto auto 1fr auto;
  justify-content: center;
  column-gap: 112px;
}
.features-page .features-service-card {
  width: 100%;
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
}
@supports (grid-template-rows: subgrid) {
  .features-page .features-service-card {
    grid-template-rows: subgrid;
    grid-row: span 5;
  }
}
.features-page .features-service-card__image-wrap {
  grid-row: 1;
  border-radius: 16px;
  overflow: hidden;
  background: linear-gradient(0deg, rgba(43, 47, 60, 0.2) 0%, rgba(43, 47, 60, 0.2) 100%);
  box-shadow: 0 0 9px 0 rgba(0, 0, 0, 0.38);
}
.features-page .features-service-card__image-wrap img {
  display: block;
  width: 100%;
  height: auto;
}
.features-page .features-service-card__title {
  grid-row: 2;
  color: #1E293B;
  text-align: center;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.4;
  margin-top: 20px;
}
.features-page .features-service-card__catch {
  grid-row: 3;
  color: #1E3A8A;
  text-align: center;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.4285714286;
  margin-top: 14px;
}
.features-page .features-service-card__text {
  grid-row: 4;
  color: #475569;
  font-size: 14px;
  font-style: normal;
  font-weight: 350;
  line-height: 1.625;
  margin-top: 16px;
}
.features-page .features-service-card__list {
  grid-row: 5;
  margin-top: 24px;
  padding-top: 24px;
  border-top: 1px solid #F1F5F9;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.features-page .features-service-card__list li {
  color: #64748B;
  font-size: 14px;
  font-style: normal;
  font-weight: 350;
  line-height: 1.4285714286;
  display: flex;
  align-items: center;
  gap: 12px;
}
.features-page .features-service-card__icon {
  width: 15px;
  height: 11px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.features-page .features-service-card__icon svg {
  display: block;
  width: 100%;
  height: auto;
}
@media screen and (max-width: 767px) {
  .features-page .features-services__lead {
    font-size: min(16px, 16 / 415 * 100vw);
  }
  .features-page .features-services__grid {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    gap: 40px;
  }
  .features-page .features-service-card {
    grid-template-rows: auto auto auto 1fr auto;
    grid-row: auto;
  }
  .features-page .features-service-card__title {
    font-size: min(20px, 20 / 415 * 100vw);
  }
  .features-page .features-service-card__catch,
  .features-page .features-service-card__text,
  .features-page .features-service-card__list li {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}

.features-page .features-related {
  padding: 96px 0;
  border-bottom: 1px solid #E2E8F0;
}
@media screen and (max-width: 767px) {
  .features-page .features-related {
    padding: 40px 0;
  }
}
.features-page .features-related .inner {
  max-width: 1120px;
}
.features-page .features-related__head {
  text-align: center;
  margin-bottom: 32px;
}
.features-page .features-related__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  align-items: flex-start;
  gap: 32px;
}
@media screen and (max-width: 767px) {
  .features-page .features-related__grid {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.features-page .related-card {
  border-radius: 16px;
  border: 1px solid #E2E8F0;
  background: #F8FAFC;
  padding: 32px;
  flex: 1 0 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 336px;
}
@media screen and (max-width: 767px) {
  .features-page .related-card {
    padding: 20px 16px;
  }
}
.features-page .related-card__body {
  flex: 1 0 auto;
}
.features-page .related-card__top {
  display: flex;
  align-items: flex-start;
  gap: 22px;
}
@media screen and (max-width: 767px) {
  .features-page .related-card__top {
    flex-direction: column;
    gap: 10px;
  }
}
.features-page .related-card__icon {
  width: 64px;
  height: 64px;
  flex-shrink: 0;
  display: inline-flex;
}
.features-page .related-card__icon svg {
  width: 100%;
  height: auto;
  display: block;
}
.features-page .related-card__heading {
  margin-top: 2px;
}
.features-page .related-card__title {
  color: #1E293B;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .features-page .related-card__title {
    font-size: min(20px, 20 / 415 * 100vw);
  }
}
.features-page .related-card__sub {
  color: #64748B;
  font-size: 14px;
  font-style: normal;
  font-weight: 350;
  line-height: 1.4285714286;
  margin-top: 2px;
}
@media screen and (max-width: 767px) {
  .features-page .related-card__sub {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.features-page .related-card__text {
  color: #475569;
  font-size: 14px;
  font-style: normal;
  font-weight: 350;
  line-height: 1.625;
  margin-top: 12px;
}
@media screen and (max-width: 767px) {
  .features-page .related-card__text {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.features-page .related-card__actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  width: 100%;
  padding-top: 24px;
  align-items: stretch;
  gap: 12px;
  border-top: 1px solid #E2E8F0;
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .features-page .related-card__actions {
    grid-template-columns: 1fr;
  }
}
.features-page .related-card__button {
  display: inline-flex;
  width: 100%;
  max-width: none;
  min-width: 0;
  height: 46px;
  padding: 12px 16px;
  justify-content: center;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  border-radius: 64px;
  font-size: 14px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.4285714286;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.features-page .related-card__button:hover, .features-page .related-card__button:focus-visible {
  opacity: 0.7;
  transform: translateY(-2px);
}
@media screen and (max-width: 767px) {
  .features-page .related-card__button {
    width: 100%;
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.features-page .related-card__button--outline {
  border: 1px solid #CBD5E1;
  background: #FFF;
  color: #475569;
}
.features-page .related-card__button--primary {
  background: var(--classicBlue, #1E3A8A);
  color: #FFF;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.2);
}
.features-page .related-card__button-icon {
  line-height: 1;
  font-size: 14px;
}

.features-page .features-for-seo {
  padding: 96px 0;
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo {
    padding: 40px 0;
  }
}
.features-page .features-for-seo .inner {
  max-width: 1150px;
}
.features-page .features-for-seo__head {
  text-align: center;
  margin-bottom: 40px;
}
.features-page .features-for-seo__panel {
  border-radius: 24px;
  background: #F4D35A;
  display: grid;
  grid-template-columns: 534fr 481fr;
  gap: 63px;
  padding: 64px 0 0 64px;
  position: relative;
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 0.6s ease, transform 0.6s ease;
}
.features-page .features-for-seo__panel.is-visible {
  opacity: 1;
  transform: translateY(0);
}
@media screen and (max-width: 1200px) {
  .features-page .features-for-seo__panel {
    grid-template-columns: 1fr;
    gap: 0;
    max-width: 540px;
    margin-inline: auto;
    padding: 40px 20px;
  }
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo__panel {
    padding: 28px 18px;
    gap: 20px;
    border-radius: 16px;
  }
}
@media (prefers-reduced-motion: reduce) {
  .features-page .features-for-seo__panel {
    transition: none;
    transform: none;
  }
}
.features-page .features-for-seo__content {
  width: 534px;
  max-width: 100%;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 1200px) {
  .features-page .features-for-seo__content {
    width: 100%;
  }
}
.features-page .features-for-seo__eyebrow {
  color: #1E3A8A;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.3333333333;
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo__eyebrow {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.features-page .features-for-seo__main-title {
  color: #1E293B;
  font-size: 48px;
  font-weight: 800;
  line-height: 1;
  margin-top: 8px;
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo__main-title {
    font-size: min(30px, 30 / 415 * 100vw);
    line-height: 1.1;
  }
}
.features-page .features-for-seo__desc {
  color: #475569;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.625;
  margin-top: 10px;
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo__desc {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.features-page .features-for-seo__list {
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.features-page .features-for-seo__list li {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  color: #64748B;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.3333333333;
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo__list li {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.features-page .features-for-seo__list strong {
  display: block;
  color: #334155;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.4285714286;
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo__list strong {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.features-page .features-for-seo__check {
  width: 14px;
  height: 14px;
  flex-shrink: 0;
  margin-top: 0.2em;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.features-page .features-for-seo__check svg {
  display: block;
  width: 100%;
  height: auto;
}
.features-page .features-for-seo__cta {
  margin-top: 16px;
  display: inline-flex;
  width: 321px;
  min-height: 56px;
  border-radius: 32px;
  background: var(--classicBlue, #1E3A8A);
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.2);
  color: #FFF;
  text-align: center;
  font-family: "Inter", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 24px;
  align-items: center;
  justify-content: center;
  padding: 16px 0;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.features-page .features-for-seo__cta:hover, .features-page .features-for-seo__cta:focus-visible {
  opacity: 0.7;
  transform: translateY(-2px);
}
@media screen and (max-width: 767px) {
  .features-page .features-for-seo__cta {
    width: 100%;
    min-width: 0;
    min-height: 56px;
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.features-page .features-for-seo__illust {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  margin-top: -22%;
}
@media screen and (max-width: 1200px) {
  .features-page .features-for-seo__illust {
    margin-top: 0;
    max-width: 400px;
    margin-inline: auto;
  }
}
.features-page .features-for-seo__illust img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.for-seo-page .for-seo-fv {
  background: #FFDA51;
  padding: 124px 0 0;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv {
    padding: 80px 0 0;
  }
}
.for-seo-page .for-seo-fv .inner {
  max-width: 1270px;
}
.for-seo-page .for-seo-fv__layout {
  display: grid;
  grid-template-columns: minmax(0, min(768px, 768 / 1240 * 100vw)) minmax(min(320px, 320 / 1240 * 100vw), 1fr);
  gap: min(20px, 20 / 1240 * 100vw);
  align-items: center;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__layout {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.for-seo-page .for-seo-fv__content {
  min-width: 0;
  max-width: 768px;
  padding: 40px 0 20px;
}
.for-seo-page .for-seo-fv__badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 16px;
  border-radius: 16px;
  background: #fff;
  color: #1e3a8a;
  font-size: 12px;
  font-weight: 700;
  line-height: 133.333%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__badge {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__title {
  margin-top: min(24px, 24 / 1240 * 100vw);
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__title {
    margin-top: min(24px, 24 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__title-top {
  display: block;
  max-width: 100%;
  color: #40535C;
  font-size: min(48px, 48 / 1240 * 100vw);
  font-weight: 800;
  text-decoration-line: underline;
  text-decoration-color: #40535C;
  text-decoration-thickness: 3px;
  text-underline-offset: min(12px, 12 / 1240 * 100vw);
  text-decoration-skip-ink: none;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__title-top {
    font-size: min(30px, 30 / 415 * 100vw);
    text-underline-offset: min(8px, 8 / 415 * 100vw);
    line-height: 1.2;
    text-decoration-thickness: 4px;
  }
}
.for-seo-page .for-seo-fv__title-main {
  display: block;
  margin-top: min(30px, 30 / 1240 * 100vw);
  margin-bottom: 30px;
  max-width: 100%;
  color: #40535c;
  font-size: min(48px, 48 / 1240 * 100vw);
  font-weight: 800;
  text-decoration-line: underline;
  text-decoration-color: #40535C;
  text-decoration-thickness: 3px;
  text-underline-offset: min(18px, 18 / 1240 * 100vw);
  text-decoration-skip-ink: none;
  letter-spacing: 0;
  white-space: normal;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__title-main {
    margin-top: 18px;
    margin-bottom: min(30px, 30 / 415 * 100vw);
    font-size: min(30px, 30 / 415 * 100vw);
    font-feature-settings: "palt";
    text-decoration-thickness: 4px;
    text-underline-offset: min(10px, 10 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__lead {
  margin-top: min(18px, 18 / 1240 * 100vw);
  max-width: min(534px, 534 / 1240 * 100vw);
  color: #475569;
  font-size: clamp(12px, 14 / 1240 * 100vw, 14px);
  font-weight: 400;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__lead {
    margin-top: min(18px, 18 / 415 * 100vw);
    max-width: min(534px, 534 / 415 * 100vw);
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.6;
  }
}
.for-seo-page .for-seo-fv__actions {
  margin-top: min(30px, 30 / 1240 * 100vw);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: min(16px, 16 / 1240 * 100vw);
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__actions {
    margin-top: min(30px, 30 / 415 * 100vw);
    gap: min(16px, 16 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__cta {
  display: inline-flex;
  width: min(321px, 321 / 1240 * 100vw);
  max-width: 100%;
  align-items: center;
  justify-content: center;
  gap: min(10px, 10 / 1240 * 100vw);
  padding: min(16px, 16 / 1240 * 100vw);
  border-radius: 32px;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.2);
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.for-seo-page .for-seo-fv__cta:hover, .for-seo-page .for-seo-fv__cta:focus-visible {
  opacity: 0.85;
  transform: translateY(-2px);
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__cta {
    width: 100%;
    max-width: 321px;
    margin-inline: auto;
    gap: min(10px, 10 / 415 * 100vw);
    padding: min(16px, 16 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__cta--primary {
  background: #1e3a8a;
  color: #fff;
}
.for-seo-page .for-seo-fv__cta--secondary {
  background: #fbc60f;
  color: #1e3a8a;
}
.for-seo-page .for-seo-fv__cta-icon {
  width: min(24px, 24 / 1240 * 100vw);
  height: min(24px, 24 / 1240 * 100vw);
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__cta-icon {
    width: min(24px, 24 / 415 * 100vw);
    height: min(24px, 24 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__cta-text {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-width: 0;
}
.for-seo-page .for-seo-fv__cta-sub {
  font-size: min(12px, 12 / 1240 * 100vw);
  font-weight: 400;
  line-height: 200%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__cta-sub {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__cta-main {
  font-size: min(16px, 16 / 1240 * 100vw);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.01em;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__cta-main {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-fv__cta--primary .for-seo-page .for-seo-fv__cta-main {
  color: #fff;
}
.for-seo-page .for-seo-fv__cta--secondary .for-seo-page .for-seo-fv__cta-main {
  color: #1e3a8a;
}
.for-seo-page .for-seo-fv__media {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  min-width: 0;
  height: 100%;
}
.for-seo-page .for-seo-fv__media img {
  width: 100%;
  height: auto;
  max-width: min(568px, 568 / 1240 * 100vw);
  display: block;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__media img {
    max-width: min(568px, 568 / 415 * 100vw);
  }
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-fv__media {
    max-width: 420px;
    margin: 0 auto;
  }
}
.for-seo-page .breadcrumb {
  background: #fff;
}
.for-seo-page .breadcrumb .inner {
  max-width: 1350px;
}

.for-seo-page .for-seo-section-head {
  text-align: center;
}
.for-seo-page .for-seo-section-head__title-en {
  display: block;
  color: #e2e8f0;
  text-align: center;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-section-head__title-en {
    font-size: min(48px, 48 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-section-head__title-ja {
  display: block;
  color: #fbc600;
  text-align: center;
  font-size: 36px;
  font-weight: 900;
  line-height: 1.22;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-section-head__title-ja {
    font-size: min(28px, 28 / 415 * 100vw);
    line-height: 1.35;
  }
}

.for-seo-page .for-seo-causes {
  background: #fff;
  padding: 44px 0 80px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-causes {
    padding: 36px 0 56px;
  }
}
.for-seo-page .for-seo-causes .inner {
  max-width: 1120px;
}
.for-seo-page .for-seo-causes__list {
  margin: 40px auto 0;
  max-width: 820px;
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 80px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-causes__list {
    margin-top: 28px;
    gap: 40px;
  }
}
.for-seo-page .for-seo-causes-item__heading {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  border-bottom: 1px solid #fbc600;
  padding-bottom: 6px;
}
.for-seo-page .for-seo-causes-item__label {
  display: inline-flex;
  align-items: baseline;
  gap: 12px;
  color: #fbc600;
  flex-shrink: 0;
}
.for-seo-page .for-seo-causes-item__label-text {
  font-size: 20px;
  font-weight: 700;
  line-height: 250%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-causes-item__label-text {
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 250%;
  }
}
.for-seo-page .for-seo-causes-item__label-number {
  font-size: 48px;
  font-weight: 700;
  line-height: 104.167%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-causes-item__label-number {
    font-size: min(36px, 36 / 415 * 100vw);
    line-height: 104.167%;
  }
}
.for-seo-page .for-seo-causes-item__title {
  margin-top: 0;
  color: #333;
  font-size: 32px;
  font-weight: 700;
  line-height: 125%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-causes-item__title {
    margin-top: 0;
    font-size: min(24px, 24 / 415 * 100vw);
    line-height: 1.25;
  }
}
.for-seo-page .for-seo-causes-item__text {
  margin-top: 10px;
  color: #333;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-causes-item__text {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}

.for-seo-page .for-seo-reason {
  background: #f7f7f7;
  padding: 96px 0 80px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason {
    padding: 56px 0;
  }
}
.for-seo-page .for-seo-reason .inner {
  max-width: 990px;
}
.for-seo-page .for-seo-reason__lead {
  margin: 16px auto 0;
  color: #475569;
  text-align: center;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason__lead {
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.7;
  }
}
.for-seo-page .for-seo-reason__cards {
  margin: 35px auto 0;
  max-width: 1024px;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 32px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason__cards {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-top: 24px;
  }
}
.for-seo-page .for-seo-reason-card {
  border-radius: 16px;
  background: #fff;
  padding: 40px;
  min-height: 460px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-card {
    min-height: 0;
    padding: 24px;
  }
}
.for-seo-page .for-seo-reason-card__label {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  color: var(--pri_Yellow, #fbc600);
}
.for-seo-page .for-seo-reason-card__label-text {
  font-size: min(20px, 20 / 1240 * 100vw);
  font-weight: 700;
  line-height: 250%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-card__label-text {
    font-size: min(18px, 18 / 415 * 100vw);
    line-height: 250%;
  }
}
.for-seo-page .for-seo-reason-card__label-number {
  font-size: min(48px, 48 / 1240 * 100vw);
  font-weight: 700;
  line-height: 104.167%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-card__label-number {
    font-size: min(36px, 36 / 415 * 100vw);
    line-height: 104.167%;
  }
}
.for-seo-page .for-seo-reason-card__title {
  margin-top: 10px;
  color: #333;
  text-align: center;
  font-size: min(20px, 20 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-card__title {
    margin-top: 12px;
    font-size: min(18px, 18 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-reason-card__solve {
  margin-top: 16px;
  color: #1e3a8a;
  text-align: center;
  font-size: min(14px, 14 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.43;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-card__solve {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-reason-card__text {
  margin-top: 16px;
  color: #475569;
  text-align: left;
  font-size: min(14px, 14 / 1240 * 100vw);
  font-weight: 400;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-card__text {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-reason-others {
  margin: 35px auto 0;
  max-width: 1024px;
  border-radius: 16px;
  background: #fff;
  padding: 40px 48px 48px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-others {
    margin-top: 24px;
    padding: 24px 16px;
  }
}
.for-seo-page .for-seo-reason-others__title-en {
  display: block;
  color: #374e71;
  text-align: center;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  line-height: 1;
  opacity: 0.1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-others__title-en {
    font-size: min(42px, 42 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-reason-others__title-ja {
  display: block;
  color: #333;
  font-size: 36px;
  font-weight: 900;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-others__title-ja {
    font-size: min(28px, 28 / 415 * 100vw);
    line-height: 1.2;
  }
}
.for-seo-page .for-seo-reason-others__lead {
  margin-top: 16px;
  color: #333;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.43;
}
.for-seo-page .for-seo-reason-others__list {
  margin-top: 32px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 24px 48px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-others__list {
    margin-top: 20px;
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.for-seo-page .for-seo-reason-others-item {
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.53);
  box-shadow: 0 4px 24px 0 rgba(0, 0, 0, 0.08);
  padding: 24px;
  text-align: left;
}
.for-seo-page .for-seo-reason-others-item__label {
  display: inline-flex;
  align-items: center;
  border-radius: 16px;
  background: var(--pri_Yellow, #fbc600);
  color: #333;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.43;
  padding: 2px 8px;
}
.for-seo-page .for-seo-reason-others-item__text {
  margin-top: 8px;
  color: #333;
  font-size: 14px;
  font-weight: 700;
  line-height: 1.43;
}
.for-seo-page .for-seo-reason-others__cta {
  margin-top: 32px;
  width: 321px;
  max-width: 100%;
  border-radius: 32px;
  background: var(--pri_Yellow, #fbc600);
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.2);
  padding: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: opacity 0.2s ease, transform 0.2s ease;
}
.for-seo-page .for-seo-reason-others__cta:hover, .for-seo-page .for-seo-reason-others__cta:focus-visible {
  opacity: 0.85;
  transform: translateY(-2px);
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-reason-others__cta {
    width: 100%;
  }
}
.for-seo-page .for-seo-reason-others__cta-icon {
  width: 36px;
  height: 36px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
.for-seo-page .for-seo-reason-others__cta-text {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  color: var(--classicBlue, #1e3a8a);
  line-height: 1;
  text-align: left;
}
.for-seo-page .for-seo-reason-others__cta-sub {
  font-size: 12px;
  font-weight: 400;
  line-height: 2;
}
.for-seo-page .for-seo-reason-others__cta-main {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}

.for-seo-page .for-seo-how {
  background: #fff;
  padding: 96px 0 30px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how {
    padding: 56px 0;
  }
}
.for-seo-page .for-seo-how .inner {
  max-width: 1120px;
}
.for-seo-page .for-seo-how__lead {
  margin-top: 8px;
  color: #475569;
  text-align: center;
  font-size: min(16px, 16 / 1240 * 100vw);
  font-weight: 400;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how__lead {
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.7;
  }
}
.for-seo-page .for-seo-how__body {
  margin-top: 30px;
  display: grid;
  grid-template-columns: 588fr 500fr;
  align-items: center;
  gap: 32px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how__body {
    margin-top: 20px;
    padding: 0;
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.for-seo-page .for-seo-how__diagram {
  margin: 0;
}
.for-seo-page .for-seo-how__diagram img {
  display: block;
  width: 100%;
  height: auto;
}
.for-seo-page .for-seo-how__works {
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  padding: 32px;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 80px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how__works {
    padding: 20px 16px;
    gap: 40px;
  }
}
.for-seo-page .for-seo-how-item__heading {
  border-bottom: 1px solid #fbc600;
  padding-bottom: 12px;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how-item__heading {
    padding-bottom: 8px;
  }
}
.for-seo-page .for-seo-how-item__label {
  display: inline-flex;
  align-items: baseline;
  gap: 10px;
  color: #fbc600;
}
.for-seo-page .for-seo-how-item__label-text {
  font-size: min(20px, 20 / 1240 * 100vw);
  font-weight: 700;
  line-height: 250%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how-item__label-text {
    font-size: min(18px, 18 / 415 * 100vw);
    line-height: 250%;
  }
}
.for-seo-page .for-seo-how-item__label-number {
  font-size: min(48px, 48 / 1240 * 100vw);
  font-weight: 700;
  line-height: 104.167%;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how-item__label-number {
    font-size: min(36px, 36 / 415 * 100vw);
    line-height: 104.167%;
  }
}
.for-seo-page .for-seo-how-item__title {
  color: #333;
  font-size: min(32px, 32 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how-item__title {
    font-size: min(28px, 28 / 415 * 100vw);
    line-height: 1.25;
  }
}
.for-seo-page .for-seo-how-item__text {
  margin-top: 8px;
  color: #333;
  font-size: min(18px, 18 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how-item__text {
    font-size: min(16px, 16 / 415 * 100vw);
    line-height: 1.7;
  }
}
.for-seo-page .for-seo-how__security {
  margin: 20px auto 0;
  width: fit-content;
  max-width: 100%;
  display: flex;
  align-items: center;
  gap: 8px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how__security {
    flex-direction: column;
    align-items: baseline;
  }
}
.for-seo-page .for-seo-how__security-label {
  display: flex;
  align-items: center;
  border-radius: 16px;
  background: #fbc600;
  color: #333;
  font-size: min(14px, 14 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.43;
  padding: 2px 8px;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how__security-label {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-how__security-text {
  color: #374e71;
  font-size: min(14px, 14 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.43;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-how__security-text {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}

.for-seo-page .for-seo-plan {
  background: #f8f8f8;
  padding: 96px 0;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan {
    padding: 56px 0;
  }
}
.for-seo-page .for-seo-plan .inner {
  max-width: 1248px;
}
.for-seo-page .for-seo-plan__head {
  text-align: center;
}
.for-seo-page .for-seo-plan__title-en {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  padding-bottom: 20px;
  border-bottom: 4px solid #fbc600;
  color: #d7dce3;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__title-en {
    font-size: min(48px, 48 / 415 * 100vw);
    padding-bottom: 14px;
  }
}
.for-seo-page .for-seo-plan__title-ja {
  display: block;
  margin-top: 16px;
  color: #374e71;
  font-size: 24px;
  font-weight: 400;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__title-ja {
    font-size: min(20px, 20 / 415 * 100vw);
    line-height: 1.4;
  }
}
.for-seo-page .for-seo-plan__lead {
  margin-top: 16px;
  color: #475569;
  text-align: center;
  font-size: 18px;
  font-weight: 400;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__lead {
    margin-top: 12px;
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.7;
  }
}
.for-seo-page .for-seo-plan__cards {
  margin: 60px auto 0;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 84px;
}
@media screen and (max-width: 1200px) {
  .for-seo-page .for-seo-plan__cards {
    gap: 32px;
  }
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__cards {
    margin-top: 28px;
    flex-direction: column-reverse;
    gap: 20px;
  }
}
.for-seo-page .for-seo-plan-card {
  border-radius: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.for-seo-page .for-seo-plan-card--standard {
  width: 443px;
  padding: 32px 16px;
  background: #fcfcfc;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card--standard {
    width: 100%;
    max-width: 443px;
    padding: 24px 16px;
  }
}
.for-seo-page .for-seo-plan-card--seo {
  width: 463px;
  padding: 64px 30px;
  border-radius: 16px;
  border: 1px solid #E0E0E0;
  background: #F8FAFC;
  box-shadow: 0 0 32px 0 rgba(0, 0, 0, 0.15);
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card--seo {
    width: 100%;
    max-width: 463px;
    padding: 28px 16px;
  }
}
.for-seo-page .for-seo-plan-card__pill {
  border-radius: 16px;
  font-size: min(16px, 16 / 1240 * 100vw);
  font-weight: 700;
  line-height: 2;
  padding: 8px 16px;
  margin-bottom: 20px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__pill {
    font-size: min(16px, 16 / 415 * 100vw);
    margin-bottom: 12px;
  }
}
.for-seo-page .for-seo-plan-card__pill--outline {
  border: 1px solid #fbc600;
  color: #000;
  background: #fff;
}
.for-seo-page .for-seo-plan-card__pill--filled {
  color: #000;
  background: #fbc600;
}
.for-seo-page .for-seo-plan-card__title {
  margin: 0;
  margin-bottom: 6px;
  color: #000;
  text-align: center;
  font-size: min(32px, 32 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__title {
    font-size: min(28px, 28 / 415 * 100vw);
    margin-bottom: 10px;
  }
}
.for-seo-page .for-seo-plan-card__sub {
  margin: 0;
  margin-bottom: 20px;
  color: #000;
  text-align: center;
  font-size: min(14px, 14 / 1240 * 100vw);
  font-weight: 700;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__sub {
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.7;
    margin-bottom: 16px;
  }
}
.for-seo-page .for-seo-plan-card__price {
  margin: 0;
  margin-bottom: 2px;
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  color: #000;
  line-height: 1;
}
.for-seo-page .for-seo-plan-card__price-label {
  font-size: min(32px, 32 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__price-label {
    font-size: min(32px, 32 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-plan-card__price-number {
  font-size: min(110.7px, 110.7 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__price-number {
    font-size: min(60px, 60 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-plan-card__price-unit {
  font-size: min(32px, 32 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1;
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__price-unit {
    font-size: min(32px, 32 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-plan-card__year {
  margin: 0;
  margin-bottom: 10px;
  text-align: center;
  line-height: 1;
  color: #94A3B8;
  font-size: min(14px, 14 / 1240 * 100vw);
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__year {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-plan-card__init {
  margin: 0;
  margin-bottom: 20px;
  color: #94a3b8;
  text-align: center;
  font-size: min(11px, 11 / 1240 * 100vw);
  font-weight: 400;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__init {
    font-size: min(11px, 11 / 415 * 100vw);
    margin-bottom: 16px;
  }
}
.for-seo-page .for-seo-plan-card__catch {
  margin: 0;
  margin-bottom: 12px;
  width: 100%;
  color: #000;
  text-align: left;
  font-size: min(20px, 20 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.6;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__catch {
    font-size: min(16px, 16 / 415 * 100vw);
    margin-bottom: 20px;
    width: fit-content;
    margin-inline: auto;
  }
}
.for-seo-page .for-seo-plan-card__catch strong {
  color: #fbc600;
  font-size: min(36px, 36 / 1240 * 100vw);
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__catch strong {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-plan-card__specs {
  width: 100%;
  max-width: 360px;
  margin: 0 auto 30px;
  display: grid;
  gap: 16px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__specs {
    margin-bottom: 24px;
  }
}
.for-seo-page .for-seo-plan-card__spec {
  border-bottom: 1px solid #000;
  padding: 6px 0;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
}
.for-seo-page .for-seo-plan-card__spec-label,
.for-seo-page .for-seo-plan-card__spec-value {
  color: #333;
  font-size: min(16px, 16 / 1240 * 100vw);
  font-weight: 400;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__spec-label,
  .for-seo-page .for-seo-plan-card__spec-value {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-plan-card__spec-value {
  text-align: right;
}
.for-seo-page .for-seo-plan-card__spec-value--standard {
  color: #005eac;
  font-weight: 700;
}
.for-seo-page .for-seo-plan-card__cta {
  margin-top: 0;
  width: 321px;
  max-width: 100%;
  border-radius: 32px;
  background: #1e3a8a;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.25);
  padding: 16px;
  color: #fff;
  text-align: center;
  font-size: min(16px, 16 / 1240 * 100vw);
  font-weight: 700;
  line-height: 1.5;
  transition: all 0.2s;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan-card__cta {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-plan-card__cta:hover {
  color: #fff;
  filter: brightness(1.06);
  transform: translateY(-1px);
}
.for-seo-page .for-seo-plan__note {
  width: min(928px, 100%);
  margin: 50px auto 0;
  color: #475569;
  text-align: center;
  font-size: 16px;
  font-weight: 350;
  line-height: 1.625;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__note {
    margin-top: 30px;
    font-size: min(13px, 13 / 415 * 100vw);
    line-height: 1.7;
  }
}
.for-seo-page .for-seo-plan__diagnosis {
  width: min(990px, 100%);
  margin: 50px auto 0;
  padding: 32px;
  border-radius: 16px;
  background: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 30px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__diagnosis {
    margin-top: 24px;
    padding: 24px 16px;
    gap: 20px;
  }
}
.for-seo-page .for-seo-plan__diagnosis-title {
  margin: 0;
  color: #000;
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__diagnosis-title {
    font-size: min(26px, 26 / 415 * 100vw);
    line-height: 1;
  }
}
.for-seo-page .for-seo-plan__diagnosis-desc {
  margin: 0;
  color: #000;
  text-align: center;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-plan__diagnosis-desc {
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.7;
  }
}
.for-seo-page .for-seo-plan__diagnosis-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(321px, 100%);
  min-height: 80px;
  padding: 16px 32px;
  border-radius: 32px;
  background: #fbc600;
  box-shadow: 0 4px 4px rgba(0, 0, 0, 0.16);
  position: relative;
  transition: all 0.2s;
  margin-top: 20px;
}
.for-seo-page .for-seo-plan__diagnosis-link:hover {
  filter: brightness(1.04);
  transform: translateY(-1px);
}
.for-seo-page .for-seo-plan__diagnosis-link-body {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1;
}
.for-seo-page .for-seo-plan__diagnosis-link-title {
  color: #1e3a8a;
  font-size: 12px;
  font-weight: 400;
  line-height: 2;
}
.for-seo-page .for-seo-plan__diagnosis-link-desc {
  color: #1e3a8a;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
}
.for-seo-page .for-seo-plan__diagnosis-link-icon {
  width: 40px;
  height: auto;
  position: absolute;
  right: 30px;
  bottom: 12px;
  pointer-events: none;
}

.for-seo-page .for-seo-flow {
  padding: 96px 0;
  background: #F8FAFC;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow {
    padding: min(60px, 60 / 415 * 100vw) 0;
  }
}
.for-seo-page .for-seo-flow .inner {
  max-width: 1440px;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .inner {
    padding: 0 32px;
  }
}
.for-seo-page .for-seo-flow .gray-title {
  width: fit-content;
  margin: 0 auto;
  color: #D7DCE3;
  text-align: center;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
  padding-bottom: 10px;
  border-bottom: 4px solid #FBC600;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .gray-title {
    font-size: min(64px, min(40px, 40 / 415 * 100vw));
    padding-bottom: 10px;
    border-bottom: 2px solid #FBC600;
  }
}
.for-seo-page .for-seo-flow .gray-title-set {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .gray-title-set {
    gap: 8px;
  }
}
.for-seo-page .for-seo-flow .gray-label {
  margin: 0;
  color: #374E71;
  text-align: center;
  font-size: 24px;
}
.for-seo-page .for-seo-flow .gray-description {
  color: #64748B;
  text-align: center;
  font-size: 18px;
  line-height: 1.56;
}
.for-seo-page .for-seo-flow .flow__lead {
  margin-top: 16px;
}
.for-seo-page .for-seo-flow .flow__grid-wrap {
  overflow-x: auto;
  overflow-y: visible;
  -webkit-overflow-scrolling: touch;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__grid-wrap {
    width: auto;
    max-width: 350px;
    margin-inline: auto;
    overflow: visible;
  }
}
.for-seo-page .for-seo-flow .flow__grid {
  margin: 0 auto;
  display: grid;
  width: max-content;
  min-width: 1280px;
  grid-template-columns: 227px 12px 227px 12px 227px 12px 227px 12px 227px;
  gap: 18px;
  align-items: center;
  padding: 40px 20px 50px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__grid {
    margin: 0;
    width: 100%;
    min-width: 0;
    grid-template-columns: 1fr;
    gap: min(20px, 20 / 415 * 100vw);
    padding: 28px 0 30px;
  }
}
.for-seo-page .for-seo-flow .flow__grid .flow__step.is-first {
  box-shadow: 0 20px 25px -5px #DBEAFE, 0 8px 10px -6px #DBEAFE;
  transform: scale(1.1);
  border-color: transparent;
}
.for-seo-page .for-seo-flow .flow__grid .flow__step.is-first .flow__step-note.is-badge {
  color: #1E3A8A;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__grid .flow__step.is-first {
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    transform: none;
    border-color: #E2E8F0;
  }
  .for-seo-page .for-seo-flow .flow__grid .flow__step.is-first .flow__step-note.is-badge {
    color: #64748B;
    font-weight: 400;
  }
}
.for-seo-page .for-seo-flow .flow__grid:has(.flow__step:not(.is-first):hover) .flow__step.is-first, .for-seo-page .for-seo-flow .flow__grid:has(.flow__step:not(.is-first):focus-within) .flow__step.is-first {
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  transform: none;
  border-color: #E2E8F0;
}
.for-seo-page .for-seo-flow .flow__grid:has(.flow__step:not(.is-first):hover) .flow__step.is-first .flow__step-note.is-badge, .for-seo-page .for-seo-flow .flow__grid:has(.flow__step:not(.is-first):focus-within) .flow__step.is-first .flow__step-note.is-badge {
  color: #64748B;
  font-weight: 400;
}
.for-seo-page .for-seo-flow .flow__arrow {
  display: flex;
  align-items: center;
  justify-content: center;
}
.for-seo-page .for-seo-flow .flow__arrow svg {
  display: block;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__arrow {
    display: none;
  }
}
.for-seo-page .for-seo-flow .flow__step {
  border-radius: 12px;
  border: 1px solid #E2E8F0;
  background: #FFF;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  padding: 40px 24px 10px;
  text-align: center;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  min-height: 380px;
  transition: all 0.3s ease;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step {
    min-height: auto;
    padding: min(30px, 30 / 415 * 100vw) min(14px, 14 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow .flow__step:hover, .for-seo-page .for-seo-flow .flow__step:focus-within {
  box-shadow: 0 20px 25px -5px #DBEAFE, 0 8px 10px -6px #DBEAFE;
  transform: scale(1.1);
  border-color: transparent;
}
.for-seo-page .for-seo-flow .flow__step:hover .flow__step-note.is-badge, .for-seo-page .for-seo-flow .flow__step:focus-within .flow__step-note.is-badge {
  color: #1E3A8A;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step:hover, .for-seo-page .for-seo-flow .flow__step:focus-within {
    box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
    transform: none;
    border-color: #E2E8F0;
  }
  .for-seo-page .for-seo-flow .flow__step:hover .flow__step-note.is-badge, .for-seo-page .for-seo-flow .flow__step:focus-within .flow__step-note.is-badge {
    color: #64748B;
    font-weight: 400;
  }
}
.for-seo-page .for-seo-flow .flow__step-badge {
  background: #FBC600;
  color: #FFF;
  font-size: 10.5px;
  font-weight: 700;
  padding: 4px 16px;
  border-radius: 999px;
  box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
  letter-spacing: 0.05em;
  position: absolute;
  left: 50%;
  top: 14.5px;
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step-badge {
    font-size: min(10.5px, 10.5 / 415 * 100vw);
    top: 10px;
  }
}
.for-seo-page .for-seo-flow .flow__step-no {
  color: #1E3A8A;
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -1.2px;
  line-height: 1.333;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step-no {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow .flow__step-icon {
  width: 96px;
  height: 96px;
  margin-bottom: -15px;
}
.for-seo-page .for-seo-flow .flow__step-icon img {
  width: 100%;
  height: 100%;
}
.for-seo-page .for-seo-flow .flow__step-title {
  color: #1E293B;
  text-align: center;
  font-size: 16px;
  font-weight: 700;
  line-height: 1.55;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step-title {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow .flow__step-text {
  font-size: 12.6px;
  line-height: 1.625;
  color: #475569;
  text-align: center;
}
.for-seo-page .for-seo-flow .flow__step-text strong {
  color: #475569;
  font-weight: 700;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step-text {
    font-size: min(12.6px, 12.6 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow .flow__step-split {
  width: 100%;
  margin-top: 1px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step-split {
    width: fit-content;
  }
}
.for-seo-page .for-seo-flow .flow__step-split-block {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 10px 0;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step-split-block {
    padding: 10px;
  }
}
.for-seo-page .for-seo-flow .flow__step-split-block--agency {
  background: #F1F5F9;
}
.for-seo-page .for-seo-flow .flow__step-split-block--client {
  background: #FFF8DB;
}
.for-seo-page .for-seo-flow .flow__step-work-label {
  width: 80px;
  height: 20px;
  border-radius: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.625;
  color: #475569;
  flex-shrink: 0;
}
.for-seo-page .for-seo-flow .flow__step-work-label--agency {
  background: #E2E8F0;
}
.for-seo-page .for-seo-flow .flow__step-work-label--client {
  background: #FBC600;
}
.for-seo-page .for-seo-flow .flow__step-split-text {
  color: #475569;
  text-align: center;
  font-size: 12px;
  font-weight: 700;
  line-height: 15.5px;
}
.for-seo-page .for-seo-flow .flow__step-note {
  margin-top: auto;
  color: #94A3B8;
  font-size: 10px;
  line-height: 1.5;
  padding: 4px 8px;
}
.for-seo-page .for-seo-flow .flow__step-note.is-badge {
  color: #64748B;
  border-radius: 4px;
  background: #F1F5F9;
  margin-bottom: 20px;
}
.for-seo-page .for-seo-flow .flow__step-note.flow__step-note--plain {
  background: transparent;
  padding: 0;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__step-note {
    font-size: min(10px, 10 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow .flow__cta {
  margin-top: 30px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__cta {
    margin-top: min(32px, 32 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow .flow__cta-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 282px;
  min-height: 60px;
  box-sizing: border-box;
  gap: 8px;
  background: #1E3A8A;
  box-shadow: 0 4px 4px 0 rgba(0, 0, 0, 0.25);
  color: #fff;
  text-align: center;
  font-size: 18px;
  font-weight: 700;
  line-height: 28px;
  padding: 16px 32px;
  border-radius: 64px;
  transition: opacity 0.3s;
}
.for-seo-page .for-seo-flow .flow__cta-btn:hover {
  opacity: 0.85;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__cta-btn {
    min-width: auto;
    min-height: min(56px, 56 / 415 * 100vw);
    font-size: min(18px, 18 / 415 * 100vw);
    line-height: min(28px, 28 / 415 * 100vw);
    padding: min(14px, 14 / 415 * 100vw) min(24px, 24 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow .flow__cta-note {
  margin-top: 12px;
  color: #64748B;
  text-align: center;
  font-size: 12px;
  line-height: 16px;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow .flow__cta-note {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.for-seo-page .for-seo-flow__period {
  color: #475569;
  text-align: center;
  font-size: 18px;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .for-seo-page .for-seo-flow__period {
    font-size: min(16px, 16 / 415 * 100vw);
    line-height: 1.5;
  }
}

.company-section-title {
  color: #D7DCE3;
  text-align: center;
  font-size: 36px;
  font-style: italic;
  font-weight: 900;
  line-height: normal;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-bottom: 10px;
  border-bottom: 4px solid #FBC600;
  width: fit-content;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .company-section-title {
    font-size: min(24px, 24 / 415 * 100vw);
  }
}

.company-page .company-info {
  padding-bottom: 80px;
}
@media screen and (max-width: 767px) {
  .company-page .company-info {
    padding-bottom: 40px;
  }
}
.company-page .company-info .inner {
  max-width: 1024px;
}
.company-page .company-info__table {
  margin-top: 30px;
}
@media screen and (max-width: 767px) {
  .company-page .company-info__table {
    margin-top: 24px;
  }
}
.company-page .company-info__row {
  display: flex;
  padding: 30px 16px;
  align-items: flex-start;
  gap: 24px;
  border-bottom: 1px solid #758CAD;
}
@media screen and (max-width: 767px) {
  .company-page .company-info__row {
    flex-direction: column;
    gap: 8px;
    padding: 20px 0;
  }
}
.company-page .company-info__label {
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 700;
  line-height: 28px;
  width: 210px;
  flex-shrink: 0;
}
@media screen and (max-width: 767px) {
  .company-page .company-info__label {
    font-size: min(15px, 15 / 415 * 100vw);
    line-height: 1.6;
    width: 100%;
  }
}
.company-page .company-info__value {
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 400;
  line-height: 28px;
  flex: 1;
}
@media screen and (max-width: 767px) {
  .company-page .company-info__value {
    font-size: min(15px, 15 / 415 * 100vw);
    line-height: 1.6;
  }
}
.company-page .company-info__value a:hover {
  text-decoration: underline;
}

.company-page .company-access {
  padding: 0 0 80px;
}
@media screen and (max-width: 767px) {
  .company-page .company-access {
    padding: 0 0 56px;
  }
}
.company-page .company-access .inner {
  max-width: 1024px;
}
.company-page .company-access__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  margin-top: 40px;
}
@media screen and (max-width: 767px) {
  .company-page .company-access__grid {
    grid-template-columns: 1fr;
    gap: 32px;
    margin-top: 24px;
  }
}
.company-page .company-access__name {
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 700;
  line-height: 28px;
  margin-bottom: 24px;
}
@media screen and (max-width: 767px) {
  .company-page .company-access__name {
    margin-bottom: 16px;
  }
}
.company-page .company-access__map {
  border-radius: 16px;
  overflow: hidden;
}
.company-page .company-access__map iframe {
  width: 100%;
  height: 329px;
  border: 0;
  display: block;
}
.company-page .company-access__address {
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 400;
  line-height: 28px;
  margin-top: 26px;
}
@media screen and (max-width: 767px) {
  .company-page .company-access__address {
    font-size: min(15px, 15 / 415 * 100vw);
    line-height: 1.6;
    margin-top: 16px;
  }
}

.company-page .company-achievement {
  padding: 0 0 80px;
}
@media screen and (max-width: 767px) {
  .company-page .company-achievement {
    padding: 0 0 56px;
  }
}
.company-page .company-achievement .inner {
  max-width: 1024px;
}
.company-page .company-achievement__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 94px;
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .company-page .company-achievement__body {
    gap: 40px;
    margin-top: 40px;
  }
}
.company-page .company-achievement__group {
  width: 100%;
}
.company-page .company-achievement__region {
  color: #1E3A8A;
  font-size: 32px;
  font-weight: 700;
  line-height: 32px;
  padding-bottom: 16px;
  border-bottom: 1px solid #FBC600;
}
@media screen and (max-width: 767px) {
  .company-page .company-achievement__region {
    font-size: min(24px, 24 / 415 * 100vw);
    line-height: 1.2;
    padding-bottom: 12px;
  }
}
.company-page .company-achievement__list {
  margin-top: 10px;
  padding-left: 45px;
}
@media screen and (max-width: 767px) {
  .company-page .company-achievement__list {
    padding-left: 26px;
  }
}
.company-page .company-achievement__list li {
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 700;
  line-height: 28px;
  list-style: disc;
}
@media screen and (max-width: 767px) {
  .company-page .company-achievement__list li {
    font-size: min(15px, 15 / 415 * 100vw);
    line-height: 1.6;
  }
}
.company-page .company-history {
  padding: 0 0 80px;
}
@media screen and (max-width: 767px) {
  .company-page .company-history {
    padding: 0 0 56px;
  }
}
.company-page .company-history .inner {
  max-width: 1024px;
}
.company-page .company-history__body {
  margin-top: 70px;
}
@media screen and (max-width: 767px) {
  .company-page .company-history__body {
    margin-top: 40px;
  }
}
.company-page .company-history__period + .company-history__period {
  margin-top: 94px;
}
@media screen and (max-width: 767px) {
  .company-page .company-history__period + .company-history__period {
    margin-top: 60px;
  }
}
.company-page .company-history__period-label {
  color: #1E3A8A;
  font-size: 32px;
  font-weight: 700;
  line-height: 32px;
  padding-bottom: 16px;
  border-bottom: 1px solid #FBC600;
}
@media screen and (max-width: 767px) {
  .company-page .company-history__period-label {
    font-size: min(24px, 24 / 415 * 100vw);
    line-height: 1.2;
    padding-bottom: 12px;
  }
}
.company-page .company-history__year-group {
  border-bottom: 1px solid #758CAD;
}
.company-page .company-history__row {
  display: flex;
  padding: 29px 16px;
  align-items: flex-start;
  gap: 24px;
}
@media screen and (max-width: 767px) {
  .company-page .company-history__row {
    flex-wrap: wrap;
    gap: 4px 0;
    padding: 20px 0;
  }
}
.company-page .company-history__row + .company-history__row {
  padding-top: 0;
}
.company-page .company-history__year {
  width: 185px;
  flex-shrink: 0;
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 700;
  line-height: 28px;
}
@media screen and (max-width: 767px) {
  .company-page .company-history__year {
    width: 100%;
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.6;
  }
}
.company-page .company-history__year:empty {
  display: none;
}
.company-page .company-history__month {
  width: 55px;
  flex-shrink: 0;
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 700;
  line-height: 28px;
}
@media screen and (max-width: 767px) {
  .company-page .company-history__month {
    width: 50px;
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.6;
  }
}
.company-page .company-history__content {
  flex: 1;
  color: #1E3A8A;
  font-size: 18px;
  font-weight: 400;
  line-height: 28px;
}
@media screen and (max-width: 767px) {
  .company-page .company-history__content {
    font-size: min(15px, 15 / 415 * 100vw);
    line-height: 1.6;
  }
}

.error404 .not-found-page {
  background: #f8fafc;
  padding-bottom: 96px;
}
@media screen and (max-width: 767px) {
  .error404 .not-found-page {
    padding-bottom: min(64px, 64 / 415 * 100vw);
  }
}
.error404 .not-found {
  margin-top: 56px;
}
@media screen and (max-width: 767px) {
  .error404 .not-found {
    margin-top: min(32px, 32 / 415 * 100vw);
  }
}
.error404 .not-found__panel {
  max-width: 900px;
  margin: 0 auto;
  border: 1px solid #dbe6f6;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 12px 24px rgba(30, 58, 138, 0.08);
  padding: 48px 56px;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .error404 .not-found__panel {
    padding: min(28px, 28 / 415 * 100vw) min(20px, 20 / 415 * 100vw);
  }
}
.error404 .not-found__status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  background: #dbeafe;
  color: #1d4ed8;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.03em;
}
@media screen and (max-width: 767px) {
  .error404 .not-found__status {
    min-width: min(88px, 88 / 415 * 100vw);
    min-height: min(32px, 32 / 415 * 100vw);
    padding: 0 min(12px, 12 / 415 * 100vw);
    font-size: min(13px, 13 / 415 * 100vw);
  }
}
.error404 .not-found__title {
  margin-top: 20px;
  color: #1e3a8a;
  font-size: 36px;
  font-weight: 900;
  line-height: 1.35;
}
@media screen and (max-width: 767px) {
  .error404 .not-found__title {
    margin-top: min(16px, 16 / 415 * 100vw);
    font-size: min(26px, 26 / 415 * 100vw);
  }
}
.error404 .not-found__text {
  margin-top: 16px;
  color: #475569;
  font-size: 16px;
  line-height: 1.9;
}
@media screen and (max-width: 767px) {
  .error404 .not-found__text {
    margin-top: min(14px, 14 / 415 * 100vw);
    font-size: min(14px, 14 / 415 * 100vw);
    line-height: 1.8;
  }
}
.error404 .not-found__actions {
  margin-top: 34px;
  display: flex;
  justify-content: center;
  gap: 12px;
}
@media screen and (max-width: 767px) {
  .error404 .not-found__actions {
    margin-top: min(24px, 24 / 415 * 100vw);
    flex-direction: column;
    gap: min(10px, 10 / 415 * 100vw);
  }
}
.error404 .not-found__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 220px;
  min-height: 52px;
  border-radius: 999px;
  padding: 0 24px;
  border: 1px solid #1e3a8a;
  background: #1e3a8a;
  color: #fff;
  font-size: 15px;
  font-weight: 700;
  line-height: 1;
  transition: opacity 0.2s ease;
}
.error404 .not-found__btn:hover {
  opacity: 0.85;
}
.error404 .not-found__btn.is-ghost {
  background: #fff;
  color: #1e3a8a;
}
@media screen and (max-width: 767px) {
  .error404 .not-found__btn {
    min-width: 100%;
    min-height: min(50px, 50 / 415 * 100vw);
    padding: 0 min(20px, 20 / 415 * 100vw);
    font-size: min(15px, 15 / 415 * 100vw);
  }
}

.c-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  text-align: center;
  font-size: 22.977px;
  font-weight: 900;
  max-width: 433px;
  width: 100%;
  height: 58px;
  margin: 0 auto;
  border-radius: 8px;
  color: #005eac;
  border: 0.479px solid #005eac;
  background: #fff;
}
@media screen and (max-width: 767px) {
  .c-btn {
    font-size: min(20px, 20 / 415 * 100vw);
    width: 80%;
    height: 50px;
  }
}
.c-btn:hover .c-btn__icon {
  transform: translateY(-50%) translateX(6px);
}
.c-btn__icon {
  position: absolute;
  right: 32px;
  top: 50%;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  transition: transform 0.2s ease;
  will-change: transform;
}
@media screen and (max-width: 767px) {
  .c-btn__icon {
    right: 20px;
  }
}

.fixed-button {
  position: fixed;
  right: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 112px;
  z-index: 80;
  transition: opacity 0.35s ease, transform 0.35s ease, visibility 0s linear 0.35s;
}
@media screen and (max-width: 767px) {
  .fixed-button {
    display: none;
  }
}
.fixed-button__link {
  display: block;
}
.fixed-button__close {
  appearance: none;
  background: transparent;
  border: 0;
  padding: 0;
  width: 37px;
  height: 37px;
  position: absolute;
  top: -14px;
  right: -14px;
  z-index: 2;
  cursor: pointer;
  transition: opacity 0.2s ease;
}
.fixed-button__close:hover {
  opacity: 0.85;
}
.fixed-button__close svg {
  display: block;
  width: 100%;
  height: 100%;
}
.fixed-button img {
  display: block;
  width: 100%;
  height: auto;
}
.fixed-button--after {
  right: 20px;
  bottom: 20px;
  top: auto;
  width: min(382px, 100vw - 40px);
  overflow: visible;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transform: translateY(12px);
}
@media screen and (max-width: 767px) {
  .fixed-button--after {
    right: 12px;
    bottom: 12px;
    width: min(260px, 100vw - 24px);
  }
}
.fixed-button--after .fixed-button__close {
  top: 18px;
  left: -8px;
  right: auto;
  z-index: 3;
}
.fixed-button--after.is-visible {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
  transition: opacity 0.35s ease, transform 0.35s ease, visibility 0s;
}
.fixed-button--after .fixed-button__link {
  transition: opacity 0.25s ease;
}
.fixed-button--after.is-visible .fixed-button__link:hover {
  opacity: 0.9;
}
.fixed-button--after.is-dismissed {
  display: none;
}
@media (prefers-reduced-motion: reduce) {
  .fixed-button {
    transition: none;
  }
  .fixed-button--after, .fixed-button--after.is-visible {
    transition: none;
    transform: translateY(0);
  }
}

/* ==============================================================================
# Footer CTA - NEXT STEP
============================================================================== */
.footer-cta {
  background: center/cover no-repeat url("../img/footer-cta/bg.webp");
  color: #fff;
  position: relative;
  overflow: hidden;
  padding: 100px 0;
}
@media screen and (max-width: 767px) {
  .footer-cta {
    padding: 60px 0;
  }
}
.footer-cta .inner {
  position: relative;
  z-index: 1;
}
.footer-cta {
  /* --------------------------------------------------
   * Header
   * -------------------------------------------------- */
}
.footer-cta__header {
  text-align: center;
  margin-bottom: 64px;
}
@media screen and (max-width: 767px) {
  .footer-cta__header {
    margin-bottom: 32px;
  }
}
.footer-cta__label {
  display: inline-block;
  margin-bottom: 18px;
  padding-bottom: 16px;
  border-bottom: 4px solid #fbc600;
  color: #D7DCE3;
  text-align: center;
  font-size: 64px;
  font-style: italic;
  font-weight: 900;
}
@media screen and (max-width: 767px) {
  .footer-cta__label {
    font-size: min(44px, 44 / 415 * 100vw);
    padding-bottom: 8px;
    border-bottom-width: 3px;
  }
}
.footer-cta__title {
  color: #FFF;
  text-align: center;
  font-size: 48px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 16px;
}
@media screen and (max-width: 767px) {
  .footer-cta__title {
    font-size: min(26px, 26 / 415 * 100vw);
  }
}
.footer-cta__lead {
  font-size: 18px;
  line-height: 1.62;
  color: #fff;
}
@media screen and (max-width: 767px) {
  .footer-cta__lead {
    font-size: min(14px, 14 / 415 * 100vw);
    text-align: left;
  }
}
.footer-cta {
  /* --------------------------------------------------
   * Grid (2 columns)
   * -------------------------------------------------- */
}
.footer-cta__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 32px;
  max-width: 1150px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .footer-cta__grid {
    grid-template-columns: 1fr;
    gap: 20px;
  }
}
.footer-cta {
  /* --------------------------------------------------
   * Panel (共通)
   * -------------------------------------------------- */
}
.footer-cta__panel {
  border-radius: 16px;
  border: 1px solid rgba(96, 165, 250, 0.3);
  background: rgba(37, 99, 235, 0.4);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(6px);
  padding: 32px;
  display: flex;
  flex-direction: column;
}
@media screen and (max-width: 767px) {
  .footer-cta__panel {
    padding: min(24px, 24 / 415 * 100vw) min(20px, 20 / 415 * 100vw);
  }
}
.footer-cta__panel-header {
  margin-bottom: 12px;
}
.footer-cta__panel-title {
  color: #FFF;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}
@media screen and (max-width: 767px) {
  .footer-cta__panel-title {
    font-size: min(20px, 20 / 415 * 100vw);
  }
}
.footer-cta__panel-title-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
}
.footer-cta__panel-subtitle {
  color: #BFDBFE;
  font-size: 14px;
  line-height: 1.42;
}
@media screen and (max-width: 767px) {
  .footer-cta__panel-subtitle {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.footer-cta {
  /* --------------------------------------------------
   * Cards (左パネル: 無料ツール)
   * -------------------------------------------------- */
}
.footer-cta__cards {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: auto;
}
.footer-cta__card {
  display: flex;
  align-items: center;
  gap: 14px;
  border-radius: 16px;
  border: 1px solid rgba(96, 165, 250, 0.3);
  background: rgba(37, 99, 235, 0.4);
  box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.25);
  backdrop-filter: blur(6px);
  padding: 32px;
  transition: all 0.3s ease;
}
.footer-cta__card:hover {
  opacity: 0.8;
  transform: translateY(-1px);
}
@media screen and (max-width: 767px) {
  .footer-cta__card {
    padding: min(20px, 20 / 415 * 100vw);
    gap: 12px;
  }
}
.footer-cta__card-icon {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.footer-cta__card-icon svg {
  width: 48px;
  height: 48px;
}
@media screen and (max-width: 767px) {
  .footer-cta__card-icon svg {
    width: 38px;
    height: 38px;
  }
}
.footer-cta__card-body {
  flex: 1;
  min-width: 0;
  color: #fff;
}
.footer-cta__card-title {
  margin: 0;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.56;
}
@media screen and (max-width: 767px) {
  .footer-cta__card-title {
    font-size: min(16px, 16 / 415 * 100vw);
  }
}
.footer-cta__card-desc {
  margin: 4px 0 0;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.34;
}
@media screen and (max-width: 767px) {
  .footer-cta__card-desc {
    font-size: min(12px, 12 / 415 * 100vw);
  }
}
.footer-cta {
  /* --------------------------------------------------
   * Consult body (右パネル: 導入相談)
   * -------------------------------------------------- */
}
.footer-cta__consult-body {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  flex: 1;
}
.footer-cta__checklist {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 34px;
  padding-left: 14px;
}
@media screen and (max-width: 767px) {
  .footer-cta__checklist {
    margin-bottom: 20px;
    gap: 10px;
    padding-left: 0;
  }
}
.footer-cta__checklist-item {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #DBEAFE;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.42;
}
@media screen and (max-width: 767px) {
  .footer-cta__checklist-item {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.footer-cta__check-icon {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
}
.footer-cta {
  /* CTA ボタン */
}
.footer-cta__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 20px 20px;
  border-radius: 12px;
  background: #2563EB;
  box-shadow: 0 0 0 4px rgba(59, 130, 246, 0.2), 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -4px rgba(0, 0, 0, 0.1);
  color: #FFF;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.55;
  text-decoration: none;
  border: none;
  cursor: pointer;
  transition: all 0.3s ease;
}
.footer-cta__btn:hover {
  background: #1d4ed8;
  transform: translateY(-2px);
}
@media screen and (max-width: 767px) {
  .footer-cta__btn {
    font-size: min(16px, 16 / 415 * 100vw);
    padding: 16px 20px;
  }
}
.footer-cta__btn-icon {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
}
.footer-cta {
  /* --------------------------------------------------
   * Tel
   * -------------------------------------------------- */
}
.footer-cta__tel {
  text-align: center;
  margin-top: 100px;
}
@media screen and (max-width: 767px) {
  .footer-cta__tel {
    margin-top: min(40px, 40 / 415 * 100vw);
  }
}
.footer-cta__tel-label {
  color: #fff;
  text-align: center;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.42;
  margin-bottom: 5px;
}
@media screen and (max-width: 767px) {
  .footer-cta__tel-label {
    font-size: min(14px, 14 / 415 * 100vw);
  }
}
.footer-cta__tel-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 26px;
  flex-wrap: wrap;
}
@media screen and (max-width: 767px) {
  .footer-cta__tel-row {
    flex-direction: column;
    gap: 10px;
  }
}
.footer-cta__tel-number {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  color: #FFF;
  text-align: center;
  font-size: 30px;
  font-weight: 700;
  line-height: 1.2;
  letter-spacing: 0.14em;
  transition: opacity 0.3s ease;
}
.footer-cta__tel-number:hover {
  opacity: 0.8;
}
@media screen and (max-width: 767px) {
  .footer-cta__tel-number {
    font-size: min(24px, 24 / 415 * 100vw);
    gap: 8px;
  }
}
.footer-cta__tel-icon {
  flex-shrink: 0;
  width: 30px;
  height: 30px;
}
@media screen and (max-width: 767px) {
  .footer-cta__tel-icon {
    width: 26px;
    height: 26px;
  }
}
.footer-cta__tel-hours {
  display: inline-block;
  color: #BFDBFE;
  text-align: center;
  font-size: 12px;
  font-weight: 400;
  line-height: 1.33;
  padding: 6px 16px;
  border-radius: 9999px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.1);
}
@media screen and (max-width: 767px) {
  .footer-cta__tel-hours {
    font-size: min(12px, 12 / 415 * 100vw);
    padding: 5px 14px;
  }
}

html {
  margin-top: 0 !important;
}

#wpadminbar {
  top: auto;
  bottom: 0;
  display: none;
}

img[src*="urlloger.cgi"] {
  position: absolute !important;
  width: 0 !important;
  height: 0 !important;
  max-width: 0 !important;
  opacity: 0 !important;
  pointer-events: none !important;
}