.contents img {
  width: 100%;
}
.contents .text-wrap a {
  text-decoration: underline;
}

.title {
  margin-bottom: 2em;
}
.title .heading02 {
  font-size: 2.4rem;
  margin-bottom: 1em;
}
.title p {
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
}

.photo {
  margin-top: 2em;
  justify-content: center;
  gap: 1em;
}
.photo li {
  flex: 1;
}
.photo + .text-wrap {
  margin-top: 2em;
}

#childcare .block {
  margin-top: 2em;
  text-align: center;
}
#childcare .btn-m {
  margin-top: 1em;
  background-color: #02858c;
}
#childcare .heading03::before {
  background: #02858c;
}

#clinic .heading03::before {
  background: #ea4e4e;
}

#training .heading03::before {
  background: #75a23a;
}

.staff .block {
  border-radius: 0.8em;
}
.staff .block + .block {
  margin-top: 2em;
}
.staff p + dl {
  margin-top: 2em;
}
.staff dl {
  gap: 1em;
}
.staff dt {
  width: 200px;
}
.staff dd {
  width: calc(100% - 200px - 1em);
}
.staff dd a {
  display: inline;
  color: #02858c;
  text-decoration: underline;
}
.staff .name {
  font-size: 1.8rem;
  font-weight: bold;
}
.staff .name span {
  font-size: 1.4rem;
  display: block;
}

.history .section li {
  display: flex;
  justify-content: space-between;
  padding: 1em 1.5em;
  background-color: white;
  border-radius: 0.8em;
}
.history .section li + li {
  margin-top: 1em;
}
.history .section h2 {
  width: 6em;
  color: #02858c;
}
.history .section p {
  width: calc(100% - 6em);
}

.outline .table {
  max-width: 800px;
  margin: 0 auto;
  padding: 1em;
  background-color: white;
  border-radius: 0.8em;
}
.outline .table a {
  color: #02858c;
  text-decoration: underline;
}
.outline table {
  width: 100%;
}
.outline table th,
.outline table td {
  padding: 1em;
}
.outline table tr {
  border-bottom: solid 1px #ddd;
}
.outline table tr:last-child {
  border: none;
}

.report ul.list {
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 2em;
}
.report ul.list li a {
  text-align: center;
  background: white;
  border-radius: 1em;
  padding: 2em 1em;
}
.report ul.list li:first-child {
  width: 100%;
}
.report ul.list li:first-child a {
  padding: 1em;
}
.report ul.list li:first-child span {
  display: block;
  color: #ea4e4e;
}
.report ul.list li:first-child img {
  max-width: 200px;
  margin: 1em auto 0;
  border: solid 1px #ddd;
}

.intro .heading01 {
  margin-bottom: 1.5em;
}
.intro.nolead .heading01 {
  margin-bottom: 0;
}
.intro p {
  font-weight: 500;
}
.intro p + p {
  margin-top: 1em;
}
.intro nav {
  margin-top: 2em;
}
.intro ul {
  justify-content: center;
  gap: 1em;
}
.intro li a {
  font-weight: 500;
  padding: 1em 2em;
  text-align: center;
  color: #fff;
  border-radius: 0.8em;
}
.intro a.blue {
  background-color: #02858c;
}
.intro a.pink {
  background-color: #ea4e4e;
}
.intro a.green {
  background-color: #75a23a;
}

.refugees .text-wrap + .title {
  margin-top: 3em;
}
.refugees figure {
  margin: 2em 0;
}
.refugees figure img {
  border: solid 10px white;
}

.privacy .section p, .privacy .section ul, .privacy .section ol {
  margin-bottom: 1em;
}
.privacy .section h2 {
  font-weight: bold;
  margin-bottom: 1em;
}
.privacy .section ul li {
  list-style-position: inside;
  list-style-type: disc;
}
.privacy .section ol li {
  list-style-position: inside;
  list-style-type: decimal;
}

article.support .faq {
  margin-top: 1.5em;
}
article.support .faq-header {
  display: inline-block;
  margin: 0;
  cursor: pointer;
  padding-right: 30px;
  position: relative;
}
article.support .faq-header::after {
  position: absolute;
  top: 38%;
  right: 10px;
  display: block;
  width: 8px;
  height: 8px;
  content: "";
  transition: transform 0.3s ease-in-out, top 0.3s ease-in-out;
  transform: rotate(135deg);
  border-top: solid 2px #02858c;
  border-right: solid 2px #02858c;
}
article.support .faq-content {
  display: none;
  padding-left: 1em;
}
article.support .faq-content dt {
  margin-top: 1em;
  color: #02858c;
}
article.support p + .block {
  margin-top: 2em;
}
article.support p + .heading04 {
  margin-top: 1em;
}
article.support .block + .block {
  margin-top: 2em;
}
article.support .block a {
  text-decoration: underline;
}
article.support .block a.blue {
  color: #02858c;
}
article.support .block a.pink {
  color: #ea4e4e;
}
article.support .block a.green {
  color: #75a23a;
}
article.support #spot .block {
  background-color: #f6f4ef;
}

article.contact strong {
  display: block;
  margin-top: 1em;
}
article.contact .second {
  padding-top: 0;
}

#spot .qr {
  display: block;
  max-width: 200px;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .title {
    margin-bottom: 1.5em;
  }
  .title .heading02 {
    font-size: 2rem;
  }
  .title p {
    font-size: 1.6rem;
  }
  .photo {
    flex-direction: column;
  }
  .report ul.list li {
    width: calc((100% - 4em) / 3);
  }
  .intro ul {
    flex-direction: column;
  }
  article.support .faq-header::after {
    display: none;
  }
}

@media screen and (max-width: 420px) {
  .title .heading02 {
    font-size: 1.8rem;
  }
  .staff dl {
    flex-direction: column;
  }
  .staff dt {
    margin: 0 auto;
  }
  .staff dd {
    width: 100%;
  }
  .history .section li {
    padding: 1em;
  }
  .report ul.list li {
    width: calc((100% - 2em) / 2);
  }
}
/*# sourceMappingURL=page.css.map */
