<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,100..900;1,100..900&amp;family=Noto+Sans+JP:wght@100..900&amp;family=Zen+Old+Mincho:wght@400;500;600;700;900&amp;display=swap");
/* ===============================================
#変数
=============================================== */
:root {
  --color-black: #333;
  --color-gray: #585858;
  --color-blue: #4b59a6;
  --color-light-blue: rgba(227, 230, 244, 0.8);
  --text-underline: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 70%, rgba(255, 245, 155, 0.5) 70%, rgba(255, 245, 155, 0.5) 100%);
  --font-family-common: "Noto Sans JP", sans-serif;
  --font-family-mincho: "Zen Old Mincho", serif;
  --font-family-en: "Montserrat", serif;
  --font-family-din: "DIN Alternate", "Montserrat", sans-serif;
  --side-space: 20px;
  --duration: 0.3s;
}
/* ===============================================
#base
=============================================== */
html {
  font-size: 62.5%;
}

body {
  background-color: #fff;
  font-family: var(--font-family-common);
  line-height: normal;
  color: var(--color-black);
  font-size: 1.6rem;
  font-weight: 400;
}

.l-container {
  overflow-x: clip;
}

img {
  width: 100%;
  height: auto;
  object-fit: cover;
}

a {
  display: inline-block;
  transition: opacity 0.3s;

  &amp;:hover {
    opacity: 0.7;
  }
}
/* ===============================================
#共通クラス
=============================================== */
.text-center {
  text-align: center;
}

.lead {
  line-height: 1.93;
  letter-spacing: 0.04em;
  text-align: center;

  p {
    &amp;:not(:first-child) {
      margin-top: 1.93em;
    }

    b {
      font-size: 1.8rem;
      color: var(--color-blue);
      font-weight: 700;
      background: var(--text-underline);
    }
  }

  &amp;.text-left {
    text-align: left;
  }

  @media (width &lt;= 767px) {
    text-align: left;

    &amp;.sp-center {
      text-align: center;
    }
  }
}

.main {
  @media (width &lt;= 1023px) {
    margin-top: 42px;
  }
}

