/* Webフォント */
/* フォント対応表:
   DIN 2014 → Oswald (Google Fonts代替)
*/
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@300;400;600;700&display=swap"); /* スマホデザインが414pxで作られている場合の,rem可変を同倍率可変にする場合は有効・不要なら削除 */
@media screen and (max-width: 767.98px) {
  html {
    font-size: 3.8647342995vw;
  }
}

/* 769px - 1399px */
@media (min-width: 768px) and (max-width: 1199px) {
  html {
    font-size: calc((100vw - 768px) / 432 * 3 + 13px);
  }
}

/* スマホではpcクラスは非表示 */
@media (max-width: 767.98px) {
  .pc {
    display: none !important;
    pointer-events: none;
  }
}

/* PCではspクラスは非表示 */
@media (min-width: 768px) {
  .sp {
    display: none !important;
    pointer-events: none;
  }
}

body {
  -webkit-font-smoothing: antialiased;
}

.fz {
  width: 100%;
  overflow: hidden;
  position: relative;
  /* overflow-x: hidden; */
}

/* ========================================
   共通クラス
   ======================================== */
/* セクションリード共通スタイル */
.fz-lead {
  font-family: "Oswald", sans-serif;
  font-family: "Shippori Mincho", serif;
  font-size: 20px;
  font-size: 1.25rem;
  font-weight: 700;
  letter-spacing: 3.2px;
  letter-spacing: 0.2rem;
  line-height: 1.19;
  display: inline-block;
  padding-bottom: 4px;
  padding-bottom: 0.25rem;
  opacity: 0.6;
}

/* カードリスト共通スタイル */
.fz-cards {
  display: flex;
  flex-direction: column;
}

/* 本文テキスト共通スタイル */
.fz-txt {
  font-family: "Noto Sans JP", sans-serif;
  color: #001023;
}

/* セクション見出し共通スタイル */
.fz-ttl {
  font-family: "Noto Sans JP", sans-serif;
  color: #001023;
}

/* figma-css:start nodeId=1-6363 */
/* ========================================
   セクション名: Header
   Figma nodeId: 1-6363
   ======================================== */
.fz-header {
  background-color: #ffffff;
  height: 48px;
  height: 3rem;
}

.fz-header__inner {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  height: 100%;
  padding-left: 11px;
  padding-left: 0.6875rem;
  position: relative;
}

.fz-header__logo-link {
  display: inline-block;
  text-decoration: none;
}

.fz-header__logo-img {
  width: 88.677px;
  width: 5.5423125rem;
  margin-right: 10px;
  margin-right: 0.625rem;
}

.fz-header__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11px;
  font-size: 0.6875rem;
  font-weight: 500;
  color: #373433;
  line-height: 1.2;
  letter-spacing: 0.66px;
  letter-spacing: 0.04125rem;
  /* text-align: center; */
  /* position: absolute; */
  /* left: 50%; */
  /* transform: translateX(-50%); */
}

/* figma-css:end nodeId=1-6363 */
/* figma-css:start nodeId=1-6369 */
/* ========================================
   セクション名: Hero
   Figma nodeId: 1-6369
   ======================================== */
.fz-hero {
  background-color: #ffffff;
  position: relative;
}

.fz-hero__inner {
  width: 100%;
}

.fz-hero__img {
  width: 100%;
  height: auto;
  display: block;
}

.fz-hero__btn {
  display: flex;
  justify-content: center;
  width: 93%;
  position: absolute;
  bottom: -3rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
}

.fz-hero__btn-img {
  width: 106%;
  height: auto;
  display: block;
  z-index: 1;
  /* position: fixed; */
  max-inline-size: initial;
}

/* figma-css:end nodeId=1-6369 */
/* figma-css:start nodeId=265-2635 */
/* ========================================
   セクション名: 企業目線サポート
   Figma nodeId: 265-2635
   ======================================== */
.fz-corporate {
  position: relative;
  overflow: hidden;
  background-color: #ffffff;
  z-index: 0;
  padding-bottom: 40px;
  padding-bottom: 0.4rem;
}

.fz-corporate__inner {
  width: 100%;
  position: relative;
}

/* ----------------------------------------
   ヘッダーエリア
   ---------------------------------------- */
.fz-corporate__header {
  position: relative;
  padding-top: 45.4px;
  padding-top: 2.8375rem;
  /* padding-bottom: 20px;
    /* padding-bottom: 1.25rem; */
  /* padding-bottom: 20px;
    /* padding-bottom: 1.25rem; */
  text-align: center;
}
.fz-corporate__content {
  position: relative;
  margin-top: -1.9rem;
  padding-top: 2.1rem;
  padding-bottom: 2.5rem;
}

.fz-corporate__header-bg {
  position: absolute;
  top: 129.6px;
  top: 8.1rem;
  left: -67px;
  left: -4.1875rem;
  width: 327px;
  width: 20.4375rem;
  z-index: 0;
  pointer-events: none;
}

.fz-corporate__header-bg-img {
  width: 100%;
  height: auto;
}

.fz-corporate__header-content {
  width: 67%;
  margin-inline: auto;
  margin-bottom: 6.4px;
  margin-bottom: 0.4rem;
}

.fz-corporate__lead {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 700;
  color: #00213a;
  line-height: -8.44;
  letter-spacing: 1.03px;
  letter-spacing: 0.064375rem;
  position: relative;
  z-index: 1;
  white-space: nowrap;
}

.fz-corporate__lead-num {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 39px;
  font-size: 2.4375rem;
  font-weight: 900;
  color: #d44c1b;
  letter-spacing: 0.78px;
  letter-spacing: 0.04875rem;
  line-height: 1.56;
}

.fz-corporate__lead-unit {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 25px;
  font-size: 1.5625rem;
  font-weight: 900;
  color: #d44c1b;
  letter-spacing: 1.51px;
  letter-spacing: 0.094375rem;
  line-height: 1.56;
}

.fz-corporate__border-img {
  display: block;
  width: 100%;
  height: auto;
  z-index: 1;
  position: relative;
}

.fz-corporate__ttl {
  font-family: "Shippori Mincho", serif;
  font-size: 24.5px;
  font-size: 1.53125rem;
  font-weight: 600;
  color: #00213a;
  line-height: 1.55;
  letter-spacing: 1.47px;
  letter-spacing: 0.091875rem;
  position: relative;
  z-index: 1;
  margin-bottom: 10px;
  margin-bottom: 0.625rem;
}

.fz-corporate__ttl-box {
  font-size: 31px;
  font-size: 1.9375rem;
  letter-spacing: 1.88px;
  letter-spacing: 0.1175rem;
  border: 0.46px solid #00213a;
  border: 0.05rem solid #00213a;
  padding: 0.8px 8px 2.72px;
  padding: 0.05rem 0.5rem 0.17rem;
  display: inline-block;
  margin-right: 5.2px;
  margin-right: 0.325rem;
}

.fz-corporate__ttl-particle {
  font-size: 26.5px;
  font-size: 1.65625rem;
  letter-spacing: 4px;
  letter-spacing: 0.25rem;
}

.fz-corporate__ttl-main {
  font-size: 36px;
  font-size: 2.25rem;
  letter-spacing: 0.72px;
  letter-spacing: 0.045rem;
}

.fz-corporate__hero-photo {
  position: relative;
  z-index: 1;
  width: 100%;
  margin-bottom: 0;
  margin-top: -12.8px;
  margin-top: -0.8rem;
}

.fz-corporate__hero-photo-img {
  width: 99%;
  height: auto;
  display: block;
  margin-inline: auto;
}

/* ----------------------------------------
   悩みエリア
   ---------------------------------------- */
.fz-corporate__worry {
  position: relative;
}

.fz-corporate__worry-bg {
  position: absolute;
  /* top: -29.6px; */
  /* top: -1.85rem; */
  left: 0;
  width: 100%;
  z-index: 1;
  pointer-events: none;
  top: 0;
}

.fz-corporate__worry-bg-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}

.fz-corporate__worry-items {
  position: relative;
  z-index: 1;
  width: 92%;
  margin: 0 auto;
  /* padding-top: 10px;
    /* padding-top: 0.625rem; */
  /* padding-top: 10px;
    /* padding-top: 0.625rem; */
  /* padding-bottom: 20px;
    /* padding-bottom: 1.25rem; */
  /* padding-bottom: 20px;
    /* padding-bottom: 1.25rem; */
}

.fz-corporate__worry-img {
  width: 100%;
  height: auto;
  display: block;
}

/* ----------------------------------------
   プロセス導入エリア
   ---------------------------------------- */
.fz-corporate__process-intro {
  text-align: center;
  position: relative;
  z-index: 1;
  padding-top: 10px;
  padding-top: 0.625rem;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}

.fz-corporate__process-arrow {
  width: 42px;
  width: 2.625rem;
  height: auto;
  margin-bottom: 18.4px;
  margin-bottom: 1.15rem;
  display: block;
  margin-inline: auto;
}

.fz-corporate__process-lead {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 900;
  color: #00213a;
  line-height: 1.47;
  letter-spacing: 0.89px;
  letter-spacing: 0.055625rem;
  margin-bottom: 2px;
  margin-bottom: 0.125rem;
}

.fz-corporate__process-ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 900;
  color: #00213a;
  line-height: 1.47;
  letter-spacing: 0.89px;
  letter-spacing: 0.055625rem;
}

.fz-corporate__process-ttl em {
  font-style: normal;
  font-size: 29px;
  font-size: 1.8125rem;
  color: #b4ab00;
  letter-spacing: 1.47px;
  letter-spacing: 0.091875rem;
}

/* ----------------------------------------
   ステップ共通
   ---------------------------------------- */
.fz-corporate__steps {
  position: relative;
  z-index: 1;
}

.fz-corporate__step {
  display: flex;
  align-items: flex-start;
  margin-bottom: 9.6px;
  margin-bottom: 0.6rem;
  position: relative;
  justify-content: flex-end;
}

.fz-corporate__step:last-child {
  margin-bottom: 0;
}

/* 奇数ステップ（01,03,05）: 写真左・テキスト右 */
.fz-corporate__step--odd {
  flex-direction: row;
  margin-bottom: 0px;
  margin-bottom: 0rem;
}

.fz-corporate__step--odd .fz-corporate__step-photo {
  width: 48%;
  flex-shrink: 0;
  /* margin-left: -5%; */
  margin-top: 11.2px;
  margin-top: 0.7rem;
}

.fz-corporate__step--odd .fz-corporate__step-body {
  flex: 1;
  padding-left: 13.6px;
  padding-left: 0.85rem;
  padding-right: 11.2px;
  padding-right: 0.7rem;
}

/* 偶数ステップ（02,04）: テキスト左・写真右 */
.fz-corporate__step--even {
  flex-direction: row-reverse;
  margin-bottom: 16px;
  margin-bottom: 1rem;
}

.fz-corporate__step--even .fz-corporate__step-photo {
  width: 48%;
  flex-shrink: 0;
  /* margin-right: -5%; */
  margin-top: 28.8px;
  margin-top: 1.8rem;
}

.fz-corporate__step--even .fz-corporate__step-body {
  flex: 1;
  padding-left: 24.8px;
  padding-left: 1.55rem;
  padding-right: 7.2px;
  padding-right: 0.45rem;
}

.fz-corporate__step-photo-img {
  width: 100%;
  height: auto;
  display: block;
}

.fz-corporate__step-num {
  font-family: "Shippori Mincho", serif;
  font-size: 36px;
  font-size: 2.25rem;
  font-weight: 500;
  color: #768c95;
  line-height: 1.29;
  letter-spacing: 1.8px;
  letter-spacing: 0.1125rem;
  opacity: 0.26;
  margin-bottom: 4px;
  margin-bottom: 0.25rem;
}

.fz-corporate__step-ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 700;
  color: #00213a;
  line-height: 1.47;
  letter-spacing: 1.02px;
  letter-spacing: 0.06375rem;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}

.fz-corporate__step-ttl em {
  font-style: normal;
  color: #b4ab00;
}

.fz-corporate__step-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 400;
  color: #00213a;
  line-height: 1.55;
  letter-spacing: 0.84px;
  letter-spacing: 0.0525rem;
}

/* figma-css:end nodeId=265-2635 */
/* figma-css:start nodeId=265-2643 */
/* ========================================
   セクション名: Voice（お客さまの声）
   Figma nodeId: 265-2643
   ======================================== */
.fz-voice {
  padding-top: 34px;
  padding-top: 1.425rem;
  padding-bottom: 24px;
  padding-bottom: 1.5rem;
  background-color: #ffffff;
  position: relative;
  overflow: hidden;
}

.fz-voice__inner {
  width: 80.5%;
  max-width: 980px;
  margin: 0 auto;
  position: relative;
}

.fz-voice__header {
  text-align: center;
  margin-bottom: 22px;
  margin-bottom: 1.375rem;
}

.fz-voice__lead {
  font-family: "Shippori Mincho", serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 700;
  color: #96b4c2;
  letter-spacing: 2.72px;
  letter-spacing: 0.17rem;
  line-height: 1.4;
  margin-bottom: 4px;
  margin-bottom: 0.25rem;
}

.fz-voice__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 27.5px;
  font-size: 1.71875rem;
  font-weight: 700;
  color: #00213a;
  letter-spacing: 1.925008px;
  letter-spacing: 0.120313rem;
  line-height: 1.35;
  z-index: 1;
  position: relative;
}

.fz-voice__deco {
  position: absolute;
  top: 14px;
  top: -0.825rem;
  right: -20px;
  right: -3.95rem;
  width: 171px;
  width: 10.6875rem;
  height: auto;
  pointer-events: none;
  z-index: 0;
}

.fz-voice__cards {
  display: flex;
  flex-direction: column;
  gap: 21px;
  gap: 1.3125rem;
  position: relative;
  z-index: 1;
}

.fz-voice__card {
  background-color: #ffffff;
  border: 1px solid #eae9e5;
  border: 0.0625rem solid #eae9e5;
  border-radius: 10px;
  border-radius: 0.625rem;
  box-shadow: 0px 0px 12.7px 0px rgba(191, 191, 191, 0.21);
  box-shadow: 0rem 0rem 0.79375rem 0rem rgba(191, 191, 191, 0.21);
  padding: 18.4px 18.4px 32px;
  padding: 1.15rem 1.15rem 2rem;
  position: relative;
}

.fz-voice__card-profile {
  display: flex;
  align-items: center;
  gap: 14px;
  gap: 0.875rem;
  margin-bottom: 12.8px;
  margin-bottom: 0.8rem;
}

.fz-voice__card-photo {
  width: 79px;
  width: 4.9375rem;
  height: 79px;
  height: 4.9375rem;
  border-radius: 50%;
  object-fit: cover;
  flex-shrink: 0;
}

