:root {
  --base: #fff;
  --main-1: #3d8f4f;
  --main-2: #9dcc2d;
  --main-3: #90c994;
  --brown: #5d3e2e;
  --text: #444
}
html {
  scroll-behavior: smooth
}
body {
  min-height: 100vh;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  color: var(--text);
  font-family: "Zen Kaku Gothic New", sans-serif;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict
}
main {
  -webkit-box-flex: 1;
  -webkit-flex: 1;
  -ms-flex: 1;
  flex: 1
}
img {
  width: 100%;
  height: auto
}
@-webkit-keyframes bgextendAnimeBase {
  from {
    opacity: 0
  }
  to {
    opacity: 1
  }
}
@keyframes bgextendAnimeBase {
  from {
    opacity: 0
  }
  to {
    opacity: 1
  }
}
@-webkit-keyframes bgextendAnimeSecond {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}
@keyframes bgextendAnimeSecond {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}
@-webkit-keyframes bgLRextendAnime {
  0% {
    -webkit-transform-origin: left;
    transform-origin: left;
    -webkit-transform: scaleX(0);
    transform: scaleX(0)
  }
  50% {
    -webkit-transform-origin: left;
    transform-origin: left;
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
  }
  50.001% {
    -webkit-transform-origin: right;
    transform-origin: right
  }
  100% {
    -webkit-transform-origin: right;
    transform-origin: right;
    -webkit-transform: scaleX(0);
    transform: scaleX(0)
  }
}
@keyframes bgLRextendAnime {
  0% {
    -webkit-transform-origin: left;
    transform-origin: left;
    -webkit-transform: scaleX(0);
    transform: scaleX(0)
  }
  50% {
    -webkit-transform-origin: left;
    transform-origin: left;
    -webkit-transform: scaleX(1);
    transform: scaleX(1)
  }
  50.001% {
    -webkit-transform-origin: right;
    transform-origin: right
  }
  100% {
    -webkit-transform-origin: right;
    transform-origin: right;
    -webkit-transform: scaleX(0);
    transform: scaleX(0)
  }
}

