@charset "utf-8";
/* CSS Document */
.decBox04 {
  border: 2px solid #1f4da0;
  background: #fff;
}
.flexBox img {
  border-radius: 2rem;
}
/*-------------------------
first
--------------------------*/
	.firstCol3 li div {
        text-align: center;
	}
.faq-list {
  display: flex;
  flex-direction: column;
  gap: 1.6rem;
}
.faq-item {
  background: #ffffff;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid #e2eae7;
}
.faq-btn {
  width: 100%;
  background: none;
  border: none;
  cursor: pointer;
  padding: 1.1rem 1.25rem;
  display: flex;
  gap: 1.6rem;
  text-align: left;
  color: #2d3a35;
  transition: background .15s;
  align-items: center;
}
.faq-btn:hover {
  background: #f0f6f4;
}
.faq-q-icon {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: #7ec04c;
  color: #fff;
  font-size: 16px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}
.faq-q-text {
  flex: 1;
  font-size: 18px;
  line-height: 1.6;
  font-weight: bold;
}
.faq-chevron {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin-top: 2px;
  color: #7aab9f;
  transition: transform .25s ease;
}
.faq-btn[aria-expanded="true"] .faq-chevron {
  transform: rotate(180deg);
}
.faq-body {
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease;
}
.faq-body.open {
  max-height: 400px;
}
.faq-answer {
  padding: .25rem 1.25rem 1.25rem 3.3rem;
  line-height: 1.85;
  color: #4d6059;
  border-top: 1px solid #e2eae7;
  padding-top: .9rem;
  margin-bottom: 1rem !important;
}
/*-------------------------
about
--------------------------*/
.p-featureList {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 40px 0;
}
.p-featureItem {
  position: relative;
  overflow: hidden;
  padding: 28px 32px 24px 32px;
  border-radius: 20px;
  border: 2px solid #d6ede9;
  background: #fff;
  z-index: 0;
}
.p-featureItem:nth-child(even) {
  border-color: #fad6d6;
}
.p-featureItem__bgNum {
  position: absolute;
  bottom: 16px;
  right: 16px;
  font-size: 130px;
  font-weight: 900;
  color: rgba(237, 248, 246, 1.00);
  line-height: 1;
  pointer-events: none;
  user-select: none;
  font-family: 'Zen Maru Gothic', sans-serif;
  letter-spacing: -6px;
  z-index: -1;
}
.p-featureItem:nth-child(even) .p-featureItem__bgNum {
  color: rgba(234, 169, 169, 0.2);
  right: inherit;
  left: 16px;
}
.p-featureItem:nth-child(even) .p-featureItem__dot {
  background: #e07070;
}
.p-featureItem__pointText {
  font-size: 11px;
  font-weight: 700;
  color: #5bbdb5;
  letter-spacing: 0.15em;
  font-family: 'Zen Maru Gothic', sans-serif;
}
.p-featureItem:nth-child(even) .p-featureItem__pointText {
  color: #e07070;
}
@media screen and (max-width: 768px) {
  .p-featureItem {
    padding: 22px 20px 20px 20px;
  }
  .p-featureItem__bgNum {
    font-size: 90px;
    top: -10px;
    right: 10px;
  }
}
	.facBox {
		position: relative;
	}
	.facBox p {
		position: absolute;
		bottom: 0;
background:rgba(255,255,255,0.7);
		margin-bottom: 0 !important;
		color: #1f4da0;
	}