.fz-voice__card-info {
  display: flex;
  flex-direction: column;
}

.fz-voice__card-name {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 700;
  color: #00213a;
  letter-spacing: 1.4px;
  letter-spacing: 0.0875rem;
  line-height: 1.4;
}

.fz-voice__card-service {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11px;
  font-size: 0.6875rem;
  font-weight: 700;
  color: #00213a;
  letter-spacing: 0.88px;
  letter-spacing: 0.055rem;
  line-height: 1.4;
}

.fz-voice__card-stars {
  font-family: "Inter", sans-serif;
  font-size: 14.85px;
  font-size: 0.928125rem;
  font-weight: 700;
  color: #efc141;
  letter-spacing: 0.329008px;
  letter-spacing: 0.020563rem;
  line-height: 1.4;
}

.fz-voice__card-catch {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 900;
  color: #4191d3;
  letter-spacing: 1.7px;
  letter-spacing: 0.10625rem;
  line-height: 1.4;
  margin-bottom: 12px;
  margin-bottom: 0.45rem;
}

.fz-voice__card-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 400;
  color: #3a3a3a;
  letter-spacing: 0.84px;
  letter-spacing: 0.0525rem;
  line-height: 1.65;
}

.fz-voice__btn {
  display: flex;
  justify-content: center;
  margin-top: 27px;
  margin-top: 1.6875rem;
  text-align: center;
}

.fz-voice__btn-img {
  width: 115.6%;
  margin-inline: auto;
  /* max-width: 364px; /* max-width: 22.75rem; */
  max-width: 396px;
  height: auto;
  display: block;
}

/* figma-css:end nodeId=265-2643 */
/* figma-css:start nodeId=265-2660 */
/* ========================================
   セクション名: Merit
   Figma nodeId: 265:2660 (SP), 265:3471 (PC)
   ======================================== */
.fz-merit {
  padding-top: 34px;
  padding-top: 2.125rem;
  padding-bottom: 50px;
  padding-bottom: 3.125rem;
  background-color: #edf2f4;
}

.fz-merit__inner {
  width: 88.1%;
  max-width: 1080px;
  margin-inline: auto;
}

.fz-merit__lead {
  color: #94c3d6;
  text-align: left;
  margin-bottom: 4px;
  margin-bottom: 0.25rem;
  opacity: 0.7;
}

.fz-merit__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 23.08px;
  font-size: 1.4425rem;
  font-weight: 900;
  color: #001023;
  line-height: 1.6;
  line-height: 1.6;
  letter-spacing: 1.616px;
  letter-spacing: 0.101rem;
  margin-bottom: 23px;
  margin-bottom: 1.4375rem;
}

.fz-merit__ttl em {
  font-style: normal;
  color: #61aecf;
}

.fz-merit__cards {
  gap: 16px;
  gap: 1rem;
}

.fz-merit-card {
  position: relative;
}

.fz-merit-card__box {
  background-color: #ffffff;
  border-radius: 10px;
  border-radius: 0.625rem;
  padding: 15.2px 32px 22px;
  padding: 0.95rem 2rem 1.375rem;
  text-align: center;
  box-shadow: 0 0 12.1px 0 rgba(170, 193, 206, 0.23);
  box-shadow: 0 0 0.75625rem 0 rgba(170, 193, 206, 0.23);
}

.fz-merit-card:nth-child(n + 2) .fz-merit-card__box {
  border: 1px solid #eaeaea;
  border: 0.0625rem solid #eaeaea;
}

.fz-merit-card__num {
  font-family: "Shippori Mincho", serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 700;
  color: #94c3d6;
  text-align: center;
  letter-spacing: 2.21px;
  letter-spacing: 0.138125rem;
  line-height: 1.7;
}

.fz-merit-card__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 19px;
  font-size: 1.1875rem;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  letter-spacing: 1.33px;
  letter-spacing: 0.083125rem;
  line-height: 2.05;
  border-radius: 0;
  margin-bottom: 14.4px;
  margin-bottom: 0.9rem;
}

.fz-merit-card__ttl span {
  background-color: #61aecf;
  padding: 1.4px 10px 3.4px;
  padding: 0.0875rem 0.625rem 0.2125rem;
  line-height: 1;
}

.fz-merit-card__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 400;
  color: #000f1b;
  line-height: 1.6;
  letter-spacing: 0.96px;
  letter-spacing: 0.06rem;
  text-align: left;
}

/* figma-css:end nodeId=265-2660 */
/* figma-css:start nodeId=265-2668 */
/* ========================================
   セクション名: Persona (SP)
   Figma nodeId: 265:2668
   ビューポート: 414px
   ======================================== */
/* ========================================
   セクション名: Persona (SP)
   Figma nodeId: 265:2668
   ビューポート: 25.875rem
   ======================================== */
.fz-persona {
  padding-top: 39px;
  padding-top: 2.4375rem;
  padding-bottom: 25px;
  padding-bottom: 1.5625rem;
  background-color: #ffffff;
}

.fz-persona__inner {
  width: 89%;
  max-width: 840px;
  margin-inline: auto;
}

.fz-persona__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 800;
  color: #001023;
  line-height: 1.3;
  letter-spacing: 1.08px;
  letter-spacing: 0.0675rem;
  margin-bottom: 18px;
  margin-bottom: 1.125rem;
}

.fz-persona__ttl em {
  border-bottom: 1px solid #222;
  border-bottom: 0.0625rem solid #222;
  font-weight: 600;
  font-size: 18px;
  font-size: 1.125rem;
  padding-bottom: 2px;
  padding-bottom: 0.125rem;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
  display: inline-block;
}

.fz-persona__ttl strong {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 900;
  color: #115498;
  letter-spacing: 1.44px;
  letter-spacing: 0.09rem;
}

.fz-persona__cards {
  gap: 26px;
  gap: 1.625rem;
  margin-bottom: 36px;
  margin-bottom: 2.25rem;
}

.fz-persona-card {
  display: flex;
  align-items: center;
  gap: 12px;
  gap: 0.75rem;
}

.fz-persona-card:nth-child(even) {
  flex-direction: row-reverse;
}

.fz-persona-card__img {
  width: 115.4px;
  width: 7.2125rem;
  height: auto;
  flex-shrink: 0;
  display: block;
}

.fz-persona-card__img--2 {
  width: 125.6px;
  width: 7.85rem;
}

.fz-persona-card__img--3 {
  width: 125.8px;
  width: 7.8625rem;
}

.fz-persona-card__body {
  flex: 1;
  min-width: 0;
}

.fz-persona-card__job {
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 500;
  color: #ffffff;
  letter-spacing: 0.28px;
  letter-spacing: 0.0175rem;
  line-height: 1.72;
  background-color: #115498;
  padding: 2px 7px;
  padding: 0.125rem 0.4375rem;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}

.fz-persona-card__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #001023;
  letter-spacing: 0.3px;
  letter-spacing: 0.01875rem;
  line-height: 1.72;
}

.fz-persona__btn {
  display: flex;
  justify-content: center;
  /* width: 100%; */
  text-align: center;
}

.fz-persona__btn-img {
  width: 100%;
  height: auto;
  display: block;
  margin-inline: auto;
  max-inline-size: initial;
}

/* figma-css:end nodeId=265-2668 */
/* figma-css:start nodeId=265-4139 */
/* ========================================
   セクション名: Reason (SP)
   Figma nodeId: 265:4139
   ビューポート: 414px
   ======================================== */
/* ========================================
   セクション名: Reason (SP)
   Figma nodeId: 265:4139
   ビューポート: 25.875rem
   ======================================== */
.fz-reason {
  padding-top: 35px;
  padding-top: 2.1875rem;
  padding-bottom: 38px;
  padding-bottom: 2.375rem;
  background: #f9f8ed;
}

.fz-reason__inner {
  width: 88%;
  max-width: 975px;
  margin-inline: auto;
}

.fz-reason__lead {
  color: #bfb545;
  text-align: left;
  margin-bottom: 12px;
  margin-bottom: 0.75rem;
  font-size: 21px;
  font-size: 1.3125rem;
}

.fz-reason__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #001023;
  line-height: 1.65;
  letter-spacing: 1.056px;
  letter-spacing: 0.066rem;
  margin-bottom: 25.2px;
  margin-bottom: 1.575rem;
}

.fz-reason__ttl strong {
  font-size: 21px;
  font-size: 1.3125rem;
  font-weight: 900;
}

.fz-reason__ttl span {
  color: #beb440;
  font-size: 35px;
  font-size: 2.1875rem;
  line-height: 1.3;
}

.fz-reason__ttl em {
  font-style: normal;
  color: #beb440;
}

.fz-reason__cards {
  gap: 20px;
  gap: 1.25rem;
}

.fz-reason-card {
  position: relative;
  background-color: #ffffff;
  border-radius: 15px;
  border-radius: 0.7375rem;
  padding: 15.2px 22px 27.2px;
  padding: 0.95rem 1.375rem 1.7rem;
  overflow: hidden;
  text-align: center;
}

.fz-reason-card__num {
  font-family: "Heisei Kaku Gothic Std", "Futura PT", "Oswald", sans-serif;
  font-family: "Zeitung Pro", sans-serif;
  font-size: 22.4px;
  font-size: 1.4rem;
  font-weight: 600;
  color: #dcd8a6;
  text-align: center;
  letter-spacing: 1.792px;
  letter-spacing: 0.112rem;
  line-height: 1.69;
  margin-bottom: 1.6px;
  margin-bottom: 0.1rem;
}

.fz-reason-card__catch {
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16.8px;
  font-size: 1.05rem;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  letter-spacing: 1.344px;
  letter-spacing: 0.084rem;
  line-height: 1.34;
  background-color: #beb440;
  padding: 4.4px 12px;
  padding: 0.275rem 0.75rem;
  margin-bottom: 7.2px;
  margin-bottom: 0.45rem;
}

.fz-reason-card__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 23.08px;
  font-size: 1.4425rem;
  font-weight: 900;
  color: #beb440;
  text-align: center;
  letter-spacing: 1.385px;
  letter-spacing: 0.0865625rem;
  line-height: 1.45;
  margin-bottom: 16px;
  margin-bottom: 1rem;
}

.fz-reason-card__img {
  width: 100%;
  height: auto;
  border-radius: 6px;
  border-radius: 0.375rem;
  margin-bottom: 16px;
  margin-bottom: 1rem;
}

.fz-reason-card__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001023;
  line-height: 1.79;
  letter-spacing: 0.75px;
  letter-spacing: 0.046875rem;
  text-align: left;
}

/* figma-css:end nodeId=265-4139 */
/* figma-css:start nodeId=265-2677 */
/* ========================================
   セクション名: Point (パターンB)
   ======================================== */
.fz-point {
  padding-top: 38px;
  padding-top: 2.375rem;
  padding-bottom: 35px;
  padding-bottom: 2.1875rem;
  background-color: #ffffff;
}

.fz-point__inner {
  width: 88%;
  max-width: 1080px;
  margin-inline: auto;
}

.fz-point__lead {
  color: #aed3e2;
  text-align: left;
  margin-bottom: 4.8px;
  margin-bottom: 0.3rem;
  border-bottom: none;
  opacity: 0.9;
}

.fz-point__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 21.08px;
  font-size: 1.3175rem;
  font-weight: 900;
  line-height: 1.41;
  letter-spacing: 1.476px;
  letter-spacing: 0.09225rem;
  margin-bottom: 28px;
  margin-bottom: 1.75rem;
}

.fz-point__ttl em {
  color: #5fabcb;
}

.fz-point__ttl strong {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 25.08px;
  font-size: 1.5675rem;
  font-weight: 900;
  color: #001023;
  letter-spacing: 1.756px;
  letter-spacing: 0.10975rem;
}

.fz-point__cards {
  gap: 26px;
  gap: 1.625rem;
}

.fz-point-card {
  position: relative;
  display: flex;
  flex-direction: column;
}

.fz-point-card__header {
  display: flex;
  align-items: flex-start;
  margin-bottom: 14px;
  margin-bottom: 0.375rem;
}

.fz-point-card__num {
  font-family: "Heisei Kaku Gothic Std", "Noto Sans JP", sans-serif;
  font-family: "Zeitung Pro", sans-serif;
  font-size: 20.8px;
  font-size: 1.3rem;
  font-weight: 700;
  color: #5fabcb;
  letter-spacing: 1.792px;
  letter-spacing: 0.112rem;
  line-height: 1.69;
  margin-right: 5px;
  margin-right: 0.3125rem;
}

.fz-point-card__ttl {
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16.64px;
  font-size: 1.04rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 1.197px;
  letter-spacing: 0.0748125rem;
  line-height: 1.65;
  background-color: #5fabcb;
  padding: 0.4px 8px 2px;
  padding: 0.025rem 0.5rem 0.125rem;
}

.fz-point-card__ttl--1 {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  background-color: #fff;
  gap: 6.4px;
  gap: 0.4rem;
}

.fz-point-card__ttl-line {
  display: block;
  background-color: #5fabcb;
  padding: 0.4px 8px 2px;
  padding: 0.025rem 0.5rem 0.125rem;
}

.fz-point-card__img {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: 14px;
  margin-bottom: 0.875rem;
  align-self: flex-start;
}

.fz-point-card__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001023;
  line-height: 1.75;
  letter-spacing: 0.45px;
  letter-spacing: 0.028125rem;
}

/* figma-css:end nodeId=265-2677 */
/* figma-css:start nodeId=1-6392 */
/* ========================================
   セクション名: fz-top3
   Figma nodeId: 1-6392
   ======================================== */
.fz-top3 {
  padding-top: 7px;
  padding-top: 0.4375rem;
  padding-bottom: 80.4px;
  padding-bottom: 5.025rem;
  background-color: #ffffff;
}

.fz-top3__inner {
  width: 88%;
  max-width: 1280px;
  max-width: 980px;
  margin-inline: auto;
}

.fz-top3__lead {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 700;
  color: #001023;
  line-height: 1.3;
  letter-spacing: 1.08px;
  letter-spacing: 0.0675rem;
  margin-bottom: 10.4px;
  margin-bottom: 0.65rem;
  border-bottom: 1.2px solid #001023;
  border-bottom: 0.075rem solid #001023;
  display: inline-block;
  padding-bottom: 3.2px;
  padding-bottom: 0.2rem;
}

.fz-top3__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-size: 1.125rem;
  font-weight: 700;
  color: #001023;
  line-height: 1.3;
  letter-spacing: 1.08px;
  letter-spacing: 0.0675rem;
  margin-bottom: 20px;
  margin-bottom: 1.25rem;
}

.fz-top3__ttl strong {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 35px;
  font-size: 2.1875rem;
  font-weight: 900;
  color: #b7a61f;
  line-height: 1.3;
  letter-spacing: 2.8px;
  letter-spacing: 0.175rem;
}

