/* 
  l- レイアウト
 */

.l-mv-sub {
  position: relative;
  height: max(50vh, 1000px);
}

.l-contents-display {
  display: flex;
  justify-content: center;
  align-items: start;
  flex-wrap: wrap;
  width: 100%;
  gap: 2rem;
}
.l-contents-display.--w1200 {
  max-width: 1200px;
  width: 90%;
  margin-inline: auto;
}

.l-contents-display.--spaceevenly {
  justify-content: space-evenly;
}

@media (max-width: 1024px) {
  .l-contents-display {
    flex-wrap: wrap;
  }
}
@media (max-width: 960px) {
  .c-mv-sub {
    justify-content: center;
  }
  .l-mv-sub {
    height: min(100vh, 700px);
  }
}
@media (max-width: 768px) {
}
@media (max-width: 479px) {
}



.l-option-post {
  display: flex;
  justify-content: center;
  align-items: start;
  flex-wrap: wrap;
  gap: 2rem;
}
.l-option-post-l {
  width: min(250px, 90%);
  min-height: 420px;
  height: 100%;
}
.l-option-post-r {
  max-width: 600px;
}

.l-option-post-list {
  display: flex;
  justify-content: center;
  align-items: start;
  flex-wrap: wrap;
  gap: 2rem;
}
.l-option-post-list > li {
  width: 180px;
  height: 224px;
}





.l-faq {
  padding: 4rem;
  border-radius: 16px;
  background-color: #fff;
}
.l-faq > dl {
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 1rem;
}
.l-faq > dl > dt,
.l-faq > dl > dd {
  position: relative;
  color: var(--color-txt);
  font-size: clamp(1.7rem, 1.6336rem + 0.14vw, 1.8rem);
  display: flex;
  align-items: center;
  width: 100%;
  padding: 0.75em 1em 0.75em 4em;
  border-radius: 32px;
}
.l-faq > dl > dt {
  font-weight: 900;
  background-color: rgba(0, 0, 0, .5);
}
.l-faq > dl > dd {
  font-weight: 500;
  margin-bottom: 4rem;
  background-color: #fff;
}

.l-faq > dl > dt::before,
.l-faq > dl > dd::before {
  position: absolute;
  top: 0.55em;
  left: 0.6em;
  width: 2.0em;
  height: 2.0em;
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  padding-left: 0.06em;
  padding-bottom: 0.06em;
}

.l-faq > dl > dt::before {
  content: "Q";
  color: #fff;
  background-color: #000;
}
.l-faq > dl > dd::before {
  content: "A";
  color: #000;
  border: 1px solid #000;
  background-color: #fff;
}

.l-faq.--instagram > dl > dt {
  color: var(--color-instagram);
  background-color: rgba(var(--color-rgb-instagram), .2);
}
.l-faq.--instagram > dl > dt::before {
  background-color: var(--color-instagram);
}

.l-faq.--line > dl > dt {
  color: var(--color-line);
  background-color: rgba(var(--color-rgb-line), .2);
}
.l-faq.--line > dl > dt::before {
  background-color: var(--color-line);
}

.l-faq.--hp > dl > dt {
  color: var(--color-hp);
  background-color: rgba(var(--color-rgb-hp), .2);
}
.l-faq.--hp > dl > dt::before {
  background-color: var(--color-hp);
}

.l-faq.--meo > dl > dt {
  color: var(--color-meo);
  background-color: rgba(var(--color-rgb-meo), .2);
}
.l-faq.--meo > dl > dt::before {
  background-color: var(--color-meo);
}

.l-faq.--seo > dl > dt {
  color: var(--color-seo);
  background-color: rgba(var(--color-rgb-seo), .2);
}
.l-faq.--seo > dl > dt::before {
  background-color: var(--color-seo);
}

@media (max-width: 960px) {
}
@media (max-width: 768px) {
  .l-faq {
    padding: 1rem;
  }
  .l-faq > dl > dt,
  .l-faq > dl > dd {
    font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
    padding: 0.75em 1em 0.75em 3em;
  }
  .l-faq > dl > dt::before,
  .l-faq > dl > dd::before {
    top: 0.6em;
  }
}
@media (max-width: 479px) {
}



.l-common-contact {
  padding: 4rem 0;
  background-color: var(--color-primary);
}
.l-common-contact-inner {
  border-radius: 32px;
  background-color: #fff;
}



.l-teams {
  width: min(800px, 90%);
  margin-inline: auto;
  flex-wrap: wrap;
  gap: 1.5rem;
}
.l-teams.--member-text {
  width: 90%;
}








.l-deco {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}



.l-about-main {
  /* padding: 4rem 2rem; */
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background-color: rgba(255, 255, 255, 0.8);
}
.l-about-main .inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 4rem 0;
  gap: 2rem;
}


.l-about-main.--philosophy .inner .__l {
}
.l-about-main.--philosophy .inner .__r {
  width: 90%;
}



.l-about-main.--vision .inner .__l {
  width: 60%;
  padding-left: 4rem;
}
.l-about-main.--vision .inner .__r {
  position: relative;
  width: 40%;
  height: 300px;
}
.l-about-main.--vision .inner .__r .__img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 60%;
}

.l-about-main.--corevalues .inner {
  padding: 4rem 0;
}
.l-about-main.--corevalues .inner .c-card-checklist span {
}


.l-about-info dl {
  display: flex;
  justify-content: space-between;
  align-items: start;
  flex-wrap: wrap;
  border-top: 1px solid rgba(var(--color-rgb-txt), .3);
  border-left: 1px solid rgba(var(--color-rgb-txt), .3);
  border-right: 1px solid rgba(var(--color-rgb-txt), .3);
}
.l-about-info dl > dt,
.l-about-info dl > dd {
  color: var(--color-txt);
  font-size: clamp(1.4rem, 1.3328rem + 0.14vw, 1.5rem);
  height: -webkit-fill-available;
  padding: 1em;
  border-bottom: 1px solid rgba(var(--color-rgb-txt), .3);
}
.l-about-info dl > dt {
  width: 30%;
  border-right: 1px solid rgba(var(--color-rgb-txt), .3);
  background-color: rgb(232, 240, 254);
}
.l-about-info dl > dd {
  width: 70%;
  background-color: #fff;
}

@media (max-width: 960px) {
  .l-about-main .inner {
    justify-content: center;
    flex-wrap: wrap;
  }
  .l-about-main.--vision .inner .__l {
    width: 90%;
    padding: 2rem 0;
  }
  .l-about-main.--vision .inner .__l > p {
    width: max-content;
    max-width: 100%;
    margin-inline: auto;
  }

  .l-about-main.--vision .inner .__r {
    width: 100%;
  }
  .l-about-main.--vision .inner .__r .__img {
    width: 90%;
    max-width: 50%;
    min-width: 280px;
  }
  
  .l-about-main.--vision.u-bg.--shakehand::before {
    top: auto;
    bottom: 0;
    width: 100%;
    height: 40%;
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0.8) 0%, rgba(255, 255, 255, 0) 30%),
    url('../img/bg-mv.webp') center / cover no-repeat;
    }
  
}
@media (max-width: 768px) {
  .l-about-info dl > dt,
  .l-about-info dl > dd {
    width: 100%;
    height: auto;
  }
  .l-about-info dl > dt {
    border-right: none;
  }
}
@media (max-width: 479px) {
}



