@charset "UTF-8";

/* ===========================================
   LP Management - independent styles
   base: 1rem / BEM / no-nest
   =========================================== */

/* ---------- utility ---------- */
.u-sp-only {
  display: none;
}

.u-br-sp425 {
  display: none;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .u-sp-only {
    display: inline;
  }
}

/* ---------- foundation ---------- */
/* アンカー（#contact 等）クリック時はスムーズスクロールで移動。
   prefers-reduced-motion 指定時は従来どおり瞬時移動にしてアクセシビリティを確保 */
@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: smooth;
  }
}

.lp-management {
  margin: 0;
  padding: 0;
  font-family: "Noto Sans JP", sans-serif;
  color: #14212e;
  line-height: 1.75;
  -webkit-font-smoothing: antialiased;
  background: #fff;
}
.lp-management * {
  box-sizing: border-box;
}
.lp-management img {
  max-width: 100%;
  height: auto;
  display: block;
}
/* <picture> はラッパーとして透過させ、内側の <img> を従来通り扱う */
.lp-management picture {
  display: contents;
}
.lp-management a {
  text-decoration: none;
  color: inherit;
}

.lp-wrap {
  width: 100%;
  overflow-x: hidden;
  font-feature-settings: "palt";
}

/* ---------- utilities ---------- */
.u-pc {
  display: inline;
}
.u-emphasis {
  font-size: 1.5em;
  font-weight: 900;
  -webkit-text-stroke: 6px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 2px #fff,
    0 0 5px #fff,
    0 0 10px rgba(255, 255, 255, 0.9);
}
.u-bold {
  font-weight: 700;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .u-pc {
    display: none;
  }
  .u-emphasis {
    -webkit-text-stroke: 5px #fff;
  }
}

/* ===========================================
   Header (logo only)
   =========================================== */
.l-header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  padding: 10px 0;
}

.l-header__logo {
  max-width: 272px;
  padding: 0 24px;
}
.l-header__logo a {
  display: block;
}
.l-header__logo img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .l-header__logo {
    width: 160px;
  }
}

/* ===========================================
   FV
   =========================================== */
/* ---------- FV base (PC) ---------- */
.p-fv {
  position: relative;
  width: 100%;
  background: #14212e;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

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

.p-fv__bg .p-fv__bg-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0.5;
}

.p-fv__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1280px;
  margin-top: 40px;
  margin-inline: auto;
  padding: 7px 12px 80px;
  flex: 1;
}

.p-fv__areas {
  display: flex;
  justify-content: center;
  gap: 13px;
  margin: 0;
}

.p-fv__area {
  min-width: clamp(110px, 11.72vw, 150px);
  height: clamp(32px, 3.125vw, 40px);
  padding: 0 clamp(8px, 1vw, 14px);
  border-radius: 20px;
  background: #fff;
  color: #171c3c;
  font-weight: 500;
  font-size: clamp(1.25rem, 2.11vw, 1.6875rem);
  line-height: clamp(2rem, 3.125vw, 2.5rem);
  text-align: center;
}

.p-fv__texts {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 25.6px;
  max-width: clamp(320px, 49.61vw, 720px);
  margin: 64px auto 0;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-fv__texts {
    max-width: clamp(320px, 55.61vw, 720px);
    margin: 48px auto 0;
  }
}

.p-fv__lead {
  text-align: center;
}
.p-fv__lead img {
  display: block;
  width: clamp(280px, 50.14vw, 601px);
  height: auto;
  margin-inline: auto;
}

.p-fv__title {
  text-align: center;
}
.p-fv__title img {
  display: block;
  width: clamp(320px, 47.08vw, 571px);
  height: auto;
  margin-inline: auto;
}
.p-fv__sub img {
  display: block;
  width: clamp(300px, 50.19vw, 640px);
  height: auto;
  margin-inline: auto;
}

.p-fv__person {
  position: absolute;
  left: calc(50% + clamp(160px, 32.305vw, 472px));
  bottom: 0;
  width: clamp(176px, 15.55vw, 304px);
  height: auto;
  z-index: 2;
  transform: translateX(-40%);
  pointer-events: none;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-fv__person {
    left: calc(50% + clamp(160px, 34.305vw, 440px));
    width: clamp(160px, 15.55vw, 304px);
  }
}

/* ---------- FV caption (white band) ---------- */
.p-fv__caption {
  position: relative;
  z-index: 1;
  width: 100%;
  flex: none;
  height: clamp(170px, 15.28vw, 254px);
  background: #fff url("../img/lp-img/fv/fv-bottom-bg.png") center
    center / cover no-repeat;
  /* WebP対応ブラウザは .webp、非対応は上の .png にフォールバック */
  background-image: image-set(
    url("../img/lp-img/fv/fv-bottom-bg.webp") type("image/webp"),
    url("../img/lp-img/fv/fv-bottom-bg.png") type("image/png")
  );
  padding: 16px;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

.p-fv__caption-person {
  display: none;
}

.p-fv__caption-text {
  display: inline-block;
  font-weight: 700;
  font-size: clamp(1.5rem, 3.5vw, 2rem);
  line-height: 1.8;
  color: #14212e;
  text-align: center;
}

.p-fv__caption-text.p-fv__caption-text--sp {
  display: none;
}

.p-fv__marker {
  position: relative;
  display: inline-block;
  padding: 0 2px;
}
.p-fv__marker::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 6px;
  height: 1em;
  background: #f4ce50;
  z-index: -1;
}

/* ---------- FV sp (768px) ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-fv {
    display: flex;
    flex-direction: column;
    background: #14212e;
  }
  .p-fv__bg {
    position: absolute;
    inset: 0;
    height: auto;
  }
  .p-fv__inner {
    position: relative;
    z-index: 1;
    margin-top: 16px;
    padding: 8px 16px 40px;
  }
  .p-fv__areas {
    gap: 6px;
    flex-wrap: nowrap;
  }
  .p-fv__area {
    min-width: clamp(56px, 18vw, 78px);
    height: 20.8px;
    line-height: 1.3rem;
    font-size: clamp(0.75rem, 3vw, 0.875rem);
    border-radius: 10.4px;
    padding: 0 10px;
  }
  .p-fv__texts {
    width: clamp(280px, 70vw, 500px);
    max-width: none;
    margin-top: 20px;
    gap: 0;
    align-items: center;
  }
  .p-fv__lead {
    margin-top: 0;
  }
  .p-fv__lead img {
    width: 76vw;
  }
  .p-fv__title {
    margin-top: 4px;
  }
  .p-fv__title img {
    width: 82vw;
    margin-inline: auto;
  }
  .p-fv__sub {
    margin-top: 4px;
  }
  .p-fv__sub img {
    width: 80vw;
  }
  /* PC用の男性を非表示 */
  .p-fv__person {
    display: none;
  }
  /* caption: 暗い背景を維持 */
  .p-fv__caption {
    position: relative;
    height: auto;
    padding: 0 1em;
    margin-top: 0;
    flex-direction: column;
  }
  /* SP用の男性をcaption内に表示 */
  .p-fv__caption-person {
    display: block;
    width: clamp(60px, 20vw, 100px);
    margin: -15px auto 0;
    pointer-events: none;
  }
  .p-fv__caption-person img {
    width: 100%;
    height: auto;
    display: block;
  }
  /* PC用テキスト非表示、SP用テキスト表示 */
  .p-fv__caption-text--pc {
    display: none;
  }
  .p-fv__caption-text.p-fv__caption-text--sp {
    display: inline-block;
  }
  /* キャプションテキスト: 白背景 + 角丸 */
  .p-fv__caption-text {
    width: clamp(280px, 90vw, 600px);
    padding: 16px 0.3em;
    background: #fff;
    font-size: clamp(0.875rem, 2.5vw, 2.75rem);
    border-radius: 15px;
    line-height: 1.8;
    letter-spacing: -0.03em;
    isolation: isolate;
    margin-inline: auto;
    margin-top: -25px;
  }
  .p-fv__marker {
    line-height: 1.3;
  }
  .p-fv__marker::after {
    height: 14px;
    bottom: -5px;
  }
}

/* ---------- Media: narrow smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-fv__caption-text {
    width: 100%;
    margin-top: -25px;
    font-size: clamp(0.75rem, 5vw, 1.25rem);
  }
}

/* ===========================================
   Point
   =========================================== */
.p-point {
  width: 100%;
  padding: 24px 0 16px;
  background: #fff url("../img/lp-img/point/point-bg.png") center
    center / cover no-repeat;
}

.p-point__inner {
  width: fit-content;
  max-width: min(85vw, 1050px);
  margin-inline: auto;
  padding: 0 12px;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-point__inner {
    max-width: 100%;
  }
}

.p-point__list {
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: clamp(16px, 2.1vw, 28px);
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-point__list {
    align-items: center;
    gap: clamp(16px, 2.5vw, 24px);
  }
}

.p-point__item {
  flex: 1 1 0;
  max-width: 260px;
}
.p-point__item img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-point__item {
    flex: none;
    width: clamp(60px, 27vw, 200px);
    max-width: 100%;
  }
}

.p-point__note {
  margin-top: clamp(16px, 2vw, 24px);
  font-size: clamp(0.75rem, 1.09vw, 0.875rem);
  color: #fff;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-point__note {
    font-size: 0.6875rem;
    padding: 0 16px;
    line-height: 1.7;
    letter-spacing: -0.03em;
  }
}

/* ===========================================
   CTA (common buttons)
   =========================================== */
.p-cta {
  width: 100%;
  background: #eaf1f8;
  padding: 40px 0 56px;
}

.p-lp-management-page {
  --fixed-cta-height: 80px;
  padding-bottom: calc(var(--fixed-cta-height) + env(safe-area-inset-bottom, 0px));
}

.p-fixed-cta {
  position: fixed;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: 900;
  padding-bottom: env(safe-area-inset-bottom, 0px);
}

.p-fixed-cta__inner {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.p-fixed-cta__item {
  min-height: var(--fixed-cta-height);
  display: flex;
  align-items: center;
  justify-content: center;
  column-gap: 16px;
  padding: 12px 24px;
  color: #fff;
  text-decoration: none;
  transition: filter 0.2s ease;
}

.p-fixed-cta__item--contact {
  background: #05c756;
}

.p-fixed-cta__item--document {
  background: #ff7800;
}

.p-fixed-cta__icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  color: #fff;
}

.p-fixed-cta__icon img {
  width: 100%;
  height: auto;
  display: block;
}

.p-fixed-cta__texts {
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  text-align: center;
}

.p-fixed-cta__sub {
  display: block;
  color: #fff;
  font-weight: 900;
  font-size: clamp(0.625rem, 0.7vw + 0.45rem, 1rem);
  line-height: 1.2;
  letter-spacing: 0.02em;
}

.p-fixed-cta__main {
  display: block;
  color: #fff;
  font-weight: 700;
  font-size: clamp(0.9375rem, 1.15vw + 0.7rem, 2rem);
  line-height: 1.15;
  letter-spacing: 0.02em;
  text-wrap: balance;
}

.p-fixed-cta__main--sp {
  display: none;
}

.p-fixed-cta__arrow {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  color: #fff;
}

.p-fixed-cta__arrow svg {
  width: 100%;
  height: auto;
  display: block;
}

.p-cta__inner {
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding: 0 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(16px, 2vw, 24px);
}

.p-cta__block {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.p-cta__label {
  font-weight: 500;
  font-size: clamp(1.25rem, 2.5vw, 1.875rem);
  color: #14212e;
  text-align: center;
  position: relative;
  padding: 0 16px;
  margin-bottom: 0;
}
.p-cta__label strong {
  font-weight: 700;
}
.p-cta__label::before,
.p-cta__label::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 1px;
  height: 1.1em;
  background: #14212e;
}
.p-cta__label::before {
  left: 0;
  transform: translateY(-50%) rotate(-20deg);
}
.p-cta__label::after {
  right: 0;
  transform: translateY(-50%) rotate(20deg);
}

.p-cta__btn {
  display: block;
  width: clamp(320px, 50vw, 600px);
  filter: drop-shadow(0 4px 0 rgba(20, 33, 46, 0.25));
  transform: translateY(0);
  transition:
    transform 0.15s ease-out,
    filter 0.15s ease-out;
}
.p-cta__btn img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- Media: hover devices ---------- */
@media (any-hover: hover) {
  .p-cta__btn:hover {
    transform: translateY(4px);
    filter: drop-shadow(0 0 0 rgba(20, 33, 46, 0.25));
  }

  .p-fixed-cta__item:hover {
    filter: brightness(0.96);
  }
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-lp-management-page {
    --fixed-cta-height: 72px;
  }

  .p-fixed-cta__item {
    column-gap: 12px;
    padding: 10px 16px;
  }

  .p-fixed-cta__icon {
    width: 44px;
  }

  .p-fixed-cta__sub {
    font-size: clamp(0.5625rem, 0.65vw + 0.4rem, 0.8125rem);
  }

  .p-fixed-cta__main {
    font-size: clamp(0.875rem, 0.95vw + 0.65rem, 1.375rem);
  }

  .p-fixed-cta__arrow {
    width: 14px;
  }

  .p-cta__label {
    font-size: clamp(0.75rem, 3vw, 2rem);
  }
  .p-cta__btn {
    width: clamp(320px, 58vw, 488px);
    max-width: 100%;
  }
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-lp-management-page {
    --fixed-cta-height: 64px;
  }

  .p-fixed-cta__item {
    column-gap: 8px;
    padding: 8px 10px;
  }

  .p-fixed-cta__item--contact {
    border-top-left-radius: 18px;
    border-top-right-radius: 18px;
  }

  .p-fixed-cta__item--document {
    border-top-left-radius: 18px;
    border-top-right-radius: 18px;
  }

  .p-fixed-cta__icon {
    width: clamp(20px, 3.6vw, 28px);
  }

  .p-fixed-cta__sub {
    font-size: clamp(0.375rem, 0.9vw + 0.22rem, 0.5625rem);
    letter-spacing: 0;
  }

  .p-fixed-cta__main {
    font-size: clamp(0.625rem, 1.85vw + 0.22rem, 0.9375rem);
    line-height: 1.15;
  }

  .p-fixed-cta__sub,
  .p-fixed-cta__main--pc {
    display: none;
  }

  .p-fixed-cta__main--sp {
    display: block;
  }

  .p-fixed-cta__arrow {
    width: clamp(8px, 1.4vw, 10px);
  }

  .p-cta__btn {
    width: 88vw;
    max-width: 352px;
  }
  .p-cta__label {
    font-size: clamp(0.75rem, 4vw, 1.875rem);
    color: #14212e;
    text-align: center;
    position: relative;
    padding: 0 16px;
    margin-bottom: 0;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-lp-management-page {
    --fixed-cta-height: 58px;
  }

  .p-fixed-cta__item {
    padding: 7px 8px;
  }

  .p-fixed-cta__sub {
    font-size: clamp(0.625rem, 0.95vw + 0.15rem, 0.75rem);
  }

  .p-fixed-cta__main {
    font-size: clamp(0.59375rem, 2.9vw + 0.18rem, 1rem);
  }

  .p-cta__label {
    font-size: clamp(0.625rem, 4vw, 1.0625rem);
  }
}
/* ===========================================
   Worry
   =========================================== */
.p-worry {
  position: relative;
  width: 100%;
  background: #fff;
  padding: 149px 0 240px;
  overflow: visible;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-worry {
    padding: 64px 0 240px;
  }
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-worry {
    padding: 24px 0 140px;
  }
}

.p-worry__inner {
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding: 0 12px;
}

.p-worry__person {
  position: absolute;
  right: calc(50% - 480px);
  bottom: -29px;
  width: clamp(160px, 22vw, 292px);
  z-index: 1;
  pointer-events: none;
}
.p-worry__person img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-worry__inner {
    padding: 0 16px;
  }
}

