/* ----- recmd01 ----- */

.recmd01 {
  background: #fff8f8;
  margin-top: 56px;
  padding-bottom: 166px;
  padding-top: 62px; /* sec01 */
}

.recmd01__heading {
  /* animation: fadeInUp 1s; */
  text-align: center;
}

.recmd01__heading-sub {
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  font-size: 36px;
  font-weight: 600;
}

.recmd01__heading-title {
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  font-size: 36px;
  font-weight: 600;
  line-height: 1;
  vertical-align: bottom;
}

.recmd01__heading-title .big {
  font-size: 47px;
  letter-spacing: -4px;
}

.recmd01__heading-title .c-t-orange {
  font-size: 58px;
  line-height: 100%;
}

.recmd01__heading-en {
  font-size: 13px;
  font-weight: 600;
  margin-top: 20px;
}

.recmd01 .sec01__items {
  display: flex;
  flex-direction: column;
  gap: 70px;
  margin-top: 83px;
}

.recmd01 .sec01__item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.recmd01 .sec01__head {
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  padding: 6px 0;
  position: relative;
  z-index: 0;
}

.recmd01 .sec01__head::after {
  background: #e75d4b;
  content: "";
  height: 100%;
  left: 50%;
  opacity: 0.11;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: calc(100% + 60px);
  z-index: -2;
}

.recmd01 .sec01__head.--even {
  padding-left: 90px;
}

.recmd01 .sec01__head-text {
  font-size: 24px;
  font-weight: 400;
}

.recmd01 .sec01__head-num {
  bottom: 0;
  font-size: 80px;
  font-style: italic;
  line-height: 1;
  opacity: 0.36;
  padding-right: 20px;
  position: absolute;
  right: -20px;
  z-index: -1;
}

.recmd01 .sec01__head-num.--even {
  left: -18px;
  opacity: 0.22;
  right: auto;
}

/* ----- recmd02 ----- */

.recmd02 {
  background: #fff; /* sec01 */
}

.recmd02__heading {
  align-items: center;
  /* animation: fadeInUp 1s; */
  color: #67c383;
  display: flex;
  flex-direction: column;
  gap: 6px;
  text-align: center;
}

.recmd02__sub {
  font-size: 24px;
  font-weight: 600;
  position: relative;
}

.recmd02__sub::before,
.recmd02__sub::after {
  background: #67c383;
  bottom: 17px;
  content: "";
  height: 2px;
  position: absolute;
  right: -47px;
  transform: rotate(-64deg);
  width: 28.65px;
}

.recmd02__sub::before {
  left: -47px;
  right: auto;
  transform: rotate(64deg);
}

.recmd02__title {
  font-size: 31px;
  font-weight: 600;
}

.recmd02__title span {
  font-size: 26px;
}

.recmd02 .sec01 {
  margin-top: 64px;
  padding-bottom: 162px;
}

.recmd02 .sec01__items {
  display: flex;
  flex-direction: column;
  gap: 41px;
}

.recmd02 .sec01__head {
  align-items: center;
  background: #67c383;
  border-radius: 12px 12px 0 0;
  display: flex;
  height: 106px;
  justify-content: center;
  padding-top: 13px;
  position: relative;
}

.recmd02 .sec01__head-text {
  color: #fff;
  font-size: 22px;
  font-weight: bold;
  line-height: 1.45;
  text-align: center;
}

.recmd02 .sec01__parts {
  position: absolute;
}

.recmd02 .sec01__parts.--left {
  left: -53px;
  top: -20px;
  width: 117px;
}

.recmd02 .sec01__parts.--right {
  bottom: -15px;
  right: -23px;
  width: 80px;
}

.recmd02 .sec01__body {
  border: 2px solid #67c383;
  padding: 32px 28px 25px;
}

.recmd02 .sec01 .c-text {
  line-height: 1.87;
}

.recmd02 .sec02 {
  background: #67c383;
  color: #fff;
  padding-block: 91px 165px;
  position: relative;
}

.recmd02 .sec02__img {
  left: 50%;
  position: absolute;
  top: -30px;
  transform: translateX(-50%);
  width: 143px;
}

.recmd02 .sec02__title {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}

.recmd02 .sec02__text {
  font-size: 14px;
  font-weight: 400;
  line-height: 2;
  margin-top: 20px;
}