.fz-top3__ttl span {
  font-size: 25px;
  font-size: 1.5625rem;
}

.fz-top3__check {
  position: relative;
  background: linear-gradient(300deg, #cfe4ec 0%, #d9eaf6 40%, #ffffff 120%);
  border-radius: 0px;
  border-radius: 0rem;
  padding: 28.4px 36px 28.4px 20px;
  padding: 1.775rem 2.25rem 1.775rem 1.25rem;
  margin-bottom: 15px;
  margin-bottom: 0.9375rem;
  border-radius: 10px;
  border-radius: 0.625rem;
}

.fz-top3__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fz-top3__item {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #00213a;
  line-height: 1.59;
  letter-spacing: 0.6px;
  letter-spacing: 0.0375rem;
  display: flex;
  align-items: center;
  gap: 8px;
  gap: 0.5rem;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
  white-space: nowrap;
}

.fz-top3__item:last-child {
  margin-bottom: 0;
}

.fz-top3__check-icon {
  width: 16px;
  width: 1rem;
  height: 16px;
  height: 1rem;
  flex-shrink: 0;
}

.fz-top3__check-img {
  position: absolute;
  right: -3%;
  top: 60.1%;
  transform: translateY(-50%);
  width: 171px;
  width: 10.6875rem;
  height: auto;
  mix-blend-mode: overlay;
  opacity: 0.7;
}

.fz-top3__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 500;
  color: #001023;
  line-height: 1.88;
  letter-spacing: 0.8px;
  letter-spacing: 0.05rem;
  margin-bottom: -13.2px;
  margin-bottom: -0.825rem;
  margin-inline: auto;
  width: 96%;
}

.fz-top3__cards {
  gap: 24px;
  gap: 1.5rem;
}

.fz-top3-card {
  position: relative;
}

.fz-top3-card__img {
  width: 100%;
  height: auto;
  display: block;
}

/* figma-css:end nodeId=1-6392 */
/* figma-css:start nodeId=1-6426 */
/* ========================================
   セクション名: Footer
   Figma nodeId: 1-6426
   ======================================== */
.fz-footer {
  background-color: #61aecf;
  padding-top: 30px;
  padding-top: 1.875rem;
  padding-bottom: 30px;
  padding-bottom: 1.875rem;
  padding: 54px 0;
  padding: 1.875rem 0;
}

.fz-footer__inner {
  width: 100%;
  text-align: center;
}

.fz-footer__copy {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  font-size: 0.8125rem;
  font-weight: 500;
  color: #ffffff;
  line-height: 1.4;
  letter-spacing: 1.43px;
  letter-spacing: 0.089375rem;
}

.fz-footer__copy small {
  font-size: inherit;
}

/* figma-css:end nodeId=1-6426 */
/* figma-css:start nodeId=1-6428 */
/* ========================================
   セクション名: FAQ
   Figma nodeId: 1-6428
   ======================================== */
.fz-faq {
  padding-top: 16px;
  padding-top: 1rem;
  padding-bottom: 44px;
  padding-bottom: 2.75rem;
  background-color: #f1f7fb;
}

.fz-faq__inner {
  width: 88%;
  max-width: 640px;
  margin-inline: auto;
}

.fz-faq__lead {
  color: #a2c2d7;
  /* border-bottom: 1.8px solid #0162c3;
    /* border-bottom: 0.1125rem solid #0162c3; */
  /* border-bottom: 1.8px solid #0162c3;
    /* border-bottom: 0.1125rem solid #0162c3; */
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
  opacity: 0.9;
}

.fz-faq__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 25.08px;
  font-size: 1.5675rem;
  font-weight: 900;
  color: #001023;
  line-height: 1.41;
  letter-spacing: 1.756px;
  letter-spacing: 0.10975rem;
  margin-bottom: 33px;
  margin-bottom: 2.0625rem;
}

.fz-faq__list {
  display: flex;
  flex-direction: column;
  gap: 20.6px;
  gap: 1.2875rem;
}

.fz-faq-item {
  padding-bottom: 23.2px;
  padding-bottom: 1.45rem;
  border-bottom: 1px solid rgba(0, 16, 35, 0.25);
  border-bottom: 0.0625rem solid rgba(0, 16, 35, 0.25);
}

.fz-faq-item:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.fz-faq-item__q {
  font-family: "Oswald", sans-serif;
  font-family: "Shippori Mincho";
  font-size: 22.77px;
  font-size: 1.423125rem;
  font-weight: 700;
  color: #a2c2d7;
  line-height: 1;
  margin-bottom: 10px;
  margin-bottom: 0.625rem;
  position: absolute;
}

.fz-faq-item__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 700;
  color: #001023;
  line-height: 1.41;
  letter-spacing: 1.19px;
  letter-spacing: 0.074375rem;
  margin-bottom: 12px;
  margin-bottom: 0.75rem;
  padding-left: 26px;
  padding-left: 1.625rem;
}

.fz-faq-item__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001023;
  line-height: 1.41;
  letter-spacing: 1.05px;
  letter-spacing: 0.065625rem;
  padding-left: 26px;
  padding-left: 1.625rem;
}

/* figma-css:end nodeId=1-6428 */
/* figma-css:start nodeId=265-2650 */
/* ========================================
   セクション名: Future（パターンB）
   Figma nodeId: 265-2650
   ======================================== */
.fz-future {
  padding-top: 49px;
  padding-top: 3.0625rem;
  padding-bottom: 40px;
  padding-bottom: 2.5rem;
  background-color: #fcfaeb;
  position: relative;
}

.fz-future__inner {
  width: 92%;
  max-width: 1120px;
  margin-inline: auto;
}

.fz-future__lead {
  font-family: "Oswald", sans-serif;
  font-family: "Jost", sans-serif;
  font-size: 42.2px;
  font-size: 2.6375rem;
  font-weight: 700;
  color: #ffffff;
  text-align: left;
  letter-spacing: 6.58px;
  letter-spacing: 0.41125rem;
  line-height: 1.3;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
  position: absolute;
  top: 0;
  left: 50%;
  opacity: 0.8;
  transform: translateY(-22%);
  transform: translate(-50%, -22%);
  white-space: nowrap;
}

.fz-future__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 29px;
  font-size: 1.8125rem;
  font-weight: 900;
  color: #001023;
  line-height: 1.5;
  letter-spacing: 2.08px;
  letter-spacing: 0.13rem;
  margin-bottom: 20px;
  margin-bottom: 1.25rem;
  text-align: center;
}

.fz-future__ttl strong {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 37px;
  font-size: 2.3125rem;
  font-weight: 900;
  color: #bfb545;
  letter-spacing: 2.75px;
  letter-spacing: 0.171875rem;
}

.fz-future__cards {
  gap: 33px;
  gap: 2.0625rem;
  margin-bottom: 30px;
  margin-bottom: 1.875rem;
}

.fz-future-card {
  position: relative;
}

.fz-future-card__box {
  border-radius: 18px;
  border-radius: 1.125rem;
  border: 1.4px solid #bfb545;
  border: 0.0875rem solid #bfb545;
  background: rgba(255, 255, 255, 0.56);
  padding: 25px 30px 30px;
  padding: 1.5625rem 1.875rem 1.875rem;
  text-align: center;
}

.fz-future-card__num {
  font-family: "Oswald", sans-serif;
  font-family: "Zeitung Pro", sans-serif;
  font-size: 25px;
  font-size: 1.5625rem;
  font-weight: 900;
  color: #bfb545;
  text-align: left;
  letter-spacing: 0.9px;
  letter-spacing: 0.05625rem;
  line-height: 1.3;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
  white-space: nowrap;
  opacity: 0.6;
}

.fz-future-card__ttl span {
  font-size: 19px;
  font-size: 1.1875rem;
}

.fz-future-card__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 25px;
  font-size: 1.5625rem;
  font-weight: 700;
  color: #001023;
  line-height: 1.3;
  letter-spacing: 3.1px;
  letter-spacing: 0.19375rem;
  margin-bottom: 12px;
  margin-bottom: 0.75rem;
}

.fz-future-card__header {
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 8px;
  gap: 0.4rem;
  margin-bottom: 2px;
  margin-bottom: 0.125rem;
}

.fz-future-card__badge {
  display: inline-block;
  margin-bottom: 12px;
  margin-bottom: 0.75rem;
}

.fz-future-card__badge-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16.8px;
  font-size: 1.05rem;
  font-weight: 700;
  color: #ffffff;
  text-align: center;
  letter-spacing: 1.34px;
  letter-spacing: 0.08375rem;
  line-height: 1.34;
  background-color: #bfb545;
  padding: 4px 12px;
  padding: 0.25rem 0.75rem;
  border-radius: 0;
}

.fz-future-card__heading {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 19px;
  font-size: 1.1875rem;
  font-weight: 900;
  color: #001023;
  text-align: center;
  letter-spacing: 1.14px;
  letter-spacing: 0.07125rem;
  line-height: 1.55;
  margin-bottom: 16px;
  margin-bottom: 1rem;
  border-bottom: #bfb545 1px solid;
  border-bottom: #bfb545 0.0625rem solid;
  padding-bottom: 17px;
  padding-bottom: 1.0625rem;
}

.fz-future-card__heading strong {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 24px;
  font-size: 1.5rem;
  font-weight: 900;
  color: #bfb545;
  letter-spacing: 1.44px;
  letter-spacing: 0.09rem;
  line-height: 1.35;
}

.fz-future-card__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 400;
  color: #001023;
  line-height: 1.65;
  letter-spacing: 0.85px;
  letter-spacing: 0.053125rem;
  text-align: left;
}

.fz-future-card__deco {
  position: absolute;
  width: 180px;
  width: 11.25rem;
  height: auto;
  opacity: 0.8;
  mix-blend-mode: color-burn;
}

.fz-future-card__deco--1 {
  bottom: -16%;
  right: 0;
  transform: translateX(24%);
}

.fz-future-card__deco--2 {
  top: 0;
  left: 0;
  transform: translateX(-49%);
}

.fz-future-card__deco--3 {
  bottom: -16%;
  right: 0;
  transform: translateX(24%);
}

.fz-future-card__license {
  background-color: #ffffff;
  border-radius: 3px;
  border-radius: 0.1875rem;
  padding: 16px;
  padding: 1rem;
  margin-top: 16px;
  margin-top: 1rem;
}

.fz-future-card__license-ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 700;
  color: #001023;
  text-align: center;
  letter-spacing: 1.28px;
  letter-spacing: 0.08rem;
  line-height: 1.35;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}

.fz-future-card__license-ttl:after {
  content: "";
  width: 57px;
  width: 3.5625rem;
  height: 1px;
  height: 0.0625rem;
  display: block;
  background-color: #222;
  margin: 9px auto 10px;
  margin: 0.5625rem auto 0.625rem;
}

.fz-future-card__license-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 300;
  color: #001023;
  line-height: 1.65;
  letter-spacing: 0.42px;
  letter-spacing: 0.02625rem;
  text-align: left;
}

.fz-future__industry {
  background-color: #ffffff;
  border-radius: 30px;
  border-radius: 1.875rem;
  padding: 24px 26.4px;
  padding: 1.5rem 1.65rem;
  text-align: center;
  width: 96.7%;
  margin-inline: auto;
}

.fz-future__industry-ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 900;
  color: #bfb545;
  text-align: center;
  letter-spacing: 1.36px;
  letter-spacing: 0.085rem;
  line-height: 1.35;
  margin-bottom: 12px;
  margin-bottom: 0.75rem;
}

.fz-future__industry-ttl:after {
  content: "";
  width: 57px;
  width: 3.5625rem;
  height: 1px;
  height: 0.0625rem;
  display: block;
  background-color: #bfb545;
  margin: 12px auto 10px;
  margin: 0.75rem auto 0.625rem;
}

.fz-future__industry-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001023;
  line-height: 1.59;
  letter-spacing: 0.45px;
  letter-spacing: 0.028125rem;
  text-align: left;
}

/* figma-css:end nodeId=265-2650 */
/* figma-css:start nodeId=265-2761 */
/* ========================================
   セクション名: Flow (パターンB)
   ======================================== */
.fz-flow {
  position: relative;
  padding-top: 38px;
  padding-top: 2.375rem;
  padding-bottom: 40px;
  padding-bottom: 2.5rem;
  background-color: #f1f7fb;
  overflow: hidden;
}

.fz-flow__inner {
  position: relative;
  width: 88.1%;
  max-width: 660px;
  margin-inline: auto;
}

.fz-flow__bg {
  position: absolute;
  top: -7px;
  top: -0.4375rem;
  right: 0;
  transform: translateX(24%);
  width: 180px;
  width: 11.25rem;
  height: auto;
  object-fit: cover;
  z-index: 0;
  mix-blend-mode: color-burn;
  opacity: 1;
}

.fz-flow__lead {
  position: relative;
  z-index: 1;
  color: #a2c2d7;
  text-align: left;
  margin-bottom: 4px;
  margin-bottom: 0.25rem;
  border-bottom: none;
  opacity: 0.9;
}

.fz-flow__ttl {
  position: relative;
  z-index: 1;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 25.08px;
  font-size: 1.5675rem;
  font-weight: 900;
  color: #001023;
  line-height: 1.41;
  letter-spacing: 1.756px;
  letter-spacing: 0.10975rem;
  margin-bottom: 31px;
  margin-bottom: 1.9375rem;
}

.fz-flow__steps {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
}

.fz-flow-step {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  gap: 1rem;
  background-color: #ffffff;
  border-radius: 5px;
  border-radius: 0.3125rem;
  padding: 22.4px 22px 19.2px;
  padding: 1.4rem 1.375rem 1.2rem;
  width: 100%;
}

.fz-flow-step__icon {
  width: 75.53px;
  width: 4.720625rem;
  height: auto;
  flex-shrink: 0;
}

.fz-flow-step__body {
  flex: 1;
  min-width: 0;
}

.fz-flow-step__num {
  font-family: "Shippori Mincho", serif;
  font-size: 13px;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #a2c2d7;
  text-align: left;
  letter-spacing: 1.43px;
  letter-spacing: 0.089375rem;
  line-height: 1.4;
  margin-bottom: 0px;
  margin-bottom: 0rem;
}

.fz-flow-step__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 700;
  color: #001023;
  line-height: 1.44;
  letter-spacing: 1.53px;
  letter-spacing: 0.095625rem;
  margin-bottom: 3px;
  margin-bottom: 0.1875rem;
}

.fz-flow-step__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 300;
  color: #001023;
  line-height: 1.44;
  letter-spacing: 0.84px;
  letter-spacing: 0.0525rem;
}