.p-worry__title {
  text-align: center;
  margin: 0 auto clamp(32px, 4vw, 52px);
}
.p-worry__title img {
  display: block;
  width: clamp(288px, 60vw, 768px);
  height: auto;
  margin-inline: auto;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-worry__title img {
    width: clamp(270px, 69vw, 768px);
  }
}

.p-worry__list {
  max-width: 980px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: clamp(20px, 1.95vw, 28px);
}

.p-worry__item {
  display: flex;
  align-items: flex-start;
  gap: 18px;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-worry__list {
    gap: 10px;
  }
  .p-worry__item {
    gap: 12px;
  }
}

.p-worry__icon {
  flex: none;
  width: 33px;
  height: 33px;
  margin-top: 4px;
  display: block;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-worry__icon {
    width: 24px;
    height: 24px;
    margin-top: 3px;
  }
}

.p-worry__text {
  margin: 0;
  font-weight: 700;
  font-size: clamp(1rem, 2.8vw, 1.4375rem);
  line-height: 1.65;
  letter-spacing: -0.01em;
  color: #14212e;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-worry__person {
    width: clamp(160px, 30vw, 240px);
    bottom: -32px;
    right: 50%;
    transform: translateX(50%);
  }
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-worry__text {
    font-size: clamp(1rem, 2.4vw, 1.4375rem);
    line-height: 1.7;
  }
  .p-worry__text span {
    display: inline-block;
  }
  .p-worry__person {
    width: 160px;
    bottom: -32px;
    right: 50%;
    transform: translateX(50%);
  }
}

/* ---------- Media: narrow smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-worry__text {
    font-size: clamp(0.75rem, 3.9vw, 1.4375rem);
  }
}
/* ===========================================
   Cause
   =========================================== */
.p-cause {
  position: relative;
  width: 100%;
  background: linear-gradient(0deg, #0c1521 0%, #132847 36%, #0c1521 100%);
  padding: 64px 0 24px;
  color: #fff;
  overflow: visible;
  z-index: 2;
}
.p-cause__triangle {
  position: absolute;
  left: 0;
  bottom: 0.5px;
  width: 100%;
  transform: translateY(100%);
  z-index: 2;
  line-height: 0;
}
.p-cause__triangle img {
  width: 100%;
  height: auto;
  display: block;
}

.p-cause__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding: 0 16px;
}

.p-cause__lead {
  position: relative;
  z-index: 0;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: clamp(24px, 2.7vw, 35px) 24px;
  background: #fff;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__lead {
    padding: 20px 16px;
  }
}

.p-cause__lead-text {
  margin: 0;
  font-weight: 700;
  font-size: clamp(1.25rem, 2.5vw, 2rem);
  line-height: 1.94;
  letter-spacing: -0.05em;
  color: #14212e;
  text-align: center;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-cause__lead {
    line-height: 2;
  }
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__lead-text {
    font-size: clamp(0.75rem, 4.5vw, 1.75rem);
    line-height: 1.85;
  }
}

.p-cause__lead-mark {
  background: linear-gradient(transparent 70%, #f4ce50 70%);
  padding: 0 2px;
}

.p-cause__lead-emphasis {
  position: relative;
  display: inline-block;
  font-size: 1.4em;
  font-weight: 900;
  color: #14212e;
  -webkit-text-stroke: 6px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 3px #fff,
    0 0 6px #fff,
    0 0 12px rgba(255, 255, 255, 0.9);
  line-height: 1;
}
.p-cause__lead-sm {
  font-size: clamp(0.875rem, 3.6vw, 1.25rem);
  font-weight: 700;
}
.p-cause__lead-emphasis::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -10px;
  height: 0.6em;
  background: #f4ce50;
  z-index: -1;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__lead-emphasis {
    -webkit-text-stroke: 5px #fff;
    font-size: clamp(1rem, 4.6vw, 1.75rem);
  }
}

.p-cause__heading {
  margin: clamp(32px, 4vw, 52px) auto 0;
  text-align: center;
}
.p-cause__heading-inner {
  display: inline-block;
  width: clamp(256px, 38.67vw, 495px);
  max-width: 90%;
}
.p-cause__heading-inner img {
  width: 100%;
  height: auto;
  display: block;
}

.p-cause__intro {
  margin: 24px auto 0;
  font-weight: 700;
  font-size: clamp(1.25rem, 2.34vw, 1.875rem);
  line-height: 1;
  letter-spacing: -0.05em;
  text-align: center;
  color: #fff;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__intro {
    font-size: 1.125rem;
  }
}

.p-cause__list {
  margin: 24px auto 0;
  max-width: clamp(600px, 79.69vw, 880px);
  display: flex;
  justify-content: center;
  gap: clamp(8px, 0.94vw, 12px);
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__list {
    flex-direction: column;
    align-items: center;
    gap: 5px;
    max-width: 354px;
    padding-left: 0;
  }
}

.p-cause__item {
  flex: 1 1 0;
  max-width: 290px;
  position: relative;
  padding-top: clamp(40px, 3.9vw, 50px);
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__item {
    flex-direction: row;
    align-items: center;
    width: 100%;
    max-width: 100%;
    padding-top: 0;
    gap: 0;
    background: #fff;
    border: 3px solid #fff;
    border-radius: 10px;
    padding: 4px 16px 4px 8px;
  }
}

.p-cause__icon {
  position: absolute;
  top: -5px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 2;
  width: 112px;
  height: auto;
  pointer-events: none;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__icon {
    position: relative;
    top: auto;
    left: auto;
    transform: none;
    width: 64px;
    flex-shrink: 0;
  }
}
.p-cause__icon img {
  width: 100%;
  height: auto;
  display: block;
}

.p-cause__box {
  width: 100%;
  height: auto;
  min-height: 180px;
  background: #fff;
  border: 3px solid #fff;
  border-radius: 20px 20px 0 0;
  display: flex;
  align-items: flex-end;
  justify-content: center;
  padding: 24px;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-cause__box {
    min-height: 160px;
    padding: 16px;
  }
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__box {
    min-height: auto;
    background: transparent;
    border: none;
    border-radius: 0;
    align-items: center;
    padding: 8px 0;
    flex: 1;
  }
}

.p-cause__box-text {
  margin: 0;
  font-weight: 700;
  font-size: clamp(1.25rem, 2.1vw, 1.8rem);
  line-height: 1.33;
  letter-spacing: -0.05em;
  text-align: center;
  color: #14212e;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__box-text {
    font-size: 1.25rem;
    text-align: left;
  }
}

.p-cause__outro {
  margin: clamp(20px, 2.5vw, 32px) auto 0;
  font-weight: 700;
  font-size: clamp(1.25rem, 2.34vw, 1.875rem);
  line-height: 1;
  letter-spacing: -0.05em;
  text-align: center;
  color: #fff;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__outro {
    font-size: 1.125rem;
  }
}

.p-cause__desc {
  margin: 40px auto 0;
  font-weight: 400;
  font-size: clamp(0.875rem, 1.56vw, 1.25rem);
  line-height: 2.45;
  letter-spacing: -0.05em;
  text-align: center;
  color: #fff;
}

.p-cause__desc span {
  display: inline-block;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__desc {
    line-height: 2;
    text-align: center;
  }
  .p-cause__desc br {
    display: none;
  }
}

.p-cause__desc-emphasis {
  font-size: 1.5rem;
  font-weight: 700;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-cause__desc-emphasis {
    font-size: 1rem;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-cause__desc {
    font-size: clamp(0.5625rem, 3.4vw, 1rem);
  }
}

/* ===========================================
   Solution
   =========================================== */
.p-solution {
  position: relative;
  width: 100%;
  padding: 140px 0 clamp(48px, 7.2vw, 92px);
  background: #fff url("../img/lp-img/solution/solution-bg.png")
    center center / cover no-repeat;
  /* WebP対応ブラウザは .webp、非対応は上の .png にフォールバック */
  background-image: image-set(
    url("../img/lp-img/solution/solution-bg.webp") type("image/webp"),
    url("../img/lp-img/solution/solution-bg.png") type("image/png")
  );
  color: #14212e;
  overflow: hidden;
}
.p-solution__triangle {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: auto;
  display: block;
  z-index: 2;
  pointer-events: none;
}

.p-solution__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding: 0 16px;
}

.p-solution__title {
  margin: 0 auto;
  text-align: center;
}
.p-solution__title img {
  width: clamp(288px, 52.8vw, 676px);
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
  filter: drop-shadow(0 0 10px rgba(9, 64, 116, 0.9));
}

.p-solution__lead {
  margin: clamp(24px, 3vw, 40px) 0 0;
  font-weight: 700;
  font-size: clamp(1rem, 1.875vw, 1.875rem);
  line-height: 1.6;
  letter-spacing: -0.09em;
  text-align: center;
  color: #14212e;
  -webkit-text-stroke: 8px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 3px #fff,
    0 0 7px #fff,
    0 0 12px rgba(255, 255, 255, 0.9);
}

.p-solution__lead-strong {
  display: inline-block;
  margin: 0.3em 0;
  font-weight: 900;
  font-size: clamp(1.375rem, 3.06vw, 3.0625rem);
  letter-spacing: -0.04em;
  line-height: 1.15;
}

.p-solution__box {
  position: relative;
  margin: clamp(24px, 2.8vw, 36px) auto 0;
  max-width: clamp(270px, 71vw, 900px);
  background: #fff;
  padding: 32px 24px;
  border-radius: 8px;
  box-shadow: 0 4px 24px rgba(9, 64, 116, 0.12);
  overflow: visible;
}

.p-solution__desc {
  margin: 0;
  font-weight: 400;
  font-size: clamp(1rem, 1.8vw, 1.4375rem);
  line-height: 1.7;
  letter-spacing: -0.08em;
  color: #14212e;
}
.p-solution__highlight-text {
  margin: 0;
  font-weight: 700;
  font-size: clamp(1rem, 2.8vw, 1.875rem);
  line-height: 1.5;
  color: #14212e;
}
.p-solution__highlight-img {
  position: absolute;
  right: -30px;
  bottom: 0;
  width: clamp(180px, 24vw, 350px);
  pointer-events: none;
}
.p-solution__highlight-img img {
  width: 100%;
  height: auto;
  display: block;
}

.p-solution__result {
  margin: clamp(28px, 3.3vw, 44px) 0 0;
  font-weight: 900;
  font-size: clamp(1.25rem, 3.06vw, 3.0625rem);
  line-height: 1.63;
  letter-spacing: -0.06em;
  text-align: center;
  color: #14212e;
  -webkit-text-stroke: 8px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 3px #fff,
    0 0 7px #fff,
    0 0 12px rgba(255, 255, 255, 0.9);
}

.p-solution__result-mark {
  position: relative;
  padding: 0 0.1em;
}
.p-solution__result-mark::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -5px;
  width: 100%;
  height: 0.6em;
  background: #f4ce50;
  z-index: -1;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-solution__box {
    padding: 20px 16px;
  }
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-solution {
    padding: 88px 0 48px;
  }
  .p-solution__title img {
    width: clamp(288px, 80.8vw, 676px);
    max-width: 100%;
  }
  .p-solution__lead {
    font-size: clamp(1rem, 4.2vw, 1.125rem);
    -webkit-text-stroke-width: 4px;
  }
  .p-solution__lead-strong {
    font-size: clamp(1rem, 5.2vw, 2rem);
    line-height: 1.2;
    -webkit-text-stroke-width: 5px;
  }
  .p-solution__box {
    max-width: clamp(270px, 69vw, 526px);
    padding: 16px 12px;
    border-radius: 10px;
  }
  .p-solution__box br {
    display: none;
  }
  .p-solution__desc {
    font-size: 0.9375rem;
    line-height: 1.85;
    letter-spacing: -0.05em;
    text-align: left;
  }
  .p-solution__desc br {
    display: none;
  }
  .p-solution__highlight-text {
    font-size: clamp(1rem, 3.7vw, 1.5rem);
  }
  .p-solution__highlight-img {
    position: relative;
    right: auto;
    bottom: auto;
    width: 160px;
    margin: 8px auto 0;
  }
  .p-solution__result {
    font-size: clamp(1rem, 4vw, 1.75rem);
    -webkit-text-stroke-width: 5px;
  }
  .p-solution__result-mark::after {
    width: 100%;
    left: -5px;
  }
}

/* ---------- Media: narrow smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-solution__box {
    width: 100%;
    max-width: 100%;
  }
  .p-solution__title img {
    width: 100%;
  }
  .p-solution__result {
    font-size: clamp(1rem, 5vw, 1.75rem);
    -webkit-text-stroke-width: 4px;
  }
  .p-solution__lead {
    font-size: clamp(0.625rem, 6.2vw, 1.125rem);
    -webkit-text-stroke-width: 5px;
  }
  .p-solution__lead-strong {
    font-size: clamp(0.75rem, 7.2vw, 2rem);
  }
  .p-solution__highlight-text {
    font-size: clamp(0.75rem, 4.7vw, 1.5rem);
  }
}
/* ===========================================
   Change
   =========================================== */
