@charset "UTF-8";
/* media query */
/* SP縦から */
/* SP横から */
/* タブレット縦から */
/* フルワイド */
@import url(https://fonts.googleapis.com/earlyaccess/notosansjapanese.css);
@import url("https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,400;0,500;0,700;1,400;1,500;1,700&display=swap");
/* family
////////////////////////////////////////////*/
.family-intro__wrapper {
  box-sizing: border-box;
  padding: 30px 80px;
  background: #dfe9f5;
  position: relative;
}
@media all and (max-width: 896px) {
  .family-intro__wrapper {
    padding: 40px 20px;
  }
}
.family-intro__wrapper::before {
  content: "";
  width: 80px;
  height: 80px;
  background-image: url("../../common/images/frame_left.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
}
@media all and (max-width: 896px) {
  .family-intro__wrapper::before {
    width: 40px;
    height: 40px;
  }
}
.family-intro__wrapper::after {
  content: "";
  width: 80px;
  height: 80px;
  background-image: url("../../common/images/frame_right.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: absolute;
  bottom: 0;
  right: 0;
}
@media all and (max-width: 896px) {
  .family-intro__wrapper::after {
    width: 40px;
    height: 40px;
  }
}
.family-intro__container {
  max-width: 1000px;
  margin-inline: auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}
@media all and (max-width: 896px) {
  .family-intro__container {
    gap: 20px 25px;
  }
}
@media all and (max-width: 600px) {
  .family-intro__container {
    flex-direction: column;
  }
}
.family-intro__contents {
  flex-grow: 1;
}
@media all and (max-width: 600px) {
  .family-intro__contents {
    width: 100%;
  }
}
.family-intro__img {
  flex-shrink: 0;
  width: 250px;
}
@media all and (max-width: 896px) {
  .family-intro__img {
    width: 200px;
  }
}
@media all and (max-width: 600px) {
  .family-intro__img {
    width: 100%;
    max-width: 200px;
  }
}
.family-intro__txt {
  font-size: 1.6rem;
  line-height: 2;
}
@media all and (max-width: 896px) {
  .family-intro__txt {
    font-size: 1.4rem;
  }
}

.family-main {
  margin-top: 60px;
}
@media all and (max-width: 896px) {
  .family-main {
    margin-top: 40px;
  }
}

.family-item {
  margin-top: 50px;
}
@media all and (max-width: 896px) {
  .family-item {
    margin-top: 35px;
  }
}
.family-item .second_title {
  margin-bottom: 25px;
}
@media all and (max-width: 896px) {
  .family-item .second_title {
    margin-bottom: 20px;
  }
}
.family-item__inner {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
}
@media all and (max-width: 896px) {
  .family-item__inner {
    gap: 20px 25px;
  }
}
@media all and (max-width: 600px) {
  .family-item__inner {
    flex-direction: column;
    align-items: center;
  }
}
.family-item__inner.--reverse {
  flex-direction: row-reverse;
}
@media all and (max-width: 600px) {
  .family-item__inner.--reverse {
    flex-direction: column;
    align-items: center;
  }
}
.family-item__contents {
  flex-grow: 1;
}
.family-item__contents > *:first-child {
  margin-top: 0;
}
.family-item__txt {
  line-height: 2;
  font-size: 1.6rem;
  margin-top: 20px;
}
@media all and (max-width: 896px) {
  .family-item__txt {
    font-size: 1.4rem;
    margin-top: 10px;
  }
}
.family-item__list {
  line-height: 2;
  font-size: 1.6rem;
  margin-top: 20px;
}
@media all and (max-width: 896px) {
  .family-item__list {
    font-size: 1.4rem;
    margin-top: 10px;
  }
}
.family-item__list > li {
  position: relative;
  padding-left: 20px;
}
@media all and (max-width: 896px) {
  .family-item__list > li {
    padding-left: 18px;
  }
}
.family-item__list > li::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #ffdd00;
  position: absolute;
  left: 0;
  top: 10px;
}
@media all and (max-width: 896px) {
  .family-item__list > li::before {
    width: 8px;
    height: 8px;
  }
}
.family-item__img {
  flex-shrink: 0;
  width: 250px;
  margin: 0 8px 8px 0;
  box-shadow: 8px 8px 0 #032f69;
}
@media all and (max-width: 896px) {
  .family-item__img {
    width: 200px;
    margin: 0 6px 6px 0;
    box-shadow: 6px 6px 0 #032f69;
  }
}
@media all and (max-width: 600px) {
  .family-item__img {
    width: 100%;
    max-width: 200px;
  }
}

.family-summary {
  margin-top: 60px;
  box-sizing: border-box;
  padding: 40px 80px;
  background: #004092;
  color: #fff;
  position: relative;
}
@media all and (max-width: 896px) {
  .family-summary {
    margin-top: 40px;
    padding: 40px 20px;
  }
}
.family-summary::before {
  content: "";
  width: 80px;
  height: 80px;
  background-image: url("../../common/images/frame_left.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: absolute;
  top: 0;
  left: 0;
}
@media all and (max-width: 896px) {
  .family-summary::before {
    width: 40px;
    height: 40px;
  }
}
.family-summary::after {
  content: "";
  width: 80px;
  height: 80px;
  background-image: url("../../common/images/frame_right.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  position: absolute;
  bottom: 0;
  right: 0;
}
@media all and (max-width: 896px) {
  .family-summary::after {
    width: 40px;
    height: 40px;
  }
}
.family-summary__inner {
  max-width: 1000px;
  margin-inline: auto;
}
.family-summary__txt {
  word-break: keep-all;
  text-align: center;
  line-height: 2;
  font-size: 1.6rem;
}
@media all and (max-width: 896px) {
  .family-summary__txt {
    font-size: 1.4rem;
  }
}