@charset "UTF-8";
/*======================================================
共通部分
======================================================*/
body {
  color: #333333;
  background: #fff;
  line-height: 1;
  position: relative;
  font-family: "Yu Gothic UI", "Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;
  word-wrap: break-word;
  font-size: 16px;
}

main {
  margin-top: 146px;
}

*::-moz-selection {
  background: #9dcaf1;
  color: #fff;
}
*::selection {
  background: #9dcaf1;
  color: #fff;
}

@media (min-width: 561px) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
    text-decoration: none;
    color: #333;
  }
}
img {
  max-width: 100%;
  vertical-align: bottom;
}

li {
  list-style: none;
}

a {
  text-decoration: none;
  transition: all 0.3s ease-in-out;
  color: #333;
  display: block;
}
a:plink {
  display: inline;
  color: #0082d5;
  text-decoration: underline;
}
a:hover {
  opacity: 0.8;
}

table {
  border-collapse: collapse;
}

.youtube-wrap {
  width: 100%;
  padding-bottom: 56.25%;
  height: 0px;
  position: relative;
}
.youtube-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  vertical-align: middle;
}

.secpad {
  width: 740px;
  margin: 0 auto;
}
@media (max-width: 560px) {
  .secpad {
    width: 100%;
  }
}

.secpad3 {
  width: 650px;
  margin: 0 auto;
}
@media (max-width: 560px) {
  .secpad3 {
    width: 100%;
  }
}

@media (max-width: 560px) {
  .pc-only {
    display: none;
  }
}
@media (min-width: 561px) {
  .sp-only {
    display: none;
  }
}
.tcenter {
  text-align: center;
}

.mb0 {
  margin-bottom: 0px !important;
}

.mb4 {
  margin-bottom: 4px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mt0 {
  margin-top: 0px !important;
}

.mt4 {
  margin-top: 4px !important;
}

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

.mt20 {
  margin-top: 20px !important;
}

.mt40 {
  margin-top: 40px !important;
}

.mt50 {
  margin-top: 50px !important;
}

#fixed-menu {
  display: none;
  position: fixed;
  top: 146px;
  width: 100%;
  z-index: 99999;
}
#fixed-menu .flex-menu ul {
  display: flex;
  justify-content: center;
  margin-top: 10px;
}
#fixed-menu .flex-wrap-menu {
  width: 900px;
  margin: 0 auto;
}
#fixed-menu .flex-wrap-menu ul {
  display: flex;
  flex-wrap: wrap;
}
#fixed-menu .flex-wrap-menu ul li {
  width: 33.3333333333%;
}
@media screen and (max-width: 560px) {
  #fixed-menu {
    top: 78px;
  }
}

.btn-list-raw {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
@media (max-width: 560px) {
  .btn-list-raw {
    gap: 15px;
  }
}
.btn-list-raw li {
  width: calc(50% - 6px);
}
@media (max-width: 560px) {
  .btn-list-raw li {
    width: 100%;
  }
}
.btn-list-raw a {
  padding: 20px 30px 20px 20px;
  border-radius: 6px;
  border: solid 1px #00a9bc;
  background: #fff;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  font-size: 16px;
  display: block;
  position: relative;
}
.btn-list-raw a::after {
  content: url(../images/ar02.svg);
  position: absolute;
  top: 50%;
  right: 15px;
  transform: translateY(-50%);
}

.btn-list-pdf {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.btn-list-pdf li {
  width: calc(50% - 8px);
}
@media (max-width: 560px) {
  .btn-list-pdf li {
    width: 100%;
  }
}
.btn-list-pdf a {
  padding: 25px 14px 25px 66px;
  position: relative;
  border: solid 1px #00a9bc;
  background: #fff;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  border-radius: 6px;
}
.btn-list-pdf a::before {
  content: url(../images/ico-pdf.svg);
  position: absolute;
  left: 13px;
  top: 50%;
  transform: translateY(-50%);
}

.btn_futo {
  position: relative;
  padding: 20px 14px;
  border: solid 1px #00a9bc;
  background: #fff;
  box-shadow: 0px 3px 6px rgba(0, 0, 0, 0.16);
  border-radius: 6px;
  color: #00a9bc;
  font-weight: bold;
}
.btn_futo::after {
  content: url(../images/ar03.svg);
  position: absolute;
  right: 13px;
  top: 50%;
  transform: translateY(-50%);
}
.btn_futo.noarrow::after {
  display: none;
}

/*======================================================
header
======================================================*/
body > header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  background-color: #fff;
}
body > header .header-top {
  width: 100%;
  padding: 13px 0 5px;
}
body > header .header-top .header-top-inner {
  width: 950px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}
body > header .header-top .header-top-inner h1 a {
  display: flex;
  align-items: center;
}
body > header .header-top .header-top-inner h1 a img:nth-child(1) {
  margin-right: 10px;
}
body > header .header-top .header-top-inner .header-top-content {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
body > header .header-top .header-top-inner .header-top-content .header-top-menu {
  display: flex;
  justify-content: flex-end;
  margin-bottom: 8px;
}
body > header .header-top .header-top-inner .header-top-content .header-top-menu li:not(:last-child) {
  border-right: 1px solid #333333;
  margin-right: 15px;
  padding-right: 15px;
}
body > header .header-top .header-top-inner .header-top-content .header-top-menu li a {
  color: #333333;
  font-size: 16px;
  line-height: 0.8;
  display: flex;
}
body > header .header-top .header-top-inner .header-top-content .header-top-menu li a span {
  margin-right: 5px;
}
body > header .header-top .header-top-inner .header-top-content .header-top-contact {
  display: flex;
}
body > header .header-top .header-top-inner .header-top-content .header-top-contact .hours {
  font-size: 16px;
  line-height: 1;
  margin-right: 10px;
}
body > header .header-top .header-top-inner .header-top-content .header-top-contact .hours span {
  display: block;
  margin-bottom: 5px;
  color: #00a9bc;
  font-weight: bold;
  font-size: 21px;
}
body > header .header-top .header-top-inner .header-top-content .header-top-contact .tel a {
  font-size: 46px;
  font-weight: bold;
  color: #00a9bc;
  line-height: 0.8;
}
body > header .header-bottom {
  background: #00a9bc;
  padding: 10px 0;
}
body > header .header-bottom ul {
  margin: 0 auto;
  display: flex;
  justify-content: center;
  width: 1100px;
}
body > header .header-bottom ul li {
  padding: 11px 0;
  position: relative;
  width: 16.6666666667%;
}
body > header .header-bottom ul li:not(:last-child) {
  border-right: solid 1px #fff;
}
body > header .header-bottom ul li a {
  display: block;
  color: #fff;
  font-size: 20px;
  text-align: center;
  font-weight: bold;
  letter-spacing: 0.6px;
  line-height: 1;
}
body > header .header-bottom ul li a::after {
  content: url(../images/arrow_w.svg);
  position: absolute;
  top: 48%;
  transform: translateY(-50%);
  margin-left: 5px;
}
body #pc-header {
  display: block;
}
body #sp-header {
  display: none;
}
body .sp-header-logo {
  display: none;
}