.mb30{
	margin-bottom: 30px;
}
.header {
  background-color: var(--base);
  z-index: 10
}
.header_sticky {
  position: -webkit-sticky;
  position: sticky;
  top: 0
}
.header_sticky .header__inner {
  height: 65px;
  grid-template-columns: 180px 1fr
}
.header_sticky .header__reservation, .header_sticky .header__access {
  height: 50px
}
.header__inner {
  height: clamp(4.0625rem, .658462867rem + 6.0449050086vw, 6.25rem);
  display: grid;
  grid-template-columns: clamp(11.25rem, -10.1468048359rem + 37.9965457686vw, 25rem) 1fr;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  padding-left: 20px
}
.header__light {
  margin-top: 10px
}
.header__logo {
  max-width: 400px
}
.header__thick {
  max-width: 960px;
  width: 100%;
  margin-left: auto
}
@media(max-width: 900px) {
  .header__thick {
    display: none
  }
}
.header__top-menu {
  max-width: 485px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 5px;
  -moz-column-gap: 5px;
  column-gap: 15px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-left: auto;
  padding-right: 20px;
   justify-content: flex-end;
}
.header__reservation {
  visibility: hidden;
  width: 140px;
  height: clamp(2.1875rem, .242335924rem + 3.4542314335vw, 3.4375rem);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  background-color: var(--main-2);
  color: var(--base);
  font-weight: 500;
  letter-spacing: .15em;
  border-radius: 0 0 10px 10px
}
.header__reservation::before {
  content: "";
  width: 22px;
  aspect-ratio: 11/8;
  background: url(../images/icon-pc.svg) no-repeat 0 0/contain
}
.header__instagram{
	width: 10%;
}
.header__access {
  width: 125px;
  height: clamp(2.1875rem, .242335924rem + 3.4542314335vw, 3.4375rem);
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 4px;
  -moz-column-gap: 4px;
  column-gap: 4px;
  background-color: #fec400;
  color: var(--base);
  font-weight: 500;
  letter-spacing: .15em;
  border-radius: 0 0 10px 10px
}
.header__map-icon {
  font-size: 1.25rem
}
.header__tel {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 1px;
  -moz-column-gap: 1px;
  column-gap: 1px;
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 1.5rem;
  font-weight: 500;
  letter-spacing: .1em;
  margin-top: 7px;
  /*margin-left: auto*/
}
.header__tel-icon {
  font-size: 1.25rem
}
@media(hover: hover)and (pointer: fine) {
  .header__logo {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .header__logo:hover, .header__logo:focus {
    opacity: .7
  }
  .header__reservation {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .header__reservation:hover, .header__reservation:focus {
    opacity: .7
  }
  .header__access {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .header__access:hover, .header__access:focus {
    opacity: .7
  }
  .header__tel {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .header__tel:hover, .header__tel:focus {
    opacity: .7
  }
}
.header-nav {
  max-width: 100%;
  position: relative;
  z-index: 1
}
@media(max-width: 900px) {
  .header-nav {
    display: none
  }
}
.header-nav_sticky .header-nav__items {
  top: 9px;
  padding-bottom: 4px
}
.header-nav_sticky .header-nav__sub-items {
  top: clamp(1rem, .4164507772rem + 1.0362694301vw, 1.375rem)
}
.header-nav__items {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  position: absolute;
  top: clamp(.5625rem, -1.868955095rem + 4.3177892919vw, 2.125rem);
  right: 0;
  background-color: var(--base);
  border-radius: 0px 0px 0px 20px;
  -webkit-box-shadow: 0px 3px 0px var(--main-3);
  box-shadow: 0px 3px 0px var(--main-3);
  padding-right: clamp(.3125rem, -2.4107297064rem + 4.8359240069vw, 2.0625rem);
  padding-bottom: clamp(.25rem, -1.1116148532rem + 2.4179620035vw, 1.125rem);
  padding-left: clamp(.3125rem, -1.2436312608rem + 2.7633851468vw, 1.3125rem)
}
.header-nav__item {
  position: relative
}
.header-nav__item.current::after {
  content: "";
  width: 25px;
  height: 2px;
  position: absolute;
  bottom: -0.25625rem;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  background-color: var(--main-1)
}
.header-nav__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 6px;
  color: #777;
  font-size: clamp(.75rem, .3609671848rem + .6908462867vw, 1rem);
  font-weight: 500;
  letter-spacing: .12em;
  padding-bottom: 2px
}
.header-nav__en {
  color: var(--main-3);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(.75rem, .5554835924rem + .3454231434vw, .875rem);
  font-weight: bold;
  letter-spacing: .1em
}
.header-nav__sub-items {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  position: absolute;
  top: clamp(1rem, -.3616148532rem + 2.4179620035vw, 1.875rem);
  left: 0;
  -webkit-clip-path: inset(0 0 100% 0);
  clip-path: inset(0 0 100% 0);
  color: #777;
  font-size: clamp(.75rem, .3609671848rem + .6908462867vw, 1rem);
  font-weight: 500;
  padding-top: 23px
}
.header-nav__sub-item {
  width: 100%;
  background-color: var(--base)
}
.header-nav__sub-item:not(:last-of-type) {
  border-bottom: 1px solid var(--main-3)
}
.header-nav__sub-link {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  height: 35px
}
@media(hover: hover)and (pointer: fine) {
  .header-nav__link {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .header-nav__link:hover, .header-nav__link:focus {
    opacity: .7
  }
  .header-nav__link:hover + .header-nav__sub-items, .header-nav__link:focus + .header-nav__sub-items {
    -webkit-clip-path: inset(0);
    clip-path: inset(0)
  }
  .header-nav__sub-items {
    -webkit-transition: -webkit-clip-path .5s;
    transition: -webkit-clip-path .5s;
    transition: clip-path .5s;
    transition: clip-path .5s, -webkit-clip-path .5s
  }
  .header-nav__sub-items:hover, .header-nav__sub-items:focus {
    -webkit-clip-path: inset(0);
    clip-path: inset(0)
  }
  .header-nav__sub-link {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .header-nav__sub-link:hover, .header-nav__sub-link:focus {
    opacity: .7
  }
}
.footer {
  position: relative;
  overflow: hidden;
  background: url(../images/footer-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/footer-bg.webp) 1x, url(../images/footer-bg@2x.webp) 2x);
  background-image: image-set(url(../images/footer-bg.webp) 1x, url(../images/footer-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .footer {
    background-repeat: repeat-y;
    background-position: top center;
    background-size: auto
  }
}
.footer_pos {
  margin-top: 155px
}
.footer__inner {
  max-width: 1174.5px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 75px 20px 55px
}
@media(max-width: 768px) {
  .footer__inner {
    padding: 35px 16px 50px
  }
}
.footer__logo {
  max-width: 400px;
  margin-inline: auto
}
.footer__main {
  display: grid;
  grid-template-columns: clamp(23rem, 2.7044663573rem + 42.2273781903vw, 34.375rem) 1fr;
  -webkit-column-gap: clamp(1.125rem, .4001595128rem + 1.5081206497vw, 1.53125rem);
  -moz-column-gap: clamp(1.125rem, .4001595128rem + 1.5081206497vw, 1.53125rem);
  column-gap: clamp(1.125rem, .4001595128rem + 1.5081206497vw, 1.53125rem);
  margin-top: 70px
}
@media(max-width: 768px) {
  .footer__main {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    row-gap: 40px;
    margin-top: 40px
  }
}
@media(max-width: 768px) {
  .footer__box {
    max-width: 550px;
    width: 100%
  }
}
.footer__button-wrapper {
  max-width: 540px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  margin-left: auto
}
@media(max-width: 768px) {
  .footer__button-wrapper {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    row-gap: 20px
  }
}
.footer__button {
  max-width: 250px;
  width: 100%;
  height: 40px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  color: var(--base);
  border-radius: 30px;
  letter-spacing: .15em
}
.footer__button_reservation {
  visibility: hidden;
  -webkit-column-gap: 5px;
  -moz-column-gap: 5px;
  column-gap: 5px;
  background-color: var(--main-2)
}
.footer__button_reservation::before {
  content: "";
  width: 22px;
  aspect-ratio: 22/16;
  background: url(../images/icon-pc.svg) no-repeat 0 0/contain
}
.footer__button_tel {
  -webkit-column-gap: 5px;
  -moz-column-gap: 5px;
  column-gap: 5px;
  background-color: var(--main-1)
}
.footer__table {
  max-width: 550px;
  width: 100%;
  color: var(--brown);
  font-weight: 500;
  margin-top: 44px
}
.footer__tr {
  border-bottom: 1px solid var(--brown)
}
.footer__tr:first-of-type {
  border-top: 1px solid var(--brown)
}
.footer__title-th {
  width: 30.7%;
  text-align: center;
  letter-spacing: .15em;
  padding-top: 18px;
  padding-bottom: 17px
}
.footer__weekday-th {
  text-align: center;
  padding-top: 18px
}
.footer__time-td {
  text-align: center;
  letter-spacing: .15em;
  padding-top: 18px;
  padding-bottom: 17px
}
.footer__td {
  color: var(--main-2);
  text-align: center;
  padding-top: 18px
}
.footer__td_slash {
  color: var(--brown)
}
.footer__text {
  font-size: .9375rem;
  letter-spacing: .15em;
  margin-top: 10px
}
@media(max-width: 768px) {
  .footer__map-wrapper {
    width: 100%
  }
}
.footer__address {
  font-size: 1.25rem;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: .15em
}
@media(max-width: 768px) {
  .footer__address {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin-inline: auto
  }
}
.footer__map {
  max-width: 600px;
  margin-top: 19px
}
@media(max-width: 768px) {
  .footer__map {
    max-width: inherit;
    width: 100vw;
    margin-inline: calc(50% - 50vi)
  }
}
.footer__gmap {
  width: 100%;
  height: 240px
}
.footer__nav {
  margin-top: 63px
}
.footer__copy {
  height: 50px;
  display: grid;
  place-items: center;
  background-color: var(--main-1);
  color: var(--base);
  font-size: .75rem;
  letter-spacing: .15em
}
.footer__page-top-button {
  width: 43px;
  aspect-ratio: 1/1;
  display: grid;
  place-items: center;
  position: absolute;
  right: 20px;
  bottom: 50px;
  z-index: 5;
  background-color: var(--main-1);
  color: var(--base);
  border-radius: 50%
}
@media (max-width: 960px) {
  .footer__page-top-button {
    bottom: 90px!important;
  }
}
@media(max-width: 768px) {
  .footer__page-top-button {
    right: 10px
  }
}
@media(hover: hover)and (pointer: fine) {
  .footer__button {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .footer__button:hover, .footer__button:focus {
    opacity: .7 !important
  }
}
.footer-nav__items {
  max-width: 882px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  margin-inline: auto
}
@media(max-width: 768px) {
  .footer-nav__items {
    max-width: 440px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    justify-items: center;
    row-gap: 30px
  }
}
@media(max-width: 500px) {
  .footer-nav__items {
    max-width: 300px;
    grid-template-columns: repeat(2, 1fr);
    justify-items: normal
  }
}
.footer-nav__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 8px;
  -moz-column-gap: 8px;
  column-gap: 8px;
  color: var(--brown);
  font-weight: 500;
  letter-spacing: .15em
}
.footer-nav__link::before {
  content: "";
  width: 15px;
  height: 5px;
  background-color: var(--main-1)
}
@media(hover: hover)and (pointer: fine) {
  .footer-nav__link {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .footer-nav__link:hover, .footer-nav__link:focus {
    opacity: .7
  }
}
.lower-mv__img {
  aspect-ratio: 1920/507;
  display: grid;
  place-items: center;
  background: url(../images/lower-mv.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/lower-mv.webp) 1x, url(../images/lower-mv@2x.webp) 2x);
  background-image: image-set(url(../images/lower-mv.webp) 1x, url(../images/lower-mv@2x.webp) 2x)
}
@media(max-width: 768px) {
  .lower-mv__img {
    aspect-ratio: 774/315;
    background: url(../images/lower-mv_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/lower-mv_sp.webp) 1x, url(../images/lower-mv_sp@2x.webp) 2x);
    background-image: image-set(url(../images/lower-mv_sp.webp) 1x, url(../images/lower-mv_sp@2x.webp) 2x)
  }
}
.lower-mv__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 6px;
  color: var(--base)
}
.lower-mv__jp {
  font-size: 1.25rem;
  font-weight: 500;
  letter-spacing: .1em;
  text-shadow: 0px 0px 6px rgba(64, 64, 64, .88)
}
.lower-mv__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1.5625rem, -.1358695652rem + 6.7934782609vw, 3.125rem);
  font-weight: 500;
  letter-spacing: .12em;
  text-shadow: 0px 0px 6px rgba(64, 64, 64, .88)
}
.br-950-b {
  display: none
}
@media(max-width: 950px) {
  .br-950-b {
    display: block
  }
}
.br-sp-b {
  display: none
}
@media(max-width: 768px) {
  .br-sp-b {
    display: block
  }
}
.br-650-b {
  display: none
}
@media(max-width: 650px) {
  .br-650-b {
    display: block
  }
}
.br-600-b {
  display: none
}
@media(max-width: 600px) {
  .br-600-b {
    display: block
  }
}
.br-500-b {
  display: none
}
@media(max-width: 500px) {
  .br-500-b {
    display: block
  }
}
.hamburger {
  width: 71px;
  height: 65px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  position: relative;
  background-color: var(--main-2);
  z-index: 30;
  margin-left: auto;
  padding-bottom: 3px
}
@media(min-width: 901px) {
  .hamburger {
    display: none
  }
}
.hamburger[aria-expanded=true] .hamburger__line {
  background-color: rgba(0, 0, 0, 0)
}
.hamburger[aria-expanded=true] .hamburger__line::before {
  left: -1px;
  -webkit-transform: translateY(-13px) rotate(135deg);
  -ms-transform: translateY(-13px) rotate(135deg);
  transform: translateY(-13px) rotate(135deg)
}
.hamburger[aria-expanded=true] .hamburger__line::after {
  -webkit-transform: translateY(9px) rotate(-135deg);
  -ms-transform: translateY(9px) rotate(-135deg);
  transform: translateY(9px) rotate(-135deg)
}
.hamburger__line {
  width: 38px;
  height: 2px;
  display: inline-block;
  position: absolute;
  top: 26px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-transition: .5s all;
  transition: .5s all;
  background-color: var(--base)
}
.hamburger__line::before {
  content: "";
  width: 100%;
  height: 2px;
  display: inline-block;
  position: absolute;
  top: 11px;
  left: 0;
  -webkit-transition: -webkit-transform .5s;
  transition: -webkit-transform .5s;
  transition: transform .5s;
  transition: transform .5s, -webkit-transform .5s;
  background-color: var(--base)
}
.hamburger__line::after {
  content: "";
  width: 100%;
  height: 2px;
  display: inline-block;
  position: absolute;
  bottom: 10px;
  left: 0;
  -webkit-transition: -webkit-transform .5s;
  transition: -webkit-transform .5s;
  transition: transform .5s;
  transition: transform .5s, -webkit-transform .5s;
  background-color: var(--base)
}
.hamburger__text {
  color: var(--base);
  font-size: .875rem;
  letter-spacing: .1em;
  margin-top: auto
}
@media(hover: hover)and (pointer: fine) {
  .hamburger {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .hamburger:hover {
    opacity: .7
  }
}
.drawer {
  width: 100%;
  height: 100vh;
  -webkit-transform: translateX(100%);
  -ms-transform: translateX(100%);
  transform: translateX(100%);
  -webkit-transition: .5s;
  transition: .5s;
  background: -webkit-gradient(linear, left top, left bottom, from(#9dcc2d), to(#3d8f4f));
  background: -webkit-linear-gradient(#9dcc2d 0%, #3d8f4f 100%);
  background: linear-gradient(#9dcc2d 0%, #3d8f4f 100%);
  z-index: 15;
  overflow: auto;
  overscroll-behavior-y: contain;
  visibility: hidden
}
.drawer[aria-hidden=false] {
  -webkit-transform: translateY(0);
  -ms-transform: translateY(0);
  transform: translateY(0);
  visibility: visible
}
.drawer_position {
  position: fixed;
  top: 0;
  right: 0
}
.drawer__inner {
  padding-bottom: 100px
}
.drawer__top {
  width: 100%;
  height: 65px;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  background-color: var(--main-2);
  z-index: 1
}
.drawer__nav {
  margin-top: 66px;
  padding-right: 10px;
  padding-left: 10px
}
.drawer__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 25px
}
.drawer__item_price {
  margin-top: 35px
}
.drawer__link {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 9px;
  color: var(--base);
  font-weight: bold;
  letter-spacing: .12em;
  margin-inline: auto
}
.drawer__en {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: .9375rem;
  font-weight: bold;
  letter-spacing: .1em
}
.drawer__sub-items {
  max-width: 417px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4px 15px;
  margin-top: 14px;
  margin-inline: auto
}
.drawer__sub-link {
  width: 100%;
  height: 42px;
  display: grid;
  place-items: center;
  background-color: #f2edde;
  font-size: .875rem
}
.is-drawer-active {
  overflow: hidden
}
@media(hover: hover)and (pointer: fine) {
  .drawer__link {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .drawer__link:hover, .drawer__link:focus {
    opacity: .7
  }
  .drawer__sub-link {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .drawer__sub-link:hover, .drawer__sub-link:focus {
    opacity: .7
  }
}
.c-link-1 {
  width: 250px;
  height: 80px;
  display: grid;
  place-items: center;
  background: -webkit-gradient(linear, left top, left bottom, from(#9dcc2d), to(#3d8f4f));
  background: -webkit-linear-gradient(#9dcc2d 0%, #3d8f4f 100%);
  background: linear-gradient(#9dcc2d 0%, #3d8f4f 100%);
  color: var(--base);
  font-size: 1.125rem;
  font-weight: bold;
  letter-spacing: .18em;
  -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, .16);
  box-shadow: 0px 3px 6px rgba(0, 0, 0, .16)
}
@media(hover: hover)and (pointer: fine) {
  .c-link-1 {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .c-link-1:hover, .c-link-1:focus {
    opacity: .7 !important
  }
}
.c-link-2 {
  width: 283px;
  height: 61px;
  display: grid;
  place-items: center;
  background: -webkit-gradient(linear, left top, left bottom, from(#9dcc2d), to(#3d8f4f));
  background: -webkit-linear-gradient(#9dcc2d 0%, #3d8f4f 100%);
  background: linear-gradient(#9dcc2d 0%, #3d8f4f 100%);
  color: var(--base);
  font-size: 1.125rem;
  font-weight: bold;
  -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, .16);
  box-shadow: 0px 3px 6px rgba(0, 0, 0, .16)
}
@media(hover: hover)and (pointer: fine) {
  .c-link-2 {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .c-link-2:hover, .c-link-2:focus {
    opacity: .7 !important
  }
}
.c-title-1 {
  color: var(--main-1);
  font-family: "Zen Old Mincho", serif;
  font-size: 2.5rem;
  font-weight: bold;
  text-align: center;
  border-bottom: 3px solid var(--main-1);
  padding-bottom: 30px
}
.c-title-2__title {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  row-gap: 10px
}
.c-title-2__jp {
  color: var(--brown);
  font-size: 1.25rem;
  font-weight: 500
}
.c-title-2__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 2.5rem;
  font-weight: 500;
  letter-spacing: .1em
}
.c-title-2__line {
  width: 45%;
  height: 1px;
  display: inline-block;
  background-color: var(--main-1)
}
@media(max-width: 768px) {
  .c-title-2__line {
    width: 67%
  }
}
.c-title-3 {
  background-color: var(--main-1);
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.875rem;
  font-weight: bold;
  line-height: 1.5;
  padding: 0 clamp(.9375rem, -.0815217391rem + 4.0760869565vw, 1.875rem)
}
.c-title-4 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 15px;
  color: var(--main-1);
  font-family: "Zen Old Mincho", serif;
  font-size: 2.875rem;
  font-weight: 700;
  letter-spacing: .1em
}
.c-title-4::before {
  content: "";
  max-width: 186px;
  width: 100%;
  aspect-ratio: 186/86;
  background: url(../images/c-title-deco.webp) no-repeat 0 0/contain;
  background-image: -webkit-image-set(url(../images/c-title-deco.webp) 1x, url(../images/c-title-deco@2x.webp) 2x);
  background-image: image-set(url(../images/c-title-deco.webp) 1x, url(../images/c-title-deco@2x.webp) 2x)
}
.c-title-5 {
  color: var(--main-1);
  font-family: "Zen Old Mincho", serif;
  font-size: 2.25rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .05em;
  border-bottom: 2px solid var(--main-2);
  padding-bottom: 15px
}
.top-mv {
  position: relative
}
.top-mv__title-wrapper {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  position: absolute;
  top: 40.9%;
  left: 7.8%;
  z-index: 3;
  white-space: pre-line;
  text-shadow: 0px 3px 6px rgba(0, 0, 0, .3)
}
@media(max-width: 768px) {
  .top-mv__title-wrapper {
    top: 15.5%;
    left: 6%
  }
}
.top-mv__title {
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(2rem, .5227771679rem + 3.0735455543vw, 3.75rem);
  font-weight: bold;
  line-height: 1.45;
  letter-spacing: .1em
}
@media(max-width: 768px) {
  .top-mv__title {
    font-size: clamp(1.25rem, .4347826087rem + 3.2608695652vw, 2rem)
  }
}
@media(max-width: 768px) {
  .top-mv__slide img {
    height: calc(100dvh - 65px);
    min-height: 400px;
    -o-object-fit: cover;
    object-fit: cover
  }
}
.top-mv__bg {
  aspect-ratio: 192/10;
  background: url(../images/top-mv-bg.webp) no-repeat top right/contain;
  background-image: -webkit-image-set(url(../images/top-mv-bg.webp) 1x, url(../images/top-mv-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-mv-bg.webp) 1x, url(../images/top-mv-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .top-mv__bg {
    height: 100px;
    aspect-ratio: inherit;
    background: url(../images/top-mv-bg_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/top-mv-bg_sp.webp) 1x, url(../images/top-mv-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-mv-bg_sp.webp) 1x, url(../images/top-mv-bg_sp@2x.webp) 2x)
  }
}
.top-news {
  min-height: 600px;
  background: url(../images/top-news-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-news-bg.webp) 1x, url(../images/top-news-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-news-bg.webp) 1x, url(../images/top-news-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .top-news {
    background: url(../images/top-news-bg_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/top-news-bg_sp.webp) 1x, url(../images/top-news-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-news-bg_sp.webp) 1x, url(../images/top-news-bg_sp@2x.webp) 2x)
  }
}
.top-news__inner {
  max-width: 1200px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 82px 20px 100px
}
@media(max-width: 768px) {
  .top-news__inner {
    padding-top: 50px;
    padding-bottom: 60px
  }
}
.top-news__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 6px
}
.top-news__jp {
  color: #777;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.125rem;
  letter-spacing: .1em
}
.top-news__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 3.4375rem;
  font-weight: 500;
  letter-spacing: .15em
}
.top-news__list {
  max-width: 1200px;
  margin-top: 35px
}
.top-news__main {
  display: grid;
  grid-template-columns: 132px 1fr;
  -webkit-column-gap: 29px;
  -moz-column-gap: 29px;
  column-gap: 29px;
  border-bottom: 1px dashed #ccc;
  padding-top: 17px;
  padding-bottom: 12px
}
@media(max-width: 768px) {
  .top-news__main {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 13px;
    padding-bottom: 15px
  }
}
.top-news__date {
  width: 130px;
  height: 30px;
  display: grid;
  place-items: center;
  background-color: var(--base);
  color: var(--main-2);
  font-weight: bold;
  letter-spacing: .18em;
  border: 1px solid var(--main-1);
  border-radius: 10px
}
.top-news__post-title {
  font-weight: bold;
  letter-spacing: .12em;
  line-height: 1.75
}
.top-news__button-wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 40px
}
@media(max-width: 768px) {
  .top-news__button-wrapper {
    margin-top: 30px
  }
}
.top-news__no-post {
  font-size: 1.25rem;
  text-align: center
}
.top-concept {
  overflow: hidden;
  background: url(../images/top-concept-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-concept-bg.webp) 1x, url(../images/top-concept-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-concept-bg.webp) 1x, url(../images/top-concept-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .top-concept {
    background: url(../images/top-concept-bg_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/top-concept-bg_sp.webp) 1x, url(../images/top-concept-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-concept-bg_sp.webp) 1x, url(../images/top-concept-bg_sp@2x.webp) 2x)
  }
}
.top-concept__inner {
  max-width: 1620px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 100px 20px 90px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: clamp(1.25rem, -46.6666666667rem + 51.1111111111vw, 7rem);
  -moz-column-gap: clamp(1.25rem, -46.6666666667rem + 51.1111111111vw, 7rem);
  column-gap: clamp(1.25rem, -46.6666666667rem + 51.1111111111vw, 7rem)
}
@media(max-width: 768px) {
  .top-concept__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 80px;
    padding-right: 16px;
    padding-left: 16px
  }
}
.top-concept__img {
  width: 100%;
  aspect-ratio: 1008/902;
  position: relative;
  z-index: 1;
  margin-left: calc(50% - 50vi)
}
@media(max-width: 768px) {
  .top-concept__img {
    width: 100vw;
    margin-inline: calc(50% - 50vi)
  }
}
.top-concept__main {
  max-width: 650px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative
}
.top-concept__main::before {
  content: "";
  width: clamp(6.25rem, -1.8241600354rem + 16.7992926614vw, 18.125rem);
  aspect-ratio: 290/323;
  position: absolute;
  top: calc(clamp(4.375rem, -.7669650752rem + 10.6984969054vw, 11.9375rem)*-1);
  right: calc(clamp(2.125rem, -2.8469827586rem + 10.3448275862vw, 9.4375rem)*-1);
  background: url(../images/top-concept-deco-1.webp) no-repeat 0 0/contain;
  background-image: -webkit-image-set(url(../images/top-concept-deco-1.webp) 1x, url(../images/top-concept-deco-1@2x.webp) 2x);
  background-image: image-set(url(../images/top-concept-deco-1.webp) 1x, url(../images/top-concept-deco-1@2x.webp) 2x)
}
.top-concept__main::after {
  content: "";
  width: clamp(6.25rem, -1.8241600354rem + 16.7992926614vw, 18.125rem);
  aspect-ratio: 290/323;
  position: absolute;
  bottom: calc(clamp(5.25rem, .0655393457rem + 10.7869142352vw, 12.875rem)*-1);
  left: calc(clamp(1.875rem, -1.6096374889rem + 7.2502210433vw, 7rem)*-1);
  background: url(../images/top-concept-deco-2.webp) no-repeat 0 0/contain;
  background-image: -webkit-image-set(url(../images/top-concept-deco-2.webp) 1x, url(../images/top-concept-deco-2@2x.webp) 2x);
  background-image: image-set(url(../images/top-concept-deco-2.webp) 1x, url(../images/top-concept-deco-2@2x.webp) 2x)
}
.top-concept__title {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 7px;
  border-bottom: 2px dashed var(--main-3);
  padding-bottom: 31px
}
.top-concept__jp {
  color: #777;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.125rem;
  letter-spacing: .1em
}
.top-concept__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: 3.4375rem;
  font-weight: 500;
  letter-spacing: .15em
}
.top-concept__top-text {
  max-width: 600px;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.125rem;
  line-height: 1.7777777778;
  text-align: center;
  letter-spacing: .12em;
  white-space: pre-line;
  margin-top: 25px
}
.top-concept__bottom-text {
  max-width: 600px;
  font-family: "Zen Old Mincho", serif;
  line-height: 2;
  letter-spacing: .12em;
  white-space: pre-line;
  margin-top: 23px
}
.top-concept__link {
  margin-top: 42px;
  margin-inline: auto
}
.top-welcome {
  position: relative
}
.top-welcome_pos {
  margin-top: -6px
}
.top-welcome__link {
  width: clamp(11rem, 3.7669655415rem + 15.0492264416vw, 17.6875rem);
  height: clamp(2.5rem, 1.0804324895rem + 2.9535864979vw, 3.8125rem);
  position: absolute;
  bottom: 30.9%;
  left: calc(50% + 21px);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%)
}
@media(max-width: 1480px) {
  .top-welcome__link {
    bottom: clamp(4.375rem, -2.4524437412rem + 14.2053445851vw, 10.6875rem)
  }
}
@media(max-width: 768px) {
  .top-welcome__link {
    width: 283px;
    height: 61px;
    bottom: 13%;
    left: 50%
  }
}
.top-feature {
  background: url(../images/top-feature-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-feature-bg.webp) 1x, url(../images/top-feature-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-feature-bg.webp) 1x, url(../images/top-feature-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .top-feature {
    background: url(../images/top-feature-bg_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/top-feature-bg_sp.webp) 1x, url(../images/top-feature-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-feature-bg_sp.webp) 1x, url(../images/top-feature-bg_sp@2x.webp) 2x)
  }
}
.top-feature__inner {
  max-width: 1200px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 111px 20px 101px
}
@media(max-width: 768px) {
  .top-feature__inner {
    padding-top: clamp(3.125rem, -1.0190217391rem + 16.5760869565vw, 6.9375rem);
    padding-bottom: clamp(5rem, 3.5733695652rem + 5.7065217391vw, 6.3125rem)
  }
}
.top-feature__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 14px
}
.top-feature__jp {
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.25rem;
  letter-spacing: .1em
}
.top-feature__en {
  color: #ccc;
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(3.75rem, .3532608696rem + 13.5869565217vw, 6.875rem);
  letter-spacing: .15em
}
.top-feature__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: clamp(3.125rem, 1.4266304348rem + 6.7934782609vw, 4.6875rem);
  margin-top: clamp(3.75rem, .8288043478rem + 11.6847826087vw, 6.4375rem)
}
@media(max-width: 768px) {
  .top-feature__items {
    max-width: 600px;
    margin-inline: auto
  }
}
.top-feature__item {
  width: 100%;
  position: relative
}
@media(max-width: 768px) {
  .top-feature__item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 30px;
    border: 1px solid var(--base);
    padding: 30px 16px
  }
}
.top-feature__frame {
  max-width: clamp(31.25rem, -15.1194960861rem + 96.4774951076vw, 62.0625rem);
  width: 100%;
  border: 1px solid var(--base);
  margin-top: 60px;
  padding-top: 39px;
  padding-bottom: 31px
}
@media(max-width: 768px) {
  .top-feature__frame {
    max-width: inherit;
    border: none;
    margin-top: 0;
    padding: 0
  }
}
.top-feature__frame_odd {
  padding-right: 16px;
  padding-left: clamp(1rem, -1.2573385519rem + 4.6966731898vw, 2.5rem)
}
@media(max-width: 768px) {
  .top-feature__frame_odd {
    padding: 0
  }
}
.top-feature__frame_even {
  margin-left: auto;
  padding-right: clamp(1rem, -1.9157289628rem + 6.0665362035vw, 2.9375rem);
  padding-left: 16px
}
@media(max-width: 768px) {
  .top-feature__frame_even {
    padding: 0
  }
}
.top-feature__text-box {
  max-width: clamp(23.75rem, -1.6450587084rem + 52.8375733855vw, 40.625rem);
  color: var(--base)
}
@media(max-width: 768px) {
  .top-feature__text-box {
    max-width: inherit
  }
}
.top-feature__text-box_even {
  margin-left: auto
}
.top-feature__item-title {
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1.875rem, .4641634051rem + 2.9354207436vw, 2.8125rem);
  letter-spacing: .15em
}
.top-feature__item-subtitle {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, .873776908rem + .782778865vw, 1.5rem);
  line-height: 1.6666666667;
  letter-spacing: .12em;
  white-space: pre-line;
  margin-top: 22px
}
.top-feature__item-text {
  font-size: clamp(1rem, .811888454rem + .3913894325vw, 1.125rem);
  line-height: 1.7777777778;
  letter-spacing: .1em;
  white-space: pre-line;
  margin-top: 14px
}
.top-feature__img {
  max-width: clamp(20rem, 6.8321917808rem + 27.397260274vw, 28.75rem);
  position: absolute;
  top: 0
}
@media(max-width: 768px) {
  .top-feature__img {
    max-width: inherit;
    position: static
  }
}
.top-feature__img_odd {
  right: 0
}
.top-feature__img_even {
  left: 0
}
.top-medical {
  background: url(../images/top-medical_bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-medical_bg.webp) 1x, url(../images/top-medical_bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-medical_bg.webp) 1x, url(../images/top-medical_bg@2x.webp) 2x)
}
.top-medical__inner {
  max-width: 1200px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 76px 20px 71px
}
@media(max-width: 768px) {
  .top-medical__inner {
    padding-top: clamp(3.125rem, -1.0190217391rem + 16.5760869565vw, 6.9375rem);
    padding-bottom: clamp(5rem, 3.5733695652rem + 5.7065217391vw, 6.3125rem)
  }
}
.top-medical__title {
  max-width: 750px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  row-gap: 10px;
  border-bottom: 1px solid var(--main-3);
  padding-bottom: 20px
}
.top-medical__jp {
  color: #777;
  font-size: 1.25rem
}
.top-medical__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1.875rem, -.1630434783rem + 8.152173913vw, 3.75rem)
}
.top-medical__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  -webkit-column-gap: clamp(.9375rem, -30rem + 45vw, 3.75rem);
  -moz-column-gap: clamp(.9375rem, -30rem + 45vw, 3.75rem);
  column-gap: clamp(.9375rem, -30rem + 45vw, 3.75rem);
  margin-top: 51px
}
@media(max-width: 1000px) {
  .top-medical__items {
    grid-template-columns: repeat(2, 1fr);
    row-gap: 40px
  }
}
@media(max-width: 768px) {
  .top-medical__items {
    max-width: 600px;
    grid-template-columns: 1fr;
    row-gap: 50px;
    margin-inline: auto
  }
}
.top-medical__tooth {
  font-size: 2.125rem
}
.top-medical__item-title {
  height: 54px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 18px;
  -moz-column-gap: 18px;
  column-gap: 18px;
  color: var(--base);
  font-size: 1.25rem;
  border-radius: 10px 0px;
  padding-left: 12px
}
.top-medical__item-title_1 {
  background-color: #ec6472
}
.top-medical__item-title_2 {
  background-color: #5c4500
}
.top-medical__item-title_3 {
  background-color: #4c764f
}
.top-medical__img {
  margin-top: 12px
}
.top-medical__link-items {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  row-gap: clamp(.9375rem, -.6344221106rem + 2.5125628141vw, 1.25rem);
  margin-top: 22px
}
.top-medical__link {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: 5px;
  -moz-column-gap: 5px;
  column-gap: 5px;
  font-size: clamp(1.125rem, .4962311558rem + 1.0050251256vw, 1.25rem);
  font-weight: 500;
  margin-left: 5px
}
.top-medical__arrow {
  color: var(--main-1);
  font-size: 1.5625rem
}
.top-blanca {
  overflow: hidden;
  background: url(../images/top-blanca-bg.webp) no-repeat center center/cover;
  background-image: -webkit-image-set(url(../images/top-blanca-bg.webp) 1x, url(../images/top-blanca-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-blanca-bg.webp) 1x, url(../images/top-blanca-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .top-blanca {
    background: url(../images/top-blanca-bg_sp.webp) no-repeat center center/cover;
    background-image: -webkit-image-set(url(../images/top-blanca-bg_sp.webp) 1x, url(../images/top-blanca-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-blanca-bg_sp.webp) 1x, url(../images/top-blanca-bg_sp@2x.webp) 2x)
  }
}
.top-greeting {
  overflow: hidden;
  background: url(../images/top-greeting-bg.webp) no-repeat center right/cover;
  background-image: -webkit-image-set(url(../images/top-greeting-bg.webp) 1x, url(../images/top-greeting-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-greeting-bg.webp) 1x, url(../images/top-greeting-bg@2x.webp) 2x)
}
.top-greeting__inner {
  max-width: 1672px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 56px 20px 100px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: clamp(1.25rem, -58.75rem + 60vw, 3.125rem);
  -moz-column-gap: clamp(1.25rem, -58.75rem + 60vw, 3.125rem);
  column-gap: clamp(1.25rem, -58.75rem + 60vw, 3.125rem)
}
@media(max-width: 768px) {
  .top-greeting__inner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 50px;
    padding-top: clamp(3.125rem, -1.0190217391rem + 16.5760869565vw, 6.9375rem);
    padding-bottom: clamp(5rem, 3.5733695652rem + 5.7065217391vw, 6.3125rem)
  }
}
.top-greeting__img {
  max-width: clamp(18.75rem, -9.3587545126rem + 58.4837545126vw, 49.125rem)
}
@media(max-width: 768px) {
  .top-greeting__img {
    max-width: inherit;
    width: 100vw;
    margin-inline: calc(50% - 50vi)
  }
}
.top-greeting__main {
  max-width: 782px;
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--base);
  -webkit-box-shadow: 0px 3px 6px rgba(0, 0, 0, .16);
  box-shadow: 0px 3px 6px rgba(0, 0, 0, .16);
  padding: 80px 15px 81px
}
@media(max-width: 768px) {
  .top-greeting__main {
    max-width: 600px;
    padding-top: 40px;
    padding-bottom: 60px
  }
}
.top-greeting__deco {
  width: 186px;
  aspect-ratio: 186/160;
  background: url(../images/top-greeting-deco.webp) no-repeat center right/cover;
  background-image: -webkit-image-set(url(../images/top-greeting-deco.webp) 1x, url(../images/top-greeting-deco@2x.webp) 2x);
  background-image: image-set(url(../images/top-greeting-deco.webp) 1x, url(../images/top-greeting-deco@2x.webp) 2x);
  margin-left: 14px
}
.top-greeting__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 10px;
  margin-top: -10px
}
.top-greeting__jp {
  color: #777;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.25rem;
  letter-spacing: .15em
}
.top-greeting__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(3rem, 2.1847826087rem + 3.2608695652vw, 3.75rem);
  letter-spacing: .15em
}
.top-greeting__text {
  max-width: 648px;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 2;
  letter-spacing: .1em;
  white-space: pre-line;
  margin-top: 47px
}
.top-greeting__link {
  margin-top: 45px
}
.top-recruit {
  position: relative;
  background-color: #e4e9e7
}
.top-recruit__inner {
  max-width: 1820px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 100px 20px 100px
}
@media(max-width: 768px) {
  .top-recruit__inner {
    max-width: 550px;
    padding: 50px 20px 65px
  }
}
.top-recruit__contents {
  display: grid;
  grid-template-columns: 1fr clamp(24.375rem, 1.6998149861rem + 47.1785383904vw, 56.25rem);
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: clamp(1.25rem, -91rem + 82vw, 3.8125rem);
  -moz-column-gap: clamp(1.25rem, -91rem + 82vw, 3.8125rem);
  column-gap: clamp(1.25rem, -91rem + 82vw, 3.8125rem);
  border-top: 2px solid var(--brown);
  border-right: 2px solid var(--brown);
  border-bottom: 2px solid var(--brown);
  border-radius: 0 50px 50px 0;
  padding: clamp(0rem, -2.1341350601rem + 4.440333025vw, 3rem) clamp(.9375rem, -1.4889705882rem + 3.8823529412vw, 3rem) clamp(1.875rem, 1.0746993525rem + 1.6651248844vw, 3rem) clamp(0rem, -3.5294117647rem + 5.6470588235vw, 3rem)
}
@media(max-width: 768px) {
  .top-recruit__contents {
    display: contents
  }
}
.top-recruit__box {
  width: 100%;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  margin-top: 34px
}
.top-recruit__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 9px
}
.top-recruit__jp {
  color: #777;
  font-size: 1.25rem;
  letter-spacing: .15em
}
.top-recruit__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(2.5625rem, 1.7177382054rem + 1.7576318224vw, 3.75rem);
  letter-spacing: .15em
}
.top-recruit__line {
  width: 46.875%;
  height: 1px;
  position: absolute;
  top: clamp(15.5rem, 9.8978954672rem + 11.6558741906vw, 23.375rem);
  left: 0;
  background-color: var(--brown)
}
@media(max-width: 768px) {
  .top-recruit__line {
    width: 100%;
    display: block;
    position: static;
    margin-top: 27px
  }
}
.top-recruit__line::after {
  content: "";
  max-width: clamp(3.75rem, 1.9715541166rem + 3.7002775208vw, 6.25rem);
  width: 100%;
  aspect-ratio: 10/9;
  position: absolute;
  right: 8.9%;
  bottom: 0;
  background: url(../images/top-recruit-deco.webp) no-repeat 0 0/contain;
  background-image: -webkit-image-set(url(../images/top-recruit-deco.webp) 1x, url(../images/top-recruit-deco@2x.webp) 2x);
  background-image: image-set(url(../images/top-recruit-deco.webp) 1x, url(../images/top-recruit-deco@2x.webp) 2x)
}
@media(max-width: 768px) {
  .top-recruit__line::after {
    max-width: clamp(3.125rem, 2.4456521739rem + 2.7173913043vw, 3.75rem)
  }
}
.top-recruit__text {
  font-size: clamp(1.0625rem, .7512719704rem + .6475485661vw, 1.5rem);
  line-height: 1.6666666667;
  text-align: center;
  letter-spacing: .15em;
  white-space: pre-line;
  margin-top: clamp(3.375rem, 1.7299375578rem + 3.4227567068vw, 5.6875rem)
}
@media(max-width: 768px) {
  .top-recruit__text {
    margin-top: 35px
  }
}
.top-recruit__link {
  margin-top: 42px;
  margin-inline: auto
}
.top-recruit__img {
  max-width: 900px;
  width: 100%
}
@media(max-width: 768px) {
  .top-recruit__img {
    margin-top: 42px;
    margin-inline: auto
  }
}
.top-insta_pos {
  margin-top: 107px
}
.top-insta__inner {
  /*max-width: 1200px;*/
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  /*padding-right: 20px;
  padding-left: 20px*/
}
.top-insta__title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  row-gap: 10px
}
.top-insta__jp {
  color: #777;
  font-size: 1.25rem;
  letter-spacing: .15em
}
.top-insta__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(3.125rem, 2.4456521739rem + 2.7173913043vw, 3.75rem);
  letter-spacing: .15em
}
.top-insta__body {
  position: relative;
  margin-top: 62px
}
.top-insta__logo {
  max-width: clamp(6.25rem, 2.1666666667rem + 16.3333333333vw, 12.375rem);
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 3
}
.top-insta__swiper_bottom {
  margin-top: 30px
}
/*Instagram slider*/
.insta-slider-wrapper {
  display: flex;
  overflow: hidden;
}
.insta-slider {
  animation: scroll-left 60s infinite linear .5s both;
  display: flex;
}
.insta-slide {
  width: calc(100vw / 4);
}
.insta-slide img {
  display: block;
  width: 100%;
}
@keyframes scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

