@charset "UTF-8";

/* DIN Alternate bold */
@font-face {
  font-family: "DIN Alternate";
  src: url(lp/asset/font/din-alternate-bold.ttf) format("opentype");
}

html {
  font-size: clamp(0px, 2vw, 15px);
}

/* font
--------------------- */
/* color
--------------------- */
/* layout
--------------------- */
:root {
  --color-main: #000;
  --color-sub: #fff;
  --color-annotation: #292929;
  --font-size-content: 1.85rem;
  --font-weight-content: 300;
  --font-size-annotation: 1.2rem;
  --font-weight-annotation: 300;
  --ff-koburina: "Koburina Gothic StdN", "Koburina Gothic W3 JIS2004", "こぶりなゴシック W3 JIS2004", sans-serif !important;
  --ff-koburina-w6: "Koburina Gothic StdN", "Koburina Gothic W6 JIS2004", "こぶりなゴシック W6 JIS2004", sans-serif !important;
}

.body {
  margin-inline: auto;
  font-family: var(--ff-koburina);
  font-weight: 300;
  width: min(50rem, 100%);
  color: #333;
  background: #000;
}

img {
  width: 100%;
  vertical-align: middle;
  object-fit: cover;
  object-position: top;
  height: auto;
}

a {
  transition: .3s;
}

a:hover {
  transform: scale(1.05);
  transition: .3s;
}

@-webkit-keyframes scaleChange {
  0% {
    scale: 1.05;
  }

  50% {
    scale: 0.95;
  }

  100% {
    scale: 1.05;
  }
}

@keyframes scaleChange {
  0% {
    scale: 1.05;
  }

  50% {
    scale: 0.95;
  }

  100% {
    scale: 1.05;
  }
}

/* ボタン */
.cvBtn {
  display: block;
  margin-inline: auto;
  width: 44rem;
  -webkit-animation: scaleChange 2s infinite;
  animation: scaleChange 2s infinite;
  -webkit-backdrop-filter: unset;
  backdrop-filter: unset;
  -webkit-backdrop-filter: blur(1px);
  backdrop-filter: blur(1px);
}

/* 注釈エリア */
*[data-ahead-double] {
  position: relative;
  padding-left: 2em;
}

*[data-ahead-double]::before {
  position: absolute;
  left: 0;
  top: 0;
  content: attr(data-ahead-double);
  display: inline-block;
  color: inherit;
  font: inherit;
}

*[data-ahead-single] {
  position: relative;
  padding-left: 1.3em;
}

*[data-ahead-single]::before {
  position: absolute;
  left: 0;
  top: 0;
  content: attr(data-ahead-single);
  display: inline-block;
  color: inherit;
  font: inherit;
}

/* フローティングエリア */
.floating {
  display: block;
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  padding-block: 2rem;
  -webkit-backdrop-filter: blur(5rem);
  backdrop-filter: blur(5rem);
  z-index: 999;
}

@media (min-width: 750px) {
  .floating {
    display: none;
  }
}

.floating img {
  max-height: 10rem;
  object-fit: contain
}

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 2.67% 3%;
  background: #fff;
}

.header__logo {
  flex-basis: 15rem;
}

.header__nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 2.5%;
}

.header__navItem:first-of-type {
  width: 12.5rem;
}

.header__navItem:nth-of-type(2) {
  width: 18rem;
}

.fv__copy {
  margin-bottom: 3%;
}

.fv__contents {
  padding: 5% 0 0;
  background: #222A37;
}

.fv__atn {
  margin-inline: auto;
  width: 89.4%;
  padding: 3% 0;
  font-size: 1.25rem;
  color: #fff;
}

/* achievements section */
.achievements {
  background: linear-gradient(309deg, #1A4560 1.87%, #2A6E9D 58.19%, #1A4560 92.57%);
  position: relative;
}

.achievements::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 100%;
  margin-top: -1px;
  aspect-ratio: 10/1;
  background: #222A37;
  clip-path: polygon(0 0, 100% 0, 0 100%);
}

.achievements__img {
  width: 100%;
}

.achievements__wrap {
  position: absolute;
  transform: translateX(-50%);
  top: 61rem;
  left: 50%;
  width: 100%;
}

.achievements__cases {
  margin: 0 6%;
  padding: 5%;
  background: #fff;
}

.achievements__case__ttl {
  text-align: center;
  margin-bottom: 3%;
  position: relative;
}

.achievements__case__ttl-img {
  width: 15rem;
}

.achievements__case__gif {
  width: 100%;
  margin-top: -6%;
  padding-bottom: 6%;
}

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

.achievements__case__annotation {
  text-align: center;
  font-size: var(--font-size-annotation);
  color: #292929;
}

/* medical section */
.medical {
  background: #fff;
}

.medical {
  background-image: url(/lp/asset/image/2025_hige_reconstruct/medical/bg_medical.webp);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 0 0;
}

.yho .medical__wrap {
  padding-top: 4rem;
  padding-bottom: 2rem;
}

.medical__txt {
  padding: 5% 6%;
  font-size: var(--font-size-content);
}

.medical__hikaku__header {
  padding: 0 6% 6%;
  text-align: center;
  color: #1B7ABA;
  font-style: normal;
  font-family: var(--ff-koburina-w6);
  font-weight: 600;
  line-height: 1.2;
}

.medical__hikaku__header__txt1 {
  font-size: 4rem;
}

.medical__hikaku__header__txt2 {
  font-size: 6.8rem;
}

.medical__hikaku__header__txt2 small {
  font-size: 4rem;
}

.medical__hikaku__figure {
  padding: 0 6%;
}

.medical__hikaku__anotation {
  padding: 1% 6% 6% 0;
  text-align: right;
  font-size: 1.7rem;
  color: var(--color-annotation);
  font-weight: var(--font-weight-annotation);
}

/* machine section */
.machine {
  background-image: url(/lp/asset/image/2025_hige_reconstruct/machine/bg_machine.webp);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 0 0;
}

.machine__machine-info {
  padding: 3% 6% 0;
  text-align: center;
}

.machine__machine-info__subttl {
  font-size: 2.3rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  letter-spacing: -1.4px;
  color: #333;
}

.machine__machine-info__ttl {
  padding-top: 1%;
}

.machine__machine-info__img {
  padding-top: 5%;
  width: 60%;
  display: block;
  margin: 0 auto;
}

.machine__points {
  padding: 7% 6% 5%;
}

.machine__point-item {
  margin-bottom: 8%;
  display: flex;
  flex-direction: column;
  gap: 3rem;
}

.point-item__header {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1%;
}

.point-item__header span {
  flex: 0 13rem;
  text-align: center;
  font-family: "DIN 2014";
  font-size: 2.6rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #222A37;
}

