/* リセットCSS */
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}
body {
  line-height: 1;
}
ol,
ul {
  list-style: none;
}
blockquote,
q {
  quotes: none;
}
blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
a {
  color: inherit;
  text-decoration: none;
}

/* 共通 */
/* Webfont: Glowgirl-Regular */
@font-face {
  font-family: "Glowgirl";
  src: url("../fonts/growgirl/Glowgirl.woff2") format("woff2"),
    url("../fonts/growgirl/Glowgirl.otf") format("opentype");
  font-style: normal;
  font-weight: normal;
  text-rendering: optimizeLegibility;
}

html {
  font-size: clamp(0.3333333333333333rem, 0rem + 0.6944vw, 0.625rem);
  scroll-behavior: smooth;
  overflow-x: hidden;
}

@media screen and (max-width: 767px) {
  html {
    font-size: clamp(0.625rem, 0rem + 2.6667vw, 1.2783333333333333rem);
  }
}

body {
  font-family: "Open Sans", "Noto Sans JP", sans-serif;
  overflow-x: hidden;
}

img {
  display: block;
  width: 100%;
  height: auto;
  object-fit: contain;
}

.invisalign-lp__pc {
  display: block;
}

@media screen and (max-width: 767px) {
  .invisalign-lp__pc {
    display: none;
  }
}

.invisalign-lp__sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .invisalign-lp__sp {
    display: block;
  }
}

.invisalign-lp__br-pc {
  display: inline;
}

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

.invisalign-lp__br-sp {
  display: none;
}

@media screen and (max-width: 767px) {
  .invisalign-lp__br-sp {
    display: inline;
  }
}

.grecaptcha-badge {
  display: none;
}

/* フローティングボタン */
.floating-btn {
  display: none;
}

@media screen and (max-width: 767px) {
  .floating-btn {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    display: flex;
    z-index: 999;
    margin: 0 !important;
    padding: 0 !important;
    gap: 0 !important;
    border: none !important;
  }

  .floating-btn * {
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
  }

  .floating-btn__btn {
    flex: 1;
    min-width: 0;
    max-width: 25%;
    display: flex;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
  }

  .floating-btn__contact-btn__icon,
  .floating-btn__line-btn__icon,
  .floating-btn__top-btn__icon {
    width: 100%;
    height: 100%;
    object-fit: fill;
    display: block;
  }

  .floating-btn__btn img {
    width: 100%;
    height: 100%;
    object-fit: fill;
    display: block;
  }

  .floating-btn__btn {
    line-height: 0;
    font-size: 0;
  }
}

/* ヘッダー */
.header {
  position: fixed;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  z-index: 10000;
}

.header__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .header__inner {
    padding: 0;
    width: 84%;
  }
}

.header__left {
  width: 11%;
}

@media screen and (max-width: 767px) {
  .header__left {
    width: 29.8%;
  }
}

.header__right {
  flex: 1;
  display: flex;
  justify-content: flex-end;
}

.header__right__btn {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.4rem;
  width: 9rem;
  height: 7rem;
  position: relative;
}

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

.header__right__btn::after {
  content: "";
  position: absolute;
  bottom: 2px;
  right: 2px;
  width: 8px;
  height: 8px;
  background: rgba(255, 255, 255, 0.8);
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.header__right__btn--pc {
  background: rgba(255, 92, 4, 0.7);

  img {
    width: 2.9rem;
  }
}

.header__right__btn--line {
  background: rgba(6, 199, 85, 0.7);

  img {
    width: 2.8rem;
  }
}

.header__right__btn--tel {
  background: rgba(0, 124, 194, 0.7);
  gap: 1rem;

  img {
    width: 2rem;
  }
}

.header__right__btn__text {
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: #ffffff;
}

.header__right__menu-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1.2rem;
  width: 9rem;
  height: 7rem;
  background: #ffffff;
  border: 1px solid #007cc2;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .header__right__menu-btn {
    width: 5.7rem;
    height: 5rem;
    gap: 0.2rem;
  }
}

.header__right__menu-btn__icon {
  width: 2.8rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

@media screen and (max-width: 767px) {
  .header__right__menu-btn__icon {
    width: 2.4rem;
    gap: 0.4rem;
  }
}

.header__right__menu-btn__icon-line {
  border: 0.2rem solid #007cc2;
}

@media screen and (max-width: 767px) {
  .header__right__menu-btn__icon-line {
    border: 1px solid #007cc2;
  }
}

.header__right__menu-btn__text {
  font-weight: 700;
  font-size: 1.4rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: #007cc2;
}

.header__menu {
  position: fixed;
  top: 0;
  right: -55.833333333333333%;
  width: 55.833333333333333%;
  height: 100vh;
  background: rgba(0, 124, 194, 0.95);
  z-index: 10000;
  transition: all 0.3s ease-in-out;
}

@media screen and (max-width: 767px) {
  .header__menu {
    right: -100%;
    width: 100%;
  }
}

.header__menu.active {
  right: 0;
}

.header__menu__inner {
  width: 72.637%;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}

@media screen and (max-width: 767px) {
  .header__menu__inner {
    width: 84%;
    gap: 2rem;
    margin: 0 auto;
  }
}

.header__menu__close-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  align-self: flex-end;
  gap: 1.5rem;
  width: 12rem;
  height: 10rem;
  background: #ffffff;
  border: 1px solid #007cc2;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .header__menu__close-btn {
    width: 5.7rem;
    height: 5.7rem;
    gap: 0.5rem;
  }
}

.header__menu__close-btn img {
  width: 68.74%;
}

@media screen and (max-width: 767px) {
  .header__menu__close-btn img {
    width: 53.49%;
  }
}

.header__menu__close-btn__text {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .header__menu__close-btn__text {
    font-size: 1.4rem;
    letter-spacing: initial;
  }
}

.header__menu__lists {
  width: 93.151%;
  margin: 0 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 3rem;
}

@media screen and (max-width: 767px) {
  .header__menu__lists {
    width: 100%;
    gap: 1.5rem;
  }
}

.header__menu__list {
  position: relative;
  padding-bottom: 2rem;
  border-bottom: 1px solid #ffffff;
}

@media screen and (max-width: 767px) {
  .header__menu__list {
    padding-bottom: 1rem;
    border-bottom: 0.5px solid #ffffff;
  }
}

.header__menu__list a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  width: 1.2rem;
  height: 1.2rem;
  background: #ffffff;
  clip-path: polygon(100% 50%, 0 0, 0 100%);
}

.header__menu__list a {
  display: block;
  width: 100%;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.1em;
  color: #ffffff;
  position: relative;
}

@media screen and (max-width: 767px) {
  .header__menu__list a {
    font-size: 1.4rem;
    line-height: 1;
  }
}

/* メインビジュアル */

.mv {
  width: 100%;
}

.mv__inner {
  width: 100%;
}

/* お悩み */

.worry {
  width: 100%;
  background: url(../images/lp/worry-bg.webp) no-repeat center center / cover;
  padding: 4rem 0;
}

@media screen and (max-width: 767px) {
  .worry {
    background: url(../images/lp/sp/worry-bg.webp) no-repeat center center /
      cover;
    padding: 2rem 0;
  }
}

.worry__title {
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1.92;
  text-align: center;
  letter-spacing: 0.1em;
  color: #262626;
  text-decoration: underline dashed #007cc2;
  text-underline-offset: 0.3em;
  margin-bottom: 6rem;
}

@media screen and (max-width: 767px) {
  .worry__title {
    font-size: 2rem;
    margin-bottom: 2.8rem;
  }
}

.worry__lists {
  max-width: 1200px;
  margin: 0 auto 4rem;
  padding: 0 20px;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: space-between;
  gap: 4.6rem 0;
}

@media screen and (max-width: 767px) {
  .worry__lists {
    width: 84%;
    margin: 0 auto 0.4rem;
    padding: 0;
    gap: 2.7rem 0;
  }
}

.worry__list {
  width: 32.25%;
  background: #ffffff;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  border-radius: 1rem;
  display: flex;
  flex-direction: column;
  position: relative;
}

@media screen and (max-width: 767px) {
  .worry__list {
    width: 48.89%;
  }
}

.worry__list::before {
  content: "";
  width: 7.5rem;
  height: 6.2rem;
  background: url(../images/lp/worry-check-icon.svg) no-repeat center center /
    contain;
  position: absolute;
  top: -1.9rem;
  left: 0;
}

@media screen and (max-width: 767px) {
  .worry__list::before {
    width: 3rem;
    height: 2.4rem;
    top: -0.8rem;
  }
}

.worry__list__title {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.46;
  text-align: center;
  letter-spacing: 0.1em;
  color: #007cc2;
  padding: 1.7rem 0 2rem;
}

@media screen and (max-width: 767px) {
  .worry__list__title {
    font-size: 1.8rem;
    line-height: 1.33;
    padding: 1.5rem 0.6rem;
    align-items: flex-start;
  }
}

.worry__img {
  display: none;
}

@media screen and (max-width: 767px) {
  .worry__img {
    display: block;
    width: 60.267%;
    margin: 0 auto;
  }
}

.worry__summary {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 2.29;
  text-align: center;
  letter-spacing: 0.1em;
  color: #262626;
  position: relative;
  width: fit-content;
  margin: 0 auto 3rem;
}

