html {
  font-size: 100%;
}

/* スマホデザインが414pxで作られている場合の,rem可変を同倍率可変にする場合は有効・不要なら削除 */
@media screen and (max-width: 540px) {
  html {
    font-size: 3.8647342995vw;
  }
}
@media screen and (min-width: 541px) {
  html {
    font-size: 20px;
  }
}

:where(.bz) img {
  width: 100%;
}

body {
  background-color: #fff;
}

.l-inner {
  padding-inline: 1rem;
}

.bz {
  position: relative;
}

/* ここにPCを時の背景 */
.bz:before {
  content: "";
  background-size: cover;
  background: url("../img/pc_bg.png") no-repeat center center / cover;
  width: 100%;
  height: 100vh;
  position: fixed;
  z-index: -1;
}

/* キャッチ */
.bz-pc-catch {
  display: none;
}
@media screen and (min-width: 1040px) {
  .bz-pc-catch {
    width: 53%;
    display: block;
    position: fixed;
    top: 7vh;
    left: 0;
  }
}

.bz-pc-catch img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 905/199;
}

.bz__inner {
  margin-inline: auto;
  max-width: 1680px;
  width: 100%;
  list-style: none;
  display: flex;
  justify-content: center;
  gap: 3.5%;
  position: relative;
}
@media screen and (min-width: 1040px) {
  .bz__inner {
    padding-right: 4.5%;
  }
}

/* ロゴ */
.bz-pc-logo {
  display: none;
}
@media screen and (min-width: 1040px) {
  .bz-pc-logo {
    width: 160px;
    height: 52px;
    display: block;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 9999;
  }
}

.bz-pc-logo a {
  width: 100%;
  display: block;
}

@media screen and (min-width: 768px) {
  .bz-pc-logo a:hover {
    opacity: 1;
  }
}

.bz-pc-logo img,
.bz-sp-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.bz-sp-logo {
  width: 38%;
  display: block;
  position: absolute;
  top: -1px;
  left: 0;
  z-index: 9999;
}

@media screen and (min-width: 768px) {
  .bz-sp-logo a:hover {
    opacity: 1;
  }
}

/* フッター */
.l-footer {
  padding-block: 11% 3%;
}

.l-footer--sub {
  padding-block: 5%;
}

.p-footer {
  text-align: center;
  background-color: #f2f9ff;
}

.p-footer small {
  font-size: 0.625rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: #071356;
}

/* 左コンテンツ */
.bz-pc-left {
  display: none;
}
@media screen and (min-width: 1040px) {
  .bz-pc-left {
    width: 44%;
    width: 30%;
    display: block;
  }
}
@media screen and (min-width: 1680px) {
  .bz-pc-left {
    width: 39%;
  }
}

.bz-pc-left__inner {
  position: sticky;
  top: 63vh;
  transform: translateY(-50%);
}

.bz-pc-left-container {
  position: relative;
}

.bz-pc-left__image {
  max-width: 554px;
  width: 100%;
}

.bz-pc-left__image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 524/564;
}

.bz-pc-left__cta {
  width: 72%;
  position: absolute;
  bottom: 8%;
  left: 14%;
}
@media screen and (min-width: 1680px) {
  .bz-pc-left__cta {
    width: 72%;
    bottom: 34px;
    left: 8%;
  }
}

.bz-pc-left__cta .c-cta__reservation img {
  aspect-ratio: 297/82;
}

.c-cta__reservation {
  width: 100%;
}
.c-cta__reservation img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 325/107;
}

.c-cta__line {
  margin-top: -15px;
  width: 100%;
}
.c-cta__line img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 321/103;
}

/* メインコンテンツ */
.bz-content {
  margin: 0 auto;
  width: 100%;
  max-width: 565px;
  background-color: #fff;
  box-shadow: 0 0 30.9px 0 rgba(0, 0, 0, 0.2);
}
@media screen and (min-width: 1040px) {
  .bz-content {
    margin: initial;
  }
}

.bz-content__inner {
  margin-inline: auto;
  position: relative;
  overflow: hidden;
}

@media screen and (max-width: 767.98px) {
  .bz__inner {
    width: 100%;
    display: block;
  }

  .bz-content__inner {
    width: 100%;
  }
}

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

FV

------------------- */
.bz-fv-wrapper {
  position: relative;
}

.bz-fv {
  margin-left: -1px;
  width: 100.5%;
}
.bz-fv img {
  aspect-ratio: 414/657;
}

.bz-fv__cta {
  position: absolute;
  bottom: -25%;
  left: 0;
}

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