.error {
  height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

.error__text {
  text-align: center;
  font-size: 2.4rem;
}
/* ===============================================
#デバイス非表示
=============================================== */
.sp {
  @media (width &gt;= 768px) {
    display: none;
  }
}

.pc {
  @media (width &lt;= 1023px) {
    display: none;
  }
}

.tb_sp {
  @media (width &gt;= 1024px) {
    display: none;
  }
}

.pc_tb {
  @media (width &lt;= 767px) {
    display: none;
  }
}
/* ===============================================
#inner
=============================================== */
.inner {
  margin-inline: auto;
  padding-inline: var(--side-space);
  position: relative;

  &amp;.max-730 {
    max-width: calc(730px + (var(--side-space) * 2));
  }

  &amp;.max-760 {
    max-width: calc(760px + (var(--side-space) * 2));
  }

  &amp;.max-826 {
    max-width: calc(826px + (var(--side-space) * 2));
  }

  &amp;.max-900 {
    max-width: calc(900px + (var(--side-space) * 2));
  }

  &amp;.max-1000 {
    max-width: calc(1000px + (var(--side-space) * 2));
  }

  &amp;.max-1200 {
    max-width: calc(1200px + (var(--side-space) * 2));
  }

  &amp;.max-1260 {
    max-width: calc(1260px + (var(--side-space) * 2));
  }

  &amp;.max-1300 {
    max-width: calc(1300px + (var(--side-space) * 2));
  }

  &amp;.max-1360 {
    max-width: calc(1360px + (var(--side-space) * 2));
  }

  @media (width &lt;= 767px) {
    padding-inline: 16px;
  }
}

.max-500 {
  margin-inline: auto;
  max-width: 500px;
}

.max-536 {
  margin-inline: auto;
  max-width: 536px;
}

.max-714 {
  margin-inline: auto;
  max-width: 714px;
}

.max-760 {
  margin-inline: auto;
  max-width: 760px;
}

.max-800 {
  margin-inline: auto;
  max-width: 800px;
}

.max-900 {
  margin-inline: auto;
  max-width: 900px;
}

.max-1000 {
  margin-inline: auto;
  max-width: 1000px;
}

.min-h-1000 {
  @media (1024px &lt;= width) {
    min-height: 1040px;
  }
}

/* ===============================================
#共通ボタン
=============================================== */
.c-btn__common {
  padding: 13px 50px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 1px;
  align-items: center;
  background: var(--color-blue);
  color: #fff;
  box-shadow: 11px 11px 0 0px #d7daef;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  transition: transform var(--duration), box-shadow var(--duration);

  @media (width &gt;= 768px) {
    &amp;:hover {
      transform: translate(11px, 11px);
      box-shadow: 0 0 0 0 #d7daef;
    }
  }

  @media (width &lt;= 767px) {
    padding: 13px 30px;
  }
}

.c-btn__common-top {
  font-size: 1.3rem;
  line-height: 1.38;
  letter-spacing: 0.1em;

  b {
    font-family: var(--font-family-din);
    font-weight: 700;
  }
}

.c-btn__common-bottom {
  font-size: 2.4rem;
  font-weight: 300;
}

.c-btn__arrow {
  background: #fff;
  padding: 23px 50px;
  font-size: 1.8rem;
  line-height: 1.72;
  letter-spacing: 0.04em;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 300px;
  margin-inline: auto;
  box-shadow: 14px 14px 0 0px #c3c7da;
  border: 1px solid #c3c7da;
  transition: transform var(--duration), box-shadow var(--duration);

  &amp;::after {
    content: "";
    width: 13px;
    height: 19px;
    background-color: var(--color-blue);
    display: block;
    -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
    clip-path: polygon(0 0, 0% 100%, 100% 50%);
  }

  &amp;.left {
    margin-left: 0;
  }

  @media (width &gt;= 768px) {
    &amp;:hover {
      transform: translate(14px, 14px);
      box-shadow: 0 0 0 0 #c3c7da;
    }
  }

  @media (width &lt;= 767px) {
    padding: 14px 50px;
    box-shadow: 5px 5px 0 0px #c3c7da;
  }
}

.c-btn__tel {
  border: 1px solid var(--color-blue);
  color: var(--color-blue);
  background: #fff;
  height: 77px;
  padding: 9px 20px;
  max-width: 352px;
  width: 100%;
  margin-inline: auto;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
  box-shadow: 11px 11px 0 0px #d7daef;
  transition: transform var(--duration), box-shadow var(--duration);

  @media (width &gt;= 768px) {
    &amp;:hover {
      transform: translate(11px, 11px);
      box-shadow: 0 0 0 0 #c3c7da;
    }
  }

  @media (width &lt;= 767px) {
    box-shadow: 7px 7px 0 0px #d7daef;
  }
}

.c-btn__tel-icon {
  width: 25px;
}

.c-btn__tel-text-box {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 6px;
}

.c-btn__tel-top-text {
  font-size: 1.3rem;
  line-height: 1.3;
}

.c-btn__tel-bottom-text {
  font-size: 2.4rem;
  font-family: var(--font-family-din);
  font-weight: 700;
}

/* ===============================================
#共通見出し
=============================================== */
.c-heading__h2 {
  display: flex;
  flex-direction: column;
  gap: 4px;
  align-items: center;
  text-align: center;
}

.c-heading__h2-en {
  color: var(--color-blue);
  font-family: var(--font-family-din);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
}

.c-heading__h2-ja {
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;

  b {
    color: var(--color-blue);
    font-size: 3.6rem;
    font-weight: 700;
  }

  @media (width &lt;= 767px) {
    font-size: 2.6rem;

    b {
      color: var(--color-blue);
      font-size: 2.6rem;
      font-weight: 700;
    }
  }
}

/* ===============================================
#背景
=============================================== */
.bg__stitch-1 {
  background-image: linear-gradient(0deg, transparent 58px, #e2e5f9 60px), linear-gradient(90deg, transparent 58px, #e2e5f9 60px);
  background-color: rgba(227, 230, 244, 0.8);
  background-size: 60px 60px;
}

.bg__stitch-2 {
  background-image: linear-gradient(0deg, transparent 58px, #fff 60px), linear-gradient(90deg, transparent 58px, #fff 60px);
  background-color: rgba(227, 230, 244, 0.8);
  background-size: 60px 60px;
}

.bg__stitch-3 {
  background-image: linear-gradient(0deg, transparent 58px, #e2e5f9 60px), linear-gradient(90deg, transparent 58px, #e2e5f9 60px);
  background-color: rgba(227, 230, 244, 0.4);
  background-size: 60px 60px;
}

.bg__oblique-line {
  background: rgba(227, 230, 244, 0.4) url(./../image/about-bg_2.webp) repeat top center / contain;
}

.bg__pattern-1 {
  background: transparent url(./../image/cure-bg_1.webp) no-repeat center center / cover;
}

.bg__color-blue {
  background-color: var(--color-light-blue);
}

.bg__color-blue-2 {
  background-color: #f4f5fb;
}

.bg__color-beige {
  background-color: #fff7e9;
}

/* ===============================================
#余白
=============================================== */
.sec-pd {
  padding-block: 80px !important;

  @media (width &lt;= 767px) {
    padding-block: 40px !important;
  }
}

.mt-0 {
  margin-top: 0 !important;
}

.mt-10 {
  margin-top: 10px !important;
}

.mt-30 {
  margin-top: 30px !important;
}

.mt-40 {
  margin-top: 40px !important;

  @media (width &lt;= 767px) {
    margin-top: 20px !important;
  }
}

.mt-50 {
  margin-top: 50px !important;

  @media (width &lt;= 767px) {
    margin-top: 30px !important;
  }
}

.mt-60 {
  margin-top: 60px !important;

  @media (width &lt;= 767px) {
    margin-top: 40px !important;
  }
}

.mt-70 {
  margin-top: 70px !important;

  @media (width &lt;= 767px) {
    margin-top: 40px !important;
  }
}

.mt-80 {
  margin-top: 80px !important;

  @media (width &lt;= 767px) {
    margin-top: 40px !important;
  }
}

/* ===============================================
#header
=============================================== */
.header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-left: 27px;

  @media (width &lt;= 1023px) {
    padding-left: 0;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
    background: #fff;
  }
}

.header__left-box {
  display: flex;
  align-items: center;
  gap: 26px;
}

.header__logo-link {
  max-width: 412px;
  position: relative;

  &amp;::before {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: -13px;
    width: 1px;
    height: 100%;
    background-color: #8b8b8b;
    pointer-events: none;
  }

  @media (width &lt;= 1100px) {
    max-width: 350px;
  }

  @media (width &lt;= 1023px) {
    max-width: 250px;

    &amp;::before {
      display: none;
    }
  }

  @media (width &lt;= 767px) {
    max-width: 197px;
  }
}

.header__access {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  white-space: nowrap;

  @media (width &lt;= 1023px) {
    display: none;
  }
}

.header__access-top-text {
  font-size: 12px;
  color: #8b8b8b;

  b {
    line-height: 1.33;
    letter-spacing: 0.1em;
    font-weight: 700;
    font-family: var(--font-family-din);
  }
}

.header__access-bottom-text {
  color: #fff;
  font-size: 1.2rem;
  background-color: var(--color-blue);
  padding: 1px 4px;

  b {
    font-weight: 700;
    font-family: var(--font-family-din);
    letter-spacing: 0.1em;
  }
}

.header__center-box {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  align-items: center;
  gap: 16px;
  margin-left: 44px;
  margin-right: auto;

  @media (width &lt;= 1420px) {
    display: none;
  }
}

.header__time {
  background-color: var(--color-light-blue);
  color: var(--color-blue);
  font-size: 1.2rem;
  padding: 5px;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  letter-spacing: 0.1em;
}

.header__week-lists {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.header__week-list {
  display: flex;
  align-items: center;
  gap: 9px;
  white-space: nowrap;
}

.header__week {
  width: 36px;
  font-size: 1.2rem;
  letter-spacing: 0.1em;
  color: var(--color-blue);
}

.header__week-time {
  font-size: 1.3rem;
  font-family: var(--font-family-din);
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
  color: var(--color-gray);
}

.header__holiday {
  background-color: var(--color-light-blue);
  border-radius: 50%;
  width: 63px;
  height: 63px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  line-height: 1.33;

  letter-spacing: 0.1em;

  b {
    color: var(--color-blue);
    font-weight: 500;
  }
}

.header__right-box {
  display: flex;

  @media (width &lt;= 1023px) {
    display: none;
  }
}

.header__contact-btn {
  width: 200px;
  height: 92px;
  background: var(--color-blue);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 30px;
  color: #fff;
  border-radius: 0px 0px 0px 8px;

  @media (width &lt;= 1023px) {
    width: 100%;
    border-radius: 0;
  }

  @media (width &lt;= 767px) {
    height: 72px;
    gap: 0;
  }
}

.header__contact-top-text {
  font-size: 1.3rem;
  line-height: 1.3;
  letter-spacing: 0.1em;

  b {
    font-family: var(--font-family-din);
    font-weight: 700;
  }
}

.header__contact-bottom-text {
  font-size: 2.4rem;
  font-weight: 300;
  line-height: 1.3;
}

.header__tel-btn {
  border: 1px solid var(--color-blue);
  color: var(--color-blue);
  background: #fff;
  height: 92px;
  padding: 9px 30px 9px 20px;
  display: flex;
  align-items: center;
  gap: 10px;

  @media (width &lt;= 1023px) {
    width: 100%;
    justify-content: center;
  }

  @media (width &lt;= 767px) {
    height: 72px;
    gap: 18px;
  }
}

.header__tel-icon {
  width: 25px;
}

.header__tel-text-box {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 6px;
}

.header__tel-top-text {
  font-size: 1.3rem;
  line-height: 1.3;
}

.header__tel-bottom-text {
  font-size: 2.4rem;
  font-family: var(--font-family-din);
  font-weight: 700;
}

.header__hamburger {
  display: none;

  @media (width &lt;= 1023px) {
    display: flex;
    box-shadow: 0px 0px 34px 0px rgba(0, 0, 0, 0.04);
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 7px;
    width: 48px;
    height: 42px;
    background: var(--color-blue);

    span {
      width: 15px;
      height: 1px;
      background-color: #fff;
    }
  }

  @media (width &lt;= 767px) {
    width: 48px;

    span {
      width: 18px;
    }
  }
}

/* ===============================================
#mv
=============================================== */
.mv {
  position: relative;
  margin: 17px 0px 0 27px;
  height: 806px;

  @media (width &lt;= 1023px) {
    margin: 17px 0px 0 0px;
  }

  @media (width &lt;= 767px) {
    margin: 0;
    position: relative;
    height: clamp(460px, 230.416px + 61.22vw, 700px);
  }

  .splide__track,
  .mv__img img {
    height: 100%;
    object-position: top;
  }
}

.mv__inner {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  height: 100%;
}

.mv__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.mv__text-box {
  width: fit-content;
  display: flex;
  flex-direction: row-reverse;
  gap: 26px;
  font-family: var(--font-family-mincho);
  color: #2e2f31;
  white-space: nowrap;

  @media (width &lt;= 767px) {
    gap: 19px;
  }

  p {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
  }
}

.mv__text-right {
  // display: flex;
  // flex-direction: row-reverse;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 6px 22px;
  text-shadow: 5px 4px 9.6px #fff;
  font-size: 5.2rem;
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: 0.11em;
  
  @media (width &lt;= 767px) {
    font-size: 2.5rem;
    grid-template-columns: repeat(1, 1fr);
    // flex-direction: column;
  }
}

.mv__text-right-1 {
  @media (768px &lt;= width) {
    grid-row: 1 / 2;
    grid-column: 2 / 3;
  }
}

.mv__text-right-2 {
  margin-top: 211px;
  
  @media (768px &lt;= width) {
    grid-row: 1 / 2;
    grid-column: 1 / 2;
  }

  @media (width &lt;= 767px) {
    margin-top: 0px;
  }
}

.mv__text-left {
  margin-top: 103px;
  // display: flex;
  // flex-direction: row-reverse;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 42px;

  @media (width &lt;= 767px) {
    margin-top: 35px;
    gap: 18px;
  }
}

.mv__text-left-big {
  font-size: 4.8rem;
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0.2em;
  text-shadow: 5px 4px 9.6px #fff;

  b {
    font-size: 6.6rem;
  }

  strong {
    color: var(--color-blue);
    font-size: 6.6rem;
  }

  @media (width &lt;= 767px) {
    font-size: 2.3rem;
    b,
    strong {
      font-size: 3.1rem;
    }
  }
}

.mv__text-left-small {
  text-shadow: 4px 4px 8px #fff;
  font-size: 2.8rem;
  font-weight: 600;
  line-height: 1.03;
  letter-spacing: 0.1em;

  @media (width &lt;= 767px) {
    font-size: 1.4rem;
  }
}

.mv__figure-box {
  position: absolute;
  bottom: 15px;
  left: 15px;
  display: grid;
  justify-items: center;
  grid-template-columns: repeat(2, 100px);
  grid-template-rows: repeat(2, 100px);
  z-index: 3;

  @media (768px &lt;= width) {
    bottom: 27px;
    grid-template-columns: repeat(2, 206px);
    grid-template-rows: repeat(2, 206px);
  }

  @media (1024px &lt;= width) {
    left: 37px;
  }
}

.mv__figure-item {
  width: 100px;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;

  &amp;:nth-of-type(1) {
    background: transparent url(./../image/top-mv-text-bg_1.webp) no-repeat center center / contain;
    z-index: 3;
    grid-area: 1 / 1 / 2 / 3;
    bottom: -25px;
    left: -5px;
  }
  
  &amp;:nth-of-type(2) {
    background: transparent url(./../image/top-mv-text-bg_3.webp) no-repeat center center / contain;
    z-index: 1;
    grid-area: 2 / 1 / 3 / 2;
  }
  
  &amp;:nth-of-type(3) {
    background: transparent url(./../image/top-mv-text-bg_2.webp) no-repeat center center / contain;
    z-index: 2;
    grid-area: 2 / 2 / 3 / 3;
    left: -10px;
  }
  
  @media (768px &lt;= width) {
    width: 206px;
    height: 206px;
    
    &amp;:nth-of-type(1) {
      bottom: -50px;
      left: -10px;
    }
    
    &amp;:nth-of-type(3) {
      left: -20px;
    }
  }
}

.mv__figure-item-text {
  color: #2e2f31;
  font-size: 1.1rem;
  line-height: 1.2;
  font-weight: 500;
  font-family: var(--font-family-mincho);
  text-align: center;

  b {
    color: var(--color-blue);
    font-weight: 600;
    font-size: 1.6rem;
  }

  strong {
    color: var(--color-blue);
    font-weight: 600;
    font-size: 2.3rem;
  }

  @media (768px &lt;= width) {
    font-size: 2.4rem;

    b {
      font-size: 3.2rem;
    }

    strong {
      font-size: 4.8rem;
    }
  }
}

/* ===============================================
#nav
=============================================== */
.nav {
  padding: 14px 10px;
  margin: 10px 0;
  background-color: #fff;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  left: 0;
  z-index: 101;

  @media (width &lt;= 1023px) {
    opacity: 0;
    visibility: hidden;
    position: fixed;
    width: 100vw;
    height: 100vh;
    overflow-y: scroll;
    transition: all var(--duration);
    padding: 0;
    margin: 0;

    &amp;.active {
      opacity: 1;
      visibility: visible;
    }
  }
}

.nav__lists {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 160px;

  @media (width &lt;= 1300px) {
    gap: 80px;
  }

  @media (width &lt;= 1023px) {
    padding: 93px 47px 32px;
    flex-direction: column;
    gap: 0;
  }
}

.nav__list {
  position: relative;

  &gt; a,
  div {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding-block: 6px;
  }

  &amp;:nth-child(n + 2) {
    &amp;:before {
      content: "";
      width: 1px;
      height: 14px;
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      left: -80px;
      background-color: var(--color-blue);
    }
  }

  @media (width &lt;= 1300px) {
    &amp;:nth-child(n + 2) {
      &amp;:before {
        left: -40px;
      }
    }
  }

  @media (width &lt;= 1023px) {
    width: 100%;

    &gt; a,
    div {
      padding-top: 22px;
      padding-bottom: 22px;
      border-top: 1px solid #c3c7da;
      width: 100%;
      flex-direction: column;
      align-items: flex-start;
      gap: 0;
    }

    &amp;:last-of-type {
      &gt; a,
      div {
        border-bottom: 1px solid #c3c7da;
      }
    }

    &amp;:nth-child(n + 2) {
      &amp;:before {
        display: none;
      }
    }
  }
}

.nav__ja {
  font-size: 2rem;

  line-height: 1.55;
  letter-spacing: 0.04em;

  @media (width &lt;= 1023px) {
    color: var(--color-lightbrown);
  }

  @media (width &lt;= 767px) {
    font-size: 1.6rem;
  }
}

.nav__en {
  color: var(--color-blue);
  font-size: 1.2rem;
  font-family: var(--font-family-en);
  font-weight: 500;
}

.nav__sub-menu {
  @media (width &gt;= 1024px) {
    opacity: 0;
    visibility: hidden;
    position: absolute;
    width: fit-content;
    display: flex;
    flex-wrap: wrap;
    left: 50%;
    top: 100%;
    background: #fff;
    padding: 20px 40px;
    box-shadow: 14px 14px 34px 0px rgba(72, 54, 25, 0.1);
    justify-content: start;
    transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s 0.3s;
    transform: translate(-50%, -10px);
    border-bottom: 1px solid #c3c7da;

    &amp;.show {
      opacity: 1;
      visibility: visible;
      transform: translate(-50%, 0);
      transition: opacity 0.3s ease, transform 0.3s ease, visibility 0s;
    }
  }

  @media (width &lt;= 1023px) {
    padding-left: 20px;
    padding-bottom: 32px;
  }
}

.nav__sub-menu-item {
  width: 100%;
  &gt; a {
    width: 100%;
    display: block;
    line-height: 1.93;
    letter-spacing: 0.04em;
    text-align: left;
    white-space: nowrap;
    border-top: 1px solid #c3c7da;
    padding: 12px 18px 12px 0;
  }

  @media (width &lt;= 1023px) {
    &gt; a {
      border-top: none;
      border-bottom: 1px solid #c3c7da;
      padding: 10px 5px 10px 0;
    }
  }
}

.nav__contact-box {
  display: none;

  @media (width &lt;= 1023px) {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    padding: 0 47px 90px;
  }

  @media (width &lt;= 767px) {
    padding: 0 26px 90px;
  }
}

.nav__hamburger-close {
  display: none;

  @media (width &lt;= 1023px) {
    display: block;
    position: absolute;
    padding: 14px;
    top: 18px;
    right: 20px;
    width: 48px;
    height: 48px;

    span {
      width: 15px;
      height: 1px;
      background-color: var(--color-black);
      top: 50%;
      left: 50%;
      translate: -50% -50%;
      display: block;
      position: absolute;

      &amp;:nth-child(1) {
        rotate: 45deg;
      }

      &amp;:nth-child(2) {
        rotate: -45deg;
      }
    }
  }
}

/* ===============================================
#pickup
=============================================== */
.pickup {
  position: relative;
  padding-top: 50px;
  padding-bottom: 50px;
  background-color: var(--color-blue);

  &amp;::before,
  &amp;::after {
    content: "";
    position: absolute;
    width: 69px;
    height: 69px;
    background-color: #fff;
    z-index: 2;
  }

  &amp;::before {
    top: 20px;
    left: 20px;
    clip-path: polygon(0 0, 0% 100%, 100% 0);
  }

  &amp;::after {
    bottom: 20px;
    right: 20px;
    clip-path: polygon(100% 0, 0% 100%, 100% 100%);
  }

  &amp;.implant-pickup {
    .pickup__img {
      opacity: 1;
    }
  }

  @media (width &lt;= 767px) {
    padding-top: 36px;
    &amp;::before,
    &amp;::after {
      width: 31px;
      height: 31px;
    }

    &amp;::before {
      top: 5px;
      left: 5px;
    }

    &amp;::after {
      bottom: 5px;
      right: 5px;
    }
  }
}

.pickup__img {
  position: absolute;
  right: 0;
  top: 0;
  z-index: 1;
  display: block;
  width: 100%;
  height: 100%;
  opacity: 0.4;
}

.pickup__container {
  position: relative;
  z-index: 2;
}

.pickup__text-box {
  color: #fff;
  text-align: center;
}

.pickup__heading {
  color: #fff;
  font-family: var(--font-family-en);
  font-size: 3.2rem;
  font-weight: 500;
  letter-spacing: 0.1em;
}

.pickup__text {
  color: #eaebf1;
  font-size: 1.2rem;
  margin-top: 2px;
}

.pickup__lists {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 60px;
  margin-top: 30px;

  @media (width &lt;= 1023px) {
    flex-wrap: wrap;
    gap: 0px 12px;
    margin-top: 18px;
  }

  @media (width &lt;= 767px) {
    max-width: 335px;
    margin-inline: auto;
  }
}

.pickup__list {
  width: 238px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  background-color: #fff;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: relative;

  @media (width &lt;= 767px) {
    width: calc(100% / 2 - 12px * 1 / 2);
  }
}

.pickup__number {
  color: var(--color-blue);
  padding-inline: 6px;
  font-size: 2.4rem;
  font-family: var(--font-family-din);
  padding-bottom: 6px;
  border-bottom: 3px solid #c3c7da;

  @media (width &lt;= 767px) {
    font-size: 1.6rem;
    padding-bottom: 4px;
  }
}

.pickup__list-text {
  color: var(--color-gray);
  font-weight: 300;
  margin-top: 16px;
  line-height: 1.3;
  font-size: 2.4rem;
  text-align: center;

  b {
    color: var(--color-black);
    font-size: 3.6rem;
    font-family: var(--font-family-mincho);

    strong {
      font-size: 4.8rem;
      font-weight: 400;
      color: var(--color-blue);

      &amp;.fs-30 {
        font-size: 3rem;
      }
    }
  }

  .underline {
    background: var(--text-underline);
  }

  @media (width &lt;= 767px) {
    font-size: 1.6rem;
    margin-top: 11px;

    b {
      font-size: 2.4rem;

      strong {
        font-size: 3.2rem;
        line-height: 1.12;

        &amp;.fs-30 {
          font-size: 2.2rem;
        }
      }
    }
  }
}

/* ===============================================
#reserve
=============================================== */
.reserve__container {
  max-width: 1200px;
  margin-inline: auto;
  background-color: rgba(227, 230, 244, 0.8);
  padding: 22px 16px;

  @media (768px &lt;= width) {
    padding: 28px 34px;
  }
}

.reserve__text-box {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 22px;
  border: 1px solid #fff;
  padding: 20px 16px;

  @media (768px &lt;= width) {
    padding: 32px 56px;
    gap: 48px;
  }
}

.reserve__img {
  width: 31.2%;
  box-shadow: -25px 25px 0px 0px var(--color-blue);

  @media (width &lt;= 1023px) {
    width: calc(100% - 8px);
    margin-inline: auto;
    box-shadow: 0px 0px 0px 0px var(--color-blue);
  }
}

.reserve__text-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 49px;
}

.reserve__today {
  position: relative;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;

  &amp;::before,
  &amp;::after {
    content: "";
    position: absolute;
    background-color: #d7daef;
    width: 49px;
    height: 43px;
    z-index: 1;
  }

  &amp;::before {
    top: -12px;
    right: -25px;
  }

  &amp;::after {
    bottom: -14px;
    left: -31px;
  }

  @media (width &lt;= 767px) {
    &amp;::before,
    &amp;::after {
      width: 40px;
      height: 36px;
    }

    &amp;::before {
      top: -10px;
      right: -14px;
    }

    &amp;::after {
      bottom: -13px;
      left: -26px;
    }
  }
}

.reserve__today-inner {
  font-size: 2rem;
  background-color: #fff;
  color: var(--color-blue);
  line-height: 1.55;

  letter-spacing: 0.04em;
  padding: 13px 50px;
  position: relative;
  z-index: 2;

  @media (width &lt;= 767px) {
    font-size: 2rem;
    padding: 10px 42px;
  }
}

.reserve__heading {
  font-family: var(--font-family-mincho);
  font-size: 1.8rem;
  text-align: center;

  @media (768px &lt;= width) {
    font-size: 2.8rem;
  }
}

.reserve__lists {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;

  @media (width &lt;= 1023px) {
    align-items: center;
  }
}

.reserve__list {
  background-color: #fff;
  padding: 10px 24px;
  font-size: 1.8rem;
  letter-spacing: 0.04em;
  white-space: nowrap;

  line-height: 1.72;
  color: var(--color-blue);
}

.reserve__text {
  max-width: 800px;
  margin-inline: auto;
  font-size: 14px;

  @media (768px &lt;= width) {
    font-size: 16px;
  }
}

.reserve__btn {
  padding: 23px 50px;
  margin-bottom: 11px;

  @media (768px &lt;= width) {
    padding-block: 23px;
  }
}

/* ===============================================
#about
=============================================== */
.about {
  position: relative;
  margin-bottom: 64px;

  @media (width &lt;= 767px) {
    margin-bottom: 32px;
  }

  &amp;.implant {
    .about__list-heading,
    .about__list-text b,
    .about__about-title-inner,
    .case__img-title,
    .case__dt,
    .case__dd b,
    .price__table td b,
    .price__table td {
      color: #5484c3;
    }

    .case__img-item:last-child::before,
    .price__table th,
    .c-btn__arrow::after {
      background-color: #5484c3;
    }

    .fee__container {
      background-color: rgba(84, 132, 195, 0.1);
    }
  }

  &amp;.authentic {
    .about__reason-heading-lead,
    .about__reason-heading-en,
    .about__reason-lead strong,
    .about__list-heading,
    .about__list-text b,
    .about__about-title-inner,
    .case__img-title,
    .case__dt,
    .case__dd b,
    .price__table td b,
    .price__table td,
    .about__lead b {
      color: #4ba677;
    }

    .about__heading-feature {
      color: rgba(75, 166, 119, 0.5);
      background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 60%, rgba(236, 242, 227, 0.4) 60%, rgba(236, 242, 227, 0.4) 100%);
    }

    .about__case-fee-content {
      background-color: rgba(236, 242, 227, 0.4);
    }

    .case__img-item:last-child::before,
    .price__table th,
    .c-btn__arrow::after {
      background-color: #4ba677;
    }

    .fee__container {
      background-color: #d5e9db;
      box-shadow: 8px 8px 0px 0px rgba(75, 166, 119, 0.4);
    }

    .about__reason-heading-box {
      box-shadow: 8px 8px 0px 0px #ecf2e3;
    }

    .c-btn__arrow {
      box-shadow: 8px 8px 0 0px #bbd2c6;
      border: 1px solid #bbd2c6;

      &amp;:hover {
        box-shadow: 0px 0px 0 0px #bbd2c6;
      }
    }

    @media (1024px &lt;= width) {
      .c-btn__arrow {
        box-shadow: 14px 14px 0 0px #bbd2c6;
      }

      .about__reason-heading-box {
        box-shadow: 15px 15px 0px 0px #ecf2e3;
      }

      .fee__container {
        box-shadow: 20px 20px 0px 0px rgba(75, 166, 119, 0.4);
      }
    }
  }

  &amp;.maintenance {
    .about__reason-heading-lead,
    .about__reason-heading-en,
    .about__reason-lead strong,
    .about__list-heading,
    .about__list-text b,
    .about__about-title-inner,
    .case__img-title,
    .case__dt,
    .case__dd b,
    .price__table td b,
    .price__table td,
    .about__lead b {
      color: #2a92d5;
    }

    .about__heading-feature {
      color: rgba(42, 146, 213, 0.5);
      background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 60%, rgba(203, 222, 246, 0.4) 60%, rgba(203, 222, 246, 0.4) 100%);
    }

    .about__case-fee-content {
      background-color: rgba(42, 146, 213, 0.5);
    }

    .case__img-item:last-child::before,
    .price__table th,
    .c-btn__arrow::after {
      background-color: #2a92d5;
    }

    .fee__container {
      background-color: #cbdef6;
      box-shadow: 8px 8px 0px 0px #cbdef6;
    }

    .about__reason-heading-box {
      box-shadow: 8px 8px 0px 0px #cbdef6;
    }

    .c-btn__arrow {
      box-shadow: 14px 14px 0 0px #cbdef6;
      border: 1px solid #cbdef6;

      &amp;:hover {
        box-shadow: 0px 0px 0 0px #cbdef6;
      }
    }

    .about__bottom-container {
      padding-bottom: 73px;
      background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 88%, rgba(203, 222, 246, 0.4) 88%, rgba(203, 222, 246, 0.4) 100%);
    }

    @media (1024px &lt;= width) {
      .c-btn__arrow {
        box-shadow: 8px 8px 0 0px #cbdef6;
      }

      .fee__container {
        box-shadow: 20px 20px 0px 0px #cbdef6;
      }

      .about__reason-heading-box {
        box-shadow: 15px 15px 0px 0px #cbdef6;
      }
    }
  }
}