.l-privacy-policy-main {
  width: 90%;
  padding-left: 4em;
  margin-inline: auto;
}
.l-privacy-policy-main > ol {
  list-style-type: auto;
}
.l-privacy-policy-main > ol > li {
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  font-weight: 600;
  line-height: 2;
  margin-bottom: 1em;
}
.l-privacy-policy-main > ol > li p,
.l-privacy-policy-main > ol > li ul {
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 2;
}
.l-privacy-policy-main > ol > li ul {
  margin-left: 2em;
  list-style-type: disc;
}

.l-contact-main {
  max-width: 90%;
  width: 600px;
  margin-inline: auto;
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
}



.l-line-cta {
  margin-bottom: 16rem;
}

.c-common-line-cta {
  display: flex;
  justify-content: space-between;
  align-items: center;

  padding: 4rem;
  background-color: var(--color-secondary);
  gap: 2rem;
}
.c-common-line-cta .__r {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  flex: 1;
}
.c-common-line-cta .__r > p {
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  font-weight: 600;
  text-align: center;
}
.c-common-line-cta .__r > a {
  margin-inline: auto;
}

@media (max-width: 768px) {
  .c-common-line-cta {
    align-items: center;
    flex-direction: column;
    gap: 2rem;
  }
  .c-common-line-cta .__r {
    width: 100%;
  }
}
@media (max-width: 479px) {
  .c-common-line-cta {
    padding: 2rem;
 }
}











.wpcf7 {
  width: 100%;
}




/* フォーム全体の枠 */
.contact-form-wrapper {
  max-width: 600px;
  margin: 0 auto;
  background-color: #ff7a3d;
  border-radius: 16px;
  padding: 40px 24px;
  color: #fff;
  font-family: "Noto Sans JP", sans-serif;
}

.wpcf7-form {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}

.wpcf7-form h4 {
  display: block;
  color: var(--color-txt);
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  font-weight: 700;
}


.wpcf7-form-control-wrap > input,
.wpcf7-form-control-wrap > textarea {
  color: var(--color-txt);
  width: 100%;
  padding: 0.5em;
  border-radius: 8px;
  background-color: rgb(232, 240, 254);
  resize: none;
}

.wpcf7-form-control-wrap textarea {
  min-height: 120px;
  resize: vertical;
}

/* プレースホルダーのスタイル */
.wpcf7-form ::placeholder {
  color: #bbb;
}

.wpcf7-form-control-wrap {
  display: block;
  margin-bottom: 1rem;
}

.wpcf7-submit {
  color: #fff;
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  width: 240px;
  max-width: 90%;
  padding: 1em 0;
  border-radius: 32px;
  margin-inline: auto;
  background-color: var(--color-hp);
}


.wpcf7-checkbox {
  display: flex;
  justify-content: start;
  align-items: start;
  flex-wrap: wrap;
  gap: 1rem 2rem;
}
.wpcf7-list-item {
  margin: 0;
}
.wpcf7-list-item-label {
  font-size: 1.4rem;
}

.wpcf7-spinner {
  margin-inline: auto;
}
.wpcf7 form.sent .wpcf7-response-output {
  border-color: var(--color-hp);
}

.wpcf7-acceptance {
  display: block;
  width: max-content;
  margin-inline: auto;
}

.wpcf7-acceptance .wpcf7-list-item-label {
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
}


.wpcf-privacy-policy-link {
  display: inline-block;
  color: var(--color-txt);
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  text-decoration: underline;
  width: max-content;
  margin-inline: auto;
  margin-bottom: 2rem;
}




@media (max-width: 768px) {
}
@media (max-width: 479px) {
  .wpcf7-checkbox {
    flex-direction: column;
  }
}













/* 
　c- コンポーネント
　  子要素を持つ
 */
.c-mv-sub {
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: inherit;
}
.c-mv-sub-main .l-contact-link-mails {
  width: max-content;
  margin-top: 7rem;
}


/* 
　ttl- タイトル
 */
.c-ttl-mv-pre {
  color: var(--color-txt-mv);
  font-size: clamp(2.3rem, 1.8336rem + 0.97vw, 3rem);
  font-family: var(--ff-jp);
  font-weight: 400;
  letter-spacing: .1em;
  line-height: 1;
}
.c-ttl-mv {
  color: var(--color-txt-mv);
  font-size: clamp(3.8rem, 2.3328rem + 3.06vw, 6rem);
  font-family: var(--ff-jp);
  font-weight: 600;
  letter-spacing: .1em;
  line-height: 2;
  white-space: nowrap;
}
.c-ttl-card-appeal {
  color: var(--color-txt);
  text-align: center;
  font-size: clamp(1.6rem, 1.5328rem + 0.14vw, 1.7rem);
  font-weight: 700;
  line-height: 1.6;
}
.c-ttl-sect {
  text-align: center;
  color: var(--color-primary);
  font-size: clamp(2.5rem, 1.9008rem + 1.25vw, 3.4rem);
  font-family: var(--ff-jp);
  font-weight: 700;
  letter-spacing: .1em;
  line-height: 2;
}
.c-ttl-sect > span {
  display: block;
  font-size: 1.3rem;
  font-weight: 500;
  line-height: 1;
}

.c-ttl-sect.--about {
  color: var(--color-txt);
}


.c-ttl-cont {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.6rem;
  gap: 1rem;
}
.c-ttl-cont .__num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 3rem;
  width: 1.4em;
  height: 1.4em;
  color: #fff;
  border-radius: 50%;
  background-color: var(--color-line);

}
.c-ttl-cont .__word {
  display: inline-block;
  
}


.c-ttl-line {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 2rem;
  flex-wrap: nowrap;
}
.c-ttl-line.__instagram {
  justify-content: space-between;
  width: 240px;
  gap: 0rem;
  flex-wrap: wrap;
}
.c-ttl-line .__word {
  color: var(--color-line);
  font-size: clamp(2.3rem, 1.8336rem + 0.97vw, 3rem);
}
.c-ttl-line.__instagram .__word {
  color: var(--color-line);
  font-size: clamp(1.8rem, 1.6672rem + 0.28vw, 2rem);
  font-weight: 700;
}


@media (max-width: 960px) {
  .c-ttl-mv-pre {
    font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
    line-height: 1.4;
  }
  .c-ttl-mv {
    font-size: clamp(3.2rem, 2.0672rem + 2.36vw, 4.9rem);
    line-height: 1.4;
    padding: 1rem 0;
    white-space: wrap;
    margin-bottom: 5rem;
  }
}
@media (max-width: 768px) {
  .c-ttl-line {
    gap: 1rem;
  }
  .c-ttl-line .__word {
    color: var(--color-line);
    font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  }
}
@media (max-width: 479px) {
  .c-ttl-line.__instagram {
    width: 200px;
  }
}


/* 
　-text テキスト
 */

.c-text-about {
  color: var(--color-txt);
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  font-family: 'Noto Serif JP', sans-serif;
  font-weight: 600;
  letter-spacing: .1em;
  line-height: 2;
}

/* @media (max-width: 960px) {
  .c-ttl-mv-pre {
    font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
    line-height: 1.4;
  }
  .c-ttl-mv {
    font-size: clamp(3.2rem, 2.0672rem + 2.36vw, 4.9rem);
    line-height: 1.4;
    padding: 1rem 0;
    white-space: wrap;
    margin-bottom: 5rem;
  }
}
@media (max-width: 768px) {
  .c-ttl-line {
    gap: 1rem;
  }
  .c-ttl-line .__word {
    color: var(--color-line);
    font-size: clamp(1.75rem, 1.6496rem + 0.21vw, 1.9rem);
  }
} */
@media (max-width: 479px) {
  .c-text-about {
    font-size: 1.5rem;
    line-height: 1.8;
    width: 90%;
    margin-inline: auto;
  }
}

