@charset "UTF-8";
/* Scss Document */
/* CSS Document */
* {
  box-sizing: border-box;
  text-decoration: none !important;
  font-family: tbchibirgothicplusk-pro, sans-serif;
  font-weight: 400;
  font-style: normal;
  color: #5f5f5f;
}

main, header {
  overflow: hidden;
}

html {
  font-size: 17px;
}

html i {
  font-style: normal !important;
}

@font-face {
  font-family: "NotoSansCJKjp-Regular";
  src: url(../webfont/NotoSansCJKjp-Regular.woff);
}

@font-face {
  font-family: "NotoSerifJP-Regular";
  src: url(../webfont/NotoSerifJP-Regular.woff);
}

@font-face {
  font-family: "NotoSansCJKjp-Regular_ver.woff";
  src: url(../webfont/NotoSansCJKjp-Regular_ver.woff);
}

@font-face {
  font-family: "NotoSerifJP-t.woff";
  src: url(../webfont/NotoSerifCJKjp-Regular.woff);
}

@font-face {
  font-family: "NotoSansCJKjp-Light";
  src: url(../webfont/NotoSansCJKjp-Light.woff);
}

.selifFont {
  font-family: "游明朝体", "Yu Mincho", "YuMincho", "NotoSerifCJKjp-Regular", serif;
}

.tbchibirgothicplusk {
  font-family: tbchibirgothicplusk-pro, sans-serif;
  font-weight: 400;
  font-style: normal;
}

button:focus,
a:focus {
  outline: none;
}

.textIndent {
  text-indent: 1rem;
}

_::-webkit-full-page-media,
_:future,
:root .textIndent {
  text-indent: 1rem;
}

.textIndent02 {
  text-indent: -1.2rem;
  padding-left: 1rem;
}

_::-webkit-full-page-media,
_:future,
:root .textIndent02 {
  text-indent: -1.2rem;
  padding-left: 1rem;
}

.c-blue {
  color: #005FFF;
}
.font15 {
  font-size: 15px;
}

/* Safari用のハックは、Chromeに適用されないようにする */
@supports (-webkit-touch-callout: none) {
  body {
    /* Safari用のハック */
    height: -webkit-fill-available;
  }
}

/* Safari用のハックは、Chromeに適用されないようにする */
@supports (-webkit-touch-callout: none) {
  body {
    /* Safari用のハック */
    height: -webkit-fill-available;
  }
}

article {
  overflow: hidden;
}

.oh {
  overflow: hidden;
}

.w_1800 {
  width: 95%;
  max-width: 1800px;
  margin: 0 auto;
  display: block;
}

.w_1790 {
  width: 95%;
  margin: 0 auto;
  display: block;
  max-width: 1790px;
}

.w_1680 {
  width: 95%;
  margin: 0 auto;
  display: block;
  max-width: 1680px;
}

.w_1600 {
  width: 95%;
  margin: 0 auto;
  display: block;
  max-width: 1600px;
}

.w_1440 {
  width: 95%;
  margin: 0 auto;
  max-width: 1440px;
}

.w_1340 {
  width: 95%;
  margin: 0 auto;
  max-width: 1340px;
}

.w_1280 {
  width: 95%;
  display: block;
  margin: 0 auto;
  max-width: 1280px;
}

.w_1200 {
  width: 95%;
  display: block;
  margin: 0 auto;
  max-width: 1200px;
}
.w_1200_2 {
  width: 85%;
  display: block;
  margin: 0 auto;
  max-width: 1200px;
}

.w_1100 {
  width: 95%;
  display: block;
  margin: 0 auto;
  max-width: 1100px;
}

.w_1024 {
  width: 95%;
  display: block;
  margin: 0 auto;
  max-width: 1024px;
}

.w_1000 {
  width: 95%;
  display: block;
  margin: 0 auto;
  max-width: 1000px;
}

.w_960 {
  width: 95%;
  max-width: 960px;
  margin: 0 auto;
}

.w_940 {
  width: 95%;
  max-width: 940px;
  margin: 0 auto;
}

.w_840 {
  width: 95%;
  max-width: 840px;
  margin: 0 auto;
}

.w_780 {
  width: 95%;
  max-width: 780px;
  margin: 0 auto;
}

.w_640 {
  width: 95%;
  max-width: 640px;
  margin: 0 auto;
}

.spBr {
  display: none;
}

.fnormal p {
  font-weight: normal !important;
}

@media only screen and (max-width: 1280px) {
  html {
    font-size: 16px;
  }
}

@media only screen and (max-width: 1024px) {
  html {
    font-size: 15px;
  }
}

@media only screen and (max-width: 768px) {
  html {
    font-size: 14.5px;
  }
}

@media only screen and (max-width: 640px) {
  html {
    font-size: 14px;
  }
  .spBr {
    display: block;
  }
  .pcBr {
    display: none;
  }
}

.bgImg {
  background-image: url(../images/bg.jpg);
}

.head01 {
  display: block;
  text-align: center;
  position: relative;
  top: 32px;
}

.head01 img {
  max-width: 95%;
}

.head01 a {
  display: inline-block;
}

.font24 {
  font-size: 24px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.41176rem;
}