.p-change {
  width: 100%;
  padding: clamp(56px, 7.8vw, 100px) 0 clamp(56px, 8.2vw, 106px);
  background: #f2f8fd;
  color: #14212e;
}

.p-change__inner {
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding: 0 16px;
}

.p-change__title {
  width: clamp(600px, 58.28vw, 809px);
  margin: 0 auto 40px;
  text-align: center;
}

.p-change__cards {
  width: 100%;
  max-width: 1000px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(24px, 3.125vw, 40px);
  align-items: stretch;
}

.p-change-card {
  display: flex;
  flex-direction: column;
  min-height: 600px;
  border-radius: 10px;
  overflow: hidden;
}

.p-change-card--before {
  background: #d9d9d9;
  --change-color: #14212e;
  --change-result-bg: #14212e;
}

.p-change-card--after {
  background: #d7f1f4;
  --change-color: #2a899d;
  --change-result-bg: #138499;
}

.p-change-card__head {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 13px;
  padding: 20px 32px 0;
  color: var(--change-color);
}

.p-change-card__line {
  display: block;
  height: 2px;
  background: currentColor;
}

.p-change-card__title {
  margin: 0;
  min-width: 104px;
  font-weight: 700;
  font-size: clamp(1.5rem, 2.8vw, 2.1875rem);
  line-height: 1;
  text-align: center;
}

.p-change-card__title span {
  display: block;
  margin-top: 4px;
  font-size: clamp(1rem, 1.8vw, 1.25rem);
  line-height: 1.3;
}

.p-change-card__list {
  flex: 1;
  margin: 0;
  padding: 40px 24px;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.p-change-card__item {
  position: relative;
  margin: 0;
  padding-left: 32px;
  font-weight: 500;
  font-size: clamp(0.875rem, 2.38vw, 1.2rem);
  line-height: 1.45;
  letter-spacing: -0.04em;
  color: #14212e;
}

.p-change-card__item::before {
  content: "";
  position: absolute;
  top: 0.18em;
  left: 0;
  width: 20px;
  height: 20px;
  border: 2px solid var(--change-color);
  border-radius: 50%;
  background: transparent;
}

.p-change-card__item::after {
  content: "";
  position: absolute;
  top: 0.5em;
  left: 6.08px;
  width: 8px;
  height: 4px;
  border-left: 2px solid var(--change-color);
  border-bottom: 2px solid var(--change-color);
  transform: rotate(-45deg);
}

.p-change-card__result {
  min-height: 116px;
  margin-top: auto;
  padding: 8px clamp(16px, 2.3vw, 28px) 18px;
  background: var(--change-result-bg);
  color: #fff;
}

.p-change-card__result-label {
  margin: 0;
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 12px;
  font-weight: 400;
  font-size: clamp(0.875rem, 2.25vw, 1.125rem);
  line-height: 1.5;
  text-align: center;
}

.p-change-card__result-label::before,
.p-change-card__result-label::after {
  content: "";
  height: 2px;
  background: currentColor;
}

.p-change-card__result-text {
  margin: 7.2px 0 0;
  font-weight: 700;
  font-size: clamp(0.875rem, 2.1vw, 1.375rem);
  line-height: 1.35;
  letter-spacing: -0.06em;
  text-align: center;
}

.p-change__message {
  margin: clamp(32px, 4.6vw, 58px) auto 0;
  font-weight: 700;
  font-size: clamp(1.25rem, 3.125vw, 2.5rem);
  line-height: 1.45;
  letter-spacing: -0.01em;
  text-align: center;
  color: #14212e;
  -webkit-text-stroke: 8px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 3px #fff,
    0 0 7px #fff,
    0 0 12px rgba(255, 255, 255, 0.9);
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-change {
    padding: 48px 0;
  }
  .p-change__title {
    width: 100%;
    margin-bottom: 32px;
  }
  .p-change__title img {
    margin: 0 auto;
    width: clamp(288px, 80.8vw, 676px);
  }
  .p-change__cards {
    grid-template-columns: 1fr;
    max-width: 448px;
    gap: 24px;
  }
  .p-change-card {
    min-height: 0;
  }
  .p-change-card__head {
    padding: 16px 16px 0;
    gap: 10px;
  }
  .p-change-card__list {
    padding: 24px 18px 20px;
    gap: 14px;
  }
  .p-change-card__item {
    padding-left: 28px;
    font-size: 0.9375rem;
    letter-spacing: -0.03em;
  }
  .p-change-card__item::before {
    width: 18px;
    height: 18px;
  }
  .p-change-card__item::after {
    left: 5.44px;
  }
  .p-change-card__result {
    min-height: 0;
    padding: 16px;
    border-radius: 10px 10px 0 0;
  }
  .p-change-card__result-text {
    font-size: clamp(1rem, 4.2vw, 1.125rem);
    line-height: 1.5;
  }
  .p-change__message {
    font-size: clamp(1rem, 3.125vw, 1.5625rem);
    line-height: 1.65;
    -webkit-text-stroke-width: 5px;
  }
}

/* ===========================================
   Reasons (xd-file/export_0054.json)
   =========================================== */
.p-reasons {
  position: relative;
  width: 100%;
  padding: 80px 0 0;
  background-color: #253a4b;
  background-image: url(../img/lp-img/reason/reason-bg.png);
  /* WebP対応ブラウザは .webp、非対応は上の .png にフォールバック */
  background-image: image-set(
    url(../img/lp-img/reason/reason-bg.webp) type("image/webp"),
    url(../img/lp-img/reason/reason-bg.png) type("image/png")
  );
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
  color: #fff;
  overflow-x: hidden;
  overflow-y: visible;
}

.p-reasons__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 850px;
  margin-inline: auto;
  padding: 0 25px;
}

.p-reasons__title {
  margin: 0 auto clamp(32px, 4.6vw, 50px);
  font-family: "Shippori Mincho", serif;
  font-weight: 700;
  font-size: clamp(1.25rem, 3.125vw, 3.125rem);
  line-height: 1.55;
  letter-spacing: 0.06em;
  text-align: center;
  color: #fff;
}

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

.p-reasons__list {
  margin: 0 auto;
  padding: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 32px;
  max-width: 800px;
}

.p-reasons-item {
  position: relative;
  display: block;
  background: #fff;
  border-radius: 0;
  box-shadow: 0 2px 10px rgba(9, 64, 116, 0.12);
  padding: 20px 34px 34px 90px;
}

.p-reasons-item__badge {
  position: absolute;
  top: -10px;
  left: 10px;
  width: 65px;
  min-height: 70px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 7px 0 6px;
  background: #2a899d;
  font-family: "Noto Serif JP", serif;
  box-shadow: 0 2px 4px rgba(9, 64, 116, 0.2);
}

.p-reasons-item__badge::after {
  content: "";
  position: absolute;
  top: 0;
  right: -10px;
  width: 0;
  height: 0;
  border-left: 10px solid #085c6e;
  border-top: 10px solid transparent;
}

.p-reasons-item__point {
  font-family: "Noto Serif JP", serif;
  font-weight: 900;
  font-size: 0.6875rem;
  line-height: 1;
  letter-spacing: 0;
  color: #fff;
  text-transform: lowercase;
}

.p-reasons-item__num {
  margin-top: 2px;
  font-family: "Noto Serif JP", serif;
  font-weight: 900;
  font-size: 2.5rem;
  line-height: 1;
  color: #fff;
}

.p-reasons-item__body {
  min-width: 0;
  padding: 0;
}

.p-reasons-item__title {
  margin: 0 0 24px;
  font-weight: 700;
  font-size: clamp(1.5625rem, 3.9vw, 1.875rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #14212e;
}

.p-reasons-item__title--long {
  font-size: clamp(1.1875rem, 3vw, 1.5rem);
  line-height: 1.25;
}

.p-reasons-item__title-sm {
  font-size: clamp(1rem, 2.6vw, 1.25rem);
}

.p-reasons-item__title-sub {
  display: block;
  font-size: clamp(0.8125rem, 2vw, 0.9375rem);
  font-weight: 700;
  line-height: 1.3;
  margin-top: 2px;
}

.p-reasons-item__text {
  margin: 0;
  font-weight: 400;
  font-size: clamp(0.9375rem, 1.4vw, 1.125rem);
  line-height: 1.4;
  letter-spacing: -0.02em;
  color: #14212e;
}

.p-reasons-item--proposal .p-reasons-item__body {
  padding-top: 0;
}

.p-reasons-item__label {
  display: inline-block;
  margin: 0 0 24px;
  padding: 4px 12px;
  font-weight: 700;
  font-size: clamp(0.875rem, 1.4vw, 1.125rem);
  line-height: 1.4;
  color: #14212e;
  border: 1px solid #787878;
  background: #fff;
}

.p-reasons-item__rows {
  display: flex;
  flex-direction: column;
  gap: 0;
}

.p-reasons-item__row {
  display: grid;
  grid-template-columns: minmax(0, 13.5rem) minmax(0, 1fr);
  gap: 12px 8px;
  align-items: start;
  padding: 8px 0;
  border-bottom: 1px solid #bdbdbd;
}

.p-reasons-item__row:first-child {
  padding-top: 0;
}

.p-reasons-item__row-label,
.p-reasons-item__row-text {
  margin: 0;
  font-size: clamp(0.875rem, 1.4vw, 1.125rem);
  line-height: 1.4;
  letter-spacing: -0.04em;
  color: #14212e;
}

.p-reasons-item__row-label {
  font-weight: 700;
}

.p-reasons-item__row-text {
  font-weight: 400;
}

.p-reasons-item__row-text::before {
  content: "：";
  margin-right: 0.15em;
}

.p-reasons__message-wrap {
  position: relative;
  margin: 88px auto 0;
  width: 100%;
  max-width: 1280px;
  overflow: visible;
  padding-bottom: 116px;
}

.p-reasons__message {
  position: relative;
  margin: 0;
  width: 100%;
}

.p-reasons__message-text {
  position: relative;
  z-index: 1;
  margin: 0;
  font-weight: 700;
  font-size: clamp(2.125rem, 3.8vw, 2.5rem);
  line-height: 1.45;
  letter-spacing: -0.02em;
  color: #fff;
  text-align: left;
}

.p-reasons__message-em {
  color: #f4ce50;
}

.p-reasons__person {
  position: absolute;
  right: -4%;
  bottom: 0;
  z-index: 0;
  width: auto;
  max-width: none;
  line-height: 0;
  pointer-events: none;
}

.p-reasons__person img {
  width: auto;
  height: clamp(272px, 38vw, 316px);
  max-width: none;
  display: block;
  object-fit: contain;
  object-position: bottom right;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-reasons {
    padding: 48px 0 0;
  }
  .p-reasons__title {
    width: clamp(288px, 80.8vw, 676px);
  }
  .p-reasons-item {
    padding: 14px 13px 13px 68px;
  }
  .p-reasons-item__badge {
    top: -8px;
    left: 8px;
    width: 48px;
    min-height: 46px;
  }
  .p-reasons-item__badge::after {
    right: -7px;
    border-left-width: 0.4375rem;
    border-top-width: 0.4375rem;
  }
  .p-reasons-item__point {
    font-size: 0.6875rem;
  }
  .p-reasons-item__num {
    margin-top: 1.6px;
    font-size: 1.5rem;
  }
  .p-reasons-item__title {
    margin: 0 0 10px;
  }
  .p-reasons-item__text {
    font-size: 0.875rem;
    line-height: 1.78;
  }
  .p-reasons-item__row {
    grid-template-columns: 1fr;
    gap: 5.6px;
    padding: 12px 0;
  }
  .p-reasons-item__row-label {
    padding-bottom: 4px;
    border-bottom: none;
  }
  .p-reasons__message-wrap {
    margin: 40px auto 0;
    padding-bottom: 0;
  }
  .p-reasons__message-text {
    font-size: clamp(1rem, 5.125vw, 2.1875rem);
    line-height: 1.65;
    text-align: left;
  }
  .p-reasons__message-text .u-pc {
    display: none;
  }
  .p-reasons__person {
    position: relative;
    right: auto;
    bottom: auto;
    margin: 20px auto 0;
    width: min(176px, 55vw);
    pointer-events: auto;
  }
  .p-reasons__person img {
    width: 100%;
    height: auto;
  }
}

/* ---------- Media: narrow smartphone (<= 435px) ---------- */
@media (max-width: 435px) {
  .p-reasons-item {
    display: grid;
    grid-template-columns: auto 1fr;
    align-items: start;
    gap: 0 10px;
    padding: 14px 13px 16px;
  }

  .p-reasons-item__badge {
    position: relative;
    top: -22px;
    left: auto;
    display: inline-flex;
    grid-column: 1;
    grid-row: 1;
    margin-bottom: 0;
  }

  .p-reasons-item__body {
    display: contents;
  }

  .p-reasons-item__title {
    grid-column: 2;
    grid-row: 1;
    align-self: start;
    margin: 0;
    padding-top: 4px;
  }

  .p-reasons-item__text {
    grid-column: 1 / -1;
    grid-row: 2;
    margin-top: 8px;
  }

  .p-reasons-item__label {
    grid-column: 1 / -1;
    grid-row: 2;
  }

  .p-reasons-item__rows {
    grid-column: 1 / -1;
    grid-row: 3;
  }

  .p-reasons-item__row {
    grid-template-columns: 1fr;
  }
  .p-reasons__person {
    width: clamp(80px, 46vw, 140px);
  }
}

/* ===========================================
   No (xd-file/export_0056.json)
   =========================================== */
.p-no {
  position: relative;
  width: 100%;
  padding: clamp(60px, 8vw, 88px) 0 clamp(64px, 8.5vw, 96px);
  background-color: #14212e;
  background-image:
    linear-gradient(rgba(20, 33, 46, 0.62), rgba(20, 33, 46, 0.62)),
    url(../img/lp-img/fv/fv-bg.png);
  /* WebP対応ブラウザは .webp、非対応は上の .png にフォールバック */
  background-image:
    linear-gradient(rgba(20, 33, 46, 0.62), rgba(20, 33, 46, 0.62)),
    image-set(
      url(../img/lp-img/fv/fv-bg.webp) type("image/webp"),
      url(../img/lp-img/fv/fv-bg.png) type("image/png")
    );
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  color: #fff;
  overflow: hidden;
}

.p-no__inner {
  width: 100%;
  max-width: 1280px;
  margin-inline: auto;
  padding: 0 16px;
  text-align: center;
}

.p-no__question {
  margin: 0 auto 40px;
  max-width: clamp(300px, 60vw, 484px);
  font-family: "Shippori Mincho", serif;
  font-weight: 500;
  line-height: 1.2;
  letter-spacing: 0.14em;
  color: #fff;
}

.p-no__title {
  margin: 0 auto 40px;
  max-width: clamp(300px, 60vw, 830px);
}

.p-no__panel {
  position: relative;
  margin: 0 auto 40px;
  width: clamp(300px, 60vw, 830px);
  padding: clamp(1.25rem, 2.8vw, 1.75rem) clamp(1rem, 2.6vw, 1.5rem)
    clamp(1.25rem, 2.6vw, 1.75rem);
  background: #fff;
}

.p-no__corner {
  position: absolute;
  width: 31px;
  height: 31px;
  pointer-events: none;
}

.p-no__corner::before,
.p-no__corner::after {
  content: "";
  position: absolute;
  background: #5594ff;
}

.p-no__corner::before {
  width: 100%;
  height: 3.3px;
}
.p-no__corner::after {
  width: 3.3px;
  height: 100%;
}

.p-no__corner--lt {
  top: 8px;
  left: 12px;
}
.p-no__corner--lt::before {
  top: 0;
  left: 0;
}
.p-no__corner--lt::after {
  top: 0;
  left: 0;
}

.p-no__corner--lb {
  bottom: 8px;
  left: 12px;
}
.p-no__corner--lb::before {
  bottom: 0;
  left: 0;
}
.p-no__corner--lb::after {
  bottom: 0;
  left: 0;
}

.p-no__corner--rt {
  top: 8px;
  right: 12px;
}
.p-no__corner--rt::before {
  top: 0;
  right: 0;
}
.p-no__corner--rt::after {
  top: 0;
  right: 0;
}

.p-no__corner--rb {
  bottom: 8px;
  right: 12px;
}
.p-no__corner--rb::before {
  bottom: 0;
  right: 0;
}
.p-no__corner--rb::after {
  bottom: 0;
  right: 0;
}

.p-no__panel::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -20px;
  transform: translateX(-50%);
  width: 40px;
  height: 36px;
  background: #fff;
  clip-path: polygon(50% 100%, 0 0, 100% 0);
}