.about__head {
  padding-block: 70px;
  position: relative;

  @media (width &lt;= 767px) {
    padding-block: 50px;
  }
}

.about__head-inner {
  @media (width &lt;= 767px) {
    padding-inline: 10px;
  }
}

.about__heading-box {
  width: fit-content;
  margin-inline: auto;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 15px;

  @media (width &lt;= 767px) {
    gap: 4px;
  }
}

.about__icon {
  width: 52px;
  margin-inline: auto;

  @media (768px &lt;= width) {
    width: 85px;
  }
}

.about__heading-en {
  color: var(--color-blue);
  font-family: var(--font-family-din);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
}

.about__heading-center {
  font-size: 3.6rem;
  line-height: 1.41;
  font-family: var(--font-family-mincho);

  @media (width &lt;= 767px) {
    font-size: 2rem;
  }
}

.about__heading {
  font-family: var(--font-family-mincho);
  color: var(--color-blue);
  font-size: 4.8rem;
  line-height: 1.06;
  text-decoration: underline;
  text-underline-offset: 12px;
  text-decoration-thickness: 2px;

  @media (width &lt;= 767px) {
    font-size: 3.6rem;
    line-height: 1.41;
  }
}

.about__wrapper-img {
  height: 500px;

  @media (width &lt;= 767px) {
    height: 194px;
  }
}

