/* =====================================================
   Style.css - Responsive-ready layout
   Converted from fixed 1400px absolute positioning
   to flow-based flexible layout
   ===================================================== */

/* ===== Base Frame ===== */
.frame {
  background-color: #ffffff;
  overflow-x: hidden;
  width: 100%;
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
}

/* ===== Header Banner (group-17) ===== */
.frame .group-17 {
  width: 100%;
  height: 299px;
  position: relative;
}

.frame .rectangle-16 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 299px;
  background-color: #77B903;
}

.frame .image-3 {
  position: absolute;
  top: 51px;
  right: 18%;
  width: 355px;
  height: 248px;
  object-fit: cover;
}

.frame .text-wrapper-98 {
  position: absolute;
  top: 263px;
  right: 15%;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 14px;
  letter-spacing: 0;
  line-height: 24px;
  border: 1px solid #ffffff;
  padding: 0 10px;
}

.frame .div-21 {
  position: absolute;
  top: 51px;
  left: 19%;
  margin: 0;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  letter-spacing: 0;
  line-height: 1.5;
}

.frame .text-wrapper-99 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  letter-spacing: 0;
}

.frame .div-22 {
  position: absolute;
  top: 102px;
  left: 19%;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 32px;
  letter-spacing: 0;
  line-height: normal;
}

.frame .rectangle-17 {
  position: absolute;
  top: 161px;
  left: 19%;
  width: 445px;
  height: 75px;
  background-color: #ffffff;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.frame .text-wrapper-100 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #4db17b;
  font-size: 40px;
  letter-spacing: 0;
  line-height: normal;
  margin: 0;
}


/* ===== お悩みセクション (group-wrapper) ===== */
.frame .group-wrapper {
  width: 100%;
  display: flex;
}

.frame .onayami-wrapper {
  width: 100%;
  display: flex;
}

.frame .onayami {
  width: 100%;
  position: relative;
  background-color: #ffffff;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 40px;
  background: linear-gradient(
    180deg,
    rgba(233, 253, 255, 1) 0%,
    rgba(255, 255, 255, 0) 50%
  );
}

.frame .rectangle-10 {
  display: none;
}

.frame .family-images {
  order: 0;
  display: flex;
  justify-content: space-between;
  width: 100%;
  max-width: 1100px;
  padding: 0 30px;
  box-sizing: border-box;
  margin-bottom: -164px;
}

.frame .img-family-child {
  width: 226px;
  height: 188px;
}

.frame .img-family-child-2 {
  width: 225px;
  height: 183px;
  right: 18px;
  position: relative;
  bottom: -2px;
}

.frame .section-onayami {
  order: 3;
  max-width: 1100px;
  width: calc(100% - 40px);
  display: flex;
  flex-wrap: wrap;
  gap: 21px;
  background-color: #f8fdf4;
  border-radius: 88px 88px 0px 0px;
  box-shadow: 0px 3px 8px #c6deb1;
  padding: 20px 20px 100px;
  box-sizing: border-box;
  margin-top: 30px;
  margin-bottom: 100px;
}

.frame .kosedai-cont {
  display: flex;
  margin-top: 38px;
  flex: 1;
  min-width: 0;
  position: relative;
  margin-left: 20px;
  flex-direction: column;
  align-items: center;
  gap: 28px;
}

.frame .onayami-list {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.frame .div-3 {
  position: relative;
  align-self: stretch;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #30a34a;
  font-size: 40px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 40px;
}

.frame .text-wrapper-47 {
  letter-spacing: 0;
  margin-right: 5px;
}

.frame .text-wrapper-48 {
  font-size: 30px;
  letter-spacing: 0.3px;
  line-height: 30px;
}

.frame .onayami-kosedai {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  list-style: none;
  margin: 0;
  padding: 0;
}

.frame .list-item {
  display: flex;
  min-height: 40px;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: #ffffff;
  border-radius: 6px;
  box-shadow: 0px 2px 5px #c6d5c1;
}

.frame .ico-check-circle {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
  margin-top: -2px;
  margin-bottom: -2px;
}

.frame .group-11 {
  position: relative;
  width: 14px;
  height: 14px;
}

.frame .vector-2 {
  position: absolute;
  width: 77.52%;
  height: 89.66%;
  top: 10.34%;
  left: 22.48%;
}

.frame .vector-3 {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
}

.frame .text-wrapper-49 {
  position: relative;
  flex: 1;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 18px;
  letter-spacing: 1px;
  line-height: 18px;
}

.frame .list-item-2 {
  display: flex;
  min-height: 40px;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: #ffffff;
  border-radius: 6px;
  box-shadow: 0px 2px 5px #c6d5c1;
}

.frame .ico-check-circle-2 {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.frame .text-wrapper-50 {
  position: relative;
  flex: 1;
  min-width: 0;
  margin-top: -0.5px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 18px;
  letter-spacing: 1px;
  line-height: 21.6px;
}

.frame .text-wrapper-51 {
  position: relative;
  flex: 1;
  min-width: 0;
  margin-top: -0.5px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 18px;
  letter-spacing: 1px;
  line-height: 21.6px;
}

.frame .hint-txt {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  margin-top: auto;
}

.frame .ico-arrow-yellow {
  position: relative;
  width: 76px;
  height: 46px;
}

.frame .vector-4 {
  position: absolute;
  width: 99.28%;
  height: 98.80%;
  top: 0;
  left: 0;
}

.frame .vector-5 {
  position: absolute;
  width: 99.28%;
  height: 61.85%;
  top: 38.15%;
  left: 0;
}

.frame .hint-kosedai {
  display: flex;
  flex-direction: column;
  min-height: 88px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 0px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: #1f9c59;
  border-radius: 12px;
}

.frame .text-wrapper-52 {
  position: relative;
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #faff71;
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 20px;
}

.frame .text-wrapper-53 {
  position: relative;
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 22px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 22px;
}

.frame .oyasedai-cont {
  display: flex;
  margin-top: 38px;
  flex: 1;
  min-width: 0;
  position: relative;
  flex-direction: column;
  align-items: center;
  gap: 28px;
}

.frame .onayami-list-2 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
  position: relative;
  flex: 0 0 auto;
  width: 100%;
}

.frame .div-4 {
  position: relative;
  width: 100%;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--sub-yellowgreen);
  font-size: 40px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 40px;
}

.frame .onayami-oyasedai {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: flex-start;
  gap: 18px;
  position: relative;
  flex: 0 0 auto;
  list-style: none;
  margin: 0;
  padding: 0;
}

.frame .hint-txt-2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
  margin-top: auto;
}

.frame .hint-oyasedai {
  display: flex;
  flex-direction: column;
  min-height: 88px;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 14px 0px;
  position: relative;
  align-self: stretch;
  width: 100%;
  background-color: var(--sub-yellowgreen);
  border-radius: 12px;
}

.frame .text-wrapper-54 {
  position: relative;
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--point-yellow);
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 20px;
}

.frame .onayami-answer {
  order: 4;
  flex-basis: 100%;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: center;
  margin-top: 30px;
  padding: 0 20px 2px;
  box-sizing: border-box;
}

.frame .div-5 {
  width: 100%;
  max-width: 646px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--3);
  font-size: 32px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 51.2px;
}

