/* ヒーローセクション */
.hero {
  position: relative;
  width: 100%;
  height: 752px;
  overflow: hidden;
  background-color: #f9f3eb;
}

/* 背景画像 */
.hero__background img {
  position: absolute;
  top: 0;
  right: 0px;
  height: 652px;
}

/* メインコンテンツ */
.hero__content {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: flex-start;
}

.hero__badge-main {
  background: #ffffff;
  color: #ff6666;
  width: 521.5px;
  height: 83.74px;
  font-size: 40px;
  line-height: 31px;
  font-weight: 900;
  border-radius: 0 22px 0 0;
  box-shadow: 9px 9px 0px 0px #ff6666;
  letter-spacing: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.hero__badge-sub {
  background: #ffffff;

  width: 795.5px;
  height: 103px;

  font-size: 44px;
  font-weight: 800;
  border-radius: 0 22px 0 0;
  box-shadow: 9px 9px 0px 0px #ff6666;
  letter-spacing: 4.4px;
  display: flex;
  align-items: center;
  gap: 10px;
  justify-content: center;

  margin-bottom: 30px;
}

.hero__badge-logo {
  height: 96.6px;
  margin-top: -20px;
  padding-left: 20px;
}

.hero__logo {
  height: 99px;
  width: auto;
  object-fit: contain;
}

.hero__dog-sp {
  position: absolute;
  display: none;
}

.hero__features {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 36px;
  margin-left: 16px;
}

.hero__cta-arrow {
  width: 25.7px;
  height: 32.1px;
}

.feature-tag {
  width: 180px;
  height: 140px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.feature-tag span {
  color: #ffffff;
  font-size: 24px;
  font-weight: 700;
  text-align: center;
  line-height: 1.5;
  position: relative;
  z-index: 2;
}

.feature-tag__bg {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 190px;
  height: 150px;
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  border-radius: 48px;
  z-index: 1;
}

/* ヒーローエリア内CTAセクション */
.hero__cta-section {
  margin-top: auto;
  margin-bottom: 80px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  margin-left: 106px;
}

.hero__cta-text {
  font-size: 0px;
  font-weight: bold;

  text-align: center;
  line-height: 1;

  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 2px;
}

.hero__cta-text span {
  font-size: 26px;
}

.hero__cta-text .highlight {
  color: #ff6666;
  font-size: 45px;
  font-weight: 800;
  letter-spacing: 0px;
}

/* レスポンシブ対応 */
@media (min-width: 391px) and (max-width: 768px) {
  /* 背景画像を右側と下側に拡張 */
  .hero__background img {
    width: calc(366px + (100vw - 390px));
    height: calc(500px + (100vw - 390px));
    left: 0px;
    top: 94px;
    object-fit: cover;
    border-radius: 0px 20px 120px 0px;
  }

  /* メインバッジを少し右に拡張 */
  .hero__badge-main {
    width: calc(238px + (100vw - 390px) * 0.3);
    height: calc(38px + (100vw - 390px) * 0.1);
    font-size: 18px;
    line-height: 18px;
    letter-spacing: 2px;
    box-shadow: 4px 4px 0 0 #f66;
    border-radius: 0 10px 0 0;
  }

  .hero__badge-sub {
    width: calc(362px + (100vw - 390px) * 0.3);
    height: calc(47px + (100vw - 390px) * 0.1);
    font-size: 20px;
    letter-spacing: 2px;
    box-shadow: 6px 6px 0px 0px #ff6666;
    border-radius: 0 10px 0 0;
    margin-bottom: calc(260px + (100vw - 390px) * 0.7);
  }

  .hero__features {
    position: relative;
    width: 100%;
    height: calc(141px + (100vw - 390px) * 0.1);
    margin: 0;
    margin-bottom: 54px;
    padding: 0px 24px;
  }

  .hero__dog-sp {
    display: block;
    width: 93.3px;
    height: 96.85px;
    top: calc(523px + (100vw - 390px) * 0.9);
    left: calc(177px + (100vw - 390px) * 0.4);
  }

  .feature-tag {
    position: absolute;
    width: 140px;
    height: 110px;
  }

  .feature-tag span {
    font-size: 18px;
    font-weight: 700;
    line-height: 1.3;
  }

  /* 1番目のタグ（裁量権が大きい環境）- 上段左 */
  .feature-tag:nth-child(1) {
    top: 0;
    left: 16px;
    z-index: 2;
  }

  /* 2番目のタグ（充実の産休育休制度）- 上段右 */
  .feature-tag:nth-child(2) {
    top: 0;
    left: calc(174px + (100vw - 390px) * 0.3);
    z-index: 2;
  }

  .feature-tag:nth-child(4) {
    top: calc(58px + (100vw - 390px) * 0.1);
    left: calc(98px + (100vw - 390px) * 0.15);
  }

  .feature-tag:nth-child(3) {
    top: calc(58px + (100vw - 390px) * 0.1);
    left: calc(262px + (100vw - 390px) * 0.4);
  }

  .feature-tag__bg {
    width: 140px;
    height: 110px;
    border-radius: 32px;
  }

  /* ロゴサイズの調整 */
  .hero__logo {
    width: 109px;
    height: 35px;
    margin: 16px 23px;
  }

  /* バッジロゴの調整 */
  .hero__badge-logo {
    height: 44px;
    margin-top: -10px;
  }

  .hero__cta-section {
    margin: 0 auto;
    margin-bottom: 40px;
    gap: 8px;
  }

  .hero__cta-text span {
    font-size: 16px;
  }

  .hero__cta-text .highlight {
    font-size: 28px;
    font-weight: 800;
  }

  /* ヒーローセクション全体の高さを調整 */
  .hero {
    height: fit-content;
  }

  .hero__cta-arrow {
    width: 16px;
    height: 20px;
  }
}

@media (max-width: 390px) {
  /* ヒーローセクション全体の高さを調整 */
  .hero {
    height: fit-content;
  }

  /* 背景画像の調整 */
  .hero__background img {
    width: 366px;
    height: 500px;
    left: 0px;
    top: 94px;
    object-fit: cover;
    border-radius: 0px 20px 120px 0px;
  }

  /* ロゴサイズの調整 */
  .hero__logo {
    width: 109px;
    height: 35px;
    margin: 16px 23px;
  }

  /* メインバッジの調整 */
  .hero__badge-main {
    width: 238px;
    height: 38px;
    font-size: 18px;
    line-height: 18px;
    letter-spacing: 2px;
    box-shadow: 4px 4px 0 0 #f66;
    border-radius: 0 10px 0 0;
  }

  /* サブバッジの調整 */
  .hero__badge-sub {
    width: 362px;
    height: 47px;
    font-size: 20px;
    letter-spacing: 2px;
    box-shadow: 6px 6px 0px 0px #ff6666;
    border-radius: 0 10px 0 0;

    margin-bottom: 260px;
  }

  /* バッジロゴの調整 */
  .hero__badge-logo {
    height: 44px;
    margin-top: -10px;
  }

  /* CTA セクションの調整 */
  .hero__cta-section {
    margin: 0 auto;
    margin-bottom: 40px;
    gap: 8px;
  }

  .hero__cta-text span {
    font-size: 16px;
  }

  .hero__cta-text .highlight {
    font-size: 28px;
    font-weight: 800;
  }

  .hero__features {
    position: relative;
    width: 100%;
    height: 141px;
    margin: 0;
    margin-bottom: 54px;
    padding: 0px 24px;
  }

  .hero__cta-arrow {
    width: 16px;
    height: 20px;
  }

  .hero__dog-sp {
    display: block;
    top: 523px;
    left: 177px;
    width: 93.3px;
    height: 96.85px;
  }

  .feature-tag {
    position: absolute;
    width: 112px;
    height: 84px;
  }

  .feature-tag span {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.3;
  }

  /* 1番目のタグ（裁量権が大きい環境）- 上段左 */
  .feature-tag:nth-child(1) {
    top: 0;
    left: 16px;
    z-index: 2;
  }

  /* 2番目のタグ（充実の産休育休制度）- 上段右 */
  .feature-tag:nth-child(2) {
    top: 0;
    left: 174px;
    z-index: 2;
  }

  /* 3番目のタグ（子育て復帰支援あり）- 下段右 */
  .feature-tag:nth-child(4) {
    top: 58px;
    left: 98px;
  }

  /* 4番目のタグ（残業月10h未満）- 下段左中央 */
  .feature-tag:nth-child(3) {
    top: 58px;
    left: 262px;
  }

  .feature-tag__bg {
    width: 120px;
    height: 100px;
    border-radius: 32px;
  }
}
