@charset "utf-8";

/*-------------------------
@import url(//fonts.googleapis.com/earlyaccess/notosanstc.css);
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@100;300;400;500;700;900&display=swap');
/*
* Noto Sans TC (Chinese_traditional) http://www.google.com/fonts/earlyaccess
 */


/* -----------------------------------

----------------------------------- */
body {
  &.yorisou {
    --supporter-color-black: #000;
    --supporter-color-white: #fff;
    --supporter-color-gray: #666;
    --supporter-color-blue: #009cde;
    --supporter-color-yellow: #ffe80c;
    --supporter-color-blue-02: #039cdd;
    --supporter-color-blue-thick: #0058a5;
    --supporter-bg-color-thin: #eff7fc;
    --supporter-bg-color-thin-02: #e1f3ff;
    --supporter-bg-color-thick: #009cde;
    --supporter-bg-color-thick-02: #5bbfe9;
    --supporter-bg-color-red: #ebcedf;
    --supporter-bg-color-purple: #c9c9f2;
    --supporter-bg-color-green: #c3e9d2;
    --supporter-bg-color-yellow: #ffffcb;
    --supporter-bg-color-orange: #eecca3;

    * {
       font-family: 'Noto Sans TC';

    }

    word-break: normal;
    overflow-wrap: anywhere;
    line-break: strict;
    font-family: "Noto Sans JP", Osaka-mono, monospace;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;

    #pageTop.to-top {
      z-index: 99;
    }
  }
}

body.is-fixed {
  overflow: hidden;
}

.category_supporter,
.category_supporter-wrap,
.supporter-article {
  overflow: hidden;
  padding: 0;
  width: 100%;
  background: #fff;
  font-family: "Noto Sans JP","Meiryo", "メイリオ", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", "ＭＳ Ｐゴシック", "ＭＳ ゴシック", "Osaka－等幅", Osaka-mono, monospace;
  font-weight: 400;
}

@media only screen and (max-width: 768px) {
  .category_supporter img,
  .category_supporter-wrap img,
  .supporter-article img {
    max-width: 100%;
  }
}

.category_supporter *,
.category_supporter-wrap *,
.supporter-article * {
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-weight: inherit;
  font-style: inherit;
}

.category_supporter p,
.category_supporter-wrap p,
.supporter-article p {
  color: #000;
}

.category_supporter small,
.category_supporter-wrap small,
.supporter-article small {
  color: #000;
}

.category_supporter sub,
.category_supporter sup,
.category_supporter-wrap sub,
.category_supporter-wrap sup,
.supporter-article sub,
.supporter-article sup {
  position: relative;
  vertical-align: baseline;
  font-size: 75%;
  line-height: 0;
}

.category_supporter sup,
.category_supporter-wrap sup,
.supporter-article sup {
  top: -0.5em;
}

.category_supporter .indent,
.category_supporter-wrap .indent,
.supporter-article .indent {
  padding-left: 1em;
  text-indent: -1em;
}

.category_supporter .view-all-link a,
.category_supporter .btn_back_list a,
.category_supporter-wrap .view-all-link a,
.category_supporter-wrap .btn_back_list a,
.supporter-article .view-all-link a,
.supporter-article .btn_back_list a {
  display: block;
  position: relative;
  margin: 10px auto 0;
  width: 320px;
  height: 50px;
  transition: all 0.2s ease-in;
  background: #0076c8;
  text-decoration: none;
  text-indent: 30px;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  line-height: 50px;
}

@media only screen and (max-width: 768px) {
  .category_supporter .view-all-link a,
  .category_supporter .btn_back_list a,
  .category_supporter-wrap .view-all-link a,
  .category_supporter-wrap .btn_back_list a,
  .supporter-article .view-all-link a,
  .supporter-article .btn_back_list a {
    margin: 25px auto 0;
  }
}

.category_supporter .view-all-link a:before,
.category_supporter .btn_back_list a:before,
.category_supporter-wrap .view-all-link a:before,
.category_supporter-wrap .btn_back_list a:before,
.supporter-article .view-all-link a:before,
.supporter-article .btn_back_list a:before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  margin: -4px 0 0;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  width: 7px;
  height: 7px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

.category_supporter .view-all-link a:hover,
.category_supporter .btn_back_list a:hover,
.category_supporter-wrap .view-all-link a:hover,
.category_supporter-wrap .btn_back_list a:hover,
.supporter-article .view-all-link a:hover,
.supporter-article .btn_back_list a:hover {
  transition: all 0.1s ease-in;
  background: #4d93c4;
  text-decoration: none;
}

.category_supporter .icon_zoom,
.category_supporter-wrap .icon_zoom,
.supporter-article .icon_zoom {
  display: block;
  position: relative;
  transition: all 0.3s ease;
}

.category_supporter .icon_zoom::after,
.category_supporter-wrap .icon_zoom::after,
.supporter-article .icon_zoom::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 32px;
  height: 32px;
  background: url(../img/supporter/icon_zoom.jpg) no-repeat 0 0/contain;
}

.category_supporter .icon_zoom:hover,
.category_supporter-wrap .icon_zoom:hover,
.supporter-article .icon_zoom:hover {
  opacity: 0.8;
}

.category_supporter .bx-wrapper,
.category_supporter-wrap .bx-wrapper,
.supporter-article .bx-wrapper {
  overflow: hidden;
  padding: 24px 0 0;
}

.category_supporter .bx-wrapper .bx-viewport,
.category_supporter-wrap .bx-wrapper .bx-viewport,
.supporter-article .bx-wrapper .bx-viewport {
  overflow: visible !important;
  padding: 0 0 0 12px;
  width: 61.33333vw !important;
}

.category_supporter .bx-wrapper .bx-pager.bx-default-pager a,
.category_supporter-wrap .bx-wrapper .bx-pager.bx-default-pager a,
.supporter-article .bx-wrapper .bx-pager.bx-default-pager a {
  border-radius: 0;
  width: 30px;
  height: 3px;
  background: #ccc;
}

.category_supporter .bx-wrapper .bx-pager.bx-default-pager a.active,
.category_supporter-wrap .bx-wrapper .bx-pager.bx-default-pager a.active,
.supporter-article .bx-wrapper .bx-pager.bx-default-pager a.active {
  background: #0164aa;
}

/* 共通 */
.supporter-article-visual {
  padding: 20px 0;
  background: #f7f7f7;
}
@media only screen and (max-width: 768px) {
  .supporter-article-visual {
    padding: 0;
  }
}

.category_supporter {
  background: url(../img/supporter/bg_dot.png) repeat right bottom/1.23vw auto;
}
@media only screen and (max-width: 768px) {
  .category_supporter {
    background: url(../img/supporter/bg_dot.png) repeat right bottom/4vw auto;
  }
}

@media only screen and (max-width: 1000px) {
  .hp_inner_pd {
    padding-right: 20px;
    padding-left: 20px;
  }
}

.hp_font_palt_left {
  margin-left: -0.5em;
  color: currentColor;
  font-size: inherit;
  font-weight: inherit;
}
.hp_font_palt_left_sm {
  color: currentColor;
  font-size: inherit;
  font-weight: inherit;
}
@media only screen and (max-width: 768px) {
  .hp_font_palt_left_sm {
    margin-left: -0.5em;
    color: currentColor;
    font-size: inherit;
    font-weight: inherit;
  }
}
.hp_font_palt_right {
  margin-right: -0.5em;
  color: currentColor;
  font-size: inherit;
  font-weight: inherit;
}
.hp_font_palt_right_sm {
  color: currentColor;
  font-size: inherit;
  font-weight: inherit;
}
@media only screen and (max-width: 768px) {
  .hp_font_palt_right_sm {
    margin-right: -0.5em;
    color: currentColor;
    font-size: inherit;
    font-weight: inherit;
  }
}

/* --------------------------------
  keyframes
-------------------------------- */
@keyframes spinIcon {
  0% {
    scale: 1;
    rotate: 0;
  }

  55% {
    scale: 1.05;
  }

  100% {
    scale: 1;
    rotate: 1turn;
  }
}

@keyframes openModal {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}
@keyframes closeModal {
  0% {
    opacity: 1;
  }

  100% {
    opacity: 0;
  }
}

@keyframes openModalBounce {
  0% {
    opacity: 0;
    scale: 0.96;
  }

  100% {
    opacity: 1;
    scale: 1;
  }
}
@keyframes closeModalBounce {
  0% {
    opacity: 1;
    scale: 1;
  }

  99% {
    opacity: 0;
    scale: 1;
  }

  100% {
    opacity: 0;
    scale: 0.96;
  }
}

/* --------------------------------
  アコーディオン
-------------------------------- */
.supporter-accordion-wrapper {
  margin: 48px auto 0;
  width: 1000px;
}

@media only screen and (max-width: 1000px) {
  .supporter-accordion-wrapper {
    width: auto;
  }
}

@media only screen and (max-width: 768px) {
  .supporter-accordion-wrapper {
    margin: 12.8vw auto 0;
  }
}

.supporter-accordion {
  display: block;
  margin: 0 auto;
  border-style: none;
  border-radius: 50px;
  outline: none;
  width: 100%;
  background: #009cde;
}

@media only screen and (max-width: 768px) {
  .supporter-accordion {
    border-radius: 6.67vw;
  }
}

.supporter-accordion.is-open .supporter-accordion-btn {
  transition: all 0.1s ease-in;
}

.supporter-accordion.is-open .supporter-accordion-btn::after {
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
}

.supporter-accordion.is-open:hover {
  opacity: 1;
}

.supporter-accordion:hover {
  opacity: 0.6;
  transition: all 0.3s ease-in;
}

@media only screen and (max-width: 768px) {
  .supporter-accordion:hover {
    opacity: 1;
  }
}

.supporter-accordion-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  gap: 0 20px;
  border-radius: min(3.84vw, 50px);
  min-height: min(11.77vw, 153px);
  text-align: center;
  letter-spacing: 0.05em;
  color: #fff;
  font-size: 21px;
  line-height: 1.33;
  cursor: pointer;
  transition: all 0.3s ease-in;
}

@media only screen and (max-width: 768px) {
  .supporter-accordion-btn {
    flex-direction: column;
    gap: 2vw 0;
    border-radius: 6.67vw;
    min-height: 34.67vw;
    font-size: 4.8vw;
    line-height: 1.4;
  }
}

.supporter-accordion-btn::before,
.supporter-accordion-btn::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 50%;
  right: 50px;
  width: 30px;
  height: 4px;
  -webkit-transform: translateY(-50%);
          transform: translateY(-50%);
  background-color: #fff;
}

@media only screen and (max-width: 768px) {
  .supporter-accordion-btn::before,
  .supporter-accordion-btn::after {
    right: 5.33vw;
    top: 26vw;
    width: 4vw;
    height: 0.53vw;
  }
}

.supporter-accordion-btn::after {
  transition: -webkit-transform 0.3s linear;
  transition: transform 0.3s linear;
  transition: transform 0.3s linear, -webkit-transform 0.3s linear;
  -webkit-transform: translateY(-50%) rotate(90deg);
          transform: translateY(-50%) rotate(90deg);
}

.supporter-accordion-content {
  display: none;
  padding: 0 50px 53px;
}

@media only screen and (max-width: 768px) {
  .supporter-accordion-content {
    padding: 0 5.33vw 5.33vw;
  }
}

.supporter-accordion-img {
  max-width: 100%;
  height: auto;
}

@media only screen and (max-width: 1000px) {
  .hp_inner_pd {
    padding-right: 20px;
    padding-left: 20px;
  }
}

/* --------------------------------
  サポーターTopページ
-------------------------------- */
/* 共通 */
.un_content_inner {
  margin: 0 auto;
  padding: 0 40px;
  max-width: 1080px;
}
@media only screen and (max-width: 768px) {
  .un_content_inner {
    padding: 0 5.87vw;
  }
}

.un_supporter-top-heading {
  display: inline-grid;
  place-content: center;
  margin: 0 auto;
  border-radius: 9999px;
  background-color: #fff;
  max-width: 760px;
  width: 100%;
  min-height: 44px;
}
@media only screen and (max-width: 768px) {
  .un_supporter-top-heading {
    min-width: 100%;
    padding: 5.33vw 0;
  }
}

.un_supporter-top-headingTag_wrapper {
  text-align: center;
}

.un_supporter-top-headingTag {
  display: inline-grid;
  place-content: center;
  margin: 0 auto;
  border-radius: 9999px;
  min-width: min(23vw, 230px);
  min-height: min(4.4vw, 44px);
  background-color: var(--supporter-color-white);
  color: #543f03;
  font-size: min(2.2vw, 22px);
  font-weight: 700;
  letter-spacing: -0.05em;
}
@media only screen and (max-width: 768px) {
  .un_supporter-top-headingTag {
    min-width: 47.2vw;
    min-height: 9.07vw;
    font-size: 4.53vw;
  }
}

.un_supporter-top-heading.--bg-blue {
  background-color: #009cde;
}

.un_supporter-top-heading02 {
  margin: 0 auto;
  text-align: center;
  font-size: min(3.4vw, 34px);
  font-weight: 700;
  color: #543f03;
  line-height: 1.4;

  > .bg-line {
    padding-bottom: 0.13em;
    background-image: linear-gradient(to right, var(--supporter-color-yellow), var(--supporter-color-yellow));
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% 5px;
    color: currentColor;
    font-size: min(3.4vw, 34px);
    font-weight: 700;
    line-height: 1.4;
  }

  &.--color-white {
    color: var(--supporter-color-white);
  }
}
@media only screen and (max-width: 768px) {
  .un_supporter-top-heading02 {
    font-size: 4.53vw;

    > .bg-line {
      background-size: 100% 0.67vw;
      font-size: 4.53vw;
    }
  }
}

.un_supporter-top-text {
  text-align: center;
  font-size: 20px;
  line-height: 1.8;
  letter-spacing: -0.05em;
  font-weight: 400;
}
@media only screen and (max-width: 768px) {
  .un_supporter-top-text {
    font-size: 4vw;
  }
}

.un_supporter-top-inner {
  margin: 0 auto;
  max-width: 1000px;
}
@media only screen and (max-width: 768px) {
  .un_supporter-top-inner {
    margin: 0;
    padding: 0 5.87vw;
    max-width: auto;
  }
}

/* モーダル */

/** 
* magnific-popup 上書き
*/
.un_modal {
  display: none;
  position: fixed;
  z-index: 100000000;
  top: 0;
  left: 0;
  width: 100%;
  height: 100dvh;

  &.--interview {
    .un_modal_container {
      padding: 20px;
    }
  }
  &.--service {
    .un_modal_container {
      padding: min(7.3vw, 73px) min(6.8vw, 68px) min(4vw, 40px);
    }
  }

  &.is-open {
    display: block;
  }

  &[aria-hidden="false"] {
    animation: openModal 0.4s ease-out both;

    .un_modal_overlay {
      opacity: 1;
      /* transition: opacity 0.1s linear; */
    }
  }

  &[aria-hidden="true"] {
    animation: closeModal 0.3s ease-out both;

    .un_modal_overlay {
      opacity: 0;
      /* transition: opacity 0.1s linear 0.2s; */
    }
  }

  &[id^=modal-interview-] {
    &[aria-hidden="false"] {
      .un_modal_container {
        animation: openModalBounce 0.5s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
      }
    }
    &[aria-hidden="true"] {
      .un_modal_container {
        animation: closeModalBounce 0.3s cubic-bezier(0.47, 0, 0.745, 0.715) both;
      }
    }
  }
}
@media only screen and (max-width: 768px) {
  .un_modal {
    &.--interview {
      .un_modal_container {
         padding: 20px;
      }
    }
    &.--service {
      .un_modal_container {
        padding: 11.2vw 6vw 8.8vw;
      }
    }
  }
}