.frame .text-wrapper-55 {
  color: #16a34a;
  letter-spacing: 0.32px;
}

.frame .text-wrapper-56 {
  color: #3e3e3e;
  letter-spacing: 0.32px;
}

.frame .img-anshin {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  max-width: 739px;
  width: calc(100% - 200px);
  height: auto;
  z-index: 1;
}

.frame .text-wrapper-57 {
  order: 2;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 24px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 24px;
  margin-top: 16px;
}

.frame .text-wrapper-58 {
  order: 1;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #30a34a;
  font-size: 32px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 32px;
  margin-top: 55px;
}

/* ===== CTA Section ===== */
.frame .CTA {
  display: flex;
  flex-direction: column;
  width: 100%;
  height: 460px;
  align-items: center;
  justify-content: center;
  gap: 30px;
  padding: 30px 20px 38px;
  background-color: #fff7ec;
  border-radius: 10px;
  overflow: hidden;
  box-sizing: border-box;
}

.frame .div-10 {
  position: relative;
  max-width: 756px;
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.frame .div-wrapper-2 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 20px 28px;
  background-color: #ffffff;
  border-radius: 6px;
  border: 1px solid;
  border-color: #e8cdad;
}

.frame .div-11 {
  margin-top: -1px;
  font-weight: 700;
  color: transparent;
  font-size: 28px;
  text-align: center;
  letter-spacing: 0;
  line-height: 20px;
  white-space: nowrap;
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
}

.frame .text-wrapper-90 {
  color: #6cab00;
}

.frame .text-wrapper-91 {
  color: #f08d18;
}

.frame .div-12 {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 20px;
  width: 100%;
}

.frame .contents {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.frame .explain {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 40px;
  padding: 0 240px 0 0;
  width: 100%;
  min-height: 179px;
  box-sizing: border-box;
}

.frame .div-13 {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  position: relative;
  flex: 0 0 auto;
}

.frame .div-14 {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.frame .check-circle {
  position: relative;
  width: 30px;
  height: 30px;
  aspect-ratio: 1;
  background-image: url(../img/image.svg);
  background-size: 100% 100%;
}

.frame .vector-8 {
  position: absolute;
  width: 91.67%;
  height: 91.67%;
  top: 8.33%;
  left: 8.33%;
}

.frame .div-15 {
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: transparent;
  font-size: 24px;
  text-align: center;
  letter-spacing: 0;
  line-height: 20px;
  white-space: nowrap;
}

.frame .text-wrapper-92 {
  color: #232b39;
}

.frame .div-16 {
  display: flex;
  align-items: center;
  gap: 8px;
  position: relative;
  align-self: stretch;
  width: 100%;
  flex: 0 0 auto;
}

.frame .check-circle-2 {
  position: relative;
  width: 30px;
  height: 30px;
  aspect-ratio: 1;
  background-image: url(../img/vector.svg);
  background-size: 100% 100%;
}

.frame .check-circle-3 {
  position: relative;
  width: 30px;
  height: 30px;
  aspect-ratio: 1;
  background-image: url(../img/vector-2.svg);
  background-size: 100% 100%;
}

.frame .div-17 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.frame .group-16 {
  position: relative;
  width: 189px;
  height: 34px;
}

.frame .union {
  position: absolute;
  top: 0;
  left: 0;
  width: 187px;
  height: 34px;
}

.frame .title {
  position: absolute;
  top: 4px;
  left: 4px;
  width: 176px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: normal;
}

.frame .div-18 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  position: relative;
  flex: 0 0 auto;
}

.frame .div-19 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
}

.frame .guide {
  position: relative;
  width: 41px;
  height: 43px;
  aspect-ratio: 0.94;
}

.frame .text-wrapper-93 {
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #232b39;
  font-size: 14px;
  text-align: center;
  letter-spacing: 0;
  line-height: 20px;
  white-space: nowrap;
}

.frame .text-wrapper-94 {
  position: relative;
  width: 10px;
  height: 40px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #232b39;
  font-size: 20px;
  text-align: center;
  letter-spacing: 0;
  line-height: 20px;
}

.frame .memo {
  position: relative;
  width: 33px;
  height: 43px;
  aspect-ratio: 0.77;
}

.frame .operator {
  position: absolute;
  right: 30px;
  bottom: 0;
  width: 219px;
  height: 179px;
  aspect-ratio: 1.23;
}

/* CTA Buttons */
.frame .cta {
  display: flex;
  width: 900px;
  max-width: 100%;
  margin-top: -10px;
  align-items: center;
  justify-content: center;
  gap: 20px;
}

.frame .btn-phone {
  display: flex;
  flex: 1;
  height: 112px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 6px 12px;
  position: relative;
  background-color: #16a34a;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0px 6px 0px #0d6d12;
  text-decoration: none;
  cursor: pointer;
}

.frame .image {
  position: relative;
  width: 56px;
  height: 79px;
  aspect-ratio: 0.7;
  object-fit: cover;
}

.frame .div-20 {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  position: relative;
  flex: 0 0 auto;
}

.frame .depth-frame-wrapper {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  position: relative;
  flex: 0 0 auto;
}

.frame .depth-frame {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  flex: 0 0 auto;
}

.frame .text-wrapper-95 {
  position: relative;
  width: fit-content;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--white);
  font-size: 28px;
  text-align: center;
  letter-spacing: 0;
  line-height: 28px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.frame .text-wrapper-96 {
  position: relative;
  width: fit-content;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--white);
  font-size: 16px;
  text-align: center;
  letter-spacing: 0;
  line-height: 24px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.frame .btn-phone-wrapper {
  all: unset;
  box-sizing: border-box;
  display: flex;
  flex: 1;
  cursor: pointer;
  height: 112px;
}

.frame .btn-phone-2 {
  display: flex;
  width: 100%;
  height: 112px;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 20px 6px;
  position: relative;
  background-color: #f08d18;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0px 6px 0px #a46317;
}

.frame .image-2 {
  position: relative;
  width: 54px;
  height: 39px;
  aspect-ratio: 1.38;
  object-fit: cover;
}

.frame .text-wrapper-97 {
  position: relative;
  width: fit-content;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 28px;
  text-align: center;
  letter-spacing: 0;
  line-height: 28px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

/* ===== Support Title Section ===== */
.frame .support-ttl {
  width: 100%;
}

.frame .div-6 {
  width: 100%;
  position: relative;
}

.frame .section-support-ttl {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 52px 20px 100px;
  background-color: var(--sub-yellowgreen);
  box-sizing: border-box;
}

.frame .text-wrapper-59 {
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 40px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 40px;
}

.frame .ttl-fukidashi {
  width: 649px;
  max-width: 100%;
  height: 120px;
  position: relative;
}

.frame .rectangle-11 {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100px;
  background-color: #ffffff;
  border-radius: 120px;
}

.frame .vector-6 {
  position: absolute;
  width: 250px;
  height: 60px;
  top: 20px;
  left: 20px;
  z-index: 1;
}

.frame .div-7 {
  position: absolute;
  top: 20px;
  left: 299px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-green);
  font-size: 59.2px;
  line-height: 59.2px;
  white-space: nowrap;
  z-index: 2;
}

.frame .text-wrapper-60 {
  letter-spacing: 0.68px;
}