.fz-flow__arrow {
  width: 34.8px;
  width: 2.175rem;
  height: auto;
  margin: 8px 0;
  margin: 0.5rem 0;
}

.fz-flow__note {
  position: relative;
  z-index: 1;
  margin-top: 20px;
  margin-top: 1.25rem;
  border: 1px solid #003b77;
  border: 0.0625rem solid #003b77;
  padding: 20px 20px;
  padding: 1.25rem 0;
  width: 95%;
  margin-inline: auto;
}

.fz-flow__note-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #003b77;
  text-align: center;
  line-height: 1.44;
  letter-spacing: 0.9px;
  letter-spacing: 0.05625rem;
}

/* figma-css:end nodeId=265-2761 */
/* figma-css:start nodeId=1-6409 */
/* ========================================
   セクション名: Message
   Figma nodeId: 1-6409
   ======================================== */
.fz-message {
  position: relative;
  padding-top: 65px;
  padding-top: 4.0625rem;
  padding-bottom: 25.4px;
  padding-bottom: 1.5875rem;
  background: linear-gradient(
    131deg,
    #f0f6fb 6.3%,
    #dbecf3 33.1%,
    #c1dbe6 83.9%
  );
  overflow: hidden;
  position: relative;
}

.fz-message::before {
  content: none;
}

.fz-message__inner {
  width: 92%;
  max-width: 800px;
  margin-inline: auto;
}

.fz-message__lead {
  font-family: "Shippori Mincho", serif;
  font-size: 29px;
  font-size: 1.8125rem;
  font-weight: 700;
  color: #94b0bc;
  text-align: center;
  letter-spacing: 3.48px;
  letter-spacing: 0.2175rem;
  line-height: 1.4;
  margin-bottom: 0;
  position: absolute;
  top: 15px;
  top: 0.9375rem;
  left: 50%;
  transform: translateX(-50%);
  white-space: nowrap;
  opacity: 0.54;
}

.fz-message__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17.1px;
  font-size: 1.06875rem;
  font-weight: 500;
  color: #00213a;
  text-align: center;
  letter-spacing: 1.37px;
  letter-spacing: 0.085625rem;
  line-height: 1.3;
  margin-bottom: 5px;
  margin-bottom: 0.3125rem;
  position: relative;
}

.fz-message__ttl span {
  border-bottom: 1px solid #00213a;
  border-bottom: 0.0625rem solid #00213a;
  padding-bottom: 4px;
  padding-bottom: 0.25rem;
}

.fz-message__ttl em {
  display: block;
  font-style: normal;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30.34px;
  font-size: 1.89625rem;
  font-weight: 900;
  color: #00213a;
  letter-spacing: 0.91px;
  letter-spacing: 0.056875rem;
  line-height: 1.3;
  margin-top: 5px;
  margin-top: 0.3125rem;
  padding-top: 8px;
  padding-top: 0.5rem;
}

.fz-message__img {
  position: relative;
  width: 100%;
  height: auto;
  /* mix-blend-mode: color-burn; */
}

.fz-message__box {
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
  border-radius: 0.625rem;
  padding: 34.8px 15.4px 22.6px;
  padding: 2.175rem 0.9625rem 1.4125rem;
  box-shadow: 0 0 33.1px rgba(75, 75, 75, 0.17);
  box-shadow: 0 0 2.06875rem rgba(75, 75, 75, 0.17);
  margin-top: -1.3rem;
}

.fz-message__quote {
  /* font-family: "Akkurat", sans-serif; */
  font-size: 50px;
  font-size: 3.125rem;
  font-weight: 400;
  color: rgba(51, 40, 0, 0.21);
  letter-spacing: 3px;
  letter-spacing: 0.1875rem;
  line-height: 1;
  position: absolute;
}

.fz-message__quote:first-of-type {
  top: 11.6px;
  top: 0.725rem;
  left: 13.2px;
  left: 0.825rem;
}

.fz-message__quote:last-of-type {
  bottom: 13.2px;
  bottom: 0.825rem;
  right: 13.2px;
  right: 0.825rem;
  transform: rotate(180deg);
}

.fz-message__box-ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16.8px;
  font-size: 1.05rem;
  font-weight: 900;
  color: #5a90a6;
  letter-spacing: 1.36px;
  letter-spacing: 0.085rem;
  line-height: 1.44;
  margin-bottom: 17px;
  margin-bottom: 1.0625rem;
}

.fz-message__box-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 350;
  color: #001023;
  letter-spacing: 0.75px;
  letter-spacing: 0.046875rem;
  line-height: 1.5;
  margin-bottom: 13px;
  margin-bottom: 0.8125rem;
}

.fz-message__box-txt:last-of-type {
  margin-bottom: 0;
}

.fz-message__btn {
  display: flex;
  width: 100%;
  margin-top: 25px;
  margin-top: 1.5625rem;
  position: relative;
  justify-content: center;
}

.fz-message__btn-img {
  width: 100%;
  margin-inline: auto;
  height: auto;
  display: block;
  max-inline-size: initial;
}

/* figma-css:end nodeId=1-6409 */
/* figma-css:start nodeId=1-6410 */
/* ========================================
   セクション名: Support
   Figma nodeId: 1-6410
   ======================================== */
.fz-support {
  /* padding-top: 20px;
    /* padding-top: 1.25rem; */
  /* padding-top: 20px;
    /* padding-top: 1.25rem; */
  padding-bottom: 21px;
  padding-bottom: 1.3125rem;
  background: #f9f8ed;
}

.fz-support__inner {
  width: 87.9%;
  max-width: 960px;
  margin-inline: auto;
}

.fz-support__lead {
  color: #bfb545;
  margin-bottom: 7px;
  margin-bottom: 0.4375rem;
  /* border-bottom: 1.8px solid #bfb545;
    /* border-bottom: 0.1125rem solid #bfb545; */
  /* border-bottom: 1.8px solid #bfb545;
    /* border-bottom: 0.1125rem solid #bfb545; */
  opacity: 0.54;
}

.fz-support__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 26.08px;
  font-size: 1.63rem;
  font-weight: 900;
  color: #200600;
  letter-spacing: 1.83px;
  letter-spacing: 0.114375rem;
  line-height: 1.41;
  margin-bottom: 21px;
  margin-bottom: 1.3125rem;
}

.fz-support__ttl em {
  font-style: normal;
  color: #beb440;
}

.fz-support__img {
  width: 100%;
  height: auto;
  display: block;
  margin-bottom: 15px;
  margin-bottom: 0.9375rem;
}

.fz-support__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 350;
  color: #200600;
  letter-spacing: 0.96px;
  letter-spacing: 0.06rem;
  line-height: 1.54;
  margin-bottom: 13px;
  margin-bottom: 0.8125rem;
}

.fz-support__check {
  background-color: rgba(255, 255, 255, 0.8);
  padding: 12px 14px;
  padding: 0.75rem 0.875rem;
  margin-bottom: 13px;
  margin-bottom: 0.8125rem;
}

.fz-support__list {
  list-style: none;
  padding: 0;
  margin: 0;
}

.fz-support__item {
  display: flex;
  align-items: flex-start;
  gap: 6px;
  gap: 0.375rem;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #200600;
  letter-spacing: 0px;
  letter-spacing: 0rem;
  line-height: 2.19;
}

.fz-support__item em {
  font-style: normal;
  color: #bdb33d;
}

.fz-support__check-icon {
  width: 14.8px;
  width: 0.925rem;
  height: auto;
  flex-shrink: 0;
  margin-top: 9.6px;
  margin-top: 0.6rem;
}

/* figma-css:end nodeId=1-6410 */
/* figma-css:start nodeId=1-6425 */
/* ========================================
   セクション名: CTA
   Figma nodeId: 1-6425
   ======================================== */
.fz-cta {
  position: relative;
  padding-top: 119.8px;
  padding-top: 6.3875rem;
  padding-bottom: 40.8px;
  padding-bottom: 2.55rem;
  background-color: #ffffff;
  overflow: hidden;
}

.fz-cta__lead {
  font-family: "Oswald", sans-serif;
  font-size: 50px;
  font-size: 3.125rem;
  font-weight: 700;
  color: #f1f7fb;
  letter-spacing: 5.5px;
  letter-spacing: 0.34375rem;
  line-height: 1.3;
  position: absolute;
  top: -7px;
  top: -0.4375rem;
  left: 50%;
  transform: translate(-50%, -14%);
  z-index: 0;
  white-space: nowrap;
}

.fz-cta__inner {
  position: relative;
  width: 90%;
  max-width: 1100px;
  margin-inline: auto;
  z-index: 1;
}

.fz-cta__catch {
  display: none;
}

.fz-cta__catch-img {
  display: block;
  width: 187px;
  width: 17.6875rem;
  height: auto;
  margin-bottom: 12px;
  margin-bottom: 0.75rem;
  position: absolute;
  z-index: 1;
  top: -7.4%;
  left: -1%;
}

.fz-cta__catch span {
  border-bottom: 1px solid #004589;
  border-bottom: 0.0625rem solid #004589;
  padding-bottom: 2px;
  padding-bottom: 0.125rem;
}

.fz-cta__hero {
  position: relative;
  margin-bottom: 43px;
  margin-bottom: 2.6875rem;
}

.fz-cta__img-wrap {
  position: relative;
  width: 97%;
  margin: 0 auto;
  overflow: hidden;
}

.fz-cta__img {
  width: 100%;
  height: auto;
  display: block;
}

.fz-cta__labels {
  position: absolute;
  bottom: -30px;
  bottom: -2.075rem;
  left: -0.3rem;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 7.6px;
  gap: 0.475rem;
}

.fz-cta__label {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18.55px;
  font-size: 1.159375rem;
  font-weight: 900;
  letter-spacing: 1.8px;
  letter-spacing: 0.1125rem;
  line-height: 1.3;
  padding: 7px 10px;
  padding: 0.4375rem 0.625rem;
  color: #ffffff;
  background: #61aecf;
}

.fz-cta__label b {
  color: #e7cb3d;
  font-weight: 900;
}

.fz-cta__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 22.08px;
  font-size: 1.38rem;
  font-weight: 900;
  color: #61aecf;
  letter-spacing: 0.42px;
  letter-spacing: 0.02625rem;
  line-height: 1.41;
  text-align: left;
  margin-bottom: 25px;
  margin-bottom: 1.1625rem;
  transform: skewX(-0.47deg);
  white-space: nowrap;
}

.fz-cta__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #000f1b;
  letter-spacing: 0;
  line-height: 2.02;
  text-align: center;
  margin-bottom: 24px;
  margin-bottom: 1.5rem;
  position: relative;
  z-index: 2;
}

.fz-cta__btn {
  display: flex;
  justify-content: center;
  position: relative;
  width: 364px;
  width: 22.75rem;
  max-width: 100%;
  margin: 0 auto;
  text-decoration: none;
  z-index: 2;
}

.fz-cta__btn-img {
  width: 100%;
  height: auto;
  display: block;
}

.fz-cta__quocard {
  /* display: none; */
  position: absolute;
  bottom: 104.4px;
  bottom: 6.925rem;
  right: 17.6px;
  right: 1.1rem;
  width: 138.8px;
  width: 8.675rem;
  height: auto;
  z-index: 0;
  transform: rotate(-1.3deg) translateX(32%);
}

.fz-cta__btn-badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 242px;
  width: 15.125rem;
  height: 32px;
  height: 2rem;
  margin: 0 auto;
  border: 1.37px solid #101010;
  border: 0.085625rem solid #101010;
  border-radius: 4px;
  border-radius: 0.25rem;
  background-color: #ffffff;
  position: relative;
  z-index: 1;
  transform: translateY(50%);
}

.fz-cta__btn-badge-label {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: -24px;
  left: -1.5rem;
  top: 0;
  height: 100%;
  width: 78px;
  width: 4.875rem;
  background: linear-gradient(135deg, #d44c1b 0%, #e94a26 100%);
  border-radius: 4px 0 0 4px;
  border-radius: 0.25rem 0 0 0.25rem;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11.17px;
  font-size: 0.698125rem;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: 0.56px;
  letter-spacing: 0.035rem;
  line-height: 1.23;
  text-align: center;
}

.fz-cta__btn-badge-value {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12.03px;
  font-size: 0.751875rem;
  font-weight: 900;
  color: #1f222c;
  line-height: 1.23;
}

.fz-cta__btn-badge-value em {
  font-style: normal;
  color: #e94a26;
}

.fz-cta__btn-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 80px;
  height: 5rem;
  background-color: #d44c1b;
  border-radius: 7px;
  border-radius: 0.4375rem;
  box-shadow: 0px 0px 13px rgba(0, 0, 0, 0.14);
  box-shadow: 0rem 0rem 0.8125rem rgba(0, 0, 0, 0.14);
  padding-top: 10px;
  padding-top: 0.625rem;
}

.fz-cta__btn-sub {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11.66px;
  font-size: 0.72875rem;
  font-weight: 500;
  color: #ffffff;
  letter-spacing: 0.58px;
  letter-spacing: 0.03625rem;
  line-height: 1.2;
  text-align: center;
  margin-bottom: 4px;
  margin-bottom: 0.25rem;
}

.fz-cta__btn-main {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 21.75px;
  font-size: 1.359375rem;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: 2.83px;
  letter-spacing: 0.176875rem;
  line-height: 1.4;
  text-align: center;
}

.fz-cta__btn-quocard {
  position: absolute;
  right: -10px;
  right: -0.625rem;
  top: 50%;
  transform: translateY(-40%);
  width: 70px;
  width: 4.375rem;
  height: auto;
  z-index: 2;
}