/*======================================================
footer
======================================================*/
footer {
  background: #00a9bc;
  color: #fff;
}
footer a {
  color: #fff;
  display: block;
  line-height: 1.33;
}
footer p {
  line-height: 1.33;
}
footer .footer-inner {
  width: 900px;
  margin: 0 auto;
  padding: 30px 0 0;
}
footer .footer-inner .footer-top {
  display: flex;
  margin-bottom: 20px;
}
footer .footer-inner .footer-top .footer-top-h1 {
  margin-right: 30px;
}
footer .footer-inner .footer-top .footer-top-profile .footer-own-address {
  font-size: 16px;
  line-height: 1.35;
}
footer .footer-inner .footer-top .footer-top-profile .footer-own-access {
  display: flex;
  align-items: center;
}
footer .footer-inner .footer-top .footer-top-profile .footer-own-access p {
  margin-right: 15px;
  line-height: 1.35;
}
footer .footer-inner .footer-top .footer-top-profile .footer-own-access a:not([class]) {
  background: #fff;
  position: relative;
  color: #00a9bc;
  border-radius: 6px;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 8px 90px;
}
footer .footer-inner .footer-top .footer-top-profile .footer-own-access a:not([class])::after {
  content: url(../images/arrow_b.svg);
  position: absolute;
  font-weight: bold;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
}
footer .footer-inner .footer-top .footer-top-profile .footer-own-access a.footer-sns {
  margin-left: 8px;
}
footer .footer-inner .footer-middle {
  display: flex;
  padding-bottom: 20px;
  border-bottom: dashed 1px #fff;
}
footer .footer-inner .footer-middle .footer-middle_1 {
  margin-right: 20px;
}
footer .footer-inner .footer-middle .footer-middle_1 li {
  margin-bottom: 6px;
}
footer .footer-inner .footer-middle .footer-middle_1 li::before {
  content: url(../images/arrow_w.svg);
  margin-right: 6px;
}
footer .footer-inner .footer-middle .footer-middle_1 li a {
  display: inline-block;
}
footer .footer-inner .footer-middle .footer-middle_2:not(:last-child) {
  margin-right: 20px;
}
footer .footer-inner .footer-middle .footer-middle_2 > a {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 3px;
}
footer .footer-inner .footer-middle .footer-middle_2 > a::before {
  content: url(../images/arrow_w.svg);
  margin-right: 6px;
}
footer .footer-inner .footer-middle .footer-middle_2 ul:not([class]) li {
  margin-bottom: 3px;
  position: relative;
  padding-left: 18px;
}
footer .footer-inner .footer-middle .footer-middle_2 ul:not([class]) li::before {
  content: "├";
  position: absolute;
  left: 0;
}
footer .footer-inner .footer-middle .footer-middle_2 ul:not([class]) li:last-child::before {
  content: "└";
}
footer .footer-inner .footer-middle .btn-list li + li {
  margin-top: 6px;
}
footer .footer-inner .footer-middle .btn-list .text-btn a {
  font-size: 14px;
  margin-top: 16px;
  border: solid 1px #00a9bc;
  background: #fff;
  color: #00a9bc;
  border-radius: 6px;
  padding: 8px 0;
  text-align: center;
  line-height: 1.1;
  width: 121px;
}
footer .footer-inner .footer-bottom {
  padding: 12px 0;
  border-bottom: dashed 1px #fff;
  display: flex;
}
footer .footer-inner .footer-bottom p,
footer .footer-inner .footer-bottom a {
  font-size: 13px;
  line-height: 1.5;
}
footer .footer-inner .footer-bottom a {
  text-decoration: underline;
}
footer .footer-inner .footer-bottom .footer-bottom-box:not(:last-child) {
  margin-right: 10px;
}
footer .footer-ex {
  width: 900px;
  margin: 0 auto;
  padding: 18px 0 25px;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
}
footer .footer-ex a {
  font-size: 12px;
  margin-right: 21px;
  position: relative;
}
footer .footer-ex a::before {
  content: url(../images/arrow_w.svg);
  position: absolute;
  top: 50%;
  left: -15px;
  transform: translateY(-50%);
  margin-left: 5px;
}
footer .footer-ex a + a {
  margin-left: 15px;
}

/*======================================================
common parts
======================================================*/
.btn_red {
  display: block;
  position: relative;
  border: 1px solid #e1474d;
  border-radius: 6px;
  font-size: 18px;
  text-align: center;
  padding: 8px 0;
  color: #e1474d;
  box-shadow: 0px 4px 6px #cfcfcf;
}
.btn_red::after {
  content: url(../images/arrow_r.svg);
  position: absolute;
  font-weight: bold;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
}

.btn_blue {
  display: block;
  position: relative;
  background: #00a9bc;
  border-radius: 6px;
  font-size: 18px;
  padding: 18px 0;
  text-align: center;
  color: #fff;
  box-shadow: 0px 4px 6px #cfcfcf;
}
.btn_blue::after {
  content: url(../images/arrow_w.svg);
  position: absolute;
  font-weight: bold;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
}

.btn_white {
  display: block;
  position: relative;
  background: #fff;
  border-radius: 6px;
  border: 1px solid #00a9bc;
  font-size: 18px;
  padding: 8px 0;
  text-align: center;
  color: #00a9bc;
  box-shadow: 0px 4px 6px #cfcfcf;
}
.btn_white::after {
  content: url(../images/arrow_b.svg);
  position: absolute;
  font-weight: bold;
  right: 15px;
  top: 50%;
  transform: translateY(-50%);
}

.common-totop-btn {
  position: fixed;
  right: 40px;
  bottom: 40px;
  width: 110px;
  height: 110px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(181, 181, 181, 0.8);
  color: #fff;
  border-radius: 50%;
  font-size: 25px;
  padding-top: 5px;
}
.common-totop-btn::before {
  content: url(/images/arrow_w_totop.svg);
  position: absolute;
  left: 50%;
  top: 12px;
  transform: translateX(-50%);
}

.common-banner {
  max-width: -moz-fit-content;
  max-width: fit-content;
  margin-left: auto;
  margin-right: auto;
  display: block;
  margin-bottom: 30px;
}
.common-banner img {
  max-width: 100%;
}
.common-banner.w450 {
  max-width: 450px;
}
.common-banner.w450 img {
  width: 450px;
}

.common-linknavi .common-linknavi-inner {
  width: 740px;
  margin: 0 auto;
}
.common-linknavi .common-linknavi-inner ul {
  display: flex;
  justify-content: center;
}

.common-link-text {
  display: inline;
  color: #0082d5;
  text-decoration: underline;
}

ul.notes-list-maru li {
  list-style: none;
  line-height: 1.375;
  position: relative;
  padding-left: 18px;
}
ul.notes-list-maru li:before {
  content: "〇";
  font-weight: bold;
  position: absolute;
  left: 0px;
  color: #00a9bc;
}
ul.notes-list-maru li:not(:last-child) {
  margin-bottom: 4px;
}
ul.notes-list-maru + p {
  margin-top: 4px;
}

.common-flex-dl div {
  display: flex;
}
.common-flex-dl div dt,
.common-flex-dl div dd {
  line-height: 1.375;
  font-size: 16px;
}
.common-flex-dl div dt {
  text-align: right;
}

@media (min-width: 561px) {
  .common-flex {
    display: flex;
  }
  .common-flex ul:not(:last-child) {
    padding-right: 40px;
  }
}
.common-gallery-wrap {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 120px;
}
.common-gallery-wrap li {
  width: calc((100% - 30px) / 3);
}
.common-gallery-wrap li:not(:nth-child(3n)) {
  margin-right: 15px;
}
.common-gallery-wrap li:nth-child(n+4) {
  margin-top: 40px;
}
.common-gallery-wrap li .image {
  background: #eeeeee;
  margin-bottom: 8px;
}
.common-gallery-wrap li .image img {
  display: block;
  margin: 0 auto;
  height: 272px;
}
.common-gallery-wrap li p {
  text-align: center;
  font-size: 14px;
  line-height: 1.1428571429;
}

.breadcrumb {
  display: flex;
  width: 900px;
  margin: 0 auto;
  padding: 11px 0;
}
.breadcrumb li {
  font-size: 14px;
}
.breadcrumb li:not(:last-child) {
  margin-right: 5px;
}
.breadcrumb li:not(:last-child)::after {
  content: ">";
  color: #00a9bc;
  margin-left: 5px;
}
.breadcrumb li:last-child {
  text-decoration: underline;
  color: #00a9bc;
}
.breadcrumb li a {
  font-size: 14px;
  color: #00a9bc;
  display: inline;
}

.pagination .page-numbers {
  display: flex;
  justify-content: center;
}
.pagination .page-numbers li:not(:last-child) {
  margin-right: 20px;
}
.pagination .page-numbers li:first-child {
  margin-right: 30px;
}
.pagination .page-numbers li:first-child a {
  width: 90px;
}
.pagination .page-numbers li:last-child {
  margin-left: 10px;
}
.pagination .page-numbers li:last-child a {
  width: 90px;
}
.pagination .page-numbers li a,
.pagination .page-numbers li span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 60px;
  height: 60px;
  border: solid 1px #707070;
}
.pagination .page-numbers li .prev,
.pagination .page-numbers li .next {
  width: 90px;
}
.pagination .page-numbers li .current {
  background: #00a9bc;
  color: #fff;
  border: solid 1px #00a9bc;
}
.pagination .page-numbers li .dot {
  border: 0;
  width: auto;
}
.pagination .page-numbers li .inactive {
  color: #b5b5b5;
  border: solid 1px #b5b5b5;
}