.c-text-mv {
  color: var(--color-txt);
  font-size: clamp(1.8rem, 1.6672rem + 0.28vw, 2rem);
  font-family: 'Noto Serif JP', sans-serif;
  font-weight: 600;
  letter-spacing: .1em;
  line-height: 2;
}

@media (max-width: 960px) {
  .c-mv-sub {
    justify-content: center;
  }
}
@media (max-width: 768px) {
}
@media (max-width: 479px) {
}









.c-list-num {
  font-size: 1.4rem;
  list-style: auto;
  margin-left: 2em;
}
.c-list-disc {
  font-size: 1.4rem;
  list-style-type: disc;
  margin-left: 2em;
}








/* カード：アピール */
.c-card-appeal {
  display: flex;
  flex-direction: column;
  justify-content: start;
  align-items: center;
  width: min(200px, 90%);
  /* height: -webkit-fill-available; */
  padding: 4rem 0;
  border-radius: 32px;
  /* margin-inline: auto; */
  background-color: rgba(255, 255, 255, 0.5);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  gap: 2rem;
}
.c-card-appeal-text,
.c-card-appeal-list {
  color: var(--color-txt);
  text-align: left;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.6;
  padding: 0 2rem;
}
.c-card-appeal-list {
  list-style-type: disc;
  padding: 0 2rem 0 4rem;
}

.c-card-appeal-highlight > span {
  display: inline-block;
  color: var(--color-txt);
  /* color: #fff; */
  text-align: center;
  font-size: 1.3rem;
  font-weight: 400;
  line-height: 1.6;
  width: max-content;
  max-width: 90%;
  padding: 1em 1em;
  background-color: var(--color-primary);
}

.c-card-appeal-highlight.--instagram > span {
  background-color: var(--color-instagram);
}
.c-card-appeal-highlight.--line > span {
  background-color: var(--color-line);
}
.c-card-appeal-highlight.--hp > span {
  background-color: var(--color-hp);
}
.c-card-appeal-highlight.--meo > span {
  background-color: var(--color-meo);
}
.c-card-appeal-highlight.--seo > span {
  background-color: var(--color-seo);
}


.c-card-appeal-appeal {
  font-size: clamp(1.7rem, 1.6336rem + 0.14vw, 1.8rem);
}


@media (max-width: 960px) {
}
@media (max-width: 768px) {
}
@media (max-width: 479px) {
  .c-card-appeal {
    padding: 2rem 0;
  }
}














/* カード：コンタクト */
.c-card-contact {
  position: relative;
  display: flex;
  flex-direction: column;

  text-align: center;
  width: min(90%, 360px);
  padding: 8rem 0 4rem;
}
.c-card-contact .c-card-contact-icon {
  position: absolute;
  top: -20px;
  left: 50%;
  transform: translateX(-50%);
}

.c-card-contact h3 {
  color: var(--color-txt);
  font-size: clamp(1.9rem, 1.7008rem + 0.42vw, 2.2rem);
  font-weight: 900;
  line-height: 2;
}
.c-card-contact p {
  color: var(--color-txt);
  font-size: clamp(1.4rem, 1.3328rem + 0.14vw, 1.5rem);
  font-weight: 600;
  margin-bottom: 6rem;
}
.c-card-contact .__link {
  margin-inline: auto;
}
.c-card-contact .__link.--mail a {
  background-color: var(--color-hp);
}

/* カード：料金プラン */
.c-card-price {
  position: relative;
  display: flex;
  flex-direction: column;
  text-align: center;
  width: min(90%, 360px);
  box-shadow: 0 0 5px 0px var(--color-primary);
  padding: 3rem 0;
  border-radius: 24px;
  background-color: #fff;
  gap: 2rem;
}
.c-card-price.--hp {
  box-shadow: 0 0 5px 0px var(--color-hp);
}
.c-card-price.--instagram {
  box-shadow: 0 0 5px 0px var(--color-instagram);
}
.c-card-price.--line {
  box-shadow: 0 0 5px 0px var(--color-line);
}
.c-card-price.--meo {
  box-shadow: 0 0 5px 0px var(--color-meo);
}
.c-card-price.--seo {
  box-shadow: 0 0 5px 0px var(--color-seo);
}




.c-card-price.--no1 {
  box-shadow: 0 0 5px 5px var(--color-primary);
}
.c-card-price.--no1.--hp {
  box-shadow: 0 0 5px 5px var(--color-hp);
}
.c-card-price.--no1.--instagram {
  box-shadow: 0 0 5px 5px var(--color-instagram);
}
.c-card-price.--no1.--line {
  box-shadow: 0 0 5px 5px var(--color-line);
}
.c-card-price.--no1.--meo {
  box-shadow: 0 0 5px 5px var(--color-meo);
}
.c-card-price.--no1.--seo {
  box-shadow: 0 0 5px 5px var(--color-seo);
}



.c-card-price.--no1::before {
  content: "人気 No.1";
  position: absolute;
  top: 22px;
  left: 0;
  color: #fff;
  font-size: 1.4rem;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, .5);
  width: max-content;
  padding: 0.5em 1em;
  border-radius: 0 32px 32px 0;
  background: linear-gradient(to right, #d8b44d, #f4cf66, #d8b44d);
}

.c-card-price > span {
  color: var(--color-primary);
  font-size: 1.4rem;
  font-weight: 500;
}

.c-card-price.--hp > span {
  color: var(--color-hp);
}
.c-card-price.--instagram > span {
  color: var(--color-instagram);
}
.c-card-price.--line > span {
  color: var(--color-line);
}
.c-card-price.--meo > span {
  color: var(--color-meo);
}
.c-card-price.--seo > span {
  color: var(--color-seo);
}



.c-card-price > h3 {
  color: var(--color-primary);
  font-size: clamp(2rem, 1.7328rem + 0.56vw, 2.4rem);
  font-weight: 900;
}

.c-card-price.--hp > h3 {
  color: var(--color-hp);
}
.c-card-price.--instagram > h3 {
  color: var(--color-instagram);
}
.c-card-price.--line > h3 {
  color: var(--color-line);
}
.c-card-price.--meo > h3 {
  color: var(--color-meo);
}
.c-card-price.--seo > h3 {
  color: var(--color-seo);
}

.c-card-price > p {
  color: var(--color-txt);
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  font-weight: 700;
}

.c-card-price ul {
  /* width: min(90%, 280px); */
  width: max-content;
  max-width: 90%;
  margin-inline: auto;
}

.c-card-price ul > li {
  display: flex;
  justify-content: start;
  align-items: center;
  gap: 1rem;
  color: var(--color-txt);
  font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
  font-weight: 700;
  margin-bottom: 1rem;
}

.c-card-price .c-card-checklist {
  max-width: 90%;
  width: max-content;
  margin-inline: auto;
}
.c-card-price .c-card-checklist > li {
  display: flex;
  justify-content: start;
  align-items: center;
  color: var(--color-txt);
  text-align: left;
  font-size: 1.4rem;
  font-weight: 700;
  border-bottom: none;
  gap: 1rem;
}