/*-------------------------
news
--------------------------*/
/*-------------------------
menu
--------------------------*/
.menuBox {
  background-color: #fff;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
}
#flu .hA::before {
  content: 'INFLUENZA';
}
#flu .decBox01 {
  border: 2px solid #1f4da0;
}
.listBnr li {
  border: 1px solid #7ec04c;
  padding: 0.9rem 1.6rem 0.9rem 4rem !important;
  border-radius: 1rem;
}
.listBnr li::before {
  top: 50% !important;
  transform: translateY(-50%) !important;
  margin-left: 1.1rem;
}
.symptomsBox .decBox {
  border: 2px solid #1f4da0;
}
.symptomsBox h4 {
  color: #1f4da0;
  text-align: center;
  font-weight: 600;
  margin-bottom: 2rem;
}
p.icon {
  width: 60px;
  height: 60px;
  margin: 0 auto 10px;
  padding: 10px;
  background: #cdf2fc;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}
p.icon img {
  width: 80%;
  display: block;
  height: auto;
}
.emergencyBox p {
  text-align: center;
}
p.emargencyNum, p.emargencyNum a {
  color: #1f4da0 !important;
}
p.emargencyNum span {
  color: #6d5239;
}
p.emargencyNum a {
	text-decoration: none !important;
}
/*-------------------------
access
--------------------------*/
.TimeSchedule {
  text-align: center;
}
/*-------------------------
staff
--------------------------*/
.staffBox .flexImg {
	position: relative;
}
.staffBox .flexImg::before {
  position: absolute;
  background: url("../../img/page/staff/img-staff-03.png") no-repeat center / cover;
  content: "";
	    z-index: 1;
}
.drname {
  line-height: 1.4;
  text-align: right;
  font-weight: 600;
  position: relative;
}
.drname::before {
  position: absolute;
  background: url(../../img/common/img_wave03.png) no-repeat center / cover;
  content: "";
  top: -10.1rem;
  right: -12.4rem;
  width: 28rem;
  height: 21.6rem;
  z-index: -1;
  opacity: 0.3;
}
.careerBox {
	position: relative;
}

.careerBox h3 {
  margin-bottom: 30px !important;
}
.careerBox dl {
  display: flex;
  flex-wrap: wrap;
}
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
PC Setting
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (min-width: 768px) {
  .mt30_pc {
    margin-top: 30px !important;
  }
  .mt50_pc {
    margin-top: 50px !important;
  }
  /*-------------------------
menu(PC)
--------------------------*/
  .reserveBox {
    width: 500px;
    margin: 0 auto;
    display: -webkit-flex;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .symptomsBox h4 {
    font-size: 2rem;
  }
  p.emargencyNum {
    font-size: 3rem;
  }
  p.emargencyNum span {
    font-size: 80%;
  }
  /*------------------------
staff(PC)
--------------------------*/
  .staffBox {
    margin-bottom: 0;
  }
  .staffBox .flexImg {
    width: 40%;
  }
	.staffBox .flexImg::before {
    width: 25rem;
    height: 24.3rem;

    left: -8rem;
    bottom: 0;;
}
  .staffBox .flexContent {
    width: 55%;
  }
  .drname {
    font-size: 2.2rem !important;
  }
  .drname span {
    font-size: 2.0rem !important;
  }
  .careerBox {
    margin-top: 80px !important;
    padding: 5rem 4rem;
  }
	.careerBox::before {
  position: absolute;
  background: url("../../img/page/staff/img-staff-04.png") no-repeat center / cover;
  content: "";
    bottom: 4rem;
    right: 3rem;
    width: 14.1rem;
    height: 15.4rem;
    z-index: 2;
}
.careerBox::after {
  position: absolute;
  background: url("../../img/page/staff/img-staff-05.png") no-repeat center / cover;
  content: "";
bottom: 1.9rem;
    right: 19.8rem;
    width: 13.2rem;
    height: 10.4rem;
    z-index: 2;
}
  .careerBox dt {
    width: 15%;
    border-bottom: 1px dotted #ffc9c0;
    margin-bottom: 20px;
    padding-bottom: 15px;
  }
  .careerBox dd {
    width: 80%;
    margin-bottom: 20px;
    padding-bottom: 15px;
    border-bottom: 1px dotted #ffc9c0;
  }
  /*-------------------------
about(PC)
--------------------------*/
.facBox p {
		padding: 10px 20px 10px 30px;
		border-radius: 0 2rem 0 2rem;
	}
}
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
tabletSetting
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 1200px) and (min-width: 768px) {}
/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
SP Setting
━━━━━━━━━━━━━━━	.staff-career {
    display: flex;
    flex-wrap: wrap;
}━━━━━━━━━━━━━━━━━━ */
@media (max-width: 767px) {
  /*-------------------------
first(SP)
--------------------------*/

	.firstCol3 {
		display: flex !important;
	}
	.firstCol3 li {
	display: block;
    width: 31%;
	}
	.firstCol3 li:first-child{
		        margin-top: 3vw;
	}
	.firstCol3 li p, .firstCol3 li div {
		width: 100% !important;
	} 
	.firstCol3 li div {
		font-size: 1.1rem;
        text-align: center;
	}
	  .faq-answer, .faq-q-text {
    font-size: 4vw;
  }
  /*-------------------------
menu(SP)
--------------------------*/
  p.emargencyNum {
    font-size: 2.7rem;
    line-height: 1.3;
  }
  p.emargencyNum span {
    font-size: 60%;
  }
  .symptomsBox h4 {
    font-size: 1.8rem;
  }
  /*------------------------
staff(SP)
--------------------------*/
  .staffBox .flexImg {
    width: 80% !important;
    margin: 4vw auto;
  }
	.staffBox .flexImg::before{
        width: 18.5rem;
        height: 18.3rem;
        z-index: -1;
        left: -8.2rem;
        bottom: -185px;
        opacity: 0.3;
	}
  .careerBox {
    margin-top: 40px !important;
  }
	
  .careerBox dt {
    width: 25%;
    border-bottom: 1px dotted #ffc9c0;
    margin-bottom: 10px;
    padding-bottom: 10px;
  }
  .careerBox dd {
    width: 70%;
    margin-bottom: 10px;
    padding-bottom: 10px;
    border-bottom: 1px dotted #ffc9c0;
  }
	
  /*-------------------------
about(SP)
--------------------------*/
	.facBox p {
        padding: 10px;
        border-radius: 0 0 2rem 2rem;
        width: 100%;
        text-align: center;
		font-size: 12px;
		line-height: 1.4;
	}
  /*-------------------------
access(SP)
--------------------------*/
  table.TimeSchedule th {
    padding: 3px;
    font-size: 4vw;
  }
  table.TimeSchedule td {
    padding: 3px;
    font-size: 4vw;
  }
}