ul.search-list {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 30px;
  gap: 15px;
}
ul.search-list li {
  width: 290px;
}
ul.search-list li a {
  background: #fff;
  display: flex;
  position: relative;
  flex-direction: column;
  align-items: center;
  border-radius: 6px;
  padding: 25px 0 46px;
  border: 1px solid #999999;
  box-shadow: 0px 3px 10px #cfcfcf;
  height: 100%;
}
ul.search-list li a::after {
  content: "";
  position: absolute;
  background: url(../images/arrow_b_tobottom.svg) 0 0/contain;
  width: 17px;
  height: 10px;
  bottom: 18px;
  left: 50%;
  transform: translate(-50%);
}
ul.search-list li a h3 {
  text-align: center;
  position: relative;
  margin-bottom: 15px;
  font-size: 24px;
}
ul.search-list li a h3::after {
  content: "";
  width: 50px;
  height: 1px;
  background: #00a9bc;
  position: absolute;
  bottom: -8px;
  left: 50%;
  transform: translateX(-50%);
}
ul.search-list li a .image {
  height: 100px;
  display: flex;
  align-items: center;
}
ul.search-list li a p {
  width: 220px;
  line-height: 1.35;
  text-align: center;
}

.gmap-wrap {
  position: relative;
  width: 100%;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;
  margin-top: 20px;
}
.gmap-wrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.t-center {
  text-align: center;
}

.t-right {
  text-align: right;
}

.t-bold {
  font-weight: bold;
}

.t-lead {
  text-align: center;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.33;
}

.t-black {
  color: #333 !important;
}

.t-red {
  color: #e1474d !important;
}

.t-blue {
  color: #00a9bc !important;
}

.t-hosoku {
  font-size: 14px !important;
  line-height: 1.2857142857 !important;
}

.t-underline {
  text-decoration: underline;
}

.kome {
  display: block;
  position: relative;
  padding-left: 18px;
}
.kome:before {
  content: "※";
  font-weight: bold;
  position: absolute;
  left: 0px;
}

.image.w200 img {
  width: 200px;
}
@media (max-width: 560px) {
  .image.w200 img {
    display: block;
    margin: 0 auto;
  }
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb16 {
  margin-bottom: 16px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

/*======================================================
Index
======================================================*/
.blog-banner {
  width: 740px;
  max-width: 100%;
  display: flex;
}
.blog-banner > div {
  width: 50%;
  background-position: left;
  background-size: cover;
}
.blog-banner picture {
  width: 50%;
}

body .home section h2 {
  text-align: center;
  position: relative;
  font-size: 34px;
  margin-bottom: 42px;
}
body .home section h2::after {
  content: "";
  width: 120px;
  height: 1px;
  background: #00a9bc;
  position: absolute;
  bottom: -15px;
  left: 50%;
  transform: translateX(-50%);
}
body .home #top-impnews .secpad {
  padding: 40px 0 30px;
}
body .home #top-impnews .secpad .top-impnews-wrap {
  padding: 30px 45px;
  border: 3px solid #e1474d;
  border-radius: 6px;
}
body .home #top-impnews .secpad .top-impnews-wrap h2 {
  text-align: center;
  color: #e1474d;
  margin-bottom: 20px;
  display: flex;
  justify-content: center;
}
body .home #top-impnews .secpad .top-impnews-wrap h2::before {
  content: url(/images/impnews-icon.svg);
  margin-right: 10px;
}
body .home #top-impnews .secpad .top-impnews-wrap h2::after {
  display: none;
}
body .home #top-impnews .secpad .top-impnews-wrap ul {
  margin-bottom: 25px;
}
body .home #top-impnews .secpad .top-impnews-wrap ul li {
  padding: 13px 0;
  border-bottom: solid 1px #eaeaea;
}
body .home #top-impnews .secpad .top-impnews-wrap ul li a {
  display: flex;
  align-items: center;
}
body .home #top-impnews .secpad .top-impnews-wrap ul li a .cat {
  width: 66px;
  background: #e1474d;
  border-radius: 3px;
  padding: 4px 0;
  color: #fff;
  text-align: center;
  margin-right: 16px;
  font-size: 12px;
}
body .home #top-impnews .secpad .top-impnews-wrap ul li a time {
  font-size: 16px;
  margin-right: 16px;
}
body .home #top-impnews .secpad .top-impnews-wrap ul li a .news-title {
  width: calc(100% - 160px);
  color: #e1474d;
  font-size: 16px;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  box-orient: vertical;
  line-clamp: 1;
  text-overflow: ellipsis;
  overflow: hidden;
}
body .home #top-impnews .secpad .top-impnews-wrap .btn_red {
  width: 320px;
  margin: 0 auto;
}
body .home #top-search {
  background: #eefafb;
  padding: 60px 0;
  margin-bottom: 60px;
}
body .home #top-search .secpad {
  width: 900px;
}
body .home #top-search .secpad .btn_blue {
  width: 550px;
  margin: 0 auto;
  box-shadow: 0px 3px 10px #cfcfcf;
}
body .home .top-linkguide a {
  width: 740px;
  margin: 0 auto;
  display: block;
}
body .home #top-news {
  padding: 60px 0 100px;
}
body .home #top-news .btn_white {
  width: 320px;
  margin: 0 auto;
}

ul.news-wrap {
  margin-bottom: 25px;
}
ul.news-wrap li {
  padding: 13px 0;
  border-bottom: solid 1px #eaeaea;
}
ul.news-wrap li a {
  display: flex;
  align-items: center;
}
ul.news-wrap li a .cat {
  width: 66px;
  background: #00a9bc;
  border-radius: 3px;
  padding: 4px 0;
  color: #fff;
  text-align: center;
  margin-right: 16px;
  font-size: 12px;
}
ul.news-wrap li a .cat-02 {
  background: #e1474d;
}
ul.news-wrap li a time {
  font-size: 16px;
  margin-right: 16px;
}
ul.news-wrap li a .news-title {
  font-size: 16px;
  width: calc(100% - 160px);
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  box-orient: vertical;
  line-clamp: 1;
  text-overflow: ellipsis;
  overflow: hidden;
}

