html {
  font-size: 16px;
}
@media screen and (max-width: 540px) {
  html {
    font-size: 3.6vw;
  }
}

body {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
}

.sp {
  display: none;
}

@media screen and (max-width: 540px) {
  .sp {
    display: block;
  }
}
@media screen and (min-width: 540px) {
  .sp2 {
    display: none;
  }
}

@media screen and (max-width: 540px) {
  .pc {
    display: none;
  }
}

a {
  color: #333333;
  text-decoration: none;
}

a:hover {
  opacity: 0.7;
  z-index: 100;
}

img {
  width: 100%;
  height: auto;
}

@keyframes fadeIn {
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

/*---------------------------------------------

	グローバルメニュー

---------------------------------------------*/
.globalMenu {
  padding: 1.6rem 2.4rem;
  display: flex;
  justify-content: space-between;
}

.globalMenu__logo {
  width: 16vw;
}

.util-button {
  color: white;
  font-size: 1.4vw;
  border-radius: 0.2rem;
  padding: 1.4rem 1.5rem;
  background: linear-gradient(90deg, #1eadac 0%, #29cfce 100%);
  text-decoration: none;
}

.util-button2 {
  color: white;
  font-size: 2.6rem;
  border-radius: 0.2rem;
  padding: 1.8rem 8rem;
  background: linear-gradient(90deg, #1eadac 0%, #29cfce 100%);
  text-decoration: none;
}

@media screen and (max-width: 540px) {
  .globalMenu {
    padding: 1rem;
    display: flex;
    justify-content: space-between;
  }

  .globalMenu__logo {
    width: 30vw;
  }

  .util-button {
    font-size: 1rem;
    padding: 1.4rem 1.5rem;
  }

  .util-button2 {
    width: 100%;
    font-size: 1.6rem;
    padding: 1.8rem 2rem;
  }
}

/*---------------------------------------------

	メインビジュアル

---------------------------------------------*/
.fv {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  height: 40vw;
  width: 100%;
  padding-bottom: 6vw;
  background-image: url("/wp-content/uploads/2024/05/VFPLP02_fv_beforeafter.png");
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

.fv__catch {
  text-align: center;
  z-index: 10;
  font-size: 4.6vw;
  line-height: 1.4;
  letter-spacing: 0.15444rem;
  color: #fff;
  animation: fadeIn 1s ease-out 0s 1 forwards;
  text-shadow: 0px 0px 54px rgba(0, 0, 0, 0.85);
  font-feature-settings: "palt";
}

.fv__catch span {
  font-size: 4.8vw;
}

.fv__catch small {
  font-size: 2.4vw;
  letter-spacing: 0.35644rem;
}

.fv__subcatch {
  color: #fff;
  font-size: 1.8vw;
  text-align: center;
  margin-top: 1rem;
  text-shadow: 0px 0px 54px rgba(0, 0, 0, 0.85);
  font-weight: 400;
  line-height: 160%; /* 2.7rem */
  letter-spacing: 0.2025rem;
  animation: fadeIn 1s ease-out 0s 1 forwards;
}

@media screen and (max-width: 540px) {
  .fv {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    height: 168vw;
    width: 100%;
    padding-bottom: 6vw;
    background-image: url("/wp-content/uploads/2024/05/VFPLP02_fv_beforeafter_sp.png");
    background-repeat: no-repeat;
    background-position: center center;
    background-size: cover;
  }

  .fv__catch {
    font-size: 8vw;
  }
  .fv__catch span {
    font-size: 9vw;
  }
  .fv__subcatch {
    font-size: 4vw;
  }
  .fv__catch small {
    font-size: 4vw;
  }
}

/*---------------------------------------------

	ライフコンシェルジュ

---------------------------------------------*/
.secConcierge {
  background-image: url("/wp-content/uploads/2024/05/VFPLP02_photo_concierge.png");
  background-size: 20% auto;
  background-position: 90% bottom;
  background-repeat: no-repeat;
  padding-top: 8vw;
  padding-bottom: 8vw;
  background-color: #eeeff1;
}

.secConcierge__inner {
  width: 80%;
  display: flex;
  margin: 0 auto;
}

.secConcierge__textArea {
  width: 70%;
}

.secConcierge__title {
  font-size: 2.8vw;
  line-height: 160%;
  margin-bottom: 1.4rem;
}

.secConcierge__text {
  font-size: 2vw;
  line-height: 180%;
}

@media screen and (max-width: 540px) {
  .secConcierge {
    background-position: center bottom;
    background-size: 30% auto;
  }

  .secConcierge__textArea {
    width: 100%;
    padding-bottom: 12rem;
  }

  .secConcierge__title {
    font-size: 1.6rem;
    line-height: 160%;
    margin-bottom: 1.4rem;
    text-align: center;
  }

  .secConcierge__text {
    font-size: 1.2rem;
    line-height: 180%;
  }
}

/*---------------------------------------------

	ユーティリティ

---------------------------------------------*/
.util-sectionTitle {
  font-size: 3.2rem;
  font-weight: 600;
  margin-bottom: 3vw;
  line-height: 1.6;
  text-align: center;
}

.util-sectionSubTitle {
  font-size: 2.6rem;
  font-weight: 600;
  margin-bottom: 4vw;
  line-height: 1.6;
}

.utile-sectonText {
  font-size: 2rem;
  line-height: 2;
  margin-bottom: 4vw;
}

.utile-sectonText span {
  background-color: #eafaf7;
}

@media screen and (max-width: 1500px) {
  .utile-sectonText {
    font-size: 1.8rem;
  }
}
@media screen and (max-width: 1400px) {
  .utile-sectonText {
    font-size: 1.6rem;
  }
}

@media screen and (max-width: 540px) {
  .util-sectionTitle {
    font-size: 2rem;
    font-weight: 500;
    margin-bottom: 1.2rem;
  }

  .util-sectionSubTitle {
    font-size: 1.6rem;
    font-weight: 500;
  }

  .utile-sectonText {
    font-size: 1.2rem;
    line-height: 1.7;
    margin-bottom: 2rem;
  }

  .no-blank br {
    display: none;
  }
}

/*---------------------------------------------

	“これから”を識る

---------------------------------------------*/
.secKnow {
  padding-top: 8vw;
  padding-bottom: 4vw;
  text-align: center;
}

.secKnow__inner {
  width: 72%;
  margin: 0 auto;
}

.secKnow__graph {
  width: 100%;
  margin-bottom: 1vw;
}

.secKnow__cap {
  color: #474747;
  font-size: 14px;
  font-family: Inter;
  text-align: right;
}

@media screen and (max-width: 540px) {
  .secKnow {
    padding-top: 8vw;
    padding-bottom: 8vw;
  }

  .secKnow__cap {
    font-size: 12px;
  }

  .secKnow__inner {
    width: 80%;
  }
  .secKnow__graph {
    margin-bottom: 0.5rem;
  }
}

/*---------------------------------------------

	ご相談者さまからいただいた声

---------------------------------------------*/
.secRealization {
  padding-top: 4vw;
  padding-bottom: 4vw;
  text-align: center;
}

.secRealization__inner {
  width: 86%;
  max-width: 1300px;
  margin: 0 auto;
}

.secRealization__image {
  width: 100%;
  margin-bottom: 6rem;
}

@media screen and (max-width: 540px) {
  .secRealization {
    padding-top: 8vw;
    padding-bottom: 8vw;
    text-align: center;
  }
  .secRealization__inner {
    width: 80%;
  }
  .secRealization__image {
    margin-bottom: 2rem;
    width: 120%;
    margin-left: -10%;
  }
}

/* カード */
.l-cards {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  row-gap: 2vw;
  margin-bottom: 3rem;
}

.card {
  width: 32%;
  background-color: #f6f4f3;
  border-radius: 1rem;
}

.card--white {
  background-color: white;
}

.card__photo {
  width: 100%;
}

.card__textArea {
  padding: 3vw 2.2vw 4vw 2.2vw;
}

.card__title {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 2.6vw;
  font-size: 1.8rem;
  margin-bottom: 3vw;
  line-height: 1.4;
}

.card__title--s {
  font-size: 1.5rem;
}

.card__text {
  font-size: 1.4rem;
  font-family: Inter;
  line-height: 1.6;
  text-align: left;
}

@media screen and (max-width: 540px) {
  .l-cards {
    row-gap: 1.4rem;
  }
  .card {
    width: 100%;
    border-radius: 1rem;
  }
  .card__title {
    height: 4rem;
    font-size: 1.6rem;
    margin-bottom: 2.4vw;
  }

  .card__title--s {
    font-size: 1.4rem;
    height: 6rem;
  }

  .card__textArea {
    padding: 1.5rem 1.5rem 3rem 1.5rem;
  }
  .card__text {
    font-size: 1.2rem;
  }
}

/*---------------------------------------------

	ファミトラとは？

---------------------------------------------*/
.secAbout {
  padding-top: 8vw;
  padding-bottom: 8vw;
  text-align: center;
}

.secAbout__inner {
  width: 72%;
  margin: 0 auto;
}

@media screen and (max-width: 540px) {
  .secAbout {
    padding-top: 3rem;
    padding-bottom: 4rem;
    text-align: center;
  }

  .secAbout__inner {
    width: 90%;
  }
}

/*---------------------------------------------

	ボタンエリア

---------------------------------------------*/
.secButton {
  text-align: center;
  padding-bottom: 8vw;
}

.secButton__inner {
  width: 86%;
  max-width: 1300px;
  margin: 0 auto;
}

@media screen and (max-width: 540px) {
  .secButton {
    padding-bottom: 6rem;
  }
}

/*---------------------------------------------

	ファミトラの3つの約束

---------------------------------------------*/
.secPromise {
  padding-top: 8vw;
  padding-bottom: 4vw;
  background-color: #eafaf7;
  padding-bottom: 8vw;
  text-align: center;
}

.secPromise__inner {
  width: 86%;
  max-width: 1300px;
  margin: 0 auto;
}
@media screen and (max-width: 540px) {
  .secPromise {
    padding-top: 3rem;
    padding-bottom: 4rem;
  }

  .secPromise__inner {
    width: 80%;
  }
}

/*---------------------------------------------

	相談予約フォーム

---------------------------------------------*/
.secForm {
  padding-top: 8vw;
  padding-bottom: 8vw;
  background: linear-gradient(
    90deg,
    #f9f1e7 50%,
    rgba(229, 252, 251, 0.4) 108.47%
  );
}

.content {
  width: 922px;
  max-width: 90%;
  margin: 0 auto;
}
@media screen and (max-width: 750px) {
  .content {
    width: 100%;
    max-width: 100%;
  }
}
@media screen and (max-width: 540px) {
  .secForm {
    padding-top: 4rem;
    padding-bottom: 4rem;
  }
  .content {
    max-width: 90%;
  }
}

.contact-read {
  color: #000;
  text-align: justify;
  font-size: 1.625rem;
  font-style: normal;
  font-weight: 500;
  line-height: 160%; /* 41.6px */
}

@media screen and (max-width: 540px) {
  .contact-read {
    font-size: 1.28rem;
  }
}

form {
  margin-top: 2rem;
  border: 1px solid #afafaf;
  padding: 4.5rem 0;
  background-color: white;
}

@media screen and (max-width: 540px) {
  form {
    padding: 0rem 0 2rem 0;
  }
}

.name-input {
  display: flex;
  gap: 2%;
  justify-content: center;
}
.name-input input {
  width: 45%;
}

.max-input {
  width: 100%;
  box-sizing: border-box;
}

select {
  padding: 1rem 1rem;
  border: 1px solid #858585;
  border-radius: 9px;
}

.input-width {
  width: 729px;
  max-width: 90%;
  margin: 0 auto;
}

.input-title {
  font-size: 1.25rem;
  display: flex;
  align-items: center;
  margin-bottom: 1rem;
  margin-top: 2.5rem;
}
@media screen and (max-width: 540px) {
  .input-title {
    font-size: 1.45rem;
    margin-top: 3rem;
    margin-bottom: 1rem;
  }
}

.required {
  display: inline-block;
  background-color: #e53e3e;
  font-size: 12px;
  font-weight: 600;
  padding: 0.2rem 0.3rem;
  border-radius: 6px;
  color: #fff;
  margin-left: 1rem;
}

input {
  border: 1px solid #858585;
  border-radius: 9px;
  padding: 1rem 1rem;
  font-size: 1.25rem;
}
@media screen and (max-width: 540px) {
  input {
    padding: 1rem 1rem;
  }
}

.custom-select {
  position: relative;
  display: inline-block;
  width: 100%;
}

.custom-select select {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: transparent;
  border: 1px solid #858585;
  padding: 1rem 1rem 1rem 1rem;
  font-size: 16px;
  border-radius: 4px;
  width: 100%;
  color: #000 !important;
}

.custom-select::after {
  content: url("/wp-content/uploads/2024/05/VFPLP02_Polygon2.svg");
  position: absolute;
  top: 50%;
  right: 1.5rem;
  transform: translateY(-50%);
  pointer-events: none;
}

.radio-title {
  font-size: 1.125rem;
}

@media screen and (max-width: 540px) {
  .custom-radio {
    font-size: 1.29rem;
  }
}
.custom-radio input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.custom-radio {
  display: inline-block;
  margin-right: 20px;
}

.custom-radio .checkmark {
  position: relative;
  top: 6px;
  left: 0;
  height: 28px;
  width: 28px;
  background-color: #d9d9d9;
  border-radius: 50%;
  display: inline-block;
  margin-right: 5px;
}

.custom-radio input:checked ~ .checkmark {
  background-color: #d9d9d9;
}

.custom-radio .checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

.custom-radio input:checked ~ .checkmark:after {
  display: block;
  top: 6.5px;
  left: 6.5px;
  width: 15px;
  height: 15px;
  border-radius: 50%;
  background: #1eadac;
}

.custom-checkbox {
  margin-bottom: 0.1rem;
  display: inline-block;
  font-size: 1.125rem;
  line-height: 1.6;
  align-items: center;
  display: flex;
}
@media screen and (max-width: 540px) {
  .custom-checkbox {
    display: flex;
    font-size: 1.27rem;
    line-height: 1.5;
    align-items: center;
    margin-bottom: 0.8rem;
    font-feature-settings: "palt";
  }
}

.custom-checkbox input {
  position: absolute;
  opacity: 0;
  cursor: pointer;
}

.custom-checkbox .checkmark {
  position: relative;
  top: 5px;
  left: 0;
  height: 28px;
  width: 28px;
  background-color: #ffffff;
  display: inline-block;
  margin-right: 10px;
  border-radius: 5px;
  border: 1px solid #858585;
}
@media screen and (max-width: 540px) {
  .custom-checkbox .checkmark {
    height: 26px;
    width: 26px;
  }
}

.custom-checkbox input:checked ~ .checkmark {
  background-color: white;
}

.custom-checkbox .checkmark:after {
  content: "";
  position: absolute;
  display: none;
}

.custom-checkbox input:checked ~ .checkmark:after {
  display: block;
  left: 8px;
  top: 3px;
  width: 8px;
  height: 16px;
  border: 2px solid #1eadac;
  border-width: 0 4px 4px 0;
  transform: rotate(45deg);
}
@media screen and (max-width: 540px) {
  .custom-checkbox input:checked ~ .checkmark:after {
    width: 8px;
    height: 16px;
    left: 8px;
    top: 2px;
  }
}

.contact-btn {
  text-align: center;
  margin-top: 2rem;
}
@media screen and (max-width: 540px) {
  .contact-btn {
    margin-top: 3rem;
    margin-bottom: 2rem;
  }
}

.submit {
  background: #1eadac;
  border: 1px solid #1eadac;
  color: white;
  width: 400px;
  margin: 0 auto;
  padding: 1.4rem 1rem;
  font-size: 1.125rem;
  box-sizing: border-box;
  border-radius: 6px;
  max-width: 90%;
  cursor: pointer;
  font-weight: 600;
}

.policy {
  font-size: 0.875rem;
  font-weight: 500;
  text-align: center;
  margin-top: 1rem;
  line-height: 1.6;
}
@media screen and (max-width: 540px) {
  .policy {
    font-size: 1rem;
  }
}
.policy a {
  color: #000;
  text-decoration: underline;
}

input::-moz-placeholder {
  font-size: 1.25rem;
  color: #a6a6a6;
  font-weight: 300;
}

input::placeholder {
  font-size: 1.25rem;
  color: #a6a6a6;
  font-weight: 300;
}

/*---------------------------------------------

	お客様の声

---------------------------------------------*/
.secVoice {
  padding-top: 8vw;
  padding-bottom: 8vw;
  text-align: center;
}

.secVoice__inner {
  width: 86%;
  max-width: 1300px;
  margin: 0 auto;
}

.secVoice .voice-item {
  border-radius: 1.875rem;
  border: 1px solid #afafaf;
  background: #fff;
  /* drop */
  box-shadow: 0px 0px 8px 0px rgba(0, 0, 0, 0.35);
  width: 32%;
  box-sizing: border-box;
  padding: 4rem 1.8rem 3rem;
  margin: 0 0.7rem;
}

.secVoice .voice-txt {
  text-align: justify;
  font-family: Inter;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 185%; /* 33.3px */
  margin-bottom: 6rem;
}
.secVoice .voice-txt span {
  font-weight: bold;
}

.secVoice .icon {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3%;
}
.secVoice .icon .icon-img {
  width: 5.8rem;
  border-radius: 50%;
}
.secVoice .icon .icon-img img {
  border-radius: 50%;
}
.secVoice .headingColor {
  margin-bottom: 0.5rem;
}

/*---------------------------------------------

	大手企業ロゴ

---------------------------------------------*/
.logo-container {
  width: 1200px;
  max-width: 100%;
  margin: 0 auto;
}
.logo-row {
  margin-top: 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
}

.logo-row picture {
  width: 33%;
  margin: 0 0.7rem;
}

.logo-row picture:first-child {
  width: 25%;
}

@media screen and (min-width: 750px) {
  .logo-row picture:first-child {
    width: 25%;
  }
}
.logo-row picture:nth-child(2) {
  width: 25%;
}

@media screen and (min-width: 750px) {
  .logo-row picture:nth-child(2) {
    width: 25%;
  }
}
@media screen and (max-width: 540px) {
  .logo-row picture:nth-child(2) {
    width: 28%;
  }
}
.logo-row:last-child picture:first-child {
  width: 36%;
}

@media screen and (max-width: 540px) {
  .logo-row:last-child picture:first-child {
    width: 45%;
  }
}
.logo-row:last-child picture:last-child {
  width: 40%;
}

/*---------------------------------------------

	フッター

---------------------------------------------*/
.secFooter {
  background-color: #eafaf7;
  text-align: center;
  padding: 2rem;
}

.secFooter img {
  width: 14rem;
}

iframe {
	border: none;
}