/* カード：オプション */
.c-card-option {
  position: relative;
  display: flex;
  flex-direction: column;
  text-align: center;
  width: min(90%, 400px);
  box-shadow: 0 0 10px 0px var(--color-primary);
  padding: 3rem 0;
  border-radius: 24px;
  background-color: #fff;
  gap: 2rem;
}

.c-card-option.--hp {
  box-shadow: 0 0 10px 0px var(--color-hp);
}
.c-card-option.--instagram {
  box-shadow: 0 0 10px 0px var(--color-instagram);
}
.c-card-option.--line {
  box-shadow: 0 0 10px 0px var(--color-line);
}
.c-card-option.--meo {
  box-shadow: 0 0 10px 0px var(--color-meo);
}
.c-card-option.--seo {
  box-shadow: 0 0 10px 0px var(--color-seo);
}

.c-card-option > h3,
.c-card-option > p
{
  color: var(--color-txt);
  font-size: clamp(1.6rem, 1.5328rem + 0.14vw, 1.7rem);
  font-weight: 900;
}

.c-card-checklist {
  width: max-content;
  max-width: 90%;
  margin-inline: auto;
}
.c-card-checklist > li {
  display: flex;
  justify-content: start;
  align-items: center;
  color: var(--color-txt);
  text-align: left;
  font-size: 1.4rem;
  font-weight: 700;
  margin-bottom: 1rem;
  gap: 1rem;
}


/* カード：チームメンバー */
.c-card-teams-logo,
.c-card-teams {
  position: relative;
  width: min(240px, 90%);
}
.c-card-teams-logo {
  height: 240px;
}
.c-card-teams {
  height: auto;
}


.c-card-teams.--text {
  width: max-content;
  max-width: 520px;
}





.c-card-teams-logo.--pixels {
  background: no-repeat center / 55% url('../img/logo-pixels.svg');
}

.c-card-team-main {
  position: relative;
  width: 100%;
  height: 240px;
}
.c-card-team-main::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: no-repeat center / cover  url('../img/bg-teams.svg');
  z-index: 1;
}
.c-card-teams.--text .c-card-team-main::before {
  background: none;
}
.c-card-teams.--text .c-card-team-main {
  height: auto;
}



.c-card-team-main::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}


.c-card-teams-logo.--dentique-atelier {
  background: no-repeat center / 55% url('../img/logo.svg');
}
.c-card-team-main.--member01::after {
  background: #dc7492;
}
.c-card-team-main.--member02::after {
  background: #88e8e8;
}
.c-card-team-main.--member03::after {
  background: #ffff80;
}
.c-card-team-main.--member04::after {
  background: #828283;
}
.c-card-team-main.--member05::after {
  background: #807ffe;
}
.c-card-team-main.--member06::before,
.c-card-team-main.--member07::before,
.c-card-team-main.--member08::before {
  background: rgba(255, 255, 255, .2);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  box-shadow: 0 0 3px 4px rgba(0, 0, 0, .2);
}

/* --primary-color-1: #dc7492;
--primary-color-1-rgb: 220, 116, 146;
--primary-color-2: #88e8e8;
--primary-color-2-rgb: 136, 232, 232;
--primary-color-3: #828283;
--primary-color-3-rgb: 130, 130, 131;
--primary-color-4: #807ffe;
--primary-color-4-rgb: 128, 127, 254;
--primary-color-5: #ffff80;
--primary-color-5-rgb: 255, 255, 128; */

.c-card-team-main .c-card-teams-member {
  position: absolute;
  right: 0;
  bottom: 0;
  width: 100%;
  height: 80%;
  z-index: 5;
}
.c-card-team-main.--member01 .c-card-teams-member {
  background: no-repeat right bottom / contain url('../img/member-01.png');
}
.c-card-team-main.--member02 .c-card-teams-member {
  background: no-repeat right bottom / contain url('../img/member-02.png');
}
.c-card-team-main.--member03 .c-card-teams-member {
  background: no-repeat right bottom / contain url('../img/member-03.png');
}
.c-card-team-main.--member04 .c-card-teams-member {
  background: no-repeat right bottom / contain url('../img/member-04.svg');
}
.c-card-team-main.--member05 .c-card-teams-member {
  background: no-repeat right bottom / contain url('../img/member-05.png');
}
.c-card-team-main.--member06 .c-card-teams-member {
  height: 100%;
  background: no-repeat right bottom / 100% url('../img/member-06.png');
}
.c-card-team-main.--member07 .c-card-teams-member {
  height: 100%;
  background: no-repeat center / 80%  url(../img/member-07.svg);
  /* right: 2rem; */
  /* bottom: 2em;
  width: 50%;
  height: 50%;
  border-radius: 50%; */
}
.c-card-team-main.--member08 .c-card-teams-member {
  height: 100%;
  background: no-repeat right bottom / 100% url('../img/member-08.jpg');
}

.c-card-teams-info {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  color: #fff;
  text-shadow: 1px 1px 2px rgba(0, 0, 0, .8);
  height: 240px;
  padding-left: 2rem;
  z-index: 9;
}
.c-card-teams.--text .c-card-teams-info {
  display: block;
  height: auto;
}



.c-card-teams .--member01 .c-card-teams-info {
}
.c-card-teams .--member02 .c-card-teams-info {
}
.c-card-teams .--member03 .c-card-teams-info {
  /* color: #000; */
}
.c-card-teams .--member04 .c-card-teams-info {
}
.c-card-teams .--member05 .c-card-teams-info {
}
.c-card-teams .--member06 .c-card-teams-info,
.c-card-teams .--member07 .c-card-teams-info,
.c-card-teams .--member08 .c-card-teams-info {
  position: absolute;
  bottom: 0;
  height: max-content;
  color: var(--color-txt);
  text-shadow: 1px 1px 2px rgba(0, 0, 0, .2);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  padding: 1rem 2rem 0.5rem;
  background: rgba(255, 255, 255, .5);
  width: max-content;
  right: 0;
  align-items: end;
  
  /* position: absolute;
  bottom: 0;
  height: 30%;
  color: var(--color-txt);
  text-shadow: 1px 1px 2px rgba(0, 0, 0, .2);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  padding: 1rem 0 0.5rem 1rem;
  background: rgba(255, 255, 255, .5);
  width: 60%;
  right: 0; */
}


.c-card-teams-info .__katagaki {
  font-size: 1.4rem;
  line-height: 1.6;
}
.c-card-teams.--text .c-card-teams-info .__katagaki {
  color: var(--color-txt);
  text-shadow: none;
  line-height: 1.8;
}
.c-card-teams.--text .c-card-teams-info .__katagaki > span {
  display: block;
  font-size: 1.2em;
  font-weight: 900;
  margin-bottom: 1em;
}



.c-card-teams-info .__name {
  font-size: clamp(1.8rem, 1.6672rem + 0.28vw, 2rem);
  line-height: 2;
}
.c-card-teams-info .__name-en {
  font-size: 1.0rem;
  line-height: 1.4;
  margin-bottom: 2rem;
}
.c-card-teams-info .__pref {
  font-size: 1.2rem;

}
.c-card-teams-info .__cons {
  font-size: 1.2rem;

}
.c-card-teams-info .__blood {
  font-size: 1.2rem;
  margin-bottom: 1rem;
}
.c-card-teams-info .__tag {
  font-size: 1.2rem;

}

.c-card-teams-text {
  color: var(--color-txt);
  text-align: left;
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.6;
  padding-top: 1em;
}