@media screen and (max-width: 767px) {
  .worry__summary {
    line-height: 1.88;
    color: #000000;
    margin-bottom: 2rem;
  }
}

.worry__summary span {
  font-size: 3.6rem;
  line-height: 1.53;
  color: #007cc2;
}

.worry__summary::before {
  content: "";
  width: 24.9rem;
  height: 17.8rem;
  background: url(../images/lp/worry-summary-img.png) no-repeat center center /
    contain;
  position: absolute;
  top: -3.6rem;
  left: -24rem;
}

@media screen and (max-width: 767px) {
  .worry__summary::before {
    display: none;
  }
}

.worry__price {
  text-align: center;
  font-weight: 700;
  font-size: 5rem;
  line-height: 1.36;
  color: #007cc2;
  filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.25));
}

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

.worry__price span:first-of-type,
.worry__price span:nth-of-type(2) {
  font-size: 2.4rem;
}

.worry__price span:last-of-type {
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1.375;
  margin-left: 1.2rem;
}

.worry__price__annotation {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.4;
  color: #262626;
  text-align: center;
  margin-top: 1rem;
  margin-bottom: 3rem;
}

.worry__cta {
  display: block;
  width: fit-content;
  padding: 2rem 0.8rem;
  margin: 0 auto;
  background: #ff5c04;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.04;
  text-align: center;
  color: #fffafa;
  position: relative;
}

@media screen and (max-width: 767px) {
  .worry__cta {
    font-size: 1.8rem;
    line-height: 1.39;
    padding: 1rem 0.5rem;
  }
}

.worry__cta::after {
  content: "";
  position: absolute;
  bottom: 4px;
  right: 4px;
  width: 13px;
  height: 13px;
  background: rgba(255, 255, 255, 0.8);
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 0% 100%);
}

@media screen and (max-width: 767px) {
  .worry__cta::after {
    width: 10px;
    height: 10px;
    bottom: 3px;
    right: 3px;
  }
}

/* 動画 */

.video {
  display: none;
  width: 100%;
  background: #ffffff;
  padding: 2rem 0 3rem;
}

@media screen and (max-width: 767px) {
  .video {
    padding: 2rem 0;
  }
}

.video__inner {
  max-width: 968px;
  padding: 0 20px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .video__inner {
    width: 84%;
    padding: 0;
  }
}

.video__inner iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 968 / 463;
}

@media screen and (max-width: 767px) {
  .video__inner iframe {
    aspect-ratio: 315 / 150;
  }
}

/* introduction */
.introduction {
  background: linear-gradient(147.53deg, #ffffff 9.19%, #f9fbff 98.92%);
  padding: 5.1rem 0 0;
  position: relative;
}

@media screen and (max-width: 767px) {
  .introduction {
    padding: 2.1rem 0 3.9rem;
    background: linear-gradient(150.83deg, #ffffff 8.72%, #f9fbff 91.12%);
  }
}

.introduction__img1 {
  position: absolute;
  top: 0;
  right: 0;
  width: 58.6113%;
  max-width: 844px;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .introduction__img1 {
    width: 69.1%;
    max-width: initial;
  }
}

.introduction__img2 {
  position: absolute;
  bottom: 23.4rem;
  left: -18.5rem;
  width: 60.278%;
  max-width: 868px;
  z-index: 1;
}

@media screen and (max-width: 767px) {
  .introduction__img2 {
    width: 65.87%;
    max-width: initial;
    bottom: 75.4rem;
    left: -3.2rem;
  }
}

.introduction__inner {
  max-width: 1200px;
  padding: 0 20px;
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .introduction__inner {
    width: 84%;
    padding: 0;
  }
}

.introduction__title {
  font-family: "Noto Serif JP";
  font-style: normal;
  font-weight: 500;
  font-size: 5rem;
  line-height: 1.36;
  color: #007cc2;
  margin-bottom: 7rem;
}

@media screen and (max-width: 767px) {
  .introduction__title {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-bottom: 2.2rem;
  }
}

.introduction__text1 {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 2;
  color: #007cc2;
  margin-bottom: 3rem;
}

@media screen and (max-width: 767px) {
  .introduction__text1 {
    font-size: 2rem;
    line-height: 1.9;
    margin-bottom: 1rem;
  }
}

.introduction__text1 span {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 2.67;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .introduction__text1 span {
    font-size: 1.6rem;
    line-height: 1.75;
  }
}

.introduction__text2 {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  color: #262626;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .introduction__text2 {
    font-size: 1.6rem;
    line-height: 1.75;
    margin-bottom: 3rem;
  }
}

.introduction__text2 span {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 2;
  color: #606060;
}

@media screen and (max-width: 767px) {
  .introduction__text2 span {
    font-size: 1.8rem;
    line-height: 2.11;
  }
}

.introduction__text3 {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 0.75;
  text-align: center;
  color: #007cc2;
  margin-bottom: 1em;
}

@media screen and (max-width: 767px) {
  .introduction__text3 {
    line-height: 1.375;
  }
}

.introduction__text4 {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  text-align: center;
  color: #262626;
  margin-bottom: 3.6rem;
}

@media screen and (max-width: 767px) {
  .introduction__text4 {
    font-size: 1.6rem;
    line-height: 1.75;
    color: #000;
    text-align: left;
    margin-bottom: 4rem;
  }
}

.introduction__text4 span {
  color: #007cc2;
}

.introduction__lists__wrapper {
  background: url(../images/lp/introduction-lists-bg.png) no-repeat center
    center / cover;
  box-shadow: 2px 5px 10px rgba(0, 0, 0, 0.25), 2px -1px 4px rgba(0, 0, 0, 0.25);
  padding: 4rem 0;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .introduction__lists__wrapper {
    background: url(../images/lp/sp/introduction-lists-bg.png) no-repeat center
      center / cover;
    padding: 2rem 0;
    border-radius: 1rem;
  }
}

.introduction__lists {
  width: fit-content;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .introduction__lists {
    width: 95.24%;
  }
}

.introduction__list {
  display: flex;
  align-items: center;
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .introduction__list {
    gap: 1.5rem;
  }
}

.introduction__list img {
  width: 3.2rem;
}

@media screen and (max-width: 767px) {
  .introduction__list img {
    width: 2rem;
  }
}

.introduction__list__text {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.58;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .introduction__list__text {
    font-size: 1.8rem;
    line-height: 2.11;
    color: #000000;
  }
}

.introduction__list__text span {
  color: #007cc2;
}

.introduction__text5 {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 0.75;
  text-align: center;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .introduction__text5 {
    font-size: 1.6rem;
    line-height: 1.875;
    color: #000000;
  }
}

.introduction__text5 span {
  line-height: 2;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .introduction__text5 span {
    font-size: 1.8rem;
    line-height: 1.67;
  }
}

.section__separator1 {
  margin-top: -3.8rem;
  position: relative;
}

@media screen and (max-width: 767px) {
  .section__separator1 {
    margin-top: 0;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
  }
}

.access {
  background: url(../images/lp/access-bg.webp) no-repeat center center / cover;
  padding-bottom: 4rem;
  margin-top: -12.6rem;
  position: relative;
}

@media screen and (max-width: 767px) {
  .access {
    background: url(../images/lp/sp/access-bg.png) no-repeat center center /
      cover;
    margin-top: 0;
    padding-bottom: 23.2rem;
  }
}

.access__img1 {
  position: absolute;
  bottom: 0;
  left: -3.1rem;
  width: 42.3rem;
}

@media screen and (max-width: 767px) {
  .access__img1 {
    width: 34.5rem;
    bottom: 60.8rem;
    left: 0;
  }
}

.access__img2 {
  position: absolute;
  bottom: 0;
  right: 0;
  width: 40.9rem;
}

@media screen and (max-width: 767px) {
  .access__img2 {
    width: 34.5rem;
  }
}

.access__title {
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1;
  color: #ffffff;
  width: fit-content;
  margin: 0 auto 4rem;
  padding: 2rem 5rem;
  background: linear-gradient(90.89deg, #007cc2 7.12%, #67b1dc 54.63%);
  position: relative;
  z-index: 3;
}

@media screen and (max-width: 767px) {
  .access__title {
    font-size: 2.4rem;
    line-height: 1.5;
    text-align: center;
    padding: 1rem 0.4rem;
    margin-bottom: 2rem;
  }
}

.access__text1 {
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1.62;
  text-align: center;
  color: #262626;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .access__text1 {
    font-size: 1.8rem;
    line-height: 1.61;
    text-align: center;
    margin-bottom: 2rem;
  }
}

.access__cta {
  width: fit-content;
  margin: 0 auto 4rem;
  display: flex;
  align-items: stretch;
  justify-content: center;
  gap: 4rem;
}

@media screen and (max-width: 767px) {
  .access__cta {
    width: 84%;
    margin-bottom: 4rem;
    flex-direction: column;
    gap: 2rem;
  }
}

.access__cta__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  padding: 3rem 0;
  width: 25.9rem;
  position: relative;
}

@media screen and (max-width: 767px) {
  .access__cta__btn {
    gap: 1.5rem;
    padding: 2.3rem 0;
    width: 100%;
  }
}