.p-no__keyword {
  position: relative;
  z-index: 0;
  margin: 0 auto;
  width: fit-content;
  padding: 0 0.4em;
  font-weight: 900;
  font-size: clamp(1.625rem, 4.5vw, 3.75rem);
  line-height: 1.16;
  letter-spacing: -0.02em;
  color: #14212e;
  -webkit-text-stroke: 8px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 3px #fff,
    0 0 7px #fff,
    0 0 12px rgba(255, 255, 255, 0.9);
}

.p-no__keyword::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: -0.1em;
  width: 100%;
  height: 1.5rem;
  background: #f4ce50;
  z-index: -1;
}

.p-no__lead {
  margin: 5.6px 0 0;
  font-weight: 900;
  font-size: clamp(1.0625rem, 2.3vw, 1.875rem);
  line-height: 1.2;
  letter-spacing: -0.02em;
  color: #14212e;
}

.p-no__result {
  margin: 40px auto 0;
  font-weight: 900;
  font-size: clamp(2rem, 5.2vw, 3.75rem);
  line-height: 1.35;
  letter-spacing: -0.02em;
  color: #fff;
}

.p-no__result-main {
  color: #f4ce50;
}

.p-no__result-em {
  color: #f4ce50;
}

.p-no__result-quote {
  color: #fff;
}

.p-no__result-tail {
  color: #fff;
  font-size: clamp(2rem, 4.7vw, 3.75rem);
}
.p-no__result-tail-sm {
  color: #fff;
  font-size: clamp(1.25rem, 3vw, 2.375rem);
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-no {
    padding: 52px 0 56px;
  }
  .p-no__question {
    width: 80%;
    letter-spacing: 0.08em;
    line-height: 1.35;
  }
  .p-no__title {
    max-width: clamp(300px, 80vw, 620.8px);
  }
  .p-no__panel {
    width: clamp(300px, 90vw, 620.8px);
  }
  .p-no__corner {
    width: 24px;
    height: 24px;
  }
  .p-no__corner::before {
    height: 2.88px;
  }
  .p-no__corner::after {
    width: 2.88px;
  }
  .p-no__panel::after {
    bottom: -16px;
    width: 32px;
    height: 28.8px;
  }
  .p-no__lead {
    font-size: clamp(1.0625rem, 3.3vw, 1.875rem);
  }
  .p-no__keyword {
    font-size: clamp(1.35rem, 6.5vw, 2.8rem);
    -webkit-text-stroke-width: 5px;
  }
  .p-no__result {
    font-size: clamp(1.5rem, 8.4vw, 2rem);
    line-height: 1.6;
  }
  .p-no__result-tail {
    font-size: clamp(1.5rem, 8.4vw, 2rem);
  }
  .p-no__result-tail-sm {
    font-size: clamp(1rem, 5.6vw, 1.25rem);
  }
}

/* ---------- 下線(::after)の位置をスマホで統一 ---------- */
@media (max-width: 768px) {
  .p-no__keyword::after,
  .p-cause__lead-emphasis::after,
  .p-solution__result-mark::after {
    bottom: -0.2em;
  }
}

/* ===========================================
   Compare (xd-file/export_0057.json)
   =========================================== */
.p-compare {
  width: 100%;
  background: #eaf1f8;
  padding: 24px 0 80px;
}

.p-compare__inner {
  width: 100%;
  max-width: 1050px;
  margin-inline: auto;
  padding: 0 25px;
}

.p-compare__scroll-wrap {
  position: relative;
}

.p-compare__scroll {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  padding-top: 56px;
}

.p-compare__table {
  display: grid;
  grid-template-columns: 13.5rem repeat(3, 16.25rem);
  width: 100%;
}

/* ---------- row ---------- */
.p-compare__row {
  display: contents;
}

/* ---------- cell base ---------- */
.p-compare__cell {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: 100px;
  padding: 20px 12px;
  font-weight: 500;
  font-size: 1.375rem;
  line-height: 1.36;
  text-align: center;
  color: #14212e;
  border-bottom: 1px solid #a3a3a3;
}

/* ---------- label column ---------- */
.p-compare__cell--label {
  background: #f4f4f4;
  font-weight: 500;
  border-right: 1px solid #a3a3a3;
}

/* ---------- リズムライフ column ---------- */
.p-compare__cell--rl {
  border-left: 10px solid #c8a42d;
  border-right: 10px solid #c8a42d;
  background: #fff;
  min-height: 130px;
}

.p-compare__row:last-child .p-compare__cell--rl {
  border-bottom: 10px solid #c8a42d;
}

.p-compare__row--header .p-compare__cell--rl {
  background: #c8a42d;
  border-top: 10px solid #c8a42d;
  border-radius: 35px 35px 0 0;
  border-bottom: none;
  padding: 12px 12px 16px;
  margin-top: -30px;
  overflow: visible;
}

/* ---------- A社 column ---------- */
.p-compare__cell--a {
  border-left: 1px solid #707070;
  border-right: 1px solid #707070;
  background: #fff;
}

.p-compare__row--header .p-compare__cell--a {
  background: #757575;
  border-bottom: none;
  padding: 16px 12px;
}

/* ---------- B社 column ---------- */
.p-compare__cell--b {
  border-left: 1px solid #707070;
  border-right: 1px solid #707070;
  background: #fff;
}

.p-compare__row--header .p-compare__cell--b {
  background: #a3a3a3;
  border-bottom: none;
  padding: 16px 12px;
}

/* ---------- header row ---------- */
.p-compare__row--header .p-compare__cell--label {
  border-bottom: none;
  background: transparent;
  border-right: none;
}

/* ---------- header content ---------- */
.p-compare__header-rl {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
}

.p-compare__crown {
  width: 69px;
  height: auto;
  display: block;
  margin-top: -56px;
}

.p-compare__logo {
  width: 212px;
  height: auto;
  display: block;
}

.p-compare__header-text {
  font-weight: 700;
  font-size: 1.375rem;
  line-height: 1;
  color: #fff;
}

.p-compare__header-other {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  font-weight: 700;
  font-size: clamp(1.125rem, 2.2vw, 1.375rem);
  line-height: 1.36;
  letter-spacing: -0.02em;
  color: #fff;
}

/* ---------- icon backgrounds ---------- */
.p-compare__cell--circle {
  background: url("../img/lp-img/compare/compare-circle.png") center
    center / 5.5rem auto no-repeat #fff;
}

.p-compare__cell--triangle {
  background: url("../img/lp-img/compare/compare-triangle.png") center
    center / 5rem auto no-repeat #fff;
}

/* ---------- cell text ---------- */
.p-compare__text {
  margin: 0;
  position: relative;
  z-index: 1;
  font-weight: 500;
  font-size: clamp(1.125rem, 2.2vw, 1.375rem);
  line-height: 1.36;
  letter-spacing: -0.04em;
  text-align: center;
}

.p-compare__dot {
  font-size: 1em;
  vertical-align: middle;
  color: #14212e;
  margin: 0 -0.25em;
  display: inline-block;
}

/* ---------- ScrollHint CDN override ---------- */
.scroll-hint-icon {
  animation-duration: 2.4s;
}

/* ---------- SP: horizontal scroll ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-compare {
    padding: 40px 0;
  }

  .p-compare__inner {
    padding: 0;
  }

  .p-compare__scroll {
    padding: 32px 16px 0;
  }

  .p-compare__table {
    grid-template-columns: 8.5rem repeat(3, 13rem);
    min-width: 760px;
  }

  .p-compare__cell {
    min-height: 5.5rem; /* SP */
    font-size: 0.8125rem;
    line-height: 1.4;
    padding: 14px 8px;
  }

  .p-compare__text {
    font-size: 0.8125rem;
    line-height: 1.4;
  }

  .p-compare__header-text {
    font-size: 0.875rem;
  }

  .p-compare__header-other {
    font-size: 0.875rem;
  }

  .p-compare__crown {
    width: 44px;
  }

  .p-compare__logo {
    width: 136px;
  }

  .p-compare__cell--circle {
    background-size: 60px auto;
  }

  .p-compare__cell--triangle {
    background-size: 52px auto;
  }

  .p-compare__row--header .p-compare__cell--rl {
    border-radius: 16px 16px 0 0;
    margin-top: -16px;
  }
}

/* ===========================================
   Plan – 定額サービス (xd-file/export_0058)
   =========================================== */
.p-plan {
  padding: clamp(48px, 5.6vw, 72px) 0;
  background: #eaf1f8;
}

.p-plan__inner {
  max-width: 1050px;
  padding: 0 24px;
  margin-inline: auto;
}

.p-plan__box {
  background: #fff;
  border-radius: 26px;
  padding: 40px 24px;
}

/* ---------- icon ---------- */
.p-plan__icon {
  width: 60px;
  margin: clamp(32px, 3.5vw, 48px) auto 0;
}

.p-plan__icon img {
  width: 100%;
  height: auto;
}

/* ---------- title ---------- */
.p-plan__title {
  margin: 16px 0 0;
  font-size: clamp(1.5rem, 2.8vw, 1.875rem);
  font-weight: 900;
  color: #14212e;
  text-align: center;
  letter-spacing: 0.01em;
  line-height: 1.4;
}

.p-plan__title-no {
  font-size: 0.7em;
}

/* ---------- pricing ---------- */
.p-plan__pricing {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 16px;
  margin-top: clamp(16px, 2vw, 24px);
}

.p-plan__pricing-label {
  font-size: clamp(0.875rem, 1.5vw, 1.25rem);
  font-weight: 700;
  color: #14212e;
  letter-spacing: 0.01em;
}

.p-plan__pricing-price {
  font-size: clamp(1.5rem, 3vw, 2.25rem);
  font-weight: 900;
  color: #14212e;
  letter-spacing: 0.05em;
  line-height: 1.3;
}

.p-plan__pricing-num {
  font-size: 1.8em;
  font-weight: 900;
  color: #14212e;
}

.p-plan__pricing-tax {
  font-size: 0.45em;
  font-weight: 500;
  margin-left: -0.5em;
}

/* ---------- dots ---------- */
.p-plan__dots {
  height: 12px;
  background: radial-gradient(circle, #a6aeb6 0.3125rem, transparent 0.3125rem)
    repeat-x center / 1.5rem 0.75rem;
  width: min(790px, 100%);
  margin: clamp(24px, 2.5vw, 32px) auto 0;
}

/* ---------- example ---------- */
.p-plan__example {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 0;
  max-width: 700px;
  margin: 40px auto 0;
}

.p-plan__example-badge {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 64px;
  height: 64px;
  background: #f4ce50;
  color: #14212e;
  font-size: 1.125rem;
  font-weight: 700;
  border-radius: 50%;
  position: absolute;
  top: -20px;
  left: -12px;
  z-index: 1;
}

.p-plan__example-body {
  flex: 1;
  background: #fff;
  border: 5px solid #2e4a66;
  border-radius: 30px;
  padding: 20px 30px 20px 60px;
}

.p-plan__example-text {
  margin: 0;
  font-size: clamp(1rem, 2.2vw, 1.125rem);
  font-weight: 500;
  color: #14212e;
  line-height: 1.5;
}

.p-plan__example-text strong {
  font-weight: 700;
}

.p-plan__example-red {
  color: #9d2525;
  font-weight: 700;
}

.p-plan__example-note {
  margin: 8px 0 0;
  font-size: clamp(0.8125rem, 1.8vw, 0.9375rem);
  font-weight: 500;
  color: #14212e;
  line-height: 1.6;
}

/* ---------- cover section ---------- */
.p-plan__cover {
  margin-top: clamp(40px, 4vw, 56px);
  text-align: center;
}

.p-plan__cover-lead {
  margin: 0;
  font-size: clamp(10px, 4vw, 1.875rem);
  font-weight: 500;
  color: #14212e;
  letter-spacing: 0.05em;
  line-height: 1.6;
}

.p-plan__cover-icons {
  display: flex;
  justify-content: center;
  gap: clamp(24px, 4vw, 40px);
  margin-top: 24px;
}

.p-plan__cover-icon-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.p-plan__cover-icon-badge {
  display: inline-block;
  background: #2e4a66;
  color: #fff;

  font-size: clamp(0.813rem, 1.6vw, 1.25rem);
  font-weight: 500;
  padding: 0.2em 1.2em;
  border-radius: 15px;
  line-height: 1.4;
}

.p-plan__cover-icon-img {
  width: clamp(55px, 7vw, 85px);
  height: auto;
}

.p-plan__cover-sub {
  margin: 18px 0 0;
  font-size: clamp(1.125rem, 2.5vw, 1.875rem);
  font-weight: 500;
  color: #14212e;
  line-height: 1.3;
}

.p-plan__cover-strong {
  margin: 40px 0 0;
  font-size: clamp(1.25rem, 2.5vw, 1.875rem);
  font-weight: 900;
  color: #14212e;
  line-height: 1.3;
}

.p-plan__cover-emphasis {
  font-size: clamp(1.25rem, 2.8vw, 2.5rem);
  color: #14212e;
}

.p-plan__cover-note {
  margin: 24px 0 0;
  font-size: clamp(1rem, 1.5vw, 1.125rem);
  font-weight: 400;
  color: #14212e;
  letter-spacing: -0.01em;
}

/* ---------- compare section ---------- */
.p-plan__compare {
  margin-top: clamp(40px, 4vw, 56px);
}

.p-plan__compare-title {
  margin: 0 auto;
  font-weight: 700;
  color: #14212e;
  text-align: center;
  letter-spacing: 0.05em;
}

.p-plan__compare-title-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}