経営者 会社員 個人事業主 最大の敵 不安や孤独

------------------- */
.bz-01 {
  margin-top: -1px;
  margin-left: -1px;
  width: 100.5%;
}

.bz-01 img {
  aspect-ratio: 414/692;
}

.bz-02 {
  width: 100.5%;
}

.bz-03,
.bz-04 {
  margin-top: -1px;
  width: 100.5%;
}

.bz-02 img {
  aspect-ratio: 414/773;
}
.bz-03 img {
  aspect-ratio: 414/589;
}
.bz-04 img {
  aspect-ratio: 414/495;
}

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

F-クオリティーなら変われます

------------------- */
.bz-05,
.bz-06,
.bz-07,
.bz-08,
.bz-09 {
  margin-top: -1px;
  width: 100.5%;
}
.bz-05 {
  margin-left: -1px;
}

.bz-05 img {
  aspect-ratio: 414/190;
}
.bz-06 img {
  aspect-ratio: 414/143;
}
.bz-07 img {
  aspect-ratio: 414/412;
}
.bz-08 img {
  aspect-ratio: 414/440;
}
.bz-09 img {
  aspect-ratio: 414/482;
}

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

この3STEPでポジティブな連鎖が生まれます

------------------- */
.bz-10,
.bz-11,
.bz-12 {
  margin-top: -1px;
  width: 100.5%;
}
.bz-12 {
  margin-left: -1px;
}

.bz-10 img {
  aspect-ratio: 414/162;
}
.bz-11 img {
  aspect-ratio: 414/402;
}
.bz-12 img {
  aspect-ratio: 414/589;
}

.bz-12__cta {
  margin-top: -20px;
}

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

すべてが好転しはじめる

------------------- */
.bz-13,
.bz-14,
.bz-15,
.bz-16,
.bz-17 {
  margin-top: -1px;
  width: 100.5%;
}
.bz-17 {
  margin-left: -1px;
}

.bz-13 img {
  aspect-ratio: 414/189;
}
.bz-14 img {
  aspect-ratio: 414/278;
}
.bz-15 img {
  aspect-ratio: 414/297;
}
.bz-16 img {
  aspect-ratio: 414/394;
}
.bz-17 img {
  aspect-ratio: 414/787;
}

.bz-17__wrapper {
  position: relative;
  z-index: 10;
}

.bz-17__cta {
  position: absolute;
  bottom: 8%;
}

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

3名の受講生の体験談

------------------- */
.bz-18 {
  width: 73.5%;
  position: relative;
  z-index: 10;
}

.bz-18 img {
  aspect-ratio: 774/362;
}

.p-interview {
  margin-top: -4.3755rem;
  padding-top: 5.4375rem;
  position: relative;
  z-index: 10;
  overflow: hidden;
  background: url("../img/interview_bg.png") no-repeat right top / cover;
}

.p-interview__inner {
  padding-top: 2.1875rem;
  padding-inline: 1.875rem;
  padding-bottom: 3.0625rem;
  position: relative;
}

.p-interview__list {
  display: grid;
  gap: 2.5rem;
}

.p-interview__item {
  padding: 1.4375rem 0.625rem 1.375rem;
  position: relative;
  background-color: #fff;
  box-shadow: 0 0 15.1px 0 rgba(204, 224, 218, 0.29);
}

.p-interview__item::before {
  content: "";
  width: 8.25rem;
  height: 1.625rem;
  display: block;
  position: absolute;
  top: -0.6875rem;
  left: 0.8125rem;
  background: url("../img/interview_number1.png") no-repeat center center /
    contain;
}

.p-interview__item:nth-child(2)::before {
  background: url("../img/interview_number2.png") no-repeat center center /
    contain;
}
.p-interview__item:nth-child(3)::before {
  background: url("../img/interview_number3.png") no-repeat center center /
    contain;
}

.p-interview__item-catch {
  font-size: 1.125rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-align: center;
  color: #071356;
}

.p-interview__item-catch span {
  display: block;
  font-size: 1rem;
  letter-spacing: 0.15em;
  color: #aca600;
  transform: skew(-5deg);
}

.p-interview__item-image {
  margin-top: 1.125rem;
  padding-inline: 0.625rem;
  width: 100%;
}
.p-interview__item-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 314/179;
}

.p-interview__item-name {
  padding-right: 0.625rem;
  font-size: 0.625rem;
  font-weight: bold;
  letter-spacing: 0.13em;
  text-align: right;
  color: #071356;
}