.un_modal_overlay {
  overflow: hidden auto;
  position: relative;
  padding: 70px 40px;
  width: 100%;
  min-height: 100%;
  max-height: 100%;
  background-color: rgba(252,250,238,1);;
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  .un_modal_overlay {
    padding: 16vw 5.33vw;
  }
}

.un_modal_container {
  position: relative;
  border: solid 4px #5b4a10;
  border-radius: 6px;
  margin: 0 auto;
  max-width: 1000px;
  background-color: #FFF;
  pointer-events: auto;
}
@media only screen and (max-width: 768px) {
  .un_modal_container {
    border: solid 0.53vw #5b4a10;
    border-radius: 0.8vw;
  }
}

.un_modal_logo {
  img {
    display: block;
    width: 100%;
  }
}
.un_modal.--interview .un_modal_logo {
  position: absolute;
  top: min(3.3vw, 33px);
  right: min(3.5vw, 35px);
  width: min(22.8vw, 228px);
}
@media only screen and (max-width: 768px) {
  .un_modal.--interview .un_modal_logo {
    top: 5.86vw;
    right: 5.6vw;
    width: 15.47vw;
  }
}
.un_modal.--service .un_modal_logo {
  position: static;
  margin: 0 auto min(3vw, 30px);
  width: min(8vw, 80px);
}
@media only screen and (max-width: 768px) {
  .un_modal.--service .un_modal_logo {
    margin: 0 auto 5.33vw;
    width: 15.47vw;
  }
}

