@charset "UTF-8";
/* ===========================================================
   # BASE
=========================================================== */
/* = LAYOUT
----------------------------------------------------------- */
/* HEAD */
.head .headIn {
  height: 8rem;
}

.pageTtl.noImg {
  background-image: linear-gradient(150deg, rgba(239, 155, 188, 0.3), rgba(247, 197, 184, 0.3) 33%, rgba(224, 222, 189, 0.3) 66%, rgba(156, 211, 203, 0.3));
  padding: 2rem 0 4rem;
}

.pageTtl.noImg::before {
  content: "";
  background-color: #CAB68E;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-size: contain;
  mask-size: contain;
  display: block;
  margin: auto;
  width: 7rem;
  height: 7rem;
}

.doctorCont .pageTtl.noImg::before {
  -webkit-mask-image: url(./img/ico_doctor.svg);
  mask-image: url(./img/ico_doctor.svg);
}

.informationCont .pageTtl.noImg::before {
  -webkit-mask-image: url(./img/ico_medical.svg);
  mask-image: url(./img/ico_medical.svg);
}

.clinicCont .pageTtl.noImg::before {
  -webkit-mask-image: url(./img/ico_clinic.svg);
  mask-image: url(./img/ico_clinic.svg);
}

.accessCont .pageTtl.noImg::before {
  -webkit-mask-image: url(./img/ico_access.svg);
  mask-image: url(./img/ico_access.svg);
}

.pageTtl.noImg h2 {
  color: rgba(202, 182, 142, 0.5);
  font-size: 4rem;
  font-weight: 500;
  letter-spacing: .05em;
  padding-top: 1em;
  position: relative;
}

.pageTtl.noImg h2 span {
  color: #4C4C4C;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 1em;
  left: 0;
  right: 0;
  bottom: .2em;
}

.pageTtl.noImg h2::before, .pageTtl.noImg h2::after {
  margin: auto;
  position: absolute;
  left: 0;
  right: 0;
}

.pageTtl.noImg h2::before {
  content: url(./img/dot.svg);
  top: 0;
  transform: scale(0.7);
}

.pageTtl.noImg h2::after {
  background: #CAB68E;
  content: "";
  width: 3rem;
  height: 1px;
  bottom: -.5em;
}

.pageTtl.hasImg h2 {
  font-size: 3.9rem;
  font-weight: 500;
  letter-spacing: 0.5em;
  padding-left: .5em;
  left: 0;
  right: 0;
  top: 3rem;
}

.entryTtl {
  font-size: min(6.4vw, 4rem);
  line-height: 1.4;
  margin-bottom: 2em;
}

.entryTtl span {
  color: #CAB68E;
  display: block;
  font-size: 1.6rem;
  font-weight: 500;
}

/* MAIN */
.cont {
  padding-top: 8rem;
}

.contBody {
  padding-top: 4rem;
}

/* SIDE */
@media (min-width: 768px) {
  /* HEAD */
  .head .headIn {
    height: 9.4rem;
  }
  .pageTtl.hasImg h2 {
    font-size: min(5vw, 6rem);
    margin-left: -40%;
    top: 50%;
    transform: translateY(-0.4em);
  }
  /* MAIN */
  .cont {
    padding-top: 9.4rem;
  }
}

@media (min-width: 1024px) {
  /* HEAD */
  .head .headIn {
    height: 12rem;
  }
  .pageTtl.noImg {
    padding: 6rem 0 7rem;
  }
  .pageTtl.noImg::before {
    width: 8rem;
    height: 8rem;
  }
  .pageTtl.noImg h2 {
    font-size: min(5vw, 6.6rem);
    padding-top: 1.2em;
  }
  .pageTtl.noImg h2 span {
    font-size: 1.8rem;
  }
  .pageTtl.noImg h2::before {
    transform: scale(1);
  }
  .pageTtl.noImg h2::after {
    width: 4rem;
    bottom: -.6em;
  }
  /* MAIN */
  .cont {
    padding-top: 12rem;
  }
  .contBody {
    padding-top: 12rem;
  }
}

@media (min-width: 1366px) {
  /* HEAD */
  .head .headIn {
    height: 16rem;
  }
  /* MAIN */
  .cont {
    padding-top: 16rem;
  }
}

/* ===========================================================
   # PAGINATION
=========================================================== */
.pageNav {
  padding-top: 3em;
}

.pageNav ul {
  display: flex;
  justify-content: center;
}

.pageNav a, .pageNav span {
  display: block;
  opacity: .8;
  transition: all 300ms 0s ease;
}

.pageNav a:hover, .pageNav a.current, .pageNav span:hover, .pageNav span.current {
  background: #CAB68E;
  border-color: #CAB68E !important;
  color: #fff;
  opacity: 1;
}