@media (min-width: 561px) {
  .top-sp-only {
    display: none;
  }
}
@media (max-width: 560px) {
  .top-sp-only {
    color: #00a9bc;
    font-weight: bold;
    font-size: 20px;
    line-height: 1.7;
    text-align: center;
  }
}
/*======================================================
固定ページ　共通パーツ
======================================================*/
.page-common > section.bg1 {
  background: #eefafb;
}
.page-common > section.bg0 + .bg0 .secpad {
  padding: 0px 0 60px;
}
.page-common > section:first-child .secpad {
  padding: 40px 0 60px;
}
.page-common > section:last-child .secpad {
  padding: 60px 0 100px;
}
.page-common > section .btn_blue {
  padding: 20px 0;
  width: 550px;
  margin: 0 auto;
}
.page-common > section .tel {
  color: #00a9bc;
  font-size: 20px;
  line-height: 1.35;
  font-weight: bold;
  margin-bottom: 30px;
  display: flex;
}
.page-common > section .tel .image {
  margin-right: 7px;
  display: flex;
  align-items: center;
}
.page-common > section .secpad {
  padding: 60px 0;
}
@media (min-width: 561px) {
  .page-common > section .secpad .secpad2 {
    padding-left: 60px;
  }
  .page-common > section .secpad .secpad2 > p {
    margin-bottom: 4px;
  }
}
.page-common > section .secpad h1 {
  font-size: 34px;
  text-align: center;
  position: relative;
  margin-bottom: 42px;
  line-height: 1.3529411765;
}
.page-common > section .secpad h1::after {
  content: "";
  position: absolute;
  width: 90px;
  height: 1px;
  background: #00a9bc;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
}
.page-common > section .secpad h1 + img {
  margin-bottom: 20px;
}
.page-common > section .secpad p + h1 {
  margin-top: 75px;
}
.page-common > section .secpad h2 {
  position: relative;
  font-size: 20px;
  text-align: left;
  padding-left: 9px;
  margin-bottom: 4px;
  line-height: 1.35;
  letter-spacing: 0.4px;
}
.page-common > section .secpad h2::before {
  content: "";
  background: #00a9bc;
  height: 25px;
  width: 3px;
  position: absolute;
  left: -2px;
  top: 2px;
}
.page-common > section .secpad h2:not(:first-child) {
  margin-top: 20px;
}
.page-common > section .secpad h3 {
  color: #00a9bc;
  font-size: 16px;
  margin-bottom: 4px;
  line-height: 1.35;
}
.page-common > section .secpad p {
  line-height: 1.5;
}
.page-common > section .secpad > p {
  margin-bottom: 20px;
}
.page-common > section .secpad .image-wrap-1 {
  display: flex;
  justify-content: center;
  align-items: flex-start;
}
.page-common > section .secpad .image-wrap-2 {
  display: flex;
  align-items: flex-start;
}
.page-common > section .secpad .image-wrap-2 > figure {
  width: calc((100% - 12px) / 2);
}
.page-common > section .secpad .image-wrap-2 > figure:not(:nth-child(2n)) {
  margin-right: 12px;
}
.page-common > section .secpad .image-wrap-2 > figure img {
  width: 100%;
}
.page-common > section .secpad .image-wrap-2 > figure figcaption {
  display: none;
}
.page-common > section .secpad .image-wrap-2 > img {
  width: calc((100% - 12px) / 2);
}
.page-common > section .secpad .image-wrap-2 > img:not(:nth-child(2n)) {
  margin-right: 12px;
}
.page-common > section .secpad .image-wrap-3 {
  display: flex;
  align-items: flex-start;
}
.page-common > section .secpad .image-wrap-3 img {
  width: calc((100% - 32px) / 3);
}
.page-common > section .secpad .image-wrap-3 img:not(:nth-child(3n)) {
  margin-right: 16px;
}
.page-common > section .secpad table.calender-wrap {
  margin-bottom: 20px;
}
.page-common > section .secpad table.calender-wrap th,
.page-common > section .secpad table.calender-wrap td {
  border-right: solid 1px #707070;
  border-bottom: solid 1px #707070;
}
.page-common > section .secpad table.calender-wrap th {
  font-size: 24px;
  background: #fff;
}
.page-common > section .secpad table.calender-wrap td {
  font-size: 22px;
  text-align: center;
  background: #fff;
}
.page-common > section .secpad table.calender-wrap thead tr th {
  height: 70px;
  width: 70px;
  border-top: solid 1px #707070;
}
.page-common > section .secpad table.calender-wrap thead tr th:first-child {
  width: 260px;
  border-left: solid 1px #707070;
}
.page-common > section .secpad table.calender-wrap thead tr th:nth-child(7) {
  color: #008fbc;
}
.page-common > section .secpad table.calender-wrap thead tr th:nth-child(7) span.satur {
  font-size: 18px;
}
.page-common > section .secpad table.calender-wrap thead tr th:nth-child(8) {
  color: #e1474d;
}
.page-common > section .secpad table.calender-wrap thead tr th p {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.page-common > section .secpad table.calender-wrap tbody tr th,
.page-common > section .secpad table.calender-wrap tbody tr td {
  color: #30b4a2;
  height: 70px;
}
.page-common > section .secpad table.calender-wrap tbody tr th {
  border-left: solid 1px #707070;
}
.page-common > section .secpad .record_note {
  line-height: 1.375;
}
.page-common > section .secpad .record_note li {
  margin-bottom: 5px;
}
.page-common > section .secpad .record.precautions {
  margin-bottom: 10px !important;
}
.page-common > section .secpad .notes-flex {
  display: flex;
}
.page-common > section .secpad .notes-flex .notes-list {
  width: 50%;
}
.page-common > section .secpad .notes-flex .notes-list:nth-child(1) {
  margin-right: 40px;
}
.page-common > section .secpad ul.point-list {
  display: flex;
  flex-direction: column;
  width: 570px;
  max-width: 100%;
  align-items: flex-start;
  margin: 0 auto 20px;
}
.page-common > section .secpad ul.point-list li {
  list-style: none;
  line-height: 1.375;
  position: relative;
  font-weight: bold;
  font-size: 18px;
  line-height: 1.3333333333;
}
.page-common > section .secpad ul.point-list li::before {
  content: "■";
  color: #00a9bc;
  font-weight: bold;
  position: absolute;
  left: -17px;
  text-decoration: none;
  font-size: 10px;
  top: 6px;
  text-decoration: none;
}
.page-common > section .secpad ul.point-list li:not(:last-child) {
  margin-bottom: 4px;
}
.page-common > section .secpad .facility_list-container {
  display: flex;
  margin-top: 20px;
  gap: 40px;
  justify-content: center;
  line-height: 1.3;
}
@media (max-width: 560px) {
  .page-common > section .secpad .facility_list-container {
    flex-direction: column;
    gap: 0;
  }
}
.page-common > section .secpad ul.notes-list > li {
  list-style: none;
  line-height: 1.375;
  position: relative;
}
.page-common > section .secpad ul.notes-list > li:before {
  content: "";
  background: #00a9bc;
  width: 4px;
  height: 4px;
  font-weight: bold;
  position: absolute;
  top: 0.5em;
  left: -0.58em;
  text-decoration: none;
}
.page-common > section .secpad ul.notes-list > li:not(:last-child) {
  margin-bottom: 4px;
}
.page-common > section .secpad ul.notes-list > li ol.notes-list-order {
  padding-left: 3px;
}
.page-common > section .secpad ul.notes-list a:not([class]) {
  display: inline;
  color: #0082d5;
  text-decoration: underline;
}
.page-common > section .secpad ul.notes-list + p {
  margin-top: 4px;
}
.page-common > section .secpad > ul.notes-list {
  padding-left: 15px;
}
.page-common > section .secpad div.notes-list-contact {
  padding-left: 0px;
}
.page-common > section .secpad div.notes-list-contact li {
  list-style: none;
  line-height: 1.375;
}
.page-common > section .secpad div.notes-list-contact li:not(:last-child) {
  margin-bottom: 4px;
}
.page-common > section .secpad ul.notes-list-kome > li {
  list-style: none;
  line-height: 1.375;
  position: relative;
  padding-left: 18px;
}
.page-common > section .secpad ul.notes-list-kome > li:before {
  content: "※";
  font-weight: bold;
  position: absolute;
  left: 0px;
}
.page-common > section .secpad ul.notes-list-kome > li:not(:last-child) {
  margin-bottom: 4px;
}
.page-common > section .secpad ul.notes-list-kome + p {
  margin-top: 4px;
}
.page-common > section .secpad ol:not([class]) {
  padding-left: 16px;
}
.page-common > section .secpad ol:not([class]) > li {
  list-style: none;
  line-height: 1.375;
  margin-bottom: 4px;
}
.page-common > section .secpad ol.notes-list-order {
  counter-reset: item;
  list-style-type: none;
  padding-left: 0;
}
.page-common > section .secpad ol.notes-list-order > li {
  position: relative;
  line-height: 1.375;
}
.page-common > section .secpad ol.notes-list-order > li::before {
  position: absolute;
  left: -17px;
  counter-increment: item;
  content: counter(item) ".";
  padding-right: 0.5em;
  font-weight: bold;
  color: #00a9bc;
  text-align: right;
}
.page-common > section .secpad ol.notes-list-order > li:not(:last-child) {
  margin-bottom: 5px;
}
.page-common > section .secpad ol.notes-list-order > li a {
  display: inline;
}
.page-common > section .secpad ol.notes-list-order > li h3 {
  color: #333;
}
.page-common > section .secpad ul.notes-list-sq:not(:last-child) {
  margin-bottom: 6px;
}
.page-common > section .secpad ul.notes-list-sq li {
  list-style: none;
  line-height: 1.375;
  position: relative;
}
.page-common > section .secpad ul.notes-list-sq li:before {
  content: "□";
  position: absolute;
  left: -17px;
}
.page-common > section .secpad ul.notes-list-sq li:not(:last-child) {
  margin-bottom: 4px;
}
.page-common > section .member_list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 15px 70px;
}
.page-common > section .member_list h2 {
  text-align: center;
  font-size: 18px;
  margin-top: 9px;
  padding-left: 0;
}
.page-common > section .member_list h2::before {
  display: none;
}

@media (max-width: 560px) {
  .page-common > section .secpad .image-wrap-2 > figure {
    width: 100%;
  }
  .page-common > section .secpad .image-wrap-2 > figure:not(:last-child) {
    margin-bottom: 4px;
  }
  .page-common > section .secpad .image-wrap-2 > figure figcaption {
    display: block;
  }
  .page-common > section .secpad .image-wrap-2 > figure img {
    margin-bottom: 4px;
  }
}
/*======================================================
Index swiper
======================================================*/
.top-slider {
  width: 100%;
  margin: 0 auto;
}
.top-slider .swiper-container {
  position: relative;
}
.top-slider .swiper-container::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  background: rgba(255, 255, 255, 0.6);
  width: calc((100% - 900px) / 2);
  height: 100%;
  z-index: 9;
}
.top-slider .swiper-container::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  background: rgba(255, 255, 255, 0.6);
  width: calc((100% - 900px) / 2);
  height: 100%;
  z-index: 9;
}
.top-slider .swiper-slide {
  width: 900px;
  position: relative;
}
.top-slider .swiper-slide .top-slider-text {
  position: absolute;
  font-size: 24px;
  line-height: 1.6666666667;
  font-weight: bold;
  color: #fff;
  left: calc(50% - 415px);
  top: 24px;
  text-shadow: 4px 4px 10px rgba(0, 0, 0, 0.4);
  z-index: 99;
}