.p-interview__item-text {
  margin-top: 0.625rem;
  padding-inline: 0.5rem;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  line-height: 1.6;
  color: #071356;
  display: -webkit-box;
  -webkit-line-clamp: 16;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.p-interview__item-text.open {
  margin-bottom: 1rem;
  -webkit-line-clamp: unset; /* 行制限を解除 */
}

.p-interview__item-btn {
  margin-inline: auto 0.9375rem;
  padding-block: 0.625rem 0.3125rem;
  display: block;
  position: relative;
  font-size: 0.8125rem;
  font-weight: bold;
  letter-spacing: 0.03em;
  color: #1f5cc5;
  background-color: unset;
}

.p-interview__item-btn::before {
  content: "";
  width: 98%;
  height: 1px;
  display: block;
  position: absolute;
  bottom: 8px;
  left: 0;
  background-color: #1f5cc5;
}

.p-interview__item-caution {
  margin-left: 0.5rem;
  line-height: 1.2;
  margin-top: 0.125rem;
  /* margin-inline: auto 0.5rem; */
  width: fit-content;
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.03em;
  color: #071356;
}

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

もうひとりでは限界だと感じている ビジネスパーソンへ

------------------- */
.bz-19,
.bz-20,
.bz-21 {
  margin-top: -1px;
  width: 100.5%;
}

.bz-19 img {
  aspect-ratio: 414/503;
}
.bz-20 img {
  aspect-ratio: 414/460;
}
.bz-21 img {
  aspect-ratio: 414/596;
}

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

よくあるご質問

------------------- */
.l-faq {
  margin-top: 1.4375rem;
  padding-bottom: 4.375rem;
}

.p-faq__inner {
  padding-inline: 2.1875rem;
}

.p-faq__title {
  font-size: 1.875rem;
  font-weight: 900;
  letter-spacing: 0.12rem;
  text-align: center;
  color: #071356;
}

.p-faq__list {
  margin-top: 1.5625rem;
  display: grid;
  gap: 1.5625rem;
}

.p-faq__item {
  padding: 1.25rem 3.75rem 1.25rem 1.875rem;
  position: relative;
  background-color: #eaf5ff;
  border-radius: 0.625rem;
}

.p-faq__item::before {
  content: "";
  width: 2.8125rem;
  height: 2.8125rem;
  display: block;
  position: absolute;
  top: -1.0625rem;
  left: -0.3125rem;
  background: url("../img/faq_icon_q.png") no-repeat center center / contain;
}

.p-faq__item-title {
  position: relative;
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: 0.06em;
  color: #071356;
}

.p-faq__item-title::before {
  content: "";
  width: 2rem;
  height: 2rem;
  display: block;
  position: absolute;
  top: -0.0875rem;
  right: -2.875rem;
  background: url("../img/faq_icon_02.png") no-repeat center center / contain;
  transition: all 0.3s;
}

.p-faq__item-title.open::before {
  background: url("../img/faq_icon_01.png") no-repeat center center / contain;
}

.js-accordion {
  cursor: pointer;
}

.p-faq__item-answer {
  margin-top: 1rem;
  display: none;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.7;
  color: #071356;
}

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

60分無料体験セッション お申し込み

------------------- */
.bz-22 {
  margin-top: -1px;
  width: 100.5%;
}

.bz-22 img {
  aspect-ratio: 414/207;
}

.p-contact {
  background-color: #c2d5e7;
}

.p-contact__inner {
  padding-inline: 1.375rem;
  padding-bottom: 3.125rem;
}

.p-contact__content {
  padding-block: 2.125rem 2.5rem;
  padding-inline: 1.625rem;
  background-color: #ffffff;
  border-radius: 3px;
}

.p-contact__image {
  width: 100%;
}

.p-contact__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 305/223;
}

.p-contact__form {
  margin-top: 0.9375rem;
}

.p-contact__form-container {
  display: grid;
  gap: 1rem;
}

.p-contact-item {
  display: flex;
  flex-direction: column;
}

::placeholder {
  font-size: 1rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: rgba(7, 19, 86, 0.3);
}

.p-contact-item__label {
  font-size: 1rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #071356;
}

.p-contact::placeholder {
  font-weight: 500;
}

.p-contact-item__label span {
  margin-left: 0.25rem;
  padding-inline: 0.3125rem;
  display: inline-block;
  font-size: 0.875rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  color: #ffffff;
  background-color: #af0000;
  border-radius: 3px;
}

.p-contact-item:nth-child(5) .p-contact-item__label span,
.p-contact-item:nth-child(6) .p-contact-item__label span {
  margin-left: -0.375rem;
}