.p-plan__compare-title-row img {
  height: clamp(32px, 3.5vw, 44px);
  width: auto;
}

.p-plan__compare-title-large {
  font-size: clamp(1.75rem, 3.2vw, 2.5rem);
  white-space: nowrap;
}

.p-plan__compare-title-small {
  font-size: 0.55em;
  font-weight: 700;
}

.p-plan__compare-title-sub {
  display: block;
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  letter-spacing: 0.08em;
  margin-top: 2px;
}

/* ---------- table ---------- */
.p-plan__table {
  width: 100%;
  max-width: 700px;
  margin: 24px auto 0;
  border-collapse: collapse;
}

.p-plan__th {
  background: #f4ce50;
  color: #14212e;
  font-size: clamp(0.75rem, 1.2vw, 0.9375rem);
  font-weight: 500;
  padding: 12px 16px;
  text-align: center;
  border: 1px solid #8c8c8c;
  letter-spacing: 0.05em;
  line-height: 1.4;
}

.p-plan__th--wide {
  width: 50%;
}

.p-plan__td {
  background: #fff;
  color: #14212e;
  font-size: clamp(1.25rem, 1.4vw, 1.5rem);
  font-weight: 700;
  padding: 12px 16px;
  text-align: center;
  border: 1px solid #d9d9d9;
  line-height: 1.4;
}

.p-plan__td--highlight {
  color: #be1111;
  font-weight: 700;
  font-size: clamp(1rem, 1.9vw, 1.5625rem);
}

.p-plan__td--highlight strong {
  font-size: clamp(1.5rem, 3.1vw, 2.5rem);
  font-weight: 900;
}

.p-plan__td-unit {
  font-weight: 900;
}

.p-plan__td-otoku {
  font-size: clamp(1.5rem, 3.1vw, 2.5rem);
  font-weight: 900;
}

/* ---------- table note ---------- */
.p-plan__table-note {
  margin: 16px 0 0;
  font-size: clamp(1.125rem, 2.5vw, 1.5625rem);
  font-weight: 500;
  color: #14212e;
  text-align: center;
  line-height: 1.8;
  letter-spacing: -0.01em;
}

.p-plan__table-note strong {
  font-weight: 700;
}

/* ---------- person area ---------- */
.p-plan__person-area {
  position: relative;
  margin-top: 62px;
}

.p-plan__person {
  position: absolute;
  bottom: -76px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 0;
  width: clamp(170px, 13vw, 204px);
}

.p-plan__person img {
  width: 100%;
  height: auto;
}

/* ---------- voices (single oval) ---------- */
.p-plan__voices {
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: #fff;
  border: 5px solid #2e4a66;
  border-radius: 90px;
  padding: 24px 40px;
  margin: 0 auto;
  max-width: clamp(160px, 80.5vw, 820px);
  min-height: clamp(128px, 12vw, 160px);
}

.p-plan__voice-text {
  margin: 0;
  font-size: clamp(1.125rem, 2.1vw, 1.5rem);
  font-weight: 700;
  color: #14212e;
  line-height: 1.5;
  letter-spacing: -0.01em;
  text-align: center;
  max-width: 45%;
}

/* ---------- CTA ---------- */
.p-plan__cta {
  position: relative;
  z-index: 1;
  margin-top: 40px;
  text-align: center;
  padding-bottom: 8px;
}

.p-plan__cta-text {
  margin: 0;
  font-size: clamp(1.5rem, 3.1vw, 2.5rem);
  font-weight: 700;
  color: #14212e;
  line-height: 1.6;
  letter-spacing: 0.01em;
  -webkit-text-stroke: 8px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 3px #fff,
    0 0 7px #fff,
    0 0 12px rgba(255, 255, 255, 0.9);
}

.p-plan__cta-em {
  position: relative;
  display: inline;
  font-weight: 900;
}

.p-plan__cta-em::after {
  content: "";
  position: absolute;
  left: -9px;
  right: 0;
  bottom: -3px;
  width: 105%;
  height: 0.6em;
  background: #f4ce50;
  z-index: -1;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-plan__title {
    font-size: clamp(0.8rem, 4.8vw, 1.2rem);
  }
  .p-plan__pricing-label {
    font-size: clamp(10px, 4vw, 2.5rem);
  }
  .p-plan__pricing-price {
    font-size: clamp(13px, 4.7vw, 2.5rem);
  }
  .p-plan__pricing {
    margin: 0 auto;
    gap: 0;
  }
  .p-plan__cover-icon-img {
    width: clamp(55px, 8vw, 85px);
  }
  .p-plan__pricing-value {
    font-size: clamp(1.5rem, 3.1vw, 2.5rem);
  }
  .p-plan__pricing-unit {
    font-size: clamp(1.125rem, 2.1vw, 1.5rem);
  }
  .p-plan__pricing-unit {
    font-size: clamp(1.125rem, 2.1vw, 1.5rem);
  }
  .p-plan__voices {
    margin: 0 auto;
    padding: 20px 24px;
    width: clamp(160px, 80.5vw, 704px);
    min-height: 112px;
  }
}
/* ---------- SP ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-plan {
    padding: 40px 0;
  }

  .p-plan__inner {
    padding: 0 16px;
  }

  .p-plan__box {
    padding: 40px 16px;
  }

  .p-plan__example-body {
    padding: 16px;
  }

  .p-plan__example-text br {
    display: none;
  }

  .p-plan__cover-icons {
    gap: 16px;
  }

  .p-plan__cover-icon-badge {
    font-size: 0.75rem;
    padding: 0.15em 0.8em;
  }

  .p-plan__cover-icon-img {
    width: 50px;
  }

  .p-plan__cover-strong {
    margin: 24px 0 0;
    font-size: clamp(10px, 3.7vw, 1.875rem);
  }

  .p-plan__compare-title-large {
    font-size: clamp(10px, 5.7vw, 1.5rem);
  }

  .p-plan__compare-title-sub {
    font-size: 1rem;
  }

  .p-plan__table-note {
    text-align: left;
  }

  .p-plan__table-note br {
    display: none;
  }

  .p-plan__voice-text {
    font-size: clamp(0.625rem, 2.7vw, 1.125rem);
    max-width: 38%;
    letter-spacing: -0.03em;
  }

  .p-plan__person {
    bottom: -38px;
    width: clamp(90px, 25vw, 155px);
  }

  .p-plan__voices {
    width: 100%;
    min-height: 116px;
    padding: 18px 16px;
    border-width: 5px;
    border-radius: 64px;
  }

  .p-plan__cta-text {
    font-size: clamp(1.25rem, 3.7vw, 2.5rem);
    -webkit-text-stroke-width: 3px;
    text-shadow:
      0 0 2px #fff,
      0 0 4px #fff,
      0 0 7px rgba(255, 255, 255, 0.9);
  }
  .p-plan__cover-emphasis {
    font-size: clamp(10px, 5.8vw, 2.5rem);
  }
  .p-plan__cover-note {
    line-height: 1.3;
    font-size: clamp(10px, 1.5vw, 1.125rem);
  }
  .p-plan__compare-title-row img {
    height: clamp(18px, 6.5vw, 44px);
    width: auto;
  }
  .p-plan__td {
    font-size: clamp(10px, 3.4vw, 1.5rem);
    font-weight: 500;
    padding: 12px 8px;
    line-height: 1.3;
  }
  .p-plan__cta {
    margin-top: 16px;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-plan__example-badge {
    width: 40px;
    height: 40px;
  }

  .p-plan__dots {
    margin-top: 8px;
    height: 8px;
    background: radial-gradient(circle, #a6aeb6 2.5px, transparent 2.5px)
      repeat-x center / 11px 8px;
  }

  .p-plan__cover-icons {
    width: 100%;
    justify-content: space-between;
    gap: 0;
    margin-top: 20px;
  }

  .p-plan__cover-icon-item {
    flex: 1 1 0;
    min-width: 0;
    gap: 10px;
  }

  .p-plan__cover-icon-badge {
    font-size: clamp(0.8125rem, 3.6vw, 0.9375rem);
    padding: 0.25em 0.75em;
    white-space: nowrap;
  }

  .p-plan__cover-icon-img {
    width: clamp(62px, 18vw, 76px);
  }

  .p-plan__pricing-price {
    font-size: clamp(13px, 4.7vw, 2.5rem);
  }
  .p-plan__voices {
    max-width: 100%;
    padding: 20px 8px;
  }
}

/* ===========================================
   Voice – お客様の声 (xd-file/export_0060.json)
   =========================================== */
.p-voice {
  background: url("../img/lp-img/voice/voice-bg.png") center / cover
    no-repeat;
  /* WebP対応ブラウザは .webp、非対応は上の .png にフォールバック */
  background-image: image-set(
    url("../img/lp-img/voice/voice-bg.webp") type("image/webp"),
    url("../img/lp-img/voice/voice-bg.png") type("image/png")
  );
  padding: 80px 0 96px;
}

.p-voice__inner {
  max-width: 800px;
  margin: 0 auto;
  padding: 0 20px;
}

.p-voice__title {
  text-align: center;
  margin: 0 0 16px;
}

.p-voice__title img {
  display: inline-block;
  max-width: 280px;
  width: 100%;
  height: auto;
}

.p-voice__divider {
  width: 120px;
  height: 5px;
  background: #fff;
  margin: 0 auto 20px;
}

.p-voice__lead {
  text-align: center;
  color: #fff;
  font-size: 1.4375rem;
  font-weight: 500;
  margin: 0 0 48px;
  letter-spacing: 0.01em;
}