.frame .text-wrapper-61 {
  font-size: 48px;
  letter-spacing: 0.96px;
  line-height: 48px;
}

.frame .vector-7 {
  position: absolute;
  top: 100px;
  left: 313px;
  width: 24px;
  height: 20px;
  z-index: 2;
}

.frame .text-wrapper-62 {
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 52px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 52px;
}

.frame .img-section-support {
  max-width: 1100px;
  width: calc(100% - 200px);
  margin: -214px auto 0;
  display: flex;
  justify-content: space-between;
  position: relative;
  z-index: 1;
}

.frame .img-man {
  width: 264px;
  height: 214px;
}

.frame .img-woman {
  width: 288px;
  height: 214px;
}

/* ===== Support Plan Section (div-8) ===== */
.frame .div-8 {
  width: 100%;
  background-color: #ffffff;
  position: relative;
}

.frame .group-wrapper-2 {
  width: 100%;
  display: flex;
}

.frame .group-12 {
  width: 100%;
  display: flex;
  flex-direction: column;
}

.frame .support-lead {
  display: flex;
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 24px;
  padding: 40px 54px;
  background-color: #ffffff;
  box-sizing: border-box;
}

.frame .text-wrapper-63 {
  position: relative;
  align-self: stretch;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-green);
  font-size: 40px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 40px;
}

.frame .support-txt {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 52px;
  position: relative;
  flex-wrap: wrap;
}

.frame .img-support {
  position: relative;
  width: 424px;
  max-width: 100%;
  height: auto;
}

.frame .element {
  position: relative;
  max-width: 514px;
  flex: 1;
  min-width: 280px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 18px;
  letter-spacing: 1px;
  line-height: 32.4px;
}

.frame .support-plan-inner {
  background-color: var(--bg-palegreen);
}

.frame .support-plan-bg {
  display: none;
}

.frame .support-plan {
  display: flex;
  flex-direction: column;
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  align-items: center;
  gap: 32px;
  padding: 46px 20px;
  box-sizing: border-box;
}

.frame .div-9 {
  position: relative;
  width: 100%;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-txt);
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 32px;
}

.frame .text-wrapper-64 {
  color: #3e3e3e;
  letter-spacing: 0.2px;
}

.frame .text-wrapper-65 {
  color: #16a34a;
  letter-spacing: 0.2px;
}

.frame .support-plan-list {
  display: flex;
  width: 100%;
  gap: 25px;
  justify-content: center;
}

/* --- Plan Cards (共通フロー配置) --- */
.frame .plan,
.frame .plan-2,
.frame .plan-3,
.frame .plan-4 {
  width: 256px;
  background-color: #ffffff;
  border-radius: 8px;
  box-shadow: 0px 2px 9px #e1dbd1;
  text-align: center;
  overflow: hidden;
}

/* カードタイトル（緑） */
.frame .text-wrapper-66,
.frame .text-wrapper-71,
.frame .text-wrapper-79 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-green);
  font-size: 28px;
  letter-spacing: 1.1px;
  line-height: 28px;
  padding: 20px 10px 0;
  margin: 0;
}

/* カードサブタイトル */
.frame .text-wrapper-67,
.frame .text-wrapper-72,
.frame .text-wrapper-75,
.frame .text-wrapper-80 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 18px;
  letter-spacing: 1px;
  line-height: 20px;
  padding: 8px 10px 16px;
  margin: 0;
}

/* オレンジ帯 */
.frame .rectangle-12 {
  background-color: var(--primary-orange);
  padding: 14px 10px;
}

/* オレンジ帯内テキスト（白） */
.frame .text-wrapper-70,
.frame .text-wrapper-74,
.frame .text-wrapper-78,
.frame .text-wrapper-83 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 27.2px;
  margin: 0;
}

/* 「向いているのは」 */
.frame .text-wrapper-69,
.frame .text-wrapper-77,
.frame .text-wrapper-82 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-orange);
  font-size: 18px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 25.2px;
  padding: 14px 10px 0;
  margin: 0;
}

/* 対象者テキスト */
.frame .text-wrapper-68,
.frame .text-wrapper-73,
.frame .text-wrapper-76,
.frame .text-wrapper-81 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 17px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 23.8px;
  padding: 4px 10px 16px;
  margin: 0;
}

/* Strategy Boxes - converted from absolute to flex */
.frame .strategy-boxes {
  display: flex;
  max-width: 1100px;
  width: 100%;
  margin: 20px auto 20px;
  gap: 20px;
  padding: 0 20px;
  box-sizing: border-box;
  flex-wrap: wrap;
  justify-content: center;
}

.frame .strategy-box {
  flex: 1;
  min-width: 280px;
  max-width: 350px;
  display: flex;
  flex-direction: column;
  align-items: center;
  background-color: #ffffff;
  border-radius: 5px;
  border: 2px solid #4db17b;
  padding: 15px 10px 20px;
  box-sizing: border-box;
}

.frame .rectangle-13,
.frame .rectangle-14,
.frame .rectangle-15 {
  display: none;
}

.frame .text-wrapper-84,
.frame .text-wrapper-85,
.frame .text-wrapper-86 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #4db17b;
  font-size: 30px;
  letter-spacing: 0;
  line-height: normal;
  white-space: nowrap;
  margin-bottom: 10px;
}

.frame .text-wrapper-87,
.frame .text-wrapper-88,
.frame .text-wrapper-89 {
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #000000;
  font-size: 22px;
  text-align: center;
  letter-spacing: 0;
  line-height: normal;
  margin-bottom: 15px;
}

.frame .group-13,
.frame .group-14,
.frame .group-15 {
  max-width: 270px;
}

.frame .group-13 {
  width: 178px;
  height: 168px;
}

.frame .group-14 {
  width: 270px;
  height: 101px;
}

.frame .group-15 {
  width: 262px;
  height: 131px;
}

/* ===== Section Support Plan Banner ===== */
.frame .section-support-plan {
  width: 100%;
  height: 210px;
  display: flex;
  background-color: #76b506;
  align-items: flex-end;
  justify-content: center;
  padding: 0 20px;
  box-sizing: border-box;
  gap: 20px;
}

.frame .img-plan-woman {
  width: 148px;
  height: 192px;
}

.frame .p {
  max-width: 513px;
  flex: 1;
  min-width: 280px;
  align-self: center;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 32px;
}

.frame .text-wrapper-44 {
  letter-spacing: 0.2px;
}

.frame .text-wrapper-45 {
  font-size: 22px;
  letter-spacing: 0.22px;
  line-height: 35.2px;
}

.frame .text-wrapper-46 {
  font-size: 26px;
  letter-spacing: 0.26px;
  line-height: 41.6px;
}

.frame .img-plan-man {
  width: 234px;
  height: 182px;
}

/* ===== Merit Section (group) ===== */
.frame .group {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.frame .merit {
  display: flex;
  width: 100%;
  position: relative;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 30px;
  padding: 80px 20px 0px 20px;
  box-sizing: border-box;
}

.frame .text-wrapper-16 {
  position: relative;
  width: fit-content;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-green);
  font-size: 40px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 56px;
}

.frame .merit-title-orange {
  color: var(--primary-orange);
}

.frame .text-wrapper-17 {
  position: relative;
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 18px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 32.4px;
}