.pageNav .page-numbers {
  gap: 1em;
  line-height: 2.3rem;
}

.pageNav .page-numbers li a, .pageNav .page-numbers li span {
  border-radius: 50%;
  width: 2.6rem;
  height: 2.6rem;
}

.pageNav .pagination {
  line-height: 3rem;
}

.pageNav .pagination li {
  width: 33.33%;
}

.pageNav .pagination li a {
  border: 1px solid #ccc;
  font-size: .9em;
  margin-left: -1px;
}

@media (min-width: 768px) {
  .pageNav {
    padding-top: 6em;
  }
  .pageNav .page-numbers {
    line-height: 3.6rem;
  }
  .pageNav .page-numbers li a, .pageNav .page-numbers li span {
    width: 4rem;
    height: 4rem;
  }
  .pageNav .pagination {
    line-height: 6rem;
  }
  .pageNav .pagination li a {
    font-size: 1em;
  }
}

/* ===========================================================
   # DOCTOR
=========================================================== */
.doctorBox.box01 {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 3rem;
  padding: 4rem;
}

.doctorBox.box01 > dt {
  background-position: 50% 0;
  background-size: 3.8rem;
  font-size: min(4.8vw, 2rem);
  padding-top: 7rem;
  text-align: center;
}

.doctorBox.box01.prof > dt {
  background-image: url(./img/ico_prof.svg);
}

.doctorBox.box01.badge > dt {
  background-image: url(./img/ico_badge.svg);
}

.doctorBox.box01 > dd dl {
  line-height: 1.6;
  padding-left: 1em;
  position: relative;
}

.doctorBox.box01 > dd dl::before {
  color: #EEAB9F;
  content: "●";
  font-size: 1rem;
  position: absolute;
  left: -.45em;
  top: .5em;
}

.doctorBox.box01 > dd dl:not(:last-of-type)::after {
  border-left: 1px dotted #ccc;
  content: "";
  width: 1px;
  height: calc(100% - .8em);
  position: absolute;
  left: 0;
  top: 1.2em;
}

.doctorBox.box01 > dd dl:not(:last-of-type) dd {
  padding-bottom: 1em;
}

@media (min-width: 768px) {
  .doctorBox.box01 {
    flex-direction: row;
    padding: 6rem;
  }
  .doctorBox.box01 > dt {
    width: 30%;
  }
}

@media (min-width: 1024px) {
  .doctorBox.box01 > dd dl {
    display: flex;
  }
  .doctorBox.box01 > dd dl dt {
    width: 10em;
  }
  .doctorBox.box01 > dd dl dd {
    width: calc(100% - 10em);
  }
}

@media (min-width: 1366px) {
  .doctorBox.box01 {
    padding: 10rem;
  }
  .doctorBox.box01 > dt {
    width: 40%;
  }
}

/* ===========================================================
   # MEDICAL
=========================================================== */
.medicalSche.box01 .serif {
  font-size: min(4.8vw, 2.4rem);
  font-weight: 700;
  letter-spacing: .5em;
  padding: 2rem 0 0.5em;
}

.medicalSche.box01 table {
  border-top: 1px solid #CAB68E;
  border-bottom: 1px solid #CAB68E;
}

.medicalSche.box01 ul {
  flex-direction: column;
  padding: 1rem;
}

.medicalSche.box01 ul li {
  font-size: .88em;
  line-height: 1.4;
  margin: 0;
}

.medicalFirst.box01 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: unset;
  padding: 1rem 1rem;
}

.medicalFirst.box01 .serif {
  font-size: min(4.7vw, 2.4rem);
  font-weight: 700;
}

.medicalFirst.box01 .serif:last-child {
  font-size: min(4.7vw, 2rem);
}

.medicalPrice.box01 {
  display: flex;
  flex-direction: column;
  gap: .5em;
  padding: 2rem;
}

.medicalPrice.box01 table {
  min-width: 100%;
  white-space: nowrap;
}

.medicalPrice.box01 table th {
  text-align: center;
}

.medicalPrice.box01 table td {
  text-align: right;
}

.medicalPrice.box01 table td:first-child {
  text-align: left;
}

.medicalPrice.box01 p {
  line-height: 1.6;
}

@media (min-width: 768px) {
  .medicalSche.box01 ul {
    flex-direction: row;
    gap: 2em;
    justify-content: center;
    padding: 2rem 0 0;
  }
  .medicalSche.box01 ul li {
    font-size: 1em;
  }
  .medicalPrice.box01 {
    gap: 0;
  }
}