.p-voice__list {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

/* ---------- card ---------- */
.p-voice-card {
  position: relative;
  background: #fff;
  border-radius: 0;
  padding: 24px 32px 32px;
}

.p-voice-card__badge {
  position: absolute;
  top: 8px;
  right: 24px;
  width: 160px;
}

.p-voice-card__badge img {
  width: 100%;
  height: auto;
}

.p-voice-card__body {
  display: flex;
  gap: 24px;
}

.p-voice-card__photo {
  flex-shrink: 0;
  width: 186px;
  height: 196px;
  overflow: hidden;
  background: #a9a4a4;
}

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

.p-voice-card__content {
  margin-top: 40px;
}

.p-voice-card__name {
  font-size: 1.25rem;
  font-weight: 700;
  color: #14212e;
  margin: 0 0 12px;
}

.p-voice-card__name-br {
  display: none;
}

.p-voice-card__heading {
  font-size: clamp(1.25rem, 2.1vw, 1.6875rem);
  font-weight: 700;
  color: #14212e;
  line-height: 1.3;
  margin: 0 0 20px;
  letter-spacing: 0.01em;
}

.p-voice-card__heading-top,
.p-voice-card__heading-bottom {
  display: inline;
}

.p-voice-card__text {
  font-size: 1.125rem;
  line-height: 1.85;
  color: #14212e;
  margin: 0;
}

/* ---------- Voice SP ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-voice {
    padding: 48px 0 64px;
  }

  .p-voice__lead {
    font-size: 1rem;
  }
}

/* ---------- Media: smartphone (<= 650px) ---------- */
@media (max-width: 650px) {
  .p-voice-card {
    display: grid;
    grid-template-columns: 7.5rem 1fr;
    grid-template-rows: auto auto auto auto;
    gap: 0 12px;
    padding: 20px 16px 24px;
  }

  .p-voice-card__body {
    display: contents;
  }

  .p-voice-card__content {
    display: contents;
  }

  .p-voice__list {
    max-width: 800px;
  }

  /* 写真: 120x120 正方形、name+badge行をspan */
  .p-voice-card__photo {
    grid-column: 1;
    grid-row: 1 / 3;
    width: 120px;
    height: 120px;
    overflow: hidden;
  }

  .p-voice-card__name {
    grid-column: 2;
    grid-row: 1;
    align-self: end;
    font-size: clamp(10px, 4.7vw, 1.125rem);
    letter-spacing: -0.01em;
    margin: 0 0 4px;
  }

  .p-voice-card__badge {
    position: relative;
    top: auto;
    right: auto;
    grid-column: 2;
    grid-row: 2;
    width: clamp(40px, 29vw, 100px);
    margin: 0;
    align-self: start;
    margin-left: auto;
  }

  .p-voice-card__heading {
    display: flex;
    grid-column: 1 / -1;
    grid-row: 3;
  }

  .p-voice-card__heading br {
    display: none;
  }

  /* heading span: 上を左寄せ、下を右寄せ */
  .p-voice-card__heading-top,
  .p-voice-card__heading-bottom {
    display: block;
  }

  .p-voice-card__heading-top {
    text-align: left;
  }

  .p-voice-card__heading-bottom {
    text-align: right;
  }

  .p-voice-card__text {
    grid-column: 1 / -1;
    grid-row: 4;
    font-size: 0.8125rem;
    line-height: 2;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-voice-card__heading {
    flex-direction: column;
    font-size: clamp(10px, 6.7vw, 2.125rem);
    margin: 12px 0 8px;
  }
}

/* ===========================================
   PDF Present – スライド資料プレゼント (xd-file/export_0061.json)
   =========================================== */
.p-pdf-present {
  position: relative;
  overflow: hidden;
  padding: 80px 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.p-pdf-present__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
}

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

.p-pdf-present__inner {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0;
  width: 100%;
  max-width: 844px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ---------- document card (SVG frame) ---------- */
.p-pdf-present__document {
  position: relative;
  width: 100%;
  max-width: 675px;
  aspect-ratio: 675 / 532;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 110px 24px 32px;
}

.p-pdf-present__frame {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
}

/* ---------- sara (image) ---------- */
.p-pdf-present__sara {
  width: clamp(200px, 21vw, 310px);
  margin: 0 auto -58px;
  position: relative;
  z-index: 2;
  top: 26px;
}

.p-pdf-present__sara img {
  width: 100%;
  height: auto;
  display: block;
}

.p-pdf-present__document-body {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.p-pdf-present__document-title {
  position: relative;
  margin-top: -90px;
  font-weight: 700;
  font-size: clamp(2rem, 3.8vw, 3.125rem);
  line-height: 1.3;
  text-align: center;
  color: #14212e;
  -webkit-text-stroke: 8px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 3px #fff,
    0 0 7px #fff,
    0 0 12px rgba(255, 255, 255, 0.9);
  padding-bottom: 0.2em;
}

.p-pdf-present__document-title::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 2px;
  height: 30px;
  background: #f5c500;
  z-index: -1;
}

.p-pdf-present__document-title-small {
  font-size: 1.5625rem;
  font-weight: 700;
}

.p-pdf-present__document-thumb {
  margin-top: 8px;
  width: clamp(64px, 10vw, 84px);
  height: auto;
}

.p-pdf-present__document-thumb img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- ribbon (image) ---------- */
.p-pdf-present__ribbon {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 842px;
  margin-top: -120px;
  text-align: center;
}

.p-pdf-present__ribbon img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-pdf-present__sara {
    width: clamp(272px, 40.5vw, 310px);
  }
  .p-pdf-present__document-title {
    margin-top: -106px;
    font-size: clamp(3.25rem, 4.6vw, 4.1875rem);
  }
  .p-pdf-text__person img {
    height: clamp(252px, 34vw, 290px);
  }
  .p-pdf-text__announce-bottom-text {
    font-size: clamp(1.25rem, 2.7vw, 1.875rem);
  }
}

/* ---------- responsive ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-pdf-present {
    padding: 48px 0;
  }

  .p-pdf-present__sara {
    width: clamp(160px, 46vw, 272px);
    margin-bottom: -40px;
  }

  .p-pdf-present__document {
    aspect-ratio: 675 / 580;
    padding: 80px 20px 24px;
    max-width: clamp(320px, 85vw, 675px);
  }

  .p-pdf-present__frame {
    height: 100%;
  }

  .p-pdf-present__document-title {
    margin-top: -32px;
    font-size: clamp(1.5rem, 5.6vw, 2.3rem);
    line-height: 1.5;
  }

  .p-pdf-present__document-title::after {
    height: 1em;
    left: -5px;
    bottom: -2px;
  }

  .p-pdf-present__document-title-small {
    font-size: clamp(0.75rem, 2.8vw, 1rem);
  }

  .p-pdf-present__document-thumb {
    width: clamp(48px, 9vw, 84px);
  }

  .p-pdf-present__ribbon {
    margin-top: 0;
    top: -12vw;
    width: 100%;
    max-width: 100%;
  }
}

@media (max-width: 425px) {
  .p-pdf-present__sara {
    width: 44vw;
    margin-bottom: -32px;
  }

  .p-pdf-present__document {
    aspect-ratio: 675 / 560;
    padding: 64px 16px 20px;
    max-width: 92vw;
  }

  .p-pdf-present__document-title {
    margin-top: -24px;
    font-size: 5.3vw;
  }

  .p-pdf-present__ribbon {
    top: -10vw;
  }
}
/* ---------- Media: smartphone (<= 768px) ---------- */

/* ===========================================
   PDF Text – PDFプレゼント文章 (xd-file/export_0063.json)
   =========================================== */
.p-pdf-text {
  background: #eaf1f8;
  padding: 64px 0 56px;
}

.p-pdf-text__inner {
  width: 100%;
  max-width: 1050px;
  margin-inline: auto;
  padding: 0 25px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ---------- head (title + koma) ---------- */
.p-pdf-text__head {
  position: relative;
  width: 100%;
  max-width: 800px;
  overflow: visible;
}

.p-pdf-text__title {
  /* margin-left: 3.5rem; */
  margin-bottom: 40px;
  font-weight: 700;
  font-size: clamp(1.25rem, 2.7vw, 2.1875rem);
  line-height: 1.5;
  letter-spacing: -0.01em;
  color: #14212e;
}

.p-pdf-text__person {
  position: absolute;
  right: -6px;
  bottom: 0;
  z-index: 2;
  width: auto;
  max-width: none;
  line-height: 0;
  pointer-events: none;
}

.p-pdf-text__person img {
  width: auto;
  height: clamp(300px, 42vw, 338px);
  max-width: none;
  display: block;
  object-fit: contain;
  object-position: bottom right;
}

.p-pdf-text__koma {
  flex-shrink: 0;
  width: clamp(112px, 15vw, 248px);
}

.p-pdf-text__koma img {
  width: 100%;
  height: auto;
  display: block;
}

/* ---------- announce box ---------- */
.p-pdf-text__announce {
  width: 100%;
  max-width: 800px;
  border: 3px solid #2e4a66;
  border-radius: 15px;
  overflow: hidden;
  margin-bottom: 24px;
}

.p-pdf-text__announce-top {
  position: relative;
  background: #fff;
  padding: 28px 32px;
  text-align: center;
  z-index: 1;
}

.p-pdf-text__announce-top::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, 50%);
  width: 0;
  height: 0;
  border-left: 52px solid transparent;
  border-right: 52px solid transparent;
  border-top: 32px solid #fff;
  z-index: 2;
}

.p-pdf-text__announce-top-text {
  font-weight: 500;
  font-size: clamp(1rem, 2vw, 1.625rem);
  line-height: 1.58;
  letter-spacing: -0.01em;
  color: #14212e;
  margin: 0;
}

.p-pdf-text__announce-bottom {
  background: #253a4b;
  padding: 28px 32px;
  text-align: center;
}

.p-pdf-text__announce-bottom-text {
  font-weight: 900;
  font-size: clamp(2rem, 2.3vw, 1.875rem);
  line-height: 1.5;
  letter-spacing: -0.01em;
  color: #fff;
  margin: 0;
}

.p-pdf-text__announce-highlight {
  color: #f4ce50;
  font-weight: 900;
}

.p-pdf-text__announce-pdf {
  font-size: 1.25rem;
  color: #fff;
}

/* ---------- cards ---------- */
.p-pdf-text__cards {
  display: flex;
  gap: 16px;
  width: 100%;
  max-width: 880px;
  margin-bottom: 40px;
}

.p-pdf-text__card {
  flex: 1;
  border-radius: 15px;
  overflow: hidden;
}

.p-pdf-text__card-header {
  padding: 16px 24px;
  text-align: center;
}

.p-pdf-text__card-header--red {
  background: #a71010;
}

.p-pdf-text__card-header--navy {
  background: #253a4b;
}

.p-pdf-text__card-heading {
  font-weight: 900;
  font-size: clamp(1.125rem, 2.3vw, 1.875rem);
  line-height: 1.47;
  letter-spacing: -0.01em;
  color: #fff;
  margin: 0;
}

.p-pdf-text__card-body {
  min-height: 180px;
  background: #fff;
  padding: 24px 6px 32px 13px;
  border: 3px solid;
  border-top: none;
  border-bottom-width: 0.375rem;
  border-radius: 0 0 15px 15px;
}

.p-pdf-text__card--benefit .p-pdf-text__card-body {
  border-color: #a71010;
}

.p-pdf-text__card--recommend .p-pdf-text__card-body {
  border-color: #253a4b;
}

.p-pdf-text__card-list {
  list-style: none;
  margin: 0;
  padding: 0;
  font-weight: 500;
  font-size: clamp(0.875rem, 1.8vw, 1.25rem);
  line-height: 1.5;
  letter-spacing: -0.01em;
  color: #14212e;
}

.p-pdf-text__card-list li {
  padding-left: 0.6em;
  text-indent: -0.6em;
  margin-bottom: 8px;
}

.p-pdf-text__card-list li::before {
  content: "・";
  display: inline-block;
  width: 0.2em;
  text-align: center;
}

/* ---------- bottom text ---------- */
.p-pdf-text__bottom {
  font-weight: 700;
  font-size: clamp(1.125rem, 2.3vw, 1.875rem);
  line-height: 1.83;
  letter-spacing: -0.01em;
  text-align: center;
  color: #14212e;
  margin: 0 0 32px;
}

/* ---------- Media: tablet and below (<= 1024px) ---------- */
@media (max-width: 1024px) {
  .p-pdf-text__title {
    font-size: clamp(1.25rem, 4vw, 2.1875rem);
  }
  .p-pdf-text__card-list {
    font-size: clamp(10px, 3.9vw, 1.6rem);
    line-height: 1.5;
    letter-spacing: -0.01em;
    color: #14212e;
  }
  .p-pdf-text__card-heading {
    font-size: clamp(1.125rem, 3.3vw, 3.875rem);
  }
  .p-pdf-text__bottom {
    font-size: clamp(1.125rem, 3vw, 2.875rem);
  }
}

/* ---------- responsive ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-pdf-text {
    padding: 40px 0 40px;
  }

  .p-pdf-text__title {
    font-size: clamp(0.875rem, 4.1vw, 1.125rem);
  }

  .p-pdf-text__person img {
    height: clamp(224px, 32vw, 300px);
  }

  .p-pdf-text__koma {
    width: 128px;
  }

  .p-pdf-text__announce-top,
  .p-pdf-text__announce-bottom {
    padding: 20px 16px;
  }

  .p-pdf-text__cards {
    flex-direction: column;
    gap: 16px;
  }
  .p-pdf-text__announce-top-text {
    font-size: clamp(1rem, 3.3vw, 1.625rem);
  }
  .p-pdf-text__card-body {
    padding: 24px 22px 32px 29px;
    border: 3px solid;
    border-top: none;
    border-bottom-width: 0.375rem;
    border-radius: 0 0 15px 15px;
  }

  .p-pdf-text__bottom br {
    display: none;
  }

  .p-pdf-text__bottom-line {
    display: inline-block;
  }
  .p-pdf-text__bottom {
    font-size: clamp(0.625rem, 3.5vw, 1.0625rem);
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-pdf-text__announce-top-text {
    font-size: clamp(10px, 3.6vw, 0.9375rem);
  }
  .p-pdf-text__person {
    right: -4px;
    width: clamp(80px, 28vw, 124px);
  }
  .p-pdf-text__person img {
    width: 100%;
    height: clamp(192px, 46vw, 268px);
  }

  .p-pdf-text__announce-bottom-text {
    font-size: clamp(0.875rem, 4.5vw, 1.25rem);
  }

  .p-pdf-text__announce-highlight {
    font-size: clamp(0.875rem, 4.1vw, 1.25rem);
  }

  .p-pdf-text__announce-pdf {
    font-size: 0.5375rem;
  }
  .p-pdf-text__card-body {
    min-height: auto;
    padding: 24px 3vw;
  }
  .p-pdf-text__title {
    font-size: clamp(0.875rem, 5.1vw, 1.125rem);
  }
}

/* ---------- Media: small smartphone (<= 375px) ---------- */
@media (max-width: 375px) {
  .p-pdf-text__head {
    text-align: center;
  }

  .p-pdf-text__person {
    position: relative;
    right: auto;
    bottom: auto;
    margin: 20px auto 0;
    width: min(176px, 55vw);
  }

  .p-pdf-text__person img {
    width: 100%;
    height: auto;
  }
}

/* ===========================================
   Flow – ご相談から管理までの流れ (xd-file/export_0064.json)
   =========================================== */
.p-flow {
  background: linear-gradient(180deg, #507da0 0%, #253a4b 100%);
  padding: 80px 0 96px;
}

.p-flow__inner {
  max-width: 1050px;
  margin: 0 auto;
  padding: 0 25px;
}

/* ---------- title ---------- */
.p-flow__title {
  text-align: center;
  margin: 0 0 56px;
}

.p-flow__title img {
  display: inline-block;
  max-width: 600px;
  width: 100%;
  height: auto;
}

/* ---------- step list ---------- */
.p-flow__steps {
  display: flex;
  flex-direction: column;
}

/* ---------- single step ---------- */
.p-flow-step {
  display: flex;
  align-items: flex-start;
  gap: 24px;
}

/* -- left column (label + circle + dots) -- */
.p-flow-step__left {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex-shrink: 0;
  width: 126px;
}

.p-flow-step__label {
  display: block;
  width: 80px;
  height: auto;
  margin-bottom: 8px;
}

.p-flow-step__circle {
  width: 126px;
  height: 126px;
  border-radius: 50%;
  background: #f4ce50;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.p-flow-step__circle--dark {
  background: #253a4b;
}

.p-flow-step__circle img {
  width: auto;
  height: auto;
  max-width: 70%;
  max-height: 60%;
}

/* -- vertical dots connecting steps -- */
.p-flow-step__dots {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 12px 0;
}

.p-flow-step__dots span {
  display: block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff3cd;
}

/* -- right column (heading + card) -- */
.p-flow-step__right {
  flex: 1;
  min-width: 0;
  padding-top: 60.8px;
}

.p-flow-step__heading {
  font-weight: 700;
  font-size: clamp(2rem, 2.7vw, 2.1875rem);
  color: #fff;
  margin: 0 12px 24px;
  line-height: 1.2;
}

.p-flow-step__card {
  background: #fff;
  border-radius: 30px;
  padding: 24px 28px;
}

.p-flow-step__text {
  font-weight: 500;
  font-size: 1.125rem;
  line-height: 1.833;
  color: #14212e;
  margin: 0;
}

/* ---------- responsive ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-flow {
    padding: 48px 0 64px;
  }
  .p-flow__inner {
    max-width: 600px;
    margin: 0 auto;
    padding: 0 25px;
  }
  .p-flow__steps {
    gap: 16px;
  }
  .p-flow-step {
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto auto;
    gap: 0;
    align-items: start;
  }

  /* ラベル画像: 1行目、左右いっぱい */
  .p-flow-step__left {
    display: contents;
  }

  .p-flow-step__label {
    grid-column: 1 / -1;
    grid-row: 1;
    width: 76.8px;
    margin-bottom: 8px;
  }

  /* 丸アイコン: 2行目左 */
  .p-flow-step__circle {
    grid-column: 1;
    grid-row: 2;
    width: 75px;
    height: 75px;
    margin-right: 12px;
  }

  /* 見出し: 2行目右（丸の隣） */
  .p-flow-step__right {
    display: contents;
  }

  .p-flow-step__heading {
    grid-column: 2;
    grid-row: 2;
    font-size: clamp(1rem, 4.7vw, 1.25rem);
    margin: 0;
    align-self: center;
  }

  /* カード: 3行目、左右いっぱい */
  .p-flow-step__card {
    grid-column: 1 / -1;
    grid-row: 3;
    padding: 16px 19px;
    border-radius: 20px;
    margin-top: 12px;
  }

  .p-flow-step__card {
    padding: 16px 19px;
    border-radius: 20px;
  }

  .p-flow-step__text {
    font-size: clamp(1rem, 2.5vw, 1.25rem);
    line-height: 1.692;
  }

  .p-flow-step__text br {
    display: none;
  }

  .p-flow-step__dots {
    display: none;
  }
}

/* ===========================================
   FAQ – よくある質問 (xd-file/export_0065.json)
   =========================================== */
.p-faq {
  background: #eaf1f8;
  padding: 64px 0 80px;
}

.p-faq__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ---------- heading ---------- */
.p-faq__heading {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 40px;
}

.p-faq__icon {
  width: 132px;
  margin-bottom: 8px;
}

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

.p-faq__title {
  width: 100%;
  max-width: 280px;
  text-align: center;
  margin: 0;
}

.p-faq__title img {
  display: inline-block;
  max-width: 400px;
  width: 100%;
  height: auto;
}

/* ---------- item list ---------- */
.p-faq__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

/* ---------- single item ---------- */
.p-faq__item {
  background: #fff;
  border-radius: 43.2px;
  overflow: hidden;
  transition: border-radius 0.3s ease;
}

.p-faq__item.is-open {
  border-radius: 49px;
}

/* ---------- question (button) ---------- */
.p-faq__question {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 18px 24px;
  background: none;
  border: none;
  cursor: pointer;
  text-align: left;
  font: inherit;
  color: inherit;
  outline: none;
  -webkit-tap-highlight-color: transparent;
}

.p-faq__question:focus,
.p-faq__question:focus-visible,
.p-faq__question:active {
  outline: none;
  box-shadow: none;
  -webkit-tap-highlight-color: transparent;
}

.p-faq__q-badge {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #303234;
}

.p-faq__q-badge img {
  width: 15px;
  height: auto;
  display: block;
  image-rendering: -webkit-optimize-contrast;
}

.p-faq__q-text {
  flex: 1;
  font-weight: 700;
  font-size: clamp(0.9375rem, 1.8vw, 1.4375rem);
  line-height: 1.43;
  letter-spacing: -0.01em;
  color: #14212e;
}

.p-faq__arrow {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20.8px;
  transform: rotate(180deg);
  transition: transform 0.35s ease;
}

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

.p-faq__item.is-open .p-faq__arrow {
  transform: rotate(0deg);
}

/* ---------- answer ---------- */
.p-faq__answer {
  height: 0;
  overflow: hidden;
  transition: height 0.35s ease;
}

.p-faq__answer-inner {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 0 24px 24px;
}

.p-faq__a-badge {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  background: #a71010;
}

.p-faq__a-badge img {
  width: 15px;
  height: auto;
  display: block;
  image-rendering: -webkit-optimize-contrast;
}

.p-faq__a-text {
  flex: 1;

  font-weight: 400;
  font-size: clamp(0.875rem, 1.4vw, 1.125rem);
  line-height: 1.67;
  color: #14212e;
  margin: 0;
  padding-top: 12px;
}

/* ---------- responsive ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-faq {
    padding: 48px 0 56px;
  }
  .p-faq__title img {
    max-width: clamp(120px, 46vw, 170px);
  }
  .p-faq__item {
    border-radius: 10px;
  }
  .p-faq__item.is-open {
    border-radius: 10px;
  }
  .p-faq__arrow {
    width: 15px;
  }

  .p-faq__icon {
    width: 80px;
  }

  .p-faq__question {
    gap: 10px;
    padding: 14px 16px;
  }

  .p-faq__q-badge,
  .p-faq__a-badge {
    width: 36px;
    height: 36px;
  }

  .p-faq__answer-inner {
    gap: 10px;
    padding: 0 16px 20px;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-faq__icon {
    width: clamp(20px, 20vw, 64px);
  }
  .p-faq__title img {
    max-width: clamp(80px, 80vw, 200px);
  }
}

/* ===========================================
   Company – 会社概要 (xd-file/export_0066.json)
   =========================================== */
.p-company {
  padding: 80px 0;
  background-color: #eaf1f8;
}

.p-company__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
}