.point-item__header::before,
.point-item__header::after {
  content: "";
  display: block;
  flex: 1;
  width: 100%;
  height: 1px;
  border-bottom: 2px solid #222A37;
}

.point-item__ttl {
  text-align: center;
  font-size: 4rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  line-height: 1.3;
}

.point-item__ttl__txt1 {
  color: #1B7ABA;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5%;
}

.point-item__ttl__txt1 strong {
  font-size: 9rem;
  font-family: "DIN 2014", sans-serif;
  font-weight: 400;
  line-height: 0;
}

.point-item__ttl__txt2 {
  color: #292929;
}

.point-item__txt {
  font-size: var(--font-size-content);
  font-weight: var(--font-weight-content);
  letter-spacing: -0.02rem;
}

.point-item__txt strong {
  background-color: #FFED89;
}

.point-item__waves-wrap {
  display: flex;
  flex-direction: column;
  gap: 1.7rem;
}

.point-item__wave-item {
  position: relative;
  padding: 3% 5%;
  border: 0.3rem solid #2C9AE5;
  background-color: #fff;
}

.point-item__wave-item::before {
  content: "";
  display: block;
  position: absolute;
  top: -1px;
  left: -1px;
  height: 30%;
  aspect-ratio: 1/1;
  clip-path: polygon(0 0, 100% 0, 0 100%);
  background-color: #2C9AE5;
}

.point-item__wave-item:nth-of-type(2) {
  border-color: #1A7ABA;
}

.point-item__wave-item:nth-of-type(2)::before {
  background-color: #1A7ABA;
}

.point-item__wave-item:nth-of-type(3) {
  border-color: #3D4E6A;
}

.point-item__wave-item:nth-of-type(3)::before {
  background-color: #3D4E6A;
}

.wave-item__name {
  font-size: 1.8rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #2C9AE5;
}

.point-item__wave-item:nth-of-type(2) .wave-item__name {
  color: #1A7ABA;

}

.point-item__wave-item:nth-of-type(3) .wave-item__name {
  color: #3D4E6A;
}