.access__cta__btn::before {
  content: "";
  position: absolute;
  bottom: 5px;
  right: 5px;
  width: 13px;
  height: 13px;
  background: rgba(255, 255, 255, 0.8);
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.access__cta__btn--remote-consulting {
  background: rgba(0, 124, 194, 0.6);
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  gap: 1.7rem;
}

@media screen and (max-width: 767px) {
  .access__cta__btn--remote-consulting {
    gap: 1.5rem;
  }
}

.access__cta__btn--web-reservation {
  filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.25));
  background: rgba(255, 92, 4, 0.8);
  gap: 1.4rem;
}

@media screen and (max-width: 767px) {
  .access__cta__btn--web-reservation {
    gap: 1.5rem;
  }
}

.access__cta__btn--line-consulting {
  filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.25));
  background: rgba(6, 199, 85, 0.8);
  gap: 0.9em;
}

@media screen and (max-width: 767px) {
  .access__cta__btn--line-consulting {
    gap: 1.5rem;
  }
}

.access__cta__btn__icon--remote-consulting {
  width: 4.6rem;
}

@media screen and (max-width: 767px) {
  .access__cta__btn__icon--remote-consulting {
    width: 6.2rem;
  }
}

.access__cta__btn__icon--web-reservation {
  width: 4.6rem;
}

@media screen and (max-width: 767px) {
  .access__cta__btn__icon--web-reservation {
    width: 5.3rem;
  }
}

.access__cta__btn__icon--line-consulting {
  width: 5rem;
}

@media screen and (max-width: 767px) {
  .access__cta__btn__icon--line-consulting {
    width: 5.6rem;
  }
}

.access__cta__btn__text {
  font-weight: 700;
  font-size: 1.6rem;
  line-height: 1.25;
  text-align: center;
  letter-spacing: 0.1em;
  color: #ffffff;
}

.access__patients {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .access__patients {
    margin-bottom: 23.6rem;
  }
}

.access__patients__fukidashi {
  width: 14.6rem;
  margin-bottom: 1.6rem;
}

@media screen and (max-width: 767px) {
  .access__patients__fukidashi {
    width: 16rem;
    margin-bottom: 1.6rem;
  }
}

.access__patients__title {
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 0.69;
  text-align: center;
  color: #000000;
  text-decoration: underline dashed #007cc2;
  text-underline-offset: 0.3em;
  margin-bottom: 5.5rem;
}

@media screen and (max-width: 767px) {
  .access__patients__title {
    font-size: 2.4rem;
    line-height: 1.04;
    margin-bottom: 4rem;
  }
}

.access__patients__map {
  width: 61.9rem;
}

@media screen and (max-width: 767px) {
  .access__patients__map {
    width: 30.2rem;
  }
}

.access__text2 {
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1.38;
  text-align: center;
  color: #000000;
  position: relative;
}

@media screen and (max-width: 767px) {
  .access__text2 {
    width: 84%;
    margin: 0 auto;
    font-size: 1.8rem;
    line-height: 1.83;
    text-align: center;
  }
}

.access__text2__color {
  color: #007cc2;
}

.access__text2__big {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.54;
  color: #007cc2;
}

.access-detail__map {
  width: 100%;
  height: auto;
  aspect-ratio: 1440 / 467;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .access-detail__map {
    aspect-ratio: 375 / 244;
  }
}

.access-detail__lists {
  display: flex;
  justify-content: center;
  align-items: flex-start;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .access-detail__lists {
    flex-direction: column;
    align-items: center;
  }
}

.access-detail__list {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  width: 27.3rem;
}

@media screen and (max-width: 767px) {
  .access-detail__list {
    width: 84%;
    margin: 0 auto;
  }
}

.access-detail__list:nth-of-type(2) {
  padding: 0 4.7rem;
  margin: 0 4.7rem;
  border-left: 1px solid #007cc2;
  border-right: 1px solid #007cc2;
}

@media screen and (max-width: 767px) {
  .access-detail__list:nth-of-type(2) {
    padding: 2rem 0;
    margin: 2rem 0;
    border-left: none;
    border-right: none;
    border-top: 1px solid #007cc2;
    border-bottom: 1px solid #007cc2;
  }
}

.access-detail__list__icon {
  width: auto;
  height: 6rem;
}

.access-detail__list__title {
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 2.22;
  text-align: center;
  letter-spacing: 0.1em;
  color: #007cc2;
}

.access-detail__list__text {
  text-align: center;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 2.5;
  text-align: center;
  letter-spacing: 0.1em;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .access-detail__list__text {
    color: #303030;
  }
}

.doctor {
  padding: 20rem 0 7rem;
  position: relative;
  overflow-x: clip;
}

@media screen and (max-width: 767px) {
  .doctor {
    padding: 8.9rem 0 4rem;
  }
}

.doctor__bg1 {
  position: absolute;
  top: -20rem;
  left: -13.6rem;
  width: 114%;
}

@media screen and (max-width: 767px) {
  .doctor__bg1 {
    top: -24rem;
    left: 0;
    width: 100%;
  }
}

.doctor__bg2 {
  position: absolute;
  bottom: 40rem;
  right: -29.6rem;
  width: 125%;
}

@media screen and (max-width: 767px) {
  .doctor__bg2 {
    bottom: initial;
    top: 33rem;
    right: 0;
    width: 100%;
  }
}

.doctor__inner {
  position: relative;
  z-index: 3;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

@media screen and (max-width: 767px) {
  .doctor__inner {
    width: 84%;
    padding: 0;
  }
}

.doctor__title {
  text-align: center;
  font-family: "Glowgirl", "Noto Serif JP", serif;
  margin-bottom: 7rem;
}

@media screen and (max-width: 767px) {
  .doctor__title {
    margin-bottom: 2rem;
  }
}

.doctor__title--en {
  font-weight: 400;
  font-size: 7.6rem;
  color: #ffffff;
  margin-bottom: 1rem;
}

@media screen and (max-width: 767px) {
  .doctor__title--en {
    font-size: 5rem;
    margin-bottom: 0;
  }
}

.doctor__title--ja {
  font-weight: 500;
  font-size: 3.6rem;
  color: #007cc2;
  position: relative;
  text-shadow: 0 0 2px rgba(255, 255, 255, 0.8),
    0 0 4px rgba(255, 255, 255, 0.6), 0 0 6px rgba(255, 255, 255, 0.4),
    0 0 8px rgba(255, 255, 255, 0.2);
}

@media screen and (max-width: 767px) {
  .doctor__title--ja {
    font-size: 2.4rem;
    line-height: 1.5;
  }
}

.doctor__content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4rem;
  margin-bottom: 6rem;
}

@media screen and (max-width: 767px) {
  .doctor__content {
    flex-direction: column;
    align-items: center;
    gap: 6rem;
    margin-bottom: 3rem;
  }
}

.doctor__figure {
  position: relative;
  width: 44.3334%;
}

@media screen and (max-width: 767px) {
  .doctor__figure {
    width: 100%;
  }
}

.doctor__img__detail {
  position: absolute;
  bottom: -2rem;
  right: -2rem;
  width: 50.188%;
}

@media screen and (max-width: 767px) {
  .doctor__img__detail {
    bottom: -2rem;
    right: 0;
    width: 84.764%;
  }
}

.doctor__content__text {
  flex: 1;
}

@media screen and (max-width: 767px) {
  .doctor__content__text {
    width: 100%;
    flex: initial;
  }
}

.doctor__content__text__title {
  font-family: "Noto Serif JP";
  font-weight: 400;
  font-size: 3.6rem;
  color: #ff5c04;
  text-shadow: 0 0 2px rgba(255, 255, 255, 0.8),
    0 0 4px rgba(255, 255, 255, 0.6), 0 0 6px rgba(255, 255, 255, 0.4),
    0 0 8px rgba(255, 255, 255, 0.2);
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  margin-bottom: 4.9rem;
}

@media screen and (max-width: 767px) {
  .doctor__content__text__title {
    align-items: center;
    font-size: 2.4rem;
    line-height: 1.4;
  }
}

.doctor__content__text__title > span:last-of-type {
  align-self: flex-end;
}

@media screen and (max-width: 767px) {
  .doctor__content__text__title > span:last-of-type {
    align-self: center;
  }
}

.doctor__content__text__text {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .doctor__content__text__text {
    font-size: 1.6rem;
    line-height: 2.06;
    text-shadow: 0 0 2px rgba(255, 255, 255, 0.8),
      0 0 4px rgba(255, 255, 255, 0.6), 0 0 6px rgba(255, 255, 255, 0.4),
      0 0 8px rgba(255, 255, 255, 0.2);
  }
}

.doctor__detail__wrapper {
  width: 90.667%;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .doctor__detail__wrapper {
    width: 100%;
  }
}

.doctor__detail__item--flex {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item--flex {
    flex-direction: column;
    align-items: center;
    gap: 2rem;
  }
}

.doctor__detail__item--case {
  align-items: flex-end;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item--case {
    flex-direction: row;
    align-items: center;
    margin-bottom: 2rem;
  }
}

.doctor__detail__item__left {
  width: 48.5667%;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item__left {
    width: 100%;
  }
}

.doctor__detail__item--case
  .doctor__detail__item__left
  .doctor__detail__item__case__img__wrapper {
  display: contents;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item--case
    .doctor__detail__item__left
    .doctor__detail__item__case__img__wrapper {
    width: 100%;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
  }

  .doctor__detail__item--case .doctor__detail__item__left img {
    width: 48.573%;
  }
}