.un_modal_closeBtn {
  display: inline-grid;
  position: absolute;
  top: 0;
  right: 0;
  translate: 50% -50%;
  border: none;
  border-radius: 50%;
  aspect-ratio: 1 / 1;
  padding: 0;
  width: min(5.5vw, 55px);
  background-color: #5b4a10;
  color: var(--supporter-color-white);
  cursor: pointer;
  transition: opacity 0.2s ease-out;

  > span {
    grid-area: 1 / -1;
    display: block;
    border-radius: 9999px;
    margin: auto;
    width: min(2.8vw, 28px);
    height: min(0.2vw, 2px);
    background-color: #FFF;

    &:first-of-type {
      rotate: 45deg;
    }
    &:last-of-type {
      rotate: -45deg;
    }
  }

  &:hover {
    > span {
      opacity: 0.7;
      transition: opacity 0.3s ease-out;
    }
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_closeBtn {
    width: 9.33vw;

    > span {
      width: 5.6vw;
      height: 0.53vw;
    }
  }
}

/* .un_modal_header {
  margin-bottom: min(5vw, 50px);
}
@media only screen and (max-width: 768px) {
  .un_modal_header {
    margin-bottom: 9.33vw;
  }
} */

.un_modal_heading {
  display: inline-flex;
  flex-direction: column-reverse;
  gap: min(0.8vw, 8px) 0;
}
@media only screen and (max-width: 768px) {
  .un_modal_heading {
    gap: 4vw 0;

    &.--pre-sm .un_modal_heading--main {
      white-space: pre;
    }
  }
}

.un_modal_heading--main {
  color: #543f03;
  font-size: min(3.7vw, 37px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: -0.03em;
  
  > .bg-line {
 
  }

  .--text-small {
    color: currentColor;
    font-size: min(3.7vw, 37px);
    font-weight: inherit;
    line-height: 1.4;
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_heading--main {
    font-size: 6.67vw;
    line-height: 1.4;

    > .bg-line {
      font-size: 5.67vw;
      line-height: 1.4;
    }

    &.--small {
      font-size: 6vw;
  
      > .bg-line {
        font-size: 5vw;
      }
    }

    .--text-small {
      color: currentColor;
      font-size: 5.6vw;
      font-weight: inherit;
      line-height: 1.4;
    }
  }
}

.un_modal_heading--sub {
  margin: 0;
  color: #da7816;
  font-size: min(2.4vw, 24px);
  font-weight: 700;
  line-height: 1.25;
}
@media only screen and (max-width: 768px) {
  .un_modal_heading--sub {
    font-size: 4.53vw;
    line-height: 1.29;
  }
}

.un_modal_lead {
  margin-top: min(2vw, 20px);
}
@media only screen and (max-width: 768px) {
  .un_modal_lead {
    margin-top: 3.2vw;
  }
}

.un_modal_leadText {
  margin: 0;
  font-size: min(1.5vw, 15px);
  font-weight: 400;
  line-height: 2;
}
@media only screen and (max-width: 768px) {
  .un_modal_leadText {
    font-size: 4vw;
  }
}

.un_modal_leadBtn_wrapper {
  text-align: center;
}

.un_modal_leadBtn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  margin: min(1.8vw, 18px) auto 0;
  padding: 0 min(1.1vw, 11px) 0 0;
  border-radius: 4px;
  min-width: clamp(220px, 24vw, 312px);
  min-height: 56px;
  background-color: var(--supporter-color-yellow);
  text-decoration: none;
  color: #0063a9;
  font-size: min(1.8vw, 18px);
  font-weight: 500;
  transition: opacity 0.2s ease-out;

  &::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: min(2vw, 25px);
    border-right: 1px solid currentColor;
    border-bottom: 1px solid currentColor;
    width: 7px;
    height: 7px;
    -webkit-transform: rotate(-45deg) translateY(-50%);
            transform: rotate(-45deg) translateY(-50%);
  }

  &:hover {
    opacity: 0.7;
    transition: opacity 0.3s ease-out;
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_leadBtn {
    margin-top: 7.6vw;
    padding: 0 4.8vw;
    border-radius: 1.07vw;
    min-width: 71.73vw;
    min-height: 11.73vw;
    font-size: 4.27vw;

    &::before {
      right: 4.27vw;
    }
  }
}

/* モーダルコンテンツ */

.un_modal_content_anchorList {
  display: flex;
  gap: 0 min(1.4vw, 14px);
  margin-bottom: min(4vw, 40px);

  &:is(.un_modal_header + *) {
    margin-top: min(3.4vw, 34px);
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_anchorList {
    gap: 0 1.87vw;
    margin-bottom: 8vw;

    &:is(.un_modal_header + *) {
      margin-top: 5.07vw;
    }
  }
}

.un_modal_content_anchor {
  width: 100%;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: min(0.4vw, 4px) min(1.8vw, 18px) min(0.4vw, 4px) min(1.1vw, 11px);
  border-radius: min(0.4vw, 4px);
  min-height: 53px;
  background-color: #543f03;
  text-decoration: none;
  color: var(--supporter-color-white);
  font-size: min(1.8vw, 18px);
  font-weight: 700;
  letter-spacing: -0.03em;

  &::before {
    content: "";
    display: block;
    position: absolute;
    top: 40%;
    right: min(2vw, 20px);
    border-right: 1px solid currentColor;
    border-top: 1px solid currentColor;
    width: 7px;
    height: 7px;
    rotate: 135deg;
    translate: -50% 0;
  }

  .--palt {
    display: inline;
    color: currentColor;
    font-size: min(1.8vw, 18px);
    font-weight: 700;
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_anchor {
    display: inline-grid;
    place-content: center;
    padding: 0.7vw 2.1vw 0.9vw 1.07vw;
    border-radius: 1.07vw;
    min-height: 11.2vw;
    font-size: 3.2vw;
    text-align: center;
    line-height: 1.33;

    &::before {
      top: 44%;
      right: 0.6vw;
      width: 1.5vw;
      height: 1.5vw;
    }

    .--palt {
      color: currentColor;
      font-size: 3.2vw;
      font-weight: 700;
      letter-spacing: -0.11em;
    }
  }
}

.un_modal_content {
  border-radius: 4px;
  padding: min(4.5vw, 45px) min(4.8vw, 48px) min(5vw, 50px);
  background-color: #fcfaef;

  & + & {
    margin-top: min(3vw, 30px);
  }

  &:is(.un_modal_header + *) {
    margin-top: min(5vw, 50px);
  }

  &:is(.un_modal_lead + *) {
    margin-top: min(5vw, 50px);
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content {
    border-radius: 1.07vw;
    padding: 8vw 5.33vw;

    & + & {
      margin-top: 5.33vw;
    }

    &:is(.un_modal_header + *) {
      margin-top: 9.33vw;
    }

    &:is(.un_modal_lead + *) {
      margin-top: 9.33vw;
    }
  }
}

.un_modal_content_heading {
  display: grid;
  position: relative;
  border-radius: 9999px;
  padding: min(1vw, 10px) min(1.1vw, 11px);
  background-color: #5b4a10;
}
@media only screen and (max-width: 768px) {
  .un_modal_content_heading {
    align-items: center;
    padding: 2.4vw 3vw;
    min-height: 17.07vw;
  }
}
.un_modal_content_headingTag {
  grid-area: 1 / -1;
  margin: auto auto auto 0;
  border-radius: 9999px;
  padding: min(0.2vw, 2px) min(1.3vw, 13px) min(0.4vw, 4px);
  color: #5b4a10;
  font-size: min(1.8vw, 18px);
  font-weight: 700;
  letter-spacing: -0.03em;
  background-color: var(--supporter-color-white);
}
@media only screen and (max-width: 768px) {
  .un_modal_content_headingTag {
    display: grid;
    place-content: center;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    padding: 1.73vw;
    font-size: 4.13vw;
  }
}
.un_modal_content_headingText {
  grid-area: 1 / -1;
  margin: 0 auto;
  color: var(--supporter-color-white);
  font-size: min(2.4vw, 24px);
  font-weight: 700;
  letter-spacing: -0.03em;
}
@media only screen and (max-width: 768px) {
  .un_modal_content_headingText {
    margin: 0 0 0 13vw;
    color: var(--supporter-color-white);
    font-size: 5.33vw;

    &.--small {
      color: var(--supporter-color-white);
      font-size: 4.6vw;
      font-weight: 700;
    }

    &.interview-1,
    &.interview-4,
    &.interview-6,
    &.interview-8,
    &.interview-11,
    &.service-1,
    &.service-2 {
      margin: 0 0 0 16.5vw;
    }
    &.interview-2,
    &.service-11 {
      margin: 0 -6vw 0 12vw;
    }
    &.service-12-content-01 {
      margin: 0 0 0 16.5vw;
    }
    &.service-12-content-02 {
      margin: 0 -4vw 0 12vw;
    }
  }
}

.un_modal_content_text {
  margin: 0;
  font-size: min(1.5vw, 15px);
  font-weight: 400;
  line-height: 2;

  &:is(.un_modal_content_heading + *) {
    margin-top: min(1.2vw, 12px);
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_text {
    line-height: 1.5;
    font-size: 4vw;

    &:is(.un_modal_content_heading + *) {
      margin-top: 4vw;
    }
  }
}

.un_modal_content_featuresList {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(min(35.4vw, 354px), 1fr));
  gap: 0 min(0.8vw, 8px);

  &.--2col {
    grid-template-columns: repeat(2, 1fr);
    gap: 0 min(4.8vw, 48px);
  }

  &.--3col {
    grid-template-columns: repeat(3, 1fr);
    gap: 0 min(0.8vw, 8px);
  }

  &:is(.un_modal_content_header + *) {
    margin-top: min(2.7vw, 27px);
  }

  & + & {
    margin-top: min(3vw, 30px);
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_featuresList {
    justify-content: center;
    grid-template-columns: 1fr;
    gap: 5.33vw;

    &.--2col {
      grid-template-columns: 1fr;
      gap: 5.33vw;
    }

    &.--3col {
      grid-template-columns: 1fr;
      gap: 5.33vw;
    }

    &:is(.un_modal_content_header + *) {
      margin-top: 6.67vw;
    }

    & + & {
      margin-top: 8vw;
    }
  }
}

.un_modal_content_featuresItem_title {
  display: flex;
  justify-content: center;
  border-radius: 9999px;
  margin: 0;
  padding: min(0.5vw, 5px) min(1.4vw, 14px) min(0.55vw, 5.5px);
  width: 100%;
  background-color: var(--supporter-color-white);
  color: #543f03;
  font-size: min(1.8vw, 18px);
  font-weight: 700;
  line-height: 1.33;
  letter-spacing: -0.05em;
}
@media only screen and (max-width: 768px) {
  .un_modal_content_featuresItem_title {
    padding: 1.1vw 4vw 1.33vw;
    font-size: 4vw;
  }
}

.un_modal_content_featuresItem_inner {
  margin-top: min(1.6vw, 16px);
}
@media only screen and (max-width: 768px) {
  .un_modal_content_featuresItem_inner {
    margin-top: 4.3vw;
  }
}

.un_modal_content_featuresItem_copy {
  text-align: center;
  margin: 0;
  color: #543f03;
  font-size: min(2vw, 20px);
  font-weight: 700;
  letter-spacing: -0.03em;

  > .bg-line {
    padding-bottom: 0.18em;
    color: #543f03;
    font-size: min(2vw, 20px);
    font-weight: 700;
    letter-spacing: -0.03em;
    background-image: linear-gradient(to right, var(--supporter-color-yellow), var(--supporter-color-yellow));
    background-repeat: no-repeat;
    background-position: left bottom;
    background-size: 100% 3px;
  }

  > .--text-small {
    color: currentColor;
    font-size: min(1.6vw, 16px);
    font-weight: 500;
    letter-spacing: -0.03em;
  }

  &.--pre {
    white-space: pre;
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_featuresItem_copy {
    font-size: 4.8vw;

    > .bg-line {
      font-size: 4.8vw;
      font-weight: 700;
      background-size: 100% 0.67vw;
    }

    > .--text-small {
      font-size: 3.2vw;
    }
  }
}

.un_modal_content_featuresItem_checkItem {
  display: flex;
  gap: 0 min(1.6vw, 16px);
  font-size: min(1.6vw, 16px);
  font-weight: 400;
  line-height: 1.6;

  &::before {
    content: "";
    flex-shrink: 0;
    align-self: flex-start;
    display: block;
    position: relative;
    top: 0.25em;
    width: min(2.2vw, 22px);
    height: min(1.6vw, 16px);
    background: url(../img/supporter/icon_check.svg) no-repeat center / 100% auto;
  }

  & + & {
    margin-top: min(1.3vw, 13px);
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_featuresItem_checkItem {
    font-size: 4vw;
    line-height: 1.4;

    &::before {
      flex-shrink: 0;
      top: 1.2vw;
      width: 4.27vw;
      height: 3.07vw;
    }

    & + & {
      margin-top: 3.2vw;
    }
  }
}

.un_modal_content_featuresItem_caption {
  margin: min(1.3vw, 13px) 0 0 0;
  color: var(--supporter-color-gray);
  font-size: min(1.2vw, 12px);
  font-weight: 400;
  line-height: 1.5;

  &.--indent {
    text-indent: -1.25em;
    padding-left: 1.25em;
  }

  &.--text-right {
    text-align: right;
  }

  & + & {
    margin-top: min(0.5vw, 5px);
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_featuresItem_caption {
    margin: 3.2vw 0 0 0;
    font-size: 2.67vw;

    & + & {
      margin-top: 1.07vw;
    }
  }
}

.un_modal_content_bottom {
  border-top: solid 1px #543f03;
  margin: min(4vw, 40px) 0 0;
  padding: min(2.7vw, 27px) 0 0;
}
@media only screen and (max-width: 768px) {
  .un_modal_content_bottom {
    margin: 10vw 0 0;
    padding: 5.33vw 0 0;
  }
}

.un_modal_content_bottom_text {
  text-align: center;
  margin: 0;
  font-weight: 400;

  > .--text-accent {
    color: #543f03;
    font-size: inherit;
    font-weight: inherit;
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_content_bottom_text {
    font-size: 4vw;
    line-height: 1.33;

    > .--text-accent {
      color: #543f03;
      font-size: inherit;
      font-weight: inherit;
    }
  }
}

/* モーダル閉じるボタン */

.un_modal_btn--close_wrapper {
  text-align: center;
}

.un_modal_btn--close {
  border: 0;
  border-radius: 9999px;
  margin-top: min(4vw, 40px);
  padding: 0 0 min(0.3vw, 3px) 0;
  min-width: min(13.2vw, 132px);
  min-height: 45px;
  background-color: #543f03;
  color: #FFF;
  font-size: min(1.8vw, 18px);
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s ease-out;
  backface-visibility: hidden;

  &:hover {
    opacity: 0.7;
    transition: opacity 0.3s ease-out;
  }
}
@media only screen and (max-width: 768px) {
  .un_modal_btn--close {
    margin-top: 6.67vw;
    padding: 0 0 0.8vw 0;
    min-width: 25.07vw;
    min-height: 8.8vw;
    font-size: 3.73vw;
    letter-spacing: -0.05em;
  }
}

/* モーダル特殊スタイル */
.un_modal {
  .supporter-top-leadContents {
    margin-bottom: min(6.4vw, 64px);
  }
  .supporter-top-lead-btn-wrapper {
    text-align: center;
  }
  @media only screen and (max-width: 768px) {
    .supporter-top-leadContents {
      margin-top: 4vw;
    }
  }
  .supporter-top-lead-btn {
    margin: min(2.4vw, 24px) auto 0;
    width: min(61.5vw, 800px);
    font-size: min(1.5vw, 20px);
  }
  @media only screen and (max-width: 768px) {
    .supporter-top-lead-btn {
      margin: 5.33vw auto 0;
      width: 100%;
      font-size: 3.73vw;
    }
  }
  .supporter-feature-name-wrapper {
    display: grid;
    place-content: center;
  }
  .supporter-feature-name_lg {
    position: relative;
    margin: 0 auto;
    padding: 0;
    width: min(60.3vw, 784px);
  }
  .supporter-feature-name_sm {
    position: relative;
    margin: 0 auto;
    padding: 0;
    width: 65.33vw;
  }
  .supporter-feature-list {
    gap: 0 min(2.2vw, 22px);
    margin-top: min(4vw, 40px);
  }
  @media only screen and (max-width: 768px) {
    .supporter-feature-list {
      gap: 0 8vw;
      margin-top: 6.93vw;
    }
  }
  .supporter-feature-item {
    flex: 1;
    margin: 0 !important;
    padding: min(1.6vw, 16px) min(0.8vw, 8px) min(1vw, 10px);
    width: auto;
    max-width: min(18.69vw, 243px);
    min-height: min(18vw, 234px);
  
    &::before {
      content: "";
      display: inline-block;
      position: absolute;
      top: 0;
      left: 50%;
      width: min(4vw, 40px);
      height: min(4vw, 40px);
      transform: translate(-50%, -50%);
    }
  
    > p {
      margin: 0;
    }
  
    &.item01 {
      padding: min(1.6vw, 16px) min(0.8vw, 8px) min(1vw, 10px);
      .supporter-feature-item-name {
        width: 100%;
      }
    }
    &.item02 {
      padding: min(1.6vw, 16px) min(2vw, 20px) min(1vw, 10px);
      .supporter-feature-item-name {
        width: 100%;
      }
    }
    &.item03 {
      padding: min(1.6vw, 16px) min(5vw, 50px) min(1vw, 10px);
      .supporter-feature-item-name {
        width: 100%;
      }
    }
  }
  @media only screen and (max-width: 768px) {
    .supporter-feature-item {
      max-width: none;
    }
    .supporter-top-noteList{
      margin-top: 5.33vw;
    }
    .supporter-feature-item-name {
      padding: 8vw 2vw 5.33vw;
    }
  }
}

@media only screen and (max-width: 768px) {
  .supporter-top-leadContents {
    margin-bottom: 8vw;
  }

  .un_modal_content {

    .supporter-feature-item {
      margin: auto !important;
      padding: 8vw 2vw 5.33vw;

      &::before {
        width: 9.33vw;
        height: 9.33vw;
      }

      &.item01 {
        padding: 8vw 2vw 5.33vw;
        .supporter-feature-item-name {
          padding: 0;
          width: 44.67vw;
        }
      }
      &.item02 {
        padding: 8vw 2vw 5.33vw;
        .supporter-feature-item-name {
          padding: 0;
          width: 47.46vw;
        }
      }
      &.item03 {
        padding: 8vw 2vw 5.33vw;
        .supporter-feature-item-name {
          padding: 0;
          width: 47.6vw;
        }
      }

      & + .supporter-feature-item {
        margin-top: 8vw !important;
      }
    }
  }
}

/* ボタン */

.supporter-top-btn {
  display: inline-flex;
  position: relative;
  padding: 0 11px 0 0;
  border-radius: 4px;
  background: #0065ab;
  text-decoration: none;
  color: #fff;
  font-size: 20px;
  text-align: center;

  justify-content: center;
  align-items: center;
  min-width: auto;
  width: 100%;
  min-height: 75px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-btn {
    justify-content: center;
    padding: 0 4.8vw;
    border-radius: 1.07vw;
    min-height: 20vw;
    font-size: 3.73vw;
  }
}
.supporter-top-btn::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  width: 7px;
  height: 7px;
  -webkit-transform: rotate(-45deg) translateY(-50%);
          transform: rotate(-45deg) translateY(-50%);
}
@media only screen and (max-width: 768px) {
  .supporter-top-btn::before {
    right: 4.27vw;
  }
}

.un_note {
  > p {
    gap: 0 min(0.8vw, 8px);
    margin: 0;
    padding-left: 1em;
    text-indent: -1em;
    color: var(--supporter-color-gray);
    font-size: min(1.2vw, 12px);
    font-weight: 400;
    line-height: 1.5;

    &::before {
      content: "";
      display: inline-block;
      position: relative;
      aspect-ratio: 1 / 1;
      border-radius: 50%;
      top: -0.15em;
      margin-right: 0.35em;
      width: 0.5em;
      background-color: currentColor;
      line-height: 1;
    }

    a {
      font-size: min(1.2vw, 12px);
      color: var(--supporter-color-blue-02);
      text-decoration: underline;
    }

    & + p {
      margin-top: 0.3em;
    }
  }
}
@media only screen and (max-width: 768px) {
  .un_note {
    > p {
      gap: 2vw;
      font-size: 2.67vw;

      a {
        font-size: 2.67vw;
        color: var(--supporter-color-blue-02);
        text-decoration: underline;
      }
    }
  }
}

.un_sup {
  position: relative;
  top: -0.5em;
  font-size: 0.6em;
}

/* --------------------------------
  コンテンツ
-------------------------------- */
/* KV */

.supporter-top-kv-inner {
  position: relative;
  aspect-ratio: 1300 / 626;
  width: 100%;
  background-color: var(--supporter-bg-color-thick-02);
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  .supporter-top-kv-inner {
    aspect-ratio: 750 / 1227;
  }
}

.supporter-top-kv-textBlock {
  display: block;
  position: absolute;
  top: 6.15vw;
  left: calc(50% - 0.8vw);
  translate: -50% 0;
  text-align: center;
  width: max-content;
  color: var(--supporter-color-white);
  z-index: 3;
}
@media only screen and (max-width: 768px) {
  .supporter-top-kv-textBlock {
    top: 11vw;
    text-align: left;
    padding: 0 6vw;
    width: 100%;
  }
}

.supporter-top-kv-heading {
  margin: 0 auto;
  width: 52vw;
  color: var(--supporter-color-white);
  font-size: 2.92vw;
  line-height: 1.5;
  opacity: 0;

  img {
    display: block;
    width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-kv-heading {
    margin: 0;
    width: 72.66vw;
    font-size: 8.26vw;
  }
}

.supporter-top-kv-lead {
  margin: 3.54vw auto 0;
  opacity: 0;

  > p {
    color: var(--supporter-color-white);
    font-size: 1.23vw;
    line-height: 1.5;
  }

  & + & {
    margin-top: 2.3vw;
  }

  img {
    display: block;
    width: 100%;
  }

  &.lead01 {
    width: 22.15vw;
  }
  &.lead02 {
    width: 25.38vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-kv-lead {
    margin: 8.93vw auto 0 0;

    > p {
      font-size: 3.73vw;
    }

    & + & {
      margin-top: 5.33vw;
    }

    &.lead01 {
      width: 67.33vw;
    }

    &.lead02 {
      width: 76.8vw;
    }
  }
}

.supporter-top-kv-img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 2;

  img {
    display: block;
    width: 100%;
  }

  &.--bubbles {
    opacity: 0;
    transform: translateY(0.9rem) translateZ(0) scale(0.97);
    transform-origin: bottom center;
    z-index: 1;
  }
}

.supporter-top-about {
  padding: 94px 0 67px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-about {
    padding: 19vw 0 11.07vw;
  }
}

.supporter-top-about-text {
  margin-top: 27px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-about-text {
    margin-top: 6vw;
  }
}

/* サポーターインタビュー */

.supporter-top-interviews {
  padding: min(2.6vw, 46px) 0 min(5.4vw, 54px);
  background-color: #f5f406;
  background-image: url(../img/supporter/bg_road_lg.svg);
  background-repeat: no-repeat;
  background-position: left calc(50% + min(0.7vw, 7px)) top max(-2.7vw, -27px);
  background-size: min(192vw, 1920px) auto;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviews {
    padding: 11vw 0 29.4vw;
    background-image: url(../img/supporter/bg_road_sm.svg);
    background-repeat: no-repeat;
    background-position: left -15vw top 27vw;
    background-size: 138.27vw auto;
  }
}

.supporter-top-interviews-lead {
  text-align: center;
  margin-top: min(1.7vw, 17px);
  font-size: min(2.2vw, 22px);
  font-weight: 500;
  line-height: 1.47;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviews-lead {
    text-align: center;
    margin-top: 2.4vw;
    font-size: 4vw;
    line-height: 1.54;
  }
}

.supporter-top-interviews-inner {
  margin: 0 auto;
  max-width: 1000px;
}

.supporter-top-interviews-list {
  margin-top: min(3.8vw, 38px);
}
@media screen and (max-width: 768px) {
  .supporter-top-interviews-list {
    margin-top: 5vw;
  }
}

.supporter-top-interviews-item {
  display: flex;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviews-item {
    flex-direction: column;
    gap: 0;
  }
}

.supporter-top-interviews-item-titleBlock {
  display: flex;
  flex-direction: column;
  z-index: 2;
  pointer-events: none;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviews-item-titleBlock {
    width: max-content;
  }
}

.supporter-top-interviews-title {
  display: inline-block;
  text-align: center;
  text-wrap: nowrap;
  font-size: 48px;
  font-weight: 700;
  color: #442d00;
  pointer-events: auto;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviews-title {
    font-size: 8vw;
  }
}

.supporter-top-interviews-img {
  display: inline-block;
  position: relative;
}
.supporter-top-interviews-img img {
  display: block;
  width: 100%;
}

.supporter-top-interviewCard-list {
  display: flex;
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-list {
    flex-direction: column;
    gap: 0;
  }
}

.supporter-top-interviewCard-item {
  display: grid;
  position: relative;
  opacity: 0;
  will-change: transform;
}

.supporter-top-interviewCard {
  display: inline-grid;
  text-decoration: none;

  &:hover {
    opacity: 1;

    .supporter-top-interviewCard-btn {
      background-color: #CCC;
      color: #543f03;
      transition: background-color 0.3s ease-out, color 0.3s ease-out;

      .supporter-top-interviewCard-btn-text {
        color: #5b4a10;
        transition: color 0.3s ease-out;
      }
    }
    .supporter-top-interviewCard-btn-iconPlus {
      animation: spinIcon 0.78s cubic-bezier(0.68, -0.18, 0.265, 1.28) both;

      > span {
        background-color: #000;
        transition: background-color 0.3s ease-out;
      }
    }
    .supporter-top-interviewCard-bg {
      scale: 1.02;
      transition: scale 0.3s ease-out 0.02s;
    }
  }
  &:active {
    .supporter-top-interviewCard-bg {
      scale: 1;
      transition: scale 0.1s ease-out;
    }
  }
}

.supporter-top-interviewCard-inner {
  grid-area: 1 / -1;
  display: grid;
  justify-content: center;
  align-content: center;
  z-index: 2;
}

.supporter-top-interviewCard-bg {
  grid-area: 1 / -1;
  z-index: 1;
  translate: 0 0 0;
  transition: scale 0.2s ease-out;

  img {
    display: block;
    width: 100%;
  }
}

.supporter-top-interviewCard-tag {
  display: inline-grid;
  place-content: center;
  justify-self: start;
  position: relative;
  border-radius: 9999px;
  padding: min(0.4vw, 4px) min(1.6vw, 16px);

  &.--treatment {
    background-color: #f0f0d6;
padding: 10px;
    img {
      width: min(9.6vw, 346px);
    }
  }
  &.--consultation {
    background-color: var(--supporter-bg-color-red);

    img {
      width: min(4.6vw, 46px);
    }
  }
  &.--life {
    background-color: var(--supporter-bg-color-orange);

    img {
      width: min(4.6vw, 46px);
    }
  }
  &.--heart {
    background-color: var(--supporter-bg-color-purple);

    img {
      width: min(6.5vw, 65px);
    }
  }
  &.--employment {
    background-color: var(--supporter-bg-color-yellow);

    img {
      width: min(11.9vw, 119px);
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-tag {
    padding: 1.07vw 3.73vw;

    &.--treatment {
      img {
        width: 10vw;
      }
    }
    &.--consultation {
      img {
        width: 10vw;
      }
    }
    &.--life {
      img {
        width: 10vw;
      }
    }
    &.--heart {
      img {
        width: 14vw;
      }
    }
    &.--employment {
      img {
        width: 24.4vw;
      }
    }
  }
}

.supporter-top-interviewCard-name {
  margin-top: min(1.3vw, 13px);
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-name {
    margin-top: 2.13vw;
  }
}

.supporter-top-interviewCard-btn {
  justify-self: center;
  display: inline-flex;
  justify-content: space-between;
  position: relative;
  border-radius: 4px;
  margin-top: min(1.6vw, 16px);
  padding: min(0.6vw, 6px) min(0.9vw, 9px) min(0.55vw, 5.5px) min(1.6vw, 16px);
  min-width: 130px;
  background-color: #442d00;
  font-size: 18px;
  font-weight: 700;
  line-height: 1.4;
  color: var(--supporter-color-white);
  text-decoration: none;
  transition: background-color 0.2s ease-out, color 0.2s ease-out;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-btn {
    border-radius: 0.53vw;
    margin-top: 3.33vw;
    padding: 1.3vw 1.86vw 1.5vw 3.6vw;
    min-width: 27.33vw;
    font-size: 3.2vw;
  }
}

.supporter-top-interviewCard-btn-text {
  position: relative;
  top: -1px;
  color: var(--supporter-color-white);
  translate: 0 0 0;
  backface-visibility: hidden;
  transition: color 0.2s ease-out;
font-size: 18px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-btn-text {
    top: -0.13vw;
  }
}

.supporter-top-interviewCard-btn-iconPlus {
  flex-shrink: 0;
  display: block;
  position: relative;
  translate: 0 0 0;
  aspect-ratio: 1 / 1;
top: -1px;
  width: min(1.2vw, 12px);
  right: 5px;


  > span {
    display: block;
    position: absolute;
    top: 50%;
    right: 0;
    border-radius: 9999px;
    width: 100%;
    height: 2px;
    background-color: var(--supporter-color-white);
    transition: background-color 0.2s ease-out;

    &:nth-of-type(2) {
      rotate: 90deg;
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-btn-iconPlus {
    top: 0.27vw;
    width: 2.8vw;

    > span {
      top: calc(50% - 0.3vw);
      height: 2px;
    }
  }
}

/* サポーターインタビュー個別 */

.supporter-top-interviews-item {
  &.interviews01 {
    justify-content: flex-end;
    gap: 0 min(2vw, 20px);
    
    .supporter-top-interviews-item-titleBlock {
      gap: min(2.4vw, 24px) 0;
    }
    .supporter-top-interviews-img {
      width: min(18.2vw, 182px);
    }
  }

  &.interviews02 {
    flex-direction: row-reverse;
    justify-content: flex-start;
    gap: 0;
    margin-top: min(9vw, 90px);

    .supporter-top-interviews-item-titleBlock {
      justify-content: flex-start;
      gap: min(3.4vw, 34px) 0;
    }
    .supporter-top-interviews-img {
      left: min(-1vw, -10px);
      width: min(27.2vw, 272px);
    }
    .supporter-top-interviewCard-list {
      display: grid;
      grid-template-columns: auto auto;
      margin: 0 max(-6.3vw, -63px) 0 0;
    }
  }

  &.interviews03 {
  margin-left: -100px;


    .supporter-top-interviews-item-titleBlock {
      gap: min(2.8vw, 28px) 0;
    }
    .supporter-top-interviews-img {
      left: max(-1vw, -10px);
      width: min(30vw, 300px);
    }
    .supporter-top-interviewCard-list {
      margin: 0 0 0 max(-10.4vw, -104px);
    }
  }

  &.interviews04 {
    flex-direction: row-reverse;
    justify-content: flex-start;
    margin: min(19vw, 190px) 0 0 0;
    padding: 0 min(8vw, 80px) 0 0;

    .supporter-top-interviews-item-titleBlock {
      justify-content: flex-start;
      gap: min(1vw, 10px) 0;
    }
    .supporter-top-interviews-img {
      width: min(20.7vw, 387px);
    }
    .supporter-top-interviewCard-list {
      display: grid;
      grid-template-columns: auto auto;
      margin: 0 max(-6vw, -60px) 0 0;
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviews-item {
    &.interviews01 {
      .supporter-top-interviews-item-titleBlock {
        gap: 2.13vw 0;
        padding: 0 0 0 9.6vw;
      }
      .supporter-top-interviews-img {
        right: -1vw;
        width: 14.27vw;
      }
      .supporter-top-interviewCard-list {
        margin-top: -13.4vw;
      }
    }

    &.interviews02 {
      flex-direction: column;
      gap: 0;
      margin-top: 3vw;

      .supporter-top-interviews-item-titleBlock {
        align-self: flex-end;
        gap: 3vw 0;
        padding: 0 7.5vw 0 0;
      }
      .supporter-top-interviews-img {
        align-self: center;
        left: auto;
        right: 0;
        width: 35.6vw;
      }
      .supporter-top-interviewCard-list {
        margin-top: -18vw;
        grid-template-columns: 1fr;
      }
    }

    &.interviews03 {
      margin: 1vw 0 0 0;
      padding: 0 0 0 0;

      .supporter-top-interviews-item-titleBlock {
        gap: 1.8vw 0;
        padding: 0 0 0 6.6vw;
      }
      .supporter-top-interviews-img {
        left: 0.4vw;
        width: 36.67vw;
      }
      .supporter-top-interviewCard-list {
        margin-top: -17.5vw;
      }
    }

    &.interviews04 {
      flex-direction: column;
      padding: 0 0 0 0;
      margin: 8vw 0 0 0;

      .supporter-top-interviews-item-titleBlock {
        align-self: flex-end;
        gap: 2.13vw 0;
        padding: 0 7vw 0 0;
      }
      .supporter-top-interviews-img {
        left: -1vw;
        width: 25.33vw;
      }
      .supporter-top-interviewCard-list {
        display: flex;
        flex-direction: column;
        margin: -29vw 0 0 0;
      }
    }
  }
}

/* サポーターインタビューカード個別スタイル */

.supporter-top-interviewCard-item.item01 {
width: 450px;
  margin-top: 15px;

  .supporter-top-interviewCard-bg {
    rotate: 0deg;
  }
  .supporter-top-interviewCard-tag {
    left: max(-0.4vw, -4px);
    top: max(-0.4vw, -4px);
  }
  .supporter-top-interviewCard-name {
    width: min(29.5vw, 295px);
  }
  .supporter-top-interviewCard-btn {
    bottom: max(-0.3vw, -3px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(2.3vw, 23px) min(0.3vw, 3px) 0 0;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item01 {
    right: -10.6vw;
    margin: 0 0 0 0;
    width: 94.93vw;

    .supporter-top-interviewCard-tag {
      left: -1.5vw;
      top: 0;
    }
    .supporter-top-interviewCard-name {
      width: 68.27vw;
    }
    .supporter-top-interviewCard-btn {
      bottom: -1vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 4.4vw 0 0 0;
    }
  }
}
.supporter-top-interviewCard-item.item02 {
  right: max(-0.5vw, -5px);
width: 450px;
  margin-top: 15px;
  z-index: 1;

  .supporter-top-interviewCard-bg {
    rotate: 0deg;
  }
  .supporter-top-interviewCard-tag {
    left: max(-1.8vw, -18px);
    top: max(-0.7vw, -7px);
  }
  .supporter-top-interviewCard-name {
    width: min(20.8vw, 208px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-0.4vw, -4px);
    bottom: max(-0.4vw, -4px);
  }
  .supporter-top-interviewCard-inner {
    padding: 80px;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item02 {
    right: auto;
    left: -7.8vw;
    margin: -13vw 0 0 0;
    width: 74.53vw;

    .supporter-top-interviewCard-tag {
      left: 0;
      top: 0;
    }
    .supporter-top-interviewCard-name {
      width: 48.8vw;
    }
    .supporter-top-interviewCard-btn {
      left: 0;
      bottom: -0.33vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 1vw 0 0 10vw;
    }
  }
}
.supporter-top-interviewCard-item.item03 {
  top: max(-1.5vw, -15px);
  right: max(-2vw, -20px);
  width: min(39.8vw, 398px);

  .supporter-top-interviewCard-tag {
    left: max(-0.4vw, -4px);
    top: max(-0.4vw, -4px);
  }
  .supporter-top-interviewCard-name {
    width: min(21.6vw, 216px);
  }
  .supporter-top-interviewCard-btn {
    left: min(0.8vw, 8px);
    bottom: max(-0.4vw, -4px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(1vw, 10px) min(0.2vw, 2px) 0 0;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item03 {
    top: auto;
    right: auto;
    left: -5.6vw;
    margin: 0 0 0 0;
    width: 80.53vw;

    .supporter-top-interviewCard-tag {
      left: -1vw;
      top: 0;
    }
    .supporter-top-interviewCard-name {
      width: 50.53vw;
    }
    .supporter-top-interviewCard-btn {
      left: 0;
      bottom: 0;
    }
    .supporter-top-interviewCard-inner {
      padding: 2.6vw 0 0 1.3vw;
    }
  }
}
.supporter-top-interviewCard-item.item04 {
top: -50px;
  right: -250px;
  width: min(38.3vw, 383px);
  z-index: 2;

  .supporter-top-interviewCard-tag {
    left: 0;
    top: max(-0.1vw, -1px);
  }
  .supporter-top-interviewCard-name {
    width: min(20.6vw, 206px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-0.8vw, -8px);
    bottom: max(-0.4vw, -4px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(3.3vw, 33px) 0 0 min(1vw, 10px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item04 {
    justify-self: end;
top: 50px;
right: 150px;
    margin: -14.7vw 0 0 0;
    width: 78.27vw;

    .supporter-top-interviewCard-tag {
      left: 0;
      top: -0.2vw;
    }
    .supporter-top-interviewCard-name {
      width: 48.27vw;
    }
    .supporter-top-interviewCard-btn {
      left: 0;
      bottom: 0.1vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 9vw 0 0 4vw;
    }
  }
}
.supporter-top-interviewCard-item.item05 {
  position: relative;
top: 350px;
right: 150px;
  margin: max(-10vw, -100px) 0 0 0;
  width: min(40.3vw, 403px);
  z-index: 1;

  .supporter-top-interviewCard-name {
    width: min(20.5vw, 205px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-0.7vw, -7px);
    bottom: 0;
  }
  .supporter-top-interviewCard-inner {
    padding: min(0.8vw, 8px) 0 0 0;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item05 {
    right: auto;
    left: -7.8vw;
    margin: -15.5vw 0 0 0;
    width: 84.8vw;
    z-index: 3;

    .supporter-top-interviewCard-name {
      width: 47.6vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 0 3.6vw 0 0;
    }
  }
}
.supporter-top-interviewCard-item.item06 {
  position: relative;
  top: max(-1.6vw, -16px);
  right: max(-14vw, -140px);
  margin: 0 0 0 0;
  width: min(40.9vw, 409px);

  .supporter-top-interviewCard-tag {
    left: max(-0.4vw, -4px);
    top: 0;
  }
  .supporter-top-interviewCard-name {
    width: min(28.3vw, 283px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-0.8vw, -8px);
    bottom: max(-0.1vw, -1px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(1.5vw, 15px) 0 0 min(2.9vw, 29px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item06 {
    justify-self: end;
    top: auto;
    right: auto;
    left: -7.3vw;
    margin: -10vw 0 0 0;
    width: 89.46vw;
    z-index: 3;

    .supporter-top-interviewCard-tag {
      left: 0;
      top: 0.1vw;
    }
    .supporter-top-interviewCard-name {
      width: 65.6vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 3.6vw 0 0 4.6vw;
    }
  }
}
.supporter-top-interviewCard-item.item07 {
  position: relative;
  left: 100px;
  bottom: -70px;
  margin: 0 0 0 0;
  width: min(36.2vw, 382px);
  z-index: 2;

  .supporter-top-interviewCard-tag {
    left: max(-0.1vw, -1px);
    top: max(-0.2vw, -2px);
  }
  .supporter-top-interviewCard-name {
    width: min(24.4vw, 244px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-1vw, -10px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(2.3vw, 23px) 0 0 min(2.4vw, 24px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item07 {
    align-self: end;
    left: auto;
    right: -6.4vw;
    bottom: 0;
    width: 87.33vw;

    .supporter-top-interviewCard-tag {
      left: 0;
      top: 0;
    }
    .supporter-top-interviewCard-name {
      width: 56.93vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 7.3vw 0 0 5.1vw;
    }
  }
}
.supporter-top-interviewCard-item.item08 {
position: relative;
  left: 100px;
  bottom: -70px;
  margin: 0 0 0 0;
  width: min(43.2vw, 422px);
  z-index: 1;

  .supporter-top-interviewCard-bg {
    rotate: -3deg;
  }
  .supporter-top-interviewCard-name {
    width: min(22.9vw, 229px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-0.8vw, -8px);
    bottom: max(-0.1vw, -1px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(3.5vw, 35px) 0 0 min(1.8vw, 18px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item08 {
    left: -3.6vw;
    margin: -21.8vw 0 0 0;
    width: 81.2vw;
    z-index: 2;

    .supporter-top-interviewCard-name {
      width: 50.93vw;
    }
    .supporter-top-interviewCard-btn {
      left: -1.8vw;
      bottom: 0.2vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 9.4vw 0 0 4vw;
    }
  }
}
.supporter-top-interviewCard-item.item09 {
  position: relative;
  top: max(-3vw, -30px);
  right: max(-5vw, -50px);
  margin: 0 0 0 0;
  width: min(40.6vw, 406px);
  z-index: 1;

  .supporter-top-interviewCard-tag {
    left: 0;
    top: max(-0.1vw, -1px);
  }
  .supporter-top-interviewCard-name {
    width: min(20.4vw, 204px);
  }
  .supporter-top-interviewCard-btn {
    left: 0;
    bottom: max(-0.2vw, -2px);
  }
  .supporter-top-interviewCard-bg {
    rotate: 3deg;
  }
  .supporter-top-interviewCard-inner {
    padding: min(2.1vw, 21px) 0 0 min(0.6vw, 6px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item09 {
    align-self: flex-start;
    top: auto;
    right: -1vw;
    width: 80vw;

    .supporter-top-interviewCard-tag {
      left: 0;
      top: -0.4vw;
    }
    .supporter-top-interviewCard-name {
      width: 46.53vw;
    }
    .supporter-top-interviewCard-btn {
      left: 0;
      bottom: 0;
    }
    .supporter-top-interviewCard-inner {
      padding: 5vw 0 0 1vw;
    }
  }
}
.supporter-top-interviewCard-item.item10 {
  position: relative;
  bottom: max(-10vw, -100px);
  margin: 0 0 0 0;
  width: min(45vw, 450px);
  z-index: 1;

  .supporter-top-interviewCard-tag {
    left: max(-0.2vw, -2px);
    top: max(-0.2vw, -2px);
  }
  .supporter-top-interviewCard-name {
    width: min(31.9vw, 319px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-0.9vw, -9px);
    bottom: max(-0.2vw, -2px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(1vw, 10px) 0 0 min(1.7vw, 17px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item10 {
    align-self: flex-end;
    right: -11.4vw;
    bottom: auto;
    margin: -9.7vw 0 0 0;
    width: 91.33vw;

    .supporter-top-interviewCard-tag {
      left: 0;
      top: -0.43vw;
    }
    .supporter-top-interviewCard-name {
      width: 48vw;
    }
    .supporter-top-interviewCard-btn {
      left: -0.16vw;
      bottom: -0.12vw;
    }
    .supporter-top-interviewCard-inner {
      padding: 6.2vw 0 0 1.4vw;
    }
  }
}
.supporter-top-interviewCard-item.item11 {
  position: relative;
  top: max(-4.3vw, -43px);
  right: max(-10.8vw, -108px);
  margin: 0 0 0 0;
  width: min(42vw, 420px);
  z-index: 2;

  .supporter-top-interviewCard-tag {
    left: min(0.2vw, 2px);
    top: 0;
  }
  .supporter-top-interviewCard-name {
    width: min(23.4vw, 234px);
  }
  .supporter-top-interviewCard-btn {
    left: max(-0.4vw, -4px);
    bottom: max(-0.3vw, -3px);
  }
  .supporter-top-interviewCard-inner {
    padding: min(2.6vw, 26px) 0 0 min(1vw, 10px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviewCard-item.item11 {
    top: auto;
    right: auto;
    left: -2.3vw;
    margin: -9.6vw 0 0 0;
    width: 84.27vw;

    .supporter-top-interviewCard-tag {
      left: 0;
      top: 0.43vw;
    }
    .supporter-top-interviewCard-name {
      width: 52vw;
    }
    .supporter-top-interviewCard-bg {
      rotate: 4deg;
    }
    .supporter-top-interviewCard-inner {
      padding: 11.3vw 0 0 2.2vw;
    }
  }
}

.supporter-top-interviews-caption {
  margin: min(1.4vw, 14px) auto 0;
  max-width: 1000px;

  > p {
    color: var(--supporter-color-gray);
    font-size: min(1.2vw, 12px);
    font-weight: 400;
    line-height: 1.5;
  }

  &.--indent {
    > p {
      text-indent: -1em;
      padding-left: 1em;
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-interviews-caption {
    margin: 4.67vw auto 0;
    padding: 0 4vw;

    > p {
      font-size: 2.67vw;
    }
  }
}

/* サポーター サービス */

.supporter-top-service {
  position: relative;
  padding: min(10.4vw, 104px) 0 min(10vw, 100px);
  background-color: #f8f8f8;
}
@media only screen and (max-width: 768px) {
  .supporter-top-service {
    padding: 18.13vw 0 16vw;
  }
}

.supporter-top-service-logo {
  position: absolute;
  top: max(-3.7vw, -37px);
  left: 50%;
  translate: -50% 0;
  width: min(18.9vw, 189px);

  img {
    display: block;
    width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-service-logo {
    top: -4vw;
    left: 50%;
    width: 27.73vw;
  }
}

@media only screen and (max-width: 768px) {
  .supporter-top-service-heading {
    font-size: 5.86vw;
    line-height: 1.36;
  }
}

.supporter-top-service-inner {
  margin: 0 auto;
  max-width: 1000px;
}
@media only screen and (max-width: 1000px) {
  .supporter-top-service-inner {
    margin: 0 5.33vw;
  }
}

.supporter-top-service-headingTag {
  margin-top: min(4.2vw, 42px);
  color: var(--supporter-color-blue-02);
}
@media only screen and (max-width: 768px) {
  .supporter-top-service-headingTag {
    margin-top: 6.67vw;
  }
}

.supporter-top-service-cardList {
  margin-top: min(1.8vw, 18px);
}
@media only screen and (max-width: 768px) {
  .supporter-top-service-cardList {
    margin-top: 5.33vw;
  }
}

.supporter-top-service-card {
  display: flex;
  position: relative;
  border-radius: min(0.8vw, 8px);
  padding: min(2vw, 20px);
  background-color: var(--supporter-color-white);

  & + & {
    margin-top: min(2vw, 20px);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-service-card {
    display: block;
    border-radius: 2.13vw;
    padding: 8vw 6vw 5.33vw;

    & + & {
      margin-top: 6.67vw;
    }
  }
}
.supporter-top-service-card {
  &.service-card01 {
    .supporter-top-service-card-img {
      top: -2vw;
    }
  }
}

.supporter-top-service-card-tag {
  flex-shrink: 0;
  align-self: center;
  display: inline-flex;
  justify-content: center;
  align-items: center;
  border-radius: 9999px;
  margin: 0 min(1.5vw, 15px) 0 0;
  padding: min(1.8vw, 18px) min(0.5vw, 5px);
  width: min(3.5vw, 35px);

  &.--treatment {
    background-color: var(--supporter-bg-color-green);

    img {
      width: min(2.5vw, 25px);
    }
  }
  &.--heart {
    background-color: var(--supporter-bg-color-purple);

    img {
      width: min(2vw, 20px);
    }
  }
  &.--employment {
    margin: max(-1.5vw, -15px) min(1.5vw, 15px) max(-1.5vw, -15px) 0;
    padding: min(1vw, 10px) min(0.5vw, 5px);
    background-color: var(--supporter-bg-color-yellow);

    img {
      width: min(2.4vw, 24px);
    }
  }
  &.--life {
    background-color: var(--supporter-bg-color-orange);

    img {
      width: min(2.5vw, 25px);
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-service-card-tag {
    margin: 0 0 0 0;
    padding: 1.5vw 5.33vw 1.5vw;
    width: auto;

    &.--treatment {
      img {
        width: 10.4vw;
      }
    }
    &.--heart {
      img {
        width: 14.4vw;
      }
    }
    &.--life {
      img {
        width: 10.4vw;
      }
    }
    &.--employment {
      margin: 0;
      padding: 1.33vw 4.53vw 1.5vw;
      width: auto;

      img {
        width: 26vw;
      }
    }
  }
}

.supporter-top-service-card-img {
  flex-shrink: 0;
  align-self: center;
  margin: 0 min(1.5vw, 15px) 0 0;
  width: min(19.5vw, 195px);

  img {
    display: block;
    width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-service-card-img {
    position: absolute;
    top: -1vw;
    right: 9vw;
    margin: 0;
    width: 34vw;
    z-index: 1;
  }
}

.supporter-top-serviceList {
  flex-grow: 1;
  display: flex;
  flex-wrap: nowrap;
  gap: 0 min(1vw, 10px);
}
@media only screen and (max-width: 768px) {
  .supporter-top-serviceList {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.33vw;
    margin-top: 4vw;
  }
}

.supporter-top-serviceItem {
  flex: 1;
  height: 100%;
}
@media only screen and (max-width: 768px) {
  .supporter-top-serviceItem {
    min-height: 16.8vw;
  }
}

.supporter-top-serviceItem-inner {
  display: grid;
  place-content: center;
  position: relative;
  border-radius: min(0.4vw, 4px);
  padding: min(2.3vw, 23px) min(1.1vw, 11px) min(2.4vw, 24px) min(1vw, 10px);
  height: 100%;
  background-color: var(--supporter-bg-color-thin);
  text-decoration: none;
  transition: background-color 0.2s ease-out, color 0.2s ease-out;

  &:hover {
    opacity: 1;
    background-color: #543f03;
    color: var(--supporter-color-white);
    transition: background-color 0.3s ease-out, color 0.3s ease-out;
    
    .supporter-top-serviceItem-iconPlus {
      color: var(--supporter-color-white);
      transition: color 0.3s ease-out;
      animation: spinIcon 0.78s cubic-bezier(0.68, -0.18, 0.265, 1.28) both;
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-serviceItem-inner {
    border-radius: 1.07vw;
    padding: 1.33vw;
  }
}

.supporter-top-serviceItem-name {
  color: currentColor;

  > p {
    text-align: center;
    color: currentColor;
    font-size: min(2vw, 20px);
    font-weight: 700;
    line-height: 1.33;

    > .--text-small {
      display: inline-block;
      color: currentColor;
      font-size: min(1.4vw, 14px);
      line-height: 1.33;
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-serviceItem-name {
    > p {
      font-size: 4vw;
      line-height: 1.13;

      > .--text-small {
        font-size: 3.2vw;
      }
    }
  }
}

.supporter-top-serviceItem-iconPlus {
  display: grid;
  position: absolute;
  right: min(0.9vw, 9px);
  bottom: min(0.9vw, 9px);
  translate: 0 0 0;
  aspect-ratio: 1 / 1;
  width: min(1vw, 10px);
  color: #543f03;
  transition: color 0.2s ease-out;

  > span {
    grid-area: 1 / -1;
    display: block;
    border-radius: 9999px;
    margin: auto;
    width: 100%;
    height: 2px;
    color: currentColor;
    background-color: currentColor;

    &:nth-of-type(2) {
      rotate: 90deg;
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-top-serviceItem-iconPlus {
    right: 0.8vw;
    bottom: 0.8vw;
    width: 1.87vw;

    > span {
      height: 1px;
    }
  }
}

/* サポーター サービス個別 */

/* 「アフラックのよりそうがん相談サポート」サポーター */

.supporter-top-lead {
  padding: 72px 0;
  background-color: #eff7fc;
}
@media only screen and (max-width: 768px) {
  .supporter-top-lead {
    padding: 16vw 0;
  }
}

.supporter-top-lead-name {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 38px;
  border-radius: 9999px;
  min-height: 100px;
  background-color: #009cde;
}
@media only screen and (max-width: 768px) {
  .supporter-top-lead-name {
    flex-direction: column;
    justify-content: center;
    gap: 0.933vw 0;
    min-height: 130px;
  }
}

.supporter-top-lead-logo {
  flex-shrink: 0;
  align-self: center;
  width: min(8.38vw, 109px);
  height: min(4.61vw, 60px);
}
@media only screen and (max-width: 768px) {
  .supporter-top-lead-logo {
    width: 64px;
    height: 36px;
  }
}

.supporter-top-lead-name-text {
  width: min(48.6vw, 632px);
}
@media only screen and (max-width: 768px) {
  .supporter-top-lead-name-text {
    width: 51.5vw;
  }
}

.supporter-top-lead-content {
  padding: 40px 0 0;
  margin: 0 auto;
  max-width: 800px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-lead-content {
    padding: 5.87vw 0 0;
    max-width: auto;
  }
}

.supporter-top-lead-img img {
  display: block;
  margin-top: 32px;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .supporter-top-lead-img img {
    margin-top: 7.46vw;
  }
}

.supporter-top-lead-btn {
  margin-top: 40px;
  font-weight: 400;
}
@media only screen and (max-width: 768px) {
  .supporter-top-lead-btn {
    margin-top: 8.4vw;
  }
}

.supporter-top-inner {
  margin: auto;
  width: 100%;
}

.supporter-top-interview-wrapper {
  padding: 80px 0;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-wrapper {
    padding: 20vw 0 17.33vw;
  }
}

.supporter-top-interview-name-wrapper {
  text-align: center;
}

.supporter-top-interview-name-img {
  width: 569px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-name-img {
    width: 64.8vw;
  }
}

@media only screen and (max-width: 768px) {
  .supporter-top-interview-name-img img {
    width: 70vw;
  }
}

.supporter-top-interview-cardList {
  position: relative;
  margin-top: 50px;
margin-left: -45px !important;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-cardList {
    margin-top: 6.67vw;
   margin-left: 0px !important;
  }
}

.supporter-top-interview-card {
  display: flex;
  position: relative;
  border-radius: 30px;
 
  padding-right: min(3.84vw, 50px);
  width: 100%;
  min-height: 240px;
  background-color: #fff;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card {
    flex-direction: column;
    border-radius: 4vw;

    padding: 0;
    min-height: 117.33vw;
     margin-left: 0px !important;
  }
}

.supporter-top-interview-card + .supporter-top-interview-card {
  margin-top: 40px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card + .supporter-top-interview-card {
    margin-top: 5.87vw;
  }
}

.supporter-top-interview-card-labelBlock {
  padding: 0 min(2.84vw, 37px) 0 min(4.38vw, 57px);
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-labelBlock {
    text-align: center;
    padding: 0 0 0.33vw;
  }
}

.supporter-top-interview-card-label {
  display: grid;
  place-items: center;
  position: relative;
  min-width: 155px;
  min-height: 101px;
  background-color: #f6db45;
  border-bottom-left-radius: 10px;
  border-bottom-right-radius: 10px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-label {
    display: inline-grid;
    min-width: 36.8vw;
    min-height: 11.33vw;
    border-bottom-left-radius: 1.33vw;
    border-bottom-right-radius: 1.33vw;
  }
}

.supporter-top-interview-card-label-number {
  position: relative;
  margin: 0 auto 35px;
  padding-bottom: 13px;
  width: 101px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-label-number {
    width: 24.13vw;
  }
}

.supporter-top-interview-card-label-number::before {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 2px;
  background-color: #fff;
}

.supporter-top-interview-card-label-illust {
  position: absolute;
  bottom: -10px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-label-illust {
    bottom: -6vw;
  }
}
.supporter-top-interview-card-label-illust img {
  width: 100%;
}
.supporter-top-interview-card.--01 .supporter-top-interview-card-label-illust {
  width: 140px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card.--01 .supporter-top-interview-card-label-illust {
    width: 22.5vw;
  }
}
.supporter-top-interview-card.--02 .supporter-top-interview-card-label-illust {
  width: 129px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card.--02 .supporter-top-interview-card-label-illust {
    bottom: -13.2vw;
    width: 24.9vw;
  }
}

.supporter-top-interview-card-content {
  flex-grow: 1;
  display: grid;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    text-align: center;
    padding: 4.5vw 5.6vw 8.66vw 5.06vw;
  }
}

.supporter-top-interview-card-name {
  display: inline-block;
  flex-direction: column;
  grid-area: 1 / -1;
padding-top: 20px;
  padding-bottom: 20px;

}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-name {
    grid-area: none;
  }
}

.supporter-top-interview-card-name .--main {
  display: inline;
  padding: 0 0 0 0;
  background-image: linear-gradient(transparent 75%, #ffe80c 0%);

  font-size: 30px;
  color: #5b4a10;
  font-weight: 600;
  line-height: 1.53;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-name .--main {
font-size: 4.7vw;
        line-height: 1.43;
  }

}
@media only screen and (max-width: 510px) {
    .supporter-top-interview-card-name .--sub {
        margin-top: 3vw;
        font-size: 3vw;
    }
}
.supporter-top-interview-card-name .--sub {
  display: block;
  margin-top: 18px;
  font-size: 18px;
  color: #383838;
  font-weight: 400;
font-family: '微軟正黑體' !important;
}
.supporter-top-interview-card-name .--sub a{
 
margin-top: 18px;
  font-size: 18px;
  text-decoration: underline;
  color: #71A21F;
line-height: 2;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-name .--sub {
    margin-top: 3vw;
    font-size: 4vw;
  }
.supporter-top-interview-card-name .--sub a {
  margin-top: 16px;
  font-size: 16px;

}
}

.supporter-top-interview-card-btn-wrapper {
  grid-area: 1 / -1;
  display: flex;
  justify-content: flex-end;
  margin: auto 0 23px auto;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-btn-wrapper {
    grid-area: none;
    justify-content: center;
    margin: 8vw auto 0;
  }
}

.supporter-top-interview-card-btn {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  position: relative;
  padding: 0 11px 0 0;
  border-radius: 4px;
  min-width: clamp(150px, 18vw, 112px);
  min-height: 56px;
  background: #ffe80c;
  text-decoration: none;
  color: #5b4a10;
  font-size: clamp(16px, 1.38vw, 18px);
  font-weight: 500;
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-btn {
    padding: 0 4.8vw;
    border-radius: 1.07vw;
    min-width: 71.73vw;
    min-height: 11.73vw;
    font-size: 4.27vw;
  }
}
.supporter-top-interview-card-btn::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: min(2vw, 25px);
  border-right: 1px solid currentColor;
  border-bottom: 1px solid currentColor;
  width: 7px;
  height: 7px;
  -webkit-transform: rotate(-45deg) translateY(-50%);
          transform: rotate(-45deg) translateY(-50%);
}
@media only screen and (max-width: 768px) {
  .supporter-top-interview-card-btn::before {
    right: 4.27vw;
  }
}


/* --------------------------------
  扉ページ
-------------------------------- */
.supporter-inner {
  margin: auto;
  padding-bottom: 40px;
  width: 100%;
}
@media only screen and (max-width: 768px) {
  .supporter-inner {
    padding-bottom: 4vw;
  }
}

.supporter-header {
  padding: 34px 0 80px;
}
@media only screen and (max-width: 768px) {
  .supporter-header {
    padding: 6.4vw 0 13.33vw;
    height: auto;
  }
}

.supporter-header-inner {
  position: relative;
  z-index: 1;
  width: 100%;
}

.supporter-mv {
  position: relative;
  margin: 0 auto;
  padding-bottom: 500px;
  border-radius: 8px;
  max-width: 1000px;
  background: url(../img/supporter/supporter_mv_lg.png) no-repeat center top/100% auto;
}
@media only screen and (max-width: 1000px) {
  .supporter-mv {
    margin: 0 20px;
    padding-bottom: 47vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-mv {
    margin: 0;
    padding-bottom: 89.33vw;
    border-radius: 0;
    max-width: auto;
    background: url(../img/supporter/supporter_mv_sm.jpg) no-repeat center top/100% auto;
  }
}
.supporter-mv::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 17px;
  right: 21px;
  width: 115px;
  height: 61px;
  background: url(../img/supporter/supporter_logo.png) no-repeat center top/100% auto;
}
@media only screen and (max-width: 768px) {
  .supporter-mv::before {
    top: 1.6vw;
    right: 1.6vw;
    width: 20.8vw;
    height: 11.2vw;
  }
}

.supporter-header-bg01 {
  position: absolute;
  z-index: -1;
  top: -34px;
  left: -149px;
  width: 370px;
  height: 180px;
  background: #009ddc;
}
@media only screen and (max-width: 768px) {
  .supporter-header-bg01 {
    top: -6.4vw;
    left: 0;
    width: 49.33333333vw;
    height: 24vw;
  }
}

.supporter-header-bg02 {
  position: absolute;
  z-index: -1;
  right: -92px;
  bottom: -30px;
  width: 334px;
  height: 220px;
  background: #2472bb;
}
@media only screen and (max-width: 768px) {
  .supporter-header-bg02 {
    right: 0;
    bottom: -4vw;
    width: 25.87vw;
    height: 29.33vw;
  }
}

.supporter-header-induction {
  position: absolute;
  bottom: 0;
  left: -38px;
  -webkit-transform: rotate(180deg);
          transform: rotate(180deg);
  letter-spacing: 0.05em;
  color: #009bdc;
  font-size: 19px;
  font-weight: 400;

  -webkit-writing-mode: vertical-rl;

          writing-mode: vertical-rl;
}
.supporter-header-induction::before {
  content: "";
  display: inline-block;
  left: 0;
  margin: 0 0 5px -5px;
  width: 2px;
  height: 73px;
  background: #009bdc;
}

.supporter-heading-block {
  position: absolute;
  z-index: 1;
  bottom: 38px;
  left: 50px;
}
@media only screen and (max-width: 768px) {
  .supporter-heading-block {
    bottom: 8.53vw;
    left: 0;
  }
}

.supporter-heading-sub {
  display: block;
  position: relative;
  padding: 5px 6px 4px 9px;
  background: #fff;
}
@media only screen and (max-width: 768px) {
  .supporter-heading-sub {
    padding: 0.8vw 1.33vw 0.8vw 1.87vw;
  }
}
.supporter-heading-sub_lg {
  width: 436px;
}
.supporter-heading-sub_sm {
  width: 80.53vw;
  height: 5.87vw;
}
.supporter-heading-sub_sm img {
  position: absolute;
  top: 0.8vw;
  width: 77.3vw;
}

.supporter-heading {
  display: block;
  margin-top: 9px;
  padding: 9px 6px 8px 7px;
  background: #fff;
}
@media only screen and (max-width: 768px) {
  .supporter-heading {
    margin-top: 1.6vw;
    padding: 1.33vw 1.33vw 1.07vw 1.33vw;
  }
}
.supporter-heading_lg {
  width: 590px;
}
.supporter-heading_sm {
  width: 93.87vw;
}

.supporter-lead {
  position: relative;
  margin: 0 auto 80px;
  padding: 21px;
  max-width: 880px;
  background: #fff;
  text-align: center;
  box-shadow: rgba(0, 157, 220, 0.2) 0px 0px 45px 2px;
}
@media only screen and (max-width: 1000px) {
  .supporter-lead {
    margin: 0 20px 80px;
    max-width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-lead {
    margin: 0 auto 13.33vw;
    padding: 4vw;
    max-width: 87.73vw;
    background: #fff;
    text-align: left;
    box-shadow: rgba(0, 157, 220, 0.2) 0px 0px 28px -6px;
  }
}

.supporter-lead-inner {
  position: relative;
  padding: 43px;
}
@media only screen and (max-width: 768px) {
  .supporter-lead-inner {
    padding: 8vw 7.2vw;
  }
}

.supporter-lead-frame {
  display: inline-block;
  position: absolute;
  width: 33px;
  height: 33px;
  background: transparent;
}
@media only screen and (max-width: 768px) {
  .supporter-lead-frame {
    width: 8vw;
    height: 8vw;
  }
}
.supporter-lead-frame.frame01 {
  top: 0;
  left: 0;
  border-top: 2px solid #009bdc;
  border-left: 2px solid #009bdc;
}
.supporter-lead-frame.frame02 {
  top: 0;
  right: 0;
  border-top: 2px solid #009bdc;
  border-right: 2px solid #009bdc;
}
.supporter-lead-frame.frame03 {
  bottom: 0;
  left: 0;
  border-bottom: 2px solid #009bdc;
  border-left: 2px solid #009bdc;
}
.supporter-lead-frame.frame04 {
  right: 0;
  bottom: 0;
  border-right: 2px solid #009bdc;
  border-bottom: 2px solid #009bdc;
}

.supporter-lead-name {
  margin: 0 auto;
  width: 704px;
  height: 32px;
}
@media only screen and (max-width: 1000px) {
  .supporter-lead-name {
    margin-left: -0.8vw;
    width: 82vw;
    height: auto;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-lead-name {
    width: 64.53vw;
    height: 13.87vw;
  }
}
.supporter-lead-name img {
  display: block;
  width: 100%;
}

.supporter-lead-text {
  position: relative;
  padding-top: 30px;
  white-space: pre;
  color: #fff;
  font-size: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 768px) {
  .supporter-lead-text {
    padding-top: 8vw;
    font-size: 4.8vw;
  }
}
.supporter-lead-text > span {
  display: inline-block;
  position: relative;
  padding: 0 0.3em;
  border-radius: 2px;
  background: linear-gradient(to bottom, #009ddc 0%, #009ddc 100%);
  background-position: center top;
  background-size: 100% auto;
  color: #fff;
}
@media only screen and (max-width: 768px) {
  .supporter-lead-text > span {
    border-radius: 0.53vw;
  }
}
.supporter-lead-text > span:not(:first-of-type) {
  margin-top: 6px;
}
@media only screen and (max-width: 768px) {
  .supporter-lead-text > span:not(:first-of-type) {
    margin-top: 1.6vw;
  }
}

.supporter-lead-text-sub {
  padding-top: 22px;
  font-size: 16px;
}
@media only screen and (max-width: 768px) {
  .supporter-lead-text-sub {
    padding-top: 5.87vw;
    font-size: 4.27vw;
  }
}

.supporter-feature {
  display: block;
  padding: 67px 0 114px;
  background: #e1f3ff;
}
@media only screen and (max-width: 768px) {
  .supporter-feature {
    padding: 15.2vw 0;
  }
}

.supporter-feature-tip-wrapper {
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .supporter-feature-tip-wrapper {
    margin-bottom: 2.13vw;
  }
}

.supporter-feature-tip_lg {
  display: inline-block;
  margin: 0 auto;
  width: 145px;
  height: 51px;
}

@media only screen and (max-width: 768px) {
  .supporter-feature-tip_sm {
    display: inline-block;
    margin: 0 auto;
    width: 32.27vw;
    height: 10.93vw;
  }
}

.supporter-feature-name-sub {
  display: flex;
  margin: 0 auto;
  border-radius: 9999px;
  background-color: #fff;

  justify-content: center;
  align-items: center;
}

.supporter-feature-name-sub_lg {
  padding: 11px 0 10px;
  width: 690px;
}

.supporter-feature-name-sub_lg img {
  display: block;
  margin: 0 auto;
  width: 640px;
  height: auto;
}

.supporter-feature-name-sub_sm {
  padding: 3.2vw 0 2.67vw 0.43vw;
  width: 87.73vw;
}

.supporter-feature-name-sub_sm img {
  display: block;
  margin: 0 auto;
  width: 70.13vw;
  height: auto;
}

.supporter-feature-name_lg {
  display: block;
  margin: 10px auto 0;
  padding-left: 2px;
  width: min(79vw, 790px);
  height: auto;
}

.supporter-feature-name_lg img {
  width: 100%;
}

@media only screen and (max-width: 768px) {
  .supporter-feature-name_sm {
    display: block;
    margin: 4.6vw auto 0;
    padding-left: 0;
    width: 87.5vw;
    height: auto;
  }
  .supporter-feature-name_sm img {
    width: 100%;
  }
}

.supporter-feature-list {
  display: flex;
  margin-top: 60px;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .supporter-feature-list {
    display: block;
    margin: 13.33vw 0 0;
  }
}

.supporter-feature-item {
  flex: 1;
  display: grid;
  place-content: center;
  position: relative;
  padding: 32px 26px 24px 24px;
  border: 4px solid #009ddc;
  border-radius: 8px;
  max-width: 82.67vw;
  min-height: 226px;
  background: #fff;

  &::before {
    content: "";
    display: inline-block;
    position: absolute;
    top: 0;
    left: 50%;
    width: 48px;
    height: 48px;
    transform: translate(-50%, -50%);
  }
}
@media only screen and (max-width: 768px) {
  .supporter-feature-item {
    border: solid 0.8vw #009ddc;
    margin: 0 auto;
    padding: 8vw 8vw 5.33vw 8vw;
    width: 87.73vw;
    min-height: 0;

    &::before {
      width: 9.33vw;
      height: 9.33vw;
    }
  }
}
.supporter-feature-item:not(:first-of-type) {
  margin-left: min(3.2vw, 32px);
}
@media only screen and (max-width: 768px) {
  .supporter-feature-item:not(:first-of-type) {
    margin: 8.8vw auto 0;
  }
}
.supporter-feature-item.item01::before {
  background: url(../img/supporter/supporter_feature_num_01.png) no-repeat center top/100% auto;
}
.supporter-feature-item.item02::before {
  background: url(../img/supporter/supporter_feature_num_02.png) no-repeat center top/100% auto;
}
.supporter-feature-item.item03::before {
  background: url(../img/supporter/supporter_feature_num_03.png) no-repeat center top/100% auto;
}

.supporter-feature-item-name {
  display: flex;
  text-align: center;
  color: #009ddc !important;
  font-size: 26px;
  font-weight: bold;
  line-height: 1.3;
  justify-content: center;
  align-items: center;

  img {
    display: block;
    width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-feature-item-name {
    letter-spacing: 0.025em;
    font-size: 5.87vw;
    line-height: 1.227;
    max-width: 100%;
  }
}

.supporter-feature-item {
  &.item01 {
    .supporter-feature-item-name {
      width: min(20.77vw, 270px);
    }
  }
  &.item02 {
    .supporter-feature-item-name {
      width: min(18.15vw, 236px);
    }
  }
  &.item03 {
    .supporter-feature-item-name {
      width: min(19.15vw, 249px);
    }
  }
}
@media only screen and (max-width: 768px) {
  .supporter-feature-item {
    &.item01 {
      .supporter-feature-item-name {
        width: 65.87vw;
      }
    }
    &.item02 {
      .supporter-feature-item-name {
        width: 52.53vw;
      }
    }
    &.item03 {
      .supporter-feature-item-name {
        width: 54.27vw;
      }
    }
  }
}

.supporter-feature-item-text {
  text-align: justify;
  text-justify: inter-ideograph;
  letter-spacing: 0.015em;
  font-size: 15px;
  font-weight: 400;
  line-height: 1.6;
}
@media only screen and (max-width: 768px) {
  .supporter-feature-item-text {
    letter-spacing: 0.02em;
    font-size: 3.73vw;
  }
}

.supporter-feature-item-note {
  margin-top: 0.5rem;
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.24;
}
.supporter-feature-item-note small {
  font-size: 12px;
}
@media only screen and (max-width: 768px) {
  .supporter-feature-item-note small {
    font-size: 3.2vw;
  }
}

.supporter-top-noteList {
  margin-top: 36px;
}
@media only screen and (max-width: 768px) {
  .supporter-top-noteList {
    margin-top: 8vw;
  }
}

.supporter-bnr-wrapper {
  padding: 40px 0;
  background-color: #f0f7fb;
}

@media only screen and (max-width: 768px) {
  .supporter-bnr-wrapper {
    padding: 10.67vw 0;
  }
}

.supporter-bnr {
  margin: 0 auto;
  text-align: center;
}

.supporter-bnr a {
  display: block;
}

.supporter-bnr img {
  max-width: 100%;
  height: auto;
}

.supporter-bnr_lg {
  width: 500px;
}

.supporter-bnr_sm {
  width: 87.73vw;
}

.supporter-list-wrapper {
  padding: 90px 0;
}
@media only screen and (max-width: 768px) {
  .supporter-list-wrapper {
    padding: 13.33vw 0;
  }
}

.supporter-list {
  margin-top: 50px;
}
@media only screen and (max-width: 1000px) {
  .supporter-list {
    padding: 0 20px;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-list {
    margin-top: 3.47vw;
    padding: 0;
  }
}

.supporter-item {
  margin: 0 auto;
  max-width: 1000px;
}
@media only screen and (max-width: 768px) {
  .supporter-item {
    max-width: auto;
  }
}
.supporter-item + .supporter-item {
  margin-top: 130px;
}
@media only screen and (max-width: 768px) {
  .supporter-item + .supporter-item {
    margin-top: 17.33vw;
  }
}

.supporter-item-inner {
  display: flex;
  position: relative;

  justify-content: flex-start;
}
@media only screen and (max-width: 768px) {
  .supporter-item-inner {
    display: block;
  }
}
.supporter-item-inner.reverse {
  flex-direction: row-reverse;
}
.supporter-item-inner.reverse .supporter-movie-wrap {
  margin-right: 0;
  margin-left: 60px;
}
@media only screen and (max-width: 1000px) {
  .supporter-item-inner.reverse .supporter-movie-wrap {
    margin-right: 0;
    margin-left: 6vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-item-inner.reverse .supporter-movie-wrap {
    margin-right: auto;
    margin-left: auto;
  }
}
.supporter-item-inner.reverse .supporter-item-content {
  padding-left: 48px;
}
@media only screen and (max-width: 1000px) {
  .supporter-item-inner.reverse .supporter-item-content {
    padding-left: 5vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-item-inner.reverse .supporter-item-content {
    padding: 8.53vw 7.47vw 0 7.47vw;
  }
}

.supporter-movie-wrap {
  display: block;
  position: relative;
  z-index: 1;
  margin-right: 60px;
  margin-left: 0;
  border-radius: 8px;
  width: 540px;
  background: #fff;
  box-shadow: rgba(0, 157, 220, 0.3) 0px 30px 28px -23px;

  flex-shrink: 0;
  align-self: start;
}
@media only screen and (max-width: 1000px) {
  .supporter-movie-wrap {
    margin-right: 6vw;
    width: 54vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-movie-wrap {
    margin: 0 auto;
    width: 87.7vw;
    box-shadow: rgba(0, 157, 220, 0.3) 0px 16px 18px -10px;
  }
}
.supporter-movie-wrap > a {
  display: flex;
  padding: 20px 19px 19px 19px;
  border-radius: 8px;

  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 1000px) {
  .supporter-movie-wrap > a {
    padding: 2vw 1.9vw 1.9vw 1.9vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-movie-wrap > a {
    padding: 3.47vw;
    border-radius: 2.13vw;
  }
}
.supporter-movie-wrap > a img {
  width: 497px;
  height: 277px;
}
@media only screen and (max-width: 1000px) {
  .supporter-movie-wrap > a img {
    width: 49.7vw;
    height: 27.7vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-movie-wrap > a img {
    width: 80.8vw;
    height: 45.33vw;
  }
}

.supporter-movie-wrap-inner {
  display: flex;
  padding: 20px 19px 19px 19px;
  border-radius: 8px;

  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 1000px) {
  .supporter-movie-wrap-inner {
    padding: 2vw 1.9vw 1.9vw 1.9vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-movie-wrap-inner {
    padding: 3.47vw;
    border-radius: 2.13vw;
  }
}

.supporter-movie-wrap-inner iframe {
  width: 502px;

  aspect-ratio: 502 / 282;
}

@media only screen and (max-width: 768px) {
  .supporter-movie-wrap-inner iframe {
    width: 80.8vw;
    height: auto;

    aspect-ratio: 303 / 170;
  }
}

.supporter-movie-wrap-bg {
  display: block;
  position: absolute;
  width: 344px;
  height: 220px;
}
.supporter-movie-wrap-bg.bg01 {
  top: -50px;
  left: -50px;
  width: 364px;
  background: #009ddc;
}
@media only screen and (max-width: 768px) {
  .supporter-movie-wrap-bg.bg01 {
    top: -3.47vw;
    left: 0;
    width: 39.2vw;
    height: 26.93vw;
  }
}
.supporter-movie-wrap-bg.bg02 {
  top: -40px;
  right: -150px;
  width: 224px;
  background: #0065ab;
}
@media only screen and (max-width: 768px) {
  .supporter-movie-wrap-bg.bg02 {
    top: -3.47vw;
    right: 0;
    width: 17.87vw;
    height: 26.93vw;
  }
}
.supporter-movie-wrap-bg.bg03 {
  top: -50px;
  left: -150px;
  width: 180px;
  background: #009ddc;
}
@media only screen and (max-width: 768px) {
  .supporter-movie-wrap-bg.bg03 {
    top: -6.93vw;
    left: 0;
    width: 14.13vw;
    height: 26.93vw;
  }
}

.supporter-item-content {
  position: relative;
  padding: 29px 0 0 0;
  max-width: 400px;
}
@media only screen and (max-width: 1000px) {
  .supporter-item-content {
    padding: 2.9vw 0 0 0;
    max-width: 40vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-item-content {
    margin: 0 auto;
    padding: 8.53vw 7.47vw 0 7.47vw;
    max-width: 87.73vw;
  }
}
.supporter-item-content::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 7px;
  left: -31px;
  width: 48px;
  height: 38px;
  background: url(../img/supporter/supporter_item_quote_lg.png) no-repeat center/100% auto;
}
@media only screen and (max-width: 768px) {
  .supporter-item-content::before {
    top: 5.33vw;
    left: 2.4vw;
    width: 9.33vw;
    height: 7.47vw;
    background: url(../img/supporter/supporter_item_quote_sm.png) no-repeat center/100% auto;
  }
}
.supporter-item-content.content02::before {
  left: 23px;
}
@media only screen and (max-width: 768px) {
  .supporter-item-content.content02::before {
    left: 2.4vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-item-content.content03 {
    max-width: 87.73vw;
  }
}

.supporter-item-lead {
  position: relative;
  z-index: 1;
  letter-spacing: 0.05em;
  font-family: "Sawarabi Mincho", serif;
  font-size: 26px;
  line-height: 1.615;
}
@media only screen and (max-width: 1000px) {
  .supporter-item-lead {
    font-size: 2.6vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-item-lead {
    font-size: 5.6vw;
    line-height: 1.6;
  }
}

.supporter-item-tag {
  display: flex;
  flex-direction: column;
  position: relative;
  z-index: 1;
  margin-top: 37px;
  padding: 0 0 4px 19px;
  min-height: 78px;

  justify-content: space-between;
}
@media only screen and (max-width: 1000px) {
  .supporter-item-tag {
    margin-top: 3.7vw;
    padding: 0 0 0.4vw 1.9vw;
    min-height: 7.8vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-item-tag {
    margin-top: 4.8vw;
    padding: 0.8vw 0 1.6vw 4vw;
    min-height: 26.67vw;
  }
}
.supporter-item-tag::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 3px;
  width: 6px;
  height: 100%;
  background: #009ddc;
}
@media only screen and (max-width: 768px) {
  .supporter-item-tag::before {
    border-radius: 0.8vw;
    width: 1.6vw;
  }
}

.supporter-item-text {
  font-size: 14px;
  line-height: 1.5;
}
@media only screen and (max-width: 768px) {
  .supporter-item-text {
    font-size: 3.73vw;
  }
}

.supporter-item-name {
  letter-spacing: 0.1em;
  font-size: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 768px) {
  .supporter-item-name {
    font-size: 5.33vw;
  }
}

.supporter-item-block {
  margin-top: 40px;
  padding: 33px 22px 30px;
  border-radius: 8px;
  background: #e1f3ff;
}
@media only screen and (max-width: 768px) {
  .supporter-item-block {
    margin: 7.2vw auto 0;
    padding: 8.8vw 8vw 8vw;
    width: 87.73vw;
  }
}

.supporter-item-block_text {
  text-align: justify;
  text-justify: inter-ideograph;
  letter-spacing: 0.01em;
  font-size: 16px;
  line-height: 1.625;
}
@media only screen and (max-width: 768px) {
  .supporter-item-block_text {
    font-size: 4.27vw;
    line-height: 1.6;
  }
}

.supporter-item-block-btn {
  margin-top: 20px;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .supporter-item-block-btn {
    margin-top: 2.93vw;
  }
}

.supporter-btn {
  display: inline-flex;
  position: relative;
  padding: 0 11px 0 0;
  border-radius: 4px;
  min-width: 312px;
  min-height: 56px;
  background: #0065ab;
  text-decoration: none;
  color: #fff;
  font-size: 18px;

  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .supporter-btn {
    padding: 0 4.8vw;
    border-radius: 1.07vw;
    min-width: 71.73vw;
    min-height: 11.73vw;
    font-size: 4.27vw;

    justify-content: flex-start;
  }
}
.supporter-btn::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  width: 7px;
  height: 7px;
  -webkit-transform: rotate(-45deg) translateY(-50%);
          transform: rotate(-45deg) translateY(-50%);
}
@media only screen and (max-width: 768px) {
  .supporter-btn::before {
    right: 4.27vw;
  }
}

.supporter-article-illust img {
  margin: 0 auto !important;
  width: 500px !important;
}
@media only screen and (max-width: 768px) {
  .supporter-article-illust img {
    width: 100% !important;
  }
}

/* よりそうサービス一覧
---------------------------------------- */
.supporter-service {
  margin: 60px auto 40px;
  width: min(75vw, 750px);
}
@media only screen and (max-width: 768px) {
  .supporter-service {
    margin: 60px auto 0;
    width: 100%;
  }
}

/* よりそうポイント
---------------------------------------- */
.supporter-point {
  overflow: hidden;
  margin: 40px auto 0;
  width: min(75vw, 750px);
  border: solid 5px #f09082;
  border-radius: 30px;
  background-image: linear-gradient(to bottom, #f09082, #f09082 40px, #fffeee 40px, #fffeee);
  background-size: 100% auto;
  background-repeat: no-repeat;
}
@media only screen and (max-width: 768px) {
  .supporter-point {
    margin: 40px auto;
    width: 100%;
  }
}

.supporter-point-header {
  background-color: #f09082;
  padding: 16px 16px 17px;
}

.supporter-point-heading {
  margin: 0 auto;
  width: 210px;
}

.supporter-point-inner {
  display: flex;
  gap: 0 13px;
  padding: 17px 16px 15px 20px;
}
@media only screen and (max-width: 768px) {
  .supporter-point-inner {
    padding: min(3.2vw, 12px);
  }
}

.supporter-point-iconWrap {
  flex-shrink: 0;
  align-self: center;
  display: flex;
  justify-content: center;
  min-width: 100px;
}
@media only screen and (max-width: 768px) {
  .supporter-point-iconWrap {
    min-width: min(21.33vw, 80px);
  }
}

.supporter-point-icon {
  width: 100px;
}
@media only screen and (max-width: 768px) {
  .supporter-point-icon {
    width: min(21.33vw, 80px);
  }
}
.supporter-point-icon img {
  width: 100%;
}

.supporter-point-text {
  margin: 0 !important;
  color: #f09082 !important;
  font-weight: 400 !important;
  font-size: 20px !important;
}
@media only screen and (max-width: 768px) {
  .supporter-point-text {
    font-size: 16px !important;
  }
}

/* --------------------------------
  詳細ページ
-------------------------------- */
.supporter-article-header {
  padding: 51px 0 50px;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-header {
    padding: 5.1vw 0 5vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-header {
    padding: 6.4vw 0 13.33vw;
  }
}

@media only screen and (max-width: 1000px) {
  .supporter-article-header-inner {
    padding: 0 20px 0;
  }
}

@media only screen and (max-width: 768px) {
  .supporter-article-header-inner {
    padding: 0;
  }
}

.supporter-article-mv {
  position: relative;
  z-index: 1;
  margin: 0 auto;
  border-radius: 8px;
  width: 1000px;
  height: 398px;
  box-shadow: rgba(0, 157, 220, 0.35) 0px 77px 30px -60px;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv {
    width: 100%;
    height: auto;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv {
    border-radius: 0;
    width: 100%;
    height: 122.13vw;
    box-shadow: rgba(0, 157, 220, 0.4) 0px 33px 20px -30px;
  }
}
.supporter-article-mv img {
  border-radius: 8px;
  width: 100%;
  height: auto;

  aspect-ratio: 1000 / 400;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv img {
    border-radius: 0;

    aspect-ratio: 375 / 458;
  }
}
.supporter-article-mv::before {
  content: "";
  display: inline-block;
  position: absolute;
  z-index: -1;
  top: -51px;
  left: -68px;
  width: 334px;
  height: 220px;
  background: #009bdc;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv::before {
    top: -5.1vw;
    left: -6.8vw;
    width: 33.4vw;
    height: 22vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv::before {
    top: -6.4vw;
    left: calc(100% - 36.53vw);
    width: 36.53vw;
    height: 29.33vw;
  }
}

.supporter-article-mv-inner {
  position: absolute;
  bottom: 49%;
  left: 420px;
  -webkit-transform: translate(0, 50%);
          transform: translate(0, 50%);
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv-inner {
    left: 40%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-inner {
    display: flex;
    bottom: 0;
    left: 50%;
    padding: 0 0 8.53vw 0;
    -webkit-transform: translate(-50%, 0);
            transform: translate(-50%, 0);

    align-items: flex-end;
  }
}

.supporter-article-mv-content {
  position: relative;
  color: #111;
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-content {
    margin: 0 auto;
    width: 90vw;
  }
}
.supporter-article-mv-content::before {
  content: "";
  display: inline-block;
  position: absolute;
  z-index: -1;
  top: -21px;
  left: -29px;
  width: 47px;
  height: 41px;
  background: url(../img/supporter/supporter_article_mv_quote_lg.png) no-repeat center/100% auto;
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-content::before {
    top: -3.1vw;
    left: -3.6vw;
    width: 7.2vw;
    height: 6.13vw;
    background: url(../img/supporter/supporter_article_mv_quote_sm.png) no-repeat center/100% auto;
  }
}

.supporter-article-mv-tag {
  display: flex;
  flex-direction: column;
  position: relative;
  margin-top: 30px;
  padding: 0 0 4px 19px;
  min-height: 85px;

  justify-content: space-between;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv-tag {
    margin-top: 3vw;
    padding: 0 0 0.4vw 1.9vw;
    min-height: 8.5vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-tag {
    margin-top: 5.4vw;
    padding: 0.3vw 0 1vw 4.2vw;
    min-height: 18.67vw;
  }
}
.supporter-article-mv-tag::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 3px;
  width: 6px;
  height: 100%;
  background: #258ad0;
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-tag::before {
    border-radius: 0.8vw;
    width: 1.07vw;
  }
}

.supporter-article-mv-lead {
  font-family: "Sawarabi Mincho", serif;
  font-size: 32px;
  line-height: 1.53;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv-lead {
    font-size: 3.2vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-lead {
    letter-spacing: 0.015em;
    word-break: keep-all;
    font-size: 5.87vw;
  }
}

.supporter-article-mv-text {
  font-size: 16px;
  line-height: 1.5;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv-text {
    font-size: 1.6vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-text {
    font-size: 3.47vw;
  }
}

.supporter-article-mv-name {
  letter-spacing: 0.1em;
  font-size: 20px;
  font-weight: bold;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv-name {
    font-size: 2vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-name {
    font-size: 4.8vw;
  }
}

.supporter-article-mv-name-sub {
  padding-left: 0.2em;
  font-size: 16px;
  font-weight: normal;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-mv-name-sub {
    font-size: 1.6vw;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-mv-name-sub {
    font-size: 3.47vw;
  }
}

.supporter-article-btn-wrapper {
  margin-top: 30px;
  text-align: center;
}

.supporter-article-btn {
  display: inline-flex;
  position: relative;
  padding: 0 52px 0 42px;
  border-radius: 9999px;
  min-width: 222px;
  min-height: 50px;
  background: #009bdb;
  text-decoration: none;
  letter-spacing: 0.05em;
  color: #fff;
  font-size: 16px;
  font-weight: 500;

  align-items: center;
}
.supporter-article-btn::before {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 30px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  width: 7px;
  height: 7px;
  -webkit-transform: rotate(45deg) translateY(-100%);
          transform: rotate(45deg) translateY(-100%);
}
@media only screen and (max-width: 768px) {
  .supporter-article-btn::before {
    right: 7.5vw;
  }
}

.supporter-article-lead {
  position: relative;
  margin: 0 auto 69px;
  padding: 21px;
  max-width: 880px;
  background: #fff;
  text-align: center;
  box-shadow: rgba(0, 157, 220, 0.2) 0px 0px 45px -4px;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-lead {
    margin: 0 20px 69px;
    max-width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead {
    margin: 0 auto 13.33vw;
    padding: 4vw;
    max-width: 87.73vw;
    background: url(../img/supporter/bg_read_sm.jpg) no-repeat 0 bottom/contain #fff;
    text-align: left;
  }
}

@media only screen and (max-width: 768px) {
  .supporter-article-lead-bg {
    display: inline-block;
    margin-top: -26.66vw;
    width: 39.2vw;
    height: 26.93vw;
    background: #009bdc;
  }
}

.supporter-article-lead-inner {
  display: flex;
  position: relative;
  padding: 20px 10px 20px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-inner {
    display: block;
    padding: 7.47vw 8vw;
  }
}

.supporter-article-lead-frame {
  display: inline-block;
  position: absolute;
  width: 33px;
  height: 33px;
  background: transparent;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-frame {
    width: 8vw;
    height: 8vw;
  }
}
.supporter-article-lead-frame.frame01 {
  top: 0;
  left: 0;
  border-top: 2px solid #009bdc;
  border-left: 2px solid #009bdc;
}
.supporter-article-lead-frame.frame02 {
  top: 0;
  right: 0;
  border-top: 2px solid #009bdc;
  border-right: 2px solid #009bdc;
}
.supporter-article-lead-frame.frame03 {
  bottom: 0;
  left: 0;
  border-bottom: 2px solid #009bdc;
  border-left: 2px solid #009bdc;
}
.supporter-article-lead-frame.frame04 {
  right: 0;
  bottom: 0;
  border-right: 2px solid #009bdc;
  border-bottom: 2px solid #009bdc;
}

.supporter-article-lead-name-wrapper {
  display: inline-flex;
  padding: 30px 52px 30px 50px;
  border-right: solid 1px #009bdc;

  flex-shrink: 0;
  align-items: center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-name-wrapper {
    display: block;
    padding: 0;
    border-right: 0;
    text-align: center;
  }
}

.supporter-article-lead-name {
  display: block;
  letter-spacing: 0.05em;
  color: #009bdc;
  font-size: 20px;
  font-weight: 500;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-name {
    padding: 4.27vw 0 8vw;
    font-size: 5.87vw;
  }
}

.supporter-article-lead-list {
  display: flex;
  flex-direction: column;
  padding: 8px 30px 6px 46px;

  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-list {
    display: block;
    padding: 0;
  }
}

.supporter-article-lead-item {
  display: flex;
  text-align: left;
  letter-spacing: 0.1em;
  font-size: 16px;
  line-height: 1.685;

  align-items: center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-item {
    font-size: 4.27vw;

    justify-content: center;
  }
}
.supporter-article-lead-item + .supporter-article-lead-item {
  margin-top: 12px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-item + .supporter-article-lead-item {
    margin-top: 2.13vw;
  }
}
.supporter-article-lead-item > dt {
  font-weight: bold;

  flex-shrink: 0;
  align-self: start;
}
@media only screen and (max-width: 768px) {
  .supporter-article-lead-item > dt {
    min-width: 0;
  }
}
.supporter-article-lead-item > dd {
  padding-left: 6px;

  align-self: start;
}
.supporter-article-lead-item li {
  padding-left: 0.5em;
  text-indent: -0.5em;
}
.supporter-article-lead-item li::before {
  content: "・";
  display: inline-block;
  width: 0.5em;
}

.supporter-article-lead-cvr-wrap .cvr-area_01 {
  padding: 30px 0;
  background: #f0f7fb;
}

.supporter-article-inner {
  position: relative;
  z-index: 0;
  padding: 96px 0 129px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-inner {
    padding: 17.33vw 0 25.33vw;
  }
}

.supporter-article-section {
  margin: 0 auto;
  max-width: 1000px;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-section {
    margin: 0 20px;
    max-width: 100%;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-section {
    max-width: 87.73vw;
  }
}
.supporter-article-section + .supporter-article-section {
  margin-top: 75px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section + .supporter-article-section {
    margin-top: 16vw;
  }
}

.supporter-article-heading {
  position: relative;
  letter-spacing: 0.05em;
  color: #0064a9;
  font-family: "Sawarabi Mincho", serif;
  font-size: 30px;
  line-height: 1.5;
}
@media only screen and (max-width: 768px) {
  .supporter-article-heading {
    font-size: 5.87vw;
  }
}
.supporter-article-heading::before {
  content: "";
  display: inline-block;
  position: absolute;
  z-index: -1;
  top: -10px;
  left: -19px;
  width: 31px;
  height: 27px;
  background: url(../img/supporter/supporter_article_item_quote.png) no-repeat center/100% auto;
}
@media only screen and (max-width: 768px) {
  .supporter-article-heading::before {
    top: -2.4vw;
    left: -2.8vw;
    width: 7.2vw;
    height: 6.13vw;
  }
}

.supporter-article-section-content {
  display: flex;
  margin-top: 28px;

  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-content {
    display: block;
    margin-top: 6.67vw;
  }
}
.supporter-article-section-content.reverse {
  flex-direction: row-reverse;
}
.supporter-article-section-content.reverse .supporter-article-section-img {
  margin: 0 30px 0 0;
}
@media only screen and (max-width: 1000px) {
  .supporter-article-section-content.reverse .supporter-article-section-img {
    margin: 0 3vw 0 0;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-content.reverse .supporter-article-section-img {
    margin: 8vw auto 0;
  }
}

.supporter-article-section-inner {
  align-self: start;
}

.supporter-article-heading-sub {
  display: inline-flex;
  position: relative;
  padding: 0.2em 0 0.2em 16px;
  min-height: 38px;
  letter-spacing: 0.01em;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.53;

  align-items: center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-heading-sub {
    padding: 0.1em 0 0.1em 2.67vw;
    font-size: 4.27vw;
    line-height: 1.4;
  }
}
.supporter-article-heading-sub::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 3px;
  width: 6px;
  height: 100%;
  background: #009ddc;
}
@media only screen and (max-width: 768px) {
  .supporter-article-heading-sub::before {
    border-radius: 0.53vw;
    width: 1.07vw;
  }
}

.supporter-article-section-text {
  margin: 12px 0 0;
  padding-left: calc(13px + 3px);
  letter-spacing: 0.01em;
  font-size: 18px;
  line-height: 1.73;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-text {
    margin-top: 3.73vw 0 0;
    padding-left: 0;
    font-size: 3.73vw;
  }
}

.supporter-article-section-img {
  position: relative;
  margin: 0 0 0 30px;
  border-radius: 4px;
  width: 312px;
  height: 400px;

  flex-shrink: 0;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-img {
    margin: 8vw auto 0;
    border-radius: 1.07vw;
    width: 71.73vw;
    height: auto;
  }
}
.supporter-article-section-img.img01::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: -29px;
  right: -90px;
  width: 312px;
  height: 200px;
  background: #0065ab;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-img.img01::before {
    top: -4.27vw;
    right: -14.13vw;
    width: 62.4vw;
    height: 40vw;
  }
}
.supporter-article-section-img.img02::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -20px;
  left: -150px;
  width: 233px;
  height: 202px;
  background: #009ddc;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-img.img02::before {
    bottom: -4vw;
    left: -14.13vw;
    width: 24.8vw;
    height: 40vw;
  }
}
.supporter-article-section-img.img03::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: -71px;
  right: -150px;
  width: 233px;
  height: 202px;
  background: #0065ab;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-img.img03::before {
    top: -4vw;
    right: -14.13vw;
    width: 24.8vw;
    height: 40vw;
  }
}
.supporter-article-section-img.img04::before {
  content: "";
  position: absolute;
  z-index: -1;
  bottom: -68px;
  left: -80px;
  width: 312px;
  height: 200px;
  background: #009ddc;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-img.img04::before {
    bottom: -9.33vw;
    left: -14.13vw;
    width: 62.4vw;
    height: 40vw;
  }
}
.supporter-article-section-img img {
  border-radius: 4px;
  width: 100%;

  aspect-ratio: 312 / 400;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center center;
     object-position: center center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-img img {
    border-radius: 1.07vw;

    aspect-ratio: 269 / 344;
  }
}

.supporter-article-section-ref {
  margin-top: 1.4em;
  padding-left: calc(13px + 3px);
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-ref {
    padding-left: 0;
  }
}

.supporter-article-section-noteList {
  margin-top: 1.4rem;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-noteList {
    margin-top: 0.8rem;
  }
}

.supporter-article-section-noteList.--pl-16 {
  padding-left: 16px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-noteList.--pl-16 {
    padding-left: 0;
  }
}

.supporter-article-section-note {
  padding-left: 1em;
  text-indent: -1em;
  line-height: 1.4;
  vertical-align: middle;
  font-size: 14px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-section-note {
    font-size: 13px;
  }
}

.supporter-article-section-note > a {
  font-size: inherit !important;
  color: #008eca;
}

.supporter-article-section-note + .supporter-article-section-note {
  margin-top: 0.5em;
}

.supporter-article-feature {
  padding: 69px 0 81px;
  background: #e1f3ff;
}
@media only screen and (max-width: 768px) {
  .supporter-article-feature {
    padding: 13.33vw 0 13.87vw;
  }
}

.supporter-article-feature-tip-wrapper {
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .supporter-article-feature-tip-wrapper {
    margin-bottom: 2.13vw;
  }
}

.supporter-article-feature-tip_lg {
  display: inline-block;
  margin: 0 auto 5px;
  width: 145px;
  height: 51px;
}

@media only screen and (max-width: 768px) {
  .supporter-article-feature-tip_sm {
    display: inline-block;
    margin: 0 auto 0.8vw;
    width: 32.53vw;
    height: 11.47vw;
  }
}

.supporter-article-feature-name_lg {
  display: inline-block;
  margin: 0 auto;
  width: 279px;
  height: 37px;
}

@media only screen and (max-width: 768px) {
  .supporter-article-feature-name_sm {
    display: inline-block;
    margin: 0 auto;
    width: 54.93vw;
    height: 7.2vw;
  }
}

.supporter-article-movie-wrap {
  display: block;
  position: relative;
  z-index: 1;
  margin: 22px auto 0;
  border-radius: 8px;
  width: 740px;
  background: #fff;
  box-shadow: rgba(0, 157, 220, 0.3) 0px 30px 20px -20px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-movie-wrap {
    width: 87.73vw;
    box-shadow: rgba(0, 157, 220, 0.3) 0px 20px 20px -20px;
  }
}
.supporter-article-movie-wrap > a {
  display: block;
  position: relative;
  margin: 23px auto 0;
  padding: 20px;
  border-radius: 8px;
}
@media only screen and (max-width: 768px) {
  .supporter-article-movie-wrap > a {
    padding: 3.47vw;
  }
}
.supporter-article-movie-wrap > a::after {
  content: "";
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  width: 100px;
  height: 100px;
  background: url(../img/supporter/icon_play.png) no-repeat 0 0/contain;
}
@media only screen and (max-width: 768px) {
  .supporter-article-movie-wrap > a::after {
    width: 50px;
    height: 50px;
  }
}

.supporter-article-feature-bg {
  display: none;
}
@media only screen and (max-width: 768px) {
  .supporter-article-feature-bg {
    display: inline-block;
    position: relative;
    margin: -1vw 1.6vw 0 auto;
    width: 41.6vw;
    height: 12.27vw;
    background: url(../img/supporter/supporter_article_item_text.png) no-repeat center/100% auto;
  }
}

.supporter-recommend {
  padding: 102px 0 106px;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend {
    padding: 15.47vw 0 16vw;
  }
}

.supporter-recommend-heading {
  display: inline-block;
  position: relative;
  margin: 0 auto 12px;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-heading {
    margin: 0 auto 2.67vw;
  }
}
.supporter-recommend-heading::before {
  content: "";
  display: inline-block;
  position: absolute;
  bottom: -12px;
  left: 50%;
  width: 102%;
  height: 2px;
  -webkit-transform: translateX(-50%);
          transform: translateX(-50%);
  background: #0065ab;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-heading::before {
    bottom: -2.67vw;
  }
}
.supporter-recommend-heading img {
  width: 100%;
}

.supporter-recommend-heading_lg {
  width: 293px;
  height: 24px;
}

@media only screen and (max-width: 768px) {
  .supporter-recommend-heading_sm {
    width: 66.13vw;
    height: 5.6vw;
  }
}

.supporter-recommend-list {
  display: flex;
  margin: 0 auto;
  padding: 50px 0 0;
  max-width: 1000px;

  justify-content: space-between;
}
@media only screen and (max-width: 1000px) {
  .supporter-recommend-list {
    flex-direction: column;

    align-items: center;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-list {
    display: block;
    padding: 13.33vw 0 0;
  }
}

.supporter-recommend-item {
  position: relative;
  z-index: 1;
  border-radius: 4px;
  width: 480px;
  min-height: 220px;
  transition: opacity 0.3s ease-in;
  background: #fff;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item {
    margin: 0 auto;
    width: 87.73vw;
    min-height: 40vw;
  }
}
@media only screen and (max-width: 1000px) {
  .supporter-recommend-item + .supporter-recommend-item {
    margin: 50px auto 0;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item + .supporter-recommend-item {
    margin: 6.7vw auto 0;
  }
}
.supporter-recommend-item::before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 0;
  left: 0;
  border-radius: 4px;
  width: 100%;
  height: 100%;
  background: #fff;
}
.supporter-recommend-item.item-left::after {
  content: "";
  display: inline-block;
  position: absolute;
  z-index: -1;
  bottom: -49px;
  left: -43px;
  width: 130px;
  height: 86px;
  background: #0064a9;
}
@media only screen and (max-width: 1000px) {
  .supporter-recommend-item.item-left::after {
    bottom: calc(100% - 112px);
    left: calc(100% - 92px);
    width: 200px;
    height: 131px;
    background: #009bdc;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item.item-left::after {
    bottom: calc(100% - 23.2vw);
    left: calc(100% - 32vw);
    width: 40vw;
    height: 26.67vw;
    background: #009bdc;
  }
}
.supporter-recommend-item.item-right::after {
  content: "";
  display: inline-block;
  position: absolute;
  z-index: -1;
  top: -20px;
  right: -108px;
  width: 200px;
  height: 132px;
  background: #009bdc;
}
@media only screen and (max-width: 1000px) {
  .supporter-recommend-item.item-right::after {
    top: calc(100% - 48px);
    right: calc(100% - 42px);
    width: 130px;
    height: 86px;
    background: #0064a9;
  }
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item.item-right::after {
    top: calc(100% - 8.8vw);
    right: calc(100% - 20vw);
    width: 26.13vw;
    height: 17.07vw;
    background: #0064a9;
  }
}
.supporter-recommend-item > a {
  display: flex;
  position: relative;
  border-radius: 4px;
  width: 480px;
  min-height: 220px;
  background: #fff;
  text-decoration: none;
  box-shadow: rgba(0, 157, 220, 0.2) 0px 24px 38px -10px;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item > a {
    border-radius: 1.07vw;
    width: 87.73vw;
    min-height: 40vw;
    box-shadow: rgba(0, 157, 220, 0.2) 0px 25px 17px -20px;
  }
}
.supporter-recommend-item > a::before {
  content: "";
  display: inline-block;
  position: absolute;
  right: 0;
  bottom: 0;
  border-bottom-right-radius: 4px;
  width: 30px;
  height: 30px;
  background: #0065ab;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item > a::before {
    border-bottom-right-radius: 1.07vw;
    width: 6.13vw;
    height: 6.13vw;
  }
}
.supporter-recommend-item > a::after {
  content: "";
  display: inline-block;
  position: absolute;
  right: 12px;
  bottom: 11px;
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  width: 7px;
  height: 7px;
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item > a::after {
    right: 2.67vw;
    bottom: 2.13vw;
    width: 1.5vw;
    height: 1.5vw;
  }
}

.supporter-recommend-item-img {
  display: block;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
  width: 168px;
  height: 220px;

  flex-shrink: 0;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-img {
    border-top-left-radius: 1.07vw;
    border-bottom-left-radius: 1.07vw;
    width: 31vw;
    height: 40vw;
  }
}
.supporter-recommend-item-img.img01 {
  background: url(../img/supporter/supporter_recommend_img01_lg.png) no-repeat center/cover;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-img.img01 {
    background: url(../img/supporter/supporter_recommend_img01_sm.png) no-repeat center/cover;
  }
}
.supporter-recommend-item-img.img02 {
  background: url(../img/supporter/supporter_recommend_img02_lg.png) no-repeat center/cover;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-img.img02 {
    background: url(../img/supporter/supporter_recommend_img02_sm.png) no-repeat center/cover;
  }
}
.supporter-recommend-item-img.img03 {
  background: url(../img/supporter/supporter_recommend_img03_lg.png) no-repeat center/cover;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-img.img03 {
    background: url(../img/supporter/supporter_recommend_img03_sm.png) no-repeat center/cover;
  }
}

.supporter-recommend-item-content {
  display: flex;
  flex-direction: column;
  padding: 44px 25px 36px 26px;
  text-align: justify;
  text-justify: inter-ideograph;

  justify-content: space-between;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-content {
    padding: 4.8vw 6.13vw 3.2vw 5.33vw;
  }
}

.supporter-recommend-item-text {
  position: relative;
  z-index: 1;
  letter-spacing: 0.001em;
  font-family: "Sawarabi Mincho", serif;
  font-size: 20px;
  line-height: 1.55;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-text {
    font-size: 4.27vw;
    line-height: 1.375;
  }
}
.supporter-recommend-item-text::before {
  content: "";
  display: inline-block;
  position: absolute;
  z-index: -1;
  top: -15px;
  left: -17px;
  width: 35px;
  height: 28px;
  background: url(../img/supporter/supporter_recommend_item_quote_lg.png) no-repeat left top/100% auto;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-text::before {
    top: -2.3vw;
    left: -2.93vw;
    width: 5.6vw;
    height: 4.8vw;
    background: url(../img/supporter/supporter_recommend_item_quote_sm.png) no-repeat left top/100% auto;
  }
}

.supporter-recommend-item-name {
  letter-spacing: 0.1em;
  font-size: 18px;
  font-weight: bold;
}
@media only screen and (max-width: 768px) {
  .supporter-recommend-item-name {
    font-size: 4.8vw;
  }
}

/* -----------------------------------
  モーダル
----------------------------------- */
body .mfp-bg {
  opacity: 0.9;
  background: #e2f5ff;
}

body .mfp-wrap {
  position: relative;
  z-index: 100000000;
}
@media only screen and (max-width: 768px) {
  body .mfp-wrap {
    height: 100vh;
  }
}

body .mfp-container {
  padding: 70px 8px 0;
}
@media only screen and (max-width: 768px) {
  body .mfp-container {
    padding: 0 6px;
  }
}
body .mfp-container .mfp-content .mfp-close {
  position: absolute;
  top: -52px;
  right: 0;
  width: 42px;
  height: 40.385px;
  font-size: 0;
  line-height: 40.385px;
}
body .mfp-container .mfp-content img.mfp-img {
  padding: 0 0 40px;
}
body .mfp-container .mfp-content .mfp-figure:after {
  background: none;
  box-shadow: none;
}

@media only screen and (min-width: 768.9px) {
  html.js-modal-absolute {
    overflow: hidden auto !important;
  
    .mfp-container,
    .mfp-content {
      height: 100%;
    }
  
    .mfp-wrap {
      overflow: auto !important;
      position: absolute;
      top: 0;
      height: 5000px;
    }
  }
}

/* ユーティリティ */
.font_mincho {
  font-family: "Sawarabi Mincho", serif;
}

.text_stuff {
  letter-spacing: -0.065em;
}

.stuff_both {
  margin-right: -0.2em;
  margin-left: -0.2em;
}

.stuff_right {
  margin-right: -0.5em;
}

.pre-wrap_pc {
  white-space: pre;
}
@media only screen and (max-width: 768px) {
  .pre-wrap_pc {
    white-space: normal;
  }
}

@media only screen and (max-width: 768px) {
  .block_sp {
    display: block;
  }
}
.ppt {
font-size: 23px;
  font-weight: 600;
  color: #533F02 !important;
font-weight: bold;
}