.c-btn {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: max-content;
  border-radius: 60px;
  padding: 1.0em 4em 1.0em 1em;
  background: var(--color-primary);
  gap: 3em;
  transition: box-shadow .4s ease;
}
.c-btn:hover {
  box-shadow: 8px 8px 8px 0px rgba(var(--color-rgb-primary), .4);
}

.c-btn.--seo {
  background: var(--color-seo);
}
.c-btn.--seo:hover {
  box-shadow: 8px 8px 8px 0px rgba(var(--color-rgb-seo), .4);
}

.c-btn.--meo {
  background: var(--color-meo);
}
.c-btn.--meo:hover {
  box-shadow: 8px 8px 8px 0px rgba(var(--color-rgb-meo), .4);
}

.c-btn.--instagram {
  background: var(--color-instagram);
}
.c-btn.--instagram:hover {
  box-shadow: 8px 8px 8px 0px rgba(var(--color-rgb-instagram), .4);
}


.c-btn.--line {
  background: var(--color-line);
}
.c-btn.--line:hover {
  box-shadow: 8px 8px 8px 0px rgba(var(--color-rgb-line), .4);
}


.c-btn.--hp {
  background: var(--color-hp);
}
.c-btn.--hp:hover {
  box-shadow: 8px 8px 8px 0px rgba(var(--color-rgb-hp), .4);
}

.c-btn > span.word {
  display: inline-block;
  color: #fff;
  font-size: clamp(1.7rem, 1.6336rem + 0.14vw, 1.8rem);
  z-index: 1;
}

#icon-mail .cls-1 {
  fill: var(--color-primary);
}


@media (max-width: 960px) {
  .c-text-mv {
    font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
    line-height: 1.4;
  }
}
@media (max-width: 768px) {
  .c-btn {
    gap: 2em;
  }
  .c-btn > span.word {
    font-size: clamp(1.4rem, 1.3328rem + 0.14vw, 1.5rem);
  }

  .c-text-mv {
    font-size: clamp(1.5rem, 1.4336rem + 0.14vw, 1.6rem);
    line-height: 1.8;
    background: rgba(0, 74, 173, 0.05);
    backdrop-filter: blur(2px);
    -webkit-backdrop-filter: blur(2px);
    display: block;
    padding: 1.5em;
    border-radius: 16px;
  }
  .c-text-mv.--instagram {
    background: rgba(var(--color-rgb-instagram), 0.05);
  }
  .c-text-mv.--line {
    background: rgba(var(--color-rgb-line), 0.05);
  }
  .c-text-mv.--hp {
    background: rgba(var(--color-rgb-hp), 0.05);
  }
  .c-text-mv.--meo {
    background: rgba(var(--color-rgb-meo), 0.05);
  }
  .c-text-mv.--seo {
    background: rgba(var(--color-rgb-seo), 0.05);
  }

}



/* 
　u- ユーティリティ
　  最小単位、どこでも使える
 */
.u-essential,
.u-option {
  font-size: 0.7em;
  margin-left: 1em;
}
.u-essential {
  color: #f00;
}
  


.u-popup {
  position: relative;
}
.u-popup::before {
  content: "popup";
  position: absolute;
  top: -2.0em;
  left: 50%;
  transform: translateX(-50%);
  color: red;
  text-align: center;
  font-size: 1.6rem;
  font-weight: 600;
  width: 100%;
}
.u-popup.--mail::before {
  content: "＼初回相談は無料です／";
}
.u-popup.--line::before {
  content: "＼特典の受取はこちらから／";
}

.u-mv-img {
  position: relative;
}
.u-mv-img::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: min(640px, 48vw);
  height: 620px;
  z-index: -1;
}

@media (max-width: 960px) {
  .u-mv-img::after {
    width: 90%;
    left: 50%;
    right: auto;
    transform: translate(-50%, -50%) scale(1.5);
    opacity: 0.2;
  }
}


.u-mv-img.--seo::after {
  background: no-repeat center / contain url('../img/mv-service-seo.svg');
}
.u-mv-img.--meo::after {
  background: no-repeat center / contain url('../img/mv-service-meo.svg');
}
.u-mv-img.--instagram::after {
  background: no-repeat center / contain url('../img/mv-service-instagram.svg');
}
.u-mv-img.--line::after {
  background: no-repeat center / contain url('../img/mv-service-line.svg');
}
.u-mv-img.--hp::after {
  background: no-repeat center / contain url('../img/mv-service-hp.svg');
}


.u-icon {
  display: inline-block;
  width: 80px;
  height: 80px;
  background: no-repeat center / 70% url('../img/logo.svg');
  z-index: 1;
}
.u-icon.--sz2-1 {
  width: 160px;
  height: 80px;
}
.u-icon.--sz15 {
  width: 15px;
  height: 15px;
}
.u-icon.--sz20 {
  width: 20px;
  height: 20px;
}
.u-icon.--sz25 {
  width: 25px;
  height: 25px;
}
.u-icon.--sz30 {
  width: 30px;
  height: 30px;
}
.u-icon.--sz40 {
  width: 40px;
  height: 40px;
}
.u-icon.--sz50 {
  width: 50px;
  height: 50px;
}
.u-icon.--sz60 {
  width: 60px;
  height: 60px;
}
.u-icon.--sz120 {
  width: 120px;
  height: 120px;
}
.u-icon.--radius50 {
  border-radius: 50%;
}

@media (max-width: 960px) {
}
@media (max-width: 768px) {
  .u-icon.--sz-sp {
    width: calc(80px * 0.85);
    height: calc(80px * 0.85);
  }
  .u-icon.--sz2-1.--sz-sp {
    width: calc(160px * 0.85);
    height: calc(80px * 0.85);
  }
  .u-icon.--sz15.--sz-sp {
    width: calc(15px * 0.85);
    height: calc(15px * 0.85);
  }
  .u-icon.--sz20.--sz-sp {
    width: calc(20px * 0.85);
    height: calc(20px * 0.85);
  }
  .u-icon.--sz25.--sz-sp {
    width: calc(25px * 0.85);
    height: calc(25px * 0.85);
  }
  .u-icon.--sz30.--sz-sp {
    width: calc(30px * 0.85);
    height: calc(30px * 0.85);
  }
  .u-icon.--sz40.--sz-sp {
    width: calc(40px * 0.85);
    height: calc(40px * 0.85);
  }
  .u-icon.--sz120.--sz-sp {
    width: calc(120px * 0.85);
    height: calc(120px * 0.85);
  }
}
@media (max-width: 479px) {
  .u-icon.--sz-sp {
    width: calc(80px * 0.7);
    height: calc(80px * 0.7);
  }
  .u-icon.--sz2-1.--sz-sp {
    width: calc(160px * 0.7);
    height: calc(80px * 0.7);
  }
  .u-icon.--sz15.--sz-sp {
    width: calc(15px * 0.7);
    height: calc(15px * 0.7);
  }
  .u-icon.--sz20.--sz-sp {
    width: calc(20px * 0.7);
    height: calc(20px * 0.7);
  }
  .u-icon.--sz25.--sz-sp {
    width: calc(25px * 0.7);
    height: calc(25px * 0.7);
  }
  .u-icon.--sz30.--sz-sp {
    width: calc(30px * 0.7);
    height: calc(30px * 0.7);
  }
  .u-icon.--sz40.--sz-sp {
    width: calc(40px * 0.7);
    height: calc(40px * 0.7);
  }
  .u-icon.--sz120.--sz-sp {
    width: calc(120px * 0.7);
    height: calc(120px * 0.7);
  }
}