.about__reason-heading-box {
  background-color: #fff;
  width: 89%;
  max-width: 850px;
  margin-inline: auto;
  padding: 24px 56px;
  text-align: center;
  position: relative;
  z-index: 2;
  box-shadow: 15px 15px 0px 0px #d7daef;

  @media (width &lt;= 767px) {
    padding: 30px 16px;
    box-shadow: 8px 8px 0px 0px #d7daef;
    margin-top: -70px;
  }
}

.about__reason-heading-lead {
  font-size: 1.6rem;
  font-weight: 700;
  color: #5484c3;

  @media (width &lt;= 767px) {
    font-size: 1.4rem;
  }
}

.about__reason-heading {
  margin-top: 20px;

  @media (width &lt;= 767px) {
    margin-top: 8px;
  }
}

.about__reason-heading-ja {
  display: block;
  font-family: var(--font-family-mincho);
  font-size: 4.8rem;
  line-height: 1.06;

  @media (width &lt;= 767px) {
    font-size: 3.2rem;
    line-height: 1.3;
  }
}

.about__reason-heading-en {
  display: block;
  color: #5484c3;
  font-family: var(--font-family-din);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
  margin-top: 7px;

  @media (width &lt;= 767px) {
    margin-top: 4px;
  }
}

.about__reason-lead {
  margin-top: 40px;
  text-align: center;
  font-size: 1.8rem;
  line-height: 1.6;
  letter-spacing: 0.04em;

  strong {
    font-size: 2.4rem;
    color: #5484c3;
    font-weight: 700;
    background-image: var(--text-underline);
  }

  b {
    font-weight: 700;
  }

  @media (width &lt;= 767px) {
    font-size: 1.4rem;
    margin-top: 20px;

    strong {
      font-size: 2rem;
    }
  }
}

.about__heading-feature {
  color: rgba(84, 132, 195, 0.6);
  font-family: var(--font-family-mincho);
  font-size: 10rem;
  font-weight: 600;
  padding-left: 27px;
  line-height: 1.2;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0) 60%, rgba(227, 230, 244, 0.4) 60%, rgba(227, 230, 244, 0.4) 100%);
  margin-top: 50px;

  @media (width &lt;= 767px) {
    font-size: 6rem;
    margin-top: 48px;
    padding-left: 7px;
  }
}

.about__about-title {
  display: flex;
  gap: 35px;
  align-items: center;

  &amp;::before,
  &amp;::after {
    content: "";
    flex: 1;
    height: 6px;
    border-top: 1px solid #c3c7da;
    border-bottom: 1px solid #c3c7da;
  }

  @media (width &lt;= 767px) {
    gap: 20px;
  }
}

.about__about-title-inner {
  width: fit-content;
  display: block;
  white-space: nowrap;
  color: var(--color-blue);
  text-align: center;
  font-weight: 700;
}

.about__about-title-small {
  display: block;
  line-height: 1.93;
  letter-spacing: 0.04em;

  @media (width &lt;= 767px) {
    font-size: 1.2rem;
    line-height: 1.33;
    letter-spacing: 0.1em;
  }
}

.about__about-title-ja {
  display: block;
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;
  font-weight: 400;

  @media (width &lt;= 767px) {
    font-size: 2.4rem;
    line-height: 1.3;
  }
}

.about__lead {
  margin-top: 58px;
  color: #2e2f31;
  font-family: var(--font-family-mincho);
  font-size: 3.6rem;
  font-weight: 600;
  text-align: center;

  b {
    font-size: 4.4rem;
    color: #5484c3;
    text-decoration: underline;
    text-underline-offset: 8px;
    text-decoration-thickness: 2px;
    font-weight: 600;
  }

  @media (width &lt;= 767px) {
    margin-top: 20px;
    font-size: 2.6rem;

    b {
      font-size: 3.2rem;
    }
  }
}

.about__lists {
  margin-top: 58px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;

  &amp;.blue {
    .about__list-text-box {
      background-color: rgba(227, 230, 244, 0.4);
    }

    .about__list-text {
      b {
        color: var(--color-gray);
        font-size: 1.6rem;
        font-weight: 700;
        background: none;
      }

      @media (width &lt;= 767px) {
        b {
          font-size: 1.6rem;
        }
      }
    }
  }

  @media (width &lt;= 1023px) {
    gap: 16px;
  }

  @media (width &lt;= 767px) {
    margin-top: 20px;
    grid-template-columns: repeat(1, 1fr);
  }
}

.about__list {
  display: flex;
  flex-direction: column;
  box-shadow: 3px 3px 4px 0px rgba(195, 199, 218, 0.5);
  background-color: #fff;

  @media (width &lt;= 767px) {
    position: relative;
  }
}

.about__list-text-box {
  padding: 16px 20px;
  background-color: #fff;
  position: relative;
  text-align: center;
  height: 100%;

  @media (width &lt;= 767px) {
    position: initial;
    padding: 16px 11px;
  }
}