.p-contact-item__input {
  margin-top: 0.475rem;
  padding: 0.75rem;
  width: 100%;
  display: block;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  background-color: #ffffff;
  border: 2px solid #d2d2d2;
  border-radius: 10px;
}

.p-contact-item select {
  -webkit-appearance: none;
  appearance: none; /* デフォルトの矢印を非表示 */
  margin-top: 0.4375rem;
  width: 47%;
  padding-block: 0.75rem;
  padding-inline: 0.625rem;
  font-size: 0.875rem;
  font-weight: 500;
  letter-spacing: 0.04em;
  color: #071356;
  background: url("../img/select_icon.png") no-repeat 93% center / cover;
  background-size: 0.65625rem 0.375rem;
  background-color: #ffffff;
  border: 2px solid #d2d2d2;
  border-radius: 10px;
}

.p-contact-item textarea {
  min-height: 8.125rem;
  background: transparent;
}

.p-contact-item__textarea-wrapper {
  position: relative;
  z-index: 1;
}

.placeholder {
  padding: 0.75rem;
  position: absolute;
  top: 0.75rem;
  left: 0;
  z-index: -1;
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  color: rgba(7, 19, 86, 0.3);
}
.placeholder.hidden {
  display: none;
}

.p-contact__item-box {
  display: flex;
  gap: 0.625rem;
}

.p-contact__btn img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 238/65;
  background-color: #fff;
}

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

サンクスページ

------------------- */
.p-thanks {
  background: url("../img/thanks_bg.png") no-repeat center top / cover;
}

.p-thanks__head {
  width: 100.5%;
}

.p-thanks__head img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.p-thanks__inner {
  margin-top: -3.875rem;
  padding-inline: 2rem;
  padding-bottom: 1rem;
}

.p-thanks__text {
  margin-top: 0.75rem;
  font-size: 0.9375rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  color: #071356;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-thanks__text {
    margin-top: 1.25rem;
  }
}

.p-thanks__container {
  margin-top: 2.375rem;
  padding-block: 2.0625rem 1rem;
  padding-inline: 1.25rem;
  position: relative;
  background-color: #ffffff;
  border-radius: 10px;
  box-shadow: 0 0 14px 0 rgba(0, 0, 0, 0.05);
}
@media screen and (min-width: 768px) {
  .p-thanks__container {
    margin-top: 2.875rem;
  }
}

.p-thanks__container::before {
  content: "";
  width: 2.5626rem;
  height: 2.4375rem;
  display: block;
  position: absolute;
  top: -6%;
  left: 50%;
  transform: translateX(-50%);
  background: url("../img/line_icon.png") no-repeat center center / contain;
}

.p-thanks__container__title {
  font-size: 1.125rem;
  font-weight: bold;
  letter-spacing: 0.08em;
  color: #243153;
  text-align: center;
}

.p-thanks__container-text {
  margin-top: 0.6875rem;
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.6;
  color: #000;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-thanks__container-text {
    margin-top: 1.3125rem;
  }
}

.p-thanks__container-image {
  margin-top: 1rem;
  width: 100%;
}
@media screen and (min-width: 768px) {
  .p-thanks__container-image {
    margin-top: 1.625rem;
  }
}

.p-thanks__container-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 270/97;
}

.p-thanks__teacher {
  padding-inline: 1.4375rem 0.3125rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.625rem;
}

.p-thanks__teacher-image {
  width: 25%;
  border-radius: 50%;
}

.p-thanks__teacher-image img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  aspect-ratio: 1/1;
}

.p-thanks__teacher-about {
  width: 40%;
}

.p-thanks__teacher-company {
  margin-top: 0.625rem;
  width: 88%;
}
.p-thanks__teacher-company img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 96/29;
}

.p-thanks__teacher-name {
  transform: translateY(-0.4375rem);
  font-size: 1.08875rem;
  font-weight: bold;
  letter-spacing: 0.08em;
  line-height: 1.5;
  color: #243153;
}

.p-thanks__teacher-name::before {
  content: "メンタルコーチ";
  display: block;
  font-size: 0.65125rem;
  letter-spacing: 0;
  color: #0049d0;
}

.p-thanks__caution {
  margin-top: 1.5rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  line-height: 1.8;
  color: #071356;
  text-align: center;
}
@media screen and (min-width: 768px) {
  .p-thanks__caution {
    margin-top: 2.125rem;
  }
}

.p-thanks__caution a {
  color: #071356;
  text-decoration: underline;
}