.u-icon.--mail {
  background: #fff;
  background: no-repeat center / 60% #fff url('../img/icon-mail.svg');
}
.u-icon.--mail.--white {
  background: no-repeat center / 60% var(--color-hp) url('../img/icon-mail-white.svg');
}
.u-icon.--rhombus {
  background: no-repeat center / contain url('../img/icon-rhombus.svg');
}
.u-icon.--star {
  background: no-repeat center / contain url('../img/icon-star.svg');
}
.u-icon.--check-circle.--green {
  background: no-repeat center / contain url('../img/icon-check-circle-green.svg');
}
.u-icon.--exclamation.--red {
  background: no-repeat center / contain url('../img/icon-exclamation-red.svg');
}


.u-icon.--mail.--seo {
  background: no-repeat center / 60% #fff url('../img/icon-mail-seo.svg');
}
.u-icon.--mail.--meo {
  background: no-repeat center / 60% #fff url('../img/icon-mail-meo.svg');
}
.u-icon.--mail.--instagram {
  background: no-repeat center / 60% #fff url('../img/icon-mail-instagram.svg');
}
.u-icon.--mail.--line {
  background: no-repeat center / 60% #fff url('../img/icon-mail-line.svg');
}
.u-icon.--mail.--hp {
  background: no-repeat center / 60% #fff url('../img/icon-mail-hp.svg');
}

.u-icon.--line {
  background: no-repeat center / 80% url('../img/icon-line.svg');
}
.u-icon.--line.--back {
  border-radius: 16px;
  background: no-repeat center / 70% #00B900 url('../img/icon-line.svg');
}
.u-icon.--line.--rev {
  border-radius: 16px;
  background: no-repeat center / contain url('../img/icon-line-rev.svg');
}
.u-icon.--line.--word.--green {
  border-radius: 16px;
  background: no-repeat center / contain url('../img/icon-line-word-green.svg');
}

.u-icon.--instagram {
  background: no-repeat center / 60% #fff url('../img/icon-instagram-color.svg');
}

.u-icon.--present {
  /* border-radius: 16px; */
  background: no-repeat center / contain url('../img/icon-present.svg');
}

.u-icon.--yen {
  background: no-repeat center / contain #fff url('../img/icon-yen.svg');
}
.u-icon.--time {
  background: no-repeat center / contain #fff url('../img/icon-time.svg');
}
.u-icon.--beginner {
  background: no-repeat center / contain #fff url('../img/icon-beginner.svg');
}
.u-icon.--check {
  background: no-repeat center / contain #fff url('../img/icon-check.svg');
}
.u-icon.--check.--meo {
  background: no-repeat center / contain #fff url('../img/icon-check-meo.svg');
}
.u-icon.--dash.--hp {
  background: no-repeat center / contain url('../img/icon-dash-hp.svg');
}
.u-icon.--leader.--hp {
  background: no-repeat center / contain url('../img/icon-leader-hp.svg');
}
.u-icon.--seo-search.--hp {
  background: no-repeat center / contain url('../img/icon-seo-search-hp.svg');
}
.u-icon.--smartphone.--instagram {
  background: no-repeat center / contain url('../img/icon-smartphone-instagram.svg');
}
.u-icon.--smartphone.--hp {
  background: no-repeat center / contain url('../img/icon-smartphone-hp.svg');
}
.u-icon.--window.--hp {
  background: no-repeat center / contain url('../img/icon-window-hp.svg');
}
.u-icon.--wordpress.--hp {
  background: no-repeat center / contain url('../img/icon-wordpress-hp.svg');
}
.u-icon.--picture.--hp {
  background: no-repeat center / contain url('../img/icon-picture-hp.svg');
}
.u-icon.--pen.--hp {
  background: no-repeat center / contain url('../img/icon-pen-hp.svg');
}
.u-icon.--gold.--hp {
  background: no-repeat center / contain url('../img/icon-gold-hp.svg');
}
.u-icon.--secure.--hp {
  background: no-repeat center / contain url('../img/icon-secure-hp.svg');
}
.u-icon.--graph.--hp {
  background: no-repeat center / contain url('../img/icon-graph-hp.svg');
}
.u-icon.--callcenter.--hp {
  background: no-repeat center / contain url('../img/icon-callcenter-hp.svg');
}
.u-icon.--config.--hp {
  background: no-repeat center / contain url('../img/icon-config-hp.svg');
}

.u-icon.--doctor.--instagram {
  background: no-repeat center / contain url('../img/icon-doctor-instagram.svg');
}
.u-icon.--pallet.--instagram {
  background: no-repeat center / contain url('../img/icon-pallet-instagram.svg');
}
.u-icon.--heart.--instagram {
  background: no-repeat center / contain url('../img/icon-heart-instagram.svg');
}
.u-icon.--load.--instagram {
  background: no-repeat center / contain url('../img/icon-load-instagram.svg');
}
.u-icon.--support.--instagram {
  background: no-repeat center / contain url('../img/icon-support-instagram.svg');
}
.u-icon.--post.--instagram {
  background: no-repeat center / contain url('../img/icon-post-instagram.svg');
}
.u-icon.--pen.--instagram {
  background: no-repeat center / contain url('../img/icon-pen-instagram.svg');
}
.u-icon.--calendar.--instagram {
  background: no-repeat center / contain url('../img/icon-calendar-instagram.svg');
}
.u-icon.--smartphone-graph.--instagram {
  background: no-repeat center / contain url('../img/icon-smartphone-graph-instagram.svg');
}





.u-icon.--teeth.--line {
  background: no-repeat center / contain url('../img/icon-teeth-line.svg');
}
.u-icon.--support.--line {
  background: no-repeat center / contain url('../img/icon-support-line.svg');
}
.u-icon.--smartphone-hand.--line {
  background: no-repeat center / contain url('../img/icon-smartphone-hand-line.svg');
}
.u-icon.--hospital.--line {
  background: no-repeat center / contain url('../img/icon-hospital-line.svg');
}
.u-icon.--stethoscope.--line {
  background: no-repeat center / contain url('../img/icon-stethoscope-line.svg');
}
.u-icon.--fuki.--line {
  background: no-repeat center / contain url('../img/icon-fuki-line.svg');
}
.u-icon.--smartphone-config.--line {
  background: no-repeat center / contain url('../img/icon-smartphone-config-line.svg');
}
.u-icon.--menu.--line {
  background: no-repeat center / contain url('../img/icon-menu-line.svg');
}
.u-icon.--talk.--line {
  background: no-repeat center / contain url('../img/icon-talk-line.svg');
}
.u-icon.--smartphone.--line {
  background: no-repeat center / contain url('../img/icon-smartphone-line.svg');
}
.u-icon.--touch.--line {
  background: no-repeat center / contain url('../img/icon-touch-line.svg');
}






.u-icon.--map.--meo {
  background: no-repeat center / contain url('../img/icon-map-meo.svg');
}
.u-icon.--analysis.--meo {
  background: no-repeat center / contain url('../img/icon-analysis-meo.svg');
}
.u-icon.--robot.--meo {
  background: no-repeat center / contain url('../img/icon-robot-meo.svg');
}

.u-icon.--teeth.--seo {
  background: no-repeat center / contain url('../img/icon-teeth-seo.svg');
}
.u-icon.--graph.--seo {
  background: no-repeat center / contain url('../img/icon-graph-seo.svg');
}
.u-icon.--team.--seo {
  background: no-repeat center / contain url('../img/icon-team-seo.svg');
}
.u-icon.--star.--seo {
  background: no-repeat center / contain url('../img/icon-star-seo.svg');
}
.u-icon.--free.--seo {
  background: no-repeat center / contain url('../img/icon-free-seo.svg');
}




