@charset "UTF-8";
/*----------------------------------------------------------------------------

 reset

----------------------------------------------------------------------------*/
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td {
  margin: 0;
  padding: 0;
}
address, caption, cite, code, dfn, em, strong, th, var {
  font-style: normal;
}
ul, ol {
  list-style-type: none;
}
em, strong, th, address {
  font-style: normal;
  font-weight: normal;
  text-align: left;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: normal;
  font-size: 100%;
}
img,
object,
embed {
  border: 0;
  vertical-align: top;
}
img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
hr {
  display: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
  font-size: 100%;
}
li {
  list-style-type: none;
}
strong {
  font-weight: bold;
}
*,
*::before,
*::after {
  box-sizing: border-box;
}
button{
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

/*----------------------------------------------------------------------------

 CSS Custom Properties 

----------------------------------------------------------------------------*/
:root {
  --primary-blue-color: #3490CF;
  --secondary-blue-color: #0072BC;
  --primary-color: #3490CF;
  --secondary-color: #71D7EB;
  --tertiary-color: #1E94E6;
  --primary-txt-color: #2C373F;
  --primary-bg-color: #EDF9FF;
  --white-color: #fff;
  --black-color: #000;
  --gray-color: #909090;
  --primary-gradient: linear-gradient(90deg, var(--tertiary-color) 0%, var(--secondary-color) 80%);
  --primary-gradient-reverse: linear-gradient(-90deg, var(--tertiary-color) 0%, var(--secondary-color) 80%);
  --primary-base-width: 1600;
  --primary-inner-width: 1280;
  --primary-inner-large-width: 1440;
  --scrollbar-size: 0px;
  --responsive-ratio: 0.70;
  --primary-padding: clamp(64px * var(--responsive-ratio), 64 / var(--primary-base-width) * 100vw, 64px);
  --section-padding-block: clamp(100px * var(--responsive-ratio), 100 / var(--primary-base-width) * 100vw, 100px);
  --section-padding-inline: clamp(100px * var(--responsive-ratio), 100 / var(--primary-base-width) * 100vw, 100px);
}
@media screen and (max-width: 1200px) {
  :root {
    --section-padding-inline: clamp(50px * var(--responsive-ratio), 50 / var(--primary-base-width) * 100vw, 50px);
  }
}
@media screen and (max-width: 991px) {
  :root {
    --section-padding-block: clamp(120px * var(--responsive-ratio), 120 / var(--primary-base-width) * 100vw, 120px);
    --section-padding-inline: clamp(40px * var(--responsive-ratio), 40 / var(--primary-base-width) * 100vw, 40px);
  }
}
@media screen and (max-width: 767px) {
  :root {
    --primary-padding: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    --primary-base-width: 375;
    --section-padding-block: clamp(80px, 80 / var(--primary-base-width) * 100vw, 100px);
    --section-padding-inline: 0;
    --responsive-ratio: 1.4;
  }
}

/*----------------------------------------------------------------------------

 base

----------------------------------------------------------------------------*/
html {
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%;
}
body {
  position: relative;
  color: var(--primary-txt-color);
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 400;
  line-height: 1;
  font-size: 1.6rem;
  background: var(--white-color);
  letter-spacing: 0.1em;
  font-feature-settings: "palt";
  -webkit-font-smoothing: antialiased;
}
body.resizing,
body.resizing *,
body.resizing *::before,
body.resizing *::after {
  transition: none !important;
  text-rendering: optimizeSpeed !important;
  font-feature-settings: normal !important;
  font-family: sans-serif;
  letter-spacing: 0.070em;
}

/*----------------------------------------------------------------------------

 layout 

----------------------------------------------------------------------------*/
.sp,
.sp_inline {
  display: none !important;
}
.pc {
  display: block !important;
}
.pc_inline {
  display: inline !important;
}
.layout-row {
  display: flex;
}
.site-common__lead {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: clamp(60px * var(--responsive-ratio), 60 / var(--primary-inner-width) * 100vw, 60px);
}
@media screen and (max-width: 767px) {
  .sp {
    display: block !important;
  }
  .sp_inline {
    display: inline !important;
  }
  .pc,
  .pc_inline {
    display: none !important;
  }
  .layout-row {
    flex-direction: column;
  }
  .site-common__lead {
    flex-direction: column;
    justify-content: flex-start;
    align-items: flex-start;
    width: min(310 / var(--primary-base-width) * 100vw, 310px * 1.6);
    margin-inline: auto;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
}

/*----------------------------------------------------------------------------

 section, title, text

----------------------------------------------------------------------------*/
.site-common__section {
  padding-block: var(--section-padding-block);
}
.site-common__outer {
  padding-inline: var(--section-padding-inline);
}
.site-common__inner {
  width: min(100%, var(--primary-inner-width) * 1px);
  margin-inline: auto;
}
.site-section__title  {
  margin-bottom: 1em;
  /* font-size: clamp(5.6rem * var(--responsive-ratio), (56 / var(--primary-inner-width) * 100vw), 5.6rem); */
  font-size: clamp(4.8rem * var(--responsive-ratio), (48 / var(--primary-inner-width) * 100vw), 4.8rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.15em;
}
.site-section__title-en {
  display: flex;
  align-items: center;
  gap: 0.75em;
  margin-bottom: 1.2em;
  color: var(--primary-color);
  font-size: clamp(1.8rem * var(--responsive-ratio), (18 / var(--primary-inner-width) * 100vw), 1.8rem);
  font-weight: 800;
  letter-spacing: 0.15em;
}
.site-section__title-en::before {
  content: '';
  width: calc(10 / 18 * 1em);
  height: calc(10 / 18 * 1em);
  border-radius: 100vmax;
  background: var(--primary-gradient);
  transform: translateY(0.1em);
}
.title--primary {
  margin-bottom: 1em;
  color: var(--primary-color);
  font-size: clamp(2.4rem * var(--responsive-ratio), (24 / var(--primary-inner-width) * 100vw), 2.4rem);
  font-weight: 700;
  line-height: 170%;
  letter-spacing: 0.1em;
}
.title--secondary {
  margin-bottom: 1em;
  color: var(--primary-color);
  font-size: clamp(2.0rem * var(--responsive-ratio), (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.1em;
}
.txt--primary {
  font-size: clamp(1.6rem * var(--responsive-ratio), (16 / var(--primary-inner-width) * 100vw), 1.6rem);
  font-weight: 400;
  line-height: 170%;
  letter-spacing: 0.1em;
  text-align: justify;
}
.txt--primary + .txt--primary {
  margin-top: 1.8em;
}
.txt--secondary {
  font-size: clamp(1.5rem * var(--responsive-ratio), (17 / var(--primary-inner-width) * 100vw), 1.5rem);
  font-weight: 400;
  line-height: 170%;
  letter-spacing: 0.1em;
  text-align: justify;
}
.txt--secondary + .txt--secondary {
  margin-top: 1.8em;
}
.txt--note {
  font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
  font-weight: 400;
  line-height: 160%;
  letter-spacing: 0.1em;
  text-align: justify;
}
.txt--secondary + .txt--secondary {
  margin-top: 1.8em;
}
.txt--midashi {
  font-size: clamp(2.2rem * var(--responsive-ratio), (22 / var(--primary-inner-width) * 100vw), 2.2rem);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.15em;
}
.txt--oomidashi {
  font-size: clamp(3.6rem * var(--responsive-ratio), (36 / var(--primary-inner-width) * 100vw), 3.6rem);
  font-weight: 700;
  line-height: 125%;
  letter-spacing: 0.15em;
}
.txt--komidashi {
  font-size: clamp(1.8rem * var(--responsive-ratio), (18 / var(--primary-inner-width) * 100vw), 1.8rem);
  font-weight: 400;
  line-height: 170%;
  letter-spacing: 0.1em;
  text-align: justify;
}
.txt--komidashi + .txt--komidashi {
  margin-top: 1.8em;
}
.txt--logo-blue {
  color: var(--primary-blue-color);
}
.txt--indent {
  padding-left: 1.2em;
  text-indent: -1.2em;
}
.txt--indent > .txt--indent_icon {
  display: inline-block;
  width: 1.2em;
  text-indent: 0;
}
.txt--gradient {
  display: inline;
  box-decoration-break: clone;
  -webkit-box-decoration-break: clone;
  background: linear-gradient(to right, rgb(30, 148, 230) 0%, rgb(113, 215, 235) 80%); /* 左から右へ */
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
@media screen and (max-width: 767px) {
  .site-common__inner {
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
    margin-inline: auto;
  }
  .page-title__inner.site-common__inner {
    width: min(310 / var(--primary-base-width) * 100vw, 310px * 1.6);
  }
  .title--primary {
    margin-bottom: 1em;
    font-size: min(18 / var(--primary-base-width) * 100vw, 1.8rem * var(--responsive-ratio));
    line-height: 150%;
    letter-spacing: 0.15em;
  }
  .title--secondary {
    margin-bottom: 1em;
    font-size: min(16 / var(--primary-base-width) * 100vw, 1.6rem * var(--responsive-ratio));
  }
  .txt--primary {
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
    line-height: 165%;
    letter-spacing: 0.05em;
  }
  .txt--secondary {
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    line-height: 165%;
    letter-spacing: 0.1em;
  }
  .txt--secondary + .txt--secondary {
    margin-top: 1.8em;
  }
  .txt--midashi {
    font-size: min(18 / var(--primary-base-width) * 100vw, 1.8rem * var(--responsive-ratio));
  }
  .txt--oomidashi {
    font-size: min(28 / var(--primary-base-width) * 100vw, 2.8rem * var(--responsive-ratio));
  }
  .txt--komidashi {
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
    line-height: 165%;
    letter-spacing: 0.05em;
  }
  .txt--note {
    font-size: min(11 / var(--primary-base-width) * 100vw, 1.1rem * var(--responsive-ratio));
    line-height: 165%;
    letter-spacing: 0.05em;
  }
  .site-section__title {
    width: min(310 / var(--primary-base-width) * 100vw, 310px * 1.6);
    margin-inline: auto;
    margin-bottom: calc(35 / 36 * 1em);
    font-size: min(36 / var(--primary-base-width) * 100vw, 3.6rem * var(--responsive-ratio));
    letter-spacing: 0.15em;
  }
  .site-section__title-en {
    gap: 0.75em;
    margin-bottom: 1.5em;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    letter-spacing: 0.15em;
  }
  .site-section__title-en::before {
    width: calc(10 / 15 * 1em);
    height: calc(10 / 15 * 1em);
    transform: translateY(0.1em);
  }
}

/*----------------------------------------------------------------------------

 parts

----------------------------------------------------------------------------*/
.site-common__link {
  display: inline-flex;
  align-items: center;
  gap: 0.75em;
}
.site-common__link-icon {
  position: relative;
  width: calc(25 / 20 * 1em);
  aspect-ratio: 1 / 1;
  background-color: rgba(113,215,235,0.3);
  border-radius: 100vmax;
}
.site-common__link-icon::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(7 / 25 * 100%);
  aspect-ratio: 1 / 1;
  background: var(--primary-gradient);
  transform: translate(-50%, -50%);
  border-radius: 100vmax;
  z-index: 1;
  transition: width .4s ease-out;
}
.site-common__link-icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(7 / 25 * 100%);
  aspect-ratio: 5 / 12;
  background: url(../img/icon_arrow_right_white.svg) no-repeat center / contain;
  pointer-events: none;
  translate: -80% -50%;
  opacity: 0;
  transition: translate .2s ease-out, opacity .2s ease-out;
  z-index: 1;
}
@media (hover: hover) and (pointer: fine) {
  .site-common__link:hover .site-common__link-icon::before {
    width: 100% !important;
  }
  .site-common__link:hover .site-common__link-icon::after {
    opacity: 1;
    translate: -40% -50%;
    transition: translate .4s ease-out .2s, opacity .2s ease-out .2s;
  }
}
.site-common__txt--bg--primary {
  padding: 0.30em 0.40em 0.40em;
  color: var(--white-color);
  background-image: var(--primary-gradient);
  border-radius: 5px;
}
.site-common__txt--bg--primary.bg-reverse {
  background-image: var(--primary-gradient-reverse);
}
.button--primary,
.button--secondary {
  position: relative;
  display: inline-flex;
  justify-content: flex-start;
  align-items: center;
  width: calc(370 / 18 * 1em);
  aspect-ratio: 370 / 80;
  padding-inline: calc(40 / 18 * 1em) calc(70 / 18 * 1em);
  color: var(--white-color);
  font-size: clamp(1.8rem * var(--responsive-ratio), (18 / var(--primary-inner-width) * 100vw), 1.8rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
  text-decoration: none;
  border-radius: 100vmax;
  background-image: var(--primary-gradient);
  transition: opacity .3s ease-out;
  overflow: clip;
  z-index: 1;
}
.button--secondary {
  color: var(--primary-blue-color);
  background-color: #fff;
}
.button--secondary::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border-radius: 100vmax;
  z-index: -1;
}
.button--secondary::before {
  border: 2px solid transparent;
  background-color: #fff;
  background-origin: border-box;
  background-clip: border-box;
  /* WebKit */
  -webkit-mask-image:
    linear-gradient(#fff 0 0),
    linear-gradient(#fff 0 0);
  -webkit-mask-clip: border-box, padding-box;
  -webkit-mask-composite: destination-in;
  /* Standard */
  mask-image:
    linear-gradient(#fff 0 0),
    linear-gradient(#fff 0 0);
  mask-clip: border-box, padding-box;
  mask-composite: intersect;
}
.button--secondary .bg {
  display: none;
}
.button--primary__icon,
.button--secondary__icon {
  position: absolute;
  display: inline-block;
  top: 50%;
  right: 8.8%;
  width: min(9.4%, 30px);
  aspect-ratio: 1 / 1;
  background-color: rgba(255,255,255,.30);
  transform: translateY(-50%);
  border-radius: 100vmax;
  z-index: -1;
}
.button--primary__icon::before,
.button--secondary__icon::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(8 / 30 * 100%);
  aspect-ratio: 1 / 1;
  background-color: rgba(255,255,255,1);
  transform: translate(-50%, -50%);
  border-radius: 100vmax;
  z-index: 1;
  transition: width .4s ease-out;
}
.button--primary__icon.min::before,
.button--secondary__icon.min::before {
  width: calc(10 / 30 * 100%);
}
.button--secondary__icon {
  background-color: rgba(113,215,235,0.3);
}
.button--secondary__icon::before {
  background: var(--primary-gradient);
}
.button--primary__icon::after,
.button--secondary__icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(8 / 30 * 100%);
  aspect-ratio: 5 / 12;
  background: url(../img/icon_arrow_right_blue.svg) no-repeat center / contain;
  pointer-events: none;
  translate: -80% -50%;
  opacity: 0;
  transition: translate .2s ease-out, opacity .2s ease-out;
  z-index: 1;
}
.button--secondary__icon::after {
  background: url(../img/icon_arrow_right_white.svg) no-repeat center / contain;
}
@media (hover: hover) and (pointer: fine) {
  .button--primary:hover .button--primary__icon::before,
  .button--secondary:hover .button--secondary__icon::before,
  .contact-form__form-btn-submit:hover .button--primary__icon::before {
    width: 100% !important;
  }
  .button--primary:hover .button--primary__icon::after,
  .button--secondary:hover .button--secondary__icon::after,
  .contact-form__form-btn-submit:hover .button--primary__icon::after {
    opacity: 1;
    translate: -40% -50%;
    transition: translate .4s ease-out .2s, opacity .2s ease-out .2s;
  }
}

@media screen and (max-width: 767px) {
  .button--primary,
  .button--secondary {
    width: calc(310 / 16 * 1em);
    aspect-ratio: 310 / 70;
    padding-inline: calc(30 / 16 * 1em) calc(50 / 16 * 1em);
    font-size: calc(1.6rem / var(--primary-base-width) * 100vw);
    font-weight: 700;
    line-height: 1;
    letter-spacing: 0.1em;
    text-decoration: none;
    border-radius: 100vmax;
    background-image: var(--primary-gradient);
    transition: opacity .3s ease-out;
    overflow: clip;
    z-index: 1;
  }
  .button--primary__icon,
  .button--secondary__icon {
    right: 20px;
    width: 20px;
  }
  .button--primary__icon::before,
  .button--secondary__icon::before {
    width: 6px;
  }
  .button--primary__icon.min::before,
  .button--secondary__icon.min::before {
    width: calc(10 / 30 * 100%);
  }
  .site-common__link::before {
    width: calc(20 / 15 * 1em);
  }
}

/*----------------------------------------------------------------------------

 共通 タブ切り替え

----------------------------------------------------------------------------*/
.site-common__tab-container {
  position: relative;
}
.site-common__tab-menu {
  display: flex;
}
.site-common__tab-wrap {
  position: relative;
}
.site-common__tab-item {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 0;
  opacity: 0;
  visibility: hidden;
  overflow-y: clip;
  transition: opacity 0.5s ease, transform 0.5s ease;
  transform: translateY(10px);
  pointer-events: none;
}
.site-common__tab-item.active {
  position: relative;
  height: auto;
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}
.qa__tab-content-item-contents-list dt {
  font-weight: 700;
  cursor: pointer;
}
.qa__tab-content-item-contents-list dd {
  pointer-events: none;
  overflow: hidden;
}
.qa__tab-content-item-contents-list .dd-wrap.active dd {
  pointer-events: auto;
}

/*----------------------------------------------------------------------------

 共通 リスト

----------------------------------------------------------------------------*/
.site-common__list-item {
  position: relative;
  background-color: #fff;
  transform: translate3d(0,0,0);
  z-index: 1;
}
.site-common__list-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: linear-gradient(150deg, var(--primary-color) 0%, var(--secondary-color) 80%);
  border-radius: 30px;
  filter: blur(8px);
  opacity: 0.5;
  z-index: -2;
  pointer-events: none;
}
.site-common__list-item::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  border-radius: 30px;
  z-index: -1;
  pointer-events: none;
}
.site-common__list-item a {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: min(20 / var(--primary-inner-width) * 100vw, 20px);
  height: 100%;
  padding: min(20 / var(--primary-inner-width) * 100vw, 20px);
  padding-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  text-decoration: none;
}
.site-common__list-item-thumbnail {
  width: 100%;
  min-height: 0;
  aspect-ratio: 360 / 234;
  border-radius: 20px;
  overflow: clip;
  border: 1px solid #dfdfdf;
}
.site-common__list-item-thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
    transition: scale .4s ease-in-out;
}
@media (hover: hover) and (pointer: fine) {
  .site-common__list-item a:hover .site-common__list-item-thumbnail img {
    scale: 1.05;
    transition: scale .4s ease-in-out .1s;
  }
}
.site-common__list-item-body {
  flex: 1;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  padding-inline: 10px;
}
.site-common__list-item-body .title--secondary {
  margin-bottom: 0.5em;
}
.site-common__list-more-wrap {
  margin-top: min(80 / var(--primary-inner-width) * 100vw, 80px);
  margin-bottom: min(100 / var(--primary-inner-width) * 100vw, 100px);
  text-align: center;
}
.site-common__list-more-btn {
  position: relative;
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: min(15 / var(--primary-inner-width) * 100vw, 15px);
  color: var(--primary-color);
  text-decoration: none;
  cursor: pointer;
  transition: color 0.3s ease;
}
.site-common__list-more-btn::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  scale: 1 .5;
  background-color: var(--primary-color);
  transition: background-color 0.3s ease;
}
.site-common__list-more-icon {
  width: 3px;
  aspect-ratio: 3 / 21;
  line-height: 1;
  mask-image: url(/assets/img/dots_blue.svg);
	mask-size: contain;
	mask-repeat: no-repeat;
	mask-position: center;
  background-color: var(--primary-color);
  transition: background-color 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .site-common__list-more-btn:hover .site-common__list-more-icon {
    background-color: var(--secondary-blue-color);
  }
  .site-common__list-more-btn:hover {
    color: var(--secondary-blue-color);
  }
  .site-common__list-more-btn:hover::after {
    background-color: var(--secondary-blue-color);
  }
}
@media screen and (max-width: 767px) {
  .site-common__list-item::before {
    border-radius: 30px;
  }
  .site-common__list-item::after {
    border-radius: 30px;
  }
  .site-common__list-item a {
    gap: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    padding: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    padding-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .site-common__list-item {
    width: calc(290 / var(--primary-base-width) * 100vw) !important;
    margin-left: 15px;
  }
  .site-common__list-item-thumbnail {
    aspect-ratio: 260 / 170;
    border-radius: 20px;
  }
  .site-common__list-item-body {
    padding-inline: min(5 / var(--primary-base-width) * 100vw, 5px * var(--responsive-ratio));
  }
  .site-common__list-more-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .site-common__list-more-btn {
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
  }

}

/*----------------------------------------------------------------------------

 共通 ダウンロードブロック

----------------------------------------------------------------------------*/
.site-common__download {
  position: relative;
  padding-block: min(80 / var(--primary-inner-width) * 100vw, 80px);
  background: var(--secondary-blue-color);
  border-radius: min(70 / var(--primary-inner-width) * 100vw, 70px);
}
.site-common__download-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: min(1096 / var(--primary-inner-large-width) * 100vw, 1096px);
  margin-inline: auto;
  color: #fff;
  --site-common__download-inner-width: 1096;
  container-type: inline-size;
}
.site-common__download-title {
  margin-top: -0.25em;
  margin-bottom: 0.75em;
  font-size: calc(36 / var(--site-common__download-inner-width) * 100cqi);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.1em;
  white-space: nowrap;
}
.site-common__download-img {
  width: calc(544 / var(--site-common__download-inner-width) * 100cqi);
}
.site-common__download-body {
  width: calc(510 / var(--site-common__download-inner-width) * 100cqi);
}
.button-2 .site-common__download-inner {
  width: min(1174 / var(--primary-inner-large-width) * 100vw, 1174px);
  --site-common__download-inner-width: 1174;
  container-type: inline-size;
}
.button-2 .site-common__download-inner .site-common__download-img {
  width: calc(544 / var(--site-common__download-inner-width) * 100cqi);
}
.button-2 .site-common__download-inner .site-common__download-body {
  width: calc(580 / var(--site-common__download-inner-width) * 100cqi);
}
.site-common__download-text.txt--primary {
  font-size: calc(16 / var(--site-common__download-inner-width) * 100cqi);
}
.site-common__download-link-wrap {
  display: flex;
  gap: calc(20 / var(--site-common__download-inner-width) * 100cqi);
  margin-top: calc(35 / var(--site-common__download-inner-width) * 100cqi);
}
.site-common__download-link-wrap .site-common__download-link {
  width: calc(280 / var(--site-common__download-inner-width) * 100cqi);
  aspect-ratio: 280 / 80;
  font-size: calc(18 / var(--site-common__download-inner-width) * 100cqi);
}
.site-common__download-link-wrap .site-common__download-link:first-of-type {
  outline: 3px solid rgb(255, 255, 255);
  outline-offset: -3px;
}
@media screen and (max-width: 991px) {
  .button-2 .site-common__download-link {
    white-space: nowrap;
  }
}
@media screen and (max-width: 767px) {
  .site-common__download {
    width: min(340 / var(--primary-base-width) * 100vw, 340px * 1.6);
    margin-inline: auto;
    padding-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-block: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    border-radius: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    translate: max(-10 / var(--primary-base-width) * 100vw, -10px * 1.6) 0;
  }
  .site-common__download-inner {
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    width: 100% !important;
  }
  .site-common__download-img {
    width: min(286 / var(--primary-base-width) * 100vw, 286px * 1.6) !important;
    padding: 0 !important;
  }
  .site-common__download-body {
    width: 100% !important;
    translate: 0 0 !important;
  }
  .site-common__download-title {
    margin-top: 0;
    margin-bottom: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    font-size: min(24 / var(--primary-base-width) * 100vw, 2.4rem * var(--responsive-ratio));
    line-height: 160%;
    text-align: center;
  }
  .site-common__download-img {
    width: min(240 / var(--primary-base-width) * 100vw, 240px * var(--responsive-ratio));
    padding: 0;
  }
  .site-common__download-text.txt--primary {
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    line-height: 150%;
  }
  .site-common__download-link-wrap {
    justify-content: center;
    flex-direction: column;
    align-items: center;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    margin-top: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
  }
  .site-common__download-text {
    text-align: center;
  }
  .site-common__download-link-wrap .site-common__download-link {
    width: calc(280 / 16 * 1em);
    aspect-ratio: 280 / 70;
    font-size: min(16 / var(--primary-base-width) * 100vw, 1.6rem * var(--responsive-ratio));
  }
  .site-common__download-link-wrap .site-common__download-link:first-of-type {
    outline: 3px solid rgb(255, 255, 255);
    outline-offset: -3px;
  }
}

/*-------------------------------------------------

 メールフォーム関連

--------------------------------------------------*/
.contact-form__title {
  margin-bottom: var(--primary-padding);
  color: var(--primary-blue-color);
  text-align: center;
}
.contact-form__form-wrap {
  width: min(930 / var(--primary-inner-width) * 100vw, 930px);
  margin-inline: auto;
  font-size: clamp(1.6rem * var(--responsive-ratio), (16 / var(--primary-inner-width) * 100vw), 1.6rem);
  line-height: 170%;
  --form-wrap-width: 930;
}
.contact-form__step-list {
  display: flex;
  margin-bottom: var(--primary-padding);
  background-color: var(--primary-bg-color);
  border-radius: 10px 0 0 10px;
  overflow: hidden;
}
.contact-form__step-item {
  position: relative;
  display: grid;
  place-content: center;
  width: 50%;
  height: calc(50 / 17 * 1em);
  color: var(--primary-blue-color);
  font-weight: 700;
  text-align: center;
}
.contact-form__step-item.active {
  color: var(--white-color);
  background-color: var(--primary-blue-color);
}
.contact-form__step-item::before,
.contact-form__step-item::after {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: calc(20 / 465 * 100%);
  height: 100%;
  background-color: var(--primary-bg-color);
  z-index: 1;
  transform: translateX(50%);
}
.contact-form__step-item.active::before {
  background-color: var(--primary-bg-color);
}
.contact-form__step-item::after {
  background-color: var(--primary-blue-color);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%, 100% 50%);
  transform: translateX(54%);
}
.contact-form__step-item.active::after {
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
  transform: translateX(50%);
}
.contact-form__step-item + .contact-form__step-item::before,
.contact-form__step-item + .contact-form__step-item::after {
  right: 0;
  left: auto;
  background-color: var(--white-color);
  transform: translateX(0);
}
.contact-form__step-item + .contact-form__step-item::after {
  background-color: var(--primary-bg-color);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
.contact-form__step-item + .contact-form__step-item.active::after {
  background-color: var(--primary-blue-color);
}
.site-common__form .contact-form__form {
  margin-bottom: var(--primary-padding);
}
.site-common__form .contact-form__form-item {
  display: flex;
  align-items: center;
  gap: min(30 / var(--form-wrap-width) * 100vw, 30px);
  margin-bottom: min(50 / var(--form-wrap-width) * 100vw, 50px);
}
.site-common__form .contact-form__form-item--textarea {
  align-items: flex-start;
}
.site-common__form .contact-form__form-item-title {
  width: min(180 / var(--form-wrap-width) * 100vw, 180px);
  font-weight: 700;
}
.site-common__form .contact-form__form-item--textarea .contact-form__form-item-title {
  padding-top: 1em;
}
.site-common__form .contact-form__form-item-title .title--optional {
  display: inline-block;
  margin-left: 1em;
  padding: 0.2em 0.3em 0.2em 0.4em;
  color: var(--primary-blue-color);
  font-size: calc(12 / 16 * 1em);
  font-weight: 400;
  line-height: 1;
  border: 1px solid var(--primary-blue-color);
}
.contact-form__form-item-input-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  gap: min(15 / var(--form-wrap-width) * 100vw, 15px);
}
.contact-form__form-item-input-wrap.flex-column {
  flex-direction: column;
  align-items: flex-start;
  gap: min(10 / var(--form-wrap-width) * 100vw, 10px);
}
.contact-form__form-item-input-wrap.radio-wrap {
  flex-wrap: wrap;
  gap: min(20 / var(--form-wrap-width) * 100vw, 20px) min(40 / var(--form-wrap-width) * 100vw, 40px);
}
.site-common__form input[type=text],
.site-common__form textarea {
  width: 100%;
  padding: 1.15em;
  color: var(--primary-txt-color);
  font-size: 1.6rem;
  line-height: 1;
  border-radius: 100vmax;
  border: 1px solid var(--primary-txt-color);
}
.site-common__form textarea {
  aspect-ratio: 720 / 240;
  border-radius: min(30 / var(--form-wrap-width) * 100vw, 30px);
  line-height: 145%;
}
.contact-form__form-item-input.short-form {
  width: calc(200 / 16 * 1em);
}
.site-common__form input[type=text]::placeholder {
  color: var(--gray-color);
}
.site-common__form select {
  padding: 1.15em;
  padding-right: 3.0em;
  color: var(--primary-txt-color);
  font-size: 1.6rem;
  line-height: 1;
  border-radius: 100vmax;
  border: 1px solid var(--primary-txt-color);
  -webkit-appearance: none;
  appearance: none;
  background-image: url('data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 24 24%27%3E%3Cdefs%3E%3ClinearGradient id=%27g%27 x1=%27-0.3%27 y1=%2712.2%27 x2=%2724.3%27 y2=%2711.6%27 gradientTransform=%27translate(0 23.9) scale(1 -1)%27 gradientUnits=%27userSpaceOnUse%27%3E%3Cstop offset=%270%27 stop-color=%27%231e94e6%27/%3E%3Cstop offset=%270.8%27 stop-color=%27%2371d7eb%27/%3E%3C/linearGradient%3E%3C/defs%3E%3Ccircle cx=%2712%27 cy=%2712%27 r=%2712%27 fill=%27url(%23g)%27/%3E%3Cpath fill=%27%23fff%27 d=%27M12 16.5c-.3 0-.6-.1-.9-.4l-4.7-4.2c-.5-.5-.5-1.2 0-1.7.5-.5 1.2-.5 1.7 0l3.9 3.6 3.9-3.6c.5-.5 1.2-.5 1.7 0 .5.5.5 1.2 0 1.7l-4.7 4.2c-.3.3-.6.4-.9.4Z%27/%3E%3C/svg%3E');
  background-repeat: no-repeat;
  background-position: right 0.75em center;
  background-size: 1.25em 1.25em;
  background-color: #fff;
  cursor: pointer;
}
.contact-form__form-item-radio-label,
.contact-form__form-item-checkbox-label {
  display: inline-flex;
  align-items: center;
  column-gap: 0.6em;
  width: fit-content;
  line-height: 1;
  white-space: nowrap;
  cursor: pointer;
}
.contact-form__form-item-radio,
.contact-form__form-item-checkbox {
  appearance: none;
  position: relative;
  width: 20px;
  height: 20px;
  border: 1px solid var(--primary-blue-color);
  border-radius: 100vmax;
  cursor: pointer;
}
.contact-form__form-item-radio:checked,
.contact-form__form-item-checkbox:checked {
  border: none;
  background-image: var(--primary-gradient);
}
.contact-form__form-item-radio:checked::after,
.contact-form__form-item-checkbox:checked::after {
  content: "";
  position: absolute;
  inset: 0;
  width: 10px;
  height: 10px;
  margin: auto;
  border-radius: 100vmax;
  background-color: #ffffff;
}
.contact-form__agreement {
  margin-bottom: var(--primary-padding);
}
.contact-form__agreement-title {
  margin-bottom: 2.0em;
  text-align: center;
}
.contact-form__agreement-title a {
  color: var(--secondary-blue-color);
}
.contact-form__agreement-content {
  margin-bottom: min(50 / var(--form-wrap-width) * 100vw, 50px);
  padding: min(40 / var(--form-wrap-width) * 100vw, 40px);
  border-radius: min(30 / var(--form-wrap-width) * 100vw, 30px);
  border: 1px solid var(--primary-txt-color);
}
.contact-form__agreement-checkbox {
  text-align: center;
}
.contact-form__form-btn {
  text-align: center;
}
.contact-form__form-btn-wrap {
  display: inline-block;
  position: relative;
  border-radius: 100vmax;
  background-image: var(--primary-gradient);
  overflow: clip;
  z-index: 1;
}
.contact-form__form-btn-wrap .contact-form__form-btn-submit {
  display: inline-flex;
  justify-content: flex-start;
  align-items: center;
  width: calc(370 / 18 * 1em);
  aspect-ratio: 370 / 80;
  font-size: clamp(1.8rem * var(--responsive-ratio), (18 / var(--primary-inner-width) * 100vw), 1.8rem);
  padding-inline: calc(40 / 18 * 1em) calc(70 / 18 * 1em);
  color: var(--white-color);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.1em;
  text-decoration: none;
}
.contact-form__form-complete-title {
  margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  color: var(--primary-blue-color);
  font-weight: 700;
  text-align: center;
}
.contact-form__form-complete-content {
  margin-bottom: var(--primary-padding);
}
.contact-form__form-complete-content p {
  text-align: center;
}
.contact-form__other-link {
  margin-bottom: var(--primary-padding);
  padding: min(40 / var(--form-wrap-width) * 100vw, 40px);
  color: var(--primary-blue-color);
  border: 1px solid var(--primary-blue-color);
  border-radius: min(30 / var(--form-wrap-width) * 100vw, 30px);
}
.contact-form__other-link p {
  text-align: center;
}
.contact-form__other-link-list {
  display: flex;
  justify-content: center;
  gap: min(50 / var(--form-wrap-width) * 100vw, 50px);
  margin-top: min(50 / var(--form-wrap-width) * 100vw, 50px);
}
.contact-form__other-link-list .site-common__link {
  color: var(--primary-blue-color);
  font-weight: 700;
  text-decoration: none;
}
.contact-form__form-btn-return {
  text-align: center;
}
@media screen and (max-width: 767px) {
  .contact-form__step-list {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    border-radius: 5px 0 0 5px;
  }
  .contact-form__step-item {
    height: calc(30 / 13 * 1em);
  }
  .contact-form__step-item::before,
  .contact-form__step-item::after {
    width: calc(10 / 13 * 1em);
  }
  .contact-form__form-wrap {
    width: min(310 / var(--primary-base-width) * 100vw, 310px * 1.6);
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    line-height: 170%;
    --form-wrap-width: 930;
  }
  .site-common__form .contact-form__form {
    width: min(290 / var(--primary-base-width) * 100vw, 290px * 1.6);
    margin-inline: auto;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .site-common__form .contact-form__form-item {
    flex-direction: column;
    align-items: flex-start;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .site-common__form .contact-form__form-item-title {
    width: auto;
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
  .contact-form__form-item-input-wrap.radio-wrap {
    display: grid;
    grid-template-columns: 1fr;
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .contact-form__form-item-radio-label, .contact-form__form-item-checkbox-label {
    column-gap: 0.6em;
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
  .contact-form__form-item-radio, .contact-form__form-item-checkbox {
    width: 16px;
    height: 16px;
  }
  .contact-form__form-item-radio:checked::after,
  .contact-form__form-item-checkbox:checked::after {
    width: 8px;
    height: 8px;
  }
  .contact-form__form-item-input-wrap.flex-column {
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
  }
  .site-common__form input[type=text] {
    width: 100%;
    padding: 0.85em 1.5em;
    font-size: 1.6rem;
  }
  .site-common__form textarea {
    aspect-ratio: 290 / 240;
    border-radius: 20px;
  }
  .site-common__form select {
    width: 100%;
    padding: 0.85em 1.5em;
  }
  .site-common__form input[type=text]::placeholder {
    font-size: calc(13 / 16 * 1em);
  }
  .contact-form__form-item-input-wrap {
    width: 100%;
    gap: 15px;
  }
  .contact-form__form-item-input.short-form {
    width: calc(250 / 16 * 1em);
  }
  .contact-form__agreement {
    width: min(290 / var(--primary-base-width) * 100vw, 290px * 1.6);
    margin-inline: auto;
    margin-bottom: var(--primary-padding);
  }
  .contact-form__agreement-title {
    margin-bottom: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    text-align: left;
  }
  .contact-form__agreement-content {
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .contact-form__form-btn-wrap .contact-form__form-btn-submit {
    width: 100%;
    aspect-ratio: 310 / 70;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    padding-inline: calc(40 / 18 * 1em) calc(70 / 18 * 1em);
  }
  .contact-form__form-btn-wrap {
    width: 100%;
  }
  .contact-form__form-complete-content p {
    text-align: left;
  }
  .contact-form__form-complete-title {
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
  .contact-form__form-complete-content {
    width: min(290 / var(--primary-base-width) * 100vw, 290px * 1.6);
    margin-inline: auto;
  }
  .contact-form__other-link {
    padding: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    border-radius: 30px;
    text-align: center;
  }
  .contact-form__other-link-list {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
}

/*----------------------------------------------------------------------------

 下層ページ

----------------------------------------------------------------------------*/
.page-common__section-lead {
  margin-bottom: var(--primary-padding);
}
.page-common__section .site-common__inner {
  position: relative;
  padding-top: var(--primary-padding);
  padding-bottom: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
}
.page-common__section + .page-common__section .site-common__inner::after {
  content: '';
  position: absolute;
  top: 0;
  left:0;
  width: 100%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.page-title {
  
}
.page-title__outer {
  padding-top: min(150 / var(--primary-base-width) * 100vw, 150px);
  padding-bottom: clamp(50px * var(--responsive-ratio), 50 / var(--primary-inner-width) * 100vw, 50px);
}
.page-title__main {
  width: min(1440 / var(--primary-base-width) * 100vw, 1440px);
  margin: auto;
  padding: min(60 / var(--primary-inner-width) * 100vw, 60px) min(80 / var(--primary-inner-width) * 100vw, 80px);
  color: var(--white-color);
  border-radius: min(50 / var(--primary-inner-width) * 100vw, 50px);
  background-image: var(--primary-gradient);
}
.page-title__main-title {
  display: inline-block;
  margin-bottom: 0.8em;
  font-size: clamp(4.8rem * var(--responsive-ratio), (48 / var(--primary-inner-width) * 100vw), 4.8rem);
  font-weight: 700;
  letter-spacing: 0.15em;
}
.page-section__title {
  position: relative;
  margin-bottom: 1em;
  padding-left: calc(35 / 40 * 1em);
  color: var(--primary-blue-color);
  font-size: clamp(3.6rem * var(--responsive-ratio), (40 / var(--primary-inner-width) * 100vw), 3.6rem);
  font-weight: 700;
  line-height: 1;
  letter-spacing: 0.15em;
}
.page-section__title::before {
  content: '';
  position: absolute;
  top: 0.25em;
  left: 0;
  width: calc(15 / 40 * 1em);
  height: calc(15 / 40 * 1em);
  border-radius: 100vmax;
  background: var(--primary-gradient);
  transform: translateY(0.1em);
}
.page-title__breadcrumb {
  display: flex;
  flex-wrap: wrap;
  color: var(--white-color);
  font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
  gap: 0.5em 0px;
	line-height: 1.5;
}
.page-title__breadcrumb a {
  color: var(--white-color);
}
.page-title__breadcrumb-item + .page-title__breadcrumb-item {
  padding-left: .5rem;
}
.page-title__breadcrumb-item + .page-title__breadcrumb-item::before {
  display: inline-block;
  padding-right: .5rem;
  content: ">";
  transform: scale(0.6, 1.4);
}
.page-title__sub {
  position: relative;
  margin-top: clamp(75px * var(--responsive-ratio), 85 / var(--primary-inner-width) * 100vw, 75px);
}
.page-title__sub .txt--komidashi {
  color: var(--gray-color);
  font-weight: 700;
}
.page-title__sub.text-comingsoon {
  margin-bottom: min(80 / var(--primary-inner-width) * 100vw, 80px);
  color: var(--primary-color);
  text-align: center;
}
@media screen and (max-width: 1640px) {
  .page-title__main {
    width: min(1440 / var(--primary-base-width) * 100vw, 100%);
  }
}
@media screen and (max-width: 1440px) {
  .page-title__main {
    width: 102%;
    translate: -1% 0;
  }
}
@media screen and (max-width: 767px) {
  .page-section__title {
    margin-bottom: 1.0em;
    padding-left: calc(35 / 40 * 1em);
    color: var(--primary-blue-color);
    font-size: min(20 / var(--primary-base-width) * 100vw, 2.0rem * var(--responsive-ratio));
    line-height: 140%;
    letter-spacing: 0.15em;
  }
  .page-section__title::before {
    top: 0.25em;
    left: 0;
    width: calc(8 / 20 * 1em);
    height: calc(8 / 20 * 1em);
    transform: translateY(0.25em);
  }
  .page-section__title .txt--midashi {
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
  }
  .page-title__outer {
    padding-top: 85px;
    padding-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .page-title__main {
    display: flex;
    justify-content: center;
    flex-direction: column;
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    width: calc(345 / var(--primary-base-width) * 100vw);
    /* aspect-ratio: 345 / 170; */
    aspect-ratio: 345 / 144;
    margin-inline: auto;
    padding-block: 0;
    padding-inline: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-bottom: 2%;
    border-radius: 30px;
    translate: 0 0;
  }
  .page-title__main-title {
    margin-bottom: 0;
    font-size: min(28 / var(--primary-base-width) * 100vw, 2.8rem * var(--responsive-ratio));
    line-height: 160%;
  }
  .page-title__breadcrumb {
    font-size: min(11 / var(--primary-base-width) * 100vw, 1.1rem * var(--responsive-ratio));
  }
  .page-common__section .site-common__inner {
    margin-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    margin-top: 0;
    padding-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    /* padding-bottom: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio)); */
    padding-bottom: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
  }
  .page-common__section + .page-common__section .site-common__inner::after {
    left: -2%;
    width: 104%;
  }
  .page-title__sub {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .page-title__sub.text-comingsoon {
    margin-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    margin-inline: -1em;
  }
}

/*----------------------------------------------------------------------------

 splide 共通スライド

----------------------------------------------------------------------------*/
.splide__section {
  margin-inline: -15px;
}
.splide__section .splide.is-overflow {
  padding-bottom: min(80 / var(--primary-inner-width) * 100vw, 80px);
}
.splide__section .splide__track {
  padding: 15px !important;
}
.splide__section .splide__arrows {
  position: absolute;
  display: flex;
  justify-content: space-between;
  right: 0;
  bottom: 0;
  width: min(120 / var(--primary-inner-width) * 100vw, 120px);
  z-index: 1;
}
.splide__section .splide__arrow-wrapper {
  position: relative;
  width: min(50 / var(--primary-inner-width) * 100vw, 50px);
  height: min(50 / var(--primary-inner-width) * 100vw, 50px);
  border-radius: 100vmax;
  background: var(--primary-gradient);
  z-index: 1;
}
.splide__section .splide__arrow-wrapper::before,
.splide__section .splide__arrow-wrapper::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 100vmax;
  background: var(--primary-gradient-reverse);
  z-index: -2;
  transition: opacity .2s ease-out;
}
.splide__section .splide__arrow-wrapper::after {
  top: 1px;
  left: 1px;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background: var(--white-color);
  z-index: -1;
}
.splide__section .splide__arrow-wrapper:last-of-type::before,
.splide__section .splide__arrow-wrapper:last-of-type::after {
  opacity: 0;
}
@media (hover: hover) and (pointer: fine) {
  .splide__section .splide__arrow-wrapper:first-of-type:hover::before,
  .splide__section .splide__arrow-wrapper:first-of-type:hover::after {
    opacity: 0;
  }
  .splide__section .splide__arrow-wrapper:last-of-type:hover::before,
  .splide__section .splide__arrow-wrapper:last-of-type:hover::after {
    opacity: 1;
  }
}
.splide__arrow__icon.prev,
.splide__arrow__icon.next {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22%;
  aspect-ratio: 83 / 150;
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
  transition: scale .1s ease-in-out;
  background: url(../img/icon_arrow_left_grad.svg) no-repeat center/contain;
  translate: -65% -50%;
}
.splide__arrow__icon.next {
  background: url(../img/icon_arrow_right_white.svg) no-repeat center/contain;
  translate: -35% -50%;
}
@media (hover: hover) and (pointer: fine) {
  .splide__arrow-wrapper:hover .splide__arrow__icon.prev {
    background: url(../img/icon_arrow_left_white.svg) no-repeat center/contain;
  }
  .splide__arrow-wrapper:hover .splide__arrow__icon.next {
    background: url(../img/icon_arrow_right_grad.svg) no-repeat center/contain;
  }
}
.splide__section .splide__arrows button {
  width: 100%;
  height: 100%;
}
.splide__section .splide:not( .is-overflow ) .splide__list {
  justify-content: start;
}
.splide__section .splide:not( .is-overflow ) .splide__slide:last-child {
  margin: 0 !important;
}
@media screen and (max-width: 767px) {
  .splide__section .splide.is-overflow {
    padding-bottom: min(70 / var(--primary-base-width) * 100vw, 70px * var(--responsive-ratio));
    padding-bottom: 0;
  }
  .splide__section .splide__arrows {
    right: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    bottom: 0;
    width: min(90 / var(--primary-base-width) * 100vw, 90px * var(--responsive-ratio));
    aspect-ratio: 90 / 40;

    display: none;
  }
  .splide__section .splide__arrow-wrapper {
    width: calc(40 / 90 * 100%);
  }
  .splide__section .splide:not( .is-overflow ) .splide__list {
	  justify-content: center;
	}
}

/*----------------------------------------------------------------------------

 fadein

----------------------------------------------------------------------------*/
.fadein {
  opacity : 0;
  filter: blur(5px);
  transform: rotate(0.0001deg);
  transition : opacity 1.4s cubic-bezier(0.33, 1, 0.68, 1), filter 1.4s cubic-bezier(0.33, 1, 0.68, 1);
}
.fadein.scrollin {
  opacity : 1;
  filter: blur(0);
}
@keyframes fadein { 
  0% {
    opacity : 0;
    transform: rotate(0.0001deg);
    filter: blur(5px);
  }
  100% {
    opacity : 1;
    transform: rotate(0.0001deg);
    filter: blur(0);
	}
}

.fadein_x,
.fadein_x02 {
  opacity : 0;
  transform : translate3d(-30px, 0, 0) rotate(0.0001deg);
  filter: blur(5px);
  transition : transform 1.4s cubic-bezier(0.33, 1, 0.68, 1), opacity 1.4s cubic-bezier(0.33, 1, 0.68, 1), filter 1.4s cubic-bezier(0.33, 1, 0.68, 1);
}
.fadein_x02 {
  transform : translate3d(-60px, 0, 0) rotate(0.0001deg);
  transition-duration: 2s;
}
.fadein_x.scrollin,
.fadein_x02.scrollin {
  opacity : 1;
  transform : translate3d(0, 0, 0) rotate(0.0001deg);
  filter: blur(0);
}
@keyframes fadein_x { 
  0% {
    opacity : 0;
    transform : translate3d(-30px, 0, 0) rotate(0.0001deg);
    filter: blur(5px);
  }
  100% {
    opacity : 1;
    transform : translate3d(0, 0, 0) rotate(0.0001deg);
    filter: blur(0);
	}
}
.fadein_y,
.fadein_y02 {
  opacity : 0;
  transform : translate3d(0, 30px, 0) rotate(0.0001deg);
  filter: blur(5px);
  transition : transform 1.4s cubic-bezier(0.33, 1, 0.68, 1), opacity 1.4s cubic-bezier(0.33, 1, 0.68, 1), filter 1.4s cubic-bezier(0.33, 1, 0.68, 1);
}
.fadein_y02 {
  transform : translate3d(0, 60px, 0) rotate(0.0001deg);
  transition-duration: 2s;
}
.fadein_y.scrollin,
.fadein_y02.scrollin {
  opacity : 1;
  transform : translate3d(0, 0, 0) rotate(0.0001deg);
  filter: blur(0);
}
@keyframes fadein_y { 
  0% {
    opacity : 0;
    transform : translate3d(0, 30px, 0) rotate(0.0001deg);
    filter: blur(5px);
  }
  100% {
    opacity : 1;
    transform : translate3d(0, 0, 0) rotate(0.0001deg);
    filter: blur(0);
	}
}
.scale_down {
  opacity : 0;
  filter: blur(5px);
  transform: scale(1.05) rotate(0.0001deg);
  transition : opacity 1.4s cubic-bezier(0.33, 1, 0.68, 1), transform 1.4s cubic-bezier(0.33, 1, 0.68, 1), filter 1.4s cubic-bezier(0.33, 1, 0.68, 1);
}
.scale_down.scrollin {
  opacity : 1;
  transform: scale(1) rotate(0.0001deg);
  filter: blur(0);
}
@keyframes scale_down { 
  0% {
    opacity : 0;
    transform: scale(1.05) rotate(0.0001deg);
    filter: blur(5px);
  }
  100% {
    opacity : 1;
    transform: scale(1) rotate(0.0001deg);
    filter: blur(0);
	}
}
.scale_up {
  opacity : 0;
  filter: blur(5px);
  transform: scale(0.5) rotate(0.0001deg);
  transition : opacity 1.0s cubic-bezier(0.33, 1, 0.68, 1), transform 1.0s cubic-bezier(0.33, 1, 0.68, 1), filter 1.0s cubic-bezier(0.33, 1, 0.68, 1);
}
.scale_up.scrollin {
  opacity : 1;
  transform: scale(1) rotate(0.0001deg);
  filter: blur(0);
}
@keyframes scale_up { 
  0% {
    opacity : 0;
    transform: scale(0.5) rotate(0.0001deg);
    filter: blur(5px);
  }
  100% {
    opacity : 1;
    transform: scale(1) rotate(0.0001deg);
    filter: blur(0);
	}
}
@keyframes scale_up2 { 
  0% {
    opacity : 0;
    transform: scale(0.5) rotate(0.0001deg);
    filter: blur(5px);
  }
  70% {
    opacity : 1;
    transform: scale(1.1) rotate(0.0001deg);
	}
  100% {
    opacity : 1;
    transform: scale(1) rotate(0.0001deg);
    filter: blur(0);
	}
}
.no_blur {
  filter: blur(0) !important;
}
.fadein_title {
  display: inline-block;
  line-height: 1;
  overflow: hidden;
}
.fadein_title > img {
  opacity: 0;
}
.fadein_title > .slide_txt {
  display: inline-block;
  opacity: 0;
}
.fadein_title.scrollin > img,
.fadein_title.scrollin > .slide_txt {
  animation: 1.0s slide_up cubic-bezier(.2,1,.28,.92) forwards;
}
@keyframes slide_up {
  0% {
      transform: translate3d(0, calc(100% + .25em), 0) rotate(0.0001deg);
      opacity: 0;
  }
  100% {
      transform: translate3d(0, 0, 0) rotate(0.0001deg);
      opacity: 1;
  }
}
.text_wipe_x {
  clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  transform: translateX(-2.5%);
  transition: clip-path 2.0s cubic-bezier(.2,1,.28,.92) 0.5s, transform 1.5s cubic-bezier(.2,1,.28,.92) 0.5s;
}
.text_wipe_x.scrollin {
  transform: translateX(0);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
}
@keyframes text_wipe_x { 
  0% {
      transform: translateX(-2.5%) rotate(0.0001deg);
      clip-path: polygon(0 0, 0 0, 0 100%, 0 100%);
  }
  100% {
      transform: translateX(0) rotate(0.0001deg);
      clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  }
}

/*-------------------------------------------------

gide line

--------------------------------------------------*/
body.debug {
  position: relative;
  overflow: inherit !important;
}
body.debug #opening {
  display: none;
}
body.debug::before {
  display: block;
  content: '';
  width: 1px;
  height: 100%;
  position: fixed;
  top: 0;
  left: 50%;
  background: magenta;
  pointer-events: none;
  z-index: 9999;
}

/*-------------------------------------------------

.site-header

--------------------------------------------------*/
.site-header {
  position: fixed;
  display: flex;
  justify-content: space-between;
  align-items: center;
  top: 0;
  left: 0;
  width: 100%;
  background: rgba(255,255,255,0);
  line-height: 1;
  z-index: 300;
}
.site-header__outer {
  width: min(100%, 1920px);
  margin-inline: auto;
  padding-top: min(20 / var(--primary-base-width) * 100vw, 20px);
  padding-inline: min(30 / var(--primary-base-width) * 100vw, 30px);
}
.site-header__inner {
  position: relative;
  display: flex;
  align-items: center;
  width: 100%;
  height: min(90 / var(--primary-base-width) * 100vw, 90px);
  z-index: 1;
  container-type: inline-size;
}
.site-header__inner::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(255,255,255,.80);
  border: 1px solid #fff;
  border-radius: 100vmax;
  box-shadow: 0 0 4px 0 rgba(0,0,0,.2);
  border-radius: 100vmax;
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  overflow: clip;
  z-index: -1;
}
.site-header__logo {
  width: min(200 / var(--primary-base-width) * 100vw, 200px);
  margin-left: min(35 / var(--primary-base-width) * 100vw, 35px);
  font-size: 1rem;
}
.site-header__nav-wrap {
  flex: 1;
  height: 100%;
}
.site-header__nav-outer {
  display: flex;
  align-items: center;
  height: 100%;
}
.site-header__nav {
  flex: 1;
  height: 100%;
}
.site-header__nav-list {
  display: flex;
  justify-content: flex-end;
  height: 100%;
  font-size: min(14 / var(--primary-base-width) * 100vw, 1.4rem);
}
.site-header__nav-item.nav-home {
  display: none;
}
.site-header__nav-item.has-child {
  position: relative;
  margin-left: min(25 / var(--primary-base-width) * 100vw, 25px);
  z-index: 1;
}
body:not(.mobile):not(.tablet) .site-header__nav-item.has-child.hover::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: -100%;
  width: 300%;
  height: calc(50% - 1em);
  background: rgba(0,0,0,0);
  z-index: -1;
}
.site-header__nav-link {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  padding-inline: min(15 / var(--primary-base-width) * 100vw, 15px);
  color: var(--primary-txt-color);
  font-weight: 600;
  text-decoration: none;
  letter-spacing: 0.15em;
}
.site-header__nav-link::before {
  content: '';
  position: absolute;
  bottom: calc(50% - 1em - 5px);
  right: calc(20 / 15 * 1em);
  width: 0;
  height: 2px;
  background: var(--primary-gradient);
  transition: width 0.3s;
}
.nav-login .site-header__nav-link {
  color: var(--primary-blue-color);
}
.site-header__nav-link.has-child__link .has-child__icon {
  display: inline-block;
  position: absolute;
  top: 50%;
  left: max(-10 / var(--primary-base-width) * 100vw, -10px);
  width: min(16 / var(--primary-base-width) * 100vw, 16px);
  aspect-ratio: 1 / 1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16'%3E%3Cdefs%3E%3ClinearGradient id='g1' x1='0' y1='0' x2='16.3474' y2='0.363205' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%231E94E6'/%3E%3Cstop offset='0.8' stop-color='%2371D7EB'/%3E%3C/linearGradient%3E%3ClinearGradient id='g2' x1='5.5' y1='5.5' x2='10.6086' y2='5.6135' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%231E94E6'/%3E%3Cstop offset='0.8' stop-color='%2371D7EB'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect x='0.5' y='0.5' width='15' height='15' rx='7.5' fill='none' stroke='url(%23g1)'/%3E%3Ccircle cx='8' cy='8' r='2.5' fill='url(%23g2)'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  transform: translateY(-45%);
  z-index: 1;
}
.site-header__nav-link.has-child__link .has-child__icon::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  translate: -50% -50%;
  background: var(--primary-gradient);
  border-radius: 100vmax;
  scale: 0;
  z-index: -1;
  transition: scale 0.3s ease-out;
}
.site-header__nav-item.has-child.hover .site-header__nav-link.has-child__link .has-child__icon::before {
  scale: 1;
}
.site-header__nav-link.has-child__link .has-child__icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 55%;
  aspect-ratio: 270 / 150;
  translate: -50% -80%;
  background-image: url('data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 19.5 10.8%27%3E%3Cpath fill=%27%23fff%27 d=%27M0 1.2c0-.4.1-.7.4-1 .5-.5 1.2-.5 1.7 0l7.7 7.7L17.5.2c.5-.5 1.2-.5 1.7 0s.4 1.2 0 1.7l-8.6 8.6c-.5.5-1.2.5-1.7 0L.4 1.9c-.3-.3-.4-.7-.4-1Z%27/%3E%3C/svg%3E');
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.3s ease-out, translate 0.3s ease-out;
}
.site-header__nav-item.has-child.hover .site-header__nav-link.has-child__link .has-child__icon::after {
  opacity: 1;
  translate: -50% -25%;
  transition: opacity 0.3s ease-out 0.2s, translate 0.3s ease-out 0.2s;
}
body.page-feature .nav-feature .site-header__nav-link::before,
body.page-option .nav-option .site-header__nav-link::before,
body.page-case_study .nav-case_study .site-header__nav-link::before,
body.page-resources .nav-resources .site-header__nav-link::before,
body.page-column .nav-column .site-header__nav-link::before,
body.page-qa .nav-qa .site-header__nav-link::before {
  right: auto;
  left: min(15 / var(--primary-base-width) * 100vw, 15px);
  width: calc(100% - (min(15 / var(--primary-base-width) * 100vw, 15px)) * 2 - 2px);
}
@media screen and (min-width: 768px) {
  @media (hover: hover) and (pointer: fine) {
    body .site-header__nav-link:hover::before,
    body .site-header__nav-item.has-child:hover .site-header__nav-link::before {
      right: auto;
      left: min(15 / var(--primary-base-width) * 100vw, 15px);
      width: calc(100% - (min(15 / var(--primary-base-width) * 100vw, 15px)) * 2 - 2px);
    }
  }
}
.site-header__child-nav-wrap {
  position: absolute;
  left: 50%;
  bottom: -5px;
  width: min(var(--site-header__child-nav-wrap-width) / 1920 * 100vw, var(--site-header__child-nav-wrap-width) * 1px);
  transform: translateX(-50%) translateY(100%);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  background-color: rgba(255,255,255,.85);
  border: 1px solid #fff;
  border-radius: 20px;
  box-shadow: 0 0 4px 0 rgba(0,0,0,.2);
  -webkit-backdrop-filter: blur(5px);
  backdrop-filter: blur(5px);
  z-index: -1;
  transition: opacity 0.3s, visibility 0.3s;
  --site-header__child-nav-wrap-width: 1300;
  container-type: inline-size;
}
.site-header__child-nav-outer::before {
  content: '';
  position: absolute;
  top: -10px;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
@media screen and (min-width: 768px) {
  body:not(.mobile):not(.tablet) .has-child.hover:hover .site-header__child-nav-wrap {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
}
body.mobile .has-child.hover .site-header__child-nav-wrap,
body.tablet .has-child.hover .site-header__child-nav-wrap {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
}
.site-header__child-nav-outer {
  position: relative;
  padding: calc(50 / var(--site-header__child-nav-wrap-width) * 100cqi) calc(50 / var(--site-header__child-nav-wrap-width) * 100cqi);
  z-index: 1;
}
.site-header__child-nav-inner {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(60 / var(--site-header__child-nav-wrap-width) * 100cqi);
  font-size: calc(15 / var(--site-header__child-nav-wrap-width) * 100cqi);
}
.site-header__child-nav-block {
  position: relative;
  padding-top: calc(40 / var(--site-header__child-nav-wrap-width) * 100cqi);
}
.site-header__child-nav-block::before {
  content: '';
  position: absolute;
  top: 0;
  left: calc(-30 / var(--site-header__child-nav-wrap-width) * 100cqi);
  width: 1px;
  height: 100%;
  background-color: #909090;
}
.site-header__child-nav-block:nth-child(1)::before,
.site-header__child-nav-block:nth-child(2)::before {
  display: none;
}
.site-header__child-nav-title {
  position: absolute;
  top: 0;
  left: 0;
  color: #909090;
  font-size: clamp(1.0rem, 12 / var(--site-header__child-nav-wrap-width) * 100vw, 1.2rem);
  font-weight: 600;
}
.site-header__child-nav-item + .site-header__child-nav-item {
  margin-top: calc(30 / var(--site-header__child-nav-wrap-width) * 100cqi);
}
.site-header__child-nav-item > a {
  display: block;
  padding-left: calc(24 / 15 * 1em);
  padding-left: 0;
  font-size: clamp(1.2rem, 15 / var(--site-header__child-nav-wrap-width) * 100vw, 1.5rem);
  text-decoration: none;
}
@media (hover: hover) and (pointer: fine) {
  .site-header__child-nav-item > a:hover .site-common__link .site-common__link-icon::before {
    width: 100% !important;
  }
  .site-header__child-nav-item > a:hover .site-common__link .site-common__link-icon::after {
    opacity: 1;
    translate: -40% -50%;
    transition: translate .4s ease-out .2s, opacity .2s ease-out .2s;
  }
}
.site-header__child-nav-item-title {
  position: relative;
  margin-bottom: 0.45em;
  color: var(--primary-blue-color);
  font-weight: 700;
  line-height: 150%;
  text-decoration: none;
}
.site-header__child-nav-item-description {
  padding-left: 2.5em;
  color: var(--primary-txt-color);
  font-size: clamp(1.0rem, 12 / var(--site-header__child-nav-wrap-width) * 100vw, 1.2rem);
  line-height: 150%;
}
.site-header__actions {
  display: flex;
  align-items: center;
  gap: min(10 / var(--primary-base-width) * 100vw, 10px);
  margin-right: min(20 / var(--primary-base-width) * 100vw, 20px);
  margin-left: min(10 / var(--primary-base-width) * 100vw, 10px);
  font-size: 1rem;
}
.site-header__button {
  width: min(155 / var(--primary-base-width) * 100vw, 155px);
  aspect-ratio: 155 / 48;
  padding-inline: 0;
  padding-left: min(30 / 13 * 1em, 30px);
  font-size: min(13 / var(--primary-base-width) * 100vw, 13px);
  text-align: center;
  white-space: nowrap;
}
.site-header__action-apply .site-header__button {
  padding-left: min(20 / 12 * 1em, 20px);
  font-size: min(12 / var(--primary-base-width) * 100vw, 12px);
  line-height: 140%;
}
.site-header__action-login {
  display: none;
}
.site-header__hamburger {
  display: none;
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  @media (hover: hover) and (pointer: fine) {
    body .site-header__nav-link:hover::before,
    body .site-header__nav-item.has-child:hover .site-header__nav-link::before {
      left: min(8 / var(--primary-base-width) * 100vw, 8px);
      width: calc(100% - (min(8 / var(--primary-base-width) * 100vw, 8px)) * 2 - 2px);
    }
  }
}
@media screen and (max-width: 991px) {
  .site-header__nav-link {
    padding-inline: min(8 / var(--primary-base-width) * 100vw, 8px);
  }
  .site-header__nav-item.has-child {
    position: static;
  }
  .site-header__child-nav-wrap {
    width: 100%;
    left: 0;
    transform: translateX(0%) translateY(100%);
  }
  .site-header__logo {
    margin-left: min(25 / var(--primary-base-width) * 100vw, 25px);
  }
  .site-header__nav-list {
    font-size: min(16 / var(--primary-base-width) * 100vw, 16px);
  }
  body.page-feature .nav-feature .site-header__nav-link::before,
  body.page-option .nav-option .site-header__nav-link::before,
  body.page-case_study .nav-case_study .site-header__nav-link::before,
  body.page-resources .nav-resources .site-header__nav-link::before,
  body.page-column .nav-column .site-header__nav-link::before,
  body.page-qa .nav-qa .site-header__nav-link::before {
    left: calc(7 / 19 * 1em);
    width: calc(100% - (15 / 19 * 1em));
  }
}
@media screen and (max-width: 767px) {
  .site-header__outer {
    padding-top: calc(10 / var(--primary-base-width) * 100vw);
    padding-top: 10px;
    padding-inline: calc(10 / var(--primary-base-width) * 100vw);
    padding-inline: 10px;
  }
  .site-header__inner {
    justify-content: space-between;
    height: 54px;
    padding-right: 7px;
  }
  .site-header__logo {
    width: 155px;
    margin-left: 25px;
  }
  .site-header__nav-wrap {
    position: fixed;
    width: 100%;
    height: 100dvh;
    top: 0;
    left: 0;
    visibility: hidden;
    pointer-events: none;
    z-index: 999;
    transition: visibility 0.2s ease-out 0.2s;
  }
  body.nav-open .site-header__nav-wrap {
    visibility: visible;
    pointer-events: auto;
    transition: visibility 0.2s ease-out;
  }
  .site-header__nav-wrap::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: 0;
    background-color: rgba(255, 255, 255, 0.8);
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    z-index: -1;
    transition: opacity 0.2s ease-out 0.2s;
  }
  body.nav-open .site-header__nav-wrap::before {
    opacity: 1;
    transition: opacity 0.2s ease-out;
  }
  .site-header__nav-outer {
    flex-direction: column;
    align-items: flex-start;
    overflow: auto;
    translate: 0 1.5%;
    opacity: 0;
    transition: translate 0.2s ease-out, opacity 0.2s ease-out;
  }
  body.nav-open .site-header__nav-outer {
    translate: 0 0;
    opacity: 1;
    transition: translate 0.2s ease-out 0.2s, opacity 0.2s ease-out 0.2s;
  }
  .site-header__nav {
    flex: inherit;
    width: 100%;
    height: auto;
    padding-top: 80px;
    padding-inline: min(45 / var(--primary-base-width) * 100vw, 45px * var(--responsive-ratio));
  }
  .site-header__nav-list {
    flex-direction: column;
    justify-content: flex-end;
    gap: min(35 / var(--primary-base-width) * 100vw, 35px * var(--responsive-ratio));
    width: min(270 / var(--primary-base-width) * 100vw, 270px * var(--responsive-ratio));
    margin-inline: auto;
    height: auto;
  }
  .site-header__nav-item.nav-home {
    display: list-item;
  }
  .site-header__nav-item.has-child {
    margin-left: 0;
  }
  .site-header__nav-link {
    display: inline-block;
    height: auto;
    padding-inline: 0;
    padding-left: 1.5em;
    color: var(--primary-blue-color);
    font-size: min(18 / var(--primary-base-width) * 100vw, 1.8rem * var(--responsive-ratio));
    letter-spacing: 0.15em;
  }
  .site-header__nav-item.nav-login {
    display: none;
  }
  body.page-feature .nav-feature .site-header__nav-link::before,
  body.page-option .nav-option .site-header__nav-link::before,
  body.page-case_study .nav-case_study .site-header__nav-link::before,
  body.page-resources .nav-resources .site-header__nav-link::before,
  body.page-column .nav-column .site-header__nav-link::before,
  body.page-qa .nav-qa .site-header__nav-link::before,
  body.page-home .nav-home .site-header__nav-link::before {
    left: 1.5em !important;
    right: auto !important;
    width: calc(100% - 1.65em) !important;
  }
  .site-header__nav-link.has-child__link .has-child__icon {
    left: 0;
    width: 1em;
    z-index: 1;
  }
  .site-header__nav-link.has-child__link .has-child__icon::after {
    width: 60%;
  }
  .site-header__actions {
    flex-direction: column;
    align-items: center;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    width: 280px;
    margin-top: 60px;
    margin-inline: auto;
    padding-bottom: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
  }
  .site-header__button.button--primary,
  .site-header__button.button--secondary {
    justify-content: center;
    width: min(280 / var(--primary-base-width) * 100vw, 280px * var(--responsive-ratio));
    aspect-ratio: 280 / 70;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    padding-right: calc(15 / 15 * 1em);
    padding-left: 0;
  }
  .site-header__action-login {
    display: block;
    margin-top: 1.0em;
    font-size: min(16 / var(--primary-base-width) * 100vw, 1.6rem * var(--responsive-ratio));
    text-align: center;
  }
  .site-header__action-login .site-header__button-link {
    color: var(--primary-color);
    font-weight: 400;
    text-decoration: none;
  }
  .site-header__child-nav-wrap {
    position: relative;
    left: auto;
    bottom: auto;
    width: auto;
    height: 0;
    transform: none;
    background-color: transparent;
    border: none;
    border-radius: 0;
    box-shadow: none;
    -webkit-backdrop-filter: blur(0px);
    backdrop-filter: blur(0px);
    z-index: 1;
    overflow: hidden;
  }
  .site-header__child-nav-outer::before {
    display: none;
  }
  body .has-child.hover .site-header__child-nav-wrap {
    height: auto;
    max-height: 200vh;
    margin-top: 0;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
  }
  body .site-header__nav-item.has-child.hover::before {
    display: none;
  }
  .site-header__child-nav-outer {
    padding: 0;
  }
  .site-header__child-nav-inner {
    grid-template-columns: 1fr;
    gap: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    margin-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-block: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
    border-bottom: 1px solid #909090;
  }
  .site-header__child-nav-inner + .site-header__child-nav-inner {
    border-top: 1px solid #909090;
  }
  .site-header__child-nav-block {
    padding-top: 0;
  }
  .site-header__child-nav-block + .site-header__child-nav-block::before {
    content: '';
    position: absolute;
    top: max(-20 / var(--primary-base-width) * 100vw, -20px * var(--responsive-ratio));
    left: 0;
    width: 100%;
    height: 1px;
    background-color: #909090;
  }
  .site-header__child-nav-block:nth-child(2)::before {
    display: block;
  }
  .site-header__child-nav-item .site-common__link {
    gap: min(5 / var(--primary-base-width) * 100vw, 5px * var(--responsive-ratio));
    margin-bottom: 0;
  } 
  .site-header__child-nav-item .site-common__link-icon {
    width: min(12 / var(--primary-base-width) * 100vw, 12px * var(--responsive-ratio));
  }
  .site-header__child-nav-item .site-common__link-icon::before {
    width: min(5 / var(--primary-base-width) * 100vw, 5px * var(--responsive-ratio));
  }
  .site-header__child-nav-item + .site-header__child-nav-item {
    margin-top: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
  }
  .site-header__child-nav-title {
    position: relative;
    top: auto;
    left: auto;
    margin-bottom: 1.5em;
    font-size: min(11 / var(--primary-base-width) * 100vw, 1.1rem * var(--responsive-ratio));
  }
  .site-header__child-nav-item > a {
    display: block;
    padding-left: 0;
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
  }
  .site-header__child-nav-item-description {
    margin-top: 0.25em;
    padding-left: min(17 / var(--primary-base-width) * 100vw, 17px * var(--responsive-ratio));
    font-size: min(9 / var(--primary-base-width) * 100vw, 0.9rem * var(--responsive-ratio));
  }
  .site-header__hamburger {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 5px;
    width: 40px;
    height: 40px;
    border-radius: 100vmax;
    background: var(--primary-gradient);
    z-index: 1000;
  }
  .site-header__hamburger::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: var(--white-color);
    border: 1px solid var(--primary-blue-color);
    border-radius: 100vmax;
    scale: 0 0;
    transition: scale 0.2s ease-out;
  }
  .site-header__hamburger.is-active::before {
    scale: 1 1;
  }
  .site-header__hamburger span {
    position: relative;
    width: 20px;
    height: 1px;
    background-color: var(--white-color);
    transition: background-color 0.2s ease-out, rotate 0.2s ease-out, translate 0.2s ease-out 0.2s;
  }
  .site-header__hamburger.is-active span {
    background-color: var(--primary-blue-color);
    transition: background-color 0.2s ease-out, rotate 0.2s ease-out 0.2s, translate 0.2s ease-out;
  }
  .site-header__hamburger.is-active span:nth-child(1) {
    translate: 0 6px;
    rotate: 45deg;
  }
  .site-header__hamburger.is-active span:nth-child(2) {
    opacity: 0;
  }
  .site-header__hamburger.is-active span:nth-child(3) {
    translate: 0 -6px;
    rotate: -45deg;
  }
}

/*-------------------------------------------------

main

--------------------------------------------------*/
main.site-main {
  position: relative;
  overflow-x: clip;
}

/*-------------------------------------------------

  statistics__list （共通）

--------------------------------------------------*/
.statistics__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.statistics__item {
  position: relative;
  display: grid;
  place-content: center;
  aspect-ratio: 1 / 1;
  background-color: #fff;
  border-radius: 100vmax;
  z-index: 1;
}
.statistics__item::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: calc(150 / 130 * 100%);
  aspect-ratio: 1 / 1;
  transform: translate(-50%, -55%);
  background: url(../img/statistics_item_object.svg) no-repeat center / contain;
  pointer-events: none;
}
.statistics__item-wrap {
  color: var(--primary-blue-color);
  font-weight: 500;
  font-size: clamp(1.7rem * var(--responsive-ratio), (17 / var(--primary-inner-width) * 100vw), 1.7rem);
}
.statistics__item-label {
  margin-bottom: 0.4em;
  text-align: center;
}
.statistics__item-value {
  text-align: center;
}
.statistics__item-unit {
  text-align: center;
}
.statistics__item-value + .statistics__item-unit {
  margin-top: 0.6em;
  font-weight: 700;
}
.statistics__item-value + .statistics__item-unit.unit3 {
  margin-top: 0.3em;
}
.statistics__item-num {
  margin-right: 0.1em;
  color: var(--primary-blue-color);
}
.statistics__note {
  margin-top: 0.8em;
  font-size: 1rem;
  text-align: center;
}

/*-------------------------------------------------

 kv

--------------------------------------------------*/
#keyvisual {
  position: relative;
  background-color: var(--primary-bg-color);
}
.keyvisual__outer {
  position: relative;
  width: 100%;
  width: min(100%, var(--keyvisual-width) * 1px);
  margin-inline: auto;
  aspect-ratio: 1600 / 800;
  container-type: inline-size;
  --keyvisual-width: 1600;
}
.keyvisual__inner {
  position: relative;
  width: 100%;
  height: 100%;
  padding-top: min(170 / var(--primary-base-width) * 100vw, 170px);
  padding-left: calc(130 / var(--keyvisual-width) * 100cqi);
}
.keyvisual__image {
  position: absolute;
  bottom: calc(40 / var(--keyvisual-width) * 100cqi);
  right: calc(61 / var(--keyvisual-width) * 100cqi);
  width: calc(874 / var(--keyvisual-width) * 100cqi);
}
.keyvisual__content {
  position: relative;
  width: calc(520 / var(--keyvisual-width) * 100cqi);
  color: var(--primary-blue-color);
}
.keyvisual__content-text {
  width: calc(520 / var(--keyvisual-width) * 100cqi);
}
.keyvisual__content-title {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  gap: calc(8 / var(--keyvisual-width) * 100cqi);
  margin-bottom: calc(80 / var(--keyvisual-width) * 100cqi);
  font-size: calc(56 / var(--keyvisual-width) * 100cqi);
  font-weight: 700;
  letter-spacing: 0.1em;
  white-space: nowrap;
  padding-top: calc(30 / var(--keyvisual-width) * 100cqi);
}
.keyvisual__content-title-wrap {
  padding: 0 0em 0.1em 0.05em;
}
.keyvisual__content-main-title {
  width: calc(470/ var(--keyvisual-width) * 100cqi);
  margin-bottom: calc(60 / var(--keyvisual-width) * 100cqi);
  text-align: center;
}
.keyvisual__content-main-title-logo {
  display: block;
  margin-inline: -1em;
  color: #0072BC;
  font-size: calc(50 / var(--keyvisual-width) * 100cqi);
  font-weight: bold;
  letter-spacing: 0 !important;
  text-align: center;
}
.keyvisual__content-main-title-text {
  display: inline-block;
  margin-bottom: 0.5em;
  color: var(--primary-blue-color);
  font-size: calc(18 / var(--keyvisual-width) * 100cqi);
  font-weight: 600;
  letter-spacing: 0.2em;
}
.keyvisual__content-actions {
  display: flex;
  justify-content: space-between;
  width: calc(470/ var(--keyvisual-width) * 100cqi);
  margin-bottom: calc(50 / var(--keyvisual-width) * 100cqi);
}
.keyvisual__actions-button {
  width: calc(230 / var(--keyvisual-width) * 100cqi);
  padding-inline: calc(30 / 20 * 1em) 0;
  aspect-ratio: 230 / 70;
  font-size: calc(20 / var(--keyvisual-width) * 100cqi);
}
.keyvisual__content-info {
  position: absolute;
  bottom: calc(38 / var(--keyvisual-width) * 100cqi);
  right: calc(180 / var(--keyvisual-width) * 100cqi);
  width: calc(460 / var(--keyvisual-width) * 100cqi);
  text-align: center;
}
.statistics__list {
  gap: calc(35 / var(--keyvisual-width) * 100cqi);
}
.statistics__item-wrap {
  color: #FF8F13;
  font-size: calc(15 / var(--keyvisual-width) * 100cqi);
}
.statistics__item-num {
  color: #FF8F13;
  font-size: calc(44 / var(--keyvisual-width) * 100cqi);
  font-weight: 800;
  letter-spacing: -0.03em;
}
.statistics__item-num.num2 {
  font-size: calc(32 / var(--keyvisual-width) * 100cqi);
}
.statistics__item-num.num3 {
  font-size: calc(36 / var(--keyvisual-width) * 100cqi);
  font-weight: 900;
}
.statistics__note {
  margin-top: calc(15 / var(--keyvisual-width) * 100cqi);
  margin-inline: -5em;
  color: var(--gray-color);
  font-size: calc(10 / var(--keyvisual-width) * 100cqi);
  letter-spacing: 0.05em;
}
.keyvisual__logo-nttdata {
  position: absolute;
  bottom: calc(57 / var(--keyvisual-width) * 100cqi);
  left: calc(130 / var(--keyvisual-width) * 100cqi);
  width: clamp(170px * var(--responsive-ratio), 170 / 1400 * 100vw, 170px);
}
@media screen and (max-width: 991px) {
  .keyvisual__logo-nttdata {
    width: clamp(140px * var(--responsive-ratio), 140 / 1400 * 100vw, 140px);
  }
}
@media screen and (max-width: 767px) {
  .keyvisual__outer {
    width: min(100%, 580px);
    aspect-ratio: inherit;
    --keyvisual-width: 375;
  }
  .keyvisual__inner {
    padding-top: 84px;
    padding-left: 0;
    padding-bottom: calc(32 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__content {
    width: 100%;
  }
  .keyvisual__content-text {
    width: 100%;
    text-align: center;
  }
  .keyvisual__content-title {
    display: inline-flex;
    align-items: flex-start;
    flex-direction: column;
    gap: calc(4 / var(--keyvisual-width) * 100cqi);
    margin-bottom: calc(30 / var(--keyvisual-width) * 100cqi);
    font-size: calc(34 / var(--keyvisual-width) * 100cqi);
    padding-top: calc(15 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__content-title-wrap {
    padding: 0.1em 0.1em 0.1em 0.15em;
  }
  .keyvisual__content-main-title {
    width: auto;
    margin-bottom: calc(30 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__content-main-title-text {
    margin-bottom: calc(6 / var(--keyvisual-width) * 100cqi);
    font-size: calc(12 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__content-main-title-logo {
    font-size: calc(30 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__content-actions {
    display: inline-flex;
    width: calc(325 / var(--keyvisual-width) * 100cqi);
    margin-bottom: calc(30 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__actions-button {
    width: calc(160 / var(--keyvisual-width) * 100cqi);
    padding-inline: calc(22 / 13 * 1em) 0;
    aspect-ratio: 160 / 48;
    font-size: calc(13 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__content-actions .button--primary::after,
  .keyvisual__content-actions .button--secondary::after {
    right: calc(16 / var(--keyvisual-width) * 100vw);
    width: calc(13 / var(--keyvisual-width) * 100vw);
  }
  .keyvisual__actions-button .button--primary__icon,
  .keyvisual__actions-button .button--secondary__icon {
    right: 15px;
    width: 16px;
  }
  .keyvisual__actions-button .button--primary__icon.min::before,
  .keyvisual__actions-button .button--secondary__icon.min::before {
    width: calc(6 / 16 * 100%);
  }
  .keyvisual__image {
    position: relative;
    bottom: auto;
    right: auto;
    width: calc(351 / var(--keyvisual-width) * 100cqi);
    margin-left: calc(13 / var(--keyvisual-width) * 100cqi);
    margin-bottom: calc(5 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__content-info {
    position: relative;
    bottom: auto;
    right: auto;
    width: calc(310 / var(--keyvisual-width) * 100cqi);
    margin-inline: auto;
  }
  .statistics__list {
    gap: calc(18 / var(--keyvisual-width) * 100cqi);
  }
  .keyvisual__logo-nttdata {
    left: auto;
    right: calc(44 / var(--keyvisual-width) * 100cqi);
    bottom: calc(15 / var(--keyvisual-width) * 100cqi);
    width: calc(68 / var(--keyvisual-width) * 100cqi);
  }
  .statistics__item-wrap {
    font-size: calc(11 / var(--keyvisual-width) * 100cqi);
  }
  .statistics__item-num {
    font-size: calc(28 / var(--keyvisual-width) * 100cqi);
    letter-spacing: -0.03em;
  }
  .statistics__item-num.num2 {
    font-size: calc(20 / var(--keyvisual-width) * 100cqi);
  }
  .statistics__item-num.num3 {
    font-size: calc(24 / var(--keyvisual-width) * 100cqi);
  }
  .statistics__note {
    display: inline-block;
    margin-top: calc(8 / var(--keyvisual-width) * 100cqi);
    margin-inline: -5em;
    font-size: calc(10 / var(--keyvisual-width) * 100cqi);
    line-height: 150%;
    text-align: left;
  }
}

/*-------------------------------------------------

clients

--------------------------------------------------*/
.clients-section {
  position: relative;
  background: var(--white-color);
  box-shadow: 0 0 30px 0 rgba(52,144,207,.3);
}
.clients__outer {

}
.clients__head {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.2em;
  margin-bottom: 20px;
  color: var(--primary-blue-color);
  font-size: clamp(1.7rem * var(--responsive-ratio), (17 / var(--primary-inner-width) * 100vw), 1.7rem);
  font-weight: 500;
  letter-spacing: 0.1em;
}
.clients__head-title {
  font-size: calc(17 / 16 * 1em);
  font-weight: 700;
  letter-spacing: 0.1em;
}
.clients__inner {
  position: relative;
  max-width: 2560px;
  margin-inline: auto;
  padding-top: 20px;
  padding-bottom: 30px;
}
.clients__list {
  width: 100%;
  padding: 0;
  container-type: inline-size;
}
.clients__list .splide:not(.is-overflow) .splide__list {
  justify-content: start;
}
.clients__list .splide:not(.is-overflow) .splide__slide:last-child {
  margin: 0 !important;
}
.clients__list .splide__list .clients__item {
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: min(160 / 1600 * 100vw, 160px);
  height: min(70 / 1600 * 100vw, 70px);
}
.clients__list .splide__list .clients__item img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
@media screen and (min-width: 2561px) {
  .clients__inner::before,
  .clients__inner::after {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 200px;
    height: 100%;
    background: linear-gradient(to right, rgba(255,255,255,1.0) 50%, rgba(255,255,255,0) 100%);
    z-index: 1;
  }
  .clients__inner::after {
    left: auto;
    right: 0;
    background: linear-gradient(to left, rgba(255,255,255,1.0) 50%, rgba(255,255,255,0) 100%);
  }
}
@media screen and (max-width: 767px) {
  .clients__inner {
    padding-top: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    padding-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .clients__head {
    flex-direction: column;
    gap: 1.2em;
    margin-bottom: 20px;
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
  .clients__head-title {
    font-size: calc(13 / 12 * 1em);
    font-weight: 700;
    letter-spacing: 0.1em;
  }
  .clients__list .splide__list .clients__item {
    max-width: calc(100 / var(--primary-base-width) * 100vw);
    max-width: 110px;
    height: calc(40 / var(--primary-base-width) * 100vw);
    height: 50px;
  }
}

/*-------------------------------------------------

 merit

--------------------------------------------------*/
.introduction-section {
  position: relative;
  padding-bottom: 0;
}
.introduction-section__title {
  margin-bottom: min(25 / var(--primary-inner-width) * 100vw, 25px);
  color: var(--primary-color);
  font-size: clamp(4.0rem * var(--responsive-ratio), (40 / var(--primary-inner-width) * 100vw), 4.0rem);
  font-weight: bold;
  line-height: 150%;
  letter-spacing: 0.15em;
  text-align: center;
}
.introduction__lead {
  margin-bottom: min(80 / var(--primary-inner-width) * 100vw, 80px);
  text-align: center;
}
.introduction__lead-text {
  display: inline-block;
  padding: 0.05em 1.2em;
  font-weight: 500;
  letter-spacing: 0.15em;
}
.introduction__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(90 / 1170 * 100%);
  width: calc(1170 / 1280 * 100%);
  margin-inline: auto;
}
.introduction__title {
  margin-bottom: 0.65em;
  text-align: center;
}
.introduction__img {
  position: relative;
  width: 100%;
  margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  z-index: 1;
}
.introduction__img-inner {
  position: relative;
  border-radius: min(30 / var(--primary-inner-width) * 100vw, 30px);
  overflow: hidden;
}
.introduction__img::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: var(--primary-gradient);
  border-radius: 30px;
  filter: blur(13px);
  z-index: -1;
}
@media screen and (max-width: 991px) {
  .introduction-section {
    padding-block: clamp(80px * var(--responsive-ratio), 80 / var(--primary-base-width) * 100vw, 80px);
  }
}
@media screen and (max-width: 767px) {
  .introduction-section {
    padding-top: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
    padding-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .introduction-section__title {
    margin-bottom: 1em;
    margin-inline: -1em;
    font-size: min(20 / var(--primary-base-width) * 100vw, 2.0rem * var(--responsive-ratio));
  }
  .introduction__title {
    margin-bottom: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
  }
  .introduction__lead {
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .introduction__lead-text {
    display: block;
    padding: 0.6em 0.8em 0.6em 1.2em;
    font-size: min(14 / var(--primary-base-width) * 100vw, 1.4rem * var(--responsive-ratio));
    letter-spacing: 0.1em;
    line-height: 140%;
    text-align: center;
  }
  .introduction__list {
    grid-template-columns: 1fr;
    gap: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    width: 100%;
  }
  .introduction__list li {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    width: min(315 / var(--primary-base-width) * 100vw, 315px * 1.6);
    margin-inline: auto;
  }
  .introduction__img {
    width: calc(120 / 315 * 100%);
  }
  .introduction__body {
    width: calc(180 / 315 * 100%);
  }
  .introduction__title {
    margin-bottom: 0.25em;
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
    line-height: 155%;
    text-align: left;
  }
  .introduction__excerpt {
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    line-height: 150%;
    letter-spacing: 0.1em;
  }
  .introduction__img {
    margin-bottom: 0;
  }
  .introduction__img::before {
    border-radius: 20px;
    filter: blur(6px);
  }
  .introduction__img-inner {
    aspect-ratio: 120 / 130;
    border-radius: 20px;
  }
  .introduction__img-inner img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: 75% center;
  }
  .introduction__item:nth-child(2) .introduction__img-inner img {
    object-position: 50% center;
  }
  .introduction__item:nth-child(3) .introduction__img-inner img {
    object-position: center center;
  }
}

/*-------------------------------------------------

 merit

--------------------------------------------------*/
.merit-section {
  position: relative;
  padding-top: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
}
.merit-section__title {
  /* margin-bottom: 1.75em; */
  margin-bottom: 1.25em;
}
.merit__lead.site-common__lead {
  flex-direction: column;
  align-items: flex-start;
}
.merit__img {
  width: min(915 / var(--primary-inner-width) * 100vw, 915px);
  margin-inline: auto;
  margin-bottom: min(75 / var(--primary-inner-width) * 100vw, 75px);
  text-align: center;
}
.merit__img img {
  width: 100%;
}
.merit__list {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(80 / var(--primary-inner-width) * 100vw, 80px);
  margin-bottom: min(60 / var(--primary-inner-width) * 100vw, 60px);
  padding: min(30 / var(--primary-inner-width) * 100vw, 30px) min(65 / var(--primary-inner-width) * 100vw, 65px);
  border-radius: 20px;
  border: 1px solid var(--primary-blue-color);
}
.merit__list::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  width: 45px;
  aspect-ratio: 90 / 36;
  background: url(../img/fukidashi_parts_btm.png) no-repeat center center / contain;
}
.merit__item {
  position: relative;
}
.merit__item:not(:last-of-type)::before {
  content: '';
  position: absolute;
  width: 1px;
  height: 86%;
  top: 7%;
  right: max(-40 / var(--primary-inner-width) * 100vw, -40px);
  background-color: var(--primary-blue-color);
}
.merit__title {
  margin-bottom: 0.65em;
  margin-inline: -0.5em;
  text-align: center;
}
.merit__excerpt {

}
@media screen and (min-width: 768px) {
  .merit__item:nth-child(2) .merit__excerpt {
    letter-spacing: 0.035em;
  }
}
@media screen and (min-width: 768px) and (max-width: 1480px) {
  .merit__list {
    gap: min(60 / var(--primary-inner-width) * 100vw, 60px);
    padding-inline: min(45 / var(--primary-inner-width) * 100vw, 45px);
  }
  .merit__item:not(:last-of-type)::before {
    right: max(-30 / var(--primary-inner-width) * 100vw, -30px);
  }
}
@media screen and (min-width: 768px) and (max-width: 1380px) {
  .merit__item .merit__excerpt {
    font-size: min(17 / 1600 * 100vw, 17px)
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .merit__item .merit__excerpt {
    font-size: min(20 / 1600 * 100vw, 20px)
  }
}
.merit__closing-text {
  text-align: center;
}
.merit__closing-text .color-bg {
  display: inline-block;
  margin-right: 0.25em;
  padding: 0em 0.35em;
  line-height: 170%;
  letter-spacing: 0.1em;
}
@media screen and (max-width: 767px) {
  .merit-section {
    padding-top: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    padding-bottom: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
  }
  .merit-section__title {
    margin-bottom: calc(35 / 36 * 1em);
  }
  .merit__closing-text.title--primary {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    margin-bottom: 0;
    line-height: 190%;
  }
  .merit__img {
    width: min(330 / var(--primary-base-width) * 100vw, 330px * var(--responsive-ratio));
    margin-inline: auto;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    translate: max(-5 / var(--primary-base-width) * 100vw, -5px * var(--responsive-ratio)) 0;
  }
  .merit__list {
    grid-template-columns: 1fr;
    gap: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    width: min(320 / var(--primary-base-width) * 100vw, 320px * var(--responsive-ratio));
    margin-inline: auto;
    margin-bottom: min(35 / var(--primary-base-width) * 100vw, 35px * var(--responsive-ratio));
    padding: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .merit__item:not(:last-of-type)::before {
    width: 110%;
    height: 1px;
    top: auto;
    bottom: max(-20 / var(--primary-base-width) * 100vw, -20px * var(--responsive-ratio));
    right: -5%;
  }
  .merit__list::after {
    width: min(54 / var(--primary-base-width) * 100vw, 54px * var(--responsive-ratio));
    width: 54px;
    bottom: -18px;
    aspect-ratio: 54 / 18;
    background: url(../img/fukidashi_parts_btm_sp.png) no-repeat center center / contain;
    transform: translateX(-50%) translateY(0);
  }
}

/*-------------------------------------------------

 feature

--------------------------------------------------*/
.feature-section {
  position: relative;
}
.feature-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--primary-bg-color);
  z-index: -1;
  border-radius: min(200 / var(--primary-base-width) * 100vw, 200px) min(200 / var(--primary-base-width) * 100vw, 200px) 0 0;
}
.feature__outer {
  position: relative;
}
.feature-section__title {
  margin-bottom: 1.25em;
}
.feature__lead.site-common__lead {
  flex-direction: column;
  align-items: flex-start;
}
.feature__img {
  margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
}
.feature__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px);
}
.feature__item {
  position: relative;
  padding: min(30 / var(--primary-inner-width) * 100vw, 30px) min(40 / var(--primary-inner-width) * 100vw, 40px);
  border-radius: 30px;
  background-color: var(--white-color);
}
.feature__item-title {
  margin-bottom: 0;
}
.feature__item-wrap {
  display: flex;
  align-items: center;
  margin-bottom: min(20 / var(--primary-inner-width) * 100vw, 20px);
  gap: min(15 / var(--primary-inner-width) * 100vw, 15px);
}
.feature__item-num {
  /*
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  */
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.40em;
  width: calc(70 / 15 * 1em);
  aspect-ratio: 1 / 1;
  color: #fff;
  font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  font-weight: bold;
  letter-spacing: 0.1em;
  background-image: var(--primary-gradient);
  border-radius: 100vmax;
  z-index: 1;
}
.feature__item-num .num {
  font-size: calc(20 / 15 * 1em);
}
.feature__more {
  margin-top: min(80 / var(--primary-inner-width) * 100vw, 80px);
  text-align: center;
}
@media screen and (min-width: 768px) {
  .feature__item .feature__item-title {
    margin-right: -0.5em;
    font-size: min(20 / 1600 * 100vw, 20px);
  }
  .feature__item .feature__item-excerpt {
    font-size: min(17 / 1600 * 100vw, 17px);
  }
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .feature__item .feature__item-title {
    font-size: min(24 / 1600 * 100vw, 24px);
  }
  .feature__item .feature__item-excerpt {
    font-size: min(20 / 1600 * 100vw, 20px);
  }
}
@media screen and (max-width: 767px) {
  .feature-section {
    padding-top: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
    padding-bottom: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
  }
  .feature-section::before {
    border-radius: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio)) min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio)) 0 0;
  }
  .feature__inner.site-common__inner {
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
  }
  .feature__more {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .feature-section__title {
    margin-bottom: min(35 / var(--primary-base-width) * 100vw, 35px * var(--responsive-ratio));
  }
  .feature__img {
    margin-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .feature__list {
    grid-template-columns: 1fr;
    gap: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-inline: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    background-color: var(--white-color);
    border-radius: 20px;
  }
  .feature__item-wrap {
    margin-bottom: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
  }
  .feature__item {
    padding: 0;
  }
  .feature__item-num {
    width: calc(45 / 12 * 1em);
    padding-top: 0.25em;
    padding-left: 0.15em;
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    letter-spacing: 0.1em;
  }
  .feature__item-num .num {
    font-size: calc(16 / 12 * 1em);
    transform: translateY(-0.1em);
  }
  .feature__item-title {
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    line-height: 140%;
    letter-spacing: 0.1em;
    text-align: left;
  }
}

/*-------------------------------------------------

 casestudy

--------------------------------------------------*/
.casestudy-section {
  position: relative;
  padding-bottom: clamp(50px * var(--responsive-ratio), 50 / var(--primary-inner-width) * 100vw, 50px);
}
.casestudy-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 50%;
  background: var(--primary-bg-color);
  z-index: -2;
}
.casestudy-section::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--white-color);
  z-index: -1;
  border-radius: min(200 / var(--primary-base-width) * 100vw, 200px) min(200 / var(--primary-base-width) * 100vw, 200px) 0 0;
}
.casestudy__outer {
  position: relative;
}
.casestudy__client {
  display: inline-block;
  padding: 0em 0.5em;
  font-size: clamp(1.2rem, (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  font-weight: 700;
  line-height: 170%;
  letter-spacing: 0.1em;
}
.casestudy__client-division {
  margin-top: 0.35em;
  padding-left: 0.5em;
  color: var(--primary-blue-color);
}
.casestudy__client-info {
  display: flex;
  gap: 1em;
  margin-top: 2.5em;
  color: var(--gray-color);
  font-size: clamp(1.3rem * var(--responsive-ratio), (13/ var(--primary-inner-width) * 100vw), 1.3rem);
}
.casestudy__client-info-item {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.casestudy__client-info-item dt {
  padding: 0.2em 0.25em 0.30em 0.35em;
  font-size: calc(12 / 13 * 1em);
  line-height: 1;
  border: 1px solid var(--gray-color);
  white-space: nowrap;
}
.casestudy__client-info-item dd {
  line-height: 150%;
}
.casestudy__client-info-item:last-of-type dd {
  white-space: nowrap;
}
.casestudy__meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  color: var(--primary-txt-color);
  margin-top: auto;
  padding-top: min(25 / var(--primary-inner-width) * 100vw, 25px);
  font-size: clamp(1.0rem, (15 / var(--primary-inner-width) * 100vw), 1.5rem);
}
.casestudy__date {
  color: #909090;
  font-size: calc(14 / 15 * 1em);
}
@media screen and (max-width: 767px) {
  .casestudy-section {
    padding-top: min(70 / var(--primary-base-width) * 100vw, 70px * var(--responsive-ratio));
    padding-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .casestudy-section::after {
    border-radius: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio)) min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio)) 0 0;
  }
  .casestudy__inner.site-common__inner {
    width: calc(320 / var(--primary-base-width) * 100vw);
  }
  .casestudy__inner .site-common__lead {
    margin-bottom: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
  }
  .casestudy__list {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
  }
  .casestudy__meta {
    padding-top: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    font-size: min(12 / var(--primary-base-width) * 100vw, 12px * var(--responsive-ratio));
  }
  .casestudy__lead-link-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    text-align: center;
  }
}

/*-------------------------------------------------

 flow

--------------------------------------------------*/
.flow-section {
  position: relative;
  padding-top: 0;
}
.flow-section .site-common__lead {
  margin-bottom: clamp(100px * var(--responsive-ratio), 100 / var(--primary-inner-width) * 100vw, 100px);
}
.flow__list {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: min(20 / var(--primary-inner-width) * 100vw, 20px);
  margin-bottom: min(160 / var(--primary-inner-width) * 100vw, 160px);
}
.flow__item {
  position: relative;
  padding-top: min(30 / var(--primary-inner-width) * 100vw, 30px);
  padding-bottom: min(30 / var(--primary-inner-width) * 100vw, 30px);
  color: var(--primary-txt-color);
  border: 2px solid var(--primary-blue-color);
  border-radius: 30px;
}
.flow__item.item2,
.flow__item.item4 {
  transform: translateY(min(60 / var(--primary-inner-width) * 100vw, 60px));
}
.flow__num {
  position: absolute;
  top: 0;
  left: 50%;
  padding: 0.65em 1em;
  color: #fff;
  font-size: clamp(1.7rem * var(--responsive-ratio), (17 / var(--primary-inner-width) * 100vw), 1.7rem);
  font-weight: bold;
  background: var(--primary-gradient);
  border-radius: 100vmax;
  white-space: nowrap;
  transform: translate3d(-50%, -50%, 0);
}
.flow__title {
  margin-bottom: 0.65em;
  text-align: center;
}
.flow__excerpt {
  width: 11em;
  margin-inline: auto;
}
.flow__icon {
  margin-bottom: min(8 / var(--primary-inner-width) * 100vw, 8px);
  text-align: center;
}
.flow__icon img {
  width: calc(130 / 236 * 100%);
}
@media screen and (max-width: 767px) {
  .flow-section {
    padding-top: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    padding-bottom: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio));
  }
  .flow-section .site-common__lead {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .flow__list {
    grid-template-columns: repeat(3, 1fr);
    row-gap: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    column-gap: min(8 / var(--primary-base-width) * 100vw, 8px * var(--responsive-ratio));
    width: min(330 / var(--primary-base-width) * 100vw, 330px * 1.6);
    translate: max(-5/ var(--primary-base-width) * 100vw, -5px * var(--responsive-ratio)) 0;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .flow__item {
    display: flex;
    flex-direction: column;
    width: auto;
    padding-top: min(22 / var(--primary-base-width) * 100vw, 22px * var(--responsive-ratio));
    padding-bottom: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    border-radius: 12px;
  }
  .flow__item:nth-child(4),
  .flow__item:nth-child(5) {
    translate: calc(50% + min(4 / var(--primary-base-width) * 100vw, 4px * var(--responsive-ratio))) 0;
  }
  .flow__item.item2,
  .flow__item.item4 {
    transform: none;
  }
  .flow__num {
    order: 0;
    padding: 0.55em 0.8em;
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
  .flow__title {
    margin-bottom: 0.65em;
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    text-align: center;
  }
  .flow__excerpt {
    width: auto;
    margin-bottom: 0;
    padding-inline: 1em;
    font-size: min(10 / var(--primary-base-width) * 100vw, 1.0rem * var(--responsive-ratio));
    line-height: 150%;
    letter-spacing: 0;
  }
  .flow__icon {
    margin-bottom: min(6 / var(--primary-base-width) * 100vw, 6px * var(--responsive-ratio));
  }
  .flow__icon img {
    width: calc(45 / 104 * 100%);
  }
  .flow__lead-link-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    margin-bottom: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio));
    text-align: center;
  }
}

/*-------------------------------------------------

 faq

--------------------------------------------------*/
.faq-section {
  position: relative;
}
.faq__outer::before {
  content: '';
  position: absolute;
  top: 0;
  left: min(30 / var(--primary-base-width) * 100vw, 30px);
  width: calc(100% - min(60 / var(--primary-base-width) * 100vw, 60px));
  height: 100%;
  background-color: var(--primary-txt-color);
  z-index: -1;
  border-radius: min(100 / var(--primary-base-width) * 100vw, 100px);
}
.faq__inner {
  position: relative;
  width: min(1380 / var(--primary-base-width) * 100vw, 1380px);
  margin-inline: auto;
  color: var(--white-color);
}
.faq__inner .splide__section {
  margin-inline: 0;
}
.splide.is-initialized:not(.is-active) .splide__list.faq__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: 1fr;
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px) min(62 / var(--primary-inner-width) * 100vw, 62px);
}
.faq__inner .splide__section .splide.is-overflow {
  padding-bottom: 0;  
}
.faq__inner .splide__section .splide__track {
  padding: 0px !important;
  padding-left: min(25 / var(--primary-inner-width) * 100vw, 25px) !important;
  overflow: inherit;
}
.faq__item {
  position: relative;
  padding: min(40 / var(--primary-inner-width) * 100vw, 40px);
  padding-bottom: min(35 / var(--primary-inner-width) * 100vw, 35px);
  color: var(--primary-txt-color);
  background-color: #fff;
  border-radius: 30px;
}
.faq__num {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.05em;
  width: calc(70 / 20 * 1em);
  aspect-ratio: 1 / 1;
  color: #fff;
  font-size: clamp(1.4rem, (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  font-weight: bold;
  letter-spacing: 0.1em;
  background-image: var(--primary-gradient);
  border-radius: 100vmax;
  z-index: 1;
  transform: translate(-35%, -35%);
}
.faq__num .num {
  font-size: calc(24 / 20 * 1em);
  transform: translateY(-0.1em);
}
@media screen and (max-width: 767px) {
  .faq-section {
    width: calc(360 / var(--primary-base-width) * 100vw);
    margin-inline: auto;
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-block: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    overflow: hidden;
  }
  .faq__outer::before {
    left: 0;
    width: calc(360 / var(--primary-base-width) * 100vw);
    border-radius: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    transform: 0;
  }
  .faq__inner {
    width: calc(310 / var(--primary-base-width) * 100vw);
  }
  .faq__list-wrap {

  }
  .faq__inner .splide__section .splide__track {
    padding: 0px !important;
    padding-right: calc(10 / var(--primary-base-width) * 100vw) !important;
  }
  .faq__item {
    width: calc(280 / var(--primary-base-width) * 100vw) !important;
    margin-left: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    padding-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-inline: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .faq__title.title--secondary {
    margin-bottom: 0;
    margin-bottom: 0.75em;
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
    line-height: 155%;
    letter-spacing: 0.05em;
    transition: margin-bottom 0.2s ease-out;
  }
  .faq__excerpt.txt--primary {
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    line-height: 150%;
    letter-spacing: 0.05em;
  }
  .faq__num {
    position: absolute;
    top: max(-10 / var(--primary-base-width) * 100vw, -10px * var(--responsive-ratio));
    left: max(-10 / var(--primary-base-width) * 100vw, -10px * var(--responsive-ratio));
    gap: 0.05em;
    width: calc(36 / 15 * 1em);
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    letter-spacing: 0em;
    transform: none;
  }
  .faq__num .num {
    font-size: calc(18 / 15 * 1em);
    transform: translateY(-0.1em);
  }
  .faq__lead-link-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    text-align: center;
  }
}


/*-------------------------------------------------

 resources

--------------------------------------------------*/
.resources-section {
  position: relative;
  padding-bottom: clamp(30px * var(--responsive-ratio), 30 / var(--primary-base-width) * 100vw, 30px);
}
.resources__excerpt {
  color: var(--primary-txt-color);
  font-size: clamp(1.0rem, (14 / var(--primary-inner-width) * 100vw), 1.4rem);
  line-height: 170%;
  letter-spacing: 0.1em;
}
.resources__meta {
  display: flex;
  align-items: center;
  color: var(--primary-txt-color);
  margin-top: auto;
  padding-top: min(25 / var(--primary-inner-width) * 100vw, 25px);
  font-size: clamp(1.0rem, (15 / var(--primary-inner-width) * 100vw), 1.5rem);
}
.resources__date {
  color: #909090;
  font-size: calc(14 / 15 * 1em);
}
@media screen and (max-width: 767px) {
  .resources-section {
    padding-top: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    padding-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .resources__inner .site-common__lead {
    margin-bottom: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
  }
  .resources__list {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
  }
  .resources__meta {
    padding-top: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    font-size: min(12 / var(--primary-base-width) * 100vw, 12px * var(--responsive-ratio));
  }
  .resources__lead-link-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    text-align: center;
  }
}

/*-------------------------------------------------

 column

--------------------------------------------------*/
.column-section {
  position: relative;
  padding-top: 0;
  padding-bottom: clamp(80px * var(--responsive-ratio), 100 / var(--primary-base-width) * 100vw, 80px);
}
.faq-section + .column-section {
  margin-top: var(--section-padding-block);
}
.column__item-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.85em;
  color: var(--primary-txt-color);
  margin-bottom: calc(15 / 13 * 1em);
  font-size: clamp(1.0rem, (13 / var(--primary-inner-width) * 100vw), 1.3rem);
}
.column__item-tags a {
  color: var(--primary-txt-color);
  text-decoration: none;
}
.tags__item {
  padding: 0.65em 1em;
  background-color: #e7e7e7;
  border-radius: 100vmax;
}
.column__excerpt {
  color: var(--primary-txt-color);
  font-size: clamp(1.0rem, (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  line-height: 170%;
  letter-spacing: 0.2em;
}
.column__meta {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  color: var(--primary-txt-color);
  margin-top: auto;
  padding-top: min(15 / var(--primary-inner-width) * 100vw, 15px);
  font-size: clamp(1.0rem, (15 / var(--primary-inner-width) * 100vw), 1.5rem);
}
.column__date {
  color: #909090;
  font-size: calc(14 / 15 * 1em);
}
@media screen and (max-width: 767px) {
  .column-section {
    padding-top: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    padding-bottom: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
  }
  .column__inner.site-common__inner {
    width: calc(320 / var(--primary-base-width) * 100vw);
  }
  .column__inner .site-common__lead {
    margin-bottom: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
  }
  .column__list {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
  }
  .column__lead-link-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    text-align: center;
  }
  .column__item-tags {
    gap: 0.8em;
    margin-bottom: calc(15 / 12 * 1em);
    font-size: min(11 / var(--primary-base-width) * 100vw, 11px * var(--responsive-ratio));
  }
  .tags__item {
    padding: 0.5em 0.8em;
  }
  .column__meta {
    padding-top: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    font-size: min(12 / var(--primary-base-width) * 100vw, 12px * var(--responsive-ratio));
  }
  .column__date {
    font-size: calc(12 / 13 * 1em);
  }
}

/*-------------------------------------------------

 information

--------------------------------------------------*/
.information-section {
  position: relative;
  padding-top: min(120 / var(--primary-base-width) * 100vw, 120px);
}
.faq-section + .information-section {
	margin-top: var(--section-padding-block);
}
.information-section::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 140%;
  background: var(--primary-bg-color);
  z-index: -1;
  border-radius: min(200 / var(--primary-base-width) * 100vw, 300px) 0 0 0;
}
.information__inner.site-common__inner {
  display: flex;
  justify-content: space-between;
}
.information__list-wrap {
  width: min(940 / var(--primary-inner-width) * 100vw, 940px);
  margin-inline: auto;
}
.information__list {
  width: 100%;
}
.information__item {
  background-color: var(--white-color);
  border-radius: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.information__item + .information__item {
  margin-top: 10px;
}
.information__item:nth-child(n+4) {
  max-height: 0;
  margin-top: 0;
  opacity: 0;
  transition: opacity .2s ease-out, max-height .2s ease-out, margin-top 0s ease-out .2s;
  pointer-events: none;
}
.information__list.is-open .information__item:nth-child(n+4) {
  max-height: 100em;
  opacity: 1;
  transition: opacity .4s ease-out, max-height .4s ease-out, margin-top 0s ease-out 0s;
  pointer-events: auto;
}
.information__list.is-open .information__item + .information__item {
  margin-top: 10px !important;
}
.information__link {
  position: relative;
  display: block;
  text-decoration: none;
}
.information__content {
  position: relative;
  display: grid;
  grid-template-columns: min-content;
  column-gap: min(60 / var(--primary-inner-width) * 100vw, 60px);
  row-gap: min(15 / var(--primary-inner-width) * 100vw, 15px);
  padding: min(24 / var(--primary-inner-width) * 100vw, 24px) min(40 / var(--primary-inner-width) * 100vw, 40px);
  padding-bottom: min(16 / var(--primary-inner-width) * 100vw, 16px);
  color: #909090;
  font-size: clamp(1.3rem * var(--responsive-ratio), 13 / var(--primary-inner-width) * 100vw, 1.3rem);
}
a[target="_blank"].information__link::after,
a[target="_blank"].information__link::before {
  content: '';
  position: absolute;
  top: 50%;
  right: min(40 / var(--primary-inner-width) * 100vw, 40px);
  width: min(40 / var(--primary-inner-width) * 100vw, 40px);
  aspect-ratio: 1 / 1;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 40 40'%3E%3Cdefs%3E%3ClinearGradient id='g1' x1='0' y1='0' x2='40.8685' y2='0.908012' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%231E94E6'/%3E%3Cstop offset='0.8' stop-color='%2371D7EB'/%3E%3C/linearGradient%3E%3ClinearGradient id='g2' x1='12.5' y1='12.5' x2='27.8257' y2='12.8405' gradientUnits='userSpaceOnUse'%3E%3Cstop stop-color='%231E94E6'/%3E%3Cstop offset='0.8' stop-color='%2371D7EB'/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect x='0.5' y='0.5' width='39' height='39' rx='19.5' fill='none' stroke='url(%23g1)'/%3E%3Cpath fill='url(%23g2)' d='M26 23V14H17V23H26ZM27.5 23C27.5 23.3978 27.342 23.7794 27.0607 24.0607C26.7794 24.342 26.3978 24.5 26 24.5H17C16.6022 24.5 16.2206 24.342 15.9393 24.0607C15.658 23.7794 15.5 23.3978 15.5 23V14C15.5 13.1675 16.1675 12.5 17 12.5H26C26.3978 12.5 26.7794 12.658 27.0607 12.9393C27.342 13.2206 27.5 13.6022 27.5 14V23ZM23 26V27.5H14C13.6022 27.5 13.2206 27.342 12.9393 27.0607C12.658 26.7794 12.5 26.3978 12.5 26V16.25H14V26H23Z'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  transform: translateY(-50%);
}
a[target="_blank"].information__link::after {
  background-image: url('data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 40 40%27%3E%3Cdefs%3E%3ClinearGradient id=%27g%27 x1=%270%27 y1=%270%27 x2=%2740.8685%27 y2=%270.908012%27 gradientUnits=%27userSpaceOnUse%27%3E%3Cstop stop-color=%27%231E94E6%27/%3E%3Cstop offset=%270.8%27 stop-color=%27%2371D7EB%27/%3E%3C/linearGradient%3E%3C/defs%3E%3Crect width=%2740%27 height=%2740%27 rx=%2720%27 fill=%27url(%23g)%27/%3E%3Cpath fill=%27%23fff%27 d=%27M26 23V14H17V23H26ZM27.5 23C27.5 23.3978 27.342 23.7794 27.0607 24.0607C26.7794 24.342 26.3978 24.5 26 24.5H17C16.6022 24.5 16.2206 24.342 15.9393 24.0607C15.658 23.7794 15.5 23.3978 15.5 23V14C15.5 13.1675 16.1675 12.5 17 12.5H26C26.3978 12.5 26.7794 12.658 27.0607 12.9393C27.342 13.2206 27.5 13.6022 27.5 14V23ZM23 26V27.5H14C13.6022 27.5 13.2206 27.342 12.9393 27.0607C12.658 26.7794 12.5 26.3978 12.5 26V16.25H14V26H23Z%27/%3E%3C/svg%3E');
  opacity: 0;
  transition: opacity 0.1s ease-in-out;
}
a.information__link .information__content {
  padding-right: min(110 / var(--primary-inner-width) * 100vw, 110px);
}
@media (hover: hover) and (pointer: fine) {
  a[target="_blank"].information__link:hover::after {
    opacity: 1;
    transition: opacity 0.1s ease-in-out 0.1s;
  }
}
.information__title {
  grid-column: 2 / 3;
  grid-row: 1 / 2;
  font-size: calc(17 / 13 * 1em);
  font-weight: 400;
  line-height: 150%;
  color: var(--primary-txt-color);
}
.information__excerpt {
  grid-column: 2 / 3;
  grid-row: 2 / 3;
  line-height: 170%;
}
.information__meta-category {
  width: min(120 / var(--primary-inner-width) * 100vw, 120px);
  padding-top: 0.2em;
}
.information__meta-date {
  text-align: center;
}
.information__meta-date .information__date {
  display: inline-block;
  margin-inline: -1em;
  font-size: clamp(1.3rem * var(--responsive-ratio), 13 / var(--primary-inner-width) * 100vw, 1.3rem);
  line-height: 170%;
  white-space: nowrap;
}
.information__meta {
  grid-column: 1 / 2;
  grid-row: 1 / 3;
  display: flex;
  flex-direction: column;
  align-items: center;
  width: min(120 / var(--primary-inner-width) * 100vw, 120px);
  padding-top: 0.2em;
  padding-right: 0;
}
.information__category {
  display: inline-block;
  width: 100%;
  margin-bottom: 1.4em;
  padding-top: 0.35em;
  padding-bottom: 0.25em;
  padding-inline: 0.25em;
  color: var(--white-color);
  text-align: center;
  letter-spacing: 0.05em;
  line-height: 130%;
  background-color: var(--primary-blue-color);
  border-radius: 100vmax;
  border-radius: 1em;
}
.information__meta .information__date {
  width: 100%;
  white-space: nowrap;
  text-align: center;
}
.information__more {
  margin-top: min(50 / var(--primary-inner-width) * 100vw, 50px);
  text-align: right;
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .information__inner.site-common__inner {
    flex-direction: column;
  }
  .information-section__title {
    width: min(940 / var(--primary-inner-width) * 100vw, 940px);
    margin-inline: auto;
  }
}
@media screen and (min-width: 992px) {
}
@media screen and (max-width: 991px) {
  .information__inner.site-common__inner {
    flex-direction: column;
    width: 80%;
    margin-inline: auto;
  }
}
@media screen and (max-width: 767px) {
  .information-section {
    padding-top: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
    padding-bottom: min(100 / var(--primary-base-width) * 100vw, 100px * var(--responsive-ratio));
  }
  .information-section::before {
    border-radius: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio)) 0 0 0;
  }
  .information__inner.site-common__inner {
    width: calc(330 / var(--primary-base-width) * 100vw);
  }
  .information__list-wrap {
    width: 100%;
  }
  .information__item + .information__item {
    margin-top: 10px;
  }
  .information__item:nth-child(n+4) {
    margin-top: 0;
  }
  .information__list.is-open .information__item + .information__item {
    margin-top: 10px !important;
  }
  .information__item {
    border-radius: 20px;
  }
  .information__content {
    grid-template-columns: 1fr;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    padding-inline: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    padding-block: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    font-size: min(12 / var(--primary-base-width) * 100cqi, 1.2rem * var(--responsive-ratio));
  }
  a.information__link .information__content {
    padding-right: min(25 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .information__excerpt {
    display: none;
  }
  .information__meta-category {
    width: auto;
    padding-top: 0;
  }
  .information__meta-date {
    text-align: left;
  }
  .information__meta-date .information__date {
    margin-inline: 0;
    font-size: min(11 / var(--primary-base-width) * 100cqi, 1.1rem * var(--responsive-ratio));
    line-height: 1;
  }
  .information__meta {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    width: auto;
    padding-bottom: 0;
    padding-right: 0;
  }
  .information__category {
    width: auto;
    min-width: min(110 / var(--primary-base-width) * 100vw, 110px * var(--responsive-ratio));
    max-width: min(150 / var(--primary-base-width) * 100vw, 150px * var(--responsive-ratio));
    margin-bottom: 0;
    padding-block: 0.35em;
    padding-inline: 0.5em;
  }
  .information__meta .information__date {
    width: auto;
    text-align: left;
  }
  .information__title {
    grid-column: 1 / 2;
    grid-row: 3 / 4;
    margin-bottom: 0;
    font-size: calc(14 / 12 * 1em);
    line-height: 170%;
  }
  a[target="_blank"].information__link::after,
  a[target="_blank"].information__link::before {
    top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    right: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    width: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    transform: translateY(0);
  }
  .information__more {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    text-align: center;
  }
}

/*-------------------------------------------------

 footer

--------------------------------------------------*/
.site-footer {
  position: relative;
  padding-top: min(160 / var(--primary-base-width) * 100vw, 160px);
  z-index: 1;
  overflow: clip;
}
.site-footer::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: var(--primary-txt-color);
  z-index: -1;
  border-radius: 0 min(300 / var(--primary-base-width) * 100vw, 3000px) 0 0;
}
.site-footer__outer {
  position: relative;
  padding-bottom: min(40 / var(--primary-base-width) * 100vw, 40px);
  color: var(--white-color);
}
.site-footer__inner {
  position: relative;
  width: min(1385 / var(--primary-base-width) * 100vw, 1385px);
  margin-left: min(100 / var(--primary-base-width) * 100vw, 100px);
  margin-inline: auto;
  display: flex;
  justify-content: space-between;
  container-type: inline-size;
  --site-footer__inner-width: 1385;
}
.site-footer__logo-area {
  width: calc(372 / var(--site-footer__inner-width) * 100cqi);
}
.site-footer__nav-area {
  width: calc(834 / var(--site-footer__inner-width) * 100cqi);
}
.site-footer__nav {
  margin-top: calc(17 / var(--site-footer__inner-width) * 100cqi);
  margin-bottom: calc(70 / var(--site-footer__inner-width) * 100cqi);
}
.site-footer__nav-list {
  display: grid;
  grid-template-columns: repeat(1, max-content);
  grid-template-rows: repeat(4, auto);
  grid-auto-flow: column;
  gap: 2.5em 7em;
  font-size: clamp(1.6rem * var(--responsive-ratio), 16 / var(--site-footer__inner-width) * 100cqi, 1.6rem);
}
.site-footer__nav-link {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0.625em;
  color: var(--white-color);
  letter-spacing: 0.2em;
  text-decoration: none;
  transition: color .1s ease-in-out;
}
.site-footer__nav-link .button--primary__icon {
  position: relative;
  display: inline-block;
  top: auto;
  right: auto;
  width: 1em;
  transform: none;
}
.site-footer__nav-link .button--primary__icon::before {
  width: calc(6 / 16 * 100%);
  transition: width .4s ease-out;
}
.site-footer__nav-link .button--primary__icon::after {
  width: calc(5 / 16 * 100%);
  background: url(../img/icon_arrow_right_gray.svg) no-repeat center / contain;
  transition: translate .2s ease-out, opacity .2s ease-out;
}
@media (hover: hover) and (pointer: fine) {
  .site-footer__nav-link:hover .button--primary__icon::before {
    width: 100% !important;
  }
  .site-footer__nav-link:hover .button--primary__icon::after {
    opacity: 1;
    translate: -40% -50%;
    transition: translate .4s ease-out .2s, opacity .2s ease-out .2s;
  }
}
.site-footer__actions {
  display: flex;
  align-items: center;
  gap: calc(15 / 834 * 100%);
}
.site-footer__button {
  width: min(232 / var(--site-footer__inner-width) * 100cqi, 232px);
  height: auto;
  aspect-ratio: 232 / 68;
  padding-inline: calc(40 / 16 * 1em) 0;
  font-size: min(16 / var(--site-footer__inner-width) * 100cqi, 1.6rem);
  text-align: center;
  line-height: 130%;
  white-space: nowrap;
}
.site-footer__action--login {
  flex: 1;
  text-align: right;
}
.site-footer__action--login .site-footer__action-link {
  color: var(--white-color);
  font-size: clamp(1.6rem * var(--responsive-ratio), 16 / var(--site-footer__inner-width) * 100cqi, 1.6rem);
  letter-spacing: 0.2em;
  text-decoration: none;
  white-space: nowrap;
  transition: color .1s ease-in-out;
}
.site-footer__sub-nav-list {
  position: relative;
  display: flex;
  justify-content: flex-end;
  gap: calc(30 / var(--site-footer__inner-width) * 100cqi);
  margin-top: calc(70 / var(--site-footer__inner-width) * 100cqi);
  margin-bottom: calc(30 / var(--site-footer__inner-width) * 100cqi);
  padding-top: calc(50 / var(--site-footer__inner-width) * 100cqi);
}
.site-footer__sub-nav-list::before {
  content: '';
  position: absolute;
  top: 0;
  left: -2%;
  width: 104%;
  height: 1px;
  background-color: #909090;
}
.site-footer__sub-nav-link {
  color: #909090;
  font-size: clamp(1.3rem * var(--responsive-ratio), 13 / var(--site-footer__inner-width) * 100cqi, 1.3rem);
  text-decoration: none;
  transition: color .1s ease-in-out;
}
.site-footer__copyright {
  color: #909090;
  font-size: clamp(1.2rem * var(--responsive-ratio), 12 / var(--site-footer__inner-width) * 100cqi, 1.2rem);
  text-align: right;
  letter-spacing: 0.1em;
}
@media (hover: hover) and (pointer: fine) {
  footer .brand a:hover {
    filter: brightness(1.1);
    transition: filter .1s ease-in-out .1s;
  }
  .site-footer__nav-link:hover,
  .site-footer__action--login .site-footer__action-link:hover {
  }
  .site-footer__action--login .site-footer__action-link:hover {
    color: #cccccc;
    transition: color .1s ease-in-out .1s;
  }
  .site-footer__sub-nav-link:hover {
    color: #b0b0b0;
    transition: color .1s ease-in-out .1s;
  }
}
@media screen and (max-width: 991px) {
  .site-footer__nav-area {
    width: calc(880 / var(--site-footer__inner-width) * 100cqi);
  }
}
@media screen and (max-width: 767px) {
  .site-footer {
    padding-top: calc(90 / var(--primary-base-width) * 100vw);
  }
  .site-footer::before {
    border-radius: 0 min(150 / var(--primary-base-width) * 100vw) 0 0;
  }
  .site-footer__outer {
    padding-bottom: calc(20 / var(--primary-base-width) * 100vw);
  }
  .site-footer__inner {
    flex-direction: column;
    gap: calc(40 / var(--site-footer__inner-width) * 100cqi);
    width: 100%;
    --site-footer__inner-width: 375;
  }
  .site-footer__logo-area {
    width: calc(240 / var(--site-footer__inner-width) * 100cqi);
    margin-left: calc(18 / var(--site-footer__inner-width) * 100cqi);
  }
  .site-footer__nav-area {
    width: calc(375 / var(--site-footer__inner-width) * 100cqi);
  }
  .site-footer__nav {
    margin-top: 0;
    margin-bottom: calc(50 / var(--site-footer__inner-width) * 100cqi);
  }
  .site-footer__nav-list {
    display: grid;
    grid-template-columns: repeat(2, max-content);
    grid-template-rows: repeat(4, auto);
    grid-auto-flow: column;
    gap: calc(25 / 12 * 1em) calc(20 / 12 * 1em);
    margin-left: calc(40 / var(--site-footer__inner-width) * 100cqi);
    font-size: calc(12 / var(--site-footer__inner-width) * 100cqi);
  }
  .site-footer__nav-link::before {
    transform: translateY(0em);
  }
  .site-footer__nav-link .button--primary__icon {
    width: 1em;
  }
  .site-footer__nav-link .button--primary__icon::before {
    width: calc(5 / 12 * 100%);
  }
  .site-footer__actions {
    flex-direction: column;
    gap: min(10 / var(--site-footer__inner-width) * 100cqi, 10px * var(--responsive-ratio));
  }
  .site-footer__button {
    justify-content: center;
    width: calc(280 / 14 * 1em);
    aspect-ratio: 280 / 70;
    padding-left: 0;
    font-size: min(15 / var(--site-footer__inner-width) * 100cqi, 1.5rem * var(--responsive-ratio));
    line-height: 140%;
  }
  .site-footer__action--login {
    margin-top: min(18 / var(--site-footer__inner-width) * 100cqi, 18px * var(--responsive-ratio));
    text-align: center;
  }
  .site-footer__action--login .site-footer__action-link {
    font-size: min(12 / var(--site-footer__inner-width) * 100cqi, 1.2rem * var(--responsive-ratio));
    letter-spacing: 0.1em;
  }
  .site-footer__sub-nav-list {
    justify-content: center;
    gap: calc(30 / var(--site-footer__inner-width) * 100cqi);
    margin-top: calc(60 / var(--site-footer__inner-width) * 100cqi);
    margin-bottom: calc(30 / var(--site-footer__inner-width) * 100cqi);
    padding-top: calc(30 / var(--site-footer__inner-width) * 100cqi);
  }
  .site-footer__sub-nav-list::before {
    left: calc(20 / var(--site-footer__inner-width) * 100cqi);
    width: calc(100% - 40 / var(--site-footer__inner-width) * 100cqi);
  }
  .site-footer__sub-nav-link {
    font-size: min(10 / var(--site-footer__inner-width) * 100cqi, 1.0rem * var(--responsive-ratio));
  }
  .site-footer__copyright {
    font-size: min(10 / var(--site-footer__inner-width) * 100cqi, 1.0rem * var(--responsive-ratio));
    text-align: center;
  }
}

/*-------------------------------------------------

 サービス・プラン

--------------------------------------------------*/
.feature-introduction__content {
  position: relative;
  width: clamp(970px * var(--responsive-ratio), 970 / var(--primary-inner-width) * 100vw, 970px);
  margin-inline: auto;
  margin-bottom: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
  padding: clamp(60px * var(--responsive-ratio), 60 / var(--primary-inner-width) * 100vw, 60px) clamp(120px * var(--responsive-ratio), 120 / var(--primary-inner-width) * 100vw, 120px);
  text-align: center;
  background-image: var(--primary-gradient);
  border-radius: 40px;
}
.feature-introduction__content::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border-radius: 40px;
  border: 1px solid transparent;
  background-color: var(--primary-bg-color);
  background-origin: border-box;
  background-clip: border-box;
  -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  -webkit-mask-clip: border-box, padding-box;
  -webkit-mask-composite: destination-in;
  mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  mask-clip: border-box, padding-box;
  mask-composite: intersect;
}
.feature-introduction__content-item {
  position: relative;
}
.feature-introduction__content-title {
  margin-bottom: 1em;
  text-align: center;
  line-height: 1;
}
.feature-introduction__content-list {
  display: inline-block;
	counter-reset: listnum; /* カウンターをリセット */
	list-style: none; /* 標準のスタイルは消す */
}
.feature-introduction__content-list li {
  position: relative;
  padding-left: 2.0em;
}
.feature-introduction__content-list li::before {
  position: absolute;
  top: 0;
  left: 0;
	counter-increment: listnum; /* counter-resetと同じ文字列 */
	content: counter(listnum) ". "; /* カウントした数に応じて番号を表示 */
  color: var(--primary-blue-color);
  font-weight: 700;
  font-size: calc(24 / 20 * 1em);
}
.feature-introduction__content-list li + li {
  margin-top: 1em;
}
.feature-introduction__section .statistics__list {
  gap: clamp(48px * var(--responsive-ratio), 48 / var(--primary-inner-width) * 100vw, 48px);
  width: clamp(620px * var(--responsive-ratio), 620 / var(--primary-inner-width) * 100vw, 620px);
  margin-inline: auto;
  container-type: inline-size;
}
.feature-introduction__section .statistics__title-num {
  font-size: calc(24 / 18 * 1em);
}
.feature-introduction__section .statistics__title-percent {

}
.feature-introduction__section .statistics__title-reduce {

}
.feature-introduction__section .statistics__item-wrap {
  font-size: calc(20 / 620 * 100cqi);
}
.feature-introduction__section .statistics__item-num {
  font-size: calc(60 / 620 * 100cqi);
}
.feature-introduction__section .statistics__item-num.num2 {
  font-size: calc(43 / 620 * 100cqi);
}
.feature-introduction__section .statistics__item-num.num3 {
  font-size: calc(48 / 620 * 100cqi);
}
.feature-introduction__section .statistics__note {
  margin-top: calc(20 / 13 * 1em);
  margin-inline: -5em;
  font-size: clamp(13px * var(--responsive-ratio), 13 / var(--primary-inner-width) * 100vw, 13px);
  letter-spacing: 0.1em;
}
.feature-system__img {
  margin-bottom: clamp(60px * var(--responsive-ratio), 60 / var(--primary-base-width) * 100vw, 60px)
}
.feature-system__content-title {
  margin-bottom: 1.5em;
  text-align: center;
  line-height: 1;
}
.feature-system__content-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
}
.feature-system__content-item {
  position: relative;
  padding: clamp(30px * var(--responsive-ratio), 30 / var(--primary-inner-width) * 100vw, 30px);
  background-image: var(--primary-gradient);
  border-radius: 30px;
}
.feature-system__content-item-nav {
  position: absolute;
  top: 50%;
  left: clamp(-42px, -42 / var(--primary-inner-width) * 100vw, -42px * var(--responsive-ratio));
  transform: translateX(-50%) translateY(-50%);
  width: min(45 / var(--primary-inner-width) * 100vw, 45px);
  height: min(45 / var(--primary-inner-width) * 100vw, 45px);
  background-image: linear-gradient(to right, var(--primary-color) 0%, var(--secondary-color) 80%);
  border-radius: 100vmax;
}
.feature-system__content-item-nav::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22%;
  aspect-ratio: 83 / 150;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 10.8 19.5'%3E%3Cpath fill='%23fff' d='M9.8,19.5c-.3,0-.5,0-.7-.3L.3,10.5c-.4-.4-.4-1,0-1.4L9,.3c.4-.4,1-.4,1.4,0s.4,1,0,1.4L2.4,9.8l8,8c.4.4.4,1,0,1.4s-.5.3-.7.3Z'/%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  transform: translate(-35%, -50%) rotate(180deg);
}
.feature-system__content-item::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border-radius: 30px;
  border: 1px solid transparent;
  background-color: var(--white-color);
  background-origin: border-box;
  background-clip: border-box;
  -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  -webkit-mask-clip: border-box, padding-box;
  -webkit-mask-composite: destination-in;
  mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  mask-clip: border-box, padding-box;
  mask-composite: intersect;
}
.feature-system__content-item-title {
  position: relative;
  margin-bottom: 1em;
  padding-bottom: 1em;
  color: var(--primary-blue-color);
  font-weight: bold;
  text-align: center;
}
.feature-system__content-item-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: -2%;
  width: 104%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.feature-system__content-item-num {
  font-size: clamp(70px * var(--responsive-ratio), 70 / var(--primary-inner-width) * 100vw, 70px);
  font-weight: 500;
  line-height: 1;
  background-image: var(--primary-gradient);
	-webkit-background-clip:text;
	-webkit-text-fill-color: transparent;
}
.feature-system__content-item .txt--primary {
  position: relative;
}
.feature-reason__content {
  margin-bottom: var(--primary-padding);
}
.feature-reason__content-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: calc(100 / var(--primary-inner-width) * 100%);
  width: calc(1190 / var(--primary-inner-width) * 100%);
  margin-inline: auto;
}
.feature-reason__content-item-title {
  position: relative;
  display: flex;
  align-items: center;
  gap: .6em;
  margin-bottom: 1em;
  padding-bottom: 1em;
  color: var(--primary-blue-color);
  font-weight: bold;
}
.feature-reason__content-item-num {
  font-size: clamp(70px * var(--responsive-ratio), 70 / var(--primary-inner-width) * 100vw, 70px);
  font-weight: 500;
  line-height: 1;
  background-image: var(--primary-gradient);
	-webkit-background-clip:text;
	-webkit-text-fill-color: transparent;
}
.feature-reason___more {
  margin-bottom: clamp(100px * var(--responsive-ratio), 100 / var(--primary-inner-width) * 100vw, 100px);
  text-align: center;
}
.feature-plan__content {
  margin-bottom: var(--primary-padding);
}
.feature-plan__table {
  width: 100%;
}
.feature-plan__table th,
.feature-plan__table td {
  color: var(--white-color);
  font-size: clamp(1.2rem, 16 / var(--primary-inner-width) * 100vw, 1.6rem);
}
.feature-plan__table .plan-name {
  position: relative;
  width: min(215 / var(--primary-inner-width) * 100vw, 215px);
  font-size: clamp(1.4rem, 20 / var(--primary-inner-width) * 100vw, 2.0rem);
  font-weight: 700;
  text-align: center;
  background: var(--secondary-blue-color);
  vertical-align: top;
}
.feature-plan__table .plan-name.name2 {
  background: var(--primary-blue-color);
}
.feature-plan__table .plan-name .name-wrap {
  position: absolute;
  top: 0;
  left: 50%;
  display: block;
  line-height: 150%;
  translate: -50% -36%;
  white-space: nowrap;
  z-index: 5;
}
.feature-plan__table .plan-name .min {
  display: inline-block;
  font-size: calc(13 / 20 * 1em);
  font-weight: 400;
  line-height: 100%;
  transform: translateY(-0.25em);
}
.feature-plan__table .plan-name::before {
  content: '';
  position: absolute;
  left: 0;
  top: -2.5em;
  width: calc(100% - 5px);
  height: 2.5em;
  background-color: var(--secondary-blue-color);
  border-radius:min(20 / var(--primary-inner-width) * 100vw, 20px) min(20 / var(--primary-inner-width) * 100vw, 20px) 0 0 ;
}
.feature-plan__table .plan-name.name2::before {
  right: 0;
  left: auto;
  background-color: var(--primary-blue-color);
}
.feature-plan__table .plan-name.name2::after {
  right: auto;
  left: 0;
}
.feature-plan__table .plan-name::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  width: 5px;
  height: 100%;
  background-color: var(--white-color);
}
.feature-plan__table .plan-name.name2::after {
  right: auto;
  left: 0;
}
.feature-plan__table .functional {
  position: relative;
  font-size: calc(20 / 16 * 1em);
  font-weight: 700;
  text-align: center;
  background: var(--secondary-blue-color);
  z-index: 2;
}
.feature-plan__table .functional.functional2 {
  background: var(--primary-blue-color);
}
.feature-plan__table .functional::before {
  content: '';
  position: absolute;
  top: auto;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 1px;
  border-bottom: 1px dashed var(--white-color);
}
.feature-plan__table .functional::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  width: 5px;
  height: 100%;
  background-color: var(--white-color);
}
.feature-plan__table .functional.functional2::after {
  right: auto;
  left: 0;
}
.feature-plan__table .functional-last,
.feature-plan__table .functional2.functional-last {
  background-color: transparent;
}
.feature-plan__table .functional-last::before {
  width: calc(100% - 5px);
  height: 100%;
  background-color: var(--secondary-blue-color);
  border-radius: 0 0 min(20 / var(--primary-inner-width) * 100vw, 20px) min(20 / var(--primary-inner-width) * 100vw, 20px);
  border: none;
}
.feature-plan__table .functional2.functional-last::before {
  left: auto;
  right: 0;
  background-color: var(--primary-blue-color);
}
.feature-plan__table .functional-blank {
  height: calc(71 / 20 * 1em);
}
.feature-plan__table .functional.functional-blank::before {
  display: none;
}
.feature-plan__table .functional .plan-name-txt {
  display: none;
}
.feature-plan__table .head-level1 {
  position: relative;
  padding-left: min(20 / var(--primary-inner-width) * 100vw, 20px);
  height: min(20 / var(--primary-inner-width) * 100vw, 20px);
  height: 0;
  color: var(--primary-blue-color);
  font-weight: bold;
}
.feature-plan__table .head-level2 {
  position: relative;
  padding-top: min(12 / var(--primary-inner-width) * 100vw, 12px);
  height: min(72 / var(--primary-inner-width) * 100vw, 72px);
  color: var(--primary-blue-color);
  font-weight: bold;
}
.feature-plan__table .head-level2::before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  scale: 1 .5;
  background-color: var(--primary-blue-color);
}
.feature-plan__table .head-level3 {
  position: relative;
  padding-inline: min(50 / var(--primary-inner-width) * 100vw, 50px);
  color: var(--primary-txt-color);
  font-weight: bold;
  line-height: 135%;
  white-space: nowrap;
  vertical-align: middle;
}
.feature-plan__table .head-level3 br.ctl {
  display: none;
}
.feature-plan__table .head-level3 .option {
  position: relative;
  display: inline-block;
  margin-left: 0.25em;
  font-size: calc(11 / 16 * 1em);
  font-weight: 400;
  line-height: 1;
  translate: 0 -0.125em;
}
.feature-plan__table .head-level3 .min {
  position: relative;
  display: inline-block;
  font-size: calc(13 / 16 * 1em);
}
.feature-plan__table .head-level3:not(.head-blank)::before {
  content: '';
  position: absolute;
  left: min(50 / var(--primary-inner-width) * 100vw, 50px);
  bottom: 0;
  width: 300%;
  height: 1px;
  border-bottom: 1px dashed #e7e7e7;
}
.feature-plan__table .txt-level1 {
  position: relative;
  display: flex;
  align-items: center;
  min-height: calc(60 / 13 * 1em);
  padding-block: 1.0em;
  padding-right: min(30 / var(--primary-inner-width) * 100vw, 30px);
  color: var(--gray-color);
  font-size: calc(13 / 16 * 1em);
  line-height: 150%;
  letter-spacing: 0.05em;
}
.feature-plan__table .txt-level1::before {
	content: '';
	min-height: calc(40 / 13 * 1em);
}
.feature-plan__table .txt-level2 {
  position: relative;
  padding-block: 1.25em 0em;
  padding-right: min(60 / var(--primary-inner-width) * 100vw, 560px);
  padding-left: min(180 / var(--primary-inner-width) * 100vw, 180px);
  color: var(--primary-txt-color);
  font-size: calc(13 / 16 * 1em);
  line-height: 150%;
}
.feature-plan__note {
  margin-top: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
  text-align: left;
}
.feature-plan___more {
  text-align: center;
}
.feature-application__content {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
  margin-bottom: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
  width: 70%;
  margin-left: auto;
  margin-right: auto;
}
.feature-application__contact,
.feature-application__application {
  position: relative;
  text-align: center;
  background-image: var(--primary-gradient);
  border-radius: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
}
.feature-application__application::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border-radius: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
  border: 5px solid transparent;
  background-color: #fff;
  background-origin: border-box;
  background-clip: border-box;
  -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  -webkit-mask-clip: border-box, padding-box;
  -webkit-mask-composite: destination-in;
  mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  mask-clip: border-box, padding-box;
  mask-composite: intersect;
}
.feature-application__contact > a,
.feature-application__application > a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  /* aspect-ratio: 620 / 300; */
  aspect-ratio: 620 / 200;
  color: var(--white-color);
  text-decoration: none;
}
.feature-application__contact .button--primary__icon,
.feature-application__application .button--secondary__icon {
  position: absolute;
  display: inline-block;
  top: 50%;
  right: clamp(35px * var(--responsive-ratio), 35 / var(--primary-inner-width) * 100vw, 35px);
  width: clamp(36px * var(--responsive-ratio), 36 / var(--primary-inner-width) * 100vw, 36px);
  aspect-ratio: 1 / 1;
  background-color: rgba(255, 255, 255, .30);
  transform: translateY(-50%);
  border-radius: 100vmax;
  z-index: 1;
}
.feature-application__application .button--secondary__icon {
  background-color: rgba(113, 215, 235, 0.3);
}
.feature-application__contact .button--primary__icon::before,
.feature-application__application .button--secondary__icon::before {
  width: calc(14 / 50 * 100%);
}
@media (hover: hover) and (pointer: fine) {
  .feature-application__contact:hover .button--primary__icon::before,
  .feature-application__application:hover .button--secondary__icon::before {
    width: 100% !important;
  }
  .feature-application__contact:hover .button--primary__icon::after,
  .feature-application__application:hover .button--secondary__icon::after {
    opacity: 1;
    translate: -40% -50%;
    transition: translate .4s ease-out .2s, opacity .2s ease-out .2s;
  }
}
.feature-application__contact-inner {
  position: relative;
  text-align: center;
}
.feature-application__contact--midashi {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.25em;
  padding-inline: 0.75em;
  font-weight: bold;
  line-height: 1;
}
.feature-application__contact .feature-application__contact--midashi {
  color: var(--primary-blue-color);
  background: var(--white-color);
}
.feature-application__contact--midashi .max {
  display: inline-block;
  font-size: calc(24 / 17 * 1em);
  letter-spacing: 0.1em;
}
.feature-application__contact-title,
.feature-application__application-title {

}
.feature-application__application-title {  
  color: var(--primary-blue-color);
}
.feature-application__note p {
  font-size: clamp(15px * var(--responsive-ratio), 15 / var(--primary-inner-width) * 100vw, 15px);
}
.feature-application__note p + p {
  margin-top: 1em;
}
.feature-application__note p a {
  color: var(--primary-txt-color);
  font-weight: bold;
}
@media screen and (max-width: 991px) {
  .feature-plan__table .head-level3 br.ctl {
    display: inline;
  }
}
@media screen and (max-width: 767px) {
  .feature-introduction__section .page-common__section-lead {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .feature-introduction__content {
    width: 100%;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .feature-introduction__content::before {
    border-radius: 20px;
  }
  .feature-introduction__content-title {
    display: block;
    margin-bottom: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    padding: 0.75em 1em;
    font-size: min(18 / var(--primary-base-width) * 100vw, 1.8rem * var(--responsive-ratio));
    border-radius: 10px;
  }
  .feature-introduction__content-list li {
    padding-left: 1.5em;
  }
  .feature-introduction__section .statistics__outer {
    text-align: center;
  }
  .feature-introduction__section .statistics__list {
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    width: min(306 / var(--primary-base-width) * 100vw, 306px * var(--responsive-ratio));
  }
  .feature-introduction__section .statistics__note {
    display: inline-block;
    margin-top: 2em;
    margin-inline: -5em;
    font-size: min(10 / var(--primary-base-width) * 100vw, 1.0rem * var(--responsive-ratio));
    letter-spacing: 0.1em;
    text-align: left;
  }
  .feature-system__img {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .feature-system__content-title {
    margin-bottom: 1.5em;
    padding: 0.65em 0;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    border-radius: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
  }
  .feature-system__content-list {
    position: relative;
    width: min(310 / var(--primary-base-width) * 100vw, 310px * 1.6);
    margin-inline: auto;
    grid-template-columns: 1fr;
    gap: 0;
    padding-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-inline: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    background-image: var(--primary-gradient);
    border-radius: 20px;
  }
  .feature-system__content-list::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100%;
    border-radius: 20px;
    border: 1px solid transparent;
    background-color: var(--white-color);
    background-origin: border-box;
    background-clip: border-box;
    -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
    -webkit-mask-clip: border-box, padding-box;
    -webkit-mask-composite: destination-in;
    mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
    mask-clip: border-box, padding-box;
    mask-composite: intersect;
  }
  .feature-system__content-item {
    padding: 0;
    background-image: none;
    border-radius: 0;
  }
  .feature-system__content-item:not(:first-of-type) {
    padding-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio))
  }
  .feature-system__content-item::before {
    display: none;
  }
  .feature-system__content-item-title {
    gap: 0.75em;
    margin-bottom: 0.6em;
    padding-bottom: 0.8em;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    line-height: 1;
  }
  .feature-system__content-item-num {
    font-size: min(30 / var(--primary-base-width) * 100vw, 3.0rem * var(--responsive-ratio));
  }
  .feature-system__content-item-nav {
    top: 0;
    left: 50%;
    transform: translateX(-50%) translateY(min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio)));
    width: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    height: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
  }
  .feature-system__content-item-nav::after {
    width: 50%;
    aspect-ratio: 270 / 150;
    background-image: url('data:image/svg+xml,%3Csvg xmlns=%27http://www.w3.org/2000/svg%27 viewBox=%270 0 19.5 10.8%27%3E%3Cpath fill=%27%23fff%27 d=%27M0 1.2c0-.4.1-.7.4-1 .5-.5 1.2-.5 1.7 0l7.7 7.7L17.5.2c.5-.5 1.2-.5 1.7 0s.4 1.2 0 1.7l-8.6 8.6c-.5.5-1.2.5-1.7 0L.4 1.9c-.3-.3-.4-.7-.4-1Z%27/%3E%3C/svg%3E');
    transform: translate3d(-50%, -40%, 0) rotate(0deg);
  }
  .feature-reason__content-list {
    grid-template-columns: 1fr;
    gap: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    width: 100%;
    margin-inline: auto;
  } 
  .feature-reason__content-list .feature-reason__content-item {
    display: flex;
    align-items: flex-start;
    gap: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
  }
  .feature-reason__content-list .introduction__img {
    width: 40%;
  }
  .feature-reason__content-list .feature-reason__content-item-body {
    flex: 1;
    margin-top: -2.5%;
  }
  .feature-reason__content-item-title {
    gap: 0.75em;
    margin-bottom: 0.20em;
    padding-bottom: 0;
    line-height: 135%;
  }
  .feature-reason__content-item-txt {
    line-height: 150%;
    letter-spacing: 0.035em;
  }
  .feature-reason__content-item-num {
    padding-bottom: 0.1em;
    font-size: min(40 / var(--primary-base-width) * 100vw, 4.0rem * var(--responsive-ratio));
    font-weight: 700;
  }
  .feature-reason__outer .page-common__section-lead {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .feature-plan__section .page-common__section-lead {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .feature-plan__content {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .feature-plan__content-explain {
    display: flex !important;
    flex-direction: column;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    font-weight: bold;
  }
  .feature-plan__content-explain .explain-wrap {
    display: flex;
    align-items: center;
    color: var(--secondary-blue-color);
  }
  .feature-plan__content-explain .explain-wrap.stress-plan {
    color: var(--primary-blue-color);
  }
  .feature-plan__content-explain .icon-square {
    display: inline-block;
    margin-right: 0.5em;
    width: 1.5em;
    height: 1.5em;
    background-color: var(--secondary-blue-color);
  }
  .feature-plan__content-explain .explain-wrap.stress-plan .icon-square {
    background-color: var(--primary-blue-color);
  }
  .feature-plan__content-explain .plan-txt {
    display: inline-block;
    padding-left: 0.2em;
    color: var(--primary-txt-color);
    font-size: calc(11 / 12 * 1em);
    font-weight: 400;
  }
  .feature-plan__table .head-level3,
  .feature-plan__table th.plan-name,
  .feature-plan__table .sp_delete {
    display: none;
  }
  .feature-plan__table .txt-level1 .td-label br.ctl {
  }
  .feature-plan__table .head-level1 {
    position: relative;
    padding: 0.5em;
    padding-left: 12px;
    font-size: min(14 / var(--primary-base-width) * 100vw, 1.4rem * var(--responsive-ratio));
    border-radius: 10px;
  } 
  .feature-plan__table .head-level2 {
    position: relative;
    height: auto;
    padding-top: min(20 / var(--primary-base-width) * 100vw, 20px);
    padding-left: 12px;
    padding-left: 0;
    padding-bottom: 1em;
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
  .feature-plan__table .head-level1::after,
  .feature-plan__table .head-level2::after,
  .feature-plan__table .txt-level1::after,
  .feature-plan__table .txt-level2::after {
    display: none;
  }
  .feature-plan__table .head-level2::before {
    left: 12px;
    left: 0;
    bottom: 0;
    width: calc(100% - 12px);
    width: 100%;
  }
  .feature-plan__table .txt-level1 {
    display: block;
    padding: 1.2em;
    padding-left: 12px;
    padding-left: 0;
    font-size: min(10 / var(--primary-base-width) * 100vw, 1.0rem * var(--responsive-ratio));
  }
  .feature-plan__table .txt-level1::before {
    content: '';
    position: absolute;
    left: 0;
    bottom: 0;
    width: 105%;
    min-height: inherit;
    border-bottom: 1px dotted #e7e7e7;
  }
  .feature-plan__table .functional::before {
    border-bottom: 1px dotted var(--white-color);
  }
  .feature-plan__table .txt-level1 .td-label {
    display: block;
    margin-bottom: 0.25em;
    color: var(--primary-txt-color);
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    font-weight: bold;
    line-height: 155%;
  }
  .feature-plan__table .txt-level1 .option {
    display: inline-block;
    margin-left: 0.25em;
    font-size: calc(9 / 12 * 1em);
    translate: 0 -0.125em;
  }
  .feature-plan__table .functional::after {
    width: 1px;
  }
  .feature-plan__table .functional.functional2::after {
    display: none;
  }
  .feature-plan__table .functional {
    padding-inline: 0.5em;
    padding-inline: 0;
    font-size: min(10 / var(--primary-base-width) * 100vw, 1.0rem * var(--responsive-ratio));
  }
  .feature-plan__table .functional .plan-name-txt {
    display: inline-block;
  }
  .feature-plan__table .functional.plan-name {
    width: calc(60 / 10 * 1em);
    padding-block: 1.0em;
    font-size: min(10 / var(--primary-base-width) * 100vw, 1.0rem * var(--responsive-ratio));
    line-height: 150%;
    letter-spacing: 0.1em;
    border-radius: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio)) min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio)) 0 0;
    vertical-align: middle;
  }
  .feature-plan__note {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    text-align: justify;
  }
  .feature-reason___more {
    margin-bottom: var(--primary-padding);
  }
  .feature-application__content {
    grid-template-columns: 1fr;
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    width: 100%;
  }
  .feature-application__contact,
  .feature-application__application {
    border-radius: 30px;
  }
  .feature-application__application::before {
    border-radius: 30px;
    border-width: 3px;
  }
  .feature-application__contact > a,
  .feature-application__application > a {
    aspect-ratio: 620 / 240;
    padding-right: 12%;
  }
  .feature-application__contact-title,
  .feature-application__application-title {
    font-size: min(20 / var(--primary-base-width) * 100vw, 2.0rem * var(--responsive-ratio));
  }
  .feature-application__contact .button--primary__icon,
  .feature-application__application .button--secondary__icon {
    right: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    width: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
}