.p-company__card {
  background: #fff;
  border-radius: 26px;
  padding: clamp(2rem, 4vw, 3rem) clamp(1.5rem, 4vw, 3rem)
    clamp(2.5rem, 5vw, 4rem);
}

/* ---------- header ---------- */
.p-company__header {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-bottom: 24px;
}

.p-company__icon {
  width: 88px;
  opacity: 0.2;
  margin-bottom: 16px;
}

.p-company__title {
  font-weight: 900;
  font-size: clamp(1.375rem, 2.3vw, 1.875rem);
  letter-spacing: 0.1em;
  color: #14212e;
  margin: 0;
  text-align: center;
}

/* ---------- table ---------- */
.p-company__table {
  width: 100%;
  border-collapse: collapse;
}

.p-company__table th,
.p-company__table td {
  font-size: clamp(0.8125rem, 1.56vw, 1.25rem);
  line-height: 1.5;
  color: #14212e;
  padding: 16px 0;
  border-bottom: 1px dotted #707070;
  vertical-align: top;
  text-align: left;
}

.p-company__table th {
  font-weight: 700;
  white-space: nowrap;
  width: 160px;
  padding-right: 24px;
}

.p-company__table td {
  font-weight: 400;
}

/* ---------- responsive ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-company {
    padding: 48px 0;
  }

  .p-company__card {
    padding: 24px 20px 32px;
  }

  .p-company__icon {
    width: 56px;
  }

  .p-company__table th {
    width: auto;
    padding-right: 16px;
  }

  .p-company__table th,
  .p-company__table td {
    font-size: 0.8125rem;
    padding: 10px 0;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-company__card {
    border-radius: 10px;
  }

  .p-company__table th,
  .p-company__table td {
    display: block;
    width: 100%;
    padding: 0;
  }

  .p-company__table th {
    padding-top: 10px;
    padding-right: 0;
    border-bottom: none;
  }

  .p-company__table td {
    padding-bottom: 10px;
    border-bottom: 1px dotted #707070;
  }
}

/* ===========================================
   Contact – お問い合わせ (xd-file/export_0067.json)
   =========================================== */
.p-contact {
  background: #fff;
  padding: 64px 0 80px;
}

.p-contact__inner {
  max-width: 900px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* ---------- heading ---------- */
.p-contact__lead {
  font-weight: 700;
  font-size: clamp(1.125rem, 2.3vw, 1.875rem);
  color: #14212e;
  text-align: center;
  margin: 0 0 4px;
}

.p-contact__title {
  text-align: center;
  max-width: clamp(200px, 48vw, 300px);
  margin: 0 0 32px;
}

.p-contact__title img {
  max-width: 100%;
  height: auto;
}

.p-contact__notice {
  font-weight: 700;
  font-size: clamp(13px, 3.5vw, 18px);
  color: #14212e;
  text-align: center;
  line-height: 1.6;
  margin: 0 0 32px;
}

.p-contact__notice > span {
  display: inline-block;
}

/* ---------- form wrapper ---------- */
.p-contact__form-wrap {
  width: 100%;
  max-width: 900px;
  background: #eaf1f8;
  border-radius: 20px;
  padding: clamp(32px, 4vw, 48px) clamp(24px, 5vw, 80px);
}

.p-contact__form {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

/* ---------- field ---------- */
.p-contact__field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.p-contact__label {
  display: flex;
  align-items: center;
  gap: 10px;

  font-weight: 500;
  font-size: clamp(0.9375rem, 1.8vw, 1.4375rem);
  color: #282828;
}

.p-contact__required {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 50px;
  height: 30px;
  padding: 0 8px;
  background: #e95555;
  color: #fff;

  font-weight: 500;
  font-size: 0.9375rem;
  line-height: 1;
  border-radius: 5px;
}

/* 詳細度メモ: テーマの oocss.css が input[type="text"] / input[type="submit"]
   (詳細度 0,1,1) でフォーム要素を上書きするため、.p-contact を前置きして
   (0,2,0) に引き上げて打ち消している */
.p-contact .p-contact__input,
.p-contact .p-contact__textarea {
  width: 100%;
  background: #fff;
  border: none;
  border-radius: 5px;

  font-weight: 500;
  font-size: clamp(0.875rem, 1.5vw, 1.25rem);
  color: #282828;
  padding: 20px 16px;
}

.p-contact__input::placeholder,
.p-contact__textarea::placeholder {
  color: #c5c5c5;
}

.p-contact__input:focus,
.p-contact__textarea:focus {
  outline: 2px solid #2e4a66;
  outline-offset: -0.125rem;
}

.p-contact .p-contact__input {
  height: 70px;
}

.p-contact .p-contact__textarea {
  min-height: 220px;
  resize: vertical;
}

/* ---------- privacy policy ---------- */
.p-contact__field--policy {
  gap: 12px;
}

.p-contact__policy-link {
  -webkit-appearance: none;
  appearance: none;
  background: none;
  border: none;
  padding: 0;
  font: inherit;
  color: #06c755;
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
}

/* ---------- privacy policy modal ---------- */
.p-modal {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  background: rgba(0, 0, 0, 0.6);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
}

.p-modal.is-open {
  opacity: 1;
  visibility: visible;
}

.p-modal__dialog {
  position: relative;
  width: 100%;
  max-width: 720px;
  max-height: 80vh;
  display: flex;
  flex-direction: column;
  background: #fff;
  border-radius: 8px;
  padding: 48px 24px 32px;
}

.p-modal__close {
  position: absolute;
  top: 10px;
  right: 12px;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: none;
  border: none;
  font-size: 26px;
  line-height: 1;
  color: #282828;
  cursor: pointer;
}

.p-modal__title {
  font-weight: 700;
  font-size: clamp(1.125rem, 2vw, 1.5rem);
  color: #282828;
  text-align: center;
  margin: 0 0 20px;
}

.p-modal__body {
  overflow-y: auto;
  padding-right: 8px;
}

.p-modal__body h3 {
  font-weight: 700;
  font-size: clamp(1rem, 1.6vw, 1.125rem);
  color: #282828;
  margin: 24px 0 8px;
}

.p-modal__body p {
  font-size: clamp(0.875rem, 1.4vw, 1rem);
  line-height: 1.8;
  color: #282828;
  margin: 0 0 12px;
}

.p-modal__sign {
  text-align: right;
  font-weight: 700;
}

.p-modal__agree {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid #e5e5e5;
}

.p-modal__agree[hidden] {
  display: none;
}

.p-modal__agree-label {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  font-weight: 500;
  font-size: clamp(0.875rem, 1.4vw, 1rem);
  color: #282828;
  cursor: pointer;
}

.p-modal__agree-check {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 5px;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  margin: 0;
}

.p-modal__agree-check:checked::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 6px;
  width: 5px;
  height: 10px;
  border: solid #06c755;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.p-contact__checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.p-contact__checkbox input[type="checkbox"] {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 5px;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}

.p-contact__checkbox input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 6px;
  width: 5px;
  height: 10px;
  border: solid #06c755;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.p-contact__checkbox-text {
  font-weight: 500;
  font-size: clamp(0.875rem, 1.4vw, 1.125rem);
  color: #282828;
}

/* ---------- submit ---------- */
.p-contact__submit {
  display: flex;
  justify-content: center;
  margin-top: 8px;
}

.p-contact .p-contact__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 300px;
  height: 70px;
  padding: 0;
  background: #06c755;
  color: #fff;

  font-weight: 500;
  font-size: clamp(1rem, 1.5vw, 1.25rem);
  border: none;
  border-radius: 35px;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.p-contact .p-contact__btn:hover {
  opacity: 0.85;
}

/* ---------- Contact Form 7 overrides ---------- */
.p-contact__form .wpcf7-form-control-wrap {
  display: block;
}

.p-contact__form p {
  margin: 0;
}

.p-contact__field--policy .wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
  display: block;
}

.p-contact__field--policy .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  cursor: pointer;
}

.p-contact__field--policy input[type="checkbox"] {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 5px;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  margin: 0;
}

.p-contact__field--policy input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 6px;
  width: 5px;
  height: 10px;
  border: solid #06c755;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.p-contact__field--policy .wpcf7-list-item-label {
  font-weight: 500;
  font-size: clamp(0.875rem, 1.4vw, 1.125rem);
  color: #282828;
}

.wpcf7-not-valid-tip {
  color: #e95555;
  font-size: 0.875rem;
  margin-top: 6px;
  display: block;
}

.wpcf7-response-output {
  margin: 20px 0 0;
  padding: 12px 16px;
  border-radius: 6px;
  font-size: 0.9375rem;
  text-align: center;
}

.wpcf7-spinner {
  vertical-align: middle;
}

/* ---------- responsive ---------- */

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-contact {
    padding: 48px 0 56px;
  }

  .p-contact__form-wrap {
    padding: 24px 20px;
  }

  .p-contact .p-contact__input {
    height: 56px;
  }

  .p-contact .p-contact__textarea {
    min-height: 160px;
  }

  .p-contact .p-contact__btn {
    width: 100%;
    min-width: auto;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-contact .p-contact__btn {
    font-size: clamp(0.875rem, 4.5vw, 1.25rem);
  }
}

