.page-vaccination .footer-block1 {
  background-color: #F7FDFA;
}
.page-title::before {
  background-image: url(/img/common/info-icon6.png);
}

.vaccination-top-wrap.bg-color {
  background-color: #F7FDFA;
}
.vaccination-top-block {
  max-width: 800px;
  margin: 50px auto;
  padding: 25px 0;
}
.vaccination-top-block::after {
  content: "";
  display: block;
  align-items: center;
  width: 284px;
  height: 278px;
  margin: auto;
  background-image: url(/img/vaccination/vaccination-top-img.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.vaccination-top-title {
  text-align: center;
  font-weight: bold;
  margin-bottom: 0.5em;
}
@media (min-width: 992px) {
  .vaccination-top-block {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 20px;
  }
  .vaccination-top-block::after {
    display: inline-block;
  }
  .vaccination-top-block .text-wrap {
    width: 70%;
  }
  .vaccination-top-title {
    text-align: left;
  }
}

.gastro-camera-wrap {
  margin: 40px 0 50px;
}
.gastro-camera-block {
  max-width: 740px;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .gastro-camera-wrap {
    margin: 70px 0 100px;
  }
  .gastro-camera-block {
    margin: 0 auto;
  }
}

.vaccination-list {
  margin-bottom: 50px;
}
.vaccination-list .table-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.vaccination-list .vaccines-table {
  width: 100%;
  border-collapse: collapse;
  border: 1px solid #beb5a4;
  background: #fff;
  min-width: 945px;
  margin: 0;
}
.vaccination-list .vaccines-table thead {
  background: #ffe6e3;
}
.vaccination-list .vaccines-table th:nth-child(1),
.vaccination-list .vaccines-table td:nth-child(1) {
  width: 15%;
}
.vaccination-list .vaccines-table th:nth-child(2),
.vaccination-list .vaccines-table td:nth-child(2) {
  width: 20%;
}
.vaccination-list .vaccines-table th:nth-child(3),
.vaccination-list .vaccines-table td:nth-child(3) {
  width: 25%;
}
.vaccination-list .vaccines-table th:nth-child(4),
.vaccination-list .vaccines-table td:nth-child(4) {
  width: 40%;
}
.vaccination-list .vaccines-table td:nth-child(1) {
  font-weight: 700;
}
.vaccination-list .vaccines-table td:nth-child(1) span {
  display: inline-block;
  font-weight: 400;
}
.vaccination-list .vaccines-table td:nth-child(4) .description {
  margin-bottom: 1em;
}

.vaccination-list .vaccines-table th,
.vaccination-list .vaccines-table td {
  border: 1px solid #c8c8c8;
  padding: 1em 0.25em 1em 0.75em;
  vertical-align: top;
  text-align: left;
}
.vaccination-list .vaccines-table th {
  font-size: 1.4rem;
  font-weight: 700;
  text-align: center;
  line-height: 1.6;
}
.vaccination-list .vaccines-table td * {
  font-size: 1.2rem;
  font-weight: 400;
  line-height: 1.6;
}
.vaccination-list .vaccines-table td .list .item {
  display: grid;
  grid-template-columns: 1em auto;
  margin-bottom: 1em;
}
.vaccination-list .vaccines-table td .list .item:before {
  content: "・";
}
.vaccination-list .vaccines-table td .dlist:not(:last-child) {
  margin-bottom: 2em;
}
.vaccination-list .vaccines-table td .dlist .term {
  font-weight: 700;
}

.vaccination-list .vaccines-table a {
  color: #0a58ca;
  text-decoration: underline;
}
.vaccination-list .vaccines-table a:hover {
  text-decoration: none;
}
.vaccination-list .note {
  margin-top: 0.75em;
  color: #7a6464;
  font-size: 1.2rem;
}

.vaccination-flow {
  margin-bottom: 50px;
}
.vaccination-flow-block{
  display: grid;
  grid-template-columns: 1fr;
  gap:20px;
}
.vaccination-flow-block::after{
  content: "";
  display: block;
  align-items: center;
  width: 141px;
  height: 155px;
  margin: auto;
  background-image: url(/img/vaccination/vaccination-flow-img.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}
.vaccination-flow .vaccination-flow-block .list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.vaccination-flow .vaccination-flow-block .item {
  color: #634f4f;
  line-height: 2.2;
  margin: 0.2em 0;
  position: relative;
  word-break: keep-all;
}
.vaccination-flow .vaccination-flow-block .item::first-letter {
  font-size: 1.6rem;
  font-weight: 700;
  margin-right: 0.4em;
  color: #6a5858;
  vertical-align: baseline;
}

.vaccination-flow .vaccination-flow-block .item:not(:last-child)::after {
  content: "⇩";
  display: block;
  color: #b9a9a9;
  line-height: 1;
  font-size: 1.6rem;
  margin: 0.25em 0 0.15em;
}

@media (min-width: 768px) {
  .vaccination-flow-block{
    grid-template-columns: 1fr auto;
  }
  .vaccination-flow .vaccination-flow-block .item {
    line-height: 2.1;
  }
  .vaccination-flow .vaccination-flow-block .item:not(:last-child)::after {
    margin: 0.2em 0 0.1em;
  }
}

.vaccination-faq {
  margin-bottom: 50px;
  --qa-size: 1.8em; /* バッジの一辺 */
  --qa-gap: 0.6em; /* バッジと本文の間隔 */
}
.vaccination-faq .vaccination-faq-block details {
  padding: 1.1em 0 1.2em;
  border-bottom: 1px dotted rgba(169, 158, 158, 0.65);
}
.vaccination-faq .vaccination-faq-block details:last-child {
  border-bottom: none;
}

.vaccination-faq .vaccination-faq-block summary {
  list-style: none;
  cursor: default;
  display: flex;
  align-items: flex-start;
  gap: 0.6em;
  font-size: 1.6rem;
  font-weight: 700;
  color: #634f4f;
  line-height: 2.2;
  margin: 0;
}
.vaccination-faq .vaccination-faq-block summary::-webkit-details-marker {
  display: none;
}

.vaccination-faq .vaccination-faq-block summary::before {
  content: "Q";
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.5em;
  height: 1.5em;
  padding: 0 0.4em;
  border-radius: 0.35em;
  background: #00cf6f;
  color: #fff;
  font-weight: 700;
  line-height: 1;
  transform: translateY(0.15em);
}

.vaccination-faq .vaccination-faq-block .answer {
  position: relative;
  padding-left: calc(var(--qa-size) + var(--qa-gap));
  margin-top: 0.55em;
  color: #7a6464;
  font-size: 1.4rem;
}
.vaccination-faq .vaccination-faq-block .answer::before {
  content: "A";
  position: absolute;
  left: 0;
  top: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: var(--qa-size);
  height: var(--qa-size);
  background: #ff7063;
  color: #fff;
  font-size: 1.4rem;
  font-weight: 700;
  line-height: 1;
  border-radius: 0;
  padding: 0;
  transform: translateY(0.1em);
}

@media (min-width: 768px) {
  .vaccination-faq .vaccination-faq-block details {
    padding: 1.1em 0 1.4em;
  }
  .vaccination-faq .vaccination-faq-block .answer {
    padding-left: 2.4em;
  }
}

.vaccination-contact-wrap{
  padding:50px 0 25px;
}
.vaccination-contact-wrap.bg-color {
  background-color: #F7FDFA;
}

.vaccination-contact-text {
  width: fit-content;
  margin: 0 auto 1em;
}
.vaccination-contact-text .text-red {
  font-weight: bold;
}

.vaccination-contact-phone {
  font-family: din-2014, sans-serif;
  font-style: normal;
  font-size: calc(1.3rem + 0.6vw);
  font-weight: bold;
  text-align: center;
}
.vaccination-contact-phone .text {
  color: #ff7063;
  font-size: 150%;
}
.vaccination-contact-phone .number {
  color: #ff7063;
  font-size: 200%;
  margin-right: 0.8em;
}

.vaccination-contact-notes {
  list-style: none;
  padding: 0;
  margin: 0 auto 50px;
  width: fit-content;
  text-align: left;
  color: #7a6464;
}
.vaccination-contact-notes::before {
  display: block;
  content: "";
  width: 100%;
  height: 182px;
  background: url(/img/vaccination/vaccination-contact.png) no-repeat center
    center / contain;
  margin: auto;
}

.vaccination-contact-notes li {
  font-size: 1.2rem;
}

@media (min-width: 768px) {
  .vaccination-contact-phone {
    font-size: 1.75rem;
  }
}