.doctor__detail__item__right {
  width: 48.5667%;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item__right {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .doctor__detail__item--case .doctor__detail__item__right {
    display: none;
  }
}

.doctor__detail__item__title {
  font-family: "Noto Serif JP";
  font-weight: 600;
  font-size: 2.4rem;
  line-height: 1.25;
  text-align: center;
  letter-spacing: 0.1em;
  color: #007cc2;
  display: flex;
  align-items: center;
  gap: 4rem;
  margin-bottom: 2.5rem;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item__title {
    font-size: 1.8rem;
    line-height: 1.67;
    gap: 1rem;
  }
}

.doctor__detail__item__title::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #007cc2;
}

.doctor__detail__item__lists li {
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 2.14;
  letter-spacing: 0.1em;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item__lists li {
    margin-bottom: 1rem;
    line-height: 1.5;
  }
}

.doctor__detail__item__text {
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 2.14;
  letter-spacing: 0.1em;
  color: #262626;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item__text {
    line-height: 1.5;
    color: #303030;
    margin-bottom: 2rem;
  }
}

.doctor__detail__item__text--flex > span {
  display: flex;
  align-items: center;
  gap: 0.8rem;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item__text--flex > span {
    gap: 1rem;
    margin-bottom: 1rem;
  }

  .doctor__detail__item__text--flex > span:last-of-type {
    margin-bottom: 0;
  }
}

.doctor__detail__item__text--flex > span > span:first-of-type {
  width: 6.4rem;
  line-height: 1.43;
}

.doctor__detail__item__text--flex > span > span:last-of-type {
  flex: 1;
}

.doctor__detail__item--case-detail {
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .doctor__detail__item--case-detail {
    margin-bottom: 2rem;
  }
}

.doctor__detail__item--case-detail:last-of-type {
  margin-bottom: 0;
}

.doctor__detail__item--case-detail-price {
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.43;
  letter-spacing: 0.1em;
  color: #262626;
  display: flex;
  align-items: baseline;
  margin-bottom: 2rem;
}

.doctor__detail__item--case-detail-price > span:first-of-type {
  font-size: 2.4rem;
  line-height: 1;
  color: #ffffff;
  padding: 0.95rem 2rem;
  background-color: #007cc2;
  margin-right: 2.1rem;
}

.doctor__detail__item--case-detail-price > span:nth-of-type(2) {
  font-weight: 700;
  font-size: 2.4rem;
  color: #ff5c04;
}

.doctor__detail__item--case-detail-price > span:nth-of-type(2) > span {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.25;
}

.doctor__detail__item--case-detail-subtitle {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.1em;
  color: #262626;
  padding-bottom: 0.4rem;
  margin-bottom: 1rem;
  position: relative;
}

.doctor__detail__item--case-detail-subtitle::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 4rem;
  height: 1px;
  background: #007cc2;
}

.doctor__detail__item--case-detail-text {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.1em;
  color: #262626;
  margin-bottom: 2rem;
}

.doctor__detail__item--case-detail-text:last-of-type {
  margin-bottom: 0;
}

.fee {
  background: linear-gradient(
    105.36deg,
    rgba(0, 160, 250, 0.3) -0.25%,
    rgba(0, 124, 194, 0.03) 95.72%
  );
  padding: 7rem 0 4rem;
  position: relative;
}

@media screen and (max-width: 767px) {
  .fee {
    padding: 4rem 0;
  }
}

.fee--2 {
  background: #fff;
  padding-top: 7rem;
}

@media screen and (max-width: 767px) {
  .fee--2 {
    padding-top: 4rem;
    background: #fff;
  }
}

.fee__img1 {
  width: 40.278%;
  max-width: 580px;
  position: absolute;
  left: 0;
  top: 0;
}

@media screen and (max-width: 767px) {
  .fee__img1 {
    width: 91.692%;
    max-width: initial;
  }
}

.fee__inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .fee__inner {
    width: 84%;
    padding: 0;
  }
}

.fee__title {
  text-align: center;
  font-family: "Glowgirl", "Noto Serif JP", serif;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .fee__title {
    margin-bottom: 2rem;
  }
}

.fee__title--en {
  font-weight: 400;
  font-size: 7.6rem;
  line-height: 1;
  background: linear-gradient(125.63deg, #007cc2 -10.7%, #71cbfe 78.04%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  margin-bottom: 1.3rem;
}

@media screen and (max-width: 767px) {
  .fee__title--en {
    font-size: 5rem;
  }
}

.fee__title--ja {
  font-family: "Noto Serif JP";
  font-weight: 500;
  font-size: 3.6rem;
  line-height: 1;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .fee__title--ja {
    font-size: 2.4rem;
  }
}

.fee__text {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  text-align: center;
  color: #262626;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .fee__text {
    margin-bottom: 2rem;
  }
}