.recmd02 + .footer-content .breadcrumb {
  color: #fff;
}

/* ----- recmd04 ----- */

.recmd04 {
  background: #fffbfb;
  padding-bottom: 190px;
  padding-top: 105px; /* sec01 */
}

.recmd04__heading {
  /* animation: fadeInUp 1s; */
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  text-align: center;
}

.recmd04__sub {
  font-size: 26px;
  font-weight: 600;
}

.recmd04__sub .red {
  color: #d85050;
}

.recmd04__title {
  font-size: 36px;
  font-weight: 600;
}

.recmd04__title .pink {
  color: #ed8f8b;
  font-size: 42px;
}

.recmd04__title .blue {
  color: #6ec8df;
  font-size: 42px;
}

.recmd04__title .small {
  font-size: 30px;
}

.recmd04 .sec01 {
  margin-top: 70px;
}

.recmd04 .sec01__items {
  display: flex;
  flex-direction: column;
  gap: 51px;
}

.recmd04 .sec01__item {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.recmd04 .sec01__head {
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  position: relative;
  z-index: 0;
}

.recmd04 .sec01__head-title {
  color: #ed8f8b;
  font-size: 26px;
  font-weight: 400;
}

.recmd04 .sec01__head-title.--even {
  color: #6dc8e0;
}

.recmd04 .sec01__head-sub {
  font-size: 18px;
  font-weight: 400;
}

.recmd04 .sec01__head-en {
  bottom: -40px;
  color: #f3b5c0;
  font-size: 108px;
  font-style: italic;
  letter-spacing: -0.05em;
  opacity: 0.18;
  position: absolute;
  right: 0;
  white-space: nowrap;
  z-index: -1;
}

.recmd04 .sec01__head-en.--even {
  color: #abddeb;
}

.recmd04 .sec01__text {
  line-height: 1.87;
}

/* ----- recmd05 ----- */

.recmd05 {
  background: #fff;
  padding-bottom: 180px;
  padding-top: 125px; /* sec01 */
}

.recmd05__heading {
  /* animation: fadeInUp 1s; */
  color: #0086c9;
  display: flex;
  flex-direction: column;
  text-align: center;
}

.recmd05__heading-title {
  font-size: 32px;
  font-weight: 600;
}

.recmd05__heading-sub {
  font-size: 26px;
  font-weight: 600;
}

.recmd05__images {
  align-items: end;
  display: flex;
  justify-content: space-between;
  margin-top: -16px;
  padding-right: 13px;
}

.recmd05__images-wrap {
  margin: 0 auto;
  max-width: 450px;
}

.recmd05__images-left {
  width: 175px;
}

.recmd05__images-right {
  width: 107px;
}

.recmd05__desc {
  font-size: 18px;
  font-weight: 500;
  margin-top: 30px;
  text-align: center;
}

.recmd05 .sec01__items {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 36px;
  margin-top: 40px;
}

.recmd05 .sec01__item {
  align-items: center;
  display: flex;
  flex-direction: column;
  width: 100%;
}

.recmd05 .sec01__head {
  align-items: center;
  background: #0086c9;
  display: flex;
  height: 70px;
  justify-content: center;
  width: 100%;
}

.recmd05 .sec01__head-text {
  color: #fff;
  font-size: 19px;
  font-weight: bold;
  line-height: 1.42;
  text-align: center;
}

.recmd05 .sec01__img {
  margin-top: 19px;
  width: 250px;
}

.recmd05 .sec01__body {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 13px;
  text-align: center;
}

.recmd05 .sec01__body-lead {
  font-size: 17px;
  font-weight: bold;
  line-height: 1.2941176471;
}

.recmd05 .sec01__body-text {
  font-size: 14px;
  font-weight: 500;
  line-height: 1.5;
}

/* ----- recmd07 ----- */

.recmd07 {
  background: linear-gradient(180deg, #ffedd0 0%, #fdf7db 50.7%, #ffc9b4 100%);
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  padding-bottom: 180px;
}

.recmd07__heading {
  align-items: center;
  /* animation: fadeInUp 1s; */
  color: #000000;
  display: flex;
  flex-direction: column;
  position: relative;
  text-align: center;
  z-index: 0;
}

.recmd07__heading-img {
  left: calc(50% - 176px);
  position: absolute;
  top: 15px;
  width: 158px;
  z-index: -1;
}

.recmd07__sub-title {
  font-size: 24px;
}

.recmd07__title {
  font-size: 32px;
}

.recmd07__inner {
  align-items: center;
  display: flex;
  flex-direction: column;
}

.recmd07__items {
  border-left: 1px solid #fc7a4c;
  display: flex;
  flex-direction: column;
  gap: 43px;
  margin-top: 56px;
}

.recmd07__item {
  padding-left: 19px;
  width: 100%;
}

.recmd07__year {
  color: #fc7a4c;
  font-size: 22px;
  font-weight: bold;
  position: relative;
  transform: translateY(-50%);
}

.recmd07__year::before,
.recmd07__year::after {
  border-radius: 50%;
  content: "";
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

.recmd07__year::before {
  border: 1px solid #fc7a4c;
  height: 19px;
  left: -29px;
  width: 19px;
}

.recmd07__year::after {
  background: #fc7a4c;
  height: 13px;
  left: -26px;
  width: 13px;
}

.recmd07__body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.recmd07__month-block {
  display: flex;
  gap: 14px;
}

.recmd07__month {
  color: #fc7a4c;
  flex-shrink: 0;
  font-size: 18px;
  font-weight: bold;
}

.recmd07__card {
  background: #fff;
  border-radius: 6px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  position: relative;
  width: 100%;
}

.recmd07__card::after {
  border-bottom: 7px solid transparent;
  border-right: 13px solid #fff;
  border-top: 7px solid transparent;
  content: "";
  height: 0;
  left: -9px;
  position: absolute;
  top: 7px;
  width: 0;
  z-index: 1;
}

.recmd07__text {
  font-size: 14px;
}

.recmd07__imgs {
  -moz-column-count: 2;
  column-count: 2;
  -moz-column-gap: 8px;
  column-gap: 8px;
}

.recmd07__img {
  margin-bottom: 8px;
  -moz-column-break-inside: avoid;
  break-inside: avoid;
}

.recmd07__img img {
  height: auto;
  width: 100%;
}

/* ----- recmd08 ----- */

.recmd08 {
  padding-top: 125px; /* sec01 */
}

.recmd08__heading {
  /* animation: fadeInUp 1s; */
  position: relative;
  text-align: center;
  z-index: 1;
}

.recmd08__heading-title {
  font-family: "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  font-size: 36px;
  font-weight: 400;
}

.recmd08__heading-title small {
  font-size: 28px;
}

.recmd08__heading-en {
  font-size: 17px;
  margin-top: 3px;
}

.recmd08__lead {
  align-items: center;
  display: flex;
  flex-direction: column;
  margin-top: 38px;
  z-index: 0;
}

.recmd08__img {
  position: relative;
  width: 90px;
}

.recmd08__img::after {
  background: #fff;
  content: "";
  filter: blur(36px);
  height: 253px;
  left: 50%;
  opacity: 0.789;
  position: absolute;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 253px;
  z-index: -1;
}

.recmd08__desc {
  font-size: 14px;
  font-weight: bold;
  letter-spacing: 0.1em;
  line-height: 1.7142857143;
  text-align: center;
}

.recmd08 .sec01 {
  background: #fff;
  margin-top: 87px;
  padding-bottom: 180px;
  position: relative;
  z-index: 1;
}

.recmd08 .sec01__head {
  align-items: center;
  background: linear-gradient(90deg, #d3baea 0%, #dacdf4 51.2%, #a6d1fd 100%);
  display: flex;
  height: 70px;
  justify-content: center;
}

.recmd08 .sec01__head.--sec {
  margin-top: 77px;
}

.recmd08 .sec01__head-text {
  color: #fff;
  font-size: 27px;
  font-weight: bold;
}

.recmd08 .sec01__items {
  display: flex;
  flex-direction: column;
  gap: 82px;
  margin-top: 40px;
}

.recmd08 .sec01__item {
  align-items: center;
  display: flex;
  flex-direction: column;
  gap: 26px;
}

.recmd08 .sec01__link {
  transition: 0.3s;
}

.recmd08 .sec01__link:hover {
  opacity: 0.7;
}

.recmd08 .sec01__link-logo.--unicef {
  width: 127px;
}

.recmd08 .sec01__link-logo.--haruka {
  width: 195px;
}

.recmd08 .sec01__link-logo.--bunner {
  width: 315px;
}

.recmd08 .sec01__link-logo.--tohoku {
  width: 255px;
}

.recmd08 .sec01__body {
  display: flex;
  flex-direction: column;
  gap: 1px;
  text-align: center;
}

.recmd08 .sec01__name {
  font-size: 16px;
  font-weight: bold;
}

.recmd08 .sec01__date {
  font-size: 14px;
  font-weight: 500;
}

@media screen and (min-width: 1080px) {
  .recmd01 {
    padding-top: 100px;
  }

  .recmd01 .sec01__head {
    padding: 10px 0px;
  }

  .recmd01 .sec01__head::after {
    border-radius: 12px;
    width: calc(100% + 200px);
  }

  .recmd02 .sec01 {
    padding-bottom: 180px;
  }

  .recmd02 .sec01__items {
    gap: 60px;
  }

  .recmd02 .sec01__body {
    padding: 32px 50px 25px;
  }

  .recmd02 .sec02 {
    padding-block: 120px 165px;
  }

  .recmd02 .sec02__img {
    width: 160px;
  }

  .recmd02 .sec02__text {
    font-size: 18px;
  }

  .recmd04 {
    padding-top: 200px;
  }

  .recmd04 .sec01 {
    margin-top: 100px;
  }

  .recmd04 .sec01__items {
    gap: 80px;
  }

  .recmd04 .sec01__item {
    gap: 24px;
  }

  .recmd04 .sec01__head-title {
    font-size: 34px;
  }

  .recmd04 .sec01__head-sub {
    font-size: 22px;
  }

  .recmd05 {
    padding-top: 200px;
  }

  .recmd05__images-wrap {
    max-width: 800px;
  }

  .recmd05__images-left {
    width: 400px;
  }

  .recmd05__images-right {
    width: 300px;
  }

  .recmd05 .sec01__items {
    gap: 50px;
  }

  .recmd05 .sec01__head-text {
    font-size: 22px;
  }

  .recmd05 .sec01__img {
    margin-top: 25px;
  }

  .recmd05 .sec01__body {
    margin-top: 20px;
  }

  .recmd05 .sec01__body-lead {
    font-size: 20px;
  }

  .recmd05 .sec01__body-text {
    font-size: 16px;
  }

  .recmd07 {
    padding-bottom: 200px;
  }

  .recmd07__heading-img {
    width: 200px;
  }

  .recmd07__items {
    gap: 60px;
    width: 100%;
  }

  .recmd07__year {
    font-size: 30px;
  }

  .recmd07__year::before {
    height: 25px;
    left: -32px;
    width: 25px;
  }

  .recmd07__year::after {
    height: 18px;
    left: -28px;
    width: 18px;
  }

  .recmd07__body {
    gap: 35px;
  }

  .recmd07__month-block {
    gap: 30px;
  }

  .recmd07__month {
    font-size: 22px;
    padding-top: 10px;
  }

  .recmd07__card {
    border-radius: 12px;
    gap: 20px;
    padding: 30px 30px 20px;
  }

  .recmd07__card::after {
    border-bottom: 10px solid transparent;
    border-right: 18px solid #fff;
    border-top: 10px solid transparent;
    left: -17px;
    top: 15px;
  }

  .recmd07__text {
    font-size: 18px;
  }

  .recmd07__imgs {
    -moz-column-gap: 16px;
    column-gap: 16px;
  }

  .recmd07__img {
    margin-bottom: 16px;
  }

  .recmd08 {
    padding-top: 200px;
  }

  .recmd08__lead {
    gap: 10px;
  }

  .recmd08__img {
    width: 150px;
  }

  .recmd08__desc {
    font-size: 16px;
  }

  .recmd08 .sec01 {
    padding-bottom: 200px;
  }

  .recmd08 .sec01__items {
    align-items: end;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
    margin-top: 80px;
  }

  .recmd08 .sec01__name {
    font-size: 18px;
  }

  .recmd08 .sec01__date {
    font-size: 16px;
  }
}