.wave-item__txt {
  font-size: 1.6rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.point-item__anotation {
  padding-top: 1%;
  font-size: var(--font-size-annotation);
  font-weight: var(--font-weight-annotation);
  color: var(--color-annotation);
  text-align: right;
}

/* reason section */

.reason {
  background-image: url(/lp/asset/image/2025_hige_reconstruct/reason/reason_bg.webp);
  background-size: cover;
  background-repeat: no-repeat;
  background-position: 0 0;
}

.reason__header {
  padding: 9% 0 0;
}

.reason__header__subttl {
  padding: 1% 4%;
  margin: 0 auto;
  width: fit-content;
  background-color: #1B7ABA;
  color: #fff;
  font-size: 3rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.reason__header__subttl small {
  font-size: 2.6rem;
}

.reason__header__ttl {
  font-size: 7.5rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #1B7ABA;
  width: fit-content;
  margin: 0 auto;
}

.reason__contents {
  display: flex;
  flex-direction: column;
  gap: 10%;
  padding-bottom: 12%;
}

.reason__content-item {
  display: flex;
  flex-direction: column;
  gap: 2.1rem;
}

.reason__content-item__ttl {
  display: flex;
  flex-direction: row;
  font-size: 4.2rem;
  position: relative;
}

.reason__content-item__ttl:first-of-type {
  padding-top: 6rem;
}

.reason__content-item:nth-of-type(even) .reason__content-item__ttl {
  flex-direction: row-reverse;
}

.reason__content-item__ttl__txt1-wrap {
  position: absolute;
  bottom: 7.3rem;
  left: 2rem;
  line-height: 4.5rem;
  background: #FFF265;
  filter: drop-shadow(2px 2px 0 #FFF);
  z-index: 1;
}

.reason__content-item__ttl__txt1-wrap::before {
  content: "";
  display: block;
  position: absolute;
  top: 99.9%;
  left: 20%;
  width: 1rem;
  height: 0.8rem;
  background-color: #FFF265;
  clip-path: polygon(0 0, 100% 0, 100% 100%);
  filter: drop-shadow(2px 2px 0 #FFF);
}

.reason__content-item__ttl__txt1 {
  position: relative;
  color: #1B7ABA;
  padding: 0.2rem 1.2rem 0.15rem;
  font-size: 3.2rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.reason__content-item__ttl__txt1 small {
  font-size: 2.6rem;
}


.reason__content-item__ttl__txt2 {
  color: #fff;
  background: linear-gradient(305deg, #286792 -0.44%, #222A37 90.45%);
  font-size: 3.8rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  padding: 1.2rem 6rem 1.2rem 4.5rem;
  clip-path: polygon(0 0, 100% 0, calc(100% - 2.5rem) 100%, 0 100%);
  letter-spacing: 2px;
}

.reason__content-item__ttl__txt2 small {
  font-size: 2.6rem;
}

.reason__content-item:nth-of-type(even) .reason__content-item__ttl__txt2 {
  padding: 1.2rem 3.5rem 1.2rem 7rem;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 2.5rem 100%);
}

.reason__content-item__figure-wrap {
  position: relative;
  padding: 0 6%;
}

.reason__content-item__mudage {
  position: absolute;
  width: 8.5rem;
  top: -5.6rem;
  right: 4.7rem;
}

.reason__content-item__txt {
  padding: 0 6%;
  font-size: var(--font-size-content);
  font-weight: var(--font-weight-content);
}

.reason__content-item__txt strong {
  background-color: #FFED89;
}

.reason__content-item__piture-prefix {
  padding-bottom: 3%;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: var(--font-size-content);
  font-weight: var(--font-weight-content);
}

.reason__content-item__piture-prefix span {
  padding: 0 1%;
}

/* no-add-fee section */

.no-add-fee__ttl {
  margin-top: -7%;
}

.no-add-fee__content-wrap {
  background: linear-gradient(305deg, #286792 -0.44%, #222A37 90.45%);
  padding: 25px 0;
}

.no-add-fee__content-wrap__prefix {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.no-add-fee__content-wrap__prefix::before {
  content: "";
  display: block;
  width: 100%;
  height: 8px;
  background-color: #E1D0B6;
}

.no-add-fee__content-wrap__prefix::after {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-color: #E1D0B6;
}

.no-add-fee__content-wrap__suffix {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.no-add-fee__content-wrap__suffix::before {
  content: "";
  display: block;
  width: 100%;
  height: 2px;
  background-color: #E1D0B6;
}

.no-add-fee__content-wrap__suffix::after {
  content: "";
  display: block;
  width: 100%;
  height: 8px;
  background-color: #E1D0B6;
}

.no-add-fee__content__txt {
  padding: 4% 0;
  text-align: center;
  font-size: var(--font-size-content);
  font-weight: var(--font-weight-content);
  color: #fff;
}

.no-add-fee__content__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1.5rem;
  padding: 0 2.2rem 4%;
}

.no-add-fee__content__list__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  width: calc((100% - 2.1rem * 2) / 3);
  aspect-ratio: 1/1;
  padding: 1.5rem 0 1rem;
  gap: 2%;
}

.no-add-fee__content__list__item__img {
  flex: 1;
  width: 7.2rem;
  aspect-ratio: 1/1;
  object-fit: contain;
}

.no-add-fee__content__list__item__ttl {
  flex: 0 0 33%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 1.3rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #222A37;
  text-align: center;
}

.no-add-fee__content__list__item__ttl small {
  font-size: 1rem;
}

/* cost-performance section */

.cost-performance {
  background-color: #F2F2F2;
  position: relative;
}

.cost-performance__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

.cost-performance__ttl {
  padding: 5rem 0 10rem;
  background: linear-gradient(237deg, #222A37 0.49%, #286792 105.14%);
  clip-path: polygon(0 0, 100% 0, 100% 70%, 0 100%);
}

.cost-performance__ttl__txt1 {
  padding: 1% 4%;
  margin: 0 auto;
  width: fit-content;
  background-color: #fff;
  color: #004271;
  font-size: 3rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  letter-spacing: 0.2rem;
}

.cost-performance__ttl__txt1 small {
  font-size: 2.4rem;
}

.cost-performance__ttl__txt2 {
  font-size: 5.6rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #fff;
  width: fit-content;
  margin: 0 auto;
}

.cost-performance__ttl__txt2 small {
  font-size: 4.3rem;
  padding-left: 0.5rem;
}

.cost-performance__bg__deco1 {
  display: block;
  height: 26rem;
  width: 100%;
  background-color: #C4C4C4;
  clip-path: polygon(0 0, 100% 30%, 100% 100%, 0 70%);
  margin-bottom: 13rem;
}

.cost-performance__bg__deco2 {
  position: relative;
  z-index: 1;
  display: block;
  height: 31rem;
  width: 100%;
  background: linear-gradient(122deg, #222A37 5.58%, #286792 115.37%);
  clip-path: polygon(0 30%, 100% 0, 100% 70%, 0 100%);
}

.cost-performance__bg__deco3 {
  display: block;
  height: 31rem;
  width: 100%;
  background-color: #C4C4C4;
  clip-path: polygon(0 0, 100% 30%, 100% 100%, 0 70%);
  margin-top: -10rem;
}

.cost-performance__contents {
  position: relative;
  z-index: 2;
  padding-top: 19rem;
}

.cost-performance__contents__face-img {
  padding: 0 6rem;
}

.cost-performance__face-parts {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-template-rows: repeat(2, 1fr);
  gap: 1rem;
  padding: 0 2.4rem 2rem;
  margin-top: -3.7rem;
}

.cost-performance__face-part {
  color: #FFF;
  background: linear-gradient(153deg, #64B4EB -151%, #286792 191.42%);
  text-align: center;
  font-size: 2.2rem;
  padding: 0.5rem 0;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.cost-performance__plan1 {
  background: linear-gradient(172deg, #D0B080 -39.32%, #BE9D6A 39.03%, #987E58 115.22%);
  color: #fff;
  padding: 4% 0 3%;
  margin: 0 2.4rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 4%;
}

.cost-performance__plan1__txt1 {
  font-size: 3.76rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #fff;
  text-align: center;
  line-height: 1.1;
}

.cost-performance__plan1__txt2 {
  font-size: 2.4rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #fff;
  text-align: center;
}

.cost-performance__plan1__wrap.right {
  padding: 2% 3% 1.5%;
  border: 0.2rem solid #fff;
  display: flex;
  align-items: flex-end;
  font-size: 3.76rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  line-height: 1;
  gap: 0.3rem;
}

.cost-performance__plan1__wrap.right strong {
  font-size: 5.8rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  line-height: 0.8;
  padding-bottom: 0.2rem;
}

.cost-performance__plan2 {
  background: #292929;
  color: #fff;
  font-size: 1.8rem;
  padding: 2% 0;
  margin: 0 2.4rem;
  display: flex;
  justify-content: center;
  gap: 2%;
  line-height: 1.3;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.cost-performance__plan2__img {
  margin-top: 0.2rem;
  height: 1em;
  width: auto;
}

.cost-performance__plan3 {
  background: #fff;
  color: #292929;
  padding: 5%;
  margin: 0 2.4rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 4%;
}

.cost-performance__plan3__img {
  width: 85%;
  display: block;
  margin: 0 auto;
}

.cost-performance__plan3__txt {
  font-size: 3.24rem;
  background: linear-gradient(transparent 0%, transparent 60%, #FFE971 60%, #FFE971 100%);
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  letter-spacing: 0.1em;
}

.cost-performance__plan3__cta__wrap {
  width: 72.5%;
  font-size: 2rem;
  font-weight: var(--font-weight-content);
  text-align: center;
}

.cost-performance__plan3__cta {
  background: linear-gradient(305deg, #222A37 -0.44%, #286792 90.45%);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2%;
  color: #fff;
  width: 100%;
  border-radius: 100rem;
  padding: 2%;
  margin-top: 3rem;
}

.cost-performance__plan3__cta::after {
  content: "";
  background-repeat: no-repeat;
  background-size: contain;
  background-image: url(/lp/asset/image/2025_hige_reconstruct/no_add_fee/arrow_plan3-cta_cost-performance.webp);
  position: absolute;
  top: 50%;
  right: 0;
  transform: translate(-50%, -50%);
  height: 25%;
  width: 5%;
}

.cost-performance__plan3__cta__txt1 {
  border-bottom: 1px solid #fff;
}

.cost-performance__plan3__cta__txt1 strong {
  font-size: 2.3rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.cost-performance__annotation {
  margin: 0 2.4rem;
  padding: 3% 0 3%;
  font-size: var(--font-size-annotation);
  font-weight: var(--font-weight-annotation);
  color: #292929;
}

/* pain section */

.pain {
  background: linear-gradient(180deg, #F2F2F2 0%, #E2E2E2 100%);
  padding-top: 6rem;
  margin-top: -1px;
  display: flex;
  flex-direction: column;
  gap: 2rem;
}

.pain__header {
  position: relative;
  margin: 0 2.4rem;
}

.pain__header::before {
  content: "";
  display: block;
  position: absolute;
  top: 6.3rem;
  left: 1.9rem;
  width: 5rem;
  aspect-ratio: 6 / 5;
  background-image: url(/lp/asset/image/2025_hige_reconstruct/pain/img_pain_ttl_prefix.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}

.pain__header__txt {
  font-size: 2.5rem;
  width: fit-content;
  margin: 0 auto;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #fff;
  background: linear-gradient(90deg, #3D4E6A 0%, #093253 100%);
  padding: 0.7rem 2.7rem;
  letter-spacing: 0.3rem;
}

.pain__header__img {
  padding-top: 2.2rem;
  display: block;
  width: 68%;
  margin: 0 auto;
}

.pain__header__float-mudage {
  position: absolute;
  bottom: -7.5rem;
  right: -0.5rem;
  width: 8rem;
  z-index: 10;
}

.pain__points {
  display: flex;
  flex-direction: column;
  gap: 2rem;
  margin: 0 2.4rem;
}

.pain__points__1 {
  background: #fff;
  margin-top: 2rem;
  padding-bottom: 3rem;
  filter: drop-shadow(8px 12px 0 #DBDDE1);
}

.c-point1__header {
  margin-top: -1.5rem;
  display: flex;
  align-items: center;
  gap: 2rem;
}

.c-point1__header__left {
  display: flex;
  align-items: center;
  padding: 1.1rem;
  width: 10rem;
  aspect-ratio: 1/1;
  background: linear-gradient(180deg, #3D4E6A 0%, #093253 100%);
  flex-shrink: 0;
}

.c-point1__header__left__num {
  flex: 1;
  align-self: flex-end;
  font-size: 4.3rem;
  font-weight: 500;
  color: #fff;
  font-family: "DIN 2014";
  line-height: 1;
}

.c-point1__header__left__img {
  flex: 1;
  align-self: flex-start;
  height: 4.7rem;
  margin: 0 auto;
  object-fit: contain;
  object-position: right;
}

.c-point1__header__right {
  flex: 1;
  align-self: flex-end;
  padding-bottom: 0.6rem;
  font-size: 3.1rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #1B7ABA;
  letter-spacing: 0.2rem;
}

.pain__points__2,
.pain__points__3 {
  background: #fff;
  margin-top: 1.2rem;
  margin-left: 2rem;
  padding: 1.7rem 0;
  filter: drop-shadow(8px 12px 0 #DBDDE1);
  display: flex;
  align-items: center;
  gap: 2.2rem;
}

.c-point2__left,
.c-point3__left {
  display: flex;
  align-items: center;
  padding: 1.1rem;
  margin-left: -2rem;
  width: 10rem;
  aspect-ratio: 1/1;
  background: linear-gradient(180deg, #3D4E6A 0%, #093253 100%);
  flex-shrink: 0;
}

.c-point2__left__num,
.c-point3__left__num {
  flex: 1;
  align-self: flex-end;
  font-size: 4.3rem;
  font-weight: 500;
  color: #fff;
  font-family: "DIN 2014";
  line-height: 1;
}

.c-point2__left__img,
.c-point3__left__img {
  flex: 1;
  align-self: flex-start;
  margin: 0 auto;
  object-fit: contain;
  object-position: right;
}

.c-point2__left__img {
  height: 3.8rem;
}

.c-point3__left__img {
  height: 2.8rem;
  margin-left: -0.7rem;
}

.c-point2__right,
.c-point3__right {
  flex: 1;
  padding: 0;
}

.c-point2__right__txtwrap,
.c-point3__right__txtwrap {
  display: flex;
  align-items: center;
  height: 100%;
}

.c-point2__right__txt,
.c-point3__right__txt {
  font-size: 2.3rem;
  font-weight: var(--font-weight-content);
  color: #222A37;
  line-height: 1.5;
  letter-spacing: 0.05rem
}

.c-point2__right__txt strong,
.c-point3__right__txt strong {
  font-size: 3.1rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #1B7ABA;
  letter-spacing: 0.2rem;
}

.c-point1__imgwrap {
  margin: 2rem 0;
  position: relative;
}

.c-point1__img {
  padding: 0 2rem;
  width: 100%;
  height: auto;
}

.c-point1__contents {
  padding: 0;
}

.c-point1__contents__lines {
  padding: 1.8rem 3.2rem 1.4rem;
  position: relative;
  width: fit-content;
  margin: 0 auto 2.2rem;
}

.c-point1__contents__lines::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 50%;
  aspect-ratio: 2/3;
  border-left: 2px solid #292929;
  border-top: 2px solid #292929;
}

.c-point1__contents__lines::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  height: 50%;
  aspect-ratio: 2/3;
  border-right: 2px solid #292929;
  border-bottom: 2px solid #292929;
}

.c-point1__contents__lines__txt {
  font-size: 1.9rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #1B7ABA;
  line-height: 1.4;
  text-align: center;
  letter-spacing: 0.1rem;
}

.c-point1__contents__txt {
  font-size: var(--font-size-content);
  color: #333;
  margin-bottom: 1.5rem;
  text-align: center;
  font-weight: 300;
}

.c-point1__contents__txt strong {
  background-color: #FFE971;
}

.c-point1__contents__anotation {
  font-size: var(--font-size-annotation);
  font-weight: var(--font-weight-annotation);
  text-align: center;
  display: block;
  color: var(--color-annotation);
}

.pain__after {
  position: relative;
  background: #fff;
  margin: 2rem 2.4rem;
  padding: 1.7rem;
  filter: drop-shadow(8px 12px 0 #DBDDE1);
  display: flex;
  align-items: center;
  gap: 2.2rem;
}

.pain__after__floatimg {
  position: absolute;
  top: -0.7rem;
  left: 3rem;
  width: 10rem;
  z-index: 2;
}

.pain__after__wrap {
  position: relative;
  z-index: 1;
  border: 0.2rem solid #1B7ABA;
}

.pain__after__header {
  padding-top: 3rem;
  font-size: 3rem;
  font-weight: 300;
  color: #292929;
  text-align: center;
  margin-bottom: 1rem;
  line-height: 1.4;
}

.pain__after__header strong {
  font-size: 3.6rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #1B7ABA;
  letter-spacing: 0.2rem;
  background: linear-gradient(180deg, transparent 0%, transparent 75%, #FFED89 75%, #FFED89 100%);
}

.pain__after__content {
  padding: 0 2.5rem;
  border-radius: 1rem;
}

.pain__after__content__txtwrap {
  background: #f8f8f8;
  padding: 2.5rem;
}

.yho .pain__after__content__txtwrap {
  padding: 2.5rem 0;
}

.pain__after__content__subtitle {
  font-size: 1.8rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #222A37;
  text-align: center;
  padding-bottom: 0.5rem;
  margin: 0 auto 2rem;
  border-bottom: 0.15rem solid black;
  width: fit-content;
}

.pain__after__content__txtlist {
  list-style: none;
  padding: 0;
}

.pain__after__content__txtlist li {
  font-size: 1.6rem;
  color: #333;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  line-height: 1.4;
  margin-bottom: 1.2rem;
  padding-left: 2rem;
  position: relative;
}

.pain__after__content__txtlist li:last-child {
  margin-bottom: 0;
}

.pain__after__content__txtlist li strong {
  font-size: 1.8rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #286792;
  letter-spacing: 0.1rem;
}

.pain__after__content__txtlist li:first-of-type strong {
  padding-left: 0.5rem;
}

.pain__after__content__txtlist li::before {
  content: "";
  position: absolute;
  top: 1.3rem;
  left: .2rem;
  width: 1.8rem;
  height: 1.8rem;
  background-image: url(/lp/asset/image/2025_hige_reconstruct/pain/icon_pain_after.webp);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transform: translate(-50%, -50%);
  display: inline-block;
}

.pain__after__content__txt {
  font-size: 1.6rem;
  color: #333;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  line-height: 1.7;
  text-align: center;
}

.pain__after__content__txt strong {
  font-size: 2rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #286792;
}

.pain__after__content__line {
  text-align: center;
  font-size: var(--font-size-content);
  font-weight: var(--font-weight-content);
  padding: 1rem 0 0.5rem;
}

.pain__after__content__line span {
  padding: 0 1rem;
}

.pain__after__content__img {
  width: 100%;
  height: auto;
}

/* plan section */

.plan__header {
  /* plan header styles */
  position: relative;
}

.plan__header__img {
  /* plan header image styles */
  margin-top: -1px;
}

.plan__tab-btn-area {
  /* plan tab button area styles */
  position: absolute;
  bottom: -1px;
  z-index: 1;
  width: 100%;
  height: 6rem;
  display: flex;
  gap: 1rem;
}

.plan__tab-btn {
  /* plan tab button styles */
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #abc9de;
  color: #292929;
  font-size: 2.2rem;
  letter-spacing: 0.1rem;
  clip-path: polygon(0 0, calc(100% - 1rem) 0, 100% 1rem, 100% 100%, 0 100%);
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.plan__tab-btn.active {
  background-color: #222A37;
  color: #fff;
}

.plan__tab-area {
  /* plan tab area styles */
  position: relative;
  z-index: 2;
}

.plan__tab-content {
  /* plan tab content styles */
  display: none;
  background-color: #222A37;
  padding: 4rem 2.4rem;
}

.plan__tab-content.active {
  /* plan tab content active styles */
  display: flex;
  flex-direction: column;
  gap: 3rem;
}

.c-plan-item {
  /* plan item styles */
  padding: 2rem;
  background-color: #fff;
  margin-bottom: 0.5rem;
}

.c-plan-item__wrapper2 {
  /* plan item wrapper styles */
  display: flex;
  gap: 1rem;
}

.c-plan-item__main-img {
  /* plan item main image styles */
  flex: 0 14rem;
  max-width: 14rem;
  max-height: 14rem;
  object-fit: contain;
  align-self: center;
}

.c-plan-item__content {
  /* plan item content styles */
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 1rem;
}

.c-plan-item__content__title {
  /* plan item content title styles */
  display: flex;
  align-items: center;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  font-size: 2.3rem;
  letter-spacing: 0.1rem;
}

.c-plan-item__content__title span {
  font-size: 1.4rem;
  color: #fff;
  padding: 0.35rem 0.9rem 0.2rem;
  letter-spacing: normal;
  margin-left: 0.5rem;
  border-radius: 10rem;
  background-color: #1B7ABA;
}

/* 個別対応：ヒゲ・頭タブ　選べる部位 */
.c-plan-item__wrapper:nth-of-type(2) .c-plan-item__content__title span {
  background-color: #004271;
}

#zenshin.plan__tab-content .c-plan-item__wrapper:first-of-type .c-plan-item__content__title {
  flex-direction: column;
  width: fit-content;
  line-height: 1.2;
}

#zenshin.plan__tab-content .c-plan-item__wrapper:first-of-type .c-plan-item__content__title small {
  font-size: 1.4rem;
  align-self: flex-end;
  letter-spacing: 0rem;
}

.c-plan-item__cta {
  /* plan item cta styles */
  display: block;
  position: relative;
  padding: 1rem;
  margin-top: 1.5rem;
  border-radius: 10rem;
  text-align: center;
  color: #fff;
  font-size: 2rem;
  font-weight: 300;
  background: linear-gradient(305deg, #222A37 -0.44%, #286792 90.45%);
}

.c-plan-item__cta::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 1.5rem;
  transform: translate(-50%, -50%);
  height: 1.6rem;
  aspect-ratio: 1 / 2;
  background-color: #fff;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.c-plan-item__anotation {
  font-size: 1rem;
  padding-top: 0.2rem;
  font-weight: var(--font-weight-annotation);
  color: #fff;
}

.plan__qanda {
  /* plan qanda section styles */
  margin-top: -1px;
  background-color: #222A37;
  padding: 0 2.4rem 12rem;
}

.plan__qanda__wrapper {
  /* plan qanda wrapper styles */
  background: #fff;
}

.plan__qanda__header {
  /* plan qanda header styles */
  display: flex;
  justify-content: center;
  align-items: center;
  background-image: url(/lp/asset/image/2025_hige_reconstruct/plan/bg_plan_qanda.webp);
  background-size: cover;
  padding: 1.8rem;
  gap: 0.8rem;
}

.plan__qanda__header__img {
  /* plan qanda header image styles */
  flex: 0;
  width: 3rem;
}

.plan__qanda__header__txt {
  /* plan qanda header text styles */
  color: #fff;
  font-size: 2.4rem;
  letter-spacing: 0.2rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.plan__qanda__content {
  /* plan qanda content styles */
  padding: 1.8rem 2.4rem;
  display: flex;
  flex-direction: column;
  gap: 1.8rem;
}

.plan__qanda__content__subtitle {
  /* plan qanda content subtitle styles */
  text-align: center;
  font-size: 2.4rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  line-height: 0.9;
}

.plan__qanda__content__subtitle small {
  /* plan qanda content subtitle styles */
  font-size: 1.5rem;
}

.plan__qanda__content__txt {
  /* plan qanda content text styles */
  font-size: 1.6rem;
  font-weight: 300;
}

.plan__qanda__content__txt small {
  /* plan qanda content text styles */
  font-size: 1.2rem;
  line-height: 2
}

/* gakusei section */

.gakusei {
  margin-top: -9rem;
  z-index: 2;
  position: relative;
}

.gakusei__figure-area {
  position: relative;
  z-index: 1;
  margin-top: -12.4rem;
}

.gakusei__figure-area__acc-btn {
  cursor: pointer;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #5383A3;
  padding: 3rem;
  font-size: 2.6rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  color: #fff;
  letter-spacing: 0.2rem;
}

.gakusei__figure-area__acc-btn::after {
  content: "＋";
  position: absolute;
  top: 50%;
  right: 2rem;
  transform: translateY(-50%);
  font-weight: 300;
  font-size: 3.5rem;
}

.gakusei__figure-area__acc-btn.active::after {
  content: "ー"
}

.gakusei__figure-area__acc-body {
  background-color: #5383A3;
  padding: 2rem 2.4rem;
  display: none;
}

.gakusei__figure-area__acc-btn.active+.gakusei__figure-area__acc-body {
  display: block;
}

.gakusei__figure-area__acc-body__price-image {
  padding: 0 0 2rem;
}

.gakusei__figure-area__acc-body__figure {
  width: 100%;
  table-layout: fixed;
}

.gakusei__figure-area__acc-body__figure {
  width: 100%;
  table-layout: fixed;
  border-collapse: separate;
  border-spacing: 2px;
}

.gakusei__figure-area__acc-body__figure th,
.gakusei__figure-area__acc-body__figure td {
  background-color: #222A37;
  color: #fff;
  font-size: 1.2rem;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
  letter-spacing: 0.1rem;
  text-align: center;
  padding: 0.2rem;
  width: 25%;
  height: 6rem;
  box-sizing: border-box;
  vertical-align: middle;
  letter-spacing: normal;
  line-height: 1.2;
}

.gakusei__figure-area__acc-body__figure thead th:first-child {
  background-color: transparent;
}

.gakusei__figure-area__acc-body__figure tbody td {
  background-color: transparent;
  color: #222A37;
  font-weight: 400;
}

.gakusei__figure-area__acc-body__figure tbody td:nth-child(1) {
  background-color: transparent;
}

.gakusei__figure-area__acc-body__figure tbody td:nth-child(2) {
  background-color: #fff;
}

.gakusei__figure-area__acc-body__figure tbody td:nth-child(3) {
  background-color: #D4E8F7;
}

.gakusei__figure-area__acc-body__figure tbody td:nth-child(4) {
  background-color: #E8D8BE;
}

.flow {
  position: relative;
}

.flow__ttl-img {
  position: absolute;
  width: 47.5rem;
  top: 4.4rem;
}

/* intro section */
.introSec01 {
  background: linear-gradient(to bottom, #222A37, #F2F2F2);
}

.introSec01__start {
  padding-bottom: 10%;
  background: url(/lp/asset/image/intro_sec01_start_bg.webp), #FFFFFF center /cover;
}

.introSec01__start .cvBtn {
  margin-top: 4%;
}

.introSec04 {
  position: relative;
  background: #222A37;
  margin-top: -3rem;
}

.introSec04__parts {
  margin-bottom: -2px;
}

.introSec04Point {
  position: absolute;
  text-align: center;
  width: 100%;
  top: 28.5%;
  font-size: 2.1rem;
  font-weight: 500;
  color: #292929;
}

.introSec04PointStrong {
  font-size: 3.8rem;
}

.introSec04 .splide {
  position: absolute;
  transform: translateX(-50%);
  top: 44.5%;
  left: 50%;
  width: 84.7%;
  z-index: 2;
}

.introSec03 .splide__track,
.introSec04 .splide__track {
  padding-left: 10.35% !important;
  padding-right: 10.35% !important;
}

/* aboutMachine section */
.aboutMachine {
  background: #fff;
}

.aboutMachine__content {
  position: relative;
}

.aboutMachine__gif {
  position: absolute;
  top: 15%;
  width: 89.3%;
  height: min(44.2vw, 332px);
  left: 5.3%;
  -o-object-fit: cover;
  object-fit: cover;
}

/* feature section */
.featureSec01 {
  position: relative;
  background: url(lp/asset/image/feature_sec_bg.webp);
}

.featureSec01__head {
  background: #5C5C5C;
}

.featureSec01__ttl {
  padding: 1% 5% 0% 5%;
}

.featureSec01__content {
  position: relative;
}

.featureSec01__subttl {
  padding: 7.42% 11.42% 0 11.42%;
}

.featureSec01__point {
  padding: 4% 4% 10% 4%;
}

.featureSec01__pointItem {
  margin-block: 1.5%;
}

.featureSec01__mudage {
  position: absolute;
  width: 17.5%;
  top: 7.8%;
  right: 2.5rem;
  z-index: 4;
}

.featureSec02 {
  position: relative;
  background: url(/lp/asset/image/feature_sec_bg.webp);
}

.featureSec02__head {
  background: #5C5C5C;
}

.featureSec02__ttl {
  padding: 1% 5% 0% 5%;
}

.featureSec02__txt {
  padding: 4% 4% 6%;
}

.featureSec02__table {
  padding: 9% 2% 0;
}

.featureSec02__point {
  position: relative;
  margin-top: -1%;
}

.featureSec02__pointTxt {
  position: absolute;
  bottom: 39%;
  right: 4%;
  width: 72%;
}

.featureSec03 {
  position: relative;
  margin-top: -9%;
}

.featureSec03__all {
  margin-bottom: 1.6%;
}

.featureSec03__ttl {
  position: absolute;
  top: 6.5%;
  left: 0;
  width: 100%;
  margin-top: 2%;
}

.featureSec04 {
  position: relative;
  background: #FFF;
}

.planSec01 {
  position: relative;
}

.planSec01__head {
  margin-bottom: -15%;
  margin-top: -1%;
  position: relative;
  overflow: hidden;
  z-index: 0;
}

.planSec01__headTtl {
  position: absolute;
  content: "";
  top: 9%;
  left: 2%;
  width: 52.5%;
}

.planArea {
  margin-bottom: -1%;
  position: relative;
  z-index: 5;
}

.payBlock {
  padding-bottom: 7%;
}

.payBlock__head {
  width: 89.3%;
  margin: 0 auto;
}

.planSec02 {
  position: relative;
  z-index: 6;
}

.planSec02__head {
  width: 100%;
}

.planSec02__student {
  margin-top: -15%
}

.planSec02__student-menu {
  display: block;
  padding: 5% 2.5% 7%;
  background: #838383;
  z-index: 10;
  position: relative;
}

.planSec02__student-menu-clinic {
  margin-bottom: 0.5em;
  font-size: 2rem;
  color: #fff;
}

.planSec02__student-menu-clinic-atn {
  text-align: right;
  display: block;
}

/* flow section */
.flow {
  position: relative;
}

.flow__ttl {
  position: absolute;
  top: 5%;
  left: 0;
}

.flow .splide {
  position: absolute;
  top: 26%;
}

.flow .splide__slideImg {
  display: block;
  width: 42rem !important;
}

.flow.flow__afi .splide {
  top: 36%;
}

.flow--yahoo {
  padding-block: 0 21%;
}

.flow--yahoo__img {
  background: #838383;
}

.flow--medical {
  background: transparent;
  padding: 0;
  z-index: 0;
  position: relative;
}

.flow--medical_yahoo {
  margin-top: -15%;
}

.flow--medical_list {
  position: absolute;
  bottom: 48%;
  width: 85%;
  left: 50%;
  transform: translateX(-50%);
}

.flow--medical_list_yahoo {
  bottom: 43%;
}

.flow--medical .splide__track {
  padding-left: 0px !important;
}

.flow--medical_arrow {
  width: 34%;
  float: right;
  padding-top: 2%;
}

.flow--medical .splide__pagination {
  bottom: -3.5em;
  width: 34%;
}

/* faq section */
.faq {
  background: #FFF;
}

/* attention section */
.attention {
  margin-bottom: -1px;
  font-size: 1.7rem;
  color: #fff;
  background: #222A37;
}

.attention p,
.attention li {
  font-weight: 300;
}

.attention__inner {
  margin: 0 auto;
  width: 89.4%;
}

.attention__head,
.attention__txt,
.attention__list {}

.attention__head {
  text-align: center;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.attention__subhead {
  margin-block: 1.1em 0.5em;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.attention__subhead:first-of-type {
  margin-top: 1.3em;
}

.attention__txt small {
  display: block;
  font-size: 1.4rem;
}

.attention__txt small:first-of-type {
  margin-top: 2.5em;
}

.attention .cvBtn {
  margin-top: 15%;
}

@media (max-width: 750px) {
  .attention .cvBtn {
    display: none;
  }
}

/* clinic section */
.clinic {
  margin-bottom: -1px;
  position: relative;
  z-index: 1;
}

.clinicAcd__stateName {
  position: relative;
  text-align: center;
  font-size: 2.5rem;
  line-height: 3.6em;
  color: #fff;
  border-bottom: 1px solid #fff;
  background: #222A37;
  cursor: pointer;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.clinicAcd__stateName::before,
.clinicAcd__stateName::after {
  position: absolute;
  top: 50%;
  right: 1.2em;
  content: "";
  display: inline-block;
  width: 0.8em;
  height: 0.085em;
  background: #fff;
}

.clinicAcd__stateName::before {
  transform: rotate(90deg) translate(-5%, 240%);
  transition: 0.3s;
}

.clinicAcd__stateName::after {
  transform: translate(-0.23em, -50%);
}

.clinicAcd__stateName.active::before {
  transform: rotate(0) translate(-28%, 0);
  opacity: 0;
}

.clinicAcd__clinicContainer {
  height: 0;
  overflow: hidden;
  transition: 0.25s;
}

.clinicAcd__clinicList {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.5%;
  padding: 7% 5.3% 4%;
  background: #f5f5f5;
}

.clinicAcd__clinicListItem {
  flex-shrink: 0;
  width: 48.5%;
}

.clinicAcd__clinicListName {
  margin-bottom: 5.5%;
  padding-block: 5%;
  width: 100.5%;
  text-align: center;
  font-size: 2.3rem;
  color: #222A37;
  background: transparent;
  border: 2px solid #222A37;
  transition: 0.2s;
  cursor: pointer;
  font-weight: 600;
  font-family: var(--ff-koburina-w6);
}

.clinicAcd__clinicListName small {
  display: block;
  font-size: 0.6em;
  font-weight: lighter;
  letter-spacing: 0.05em;
  color: #222A37;
}

.clinicAcd__clinicListName.active {
  color: #fff;
  background: #286792;
  border: 2px solid #286792;
}

.clinicAcd__clinicListName.active small {
  color: #fff;
}

.clinicAcd__clinicListItem.kokura .clinicAcd__clinicListName.active {
  margin-bottom: 15.5%;
}

.clinicAcd__clinicListItem.ikebukuro-higashiguchi .clinicAcd__clinicListName.active {
  margin-bottom: 15.5%;
}

.clinicAcd__clinicInfo {
  width: 44.8rem;
  height: 0;
  overflow-y: hidden;
}

.clinicAcd__clinicInfoInner {
  margin-bottom: 6%;
  padding: 2% 5% 7%;
  border: 2px solid #286792;
  background: #fff;
}

.clinicAcd__clinicInfoLabel {
  margin-bottom: 2%;
  display: flex;
  align-items: stretch;
  gap: 1.6em;
}

.clinicAcd__clinicInfoLabel.no01 {
  margin-top: 4%;
}

.clinicAcd__clinicNotice {
  margin-top: 5.4%;
  padding: 3rem;
  border: 2px solid #1d81f9;
}

.clinicAcd__clinicNoticeInner {
  color: #2A648D;
  font-size: 2rem;
  text-align: center;
  font-family: var(--ff-koburina-w6);
  font-weight: 600;
}

.clinicAcd__clinicNoticeDetail {
  margin-top: 3rem;
  font-size: 1.8rem;
  color: #222A37;
  text-align: left;
}

.clinicAcd__clinicInfoSummay {
  flex-shrink: 0;
  display: grid;
  place-items: center;
  width: 23.9%;
  min-height: 2.8em;
  text-align: center;
  font-size: 1.8rem;
  font-weight: bold;
  background: #EBDDC3;
  color: #222A37;
}

.clinicAcd__clinicInfoDetail {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  font-weight: 300;
  font-size: 1.9rem;
  color: #292929;
}

.clinicAcd__clinicInfoCv {
  position: relative;
  display: block;
  margin-block: 1.2em;
  width: 100%;
  text-align: center;
  font-size: 2.1rem;
  line-height: 2.8em;
  border-radius: 2em;
  color: #fff;
  background: linear-gradient(to right, #286792, #222A37);
  z-index: 1;
}

.clinicAcd__clinicInfoNotice {
  text-align: center;
  display: block;
  margin-top: -10px;
  margin-bottom: 2rem;
  font-size: 2rem;
}

.clinicAcd__clinicInfoMap {
  margin-bottom: 4.5%;
  aspect-ratio: 2/1;
}

.clinicAcd__doctorInfo {
  padding-inline: 3.3%;
}

.clinicAcd__doctorName {
  display: flex;
  align-items: end;
  margin-bottom: 2.3em;
}

.clinicAcd__doctorName span {
  flex-shrink: 0;
  margin-right: 1.7em;
  font-size: 2.2rem;
  line-height: 2.2em;
}

.clinicAcd__doctorName img {
  flex-shrink: 0;
  width: 70%;
  pointer-events: none;
}

.clinicAcd__doctorHistory dl {
  display: flex;
  gap: 0.5em;
  font-weight: 300;
  font-size: 1.6rem;
  color: #000;
}

.clinicAcd__doctorHistory dt {
  white-space: nowrap;
}

.clinicAcd__doctorHistory dd {
  letter-spacing: 0.02em;
}

.line__bnr {
  margin-inline: auto;
  width: 46rem;
  margin-bottom: 10%;
}

.clinic__president {
  padding-block: 7% 11%;
  background: #222A37;
}

.clinic__presidentSubttl {
  display: block;
  text-align: center;
  font-size: 2.4rem;
  line-height: 2.6em;
  background: #D9D9D9;
}

.clinic__presidentInner {
  margin-inline: auto;
  margin: 0 2.3rem;
  background: #fff;
  overflow: hidden;
}

.clinic__presidentInfo {
  margin: 5% auto;
  width: 80%;
}

.clinic__presidentName {
  display: flex;
  align-items: end;
  gap: 2em;
  margin-bottom: 1em;
  font-size: 2.3rem;
}

.clinic__presidentName span {
  line-height: 2.2em;
  white-space: nowrap;
}

.clinic__presidentName img {
  width: 55%;
}

.clinic__presidentCareer {
  display: flex;
  gap: 0.5em;
  font-size: 1.6rem;
}

.clinic__presidentCareer dt {
  white-space: nowrap;
}

.clinicAcd__clinicList .clinicAcd__clinicListItem:nth-child(2n) .clinicAcd__clinicInfo {
  transform: translateX(-51.4%);
}




/* JavaScript animation classes */
.js_fadein__left {
  transition: 0.6s 0.125s;
}

.js_fadein__left.inactive {
  opacity: 0;
  transform: translateX(-5%);
}

.js_fadein__right {
  transition: 0.6s 0.125s;
}

.js_fadein__right.inactive {
  opacity: 0;
  transform: translateX(5%);
}

.js_fadein__bottom {
  transition: 0.6s 0.125s;
}

.js_fadein__bottom.inactive {
  opacity: 0;
  transform: translateY(5%);
}

.js_marker {
  font-size: 6.1rem;
  background: -webkit-linear-gradient(bottom, rgb(192, 240, 255) 50%, transparent 50%);
  display: inline;
  background: linear-gradient(bottom, rgb(192, 240, 255) 50%, transparent 50%);
  background-repeat: no-repeat;
  background-size: 0% 100%;
  transition: background-size 1s ease-in-out;
  margin-left: 17%;
}

.js_marker.is-active {
  background-size: 100% 100%;
}

.js_balloon.is-active {
  -webkit-animation: balloon 0.7s linear;
  animation: balloon 0.7s linear;
}

@-webkit-keyframes balloon {

  0%,
  40%,
  100% {
    transform: scale(1);
  }

  50%,
  90% {
    transform: scale(1.3);
  }
}

@keyframes balloon {

  0%,
  40%,
  100% {
    transform: scale(1);
  }

  50%,
  90% {
    transform: scale(1.3);
  }
}

.js_swaying.is-active {
  -webkit-animation: swaying 2s ease-in-out;
  animation: swaying 2s ease-in-out;
}

@-webkit-keyframes swaying {
  0% {
    transform: rotate(5deg);
  }

  50% {
    transform: rotate(-5deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

@keyframes swaying {
  0% {
    transform: rotate(5deg);
  }

  50% {
    transform: rotate(-5deg);
  }

  100% {
    transform: rotate(0deg);
  }
}

.js_shine {
  position: relative;
  overflow: hidden;
  opacity: 1;
}

.js_shine::before {
  transition: cubic-bezier(0.32, 0, 0.67, 0);
  opacity: 0;
  background-color: #fff;
  content: "";
  position: absolute;
  display: block;
  bottom: 0;
  width: 30px;
  height: 100%;
}

.js_shine.is-active::before {
  -webkit-animation: shine 0.5s linear;
  animation: shine 0.5s linear;
}

@-webkit-keyframes shine {
  0% {
    transform: scale(2) rotate(45deg);
    opacity: 0;
  }

  20% {
    transform: scale(20) rotate(45deg);
    opacity: 0.6;
  }

  40% {
    transform: scale(30) rotate(45deg);
    opacity: 0.4;
  }

  80% {
    transform: scale(45) rotate(45deg);
    opacity: 0.2;
  }

  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

@keyframes shine {
  0% {
    transform: scale(2) rotate(45deg);
    opacity: 0;
  }

  20% {
    transform: scale(20) rotate(45deg);
    opacity: 0.6;
  }

  40% {
    transform: scale(30) rotate(45deg);
    opacity: 0.4;
  }

  80% {
    transform: scale(45) rotate(45deg);
    opacity: 0.2;
  }

  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}

.js_slideinLeft {
  opacity: 0;
}

.js_slideinLeft.is-active {
  -webkit-animation: slideinLeft 0.4s;
  animation: slideinLeft 0.4s;
  transform: translateX(0) translateY(0);
  opacity: 1;
}

@-webkit-keyframes slideinLeft {
  0% {
    transform: translateX(-250px) translateY(50px);
  }

  100% {
    transform: translateX(0) translateY(0);
  }
}

@keyframes slideinLeft {
  0% {
    transform: translateX(-250px) translateY(50px);
  }

  100% {
    transform: translateX(0) translateY(0);
  }
}

.js_jump.is-active {
  -webkit-animation-name: jump;
  animation-name: jump;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
}

@-webkit-keyframes jump {
  0% {
    transform: translate(0%, 5%) rotateY(20deg);
  }

  40% {
    transform: translate(0%, 0%);
  }

  60% {
    transform: translate(0%, 5%) rotateY(20deg);
  }

  100% {
    transform: translate(0%, 0%);
  }
}

@keyframes jump {
  0% {
    transform: translate(0%, 5%) rotateY(20deg);
  }

  40% {
    transform: translate(0%, 0%);
  }

  60% {
    transform: translate(0%, 5%) rotateY(20deg);
  }

  100% {
    transform: translate(0%, 0%);
  }
}

/* Splide slider styles */
.splide__track {
  padding-left: 7.35% !important;
}

.splide__slide {
  flex-shrink: 0;
}

.splide__slide.is-next,
.splide__slide.is-prev {
  -webkit-filter: brightness(0.7);
  filter: brightness(0.7);
}

.splide__slideImg {
  display: block;
  width: 40rem !important;
}

.splide__arrows {
  display: none;
}

.splide__pagination {
  bottom: -5.5%;
  gap: 4%;
}

.flow .splide__pagination {
  bottom: -9.5%;
  gap: 2.5%;
}

.splide__pagination__page {
  margin: 0 0.2em;
  width: 1.2rem;
  height: 1.2rem;
  background: #D5CFCF;
}

.splide__pagination__page.is-active {
  background: #000000;
  transform: unset;
}

.footer {
  margin-bottom: -15px;
  padding-block: 3rem 6rem;
  text-align: center;
  font-size: 1.6rem;
  background: #222A37;
}

.line .footer {
  padding-block: 3rem 16rem;
}

@media (max-width: 750px) {
  .footer {
    padding-block: 3em 9.5em;
  }
}

.footer__link {
  display: block;
  margin-bottom: 1em;
  color: #fff;
}

.footer__copy {
  display: block;
  line-height: 3em;
  color: #333;
  background: #D9D9D9;
}

.medical_body .footer {
  padding-block: 3em 0;
}