/*-------------------------------------------------

オプションサービス

--------------------------------------------------*/
.page-option .page-title {
  margin-bottom: clamp(50px * var(--responsive-ratio), 50 / var(--primary-inner-width) * 100vw, 50px);
}
.page-option .page-title__sub {
  justify-content: space-between;
  align-items: center;
}
.page-option .page-title__sub-button-link {
  width: calc(420 / 18 * 1em);
}
.mental-care-solution__section {

}
.page-option-section__title .site-common__txt--bg--primary {
  display: inline-block;
  line-height: 1;
}
.page-option .page-common__section:first-of-type .site-common__inner {
  padding-top: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
}
.page-option .page-common__section:last-of-type .site-common__inner {
  position: relative;
  margin-bottom: var(--primary-padding);
  padding-bottom: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
}
.page-option .page-common__section.option-application__section:last-of-type .site-common__inner {
  padding-top: clamp(20px * var(--responsive-ratio), 20 / var(--primary-inner-width) * 100vw, 20px);
  padding-bottom: clamp(70px * var(--responsive-ratio), 70 / var(--primary-inner-width) * 100vw, 70px);
}
.page-option .page-common__section:last-of-type .site-common__inner::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.page-option .page-common__section.option-application__section:last-of-type .site-common__inner::before {
  display: none;
}
.page-option .page-section__title {
  margin-bottom: 0.65em;
}
.page-option .page-section__title-upper {
  margin-bottom: 0.65em;
  padding-left: calc(35 / 24 * 1em);
  color: var(--primary-blue-color);
}
.page-option .page-option__title-lead {
  padding-left: calc(35 / 17 * 1em);
  color: var(--gray-color);
}
.page-option-common__content {
  justify-content: space-between;
  flex-direction: row-reverse;
}
.arilju__section .page-option-common__content,
.sleep-support__section .page-option-common__content {
  align-items: center;
}
.page-option .page-common__section .site-common__inner {
  padding-bottom: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
}
.page-option-common__content-img {
  width: calc(620 / 1280 * 100%);
  padding-top: 0.5%;
}
.page-option-common__content-text {
  width: calc(600 / 1280 * 100%);
}
.special-examination__text {
}
.page-option-common__content-text-note {
  margin-top: 1.75em;
  color: var(--primary-color);
}
.page-option-common__head {
  margin-bottom: min(50 / var(--primary-inner-width) * 100vw, 50px);
}
.page-option-common__content-text-img {
  margin-top: auto;
}