.fee__text span {
  font-weight: 700;
  font-size: 2.4rem;
  line-height: 1.38;
  background: linear-gradient(0deg, #007cc2, #007cc2);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

.fee__table {
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .fee__table {
    gap: 1rem;
  }
}

.fee__table__item {
  display: flex;
  align-items: stretch;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.25;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 767px) {
  .fee__table__item {
    font-size: 1.6rem;
    flex-direction: column;
    justify-content: center;
    align-items: center;
  }
}

.fee__table__item__title {
  display: flex;
  align-items: center;
  width: 24.2rem;
  color: #ffffff;
  padding: 1.5rem 2rem;
  background: #007cc2;
  border: 0.5px solid #007cc2;
}

@media screen and (max-width: 767px) {
  .fee__table__item__title {
    width: 100%;
    display: block;
    padding: 1.5rem 0;
    justify-content: center;
    text-align: center;
  }
}

.fee__table__item__wrapper .fee__table__item__title {
  border-bottom: 1px solid #fff;
}

.fee__table__item__title__sub {
  display: none;
}

@media screen and (max-width: 767px) {
  .fee__table__item__wrapper .fee__table__item__title {
    border-bottom: none;
  }

  .fee__table__item__title__sub {
    display: block;
    font-weight: 400;
    font-size: 1.4rem;
    line-height: 1.43;
    text-align: center;
  }
}

.fee__table__item__wrapper
  > .fee__table__item:last-of-type
  > .fee__table__item__title {
  border-bottom: 0.5px solid #007cc2;
}

@media screen and (max-width: 767px) {
  .fee__table__item__wrapper
    > .fee__table__item:last-of-type
    > .fee__table__item__title {
    border-bottom: none;
  }
}

.fee__table__item__text {
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
  flex: 1;
  color: #262626;
  padding: 1.5rem 4rem;
  background: #fdfdfd;
  border: 0.5px solid #262626;
}

.fee__table__item__text__sub {
  display: none;
}

@media screen and (max-width: 767px) {
  .fee__table__item__text {
    padding: 1.5rem 0;
    border: 0.5px solid #007cc2;
    width: 100%;
    justify-content: center;
    flex: initial;
    font-family: "Noto Serif JP";
    font-weight: 300;
    line-height: 1.56;
    text-align: center;
    display: block;
  }

  .fee__table__item__text__sub {
    display: none;
  }

  .fee__table__item__text span {
    font-size: 1.4rem;
  }
}

@media screen and (max-width: 767px) {
  .fee__table__item__text {
    border-top: none;
  }
}

.fee__table__item__wrapper .fee__table__item__text {
  border-bottom: 0.25px solid #262626;
}

@media screen and (max-width: 767px) {
  .fee__table__item__wrapper .fee__table__item__text {
    border-bottom: none;
  }
}

.fee__table__item__wrapper
  > .fee__table__item:last-of-type
  > .fee__table__item__text {
  border-bottom: 0.5px solid #262626;
}

@media screen and (max-width: 767px) {
  .fee__table__item__wrapper
    > .fee__table__item:last-of-type
    > .fee__table__item__text {
    border-bottom: 0.5px solid #007cc2;
  }
}

.fee__table__item__plus {
  width: 32px;
  height: 32px;
  margin: 0 auto;
}

.payment {
  background: url(../images/lp/payment-bg.webp) no-repeat center center / cover;
  padding: 7rem 0;
}

@media screen and (max-width: 767px) {
  .payment {
    padding: 4rem 0;
    background: url(../images/lp/sp/payment-bg-sp.webp) no-repeat center center /
      cover;
  }
}

.payment__text {
  font-weight: 400;
  font-size: 2.4rem;
  letter-spacing: 0.1em;
  color: #262626;
  text-align: center;
  text-shadow: 0 0 2px rgba(255, 255, 255, 0.8),
    0 0 4px rgba(255, 255, 255, 0.6), 0 0 6px rgba(255, 255, 255, 0.4),
    0 0 8px rgba(255, 255, 255, 0.2);
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .payment__text {
    font-size: 1.8rem;
    line-height: 1.11;
    margin-bottom: 2rem;
  }
}

.payment__lists {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3rem;
}

@media screen and (max-width: 767px) {
  .payment__lists {
    flex-wrap: wrap;
    gap: 0 1.3rem;
  }
}

.payment__list {
  width: 32.2rem;
  height: auto;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 2.8rem;
}

@media screen and (max-width: 767px) {
  .payment__list {
    width: 15.1rem;
    gap: 1.1rem;
  }
}

.payment__list:first-of-type {
  gap: 4.3rem;
}

@media screen and (max-width: 767px) {
  .payment__list:first-of-type {
    gap: 2rem;
  }
}

.payment__list__icon {
  height: 11.6rem;
}

@media screen and (max-width: 767px) {
  .payment__list__icon {
    height: 5.4rem;
  }
}

.payment__list:first-of-type .payment__list__icon {
  height: 12.1rem;
}

@media screen and (max-width: 767px) {
  .payment__list:first-of-type .payment__list__icon {
    height: 5.4rem;
  }
}

.payment__list__text {
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1.12;
  text-align: center;
  letter-spacing: 0.1em;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .payment__list__text {
    font-size: 1.8rem;
  }
}

.dental-loan {
  padding: 5.4rem 2rem 4rem;
}

@media screen and (max-width: 767px) {
  .dental-loan {
    padding: 6.7rem 0 4.3rem;
  }
}

.dental-loan__inner {
  max-width: 1020px;
  margin: 0 auto;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  padding: 7.5rem 0;
  position: relative;
}

@media screen and (max-width: 767px) {
  .dental-loan__inner {
    padding: 5.5rem 0;
    width: 83.47%;
    margin: 0 auto;
  }
}

.dental-loan__img {
  position: absolute;
  top: -3.1rem;
  left: -8.9rem;
  z-index: 2;
  width: 30%;
  max-width: 306px;
}

@media screen and (max-width: 767px) {
  .dental-loan__img {
    width: 19.4rem;
    max-width: initial;
    top: initial;
    left: initial;
    bottom: -5.4rem;
    right: -5.9rem;
  }
}

.dental-loan__inner::before {
  position: absolute;
  top: -0.5rem;
  left: -0.6rem;
  content: "";
  width: 100%;
  height: 100%;
  border: 1px solid #007cc2;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
}

@media screen and (max-width: 767px) {
  .dental-loan__inner::before {
    top: -0.3rem;
    left: -0.4rem;
  }
}

.dental-loan__inner::after {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  content: "";
  background: linear-gradient(127.2deg, #007cc2 16.75%, #71cbfe 78.5%);
  opacity: 0.15;
}

.dental-loan__title {
  font-family: "Noto Serif JP";
  font-weight: 700;
  font-size: 3.6rem;
  line-height: 1;
  text-align: center;
  letter-spacing: 0.1em;
  color: #007cc2;
  width: fit-content;
  background: #fff;
  padding-left: 3rem;
  padding-right: 5rem;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: -2.5rem;
  white-space: nowrap;
}

@media screen and (max-width: 767px) {
  .dental-loan__title {
    font-size: 2.4rem;
    line-height: 1.12;
  }
}

.dental-loan__subtitle {
  font-family: "Noto Serif JP";
  font-weight: 400;
  font-size: 3.6rem;
  text-align: center;
  letter-spacing: 0.1em;
  color: #262626;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .dental-loan__subtitle {
    font-size: 1.8rem;
    line-height: 1.12;
  }
}

.dental-loan__subtitle span {
  font-weight: 700;
  font-size: 7rem;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .dental-loan__subtitle span {
    font-size: 5rem;
  }
}

.dental-loan__text {
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.93;
  text-align: center;
  letter-spacing: 0.1em;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .dental-loan__text {
    font-size: 1.2rem;
    line-height: 1.67;
    text-align: left;
  }
}

.medical-expense-deduction {
  padding-bottom: 7rem;
}

@media screen and (max-width: 767px) {
  .medical-expense-deduction {
    padding-bottom: 4rem;
  }
}

.medical-expense-deduction__inner {
  max-width: 1017px;
  margin: 0 auto;
  padding: 0 20px;
  position: relative;
  z-index: 2;
}

@media screen and (max-width: 767px) {
  .medical-expense-deduction__inner {
    width: 84%;
    margin: 0 auto;
    padding: 0;
  }
}

.medical-expense-deduction__title {
  width: 76.205%;
  margin: 0 auto 4rem;
  display: flex;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .medical-expense-deduction__title {
    width: 100%;
    margin-bottom: 2.5rem;
  }
}

.medical-expense-deduction__title span {
  width: fit-content;
  padding: 0 3rem;
  margin: 0 auto;
  border-right: 1px solid #000000;
  border-left: 1px solid #000000;
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1.12;
  letter-spacing: 0.1em;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .medical-expense-deduction__title span {
    border: none;
    padding: 0 1.5rem;
    font-size: 1.8rem;
    line-height: 1.5;
  }
}

.medical-expense-deduction__title::before,
.medical-expense-deduction__title::after {
  content: "";
  flex: 1;
  background-color: #262626;
  height: 1px;
}

.medical-expense-deduction__text {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 2.06;
  letter-spacing: 0.1em;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .medical-expense-deduction__text {
    font-size: 1.6rem;
    line-height: 2.13;
  }
}

.contact {
  background: url(../images/lp/contact-bg.webp) no-repeat center center / cover;
  padding: 7rem 0;
}

@media screen and (max-width: 767px) {
  .contact {
    padding: 4rem 0;
  }
}

.contact__title {
  font-family: "Glowgirl", "Noto Serif JP", sans-serif;
  font-size: 12rem;
  letter-spacing: 0.1em;
  color: #ffffff;
  text-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  text-align: center;
  line-height: 0.55;
}

@media screen and (max-width: 767px) {
  .contact__title {
    font-size: 5.5rem;
    line-height: 1;
    color: #ffffff;
  }
}

.contact__inner {
  width: 83.3334%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 4rem;
  background: #ffffff;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
}

@media screen and (max-width: 767px) {
  .contact__inner {
    width: 84%;
    margin-top: -1.2rem;
    padding: 2rem 1rem;
  }
}

.contact__subtitle1 {
  font-family: "Noto Serif JP";
  font-weight: 400;
  font-size: 3.6rem;
  color: #007cc2;
  text-align: center;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .contact__subtitle1 {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-bottom: 2rem;
  }
}

.contact__text {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  text-align: center;
  color: #262626;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .contact__text {
    font-size: 1.6rem;
    line-height: 2.06;
    color: #000000;
    margin-bottom: 2rem;
  }
}

.contact__btn-wrapper {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
}

@media screen and (max-width: 767px) {
  .contact__btn-wrapper {
    flex-direction: column;
  }
}

.contact__btn {
  width: 40.4rem;
}

@media screen and (max-width: 767px) {
  .contact__btn {
    width: 100%;
  }
}

.contact__hr {
  width: 100%;
  margin: 2rem auto;
  border: 1px dashed #007cc2;
}

.contact__subtitle2 {
  font-weight: 700;
  font-size: 1.8rem;
  line-height: 1.83;
  text-align: center;
  color: #fff;
  width: fit-content;
  margin: 0 auto;
  padding: 0.3rem 3rem;
  background: #007cc2;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .contact__subtitle2 {
    padding: 0.3rem 0;
    width: 100%;
  }
}

.contact__lists {
  display: flex;
  flex-wrap: wrap;
  gap: 4rem;
  max-width: 992px;
  margin: 0 auto;
  padding: 0 20px;
}

@media screen and (max-width: 767px) {
  .contact__lists {
    padding: 0;
    flex-direction: column;
    gap: 1.5rem;
  }
}

.contact__list {
  display: flex;
  align-items: center;
  gap: 1.5rem;
  font-weight: 600;
  font-size: 1.8rem;
  letter-spacing: 0.1em;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .contact__list {
    align-items: flex-start;
    font-size: 1.6rem;
    line-height: 1.125;
  }
}

.contact__list:nth-of-type(odd) {
  width: 51rem;
}

@media screen and (max-width: 767px) {
  .contact__list:nth-of-type(odd) {
    width: 100%;
  }
}

.contact__list:nth-of-type(even) {
  flex: 1;
}

@media screen and (max-width: 767px) {
  .contact__list:nth-of-type(even) {
    width: 100%;
  }
}

@media screen and (max-width: 767px) {
  .contact__list:nth-of-type(1) {
    order: 1;
  }

  .contact__list:nth-of-type(2) {
    order: 5;
  }

  .contact__list:nth-of-type(3) {
    order: 2;
  }

  .contact__list:nth-of-type(4) {
    order: 3;
  }

  .contact__list:nth-of-type(5) {
    order: 4;
  }
}

.contact__list__icon {
  width: 2.6rem;
}

@media screen and (max-width: 767px) {
  .contact__list__icon {
    width: 2rem;
  }
}

.contact__list2__text {
  flex: 1;
}

.reason {
  background: url(../images/lp/reason-bg.webp) no-repeat center center / cover;
  padding-top: 17.2rem;
  padding-bottom: 7rem;
  margin-top: -10.4rem;
}

@media screen and (max-width: 767px) {
  .reason {
    background: url(../images/lp/sp/reason-bg.webp) no-repeat center center /
      cover;
    padding-top: 15.1rem;
    padding-bottom: 4rem;
    margin-top: -10.4rem;
  }
}

.reason__title {
  text-align: center;
  margin-bottom: 7.7rem;
}

@media screen and (max-width: 767px) {
  .reason__title {
    margin-bottom: 5.4rem;
  }
}