.frame .div-2 {
  position: relative;
}

.frame .group-2 {
  width: 100%;
  background-color: #fffbef;
}

.frame .merit-wave-top,
.frame .merit-wave-bottom {
  width: 100%;
  display: block;
}

.frame .merit-wave-top {
  margin-bottom: -130px;
}

.frame .merit-wave-bottom {
  margin-top: -1px;
}

.frame .merit-2 {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  padding: 0 20px;
  box-sizing: border-box;
}

.frame .merit-lead {
  display: flex;
  width: 100%;
  position: relative;
  flex-direction: column;
  align-items: center;
  gap: 40px;
  padding: 40px 0px 48px;
}

.frame .text-wrapper-18 {
  position: relative;
  align-self: stretch;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-orange);
  font-size: 40px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 56px;
}

.frame .text-wrapper-19 {
  position: relative;
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-green);
  font-size: 40px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 56px;
}

.frame .text-wrapper-20 {
  position: relative;
  align-self: stretch;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 18px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 32.4px;
}

.frame .flow-list-inner {
  width: 100%;
  margin-top: 2px;
  padding-top: 30px;
}

.frame .ico-arrow,
.frame .ico-arrow-2,
.frame .ico-arrow-3 {
  display: none;
}

.frame .flow-list {
  width: 100%;
  display: flex;
  gap: 20px;
  flex-wrap: wrap;
  justify-content: center;
  list-style: none;
  margin: 0;
  padding: 0;
}

.frame .flow {
  width: 246px;
  display: flex;
  flex-direction: column;
  background-color: #ffffff;
  border: 1px solid;
  border-color: #f1e4d8;
  box-shadow: 0px 4px 4px #efe5d9;
  padding: 0 8px 20px;
  box-sizing: border-box;
}

.frame .text-wrapper-21 {
  margin-left: auto;
  margin-right: auto;
  width: 37px;
  height: 32px;
  margin-top: -16px;
  font-family: "Roboto", Helvetica;
  font-weight: 700;
  color: var(--primary-orange);
  font-size: 32px;
  text-align: center;
  letter-spacing: 0;
  line-height: 32px;
  white-space: nowrap;
}

.frame .text-wrapper-22 {
  width: auto;
  margin-top: 18px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-txt);
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 25.6px;
}

.frame .text-wrapper-23 {
  margin-left: 22px;
  margin-right: 22px;
  margin-top: 17px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 17px;
  letter-spacing: 1px;
  line-height: 26.5px;
}

.frame .text-wrapper-24 {
  margin-left: auto;
  margin-right: auto;
  width: 37px;
  height: 32px;
  margin-top: -16px;
  font-family: "Roboto", Helvetica;
  font-weight: 700;
  color: var(--primary-orange);
  font-size: 32px;
  text-align: center;
  letter-spacing: 0;
  line-height: 32px;
  white-space: nowrap;
}

.frame .text-wrapper-25 {
  width: auto;
  margin-top: 18px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-txt);
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 25.6px;
}

.frame .text-wrapper-26 {
  margin-left: auto;
  margin-right: auto;
  width: 37px;
  height: 32px;
  margin-top: -16px;
  font-family: "Roboto", Helvetica;
  font-weight: 700;
  color: var(--primary-orange);
  font-size: 32px;
  text-align: center;
  letter-spacing: 0;
  line-height: 32px;
  white-space: nowrap;
}

.frame .text-wrapper-27 {
  width: auto;
  margin-top: 18px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-txt);
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 25.6px;
}

.frame .text-wrapper-28 {
  margin-left: 22px;
  margin-right: 22px;
  margin-top: 17px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 17px;
  letter-spacing: 1px;
  line-height: 26.5px;
}

.frame .text-wrapper-29 {
  margin-left: auto;
  margin-right: auto;
  width: 37px;
  height: 32px;
  margin-top: -16px;
  font-family: "Roboto", Helvetica;
  font-weight: 700;
  color: var(--primary-orange);
  font-size: 32px;
  text-align: center;
  letter-spacing: 0;
  line-height: 32px;
  white-space: nowrap;
}

.frame .text-wrapper-30 {
  width: auto;
  margin-top: 30px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-txt);
  font-size: 20px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 25.6px;
  white-space: nowrap;
}

.frame .text-wrapper-31 {
  margin-left: 22px;
  margin-right: 22px;
  margin-top: 31px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--primary-txt);
  font-size: 17px;
  letter-spacing: 1px;
  line-height: 26.5px;
}

.frame .text-wrapper-32 {
  text-align: center;
  width: 100%;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--primary-txt);
  font-size: 24px;
  letter-spacing: 1px;
  line-height: 24px;
  white-space: nowrap;
  margin-bottom: 40px;
}

.frame .img-senmonka {
  max-width: 1007px;
  width: 100%;
  height: auto;
  margin-top: 57px;
}

/* Expert Cards */
.frame .group-4 {
  max-width: 1100px;
  width: 100%;
  margin: 0 auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  padding: 0 20px;
  box-sizing: border-box;
}

.frame .expert-card {
  background: #ffffff;
  border-radius: 4px;
  box-shadow: 0px 3.48px 3.48px #00000040;
  overflow: hidden;
}

.frame .expert-card__header {
  background-color: #f08d18;
  padding: 0 10px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #ffffff;
  font-size: 22px;
  text-align: center;
  line-height: 58px;
}

.frame .expert-card__body {
  padding: 16px 10px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: #000000;
  font-size: 16px;
  text-align: center;
  line-height: 1.5;
}

/* ===== Case List Inner ===== */
.frame .case-list-inner {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 0 20px 80px;
  box-sizing: border-box;
  background-color: #ffffff;
}

.frame .case-list-green {
  max-width: 1400px;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 20px;
  padding: 40px 30px 60px;
  box-sizing: border-box;
  background-color: #76b506;
  border-radius: 24px;
  position: relative;
}

.frame .rectangle {
  display: none;
}

.frame .list-talk {
  max-width: 480px;
  width: 45%;
  display: flex;
  flex-direction: column;
  gap: 15px;
  list-style: none;
  margin: 0;
  padding: 0;
  z-index: 1;
}

.frame .list-talk-item {
  display: flex;
  width: 100%;
  min-height: 52px;
  position: relative;
  align-items: center;
  gap: 9.21px;
  padding: 12.89px;
  background-color: #ffffff;
  border-radius: 92.38px;
  border: 0.92px solid;
  border-color: var(--5);
  box-shadow: 0px 2px 4px #03723675;
  box-sizing: border-box;
}

.frame .ico-check-green {
  position: relative;
  width: 25.87px;
  height: 25.87px;
  background-color: #4eb17c;
  border-radius: 12.93px;
  flex-shrink: 0;
}

.frame .vector {
  position: absolute;
  top: 6px;
  left: 3px;
  width: 19px;
  height: 13px;
}

.frame .text-wrapper-11 {
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--4);
  font-size: 18.5px;
  letter-spacing: 0.92px;
  line-height: 18.5px;
  white-space: nowrap;
}

.frame .list-talk-item-2 {
  min-height: 52px;
  gap: 9.24px;
  padding: 12.93px;
  border-radius: 92.69px;
  border: 0.93px solid;
  display: flex;
  width: 100%;
  position: relative;
  align-items: center;
  background-color: #ffffff;
  border-color: var(--5);
  box-shadow: 0px 2px 4px #03723675;
  box-sizing: border-box;
}