.swiper-container {
  width: 100%;
  overflow: hidden;
}

@media (min-width: 561px) {
  .top-slider .swiper-pagination {
    display: none;
  }
  .swiper-button-prev::after,
  .swiper-button-next::after {
    display: none;
  }
  .swiper-button-prev {
    left: calc(50vw - 450px - 20px) !important;
    background: url(../images/arrow_slider.svg) no-repeat;
    transform: translateX(-100%);
  }
  .swiper-button-next {
    right: calc(50vw - 450px - 20px) !important;
    transform: translateX(100%);
    background: url(../images/arrow_slider.svg) no-repeat;
  }
}
@media (max-width: 560px) {
  .swiper-button-prev,
  .swiper-button-next {
    display: none !important;
  }
}
/*======================================================
固定ページ　診療・外来
======================================================*/
.page-common.page-gairai > section#s1 .secpad {
  width: 900px;
}
.page-common.page-gairai > section#s1 .secpad ul.search-list li {
  width: 290px;
}
.page-common.page-gairai > section#s1 .secpad ul.search-list li a h3 {
  font-size: 24px;
  color: #333;
  bottom: -8px;
}
.page-common.page-gairai > section#s1 .secpad .common-banner {
  margin: 0 auto;
  width: 740px;
}
.page-common.page-gairai .gairai_flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 45px;
  gap: 15px;
}
.page-common.page-gairai .gairai_flex > a {
  max-width: 400px;
  flex: 1;
}
.page-common.page-gairai .gairai_flex img {
  -o-object-fit: cover;
     object-fit: cover;
  height: auto;
  max-height: 600px;
}
@media (max-width: 560px) {
  .page-common.page-gairai .gairai_flex {
    flex-direction: column;
    gap: 45px;
  }
}

/*======================================================
固定ページ　看護部
======================================================*/
.page-common > section .kangobu-aisatu-flex {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.page-common > section .kangobu-aisatu-flex > div {
  width: calc(100% - 30px - 200px);
}
.page-common > section .kangobu-aisatu-flex > div h3 {
  font-size: 18px;
  color: #333;
}
.page-common > section .kangobu-aisatu-flex > div p.name {
  margin-bottom: 4px;
}
.page-common > section .kangobu-aisatu-flex img {
  width: 200px;
}
.page-common > section .kensyu-wrap {
  display: flex;
}
.page-common > section .kensyu-wrap p {
  padding-right: 15px;
}

/*======================================================
固定ページ　入院案内
======================================================*/
.page-common > section .menkai-wrap div {
  display: flex;
}
.page-common > section .menkai-wrap div dt,
.page-common > section .menkai-wrap div dd {
  line-height: 1.375;
}
.page-common > section .menkai-wrap div dt {
  width: 56px;
}

.page-hospitalization .btn_blue.other_price {
  width: 400px;
  margin: 20px 0 35px;
  padding: 14px 0;
  font-size: 16px;
}
@media (max-width: 560px) {
  .page-hospitalization .btn_blue.other_price {
    width: 100%;
  }
}

/*======================================================
固定ページ　作品一覧
======================================================*/
.page-common.page-gallery > section .secpad {
  width: 900px;
  padding: 60px 0 100px;
  margin: 0 auto;
}
.page-common.page-gallery > section .secpad h1 {
  font-size: 34px;
  text-align: center;
  position: relative;
  margin-bottom: 42px;
}
.page-common.page-gallery > section .secpad h1::after {
  content: "";
  position: absolute;
  width: 120px;
  height: 1px;
  background: #00a9bc;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
}

/*======================================================
固定ページ　診療協力体制
======================================================*/
.page-common.page-team > section.team_1 dl {
  margin-bottom: 20px;
}
.page-common.page-team > section.team_1 dl dt {
  font-size: 20px;
  font-weight: bold;
  line-height: 1.35;
  text-align: center;
  color: #00a9bc;
  margin-bottom: 20px;
}
.page-common.page-team > section.team_1 nav ul {
  display: flex;
  justify-content: space-between;
}

/*======================================================
固定ページ　地域生活支援
======================================================*/
.page-common.page-area > section#s1 .secpad dl.area_1 div {
  margin-bottom: 10px;
}
.page-common.page-area > section#s1 .secpad dl.area_1 div dt {
  margin-bottom: 4px;
  line-height: 1.375;
}
.page-common.page-area > section#s1 .secpad dl.area_1 div dt:before {
  content: "・";
  color: #00a9bc;
  font-weight: bold;
  text-decoration: none;
}
.page-common.page-area > section#s1 .secpad dl.area_1 div dt.dt_type_list:before {
  display: none;
}
.page-common.page-area > section#s1 .secpad dl.area_1 div dt.dt_type_list li::before {
  content: "・";
  color: #00a9bc;
  font-weight: bold;
  text-decoration: none;
}
.page-common.page-area > section#s1 .secpad dl.area_1 div dd {
  font-size: 16px;
  line-height: 1.375;
}

/*======================================================
固定ページ　アクセス
======================================================*/
.page-common.page-access > section#s2 .secpad .common-flex {
  justify-content: space-between;
}
.page-common.page-access > section#s2 .secpad .common-flex > div {
  width: calc((100% - 34px) / 2);
  display: flex;
  flex-direction: column;
}
.page-common.page-access > section#s2 .secpad .common-flex > div h2 {
  margin-bottom: 16px;
}
.page-common.page-access > section#s2 .secpad .common-flex > div img {
  margin-bottom: 8px;
}
.page-common.page-access > section#s2 .secpad .common-flex > div table {
  width: 100%;
}
.page-common.page-access > section#s2 .secpad .common-flex > div table + img {
  margin-top: auto;
}
.page-common.page-access > section#s2 .secpad .common-flex > div table tr td,
.page-common.page-access > section#s2 .secpad .common-flex > div table tr th {
  width: 50%;
  font-size: 21px;
  font-weight: normal;
  padding: 8px 0;
  text-align: center;
}
.page-common.page-access > section#s2 .secpad .common-flex > div table tr th {
  background: #00a9bc;
  color: #fff;
}
.page-common.page-access > section#s2 .secpad .common-flex > div table tr th:not(:last-child) {
  border-right: 1px solid #fff;
}
.page-common.page-access > section#s2 .secpad .common-flex > div table tr td {
  background: #fff;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}
.page-common.page-access > section#s2 .secpad .common-flex > div table tr td:not(:last-child) {
  border-left: 1px solid #ccc;
}
.page-common.page-access > section#s3 .secpad {
  width: 900px;
}
.page-common.page-access > section#s3 .secpad .common-flex {
  justify-content: space-between;
  margin-bottom: 20px;
}
.page-common.page-access > section#s3 .secpad .common-flex > div {
  width: calc((100% - 32px) / 2);
}
.page-common.page-access > section#s3 .secpad .common-flex > div p {
  color: #00a9bc;
  font-weight: bold;
  font-size: 18px;
  margin-bottom: 9px;
}
.page-common.page-access .gmap-wrap {
  padding-bottom: 600px;
}