.reason__title--en {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 7.6rem;
  line-height: 1.1;
  text-align: center;
  background: linear-gradient(125.63deg, #007cc2 -10.7%, #71cbfe 78.04%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  display: block;
}

@media screen and (max-width: 767px) {
  .reason__title--en {
    font-size: 5rem;
    line-height: 1.2;
  }
}

.reason__title--ja {
  font-family: "Noto Serif JP";
  font-weight: 400;
  font-size: 7.6rem;
  line-height: 1;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .reason__title--ja {
    font-size: 5rem;
    line-height: 1.2;
  }
}

.reason__title--ja__text {
  display: block;
  font-family: "Open Sans", "Noto Sans JP", sans-serif;
  font-weight: 600;
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: 0.1em;
  color: #262626;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .reason__title--ja__text {
    font-size: 2rem;
    line-height: 1.2;
  }
}

.reason__title--ja__text__number {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 12rem;
  background: linear-gradient(127.2deg, #007cc2 16.75%, #71cbfe 78.5%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  transform: rotate(5deg);
}

.reason__lists {
  display: flex;
  flex-direction: column;
  gap: 7rem;
}

@media screen and (max-width: 767px) {
  .reason__lists {
    gap: 7.3rem;
  }
}

.reason__list {
  width: 91.667%;
}

@media screen and (max-width: 767px) {
  .reason__list {
    width: 92%;
  }
}

.reason__list__inner {
  display: flex;
  gap: 4rem;
}

@media screen and (max-width: 767px) {
  .reason__list__inner {
    flex-direction: column;
    gap: 2rem;
    position: relative;
  }

  .reason__list--right .reason__list__inner {
    flex-direction: column-reverse;
  }
}

.reason__list--right {
  margin: 0 0 0 auto;
}

.reason__list__img {
  width: 48.7123%;
}

@media screen and (max-width: 767px) {
  .reason__list__img {
    width: 100%;
  }
}

.reason__list__content {
  flex: 1;
}

@media screen and (max-width: 767px) {
  .reason__list__content {
    width: 100%;
  }
}

.reason__list__number {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  margin-bottom: 2.6rem;
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: 0.1em;
}

@media screen and (max-width: 767px) {
  .reason__list__number {
    position: absolute;
    top: -3.3rem;
    right: 0;
    margin-bottom: 0;
    align-items: flex-start;
  }

  .reason__list--right .reason__list__number {
    right: initial;
    left: 0;
  }
}

.reason__list__number span:first-of-type {
  font-size: 1.8rem;
  background: linear-gradient(127.2deg, #007cc2 16.75%, #71cbfe 78.5%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .reason__list__number span:first-of-type {
    margin-top: 1.9rem;
  }
}

.reason__list__number span:last-of-type {
  font-size: 10rem;
  background: linear-gradient(106.88deg, #007cc2 21.05%, #71cbfe 83.6%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .reason__list__number span:last-of-type {
    font-size: 7rem;
  }
}

.reason__list__title {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 3.6rem;
  line-height: 1.39;
  text-align: center;
  letter-spacing: 0.1em;
  color: #007cc2;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .reason__list__title {
    font-size: 2.4rem;
    line-height: 1.2;
    margin-bottom: 1.5rem;
  }
}

.reason__list__title span {
  font-size: 2.4rem;
  margin-bottom: 1rem;
}

@media screen and (max-width: 767px) {
  .reason__list__title span {
    font-size: 1.6rem;
  }
}

.reason__list__text {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  letter-spacing: 0.1em;
  color: #000;
}

@media screen and (max-width: 767px) {
  .reason__list__text {
    width: 91.305%;
    margin: 0 0 0 auto;
    font-size: 1.6rem;
    line-height: 2.06;
  }

  .reason__list--right .reason__list__text {
    width: 91.305%;
    margin: 0 auto 0 0;
  }
}

.reason__list3__flex {
  width: 100%;
  margin-top: -3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3.1rem;
}

@media screen and (max-width: 767px) {
  .reason__list3__flex {
    margin-top: -5.3rem;
    gap: 0.9rem;
  }
}

.reason__list3__flex img {
  width: 36.6945%;
}

@media screen and (max-width: 767px) {
  .reason__list3__flex img {
    width: 40.8%;
  }
}

.reason__list4__img__wrapper {
  margin-top: -3rem;
}

@media screen and (max-width: 767px) {
  .reason__list4__img__wrapper {
    margin-top: -5.3rem;
  }
}

.reason__list4__img {
  width: 75.556%;
  max-width: 1088px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .reason__list4__img {
    width: 84%;
  }
}

.reason__list6__img__wrapper {
  margin-top: -3rem;
}

@media screen and (max-width: 767px) {
  .reason__list6__img__wrapper {
    margin-top: -5.3rem;
  }
}

.reason__list6__img {
  width: 83.3334%;
  max-width: 1200px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .reason__list6__img {
    width: 84%;
  }
}

.reason__list7__img__wrapper {
  margin-top: -3rem;
}

@media screen and (max-width: 767px) {
  .reason__list7__img__wrapper {
    margin-top: -8.7rem;
  }
}

.reason__list7__img {
  width: 83.3334%;
  max-width: 1200px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .reason__list7__img {
    width: 92%;
    margin: 0 0 0 auto;
  }
}

.reason__list9__img__wrapper {
  margin-top: -3rem;
}

@media screen and (max-width: 767px) {
  .reason__list9__img__wrapper {
    margin-top: -5.3rem;
  }
}

.reason__list9__img {
  width: 80.556%;
  max-width: 1160px;
  margin: 0 auto;
}

@media screen and (max-width: 767px) {
  .reason__list9__img {
    width: 84%;
  }
}

.reason__list9__link {
  display: none;
  width: fit-content;
  padding: 3.8rem 17.5rem;
  margin: 2.1rem auto 0;
  font-family: "Noto Serif JP";
  font-weight: 400;
  font-size: 2.4rem;
  line-height: 1;
  letter-spacing: 0.1em;
  color: #ff5c04;
  background: #ffffff;
  border: 1px solid #ff5c04;
  position: relative;
}

@media screen and (max-width: 767px) {
  .reason__list9__link {
    padding: 2.4rem 8rem;
  }
}

.reason__list9__link__img {
  position: absolute;
  width: 17.1rem;
  top: -2.2rem;
  left: -4.7rem;
}

@media screen and (max-width: 767px) {
  .reason__list9__link__img {
    width: 13rem;
    top: -2.1rem;
    left: -3.5rem;
  }
}

.reason__list9__link__arrow {
  position: absolute;
  width: 2.4rem;
  top: 50%;
  right: 2rem;
  transform: translateY(-50%);
}

@media screen and (max-width: 767px) {
  .reason__list9__link__arrow {
    right: 1.1rem;
    width: 2rem;
  }
}

.about-invisalign {
  background: url(../images/lp/about-invisalign-bg.webp) no-repeat center center /
    cover;
  padding: 7rem 0;
}

@media screen and (max-width: 767px) {
  .about-invisalign {
    background: url(../images/lp/sp/about-invisalign-bg.webp) no-repeat center
      center / cover;
    padding: 4rem 0;
  }
}

.about-invisalign__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

@media screen and (max-width: 767px) {
  .about-invisalign__inner {
    padding: 0;
    width: 92%;
  }
}

.about-invisalign__title {
  text-align: center;
  margin-bottom: 7rem;
  line-height: 1;
  display: flex;
  flex-direction: column;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__title {
    margin-bottom: 0;
  }
}

.about-invisalign__title--en {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 7.6rem;
  line-height: 1.1;
  background: linear-gradient(125.63deg, #007cc2 -10.7%, #71cbfe 78.04%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .about-invisalign__title--en {
    font-size: 5rem;
  }
}

.about-invisalign__title--ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 3.6rem;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .about-invisalign__title--ja {
    font-size: 2.4rem;
    line-height: 1.5;
  }
}

.about-invisalign__flex {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 4.2rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__flex {
    width: 84%;
    margin: 0 auto 4rem;
    flex-direction: column;
  }
}

.about-invisalign__flex img {
  width: 37.5695%;
  margin-right: -2.8rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__flex img {
    width: 120.4%;
    margin-right: 0;
    margin-left: -1rem;
  }
}

.about-invisalign__text {
  width: 52.5%;
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  letter-spacing: 0.1em;
  color: #303030;
}

@media screen and (max-width: 767px) {
  .about-invisalign__text {
    width: 100%;
    font-size: 1.6rem;
    line-height: 1.5625;
  }
}

.about-invisalign__text span {
  font-weight: 700;
}

.about-invisalign__merit-title {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
  text-align: center;
  margin-bottom: 5.6rem;
  line-height: 1;
  display: flex;
  flex-direction: column;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-title {
    width: 84%;
    margin: 0 auto 4rem;
    padding: 0;
  }
}

.about-invisalign__merit-title--ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1;
  color: #007cc2;
  margin-bottom: 1rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-title--ja {
    font-size: 1.4rem;
    line-height: 1.29;
  }
}

.about-invisalign__merit-title--en {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 7.6rem;
  line-height: 1;
  background: linear-gradient(125.63deg, #007cc2 -10.7%, #71cbfe 78.04%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-title--en {
    font-size: 5rem;
    gap: 1rem;
  }
}

.about-invisalign__merit-title--en::before,
.about-invisalign__merit-title--en::after {
  content: "";
  flex: 1;
  height: 1px;
  background: #007cc2;
}