.special-examination__flow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: min(12 / var(--primary-inner-width) * 100vw, 12px);
}
.special-examination__flow-item {
  position: relative;
  padding-top: min(30 / var(--primary-inner-width) * 100vw, 30px);
  padding-bottom: min(30 / var(--primary-inner-width) * 100vw, 30px);
  color: var(--primary-txt-color);
  border: 2px solid var(--primary-blue-color);
  border-radius: 30px;
}
.special-examination__flow-num {
  position: absolute;
  top: 0;
  left: 50%;
  padding: 0.35em 1em 0.45em;
  color: #fff;
  font-size: clamp(1.7rem * var(--responsive-ratio), (17 / var(--primary-inner-width) * 100vw), 1.7rem);
  font-weight: bold;
  background: var(--primary-gradient);
  border-radius: 100vmax;
  white-space: nowrap;
  transform: translate3d(-50%, -50%, 0);
}
.special-examination__flow-title {
  margin-bottom: 0.65em;
  color: var(--primary-color);
  font-weight: 700;
  text-align: center;
}
.special-examination__flow-excerpt {
  text-align: center;
}
.special-examination__flow-icon {
  margin-bottom: min(8 / var(--primary-inner-width) * 100vw, 8px);
  text-align: center;
}
.special-examination__flow-icon img {
  width: calc(90 / 156 * 100%);
}
.hdb-app__section .page-option-common__content {
  gap: 0;
  justify-content: space-between;
}
.hdb-app__section .page-option-common__content-img {
  position: relative;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  width: calc(660 / 1280 * 100%);
}
.hdb-app__section .page-option-common__content-img > img {
  margin-top: auto;
}
.hdb-app__img-download-btn {
  position: absolute;
  right: 0;
  bottom: 0;
  display: flex;
  flex-direction: column;
  gap: min(15 / var(--primary-inner-width) * 100vw, 15px);
  width: calc(160 / 660 * 100%);
}
.hdb-app__section .page-option-common__content-img .hdb-app__img-main {
  width: calc(520 / 660 * 100%);
}
.hdb-app__section .page-option-common__content-text {
  width: calc(620 / 1280 * 100%);
}
.hdb-app__section .page-section__title {
  margin-bottom: min(80 / var(--primary-inner-width) * 100vw, 80px);
}
.hdb-app__section .hdb-app__text-logo {
  width: calc(565 / 620 * 100%);
  margin-bottom: min(60 / var(--primary-inner-width) * 100vw, 60px);
}
.hdb-app__section .hdb-app__text-lead {
  margin-bottom: min(30 / var(--primary-inner-width) * 100vw, 30px);
  color: var(--gray-color);
  font-size: clamp(5.6rem * var(--responsive-ratio), (56 / var(--primary-inner-width) * 100vw), 5.6rem);
  font-weight: bold;
  line-height: 150%;
  letter-spacing: 0.15em;
  white-space: nowrap;
}
.hdb-app__text-lead-color {
  color: #FF8F13;
}
.hdb-app__text-excerpt {
  font-size: clamp(2.4rem * var(--responsive-ratio), (24 / var(--primary-inner-width) * 100vw), 2.4rem);
  font-weight: bold;
  line-height: 170%;
  letter-spacing: 0.15em;
  white-space: nowrap;
}
.hdb-app__content-sub {
  position: relative;
  margin-top: min(60 / var(--primary-inner-width) * 100vw, 60px);
  padding: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
  background-image: var(--primary-gradient);
  border-radius: 30px;
}
.hdb-app__content-sub::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border-radius: 30px;
  border: 1px solid transparent;
  background-color: var(--white-color);
  background-origin: border-box;
  background-clip: border-box;
  -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  -webkit-mask-clip: border-box, padding-box;
  -webkit-mask-composite: destination-in;
  mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  mask-clip: border-box, padding-box;
  mask-composite: intersect;
}
.hdb-app__content-sub-title {
  position: relative;
  margin-bottom: 1em;
  color: var(--primary-color);
}
.hdb-app__content-sub .txt--primary {
  position: relative;
}
.hdb-app__content-sub .txt--primary + .hdb-app__content-sub-wrap {
  margin-top: min(50 / var(--primary-inner-width) * 100vw, 50px);
}
.hdb-app__content-sub-wrap {
  position: relative;
  justify-content: space-between;
}
.content-sub1 .hdb-app__content-sub-block.block1 {
  width: calc(540 / 1120 * 100%);
}
.content-sub1 .hdb-app__content-sub-block.block2 {
  width: calc(480 / 1120 * 100%);
}
.content-sub1 .hdb-app__content-sub-block.block1 .img {
  margin-top: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.content-sub2 .hdb-app__content-sub-block.block1 {
  width: calc(510 / 1120 * 100%);
}
.content-sub2 .hdb-app__content-sub-block.block2 {
  width: calc(510 / 1120 * 100%);
}
.content-sub3 .hdb-app__content-sub-block.block1 {
  width: calc(510 / 1120 * 100%);
}
.content-sub3 .hdb-app__content-sub-block.block2 {
  width: calc(510 / 1120 * 100%);
}
.page-option-common__contact-wrap {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: min(80 / var(--primary-inner-width) * 100vw, 80px);
  padding-block: min(40 / var(--primary-inner-width) * 100vw, 40px);
  padding-inline: min(120 / var(--primary-inner-width) * 100vw, 120px);
  background: var(--secondary-blue-color);
  border-radius: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.page-option-common__contact-wrap .txt--komidashi {
  color: var(--white-color);
  font-weight: bold;
}
.page-option-common__contact-wrap .site-common__download-link {
  outline: 3px solid rgb(255, 255, 255);
  outline-offset: -3px;
}
.option-application__content {
  align-items: center;
  justify-content: space-between;
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px);
  width: 100%;
  padding-block: min(70 / var(--primary-inner-width) * 100vw, 70px);
  padding-inline: min(120 / var(--primary-inner-width) * 100vw, 120px);
  color: var(--white-color);
  border-radius: min(50 / var(--primary-inner-width) * 100vw, 50px);
  background-color: var(--secondary-blue-color);
}
.page-option-common__content-img-text {
  display: inline-block;
  margin-bottom: calc(15 / 13 * 1em);
  padding-block: calc(6 / 13 * 1em);
  padding-inline: calc(10 / 13 * 1em);
  color: var(--primary-txt-color);
  font-size: clamp(13px * var(--responsive-ratio), 13 / var(--primary-inner-width) * 100vw, 13px);
  border: 1px solid var(--primary-txt-color);
  border-radius: 100vmax;
}
.option-application__content p.txt--midashi {
  line-height: 170%;
  text-align: center;
}
.option-application__button-link {
  width: calc(420 / 18 * 1em);
  outline: 3px solid rgb(255, 255, 255);
  outline-offset: -3px;
}
@media screen and (max-width: 1300px) {
  .hdb-app__section .page-option-common__content-img {
    width: calc(600 / 1280 * 100%);
  }
}
@media screen and (max-width: 991px) {
  .hdb-app__section .page-option-common__content-img {
     width: calc(540 / 1280 * 100%);
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px){
  .page-option .page-section__title-upper {
    padding-left: calc(35 / 18 * 1em);
    font-size: clamp(1.8rem * var(--responsive-ratio), (18 / var(--primary-inner-width) * 100vw), 1.8rem);
  }
  .page-option .page-section__title {
    padding-left: calc(35 / 30 * 1em);
    font-size: clamp(3.0rem * var(--responsive-ratio), (30 / var(--primary-inner-width) * 100vw), 3.0rem);
    white-space: nowrap;
  }
  .page-option .page-option__title-lead {
	  font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  }
  .option-application__content p.txt--midashi {
	  font-size: clamp(1.8rem * var(--responsive-ratio), (18 / var(--primary-inner-width) * 100vw), 18rem);
  }
}
@media screen and (max-width: 767px) {
  .page-option .page-title {
    margin-bottom: 0;
  }
  .page-option .page-title__sub-button {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-option .page-title__sub-button-link,
  .option-application__button-link {
    width: calc(310 / 15 * 1em);
    aspect-ratio: 310 / 70;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
  .page-option .page-title__outer {
    padding-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  } 
  .option-application__button-link {
    width: calc(280 / 18 * 1em);
  }
  .page-option .page-common__section:first-of-type .site-common__inner {
    margin-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .page-option-common__content {
    justify-content: space-between;
    flex-direction: column-reverse;
    gap: min(35 / var(--primary-base-width) * 100vw, 35px * var(--responsive-ratio));
    margin-top: 0;
  }
  .page-option .page-option__title-lead {
    padding-left: calc(17 / 13 * 1em);
  }
  .page-option-common__head {
    margin-bottom: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
  }
  .page-option .page-common__section .site-common__inner {
    padding-bottom: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
  }
  .page-option-common__content-img {
    width: 100%;
  }
  .page-option-common__content-text {
    width: 100%;
  }
  .hdb-app__section .page-option-common__content-text {
    width: 100%;
  }
  .hdb-app__section .hdb-app__text-logo {
    width: min(280 / var(--primary-base-width) * 100vw, 280px * var(--responsive-ratio));
    margin-inline: auto;
    margin-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .hdb-app__section .hdb-app__text-lead {
    margin-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-left: 0.2em;
    font-size: min(30 / var(--primary-base-width) * 100vw, 3rem * var(--responsive-ratio));
    text-align: center;
  }
  .hdb-app__text-excerpt {
    font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
    line-height: 165%;
    letter-spacing: 0.075em;
    text-align: center;
  }
  .hdb-app__section .page-option-common__content {
    gap: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
  }
  .hdb-app__section .page-option-common__content-img {
    width: min(300 / var(--primary-base-width) * 100vw, 300px * var(--responsive-ratio));
    margin-inline: auto;
  }
  .hdb-app__section .page-option-common__content-img .hdb-app__img-main {
    width: 100%;
  }
  .hdb-app__img-download-btn {
    position: relative;
    right: auto;
    bottom: auto;
    flex-direction: row;
    justify-content: center;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    width: auto;
    margin-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .hdb-app__img-download-btn img {
    width: auto;
    height: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .hdb-app__content-sub {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .content-sub1 .hdb-app__content-sub-block.block1 {
    width: 100%;
  }
  .content-sub1 .hdb-app__content-sub-block.block1 .img {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .content-sub1 .hdb-app__content-sub-block.block2 {
    width: 100%;
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .hdb-app__content-sub .txt--primary + .hdb-app__content-sub-wrap {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .content-sub2 .hdb-app__content-sub-block.block1 {
    width: 100%;
  }
  .content-sub2 .hdb-app__content-sub-block.block2 {
    width: 100%;
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .content-sub3 .hdb-app__content-sub-block.block1 {
    width: 100%;
  }
  .content-sub3 .hdb-app__content-sub-block.block2 {
    width: 100%;
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-option-common__contact-wrap {
    position: relative;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    margin-top: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    padding-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-inline: 0;
    border-radius: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-option-common__contact-wrap .site-common__download-link {
    width: min(280 / var(--primary-base-width) * 100vw, 280px * var(--responsive-ratio));
    aspect-ratio: 280 / 70;
  }
  .page-option .page-common__section:last-of-type .site-common__inner {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding-bottom: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
  }
  .page-option .page-option-section__title .txt--midashi {
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
  .page-option .page-section__title-upper {
    padding-left: calc(17 / 12 * 1em);
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
  .page-option .page-common__section.option-application__section:last-of-type .site-common__inner {
    padding-top: min(5 / var(--primary-base-width) * 100vw, 5px * var(--responsive-ratio));
    padding-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .page-option .option-application__content {
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-inline: 0;
    border-radius: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-option .option-application__content p.txt--midashi {
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
  .page-option .option-application__content .option-application__button-link {
    width: calc(280 / 15 * 1em);
    aspect-ratio: 280 / 70;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
}

/*-------------------------------------------------

 導入事例

--------------------------------------------------*/
.page-case_study .case-study-list__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px);
}
.page-case_study .case-study__button {
  justify-content: center;
  gap: min(30 / var(--primary-base-width) * 100vw, 30px);
  margin-top: var(--primary-padding);
}
.page-case_study .casestudy__button-link {
  width: calc(280 / 18 * 1em);
  aspect-ratio: 280 / 80;
}
.page-case_study .client-voice__section .site-common__lead {
  margin-bottom: min(60 / var(--primary-base-width) * 100vw, 60px);
}
.page-case_study .splide__section.client-voice__list-wrap .splide.is-overflow {
  padding-bottom: 0;
}
.client-voice__list {
  position: relative;
  padding: min(40 / var(--primary-inner-width) * 100vw, 40px);
  border-radius: 40px;
  background-color: var(--primary-bg-color);
  overflow: clip;
  z-index: 1;
}
.client-voice__list::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-radius: 40px;
  border: 1px solid transparent;
  background-image: var(--primary-gradient);
  background-origin: border-box;
  background-clip: border-box;
  -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  -webkit-mask-clip: padding-box, border-box;
  -webkit-mask-composite: destination-out;
  mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  mask-clip: padding-box, border-box;
  mask-composite: exclude;
  pointer-events: none;
}
.client-voice__list + .client-voice__list {
  margin-top: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.client-voice__item {
  justify-content: space-between;
  gap: min(75 / var(--primary-inner-width) * 100vw, 75px);
}
.client-voice__item-title {
  flex: 1;
}
.client-voice__item-content {
  width: calc(750 / 1200 * 100%);
}
.client-voice__item-title-text {
  display: inline-block;
  padding-block: 0.05em 0.1em;
  line-height: 125%;
}
.client-voice__item-info {
  display: flex;
  gap: 1.5em;
  margin-top: 2.0em;
  color: var(--primary-txt-color);
  font-size: clamp(1.3rem * var(--responsive-ratio), (13/ var(--primary-inner-width) * 100vw), 1.3rem);
}
.client-voice__item-info-item {
  display: flex;
  align-items: center;
  gap: 0.5em;
}
.client-voice__item-info-item dt {
  padding: 0.2em 0.25em 0.30em 0.35em;
  font-size: calc(12 / 13 * 1em);
  line-height: 1;
  border: 1px solid var(--gray-color);
  white-space: nowrap;
}
.client-voice__item-info-item dd {
  line-height: 150%;
}
.client-voice__item-info-item:last-of-type dd {
  white-space: nowrap;
}

/* 記事ページ 共通 */
.site-common__article-wrap {
  /* margin-bottom: min(150 / var(--primary-base-width) * 100vw, 150px); */
  margin-bottom: min(80 / var(--primary-base-width) * 100vw, 80px);
  padding-top: min(150 / var(--primary-base-width) * 100vw, 150px);
}
.site-common__article-wrap-inner {
  position: relative;
  width: min(100%, var(--primary-inner-large-width) * 1px);
  margin-inline: auto;
  padding: min(80 / var(--primary-inner-width) * 100vw, 80px);
  /* padding-top: calc(var(--primary-padding) / 2); */
  padding-top: calc(var(--primary-padding) / 4);
  padding-bottom: 0;
  border-radius: min(80 / var(--primary-inner-width) * 100vw, 80px);
  z-index: 1;
}
.article-title__main {
  position: relative;
  margin-bottom: min(50 / var(--primary-inner-width) * 100vw, 50px);
  /* padding-bottom: var(--primary-padding); */
  padding-bottom: clamp(40px * var(--responsive-ratio), 40 / var(--primary-base-width) * 100vw, 40px)
}
.article-title__main::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.page-column-article .page-title__breadcrumb,
.page-column-article .page-title__breadcrumb a,
.page-case_study-article .page-title__breadcrumb,
.page-case_study-article .page-title__breadcrumb a,
.page-resources-article .page-title__breadcrumb,
.page-resources-article .page-title__breadcrumb a {
  color: var(--primary-blue-color);
}
.article-title__main-title {
  display: inline-block;
  margin-bottom: 1.0em;
}
.article-footer__nav {
  margin-top: min(100 / var(--primary-inner-width) * 100vw, 100px);
}
.article-footer__nav-list {
  position: relative;
  gap: min(120 / var(--primary-inner-width) * 100vw, 120px);
  justify-content: center;
}
.article-footer__nav-list::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  width: 1px;
  height: 100%;
  background: var(--primary-blue-color);
}
.article-footer__nav-link {
  position: relative;
  display: flex;
  align-items: center;
  gap: 1.2em;
  color: var(--primary-blue-color);
  line-height: 1;
  text-decoration: none;
}
.article-footer__nav-item.end .article-footer__nav-link {
  opacity: 0.5;
  pointer-events: none;
}
.article-footer__nav-link .icon-wrap {
  position: relative;
  display: inline-block;
  width: calc(50 / 17 * 1em);
  aspect-ratio: 1 / 1;
  border-radius: 100vmax;
  background: var(--primary-gradient);
  pointer-events: none;
  overflow: hidden;
  z-index: 1;
}
.article-footer__nav-link .icon-wrap::before,
.article-footer__nav-link .icon-wrap::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: 100vmax;
  background: var(--primary-gradient-reverse);
  z-index: -2;
  transition: opacity .2s ease-out;
}
.article-footer__nav-link .icon-wrap::after {
  top: 1px;
  left: 1px;
  width: calc(100% - 2px);
  height: calc(100% - 2px);
  background: var(--white-color);
  z-index: -1;
}
.article-footer__nav-link.article-footer__nav-link--next .icon-wrap::before,
.article-footer__nav-link.article-footer__nav-link--next .icon-wrap::after {
  opacity: 0;
}
@media (hover: hover) and (pointer: fine) {
  .article-footer__nav-link.article-footer__nav-link--prev:hover .icon-wrap::before,
  .article-footer__nav-link.article-footer__nav-link--prev:hover .icon-wrap::after {
    opacity: 0;
  }
  .article-footer__nav-link.article-footer__nav-link--next:hover .icon-wrap::before,
  .article-footer__nav-link.article-footer__nav-link--next:hover .icon-wrap::after {
    opacity: 1;
  }
}
.article-footer__nav-link .icon-wrap .icon {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  width: 22%;
  aspect-ratio: 83 / 150;
  background: url(../img/icon_arrow_left_grad.svg) no-repeat center / contain;
  translate: -60% -50%;
  background-size: contain;
  background-repeat: no-repeat;
  pointer-events: none;
}
.article-footer__nav-link.article-footer__nav-link--next .icon-wrap .icon {
  background: url(../img/icon_arrow_right_white.svg) no-repeat center / contain;
  translate: -40% -50%;
}
@media (hover: hover) and (pointer: fine) {
  .article-footer__nav-link.article-footer__nav-link--prev:hover .icon-wrap .icon {
    background: url(../img/icon_arrow_left_white.svg) no-repeat center / contain;
  }
  .article-footer__nav-link.article-footer__nav-link--next:hover .icon-wrap .icon {
    background: url(../img/icon_arrow_right_grad.svg) no-repeat center / contain;
  }
}
.article-footer__contact {
  align-items: center;
  justify-content: space-between;
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px);
  width: min(var(--primary-inner-width) / var(--primary-inner-large-width) * 100%, var(--primary-inner-width) * 1px);
  margin-inline: auto;
  margin-top: min(100 / var(--primary-inner-width) * 100vw, 100px);
  padding-block: var(--primary-padding);
  color: var(--white-color);
  border-radius: min(50 / var(--primary-inner-width) * 100vw, 50px);
  background: var(--secondary-blue-color);
}
.article-footer__contact-title {
  margin-bottom: 2em;
  color: var(--white-color);
  font-weight: 700;
  text-align: center;
}
.article-footer__contact-link-wrap {
  display: flex;
  justify-content: center;
  gap: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.article-footer__contact-link {
  width: calc(280 / 18 * 1em);
  aspect-ratio: 280 / 80;
}
.article-footer__contact-link:first-of-type {
  outline: 3px solid rgb(255, 255, 255);
  outline-offset: -3px;
}
.site-common__article-wrap .flow__download {
  margin-inline: auto;
  margin-top: min(80 / var(--primary-inner-width) * 100vw, 80px);
}
.site-common__article-body {
  width: calc(1000 / 1280 * 100%);
  margin: 0 auto;
  padding-top: min(100 / var(--primary-inner-width) * 100vw, 100px);
}
.site-common__article-body h2 {
  position: relative;
  margin-bottom: 1.5em;
  padding-bottom: 1.5em;
  padding-left: 1em;
  font-size: clamp(2.4rem * var(--responsive-ratio), (24 / var(--primary-inner-width) * 100vw), 2.4rem);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.15em;
  background: var(--primary-gradient);
	-webkit-background-clip:text;
	-webkit-text-fill-color: transparent;
}
.site-common__article-body * + h2 {
  margin-top: min(100 / var(--primary-inner-width) * 100vw, 100px);
}
.site-common__article-body .asset-image + h2,
.site-common__article-body .mt-figure + h2 {
  margin-top: min(70 / var(--primary-inner-width) * 100vw, 70px);
}
.site-common__article-body h2::before {
  content: '';
  position: absolute;
  top: 0.6em;
  left: 0;
  width: calc(10 / 24 * 1em);
  height: calc(10 / 24 * 1em);
  border-radius: 100vmax;
  background: var(--primary-gradient);
}
.site-common__article-body h2::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: -1%;
  width: 102%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.site-common__article-body blockquote {
	position: relative;
	margin: 2em 0 2em 0;
	border: 1px solid var(--primary-color);
	padding: 1em 2em;
	color: var(--primary-color);
}
.site-common__article-body blockquote:has(h2) {
  position: relative;
  margin: 0;
  padding: 0;
  border: none;
  color: var(--primary-txt-color);
  margin-bottom: 1.5em;
  padding-bottom: 1.35em;
  font-size: clamp(2.4rem * var(--responsive-ratio), (24 / var(--primary-inner-width) * 100vw), 2.4rem);
}
.site-common__article-body * + blockquote:has(h2) {
  margin-top: min(100 / var(--primary-inner-width) * 100vw, 100px);
}
.site-common__article-body .asset-image + blockquote,
.site-common__article-body .mt-figure + blockquote {
  margin-top: min(70 / var(--primary-inner-width) * 100vw, 70px);
}
.site-common__article-body blockquote h2 {
  margin-bottom: 0;
  padding-bottom: 0;
  padding-left: 1.2em;
  font-size: clamp(3.2rem * var(--responsive-ratio), (32 / var(--primary-inner-width) * 100vw), 3.2rem);
}
.site-common__article-body blockquote h2::before {
  content: '“';
  position: absolute;
  top: 0.1em;
  left: -0.1em;
  width: auto;
  height: auto;
  font-size: calc(50 / 32 * 1em);
  border-radius: 0;
  background: var(--primary-gradient);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}
.site-common__article-body blockquote h2 + p {
  margin-top: 1em;
  font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  font-weight: 400;
  line-height: 170%;
  letter-spacing: 0.1em;
  text-align: right;
}
.site-common__article-body blockquote h2::after {
  display: none;
}
.site-common__article-body blockquote:has(h2)::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: -1%;
  width: 102%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.site-common__article-body .mt-figure {
  width: 100%;
  margin-block: var(--primary-padding);
  margin-inline: 0;
  padding: 0;
}
.site-common__article-body .mt-figure img {
  margin: 0;
}
.site-common__article-body .mt-figure figcaption {
  margin-top: 1em;
  font-size: clamp(1.4rem * var(--responsive-ratio), (14 / var(--primary-inner-width) * 100vw), 1.4rem);
  font-weight: 400;
  line-height: 150%;
  letter-spacing: 0.1em;
  text-align: center;
}
.resources-article__summary-wrap h2 {
  margin-bottom: 1.0em;
  padding: 0;
  color: var(--primary-color);
  font-size: clamp(2.0rem * var(--responsive-ratio), (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  line-height: 150%;
  background: transparent;
	-webkit-background-clip: inherit;
	-webkit-text-fill-color: inherit;
}
.resources-article__summary-wrap h2::before,
.resources-article__summary-wrap h2::after {
  display: none;
}
.resources-article__summary-wrap h3 {
  position: relative;
  margin-block: 2.5em 1.25em;
  padding-left: 2.5em;
  color: var(--primary-color);
  font-size: clamp(2.0rem * var(--responsive-ratio), (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  font-weight: 700;
  line-height: 170%;
  letter-spacing: 0.1em;
}
.site-common__article-body h3 {
  position: relative;
  margin-block: 2.5em 1.25em;
  padding-left: 2.5em;
  color: var(--primary-color);
  font-size: clamp(2.0rem * var(--responsive-ratio), (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  font-weight: 700;
  line-height: 170%;
  letter-spacing: 0.1em;
}
.site-common__article-body h3::before {
  content: '';
  position: absolute;
  top: 0.85em;
  left: 0;
  width: 2em;
  height: 2px;
  background: var(--primary-color);
}
.site-common__article-body h4 {
  margin-bottom: 1.0em;
  padding: 0;
  color: var(--primary-color);
  font-size: clamp(1.6rem * var(--responsive-ratio), (16 / var(--primary-inner-width) * 100vw), 1.6rem);
  font-weight: 700;
  line-height: 150%;
}
.site-common__article-body h4 {
	margin-top: 2em;	
}
.site-common__article-body p + p {
  margin-top: 1.5em;
}
.site-common__article-body .asset-image {
  margin-block: var(--primary-padding);
  border-radius: min(50 / var(--primary-inner-width) * 100vw, 50px);
}
.site-common__article-body ul {
  margin-block: 1em;
  margin-left: 0.5em;
}
.site-common__article-body li {
  position: relative;
  padding-left: 1em;
}
.site-common__article-body ul li::before {
  content: '・';
  position: absolute;
  top: 0;
  left: 0;
}
.site-common__article-body ol {
  margin-block: 1em;
  margin-left: 1.2em;
  padding-left: 1em;
  list-style-type: decimal;
}
.site-common__article-body ol li {
  position: relative;
  list-style-type: decimal;
  padding-left: 0;
}
.site-common__article-body .asset-image + p {
  margin-top: 0;
}
.site-common__article-body .asset-image + ul {
  position: relative;
}
.site-common__article-wrap-inner a {
	color: var(--primary-color);
}
.site-common__article-wrap-inner a::hover {
	color: var(--tertiary-color);
}
.site-common__article-body td, 
.site-common__article-wrap-inner td {
	padding: 1em;
}
.site-common__article-body hr {
	display: block;
	border: none;
	background: var(--primary-gradient);
	height: 1px;
	margin: 3em 0;
}

/* 記事ページ 導入事例 */
.casestudy-article__client-info-inner {
  justify-content: space-between;
  align-items: center;
}
.casestudy-article__client-info-img {
  width: calc(540 / 1280 * 100%);
  aspect-ratio: 640 / 390;
  border-radius: min(50 / var(--primary-inner-width) * 100vw, 50px);
  overflow: hidden;
}
.casestudy-article__client-info-img img {
}
.casestudy-article__client-info-text {
  width: calc(660 / 1280 * 100%);
}
.casestudy-article__client-logo {
  width: calc(268 / 560 * 100%);
  aspect-ratio: 268 / 45;
  margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
}
.casestudy-article__client-logo img {
  object-fit: contain;
  object-position: 0 center;
  width: 100%;
  height: 100%;
}
.casestudy-article__client-info-title {
  display: inline-block;
  margin-bottom: 0.75em;
  padding: 0em 0.40em 0.05em;
  font-weight: 700;
}
.casestudy-article__client-info-name {
  margin-bottom: 1.5em;
  padding-left: 0.5em;
}
.casestudy-article__client-info-list {
  display: flex;
  gap: 1.5em;
  color: var(--gray-color);
}
.casestudy-article__meta {
  margin-top: min(50 / var(--primary-inner-width) * 100vw, 50px);
}
.casestudy-article__more {
  color: var(--primary-txt-color);
  text-decoration: none;
}
.casestudy-article__before-after {
  position: relative;
  margin-top: var(--primary-padding);
  padding: min(40 / var(--primary-inner-width) * 100vw, 40px) min(80 / var(--primary-inner-width) * 100vw, 80px);
  background-color: var(--primary-bg-color);
  border-radius: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.casestudy-article__before-after + .casestudy-article__before-after {
  margin-top: var(--primary-padding);
}
.casestudy-article__before-after-inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: min(125 / var(--primary-inner-width) * 100vw, 125px);
}
.casestudy-article__before-after-title {
  position: relative;
  margin-bottom: 1.5em;
  padding-bottom: 1.5em;
  color: var(--primary-color);
  text-align: center;
  line-height: 1;
}
.casestudy-article__before-after-title::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: -1%;
  width: 102%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.casestudy-article__before-after-label {
  display: inline-block;
  margin-bottom: 1.25em;
  padding: 0.45em 1.2em;
  color: var(--white-color);
  font-weight: 700;
  line-height: 1;
  background: var(--gray-color);
  border-radius: 100vmax;
}
.casestudy-article__before-after-after .casestudy-article__before-after-label {
  background: var(--primary-gradient);
}
.casestudy-article__before-after-inner .casestudy-article__before-after-after ul li::before {
  background: var(--primary-gradient);
}
.casestudy-article__input-body h2 {
  position: relative;
  margin-bottom: 1.5em;
  padding-bottom: 1.5em;
  padding-left: 1em;
  font-size: clamp(2.4rem * var(--responsive-ratio), (24 / var(--primary-inner-width) * 100vw), 2.4rem);
  font-weight: 700;
  line-height: 150%;
  letter-spacing: 0.15em;
  background: var(--primary-gradient);
	-webkit-background-clip:text;
	-webkit-text-fill-color: transparent;
}
.casestudy-article__input-body h2::before {
  content: '';
  position: absolute;
  top: 0.6em;
  left: 0;
  width: calc(10 / 24 * 1em);
  height: calc(10 / 24 * 1em);
  border-radius: 100vmax;
  background: var(--primary-gradient);
}
.casestudy-article__input-body h3 {
  margin-bottom: 1.0em;
  padding: 0;
  color: var(--primary-color);
  font-size: clamp(2.0rem * var(--responsive-ratio), (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  font-weight: 700;
  line-height: 150%;
  background: transparent;
	-webkit-background-clip: inherit;
	-webkit-text-fill-color: inherit;
}
.casestudy-article__input-body * + h3 {
	margin-top: 2em;	
}
.casestudy-article__input-body h4 {
  margin-bottom: 1.0em;
  padding: 0;
  color: var(--primary-color);
  font-size: clamp(1.6rem * var(--responsive-ratio), (16 / var(--primary-inner-width) * 100vw), 1.6rem);
  font-weight: 700;
  line-height: 150%;
}
.casestudy-article__input-body * + h4 {
	margin-top: 2em;	
}
.casestudy-article__input-body p + p {
	margin-top: 1em;
}
.casestudy-article__input-body ul {
  margin-block: 1em;
  margin-left: 0.5em;
}
.casestudy-article__input-body ul li {
  position: relative;
  padding-left: 1em;
}
.casestudy-article__input-body ol {
  margin-block: 1em;
  margin-left: 0.6em;
  padding-left: 1em;
  list-style-type: decimal;
}
.casestudy-article__before-after-box ol li {
  position: relative;
  list-style-type: decimal;
}
.casestudy-article__before-after-box ul li::before {
  content: '・';
  position: absolute;
  top: 0;
  left: 0;
}
.casestudy-article__before-after-box {
  position: relative;
}
.casestudy-article__before-after-box.after::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 0;
  width: 1.2em;
  aspect-ratio: 25 / 55;
  background: var(--primary-blue-color);
  transform: translate(max(-50% - (62 / var(--primary-inner-width) * 100vw), -50% - 62px), -50%);
  clip-path: polygon(0 0, 0% 100%, 100% 50%);
}
.casestudy-article__before-after-summary {
}
.casestudy-article__closing {
  margin-top: var(--primary-padding);
  padding: min(60 / var(--primary-inner-width) * 100vw, 60px);
  color: var(--primary-blue-color);
  background: var(--primary-bg-color);
  border-radius: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
@media screen and (max-width: 767px) {
  .page-case_study .case-study-list__items {
    position: relative;
    grid-template-columns: 1fr;
    gap: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    width: min(290 / var(--primary-base-width) * 100vw, 290px * var(--responsive-ratio));
    margin-inline: auto;
    transform: translate3d(0,0,0);
  }
  .page-case_study .case-study-list__items .site-common__list-item {
    width: 100% !important;
    margin-left: 0;
  }
  .page-case_study .site-common__list-item-body .title--secondary {
    margin-bottom: 1.0em;
  }
  .casestudy__meta {
    padding-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    font-size: min(12 / var(--primary-base-width) * 100vw, 12px * var(--responsive-ratio));
  }
  .page-case_study .case-study__button {
    gap: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    width: min(280 / var(--primary-base-width) * 100vw, 280px * var(--responsive-ratio));
    margin-inline: auto;
  }
  .page-case_study .casestudy__button-link {
    width: 100%;
    aspect-ratio: 280 / 70;
  }
  .page-case_study .client-voice__section .site-common__lead {
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-case_study .client-voice__section .client-voice__list-wrap {
    width: 100vw;
    margin-inline: calc(50% - 50vw) !important;
  }
  .page-case_study .client-voice__list-wrap .splide__track {
    padding-inline: 20px !important;
    overflow: inherit;
  }
  .page-case_study .client-voice__list {
    width: calc(290 / var(--primary-base-width) * 100vw) !important;
    padding-block: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding-inline: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    border-radius: 30px;
  }
  .page-case_study .client-voice__list::before {
    border-radius: 30px;
  }
  .client-voice__list + .client-voice__list {
    margin-top: 0;
  }
  .client-voice__item-title-text {
    text-align: center;
  }
  .client-voice__item-info {
    gap: 10px;
    margin-top: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    font-size: min(11 / var(--primary-base-width) * 100vw, 1.1rem * var(--responsive-ratio));
  }
  .client-voice__item-content {
    width: 100%;
  }
  .page-case_study .splide__section.client-voice__list-wrap .splide.is-overflow {
  }

  /* 記事ページ 共通 */
  .site-common__article-wrap {
    margin-bottom: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
    padding-top: 110px;
    padding-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .site-common__article-wrap-inner {
    position: relative;
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
    margin-inline: auto;
    padding: 0;
    padding-inline: 0;
    padding-top: 0;
    padding-bottom: 0;
  }
  .article-title__main {
    margin-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-bottom: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .article-title__main::after {
    left: -3%;
    width: 106%;
  }
  .site-common__article-body {
    width: min(300 / var(--primary-base-width) * 100vw, 300px * 1.6);
    margin-inline: auto;
    padding-top: var(--primary-padding);
  }
  .site-common__article-body h2 {
    margin-bottom: 1.5em;
    margin-inline: max(-10 / var(--primary-base-width) * 100vw, -10px * var(--responsive-ratio));
    padding-bottom: 1.5em;
    padding-left: 1em;
    font-size: min(18 / var(--primary-base-width) * 100vw, 1.8rem * var(--responsive-ratio));
  }
  .site-common__article-body h2 br {
	  display: none;
	}
  .site-common__article-body * + h2 {
    margin-top: min(60 / var(--primary-base-width) * 100vw, 60px * 1.6);
  }
  .site-common__article-body .asset-image + h2,
  .site-common__article-body .mt-figure + h2 {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * 1.6);
  }
  .site-common__article-body .resources-article__summary-wrap h2 {
    margin-bottom: 1.0em;
    margin-inline: 0;
    padding-bottom: 0;
    padding-left: 0;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
  .site-common__article-body h3 {
    margin-block: 2.0em 1.0em;
    padding-left: 2.5em;
    color: var(--primary-blue-color);
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    letter-spacing: 0.1em;
  }
  .site-common__article-body h4 {
  	font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
  }
  .site-common__article-body blockquote {
    margin-bottom: 1.5em;
    margin-inline: max(-10 / var(--primary-base-width) * 100vw, -10px * var(--responsive-ratio));
    padding-bottom: 1.35em;
    font-size: min(18 / var(--primary-base-width) * 100vw, 1.8rem * var(--responsive-ratio));
  }
  .site-common__article-body * + blockquote {
    margin-top: min(60 / var(--primary-base-width) * 100vw, 60px * 1.6);
  }
  .site-common__article-body .asset-image + blockquote,
  .site-common__article-body .mt-figure + blockquote {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * 1.6);
  }
  .site-common__article-body blockquote h2 {
    margin-inline: auto;
    padding-bottom: 0;
    padding-left: 1.2em;
    font-size: min(18 / var(--primary-base-width) * 100vw, 1.8rem * var(--responsive-ratio));
  }
  .site-common__article-body blockquote h2 br {
    display: none;
	}
  .site-common__article-body blockquote p {
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
  }
	.site-common__article-body blockquote h2 + p {
	  font-size: min(13 / var(--primary-base-width) * 100vw, 1.3rem * var(--responsive-ratio));
	}
  .site-common__article-body .mt-figure {
    margin-block: min(30 / var(--primary-base-width) * 100vw, 30px * 1.6);
  }
  .site-common__article-body .mt-figure figcaption {
    font-size: min(12 / var(--primary-base-width) * 100vw, 1.2rem * var(--responsive-ratio));
    text-align: left;
    line-height: 180%;
  }
  .site-common__article-body .asset-image {
    margin-block: min(30 / var(--primary-base-width) * 100vw, 30px * 1.6);
    border-radius: 20px;
  }
  .article-footer__nav {
    margin-block: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio));
  }
  .article-footer__nav-list {
    flex-direction: row;
    gap: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
  }
  .article-footer__nav-link {
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
  }
  .article-footer__nav-link .icon-wrap {
    width: min(32 / var(--primary-base-width) * 100vw, 32px * var(--responsive-ratio));
  }
  .article-footer__nav-link .icon-wrap .icon {
    width: min(8 / var(--primary-base-width) * 100vw, 8px * var(--responsive-ratio));
  }
  .site-common__article-body td, 
	.site-common__article-wrap-inner td {
		padding: .25em;
	}
  

  /* 記事ページ 導入事例 */
  .casestudy-article__client-info-inner {
    gap: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
    margin-inline: auto;
  }
  .casestudy-article__client-info-img {
    width: 100%;
  }
  .casestudy-article__client-info-text {
    width: min(280 / var(--primary-base-width) * 100vw, 280px * 1.6);
    margin-inline: auto;
  }
  .casestudy-article__client-logo {
    width: min(178 / var(--primary-base-width) * 100vw, 178px * 1.6);
    aspect-ratio: 178 / 30;
    margin-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .casestudy-article__client-info-name {
    margin-bottom: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    padding-left: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
  }
  .casestudy-article__client-info-list {
    flex-direction: column;
    gap: 0.5em;
  }
  .casestudy-article__meta {
    margin-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .casestudy-article__before-after {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .casestudy-article__before-after + .casestudy-article__before-after {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .casestudy-article__before-after-title {
    margin-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .casestudy-article__before-after-inner {
    grid-template-columns: 1fr;
    gap: 50px;
  }
  .casestudy-article__input-body h3 {
    margin-bottom: 1.0em;
    margin-inline: 0;
    padding-bottom: 0;
    padding-left: 0;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
  .casestudy-article__before-after-box.after {
    padding-top: 2.5%;
  }
  .casestudy-article__before-after-box.after::after {
    content: '';
    position: absolute;
    top: -25px;
    left: 50%;
    transform: none;
    translate: -50% -50%;
    width: 35px;
    aspect-ratio: 35 / 15;
    background: var(--primary-color);
    clip-path: polygon(0 0, 50% 100%, 100% 0);
  }
  .casestudy-article__before-after-summary {
  }
  .casestudy-article__client-info-img img {
    border-radius: 20px;
  }
  .casestudy-article__closing {
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
    padding: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding-inline: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    border-radius: 30px;
    translate: max(-10 / var(--primary-base-width) * 100vw, -10px * 1.6) 0;
  }
  .article-footer__contact {
    width: min(340 / var(--primary-base-width) * 100vw, 340px * 1.6);
    margin-inline: auto;
    margin-top: 0;
    padding-block: var(--primary-padding);
    border-radius: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
  }
  .article-footer__contact-link-wrap {
    flex-direction: column;
    align-items: center;
    gap: min(10 / var(--primary-base-width) * 100vw, 10px * var(--responsive-ratio));
    width: min(280 / var(--primary-base-width) * 100vw, 280px * 1.6);
    margin-inline: auto;
  }
  .article-footer__contact-link {
    width: 100%;
    aspect-ratio: 280 / 70;
  }

  .site-common__article-wrap .flow__download {
    width: min(340 / var(--primary-base-width) * 100vw, 340px * 1.6);
    margin-top: min(80 / var(--primary-inner-width) * 100vw, 80px);
    translate: 0 0;
  }

}

/*-------------------------------------------------

 お役立ち資料

--------------------------------------------------*/
.page-resources .page-common__section .site-common__inner {
  padding-top: 0;
}
.page-resources-article .site-common__article-wrap {
  margin-bottom: 0;
}
.page-resources .site-common__article-wrap-inner {
  padding-top: calc(var(--primary-padding) / 2);
  padding-bottom: var(--primary-padding);
}
.page-resources .site-common__article-wrap-inner::before {
  display: none;
}
.page-resources-article .site-common__article-wrap .article-title__main .page-title__breadcrumb,
.page-resources-article .site-common__article-wrap .page-title__breadcrumb a {
  color: var(--primary-blue-color);
}
.page-resources .site-common__article-body {
  width: 100%;
  padding-top: 0;
}
.page-resources .site-common__article-body * + h1 {
  margin-top: var(--primary-padding);
}
.page-resources .resources-list__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px);
  margin-bottom: 0;
  transform: translate3d(0,0,0);
}
.page-resources .site-common__list-more-wrap {
  margin-bottom: min(150 / var(--primary-inner-width) * 100vw, 150px);
}
.page-resources .site-common__download-inner {

}
.resources-article__main-wrap {
  margin-bottom: var(--primary-padding);
}
.resources-article__main-img-wrap {
	width: 90%;
	margin: auto;
  margin-bottom: var(--primary-padding);
  border-radius: min(32 / var(--primary-inner-width) * 100vw, 32px);
  overflow: hidden;
}
.page-resources .resources-article__main-img-wrap {
  border: 1px solid #dfdfdf;
}
.resources-article__summary-wrap {
  padding-block: min(40 / var(--primary-inner-width) * 100vw, 40px);
  padding-inline: min(70 / var(--primary-inner-width) * 100vw, 70px);
  background-color: var(--primary-bg-color);
  border-radius: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.resources-article__summary-wrap + h2 {
  margin-top: 0;
}

/* お役立ち資料ページ フォームセクション */
@media screen and (min-width: 768px) {
  .page-resources-article .site-common__article-wrap-outer {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: min(100%, var(--primary-inner-width) * 1px);
    margin-inline: auto;
    margin-bottom: min(150 / var(--primary-inner-width) * 100vw, 150px);
    padding-top: min(16 / var(--primary-inner-width) * 100vw, 16px);
  }
  .page-resources-article .site-common__article-wrap-inner {
    width: calc(640 / 1280 * 100%);
    margin: 0;
    padding: 0;
  }
  .page-resources-article .contact-form__section {
    width: calc(550 / 1280 * 100%);
  }
  .page-resources .contact-form__section .site-common__outer {
    position: relative;
    padding: min(40 / var(--primary-inner-width) * 100vw, 40px) min(50 / var(--primary-inner-width) * 100vw, 50px);
    border-radius: min(40 / var(--primary-inner-width) * 100vw, 40px);
    background-image: var(--primary-gradient);
  }
  .page-resources .contact-form__section .site-common__outer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100%;
    border-radius: min(40 / var(--primary-inner-width) * 100vw, 40px);
    border: 1px solid transparent;
    background-color: var(--white-color);
    background-origin: border-box;
    background-clip: border-box;
    -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
    -webkit-mask-clip: border-box, padding-box;
    -webkit-mask-composite: destination-in;
    mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
    mask-clip: border-box, padding-box;
    mask-composite: intersect;
  }
  .page-resources .contact-form__section .contact-form__inner {
    position: relative;
    margin: 0;
    padding: 0;
  }
  .page-resources .contact-form__section .contact-form__form-wrap {
    width: 100%;
    font-size: clamp(1.4rem * var(--responsive-ratio), (14 / var(--primary-inner-width) * 100vw), 1.4rem);
    line-height: 170%;
    --form-wrap-width: 550;
  }
  .page-resources .site-common__form .contact-form__form-item {
    flex-direction: column;
    align-items: flex-start;
    gap: min(6 / var(--form-wrap-width) * 100vw, 6px);
    margin-bottom: min(15 / var(--form-wrap-width) * 100vw, 15px);
  }
  .page-resources .site-common__form .contact-form__form-item-title,
  .page-resources .contact-form__form-item-input-wrap {
    width: 100%;
  }
  .page-resources .contact-form__title {
    margin-bottom: min(24 / var(--primary-inner-width) * 100vw, 24px);
    margin-inline: -1em;
    font-size: clamp(2.0rem * var(--responsive-ratio), (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  }
  .page-resources .contact-form__section .contact-form__step-list {
    margin-bottom: min(24 / var(--primary-inner-width) * 100vw, 24px);
  }
  .page-resources .contact-form__section .contact-form__step-item {
    height: calc(36 / 15 * 1em);
    font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  }
  .page-resources .contact-form__section .contact-form__step-item::before,
  .page-resources .contact-form__section .contact-form__step-item::after {
    width: 10px
  }
  .page-resources .site-common__form select {
    padding: 0.85em 1.5em;
    padding-right: 3.0em;
    font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
  }
  .page-resources .site-common__form input[type=text],
  .page-resources .site-common__form textarea {
    padding: 0.85em 1.5em;
    font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
  }
  .page-resources .site-common__form .contact-form__form {
    margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  }
  .page-resources .site-common__form .contact-form__agreement {
    margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  }
  .page-resources .contact-form__agreement-title {
    margin-bottom: 2.0em;
    text-align: center;
  }
  .page-resources .contact-form__agreement-title.txt--secondary {
    font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
    line-height: 160%;
    text-align: left;
  }
  .page-resources .contact-form__agreement-title .txt--note {
    font-size: clamp(1.1rem * var(--responsive-ratio), (11 / var(--primary-inner-width) * 100vw), 1.1rem);
  }
  .page-resources .contact-form__form-complete-content .txt--primary {
    text-align: center;
  }
  .page-resources .contact-form__section .contact-form__form-btn-wrap .contact-form__form-btn-submit {
    width: calc(310 / 15 * 1em);
    aspect-ratio: 310 / 70;
    font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
    padding-inline: calc(40 / 15 * 1em) calc(70 / 15 * 1em);
  }
  .page-resources .contact-form__section .button--primary__icon,
  .page-resources .contact-form__section .button--secondary__icon {
    right: 8.8%;
    width: min(6.5%, 20px);
  }
}
.page-resources .resources-application-complete__wrap .page-title__breadcrumb,
.page-resources .resources-application-complete__wrap .page-title__breadcrumb a {
  color: var(--white-color);
}
.page-resources .resources-application-complete__section {
  margin-top: min(100 / var(--primary-inner-width) * 100vw, 100px);
}
.page-resources .resources-application-complete__section .contact-form__form-complete-content {
  margin-bottom: 0;
}
.page-resources .resources-application-complete__section .contact-form__other-link-title {
  margin-block: min(40 / var(--primary-inner-width) * 100vw, 40px) min(20 / var(--primary-inner-width) * 100vw, 20px);
  color: var(--secondary-blue-color);
  font-weight: bold;
  text-align: center;
}
.page-resources .resources-application-complete__section .contact-form__section .contact-form__download-btn {
  width: calc(310 / 15 * 1em);
  aspect-ratio: 310 / 70;
  font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  padding-inline: calc(40 / 15 * 1em) calc(70 / 15 * 1em);
}
.page-resources .contact-form__download-wrap {
  margin-top: min(70 / var(--primary-inner-width) * 100vw, 70px);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .page-resources-article .site-common__article-wrap-inner {
    padding-top: 0;
    padding-bottom: 0;
  }
  .page-resources .page-common__section .site-common__inner {
    padding-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .page-resources .resources-list__items {
    position: relative;
    grid-template-columns: 1fr;
    gap: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    width: min(290 / var(--primary-base-width) * 100vw, 290px * var(--responsive-ratio));
    margin-inline: auto;
    transform: translate3d(0,0,0);
  }
  .page-resources .site-common__list-more-wrap {
    margin-bottom: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio));
  }
  .page-resources .resources-list__items .site-common__list-item {
    width: 100% !important;
    margin-left: 0;
  }
  .page-resources .site-common__list-item-body .title--secondary {
    margin-bottom: 1.0em;
  }
  .resources-article__main-img-wrap {
    width: 100%;
  }
  .page-resources .site-common__article-body {
    width: min(300 / var(--primary-base-width) * 100vw, 300px * 1.6);
    margin-inline: auto;
  }
  .resources-article__main-wrap {
    flex-direction: column;
    gap: 0;
    margin-bottom: var(--primary-padding);
  }
  .resources-article__introduction-wrap {
    width: 100%;
  }
  .page-resources .resources-article__main-img-wrap {
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
    margin-inline: auto;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    border-radius: 20px;
    translate: max(-10 / var(--primary-base-width) * 100vw, -10px * 1.6) 0;
  }
  .resources-article__summary-wrap {
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    margin-bottom: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    padding: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    border-radius: 20px;
    translate: max(-10 / var(--primary-base-width) * 100vw, -10px * 1.6) 0;
  }
  .resources-application-complete__section {
    margin-block: 0;
  }
  .page-resources .resources-application-complete__section {
    margin-top: 0;
  }
  .page-resources .resources-application-complete__section .contact-form__other-link-title {
    margin-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-resources .resources-application-complete__section .contact-form__section .contact-form__download-btn {
    width: calc(310 / 15 * 1em);
    aspect-ratio: 310 / 70;
    font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
    padding-inline: calc(40 / 15 * 1em) calc(70 / 15 * 1em);
  }
  .page-resources .resources-application-complete__section .contact-form__download-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    text-align: center;
  }
  .page-resources .resources-application-complete__section .contact-form__form-complete-content {
    margin-bottom: 0;
  }
  .page-resources-article .page-common__section .site-common__inner::after {
    content: '';
    position: absolute;
    top: 0;
    left: -2%;
    width: 104%;
    height: 1px;
    background: var(--primary-gradient);
  }
}

/*-------------------------------------------------

 コラム

--------------------------------------------------*/
.page-column .page-common__section .site-common__inner {
  padding-top: 0;
}
.page-column .column-list__tags {
  position: relative;
  width: min(100%, 1280px);
  margin-inline: auto;
  margin-top: min(50 / var(--primary-inner-width) * 100vw, 50px);
  margin-bottom: var(--primary-padding);
  padding-block: min(40 / var(--primary-inner-width) * 100vw, 40px);
}
.page-column .column-list__tags::before,
.page-column .column-list__tags::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.page-column .column-list__tags::after {
  top: auto;
  bottom: 0;
}
.page-column .column-list__tags-title {
  position: absolute;
  top: 0;
  left: 0;
  translate: 0 -100%;
  padding: 0.5em 1em;
  color: var(--white-color);
  background: var(--primary-gradient);
  font-weight: 700;
  line-height: 1;
  border-radius: min(10 / var(--primary-inner-width) * 100vw, 10px) min(10 / var(--primary-inner-width) * 100vw, 10px) 0 0;
}
.page-column .column-list__tags-list {
  display: flex;
  flex-wrap: wrap;
  gap: min(15 / var(--primary-inner-width) * 100vw, 15px);
  font-size: clamp(1.3rem, (13 / var(--primary-inner-width) * 100vw), 1.3rem);
  line-height: 1;
}
.page-column .column-list__tags-list li {
  line-height: 1;
}
.page-column .column-list__tags-list li a {
  display: block;
  padding: 0.65em 1.0em;
  color: var(--white-color);
  line-height: 1;
  text-decoration: none;
  background: var(--primary-blue-color);
  border-radius: 100vmax;
}
.page-column .column-list__tags-head {
  margin-bottom: var(--primary-padding);
}
.page-column .column-list__tags-head-title {
  display: inline-flex;
  align-items: center;
  gap: 0.75em;
  background-image: var(--primary-gradient);
	-webkit-background-clip:text;
	-webkit-text-fill-color: transparent;
}
.page-column .column-list__tags-head-title::before {
  content: '';
  width: calc(10 / 24 * 1em);
  height: calc(10 / 24 * 1em);
  border-radius: 100vmax;
  background: var(--primary-gradient);
  transform: translateY(0.1em);
}
.page-column .column-list__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px);
}
.page-column .site-common__list-more-wrap {
  margin-bottom: min(150 / var(--primary-inner-width) * 100vw, 150px);
}
.page-column .site-common__download-inner {

}
.page-column .column-article__main-img-wrap {
  width: calc(1000 / 1280 * 100%);
  margin: 0 auto;
  border-radius: min(60 / var(--primary-inner-width) * 100vw, 60px);
  overflow: hidden;
}
.page-column .article-footer__nav {
  margin-bottom: min(150 / var(--primary-inner-width) * 100vw, 150px);
}
.page-column .column-article__toc-wrap {
  position: relative;
  width: clamp(1025px * var(--responsive-ratio), 1025 / var(--primary-inner-width) * 100vw, 1025px);
  margin-inline: auto;
  margin-top: min(40 / var(--primary-inner-width) * 100vw, 40px);
  padding-inline: clamp(80px * var(--responsive-ratio), 80 / var(--primary-inner-width) * 100vw, 80px);
  padding-block: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
  text-align: center;
  background-color: var(--primary-bg-color);
  border-radius: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px);
  z-index: 1;
}
.page-column .column-article__toc-title {
  margin-bottom: min(24 / var(--primary-inner-width) * 100vw, 24px);
  color: var(--secondary-blue-color);
}
.column-article__item-tags {
  margin-top: min(40 / var(--primary-inner-width) * 100vw, 40px);
  margin-bottom: 0;
}
.column-article__toc-list {
  display: inline-block;
  display: block;
	counter-reset: listnum; /* カウンターをリセット */
	list-style: none; /* 標準のスタイルは消す */
}
.column-article__toc-list li {
  position: relative;
  padding-left: 1.8em;
}
.column-article__toc-list li::before {
  position: absolute;
  top: 0;
  left: 0;
	counter-increment: listnum; /* counter-resetと同じ文字列 */
	content: counter(listnum) ". "; /* カウントした数に応じて番号を表示 */
  color: var(--primary-blue-color);
  font-weight: 700;
  font-size: calc(20 / 15 * 1em);
}
.column-article__toc-list li + li {
  margin-top: 0.5em;
}
.column-article__toc-list li a {
  color: var(--primary-txt-color);
}
@media screen and (max-width: 767px) {
  .page-column .site-common__article-body {
    padding-top: 0;
  }
  .page-column .column-list__tags {
    width: 100vw;
    margin-inline: calc(50% - 50vw);
    margin-top: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
    margin-bottom: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
    padding: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-inline: 0;
  }
  .page-column .column-list__tags-wrap {
    width: 100%;
    overflow: auto;
  }
  .page-column .column-list__tags-title {
    left: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding: 0.5em 1em;
    border-radius: min(8 / var(--primary-base-width) * 100vw, 8px * var(--responsive-ratio)) min(8 / var(--primary-base-width) * 100vw, 8px * var(--responsive-ratio)) 0 0;
  }
  .page-column .column-list__tags-list {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    width: max-content; /* コンテンツ幅に合わせる */
    max-width: 300vw;   /* 最大300vwまで */
    padding-inline: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    font-size: min(11 / var(--primary-base-width) * 100vw, 11px * var(--responsive-ratio));
    line-height: 1;
    overflow: auto;
  }
  .page-column .column-list__tags-list li a {
    padding: 0.5em 0.7em;
    white-space: nowrap;
  }
  .page-column .column-list__items {
    position: relative;
    grid-template-columns: 1fr;
    gap: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    width: min(290 / var(--primary-base-width) * 100vw, 290px * var(--responsive-ratio));
    margin-inline: auto;
    transform: translate3d(0,0,0);
  }
  .page-column .site-common__list-more-wrap {
    margin-bottom: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio));
  }
  .page-column .column-list__items .site-common__list-item {
    width: 100% !important;
    margin-left: 0;
  }
  .column-article__item-tags {
    margin-top: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-column .column-article__toc-wrap {
    width: min(320 / var(--primary-base-width) * 100vw, 320px * 1.6);
    margin-block: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-inline: min(22 / var(--primary-base-width) * 100vw, 22px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .page-column .column-article__toc-wrap::before {
    border-radius: 20px;
  }
  .page-column .column-article__main-img-wrap {
    width: min(320 / var(--primary-base-width) * 100vw, 320px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .page-column .article-footer__nav {
    margin-bottom: min(100 / var(--primary-base-width) * 100vw, 100px * var(--responsive-ratio));
  }
}

/*-------------------------------------------------

 よくある質問

--------------------------------------------------*/
.page-qa .page-section__title {
  margin-bottom: var(--primary-padding);
}
.qa__tab-list {
  line-height: 1;
  justify-content: center;
  gap: calc(50 / 20 * 1em);
}
.qa__tab-list-item a {
  gap: 0.75em;
  color: var(--primary-blue-color);
  font-weight: 700;
  text-decoration: none;
}
.qa__tab-list-item .site-common__link-icon {
  transform: translateY(-0.2em);
}
.qa__tab-list-item a.site-common__link.active .site-common__link-icon {
  background: var(--primary-gradient);
}
.qa__tab-list-item a.site-common__link.active .site-common__link-icon::before {
  display: none;
}
.qa__tab-list-item a.site-common__link.active .site-common__link-icon::after {
  opacity: 1;
  translate: -40% -50%;
}
.qa__tab-item-name {
  position: relative;
  display: inline-block;
  padding-bottom: 0.45em;
}
.qa__tab-item-name::after {
  content: '';
  position: absolute;
  bottom: 0;
  right: 0;
  width: 0%;
  height: 2px;
  background: var(--primary-gradient);
  transition: width .2s ease-out;
}
.qa__tab-list-item a.active .qa__tab-item-name::after {
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .qa__tab-list-item a:hover .qa__tab-item-name::after {
    width: 100%;
    left: 0;
    right: auto;
  }
}
.qa__tab-content-item-contents {
  position: relative;
  margin-top: min(40 / var(--primary-inner-width) * 100vw, 40px);
  padding-top: var(--primary-padding);
}
.qa__tab-content-item-contents::after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 2px;
  scale: 1 .5;
  background: var(--primary-gradient);
}
.qa__tab-content-item-contents-list {
  position: relative;
  width: calc(1200 / 1280 * 100%);
  margin-inline: auto;
}
.qa__tab-content-item-contents-list + .qa__tab-content-item-contents-list {
  margin-top: min(20 / var(--primary-inner-width) * 100vw, 20px);
}
.qa__tab-content-item-contents-list dt,
.qa__tab-content-item-contents-list dd {
  padding-inline: min(100 / var(--primary-inner-width) * 100vw, 100px);
  padding-block: min(40 / var(--primary-inner-width) * 100vw, 40px);
  position: relative;
  background-image: var(--primary-gradient);
}
.qa__tab-content-item-contents-list dt {
  position: relative;
  padding-left: min(100 / var(--primary-inner-width) * 100vw, 100px);
  padding-right: min(110 / var(--primary-inner-width) * 100vw, 110px);
  padding-block: min(40 / var(--primary-inner-width) * 100vw, 40px);
  color: #fff;
  border-radius: 20px;
  transition: border-radius 0.2s ease-out 0.2s;
}
.qa__tab-content-item-contents-list dt.active {
  border-radius: min(20 / var(--primary-inner-width) * 100vw, 20px) min(20 / var(--primary-inner-width) * 100vw, 20px) 0 0;
  transition: border-radius 0.2s ease-out;
}
.qa__tab-content-item-contents-list dt .icon-open {
  position: absolute;
  top: 50%;
  right: min(40 / var(--primary-inner-width) * 100vw, 40px);
  display: flex;
  align-items: center;
  width: clamp(30px * var(--responsive-ratio), 30 / var(--primary-inner-width) * 100vw, 30px);
  aspect-ratio: 1 / 1;
  transform: translateY(-50%) translateZ(0);
  pointer-events: none;
  z-index: 2;
  scale: 1;
  transform-origin: center top;
  transition: scale .2s ease-out;

}
@media (hover: hover) and (pointer: fine) {
  .qa__tab-content-item-contents-list dt:hover .icon-open {
    scale: 1.4;
  }
}
.qa__tab-content-item-contents-list dt .icon-open::before {
  content: '';
  width: 100%;
  height: 2px;
  background-color: var(--white-color);
}
.qa__tab-content-item-contents-list dt .icon-open::after {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  translate: -50% 0;
  width: 2px;
  height: 100%;
  background-color: var(--white-color);
  scale: 1 1;
  transition: scale .2s ease-out;
}
.qa__tab-content-item-contents-list dt.active .icon-open::after {
  scale: 1 0;
}
.qa__tab-content-item-contents-list .dd-wrap {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.2s ease-out;
}
.qa__tab-content-item-contents-list .dd-wrap.active {
  grid-template-rows: 1fr;
  transition-delay: 0.2s;
}
.qa__tab-content-item-contents-list .dd-wrap__inner {
  overflow: hidden;
}
.qa__tab-content-item-contents-list dd {
  color: var(--primary-color);
  border-radius: 0 0 min(20 / var(--primary-inner-width) * 100vw, 20px) min(20 / var(--primary-inner-width) * 100vw, 20px);
  z-index: 1;
}
.qa__tab-content-item-contents-list dd a {
  color: var(--primary-color);
}
.qa__tab-content-item-contents-list dd::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border: 2px solid transparent;
  border-top: none;
  background-color: #fff;
  background-origin: border-box;
  background-clip: border-box;
  -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  -webkit-mask-clip: border-box, padding-box;
  -webkit-mask-composite: destination-in;
  mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  mask-clip: border-box, padding-box;
  mask-composite: intersect;
  border-radius: 0 0 min(20 / var(--primary-inner-width) * 100vw, 20px) min(20 / var(--primary-inner-width) * 100vw, 20px);
  z-index: -1;
}
.qa__tab-content-item-contents-list dt::after,
.qa__tab-content-item-contents-list dd::after {
  content: 'Q';
  position: absolute;
  top: 50%;
  left: min(30 / var(--primary-inner-width) * 100vw, 30px);
  display: grid;
  place-content: center;
  width: clamp(50px * var(--responsive-ratio), 50 / var(--primary-inner-width) * 100vw, 50px);
  height: clamp(50px * var(--responsive-ratio), 50 / var(--primary-inner-width) * 100vw, 50px);
  padding-bottom: 0.15em;
  padding-left: 0.1em;
  color: var(--primary-blue-color);
  font-size: clamp(24px * var(--responsive-ratio), 24 / var(--primary-inner-width) * 100vw, 24px);
  line-height: 1;
  background: #fff;
  font-weight: 700;
  text-align: center;
  border-radius: 100vmax;
  transform: translateY(-50%);
}
.qa__tab-content-item-contents-list dd::after {
  content: 'A';
  color: var(--white-color);
  background-image: var(--primary-gradient);
}
.qa-application__content {
  align-items: center;
  justify-content: space-between;
  gap: min(40 / var(--primary-inner-width) * 100vw, 40px);
  width: 100%;
  padding-block: min(70 / var(--primary-inner-width) * 100vw, 70px);
  padding-inline: min(120 / var(--primary-inner-width) * 100vw, 120px);
  color: var(--white-color);
  border-radius: min(60 / var(--primary-inner-width) * 100vw, 60px);
  background: var(--secondary-blue-color);
}
.qa-application__content p.txt--midashi {
  line-height: 170%;
  text-align: center;
}
.qa-application__button-link {
  width: calc(280 / 18 * 1em);
  aspect-ratio: 280 / 80;
}
@media screen and (min-width: 768px) and (max-width: 991px) {
  .qa__tab-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}
@media screen and (max-width: 767px) {
  body.page-qa .page-title__sub-text .txt--komidashi {
    letter-spacing: 0.035em;
  }
  .qa__tab-list {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: calc(20 / 13 * 1em);
  }
  .qa__tab-list-item a::before {
    width: calc(20 / 13 * 1em);
    transform: translateY(-0.2em);
  }
  .qa__tab-content-item-contents {
    position: relative;
    margin-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .page-qa .page-section__title {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .qa__tab-content-item-contents-list {
    width: min(330 / var(--primary-base-width) * 100vw, 330px * 1.6);
    translate: max(-5 / var(--primary-base-width) * 100vw, -5px * var(--responsive-ratio)) 0;
    transform: translate3d(0,0,0);
  }
  .qa__tab-content-item-contents::after {
    left: -3%;
    width: 106%;
  }
  .qa__tab-content-item-contents-list dt {
    padding-inline: min(52 / var(--primary-base-width) * 100vw, 52px * var(--responsive-ratio));
    padding-block: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    border-radius: 20px;
  }
  .qa__tab-content-item-contents-list dt.active {
    border-radius: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio)) min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio)) 0 0;
  }
  .qa__tab-content-item-contents-list dt::after,
  .qa__tab-content-item-contents-list dd::after {
    left: min(15 / var(--primary-base-width) * 100vw, 15px * var(--responsive-ratio));
    width: min(28 / var(--primary-base-width) * 100vw, 28px * var(--responsive-ratio));
    height: min(28 / var(--primary-base-width) * 100vw, 28px * var(--responsive-ratio));
    padding-bottom: 0.15em;
    padding-left: 0.1em;
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
  .qa__tab-content-item-contents-list dd::after {
    top: min(25 / var(--primary-base-width) * 100vw, 25px * var(--responsive-ratio));
    transform: translateY(0%);
  }
  .qa__tab-content-item-contents-list dt .icon-open {
    right: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    width: min(16 / var(--primary-base-width) * 100vw, 16px * var(--responsive-ratio));
  }
  .qa__tab-content-item-contents-list + .qa__tab-content-item-contents-list {
    margin-top: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .qa__tab-content-item-contents-list dd {
    padding-inline: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-block: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    padding-left: min(52 / var(--primary-base-width) * 100vw, 52px * var(--responsive-ratio));
    border-radius: 0 0 min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio)) min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .qa__tab-content-item-contents-list dd::before {
    border-radius: 0 0 min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio)) min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
  }
  .qa-application__content {
    gap: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-block: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    padding-inline: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    border-radius: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .qa-application__content .txt--midashi {
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
    line-height: 140%;
  }
}

/*-------------------------------------------------

 お問い合わせ

--------------------------------------------------*/
.page-contact .page-title__sub-text {
  margin-bottom: var(--primary-padding);
}
.page-contact .page-title__sub-text p {
  text-align: center;
}
.page-contact .page-title__sub-text p a {
  color: var(--primary-blue-color);
}
.page-contact .page-title__sub-text p + p {
  margin-top: 2em;
}
.page-contact .page-title__sub-list-wrap {
  position: relative;
  width: clamp(760px * var(--responsive-ratio), 760 / var(--primary-inner-width) * 100vw, 760px);
  margin-inline: auto;
  margin-bottom: clamp(85px * var(--responsive-ratio), 85 / var(--primary-inner-width) * 100vw, 85px);
  padding: clamp(40px * var(--responsive-ratio), 40 / var(--primary-inner-width) * 100vw, 40px) clamp(120px * var(--responsive-ratio), 120 / var(--primary-inner-width) * 100vw, 120px);
  text-align: center;
  background-image: var(--primary-gradient);
  border-radius: 40px;
}
.page-contact .page-title__sub-list-wrap::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 100%;
  border-radius: 40px;
  border: 1px solid transparent;
  background-color: var(--primary-bg-color);
  background-origin: border-box;
  background-clip: border-box;
  -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  -webkit-mask-clip: border-box, padding-box;
  -webkit-mask-composite: destination-in;
  mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
  mask-clip: border-box, padding-box;
  mask-composite: intersect;
}
.page-contact .page-title__sub-list-text {
  position: relative;
  text-align: center;
}
.page-contact .page-title__sub-list-title {
  margin-bottom: min(30 / var(--primary-inner-width) * 100vw, 30px);
}
.page-contact .page-title__sub-list {
  display: inline-block;
}
.page-contact .page-title__sub-list li {
  position: relative;
  padding-left: calc(30 / 20 * 1em);
}
.page-contact .page-title__sub-list li::before {
  content: '';
  position: absolute;
  top: 0.25em;
  left: 0;
  width: calc(10 / 20 * 1em);
  height: calc(10 / 20 * 1em);
  border-radius: 100vmax;
  background: var(--primary-gradient);
  transform: translateY(0.4em);
}
.page-contact .page-title__sub-list li + li {
  margin-top: 0.5em;
}
.page-contact .page-common__section .site-common__inner::after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 2px;
    scale: 1 .5;
    background: var(--primary-gradient);
}
@media screen and (max-width: 767px) {
  .page-contact .page-title__sub-text {
    width: min(310 / var(--primary-base-width) * 100vw, 310px * 1.6);
    margin-inline: auto;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .page-contact .page-title__sub-text p {
    text-align: left;
  }
  .page-contact .page-title__sub-text p + p {
    margin-top: 1em;
  }
  .page-contact .page-title__sub-list-wrap {
    width: 100%;
    margin-bottom: min(60 / var(--primary-base-width) * 100vw, 60px * var(--responsive-ratio));
    padding-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
    padding-inline: min(22 / var(--primary-base-width) * 100vw, 22px * var(--responsive-ratio));
    border-radius: 30px;
  }
  .page-contact .page-title__sub-list-wrap::before {
    border-radius: 30px;
  }
  .page-contact .page-title__sub-list-title {
    margin-bottom: min(20 / var(--primary-base-width) * 100vw, 20px * var(--responsive-ratio));
    font-size: min(15 / var(--primary-base-width) * 100vw, 1.5rem * var(--responsive-ratio));
  }
  .page-contact .page-title__sub-list {
    width: calc(224 / 276 * 100%);
    width: 90%;
  }
  .page-contact .page-common__section .site-common__inner::after {
    left: -2%;
    width: 104%;
  }
}

/*-------------------------------------------------

 資料請求

--------------------------------------------------*/

.page-download .resources-article__main-img-wrap {
	width: 90%;
	margin: 2em auto 3em;
}


/* 資料請求ページ フォームセクション */
@media screen and (min-width: 768px) {
  .page-common__section .download-application__inner.site-common__inner {
    padding-top: 0;
  }
  .download-application__wrap {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    width: min(100%, 1280px);
    margin-inline: auto;
    margin-bottom: min(20 / var(--primary-inner-width) * 100vw, 20px);
    padding-top: 0;
  }
  .download-application__description {
    width: calc(640 / 1280 * 100%);
    margin: 0;
    padding: 0;
  }
  .download-application__description .site-common__article-body {
    width: 100%;
    padding-top: 0;
  }
  .download-application__contact-form {
    width: calc(550 / 1280 * 100%);
  }
  .page-download .download-application__contact-form .contact-form__outer {
    position: relative;
    padding: min(50 / var(--primary-inner-width) * 100vw, 50px);
    border-radius: min(40 / var(--primary-inner-width) * 100vw, 40px);
    background-image: var(--primary-gradient);
  }
  .page-download .download-application__contact-form .contact-form__outer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    width: 100%;
    height: 100%;
    border-radius: min(40 / var(--primary-inner-width) * 100vw, 40px);
    border: 1px solid transparent;
    background-color: var(--white-color);
    background-origin: border-box;
    background-clip: border-box;
    -webkit-mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
    -webkit-mask-clip: border-box, padding-box;
    -webkit-mask-composite: destination-in;
    mask-image: linear-gradient(#fff 0 0), linear-gradient(#fff 0 0);
    mask-clip: border-box, padding-box;
    mask-composite: intersect;
  }
  .page-download .download-application__contact-form .contact-form__inner {
    position: relative;
    margin: 0;
    padding: 0;
  }
  .page-download .download-application__contact-form .contact-form__form-wrap {
    width: 100%;
    font-size: clamp(1.4rem * var(--responsive-ratio), (14 / var(--primary-inner-width) * 100vw), 1.4rem);
    line-height: 170%;
    --form-wrap-width: 550;
  }
  .page-download .site-common__form .contact-form__form-item {
    flex-direction: column;
    align-items: flex-start;
    gap: min(6 / var(--form-wrap-width) * 100vw, 6px);
    margin-bottom: min(15 / var(--form-wrap-width) * 100vw, 15px);
  }
  .page-download .site-common__form .contact-form__form-item-title,
  .page-download .contact-form__form-item-input-wrap {
    width: 100%;
  }
  .page-download .contact-form__title {
    margin-bottom: min(30 / var(--primary-inner-width) * 100vw, 30px);
    font-size: clamp(2.0rem * var(--responsive-ratio), (20 / var(--primary-inner-width) * 100vw), 2.0rem);
  }
  .page-download .download-application__contact-form .contact-form__step-list {
    margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  }
  .page-download .download-application__contact-form .contact-form__step-item {
    height: calc(36 / 15 * 1em);
    font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
  }
  .page-download .download-application__contact-form .contact-form__step-item::before,
  .page-download .download-application__contact-form .contact-form__step-item::after {
    width: 10px
  }
  .page-download .site-common__form select {
    padding: 0.85em 1.5em;
    padding-right: 3.0em;
    font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
  }
  .page-download .site-common__form input[type=text],
  .page-download .site-common__form textarea {
    padding: 0.85em 1.5em;
    font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
  }
  .page-download .site-common__form .contact-form__form {
    margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  }
  .page-download .site-common__form .contact-form__agreement {
    margin-bottom: min(40 / var(--primary-inner-width) * 100vw, 40px);
  }
  .page-download .contact-form__agreement-title {
    margin-bottom: 2.0em;
    text-align: center;
  }
  .page-download .contact-form__agreement-title.txt--secondary {
    font-size: clamp(1.3rem * var(--responsive-ratio), (13 / var(--primary-inner-width) * 100vw), 1.3rem);
    line-height: 160%;
    text-align: left;
  }
  .page-download .contact-form__agreement-title .txt--note {
    font-size: clamp(1.1rem * var(--responsive-ratio), (11 / var(--primary-inner-width) * 100vw), 1.1rem);
  }
  .page-download .contact-form__form-complete-content .txt--primary {
    text-align: center;
  }
  .page-download .contact-form__form-btn .contact-form__form-btn-wrap .contact-form__form-btn-submit {
    width: calc(310 / 15 * 1em);
    aspect-ratio: 310 / 70;
    font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
    padding-inline: calc(40 / 15 * 1em) calc(70 / 15 * 1em);
  }
  .page-download .contact-form__form-btn .button--primary__icon,
  .page-download .contact-form__form-btn .button--secondary__icon {
    right: 8.8%;
    width: min(6.5%, 20px);
  }
}
@media screen and (max-width: 767px) {
  .page-download .site-common__article-body {
    padding-top: 0;
  }
  .page-download .page-common__section .site-common__inner {
    padding-bottom: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio));
  }
  .page-download .resources-article__main-img-wrap {
	  width: 100%;
		margin: 0;
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .page-download .contact-form__title {
    margin-bottom: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .page-download .download-application__contact-form {
    position: relative;
    /* margin-top: min(80 / var(--primary-base-width) * 100vw, 80px * var(--responsive-ratio)); */
    margin-top: min(50 / var(--primary-base-width) * 100vw, 50px * var(--responsive-ratio));
    padding-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
  }
  .page-download .download-application__contact-form::after {
    content: '';
    position: absolute;
    top: 0;
    left: -2%;
    width: 104%;
    height: 2px;
    scale: 1 .5;
    background: var(--primary-gradient);
  }
}
/* 資料請求ページ 完了ページ */
.page-download .contact-form__form-complete-content {
  margin-bottom: min(20 / var(--primary-inner-width) * 100vw, 20px);
}
.page-download .download-application-complete__section .contact-form__other-link-title {
  margin-block: min(40 / var(--primary-inner-width) * 100vw, 40px) min(20 / var(--primary-inner-width) * 100vw, 20px);
  color: var(--secondary-blue-color);
  font-weight: bold;
  text-align: center;
}
.page-download .contact-form__download-wrap {
  margin-top: min(70 / var(--primary-inner-width) * 100vw, 70px);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .page-download .download-application-complete__section {
    margin-top: 0;
  }
  .page-download .download-application-complete__section .contact-form__other-link-title {
    margin-block: min(30 / var(--primary-base-width) * 100vw, 30px * var(--responsive-ratio));
  }
  .page-download .download-application-complete__section .contact-form__section .contact-form__download-btn {
    width: calc(310 / 15 * 1em);
    aspect-ratio: 310 / 70;
    font-size: clamp(1.5rem * var(--responsive-ratio), (15 / var(--primary-inner-width) * 100vw), 1.5rem);
    padding-inline: calc(40 / 15 * 1em) calc(70 / 15 * 1em);
  }
  .page-download .download-application-complete__section .contact-form__download-wrap {
    margin-top: min(40 / var(--primary-base-width) * 100vw, 40px * var(--responsive-ratio));
    text-align: center;
  }
  .page-download .download-application-complete__section .contact-form__form-complete-content {
    margin-bottom: 0;
  }
}

/*-------------------------------------------------

 ヘッダー＆フッター処理

--------------------------------------------------*/
body.no-global-nav .site-header__nav-wrap,
body.no-global-nav .site-header__hamburger {
  display: none;
}
body.no-global-nav .site-footer__nav,
body.no-global-nav .site-footer__actions {
  display: none;
}
body.no-global-nav .site-footer__sub-nav-list {
  padding-top: 0;
}
body.no-global-nav .site-footer__sub-nav-list::before {
  display: none;
}
@media screen and (max-width: 767px) {
  body.no-global-nav .site-footer__sub-nav-list {
    margin-top: 0;
  }
}