@media only screen and (max-width: 1280px) {
  .font24 {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

@media only screen and (max-width: 1024px) {
  .font24 {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

@media only screen and (max-width: 768px) {
  .font24 {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

@media only screen and (max-width: 640px) {
  .font24 {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

.sec100 {
  padding-top: 100px;
  padding-left: 0px;
  padding-bottom: 100px;
  padding-right: 0px;
}

@media only screen and (max-width: 1440px) {
  .sec100 {
    padding-top: 6.94444vw;
    padding-left: 0vw;
    padding-bottom: 6.94444vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  .sec100 {
    padding-top: 13.88889vw;
    padding-left: 0vw;
    padding-bottom: 13.88889vw;
    padding-right: 0vw;
  }
}

.menf:nth-child(1) {
  width: 52%;
  display: flex;
  align-items: center;
}

.menf:nth-child(1) .textBox .tbchibirgothicplusk {
  line-height: 2.4;
}

.menf:nth-child(1) .circleGiant {
  position: absolute;
  top: 14%;
  left: -51%;
}

.menf:nth-child(2) {
  width: 48%;
}

.menf:nth-child(2) span {
  display: block;
}

.clinicLink a {
  display: block;
  width: calc(33.333% - 15px);
  margin-right: 22px;
  margin-top: 35px;
}

.clinicLink a:nth-child(3n + 3) {
  margin-right: 0;
}

.clinicLink a > span {
  display: block;
  width: 100%;
}

.clinicLink a > span img {
  width: 100%;
  height: auto;
}

.clinicLink a .femk {
  padding: 10px 0;
}

.clinicLink a .femk img {
  width: 95%;
  margin: 0 auto;
  height: auto;
}

.clinicLink a .omelink {
  background-color: #fff;
  text-align: center;
  padding: 10px 0;
  overflow: hidden;
  position: relative;
}

.clinicLink a .omelink p {
  width: 100%;
  text-align: center;
  position: relative;
  z-index: 5;
}

.clinicLink a .omelink:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform: translateX(-100%);
  z-index: 1;
  transition: 0.3s;
}

.clinicLink a.kumagai .femk {
  background-color: #5accc4;
}

.clinicLink a.kumagai .omelink p {
  color: #00a99d;
}

.clinicLink a.kumagai:hover .omelink p {
  color: #fff;
}

.clinicLink a.kumagai:hover .omelink:after {
  background-color: #00a99d;
  transform: translateX(0);
}

.clinicLink a.hiraoka .femk {
  background-color: #5bbfe9;
}

.clinicLink a.hiraoka .omelink p {
  color: #0099d9;
}

.clinicLink a.hiraoka:hover .omelink p {
  color: #fff;
}

.clinicLink a.hiraoka:hover .omelink:after {
  background-color: #0099d9;
  transform: translateX(0);
}

.clinicLink a.sinsapporo .femk {
  background-color: #bddf88;
}

.clinicLink a.sinsapporo .omelink p {
  color: #89d90c;
}

.clinicLink a.sinsapporo:hover .omelink p {
  color: #fff;
}

.clinicLink a.sinsapporo:hover .omelink:after {
  background-color: #89d90c;
  transform: translateX(0);
}

.clinicLink a.minamisapporo .femk {
  background-color: #6ad59f;
}

.clinicLink a.minamisapporo .omelink p {
  color: #07ac58;
}

.clinicLink a.minamisapporo:hover p {
  color: #fff;
}

.clinicLink a.minamisapporo:hover .omelink:after {
  background-color: #07ac58;
  transform: translateX(0);
}

.clinicLink a.asabu .femk {
  background-color: #eab974;
}

.clinicLink a.asabu .omelink p {
  color: #ec8c06;
}

.clinicLink a.asabu:hover p {
  color: #fff;
}

.clinicLink a.asabu:hover .omelink:after {
  background-color: #ec8c06;
  transform: translateX(0);
}

.clinicLink a.kitahiro .femk {
  background-color: #f8aad1;
}

.clinicLink a.kitahiro .omelink p {
  color: #f8aad1;
}

.clinicLink a.kitahiro:hover p {
  color: #fff;
}

.clinicLink a.kitahiro:hover .omelink:after {
  background-color: #ff7bbc;
  transform: translateX(0);
}

.head02 {
  position: relative;
  padding: 15px 0 15px 20px;
}

.head02:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 5px;
  background-color: #000;
}

.head02 span {
  font-size: 30px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.76471rem;
  letter-spacing: 0.1rem;
  position: relative;
  z-index: 3;
}

.re1 div:nth-child(1) p {
  font-weight: bold;
}

.re1 div:nth-child(4) p a {
  color: #0099d9 !important;
}

@media only screen and (max-width: 1280px) {
  .head02 span {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 1024px) {
  .head02 span {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 768px) {
  .head02 span {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 640px) {
  .head02 span {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

.head02 p {
  position: absolute;
  top: 50%;
  left: 4%;
  opacity: 0.5;
  font-size: 220px;
  font-family: "ADAM.CG PRO";
  /*IE9以下で反映されるよう記述*/
  font-size: 12.94118rem;
  color: #fff;
  transform: translate(0, -55%);
  z-index: 1;
}

@media only screen and (max-width: 1280px) {
  .head02 p {
    font-size: 220px;
    /*IE9以下で反映されるよう記述*/
    font-size: 12.94118rem;
  }
}

@media only screen and (max-width: 1024px) {
  .head02 p {
    font-size: 220px;
    /*IE9以下で反映されるよう記述*/
    font-size: 12.94118rem;
  }
}

@media only screen and (max-width: 768px) {
  .head02 p {
    font-size: 220px;
    /*IE9以下で反映されるよう記述*/
    font-size: 12.94118rem;
  }
}

@media only screen and (max-width: 640px) {
  .head02 p {
    font-size: 220px;
    /*IE9以下で反映されるよう記述*/
    font-size: 12.94118rem;
  }
}

.head02.head02_kumagai:before {
  background-color: #00a99d;
}

.head02.head02_kumagai span {
  color: #00a99d;
}

.head02.head02_blue:before {
  background-color: #0099d9;
}

.head02.head02_blue span {
  color: #0099d9;
}

.kep {
  overflow: hidden;
  display: block;
  width: 48%;
  padding: 35px;
}

.kep:nth-child(1) {
  background-color: #e6f8f7;
}

.kep:nth-child(2) {
  background-color: #e1f6fb;
}

.kep .textBox {
  position: relative;
  z-index: 10;
  margin-left: 20px;
}

.hackKep {
  background-color: #f6f6f6 !important;
}

.hackKep01 {
  background-color: #e6f8f7 !important;
}

.kennk {
  width: calc(100% - 100px);
}

.kennk:nth-child(1) .ff {
  font-size: 26px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.52941rem;
  color: #00a99d;
}

@media only screen and (max-width: 1280px) {
  .kennk:nth-child(1) .ff {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

@media only screen and (max-width: 1024px) {
  .kennk:nth-child(1) .ff {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

@media only screen and (max-width: 768px) {
  .kennk:nth-child(1) .ff {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

@media only screen and (max-width: 640px) {
  .kennk:nth-child(1) .ff {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

.kennk:nth-child(1) .ff2 {
  font-size: 32px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.88235rem;
}

.kennk:nth-child(1) .ff2 span {
  font-size: 20px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.17647rem;
  display: block;
}

@media only screen and (max-width: 1280px) {
  .kennk:nth-child(1) .ff2 span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1024px) {
  .kennk:nth-child(1) .ff2 span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 768px) {
  .kennk:nth-child(1) .ff2 span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 640px) {
  .kennk:nth-child(1) .ff2 span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1280px) {
  .kennk:nth-child(1) .ff2 {
    font-size: 32px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.88235rem;
  }
}

@media only screen and (max-width: 1024px) {
  .kennk:nth-child(1) .ff2 {
    font-size: 32px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.88235rem;
  }
}

@media only screen and (max-width: 768px) {
  .kennk:nth-child(1) .ff2 {
    font-size: 32px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.88235rem;
  }
}

@media only screen and (max-width: 640px) {
  .kennk:nth-child(1) .ff2 {
    font-size: 32px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.88235rem;
  }
}

.kennk:nth-child(2) {
  width: 100px;
}

.font15 {
  font-size: 15px;
  /*IE9以下で反映されるよう記述*/
  font-size: 0.88235rem;
}

@media only screen and (max-width: 1280px) {
  .font15 {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 1024px) {
  .font15 {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 768px) {
  .font15 {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) {
  .font15 {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

.poas {
  position: relative;
  padding-bottom: 15px;
  z-index: 150;
}

.poas:hover:after {
  border-bottom: 1px solid #00a99d;
}

.poas:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
  transition: 0.2s;
}

.mdskf {
  font-size: 15px;
  /*IE9以下で反映されるよう記述*/
  font-size: 0.88235rem;
}

@media only screen and (max-width: 1280px) {
  .mdskf {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 1024px) {
  .mdskf {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 768px) {
  .mdskf {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) {
  .mdskf {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

.mdskf:nth-child(1) {
  width: 170px;
}

.mdskf:nth-child(2) {
  width: calc(100% - 170px);
}

.pjdp {
  width: 50%;
}

.pjdp p {
  font-size: 15px;
  /*IE9以下で反映されるよう記述*/
  font-size: 0.88235rem;
  margin-bottom: 15px;
}

@media only screen and (max-width: 1280px) {
  .pjdp p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 1024px) {
  .pjdp p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 768px) {
  .pjdp p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) {
  .pjdp p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

.pjdp p:last-child {
  margin-bottom: 0;
}

.hackPoas:hover:after {
  border-bottom: 1px solid #0099d9;
}

.newsUl li a {
  padding: 8px 0 0 0;
  display: flex;
}

.newsUl li a span:nth-child(1) {
  width: 100px;
}

.newsUl li a span:nth-child(2) {
  width: calc(100% - 100px);
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

.smallCopy {
  text-align: center;
  background-color: #00a99d;
  color: #fff;
  display: block;
  padding: 15px;
}

.smallCopy strong {
  color: #fff;
}

.floatItem {
  float: right;
  width: 100%;
  max-width: 480px;
}

.floatItem > img {
  margin: 0 auto;
}

.nne {
  padding: 12px 10px;
  background-color: #00a99d;
}

.nne p {
  color: #fff;
}

.nne .nne01 {
  display: flex;
  padding-bottom: 10px;
}

.nne .nne01 p:nth-child(1) {
  text-align: right;
  width: 60%;
  font-size: 17px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1rem;
}

@media only screen and (max-width: 1280px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 1024px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 768px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 640px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

.nne .nne01 p:nth-child(2) {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 35%;
  font-size: 24px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.41176rem;
  text-align: center;
}

@media only screen and (max-width: 1280px) {
  .nne .nne01 p:nth-child(2) {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

@media only screen and (max-width: 1024px) {
  .nne .nne01 p:nth-child(2) {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

@media only screen and (max-width: 768px) {
  .nne .nne01 p:nth-child(2) {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

@media only screen and (max-width: 640px) {
  .nne .nne01 p:nth-child(2) {
    font-size: 24px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.41176rem;
  }
}

.nne .nne02 {
  text-align: center;
  position: relative;
  padding-top: 10px;
}

.nne .nne02:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: 80%;
  left: 50%;
  transform: translateX(-50%);
  height: 1px;
  background-color: #fff;
  opacity: 0.4;
}

.nne .nne02 p {
  color: #fff;
  opacity: 0.6;
  letter-spacing: 0.1rem;
}

.head02Em {
  color: #00a99d;
  font-size: 30px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.76471rem;
}

@media only screen and (max-width: 1280px) {
  .head02Em {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 1024px) {
  .head02Em {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 768px) {
  .head02Em {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 640px) {
  .head02Em {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

.kjrk {
  background-color: #fff;
  padding-top: 70px;
  padding-left: 0px;
  padding-bottom: 70px;
  padding-right: 0px;
}

@media only screen and (max-width: 1440px) {
  .kjrk {
    padding-top: 4.86111vw;
    padding-left: 0vw;
    padding-bottom: 4.86111vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  .kjrk {
    padding-top: 9.72222vw;
    padding-left: 0vw;
    padding-bottom: 9.72222vw;
    padding-right: 0vw;
  }
}

.sec200 {
  padding-top: 200px;
  padding-left: 0px;
  padding-bottom: 200px;
  padding-right: 0px;
}

@media only screen and (max-width: 1440px) {
  .sec200 {
    padding-top: 13.88889vw;
    padding-left: 0vw;
    padding-bottom: 13.88889vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  .sec200 {
    padding-top: 27.77778vw;
    padding-left: 0vw;
    padding-bottom: 27.77778vw;
    padding-right: 0vw;
  }
}

.secTop200 {
  padding-top: 200px;
  padding-left: 0px;
  padding-bottom: 0px;
  padding-right: 0px;
}

@media only screen and (max-width: 1440px) {
  .secTop200 {
    padding-top: 13.88889vw;
    padding-left: 0vw;
    padding-bottom: 0vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  .secTop200 {
    padding-top: 27.77778vw;
    padding-left: 0vw;
    padding-bottom: 0vw;
    padding-right: 0vw;
  }
}

.secBot200 {
  padding-top: 0px;
  padding-left: 0px;
  padding-bottom: 200px;
  padding-right: 0px;
}

@media only screen and (max-width: 1440px) {
  .secBot200 {
    padding-top: 0vw;
    padding-left: 0vw;
    padding-bottom: 13.88889vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  .secBot200 {
    padding-top: 0vw;
    padding-left: 0vw;
    padding-bottom: 27.77778vw;
    padding-right: 0vw;
  }
}

.newsBox li {
  margin-bottom: 35px;
}

.newsBox li:last-child {
  margin-bottom: 0;
}

.newsBox li a {
  width: 100%;
  display: flex;
  justify-content: space-between;
}

.newsBox li a span.time {
  width: 80px;
    display: flex;
    align-items: center;
}

.newsBox li a span.area {
  padding: 2px 0 2px 0;
  width: 100px;
  font-size: 0.9rem;
  text-align: center;
  color: #fff;
}

.newsBox li a span.area.kumagai {
  background-color: #00a99d;
}

.newsBox li a span.area.hiraoka {
  background-color: #ffe402;
  color: #5f5f5f;
}

.newsBox li a span.area.sinnsapporo {
  background-color: #89d90c;
}

.newsBox li a span.area.minamisapporo {
  background-color: #07ac58;
}

.newsBox li a span.area.asabu {
  background-color: #ec8c06;
}
.newsBox li a span.area.kitahiro {
  background-color: #f18db7;
}

.newsBox li a span:last-child {
  width: calc(100% - 250px);
}

.newsBox li a > div {
  width: 100px;
}

.newsBox li a > div .area {
  display: inline-block;
  width: 100%;
  font-size: 0.8rem;
  text-align: center;
  color: #fff;
}

.newsBox li a > div .area.kumagai {
  background-color: #00a99d;
}

.newsBox li a > div .area.hiraoka {
  background-color: #ffe402;
  color: #5f5f5f;
}

.newsBox li a > div .area.sinnsapporo {
  background-color: #89d90c;
}

.newsBox li a > div .area.minamisapporo {
  background-color: #07ac58;
}

.newsBox li a > div .area.asabu {
  background-color: #ec8c06;
}
.newsBox li a > div .area.kitahiro {
  background-color: #f18db7;
}

.font22 {
  font-size: 22px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.29412rem;
}

@media only screen and (max-width: 1280px) {
  .font22 {
    font-size: 22px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.29412rem;
  }
}

@media only screen and (max-width: 1024px) {
  .font22 {
    font-size: 22px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.29412rem;
  }
}

@media only screen and (max-width: 768px) {
  .font22 {
    font-size: 22px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.29412rem;
  }
}

@media only screen and (max-width: 640px) {
  .font22 {
    font-size: 22px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.29412rem;
  }
}

.topMain {
  width: 100%;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: cover;
}

.kumagaiTopMain {
  background-image: url(../ariosapporo/images/index.jpg);
}

.ariosapporoTopMain {
  background-image: url(../ariosapporo/images/index.jpg);
}

.asabuTopMain {
  background-image: url(../asabu/images/index.jpg);
}

.shinsapporoTopMain {
  background-image: url(../shinsapporo/images/index.jpg);
}

.hiraokaTopMain {
  background-image: url(../hiraokakohen/images/index.jpg);
}

.minamisapporoTopMain {
  background-image: url(../minamisapporo/images/index.jpg);
}

.kitaTopMain {
  background-image: url(../kitahiro/images/kita_bg.jpg);
}

.elj a {
  display: block;
  width: calc(25% - 20px);
  border-radius: 10px;
  text-align: center;
  font-size: 23px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.35294rem;
  padding: 15px 0;
}

@media only screen and (max-width: 1280px) {
  .elj a {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

@media only screen and (max-width: 1024px) {
  .elj a {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

@media only screen and (max-width: 768px) {
  .elj a {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

@media only screen and (max-width: 640px) {
  .elj a {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

.elj a p {
  color: #fff;
}

.elj a span {
  display: block;
  opacity: 1;
  font-size: 13px;
  /*IE9以下で反映されるよう記述*/
  font-size: 0.76471rem;
  font-weight: bold;
}

.c-ef5a38 {
  color: #ef5a38;
}

.c-74be15 {
  color: #74be15;
}

.c-0aacb2 {
  color: #0aacb2;
}

.c-ee5093 {
  color: #ee5093;
}
.c-593a6b{
  color: #593a6b;
}
@media only screen and (max-width: 1280px) {
  .elj a span {
    font-size: 13px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.76471rem;
  }
}

@media only screen and (max-width: 1024px) {
  .elj a span {
    font-size: 13px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.76471rem;
  }
}

@media only screen and (max-width: 768px) {
  .elj a span {
    font-size: 13px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.76471rem;
  }
}

@media only screen and (max-width: 640px) {
  .elj a span {
    font-size: 13px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.76471rem;
  }
}

.new-ario_menu{
  margin-top: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 25px;
}
.elj a.orange {
  background-color: #fb9b85;
}

.elj a.pink {
  background-color: #f18db7;
}

.elj a.blue {
  background-color: #19d6dd;
}

.elj a.green {
  background-color: #9cdf45;
}
.elj a.purple{
  background-color: #7f5399;
}
.secTop100 {
  padding-top: 100px;
  padding-left: 0px;
  padding-bottom: 0px;
  padding-right: 0px;
}

@media only screen and (max-width: 1440px) {
  .secTop100 {
    padding-top: 6.94444vw;
    padding-left: 0vw;
    padding-bottom: 0vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  .secTop100 {
    padding-top: 13.88889vw;
    padding-left: 0vw;
    padding-bottom: 0vw;
    padding-right: 0vw;
  }
}

.BoxLeftLine {
  padding: 60px 35px 5px 35px;
  position: relative;
}

.BoxLeftLine:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 5px;
  border-radius: 3px;
}

.newsBoxSmall {
  position: relative;
  z-index: 40;
}

.newsBoxSmall li {
  margin-bottom: 10px;
}

.newsBoxSmall li span {
  display: inline-block;
}

.newsBoxSmall li span:nth-child(1) {
  width: 130px;
}

.newsBoxSmall li:last-child {
  margin-bottom: 0;
}

.decoTxt {
  position: absolute;
  top: -50%;
  transform: translateY(-50%);
  left: 40px;
  font-size: 220px;
  font-family: "ADAM.CG PRO";
  /*IE9以下で反映されるよう記述*/
  font-size: 12.94118rem;
}

@media only screen and (max-width: 1280px) {
  .decoTxt {
    font-size: 220px;
    /*IE9以下で反映されるよう記述*/
    font-size: 12.94118rem;
  }
}

@media only screen and (max-width: 1024px) {
  .decoTxt {
    font-size: 220px;
    /*IE9以下で反映されるよう記述*/
    font-size: 12.94118rem;
  }
}

@media only screen and (max-width: 768px) {
  .decoTxt {
    font-size: 220px;
    /*IE9以下で反映されるよう記述*/
    font-size: 12.94118rem;
  }
}

@media only screen and (max-width: 640px) {
  .decoTxt {
    font-size: 220px;
    top: 12%;
    /*IE9以下で反映されるよう記述*/
    font-size: 6.94118rem;
  }
}

.more {
  display: inline-block;
  position: relative;
  padding-bottom: 5px;
}

.more:after {
  content: "";
  display: block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
}

.epin {
  width: 48%;
}

.timeTable {
  width: 100%;
  border-spacing: 0px 8px;
  border-collapse: separate;
}

.timeTable tr th,
.timeTable tr td {
  text-align: center;
}

.timeTable tr th p,
.timeTable tr td p {
  padding: 15px 0;
}

.timeTable tr .xH {
  width: 160px;
  font-size: 18px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.05882rem;
}

@media only screen and (max-width: 1280px) {
  .timeTable tr .xH {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 1024px) {
  .timeTable tr .xH {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 768px) {
  .timeTable tr .xH {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 640px) {
  .timeTable tr .xH {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

.timeTable tr .xH span {
  display: block;
  font-size: 14px;
  /*IE9以下で反映されるよう記述*/
  font-size: 0.82353rem;
}

@media only screen and (max-width: 1280px) {
  .timeTable tr .xH span {
    font-size: 14px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.82353rem;
  }
}

@media only screen and (max-width: 1024px) {
  .timeTable tr .xH span {
    font-size: 14px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.82353rem;
  }
}

@media only screen and (max-width: 768px) {
  .timeTable tr .xH span {
    font-size: 14px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.82353rem;
  }
}

@media only screen and (max-width: 640px) {
  .timeTable tr .xH span {
    font-size: 14px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.82353rem;
  }
}

.telBox {
  padding: 15px 20px;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  border-radius: 10px;
}

.telBox span {
  font-size: 26px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.52941rem;
  letter-spacing: 0.1rem;
  margin-right: 1rem;
  font-weight: bold;
}

@media only screen and (max-width: 1280px) {
  .telBox span {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

@media only screen and (max-width: 1024px) {
  .telBox span {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

@media only screen and (max-width: 768px) {
  .telBox span {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

@media only screen and (max-width: 640px) {
  .telBox span {
    font-size: 26px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.52941rem;
  }
}

.telBox a {
  font-size: 56px;
  /*IE9以下で反映されるよう記述*/
  font-size: 3.29412rem;
  letter-spacing: 0.1rem;
  line-height: 1;
  font-weight: bold;
}

@media only screen and (max-width: 1280px) {
  .telBox a {
    font-size: 56px;
    /*IE9以下で反映されるよう記述*/
    font-size: 3.29412rem;
  }
}

@media only screen and (max-width: 1024px) {
  .telBox a {
    font-size: 56px;
    /*IE9以下で反映されるよう記述*/
    font-size: 3.29412rem;
  }
}

@media only screen and (max-width: 768px) {
  .telBox a {
    font-size: 56px;
    /*IE9以下で反映されるよう記述*/
    font-size: 3.29412rem;
  }
}

@media only screen and (max-width: 640px) {
  .telBox a {
    font-size: 56px;
    /*IE9以下で反映されるよう記述*/
    font-size: 3.29412rem;
  }
}

.kke {
  display: block;
  padding: 15px 5px;
  text-align: center;
}

.kke span {
  color: #fff;
  letter-spacing: 0.1rem;
  font-size: 20px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.17647rem;
}

@media only screen and (max-width: 1280px) {
  .kke span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1024px) {
  .kke span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 768px) {
  .kke span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 640px) {
  .kke span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

.me9 {
  width: 50%;
}

.me9:nth-child(1) {
  background-color: #00a99e;
  display: flex;
  align-items: center;
  justify-content: center;
}

.me9:nth-child(2) {
  padding: 30px;
}

.me9:nth-child(2) a {
  width: 48%;
  text-align: center;
  padding: 10px 0;
  margin: 5px 0;
}

.me9:nth-child(2) a img {
  margin: 0 auto;
}

.me9:nth-child(2) .blue {
  background-color: #70d1ca;
}

.me9:nth-child(2) .yellow {
  background-color: #5cbfe9;
}

.me9:nth-child(2) .yGreen {
  background-color: #bddf88;
}

.me9:nth-child(2) .green {
  background-color: #6ad59f;
}

.me9:nth-child(2) .orange {
  background-color: #eab974;
}

.me9:nth-child(2) .pink {
  background-color: #f8aad1;
}

.ekkg {
  width: 49%;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: cover;
  height: 135px;
  display: flex;
  align-items: center;
  padding: 0 40px;
}

.ekkg p {
  font-size: 28px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.64706rem;
}

@media only screen and (max-width: 1280px) {
  .ekkg p {
    font-size: 28px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.64706rem;
  }
}

@media only screen and (max-width: 1024px) {
  .ekkg p {
    font-size: 28px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.64706rem;
  }
}

@media only screen and (max-width: 768px) {
  .ekkg p {
    font-size: 28px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.64706rem;
  }
}

@media only screen and (max-width: 640px) {
  .ekkg p {
    font-size: 28px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.64706rem;
  }
}

.ekkg.rk1 {
  background-image: url(../kumagai/images/banner01.jpg);
}

.ekkg.rk2 {
  background-image: url(../kumagai/images/banner02.jpg);
}

.ekkg.rk2 p {
  color: #fff;
}

.faee > div {
  width: 16.666%;
}

.faee > div img {
  width: 100%;
  height: auto;
}

footer {
  padding-top: 70px;
  padding-left: 0px;
  padding-bottom: 0px;
  padding-right: 0px;
}

@media only screen and (max-width: 1440px) {
  footer {
    padding-top: 4.86111vw;
    padding-left: 0vw;
    padding-bottom: 13vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  footer {
    padding-top: 9.72222vw;
    padding-left: 0vw;
    padding-bottom: 13vw;
    padding-right: 0vw;
  }
}

footer .fLogo {
  display: block;
}

footer .fLogo img {
  width: 80%;
  max-width: 361px;
}

footer p,
footer a,
footer span {
  color: #fff;
}

footer .enn {
  width: 48%;
}

footer .timeTable {
  border-spacing: 0px 4px;
}

footer .timeTable span {
  color: #5f5f5f;
}

footer .timeTable tr:nth-child(1) {
  background-color: #fff9ba;
}

footer .timeTable tr:nth-child(2) {
  background-color: #e6fac7;
}

footer .timeTable tr:nth-child(3) {
  background-color: #ffe9c9;
}

footer .timeTable tr:nth-child(4) {
  background-color: #C9F4F6;
}

footer .timeTable tr p,
footer .timeTable tr span {
  line-height: 1;
  color: #5f5f5f;
}

footer nav {
  max-width: 800px;
  display: block;
  margin: 0 auto;
}

footer nav ul {
  display: flex;
}

footer nav ul li {
  flex-grow: 1;
  text-align: center;
}

footer nav ul li + li {
  border-left: 1px solid #fff;
}

footer nav ul li a {
  color: #fff;
  line-height: 1;
}

.fTel {
  display: flex;
  align-items: flex-end;
}

.fTel span {
  line-height: 1;
}

.fTel span:nth-child(1) {
  margin-right: 0.7rem;
}

.fTel span:nth-child(2) {
  font-size: 23px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.35294rem;
}

/**************************************************************

    アリオさっぽろ

**************************************************************/
.ario_main_open {
    text-align: center;
    margin-top: 30px;
    font-weight: bold;
    font-size: clamp(22px,3.5vw, 42px);
}
.timeTable.ario_table td {
    width: 9.5%;
}
.timeTable.ario_table .txt {
    font-size: clamp(12px,1.2vw, 15px);
}
.insta_fixed_sapporo{
  font-size: 0.9em;
  color: #fff;
  position: fixed;
  top: 78%;
  right: 0;
  transform: translateY(-50%);
  border-radius: 15px 0 0 15px;
  background: url(../ariosapporo/images/insta_color.webp) 50% 0/100% 102% no-repeat;
  padding: 10px 22px;
  z-index: 50;
  border-top: 5px solid #00a99d;
  border-left: 5px solid #00a99d;
  border-bottom: 5px solid #00a99d;
  width: 90px;
  height: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.insta_fixed_sapporo img{
  width: 100%;
}
/***院長ご挨拶***********/
.bg_edf9f8 {
    background-color: #edf9f8;
}
.about_table > div {
    display: flex;
    justify-content: space-between;
}
.about_table > div:nth-child(n+2) {
    margin-top: 15px;
}
.ab_cell1 {
    width: 120px;
}
.ab_cell2 {
    width: calc(100% - 120px);
    max-width: 420px;
}
/***/
.about03_flex {
    margin-top: 50px;
    display: flex;
    justify-content: space-between;
}
.about03_flex > div {
    width: 48%;
    max-width: 660px;
}
.about03_table {
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.about03_img {
    max-width: 300px;
    width: 45%;
}
.about03_img img{
    max-width: 100%;
    height: auto;
}
.about03_name {
    background-color: #5accc4;
    text-align: center;
    max-width: 290px;
    width: 50%;
    padding: 25px 10px;
    font-size: 18px;
}
.about03_name p{
    font-size: 18px;
    color: #FFF;
}
.about03_name h3{
    font-size: 28px;
    color: #FFF;
}
.about03_txt {
    margin-top: 30px;
}
.about03_txt p{
    line-height: 2em;
    font-size: 18px;
}
/***アクセス***********/
.bold {
    font-weight: bold;
}
.indent_txt {
    text-indent: -1.3em;
    padding-left: 1.3em;
}
.text_16 {
    font-size: 16px;
}
@media only screen and (max-width: 1024px) {
/**************************************************************

    アリオさっぽろ

**************************************************************/
.insta_fixed_sapporo{
  top: 83%;
}
.ario_allergy .insta_fixed_sapporo{
  top: 72%;
}
.ario_allergy .fixedBox{
  top: 38%;
}

/***院長ご挨拶***********/
.about03_flex {
    display: flex;
    flex-wrap: wrap;
    grid-row-gap: 40px;
}
.about03_flex > div {
    width: 100%;
    max-width: 640px;
    margin-left: auto;
    margin-right: auto;
}
}
@media only screen and (max-width: 768px) {
.insta_fixed_sapporo{
  font-size: 0.8em;
  top: 7%;
  right: 3%;
  border-radius: 15px;
  background: url(../ariosapporo/images/insta_color.webp) 50% 0/100% 100% no-repeat;
  padding: 10px 20px;
  z-index: 50;
  border-top: 3px solid #00a99d;
  border-left: 3px solid #00a99d;
  border-right: 3px solid #00a99d;
  border-bottom: 3px solid #00a99d;
  width: 70px;
  height: auto;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;

}
.ario_allergy .insta_fixed_sapporo{
  top: 7%;
}

}
@media only screen and (max-width: 740px) {

/**************************************************************

    アリオさっぽろ

**************************************************************/
.about03_flex {
    margin-top: 30px;
    grid-row-gap: 20px;
}
.about03_name {
    padding: 15px 10px;
}
.about03_name p{
    font-size: 14px;
}
.about03_name h3{
    font-size: 20px;
}
.about03_txt {
    margin-top: 10px;
}
.about03_txt p{
    line-height: 2em;
    font-size: 14px;
}
/***アクセス***********/
.indent_txt {
    text-indent: -1.2em;
    padding-left: 1.2em;
}
.text_16 {
    font-size: 14px;
}
}

/***********************/

@media only screen and (max-width: 1280px) {
  .fTel span:nth-child(2) {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

@media only screen and (max-width: 1024px) {
  .fTel span:nth-child(2) {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

@media only screen and (max-width: 768px) {
  .fTel span:nth-child(2) {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

@media only screen and (max-width: 640px) {
  .fTel span:nth-child(2) {
    font-size: 23px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.35294rem;
  }
}

.dmi a {
  display: block;
  width: 100%;
  max-width: 230px;
  background-color: #fff;
  text-align: center;
  padding: 10px 0;
}

.dmi a span {
  color: #00a99e;
  font-size: 19px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.11765rem;
}

@media only screen and (max-width: 1280px) {
  .dmi a span {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

@media only screen and (max-width: 1024px) {
  .dmi a span {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

@media only screen and (max-width: 768px) {
  .dmi a span {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

@media only screen and (max-width: 640px) {
  .dmi a span {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

.dmi a:nth-child(1) {
  margin-right: 15px;
}

.fixedBox {
  position: fixed;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
  border-radius: 15px 0 0px 15px;
  background-color: #5f5f5f;
  padding: 15px 20px;
  z-index: 50;
}
.fixedBox span {
  font-size: 20px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.17647rem;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #fff;
  letter-spacing: 0.1rem;
}
.questionnaire{
  position: fixed;
  bottom: 2%;
  right: 1%;
  z-index: 50;
  /* width: 200px; */
  background-color: #8f62a8;
  border-radius: 15px;
  padding: 30px;
}
.questionnaire a{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 10px;
}
.questionnaire:hover{
  background-color: #7F5399;
}
.questionnaire a span{
  color: #fff;
  margin: 0 auto;
  font-size: 32px;
  font-weight: bold;
}
.questionnaire a p{
  font-size: 18px;
  color: #fff;
  margin: 0 auto;
}
@media only screen and (max-width: 1280px) {
  .fixedBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
    .questionnaire{
    bottom: 1%;
  }
  .questionnaire a span{
    font-size: 28px;
  }
  .questionnaire a p{
    font-size: 16px;
  }

}

@media only screen and (max-width: 1024px) {
  .fixedBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 768px) {
  .fixedBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
  .questionnaire{
    bottom: 80px;
    padding: 20px;

  }
    .questionnaire a span{
          font-weight: normal;

    }
}

@media only screen and (max-width: 640px) {
  .fixedBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
    .questionnaire{
      right: 2%;
    bottom: 75px;
  }
  .questionnaire a span{
    font-size: 23px;
  }
  .questionnaire a p{
    font-size: 15px;
  }

}
@media only screen and (max-width: 480px) {
      .questionnaire{
    bottom: 60px;
    padding: 15px;
  }
  .questionnaire img{
    width: 20px !important;
  }
  .questionnaire a span{
    font-size: 18px;
  }
  .questionnaire a p{
    font-size: 12px;
  }

}
.fixedBox span i {
  letter-spacing: 0.1rem;
  color: #fff;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: 1.5em;
  font-weight: bold;
}

.fixedBox img {
  position: absolute;
  bottom: -12%;
  left: -64%;
}

.innerMain {
  height: 440px;
  width: 100%;
  background-repeat: no-repeat;
  background-position: 50%;
  background-size: cover;
}

.innerMain .head02-k {
  position: relative;
  text-align: center;
  font-size: 36px;
  /*IE9以下で反映されるよう記述*/
  font-size: 2.11765rem;
  padding-top: 115px;
  padding-left: 0px;
  padding-bottom: 90px;
  padding-right: 0px;
}

@media only screen and (max-width: 1280px) {
  .innerMain .head02-k {
    font-size: 36px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.11765rem;
  }
}

@media only screen and (max-width: 1024px) {
  .innerMain .head02-k {
    font-size: 36px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.11765rem;
  }
}

@media only screen and (max-width: 768px) {
  .innerMain .head02-k {
    font-size: 36px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.11765rem;
  }
}

@media only screen and (max-width: 640px) {
  .innerMain .head02-k {
    font-size: 36px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.11765rem;
  }
}

@media only screen and (max-width: 1440px) {
  .innerMain .head02-k {
    padding-top: 6.25vw;
    padding-left: 0vw;
    padding-bottom: 6.25vw;
    padding-right: 0vw;
  }
}

@media only screen and (max-width: 550px) {
  .innerMain .head02-k {
    padding-top: 12.5vw;
    padding-left: 0vw;
    padding-bottom: 12.5vw;
    padding-right: 0vw;
  }
}

.innerMain .head02-k span {
  width: 100%;
  position: absolute;
  top: 47%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  font-size: 170px;
  /*IE9以下で反映されるよう記述*/
  font-size: 10rem;
  opacity: 0.15;
  display: block;
  text-align: center;
  width: 300%;
  font-family: "ADAM.CG PRO";
}
.innerMain .head02-k.allergy_h2 span{
  width: 100%;
  position: absolute;
  top: 47%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  font-size: 170px;
  /*IE9以下で反映されるよう記述*/
  font-size: 9rem;
  opacity: 0.15;
  display: block;
  text-align: center;
  width: 300%;
  font-family: "ADAM.CG PRO";}
@media only screen and (max-width: 1280px) {
  .innerMain .head02-k span {
    font-size: 170px;
    /*IE9以下で反映されるよう記述*/
    font-size: 10rem;
  }
}

@media only screen and (max-width: 1024px) {
  .innerMain .head02-k span {
    font-size: 170px;
    /*IE9以下で反映されるよう記述*/
    font-size: 10rem;
  }
}

@media only screen and (max-width: 768px) {
  .innerMain .head02-k span {
    font-size: 170px;
    /*IE9以下で反映されるよう記述*/
    font-size: 10rem;
  }
}

@media only screen and (max-width: 640px) {
  .innerMain .head02-k span {
    font-size: 170px;
    /*IE9以下で反映されるよう記述*/
    font-size: 10rem;
  }
}

.ekp:nth-child(1) {
  width: 57%;
}

.ekp:nth-child(2) {
  width: 38%;
}

.nne .hackNne01 {
  display: flex;
  justify-content: center;
  align-items: flex-end;
}

.nne .hackNne01:nth-child(1) {
  text-align: unset;
}

.nne .hackNne01:nth-child(1) p {
  margin-right: 10px;
  width: unset;
}

.nne .hackNne01:nth-child(1) p:nth-child(2) {
  line-height: 1.32;
}

.hackBoxLeftLine {
  padding: 15px 35px 15px 35px;
}

.eio10:nth-child(1) {
  width: 100%;
}

.eio10:nth-child(1) .e9f {
  margin-top: 35px;
}

.eio10:nth-child(1) .e9f:nth-child(1) {
  margin-top: 0;
}

.eio10:nth-child(1) .e9f > div:nth-child(1) {
  width: 150px;
}

.eio10:nth-child(1) .e9f > div:nth-child(2) {
  width: calc(100% - 150px);
}

.eio9:nth-child(1) {
  width: 60%;
}

.eio9:nth-child(1) .e9f {
  margin-top: 35px;
}

.eio9:nth-child(1) .e9f:nth-child(1) {
  margin-top: 0;
}

.eio9:nth-child(1) .e9f > div:nth-child(1) {
  width: 150px;
}

.eio9:nth-child(1) .e9f > div:nth-child(2) {
  width: calc(100% - 150px);
}

.eio9:nth-child(2) {
  width: 30%;
}
.eio9:nth-child(2) > div:nth-child(n+2){
    margin-top: 20px;
}

.mapBox iframe {
  width: 100%;
  height: 560px;
}

.en38 {
  width: calc(33.333% - 67px);
  margin-right: 100px;
  margin-bottom: 30px;
  position: relative;
  cursor: pointer;
}

.en38 .ein {
  font-size: 1.2rem;
  padding: 10px 15px;
  background-color: #f6f6f6;
  position: relative;
}

.en38 .ein i {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translateY(-50%);
  width: 10px;
  height: 10px;
}

.en38 .ein i:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: 2px;
  height: 100%;
  background-color: #5f5f5f;
}

.en38 .ein i:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  width: 100%;
  height: 2px;
  background-color: #5f5f5f;
}

.en38:nth-child(3n + 3) {
  margin-right: 0;
}

.en38 .dropBoxCover {
  position: absolute;
  bottom: 0;
  left: 0%;
  width: 100%;
  transform: translateY(100%);
  z-index: 10;
  overflow: hidden;
  height: 0;
  transition: 0.3s;
}

.en38 .dropBoxCover .dropBox {
  background-color: #eee;
  padding: 15px;
}

.en38 .dropBoxCover .dropBox .dropBoxItem {
  margin-top: 15px;
}

.en38 .dropBoxCover .dropBox .dropBoxItem:nth-child(1) {
  margin-top: 0;
}

.en38 .dropBoxCover .dropBox .dropBoxItem .textBox p {
  font-size: 15px;
  /*IE9以下で反映されるよう記述*/
  font-size: 0.88235rem;
}

@media only screen and (max-width: 1280px) {
  .en38 .dropBoxCover .dropBox .dropBoxItem .textBox p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 1024px) {
  .en38 .dropBoxCover .dropBox .dropBoxItem .textBox p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 768px) {
  .en38 .dropBoxCover .dropBox .dropBoxItem .textBox p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) {
  .en38 .dropBoxCover .dropBox .dropBoxItem .textBox p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

.en38 .dropBoxCover .close {
  display: block;
  text-align: center;
}

.en38 .dropBoxCover .close i {
  font-weight: bold;
  font-size: 30px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.76471rem;
}

@media only screen and (max-width: 1280px) {
  .en38 .dropBoxCover .close i {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 1024px) {
  .en38 .dropBoxCover .close i {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 768px) {
  .en38 .dropBoxCover .close i {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 640px) {
  .en38 .dropBoxCover .close i {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

.re0 > div {
  text-align: center;
  margin-right: 3px;
  padding: 10px 0;
}

.re0 > div:nth-child(1) {
  width: 30%;
}

.re0 > div:nth-child(2) {
  width: 25%;
}

.re0 > div:nth-child(3) {
  width: 10%;
}

.re0 > div:nth-child(4) {
  width: calc(35% - 9px);
}

.re0.kita_re0 > div:nth-child(1) {
  width: 25%;
}

.re0.kita_re0 > div:nth-child(2) {
  width: 23%;
}

.re0.kita_re0 > div:nth-child(3) {
  width: 17%;
}

.re0.kita_re0 > div:nth-child(4) {
  width: calc(35% - 9px);
}

.re0 > div:last-child {
  margin-right: 0;
}

.re0 > div p {
  color: #fff;
  letter-spacing: 0.1rem;
}

.re1 {
  margin-bottom: 3px;
}

.re1 > div {
  margin-right: 3px;
  padding: 15px 15px;
  background-color: #f3f3f3;
  display: flex;
  align-items: center;
}

.re1 > div:nth-child(1) {
  width: 30%;
}

.re1 > div:nth-child(2) {
  width: 25%;
}

.re1 > div:nth-child(3) {
  width: 10%;
}

.re1 > div:nth-child(4) {
  width: calc(35% - 9px);
}

.re1 > div .blue {
  color: #0099d9;
  font-size: 17px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1rem;
}

.re1.kita_re1 > div:nth-child(3) {
  width: 17%;
  text-align: center;
  justify-content: center;
}

.re1.kita_re1 > div:nth-child(1) {
  width: 25%;
}

.re1.kita_re1 > div:nth-child(2) {
  width: 23%;
}

@media only screen and (max-width: 1280px) {
  .re1 > div .blue {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 1024px) {
  .re1 > div .blue {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 768px) {
  .re1 > div .blue {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 640px) {
  .re1 > div .blue {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

.re1 > div:last-child {
  margin-right: 0;
}

.re1 > div p {
  letter-spacing: 0.1rem;
  font-size: 15px;
  /*IE9以下で反映されるよう記述*/
  font-size: 0.88235rem;
}

@media only screen and (max-width: 1280px) {
  .re1 > div p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 1024px) {
  .re1 > div p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 768px) {
  .re1 > div p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) {
  .re1 > div p {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

.sliderNotached {
  position: relative;
  overflow: hidden;
  padding-top: 60px;
}

.sliderNotached:after {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 10;
}

@media (max-width: 740px) {
  .sliderNotached {
    padding-top: 0px;
  }
}

.topMain .font22 {
  font-size: 19px;
  /*IE9以下で反映されるよう記述*/
  font-size: 1.11765rem;
}

@media only screen and (max-width: 1280px) {
  .topMain .font22 {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

@media only screen and (max-width: 1024px) {
  .topMain .font22 {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

@media only screen and (max-width: 768px) {
  .topMain .font22 {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

@media only screen and (max-width: 640px) {
  .topMain .font22 {
    font-size: 19px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.11765rem;
  }
}

.fixedBox02 {
  display: none;
}

@media only screen and (max-width: 1280px) {
  html {
    font-size: 16px;
  }
  .telBox a {
    font-size: 40px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.35294rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 1280px) {
  .telBox a {
    font-size: 40px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.35294rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 1024px) {
  .telBox a {
    font-size: 40px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.35294rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 768px) {
  .telBox a {
    font-size: 40px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.35294rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 640px) {
  .telBox a {
    font-size: 40px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.35294rem;
  }
}

@media only screen and (max-width: 1280px) {
  .floatItem {
    max-width: 335px;
  }
  .nne .nne01 p:nth-child(1) {
    font-size: 16px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.94118rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 1280px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 16px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.94118rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 1024px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 16px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.94118rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 768px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 16px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.94118rem;
  }
}

@media only screen and (max-width: 1280px) and (max-width: 640px) {
  .nne .nne01 p:nth-child(1) {
    font-size: 16px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.94118rem;
  }
}

@media only screen and (max-width: 1280px) {
  .me9:nth-child(1) {
    width: 40%;
  }
  .me9:nth-child(2) {
    width: 60%;
  }
}

.me9:nth-child(2) {
  padding: 30px;
}

.yubinWhite {
  width: 0.7rem;
  height: auto;
}

.yubin {
  width: 0.7rem;
  height: auto;
}

.new_yubin {
  padding-right: 10px;
}

@media only screen and (max-width: 1024px) {
  html {
    font-size: 15px;
  }
  .en38 {
    width: calc(33.333% - 45px);
    margin-right: 45px;
    margin-bottom: 20px;
  }
  .mapBox iframe {
    height: 360px;
  }
  .head01 {
    max-width: 380px;
    margin: 0 auto;
  }
  .innerMain {
    height: 320px;
  }
  .dmi a {
    max-width: 175px;
  }
  .me9:nth-child(1) {
    width: 100%;
  }
  .me9:nth-child(1) span img {
    width: 100%;
    max-width: 320px;
  }
  .me9:nth-child(2) {
    width: 100%;
  }
  .epin {
    width: 100%;
  }
  .epin:nth-child(2) {
    padding-top: 6.94444vw;
  }
  .timeTable tr .xH {
    width: 130px;
  }
  .menf .font24 {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1024px) and (max-width: 1280px) {
  .menf .font24 {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1024px) and (max-width: 1024px) {
  .menf .font24 {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1024px) and (max-width: 768px) {
  .menf .font24 {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1024px) and (max-width: 640px) {
  .menf .font24 {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 1024px) {
  .floatItem {
    float: none;
    margin: 0 auto;
  }
  .floatTxt {
    margin-top: 25px;
  }
}

@media only screen and (max-width: 768px) {
  html {
    font-size: 14.5px;
  }
  .innerMain .head02-k span {
    font-size: 50px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.94118rem;
    transform: translateY(-50%) translateX(-50%);
  }
}

@media only screen and (max-width: 768px) and (max-width: 1280px) {
  .innerMain .head02-k span {
    font-size: 50px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.94118rem;
  }
}

@media only screen and (max-width: 768px) and (max-width: 1024px) {
  .innerMain .head02-k span {
    font-size: 50px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.94118rem;
  }
}

@media only screen and (max-width: 768px) and (max-width: 768px) {
  .innerMain .head02-k span {
    font-size: 50px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.94118rem;
  }
}

@media only screen and (max-width: 768px) and (max-width: 640px) {
  .innerMain .head02-k span {
    font-size: 50px;
    /*IE9以下で反映されるよう記述*/
    font-size: 2.94118rem;
  }
}

@media only screen and (max-width: 768px) {
  .en38:nth-child(3n + 3) {
    margin-right: 35px;
  }
  .en38:nth-child(even) {
    margin-right: 0px;
  }
  .en38 {
    width: calc(50% - 18px);
    margin-right: 35px;
  }
  .re0 {
    display: none;
  }
  .re1 {
    margin-bottom: 15px;
  }
  .re1 > div {
    margin-right: 0;
    padding: 10px 10px;
  }
  .re1 > div:nth-child(1) {
    width: 100%;
  }
  .re1 > div:nth-child(2) {
    width: 100%;
    margin-top: 4px;
    margin-bottom: 4px;
    position: relative;
    padding: 0 0 0 60px;
  }
  .re1.kita_re1 > div:nth-child(1) {
    width: 100%;
  }
  .re1.kita_re1 > div:nth-child(2) {
    width: 100%;
    margin-top: 4px;
    margin-bottom: 0;
    position: relative;
  }
  .re1 > div:nth-child(2):before {
    position: absolute;
    top: 50%;
    left: 10px;
    transform: translateY(-50%);
    content: "対象年齢:";
    color: #888888;
    font-size: 10px;
  }
  .re1.kita_re1 > div:nth-child(3) {
    width: 100%;
    margin-top: 4px;
    margin-bottom: 4px;
    position: relative;
    padding-top: 30px;
  }
  .re1 > div:nth-child(3) {
    width: 100%;
  }
  .re1 > div:nth-child(3):before {
    position: absolute;
    top: 10px;
    left: 10px;
    content: "対象年齢:";
    color: #888888;
    font-size: 10px;
  }
  .re1 > div:nth-child(4) {
    width: 100%;
  }
  .eio9:nth-child(1) {
    width: 100%;
  }
  .eio9:nth-child(2) {
    width: 100%;
    display: flex;
    margin-top: 25px;
      column-gap: 10px;
  }
    .eio9:nth-child(2) > div:nth-child(n+2){
        margin-top: 0;
    }
  .ekp:nth-child(1) {
    width: 100%;
    order: 2;
    margin-top: 25px;
  }
  .ekp:nth-child(2) {
    width: 100%;
    order: 1;
    max-width: 335px;
    margin: 0 auto;
  }
  footer .enn {
    width: 100%;
    max-width: 550px;
    margin: 0 auto;
  }
  footer .fLogo img {
    max-width: 310px;
  }
  .elj a {
    width: calc(50% - 10px);
    margin-top: 10px;
  }
  .elj a:nth-child(1) {
    margin-top: 0;
  }
  .elj a:nth-child(2) {
    margin-top: 0;
  }
  .fixedBox {
    display: none;
  }
  .fixedBox02 {
    display: flex;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 50;
  }
  .fixedBox02 a {
    width: 50%;
    padding: 2vw 0;
  }
  .fixedBox02 a:nth-child(1) {
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .fixedBox02 a:nth-child(1) span {
    color: #fff;
  }
  .fixedBox02 a:nth-child(1) span:nth-child(1) {
    font-size: 2.5vw;
    margin-right: 0.5rem;
    margin-top: 0.4rem;
  }
  .fixedBox02 a:nth-child(1) span:nth-child(2) {
    font-size: 5vw;
    line-height: 1;
  }
  .fixedBox02 a:nth-child(2) {
    background-color: #5f5f5f;
    position: relative;
    text-align: center;
  }
  .fixedBox02 a:nth-child(2) span {
    color: #fff;
  }
  .fixedBox02 a:nth-child(2) span:nth-child(1) {
    font-size: 4vw;
    line-height: 1;
  }
  .fixedBox02 a:nth-child(2) span:nth-child(2) {
    font-size: 2.5vw;
  }
  .fixedBox02 a:nth-child(2) i {
    position: absolute;
    left: -15px;
    bottom: 10px;
  }
  .fixedBox02 a:nth-child(2) i img {
    width: 9vw;
    height: auto;
  }
  .topMain .font22 {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 768px) and (max-width: 1280px) {
  .topMain .font22 {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 768px) and (max-width: 1024px) {
  .topMain .font22 {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 768px) and (max-width: 768px) {
  .topMain .font22 {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 768px) and (max-width: 640px) {
  .topMain .font22 {
    font-size: 17px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1rem;
  }
}

@media only screen and (max-width: 768px) {
  .newsBox li a {
    flex-wrap: wrap;
      justify-content: flex-start;
  }
  .newsBox li a span:last-child {
    width: calc(100% - 0px);
  }
  .menf {
    max-width: 450px;
    margin: 0 auto;
  }
  .menf:nth-child(1) {
    width: 100%;
  }
  .menf:nth-child(2) {
    width: 80vw;
    margin: -10% 0 auto auto;
  }
  .clinicLink a {
    width: calc(100% - 0px);
    margin-right: 0px;
    margin-top: 15px;
  }
  .clinicLink a > span {
    display: none;
  }
  .kep {
    width: 100%;
    padding: 15px;
  }
  .kep:nth-child(2) {
    margin-top: 15px;
  }
  .kep:nth-child(3) {
    margin-top: 15px;
  }
  .kep:nth-child(4) {
    margin-top: 15px;
  }
  .mdskf:nth-child(2) {
    width: calc(100% - 0px);
  }
}

@media only screen and (max-width: 640px) {
  html {
    font-size: 14px;
  }
  .mapBox iframe {
    height: 320px;
  }
  .eio9:nth-child(1) .e9f > div:nth-child(1) {
    width: 100%;
  }
  .eio9:nth-child(1) .e9f > div:nth-child(2) {
    width: 100%;
  }
  .eio9:nth-child(1) .e9f {
    margin-top: 15px;
  }
  .eio10:nth-child(1) .e9f > div:nth-child(1) {
    width: 100%;
  }
  .eio10:nth-child(1) .e9f > div:nth-child(2) {
    width: 100%;
  }
  .eio10:nth-child(1) .e9f {
    margin-top: 15px;
  }
  .innerMain {
    height: 230px;
  }
  footer nav {
    display: none;
  }
  .timeTable tr th p,
  .timeTable tr td p {
    padding: 5px 0;
  }
  .dmi a {
    max-width: 135px;
  }
  .timeTable tr .xH {
    width: 105px;
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 1280px) {
  .timeTable tr .xH {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 1024px) {
  .timeTable tr .xH {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 768px) {
  .timeTable tr .xH {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 640px) {
  .timeTable tr .xH {
    font-size: 15px;
    /*IE9以下で反映されるよう記述*/
    font-size: 0.88235rem;
  }
}

@media only screen and (max-width: 640px) {
  .timeTable tr .xH span {
    font-size: 10px;
  }
  footer .timeTable tr p,
  footer .timeTable tr span {
    font-size: 13px;
  }
  .me9:nth-child(2) a {
    width: 100%;
  }
  .ekkg {
    width: 100%;
    height: 110px;
    padding: 0 30px;
  }
  .BoxLeftLine {
    padding: 15px 10px 5px 15px;
  }
  .BoxLeftLine:before {
    width: 2px;
  }
  .newsBoxSmall li span:nth-child(2) {
    width: calc(100% - 0px);
  }
  .elj a {
    width: calc(50% - 5px);
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 1280px) {
  .elj a {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 1024px) {
  .elj a {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 768px) {
  .elj a {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 640px) {
  .elj a {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 640px) {
  .menf .font24 {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 1280px) {
  .menf .font24 {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 1024px) {
  .menf .font24 {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 768px) {
  .menf .font24 {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 640px) and (max-width: 640px) {
  .menf .font24 {
    font-size: 18px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.05882rem;
  }
}

@media only screen and (max-width: 640px) {
  .head01 {
    max-width: 200px;
    margin: 0 auto;
  }
  .kennk {
    width: calc(100% - 0px);
  }
  .kennk:nth-child(2) {
    width: 100%;
    margin-top: 25px;
  }
  .newsUl li a span:nth-child(2) {
    width: 100%;
  }
  .newsUl li a {
    flex-wrap: wrap;
  }
  .elj a {
    display: flex;
    align-items: center;
    justify-content: center;
  }
}

@media only screen and (max-width: 420px) {
  .en38 {
    width: calc(100% - 0px);
    margin-right: 0px !important;
  }
  .en38:nth-child(3n + 3) {
    margin-right: 0px !important;
  }
  .re1 > div:nth-child(2):before {
    top: 10px;
    transform: translateY(0%);
  }
  .re1 > div:nth-child(2) {
    width: 100%;
    padding: 30px 10px 10px 10px;
    margin-bottom: 0px;
  }
  .re1 > div:nth-child(3) {
    width: 100%;
  }
  .telBox {
    display: block;
    text-align: center;
  }
  .telBox a {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 1280px) {
  .telBox a {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 1024px) {
  .telBox a {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 768px) {
  .telBox a {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 640px) {
  .telBox a {
    font-size: 30px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.76471rem;
  }
}

@media only screen and (max-width: 420px) {
  .telBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 1280px) {
  .telBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 1024px) {
  .telBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 768px) {
  .telBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

@media only screen and (max-width: 420px) and (max-width: 640px) {
  .telBox span {
    font-size: 20px;
    /*IE9以下で反映されるよう記述*/
    font-size: 1.17647rem;
  }
}

/* CSS Document */
.catBox.shinsapporo {
  background-color: #89d90c;
  display: inline-block;
  font-size: 0.9rem;
  text-align: center;
  color: #fff;
  padding: 2px 5px;
  margin: 5px 0;
}

.catBox.ariosapporo {
  background-color: #00A99D;
  display: inline-block;
  font-size: 0.9rem;
  text-align: center;
  color: #fff;
  padding: 2px 5px;
  margin: 5px 0;
}

.catBox.hiraoka {
  background-color: #FFE402;
  display: inline-block;
  font-size: 0.9rem;
  text-align: center;
  color: #333;
  padding: 2px 5px;
  margin: 5px 0;
}

.catBox.minamisapporo {
  background-color: #07AC58;
  display: inline-block;
  font-size: 0.9rem;
  text-align: center;
  color: #fff;
  padding: 2px 5px;
  margin: 5px 0;
}

.catBox.asabu {
  background-color: #EC8C06;
  display: inline-block;
  font-size: 0.9rem;
  text-align: center;
  color: #fff;
  padding: 2px 5px;
  margin: 5px 0;
}
.catBox.kitahiro {
  background-color: #f18db7;
  display: inline-block;
  font-size: 0.9rem;
  text-align: center;
  color: #fff;
  padding: 2px 5px;
  margin: 5px 0;
}

.screen-reader-text {
  display: none !important;
  opacity: 0;
}

.nav-links {
  margin-top: 25px;
  max-width: 550px;
  margin: 25px auto 0 auto;
  display: flex;
  justify-content: center;
  gap: 15px;
}

.page-numbers {
  display: flex;
  justify-content: center;
}

.page-numbers li {
  background-color: #5f5f5f;
  display: block;
  padding: 0px 5px;
  color: #fff;
  margin: 0 5px;
}

.page-numbers li span {
  color: #fff;
}

.roster {
  margin-bottom: 2em;
}

.roster h3 {
  font-size: 1.4em;
  line-height: 1em;
  text-align: center;
  padding-top: 0.4em;
  padding-bottom: 0.4em;
  margin-top: 1em;
  margin-bottom: 0.4em;
  background-image: url(../img/tx01.png);
  font-weight: bold;
}

.roster .table {
  width: 100%;
  margin-bottom: 0.4em;
  display: table;
  border-top: 1px solid #999999;
  border-right: 1px none #999999;
  border-bottom: 1px solid #999999;
  border-left: 1px none #999999;
}

.roster .table .day-of-the-weeek td, .roster .table .day-of-the-weeek th {
  background: #B19665;
  vertical-align: middle;
  color: #FFFFFF;
  font-weight: bold;
  border: 1px solid #FFFFFF;
}

.roster .table .tbl-roster-header th {
  font-size: 1.4em;
  background: #C5E4DF;
}

.roster .table tr th {
  background-color: #F3F0DB;
  text-align: center;
  padding-top: 0.2em;
  border-bottom: 1px dotted #337550;
  border-left: 1px solid #999999;
  font-size: 0.9em;
  vertical-align: middle;
  border-right: 1px solid #999999;
}

.roster .table tr td {
  text-align: center;
  padding: 0.2em;
  border-left: 1px solid #999999;
  border-bottom: 1px dotted #999999;
  width: 15%;
  vertical-align: middle;
  border-right: 1px solid #999999;
  background: url(../img/tx00.png);
}

@media screen and (max-width: 479px) and (min-width: 320px) {
  .roster .table tr th {
    word-wrap: normal;
    font-size: 0.6em;
    padding-right: 0.1em;
    padding-left: 0.1em;
  }
  .roster .table tr td {
    font-size: 0.8em;
    vertical-align: middle;
  }
}

.mini_th {
    font-size: 14px;
    letter-spacing: 0;
}
.online_table {
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 350px;
}
.on_cell1 {
    width: calc(100% - 100px);
}
.on_cell1 .mini {
    font-size: 14px;
}
.on_cell2 {
    width: 120px;
    text-align: right;
}

/********アレルギー外来********/
#allergy{box-sizing: border-box;}
#allergy .main100{
  padding: 100px 0;
  margin: 0 auto;
}
#allergy .sec100{padding: 100px 0 30px;}
#allergy .sec30{padding: 30px 0 0;}
.allergy_text{
  margin-bottom: 40px;
}
#allergy .BoxLeftLine {
  padding: 0 0 0 35px;
  position: relative;
}
.BoxLeftLine:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 5px;
  border-radius: 3px;
}
.wrapper{padding: 100px 0 0;}
#allergy h3{font-size: 30px;
color: #00a99d;
margin-bottom: 15px;}
.p_1180{
  width: 1180px;
  margin: 0 auto;
}
.food_allergy{
  margin: 0 auto;
  width: 100%;
}
.food_allergy dl dt{
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 5px;
}
.dd_allergy{
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 15px;}
.food_allergy dl dd:nth-of-type(1){margin-bottom: 15px;}
.food_allergy dl dd:nth-of-type(2){margin-bottom: 15px;}
.food_allergy img{width: 600px;}
.trademark1 {
  font-size: 18px; /* メインのフォントサイズ */
  font-weight: bold;
  position: relative;
}
.trademark1::after {
  content: "®"; /* 登録商標マーク */
  font-size: 0.6em; /* 小さく表示 */
  position: absolute;
  top: 0; /* 上に少しズラす */
  right: -13px; /* 右に少しズラす */
}
.trademark2 {
  font-size: 17px; /* メインのフォントサイズ */
  position: relative;
}
.trademark2::after {
  content: "®"; /* 登録商標マーク */
  font-size: 0.6em; /* 小さく表示 */
  position: absolute;
  top: 0; /* 上に少しズラす */
  right: -13px; /* 右に少しズラす */
}
.bronchial-asthma{
  width: 80%;
  max-width: 1180px;
  margin: 45px auto 0;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  gap: 20px;
}
.bronchial-asthma img{
  width: 61%;
  max-width: 575px;
}
@media(width<1280px){
#allergy .sec100{padding: 70px 0 20px;}
#allergy h3{font-size: 30px;
margin-bottom: 15px;}
.p_1180{
  width: 90%;
  margin: 0 auto;
}
.food_allergy dl dt{
  font-size: 18px;
  margin-bottom: 5px;
}
.food_allergy img{width: 400px;}
.trademark2 {
  font-size: 16px;
}
}
@media(width<1024px){
  .trademark2 {
    font-size: 15px;
  }
  
}
@media(width<769px){
  #allergy .main100{
    padding: 40px 0;
      }
  .trademark2 {
    font-size: 14px;}
  .trademark2::after {
    right: -11px;}
  .bronchial-asthma{
    flex-direction: column;
  }
  .bronchial-asthma img{
    width: 100%;
  }
}