.frame .vector-wrapper {
  position: relative;
  width: 25.95px;
  height: 25.95px;
  background-color: #4eb17c;
  border-radius: 12.98px;
  flex-shrink: 0;
}

.frame .text-wrapper-12 {
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: var(--4);
  font-size: 18.5px;
  letter-spacing: 0.93px;
  line-height: 18.5px;
  white-space: nowrap;
}

.frame .list-talk-item-3 {
  min-height: 51px;
  gap: 9.24px;
  padding: 12.93px;
  border-radius: 92.69px;
  border: 0.93px solid;
  display: flex;
  width: 100%;
  position: relative;
  align-items: center;
  background-color: #ffffff;
  border-color: var(--5);
  box-shadow: 0px 2px 4px #03723675;
  box-sizing: border-box;
}

.frame .img-wrapper {
  margin-top: -0.41px;
  margin-bottom: -0.41px;
  position: relative;
  width: 25.95px;
  height: 25.95px;
  background-color: #4eb17c;
  border-radius: 12.98px;
  flex-shrink: 0;
}

.frame .list-talk-item-4 {
  min-height: 51px;
  gap: 9.24px;
  padding: 12.93px;
  border-radius: 92.69px;
  border: 0.93px solid;
  display: flex;
  width: 100%;
  position: relative;
  align-items: center;
  background-color: #ffffff;
  border-color: var(--5);
  box-shadow: 0px 2px 4px #03723675;
  box-sizing: border-box;
}

.frame .list-talk-item-5 {
  min-height: 70px;
  gap: 9.24px;
  padding: 12.93px;
  border-radius: 92.69px;
  border: 0.93px solid;
  display: flex;
  width: 100%;
  position: relative;
  align-items: center;
  background-color: #ffffff;
  border-color: var(--5);
  box-shadow: 0px 2px 4px #03723675;
  box-sizing: border-box;
}

.frame .text-wrapper-13 {
  margin-top: -0.86px;
  font-weight: 400;
  color: var(--4);
  font-size: 18.4px;
  letter-spacing: 0.89px;
  line-height: 22.1px;
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
}

.frame .list-talk-2 {
  max-width: 480px;
  width: 45%;
  display: flex;
  flex-direction: column;
  gap: 15px;
  list-style: none;
  margin: 0;
  padding: 0;
  z-index: 1;
}

.frame .list-talk-item-6 {
  min-height: 52px;
  gap: 9.21px;
  padding: 12.89px;
  border-radius: 92.38px;
  border: 0.92px solid;
  display: flex;
  width: 100%;
  position: relative;
  align-items: center;
  background-color: #ffffff;
  border-color: var(--5);
  box-shadow: 0px 2px 4px #03723675;
  box-sizing: border-box;
}

.frame .img-case-talk {
  position: absolute;
  left: 32%;
  bottom: 0;
  transform: translateX(-50%);
  width: 228px;
  max-width: 100%;
  height: auto;
  z-index: 0;
}

.frame .text-wrapper-14 {
  width: 100%;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--7);
  font-size: 30px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 48px;
}

.frame .text-wrapper-15 {
  width: 100%;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--3);
  font-size: 24px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 38.4px;
}

/* ===== QA Section ===== */
.frame .qa {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  justify-content: center;
  gap: 46px;
  padding: 96px 20px;
  background-color: #ffffff;
  box-sizing: border-box;
}

.frame .text-wrapper-4 {
  position: relative;
  max-width: 1100px;
  width: 100%;
  font-family: var(--underline-font-family);
  font-weight: var(--underline-font-weight);
  color: #000000;
  font-size: var(--underline-font-size);
  text-align: center;
  letter-spacing: var(--underline-letter-spacing);
  line-height: var(--underline-line-height);
  text-decoration: underline;
  font-style: var(--underline-font-style);
}

.frame .question {
  position: relative;
  max-width: 1100px;
  width: 100%;
  background-color: #ffffff;
}

.frame .answer {
  display: flex;
  width: 100%;
  align-items: flex-start;
  gap: 12px;
  padding: 18px 16px 0px;
  margin-top: 10px;
  background-color: #ffffff;
  box-sizing: border-box;
}

.frame .ico-answer {
  position: relative;
  width: 32px;
  height: 56.58px;
  flex-shrink: 0;
}

.frame .ellipse {
  position: absolute;
  top: 0;
  left: 0;
  width: 32px;
  height: 32px;
  background-color: #f08d18;
  border-radius: 16px;
}

.frame .text-wrapper-5 {
  position: absolute;
  top: 6px;
  left: 9px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: 1.24px;
  line-height: 18px;
  white-space: nowrap;
}

.frame .text-wrapper-6 {
  position: relative;
  flex: 1;
  min-width: 0;
  margin-top: -1px;
  font-family: "BIZ UDGothic", Helvetica;
  font-weight: 700;
  color: var(--mainblack);
  font-size: 20px;
  letter-spacing: 1px;
  line-height: 36px;
}

.frame .questin {
  display: flex;
  width: 100%;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background-color: #f5f9f2;
  border-radius: 120px;
  box-sizing: border-box;
}

.frame .ico-question {
  position: relative;
  width: 32px;
  height: 32px;
  background-color: var(--green);
  border-radius: 16px;
  overflow: hidden;
  flex-shrink: 0;
}

.frame .text-wrapper-7 {
  position: absolute;
  top: 6px;
  left: 8px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #ffffff;
  font-size: 18px;
  letter-spacing: 1.24px;
  line-height: 18px;
  white-space: nowrap;
}

.frame .text-wrapper-8 {
  position: relative;
  width: fit-content;
  font-family: "BIZ UDGothic", Helvetica;
  font-weight: 700;
  color: var(--mainblack);
  font-size: 20px;
  letter-spacing: 1px;
  line-height: 36px;
  white-space: nowrap;
}

.frame .question-2 {
  position: relative;
  max-width: 1100px;
  width: 100%;
  background-color: #ffffff;
}

.frame .answer-2 {
  display: flex;
  width: 100%;
  align-items: flex-start;
  gap: 12px;
  padding: 18px 16px 0px;
  margin-top: 10px;
  background-color: #ffffff;
  box-sizing: border-box;
}

.frame .div-wrapper {
  position: relative;
  width: 32px;
  height: 32px;
  background-color: #f08d18;
  border-radius: 16px;
  overflow: hidden;
  flex-shrink: 0;
}

.frame .text-wrapper-9 {
  position: relative;
  flex: 1;
  min-width: 0;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--mainblack);
  font-size: 20px;
  letter-spacing: 1px;
  line-height: 36px;
}

.frame .text-wrapper-10 {
  position: relative;
  width: fit-content;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: var(--mainblack);
  font-size: 20px;
  letter-spacing: 1px;
  line-height: 36px;
  white-space: nowrap;
}

/* ===== Message Section ===== */
.frame .message {
  display: flex;
  flex-direction: column;
  width: 100%;
  align-items: center;
  justify-content: center;
  gap: 38px;
  padding: 80px 20px;
  background: linear-gradient(
    180deg,
    rgba(252, 249, 245, 1) 0%,
    rgba(252, 249, 245, 0) 100%
  );
  box-sizing: border-box;
}