.about-invisalign__merit-lists {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-wrap: wrap;
  gap: 4rem 2rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-lists {
    width: 84%;
    margin: 0 auto;
    padding: 0;
    gap: 2rem 1.07rem;
  }
}

.about-invisalign__merit-list {
  width: 23.75%;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-list {
    width: 48.3%;
  }
}

.about-invisalign__merit-list__img {
  width: 100%;
  margin-bottom: 1.5rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-list__img {
    margin-bottom: 1rem;
  }
}

.about-invisalign__merit-list__title {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-size: 2.3rem;
  line-height: 1.38;
  text-align: center;
  color: #007cc2;
  margin-bottom: 1rem;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-list__title {
    font-size: 1.6rem;
    line-height: 1;
    margin-bottom: 0.5rem;
  }
}

.about-invisalign__merit-list__text {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 2.1;
  color: #262626;
}

@media screen and (max-width: 767px) {
  .about-invisalign__merit-list__text {
    font-size: 1.4rem;
    line-height: 1.43;
  }
}

.comparison {
  background: url(../images/lp/comparison-bg.webp) no-repeat center center /
    cover;
  padding: 7rem 0;
}

@media screen and (max-width: 767px) {
  .comparison {
    background: url(../images/lp/sp/comparison-bg.webp) no-repeat center center /
      cover;
    padding: 4rem 0;
  }
}

.comparison__title {
  line-height: 1;
  display: flex;
  flex-direction: column;
  margin-bottom: 4rem;
  text-align: center;
}

.comparison__title--en {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 7.6rem;
  line-height: 1.1;
  background: linear-gradient(125.63deg, #007cc2 -10.7%, #71cbfe 78.04%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .comparison__title--en {
    font-size: 5rem;
    line-height: 1.52;
  }
}

.comparison__title--ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 3.6rem;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .comparison__title--ja {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-top: -1rem;
  }
}

.comparison__text {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  text-align: center;
  letter-spacing: 0.1em;
  color: #303030;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .comparison__text {
    font-size: 1.6rem;
    line-height: 2.06;
    width: 84%;
    margin: 0 auto 4rem;
  }
}

.comparison__table {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}

@media screen and (max-width: 767px) {
  .comparison__table {
    width: 92%;
    margin: 0 auto;
    padding: 0;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

.comparison__table img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .comparison__table img {
    width: 68.7rem;
    height: auto;
  }
}

@media screen and (max-width: 767px) {
  .scroll-hint-icon {
    background: rgba(217, 217, 217, 0.9);
    border-radius: 1rem;
    width: 13rem;
    padding: 5.5rem 0;
  }

  .scroll-hint-icon::before,
  .scroll-hint-icon::after {
    display: none;
  }

  .scroll-hint-text {
    font-weight: 700;
    font-size: 1.6rem;
    line-height: 1.25;
    letter-spacing: 0.1em;
    color: #000000;
  }
}

.flow {
  padding: 7rem 0;
}

@media screen and (max-width: 767px) {
  .flow {
    padding: 4rem 0;
  }
}

.flow__title {
  text-align: center;
  margin-bottom: 4rem;
  line-height: 1;
  display: flex;
  flex-direction: column;
}

@media screen and (max-width: 767px) {
  .flow__title {
    margin-bottom: 2rem;
  }
}

.flow__title--en {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 7.6rem;
  background: linear-gradient(125.63deg, #007cc2 -10.7%, #71cbfe 78.04%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .flow__title--en {
    font-size: 5rem;
    line-height: 1.52;
  }
}

.flow__title--ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 3.6rem;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .flow__title--ja {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-top: -1rem;
  }
}

.flow__inner {
  max-width: 1170px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  position: relative;
}

@media screen and (max-width: 767px) {
  .flow__inner {
    width: 84%;
    margin: 0 auto;
    padding: 0;
  }
}

.flow__inner::before {
  content: "";
  position: absolute;
  top: 0;
  left: 5.5%;
  background-color: #007cc2;
  height: 92%;
  width: 1px;
  z-index: -1;
}

@media screen and (max-width: 767px) {
  .flow__inner::before {
    left: 6.5%;
    height: 89%;
  }
}

.flow__item {
  display: flex;
  align-items: flex-start;
  gap: 4rem;
}

@media screen and (max-width: 767px) {
  .flow__item {
    gap: 1rem;
  }
}

.flow__item__number {
  width: 7.949%;
}

@media screen and (max-width: 767px) {
  .flow__item__number {
    width: 12.7%;
  }
}

.flow__item__wrapper {
  display: contents;
}

@media screen and (max-width: 767px) {
  .flow__item__wrapper {
    display: flex;
    flex-direction: column-reverse;
    gap: 1.1rem;
    margin-top: 2rem;
  }
}

.flow__item__content {
  flex: 1;
  margin-top: 2.8rem;
}

@media screen and (max-width: 767px) {
  .flow__item__content {
    margin-top: 0;
  }
}

.flow__item__title {
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: 3.6rem;
  line-height: 1;
  color: #007cc2;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .flow__item__title {
    font-size: 2.4rem;
    line-height: 1.5;
    margin-bottom: 1rem;
  }
}

.flow__item__text {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  color: #000000;
}

@media screen and (max-width: 767px) {
  .flow__item__text {
    font-size: 1.6rem;
    line-height: 2.06;
  }
}

.flow__item__img {
  width: 38.12%;
  margin-top: 2.8rem;
}

@media screen and (max-width: 767px) {
  .flow__item__img {
    width: 100%;
    margin-top: 0;
  }
}

.slide-show-area {
  padding: 7rem 0 4rem;
}

@media screen and (max-width: 767px) {
  .slide-show-area {
    padding: 4rem 0;
  }
}

.slide-show {
  overflow: hidden;
  height: 25rem;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .slide-show {
    height: 10.5rem;
  }
}

.slide-show__item {
  display: flex;
  width: fit-content;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  gap: 1rem;
  height: 100%;
}

@media screen and (max-width: 767px) {
  .slide-show__item {
    gap: 0.4rem;
  }
}

.slide-show__item img {
  display: block;
  width: auto;
  height: 100%;
  object-fit: contain;
  flex-shrink: 0;
}

.slide-show--left {
  margin-bottom: 1rem;
}

@media screen and (max-width: 767px) {
  .slide-show--left {
    margin-bottom: 0.4rem;
  }
}

/* 右から左にスクロール */
.slide-show--left .slide-show__item {
  animation-name: slideLeft;
  animation-duration: 30s;
}

@keyframes slideLeft {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-50%);
  }
}

/* 左から右にスクロール */
.slide-show--right .slide-show__item {
  animation-name: slideRight;
  animation-duration: 30s;
}

@keyframes slideRight {
  0% {
    transform: translateX(-50%);
  }
  100% {
    transform: translateX(0);
  }
}

.clinic-hours {
  padding: 0 0 4rem;
}

@media screen and (max-width: 767px) {
  .clinic-hours {
    padding: 0 0 2rem;
  }
}

.clinic-hours__inner {
  display: flex;
  justify-content: center;
  gap: 4rem;
}

@media screen and (max-width: 767px) {
  .clinic-hours__inner {
    flex-direction: column;
    gap: 2rem;
  }
}

.clinic-hours__about {
  width: 33.1945%;
  max-width: 478px;
}

@media screen and (max-width: 767px) {
  .clinic-hours__about {
    width: 84%;
    margin: 0 auto;
    max-width: none;
  }
}

.clinic-hours__about__title {
  width: 100%;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .clinic-hours__about__title {
    margin-bottom: 1.5rem;
  }
}

.clinic-hours__about__text {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.88;
  letter-spacing: 0.1em;
  color: #42370a;
  margin-bottom: 2rem;
}

@media screen and (max-width: 767px) {
  .clinic-hours__about__text {
    font-size: 1.6rem;
    line-height: 1.88;
    margin-bottom: 1.5rem;
    color: #262626;
  }
}

.clinic-hours__about__btn {
  width: fit-content;
  padding: 0.3rem 1.5rem;
  background: #ffffff;
  border: 0.5px solid #ff5c04;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.88;
  letter-spacing: 0.1em;
  color: #42370a;
}

.clinic-hours__about__btn img {
  width: 1.4rem;
}

.clinic-hours__hours {
  width: 38.889%;
  max-width: 560px;
}

@media screen and (max-width: 767px) {
  .clinic-hours__hours {
    width: 100%;
    max-width: none;
  }
}

.faq {
  background: url(../images/lp/faq-bg.webp) no-repeat center center / cover;
  padding: 7rem 0;
}

@media screen and (max-width: 767px) {
  .faq {
    padding: 4rem 0;
    background: url(../images/lp/sp/faq-bg.png) no-repeat center center / cover;
  }
}

.faq__title {
  text-align: center;
  margin-bottom: 4rem;
  line-height: 1;
  display: flex;
  flex-direction: column;
}

