/* =========================================================
   Final Overrides
   Keep this file small. Use only for temporary fixes or for
   selectors that must beat Lightning / plugin CSS.
   ========================================================= */


/* =========================================================
   Section Heading Override
   HOME: NEWS / PLANS を h2::after で表示する
   ========================================================= */

/* HOMEセクション見出し共通 */
body.home .entry-body section.news-section > h2,
body.home .entry-body section.plan-section > h2,
.news-section > h2,
.plan-section > h2 {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin: 0 0 42px !important;
  padding: 0 0 14px !important;
  color: var(--color-secondary) !important;
  line-height: 1.3 !important;
  letter-spacing: 0.04em !important;
  border: none !important;
  background: transparent !important;
}

/* 見出し上の青い線 */
body.home .entry-body section.news-section > h2::before,
body.home .entry-body section.plan-section > h2::before,
.news-section > h2::before,
.plan-section > h2::before {
  content: "" !important;
  position: absolute !important;
  left: 0 !important;
  top: -14px !important;
  bottom: auto !important;
  width: 100% !important;
  height: 2px !important;
  border: none !important;
  background: var(--color-primary) !important;
  opacity: 1 !important;
}

/* NEWSバッジ */
body.home .entry-body section.news-section > h2::after,
.news-section > h2::after {
  content: "NEWS" !important;
  position: static !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: auto !important;
  height: 24px !important;
  padding: 0 10px !important;
  border: none !important;
  border-radius: 999px !important;
  background: rgba(0, 123, 255, 0.08) !important;
  color: var(--color-primary) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: 0.1em !important;
  white-space: nowrap !important;
  transform: translateY(1px) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* PLANSバッジ */
body.home .entry-body section.plan-section > h2::after,
.plan-section > h2::after {
  content: "PLANS" !important;
  position: static !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex: 0 0 auto !important;
  width: auto !important;
  min-width: auto !important;
  height: 24px !important;
  padding: 0 10px !important;
  border: none !important;
  border-radius: 999px !important;
  background: rgba(0, 123, 255, 0.08) !important;
  color: var(--color-primary) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  line-height: 1 !important;
  letter-spacing: 0.1em !important;
  white-space: nowrap !important;
  transform: translateY(1px) !important;
  opacity: 1 !important;
  visibility: visible !important;
}

/* HTML側に残ったspanバッジは非表示にする */
body.home .entry-body section.news-section > h2 .section-badge,
body.home .entry-body section.plan-section > h2 .section-badge,
.news-section > h2 .section-badge,
.plan-section > h2 .section-badge {
  display: none !important;
}


/* =========================================================
   Header Layout Correction
   ロゴとメニュー位置の補正
   ========================================================= */

@media (min-width: 992px) {
  .site-header {
    overflow: visible !important;
  }

  .site-header-container.container,
  #site-header-container.container {
    box-sizing: border-box !important;
    width: min(100% - 48px, 1320px) !important;
    max-width: 1320px !important;
    min-height: 76px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;

    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    align-items: center !important;
    column-gap: 36px !important;
  }

  .site-header-logo {
    grid-column: 1 !important;
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1 !important;
    justify-self: start !important;
  }

  .site-header-logo a,
  .site-header-logo span {
    display: inline-flex !important;
    align-items: center !important;
    line-height: 1 !important;
  }

  .site-header-logo img {
    max-height: 42px !important;
    max-width: 260px !important;
    width: auto !important;
    height: auto !important;
    display: block !important;
  }

  .global-nav {
    grid-column: 2 !important;
    justify-self: end !important;

    width: auto !important;
    max-width: 100% !important;
    min-width: 0 !important;

    margin-left: 0 !important;
    margin-right: 0 !important;
    float: none !important;
  }

  .global-nav-list,
  .vk-menu-acc.global-nav-list {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    flex-wrap: nowrap !important;

    gap: 2px !important;
    margin: 0 !important;
    padding: 0 !important;
    min-width: 0 !important;
  }

  .global-nav-list > li > a {
    min-height: 76px !important;
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .global-nav-name {
    font-size: 0.88rem !important;
    letter-spacing: 0.03em !important;
  }

  .global-nav-description {
    font-size: 0.58rem !important;
    letter-spacing: 0.07em !important;
  }
}

/* 1200px台ではさらに詰める */
@media (min-width: 992px) and (max-width: 1240px) {
  .site-header-container.container,
  #site-header-container.container {
    width: min(100% - 32px, 1180px) !important;
    column-gap: 24px !important;
  }

  .site-header-logo img {
    max-width: 230px !important;
  }

  .global-nav-list > li > a {
    padding-left: 7px !important;
    padding-right: 7px !important;
  }

  .global-nav-name {
    font-size: 0.82rem !important;
  }

  .global-nav-description {
    font-size: 0.54rem !important;
  }
}

/* モバイルではLightning側の挙動を優先し、ロゴだけ軽く整える */
@media (max-width: 991px) {
  .site-header-container.container,
  #site-header-container.container {
    min-height: 64px !important;
  }

  .site-header-logo {
    margin: 0 !important;
    line-height: 1 !important;
  }

  .site-header-logo img {
    max-height: 36px !important;
    max-width: 220px !important;
    width: auto !important;
    height: auto !important;
    display: block !important;
  }
}