.frame .text-wrapper {
  position: relative;
  width: fit-content;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #16a34a;
  font-size: 32px;
  text-align: center;
  letter-spacing: 1px;
  line-height: 48px;
}

.frame .message-cont {
  display: flex;
  max-width: 1100px;
  width: 100%;
  align-items: flex-start;
  gap: 50px;
  position: relative;
  flex-wrap: wrap;
  justify-content: center;
}

.frame .mask-group {
  position: relative;
  width: 432px;
  max-width: 100%;
  height: auto;
  aspect-ratio: 432 / 400;
}

.frame .div {
  position: relative;
  flex: 1;
  min-width: 280px;
  margin-top: -1px;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 400;
  color: transparent;
  font-size: 20px;
  letter-spacing: 0;
  line-height: 34px;
}

.frame .span {
  color: #000000;
}

.frame .text-wrapper-2 {
  font-weight: 700;
  color: #1f9c59;
}

.frame .text-wrapper-3 {
  font-weight: 700;
  color: #000000;
}

/* ===== PC: スマホ専用要素非表示 ===== */
.frame .sp-badge-area {
  display: none;
}

/* PC: スマホ用お悩みイラスト非表示 */
.frame .sp-onayami-illust {
  display: none;
}

.frame .sp-anshin-young,
.frame .sp-anshin-adult {
  display: none;
}

.frame .sp-fv-cta {
  display: block;
  width: 100%;
  padding: 40px 20px;
  box-sizing: border-box;
  background-color: #ffffff;
}

.frame .sp-fv-cta .cta {
  max-width: 900px;
  margin: 0 auto;
}

.frame .sp-fv-cta-lead {
  text-align: center;
  font-family: "BIZ UDPGothic", Helvetica;
  font-weight: 700;
  color: #A87A59;
  font-size: 28px;
  margin: 0 0 20px;
  line-height: 1.4;
}

.frame .sp-fv-cta-main {
  font-size: 32px;
  color: #77B903;
}

.frame .sp-fv-cta-sub {
  font-size: 20px;
  color: #A87A59;
}

/* ===== スマホ用レスポンシブ ===== */
.sp-only {
  display: none;
}