@media(max-width: 768px) {
  .top-insta__swiper_bottom {
    margin-top: 15px
  }
  .insta-slide {
    width: calc(100vw / 3);
  }
}
.top-insta__wrapper {
  -webkit-transition-timing-function: linear;
  transition-timing-function: linear
}
.top-insta__slide img {
  aspect-ratio: 1/1;
  -o-object-fit: cover;
  object-fit: cover
}
.medical-bg {
  background: url(../images/medical-bg.webp) repeat-y top center/100%;
  background-image: -webkit-image-set(url(../images/medical-bg.webp) 1x, url(../images/medical-bg@2x.webp) 2x);
  background-image: image-set(url(../images/medical-bg.webp) 1x, url(../images/medical-bg@2x.webp) 2x);
  padding-top: 100px;
  padding-bottom: 100px
}
.medical-menu {
  max-width: 1200px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px
}
.medical-main_pos {
  margin-top: 100px
}
.medical-main__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px
}
.medical-main__body {
  margin-top: 70px
}
.medical-body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 50px
}
.medical-body__subtitle {
  margin-top: 30px
}
.medical-body__text {
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .1em;
  white-space: pre-line;
  margin-top: 20px
}
.medical-body__text_center {
  text-align: center
}
.medical-body__text_whitening {
  color: red
}
.medical-body__box {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-column-gap: 20px;
  -moz-column-gap: 20px;
  column-gap: 20px;
  margin-top: 30px;
  margin-inline: auto
}
@media(max-width: 768px) {
  .medical-body__box {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    row-gap: 20px
  }
}
.medical-body__box_780 {
  max-width: 780px
}
.medical-body__box-normal {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-column-gap: 20px;
  -moz-column-gap: 20px;
  column-gap: 20px;
  margin-top: 30px
}
@media(max-width: 768px) {
  .medical-body__box-normal {
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -webkit-flex-direction: column-reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
    row-gap: 20px;
    margin-inline: auto
  }
}
.medical-body__box-normal_780 {
  max-width: 780px
}
.medical-body__box-text {
  max-width: 500px;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .1em;
  white-space: pre-line
}
.medical-body__box-text2 {
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .1em;
  white-space: pre-line
}
.medical-body__box-text_wide {
  max-width: 100%
}
.medical-body__box-img {
  max-width: 250px;
  width: 100%
}
.medical-body__img-l {
  max-width: 640px;
  margin-inline: auto
}
.medical-body__img-l_one-off {
  margin-top: 30px
}
.medical-body__child-table {
  background-color: var(--base);
  margin-top: 30px;
  padding: 5px 20px 20px
}
.medical-body__child-table-dl {
  display: grid;
  grid-template-columns: clamp(7.5rem, -10.494011976rem + 47.9041916168vw, 12.5rem) 1fr;
  font-weight: 500
}
@media(max-width: 600px) {
  .medical-body__child-table-dl {
    grid-template-columns: 1fr
  }
}
.medical-body__child-table-dt {
  display: grid;
  place-items: center;
  color: var(--base);
  font-size: 1.375rem
}
@media(max-width: 600px) {
  .medical-body__child-table-dt {
    min-height: 50px
  }
}
.medical-body__child-table-dt_1 {
  background-color: #f99
}
.medical-body__child-table-dt_2 {
  background-color: #f93
}
.medical-body__child-table-dt_3 {
  background-color: #fc3
}
.medical-body__child-table-dt_4 {
  background-color: #6c6
}
.medical-body__child-table-dt_5 {
  background-color: #6cf
}
.medical-body__child-table-dd {
  line-height: 1.75;
  letter-spacing: .1em;
  white-space: pre-line;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  padding: 10px 10px
}
@media(max-width: 600px) {
  .medical-body__child-table-dd {
    border-bottom: none;
    border-left: 1px solid #ccc;
    padding-bottom: 25px
  }
}
.medical-body__child-table-dd:first-of-type {
  border-top: 1px solid #ccc
}
@media(max-width: 600px) {
  .medical-body__child-table-dd:first-of-type {
    border-top: none
  }
}
@media(max-width: 600px) {
  .medical-body__child-table-dd:last-of-type {
    border-bottom: 1px solid #ccc
  }
}
.medical-body__dot-items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 10px
}
.medical-body__dot-items_one-off {
  margin-top: 20px
}
.medical-body__dot-item {
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .1em;
  text-indent: -1em;
  padding-left: 1rem
}
.medical-body__accent {
  color: var(--main-1);
  font-weight: bold
}
.medical-body__prevention-table {
  margin-top: 15px
}
.medical-body__square-text {
  color: var(--brown);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 30px
}
.medical-body__square-text::first-letter {
  color: var(--main-1)
}
.medical-body__flow {
  margin-top: 30px
}
.medical-body__plus {
  display: block;
  font-size: 1.875rem;
  font-weight: bold;
  text-align: center;
  margin-top: 10px
}
.medical-body__dl {
  margin-top: 30px
}
.medical-body__cosmetic-table {
  margin-top: 30px
}
.medical-body__whitening-table {
  margin-top: 30px
}
.medical-body__teeth-list {
  margin-top: 30px
}
.medical-prevention-table {
  overflow: auto
}
.medical-prevention-table__title {
  font-size: 1.875rem;
  font-weight: bold;
  line-height: 1.5;
  margin-top: 30px
}
.medical-prevention-table__text {
  line-height: 1.5
}
.medical-prevention-table td, .medical-prevention-table th {
  border: 1px solid #ccc;
  border-collapse: collapse
}
.medical-prevention-table__table {
  min-width: 728px;
  width: 100%;
  background-color: var(--base)
}
.medical-prevention-table__titel-l {
  width: 30%;
  background-color: var(--main-2);
  color: var(--base);
  padding-top: 20px;
  padding-bottom: 20px;
  padding-left: 20px
}
.medical-prevention-table__th-top {
  text-align: center;
  padding-top: 20px
}
.medical-prevention-table__th-top_low {
  padding-top: 5px
}
.medical-prevention-table__th-sub {
  text-align: center;
  padding-top: 5px
}
.medical-prevention-table__td {
  text-align: center;
  padding-top: 20px
}
.medical-prevention-table__td_accent {
  color: red;
  font-weight: bold
}
.medical-flow {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 70px
}
.medical-flow__item {
  position: relative;
  background-color: var(--base);
  padding: 15px 30px
}
.medical-flow__item:not(:last-of-type)::after {
  content: "";
  width: 50px;
  height: 30px;
  position: absolute;
  bottom: -53px;
  left: 50%;
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  transform: translateX(-50%);
  -webkit-clip-path: polygon(0 0, 50% 100%, 100% 0);
  clip-path: polygon(0 0, 50% 100%, 100% 0);
  background-color: var(--brown)
}
.medical-flow__title {
  color: var(--main-1);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.5;
  border-bottom: 1px solid var(--main-2);
  padding-bottom: 10px
}
.medical-dl {
  display: grid
}
.medical-dl_visit {
  max-width: 500px;
  grid-template-columns: clamp(8.125rem, -3.5416666667rem + 46.6666666667vw, 12.5rem) 1fr
}
.medical-dl_visit dd {
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center
}
.medical-dl_treatment {
  grid-template-columns: clamp(6.875rem, -2.625rem + 38vw, 18.75rem) 1fr
}
.medical-dl__dt {
  min-height: 50px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--main-2);
  color: var(--base);
  font-weight: bold
}
.medical-dl__dt:not(:last-of-type) {
  border-bottom: 1px solid var(--base)
}
.medical-dl__dd {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--base);
  line-height: 1.5;
  white-space: pre-line;
  border-top: 1px solid #ccc;
  border-right: 1px solid #ccc;
  padding: 11px clamp(.625rem, .285326087rem + 1.3586956522vw, .9375rem) 11px clamp(.625rem, -.0543478261rem + 2.7173913043vw, 1.25rem)
}
.medical-dl__dd:last-of-type {
  border-bottom: 1px solid #ccc
}
.medical-cosmetic-table {
  overflow: auto
}
.medical-cosmetic-table__table {
  min-width: 720px;
  width: 100%;
  background-color: var(--base)
}
.medical-cosmetic-table td, .medical-cosmetic-table th {
  border: 1px solid #ccc;
  border-collapse: collapse
}
.medical-cosmetic-table__th-l {
  width: 15%;
  height: 50px;
  background-color: var(--main-2);
  color: var(--base);
  vertical-align: middle;
  text-align: center
}
.medical-cosmetic-table__th-r {
  background-color: var(--main-2);
  color: var(--base);
  vertical-align: middle;
  text-align: center
}
.medical-cosmetic-table__td {
  padding: 15px
}
.medical-cosmetic-table__img {
  max-width: 200px;
  margin-inline: auto
}
.medical-whitening-table {
  overflow: auto
}
.medical-whitening-table__table {
  min-width: 642px;
  width: 100%;
  background-color: var(--base)
}
.medical-whitening-table td, .medical-whitening-table th {
  border: 1px solid #ccc;
  border-collapse: collapse
}
.medical-whitening-table__th {
  min-width: 93px;
  width: 10%;
  height: 50px;
  background-color: var(--main-2);
  color: var(--base);
  text-align: center;
  vertical-align: middle
}
.medical-whitening-table__td {
  white-space: pre-line;
  padding: 15px
}
.medical-whitening-table__td_img {
  text-align: center
}
.medical-whitening-table__img {
  max-width: 200px;
  margin-inline: auto
}
.medical-whitening-table__price {
  color: red
}
.medical-teeth-list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 15px
}
.medical-teeth-list__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 1px;
  -moz-column-gap: 1px;
  column-gap: 1px;
  font-weight: 500;
  line-height: 1.75;
  letter-spacing: .1em
}
.medical-teeth-list__title {
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content;
  font-weight: bold
}
.medical-teeth-list__item-img {
  max-width: 700px;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px
}
.clinic-bg {
  background: url(../images/clinic-bg.webp) repeat-y top right/100%;
  background-image: -webkit-image-set(url(../images/clinic-bg.webp) 1x, url(../images/clinic-bg@2x.webp) 2x);
  background-image: image-set(url(../images/clinic-bg.webp) 1x, url(../images/clinic-bg@2x.webp) 2x);
  padding-top: 100px;
  padding-bottom: 100px
}
.clinic-inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px
}
.clinic-policy_pos {
  margin-top: 80px
}
.clinic-policy__subtitle {
  margin-top: 70px
}
.clinic-policy__text {
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 2;
  white-space: pre-line;
  font-size: 1.125rem;
  line-height: 2;
  white-space: pre-line
}
.clinic-policy__text_top {
  margin-top: 30px
}
.clinic-policy__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: 10px;
  -moz-column-gap: 10px;
  column-gap: 10px;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 1.75
}
.clinic-policy__dot {
  width: 10px;
  height: 10px;
  background-color: var(--main-2);
  border-radius: 50%;
  margin-top: 11px
}
.clinic-body__title{
	margin-top: 50px;
}
.ufb-body__box-text{
	max-width: 100%;
	font-weight: 500;
	line-height: 1.75;
	letter-spacing: .1em;
	white-space: pre-line;
}
.ufb__pick{
	display: flex;
 	justify-content: space-between;
	margin-top: 40px;
}
.ufb__pick__item{
	width: calc((100% - 6rem) / 4);
	background-color: #fff;
	box-shadow: 0 0.3rem 0.6rem rgba(0, 0, 0, 0.16);
}
.ufb__pick__heading {
	position: relative;
	color: #3d8f4f;
	font-size: 1.25rem;
	font-weight: bold;
	margin: 15px 0;
	padding: 0 10px;
}
.ufb__pick__text {
	line-height: 1.75;
	padding: 0 10px;
	padding-bottom: 15px;
}
@media(max-width: 768px) {
	.ufb__pick{
		display: block;
	}
	.ufb__pick__item{
		width: 100%!important;
		margin-bottom: 30px;
	}
}