/* 

 */
.u-deco {
  position: relative;
}
.u-deco-ab {
  position: absolute;
}

.u-deco::before,
.u-deco::after {
  content: "";
  position: absolute;
}
.u-deco-lbl {
  width: max-content;
  margin-inline: auto;
  z-index: 9;
}
.u-deco-lbl.--paint::before {
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) scale(2.5, 2);
  width: 100%;
  height: 100%;
  z-index: -1;
}
.u-deco-lbl.--paint.--blue::before {
  background: no-repeat center / contain url('../img/icon-paint-blue.svg');
}
.u-deco-lbl.--paint.--red::before {
  background: no-repeat center / contain url('../img/icon-paint-red.svg');
}

.u-deco-lbl.--paint.--instagram::before {
  background: no-repeat center / contain url('../img/icon-paint-instagram.svg');
  opacity: .6;
}
.u-deco-lbl.--paint.--line::before {
  background: no-repeat center / contain url('../img/icon-paint-line.svg');
  opacity: .6;
}
.u-deco-lbl.--paint.--hp::before {
  background: no-repeat center / contain url('../img/icon-paint-hp.svg');
  opacity: .6;
}
.u-deco-lbl.--paint.--meo::before {
  background: no-repeat center / contain url('../img/icon-paint-meo.svg');
  opacity: .6;
}
.u-deco-lbl.--paint.--seo::before {
  background: no-repeat center / contain url('../img/icon-paint-seo.svg');
  opacity: .6;
}
.u-deco-lbl.--paint.--primary::before {
  background: no-repeat center / contain url('../img/icon-paint-primary.svg');
  opacity: .6;
}

.u-deco-lbl.--paint::after {
  top: 20%;
  right: -90px;
  transform: translateY(-50%);
  width: 80px;
  height: 80px;
  background: no-repeat center / contain url('../img/icon-brush.svg');
}

.u-deco-lbl.--dot::before {
  left: 50%;
  bottom: -0.5em;
  transform: translateX(-50%);
  width: 100px;
  height: 20px;
  background: no-repeat center / contain url('../img/icon-paint-dot.svg');
}


.u-deco.u-deco-word::after {
  width: 50vw;
  height: 200px;
  transform: translateX(-50%);
  opacity: .4;
  z-index: -1;
}

.u-deco.u-deco-word.--feature::after {
  max-width: 700px;
  top: -60px;
  left: calc(50% - 20%);
  background: no-repeat center / contain url(../img/icon-feature.svg);
}
.u-deco.u-deco-word.--price::after {
  max-width: 465px;
  top: -100px;
  left: calc(50% + 20%);
  background: no-repeat center / contain url(../img/icon-price.svg);
}
.u-deco.u-deco-word.--faq::after {
  max-width: 465px;
  top: -100px;
  left: calc(50% - 20%);
  background: no-repeat center / contain url(../img/icon-faq.svg);
}
.u-deco.u-deco-word.--teams::after {
  max-width: 465px;
  top: -100px;
  left: calc(50% + 20%);
  background: no-repeat center / contain url(../img/icon-teams.svg);
}

@media (max-width: 960px) {
}

@media (max-width: 768px) {
}

@media (max-width: 479px) {
}




.u-deco.u-deco-paint-c.--twin::after,
.u-deco-ab.u-deco-paint-c.--twin {
  max-width: 120px;
  width: 50vw;
  height: 120px;
  top: -80px;
  right: -130px;
  background: no-repeat center / contain url(../img/icon-paint-circle-twin.svg);
  z-index: -1;
}

.u-deco.u-deco-paint-c.--blue.--1::after,
.u-deco-ab.u-deco-paint-c.--blue.--1 {
  max-width: 140px;
  width: 50vw;
  height: 140px;
  top: 0;
  right: 0;
  background: no-repeat center / contain url(../img/icon-paint-circle-blue.svg);
  z-index: -1;
}
.u-deco.u-deco-paint-c.--blue.--2::after,
.u-deco-ab.u-deco-paint-c.--blue.--2 {
  max-width: 160px;
  width: 50vw;
  height: 160px;
  top: -180px;
  left: 80px;
  background: no-repeat center / contain url(../img/icon-paint-circle-blue.svg);
  z-index: -1;
}
.u-deco.u-deco-paint-c.--blue.--3::after,
.u-deco-ab.u-deco-paint-c.--blue.--3 {
  max-width: 180px;
  width: 50vw;
  height: 180px;
  top: calc(50% + 10%);
  right: -90px;
  transform: translateY(-50%);
  background: no-repeat center / contain url(../img/icon-paint-circle-blue.svg);
  z-index: -1;
}

.u-deco.u-deco-paint-c.--red.--1::after,
.u-deco-ab.u-deco-paint-c.--red.--1 {
  max-width: 60px;
  width: 50vw;
  height: 60px;
  right: -60px;
  bottom: -60px;
  background: no-repeat center / contain url(../img/icon-paint-circle-red.svg);
  z-index: -1;
}
.u-deco.u-deco-paint-c.--red.--2::after,
.u-deco-ab.u-deco-paint-c.--red.--2 {
  max-width: 120px;
  width: 50vw;
  height: 120px;
  top: 0;
  left: 0;
  background: no-repeat center / contain url(../img/icon-paint-circle-red.svg);
  z-index: -1;
}
.u-deco.u-deco-paint-c.--red.--3::after,
.u-deco-ab.u-deco-paint-c.--red.--3 {
  max-width: 80px;
  width: 50vw;
  height: 80px;
  top: calc(50% - 10%);
  right: -80px;
  transform: translateY(-50%);
  background: no-repeat center / contain url(../img/icon-paint-circle-red.svg);
  z-index: -1;
}

.u-deco.u-deco-paint-c.--red.--4::after {
  max-width: 180px;
  width: 50vw;
  height: 180px;
  left: -192px;
  bottom: -128px;
  background: no-repeat center / contain url(../img/icon-paint-circle-red.svg);
  z-index: -1;
}

.u-deco.u-deco-paint-c.--green.--1::before,
.u-deco-ab.u-deco-paint-c.--green.--1 {
  max-width: 80px;
  width: 50vw;
  height: 80px;
  top: 0;
  left: -80px;
  background: no-repeat center / contain url(../img/icon-paint-circle-green.svg);
  z-index: -1;
}
.u-deco.u-deco-paint-c.--green.--2::after {
  max-width: 80px;
  width: 50vw;
  height: 80px;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  background: no-repeat center / contain url(../img/icon-paint-circle-green.svg);
  z-index: -1;
}


@media (max-width: 960px) {
}

@media (max-width: 768px) {
  .u-deco.u-deco-paint-c.--blue.--2::after,
  .u-deco-ab.u-deco-paint-c.--blue.--2 {
    left: -80px;
  }
}

@media (max-width: 479px) {
}










.u-logo-all {
  position: relative;
  width: min(360px, 90vw);
  height: 360px;
}
.u-logo-all::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: clamp(280px, 90vw, 320px);
  height: clamp(280px, 90vw, 320px);
  border-radius: 50%;
  background: no-repeat center / 70% var(--color-secondary) url('../img/logo-all.svg');
}