@media screen and (max-width: 768px) {

  .sp-only {
    display: inline;
  }

  /* --- Header Banner (group-17) SP --- */
  .frame .group-17 {
    height: auto;
    padding-bottom: 280px;
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow: hidden;
  }

  /* 背景色をabsoluteではなくgroup-17自体に */
  .frame .rectangle-16 {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
  }

  /* flexの要素順序をorderで制御 */
  .frame .div-21 {
    position: relative;
    top: auto;
    left: auto;
    margin: 0;
    text-align: center;
    width: 100%;
    padding-top: 20px;
    padding-bottom: 0;
    font-size: 22px;
    z-index: 4;
    order: 1;
    line-height: 1.6;
  }

  .frame .div-22 {
    position: relative;
    top: auto;
    left: auto;
    text-align: center;
    width: 100%;
    padding-top: 0;
    font-size: 20px;
    z-index: 4;
    order: 2;
    line-height: 1.6;
  }

  .frame .text-wrapper-99 {
    font-size: 22px;
  }

  /* 「相続対策」を太字に */
  .frame .div-21 .text-wrapper-99:nth-child(2) {
    font-weight: 700;
    font-size: 26px;
  }

  /* 「無料相談」を太字に */
  .frame .div-22 .text-wrapper-99:nth-child(2) {
    font-weight: 700;
    font-size: 26px;
  }

  /* 「生前にできる相続対策」ボックス中央 */
  .frame .rectangle-17 {
    position: relative;
    top: auto;
    left: auto;
    width: auto;
    max-width: 92%;
    height: auto;
    padding: 10px 16px;
    margin: 14px auto 0;
    z-index: 2;
    order: 3;
  }

  .frame .text-wrapper-100 {
    font-size: 24px;
    text-align: center;
    white-space: nowrap;
  }

  /* 相続専門相談員ラベル非表示 */
  .frame .text-wrapper-98 {
    display: none;
  }

  /* バッジ画像表示 */
  .frame .sp-badge-area {
    display: block;
    position: absolute;
    left: 20px;
    bottom: 15%;
    z-index: 3;
  }

  .frame .sp-badge-img {
    width: 50vw;
    max-width: 210px;
    height: auto;
  }

  /* 女性画像：下部中央に大きく */
  .frame .image-3 {
    position: absolute;
    top: auto;
    bottom: 0;
    right: 0;
    left: auto;
    display: block;
    width: 68.25vw;
    max-width: 294px;
    height: auto;
    margin: 0;
    z-index: 2;
    order: 6;
  }

  /* FV下CTAボタン表示 */
  .frame .sp-fv-cta {
    display: block;
    width: 100%;
    padding: 20px 16px;
    box-sizing: border-box;
    background-color: #ffffff;
    border: 3px solid #77B903;
  }

  .frame .sp-fv-cta .cta {
    width: 100%;
    flex-direction: column;
    gap: 10px;
    margin-top: 0;
  }

  .frame .sp-fv-cta .btn-phone {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 64px;
    min-height: 64px;
    padding: 0 16px;
    border-radius: 12px;
    box-shadow: 0px 4px 0px #0d6d12;
    box-sizing: border-box;
    gap: 8px;
    flex-shrink: 0;
  }

  .frame .sp-fv-cta .btn-phone-wrapper {
    all: unset;
    display: flex;
    width: 100%;
    height: 64px;
    box-sizing: border-box;
    cursor: pointer;
  }

  .frame .sp-fv-cta .text-wrapper-95 {
    font-size: 17px;
    line-height: 20px;
    white-space: nowrap;
  }

  .frame .sp-fv-cta .text-wrapper-96 {
    font-size: 10px;
    line-height: 14px;
    white-space: nowrap;
  }

  .frame .sp-fv-cta .image {
    width: 26px;
    height: 36px;
  }

  .frame .sp-fv-cta .btn-phone-2 {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 64px;
    padding: 0 16px;
    border-radius: 12px;
    box-shadow: 0px 4px 0px #a46317;
    box-sizing: border-box;
    gap: 8px;
  }

  .frame .sp-fv-cta .text-wrapper-97 {
    font-size: 17px;
    line-height: 20px;
    white-space: nowrap;
  }

  .frame .sp-fv-cta .image-2 {
    width: 34px;
    height: 25px;
  }

  .frame .sp-fv-cta-lead {
    font-size: 18px;
    margin: 0 0 8px;
  }

  /* お悩みタイトル：改行せず画面幅に応じて縮小 */
  .frame .text-wrapper-58 {
    font-size: clamp(18px, 5.5vw, 32px);
    white-space: nowrap;
    margin-top: 30px;
  }

  .frame .text-wrapper-57 {
    font-size: clamp(14px, 4.2vw, 24px);
    white-space: nowrap;
  }

  /* --- お悩みセクション SP --- */

  /* PC用の上部イラスト2枚を非表示 */
  .frame .family-images {
    display: none;
  }

  /* セクション全体：背景・シャドウ・角丸を除去 */
  .frame .section-onayami {
    flex-direction: column;
    flex-wrap: nowrap;
    background-color: transparent;
    box-shadow: none;
    border-radius: 0;
    padding: 0;
    gap: 0;
    margin-top: 0;
    margin-bottom: 20px;
    width: 100%;
  }

  .frame .onayami {
    padding-top: 20px;
  }

  /* 子世代・親世代の共通 */
  .frame .kosedai-cont,
  .frame .oyasedai-cont {
    margin-top: 0;
    margin-left: 0;
    width: 100%;
    gap: 0;
    overflow: visible;
  }

  /* スマホ用イラスト+半円背景 */
  .frame .sp-onayami-illust {
    display: flex;
    justify-content: center;
    align-items: flex-end;
    width: 200px;
    height: 180px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
  }

  .frame .sp-onayami-illust::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 200px;
    height: 100px;
    background-color: #e4f3da;
    border-radius: 100px 100px 0 0;
  }

  .frame .sp-onayami-illust img {
    position: relative;
    z-index: 1;
    width: 150px;
    height: auto;
  }

  /* リスト・ヒント：背景色を画面いっぱいに */
  .frame .onayami-list,
  .frame .onayami-list-2 {
    display: flex;
    background-color: #e4f3da;
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    padding: 20px 20px 4px;
    box-sizing: border-box;
    gap: 16px;
  }

  .frame .hint-txt,
  .frame .hint-txt-2 {
    background-color: #e4f3da;
    width: 100vw;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
    padding: 16px 20px 24px;
    margin-top: 0 !important;
    box-sizing: border-box;
  }

  /* 見出しフォントサイズ調整 */
  .frame .div-3,
  .frame .div-4 {
    font-size: 30px;
    line-height: 34px;
  }

  .frame .text-wrapper-47 {
    margin-right: 4px;
  }

  .frame .text-wrapper-48 {
    font-size: 22px;
    line-height: 26px;
  }

  /* リストアイテムのフォントサイズ */
  .frame .text-wrapper-49,
  .frame .text-wrapper-50,
  .frame .text-wrapper-51 {
    font-size: 15px;
    line-height: 20px;
  }

  /* ヒントテキスト */
  .frame .text-wrapper-52 {
    font-size: 16px;
  }

  .frame .text-wrapper-53 {
    font-size: 17px;
    line-height: 24px;
  }

  /* 親世代の区切り */
  .frame .oyasedai-cont {
    margin-top: 10px;
  }

  /* お悩み回答セクションの余白を詰める */
  .frame .onayami-answer {
    margin-top: 0;
    padding-top: 24px;
    flex-basis: auto;
    align-items: center;
  }

  /* 安心イメージ画像：スマホ非表示 */
  .frame .img-anshin {
    display: none;
  }

  /* お悩み回答テキスト縮小 */
  .frame .div-5 {
    font-size: 16px;
    line-height: 24px;
  }

  .frame .text-wrapper-55 {
    font-size: 16px;
  }

  .frame .text-wrapper-56 {
    font-size: 14px;
  }

  /* 上下に挟む画像を表示 */
  .frame .sp-anshin-young,
  .frame .sp-anshin-adult {
    display: block;
    width: 50%;
    max-width: 180px;
    height: auto;
  }

  .frame .sp-anshin-young {
    align-self: center;
    margin-bottom: -16px;
  }

  .frame .sp-anshin-adult {
    align-self: center;
    margin: 0;
  }

  /* onayami → CTA 間の隙間をゼロに */
  .frame .section-onayami {
    margin-bottom: 0;
  }
  .frame .onayami {
    padding-bottom: 0;
  }
  .frame .onayami-answer {
    padding-bottom: 0;
    margin-bottom: 0;
  }

  /* --- CTAセクション SP --- */
  .frame .CTA {
    height: auto;
    margin-top: 0;
    padding: 24px 12px 24px;
    gap: 0;
    border-radius: 0;
  }

  /* タイトル */
  .frame .div-11 {
    font-size: 20px;
    white-space: normal;
    line-height: 28px;
  }

  .frame .div-wrapper-2 {
    padding: 14px 16px;
  }

  /* 説明エリア全体 */
  .frame .div-12 {
    width: 100%;
  }

  .frame .contents {
    display: block;
    width: 100%;
  }

  /* explain: position relative でoperatorを右下配置可能に */
  .frame .explain {
    position: relative;
    display: block;
    width: 100%;
    padding: 0;
    min-height: 0;
  }

  /* チェック3項目 */
  .frame .div-13 {
    display: flex;
    flex-direction: column;
    gap: 12px;
  }

  /* チェック項目のフォントサイズ */
  .frame .div-15 {
    font-size: 20px;
  }

  /* プレゼント情報: チェック項目の直下 */
  .frame .div-17 {
    transform: scale(0.9);
    transform-origin: top left;
    margin-top: 8px;
  }

  /* オペレーター画像: explain の右下に絶対配置 */
  .frame .operator {
    position: absolute;
    right: 5px;
    bottom: 0;
    width: 45vw;
    max-width: 200px;
    height: auto;
    margin: 0;
    z-index: 1;
  }

  /* CTAボタンのz-indexを調整 */
  .frame .CTA .cta {
    position: relative;
    z-index: 0;
  }

  /* CTAボタンを縦並び */
  .frame .CTA .cta {
    flex-direction: column;
    width: 100%;
    gap: 12px;
    margin-top: 0;
  }

  .frame .CTA .btn-phone {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 64px;
    min-height: 64px;
    padding: 0 16px;
    border-radius: 12px;
    box-shadow: 0px 4px 0px #0d6d12;
    box-sizing: border-box;
    gap: 8px;
    flex-shrink: 0;
  }

  .frame .CTA .btn-phone .image {
    width: 26px;
    height: 36px;
  }

  .frame .CTA .text-wrapper-95 {
    font-size: 17px;
    line-height: 20px;
    white-space: nowrap;
  }

  .frame .CTA .text-wrapper-96 {
    font-size: 10px;
    line-height: 14px;
    white-space: nowrap;
  }

  .frame .CTA .btn-phone-wrapper {
    all: unset;
    display: flex;
    width: 100%;
    height: 64px;
    box-sizing: border-box;
    cursor: pointer;
  }

  .frame .CTA .btn-phone-2 {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 64px;
    min-height: 64px;
    padding: 0 16px;
    border-radius: 12px;
    box-shadow: 0px 4px 0px #a46317;
    box-sizing: border-box;
    gap: 8px;
    flex-shrink: 0;
  }

  .frame .CTA .btn-phone-2 .image-2 {
    width: 34px;
    height: 25px;
  }

  .frame .CTA .text-wrapper-97 {
    font-size: 17px;
    line-height: 20px;
    white-space: nowrap;
  }

  /* --- Support Title Section SP --- */

  /* テキスト部分：上に寄せて下にゆとり */
  .frame .section-support-ttl {
    padding: 30px 12px 120px;
    gap: 10px;
  }

  /* 「相続対策のお悩み、」 */
  .frame .text-wrapper-59 {
    font-size: 24px;
    line-height: 28px;
  }

  /* 吹き出し：幅100%で収める */
  .frame .ttl-fukidashi {
    width: 100%;
    height: auto;
    aspect-ratio: 649 / 120;
    transform: none;
    margin-bottom: 0;
  }

  /* 吹き出し内の要素を%ベースでリサイズ */
  .frame .rectangle-11 {
    height: 83%;
  }

  .frame .vector-6 {
    width: 38%;
    height: 50%;
    top: 16%;
    left: 3%;
  }

  .frame .div-7 {
    top: 16%;
    left: 46%;
    font-size: 9vw;
    line-height: 1;
  }

  .frame .text-wrapper-61 {
    font-size: 7.5vw;
    line-height: 1;
  }

  .frame .vector-7 {
    top: 83%;
    left: 48%;
    width: 4%;
    height: 17%;
  }

  /* 「解決します！」 */
  .frame .text-wrapper-62 {
    font-size: 28px;
    line-height: 32px;
  }

  /* 画像エリア：位置そのまま・縮小・次セクションにくっつく */
  .frame .img-section-support {
    position: absolute;
    bottom: 0;
    left: 10px;
    right: 10px;
    width: auto;
    margin: 0;
  }

  .frame .img-man {
    width: 30vw;
    max-width: 160px;
    height: auto;
  }

  .frame .img-woman {
    width: 33vw;
    max-width: 180px;
    height: auto;
  }

  /* --- 専門家カード SP --- */
  .frame .group-4 {
    grid-template-columns: 1fr;
    gap: 14px;
    padding: 0 16px;
  }

  /* --- 3つの対策ボックス SP --- */
  .frame .strategy-boxes {
    flex-direction: column;
    gap: 12px;
  }

  .frame .strategy-box {
    min-width: 0;
    max-width: 100%;
    width: 100%;
  }

  .frame .text-wrapper-84,
  .frame .text-wrapper-85,
  .frame .text-wrapper-86 {
    font-size: 20px;
  }

  .frame .text-wrapper-87,
  .frame .text-wrapper-88,
  .frame .text-wrapper-89 {
    font-size: 14px;
    line-height: 1.6;
  }

  /* --- メリットセクション SP --- */
  .frame .merit {
    padding: 80px 20px;
  }

  .frame .merit-wave-top {
    margin-bottom: -1px;
  }

  .frame .text-wrapper-16 {
    font-size: 24px;
    line-height: 36px;
  }

  .frame .text-wrapper-17 {
    font-size: 14px;
    line-height: 24px;
  }

  /* --- セクション: 最適なプラン SP --- */
  .frame .section-support-plan {
    height: auto;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: space-between;
    padding: 30px 10px 0;
    gap: 0;
  }

  .frame .section-support-plan .p {
    width: 100%;
    order: -1;
    margin-bottom: 20px;
  }

  /* --- プランカード SP --- */
  .frame .support-plan-list {
    flex-direction: column;
    gap: 16px;
  }

  .frame .plan,
  .frame .plan-2,
  .frame .plan-3,
  .frame .plan-4 {
    width: 100%;
  }

  /* --- 相談リスト SP --- */
  .frame .case-list-green {
    flex-direction: column;
    align-items: center;
    padding: 24px 16px 0;
    border-radius: 16px 16px 0 0;
  }

  .frame .list-talk {
    width: 100%;
    max-width: 100%;
    order: 2;
  }

  .frame .list-talk-2 {
    width: 100%;
    max-width: 100%;
    order: 1;
  }

  .frame .img-case-talk {
    position: relative;
    left: auto;
    bottom: auto;
    transform: none;
    width: 45%;
    max-width: 180px;
    order: 3;
    margin-top: 10px;
  }

  /* 「相続対策」「無料相談」を太字・大きく */
  .frame .div-21 .text-wrapper-99.sp-emphasis {
    font-weight: 700 !important;
    font-size: 29px !important;
  }

  /* リストアイテムのはみ出し防止 */
  .frame .text-wrapper-11,
  .frame .text-wrapper-12,
  .frame .text-wrapper-13 {
    white-space: normal;
    width: auto;
    flex: 1;
    min-width: 0;
    font-size: 14px;
    line-height: 20px;
  }

  /* --- 各セクション見出し・テキスト SP縮小 --- */

  /* いい相続なら「相続対策をトータルサポート」 40px→22px */
  .frame .text-wrapper-63 {
    font-size: 22px;
    line-height: 30px;
  }

  /* SP: support-lead の左右余白を縮小 */
  .frame .support-lead {
    padding: 30px 12px;
  }

  /* いい相続だから 40px→24px */
  .frame .text-wrapper-18 {
    font-size: 24px;
    line-height: 28px;
  }

  /* 中立的な立場で、適切な専門家をご紹介 40px→22px */
  .frame .text-wrapper-19 {
    font-size: 22px;
    line-height: 30px;
  }

  /* 日本全国から〜 24px→16px */
  .frame .text-wrapper-15 {
    font-size: 16px;
    line-height: 24px;
  }

  /* ＼ひとつでも当てはまる方は〜 30px→18px */
  .frame .text-wrapper-14 {
    font-size: 18px;
    line-height: 26px;
  }

  /* よくある質問 */
  .frame .text-wrapper-4 {
    font-size: 24px;
  }

  /* Q: 質問文 20px→15px */
  .frame .text-wrapper-8,
  .frame .text-wrapper-10 {
    font-size: 15px;
    line-height: 22px;
    white-space: normal;
  }

  /* A: 回答文 →14px */
  .frame .text-wrapper-6,
  .frame .text-wrapper-9 {
    font-size: 14px;
    line-height: 22px;
  }

  /* 相続やお金のことで〜 32px→22px */
  .frame .text-wrapper {
    font-size: 22px;
    line-height: 30px;
    white-space: normal;
  }

  /* merit説明文 18px→14px */
  .frame .text-wrapper-20 {
    font-size: 14px;
    line-height: 24px;
  }

  /* メッセージ本文 20px→14px */
  .frame .div {
    font-size: 14px;
    line-height: 24px;
    min-width: 0;
  }

  /* --- img-plan-man：左下右下に配置、ボトムを次セクションに合わせる --- */
  .frame .img-plan-woman {
    height: 40vw;
    max-height: 160px;
    width: auto;
    margin-bottom: 0;
  }

  .frame .img-plan-man {
    height: 40vw;
    max-height: 160px;
    width: auto;
    margin-bottom: 0;
  }

  .frame .section-support-plan {
    padding-bottom: 0;
    margin-bottom: 0;
  }

  /* --- フローカードの隙間を広げる --- */
  .frame .flow-list {
    gap: 20px;
  }

  /* --- SP: merit-2 の左右余白を縮小 / .flow を幅いっぱいに --- */
  .frame .merit-2 {
    padding: 0 12px;
  }

  .frame .flow {
    width: 100%;
    max-width: 100%;
  }

  /* --- case-list-innerとqaのパディング縮小 --- */
  .frame .case-list-inner {
    padding: 40px 16px 30px;
    gap: 14px;
  }

  .frame .qa {
    padding: 30px 16px 40px;
    gap: 24px;
  }

  /* --- img-case-talk：親ラッパーのボトムに合わせる --- */
  .frame .case-list-green {
    padding-bottom: 0;
  }

  .frame .img-case-talk {
    margin-top: 16px;
    margin-bottom: 0;
    align-self: center;
  }

}
