/* ==========================================================================
   Project: FV
   ========================================================================== */

/* FV + Our Approach まで背景を固定表示 */
.p-fv-area {
  position: relative;
  isolation: isolate;
}

.p-fv-area__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
}

.p-fv-area__bg-sticky {
  position: sticky;
  top: var(--wp-admin-bar-height);
  width: 100%;
  height: calc(100svh - var(--wp-admin-bar-height));
  overflow: hidden;
  background: linear-gradient(
    145deg,
    var(--color-bg-fv-start) 0%,
    var(--color-bg-fv-mid) 42%,
    var(--color-bg-fv-end) 100%
  );
}

.p-fv__bg-video {
  position: absolute;
  inset: 0;
  z-index: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  opacity: 0.25;
}

.p-fv {
  position: relative;
  z-index: 1;
  /* min-height: 100vh; */
  padding-top: calc(var(--header-height-sp) + var(--space-lg));
  padding-bottom: 88px;
  overflow: visible;
  background: transparent;
}

@media (min-width: 768px) {
  .p-fv {
    padding-top: calc(var(--header-height-pc) + var(--space-lg));
    padding-bottom: 96px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .p-fv__bg-video {
    display: none;
  }
}

.p-fv__bg-text {
  position: absolute;
  z-index: 1;
  top: 3%;
  right: -8%;
  width: min(72vw, 800px);
  margin: 0;
  line-height: 0;
  transform: rotate(-4deg);
  user-select: none;
  pointer-events: none;
  contain: layout paint;
}

.p-fv__bg-text-img {
  display: block;
  width: 100%;
  height: auto;
}

@media (min-width: 768px) {
  .p-fv__bg-text {
    top: 3%;
    right: 2%;
    opacity: 0.7;
  }
}

@media (min-width: 1024px) {
  .p-fv__bg-text {
    right: 0;
  }
}

.p-fv__inner {
  position: relative;
  z-index: var(--z-fv-content);
  margin-bottom: var(--space-xl);
}

.p-fv__content {
  padding-top: var(--space-md);
}

@media (max-width: 767px) {
  .p-fv__content {
    display: flex;
    flex-direction: column;
  }

  .p-fv__title {
    order: 1;
  }

  .p-fv__lead {
    order: 2;
  }

  .p-fv__features {
    order: 3;
  }

  .p-fv__actions {
    order: 4;
    margin-top: var(--space-sm);
  }
}

/* @media (min-width: 768px) {
  .p-fv__content {
    padding-top: var(--space-lg);
  }
} */

.p-fv__title {
  font-family: var(--font-serif);
  font-weight: 500;
  color: var(--color-text);
}

.p-fv__title-line {
  display: block;
}

.p-fv__title-line--1 {
  font-size: clamp(22px, 5.6vw, 54px);
  line-height: 1.65;
}

.p-fv__title-line--2 {
  font-size: clamp(26px, 6.8vw, 54px);
  line-height: 1.55;
}

.p-fv__title-highlight1{
  color: var(--color-primary-dark);
  font-weight: 500;
  font-size: 120%;
}

.p-fv__title-highlight2{
  color: var(--color-accent);
  font-weight: 500;
  font-size: 120%;
}

.p-fv__lead {
  margin-top: var(--space-sm);
  font-size: var(--font-size-text-sp, 14px);
  line-height: 2;
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
}

@media (min-width: 768px) {
  .p-fv__lead {
    margin-top: var(--space-sm);
    font-size: 18px;
  }
}

.p-fv__actions {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-top: var(--space-lg);
}

@media (max-width: 767px) {
  .p-fv__actions {
    margin-top: var(--space-sm);
  }
}

@media (min-width: 768px) {
  .p-fv__actions {
    gap: var(--space-md);
    margin-top: var(--space-lg);
  }
}

/* FV CTA レイアウト */
.p-fv__actions .c-btn--fv {
  flex: 1 1 0;
  min-width: 0;
  width: auto;
  min-height: 48px;
  padding: 11px 10px 11px 14px;
  font-size: 12px;
  letter-spacing: 0.01em;
  gap: 6px;
}

.p-fv__actions .c-btn--fv .c-btn__label {
  line-height: 1.35;
}

.p-fv__actions .c-btn--fv .c-btn__arrow--dot {
  width: 22px;
  height: 6px;
}

@media (min-width: 768px) {
  .p-fv__actions .c-btn--fv,
  .p-approach__body .c-btn--fv {
    flex: 0 0 auto;
    width: auto;
    min-width: 280px;
    max-width: 280px;
    min-height: 52px;
    padding: 14px 24px 14px 28px;
    font-size: 14px;
    letter-spacing: 0.02em;
    gap: 12px;
  }

  .p-fv__actions .c-btn--fv .c-btn__arrow--dot {
    width: 28px;
    height: 8px;
  }
}

.p-fv__features {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-xs) var(--space-xs);
  margin: var(--space-md) auto;
}