/*======================================================
固定ページ　認知症疾患医療センター
======================================================*/
.page-common.page-center > section#s1 .secpad ul.news-wrap li {
  padding: 8px 0;
}
.page-common.page-center > section#s1 .secpad ul.news-wrap li a p.cat {
  padding: 1px 0;
}
.page-common.page-center > section#s1 .secpad .btn_white {
  width: 320px;
  margin: 0 auto 100px;
}
.page-common.page-center > section#s1 .secpad .notes-list li span {
  display: block;
  margin-bottom: 4px;
}
.page-common.page-center > section#s1 .secpad .notes-list li .common-flex > div:first-child {
  margin-right: 15px;
}
.page-common.page-center > section#s2 .secpad {
  width: 900px;
}
.page-common.page-center > section#s2 .secpad table {
  border: solid 1px #707070;
}
.page-common.page-center > section#s2 .secpad table tr th,
.page-common.page-center > section#s2 .secpad table tr td {
  background: #fff;
}
.page-common.page-center > section#s2 .secpad table tr th:nth-child(2),
.page-common.page-center > section#s2 .secpad table tr td:nth-child(2) {
  width: 124px;
}
.page-common.page-center > section#s2 .secpad table tr th:nth-child(3),
.page-common.page-center > section#s2 .secpad table tr td:nth-child(3) {
  width: 124px;
}
.page-common.page-center > section#s2 .secpad table tr th {
  padding: 8px 0;
  font-size: 18px;
  line-height: 1.3333333333;
  border-bottom: solid 1px #707070;
  font-weight: normal;
}
.page-common.page-center > section#s2 .secpad table tr th:not(:last-child) {
  border-right: solid 1px #707070;
}
.page-common.page-center > section#s2 .secpad table tr th:nth-child(2) {
  color: #00a9bc;
}
.page-common.page-center > section#s2 .secpad table tr td {
  padding: 11px 18px;
}
.page-common.page-center > section#s2 .secpad table tr td:not(:last-child) {
  border-right: solid 1px #707070;
}
.page-common.page-center > section#s2 .secpad table tr td h3 {
  font-size: 20px;
  line-height: 1.2;
}
.page-common.page-center > section#s2 .secpad table tr td:nth-child(2) {
  text-align: center;
  padding: 0 10px;
  color: #00a9bc;
}
.page-common.page-center > section#s2 .secpad table tr td:nth-child(3) {
  text-align: center;
  padding: 0 10px;
}
.page-common.page-center > section#s2 .secpad table tr:not(:last-child) td {
  border-bottom: solid 1px #707070;
}
.page-common.page-center > section#s4 .secpad .common-flex {
  width: 700px;
  margin: 0 auto;
}
.page-common.page-center > section#s4 .secpad .common-flex > div.common-flex-inner {
  width: 50%;
}
.page-common.page-center > section#s4 .secpad .common-flex > div.common-flex-inner > div {
  margin-bottom: 20px;
}
.page-common.page-center > section#s4 .secpad .common-flex a {
  color: #0082d5;
  text-decoration: underline;
}
.page-common.page-center > section#s5 .secpad .left-green {
  position: relative;
  font-size: 20px;
  text-align: left;
  padding-left: 9px;
  margin-bottom: 4px;
  line-height: 1.35;
  letter-spacing: 0.4px;
  font-weight: bold;
}
.page-common.page-center > section#s5 .secpad .left-green::before {
  content: "";
  background: #00a9bc;
  height: 25px;
  width: 3px;
  position: absolute;
  left: -2px;
  top: 2px;
}
.page-common.page-center > section#s5 .secpad iframe {
  margin-bottom: 0px;
}
.page-common.page-center > section#s5 .secpad .text {
  border: 7px solid #707070;
  padding: 15px;
}

/*======================================================
固定ページ　歯科
======================================================*/
.page-common.page-tooth > section#s3 .secpad h2 {
  margin-bottom: 10px;
}
.page-common.page-tooth > section#s3 .secpad iframe {
  margin: 0 auto;
  width: 100%;
  height: 400px;
}
.page-common.page-tooth > section#s3 .secpad ol.notes-list-order:not(:last-child) {
  padding-right: 80px;
}
.page-common.page-tooth > section#s3 .secpad ol.notes-list-order > li a {
  text-decoration: underline;
}
.page-common.page-tooth > section#s3 .secpad ol.notes-list-order > li > a {
  font-weight: bold;
}
.page-common.page-tooth > section#s3 .secpad ol.notes-list-order > li ul li {
  margin-bottom: 4px;
  font-size: 16px;
  line-height: 1.375;
}

/*======================================================
固定ページ　造形教室
======================================================*/
.page-common.page-zoukei section#s1 .common-flex > div:nth-child(1) {
  width: 550px;
  padding-right: 30px;
}
.page-common.page-zoukei section#s1 .common-flex > div:nth-child(2) {
  width: calc(100% - 550px);
}
.page-common.page-zoukei section#s1 .zoukei-dl div {
  margin-bottom: 10px;
}
.page-common.page-zoukei section#s1 .zoukei-dl div dt {
  margin-bottom: 4px;
  line-height: 1.375;
  font-weight: bold;
}
.page-common.page-zoukei section#s1 .zoukei-dl div dd {
  line-height: 1.375;
}
.page-common.page-zoukei section#s2 .secpad {
  width: 900px;
  padding: 60px 0 100px;
  margin: 0 auto;
}
.page-common.page-zoukei section#s2 .secpad .common-gallery-wrap {
  margin-bottom: 40px;
}
.page-common.page-zoukei section#s2 .secpad .btn_white {
  width: 300px;
  margin: 0 auto;
}

@media (max-width: 560px) {
  .page-common.page-zoukei section#s1 .common-flex > div:nth-child(1) {
    width: 100%;
    padding-right: 0;
    margin-bottom: 14px;
  }
  .page-common.page-zoukei section#s1 .common-flex > div:nth-child(2) {
    width: 100%;
  }
}
/*======================================================
固定ページ　病院紹介
======================================================*/
.page-common.page-intro .member_list {
  margin-bottom: 45px;
}
.page-common.page-intro .member_list li {
  width: 33.3333333333%;
}
.page-common.page-intro section#s1 .common-flex > div:nth-child(1),
.page-common.page-intro section#s2 .common-flex > div:nth-child(1) {
  width: calc(100% - 370px);
  padding-right: 25px;
}
.page-common.page-intro section#s1 .common-flex > div:nth-child(1) .name,
.page-common.page-intro section#s2 .common-flex > div:nth-child(1) .name {
  text-align: right;
  margin-top: 10px;
  font-weight: bold;
}
.page-common.page-intro section#s1 .common-flex > div:nth-child(2),
.page-common.page-intro section#s2 .common-flex > div:nth-child(2) {
  width: 370px;
}
.page-common.page-intro section#s2 .secpad {
  padding: 60px 0;
}
.page-common.page-intro section#s2 .secpad dl div {
  display: flex;
}
.page-common.page-intro section#s2 .secpad dl div dt,
.page-common.page-intro section#s2 .secpad dl div dd {
  line-height: 1.375;
}
.page-common.page-intro section#s2 .secpad dl div dt {
  width: 97px;
}
.page-common.page-intro section#s2 .secpad dl div dd {
  width: calc(100% - 97px);
}
.page-common.page-intro section#s2 .secpad nav ul {
  display: flex;
  justify-content: space-between;
}
.page-common.page-intro section#s3 .secpad p {
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}
.page-common.page-intro section#s4 .secpad .common-flex-dl {
  width: 500px;
  margin: 0 auto;
}
.page-common.page-intro section#s4 .secpad .common-flex-dl div {
  margin-bottom: 4px;
}
.page-common.page-intro section#s4 .secpad .common-flex-dl div dt {
  width: 170px;
  padding-right: 21px;
  position: relative;
}
.page-common.page-intro section#s4 .secpad .common-flex-dl div dt::after {
  content: "|";
  position: absolute;
  right: 8px;
}
.page-common.page-intro section#s4 .secpad .common-flex-dl div dd {
  width: calc(100% - 170px);
}
.page-common.page-intro section#s4 .secpad .notes-list > li:nth-child(1) li {
  margin-right: 9px;
}
.page-common.page-intro section#s4 .secpad .notes-list > li:nth-child(2) li {
  width: 50%;
}
.page-common.page-intro section#s4 .secpad .notes-list > li:nth-child(2) li:nth-child(2n+1) {
  padding-right: 5px;
}
.page-common.page-intro section#s4 .secpad .notes-list > li ul {
  display: flex;
  flex-wrap: wrap;
}
.page-common.page-intro section#s4 .secpad .notes-list > li a {
  color: #0082d5;
  text-decoration: underline;
}
.page-common.page-intro section#s5 .secpad .common-flex-dl {
  width: 100%;
  margin: 0 auto;
}
.page-common.page-intro section#s5 .secpad .common-flex-dl div dt {
  width: 162px;
  padding-right: 21px;
  position: relative;
}
.page-common.page-intro section#s5 .secpad .common-flex-dl div dt::after {
  content: "|";
  position: absolute;
  right: 8px;
}
.page-common.page-intro section#s5 .secpad .common-flex-dl div dt span.year {
  display: inline-block;
  width: 1.5em;
}
.page-common.page-intro section#s5 .secpad .common-flex-dl div dt span.month {
  display: inline-block;
  width: 1.5em;
}
.page-common.page-intro section#s5 .secpad .common-flex-dl div dd {
  width: calc(100% - 160px);
}
.page-common.page-intro section#s6 .secpad h2 {
  margin-bottom: 10px;
}
@media (max-width: 560px) {
  .page-common.page-intro section#s6 .secpad .sp-only__mb32 {
    margin-top: 32px;
  }
}
.page-common.page-intro section#s6 .secpad .s6-wrap {
  display: flex;
  flex-wrap: wrap;
}
@media (max-width: 560px) {
  .page-common.page-intro section#s6 .secpad .s6-wrap {
    flex-direction: column;
  }
}
@media (min-width: 561px) {
  .page-common.page-intro section#s6 .secpad .s6-wrap div:nth-child(1) {
    width: 50%;
  }
  .page-common.page-intro section#s6 .secpad .s6-wrap div:nth-child(2) {
    width: 50%;
  }
}
.page-common.page-intro section#s6 .secpad .s6-wrap div h3 {
  position: relative;
  border-left: 0;
  font-size: 16px;
  padding-left: 0;
  color: black;
}
.page-common.page-intro section#s6 .secpad .s6-wrap div h3::before {
  content: "・";
  color: #00a9bc;
  font-weight: bold;
  position: absolute;
  left: -18px;
  text-decoration: none;
  background: none;
}
@media (max-width: 560px) {
  .page-common.page-intro section#s6 .secpad .s6-wrap div .sp-only__mb12 {
    margin-top: 12px;
  }
}
.page-common.page-intro section#s6 .secpad .s6-wrap div ul li {
  line-height: 1.375;
}
@media (max-width: 561px) {
  .page-common.page-intro section#s6 .secpad .s6-wrap div .pc_only__mb37 {
    margin-top: 37px;
  }
}
@media (max-width: 560px) {
  .page-common.page-intro section#s6 .secpad .s6-wrap div .pc_only__mb37 {
    margin-top: 0;
  }
}
.page-common.page-intro section#s6 .secpad .s6-wrap-2 {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.page-common.page-intro section#s6 .secpad .s6-wrap-2 > div:nth-child(2) {
  max-width: 650px;
  align-self: center;
}