.clinic-blanca_pos{
	margin-top: 100px;
}
.clinic-blanca .medical-body__box-img{
	max-width: 400px;
	width: 100%;
}

.clinic-tour_pos {
  margin-top: 100px
}
.clinic-tour__main {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 50px;
  margin-top: 70px
}
.clinic-tour__items {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px clamp(.9375rem, -16.875rem + 30vw, 1.875rem);
  margin-top: 20px
}
@media(max-width: 768px) {
  .clinic-tour__items {
    grid-template-columns: repeat(2, 1fr)
  }
}
.clinic-overview_pos {
  margin-top: 100px
}
.clinic-overview__dl {
  display: grid;
  grid-template-columns: clamp(6.875rem, -2.625rem + 38vw, 18.75rem) 1fr;
  font-size: clamp(1rem, .8641304348rem + .5434782609vw, 1.125rem);
  font-weight: 500;
  margin-top: 70px
}
.clinic-overview__dt {
  min-height: 50px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--main-2);
  color: var(--base);
  font-weight: bold
}
.clinic-overview__dt:not(:last-of-type) {
  border-bottom: 1px solid var(--base)
}
.clinic-overview__dd {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--base);
  line-height: 1.5;
  white-space: pre-line;
  border-top: 1px solid #ccc;
  border-right: 1px solid #ccc;
  padding: 11px clamp(.625rem, .285326087rem + 1.3586956522vw, .9375rem) 11px clamp(.625rem, -.0543478261rem + 2.7173913043vw, 1.25rem)
}
.clinic-overview__dd:last-of-type {
  border-bottom: 1px solid #ccc
}
.clinic-access_pos {
  margin-top: 100px
}
.clinic-access__map {
  margin-top: 70px
}
.clinic-access__gmap {
  width: 100%;
  height: 430px
}
.clinic-access__text {
  color: var(--brown);
  font-size: 1.125rem;
  font-weight: 500;
  margin-top: 20px
}
.doctor-main {
  background: url(../images/top-news-bg.webp) repeat-y center center/100%;
  background-image: -webkit-image-set(url(../images/top-news-bg.webp) 1x, url(../images/top-news-bg@2x.webp) 2x);
  background-image: image-set(url(../images/top-news-bg.webp) 1x, url(../images/top-news-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .doctor-main {
    background: url(../images/top-news-bg_sp.webp) repeat-y center center/100%;
    background-image: -webkit-image-set(url(../images/top-news-bg_sp.webp) 1x, url(../images/top-news-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/top-news-bg_sp.webp) 1x, url(../images/top-news-bg_sp@2x.webp) 2x)
  }
}
.doctor-main_staff {
  background: url(../images/doctor-bg.webp) repeat-y center center/100%;
  background-image: -webkit-image-set(url(../images/doctor-bg@2x.webp) 1x, url(../images/doctor-bg@2x.webp) 2x);
  background-image: image-set(url(../images/doctor-bg@2x.webp) 1x, url(../images/doctor-bg@2x.webp) 2x)
}
@media(max-width: 768px) {
  .doctor-main_staff {
    background: url(../images/doctor-bg_sp.webp) repeat-y center center/100%;
    background-image: -webkit-image-set(url(../images/doctor-bg_sp@2x.webp) 1x, url(../images/doctor-bg_sp@2x.webp) 2x);
    background-image: image-set(url(../images/doctor-bg_sp@2x.webp) 1x, url(../images/doctor-bg_sp@2x.webp) 2x)
  }
}
.doctor-main__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 80px 20px 100px
}
.doctor-main__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: 100px;
  margin-top: 80px
}
.doctor-main__name {
  max-width: 700px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: column-reverse;
  -ms-flex-direction: column-reverse;
  flex-direction: column-reverse;
  row-gap: 10px;
  font-family: "Zen Old Mincho", serif;
  border-bottom: 2px solid var(--main-3);
  padding-bottom: clamp(1.25rem, 0rem + 5vw, 1.875rem)
}
.doctor-main__jp {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-column-gap: clamp(1.25rem, 0rem + 5vw, 1.875rem);
  -moz-column-gap: clamp(1.25rem, 0rem + 5vw, 1.875rem);
  column-gap: clamp(1.25rem, 0rem + 5vw, 1.875rem);
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  color: var(--brown);
  font-size: clamp(1.625rem, .375rem + 5vw, 2.25rem);
  font-weight: bold;
  letter-spacing: .1em
}
.doctor-main__en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1rem, .5rem + 2vw, 1.25rem)
}
.doctor-main__job {
  font-size: clamp(1.25rem, .75rem + 2vw, 1.5rem);
  font-weight: bold
}
.doctor-main__img {
  max-width: 600px;
  margin-top: 50px;
  margin-inline: auto
}
.doctor-main__img2 {
  max-width: 424px;
  margin-top: 50px;
  margin-inline: auto
}
.doctor-main__details {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 50px clamp(1.25rem, -8.5043819188rem + 20.295202952vw, 4.6875rem);
  margin-top: 50px
}
@media(max-width: 768px) {
  .doctor-main__details {
    grid-template-columns: 1fr
  }
}
.doctor-main__details_table {
  display: block
}
.doctor-main__details-item {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
  gap: 0
}
.doctor-main__details-title {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--main-1);
  color: var(--base);
  font-family: "Zen Old Mincho", serif;
  font-size: 1.25rem;
  font-weight: bold;
  padding: 11px 20px
}
.doctor-main__details-text {
  font-size: 1.125rem;
  line-height: 1.75;
  white-space: pre-line;
  margin-top: 20px
}
.doctor-main__dl {
  display: grid;
  grid-template-columns: clamp(6.875rem, -2.625rem + 38vw, 18.75rem) 1fr;
  font-size: clamp(1rem, .8641304348rem + .5434782609vw, 1.125rem);
  margin-top: 30px
}
.doctor-main__dt {
  min-height: 50px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--main-2);
  color: var(--base);
  font-weight: bold
}
.doctor-main__dt:not(:last-of-type) {
  border-bottom: 1px solid var(--base)
}
.doctor-main__dd {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  background-color: var(--base);
  line-height: 1.5;
  border-top: 1px solid #ccc;
  border-right: 1px solid #ccc;
  padding: 11px clamp(.625rem, .285326087rem + 1.3586956522vw, .9375rem) 11px clamp(.625rem, -.0543478261rem + 2.7173913043vw, 1.25rem)
}
.doctor-main__dd:last-of-type {
  border-bottom: 1px solid #ccc
}
.doctor-main__staff-name {
  max-width: 400px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-box-pack: start;
  -webkit-justify-content: start;
  -ms-flex-pack: start;
  justify-content: start;
  -webkit-box-align: baseline;
  -webkit-align-items: baseline;
  -ms-flex-align: baseline;
  align-items: baseline;
  -webkit-column-gap: 30px;
  -moz-column-gap: 30px;
  column-gap: 30px;
  border-bottom: 2px solid var(--main-3);
  padding-bottom: 20px
}
.doctor-main__staff-en {
  color: var(--main-1);
  font-family: "Cinzel", serif;
  font-optical-sizing: auto;
  font-size: clamp(1.625rem, .375rem + 5vw, 2.25rem);
  font-size: 3.125rem;
  font-weight: bold;
  letter-spacing: .1em
}
.doctor-main__staff-job {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.25rem, .75rem + 2vw, 1.5rem);
  font-weight: bold
}
.price-main_pos {
  margin-top: 100px
}
.price-main__inner {
  max-width: 1280px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px
}
.price-main__box {
  height: 200px;
  display: grid;
  place-items: center;
  background-color: var(--main-1)
}
.price-main__text {
  color: var(--base);
  font-size: 1.25rem;
  font-weight: bold
}
.news-list__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 80px 20px 100px
}
@media(max-width: 600px) {
  .news-list__inner {
    max-width: 400px
  }
}
.news-list__items {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-flex-direction: column;
  -ms-flex-direction: column;
  flex-direction: column;
  row-gap: clamp(1.875rem, -.3571428571rem + 5.9523809524vw, 2.5rem);
  margin-top: 100px
}
@media(max-width: 600px) {
  .news-list__items {
    row-gap: 50px;
    margin-top: 50px
  }
}
.news-list__post-link {
  display: grid;
  grid-template-columns: clamp(11.25rem, -4.375rem + 41.6666666667vw, 15.625rem) 1fr;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-column-gap: clamp(.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
  -moz-column-gap: clamp(.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
  column-gap: clamp(.9375rem, -2.4107142857rem + 8.9285714286vw, 1.875rem);
  border: 1px solid var(--main-3)
}
@media(max-width: 600px) {
  .news-list__post-link {
    grid-template-columns: 1fr;
    row-gap: 10px
  }
}
.news-list__thumbnail {
  max-width: 300px
}
@media(max-width: 600px) {
  .news-list__thumbnail {
    max-width: 100%
  }
}
.news-list__thumbnail img {
  aspect-ratio: 4/3;
  -o-object-fit: cover;
  object-fit: cover
}
@media(max-width: 600px) {
  .news-list__text-box {
    padding-right: 10px;
    padding-left: 10px;
    padding-bottom: 20px
  }
}
.news-list__date {
  display: block;
  color: var(--main-1);
  font-size: 1.25rem;
  font-weight: bold;
  line-height: 1.75
}
.news-list__post-title {
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(1.125rem, .6785714286rem + 1.1904761905vw, 1.25rem);
  font-weight: bold;
  line-height: 1.75;
  text-align: start;
  word-break: break-all;
  padding-right: 15px
}
@media(max-width: 600px) {
  .news-list__post-title {
    padding-right: 0
  }
}
.news-list__no-post {
  height: 200px;
  display: grid;
  place-items: center;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.25rem;
  font-weight: bold
}
.news-list__pagination {
  font-size: 1.25rem;
  margin-top: 150px
}
@media(max-width: 768px) {
  .news-list__pagination {
    margin-top: 80px
  }
}
.news-list__pagination ul.page-numbers {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  gap: clamp(1.125rem, -0.875rem + 8vw, 2.125rem);
  margin-inline: auto
}
.news-list__pagination ul.page-numbers li {
  min-width: -webkit-fit-content;
  min-width: -moz-fit-content;
  min-width: fit-content
}
.news-list__pagination .page-numbers.current {
  color: var(--main)
}
@media(hover: hover)and (pointer: fine) {
  .news-list__post-link {
    -webkit-transition: background-color .4s;
    transition: background-color .4s
  }
  .news-list__post-link:hover, .news-list__post-link:focus {
    background-color: rgba(157, 204, 45, .1)
  }
  .news-list__pagination a {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .news-list__pagination a:hover, .news-list__pagination a:focus {
    opacity: .7
  }
}
.news-post__inner {
  max-width: 840px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding: 80px 30px 100px
}
.news-post__bg {
  border: 1px solid var(--main-3);
  padding: 50px 20px 100px
}
.news-post__date {
  display: block;
  color: var(--main-1);
  font-size: 1.25rem;
  font-weight: bold
}
@media(max-width: 768px) {
  .news-post__date {
    font-size: 1.125rem
  }
}
.news-post__title {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.5rem;
  font-weight: bold;
  line-height: 1.75;
  word-break: break-all;
  margin-top: 10px
}
@media(max-width: 768px) {
  .news-post__title {
    font-size: 1.375rem;
    margin-top: 10px
  }
}
.news-post__thumbnail {
  margin-top: 40px
}
.news-post__editor {
  margin-top: 40px
}
.news-post-pager {
  border: 1px solid var(--main-3)
}
.news-post-pager_pos {
  max-width: 840px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px;
  margin-top: 80px
}
@media(max-width: 768px) {
  .news-post-pager_pos {
    margin-top: 60px
  }
}
.news-post-pager__nav {
  height: 70px;
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center;
  color: var(--main);
  font-size: clamp(1rem, .1071428571rem + 3.8095238095vw, 1.25rem);
  padding-right: clamp(0rem, -4.4642857143rem + 19.0476190476vw, 1.25rem);
  padding-left: clamp(0rem, -4.4642857143rem + 19.0476190476vw, 1.25rem)
}
.news-post-pager__blank {
  min-width: 106px;
  min-width: clamp(5.4375rem, .5267857143rem + 20.9523809524vw, 6.8125rem)
}
@media(hover: hover)and (pointer: fine) {
  .news-post-pager__link {
    -webkit-transition: opacity .5s;
    transition: opacity .5s
  }
  .news-post-pager__link:hover, .news-post-pager__link:focus {
    opacity: .7
  }
}
.page-404_pos {
  margin-top: 100px
}
.page-404__inner {
  max-width: 1000px;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  margin-inline: auto;
  padding-right: 20px;
  padding-left: 20px
}
.page-404__title {
  color: var(--main-1);
  font-size: 1.5rem;
  font-weight: bold
}
.page-404__text {
  line-height: 1.75;
  white-space: pre-line;
  margin-top: 60px
}
.page-404__button-wrapper {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 100px
}

/*SPフローティングボタン*/
.sp-fixed-buttons {
	display: none;
	width: 100%;
	height: 80px;
	position: fixed;
	z-index: 1;
	bottom: 0;
	/* display: grid; */
	grid-template-columns: repeat(3, 1fr);
	.button {
		background-color: #9dcc2d;
		color: #ffffff;
		width: 100%;
		display: flex;
		justify-content: center;
		flex-direction: column;
		border-top: 1px solid #ffffff;
		&:not(:last-of-type) {
			border-right: 1px solid #ffffff;
		}
	}
	.icon-wrapper {
		width: 100%;
		display: grid;
		place-items: center;
	}
	.icon {
		width: 35px;
		margin-inline: auto;
		margin-bottom: 0.5rem;
	}
	.text{
		text-align: center;
	}
}
@media (max-width: 960px) {
	body {
		margin-bottom: 80px;
	}
	.sp-fixed-buttons {
		display: grid;
	}
}


/* PC採用情報フローティングボタン */
.recruit_bnr {
    position: fixed;
    right: 20px;
    bottom: 110px;
    z-index: 9998;
    background-color: #fec400;
    color: #fff;
    padding: 20px;
    border-radius: 10px;
    text-decoration: none;
    max-width: 200px;
}

.recruit_bnr:hover {
    opacity: 0.8;
    transition: 0.5s;
    cursor: pointer;
}

.recruit_bnr a {
    cursor: pointer;
}

.recruit_bnr p {
    text-align: center;
}

.recruit_bnr img {
    margin: 5% 0;
}

.recruit_bnr_close {
    font-weight: bold;
    position: absolute;
    top: 5px;
    right: 5px;
    z-index: 9999;
    padding: 5px 8px;
    border: none;
    background-color: #fff;
    border-radius: 50px;
    cursor: pointer;
    color: #333;
}

.recruit_bnr_close:hover {
    opacity: 0.8;
    transition: 0.5s;
}

@media (max-width: 960px) {
	.recruit_bnr {
		display: none;
	}
}
/*PC採用情報フローティングボタン*/
/*.pc_recruit_close{
	background-color: #fff;
	color: #333;
	border-radius: 50px;
}
.pc_recruit_btn {
	position: fixed;
	z-index: 99999;
	bottom: 110px;
	right: 20px;
	background-color: #fec400;
	border-radius: 10px;
	color:#fff;
	padding: 15px;
}*/
.pc_recruit_btn {　/* 任意の名前 */
	position: fixed;
	z-index: 99998;
	bottom: 110px;
	right: 20px;
	background-color: #fec400;
	border-radius: 10px;
	color:#fff;
	padding: 15px;
}
.pc_recruit_btn_close {
    font-weight: bold;
    position: absolute;
    top: 0px;　/* 閉じるボタンのトップからの設置位置 */
    right: 0px;　/* 閉じるボタンの右端からの設置位置 */
    z-index: 99999;　/* 他の要素より前面に表示 */
    padding: 4px 8px;
    border: none;
    background-color: #f8f8f8;
    border-radius: 25px;
    cursor: pointer;
    -webkit-box-shadow: 0 0 7px rgb(0 0 0 / 40%);
    box-shadow: 0 0 7px rgb(0 0 0 / 40%);
}
@media (max-width: 960px) {
	.pc_recruit_btn {
		display: none;
	}
}