.u-price-highlight {
  color: var(--color-txt);
  font-size: 1.6em;
  font-weight: 900;
}
.u-price-highlight.--instagram {
  color: var(--color-instagram);
}
.u-price-highlight.--line {
  color: var(--color-line);
}
.u-price-highlight.--hp {
  color: var(--color-hp);
}
.u-price-highlight.--meo {
  color: var(--color-meo);
}
.u-price-highlight.--seo {
  color: var(--color-seo);
}













.l-table-anime {
  display: grid;
  align-items: center;
  justify-items: center;
  width: 100%;
  height: 600px;
  margin-inline: auto;
}

.u-move-circle {
  position: relative;
  display: grid;
  align-items: center;
  justify-items: center;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: #b4daed;
  box-shadow: 0 0 20px 8px rgba(0, 0, 0, .2);
  animation: spin 24s linear infinite;
}
.u-move-circle::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  background: no-repeat center / 60% url('../img/doctor.png');
  animation: spin-3 24s linear infinite;
}

.u-link-circle {
  position: absolute;
  display: block;
  width: 160px;
  height: 160px;
  border-radius: 50%;
  box-shadow: 0 0 12px 4px rgba(0, 0, 0, .2);
  transform: translate(-50%, -50%);
  animation: spin-2 24s linear infinite;
  transition: width .4s ease, height .4s ease;
}
.u-link-circle.__item {
  top: 50%;
  left: 50%;
}
.u-link-circle .link-word {
  font-size: 1.8rem;
}

.u-link-circle.__instagram {
  top: calc(50% + 172px);
  left: calc(50% + 128px);
  background: linear-gradient(to right, var(--color-instagram), var(--color-instagram-sub));
}

.u-link-circle.__line {
  top: calc(50% + 172px);
  left: calc(50% + -128px);
  background: var(--color-line);
}
.u-link-circle.__hp {
  top: calc(50% + -72px);
  left: calc(50% + -200px);
  background: var(--color-hp);
}
.u-link-circle.__meo {
  top: calc(50% + -210px);
  left: calc(50% + 0px);
  background: var(--color-meo);
}
.u-link-circle.__seo {
  top: calc(50% + -72px);
  left: calc(50% + 200px);
  background: var(--color-seo);
}

.u-link-circle.__instagram .link-icon {
  background: no-repeat center / 80% url('../img/icon-instagram.svg');
}
.u-link-circle.__line .link-icon {
  background: no-repeat center / 80% url('../img/icon-line.svg');
}
.u-link-circle.__hp .link-icon {
  background: no-repeat center / 80% url('../img/icon-homepage.svg');
}
.u-link-circle.__meo .link-icon {
  background: no-repeat center / contain url('../img/icon-meo.svg');
}
.u-link-circle.__seo .link-icon {
  background: no-repeat center / 80% url('../img/icon-seo.svg');
}

.l-link-circle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  transition: width .4s ease, height .4s ease;
}
.l-link-circle:hover {
  width: calc(160px * 1.2);
  height: calc(160px * 1.2);
  transition: width .4s ease, height .4s ease;
}

.l-link-circle .link-icon {
  width: 80px;
  height: 80px;
  transition: width .4s ease, height .4s ease;
}
.l-link-circle .link-word {
  color: #fff;
  font-size: 1.8rem;
  transition: font-size .4s ease;
}

.l-link-circle:hover .link-icon {
  width: calc(80px * 1.2);
  height: calc(80px * 1.2);
  transition: width .4s ease, height .4s ease;
}
.l-link-circle:hover .link-word {
  font-size: calc(1.8rem * 1.2);
  transition: font-size .4s ease;
}


@media (max-width: 960px) {
}

@media (max-width: 479px) {
  .l-table-anime {
    height: 400px;
  }

  .u-move-circle {
    width: 120px;
    height: 120px;
  }
  .u-link-circle {
    width: 80px;
    height: 80px;
  }

  .u-link-circle.__seo {
    top: calc(50% + -130px);
    left: calc(50% + 0px);
  }

  .u-link-circle.__meo {
    top: calc(50% + -42px);
    left: calc(50% + 120px);
  }

  .u-link-circle.__instagram {
    top: calc(50% + 102px);
    left: calc(50% + 78px);
  }

  .u-link-circle.__line {
    top: calc(50% + 102px);
    left: calc(50% + -78px);
  }

  .u-link-circle.__hp {
    top: calc(50% + -42px);
    left: calc(50% + -120px);
  }

  .l-link-circle .link-icon {
    width: 40px;
    height: 40px;
  }
  
  .l-link-circle .link-word {
    font-size: 1.0rem;
  }

}







@keyframes move-circle {
  0%{
    height:0;
    transform: translateY(-100px);
    opacity: 0;
  }
  45%{
    height: 100px;
    transform: translateY(7px);
    opacity: 1;
  }
  55%{
    height: 100px;
    transform: translateY(7px);
    opacity: 1;
  }
  100%{
    height:0;
    transform: translateY(7px);
    opacity: 0;
  }
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
@keyframes spin-2 {
  0% {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -50%) rotate(-360deg);
  }
}
@keyframes spin-3 {
  0% {
    transform: translate(-50%, -50%) rotate(0deg);
  }
  100% {
    transform: translate(-50%, -50%) rotate(-360deg);
  }
}



.u-bg {
  position: relative;
}
.u-bg.--main {
  background: no-repeat center / cover url('../img/bg-main.webp');
  z-index: 0;
}
.u-bg.--main::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(255, 255, 255, .6);
  z-index: -1;
}

.u-bg.--sub {
  background: no-repeat center / cover url('../img/bg-sub.webp') fixed;
}

.u-bg.--shakehand::before {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  width: 45%;
  height: 100%;
  background: linear-gradient(to right, rgba(255, 255, 255, 0.8) 0%, rgba(255, 255, 255, 0) 30%),
  url('../img/bg-mv.webp') center / cover no-repeat;
}






@media (max-width: 960px) {
}
@media (max-width: 768px) {
}
@media (max-width: 479px) {
}







.c-front-about-msg h3,
.l-strength-msg-inner > h3 {
  font-size: clamp(2rem, 1.7328rem + 0.56vw, 2.4rem);
  font-family: var(--ff-jp);
  font-weight: 600;
  letter-spacing: .1em;
}

.l-strength-msg.right .l-strength-msg-inner > h3,
.l-strength-msg.right .l-strength-msg-inner > p {
  text-align: right;
  direction: ltr;
}
.c-sec-ex {
  text-align: center;
  color: var(--color-primary);
  font-size: clamp(2rem, 1.7328rem + 0.56vw, 2.4rem);
  font-family: var(--ff-jp);
  font-weight: 600;
  letter-spacing: .1em;
  line-height: 1.6;
}

@media (max-width: 960px) {
  .l-strength-msg.right .l-strength-msg-inner > h3,
  .l-strength-msg.right .l-strength-msg-inner > p {
    text-align: left;
  }
}

@media (max-width: 479px) {
  .c-sec-ex {
    font-size: 1.5rem;
    line-height: 1.8;

    text-align: left;
    margin-inline: auto;
    width: max-content;
    max-width: 100%;
  }

  .c-front-about-msg h3,
  .l-strength-msg-inner > h3 {
    font-size: 1.8rem;
  }

  .l-strength-msg.right .l-strength-msg-inner > h3 {
    text-align: left;
  }
  .l-strength-msg.right .l-strength-msg-inner > p {
    text-align: left;
  }
}