.about__list-number {
  background-color: var(--color-blue);
  color: #fff;
  font-size: 2.4rem;
  font-family: var(--font-family-din);
  line-height: 28px;
  font-weight: 700;
  width: 28px;
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;

  @media (width &lt;= 767px) {
    font-size: 2.4rem;
    width: 32px;
    height: 28px;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

.about__list-heading {
  font-size: 2rem;
  letter-spacing: 0.04em;
  font-weight: 700;
  color: var(--color-blue);
  font-family: var(--font-family-mincho);

  @media (768px &lt;= width) {
    font-size: 2.6rem;
  }
}

.about__list-text {
  margin-top: 16px;
  color: var(--color-gray);
  letter-spacing: 0.04em;

  b {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-blue);
    background-image: var(--text-underline);
  }

  @media (width &lt;= 767px) {
    margin-top: 6px;
  }
}

.about__case-fee-content {
  margin-top: -167px;
  padding-top: calc(167px + 65px);
  padding-bottom: 80px;
  background: rgba(227, 230, 244, 0.4) url(./../image/about-bg_2.webp) no-repeat top center / cover;

  @media (width &lt;= 767px) {
    margin-top: -927px;
    padding-top: calc(927px + 40px);
    padding-bottom: 40px;
  }
}

/* ===============================================
#case
=============================================== */
.case__container {
  max-width: 730px;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 50px;
  margin-top: 50px;

  @media (width &lt;= 767px) {
    margin-top: 26px;
  }
}

.case__img-box {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 87px;

  @media (width &lt;= 767px) {
    gap: 23px;
  }
}

.case__img-title {
  color: var(--color-blue);
  font-family: var(--font-family-din);
  font-size: 2.4rem;
  font-weight: 700;

  @media (width &lt;= 767px) {
    font-size: 1.8rem;
  }
}

.case__img {
  margin-top: 20px;

  @media (width &lt;= 767px) {
    margin-top: 14px;
  }
}

.case__img-item {
  position: relative;

  &amp;:last-child {
    &amp;::before {
      content: "";
      display: block;
      width: 23px;
      height: 48px;
      background-color: var(--color-blue);
      position: absolute;
      top: 50%;
      left: -51px;
      transform: translateY(-50%);
      -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
      clip-path: polygon(0 0, 0% 100%, 100% 50%);
    }
  }

  @media (width &lt;= 767px) {
    &amp;:last-child {
      &amp;::before {
        width: 13px;
        height: 25px;
        left: -17px;
      }
    }
  }
}

.case__text-box {
  margin-top: 40px;
  background-color: #fff;
  padding: 32px 80px;

  @media (width &lt;= 767px) {
    margin-top: 20px;
    padding: 18px 20px;
  }
}

.case__lists {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.case__list {
  display: flex;
  align-items: flex-start;
  gap: 14px;

  @media (768px &lt;= width) {
    gap: 25px;
  }
}

.case__dt {
  width: 83px;
  white-space: nowrap;
  color: var(--color-blue);
  font-size: 2rem;
  font-weight: 400;

  @media (width &lt;= 767px) {
    font-size: 1.2rem;
    width: 50px;
    padding-top: 2px;
  }
}

.case__dd {
  flex: 1;
  line-height: 1.55;
  letter-spacing: 0.04em;
  margin-top: 3px;

  b {
    color: var(--color-blue);
    font-size: 3rem;
    font-family: var(--font-family-din);
    font-weight: 500;
    line-height: 0.9;
  }

  @media (width &lt;= 767px) {
    font-size: 1.2rem;

    b {
      font-size: 1.8rem;
    }
  }
}

.case__text-box-title {
  margin-top: 24px;
  font-size: 1.8rem;
  line-height: 1.72;
  letter-spacing: 0.04em;

  @media (width &lt;= 767px) {
    margin-top: 14px;
    font-size: 1.1rem;
    line-height: 1.63;
    letter-spacing: 0.1em;
  }
}

.case__text {
  margin-top: 12px;
  line-height: 1.93;
  letter-spacing: 0.04em;

  @media (width &lt;= 767px) {
    font-size: 1.2rem;
    letter-spacing: 0;
    line-height: normal;
  }
}

.case__text-lists {
  margin-top: 12px;
}

.case__text-list {
  line-height: 1.93;
  letter-spacing: 0.04em;
  text-indent: -1em;
  margin-left: 1em;

  &amp;::before {
    content: "・";
  }

  @media (width &lt;= 767px) {
    font-size: 1.2rem;
    letter-spacing: 0;
    line-height: normal;
  }
}

/* ===============================================
#fee
=============================================== */
.about__fee-content {
  margin-top: 40px;

  @media (width &lt;= 767px) {
    padding-bottom: 14px;
  }
}

.fee__container-inner {
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 48px;

  @media (width &lt;= 767px) {
    gap: 24px;
  }
}

.fee__container {
  padding: 40px 20px;
  background-color: var(--color-light-blue);
  box-shadow: 20px 20px 0px 0px rgba(75, 89, 166, 0.4);

  @media (width &lt;= 1023px) {
    box-shadow: 8px 8px 0px 0px rgba(75, 89, 166, 0.4);
  }

  @media (width &lt;= 767px) {
    padding: 23px 14px;
    background-color: transparent;
  }
}

.price__table {
  width: 100%;
  max-width: 800px;
  margin-inline: auto;
  background-color: #fff;

  tr {
    &amp;:not(:first-child) {
      border-top: 1px solid #e4e4e4;
    }
  }

  th,
  td {
    padding: 28px 10px;
    text-align: center;
    vertical-align: middle;
    width: 50%;

    small {
      font-size: 1.3rem;
      line-height: 1.3;
    }
  }

  th {
    color: #fff;
    background: var(--color-blue);
    font-size: 1.8rem;
    font-weight: 400;
    line-height: 1.72;
  }

  td {
    background-color: rgba(220, 231, 242, 0.41);
    color: var(--color-blue);
    line-height: 1.93;

    b {
      font-size: 3rem;
      font-family: var(--font-family-din);
      font-weight: 700;
      line-height: normal;
      margin-right: 4px;
    }
  }

  @media (width &lt;= 767px) {
    th,
    td {
      padding: 9px;

      small {
        font-size: 0.8rem;
        line-height: 1;
        letter-spacing: 0.1em;
      }
    }

    th {
      font-size: 1.3rem;
      line-height: 1.3;
      width: 60%;
    }

    td {
      line-height: 1.63;
      font-size: 1.1rem;
      width: 40%;

      b {
        font-size: 1.8rem;
        margin-right: 2px;
      }
    }
  }
}

/* ===============================================
#medical-menu
=============================================== */
.medical-menu {
  background-color: rgba(227, 230, 244, 0.4);
  padding-block: 70px;

  @media (width &lt;= 767px) {
    background-color: #fff;
    padding-block: 40px;
  }
}

.medical-menu__list-box {
  background-color: rgba(75, 89, 166, 0.9);
  padding: 60px 70px;
  display: flex;
  align-items: center;
  gap: 40px;

  @media (width &lt;= 1023px) {
    flex-direction: column;
    padding: 60px 30px;
  }

  @media (width &lt;= 767px) {
    padding: 60px 16px;
  }
}

.medical-menu__list-title {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  color: #fff;
  display: flex;
  flex-direction: column;
  align-items: center;
  white-space: nowrap;
  gap: 2px;
}

.medical-menu__list-title-ja {
  font-size: 3.6rem;
  line-height: 1.41;
  font-family: var(--font-family-mincho);
}

.medical-menu__list-title-en {
  font-family: var(--font-family-din);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
}

.medical-menu__lists {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  flex: 1;
  width: 100%;

  @media (width &lt;= 767px) {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
}

.medical-menu__list {
  a {
    color: var(--color-blue);
    background: #fff;
    box-shadow: 0px -4px 9px 0px rgba(0, 0, 0, 0.25) inset, 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    font-size: 1.8rem;
    letter-spacing: 0.04em;
    line-height: 1.72;
    padding: 10px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    &amp;::after {
      content: "";
      width: 8px;
      height: 12px;
      background-color: var(--color-blue);
      display: block;
      -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
      clip-path: polygon(0 0, 0% 100%, 100% 50%);
    }
  }

  @media (width &lt;= 767px) {
    font-size: 1.7rem;

    a {
      font-size: 1.4rem;
      padding: 10px 6px;
    }
  }
}

/* ===============================================
#cure
=============================================== */
.cure__top-container {
  position: relative;
  padding-top: 100px;
  padding-bottom: 70px;

  @media (width &lt;= 767px) {
    padding-top: 20px;
    padding-bottom: 20px;
  }
}

.cure__top-container-inner {
  position: initial;
  @media (width &lt;= 767px) {
    display: flex;
    align-items: flex-start;
    gap: 20px;
  }
}

.cure__top-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 76.4%;
  height: 100%;
  z-index: 1;

  img {
    height: 100%;
    object-position: right;
  }

  @media (width &lt;= 1023px) {
    width: 100%;
  }
}

.cure__top-text-box {
  width: fit-content;
  margin-left: auto;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  position: relative;
  z-index: 2;

  @media (width &lt;= 767px) {
    width: 123px;
  }

  @media (width &lt;= 767px) {
    width: fit-content;
    margin-right: -7px;
  }
}

.cure__top-text-blue {
  background-color: var(--color-blue);
  color: #fff;
  font-size: 2.8rem;
  line-height: 1.3;
  letter-spacing: 0.13em;
  padding: 10px;
  display: inline-block;
  margin-left: 32px;

  @media (width &lt;= 767px) {
    padding: 5px;
    font-size: 1.2rem;
    margin-left: 13px;
  }
}

.cure__top-heading {
  font-family: var(--font-family-mincho);
  font-size: 3.6rem;
  letter-spacing: 0.106em;
  text-shadow: 4px 4px 6px rgba(255, 255, 255, 0.9);
  display: flex;
  flex-direction: column;
  gap: 24px;
  white-space: nowrap;

  .center {
    font-size: 4rem;
    background-color: #fff;
    box-shadow: 5px 5px 0px 0px #d7daef;
    padding: 17px 6px;
  }

  b {
    font-weight: 400;
    color: var(--color-blue);
    font-size: 4.8rem;
  }

  span:last-child {
    text-align: right;
  }

  @media (width &lt;= 767px) {
    font-size: 1.8rem;
    gap: 5px;

    .center {
      font-size: 2.4rem;
      box-shadow: 3px 3px 0px 0px #d7daef;
    }

    b {
      font-size: 3rem;
    }
  }
}

.cure__bottom-container {
  padding-block: 100px;
  background: transparent url(./../image/cure-bg_1.webp) no-repeat center center / cover;

  @media (width &lt;= 767px) {
    padding-block: 40px;
  }
}

.cure__container {
  display: flex;
  flex-direction: column;
  gap: 64px;
}

.cure__wrapper {
  display: flex;
  align-items: center;
  gap: 64px;

  @media (width &lt;= 767px) {
    flex-direction: column;
    gap: 24px;
  }
}

.cure__img {
  width: calc(40.4% - 64px);

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.cure__text-box {
  width: 59.6%;

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.cure__title {
  font-size: 3.6rem;
  font-family: var(--font-family-mincho);
  line-height: 1.41;

  b {
    color: var(--color-blue);
    font-weight: 400;
  }

  @media (width &lt;= 767px) {
    font-size: 2.4rem;

    span {
      font-size: 2.6rem;
    }
  }
}

.cure__text {
  font-size: 1.8rem;
  font-weight: 400;
  line-height: 1.72;
  letter-spacing: 0.04em;
  margin-top: 10px;

  b {
    font-size: 2rem;
    color: var(--color-blue);
    font-weight: 700;
    background: var(--text-underline);
  }

  @media (width &lt;= 767px) {
    font-size: 1.4rem;
    margin-top: 12px;

    b {
      font-size: 1.6rem;
    }
  }
}

.cure__btn {
  margin-left: 0;

  @media (width &lt;= 767px) {
    margin-inline: auto;
  }
}

/* ===============================================
#doctor
=============================================== */
.doctor {
  background-color: #fff7e9;
  padding-top: 100px;
  padding-bottom: 71px;

  @media (width &lt;= 767px) {
    padding-top: 60px;
    padding-bottom: 45px;
  }
}

.doctor__heading {
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 7px;
  color: var(--color-blue);
}

.doctor__heading-ja {
  font-family: var(--font-family-mincho);
  font-size: 4.8rem;
  line-height: 1.06;

  @media (width &lt;= 767px) {
    font-size: 3.6rem;
    line-height: 1.41;
  }
}

.doctor__heading-en {
  font-size: 1.3rem;
  font-family: var(--font-family-en);
  line-height: 1.38;
  letter-spacing: 0.1em;
}

.doctor__container {
  margin-top: 54px;
  margin-bottom: 80px;
  display: flex;
  flex-direction: column;
  gap: 80px;

  @media (width &lt;= 1023px) {
    gap: 32px;
  }

  @media (width &lt;= 767px) {
    margin-top: 40px;
    margin-bottom: 60px;
  }
}

.doctor__wrapper {
  display: flex;
  align-items: center;
  position: relative;

  @media (width &gt;= 1024px) {
    &amp;.top {
      .doctor__img {
        width: 62.7vw;
        margin-left: calc((100vw - 100%) / -2);
        min-height: 671px;
        position: absolute;
      }

      .doctor__text-box {
        width: 46.4%;
        right: 0;
        position: relative;
        margin-left: auto;
      }
    }

    &amp;.center {
      .doctor__img {
        width: 62.7vw;
        margin-right: calc((100vw - 100%) / -2);
        min-height: 671px;
        position: absolute;
        right: 0;
      }

      .doctor__text-box {
        width: 55.4%;
        position: relative;
      }
    }

    &amp;.bottom {
      .doctor__img {
        width: 64.9vw;
        margin-left: calc((100vw - 100%) / -2);
      }

      .doctor__text-box {
        width: 46.4%;
        right: 0;
      }
    }

    @media (width &lt;= 1200px) {
      &amp;.center {
        .doctor__text-box {
          width: 68.4%;
        }
      }
    }
  }

  @media (width &lt;= 1023px) {
    flex-direction: column;
    gap: 0px;
  }
}

.doctor__img {
  position: relative;
  z-index: 1;

  @media (width &lt;= 1023px) {
    width: 100vw;
    margin-inline: calc(var(--side-space) * -2);
  }
}

.doctor__text-box {
  position: absolute;
  z-index: 2;
  width: 60%;

  @media (width &lt;= 1023px) {
    position: relative;
    width: 100%;
    margin-top: -20px;
  }
}

.doctor__name-box {
  display: flex;
  align-items: center;
  gap: 16px;
  font-family: var(--font-family-mincho);

  @media (width &lt;= 767px) {
    gap: 8px;
    align-items: baseline;
  }
}

.doctor__position {
  color: var(--color-blue);
  font-size: 3rem;
  line-height: 1.7;
}

.doctor__name {
  font-size: 3.6rem;
  line-height: 1.41;
}

.doctor__text {
  margin-top: 30px;

  p {
    line-height: 1.93;
    letter-spacing: 0.04em;
  }

  @media (width &lt;= 767px) {
    margin-top: 8px;

    p {
      font-size: 1.4rem;
      line-height: 1.71;
    }
  }
}

.doctor__list-box {
  margin-top: 30px;
  display: flex;
  flex-direction: column;
  gap: 30px;

  @media (width &lt;= 767px) {
    margin-top: 8px;
    gap: 10px;
  }
}

.doctor__list-title {
  color: var(--color-blue);
  line-height: 1.93;
  letter-spacing: 0.04em;
  font-weight: 700;
}

.doctor__list-text {
  margin-top: 8px;
  font-size: 1.4rem;
  line-height: 1.28;
  color: var(--color-gray);
}

.doctor__history-lists {
  width: 100%;
}

.doctor__history-list-year {
  font-weight: 500;
  padding-right: 2em;
  white-space: nowrap;
  @media (width &lt;= 1023px) {
    padding-right: 1em;
  }
}

.doctor__bottom-text-box {
  background: rgba(255, 255, 255, 0.85);
  box-shadow: 10px 10px 0px 0px rgba(75, 89, 166, 0.5);
  padding: 40px 80px;
  text-align: center;
  margin-inline: auto;
  display: flex;
  flex-direction: column;
  gap: 35px;

  @media (width &lt;= 767px) {
    padding: 20px 9px;
    gap: 18px;
  }
}

.doctor__bottom-heading {
  font-family: var(--font-family-mincho);
  font-size: 3.8rem;
  font-weight: 600;
  color: var(--color-blue);
  width: fit-content;
  margin-inline: auto;
  padding-inline: 25px;
  border-bottom: 1px solid currentColor;
  padding-bottom: 7px;

  @media (width &lt;= 767px) {
    font-size: 2.8rem;
    padding-inline: 0;
    padding-bottom: 3px;
  }
}

.doctor__bottom-text {
  p {
    font-size: 2rem;
    font-weight: 400;
    letter-spacing: 0.04em;

    &amp;:not(:first-child) {
      margin-top: 1.55em;
    }
  }

  @media (width &lt;= 767px) {
    p {
      font-size: 1.4rem;

      &amp;:not(:first-child) {
        margin-top: 1.4em;
      }
    }
  }
}

.doctor__certificate-box {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 30px;

  img {
    width: calc(100% / 4 - 6px * 3 / 4);
  }

  @media (width &lt;= 767px) {
    margin-top: 20px;

    img {
      width: calc(100% / 3 - 6px * 2 / 3);
    }
  }
}

.doctor__bottom-text-box-bg {
  position: relative;
  margin-bottom: 40px;

  @media (768px &lt;= width) {
    padding-top: 294px;
    padding-bottom: 56px;
    margin-bottom: 0;
    height: auto;

    img {
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
  }

  .inner.max-826 {
    @media (width &lt;= 767px) {
      margin-top: -110px;
    }
  }
}

/* ===============================================
#access
=============================================== */
.access {
  background-image: linear-gradient(170deg, rgba(227, 230, 244, 0.4) 0%, rgba(227, 230, 244, 0.4) 30%, rgba(195, 199, 218, 0.5) 30%, rgba(195, 199, 218, 0.5) 100%);

  @media (width &lt;= 767px) {
    background-image: linear-gradient(140deg, rgba(227, 230, 244, 0.4) 0%, rgba(227, 230, 244, 0.4) 55%, rgba(195, 199, 218, 0.5) 55%, rgba(195, 199, 218, 0.5) 100%);
  }
}

.access__container {
  display: flex;
  align-items: flex-start;
  gap: 80px;

  @media (width &lt;= 1023px) {
    flex-direction: column;
    gap: 28px;
  }
}

.access__text-box {
  width: 495px;

  @media (width &lt;= 1023px) {
    max-width: 500px;
    margin-inline: auto;
    width: 100%;
  }
}

.access__img {
  width: calc(100% - 495px - 80px + ((100vw - 100%) / 2));
  margin-right: calc((100vw - 100%) / -2);

  @media (width &lt;= 1023px) {
    width: 80%;
    margin-inline: auto;
  }

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.access__heading {
  color: var(--color-blue);
  font-family: var(--font-family-mincho);
  font-size: 3.8rem;
  line-height: 1.3;

  @media (width &lt;= 767px) {
    font-size: 2.8rem;
    line-height: 1.7;
  }
}

.access__grid {
  margin-top: 40px;
  display: grid;
  grid-template-columns: repeat(2, fit-content(300px));
  gap: 24px 70px;

  @media (width &lt;= 767px) {
    margin-top: 28px;
    grid-template-columns: repeat(1, 1fr);
    gap: 12px 40px;
  }
}

.access__grid-title {
  color: var(--color-blue);
  font-size: 1.8rem;
  font-family: var(--font-family-mincho);
  line-height: 1.3;
}

.access__grid-text {
  margin-top: 4px;
  font-size: 1.4rem;
  line-height: 1.6;
}

.access__time-box {
  margin-top: 40px;
  background-color: #fff;
  padding: 20px 40px;

  @media (width &lt;= 1023px) {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto;
    padding: 20px 16px;
  }

  @media (width &lt;= 767px) {
    margin-top: 28px;
    max-width: 335px;
    width: 100%;
  }

  @media (width &lt;= 370px) {
    padding: 20px 10px;
  }
}

.access__time-title {
  background-color: var(--color-light-blue);
  text-align: center;
  padding: 7px 10px;
  font-size: 2rem;
  font-size: 1.7rem;
  color: var(--color-blue);
  font-weight: 500;

  @media (width &lt;= 767px) {
    padding: 5px;
    font-size: 1.8rem;
  }
}

.access__time-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 24px;
  gap: 16px;
}

.access__time-lists {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.access__time-item {
  display: flex;
  align-items: center;
  gap: 16px;

  @media (width &lt;= 767px) {
    gap: 8px;
  }
}

.access__time-day {
  width: 46px;
  font-size: 1.7rem;
  color: var(--color-blue);
  letter-spacing: 0.1em;
  white-space: nowrap;

  @media (width &lt;= 767px) {
    width: 43px;
    font-size: 1.4rem;
  }
}

.access__time {
  flex: 1;
  font-size: 1.9rem;
  font-family: var(--font-family-din);
  line-height: 1.38;
  letter-spacing: 0.1em;
  font-weight: 700;
  color: var(--color-gray);
  white-space: nowrap;

  @media (width &lt;= 767px) {
    font-size: 1.3rem;
  }
}

.access__time-holiday {
  background-color: var(--color-light-blue);
  width: 90px;
  height: 90px;
  border-radius: 50%;
  font-size: 1.6rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;

  b {
    color: var(--color-blue);
    font-weight: 500;
  }

  @media (width &lt;= 767px) {
    font-size: 1.4rem;
    width: 71px;
    height: 71px;

    b {
      font-size: 1.7rem;
    }
  }
}

/* ===============================================
#news
=============================================== */
.news {
  @media (width &gt;= 768px) {
    background-image: linear-gradient(0deg, transparent 58px, #ebeefc 60px), linear-gradient(90deg, transparent 58px, #ebeefc 60px);
    background-color: rgba(227, 230, 244, 0.4);
    background-size: 60px 60px;
  }

  @media (width &lt;= 767px) {
    background-color: rgba(227, 230, 244, 0.4);
  }
}

.news__container {
  @media (width &gt;= 768px) {
    background-color: var(--color-light-blue);
    box-shadow: 20px 20px 0px 0px rgba(75, 89, 166, 0.4);
    padding: 38px 20px 56px;
  }
}

.news__heading {
  text-align: center;
  font-family: var(--font-family-mincho);
  font-size: 3.6rem;
  font-weight: 400;
  line-height: 1.41;
}

.news__lists {
  margin-top: 25px;
  max-width: 650px;
  margin-inline: auto;
  border-bottom: 1px solid #c3c7da;

  @media (width &lt;= 767px) {
    margin-top: 35px;
  }
}

.news__text {
  font-size: 1.8rem;
  line-height: 1.72;
  letter-spacing: 0.04em;
  margin-top: 25px;
  max-width: 650px;
  margin-inline: auto;

  @media (width &lt;= 767px) {
    font-size: 1.4rem;
    margin-top: 35px;
  }
}

.news__link {
  padding-block: 32px;
  border-top: 1px solid #c3c7da;
  display: flex;
  gap: 24px;
  align-items: flex-start;
}

.news__date {
  width: 80px;
  color: var(--color-blue);
  font-family: var(--font-family-din);
  font-size: 1.8rem;
  font-weight: 700;
  padding-top: 5px;
  white-space: nowrap;

  @media (width &lt;= 767px) {
    font-size: 1.1rem;
    width: 50px;
    padding-top: 6px;
  }
}

.news__title {
  flex: 1;
  font-size: 1.8rem;
  line-height: 1.72;
  letter-spacing: 0.04em;

  @media (width &lt;= 767px) {
    font-size: 1.4rem;
  }
}

/* ===============================================
#footer
=============================================== */
.footer {
  background-color: var(--color-blue);
  padding-block: 80px;

  @media (width &lt;= 767px) {
    padding-top: 40px;
    padding-bottom: 102px;
  }
}

.footer__container {
  display: flex;
  justify-content: space-between;
  align-items: center;

  @media (width &lt;= 1023px) {
    flex-direction: column;
    gap: 62px;
  }
}

.footer__container-left {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

.footer__logo {
  max-width: 443px;

  &amp;:hover {
    opacity: 1;
  }
}

.footer__access {
  color: #fff;
  font-size: 1.4rem;
  text-align: center;
  margin-top: 2px;
  line-height: 1.71;

  @media (width &lt;= 767px) {
    font-size: 1rem;
  }
}

.footer__menu {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-right: 100px;

  @media (width &lt;= 1023px) {
    margin-right: 0;
  }
}

.footer__menu-list {
  display: grid;
  grid-template-columns: repeat(2, fit-content(300px));
  gap: 21px 103px;

  @media (width &lt;= 767px) {
    gap: 21px 40px;
  }
}

.footer__menu-item {
  a {
    color: #fff;
    font-size: 2rem;
    line-height: 1.55;
    letter-spacing: 0.04em;
  }

  @media (width &lt;= 767px) {
    a {
      font-size: 1.8rem;
    }
  }
}

.footer__banner-box {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px 20px;
}

/* ===============================================
#c-fixed
=============================================== */
.c-fixed {
  display: none;
  @media (width &lt;= 767px) {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 99;
  }
}

.c-fixed__tel-btn {
  border: 1px solid var(--color-blue);
  background: var(--color-blue);
  width: 100%;
  padding: 10px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
}

.c-fixed__tel-icon {
  width: 20px;
}

.c-fixed__tel-text-box {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 5px;
  white-space: nowrap;
  color: #fff;
}

.c-fixed__tel-top-text {
  font-size: 1.1rem;
  letter-spacing: 0.1em;
  line-height: 1.63;
}

.c-fixed__tel-bottom-text {
  font-size: 2.2rem;
  font-family: var(--font-family-din);
  font-weight: 700;
}

.c-fixed__contact-btn {
  width: 50%;
  background: var(--color-blue);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 8px 30px;
  color: #fff;
}

.c-fixed__contact-top-text {
  font-size: 1.3rem;
  line-height: 1.3;
  letter-spacing: 0.1em;
}

.c-fixed__contact-bottom-text {
  font-size: 2.4rem;
  font-weight: 300;
  line-height: 1.3;
}

/* ===============================================
#sub-mv
=============================================== */
.sub-mv {
  margin-top: 35px;
  margin-bottom: 50px;
  position: relative;

  @media (width &lt;= 1023px) {
    margin-top: 42px;
  }

  @media (width &lt;= 767px) {
    margin-bottom: 0;
  }
}

.sub-mv__img {
  display: block;
  max-width: 960px;
  margin-inline: auto;
}

.sub-mv__text-box {
  position: absolute;
  bottom: 0;
  left: calc(50% + 225px);
  background-color: #fff;
  padding: 32px 40px;
  width: fit-content;
  max-width: 500px;
  min-width: 300px;
  white-space: nowrap;
  display: flex;
  flex-direction: column;
  gap: 10px;

  @media (width &lt;= 1400px) {
    left: auto;
    right: 0;
  }

  @media (width &lt;= 767px) {
    position: relative;
    width: 100%;
    max-width: 100%;
    padding: 20px;
    align-items: center;
    text-align: center;
    margin-inline: auto;
  }
}

.sub-mv__en {
  color: var(--color-blue);
  font-family: var(--font-family-din);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
}

.sub-mv__text {
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.33;

  @media (width &lt;= 767px) {
    font-size: 2.4rem;
  }
}

.sub-mv__heading {
  color: var(--color-blue);
  font-family: var(--font-family-mincho);
  font-size: 4.8rem;
  font-weight: 700;
  line-height: 1.06;

  @media (width &lt;= 767px) {
    font-size: 3.6rem;
  }
}

/* ===============================================
#sub-main
=============================================== */
.sub-main__content {
  padding-left: 345px;

  @media (width &lt;= 1023px) {
    padding-left: 0;
  }
}
/* ===============================================
#sidebar
=============================================== */
.sidebar {
  padding: 60px 50px;
  width: 300px;
  background: rgba(75, 89, 166, 0.9);
  position: absolute;
  top: 0;
  left: 20px;
  z-index: 90;

  @media (width &lt;= 1023px) {
    display: none;
  }
}

.sidebar__heading {
  color: #fff;
  text-align: center;
}

.sidebar__heading-ja {
  display: block;
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;
}

.sidebar__heading-en {
  display: block;
  font-family: var(--font-family-din);
  font-size: 1.3rem;
  font-weight: 700;
  line-height: 1.38;
  letter-spacing: 0.1em;
}

.sidebar__lists {
  margin-top: 40px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.sidebar__list {
  a {
    color: var(--color-blue);
    background: #fff;
    box-shadow: 0px -4px 9px 0px rgba(0, 0, 0, 0.25) inset, 0px 4px 4px 0px rgba(0, 0, 0, 0.25);
    font-size: 1.8rem;
    letter-spacing: 0.04em;
    line-height: 1.72;
    padding: 10px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;

    &amp;::after {
      content: "";
      width: 8px;
      height: 12px;
      background-color: var(--color-blue);
      display: block;
      -webkit-clip-path: polygon(0 0, 0% 100%, 100% 50%);
      clip-path: polygon(0 0, 0% 100%, 100% 50%);
    }
  }
}

/* ===============================================
#implant-treatment
=============================================== */

.implant-treatment__container {
  padding: 45px 90px;
  max-width: 1000px;
  margin-inline: auto;
  background-color: rgba(227, 230, 244, 0.8);
  box-shadow: 20px 20px 0px 0px rgba(75, 89, 166, 0.4);

  @media (width &lt;= 1200px) {
    padding: 45px 40px;
  }

  @media (width &lt;= 767px) {
    padding: 30px 15px;
    box-shadow: 8px 8px 0px 0px rgba(75, 89, 166, 0.4);
  }
}

.implant-treatment__text {
  margin-top: 40px;
  text-align: center;
  line-height: 1.93;
  letter-spacing: 0.04em;

  p {
    b {
      font-size: 1.8rem;
      color: var(--color-blue);
      font-weight: 700;
      background: var(--text-underline);
    }

    &amp;:not(:first-child) {
      margin-top: 1.93em;
    }
  }

  @media (width &lt;= 767px) {
    margin-top: 20px;
  }
}

.implant-treatment__img {
  display: block;
  max-width: 585px;
  margin: 40px auto 0;
}

/* ===============================================
#implant-merit
=============================================== */
.implant-merit__container {
  background: rgba(255, 255, 255, 0.7);
  padding: 45px 90px;

  @media (width &lt;= 1200px) {
    padding: 45px 40px;
  }

  @media (width &lt;= 767px) {
    padding: 20px 14px;
  }
}

.implant-merit__lists {
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  gap: 64px;

  @media (width &lt;= 767px) {
    margin-top: 24px;
    gap: 40px;
  }
}

.implant-merit__list {
  display: flex;
  align-items: flex-start;
  gap: 24px;

  &amp;:nth-of-type(even) {
    flex-direction: row-reverse;
  }

  @media (width &lt;= 767px) {
    flex-direction: column;

    &amp;:nth-of-type(even) {
      flex-direction: column;
    }
  }
}

.implant-merit__img {
  width: calc(37.7% - 24px);

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.implant-merit__text-box {
  width: 62.3%;
  display: flex;
  flex-direction: column;
  gap: 12px;

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.implant-merit__list-title {
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;

  b {
    color: var(--color-blue);
    font-weight: 700;
  }

  small {
    font-size: 1.6rem;
  }

  @media (width &lt;= 767px) {
    font-size: 2.4rem;
  }
}

.implant-merit__list-text {
  letter-spacing: 0.04em;
  line-height: 1.93;
}

.implant-merit__list-notice {
  font-size: 1.3rem;
  line-height: 1.3;
  max-width: 373px;
}

/* ===============================================
#implant-features
=============================================== */
.implant-features__lists {
  margin-top: 48px;
  display: flex;
  flex-wrap: wrap;
  gap: 24px 40px;

  @media (width &lt;= 767px) {
    gap: 64px;
    margin-top: 24px;
  }
}

.implant-features__list {
  width: calc(100% / 2 - 40px * 1 / 2);

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.implant-features__list-title {
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;
  margin-top: 24px;

  b {
    color: var(--color-blue);
    font-weight: 700;
  }

  small {
    font-size: 2rem;
    letter-spacing: 0.04em;
  }
  @media (width &lt;= 767px) {
    font-size: 2.4rem;
    small {
      font-size: 1.8rem;
    }
  }
}

.implant-features__list-text {
  line-height: 1.93;
  letter-spacing: 0.04em;
  margin-top: 12px;

  b {
    color: var(--color-blue);
    font-weight: 700;
    background: var(--text-underline);
  }
}

.implant-features__list-notice {
  margin-top: 12px;
  font-size: 1.3rem;
  line-height: 1.3;
}

/* ===============================================
#implant-flow
=============================================== */
.implant-flow__lists {
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  gap: 64px;

  @media (width &lt;= 767px) {
    margin-top: 24px;
    gap: 32px;
  }
}

.implant-flow__list {
  display: flex;
  align-items: flex-start;
  gap: 24px;

  @media (width &lt;= 767px) {
    flex-direction: column;
  }
}

.implant-flow__list-img {
  width: calc(38.3% - 24px);

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.implant-flow__text-box {
  width: 61.7%;
  display: flex;
  flex-direction: column;
  gap: 4px;

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.implant-flow__step {
  color: var(--color-blue);
  font-family: var(--font-family-din);
  font-size: 3rem;
  font-weight: 700;

  @media (width &lt;= 767px) {
    font-size: 1.8rem;
  }
}

.implant-flow__list-title {
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;

  @media (width &lt;= 767px) {
    font-size: 2.4rem;
  }
}

.implant-flow__list-text {
  line-height: 1.93;
  letter-spacing: 0.04em;

  p {
    &amp;:not(:first-child) {
      margin-top: 1.93em;
    }
  }

  b {
    color: var(--color-blue);
    font-weight: 700;
    background: var(--text-underline);
  }

  ul {
    list-style: initial;
    padding-left: 1.4em;
  }
}

/* ===============================================
#implant-qa
=============================================== */
.implant-qa__lists {
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  gap: 48px;

  @media (width &lt;= 767px) {
    margin-top: 24px;
  }
}

.implant-qa__dt {
  display: flex;
  align-items: flex-start;
  gap: 24px;
  padding-bottom: 12px;
  font-weight: 400;
  font-family: var(--font-family-mincho);
  border-bottom: 0.5px solid #d2d2d7;

  @media (width &lt;= 767px) {
    gap: 12px;
  }
}

.implant-qa__left-text {
  color: var(--color-blue);
  font-size: 3rem;
  letter-spacing: 0.08em;

  @media (width &lt;= 767px) {
    font-size: 2rem;
  }
}

.implant-qa__question-text {
  font-size: 1.8rem;
  margin-top: 10px;
  flex: 1;

  @media (width &lt;= 767px) {
    margin-top: 2px;
  }
}

.implant-qa__dd {
  margin-top: 21px;
  display: flex;
  align-items: flex-start;
  font-family: var(--font-family-mincho);
  gap: 26px;

  @media (width &lt;= 767px) {
    gap: 12px;
  }
}

.implant-qa__answer-text {
  font-size: 1.5rem;
  line-height: 1.64;
  letter-spacing: 0.1em;
  margin-top: 6px;
  flex: 1;

  p {
    &amp;:not(:first-child) {
      margin-top: 1.64em;
    }

    small {
      font-size: 1.3rem;
    }
  }

  @media (width &lt;= 767px) {
    margin-top: 3px;
  }
}

/* ===============================================
#reservation-parts
=============================================== */
.reservation-parts__container {
  padding: 45px 90px;
  background: rgba(255, 255, 255, 0.8);
  display: flex;
  flex-direction: column;
  gap: 48px;

  @media (width &lt;= 767px) {
    padding: 40px 14px;
    gap: 24px;
  }
}

.reservation-parts__text {
  text-align: center;
  line-height: 1.93;
  letter-spacing: 0.04em;
  p {
    &amp;:not(:first-child) {
      margin-top: 1.93em;
    }

    b {
      font-size: 1.8rem;
      color: var(--color-blue);
      font-weight: 700;
      background: var(--text-underline);
    }
  }

  @media (width &lt;= 767px) {
    &amp;.sp-left {
      text-align: left;
    }
  }
}

.reservation-parts__img {
  display: block;
  max-width: 585px;
  margin-inline: auto;
}

/* ===============================================
#aesthetic-top
=============================================== */
.aesthetic-top__block {
  display: flex;
  flex-wrap: wrap;
  gap: 48px 26px;

  @media (width &lt;= 767px) {
    gap: 26px 10px;
  }
}

.aesthetic-top__img,
.aesthetic-top__img-box {
  width: calc(50% - 13px);

  @media (width &gt;= 768px) {
    order: 1;

    &amp;.pc-order-2 {
      order: 2;
    }
  }

  @media (width &lt;= 767px) {
    width: 100%;

    &amp;.sp-col-2 {
      width: calc(50% - 5px);
    }
  }
}

.aesthetic-top__text {
  width: 100%;
  line-height: 1.93;
  letter-spacing: 0.04em;
  text-align: center;

  @media (width &gt;= 768px) {
    order: 3;
  }

  p {
    &amp;:not(:first-child) {
      margin-top: 1.93em;
    }

    b {
      font-size: 1.8rem;
      color: var(--color-blue);
      font-weight: 700;
      background: var(--text-underline);
    }
  }

  @media (width &lt;= 767px) {
    text-align: left;

    &amp;.sp-center {
      text-align: center;
    }
  }
}

/* ===============================================
#authentic-microscope
=============================================== */
.authentic-microscope__contents {
  display: flex;
  flex-direction: column;
  gap: 48px;

  @media (width &lt;= 767px) {
    gap: 20px;
  }
}

.authentic-microscope {
  background: transparent url(./../image/authentic-microscope-bg.webp) no-repeat center center / cover;

  @media (width &lt;= 767px) {
    background: transparent url(./../image/sp/authentic-microscope-bg.webp) no-repeat center center / cover;
  }
}

.authentic-microscope__img {
  display: block;
  max-width: 585px;
  margin: 40px auto 0;

  @media (width &lt;= 767px) {
    margin-inline: -16px;
    width: 100vw;
  }
}

/* ===============================================
#authentic-merit
=============================================== */
.authentic-merit__lists {
  display: flex;
  flex-direction: column;
  gap: 48px;

  @media (width &lt;= 767px) {
    gap: 24px;
  }
}

.authentic-merit__list-head {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding-bottom: 10px;
  border-bottom: 0.5px solid #c3c7da;
}

.authentic-merit__list-number {
  color: var(--color-blue);
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;
  white-space: nowrap;

  @media (width &lt;= 767px) {
    font-size: 2.4rem;
  }
}

.authentic-merit__list-title {
  flex: 1;
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  font-weight: 400;
  line-height: 1.7;

  @media (width &lt;= 767px) {
    font-size: 2.4rem;
  }
}

.authentic-merit__list-text {
  font-weight: 400;
  line-height: 1.93;
  letter-spacing: 0.04em;
  margin-top: 24px;

  span {
    color: var(--color-blue);
  }

  b {
    font-size: 1.8rem;
    font-weight: 700;
    color: var(--color-blue);
    background: var(--text-underline);
  }

  @media (width &lt;= 767px) {
    margin-top: 12px;
  }
}

.authentic-merit__list-img {
  max-width: 585px;
  margin-inline: auto;
  display: block;
  margin-top: 48px;

  @media (width &lt;= 767px) {
    margin-top: 16px;
  }
}

.authentic-merit__list-blocks {
  display: flex;
  flex-wrap: wrap;
  gap: 64px 43px;
  margin-top: 48px;

  @media (width &lt;= 767px) {
    margin-top: 24px;
    gap: 14px;
  }
}

.authentic-merit__list-block {
  width: calc(50% - 43px * 1 / 2);

  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.authentic-merit__list-block-caption {
  line-height: 1.93;
  letter-spacing: 0.04em;
  margin-top: 8px;

  @media (width &lt;= 767px) {
    line-height: 1.28;
    font-size: 1.4rem;
  }
}

/* ===============================================
#authentic-skills
=============================================== */
.authentic-skills__container {
  background: rgba(255, 255, 255, 0.7);
  padding: 45px 90px;

  @media (width &lt;= 767px) {
    padding: 40px 14px;
  }
}

/* ===============================================
#maintenance
=============================================== */
.maintenance__bg {
  background: transparent url(./../image/maintenance-bg_1.webp) no-repeat center center / cover;
}

.maintenance__caption {
  text-align: center;
  font-size: 1.3rem;
  line-height: 1.3;
  margin-top: 12px;
}

.maintenance__list {
  display: flex;
  flex-direction: column;
  gap: 24px;

  @media (width &lt;= 767px) {
    gap: 12px;
  }
}

.maintenance__title {
  font-family: var(--font-family-mincho);
  font-size: 3rem;
  line-height: 1.7;
  padding-bottom: 10px;
  border-bottom: 0.5px solid #c3c7da;

  @media (width &lt;= 767px) {
    font-size: 2rem;
  }
}

.maintenance__img {
  display: block;
}

/* ===============================================
#medical
=============================================== */
.medical__img {
  display: block;
}

.medical__img-blocks {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 20px;

  @media (width &lt;= 767px) {
    gap: 12px;
  }
}

.medical__img-block {
  width: calc(100% / 2 - 20px * 1 / 2);
  @media (width &lt;= 767px) {
    width: 100%;
  }
}

.medical__list-container {
  display: flex;
  flex-direction: column;
  gap: 24px;

  @media (width &lt;= 767px) {
    gap: 24px;
  }
}

/* ===============================================
#clinic
=============================================== */
.clinic__container {
  display: flex;
  flex-direction: column;
  gap: 100px;

  @media (width &lt;= 767px) {
    gap: 40px;
  }
}

.clinic__wrapper {
  display: flex;
  flex-direction: column;
  gap: 48px;

  .authentic-merit__list-blocks {
    gap: 20px;
    justify-content: center;
  }

  .authentic-merit__list-block {
    width: calc(100% / 2 - 20px * 1 / 2);
  }

  @media (width &lt;= 767px) {
    gap: 24px;

    .authentic-merit__list-blocks {
      gap: 8px;
    }
    .authentic-merit__list-block {
      width: calc(100% / 2 - 8px * 1 / 2);
    }
  }
}

/* ===============================================
#contact-parts
=============================================== */
.contact-parts {
  background-color: #fff;
  padding: 75px 90px;
  display: flex;
  flex-direction: column;
  gap: 48px;
  margin-top: 64px;

  @media (width &lt;= 767px) {
    padding: 20px 14px;
    margin-top: 24px;
    gap: 24px;
  }
}

/* ===============================================
#staff
=============================================== */
.staff__section {
  padding-top: 80px;
  padding-bottom: 80px;

  @media (width &lt;= 1023px) {
    padding-top: 0;
  }

  @media (width &lt;= 767px) {
    padding-bottom: 40px;
  }
}

.staff__container {
  .doctor__container {
    margin-top: 0;
  }

  .doctor__wrapper {
    @media (width &gt;= 1024px) {
      &amp;.top {
        .doctor__img {
          width: 68%;
          margin-left: 0;

          img {
            min-height: 671px;
            object-position: right;
          }
        }

        .doctor__text-box {
          width: 495px;
          top: 0;
        }
      }

      @media (width &lt;= 1300px) {
        &amp;.top {
          .doctor__img {
            img {
              min-height: 550px;
            }
          }
        }
      }

      @media (width &lt;= 1200px) {
        &amp;.top {
          .doctor__img {
            min-height: 820px;
            width: 80%;
          }
          .doctor__text-box {
            width: 335px;
          }
        }
      }

      &amp;.center {
        align-items: flex-start;
        .doctor__text-box {
          padding-top: 32px;
          width: 524px;
        }

        .doctor__img {
          width: 90%;
          margin-right: 0;
          min-height: 671px;

          img {
            min-height: 671px;
            object-position: right;
          }
        }

        .doctor__list-box {
          flex-direction: row;
        }
      }

      @media (width &lt;= 1300px) {
        &amp;.center {
          .doctor__img {
            width: 70%;

            img {
              min-height: 500px;
            }
          }
        }
      }

      @media (width &lt;= 1200px) {
        &amp;.center {
          .doctor__text-box {
            width: 335px;
          }

          .doctor__img {
            min-height: 950px;
            width: 70%;
          }
        }
      }

      &amp;.bottom {
        .doctor__text-box {
          width: 495px;
        }

        .doctor__img {
          width: 68%;
          margin-left: 0;
          min-height: 694px;

          img {
            min-height: 694px;
            object-position: right;
          }
        }
      }

      @media (width &lt;= 1300px) {
        &amp;.bottom {
          .doctor__img {
            width: 60%;
            min-height: 500px;

            img {
              min-height: 500px;
            }
          }
        }
      }

      @media (width &lt;= 1200px) {
        &amp;.bottom {
          .doctor__text-box {
            width: 335px;
          }

          .doctor__img {
            width: 70%;
          }
        }
      }
    }
  }
}

/* ===============================================
#sub-access
=============================================== */
.sub-access__container {
  display: flex;
  flex-direction: column;
  gap: 64px;

  @media (width &lt;= 767px) {
    gap: 24px;
  }
}

.sub-access__table-container {
  width: fit-content;
  margin-inline: auto;
}

.sub-access__table-inner {
  width: fit-content;
  padding: 20px 40px;
  background-color: #fff;

  @media (width &lt;= 1100px) {
    padding: 20px 14px;
  }

  @media (width &lt;= 767px) {
    max-width: 315px;
  }
}

.sub-access__table {
  th,
  td {
    padding: 8px 12px;
    vertical-align: middle;
    text-align: center;
    font-size: 1.8rem;
    font-weight: 400;
  }

  thead {
    th {
      font-size: 2rem;
      &amp;:not(:first-child) {
        background-color: var(--color-blue);
        color: #fff;
      }
    }
  }

  tbody {
    th {
      text-align: left;
      font-family: var(--font-family-din);
      padding: 8px 22px 0 0;
      font-size: 1.6rem;
    }

    td {
      color: var(--color-blue);
      padding: 8px 12px 0;
    }
  }

  @media (width &lt;= 767px) {
    th,
    td {
      padding: 4px 5px;
      font-size: 1.8rem;
    }

    thead {
      th {
        font-size: 1.4rem;
      }
    }

    tbody {
      th {
        padding: 4px 9px 0 0;
        font-size: 1.4rem;
      }

      td {
        padding: 8px 5px 0;
      }
    }
  }
}

.sub-access__table-notice {
  margin-top: 10px;
  text-align: right;
  line-height: 1.93;
  letter-spacing: 0.04em;

  b {
    font-weight: 400;
    color: var(--color-blue);
  }

  @media (width &lt;= 767px) {
    font-size: 1.2rem;
  }
}

.sub-access__map {
  height: 295px;

  &gt; iframe {
    width: 100%;
    height: 100%;
  }
}

.sub-access__map-title {
  color: var(--color-blue);
  font-family: var(--font-family-mincho);
  font-size: 3.8rem;
  line-height: 1.3;

  @media (width &lt;= 767px) {
    font-size: 2.8rem;
  }
}

.sub-access__text-blocks {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  margin-top: 34px;

  @media (width &lt;= 767px) {
    margin-top: 26px;
  }
}

.sub-access__text-block {
  width: fit-content;
  display: flex;
  flex-direction: column;
  gap: 24px;

  @media (width &lt;= 1023px) {
    width: 100%;
  }
}

.sub-access__text-block-title {
  color: var(--color-blue);
  font-size: 1.3rem;
  line-height: 1.3;
}

.sub-access__text-block-text {
  margin-top: 4px;
  font-size: 1.4rem;
}

/* ===============================================
#price
=============================================== */
.price__container {
  display: flex;
  flex-direction: column;
  gap: 80px;
  padding: 100px 90px;

  @media (width &lt;= 767px) {
    padding: 20px 14px;
    gap: 40px;
  }
}

.price__container-top {
  display: flex;
  flex-direction: column;
  gap: 40px;
}

.price__wrapper-top {
  display: flex;
  flex-direction: column;
  gap: 30px;

  @media (width &lt;= 767px) {
    gap: 20px;
  }
}

.price__heading {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--color-blue);
}

.price__heading-en {
  color: var(--color-blue);
  font-family: var(--font-family-din);
  font-size: 1.3rem;
  line-height: 1.38;
  letter-spacing: 0.1em;
}

.price__heading-ja {
  color: var(--color-blue);
  font-family: var(--font-family-mincho);
  font-size: 2.4rem;
  line-height: 1.44;
}

.price__anchor-box {
  display: flex;
  flex-wrap: wrap;
  gap: 24px 12px;

  @media (width &lt;= 767px) {
    gap: 8px;
  }
}

.price__anchor {
  width: 240px;
  background: var(--color-blue);
  box-shadow: 0px 4px 4px 0px rgba(0, 0, 0, 0.25), 0px -4px 9px 0px rgba(0, 0, 0, 0.25) inset;
  padding: 23px 70px 23px 17px;
  position: relative;
  display: flex;
  justify-content: center;

  span {
    text-align: center;
    color: #fff;
    font-family: var(--font-family-mincho);
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.3;
    min-width: 123px;
    width: fit-content;
  }

  &amp;::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 46px;
    transform: translateY(-50%);
    width: 22px;
    height: 13px;
    background: transparent url(./../image/icon-btn-arrow.svg) no-repeat center center / contain;
  }

  @media (width &lt;= 767px) {
    width: calc(100% / 2 - 8px * 1 / 2);
    padding: 23px 25px 23px 17px;

    span {
      font-size: 1.7rem;
    }

    &amp;::after {
      right: 9px;
      width: 14px;
      height: 8px;
    }
  }
}

.price__container-bottom {
  display: flex;
  flex-direction: column;
  gap: 80px;

  @media (width &lt;= 767px) {
    gap: 40px;
  }
}

.price__table-box {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 20px;

  @media (width &lt;= 767px) {
    margin-top: 12px;
  }
}

.price__notice {
  font-size: 2rem;
  margin-top: 30px;

  @media (width &lt;= 767px) {
    font-size: 1.6rem;
    margin-top: 10px;
  }
}

/* ===============================================
#リンク集
=============================================== */
.links__container {
  padding-inline: 30px;
}
</pre></body></html>