@media (min-width: 1024px) {
  .medicalSche.box01 .serif {
    padding-bottom: 1em;
  }
  .medicalFirst.box01 {
    gap: 0.7em;
    padding: 5rem 2rem;
  }
  .medicalPrice.box01 {
    padding: 5rem;
  }
  .medicalPrice.box01 table td {
    padding: 1rem 2em;
  }
}

@media (min-width: 1366px) {
  .medicalPrice.box01 {
    padding: 8rem 20rem;
  }
}

/* ===========================================================
   # CLINIC
=========================================================== */
.clinicFacility.box01 .gallery dl {
  padding-bottom: 3rem;
}

.clinicFacility.box01 .gallery dl:last-of-type {
  padding-bottom: 1rem;
}

.clinicFacility.box01 .gallery dl dt {
  margin: 0;
}

.clinicFacility.box01 .gallery dl dd {
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 1rem;
  font-size: 1em;
  padding-top: 1.5rem;
  text-align: center;
}

.clinicFacility.box01 .gallery dl dd::before {
  background: #4C4C4C;
  content: "";
  width: 1px;
  height: 2rem;
}

@media (min-width: 768px) {
  .clinicFacility.box01 .gallery {
    gap: 4rem 3.5%;
  }
  .clinicFacility.box01 .gallery dl {
    padding-bottom: 0;
    width: 31%;
  }
}

@media (min-width: 1024px) {
  .clinicFacility.box01 .gallery {
    flex-wrap: nowrap;
    gap: 2rem;
    padding-top: 1rem;
  }
  .clinicFacility.box01 .gallery dl {
    flex: auto;
  }
}

/* ===========================================================
   # RECRUIT
=========================================================== */
.recruitCatch {
  font-size: min(6.4vw, 3.6rem);
  letter-spacing: .2em;
}

.recruitEnviron.flex.box01 {
  flex-direction: column;
  gap: 3rem;
  padding-left: 0;
  padding-right: 0;
}

.recruitEnviron.flex.box01 li {
  counter-increment: recruitEnviron;
  display: flex;
  align-items: center;
  flex-direction: column;
  gap: 3rem;
  position: relative;
  text-align: center;
}

.recruitEnviron.flex.box01 li::before {
  border-bottom: 1px solid #EEAB9F;
  content: counter(recruitEnviron);
  font-family: 'EB Garamond', 'Noto Serif JP', serif;
  font-size: min(6.4vw, 4.8rem);
  width: 7rem;
}

.recruitVoice {
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  margin: 0;
}

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

.recruitVoice:not(:first-of-type) {
  margin-top: 2rem;
}

.recruitVoice dt {
  width: 35%;
}

.recruitVoice dd {
  border-bottom: 1px solid #4C4C4C;
  padding: 2rem 0 1rem;
  line-height: 1.6;
  width: calc(100% - 35%);
  position: relative;
}

.recruitVoice dd::after {
  background: #F7F4EF;
  content: "";
  margin: auto;
  width: 2rem;
  height: 2rem;
  position: absolute;
  left: 0;
  right: 0;
  bottom: -2.1rem;
}

.recruitVoice:nth-of-type(odd) dd::after {
  border-right: 1px solid #4C4C4C;
  transform: rotate(45deg);
  transform-origin: right top;
}

.recruitVoice:nth-of-type(even) dd::after {
  border-left: 1px solid #4C4C4C;
  transform: rotate(-45deg);
  transform-origin: left top;
}

@media (min-width: 768px) {
  .recruitEnviron.flex.box01 {
    flex-direction: row;
    gap: 0;
  }
  .recruitEnviron.flex.box01 li {
    flex: 1;
    font-size: .9em;
  }
  .recruitEnviron.flex.box01 li::before {
    width: 4.6rem;
  }
  .recruitEnviron.flex.box01 li:not(:last-child)::after {
    border-right: 1px solid #EEAB9F;
    content: "";
    margin: auto;
    width: 1px;
    height: 60%;
    position: absolute;
    right: 0;
    top: 10%;
    bottom: 0;
  }
  .recruitMessage {
    text-align: center;
  }
  .recruitVoice:not(:first-of-type) {
    margin-top: 0;
  }
  .recruitVoice dt {
    width: 19rem;
  }
  .recruitVoice dd {
    line-height: 2;
    padding: 6rem 2rem 2rem;
    width: auto;
  }
}

@media (min-width: 1024px) {
  .recruitEnviron.flex.box01 {
    padding-left: 5rem;
    padding-right: 5rem;
  }
  .recruitEnviron.flex.box01 li {
    font-size: 1em;
  }
  .recruitVoice:not(:first-of-type) {
    margin-top: -20rem;
  }
}

/*# sourceMappingURL=content.map */