@media (min-width: 768px) {
  .p-fv__features {
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-lg);
    margin-top: var(--space-lg);
  }
}

.p-fv__feature {
  display: flex;
  flex-direction: row;
  align-items: center;
  gap: var(--space-xs);
  text-align: left;
}

@media (min-width: 768px) {
  .p-fv__feature {
    flex: 0 0 auto;
    flex-direction: column;
    align-items: center;
    gap: var(--space-xs);
    min-width: 120px;
    text-align: center;
  }
}

.p-fv__feature-icon {
  display: flex;
  flex-shrink: 0;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  line-height: 0;
}

@media (min-width: 768px) {
  .p-fv__feature-icon {
    width: 83px;
    height: 83px;
  }
}

.p-fv__feature-icon-img {
  display: block;
  width: 48px;
  height: auto;
}

@media (min-width: 768px) {
  .p-fv__feature-icon-img {
    width: 83px;
  }
}

.p-fv__feature-label {
  font-size: 11px;
  line-height: 1.5;
  font-weight: 500;
  color: var(--color-primary-dark);
  letter-spacing: 0.02em;
}

@media (min-width: 768px) {
  .p-fv__feature-label {
    font-size: 12px;
  }
}

.p-fv__news {
  position: absolute;
  right: 0;
  bottom: 0;
  z-index: var(--z-fv-news);
  background-color: rgba(255, 255, 255, 0.92);
  border-top: 1px solid rgba(118, 199, 192, 0.12);
  backdrop-filter: blur(6px);
}
.p-fv__news-label {
  position: absolute;
  top: -40%;
  font-family: var(--font-script);
  font-size: clamp(24px, 2vw, 28px);
  line-height: 1.5;
  font-weight: 500;
  color: var(--color-primary-dark);
  letter-spacing: 0.02em;
}
@media (max-width: 767px) {
  .p-fv__news {
    width: 80%;
    padding: 0;
  }
}

.p-fv__news-inner {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  min-height: 56px;
  padding-block: var(--space-sm);
}

@media (min-width: 768px) {
  .p-fv__news-inner {
    gap: var(--space-md);
    min-height: 64px;
  }
}

.p-fv__news-link {
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.5em var(--space-sm);
  min-width: 0;
  font-size: 12px;
  color: var(--color-text);
  transition: opacity var(--transition-base);
}

@media (min-width: 768px) {
  .p-fv__news-link {
    flex-wrap: nowrap;
    font-size: 13px;
  }
}

@media (hover: hover) {
  .p-fv__news-link:hover {
    opacity: 0.7;
  }
}

.p-fv__news-date {
  flex-shrink: 0;
  color: var(--color-text-muted);
  letter-spacing: 0.04em;
}

.p-fv__news-category {
  flex-shrink: 0;
  color: var(--color-primary-dark);
  letter-spacing: 0.02em;
  border: 1px solid var(--color-primary-dark);
  padding: 0 6px;
}

.p-fv__news-title {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* JS 有効時：FV の GSAP 適用前ちらつき防止 */
html.js .p-fv [data-fv-title],
html.js .p-fv [data-fv-lead],
html.js .p-fv [data-fv-actions],
html.js .p-fv [data-fv-feature],
html.js .p-fv [data-fv-news] {
  opacity: 0;
  filter: blur(12px);
}

@media (prefers-reduced-motion: reduce) {
  html.js .p-fv [data-fv-title],
  html.js .p-fv [data-fv-lead],
  html.js .p-fv [data-fv-actions],
  html.js .p-fv [data-fv-feature],
  html.js .p-fv [data-fv-news] {
    opacity: 1;
    filter: none;
  }
}