main.page-professor-sub.page-owner .professor_history dl dt {
  width: 100px;
}

/*======================================================
固定ページ　施設案内
======================================================*/
.page-common.page-guide section#s1 .secpad {
  width: 820px;
  padding: 60px 0 30px;
}
.page-common.page-guide section#s1 .secpad h2 {
  font-size: 20px;
  line-height: 1.35;
  color: #00a9bc;
  padding-left: 0;
}
.page-common.page-guide section#s1 .secpad h2::before {
  display: none;
}
.page-common.page-guide section#s1 .secpad .common-flex > div:nth-child(1) {
  width: calc(100% - 465px);
}
.page-common.page-guide section#s1 .secpad .common-flex > div:nth-child(2) {
  width: 465px;
}
.page-common.page-guide section#s1 .secpad .common-flex-dl {
  margin-bottom: 10px;
}
.page-common.page-guide section#s1 .secpad .common-flex-dl div dt {
  width: 25px;
  text-align: left;
}
.page-common.page-guide section#s1 .secpad .common-flex-dl div dd {
  width: calc(100% - 25px);
}
.page-common.page-guide section#s1 .secpad .common-flex-dl div dd a {
  color: #0082d5;
  text-decoration: underline;
}
.page-common.page-guide section#s1 nav {
  width: 900px;
  margin: 0 auto;
}
.page-common.page-guide section#s1 nav ul {
  display: flex;
  flex-wrap: wrap;
}
.page-common.page-guide section#s1 nav ul li {
  width: 33.3333333333%;
}

/*======================================================
お知らせ
======================================================*/
main.archive {
  padding: 0px 0 200px;
}
main.archive h1 {
  font-size: 34px;
  text-align: center;
  position: relative;
  margin-bottom: 42px;
}
main.archive h1::after {
  content: "";
  position: absolute;
  width: 90px;
  height: 1px;
  background: #00a9bc;
  bottom: -12px;
  left: 50%;
  transform: translateX(-50%);
}
@media (min-width: 561px) {
  main.archive .cat-list {
    width: 100%;
    border-bottom: solid 1px #00a9bc;
    margin-bottom: 50px;
  }
  main.archive .cat-list ul {
    width: 740px;
    margin: 0 auto;
    display: flex;
  }
  main.archive .cat-list ul li {
    border-left: solid 1px #00a9bc;
    border-top: solid 1px #00a9bc;
    border-right: solid 1px #00a9bc;
    margin-right: 4px;
    width: 80px;
    color: #00a9bc;
    border-radius: 6px 6px 0 0;
  }
  main.archive .cat-list ul li span,
  main.archive .cat-list ul li a {
    display: block;
    text-align: center;
    padding: 18px 0;
    font-weight: bold;
    color: #00a9bc;
  }
  main.archive .cat-list ul li.current {
    background: #00a9bc;
  }
  main.archive .cat-list ul li.current a {
    color: #fff;
  }
  main.archive .cat-list ul li:nth-child(1) {
    width: 146px;
  }
  main.archive .cat-list ul li:nth-child(2).current {
    background: #e1474d;
  }
  main.archive .cat-list ul li:nth-child(2).current a {
    color: #fff;
  }
  main.archive .cat-list ul li:nth-child(6) {
    width: 146px;
  }
  main.archive .cat-list ul li:nth-child(2) {
    border-left: solid 1px #e1474d;
    border-top: solid 1px #e1474d;
    border-right: solid 1px #e1474d;
    color: #e1474d;
  }
  main.archive .cat-list ul li:nth-child(2) a {
    color: #e1474d;
  }
  main.archive .cat-list ul li:nth-child(8) {
    display: none;
  }
}
main.archive article {
  width: 740px;
  margin: 0 auto 50px;
  border-bottom: solid 1px #333;
  padding-bottom: 50px;
}
main.archive article .meta {
  display: flex;
  align-items: center;
  margin-bottom: 16px;
}
main.archive article .meta .cat {
  width: 110px;
  padding: 3px 0;
  color: #fff;
  background: #00a9bc;
  text-align: center;
  border-radius: 6px;
  line-height: 1.375;
  margin-right: 10px;
}
main.archive article .meta .date {
  color: #999;
  font-size: 16px;
}
main.archive article h2 {
  color: #00a9bc;
  font-size: 26px;
  line-height: 1.3461538462;
  font-weight: bold;
  letter-spacing: 0.31px;
  border-bottom: 1px solid #00a9bc;
  margin-bottom: 22px;
  padding-bottom: 2px;
}
main.archive article h3 {
  font-size: 20px;
  line-height: 1.35;
  margin-bottom: 20px;
}
main.archive article p {
  font-size: 16px;
  line-height: 1.375;
}
main.archive article p:not(:last-child) {
  margin-bottom: 20px;
}
main.archive article a {
  display: inline-block;
  color: #0082d5;
  text-decoration: underline;
}
main.archive article a:not(:last-child) {
  margin-bottom: 20px;
}

/*======================================================
固定ページ　採用
======================================================*/
.page-common.page-recruit > section#s1 .secpad {
  padding: 60px 0 190px;
}
.page-common.page-recruit > section#s1 .common-link-text {
  position: relative;
  display: block;
  margin-bottom: 10px;
}
.page-common.page-recruit > section#s1 .common-link-text:before {
  content: "";
  background: #00a9bc;
  width: 4px;
  height: 4px;
  font-weight: bold;
  position: absolute;
  top: 0.5em;
  left: -0.58em;
  text-decoration: none;
}
.page-common.page-recruit > section#s1 .rec_occupation_wrap {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
}
@media (max-width: 560px) {
  .page-common.page-recruit > section#s1 .rec_occupation_wrap {
    gap: 8px;
  }
}
.page-common.page-recruit > section#s1 .rec_occupation_wrap .btn_futo {
  width: 200px;
}
.page-common.page-recruit > section#s1 .rec_occupation_wrap ul {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/*======================================================
固定ページ　認知症
======================================================*/
.link-tel {
  display: inline;
  font-size: 28px;
}