.faq__title--en {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 7.6rem;
  line-height: 1.1;
  background: linear-gradient(125.63deg, #007cc2 -10.7%, #71cbfe 78.04%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  text-fill-color: transparent;
}

@media screen and (max-width: 767px) {
  .faq__title--en {
    font-size: 5rem;
    line-height: 1.52;
  }
}

.faq__title--ja {
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  font-size: 3.6rem;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .faq__title--ja {
    font-size: 2.4rem;
  }
}

.faq__inner {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}

@media screen and (max-width: 767px) {
  .faq__inner {
    width: 84.267%;
    padding: 0;
    gap: 3rem;
  }
}

.faq__item {
  width: 100%;
}

.faq__item__question {
  display: flex;
  align-items: center;
  gap: 1rem;
  border-bottom: 1px solid #303030;
  padding-bottom: 2rem;
  position: relative;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .faq__item__question {
    gap: 0.9rem;
    align-items: flex-start;
  }
}

.faq__item__question::before,
.faq__item__question::after {
  content: "";
  position: absolute;
  right: 0;
  top: 34%;
  transform: translateY(-50%);
  width: 3.5rem;
  height: 2px;
  background: #007cc2;
  transition: transform 0.3s ease, opacity 0.3s ease;
}

@media screen and (max-width: 767px) {
  .faq__item__question::before {
    width: 2.5rem;
  }
}

/* 閉じているとき：プラスマーク（横線 + 縦線） */
.faq__item__question::before {
  width: 3.5rem;
  height: 2px;
}

@media screen and (max-width: 767px) {
  .faq__item__question::before {
    width: 2.5rem;
  }
}

.faq__item__question::after {
  width: 2px;
  height: 3.5rem;
  top: 34%;
  left: auto;
  right: 1.75rem;
  transform: translateY(-50%) rotate(0deg);
  opacity: 1;
}

@media screen and (max-width: 767px) {
  .faq__item__question::after {
    height: 2.5rem;
    right: 1.15rem;
  }
}

/* 開いているとき：マイナスマーク（横線のみ） */
.faq__item[open] .faq__item__question::after {
  transform: translateY(-50%) rotate(90deg);
  opacity: 0;
}

.faq__item__question__number {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 3.6rem;
  line-height: 1.11;
  letter-spacing: 0.1em;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .faq__item__question__number {
    font-size: 2.4rem;
    line-height: 1.67;
  }
}

.faq__item__question__text {
  font-weight: 600;
  font-size: 1.8rem;
  line-height: 2.22;
  letter-spacing: 0.1em;
  color: #303030;
}

@media screen and (max-width: 767px) {
  .faq__item__question__text {
    font-size: 1.6rem;
    line-height: 1.25;
    width: 81.014%;
  }
}

.faq__item__answer {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  padding-top: 0;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.3s ease, padding-top 0.3s ease;
}

/* JavaScriptで制御するため、[open]セレクタはフォールバック用 */
.faq__item[open] .faq__item__answer {
  max-height: 1000px;
  opacity: 1;
  padding-top: 2rem;
}

@media screen and (max-width: 767px) {
  .faq__item[open] .faq__item__answer {
    padding-top: 1rem;
  }
}

.faq__item__answer__number {
  font-family: "Glowgirl", "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 3.6rem;
  line-height: 1.11;
  text-align: center;
  letter-spacing: 0.1em;
  color: #007cc2;
}

@media screen and (max-width: 767px) {
  .faq__item__answer__number {
    font-size: 2.4rem;
    line-height: 1.67;
  }
}

.faq__item__answer__text {
  font-weight: 400;
  font-size: 1.8rem;
  line-height: 1.83;
  letter-spacing: 0.1em;
  color: #303030;
  width: 84.7%;
  margin-left: 4.7rem;
}

@media screen and (max-width: 767px) {
  .faq__item__answer__text {
    font-size: 1.6rem;
    line-height: 1.88;
    width: 82.595%;
    margin: 0 auto;
  }
}

.unapproved-medicines {
  background-color: #f5f5f5;
  padding: 4rem 0;
}

@media screen and (max-width: 767px) {
  .unapproved-medicines {
    padding: 3rem 0;
  }
}

.unapproved-medicines__inner {
  max-width: 880px;
  margin: 0 auto;
  padding: 0 20px;
}

@media screen and (max-width: 767px) {
  .unapproved-medicines__inner {
    width: 84%;
    padding: 0;
  }
}

.unapproved-medicines__title {
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 1.94;
  letter-spacing: 0.1em;
  color: #262626;
  position: relative;
  padding-bottom: 1.2rem;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .unapproved-medicines__title {
    margin-bottom: 3.4rem;
  }
}

.unapproved-medicines__title::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  width: 5rem;
  height: 1px;
  background: #262626;
}

.unapproved-medicines__text {
  font-weight: 300;
  font-size: 1.6rem;
  line-height: 1.94;
  letter-spacing: 0.1em;
  color: #262626;
  margin-bottom: 4rem;
}

.unapproved-medicines__subtitle {
  font-weight: 600;
  font-size: 1.6rem;
  line-height: 1.94;
  letter-spacing: 0.1em;
  color: #262626;
  margin-bottom: 1rem;
}

.unapproved-medicines__list {
  font-weight: 300;
  font-size: 1.6rem;
  line-height: 1.94;
  letter-spacing: 0.1em;
  color: #262626;
  position: relative;
  padding-left: 1.6rem;
}

.unapproved-medicines__list::before {
  content: "・";
  font-size: 1.6rem;
  color: #262626;
  position: absolute;
  left: 0;
  top: 0;
}

.footer {
  background-color: #eaf3fa;
  padding-top: 7rem;
}

@media screen and (max-width: 767px) {
  .footer {
    padding-top: 4rem;
    padding-bottom: 0.6rem;
  }
}

.footer__inner {
  max-width: 1000px;
  margin: 0 auto 9.5rem;
  padding: 0 20px;
  display: flex;
  flex-direction: column;
  gap: 4rem;
}

@media screen and (max-width: 767px) {
  .footer__inner {
    width: 84%;
    padding: 0;
    margin: 0 auto 4rem;
    gap: 3rem;
  }
}

.footer__top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}

@media screen and (max-width: 767px) {
  .footer__top {
    flex-direction: column;
    align-items: center;
    gap: 4rem;
  }
}

.footer__logo {
  width: 44.4%;
}

@media screen and (max-width: 767px) {
  .footer__logo {
    width: 100%;
  }
}

.footer__btns {
  display: flex;
  align-items: stretch;
  justify-content: flex-end;
  gap: 1rem;
  flex: 1;
}

@media screen and (max-width: 767px) {
  .footer__btns {
    width: 100%;
    gap: 0.8rem;
  }
}

.footer__btn {
  width: 21.584%;
  padding: 1rem 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.8rem;
  box-shadow: 2px 2px 4px rgba(0, 0, 0, 0.25);
  position: relative;
}

@media screen and (max-width: 767px) {
  .footer__btn {
    width: 31.578%;
  }
}

.footer__btn::after {
  content: "";
  position: absolute;
  bottom: 5px;
  right: 5px;
  width: 8px;
  height: 8px;
  background: rgba(255, 255, 255, 0.8);
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.footer__btn span {
  font-weight: 400;
  font-size: 1.6rem;
  line-height: 1.375;
  letter-spacing: 0.1em;
  color: #ffffff;
}

.footer__btn-web {
  background: #ff5c04;
  gap: 1rem;
}

@media screen and (max-width: 767px) {
  .footer__btn-web {
    background: #007cc2;
    gap: 0.9rem;
  }
}

.footer__btn-web img {
  width: 5.2rem;
}

@media screen and (max-width: 767px) {
  .footer__btn-web img {
    width: 4.63em;
  }
}

.footer__btn-line {
  background: #06c755;
}

.footer__btn-line img {
  width: 5rem;
}

@media screen and (max-width: 767px) {
  .footer__btn-line img {
    width: 4.1em;
  }
}

.footer__btn-tel {
  background: #ffffff;
}

.footer__btn-tel::after {
  content: "";
  position: absolute;
  bottom: 5px;
  right: 5px;
  width: 8px;
  height: 8px;
  background: #007cc2;
  clip-path: polygon(100% 0%, 100% 0%, 100% 100%, 0% 100%);
}

.footer__btn-tel img {
  width: 4.6rem;
}

@media screen and (max-width: 767px) {
  .footer__btn-tel img {
    width: 3.8rem;
  }
}

.footer__btn-tel span {
  color: #007cc2;
}

.footer__btn-top {
  width: 17.626%;
  margin-left: 0.5rem;
  padding: 0;
  box-shadow: none;
}

@media screen and (max-width: 767px) {
  .footer__btn-top {
    display: none;
  }
}

.footer__btn-top img {
  filter: drop-shadow(2px 2px 4px rgba(0, 0, 0, 0.25));
}

.footer__sns {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 2.5rem;
}

.footer__sns-link {
  width: 4.8%;
}

@media screen and (max-width: 767px) {
  .footer__sns-link {
    width: 15.24%;
  }
}

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
}

@media screen and (max-width: 767px) {
  .footer__bottom {
    flex-direction: column;
    align-items: center;
    gap: 3rem;
  }
}

.footer__map {
  width: 48%;
}

@media screen and (max-width: 767px) {
  .footer__map {
    width: 100%;
    aspect-ratio: 315/209;
  }
}

.footer__map iframe {
  width: 100%;
  height: 100%;
}

.footer__hours {
  width: 48%;
}

@media screen and (max-width: 767px) {
  .footer__hours {
    width: 100%;
  }
}

.footer__copyright {
  font-weight: 400;
  font-size: 1.1rem;
  line-height: 3;
  letter-spacing: 0.1em;
  color: #007cc2;
  text-align: center;
}