/* ===========================================
   Footer (xd-file/export_0068.json)
   =========================================== */
.l-footer {
  padding: 40px 20px 32px;
  text-align: center;
  background-color: #eaf1f8;
}

.l-footer__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

.l-footer__logo {
  max-width: 349px;
}

.l-footer__copy {
  font-weight: 400;
  font-size: 0.9375rem;
  line-height: 2.667;
  color: #afafaf;
  margin: 0;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .l-footer {
    padding: 32px 16px 24px;
  }

  .l-footer__logo {
    max-width: 224px;
  }

  .l-footer__copy {
    font-size: 0.75rem;
  }
}

/* ---------- Media: small smartphone (<= 375px) – inner padding ---------- */
@media (max-width: 375px) {
  .p-fv__inner,
  .p-point__inner,
  .p-cta__inner,
  .p-worry__inner,
  .p-cause__inner,
  .p-solution__inner,
  .p-change__inner,
  .p-reasons__inner,
  .p-no__inner,
  .p-compare__inner,
  .p-plan__inner,
  .p-pdf-present__inner,
  .p-pdf-text__inner,
  .p-flow__inner,
  .p-faq__inner,
  .p-company__inner,
  .p-contact__inner,
  .p-voice__inner,
  .l-footer__inner {
    padding-left: 16px;
    padding-right: 16px;
  }

  .p-voice-card__name-br {
    display: block;
  }
}

/* ---------- Media: narrow smartphone (<= 425px) – utility & underline ---------- */
@media (max-width: 425px) {
  .u-br-sp425 {
    display: block;
  }

  .p-fv__marker::after {
    height: 10px;
  }

  .p-cause__lead-emphasis::after {
    height: 12px;
  }

  .p-no__keyword::after {
    height: 1rem;
  }
}

@media (max-width: 375px) {
  .p-plan__voice-br {
    display: none;
  }
  .p-plan__voice-text {
    font-size: clamp(0.625rem, 2.9vw, 1.125rem);
  }
}

/* ===========================================
   Thanks – お問い合わせ完了 (xd-file/export_0077.json)
   =========================================== */
.p-thanks-page {
  background: #e8eef4;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.p-thanks-page .lp-wrap {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.p-thanks {
  flex: 1;
  padding: clamp(2.5rem, 6vw, 5rem) 1rem;
}

.p-thanks__inner {
  width: 100%;
  max-width: 56.25rem; /* 900px */
  margin: 0 auto;
}

.p-thanks__title {
  text-align: center;
  margin: 0 0 2rem;
}

.p-thanks__title img {
  display: inline-block;
  max-width: clamp(12rem, 26vw, 21rem);
  height: auto;
}

.p-thanks__card {
  background: #fff;
  border-radius: 1.625rem; /* 26px */
  padding: clamp(2.5rem, 6vw, 5rem) clamp(1.5rem, 4vw, 3.75rem);
  text-align: center;
}

.p-thanks__heading {
  font-size: clamp(1.25rem, 2.4vw, 1.875rem); /* 30px */
  font-weight: 700;
  color: #14212e;
  line-height: 1.5;
  margin: 0 0 1.75rem;
}

.p-thanks__text {
  font-size: clamp(0.9375rem, 1.8vw, 1.4375rem); /* 23px */
  line-height: 1.9;
  color: #14212e;
  margin: 0;
}

.p-thanks__divider {
  width: 100%;
  max-width: 50rem; /* 800px */
  height: 1px;
  background: #707070;
  margin: clamp(3rem, 7vw, 5.5rem) auto 2rem;
}

.p-thanks__btn-wrap {
  text-align: center;
}

a.p-thanks__btn {
  display: inline-block;
  width: 15rem; /* 240px */
  max-width: 100%;
  padding: 1rem 1.25rem;
  background: #25ae00;
  color: #fff;
  font-size: 1.25rem; /* 20px */
  font-weight: 500;
  text-align: center;
  text-decoration: none;
  border-radius: 0.25rem;
  transition: opacity 0.2s ease;
}

.p-thanks__btn:hover {
  opacity: 0.85;
}

/* ---------- Media: smartphone (<= 768px) ---------- */
@media (max-width: 768px) {
  .p-thanks {
    padding: 2rem 1rem;
  }

  .p-thanks__card {
    padding: 2rem 1.25rem;
  }

  .p-thanks__heading {
    font-size: 1.125rem;
    margin-bottom: 1.25rem;
  }

  .p-thanks__text {
    font-size: 0.875rem;
    line-height: 1.75;
  }

  .p-thanks__divider {
    margin: 2.25rem auto 1.5rem;
  }

  .p-thanks__btn {
    width: 100%;
    max-width: 18rem;
    font-size: 1rem;
  }
}

/* ===========================================
   Document Download – /document/ , /document-thanks/
   - フォームページと完了（DL）ページの共通レイアウト
   =========================================== */
.p-document-page {
  background: #e8eef4;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

.p-document-page .lp-wrap {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

.p-document {
  flex: 1;
  padding: clamp(2rem, 5vw, 4rem) 1rem clamp(2.5rem, 6vw, 5rem);
}

.p-document__inner {
  width: 100%;
  max-width: 56.25rem; /* 900px */
  margin: 0 auto;
}

.p-document__lead {
  font-weight: 700;
  font-size: clamp(1rem, 2vw, 1.5rem);
  color: #14212e;
  text-align: center;
  margin: 0 0 0.5rem;
}

.p-document__title {
  font-family: "Shippori Mincho", "Noto Serif JP", serif;
  font-weight: 700;
  font-size: clamp(1.875rem, 4.5vw, 3rem);
  color: #14212e;
  text-align: center;
  letter-spacing: 0.08em;
  margin: 0 0 clamp(1.5rem, 4vw, 2.5rem);
}

.p-document__card {
  background: #fff;
  border-radius: 1.625rem; /* 26px */
  padding: clamp(2rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3.5rem);
}

.p-document__notice {
  font-size: clamp(0.9375rem, 1.5vw, 1.125rem);
  line-height: 1.7;
  color: #14212e;
  margin: 0 0 clamp(2rem, 5vw, 3rem);
}

/* ---------- Form (CF7 出力に被せる) ---------- */
.p-document__form-wrap {
  width: 100%;
}

.p-document__form-todo {
  padding: 1rem;
  border: 1px dashed #c5c5c5;
  border-radius: 0.5rem;
  background: #fafafa;
  color: #555;
  font-size: 0.875rem;
  line-height: 1.7;
}

.p-document__form-todo code {
  background: #eee;
  padding: 0 6px;
  border-radius: 3px;
  font-family: monospace;
}

.p-document__form {
  display: flex;
  flex-direction: column;
  gap: clamp(1.25rem, 2.5vw, 2rem);
}

.p-document__field {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.p-document__label {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  font-size: clamp(1rem, 1.8vw, 1.25rem);
  color: #14212e;
}

.p-document__required {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 50px;
  height: 28px;
  padding: 0 8px;
  background: #e95555;
  color: #fff;
  font-weight: 700;
  font-size: 0.875rem;
  line-height: 1;
  border-radius: 5px;
}

/* テーマ oocss.css の input[type] (詳細度 0,1,1) を上書きするため .p-document 前置 */
.p-document .p-document__input {
  width: 100%;
  height: 64px;
  background: #fff;
  border: 1px solid #d9d9d9;
  border-radius: 8px;
  padding: 0 16px;
  font-weight: 400;
  font-size: clamp(0.9375rem, 1.5vw, 1.125rem);
  color: #282828;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.03);
}

.p-document__input::placeholder {
  color: #c5c5c5;
}

.p-document__input:focus {
  outline: 2px solid #2e4a66;
  outline-offset: -2px;
}

/* ---------- Privacy policy field ---------- */
.p-document__field--policy {
  margin-top: 0.25rem;
}

.p-document__form .p-document__field--policy .wpcf7-acceptance .wpcf7-list-item {
  margin: 0;
  display: block;
}

.p-document__form .p-document__field--policy .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.p-document__field--policy input[type="checkbox"] {
  -webkit-appearance: none;
  appearance: none;
  width: 20px;
  height: 20px;
  background: #fff;
  border: 1px solid #c5c5c5;
  border-radius: 4px;
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  margin: 0;
}

.p-document__field--policy input[type="checkbox"]:checked::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 6px;
  width: 5px;
  height: 10px;
  border: solid #06c755;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.p-document__field--policy .wpcf7-list-item-label,
.p-document__policy-link {
  font-weight: 400;
  font-size: clamp(0.875rem, 1.4vw, 1rem);
  color: #282828;
}

.p-document__policy-link {
  color: #282828;
  text-decoration: underline;
  text-underline-offset: 2px;
  cursor: pointer;
}

/* ---------- Submit ---------- */
.p-document__submit {
  display: flex;
  justify-content: center;
  margin-top: clamp(1rem, 2.5vw, 1.5rem);
}

.p-document .p-document__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 340px;
  height: 66px;
  padding: 0 1.5rem;
  background: #25ae00;
  color: #fff;
  font-weight: 700;
  font-size: clamp(1rem, 1.6vw, 1.25rem);
  border: none;
  border-radius: 33px;
  cursor: pointer;
  transition: opacity 0.2s ease;
}

.p-document .p-document__btn:hover {
  opacity: 0.85;
}

/* ===========================================
   Document Download – Thanks/Completion (/document-thanks/)
   - .p-pdf-present に依存しないまっさらなBEM実装
   =========================================== */
.p-document__card--dl {
  padding: clamp(1rem, 3vw, 2rem) clamp(1rem, 3vw, 2.5rem) clamp(1.5rem, 4vw, 2.5rem);
}

/* DL Panel - PDF紹介ボックス（外枠） */
.p-document-dl__panel {
  position: relative;
  background: #fff;
  border: 2px solid #070203;
  border-radius: 30px;
  padding: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 3vw, 2rem);
  text-align: center;
}

/* タイトル */
.p-document-dl__title {
  font-weight: 900;
  font-size: clamp(1.125rem, 4vw, 2.5rem);
  line-height: 1.65;
  color: #14212e;
  margin: 0 auto;

  /* 白縁（軽め）: 黄ハイライトと文字の間に微かなセパレーション */
  -webkit-text-stroke: 3px #fff;
  paint-order: stroke fill;
  text-shadow:
    0 0 2px #fff,
    0 0 4px rgba(255, 255, 255, 0.7);
}

/* 各行を inline-block にして、行ごとに黄ハイライトを当てる */
.p-document-dl__title-line {
  display: inline-block;
  padding: 0 0.15em;
  background-image: linear-gradient(
    transparent 58%,
    #f5c500 58%,
    #f5c500 92%,
    transparent 92%
  );
  background-repeat: no-repeat;
  background-size: 100% 100%;
}

.p-document-dl__title-small {
  font-size: 0.6em;
  font-weight: 700;
  margin-left: 0.15em;
}

/* DLボタン - パネル内に配置。ラベル + btn-download.webp 画像 */
.p-document-dl__btn-wrap {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(0.5rem, 1.2vw, 1rem);
  margin-top: clamp(1.5rem, 3.5vw, 2.5rem);
}

.p-document-dl__btn-label {
  font-weight: 700;
  font-size: clamp(0.9375rem, 1.5vw, 1.125rem);
  color: #14212e;
  margin: 0;
  line-height: 1.4;
}

.p-document-dl__btn {
  display: block;
  width: clamp(240px, 22vw, 320px);
  filter: drop-shadow(0 3px 0 rgba(20, 33, 46, 0.25));
  transform: translateY(0);
  transition: transform 0.15s ease-out, filter 0.15s ease-out;
}

.p-document-dl__btn img {
  width: 100%;
  height: auto;
  display: block;
}

@media (any-hover: hover) {
  .p-document-dl__btn:hover {
    transform: translateY(2px);
    filter: drop-shadow(0 1px 0 rgba(20, 33, 46, 0.25));
  }
}

.p-document-dl__btn-todo {
  padding: 1rem;
  border: 1px dashed #c5c5c5;
  border-radius: 0.5rem;
  background: #fafafa;
  color: #555;
  font-size: 0.875rem;
  line-height: 1.7;
  text-align: left;
}

.p-document-dl__btn-todo code {
  background: #eee;
  padding: 0 6px;
  border-radius: 3px;
  font-family: monospace;
}

/* Back to LP button (subdued secondary) */
.p-document-dl__back-wrap {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: clamp(1rem, 2vw, 1.5rem);
}

.p-document-dl__back {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-width: 240px;
  height: 52px;
  padding: 0 1.5rem;
  background: #fff;
  color: #14212e;
  font-weight: 500;
  font-size: clamp(0.9375rem, 1.4vw, 1.0625rem);
  text-decoration: none;
  border: 1.5px solid #14212e;
  border-radius: 26px;
  transition: background-color 0.2s ease, color 0.2s ease;
}

.p-document-dl__back:hover {
  background: #14212e;
  color: #fff;
}

.p-document-dl__back-arrow {
  font-size: 1.1em;
  line-height: 1;
}

/* ---------- Media: tablet & smartphone (<= 768px) ----------
   フォーム要素の縦積み・ボタン幅100%化など、汎用的なレイアウト調整のみ */
@media (max-width: 768px) {
  .p-document {
    padding: 1.5rem 1rem 2.5rem;
  }

  .p-document__card {
    padding: 1.75rem 1.25rem;
  }

  .p-document .p-document__input {
    height: 56px;
  }

  .p-document .p-document__btn {
    width: 100%;
    min-width: auto;
    height: 60px;
  }

  .p-document-dl__btn {
    width: 100%;
    max-width: 320px;
  }

  .p-document-dl__back {
    width: 100%;
    min-width: auto;
    max-width: 320px;
    height: 50px;
  }
}

/* ---------- Media: smartphone (<= 425px) ---------- */
@media (max-width: 425px) {
  .p-document__title {
    font-size: 1.875rem;
  }

  /* DLカード：左右paddingを詰める */
  .p-document__card--dl {
    padding: 1.5rem clamp(0.5rem, 3vw, 1.25rem) 2rem;
  }

  .p-document-dl__panel {
    padding: 1.75rem 1rem 2rem;
    border-radius: 20px;
  }

  .p-document-dl__title {
    font-size: clamp(1.0625rem, 5.2vw, 1.5rem);
  }

  .p-document-dl__btn {
    width: 100%;
    max-width: 280px;
  }
}