/* figma-css:end nodeId=1-6425 */
@media only screen and (min-width: 768px) {
  body {
  }

  .fz {
  }

  /* ========================================
   共通クラス
   ======================================== */
  /* セクションリード共通スタイル */
  .fz-lead {
    font-size: 26px;
    font-size: 1.625rem;
    font-weight: 400;
  }

  /* カードリスト共通スタイル */
  .fz-cards {
  }

  /* 本文テキスト共通スタイル */
  .fz-txt {
  }

  /* セクション見出し共通スタイル */
  .fz-ttl {
  }

  /* ボタン共通スタイル */
  .fz-btn {
    width: 520px;
    width: 32.5rem;
    /* display: block; */
    margin-inline: auto;
    max-width: 38.2vw;
    min-width: 430px;
  }

  /* figma-css:start nodeId=1-6363 */
  /* ========================================
   セクション名: Header
   Figma nodeId: 1-6363
   ======================================== */
  .fz-header {
    height: auto;
  }

  .fz-header__inner {
    padding-left: 25px;
    padding-left: 1.5625rem;
  }

  .fz-header__logo-img {
    width: 160px;
    width: 10rem;
    padding: 12.8px 0;
    padding: 0.8rem 0;
    margin-right: 19.2px;
    margin-right: 1.2rem;
  }

  .fz-header__txt {
    font-size: 14.4px;
    font-size: 0.9rem;
  }

  /* figma-css:end nodeId=1-6363 */
  /* figma-css:start nodeId=1-6369 */
  /* ========================================
   セクション名: Hero
   Figma nodeId: 1-6369
   ======================================== */
  .fz-hero {
  }

  .fz-hero__inner {
  }

  .fz-hero__img {
    min-width: 1360px;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }

  .fz-hero__btn {
    max-width: 470px;
    bottom: -4.25rem;
    transform: translateX(-50%);
    width: 25%;
  }

  .fz-hero__btn-img {
  }

  /* figma-css:end nodeId=1-6369 */
  /* figma-css:start nodeId=265-2635 */
  /* ========================================
   セクション名: 企業目線サポート (PC)
   Figma nodeId: 265-2635
   ======================================== */
  .fz-corporate__inner {
    /* max-width: 1200px;
        /* max-width: 75rem; */
    /* max-width: 1200px;
        /* max-width: 75rem; */
    margin: 0 auto;
  }

  /* ----------------------------------------
   ヘッダーエリア (PC)
   ---------------------------------------- */
  .fz-corporate__header {
    padding-top: 50px;
    padding-top: 3.125rem;
    /* padding-bottom: 40px;
        /* padding-bottom: 2.5rem; */
    /* padding-bottom: 40px;
        /* padding-bottom: 2.5rem; */
  }

  .fz-corporate__header-bg {
    left: 424px;
    left: 26.5rem;
    /* right: 25%; */
    top: 90.4px;
    top: 5.65rem;
    width: 434.8px;
    width: 27.175rem;
  }

  .fz-corporate__header-content {
    width: 21.5%;
    min-width: 365px;
  }

  .fz-corporate__lead {
    font-size: 22px;
    font-size: 1.375rem;
    letter-spacing: 1.33px;
    letter-spacing: 0.083125rem;
  }

  .fz-corporate__border-img {
    /* 親(.fz-corporate__header-content)と同じ幅で .fz-corporate__lead と揃う */
    width: 100%;
    height: auto;
  }

  .fz-corporate__lead-num {
    font-size: 50px;
    font-size: 3.125rem;
    letter-spacing: 1.01px;
    letter-spacing: 0.063125rem;
  }

  .fz-corporate__lead-unit {
    font-size: 33px;
    font-size: 2.0625rem;
    letter-spacing: 1.96px;
    letter-spacing: 0.1225rem;
  }

  .fz-corporate__ttl {
    font-size: 31px;
    font-size: 1.9375rem;
    letter-spacing: 1.91px;
    letter-spacing: 0.119375rem;
    margin-bottom: 20px;
    margin-bottom: 1.25rem;
    line-height: 1.65;
  }

  .fz-corporate__ttl-box {
    font-size: 40px;
    font-size: 2.5rem;
    letter-spacing: 2.44px;
    letter-spacing: 0.1525rem;
    border: 1.48px solid #00213a;
    border: 0.0925rem solid #00213a;
    padding: 2.8px 12px;
    padding: 0.175rem 0.75rem;
  }

  .fz-corporate__ttl-particle {
    font-size: 32px;
    font-size: 2rem;
  }

  .fz-corporate__ttl-main {
    font-size: 47px;
    font-size: 2.9375rem;
    letter-spacing: 0.93px;
    letter-spacing: 0.058125rem;
  }

  .fz-corporate__hero-photo {
    max-width: 700px;
    margin: 0 auto;
    width: 29.6%;
  }

  /* ----------------------------------------
   悩みエリア (PC)
   ---------------------------------------- */
  .fz-corporate__worry {
    /* padding-bottom: 10px;
        /* padding-bottom: 0.625rem; */
    /* padding-bottom: 10px;
        /* padding-bottom: 0.625rem; */
  }
  .fz-corporate__content {
    padding-bottom: 4.1rem;
  }

  .fz-corporate__worry-bg {
    top: -24.8px;
    top: 0.45rem;
    height: calc(100% + 1.55rem);
  }

  .fz-corporate__worry-items {
    width: 72%;
    max-width: 884px;
    /* padding-top: 20px;
        /* padding-top: 1.25rem; */
    /* padding-top: 20px;
        /* padding-top: 1.25rem; */
    /* padding-bottom: 40px;
        /* padding-bottom: 2.5rem; */
    /* padding-bottom: 40px;
        /* padding-bottom: 2.5rem; */
  }

  /* ----------------------------------------
   プロセス導入エリア (PC)
   ---------------------------------------- */
  .fz-corporate__process-intro {
    padding-top: 0;
    margin-bottom: 21.2px;
    margin-bottom: 1.325rem;
  }

  .fz-corporate__process-lead {
    font-size: 23px;
    font-size: 1.4375rem;
    letter-spacing: 2.76px;
    letter-spacing: 0.1725rem;
    display: inline-block;
  }

  .fz-corporate__process-ttl {
    font-size: 23px;
    font-size: 1.4375rem;
    letter-spacing: 1.16px;
    letter-spacing: 0.0725rem;
    display: inline-block;
  }

  .fz-corporate__process-ttl em {
    font-size: 38px;
    font-size: 2.375rem;
    letter-spacing: 1.91px;
    letter-spacing: 0.119375rem;
  }

  /* ----------------------------------------
   ステップ共通 (PC)
   ---------------------------------------- */
  .fz-corporate__steps {
    max-width: 822px;
    margin: 0 auto;
    /* width: 43%; */
  }

  .fz-corporate__step {
    align-items: center;
    margin-bottom: 0.8px;
    margin-bottom: 0.05rem;
    gap: 40px;
    gap: 2.5rem;
  }
  .fz-corporate__step--odd {
    gap: 0;
  }
  .fz-corporate__step--even {
    gap: 0px;
    gap: 0rem;
  }

  /* 奇数ステップ (PC) */
  .fz-corporate__step--odd .fz-corporate__step-photo {
    width: 33.2%;
    margin-left: 0;
    margin-top: 30.4px;
    margin-top: 1.9rem;
  }

  .fz-corporate__step--odd .fz-corporate__step-body {
    padding-left: 20px;
    padding-left: 1.25rem;
    flex: none;
  }

  /* 偶数ステップ (PC) */
  .fz-corporate__step--even .fz-corporate__step-photo {
    width: 33.2%;
    margin-right: 0;
  }

  .fz-corporate__step--even .fz-corporate__step-body {
    padding-left: 0;
    padding-right: 20px;
    padding-right: 1.25rem;
    flex: none;
  }

  .fz-corporate__step-num {
    font-size: 50px;
    font-size: 3.125rem;
    letter-spacing: 2.51px;
    letter-spacing: 0.156875rem;
    margin-bottom: 8px;
    margin-bottom: 0.5rem;
  }

  .fz-corporate__step-ttl {
    font-size: 24px;
    font-size: 1.5rem;
    letter-spacing: 1.42px;
    letter-spacing: 0.08875rem;
    margin-bottom: 16px;
    margin-bottom: 1rem;
  }

  .fz-corporate__step-txt {
    font-size: 16.5px;
    font-size: 1.03125rem;
    letter-spacing: 0.99px;
    letter-spacing: 0.061875rem;
    max-width: 402px;
  }

  /* figma-css:end nodeId=265-2635 */
  /* figma-css:start nodeId=265-2643 */
  .fz-voice {
    padding-top: 44px;
    padding-top: 2.75rem;
    padding-bottom: 60px;
    padding-bottom: 3.75rem;
  }

  .fz-voice__inner {
  }

  .fz-voice__header {
    margin-bottom: 30px;
    margin-bottom: 1.875rem;
  }

  .fz-voice__lead {
    font-size: 22.1px;
    font-size: 1.38125rem;
    letter-spacing: 3.536px;
    letter-spacing: 0.221rem;
  }

  .fz-voice__ttl {
    font-size: 35.75px;
    font-size: 2.234375rem;
    letter-spacing: 2.502496px;
    letter-spacing: 0.156406rem;
  }

  .fz-voice__deco {
    top: -28.6px;
    top: -1.7875rem;
    right: calc(50% - 276px);
    width: 236px;
    width: 14.75rem;
  }

  .fz-voice__cards {
    flex-direction: row;
    justify-content: center;
    gap: 30px;
    gap: 1.875rem;
  }

  .fz-voice__card {
    width: 398px;
    width: 24.875rem;
    flex-shrink: 0;
  }

  .fz-voice__card-txt {
    font-size: 14px;
    font-size: 0.875rem;
  }

  .fz-voice__btn {
    margin-top: 40px;
    margin-top: 2.5rem;
  }

  .fz-voice__btn-img {
    max-width: 499.6px;
    width: 85.6%;
  }

  /* figma-css:end nodeId=265-2643 */
  /* figma-css:start nodeId=265-3471 */
  /* ========================================
   セクション名: Merit (PC: min-width 768px)
   Figma nodeId: 265:3471
   ======================================== */
  .fz-merit {
    padding-top: 40px;
    padding-top: 2.5rem;
  }

  .fz-merit__inner {
  }

  .fz-merit__lead {
    /* font-size: 24px;
    /* font-size: 1.5rem; */
  }

  .fz-merit__ttl {
    font-size: 27.7px;
    font-size: 1.73125rem;
    letter-spacing: 1.939008px;
    letter-spacing: 0.121188rem;
  }

  .fz-merit__ttl em {
  }

  .fz-merit__cards {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
  }

  .fz-merit-card {
    width: 31.9%;
    display: flex;
    flex-direction: column;
  }

  .fz-merit-card__box {
    flex: 1;
    min-width: 0;
    padding: 16.4px 25px 28px;
    padding: 1.025rem 1.5625rem 1.75rem;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .fz-merit-card__num {
    margin-bottom: 1.6px;
    margin-bottom: 0.1rem;
  }

  .fz-merit-card__ttl {
    white-space: nowrap;
    margin-bottom: 12.8px;
    margin-bottom: 0.8rem;
    white-space: nowrap;
  }

  .fz-merit-card__ttl span {
  }

  .fz-merit-card__txt {
  }

  /* figma-css:end nodeId=265-3471 */
  /* figma-css:start nodeId=265-3474 */
  /* ========================================
   セクション名: Persona (PC)
   Figma nodeId: 265:3474
   ビューポート: 1680px
   ======================================== */
  /* ========================================
   セクション名: Persona (PC)
   Figma nodeId: 265:3474
   ビューポート: 105rem
   ======================================== */
  .fz-persona {
    padding-top: 64px;
    padding-top: 4rem;
    padding-bottom: 42.6px;
    padding-bottom: 2.6625rem;
  }

  .fz-persona__inner {
  }

  .fz-persona__ttl {
    text-align: center;
    zoom: 1.3;
    margin-bottom: 40px;
    margin-bottom: 2.5rem;
  }

  .fz-persona__ttl em {
  }

  .fz-persona__ttl strong {
  }

  .fz-persona__cards {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    margin-bottom: 38px;
    margin-bottom: 2.375rem;
  }

  .fz-persona-card {
    display: flex;
    flex-direction: column;
    width: 30.4%;
    gap: 0;
  }

  .fz-persona-card:nth-child(even) {
    flex-direction: column;
  }

  .fz-persona-card__img {
    height: 130px;
    height: 8.125rem;
    object-fit: cover;
    object-position: top;
    width: 120.2px;
    width: 7.5125rem;
  }

  .fz-persona-card__img--2 {
    width: 133px;
    width: 8.3125rem;
  }

  .fz-persona-card__img--3 {
    width: 136.2px;
    width: 8.5125rem;
  }

  .fz-persona-card__body {
    text-align: center;
  }

  .fz-persona-card__job {
    zoom: 1.2;
    margin-bottom: 18px;
    margin-bottom: 1.125rem;
  }

  .fz-persona-card__txt {
    text-align: left;
    font-size: 17px;
    font-size: 1.0625rem;
  }

  .fz-persona__btn {
    width: 408px;
    width: 28.4rem;
  }

  .fz-persona__btn-img {
  }

  /* figma-css:end nodeId=265-3474 */
  /* figma-css:start nodeId=265-3565 */
  /* ========================================
   セクション名: Reason (PC)
   Figma nodeId: 265:3565
   ビューポート: 1680px
   ======================================== */
  /* ========================================
   セクション名: Reason (PC)
   Figma nodeId: 265:3565
   ビューポート: 105rem
   ======================================== */
  .fz-reason {
    padding-bottom: 30px;
    padding-bottom: 1.875rem;
    padding-top: 83px;
    padding-top: 5.1875rem;
  }

  .fz-reason__inner {
  }

  .fz-reason__lead {
  }

  .fz-reason__ttl {
    zoom: 1.4;
    /* max-width: 560px;
        /* max-width: 35rem; */
    /* max-width: 560px;
        /* max-width: 35rem; */
    margin-inline: auto;
    margin-bottom: 30px;
    margin-bottom: 1.875rem;
    font-size: 18px;
    font-size: 1.125rem;
  }

  .fz-reason__ttl strong {
    /* font-size: 31px;
    /* font-size: 1.9375rem; */
  }

  .fz-reason__ttl em {
  }
  .fz-reason__ttl span {
    font-size: 21px;
    font-size: 1.3125rem;
  }

  .fz-reason__cards {
    gap: 0;
  }

  .fz-reason-card {
    padding: 24.8px 70.4px 88px;
    padding: 1.55rem 4.4rem 3.1rem;
    margin-bottom: 22.4px;
    margin-bottom: 1.4rem;
  }

  .fz-reason-card__num {
    font-size: 26px;
    font-size: 1.625rem;
  }

  .fz-reason-card__catch {
    font-size: 18.7px;
    font-size: 1.16875rem;
    padding: 6px 40px;
    padding: 0.375rem 2.5rem;
    border-radius: 1px;
    border-radius: 0.0625rem;
  }

  .fz-reason-card__ttl {
    font-size: 26.8px;
    font-size: 1.675rem;
    margin-bottom: 33px;
    margin-bottom: 2.0625rem;
  }

  .fz-reason-card__body {
    display: flex;
    align-items: flex-start;
    gap: 32.2px;
    gap: 2.0125rem;
  }

  .fz-reason-card__img {
    width: 44.1%;
    border-radius: 0;
  }

  .fz-reason-card__txt {
  }

  /* figma-css:end nodeId=265-3565 */
  /* figma-css:start nodeId=265-3574 */
  /* ========================================
   セクション名: Point (パターンB) PC
   ======================================== */
  .fz-point {
    padding-top: 60.4px;
    padding-top: 3.775rem;
  }

  .fz-point__inner {
  }

  .fz-point__lead {
  }

  .fz-point__ttl {
    font-size: 25.3px;
    font-size: 1.58125rem;
    letter-spacing: 1.771px;
    letter-spacing: 0.1106875rem;
    margin-bottom: 47px;
    margin-bottom: 2.9375rem;
  }

  .fz-point__ttl em {
  }

  .fz-point__ttl strong {
    font-size: 33.1px;
    font-size: 2.06875rem;
    letter-spacing: 2.979px;
    letter-spacing: 0.1861875rem;
  }

  .fz-point__cards {
    flex-direction: row;
    justify-content: space-between;
  }

  .fz-point-card {
    width: 31.2%;
    display: flex;
    flex-direction: column;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .fz-point-card__header {
    display: block;
    text-align: center;
  }
  .fz-point-card__header--1 {
  }
  .fz-point-card__header--2 {
    margin-bottom: 2.675rem;
  }
  .fz-point-card__header--3 {
    margin-bottom: 2.675rem;
  }

  .fz-point-card__num {
    font-weight: 500;
    margin-bottom: 9px;
    margin-bottom: 0.5625rem;
    margin-bottom: 0;
  }

  .fz-point-card__ttl {
    font-size: 15px;
    font-size: 0.9375rem;
    white-space: nowrap;
  }
  .fz-point-card__ttl--1 {
    align-items: center;
  }

  .fz-point-card__img {
    align-self: flex-start;
  }

  .fz-point-card__txt {
  }

  /* figma-css:end nodeId=265-3574 */
  /* figma-css:start nodeId=1-6392 */
  /* ========================================
   セクション名: fz-top3
   Figma nodeId: 1-6392
   ======================================== */
  .fz-top3 {
  }

  .fz-top3__inner {
  }

  .fz-top3__lead {
    font-size: 18px;
    font-size: 1.125rem;
    margin-bottom: 0.35rem;
  }

  .fz-top3__ttl {
    font-size: 25px;
    font-size: 1.5625rem;
    margin-bottom: 32px;
    margin-bottom: 2rem;
  }

  .fz-top3__ttl strong {
    font-size: 35px;
    font-size: 2.1875rem;
  }

  .fz-top3__check {
    margin-right: 26px;
    margin-right: 1.625rem;
    zoom: 1.1;
    margin-bottom: 0;
  }

  .fz-top3__check-wrap {
    display: flex;
    align-items: center;
    margin-bottom: 58px;
    margin-bottom: 3.625rem;
  }

  .fz-top3__check-wrap .fz-top3__check,
  .fz-top3__check-wrap .fz-top3__txt {
    align-self: center;
  }

  .fz-top3__list {
  }

  .fz-top3__item {
  }

  .fz-top3__item:last-child {
  }

  .fz-top3__check-icon {
  }

  .fz-top3__check-img {
  }

  .fz-top3__txt {
    /* margin-top: 16px; */
    /* margin-top: 1rem; */
    margin-bottom: 0;
  }

  .fz-top3__cards {
    width: 88vw;
    max-width: 1254px;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: row;
    gap: 5%;
  }

  @media only screen and (max-width: 1０00px) {
    .fz-top3__cards {
      width: 90%;
      max-width: 500px;
      position: relative;
      display: flex;
      flex-direction: column;
      gap: 3.4%;
    }
  }

  .fz-top3-card {
  }

  .fz-top3-card__img {
  }

  /* figma-css:end nodeId=1-6392 */
  /* figma-css:start nodeId=1-6426 */
  /* ========================================
   セクション名: Footer
   Figma nodeId: 1-6426
   ======================================== */
  .fz-footer {
    padding: 3.375rem 0;
  }

  .fz-footer__inner {
  }

  .fz-footer__copy {
  }

  .fz-footer__copy small {
  }

  /* figma-css:end nodeId=1-6426 */
  /* figma-css:start nodeId=1-6428 */
  /* ========================================
   セクション名: FAQ
   Figma nodeId: 1-6428
   ======================================== */
  .fz-faq {
  }

  .fz-faq__inner {
  }

  .fz-faq__lead {
  }

  .fz-faq__ttl {
  }

  .fz-faq__list {
    gap: 28.6px;
    gap: 1.7875rem;
  }

  .fz-faq-item {
    padding-bottom: 24.8px;
    padding-bottom: 1.55rem;
  }

  .fz-faq-item:last-child {
  }

  .fz-faq-item__q {
  }

  .fz-faq-item__ttl {
    font-size: 20px;
    font-size: 1.25rem;
  }

  .fz-faq-item__txt {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.8;
  }

  /* figma-css:end nodeId=1-6428 */
  /* figma-css:start nodeId=265-3468 */
  /* ========================================
   セクション名: Future（パターンB）PC
   Figma nodeId: 265-3468
   ======================================== */
  .fz-future {
    padding-top: 110px;
    padding-top: 6.875rem;
  }

  .fz-future__inner {
  }

  .fz-future__lead {
    font-size: 76.4px;
    font-size: 4.775rem;
    letter-spacing: 12.04px;
    letter-spacing: 0.7525rem;
  }

  .fz-future__ttl {
    font-size: 35px;
    font-size: 2.1875rem;
    position: relative;
    margin-bottom: 30px;
    margin-bottom: 1.875rem;
  }

  .fz-future__ttl strong {
    font-size: 45px;
    font-size: 2.8125rem;
  }

  .fz-future__cards {
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: center;
    gap: 30px;
    gap: 1.875rem;
    column-gap: 30px;
    column-gap: 1.875rem;
    margin-bottom: 0;
    row-gap: 7.6px;
    row-gap: 0.475rem;
  }

  .fz-future-card {
    width: calc((100% - 60px) / 3);
    width: calc((100% - 3.75rem) / 3);
    margin-bottom: 30px;
    margin-bottom: 1.875rem;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .fz-future-card__box {
    padding: 27px 20.4px 41px;
    padding: 1.6875rem 1.275rem 2.5625rem;
    display: flex;
    flex-direction: column;
    flex: 1;
    min-width: 0;
  }

  .fz-future-card__num {
  }

  .fz-future-card__ttl {
    white-space: nowrap;
  }

  .fz-future-card__header {
  }

  .fz-future-card__badge {
  }

  .fz-future-card__badge-txt {
    display: inline-block;
  }

  .fz-future-card__heading {
  }

  .fz-future-card__heading strong {
  }

  .fz-future-card__txt {
    flex: 1;
    min-width: 0;
    width: 95%;
    margin-inline: auto;
  }

  .fz-future-card__deco {
    width: 260px;
    width: 16.25rem;
  }

  .fz-future-card__deco--1 {
    bottom: initial;
    top: -20px;
    top: -1.25rem;
    right: 0;
    transform: translateX(50%);
    display: none;
  }

  .fz-future-card__deco--2 {
    top: 62%;
    transform: translateX(50%);
  }

  .fz-future-card__deco--3 {
    bottom: -20%;
    right: 0;
    transform: translateX(-105%);
  }
  .fz-future-card__deco--4 {
    display: none;
  }

  .fz-future-card__license {
  }

  .fz-future-card__license-ttl {
  }

  .fz-future-card__license-ttl:after {
  }

  .fz-future-card__license-txt {
  }

  .fz-future__industry {
    max-width: 702px;
    margin-inline: auto;
    margin-top: 8px;
    margin-top: 0.5rem;
  }

  .fz-future__industry-ttl {
  }

  .fz-future__industry-ttl:after {
  }

  .fz-future__industry-txt {
    display: inline-block;
  }

  /* figma-css:end nodeId=265-3468 */
  /* figma-css:start nodeId=265-3824 */
  /* ========================================
   セクション名: Flow (パターンB) PC
   ======================================== */
  .fz-flow {
    padding-top: 49.2px;
    padding-top: 3.075rem;
  }

  .fz-flow__inner {
  }

  .fz-flow__bg {
    top: -31px;
    top: -1.9375rem;
    right: 0;
    transform: translateX(54%);
    width: 244px;
    width: 15.25rem;
  }

  .fz-flow__lead {
  }

  .fz-flow__ttl {
    font-size: 30.1px;
    font-size: 1.88125rem;
    letter-spacing: 2.107px;
    letter-spacing: 0.1316875rem;
    margin-bottom: 25.4px;
    margin-bottom: 1.5875rem;
  }

  .fz-flow__steps {
  }

  .fz-flow-step {
    padding: 25.6px 25.2px;
    padding: 1.6rem 1.575rem;
  }

  .fz-flow-step__icon {
  }

  .fz-flow-step__body {
  }

  .fz-flow-step__num {
    font-size: 13.6px;
    font-size: 0.85rem;
    letter-spacing: 1.496px;
    letter-spacing: 0.0935rem;
  }

  .fz-flow-step__ttl {
  }

  .fz-flow-step__txt {
    font-size: 15px;
    font-size: 0.9375rem;
    letter-spacing: 0.9px;
    letter-spacing: 0.05625rem;
  }

  .fz-flow__arrow {
  }

  .fz-flow__note {
  }

  .fz-flow__note-txt {
    font-size: 15px;
    font-size: 0.9375rem;
    line-height: 1.44;
  }

  /* figma-css:end nodeId=265-3824 */
  /* figma-css:start nodeId=1-6409 */
  /* ========================================
   セクション名: Message
   Figma nodeId: 1-6409
   ======================================== */
  .fz-message {
    padding-top: 123px;
    padding-top: 7.6875rem;
    padding-bottom: 39.8px;
    padding-bottom: 2.4875rem;
  }

  .fz-message::before {
  }

  .fz-message__inner {
  }

  .fz-message__lead {
    font-size: 106px;
    font-size: 6.625rem;
    letter-spacing: 12.74px;
    letter-spacing: 0.79625rem;
    opacity: 0.12;
    top: -35px;
    top: -2.1875rem;
    transform: translateX(-50%);
  }

  .fz-message__ttl {
    font-size: 20.52px;
    font-size: 1.2825rem;
    letter-spacing: 1.64px;
    letter-spacing: 0.1025rem;
  }

  .fz-message__ttl span {
  }

  .fz-message__ttl em {
    font-size: 35.21px;
    font-size: 2.200625rem;
    letter-spacing: 2.46px;
    letter-spacing: 0.15375rem;
  }

  .fz-message__img {
    max-width: 535px;
    width: 66.8%;
    margin-inline: auto;
    display: block;
  }

  .fz-message__box {
    padding: 46px 50.6px 35.4px;
    padding: 2.875rem 3.1625rem 2.2125rem;
    max-width: 744px;
    margin-inline: auto;
    box-shadow: 0 0 33.5px rgba(75, 75, 75, 0.05);
    box-shadow: 0 0 2.09375rem rgba(75, 75, 75, 0.05);
  }

  .fz-message__quote {
  }

  .fz-message__quote:first-of-type {
    top: 21.2px;
    top: 1.325rem;
    left: 48.4px;
    left: 3.025rem;
    color: #d7e3ea;
  }

  .fz-message__quote:last-of-type {
    bottom: 26px;
    bottom: 1.625rem;
    right: 51.6px;
    right: 3.225rem;
    color: #d7e3ea;
  }

  .fz-message__box-ttl {
    font-size: 19px;
    font-size: 1.1875rem;
    letter-spacing: 1.52px;
    letter-spacing: 0.095rem;
  }

  .fz-message__box-txt {
  }

  .fz-message__box-txt:last-of-type {
  }

  .fz-message__btn {
    margin-top: 39.4px;
    margin-top: 2.4625rem;
    max-width: 455.1px;
    margin-inline: auto;
  }

  .fz-message__btn-img {
  }

  /* figma-css:end nodeId=1-6409 */
  /* figma-css:start nodeId=1-6410 */
  /* ========================================
   セクション名: Support
   Figma nodeId: 1-6410
   ======================================== */
  .fz-support {
    padding-bottom: 85px;
    padding-bottom: 5.3125rem;
  }

  .fz-support__inner {
  }

  .fz-support__lead {
  }

  .fz-support__ttl {
    font-size: 31.3px;
    font-size: 1.95625rem;
    letter-spacing: 2.19px;
    letter-spacing: 0.136875rem;
    margin-bottom: 30.6px;
    margin-bottom: 1.9125rem;
  }

  .fz-support__ttl em {
  }

  .fz-support__img {
    width: 260px;
    width: 16.25rem;
  }

  .fz-support__main {
    display: flex;
    align-items: flex-start;
    gap: 40px;
    gap: 2.5rem;
  }

  .fz-support__body {
    flex: 1;
    min-width: 0;
  }

  .fz-support__txt {
  }

  .fz-support__check {
    display: inline-block;
    padding: 16.8px 28.4px;
    padding: 1.05rem 1.775rem;
  }

  .fz-support__list {
  }

  .fz-support__item {
  }

  .fz-support__item em {
  }

  .fz-support__check-icon {
  }

  /* figma-css:end nodeId=1-6410 */
  /* figma-css:start nodeId=1-6425 */
  /* ========================================
   セクション名: CTA
   Figma nodeId: 1-6425
   ======================================== */
  .fz-cta {
    padding-top: 7.3875rem;
  }

  .fz-cta__lead {
    font-size: 82px;
    font-size: 5.125rem;
    letter-spacing: 0.1em;
    top: -13.4px;
    top: -0.8375rem;
  }

  .fz-cta__inner {
  }

  .fz-cta__catch-wrap {
    display: flex;
    justify-content: space-between;
    /* gap: 21px; */
    /* gap: 1.3125rem; */
    margin-bottom: 29.2px;
    margin-bottom: 1.825rem;
  }

  .fz-cta__catch-left {
    width: 39%;
  }

  .fz-cta__catch-right {
    flex: 1;
    min-width: 0;
    margin-top: 9.6px;
    margin-top: 0.8rem;
  }

  .fz-cta__catch {
    margin-bottom: -16px;
    margin-bottom: -1rem;
    font-size: 20px;
    font-size: 1.25rem;
    position: relative;
    z-index: 2;
  }

  .fz-cta__catch-img {
    width: 296px;
    width: 18.5rem;
    position: absolute;
    z-index: 1;
    top: -11.1%;
    left: 1%;
  }

  .fz-cta__catch span {
  }

  .fz-cta__hero {
  }

  .fz-cta__img-wrap {
    width: 84.3%;
  }

  .fz-cta__img {
  }

  .fz-cta__labels {
    zoom: 1.2;
    left: 1.2rem;
  }

  .fz-cta__label {
  }

  .fz-cta__label b {
  }

  .fz-cta__ttl {
    font-size: 23.08px;
    font-size: 1.4425rem;
    letter-spacing: 1.15px;
    letter-spacing: 0.071875rem;
    margin-bottom: 0.2625rem;
  }

  .fz-cta__txt {
    text-align: left;
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.88;
  }

  .fz-cta__btn {
    width: 454.8px;
    width: 28.425rem;
  }

  .fz-cta__btn-img {
  }

  .fz-cta__quocard {
    bottom: 36%;
    right: 30px;
    right: 4.975rem;
    width: 262px;
    width: 12.775rem;
  }

  .fz-cta__btn-badge {
    width: 284px;
    width: 17.75rem;
    height: 37px;
    height: 2.3125rem;
    border-width: 1.6px;
    border-width: 0.1rem;
    border-radius: 4px;
    border-radius: 0.25rem;
  }

  .fz-cta__btn-badge-label {
    left: -28px;
    left: -1.75rem;
    width: 91px;
    width: 5.6875rem;
    font-size: 13.07px;
    font-size: 0.816875rem;
    letter-spacing: 0.65px;
    letter-spacing: 0.040625rem;
  }

  .fz-cta__btn-badge-value {
    font-size: 14.08px;
    font-size: 0.88rem;
  }

  .fz-cta__btn-badge-value em {
    font-size: 14.08px;
    font-size: 0.88rem;
  }

  .fz-cta__btn-body {
    height: 93px;
    height: 5.8125rem;
    border-radius: 8px;
    border-radius: 0.5rem;
    border: 1.17px solid #ffffff;
    border: 0.073125rem solid #ffffff;
    box-shadow: 0px 0px 15px rgba(0, 0, 0, 0.25);
    box-shadow: 0rem 0rem 0.9375rem rgba(0, 0, 0, 0.25);
  }

  .fz-cta__btn-sub {
    font-size: 13.65px;
    font-size: 0.853125rem;
    letter-spacing: 0.68px;
    letter-spacing: 0.0425rem;
  }

  .fz-cta__btn-main {
    font-size: 25.45px;
    font-size: 1.590625rem;
    letter-spacing: 3.31px;
    letter-spacing: 0.206875rem;
  }

  .fz-cta__btn-quocard {
    right: -15px;
    right: -0.9375rem;
    width: 85px;
    width: 5.3125rem;
  }

  /* figma-css:end nodeId=1-6425 */
}

/* figma-css:start nodeId=19-7144 */
/* ========================================
   セクション名: 追従ボタン
   Figma nodeId: 19-7144
   ======================================== */
.fz-fixed-btn {
  position: fixed;
  bottom: 5px;
  bottom: 0.3125rem;
  left: 50%;
  transform: translateX(-50%);
  width: 91%;
  max-width: 400px;
  z-index: 999;
  opacity: 1;
  transition: opacity 0.2s ease-out;
  pointer-events: auto;
}

.fz-fixed-btn.is-hidden {
  opacity: 0;
  pointer-events: none;
}

.fz-fixed-btn__link {
  display: flex;
  justify-content: center;
  position: relative;
  text-decoration: none;
  border-radius: 7px;
  border-radius: 0.4375rem;
  overflow: visible;
  /* box-shadow: 0px 0px 13px rgba(0, 0, 0, 0.25);
    /* box-shadow: 0rem 0rem 0.8125rem rgba(0, 0, 0, 0.25); */
  /* box-shadow: 0px 0px 13px rgba(0, 0, 0, 0.25);
    /* box-shadow: 0rem 0rem 0.8125rem rgba(0, 0, 0, 0.25); */
}

.fz-fixed-btn__img {
  display: none;
}

/* LINEボタン（画面右端固定・追従） */
.fz-fixed-line {
  position: fixed;
  bottom: 5px;
  bottom: 0.3125rem;
  bottom: 11%;
  right: 0;
  z-index: 1000;
  display: block;
  text-decoration: none;
  line-height: 0;
  opacity: 1;
  transition: opacity 0.2s ease-out;
  pointer-events: auto;
}

.fz-fixed-line.is-hidden {
  opacity: 0;
  pointer-events: none;
}

.fz-fixed-line__img {
  display: block;
  width: 33.4%;
  height: auto;
  margin-right: 0;
  margin-left: auto;
}

@media (min-width: 768px) {
  .fz-fixed-line {
    display: none;
  }
}

.fz-fixed-btn__badge {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 242px;
  width: 15.125rem;
  height: 32px;
  height: 2rem;
  margin: 0 auto;
  border: 1.37px solid #101010;
  border: 0.085625rem solid #101010;
  border-radius: 4px;
  border-radius: 0.25rem;
  background-color: #ffffff;
  position: relative;
  z-index: 1;
  transform: translateY(50%);
}

.fz-fixed-btn__badge-label {
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  left: -24px;
  left: -1.5rem;
  top: 0;
  height: 100%;
  width: 78px;
  width: 4.875rem;
  background: linear-gradient(135deg, #d44c1b 0%, #e94a26 100%);
  border-radius: 4px 0 0 4px;
  border-radius: 0.25rem 0 0 0.25rem;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11.17px;
  font-size: 0.698125rem;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: 0.56px;
  letter-spacing: 0.035rem;
  line-height: 1.23;
  text-align: center;
}

.fz-fixed-btn__badge-value {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12.03px;
  font-size: 0.751875rem;
  font-weight: 900;
  color: #1f222c;
  line-height: 1.23;
}

.fz-fixed-btn__badge-value em {
  font-style: normal;
  color: #e94a26;
}

.fz-fixed-btn__body {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 80px;
  height: 5rem;
  background-color: #d44c1b;
  border-radius: 7px;
  border-radius: 0.4375rem;
  padding-top: 10px;
  padding-top: 0.625rem;
}

.fz-fixed-btn__sub {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 11.66px;
  font-size: 0.72875rem;
  font-weight: 500;
  color: #ffffff;
  letter-spacing: 0.58px;
  letter-spacing: 0.03625rem;
  line-height: 1.2;
  text-align: center;
  margin-bottom: 4px;
  margin-bottom: 0.25rem;
}

.fz-fixed-btn__main {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 21.75px;
  font-size: 1.359375rem;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: 2.83px;
  letter-spacing: 0.176875rem;
  line-height: 1.4;
  text-align: center;
}

.fz-fixed-btn__quocard {
  position: absolute;
  right: -10px;
  right: -0.625rem;
  top: 50%;
  transform: translateY(-40%);
  width: 70px;
  width: 4.375rem;
  height: auto;
  z-index: 2;
}

@media (min-width: 768px) {
  .fz-fixed-btn {
    display: none;
  }
}

/* figma-css:end nodeId=19-7144 */
/* figma-css:start nodeId=19-7143 */
/* ========================================
   セクション名: Thanks
   Figma nodeId: 19-7143
   ======================================== */
.fz-thanks {
  background-color: #ebf3f9;
  padding-top: 40px;
  padding-top: 2.5rem;
  padding-bottom: 55px;
  padding-bottom: 3.4375rem;
  min-height: calc(100vh - 48px - 60px);
  display: flex;
  flex-direction: column;
  align-items: center;
}

.fz-thanks__inner {
  width: 92.75%;
  max-width: 600px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.fz-thanks__card {
  background-color: #ffffff;
  border-radius: 10px;
  border-radius: 0.625rem;
  padding: 35px 24px 40px;
  padding: 2.1875rem 1.5rem 2.5rem;
  width: 100%;
  margin-bottom: 35px;
  margin-bottom: 2.1875rem;
}

.fz-thanks__ttl {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 22px;
  font-size: 1.375rem;
  font-weight: 900;
  color: #004f9e;
  line-height: 1.4;
  letter-spacing: 1.1px;
  letter-spacing: 0.06875rem;
  text-align: center;
  margin-bottom: 20px;
  margin-bottom: 1.25rem;
}

.fz-thanks__body {
  display: flex;
  flex-direction: column;
  gap: 10px;
  gap: 0.625rem;
}

.fz-thanks__txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001126;
  line-height: 1.6;
  letter-spacing: 0.6px;
  letter-spacing: 0.0375rem;
}

.fz-thanks__back {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 500;
  color: #001126;
  line-height: 1.4;
  letter-spacing: 0.3px;
  letter-spacing: 0.01875rem;
  text-decoration: underline;
  text-underline-offset: 0.25em;
}

.fz-thanks__back:hover {
  text-decoration: none;
}

/* figma-css:end nodeId=19-7143 */
/* PC用レスポンシブ: Thanks */
@media (min-width: 768px) {
  .fz-thanks {
    padding-top: 0;
    padding-bottom: 0;
    min-height: calc(100vh - 70px - 60px);
    justify-content: center;
  }

  .fz-thanks__inner {
    max-width: 640px;
  }

  .fz-thanks__card {
    padding: 50px 60px 55px;
    padding: 3.125rem 3.75rem 3.4375rem;
    margin-bottom: 40px;
    margin-bottom: 2.5rem;
  }

  .fz-thanks__ttl {
    font-size: 28px;
    font-size: 1.75rem;
    letter-spacing: 1.4px;
    letter-spacing: 0.0875rem;
    margin-bottom: 28px;
    margin-bottom: 1.75rem;
  }

  .fz-thanks__body {
    gap: 16px;
    gap: 1rem;
  }

  .fz-thanks__txt {
    font-size: 16px;
    font-size: 1rem;
    line-height: 1.75;
    letter-spacing: 0.8px;
    letter-spacing: 0.05rem;
  }

  .fz-thanks__back {
    font-size: 16px;
    font-size: 1rem;
  }
}

/* figma-css:start nodeId=19-7141 */
/* ========================================
   セクション名: Contact
   Figma nodeId: 19-7141
   ======================================== */
.fz-contact {
  background-color: #ffffff;
  padding-bottom: 40px;
  padding-bottom: 2.5rem;
}

.fz-contact__inner {
  width: 100%;
  /* max-width: 414px;
    /* max-width: 25.875rem; */
  margin-inline: auto;
}

/* プログレスバー（ステップバー） */
.fz-contact__progress {
  background-color: #ecf4f9;
  padding: 20px 15px;
  padding: 1.25rem 0.9375rem;
  position: sticky;
  top: 0;
  z-index: 100;
}

.fz-contact__progress-inner {
  width: 75%;
  max-width: 454px;
  margin-inline: auto;
  display: flex;
  align-items: center;
  gap: 10px;
  gap: 0.625rem;
}

.fz-contact__progress-label {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  font-size: 0.8125rem;
  font-weight: 700;
  color: #001023;
  letter-spacing: 0.52px;
  letter-spacing: 0.0325rem;
  line-height: 0.95;
  white-space: nowrap;
}

.fz-contact__progress-count {
  font-family: "Noto Sans JP", sans-serif;
}

.fz-contact__progress-bar {
  position: relative;
  flex: 1;
  height: 20px;
  height: 1.25rem;
}

.fz-contact__progress-track {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  height: 12px;
  height: 0.75rem;
  background-color: #ffffff;
  border-radius: 8.4px;
  border-radius: 0.525rem;
  transform: translateY(-50%);
}

.fz-contact__progress-fill {
  position: absolute;
  top: 50%;
  left: 0;
  width: 0%;
  height: 8.8px;
  height: 0.55rem;
  background-color: #005a8e;
  border-radius: 2px;
  border-radius: 0.125rem;
  transform: translateY(-50%);
  transition: width 0.5s ease;
}

/* マーカードット（4つの区切り点） */
.fz-contact__progress-marker {
  position: absolute;
  top: 50%;
  width: 8px;
  width: 0.5rem;
  height: 8px;
  height: 0.5rem;
  background-color: #005a8e;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  z-index: 1;
}

.fz-contact__progress-marker[data-marker="1"] {
  left: 0%;
}

.fz-contact__progress-marker[data-marker="2"] {
  left: 31%;
}

.fz-contact__progress-marker[data-marker="3"] {
  left: 62%;
}

.fz-contact__progress-marker[data-marker="4"] {
  left: 93%;
}

/* 進行済みマーカーの色 */
.fz-contact__progress-marker.is-passed {
  background-color: #005a8e;
}

/* メインの移動するドット */
.fz-contact__progress-dot {
  position: absolute;
  top: 50%;
  left: 0%;
  width: 20px;
  width: 1.25rem;
  height: 20px;
  height: 1.25rem;
  background-color: #005a8e;
  border: 3px solid #ffffff;
  border: 0.1875rem solid #ffffff;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  transition: left 0.5s ease;
  z-index: 2;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.15);
  box-shadow: 0 0.125rem 0.25rem rgba(0, 0, 0, 0.15);
}

/* エラーリスト */
.fz-contact__error-list {
  padding: 15px;
  padding: 0.9375rem;
  background-color: #fdf5f2;
  margin: 15px;
  margin: 0.9375rem;
  border-radius: 5px;
  border-radius: 0.3125rem;
}

.fz-contact__error-item {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 400;
  color: #da2413;
  line-height: 1.45;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}

.fz-contact__error-item:last-child {
  margin-bottom: 0;
}

/* クライアントサイドバリデーションエラー */
.fz-contact__validation-errors {
  padding: 15px;
  padding: 0.9375rem;
  background-color: #fdf5f2;
  margin: 15px;
  margin: 0.9375rem;
  border-radius: 5px;
  border-radius: 0.3125rem;
  border: 1px solid #da2413;
  border: 0.0625rem solid #da2413;
}

.fz-contact__validation-error {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 14px;
  font-size: 0.875rem;
  font-weight: 400;
  color: #da2413;
  line-height: 1.45;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}

.fz-contact__validation-error:last-child {
  margin-bottom: 0;
}

/* エラー状態のフィールド */
.fz-contact__input.is-error,
.fz-contact__select.is-error {
  border-color: #da2413;
  background-color: #fdf5f2;
}

.fz-contact__answer.has-error {
  border-left: 3px solid #da2413;
  border-left: 0.1875rem solid #da2413;
  padding-left: 12px;
  padding-left: 0.75rem;
}

/* フォーム */
.fz-contact__form {
  padding: 0;
}

/* ステップ */
.fz-contact__step {
  display: none;
  padding: 15px;
  padding: 0.9375rem;
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.4s ease,
    transform 0.4s ease;
}

.fz-contact__step.is-active {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

/* チャット部分 */
.fz-contact__chat {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  gap: 0.625rem;
  margin-bottom: 20px;
  margin-bottom: 1.25rem;
}

.fz-contact__agent {
  flex-shrink: 0;
}

.fz-contact__agent-img {
  width: 80px;
  width: 5rem;
  height: 80px;
  height: 5rem;
  border-radius: 50%;
  object-fit: cover;
}

.fz-contact__bubble {
  background-color: #ecf4f9;
  border-radius: 0 30px 30px 30px;
  border-radius: 0 1.875rem 1.875rem 1.875rem;
  padding: 20px 24px;
  padding: 1.25rem 1.5rem;
  max-width: 273px;
}

.fz-contact__bubble-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001126;
  line-height: 1.45;
  letter-spacing: 0.3px;
  letter-spacing: 0.01875rem;
}

.fz-contact__bubble-note {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 12px;
  font-size: 0.75rem;
  font-weight: 400;
  color: #001126;
  line-height: 1.45;
  letter-spacing: 0.24px;
  letter-spacing: 0.015rem;
  margin-top: 10px;
  margin-top: 0.625rem;
}

/* 回答部分 */
.fz-contact__answer {
  background-color: #f2f2f2;
  border-radius: 30px 0 30px 30px;
  border-radius: 1.875rem 0 1.875rem 1.875rem;
  padding: 32px 40px;
  padding: 2rem 2.5rem;
  margin-left: auto;
  max-width: 383px;
}

.fz-contact__answer--form {
  padding: 32px 24px;
  padding: 2rem 1.5rem;
}

/* 選択肢（ラジオボタン・チェックボックス） */
.fz-contact__option {
  display: block;
  cursor: pointer;
  margin-bottom: 12px;
  margin-bottom: 0.75rem;
}

.fz-contact__option:last-child {
  margin-bottom: 0;
}

.fz-contact__radio,
.fz-contact__checkbox {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.fz-contact__option-box {
  display: flex;
  align-items: center;
  gap: 12px;
  gap: 0.75rem;
  background-color: #ffffff;
  border: 1px solid transparent;
  border: 0.0625rem solid transparent;
  border-radius: 5px;
  border-radius: 0.3125rem;
  padding: 14px 20px;
  padding: 0.875rem 1.25rem;
  transition: all 0.2s ease;
}

.fz-contact__radio:checked + .fz-contact__option-box,
.fz-contact__checkbox:checked + .fz-contact__option-box {
  background-color: #e3edf6;
  border-color: #0162c3;
}

.fz-contact__option-circle {
  width: 20px;
  width: 1.25rem;
  height: 20px;
  height: 1.25rem;
  border: 2px solid #c1c9d2;
  border: 0.125rem solid #c1c9d2;
  border-radius: 50%;
  flex-shrink: 0;
  position: relative;
  transition: all 0.2s ease;
}

.fz-contact__radio:checked
  + .fz-contact__option-box
  .fz-contact__option-circle {
  border-color: #0162c3;
  background-color: #0162c3;
}

.fz-contact__radio:checked
  + .fz-contact__option-box
  .fz-contact__option-circle::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  width: 0.5rem;
  height: 8px;
  height: 0.5rem;
  background-color: #ffffff;
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.fz-contact__checkbox:checked
  + .fz-contact__option-box
  .fz-contact__option-circle {
  border-color: #0162c3;
  background-color: #0162c3;
}

.fz-contact__checkbox:checked
  + .fz-contact__option-box
  .fz-contact__option-circle::after {
  content: "";
  position: absolute;
  top: 45%;
  left: 50%;
  width: 6px;
  width: 0.375rem;
  height: 10px;
  height: 0.625rem;
  border: solid #ffffff;
  border-width: 0 2px 2px 0;
  border-width: 0 0.125rem 0.125rem 0;
  transform: translate(-50%, -50%) rotate(45deg);
}

.fz-contact__option-txt {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001126;
  line-height: 1.45;
  letter-spacing: 0.3px;
  letter-spacing: 0.01875rem;
}

/* フォームフィールド */
.fz-contact__field {
  margin-bottom: 20px;
  margin-bottom: 1.25rem;
}

.fz-contact__field:last-child {
  margin-bottom: 0;
}

.fz-contact__field--half {
  flex: 1;
  min-width: 0;
  margin-bottom: 0;
}

.fz-contact__label {
  display: block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 400;
  color: #001126;
  line-height: 1.45;
  letter-spacing: 0.3px;
  letter-spacing: 0.01875rem;
  margin-bottom: 8px;
  margin-bottom: 0.5rem;
}

.fz-contact__input-row {
  display: flex;
  gap: 18px;
  gap: 1.125rem;
}

.fz-contact__input-wrap {
  flex: 1;
  min-width: 0;
}

.fz-contact__input {
  width: 100%;
  height: 49px;
  height: 3.0625rem;
  background-color: #ffffff;
  border: 1px solid #3698de;
  border: 0.0625rem solid #3698de;
  border-radius: 5px;
  border-radius: 0.3125rem;
  padding: 0 12px;
  padding: 0 0.75rem;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 500;
  color: #001126;
  line-height: 1.4;
  letter-spacing: 0.32px;
  letter-spacing: 0.02rem;
}

.fz-contact__input::placeholder {
  color: #d9d9d9;
}

.fz-contact__input--half {
  flex: 1;
  min-width: 0;
}

.fz-contact__input:focus {
  outline: none;
  border-color: #0162c3;
}

.fz-contact__input.is-error {
  background-color: #fdf5f2;
  border-color: #da2413;
}

.fz-contact__input-error {
  display: none;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 13px;
  font-size: 0.8125rem;
  font-weight: 400;
  color: #da2413;
  line-height: 1.45;
  letter-spacing: 0.26px;
  letter-spacing: 0.01625rem;
  margin-top: 5px;
  margin-top: 0.3125rem;
}

.fz-contact__input.is-error + .fz-contact__input-error {
  display: block;
}

/* セレクトボックス */
.fz-contact__select-wrap {
  position: relative;
}

.fz-contact__select-wrap--half {
  flex: 1;
  min-width: 0;
}

.fz-contact__select {
  width: 100%;
  height: 49px;
  height: 3.0625rem;
  background-color: #ffffff;
  border: 1px solid #3698de;
  border: 0.0625rem solid #3698de;
  border-radius: 5px;
  border-radius: 0.3125rem;
  padding: 0 35px 0 12px;
  padding: 0 2.1875rem 0 0.75rem;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  font-weight: 500;
  color: #001126;
  line-height: 1.4;
  letter-spacing: 0.32px;
  letter-spacing: 0.02rem;
  appearance: none;
  cursor: pointer;
}

.fz-contact__select:invalid,
.fz-contact__select option[value=""] {
  color: #d9d9d9;
}

.fz-contact__select:focus {
  outline: none;
  border-color: #0162c3;
}

.fz-contact__select-wrap::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 12px;
  right: 0.75rem;
  width: 0;
  height: 0;
  border-left: 6px solid transparent;
  border-left: 0.375rem solid transparent;
  border-right: 6px solid transparent;
  border-right: 0.375rem solid transparent;
  border-top: 8px solid #666666;
  border-top: 0.5rem solid #666666;
  transform: translateY(-50%);
  pointer-events: none;
}

/* 送信ボタン */
.fz-contact__submit-wrap {
  padding: 20px 15px 0;
  padding: 1.25rem 0.9375rem 0;
}

.fz-contact__submit {
  display: block;
  width: 223px;
  width: 13.9375rem;
  height: 62px;
  height: 3.875rem;
  margin: 0 auto;
  background: #128ec3;
  border-radius: 50px;
  border-radius: 3.125rem;
  box-shadow: 0px 0px 16px rgba(0, 0, 0, 0.18);
  box-shadow: 0rem 0rem 1rem rgba(0, 0, 0, 0.18);
  font-family: "Noto Sans JP", sans-serif;
  font-size: 17px;
  font-size: 1.0625rem;
  font-weight: 900;
  color: #ffffff;
  letter-spacing: 2.04px;
  letter-spacing: 0.1275rem;
  line-height: 1.2;
  text-align: center;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.fz-contact__submit:disabled {
  /* opacity: 0.6; */
  cursor: not-allowed;
}

.fz-contact__submit:not(:disabled):hover {
  opacity: 0.9;
}

/* ステップ3「次へ」ボタン */
.fz-contact__next-btn {
  display: block;
  width: 100%;
  max-width: 200px;
  height: 50px;
  height: 3.125rem;
  margin: 20px auto 0;
  margin: 1.25rem auto 0;
  background: linear-gradient(90deg, #0d52a8 0%, #2e7de0 100%);
  border: none;
  border-radius: 25px;
  border-radius: 1.5625rem;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 15px;
  font-size: 0.9375rem;
  font-weight: 700;
  color: #ffffff;
  letter-spacing: 1px;
  letter-spacing: 0.0625rem;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

.fz-contact__next-btn:hover {
  opacity: 0.9;
}

/* プログレスドットのアニメーション */
.fz-contact__progress-dot.is-animating {
  animation: dotPulse 0.5s ease;
}

@keyframes dotPulse {
  0% {
    transform: translate(-50%, -50%) scale(1);
  }

  50% {
    transform: translate(-50%, -50%) scale(1.4);
  }

  100% {
    transform: translate(-50%, -50%) scale(1);
  }
}

/* 送信ボタンの表示/非表示トランジション */
.fz-contact__submit-wrap {
  opacity: 1;
  transition: opacity 0.3s ease;
}

/* 選択肢のホバー・選択状態 */
.fz-contact__option:hover .fz-contact__option-box {
  background-color: #f5f9fc;
}

.fz-contact__option.is-selected .fz-contact__option-box {
  background-color: #e3edf6;
  border-color: #0162c3;
}

/* ========================================
   PC対応（768px以上）
   ======================================== */
@media (min-width: 768px) {
  .fz-contact {
    padding-bottom: 80px;
    padding-bottom: 5rem;
  }

  .fz-contact__inner {
    max-width: 640px;
  }

  /* プログレスバー */
  .fz-contact__progress {
    padding: 24px 20px;
    padding: 1.5rem 1.25rem;
  }

  .fz-contact__progress-inner {
    max-width: 640px;
  }

  .fz-contact__progress-label {
    font-size: 15px;
    font-size: 0.9375rem;
  }

  .fz-contact__progress-bar {
    height: 24px;
    height: 1.5rem;
  }

  .fz-contact__progress-track {
    height: 10px;
    height: 0.625rem;
    border-radius: 5px;
    border-radius: 0.3125rem;
  }

  .fz-contact__progress-fill {
    height: 10px;
    height: 0.625rem;
    border-radius: 5px;
    border-radius: 0.3125rem;
  }

  .fz-contact__progress-marker {
    width: 10px;
    width: 0.625rem;
    height: 10px;
    height: 0.625rem;
  }

  .fz-contact__progress-dot {
    width: 24px;
    width: 1.5rem;
    height: 24px;
    height: 1.5rem;
    border-width: 4px;
    border-width: 0.25rem;
  }

  /* ステップ */
  .fz-contact__step {
    padding: 30px 20px;
    padding: 1.875rem 1.25rem;
  }

  /* チャット部分 */
  .fz-contact__chat {
    gap: 16px;
    gap: 1rem;
    margin-bottom: 30px;
    margin-bottom: 1.875rem;
  }

  .fz-contact__agent-img {
    width: 100px;
    width: 6.25rem;
    height: 100px;
    height: 6.25rem;
  }

  .fz-contact__bubble {
    border-radius: 0 40px 40px 40px;
    border-radius: 0 2.5rem 2.5rem 2.5rem;
    padding: 28px 32px;
    padding: 1.75rem 2rem;
    max-width: 450px;
  }

  .fz-contact__bubble-txt {
    font-size: 17px;
    font-size: 1.0625rem;
    line-height: 1.6;
  }

  .fz-contact__bubble-note {
    font-size: 14px;
    font-size: 0.875rem;
    margin-top: 14px;
    margin-top: 0.875rem;
  }

  /* 回答部分 */
  .fz-contact__answer {
    border-radius: 40px 0 40px 40px;
    border-radius: 2.5rem 0 2.5rem 2.5rem;
    padding: 40px 48px;
    padding: 2.5rem 3rem;
    max-width: initial;
  }

  .fz-contact__answer--form {
    padding: 40px 36px;
    padding: 2.5rem 2.25rem;
  }

  /* 選択肢 */
  .fz-contact__option {
    margin-bottom: 16px;
    margin-bottom: 1rem;
  }

  .fz-contact__option-box {
    gap: 16px;
    gap: 1rem;
    border-radius: 8px;
    border-radius: 0.5rem;
    padding: 18px 24px;
    padding: 1.125rem 1.5rem;
  }

  .fz-contact__option-circle {
    width: 24px;
    width: 1.5rem;
    height: 24px;
    height: 1.5rem;
  }

  .fz-contact__radio:checked
    + .fz-contact__option-box
    .fz-contact__option-circle::after {
    width: 10px;
    width: 0.625rem;
    height: 10px;
    height: 0.625rem;
  }

  .fz-contact__checkbox:checked
    + .fz-contact__option-box
    .fz-contact__option-circle::after {
    width: 8px;
    width: 0.5rem;
    height: 12px;
    height: 0.75rem;
  }

  .fz-contact__option-txt {
    font-size: 17px;
    font-size: 1.0625rem;
  }

  /* フォームフィールド */
  .fz-contact__field {
    margin-bottom: 28px;
    margin-bottom: 1.75rem;
  }

  .fz-contact__label {
    font-size: 17px;
    font-size: 1.0625rem;
    margin-bottom: 12px;
    margin-bottom: 0.75rem;
  }

  .fz-contact__input-row {
    gap: 24px;
    gap: 1.5rem;
  }

  .fz-contact__input {
    height: 56px;
    height: 3.5rem;
    font-size: 17px;
    font-size: 1.0625rem;
    padding: 0 16px;
    padding: 0 1rem;
    border-radius: 8px;
    border-radius: 0.5rem;
  }

  .fz-contact__input-error {
    font-size: 14px;
    font-size: 0.875rem;
    margin-top: 8px;
    margin-top: 0.5rem;
  }

  /* セレクトボックス */
  .fz-contact__select {
    height: 56px;
    height: 3.5rem;
    font-size: 17px;
    font-size: 1.0625rem;
    padding: 0 40px 0 16px;
    padding: 0 2.5rem 0 1rem;
    border-radius: 8px;
    border-radius: 0.5rem;
  }

  .fz-contact__select-wrap::after {
    right: 16px;
    right: 1rem;
  }

  /* 送信ボタン */
  .fz-contact__submit-wrap {
    padding: 10px 20px 0;
    padding: 0.625rem 1.25rem 0;
  }

  .fz-contact__submit {
    width: 280px;
    width: 17.5rem;
    height: 72px;
    height: 4.5rem;
    font-size: 19px;
    font-size: 1.1875rem;
    border-radius: 36px;
    border-radius: 2.25rem;
  }

  /* エラー表示 */
  .fz-contact__error-list,
  .fz-contact__validation-errors {
    padding: 20px;
    padding: 1.25rem;
    margin: 20px;
    margin: 1.25rem;
    border-radius: 8px;
    border-radius: 0.5rem;
  }

  .fz-contact__error-item,
  .fz-contact__validation-error {
    font-size: 15px;
    font-size: 0.9375rem;
    margin-bottom: 10px;
    margin-bottom: 0.625rem;
  }
}