/*======================================================
固定ページ　発達障害
======================================================*/
.page-developmental-disability .sp_only {
  display: none;
}
@media (max-width: 560px) {
  .page-developmental-disability .sp_only {
    display: block;
  }
}
.page-developmental-disability .program__wrap {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
@media (max-width: 560px) {
  .page-developmental-disability .program__wrap {
    gap: 8px;
  }
}
.page-developmental-disability .program__wrap .btn_futo {
  width: 320px;
  padding: 28px 18px;
  font-size: 18px;
}
@media (max-width: 560px) {
  .page-developmental-disability .calender-wrap {
    table-layout: fixed;
  }
}
.page-developmental-disability .calender-wrap span {
  color: #00a9bc;
  font-weight: bold;
}
.page-developmental-disability .calender-wrap thead tr th:not(:first-of-type) {
  width: 98px !important;
}
@media (max-width: 560px) {
  .page-developmental-disability .calender-wrap thead tr th:not(:first-of-type) {
    width: auto !important;
  }
}
@media (max-width: 560px) {
  .page-developmental-disability .calender-wrap thead tr th:first-child {
    width: 130px !important;
  }
}
.page-developmental-disability .calender-wrap tbody td {
  font-size: 20px !important;
}
@media (max-width: 560px) {
  .page-developmental-disability .calender-wrap tbody td span {
    font-size: 15px;
  }
}
.page-developmental-disability .btn_blue {
  text-align: left;
  padding: 24px 26px !important;
  font-size: 25px;
  width: 100% !important;
  font-weight: 600;
}
@media (max-width: 560px) {
  .page-developmental-disability .btn_blue {
    font-size: 15px;
    padding: 24px 14px !important;
  }
}
.page-developmental-disability .btn_blue:after {
  content: url(../images/download__btn.svg);
}
.page-developmental-disability .fw__bold {
  font-weight: 600;
}

/*======================================================
固定ページ　うつ病の新しい治療法 rTMS

======================================================*/
.secpad2.rtms_contact {
  border: 1px solid #333;
  border-radius: 10px;
  padding: 20px !important;
  display: flex;
  line-height: 1.5;
}
@media (max-width: 560px) {
  .secpad2.rtms_contact {
    flex-direction: column;
  }
}
.secpad2.rtms_contact .rtms_tel {
  margin-top: 15px;
}
.secpad2.rtms_contact .rtms_guide {
  font-weight: normal !important;
}

/*======================================================
固定ページ　個人情報保護方針
======================================================*/
.page-privacy > section .secpad h2,
.page-privacy > section .secpad16 h2 {
  margin-bottom: 10px;
  margin-left: -9px;
}
.page-privacy > section .secpad h3,
.page-privacy > section .secpad16 h3 {
  font-size: 18px;
  line-height: 1.3333333333;
  margin-bottom: 4px;
  color: #333333;
}
.page-privacy > section .secpad dl div,
.page-privacy > section .secpad16 dl div {
  display: flex;
  gap: 10px;
}
.page-privacy > section .secpad .box,
.page-privacy > section .secpad16 .box {
  border: solid 2px #00a9bc;
  padding: 10px 16px;
}
.page-privacy > section .secpad .box + .box,
.page-privacy > section .secpad16 .box + .box {
  margin-top: 10px;
}
.page-privacy > section .secpad .box h5 + dl,
.page-privacy > section .secpad16 .box h5 + dl {
  margin-top: 8px;
}
.page-privacy > section .secpad .box dl dt,
.page-privacy > section .secpad .box dl dd,
.page-privacy > section .secpad16 .box dl dt,
.page-privacy > section .secpad16 .box dl dd {
  font-size: 13px;
}
.page-privacy > section .secpad .box p,
.page-privacy > section .secpad16 .box p {
  font-size: 14px;
}
.page-privacy > section .secpad p,
.page-privacy > section .secpad16 p {
  margin-bottom: 4px;
}
.page-privacy > section .secpad p + .box,
.page-privacy > section .secpad16 p + .box {
  margin-top: 15px;
}
.page-privacy > section .secpad ul:not([class]),
.page-privacy > section .secpad16 ul:not([class]) {
  margin-bottom: 10px;
}
.page-privacy > section .secpad ul:not([class]) > li,
.page-privacy > section .secpad16 ul:not([class]) > li {
  list-style: none;
}
.page-privacy > section .secpad ul:not([class]) > li::before,
.page-privacy > section .secpad16 ul:not([class]) > li::before {
  content: "・";
}
.page-privacy > section .secpad ol:not([class]),
.page-privacy > section .secpad16 ol:not([class]) {
  padding-left: 16px;
}
.page-privacy > section .secpad ol:not([class]) > li,
.page-privacy > section .secpad16 ol:not([class]) > li {
  list-style: decimal;
  line-height: 1.375;
  margin-bottom: 4px;
}
.page-privacy > section .secpad ol:not([class]) ul,
.page-privacy > section .secpad16 ol:not([class]) ul {
  margin-bottom: 0;
}
.page-privacy > section .secpad table,
.page-privacy > section .secpad16 table {
  border: solid 1px #333;
}
.page-privacy > section .secpad table tr:not(:last-child) td,
.page-privacy > section .secpad16 table tr:not(:last-child) td {
  border-bottom: solid 1px #333;
}
.page-privacy > section .secpad table tr th,
.page-privacy > section .secpad16 table tr th {
  width: 25%;
  background: #f0f0f0;
  padding: 4px 0;
  text-align: center;
  border-bottom: solid 1px #333;
}
.page-privacy > section .secpad table tr th:not(:last-child),
.page-privacy > section .secpad16 table tr th:not(:last-child) {
  border-right: solid 1px #333;
}
.page-privacy > section .secpad table tr td,
.page-privacy > section .secpad16 table tr td {
  padding: 8px 10px;
  line-height: 1.375;
  vertical-align: baseline;
}
.page-privacy > section .secpad table tr td:not(:last-child),
.page-privacy > section .secpad16 table tr td:not(:last-child) {
  border-right: solid 1px #333;
}
.page-privacy > section .secpad ul.notes-list + h3,
.page-privacy > section .secpad16 ul.notes-list + h3 {
  margin-top: 10px;
}
.page-privacy > section .secpad > ul.notes-list,
.page-privacy > section .secpad16 > ul.notes-list {
  margin-bottom: 10px;
  padding-left: 0;
}
.page-privacy > section .secpad > ul.notes-list h4,
.page-privacy > section .secpad16 > ul.notes-list h4 {
  margin-bottom: 4px;
}
.page-privacy > section .secpad > ul.notes-list > li,
.page-privacy > section .secpad16 > ul.notes-list > li {
  margin-bottom: 10px;
}
.page-privacy > section .secpad > ul.notes-list > li > ul.notes-list,
.page-privacy > section .secpad16 > ul.notes-list > li > ul.notes-list {
  padding-left: 9px;
}
.page-privacy > section .secpad .secpad16,
.page-privacy > section .secpad16 .secpad16 {
  padding-left: 16px;
}
.page-privacy > section .secpad .secpad45,
.page-privacy > section .secpad16 .secpad45 {
  padding-left: 45px;
}
.page-privacy > section#s3 .secpad .notes-list h3 {
  font-size: 16px;
}

/*======================================================
固定ページ　アルコール依存症
======================================================*/
.page-alcoholic #s3 .secpad .secpad2 {
  margin-bottom: 20px;
}

/*======================================================
固定ページ　教授紹介
======================================================*/
main.page-professor section .secpad > p {
  text-align: center;
}

main.page-professor-sub section .secpad h2 {
  font-size: 18px;
  margin-bottom: 6px;
  padding-left: 0;
}
main.page-professor-sub section .secpad h2::before {
  display: none;
}
main.page-professor-sub .professor_profile {
  display: flex;
  gap: 32px;
  margin-bottom: 16px;
}
main.page-professor-sub .professor_profile img {
  width: 200px;
}
main.page-professor-sub .professor_profile .text h1 {
  margin-bottom: 16px;
  font-size: 18px;
  font-weight: bold;
  text-align: left;
}
main.page-professor-sub .professor_profile .text h1::after {
  display: none;
}
main.page-professor-sub .professor_profile .text h2 {
  font-size: 16px;
  font-weight: normal;
  margin-bottom: 6px;
}
main.page-professor-sub .professor_profile .text p {
  font-size: 16px;
  line-height: 1.5;
}
main.page-professor-sub .professor_profile .text p.catch {
  margin-bottom: 10px;
}
main.page-professor-sub .professor_content {
  margin-bottom: 30px;
}
main.page-professor-sub .professor_content p {
  font-size: 16px;
  line-height: 1.5;
}
main.page-professor-sub .professor_content p:not(:last-child) {
  margin-bottom: 12px;
}
main.page-professor-sub .professor_history {
  margin-bottom: 12px;
}
main.page-professor-sub .professor_history dl div {
  display: flex;
}
main.page-professor-sub .professor_history dl div:not(:last-child) {
  margin-bottom: 4px;
}
main.page-professor-sub .professor_history dl dt,
main.page-professor-sub .professor_history dl dd {
  line-height: 1.5;
}
main.page-professor-sub .professor_history dl dt {
  width: 70px;
  margin-right: 10px;
}
main.page-professor-sub .professor_history dl dd {
  width: calc(100% - 80px);
}
main.page-professor-sub .professor_officer li {
  margin-bottom: 4px;
  line-height: 1.5;
}

/*======================================================
固定ページ　サイトポリシー
======================================================*/
.page-privacy.sitepolicy > section .secpad ol {
  list-style-type: none;
}
.page-privacy.sitepolicy > section .secpad ol li {
  list-style: none;
  counter-increment: cnt;
}
.page-privacy.sitepolicy > section .secpad ol li::before {
  content: "(" counter(cnt) ") ";
}/*# sourceMappingURL=style.css.map */