/* reset */
*,
*::before,
*::after {
  box-sizing: border-box;
}
html {
  -moz-text-size-adjust: none;
  -webkit-text-size-adjust: none;
  text-size-adjust: none;
}
body,
h1,
h2,
h3,
h4,
p,
figure,
blockquote,
dl,
dd {
  margin: 0;
}
ul[role="list"],
ol[role="list"] {
  list-style: none;
}
body {
  min-height: 100vh;
  line-height: 1.5;
}
h1,
h2,
h3,
h4,
button,
input,
label {
  line-height: 1.1;
}
h1,
h2,
h3,
h4 {
  text-wrap: balance;
}
a:not([class]) {
  text-decoration-skip-ink: auto;
  color: currentColor;
}
img,
picture {
  max-width: 100%;
  height: auto;
  display: block;
}
input,
button,
textarea,
select {
  font: inherit;
}
textarea:not([rows]) {
  min-height: 10em;
}
:target {
  scroll-margin-block: 5ex;
}
summary::-webkit-details-marker {
  /* Safariで表示されるデフォルトの三角形アイコンを消します */
  display: none;
}
/* utillity */
.ff_mincho {
  font-family: "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
}
.utillity_bg_gray {
  background: #f8f8f8;
}
.utillity_block {
  display: flex;
  place-content: center;
  padding: 5rem 3rem;
}
@media screen and (max-width: 767px) {
  .utillity_block {
    display: flex;
    place-content: center;
    padding: 2.5rem 1.5rem;
  }
}
.centering_container {
  max-width: 129.5rem;
  margin-inline: auto;
  padding-inline: 3rem;
}
@media screen and (max-width: 767px) {
  .centering_container {
    padding-inline: 1.5rem;
  }
}
.heading {
  font-size: 3.8rem;
  font-weight: bold;
  text-align: center;
  line-height: calc(65 / 38);
  position: relative;
}
@media screen and (max-width: 767px) {
  .heading {
    font-size: 2.8rem;
  }
}
.heading_3 {
  font-size: 2.6rem;
  font-weight: bold;
  text-align: center;
  position: relative;
}
@media screen and (max-width: 767px) {
  .heading_3 {
    font-size: 2rem;
  }
}
.heading__subtext {
  height: 1em;
  margin-block: auto;
  font-size: 1.2rem;
  font-weight: normal;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
}
@media screen and (max-width: 767px) {
  .heading__subtext {
    margin-block: 0;
    top: auto;
    bottom: calc(-1em + -1.5rem);
  }
}
@media screen and not (max-width: 767px) {
  .pc_hidden {
    display: none !important;
  }
}
@media screen and (max-width: 767px) {
  .sp_hidden {
    display: none !important;
  }
}
/* style */
:root {
  color: #333333;
  font-size: min(calc(10 / 1295 * 100vw), 62.5%);
}
@media screen and (max-width: 767px) {
  :root {
    font-size: min(calc(10 / 375 * 100vw));
  }
}
body {
  font-family: "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}
a:hover {
  opacity: 0.7;
}
.header {
  display: flex;
  align-items: center;
  padding: 5.2rem 3rem 3.6rem;
}
@media screen and (max-width: 767px) {
  .header {
    justify-content: center;
    padding: 2rem 1rem;
  }
}
.header__logo {
  display: flex;
  align-items: center;
  column-gap: 1.3rem;
}
.header__logo_post {
  font-size: 1.9rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .header__logo_post {
    font-size: 1.4rem;
  }
}
.header__logo_name {
  font-size: 4.3rem;
}
@media screen and (max-width: 767px) {
  .header__logo_name {
    font-size: 3.2rem;
    line-height: 1;
  }
}
.header__btn {
  display: flex;
  align-items: center;
  column-gap: 1.8rem;
  margin-left: auto;
  padding: 1.6rem 1.2rem 1.6rem 2rem;
  color: #313131;
  font-size: 1.3rem;
  font-weight: bold;
  text-decoration: none;
  letter-spacing: 0.1rem;
  border: 0.1rem solid #242424;
  border-radius: 1rem;
}
@media screen and (max-width: 767px) {
  .header__btn {
    justify-content: space-between;
    width: 100%;
    margin-top: 2rem;
    margin-left: 0;
    padding: 1.6rem 2rem;
    column-gap: 1rem;
  }
}
.header__btn::after {
  content: "";
  flex-shrink: 0;
  display: block;
  width: 0.6rem;
  height: 0.6rem;
  background: transparent;
  border-right: 0.2rem solid #333333;
  border-bottom: 0.2rem solid #333333;
  translate: -50%;
  rotate: 45deg;
}
.mainvisual {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  max-width: min(1235px, calc(100vw - 6rem));
  min-height: 58.6rem;
  padding: 0 0 2.5rem 4.7rem;
  background: url(./img/mainvisual_bg.jpg) no-repeat center / cover;
  border-radius: 2rem;
  position: relative;
}
@media screen and (max-width: 767px) {
  .mainvisual {
    align-items: center;
    max-width: none;
    margin-inline: 1.65rem;
    padding: 17rem 0 0;
    background-image: none;
    z-index: 0;
  }
}
@media screen and (max-width: 767px) {
  .mainvisual::before {
    content: "";
    width: 100%;
    aspect-ratio: 360 / 382;
    background: url(./img/mainvisual_bg-sp.jpg) no-repeat center / cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
}
.mainvisual__catchcopy {
  width: 100%;
  color: #ffffff;
  font-family: "toppan-bunkyu-midashi-go-std", sans-serif;
  font-size: 2.6rem;
  font-weight: 900;
  font-style: normal;
  line-height: calc(52 / 33);
  letter-spacing: 0.2rem;
}
@media screen and (max-width: 767px) {
  .mainvisual__catchcopy {
    padding-inline: 1.5rem;
    font-size: 1.8rem;
  }
}
.mainvisual__catchcopy + .mainvisual__catchcopy {
  margin-top: 1em;
}
.mainvisual__catchcopy--yellow {
  color: #ff0;
}
.mainvisual__post {
  margin: 6.3rem 0 0;
  padding-left: 0;
  color: #ffffff;
  font-size: 2rem;
  font-weight: bold;
  line-height: calc(34 / 20);
}
@media screen and (max-width: 767px) {
  .mainvisual__post {
    margin-top: 6rem;
    color: #333333;
    font-size: 1.6rem;
    line-height: calc(31 / 16);
    font-feature-settings: "palt";
  }
}
.mainvisual__title {
  display: flex;
  align-items: flex-end;
  column-gap: 1.5rem;
  margin-top: 2.3rem;
  color: #ffffff;
}
@media screen and (max-width: 767px) {
  .mainvisual__title {
    width: 100%;
    justify-content: flex-start;
    row-gap: 1.5rem;
    margin-top: 3rem;
    color: #333333;
  }
}
.mainvisual__title p {
  font-size: 2.9rem;
  font-weight: bold;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .mainvisual__title p {
    font-size: 2.3rem;
  }
}
.mainvisual__title h1 {
  font-size: 4.3rem;
  font-weight: normal;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .mainvisual__title h1 {
    font-size: 3.6rem;
  }
}
.mainvisual__onepoint {
  padding: 2.5rem 11.8rem 2.3rem 3.2rem;
  background: #ffffff;
  border: 0.2rem solid #065b6f;
  border-radius: 2rem;
  text-decoration: none;
  position: absolute;
  right: 1.8rem;
  bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .mainvisual__onepoint {
    width: calc(100% - 3rem);
    padding: 1.5rem 11.8rem 1.5rem 2.5rem;
    bottom: 2rem;
  }
}
.mainvisual__onepoint::after {
  content: "";
  display: block;
  width: 9.4rem;
  height: 14.8rem;
  background: url(./img/mainvisual_robot.png) no-repeat center / contain;
  position: absolute;
  right: 1.8rem;
  bottom: 1.3rem;
}
.mainvisual__onepoint span {
  color: #065b6f;
  font-size: 1.9rem;
  font-weight: bold;
  line-height: calc(32 / 19);
}
@media screen and (max-width: 767px) {
  .mainvisual__onepoint span {
    font-size: 1.4rem;
  }
}
.mainvisual__onepoint span::after {
  content: "";
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  margin-left: 1.5rem;
  border-right: 0.2rem solid #065b6f;
  border-bottom: 0.2rem solid #065b6f;
  vertical-align: middle;
  rotate: 45deg;
  translate: 0 -50%;
}
.medical_institution {
  margin-top: 8rem;
}
.medical_institution__list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 2.6rem 6.3rem;
  margin-top: 4rem;
  padding: 3rem 4rem 4rem;
  background: #f8f8f8;
  border-radius: 2rem;
}
@media screen and (max-width: 767px) {
  .medical_institution__list {
    gap: 3rem 2rem;
    padding: 2rem;
    font-size: 1.4rem;
  }
}
.medical_institution__list li {
  display: flex;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .medical_institution__list li {
    width: calc((100% - 2rem) / 2);
  }
}
@media screen and (max-width: 767px) {
  .medical_institution__list li img {
    width: 100%;
  }
}
.medical_institution__btn {
  display: flex;
  align-items: center;
  column-gap: 2.4rem;
  width: fit-content;
  margin: 4rem auto 0;
  padding: 1.6rem 1.8rem 1.6rem 2rem;
  color: #313131;
  font-size: 2.2rem;
  font-weight: bold;
  text-decoration: none;
  letter-spacing: 0.1rem;
  border: 0.1rem solid #242424;
  border-radius: 1rem;
  transition: all 0.3s;
}
@media screen and (max-width: 767px) {
  .medical_institution__btn {
    justify-content: space-between;
    width: 100%;
    padding: 1.6rem 2rem;
    font-size: 1.6rem;
  }
}
.medical_institution__btn:hover {
  color: #fff;
  background: #242424;
}
.medical_institution__btn::after {
  content: "";
  flex-shrink: 0;
  display: block;
  width: 1rem;
  height: 1rem;
  background: transparent;
  border-right: 0.2rem solid #333333;
  border-bottom: 0.2rem solid #333333;
  translate: -50%;
  rotate: 45deg;
  transition: all 0.3s;
}
@media screen and (max-width: 767px) {
  .medical_institution__btn::after {
    content: "";
    flex-shrink: 0;
    display: block;
    width: 0.6rem;
    height: 0.6rem;
  }
}
.medical_institution__btn:hover::after {
  border-color: #fff;
}
.about {
  margin-top: 8rem;
}
.treatment_policy {
  display: flex;
  justify-content: stretch;
  column-gap: 9.5rem;
  margin-top: 5rem;
  margin-bottom: 6rem;
}
@media screen and (max-width: 767px) {
  .treatment_policy {
    flex-direction: column;
    row-gap: 4rem;
  }
}
.treatment_policy > div {
  flex-grow: 1;
}
.treatment_policy > img {
  width: 57rem;
  height: auto;
}
.treatment_policy .heading_3 {
  margin-bottom: 3rem;
  padding-bottom: 2rem;
  border-bottom: 0.1rem solid #333333;
  text-align: left;
}
.treatment_policy p {
  font-size: 1.8rem;
  line-height: 2;
}
@media screen and (max-width: 767px) {
  .treatment_policy p {
    font-size: 1.4rem;
  }
}
.treatment_policy p + p {
  margin-top: 1em;
}
.familar_surgery {
  display: flex;
  flex-direction: row-reverse;
  justify-content: stretch;
  column-gap: 9.5rem;
  padding-top: 6rem;
}
@media screen and (max-width: 767px) {
  .familar_surgery {
    flex-direction: column;
    row-gap: 4rem;
  }
}
.familar_surgery > div {
  flex-grow: 1;
}
.familar_surgery > img {
  width: 57rem;
  height: auto;
}
.familar_surgery .heading_3 {
  margin-bottom: 3rem;
  padding-bottom: 2rem;
  border-bottom: 0.1rem solid #333333;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .familar_surgery .heading_3 {
    margin-bottom: 5rem;
    padding-bottom: 1rem;
  }
}
.familar_surgery dl {
  font-size: 1.8rem;
  line-height: calc(31 / 18);
}
@media screen and (max-width: 767px) {
  .familar_surgery dl {
    font-size: 1.4rem;
  }
}
.familar_surgery dl dt:not(:first-of-type) {
  margin-top: 1em;
}
.familar_surgery dl dd span {
  color: #145188;
  text-decoration: underline;
  cursor: pointer;
}
/**************************\
  Basic Modal Styles
\**************************/
.modal__overlay {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(0, 0, 0, 0.3);
  display: flex;
  justify-content: center;
  align-items: flex-end;
}
.modal__container {
  background-color: #fff;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  margin-inline: auto;
  padding: 7rem 3rem;
  width: 100%;
  height: calc(100vh - 10.2rem);
  max-width: 100%;
  max-height: 100vh;
  border-radius: 3rem 3rem 0 0;
  box-shadow: 0 -1.1rem 0.6rem rgba(0, 0, 0, 0.16);
  overflow-y: auto;
  box-sizing: border-box;
}
.modal__header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  max-width: 93rem;
}
.modal__title {
  margin-top: 0;
  margin-bottom: 0;
  font-weight: 600;
  font-size: 1.9rem;
  line-height: 1.25;
  color: #333333;
  box-sizing: border-box;
}
.modal__close {
  background: transparent;
  border: 0;
  font-size: 2.6rem;
  position: absolute;
  top: 2rem;
  right: 4rem;
}
@media screen and (max-width: 767px) {
  .modal__close {
    right: 2rem;
  }
}
.modal__header .modal__close:before {
  content: "\2715";
}
.modal__content {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 93rem;
  margin-block: 2rem;
  line-height: 1.5;
  color: rgba(0, 0, 0, 0.8);
}
@media screen and (max-width: 767px) {
  .modal__content {
    margin-bottom: 0;
  }
}
.modal__inner {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  gap: 1.5rem 2rem;
}
.modal__inner--multicol {
  grid-template-columns: repeat(2, 1fr);
}
@media screen and (max-width: 767px) {
  .modal__inner {
    grid-template-columns: auto;
  }
}
.modal__inner--multicol .video-wrap {
  display: grid;
  grid-template-rows: subgrid;
  grid-row: span 2;
}
.modal__content video {
  width: auto;
  max-width: 100%;
  max-height: 44rem;
}
@media screen and (max-width: 767px) {
  .modal__content video {
    width: 100%;
    height: auto;
  }
}
.modal__content iframe {
  width: 93rem;
  height: 52.3rem;
  aspect-ratio: 930 / 523;
}
@media screen and (max-width: 767px) {
  .modal__content iframe {
    width: 100%;
    height: auto;
  }
}
.modal__content p {
  width: 100%;
  font-size: 1.4rem;
}
.modal__content > p {
  margin-top: 1.5rem;
}
/**************************\
  Demo Animation Style
\**************************/
@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmslideIn {
  from {
    transform: translateY(15%);
  }
  to {
    transform: translateY(0);
  }
}
@keyframes mmslideOut {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(-10%);
  }
}
.micromodal-slide {
  display: none;
  position: relative;
  z-index: 99999;
}
.micromodal-slide.is-open {
  display: block;
}
@media screen and (max-width: 767px) {
  .modal__container {
    justify-content: flex-start;
    padding-bottom: 3rem;
  }
}
.micromodal-slide[aria-hidden="false"] .modal__overlay {
  animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.micromodal-slide[aria-hidden="false"] .modal__container {
  animation: mmslideIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.micromodal-slide[aria-hidden="true"] .modal__overlay {
  animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.micromodal-slide[aria-hidden="true"] .modal__container {
  animation: mmslideOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.micromodal-slide .modal__container,
.micromodal-slide .modal__overlay {
  will-change: transform;
}
.book {
  margin-top: 9rem;
  margin-bottom: 9rem;
}
.book-details {
  margin-top: 8rem;
}
.book-details__summary {
  display: flex;
  align-items: center;
  padding: 2rem 10.8rem 2rem 4rem;
  background: #f8f8f8;
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 1;
  border: 0.1rem solid #a2a2a2;
  position: relative;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .book-details__summary {
    padding: 2rem 7.3rem 2rem 1.5rem;
    font-size: 2.2rem;
  }
}
.book-details__summary_icon {
  flex-shrink: 0;
  display: block;
  width: 6.8rem;
  height: 100%;
  background: #797979;
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .book-details__summary_icon {
    width: 6.2rem;
  }
}
.book-details__summary_icon::before,
.book-details__summary_icon::after {
  content: "";
  width: 3.5rem;
  height: 0.1rem;
  margin: auto;
  background: #ffffff;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .book-details__summary_icon::before,
  .book-details__summary_icon::after {
    width: 2.5rem;
  }
}
.book-details__summary_icon::after {
  rotate: 90deg;
}
.book-details[open] .book-details__summary_icon::after {
  rotate: 0deg;
}
.book__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4.2rem 5.9rem;
  margin-top: 0;
  padding: 3rem 4rem 5rem;
  border: 0.1rem solid #a2a2a2;
  border-top: none;
}
@media screen and (max-width: 767px) {
  .book__list {
    grid-template-columns: 1fr;
  }
}
.book__list figure {
  display: flex;
  flex-direction: column;
  row-gap: 2rem;
}
.book__list figure img {
  width: 37.2rem;
  height: auto;
}
.book__list figure figcaption {
  font-size: 1.8rem;
  font-weight: bold;
}
@media screen and (max-width: 767px) {
  .book__list figure figcaption {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 767px) {
  .about .utillity_block iframe {
    width: 34.5rem;
    height: 19.4rem;
  }
}
.profile {
  margin-top: 9rem;
}
.profile_main {
  display: flex;
  column-gap: 8.8rem;
}
@media screen and (max-width: 767px) {
  .profile_main {
    flex-direction: column;
    row-gap: 3rem;
  }
}
.profile_main > img {
  width: 57rem;
  height: auto;
}
.profile__name {
  font-size: 5.8rem;
}
@media screen and (max-width: 767px) {
  .profile__name {
    font-size: 3.6rem;
  }
}
.profile__post {
  margin-top: 2.5rem;
  padding-left: 0;
  font-size: 1.8rem;
  line-height: calc(30 / 18);
}
@media screen and (max-width: 767px) {
  .profile__post {
    font-size: 1.4rem;
  }
}
.profile__qualification {
  margin-top: 2.3rem;
}
.profile__qualification_heading {
  font-size: 2.2rem;
}
.profile__qualification_list {
  margin-top: 0.9rem;
  padding-left: 0;
  font-size: 1.6rem;
  line-height: calc(27 / 16);
}
@media screen and (max-width: 767px) {
  .profile__qualification_list {
    font-size: 1.4rem;
  }
}
.profile__message {
  margin-top: 1.9rem;
  font-size: 1.6rem;
  line-height: calc(27 / 16);
}
@media screen and (max-width: 767px) {
  .profile__message {
    font-size: 1.4rem;
  }
}
.biography {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .biography {
    margin-top: 6rem;
  }
}
.biography__summary {
  display: flex;
  align-items: center;
  padding: 2rem 10.8rem 2rem 4rem;
  background: #f8f8f8;
  font-size: 2.8rem;
  font-weight: bold;
  line-height: 1;
  border: 0.1rem solid #a2a2a2;
  position: relative;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .biography__summary {
    padding: 2rem 7.3rem 2rem 1.5rem;
    font-size: 2.2rem;
  }
}
.biography__summary_icon {
  flex-shrink: 0;
  display: block;
  width: 6.8rem;
  height: 100%;
  background: #797979;
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .biography__summary_icon {
    width: 6.2rem;
  }
}
.biography__summary_icon::before,
.biography__summary_icon::after {
  content: "";
  width: 3.5rem;
  height: 0.1rem;
  margin: auto;
  background: #ffffff;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .biography__summary_icon::before,
  .biography__summary_icon::after {
    width: 2.5rem;
  }
}
.biography__summary_icon::after {
  rotate: 90deg;
}
.biography[open] .biography__summary_icon::after {
  rotate: 0deg;
}
.biography__contents {
  padding: 3rem 4rem 8.5rem;
  border: 0.1rem solid #a2a2a2;
  border-top: none;
  font-size: 1.6rem;
  line-height: calc(36 / 16);
}
@media screen and (max-width: 767px) {
  .biography__contents {
    padding: 2rem 1.5rem 4rem;
    font-size: 1.4rem;
  }
}
.biography__contents dt,
.biography__contents p {
  font-weight: bold;
}
.biography__contents dl:not(:first-child),
.biography__contents dt:not(:first-child),
.biography__contents p:not(:first-child) {
  margin-top: 1em;
}
.media {
  margin-top: 8rem;
}
.media__list {
  display: flex;
  flex-wrap: wrap;
  gap: 7rem 3.7rem;
  margin-top: 5rem;
  padding-left: 0;
}
@media screen and (max-width: 767px) {
  .media__list {
    row-gap: 2.5rem;
  }
}
.media__list li figure {
  display: flex;
  flex-direction: column;
  row-gap: 1.7rem;
}
@media screen and (max-width: 767px) {
  .media__list li figure {
    row-gap: 1rem;
  }
}
.media__list li figure img {
  width: 38.7rem;
  height: auto;
}
.media__list li figure figcaption {
  flex-grow: 1;
  display: flex;
  align-items: center;
  font-size: 2.1rem;
  font-weight: bold;
  line-height: calc(36 / 21);
}
@media screen and (max-width: 767px) {
  .media__list li figure figcaption {
    font-size: 1.6rem;
  }
}
.media__list li figure figcaption a {
  color: #333333;
  text-decoration: underline;
}
.media__list li figure figcaption a[target="_blank"]::after {
  content: "";
  display: inline-block;
  width: 1.6rem;
  height: 1.5rem;
  margin-left: 1em;
  background: url(./img/icon_blank.svg) no-repeat center / contain;
  vertical-align: middle;
}
.media__list .media__list_item--main {
  width: 100%;
}
.media__list .media__list_item--main figure img {
  width: 57rem;
  height: auto;
}
.media__list .media__list_item--main figure {
  flex-direction: row;
  column-gap: 4.7rem;
}
@media screen and (max-width: 767px) {
  .media__list .media__list_item--main figure {
    flex-direction: column;
  }
}
.media__list .media__list_item--main figure figcaption {
  font-size: 2.4rem;
  line-height: calc(41 / 24);
}
@media screen and (max-width: 767px) {
  .media__list .media__list_item--main figure figcaption {
    font-size: 1.6rem;
  }
}
.hospitals {
  margin-top: 29.6rem;
}
@media screen and (max-width: 767px) {
  .hospitals {
    margin-top: 10rem;
  }
}
.hospitals__text {
  margin-top: 8rem;
  font-size: 2.4rem;
  line-height: calc(41 / 24);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .hospitals__text {
    margin-top: 5rem;
    font-size: 1.8rem;
  }
}
.hospitals__sub-text {
  margin-top: 6rem;
  font-size: 1.8rem;
  line-height: calc(31 / 18);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .hospitals__sub-text {
    margin-top: 5rem;
  }
}
.hospitals__sub-text + .hospitals__sub-text {
  margin-top: 1em;
}
.hospital {
  margin-top: 6.4rem;
}
@media screen and (max-width: 767px) {
  .hospital {
    margin-top: 5rem;
  }
}
.hospital + .hospital {
  margin-top: 4.8rem;
}
@media screen and (max-width: 767px) {
  .hospital + .hospital {
    margin-top: 3.5rem;
  }
}
.hospital__summary {
  display: flex;
  align-items: center;
  padding: 2rem 10.8rem 2rem 4rem;
  background: #f8f8f8;
  font-size: 2rem;
  font-weight: bold;
  line-height: 1;
  border: 0.1rem solid #a2a2a2;
  position: relative;
  cursor: pointer;
}
@media screen and (max-width: 767px) {
  .hospital__summary {
    flex-direction: column;
    align-items: flex-start;
    row-gap: 1rem;
    padding: 2rem 7.3rem 2rem 1.5rem;
    font-size: 2rem;
    line-height: 1.2;
  }
}
.hospital__summary span:not(.hospital__summary_icon) {
  margin-right: 1.8rem;
  font-size: 1.9rem;
  font-weight: normal;
}
@media screen and (max-width: 767px) {
  .hospital__summary span:not(.hospital__summary_icon) {
    font-size: 1.8rem;
  }
}
.hospital__summary_icon {
  flex-shrink: 0;
  display: block;
  width: 6rem;
  height: 100%;
  background: #797979;
  position: absolute;
  top: 0;
  right: 0;
}
@media screen and (max-width: 767px) {
  .hospital__summary_icon {
    height: 100%;
  }
}
.hospital__summary_icon::before,
.hospital__summary_icon::after {
  content: "";
  width: 3.5rem;
  height: 0.1rem;
  margin: auto;
  background: #ffffff;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
}
@media screen and (max-width: 767px) {
  .hospital__summary_icon::before,
  .hospital__summary_icon::after {
    width: 2.5rem;
  }
}
.hospital__summary_icon::after {
  rotate: 90deg;
}
.hospital[open] .hospital__summary_icon::after {
  rotate: 0deg;
}
.hospital__contents {
  display: grid;
  grid-template-columns: minmax(0, 47.5rem) 1fr;
  gap: 3.4rem 5.6rem;
  padding: 5.6rem 10rem 4.7rem;
  border: 0.1rem solid #a2a2a2;
  border-top: none;
}
@media screen and (max-width: 767px) {
  .hospital__contents {
    grid-template-columns: 1fr;
    padding: 2rem 1.5rem;
  }
}
.hospital__contents > img {
  width: 47.5rem;
  height: auto;
}
.hospital__contents dl dt,
.hospital__contents dl dd {
  font-size: 1.8rem;
  line-height: calc(31 / 18);
}
@media screen and (max-width: 767px) {
  .hospital__contents dl dt,
  .hospital__contents dl dd {
    font-size: 1.4rem;
  }
}
.hospital__contents dl dt {
  font-weight: bold;
}
.hospital__contents dl dt:not(:first-child) {
  margin-top: 1em;
}
.hospital__btn {
  display: flex;
  place-content: center;
  margin-top: 1.7rem;
  padding: 2rem 5rem;
  color: #472573;
  font-size: 1.5rem;
  font-weight: bold;
  text-decoration: none;
  border: 0.1rem solid #472573;
  border-radius: 10rem;
  position: relative;
  box-shadow: 0 0.3rem 3.6rem rgba(0, 0, 0, 0.1);
}
@media screen and (max-width: 767px) {
  .hospital__btn {
    padding: 1.5rem 4rem;
    font-size: 1.4rem;
  }
}
.hospital__btn + .hospital__btn {
  margin-top: 1rem;
}
.hospital__btn::after {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  margin-block: auto;
  border-top: 0.2rem solid #472573;
  border-right: 0.2rem solid #472573;
  rotate: 45deg;
  position: absolute;
  top: 0;
  right: 2.2rem;
  bottom: 0;
}
@media screen and (max-width: 767px) {
  .hospital__btn::after {
    right: 1.5rem;
  }
}
.hospital__contents iframe {
  width: 100%;
  height: 100%;
  aspect-ratio: 475 / 356;
}
.hospital_sub {
  margin-top: 8rem;
}
@media screen and (max-width: 767px) {
  .hospital_sub {
    margin-top: 6rem;
  }
}
.hospital_sub .heading_3 {
  text-align: left;
}
.movies {
  margin-top: 14.5rem;
  padding-top: 8rem;
  padding-bottom: 10rem;
}
@media screen and (max-width: 767px) {
  .movies {
    margin-top: 10rem;
  }
}
.movies__text {
  margin-top: 6rem;
  font-size: 1.8rem;
  line-height: calc(31 / 18);
  text-align: center;
}
@media screen and (max-width: 767px) {
  .movies__text {
    margin-top: 5rem;
  }
}
.movies__text + .movies__text {
  margin-top: 1em;
}
.movies__list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 3.8rem;
  margin-top: 6rem;
  padding-left: 0;
}
@media screen and (max-width: 767px) {
  .movies__list li iframe {
    width: 34.5rem;
  }
}
.footer {
  padding-top: 1.3rem;
  padding-bottom: 1.1rem;
  background: #797979;
}
.footer__copyright {
  color: #ffffff;
  font-size: 1.6rem;
  text-align: center;
}
