/* ==========================================================================
  component
========================================================================== */
.c-news-list {
  border-bottom: 1px solid var(--color-gray);
  list-style: none;
  padding: 0;
}

.c-card--news {
  align-items: center;
  border-top: 1px solid var(--color-gray);
  color: var(--color-text);
  display: grid;
  grid-template-areas: "date label" "title title";
  grid-template-columns: auto 1fr;
  column-gap: calc(15 / 375 * 100vw);
  row-gap: calc(10 / 375 * 100vw);
  padding-block: calc(15 / 375 * 100vw);
  text-decoration: none;
  background-color: transparent;
  box-shadow: none;
}
.c-card--news::after {
  content: none;
}
.c-card--news:hover .c-card--news__title {
  text-decoration: underline;
}
@media (min-width: 782px) {
  .c-card--news {
    grid-template-areas: "date label title";
    grid-template-columns: 7em min(130px, 130 / 960 * 100vw) 1fr;
    column-gap: min(20px, 20 / 960 * 100vw);
    row-gap: 0;
    padding-block: min(20px, 20 / 960 * 100vw);
  }
}

.c-card--news__date {
  font-size: calc(14 / 375 * 100vw);
  grid-area: date;
}
@media (min-width: 782px) {
  .c-card--news__date {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

.c-card--news__label {
  align-items: center;
  background-color: var(--color-gray);
  border-radius: 3px;
  color: var(--color-white);
  display: flex;
  font-size: calc(12 / 375 * 100vw);
  grid-area: label;
  justify-content: center;
  justify-self: end;
  letter-spacing: 0.05em;
  line-height: 1;
  padding: 0.4em 0.8em;
  min-width: calc(88 / 375 * 100vw);
}
.c-card--news__label.is-pressrelease {
  background-color: #79A6E1;
}
.c-card--news__label.is-media {
  background-color: #D5B037;
}
.c-card--news__label.is-information {
  background-color: #E99696;
}
@media (min-width: 782px) {
  .c-card--news__label {
    font-size: min(16px, 16 / 960 * 100vw);
    justify-self: stretch;
    min-width: min(130px, 130 / 960 * 100vw);
  }
}

.c-card--news__title {
  font-size: calc(16 / 375 * 100vw);
  grid-area: title;
  line-height: 1.6;
  margin: 0;
}
@media (min-width: 782px) {
  .c-card--news__title {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

.c-member {
  display: flex;
  flex-direction: column;
  gap: calc(40 / 375 * 100vw);
  position: relative;
  z-index: 2;
}
@media (min-width: 782px) {
  .c-member {
    flex-direction: row-reverse;
    gap: min(60px, 60 / 960 * 100vw);
  }
}

@media (min-width: 782px) {
  .c-member__main {
    width: min(795px, 795 / 960 * 100vw);
  }
}

@media (min-width: 782px) {
  .c-member__aside {
    width: min(376px, 376 / 960 * 100vw);
  }
}

.c-member__image {
  margin-bottom: calc(30 / 375 * 100vw);
}
.c-member__image img {
  border-radius: 15px;
  aspect-ratio: 1;
  display: block;
  height: auto;
  object-fit: cover;
  width: 100%;
}
@media (min-width: 782px) {
  .c-member__image {
    margin-bottom: min(30px, 30 / 960 * 100vw);
  }
}

.c-member__header {
  display: flex;
  flex-direction: column;
  gap: calc(20 / 375 * 100vw);
}
@media (min-width: 782px) {
  .c-member__header {
    gap: min(25px, 25 / 960 * 100vw);
  }
}

.c-member__position {
  font-size: calc(16 / 375 * 100vw);
  margin: 0;
}
@media (min-width: 782px) {
  .c-member__position {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

.c-member__name {
  display: flex;
  gap: 1em;
  align-items: baseline;
  font-size: calc(24 / 375 * 100vw);
  font-weight: var(--font-bold);
  line-height: 1.4;
  margin: 0;
}
@media (min-width: 782px) {
  .c-member__name {
    font-size: min(24px, 24 / 960 * 100vw);
  }
}

.c-member__ruby {
  font-size: calc(13 / 375 * 100vw);
  font-weight: var(--font-normal);
}
@media (min-width: 782px) {
  .c-member__ruby {
    font-size: min(14px, 14 / 960 * 100vw);
  }
}

.c-member__content {
  margin-top: calc(30 / 375 * 100vw);
}
@media (min-width: 782px) {
  .c-member__content {
    margin-top: min(40px, 40 / 960 * 100vw);
  }
}

.c-member__footer {
  margin-top: calc(40 / 375 * 100vw);
  text-align: center;
}
@media (min-width: 782px) {
  .c-member__footer {
    margin-top: min(60px, 60 / 960 * 100vw);
  }
}

.c-member-lead {
  font-size: calc(18 / 375 * 100vw);
  margin: 0;
}
@media (min-width: 782px) {
  .c-member-lead {
    font-size: min(18px, 18 / 960 * 100vw);
  }
}

.c-member-grid {
  display: grid;
  gap: calc(20 / 375 * 100vw);
  grid-template-columns: repeat(2, 1fr);
  list-style: none;
  margin: calc(30 / 375 * 100vw) 0 0;
  padding: 0;
}
@media (min-width: 782px) {
  .c-member-grid {
    gap: min(20px, 20 / 1210 * 100vw) min(70px, 70 / 1210 * 100vw);
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    margin-top: min(70px, 70 / 1210 * 100vw);
  }
}

.c-card--member {
  color: var(--color-text);
  display: block;
  text-decoration: none;
}
.c-card--member:hover {
  color: var(--color-teal);
}

.c-card--member__image {
  aspect-ratio: 1;
  border-radius: 10px;
  margin-bottom: calc(12 / 375 * 100vw);
  overflow: hidden;
}
.c-card--member__image img {
  display: block;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
  width: 100%;
}
.c-card--member:hover .c-card--member__image img {
  opacity: 1;
  transform: scale(1.05);
}
@media (min-width: 782px) {
  .c-card--member__image {
    margin-bottom: min(12px, 12 / 960 * 100vw);
  }
}

.c-card--member__body {
  display: flex;
  flex-direction: column;
  gap: calc(4 / 375 * 100vw);
  text-align: center;
}
@media (min-width: 782px) {
  .c-card--member__body {
    gap: min(4px, 4 / 960 * 100vw);
  }
}

.c-card--member__name {
  font-size: calc(16 / 375 * 100vw);
  font-weight: var(--font-normal);
  margin: 0;
}
@media (min-width: 782px) {
  .c-card--member__name {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

.c-card--member__ruby {
  font-size: calc(12 / 375 * 100vw);
  margin: 0;
}
@media (min-width: 782px) {
  .c-card--member__ruby {
    font-size: min(12px, 12 / 960 * 100vw);
  }
}

.c-card--member__position {
  font-size: calc(14 / 375 * 100vw);
  margin: 0;
}
@media (min-width: 782px) {
  .c-card--member__position {
    font-size: min(14px, 14 / 960 * 100vw);
  }
}

/* ==========================================================================
  c-company-logo-list
========================================================================== */
.c-company-logo-list {
  display: grid;
  gap: calc(30 / 375 * 100vw);
  grid-template-columns: repeat(3, 1fr);
  list-style: none;
  margin: 0;
  padding: 0;
}
@media (min-width: 782px) {
  .c-company-logo-list {
    --column-size: min(98px, calc((98 / 1210) * 100vw));
    grid-template-columns: repeat(auto-fill, minmax(var(--column-size), 1fr));
    gap: min(40px, 40 / 960 * 100vw);
  }
}

.c-company-logo-list__item {
  align-items: center;
  display: flex;
  justify-content: center;
}
.c-company-logo-list__item img {
  display: block;
  height: auto;
  max-height: calc(40 / 375 * 100vw);
  object-fit: contain;
  width: 100%;
}
@media (min-width: 782px) {
  .c-company-logo-list__item img {
    max-height: min(50px, 50 / 960 * 100vw);
  }
}

/* ==========================================================================
  project
========================================================================== */
.p-event-section {
  margin-top: calc(40 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-event-section {
    margin-top: min(110px, 110 / 960 * 100vw);
  }
}
.p-event-section .c-card-list {
  margin-top: calc(30 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-event-section .c-card-list {
    margin-top: min(40px, 40 / 960 * 100vw);
  }
}

.p-event-section__empty {
  margin-top: calc(20 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-event-section__empty {
    margin-top: min(30px, 30 / 960 * 100vw);
  }
}

.p-event-section__more {
  margin-top: calc(30 / 375 * 100vw);
  text-align: right;
}
@media (min-width: 782px) {
  .p-event-section__more {
    margin-top: min(30px, 30 / 960 * 100vw);
  }
}

/* ==========================================================================
  p-top-kv
========================================================================== */
.p-top-kv {
  position: relative;
}
@media (min-width: 782px) {
  .p-top-kv {
    margin-top: calc(var(--header-height) * -1);
  }
}

.p-top-kv__title {
  color: var(--color-text);
  font-size: calc(42 / 375 * 100vw);
  font-weight: var(--font-normal);
  left: calc(20 / 375 * 100vw);
  letter-spacing: 0.1em;
  line-height: 1.6;
  margin: 0;
  position: absolute;
  top: calc(15 / 375 * 100vw);
  z-index: 3;
}
@media (min-width: 782px) {
  .p-top-kv__title {
    font-size: min(86px, 86 / 1920 * 100vw);
    left: min(160px, 160 / 1920 * 100vw);
    line-height: 1.5;
    top: calc(min(55px, 55 / 1920 * 100vw) + var(--header-height));
  }
}

.p-top-kv__badges {
  bottom: calc(50 / 375 * 100vw);
  display: flex;
  gap: calc(10 / 375 * 100vw);
  left: calc(20 / 375 * 100vw);
  list-style: none;
  margin: 0;
  padding: 0;
  position: absolute;
  z-index: 3;
}
@media (min-width: 782px) {
  .p-top-kv__badges {
    bottom: min(90px, 90 / 1920 * 100vw);
    gap: min(30px, 30 / 1920 * 100vw);
    left: min(160px, 160 / 1920 * 100vw);
  }
}

.p-top-kv__badge {
  margin: 0;
  width: calc(56 / 375 * 100vw);
}
.p-top-kv__badge img {
  display: block;
  width: 100%;
}
@media (min-width: 782px) {
  .p-top-kv__badge {
    width: min(100px, 100 / 1920 * 100vw);
  }
}

.p-top-kv__slider {
  width: 100%;
}

.p-top-kv__slide img {
  display: block;
  height: auto;
  width: 100%;
}

/* ==========================================================================
  p-top-about
========================================================================== */
.p-top-about {
  padding-top: calc(5 / 375 * 100vw);
  padding-bottom: calc(50 / 375 * 100vw);
  overflow: hidden;
  position: relative;
}
.p-top-about::before {
  background-image: url("../images/bg/bg-ribon-sp.webp");
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: right top;
  content: "";
  display: block;
  height: 97.3333333333vw;
  width: 100vw;
  position: absolute;
  right: 0;
  top: 0;
  z-index: -1;
}
@media (min-width: 782px) {
  .p-top-about {
    padding-top: min(110px, 110 / 960 * 100vw);
    padding-bottom: min(130px, 130 / 960 * 100vw);
  }
  .p-top-about::before {
    background-image: url("../images/bg/bg-ribon.webp");
    height: 39.0625vw;
  }
}

.p-top-about__inner {
  gap: calc(45 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-about__inner {
    align-items: flex-start !important;
    justify-content: space-between;
    flex-wrap: nowrap;
    gap: min(40px, 40 / 960 * 100vw) !important;
  }
}

@media (min-width: 782px) {
  .p-top-about__content {
    max-width: 780px;
    padding-top: min(60px, 60 / 960 * 100vw);
    width: min(780px, 780 / 1920 * 100vw);
  }
}
.p-top-about__content .wp-block-paragraph {
  font-size: calc(16 / 375 * 100vw);
  text-align: justify;
}
@media (min-width: 782px) {
  .p-top-about__content .wp-block-paragraph {
    font-size: min(18px, 18 / 960 * 100vw);
    max-width: min(570px, 570 / 960 * 100vw);
    line-height: 2.2;
  }
}

.p-top-about__title {
  font-size: calc(24 / 375 * 100vw);
  font-weight: var(--font-mid);
  line-height: 1.6;
  margin-top: 0;
  margin-bottom: calc(20 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-about__title {
    font-size: min(36px, 36 / 960 * 100vw);
    margin-bottom: min(60px, 60 / 960 * 100vw);
  }
  .p-top-about__title br {
    display: none;
  }
}

.p-top-about__media {
  margin-inline: calc(var(--m) * -1) !important;
}
@media (min-width: 782px) {
  .p-top-about__media {
    margin-top: 0;
    margin-left: 0 !important;
    width: min(940px, 940 / 1920 * 100vw);
  }
}

.p-top-about__photos {
  display: block !important;
  position: relative;
  aspect-ratio: 375/320;
}
@media (min-width: 782px) {
  .p-top-about__photos {
    aspect-ratio: 9/7;
    max-height: 700px;
    max-width: 900px;
    margin-left: max(0px, (100vw - 1600px) * 0.125);
  }
}
.p-top-about__photos.wp-block-gallery {
  flex-wrap: unset !important;
}
.p-top-about__photos .wp-block-image {
  flex: unset !important;
  max-width: unset !important;
  margin: 0 !important;
  position: absolute !important;
}
.p-top-about__photos .wp-block-image img {
  display: block !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
.p-top-about__photos .wp-block-image.is-left_top {
  top: calc(22 / 375 * 100vw);
  left: calc(16 / 375 * 100vw);
  width: calc(216 / 375 * 100vw) !important;
  z-index: 3;
}
@media (min-width: 782px) {
  .p-top-about__photos .wp-block-image.is-left_top {
    top: min(70px, 70 / 1920 * 100vw);
    left: 0;
    width: min(544px, 544 / 1920 * 100vw) !important;
  }
}
.p-top-about__photos .wp-block-image.is-right_top {
  top: 0;
  right: calc(28 / 375 * 100vw);
  width: calc(136 / 375 * 100vw) !important;
  z-index: 2;
}
@media (min-width: 782px) {
  .p-top-about__photos .wp-block-image.is-right_top {
    right: min(70px, 70 / 1920 * 100vw);
    width: min(340px, 340 / 1920 * 100vw) !important;
  }
}
.p-top-about__photos .wp-block-image.is-left_bottom {
  bottom: 0;
  left: 0;
  width: calc(152 / 375 * 100vw) !important;
}
@media (min-width: 782px) {
  .p-top-about__photos .wp-block-image.is-left_bottom {
    left: min(30px, 30 / 1920 * 100vw);
    width: min(297px, 297 / 1920 * 100vw) !important;
  }
}
.p-top-about__photos .wp-block-image.is-right_bottom {
  aspect-ratio: 187/154;
  bottom: calc(20 / 375 * 100vw);
  right: 0;
  width: calc(187 / 375 * 100vw) !important;
  z-index: 4;
}
@media (min-width: 782px) {
  .p-top-about__photos .wp-block-image.is-right_bottom {
    aspect-ratio: unset;
    bottom: min(16px, 16 / 1920 * 100vw);
    width: min(437px, 437 / 1920 * 100vw) !important;
  }
}

/* ==========================================================================
  p-top-news
========================================================================== */
.p-top-news {
  overflow-x: clip;
  margin-bottom: min(70px, 70 / 1920 * 100vw);
  padding-top: calc(50 / 375 * 100vw);
  padding-bottom: calc(45 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-news {
    padding-top: min(70px, 70 / 1920 * 100vw);
    padding-bottom: min(65px, 65 / 1920 * 100vw);
    position: relative;
  }
  .p-top-news::before {
    background-image: url("../images/bg/bg-line-f.png");
    background-size: 100%;
    content: "";
    display: block;
    height: 28.6458333333vw;
    width: 109.8958333333vw;
    mix-blend-mode: multiply;
    opacity: 0.75;
    position: absolute;
    bottom: -3.6458333333vw;
    left: -5.46875vw;
  }
}

.p-top-news__heading {
  display: flex;
  align-items: baseline;
  gap: 0.5em;
  margin-bottom: calc(25 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-news__heading {
    gap: min(20px, 20 / 960 * 100vw);
    margin-bottom: min(50px, 50 / 960 * 100vw);
  }
}

.p-top-news__title {
  font-size: calc(24 / 375 * 100vw);
  font-weight: var(--font-mid);
  letter-spacing: 0.2em;
  line-height: 1;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-news__title {
    font-size: min(32px, 32 / 960 * 100vw);
  }
}

.p-top-news__en {
  font-size: calc(16 / 375 * 100vw);
  font-weight: var(--font-normal);
  font-family: var(--font-roboto);
  line-height: 1;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-news__en {
    font-size: min(18px, 18 / 960 * 100vw);
  }
}

.p-top-news__footer {
  margin-top: calc(30 / 375 * 100vw);
  text-align: right;
  position: relative;
  z-index: 2;
}
@media (min-width: 782px) {
  .p-top-news__footer {
    margin-top: min(50px, 50 / 960 * 100vw);
  }
}

/* ==========================================================================
  p-top-service
========================================================================== */
.p-top-service {
  margin-top: calc(40 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-service {
    margin-top: min(130px, 130 / 960 * 100vw);
  }
}

.p-top-service__section {
  background-color: var(--color-mint);
  border-radius: 20px;
  max-width: 1350px;
  margin-inline: auto;
  padding: calc(25 / 375 * 100vw) calc(15 / 375 * 100vw) calc(30 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-service__section {
    padding: min(75px, 75 / 960 * 100vw) min(70px, 70 / 960 * 100vw);
  }
}

.p-top-service__heading {
  margin-bottom: calc(30 / 375 * 100vw);
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-service__heading {
    margin-bottom: min(50px, 50 / 960 * 100vw);
  }
}

.p-top-service__title {
  font-size: calc(18 / 375 * 100vw);
  font-weight: var(--font-mid);
  line-height: 1.4;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-service__title {
    font-size: min(32px, 32 / 960 * 100vw);
    line-height: 1.2;
  }
  .p-top-service__title br {
    display: none;
  }
}

.p-top-service__en {
  font-size: calc(16 / 375 * 100vw);
  font-weight: var(--font-normal);
  line-height: 1;
  margin: calc(10 / 375 * 100vw) 0 0;
}
@media (min-width: 782px) {
  .p-top-service__en {
    font-size: min(20px, 20 / 960 * 100vw);
    margin-top: min(12px, 12 / 960 * 100vw);
  }
}

.p-top-service__cards {
  display: flex;
  flex-direction: column;
  gap: calc(10 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-service__cards {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: min(40px, 40 / 960 * 100vw);
  }
}

.p-top-service__card {
  background-color: #fff;
  border-radius: 8px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
  overflow: hidden;
  margin: 0 !important;
  padding: calc(10 / 375 * 100vw);
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-service__card {
    padding: min(15px, 15 / 960 * 100vw) min(30px, 30 / 960 * 100vw) min(20px, 20 / 960 * 100vw);
  }
}
.p-top-service__card.has-link:hover .p-top-service__logo img {
  scale: 1.1;
}
.p-top-service__card.has-link:hover .p-top-service__bar {
  background-color: color-mix(in srgb, var(--color-bg), white 10%);
}

.p-top-service__logo {
  display: flex;
  align-items: center;
  justify-content: center;
  margin: 0 0 calc(10 / 375 * 100vw);
  min-height: calc(20 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-service__logo {
    min-height: min(55px, 55 / 960 * 100vw);
    margin-bottom: 0;
  }
}
.p-top-service__logo img {
  width: auto;
  max-width: 100%;
  transition: scale 0.3s;
}
.is-loandeal .p-top-service__logo img {
  max-height: calc(35 / 375 * 100vw);
}
.is-sideproject .p-top-service__logo img {
  max-height: calc(28 / 375 * 100vw);
}
.is-outsight .p-top-service__logo img {
  max-height: calc(28 / 375 * 100vw);
}
.is-willaction .p-top-service__logo img {
  max-height: calc(19 / 375 * 100vw);
}
@media (min-width: 782px) {
  .is-loandeal .p-top-service__logo img {
    max-height: min(55px, 55 / 960 * 100vw);
  }
  .is-sideproject .p-top-service__logo img {
    max-height: min(45px, 45 / 960 * 100vw);
  }
  .is-outsight .p-top-service__logo img {
    max-height: min(42px, 42 / 960 * 100vw);
  }
  .is-willaction .p-top-service__logo img {
    max-height: min(30px, 30 / 960 * 100vw);
  }
}

.p-top-service__bar {
  background-color: var(--color-bg);
  color: var(--color-white);
  font-size: calc(12 / 375 * 100vw);
  line-height: 1;
  margin: 0;
  padding: 0.4em 1em;
  transition: background 0.3s;
}
@media (min-width: 782px) {
  .p-top-service__bar {
    font-size: min(15px, 15 / 960 * 100vw);
  }
}
.is-loandeal .p-top-service__bar {
  --color-bg: #3c918d;
}
.is-sideproject .p-top-service__bar {
  --color-bg: #4d6589;
}
.is-outsight .p-top-service__bar {
  --color-bg: #a54a44;
}
.is-willaction .p-top-service__bar {
  --color-bg: #2b2c33;
}

.p-top-service__card > p:not(.p-top-service__bar) {
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.9;
  margin: 0;
  margin-top: calc(10 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-service__card > p:not(.p-top-service__bar) {
    font-size: min(16px, 16 / 960 * 100vw);
    margin-top: min(10px, 10 / 960 * 100vw);
  }
}

/* ==========================================================================
  p-top-mechanism
========================================================================== */
.p-top-mechanism {
  margin: calc(35 / 375 * 100vw) 0 0;
  padding-bottom: calc(80 / 375 * 100vw);
  position: relative;
  overflow: hidden;
}
.p-top-mechanism::before {
  background-image: url("../images/bg/bg-line-a.png");
  background-size: 100%;
  content: "";
  display: block;
  height: 136vw;
  width: 360vw;
  mix-blend-mode: multiply;
  opacity: 0.75;
  position: absolute;
  bottom: -32.8vw;
  right: -144.5333333333vw;
  z-index: -1;
}
@media (min-width: 782px) {
  .p-top-mechanism {
    margin-top: min(120px, 120 / 1920 * 100vw);
    padding-bottom: min(115px, 115 / 1920 * 100vw);
  }
  .p-top-mechanism::before {
    height: 49.4791666667vw;
    width: 130.2083333333vw;
    bottom: -9.1145833333vw;
    right: -23.6979166667vw;
  }
}

.p-top-mechanism__heading {
  margin-bottom: calc(30 / 375 * 100vw);
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-mechanism__heading {
    margin-bottom: min(50px, 50 / 960 * 100vw);
  }
}

.p-top-mechanism__subtitle {
  font-size: calc(16 / 375 * 100vw);
  line-height: 1;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-mechanism__subtitle {
    font-size: min(24px, 24 / 960 * 100vw);
  }
}

.p-top-mechanism__title {
  font-size: calc(24 / 375 * 100vw);
  font-weight: var(--font-normal);
  line-height: 1.4;
  margin: 0.5em 0 0;
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-mechanism__title {
    font-size: min(36px, 36 / 960 * 100vw);
  }
}

.p-top-mechanism__lead {
  margin-bottom: calc(60 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-mechanism__lead {
    margin-bottom: min(70px, 70 / 960 * 100vw);
  }
}
.p-top-mechanism__lead p {
  font-size: calc(14 / 375 * 100vw);
  line-height: 2;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-mechanism__lead p {
    font-size: min(20px, 20 / 960 * 100vw);
    text-align: center;
  }
}

.p-top-mechanism__diagram {
  margin: 0 0 calc(30 / 375 * 100vw) !important;
}
@media (min-width: 782px) {
  .p-top-mechanism__diagram {
    margin: 0 min(100px, 100 / 960 * 100vw);
    margin-inline: auto !important;
    max-width: 900px;
  }
}
.p-top-mechanism__diagram img {
  height: auto;
  width: 100%;
}

.p-top-mechanism__points {
  display: flex;
  flex-direction: column;
  gap: calc(20 / 375 * 100vw);
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-mechanism__points {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: auto auto;
    column-gap: min(40px, 40 / 960 * 100vw);
    row-gap: 0;
  }
}

.p-top-mechanism__point-item {
  display: flex;
  flex-direction: column;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-mechanism__point-item {
    display: grid;
    grid-row: span 2;
    grid-template-rows: subgrid;
  }
}

.p-top-mechanism__point {
  background-color: var(--color-gray-light);
  border-radius: 8px;
  overflow: hidden;
  margin: 0;
  padding: calc(20 / 375 * 100vw) calc(16 / 375 * 100vw) calc(24 / 375 * 100vw);
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-mechanism__point {
    padding: min(30px, 30 / 960 * 100vw) min(24px, 24 / 960 * 100vw) min(36px, 36 / 960 * 100vw);
  }
}

.p-top-mechanism__point-eyebrow {
  color: var(--color-teal);
  font-size: calc(16 / 375 * 100vw);
  font-weight: var(--font-mid);
  font-family: var(--font-roboto);
  letter-spacing: 0.15em;
  line-height: 1;
  margin: 0;
  margin-bottom: 0.5em;
}
@media (min-width: 782px) {
  .p-top-mechanism__point-eyebrow {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

.p-top-mechanism__point-num {
  color: var(--color-teal);
  font-size: calc(45 / 375 * 100vw);
  font-weight: var(--font-mid);
  font-family: var(--font-roboto);
  line-height: 1;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-mechanism__point-num {
    font-size: min(45px, 45 / 960 * 100vw);
  }
}

.p-top-mechanism__point-title {
  font-size: calc(18 / 375 * 100vw);
  font-weight: var(--font-normal);
  line-height: 1.6;
  margin: 0;
  margin-top: 0.5em;
}
@media (min-width: 782px) {
  .p-top-mechanism__point-title {
    font-size: min(18px, 18 / 960 * 100vw);
    margin: min(16px, 16 / 960 * 100vw) 0 min(20px, 20 / 960 * 100vw);
  }
}

.p-top-mechanism__point-img {
  margin: 0;
  margin-top: 2em;
}
.p-top-mechanism__point-img img {
  display: block;
  height: auto;
  width: 100%;
}

.p-top-mechanism__point > p:not(.p-top-mechanism__point-eyebrow):not(.p-top-mechanism__point-num):not(.p-top-mechanism__point-title) {
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.9;
  margin: 0;
  margin-top: 1em;
  text-align: justify;
}
@media (min-width: 782px) {
  .p-top-mechanism__point > p:not(.p-top-mechanism__point-eyebrow):not(.p-top-mechanism__point-num):not(.p-top-mechanism__point-title) {
    font-size: min(16px, 16 / 960 * 100vw);
    margin-top: min(20px, 20 / 960 * 100vw);
  }
}

.p-top-mechanism__note {
  color: var(--color-gray);
  font-size: calc(10 / 375 * 100vw);
  line-height: 1.7;
  margin: 1em 0 0;
}
@media (min-width: 782px) {
  .p-top-mechanism__note {
    font-size: min(12px, 12 / 960 * 100vw);
  }
}

/* ==========================================================================
  p-top-issue
========================================================================== */
.p-top-issue {
  background-color: var(--color-mint);
  margin: 0;
  padding-block: calc(50 / 375 * 100vw) calc(65 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue {
    padding-block: min(90px, 90 / 960 * 100vw);
  }
}

.p-top-issue__title {
  font-size: calc(28 / 375 * 100vw);
  font-weight: var(--font-normal);
  line-height: 1.4;
  margin: 0;
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-issue__title {
    font-size: min(32px, 32 / 960 * 100vw);
  }
  .p-top-issue__title br {
    display: none;
  }
}

.p-top-issue__cards {
  margin: calc(50 / 375 * 100vw) 0 0;
  display: flex;
  flex-direction: column;
  gap: calc(16 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue__cards {
    margin-top: min(50px, 50 / 960 * 100vw);
    display: grid;
    gap: min(30px, 30 / 960 * 100vw);
    grid-template-columns: repeat(3, 1fr);
  }
}

.p-top-issue__card {
  background-color: var(--color-white);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  margin: 0;
  padding: calc(30 / 375 * 100vw) calc(20 / 375 * 100vw) calc(20 / 375 * 100vw);
  position: relative;
}
@media (min-width: 782px) {
  .p-top-issue__card {
    padding: min(30px, 30 / 960 * 100vw) min(20px, 20 / 960 * 100vw);
  }
}
.p-top-issue__card:has(.p-top-issue__card-overlay:hover) .p-top-issue__card-title {
  color: var(--color-teal);
  text-decoration: underline;
}

.p-top-issue__card-overlay {
  appearance: none;
  background: none;
  border: none;
  cursor: pointer;
  inset: 0;
  margin: 0;
  padding: 0;
  position: absolute;
}

.p-top-issue__card-icon {
  margin: 0 auto;
  overflow: hidden;
  width: calc(120 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue__card-icon {
    width: min(125px, 125 / 960 * 100vw);
  }
}
.p-top-issue__card-icon img {
  display: block;
  height: auto;
  width: 100%;
}

.p-top-issue__card-title {
  font-size: calc(18 / 375 * 100vw);
  font-weight: var(--font-normal);
  line-height: 1.5;
  margin: 0.5em 0 0;
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-issue__card-title {
    font-size: min(20px, 20 / 960 * 100vw);
  }
}

.p-top-issue__card-desc {
  flex: 1;
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.9;
  margin: 1em 0 0;
}
@media (min-width: 782px) {
  .p-top-issue__card-desc {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

.p-top-issue__more {
  align-self: flex-end;
  font-family: var(--font-roboto);
  margin: calc(30 / 375 * 100vw) 0 0;
  padding: 0;
  position: relative;
  z-index: 1;
}
@media (min-width: 782px) {
  .p-top-issue__more {
    margin-top: min(30px, 30 / 960 * 100vw);
  }
}

.p-top-issue__footer {
  margin-top: calc(24 / 375 * 100vw);
  text-align: right;
}
@media (min-width: 782px) {
  .p-top-issue__footer {
    margin-top: min(30px, 30 / 960 * 100vw);
  }
}

/* ==========================================================================
  p-top-issue popup (Popover API)
========================================================================== */
.p-top-issue__popup {
  border: none;
  inset: 0;
  margin: auto;
  max-height: 90dvh;
  max-width: min(1200px, 100vw - 40px);
  overflow-y: auto;
  padding: 0;
  width: 100%;
  opacity: 0;
  transform: translateY(12px);
  transition: opacity 0.3s ease, transform 0.3s ease, display 0.3s allow-discrete, overlay 0.3s allow-discrete;
}
.p-top-issue__popup:popover-open {
  opacity: 1;
  transform: translateY(0);
}
@starting-style {
  .p-top-issue__popup:popover-open {
    opacity: 0;
    transform: translateY(12px);
  }
}
.p-top-issue__popup::backdrop {
  background-color: rgba(60, 145, 141, 0.2);
  backdrop-filter: blur(9px) brightness(0.85);
  opacity: 0;
  transition: opacity 0.3s ease, display 0.3s allow-discrete, overlay 0.3s allow-discrete;
}
.p-top-issue__popup:popover-open::backdrop {
  opacity: 1;
}
@starting-style {
  .p-top-issue__popup:popover-open::backdrop {
    opacity: 0;
  }
}

.p-top-issue__popup-upper {
  background-color: var(--color-mint);
  display: flex;
  flex-direction: column;
  position: relative;
}
@media (min-width: 782px) {
  .p-top-issue__popup-upper {
    align-items: stretch;
    flex-direction: row;
  }
}

.p-top-issue__popup-close-holder {
  height: 0;
  position: sticky;
  top: 0;
  z-index: 1;
}

.p-top-issue__popup-close {
  position: absolute;
  right: calc(7 / 375 * 100vw);
  top: calc(7 / 375 * 100vw);
}

.p-top-issue__popup-aside {
  align-items: center;
  display: flex;
  flex-direction: row;
  gap: calc(25 / 375 * 100vw);
  padding: calc(13 / 375 * 100vw) calc(25 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue__popup-aside {
    flex-direction: column;
    gap: min(30px, 30 / 960 * 100vw);
    justify-content: center;
    padding: min(20px, 20 / 960 * 100vw);
    width: min(300px, 300 / 960 * 100vw);
  }
}

.p-top-issue__popup-icon {
  flex-shrink: 0;
  margin: 0;
  overflow: hidden;
  width: calc(60 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue__popup-icon {
    width: min(130px, 130 / 960 * 100vw);
  }
}
.p-top-issue__popup-icon svg,
.p-top-issue__popup-icon img {
  display: block;
  height: auto;
  width: 100%;
}

.p-top-issue__popup-name {
  font-size: calc(16 / 375 * 100vw);
  line-height: 1.5;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-issue__popup-name {
    font-size: min(20px, 20 / 960 * 100vw);
    text-align: center;
  }
}

.p-top-issue__popup-body {
  background-color: var(--color-white);
  flex: 1;
  padding: calc(15 / 375 * 100vw) calc(20 / 375 * 100vw) calc(20 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue__popup-body {
    padding: min(35px, 35 / 960 * 100vw) min(50px, 50 / 960 * 100vw) min(50px, 50 / 960 * 100vw);
  }
}

.p-top-issue__popup-title {
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.7;
  margin: 0;
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-issue__popup-title {
    font-size: min(22px, 22 / 960 * 100vw);
  }
}

.p-top-issue__popup-points {
  display: grid;
  gap: calc(5 / 375 * 100vw);
  grid-template-columns: 1fr;
  list-style: none;
  margin: calc(15 / 375 * 100vw) 0 0;
  padding: 0;
}
@media (min-width: 782px) {
  .p-top-issue__popup-points {
    margin-top: min(40px, 40 / 960 * 100vw);
    gap: min(14px, 14 / 960 * 100vw);
    grid-template-columns: 1fr 1fr;
  }
}
.p-top-issue__popup-points li {
  background-color: var(--color-mint);
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.7;
  padding: calc(15 / 375 * 100vw);
  display: flex;
  align-items: center;
  overflow: hidden;
  justify-content: center;
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-issue__popup-points li {
    font-size: min(16px, 16 / 960 * 100vw);
    padding: min(20px, 20 / 960 * 100vw);
    word-break: keep-all;
  }
}

.p-top-issue__popup-sep {
  border-top: 2px solid var(--color-teal);
  color: var(--color-teal);
  display: flex;
  justify-content: center;
  line-height: 0;
  height: calc(23 / 375 * 100vw);
}
.p-top-issue__popup-sep::after {
  background: url("../images/icon/icon-yajirushi.svg") no-repeat center top;
  background-size: auto 100%;
  content: "";
  display: block;
  margin-top: -2px;
  height: calc(23 / 375 * 100vw);
  width: calc(50 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue__popup-sep {
    height: min(35px, 35 / 960 * 100vw);
  }
  .p-top-issue__popup-sep::after {
    height: min(35px, 35 / 960 * 100vw);
    width: min(75px, 75 / 960 * 100vw);
  }
}

.p-top-issue__popup-lower {
  background-color: var(--color-white);
  display: flex;
  flex-direction: column;
  padding: calc(15 / 375 * 100vw) calc(20 / 375 * 100vw) calc(20 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-issue__popup-lower {
    padding: min(15px, 15 / 960 * 100vw) min(45px, 45 / 960 * 100vw) min(45px, 45 / 960 * 100vw);
    align-items: stretch;
    gap: min(50px, 50 / 960 * 100vw);
    flex-direction: row;
  }
}

.p-top-issue__popup-services-label {
  align-items: center;
  background-color: var(--color-teal);
  color: var(--color-white);
  display: flex;
  font-size: calc(14 / 375 * 100vw);
  justify-content: center;
  padding: 0.5em 1em;
}
@media (min-width: 782px) {
  .p-top-issue__popup-services-label {
    font-size: min(20px, 20 / 960 * 100vw);
    width: min(255px, 255 / 960 * 100vw);
  }
}

.p-top-issue__popup-services {
  flex: 1;
  list-style: none;
  margin: 0;
}

.p-top-issue__popup-service {
  align-items: center;
  border-bottom: 1px solid var(--color-teal);
  display: flex;
  flex-direction: column;
  gap: calc(8 / 375 * 100vw);
  padding: calc(20 / 375 * 100vw) 0;
}
.p-top-issue__popup-service:last-child {
  border-bottom: none;
}
@media (min-width: 782px) {
  .p-top-issue__popup-service {
    flex-direction: row;
    gap: min(24px, 24 / 960 * 100vw);
    padding-block: min(14px, 14 / 960 * 100vw);
  }
}
.p-top-issue__popup-service p {
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.6;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-issue__popup-service p {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

.p-top-issue__popup-service-logo {
  flex-shrink: 0;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-issue__popup-service-logo {
    min-width: min(230px, 230 / 960 * 100vw);
  }
}
.p-top-issue__popup-service-logo img {
  display: block;
  height: auto;
  width: auto;
}
.is-loandeal .p-top-issue__popup-service-logo img {
  max-height: calc(35 / 375 * 100vw);
}
@media (min-width: 782px) {
  .is-loandeal .p-top-issue__popup-service-logo img {
    max-height: min(36px, 36 / 960 * 100vw);
  }
}
.is-sideproject .p-top-issue__popup-service-logo img {
  max-height: calc(30 / 375 * 100vw);
}
@media (min-width: 782px) {
  .is-sideproject .p-top-issue__popup-service-logo img {
    max-height: min(30px, 30 / 960 * 100vw);
  }
}
.is-outsight .p-top-issue__popup-service-logo img {
  max-height: calc(30 / 375 * 100vw);
}
@media (min-width: 782px) {
  .is-outsight .p-top-issue__popup-service-logo img {
    max-height: min(30px, 30 / 960 * 100vw);
  }
}
.is-willaction .p-top-issue__popup-service-logo img {
  max-height: calc(20 / 375 * 100vw);
}
@media (min-width: 782px) {
  .is-willaction .p-top-issue__popup-service-logo img {
    max-height: min(30px, 30 / 960 * 100vw);
  }
}

/* ==========================================================================
  p-top-clients
========================================================================== */
.p-top-clients {
  padding-block: calc(55 / 375 * 100vw) calc(80 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-clients {
    padding-block: min(125px, 125 / 960 * 100vw) min(145px, 145 / 960 * 100vw);
  }
}
.p-top-clients .is-pc {
  display: none;
}
@media (min-width: 782px) {
  .p-top-clients .is-pc {
    display: block;
  }
}
@media (min-width: 782px) {
  .p-top-clients .is-sp {
    display: none;
  }
}

.p-top-clients__lead {
  margin: 0;
  text-align: center;
}

.p-top-clients__title {
  color: var(--color-teal);
  display: inline-block;
  font-size: calc(24 / 375 * 100vw);
  font-weight: var(--font-normal);
  line-height: 1.3;
  margin: 0 !important;
  text-align: center;
  text-decoration: underline;
  text-underline-offset: 0.4em;
}
.p-top-clients__title strong {
  font-size: calc(48 / 375 * 100vw);
  font-weight: var(--font-mid);
}
@media (min-width: 782px) {
  .p-top-clients__title {
    font-size: min(38px, 38 / 960 * 100vw);
  }
  .p-top-clients__title strong {
    font-size: min(60px, 60 / 960 * 100vw);
  }
}

.p-top-clients__graph {
  margin: 1em auto 0;
}
.p-top-clients__graph img {
  display: block;
  height: auto;
  width: 100%;
}
@media (min-width: 782px) {
  .p-top-clients__graph {
    margin-top: min(30px, 30 / 960 * 100vw);
    max-width: 654px;
  }
}

.p-top-clients__body {
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.9;
  margin-top: calc(20 / 375 * 100vw);
  text-align: justify;
}
@media (min-width: 782px) {
  .p-top-clients__body {
    font-size: min(20px, 20 / 960 * 100vw);
    margin-top: min(45px, 45 / 960 * 100vw);
    text-align: center;
  }
}

.p-top-clients__logos {
  margin-top: calc(35 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-clients__logos {
    margin-top: min(60px, 60 / 960 * 100vw);
  }
}

.p-top-clients__logos-label {
  align-items: center;
  color: var(--color-teal);
  display: flex;
  font-size: calc(18 / 375 * 100vw);
  font-weight: var(--font-mid);
  gap: 1em;
  margin: 0 0 calc(20 / 375 * 100vw);
  white-space: nowrap;
}
@media (min-width: 782px) {
  .p-top-clients__logos-label {
    font-size: min(20px, 20 / 960 * 100vw);
    margin-bottom: min(40px, 40 / 960 * 100vw);
  }
}
.p-top-clients__logos-label::before, .p-top-clients__logos-label::after {
  background-color: currentcolor;
  content: "";
  display: block;
  flex: 1;
  height: 1px;
}

/* ==========================================================================
  p-top-members
========================================================================== */
.p-top-members {
  background-color: #768383;
  color: var(--color-white);
  overflow: hidden;
  margin: 0;
  padding-block: calc(65 / 375 * 100vw) calc(80 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-members {
    padding-block: min(110px, 110 / 960 * 100vw) min(120px, 120 / 960 * 100vw);
  }
}

.p-top-members__header {
  gap: min(75px, 75 / 960 * 100vw) !important;
  position: relative;
  z-index: 2;
}
@media (min-width: 782px) {
  .p-top-members__header .wp-block-column:first-child {
    flex: unset;
  }
}

.p-top-members__title {
  font-size: calc(24 / 375 * 100vw);
  font-weight: var(--font-normal);
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-members__title {
    font-size: min(38px, 38 / 960 * 100vw);
  }
}

.p-top-members__en {
  font-size: calc(16 / 375 * 100vw);
  font-family: var(--font-roboto);
  margin: 0.5em 0 0;
}
@media (min-width: 782px) {
  .p-top-members__en {
    font-size: min(20px, 20 / 960 * 100vw);
  }
}

.p-top-members__lead {
  font-size: calc(16 / 375 * 100vw);
  line-height: 1.9;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-members__lead {
    font-size: min(22px, 22 / 960 * 100vw);
    margin-top: 0;
  }
}

.p-top-members__photos {
  margin: calc(30 / 375 * 100vw) 0 0;
  margin-inline: calc(var(--m) * -1);
  padding-inline: var(--m);
  position: relative;
}
.p-top-members__photos::before, .p-top-members__photos::after {
  background: url("../images/bg/bg-line-f.png") no-repeat center center;
  background-size: 100%;
  content: "";
  display: block;
  height: 70.6666666667vw;
  width: 250.6666666667vw;
  position: absolute;
  transform: scale(1, -1);
  mix-blend-mode: color;
  z-index: 1;
}
.p-top-members__photos::before {
  top: 2.1333333333vw;
  left: -17.8666666667vw;
}
.p-top-members__photos::after {
  right: 0;
  bottom: 0;
}
@media (min-width: 782px) {
  .p-top-members__photos {
    margin-top: min(65px, 65 / 960 * 100vw);
  }
  .p-top-members__photos::before {
    height: 29.0625vw;
    width: 114.3229166667vw;
    top: 0.5208333333vw;
    left: -6.25vw;
  }
  .p-top-members__photos::after {
    content: unset;
  }
}

.p-top-members__photos-inner {
  background-image: url("../images/bg/bg-square-sp.svg");
  background-position: center top;
  background-repeat: repeat-x;
  background-size: 113.3333333333vw auto;
  margin: 0;
  margin-inline: calc(var(--m) * -1);
  padding-inline: var(--m);
  padding-block: calc(25 / 375 * 100vw) calc(55 / 375 * 100vw);
  position: relative;
  z-index: 2;
}
@media (min-width: 782px) {
  .p-top-members__photos-inner {
    background-image: url("../images/bg/bg-square.svg");
    background-size: min(2122px, 2122 / 1920 * 100vw);
    padding-block: min(50px, 50 / 1920 * 100vw) min(105px, 105 / 1920 * 100vw);
    position: static;
  }
}

.p-top-members__photo-list {
  display: grid;
  row-gap: calc(50 / 375 * 100vw);
  column-gap: calc(8 / 375 * 100vw);
  grid-template-columns: repeat(4, 1fr);
  list-style: none;
  margin: 0;
  padding: 0;
  position: relative;
  z-index: 2;
}
@media (min-width: 782px) {
  .p-top-members__photo-list {
    gap: min(15px, 15 / 1920 * 100vw);
    grid-template-columns: repeat(8, 1fr);
  }
}

.p-top-members__photo-item:nth-child(even) {
  margin-top: calc(35 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-members__photo-item:nth-child(even) {
    margin-top: min(65px, 65 / 1920 * 100vw);
  }
}

.p-top-members__photo-link {
  display: block;
}
.p-top-members__photo-link:hover .p-top-members__photo-image img {
  opacity: 1;
  transform: scale(1.05);
}

.p-top-members__photo-image {
  aspect-ratio: 1/2;
  overflow: hidden;
}
.p-top-members__photo-image img {
  display: block;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
  width: 100%;
  filter: grayscale(1);
}

.p-top-members__footer {
  margin: 0;
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-members__footer {
    text-align: right;
  }
}
.p-top-members__footer .c-button-more {
  border: 1px solid var(--color-white);
  border-radius: 5px;
  color: var(--color-white);
  font-size: calc(14 / 375 * 100vw);
  font-weight: var(--font-mid);
  padding: 1em 1.2em;
  width: calc(254 / 375 * 100vw);
  justify-content: space-between;
}
@media (min-width: 782px) {
  .p-top-members__footer .c-button-more {
    font-size: min(20px, 20 / 960 * 100vw);
    width: auto;
  }
}

/* ==========================================================================
  p-top-posts
========================================================================== */
.p-top-posts {
  margin: 0;
  padding-block: calc(60 / 375 * 100vw) calc(60 / 375 * 100vw);
  overflow: hidden;
  position: relative;
}
.p-top-posts:has(+ .p-top-posts) {
  padding-bottom: calc(30 / 375 * 100vw);
}
.p-top-posts + .p-top-posts {
  padding-top: calc(30 / 375 * 100vw);
}
.p-top-posts::before {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: 100%;
  content: "";
  display: block;
  opacity: 0.75;
  position: absolute;
  z-index: -1;
}
.p-top-posts.is-ribbon-top::before {
  background-image: url("../images/bg/bg-line-e.png");
  height: 64vw;
  width: 173.3333333333vw;
  top: -10.6666666667vw;
  right: -108.5333333333vw;
}
.p-top-posts.is-ribbon-bottom::before {
  background-image: url("../images/bg/bg-line-b.png");
  height: 93.3333333333vw;
  width: 114.6666666667vw;
  bottom: -10.1333333333vw;
  left: -10.1333333333vw;
}
@media (min-width: 782px) {
  .p-top-posts {
    padding-block: min(120px, 120 / 960 * 100vw) min(120px, 120 / 960 * 100vw);
  }
  .p-top-posts:has(+ .p-top-posts) {
    padding-bottom: min(60px, 60 / 960 * 100vw);
  }
  .p-top-posts + .p-top-posts {
    padding-top: min(60px, 60 / 960 * 100vw);
  }
  .p-top-posts.is-ribbon-top::before {
    height: 29.4270833333vw;
    width: 82.03125vw;
    top: -4.1666666667vw;
    right: -43.75vw;
  }
  .p-top-posts.is-ribbon-bottom::before {
    background-image: url("../images/bg/bg-line-b.png");
    height: 40.8854166667vw;
    width: 51.0416666667vw;
    bottom: -4.1666666667vw;
    left: -4.1666666667vw;
  }
}

.p-top-posts__header {
  margin: 0;
  text-align: center;
}

.p-top-posts__title {
  font-size: calc(24 / 375 * 100vw);
  font-weight: var(--font-normal);
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-posts__title {
    font-size: min(36px, 36 / 960 * 100vw);
  }
}

.p-top-posts__en {
  font-family: var(--font-roboto);
  font-size: calc(16 / 375 * 100vw);
  font-weight: var(--font-mid);
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-posts__en {
    font-size: min(20px, 20 / 960 * 100vw);
  }
}

.p-top-posts__list {
  margin: calc(25 / 375 * 100vw) 0 0;
}
@media (min-width: 782px) {
  .p-top-posts__list {
    margin-top: min(60px, 60 / 960 * 100vw);
  }
}

.p-top-posts__footer {
  margin-top: calc(25 / 375 * 100vw);
  text-align: right;
}
@media (min-width: 782px) {
  .p-top-posts__footer {
    margin-top: min(40px, 40 / 960 * 100vw);
  }
  .p-top-posts__footer .c-button-more {
    font-size: min(16px, 16 / 960 * 100vw);
  }
}

/* ==========================================================================
  p-top-services
========================================================================== */
.p-top-services {
  background-color: #E7EAE9;
  margin: 0;
  padding-block: calc(45 / 375 * 100vw) calc(65 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-services {
    padding-block: min(115px, 115 / 960 * 100vw) min(120px, 120 / 960 * 100vw);
  }
}

.p-top-services__heading {
  margin: 0;
  text-align: center;
}

.p-top-services__title {
  font-size: calc(18 / 375 * 100vw);
  font-weight: var(--font-normal);
  line-height: 1.6;
  margin: 0;
}
@media (min-width: 782px) {
  .p-top-services__title {
    font-size: min(28px, 28 / 960 * 100vw);
  }
  .p-top-services__title br {
    display: none;
  }
}

.p-top-services__en {
  font-family: var(--font-roboto);
  font-size: calc(16 / 375 * 100vw);
  font-weight: var(--font-mid);
  line-height: 1;
  margin: 0.5em 0 0;
}
@media (min-width: 782px) {
  .p-top-services__en {
    font-size: min(20px, 20 / 960 * 100vw);
  }
}

.p-top-services__list {
  display: flex;
  flex-direction: column;
  gap: calc(20 / 375 * 100vw);
  margin: calc(40 / 375 * 100vw) 0 0;
}
@media (min-width: 782px) {
  .p-top-services__list {
    margin-top: min(60px, 60 / 960 * 100vw);
    gap: min(30px, 30 / 960 * 100vw);
  }
}

.p-top-services__card {
  background-color: #fff;
  border-radius: 10px;
  box-shadow: rgba(0, 0, 0, 0.1) 0px 4px 12px;
  display: grid;
  grid-template-columns: 1fr;
  margin: 0 !important;
  overflow: hidden;
}
@media (min-width: 782px) {
  .p-top-services__card {
    grid-template-columns: 1fr 1.9fr;
  }
}
.p-top-services__card.has-link:hover .p-top-services__photo img {
  scale: 1.1;
}

.p-top-services__photo {
  aspect-ratio: 345/136;
  margin: 0 !important;
  overflow: hidden;
  position: relative;
}
@media (min-width: 782px) {
  .p-top-services__photo {
    aspect-ratio: auto;
    height: 100%;
  }
}
.p-top-services__photo::after {
  background-color: var(--color-teal);
  content: "";
  filter: brightness(0.9);
  inset: 0;
  opacity: 0.25;
  pointer-events: none;
  position: absolute;
}
.p-top-services__photo img {
  display: block;
  height: 100%;
  object-fit: cover;
  object-position: center 5%;
  width: 100%;
  transition: scale 0.3s;
}

.p-top-services__body {
  align-items: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  margin: 0 !important;
  padding: calc(10 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-services__body {
    padding: min(20px, 20 / 960 * 100vw) min(65px, 65 / 960 * 100vw);
  }
}

.p-top-services__logo {
  align-items: center;
  display: flex;
  justify-content: center;
  margin: 0 !important;
  min-height: calc(30 / 375 * 100vw);
}
@media (min-width: 782px) {
  .p-top-services__logo {
    min-height: min(50px, 50 / 960 * 100vw);
  }
}
.p-top-services__logo img {
  height: 100%;
  width: auto;
  max-width: 100%;
}
.is-loandeal .p-top-services__logo img {
  max-height: calc(35 / 375 * 100vw);
}
.is-sideproject .p-top-services__logo img {
  max-height: calc(28 / 375 * 100vw);
}
.is-outsight .p-top-services__logo img {
  max-height: calc(28 / 375 * 100vw);
}
.is-willaction .p-top-services__logo img {
  max-height: calc(19 / 375 * 100vw);
}
@media (min-width: 782px) {
  .is-loandeal .p-top-services__logo img {
    max-height: min(55px, 55 / 960 * 100vw);
  }
  .is-sideproject .p-top-services__logo img {
    max-height: min(45px, 45 / 960 * 100vw);
  }
  .is-outsight .p-top-services__logo img {
    max-height: min(42px, 42 / 960 * 100vw);
  }
  .is-willaction .p-top-services__logo img {
    max-height: min(28px, 28 / 960 * 100vw);
  }
}

.p-top-services__bar {
  color: var(--color-white);
  font-size: calc(12 / 375 * 100vw);
  line-height: 1;
  margin: calc(10 / 375 * 100vw) 0 0;
  padding: 0.3em 1em;
  text-align: center;
  width: 100%;
}
@media (min-width: 782px) {
  .p-top-services__bar {
    font-size: min(18px, 18 / 960 * 100vw);
    margin-top: min(12px, 12 / 960 * 100vw);
  }
}
.is-loandeal .p-top-services__bar {
  background-color: #3c918d;
}
.is-sideproject .p-top-services__bar {
  background-color: #4d6589;
}
.is-outsight .p-top-services__bar {
  background-color: #a54a44;
}
.is-willaction .p-top-services__bar {
  background-color: #2b2c33;
}

.p-top-services__body > p:not(.p-top-services__bar) {
  font-size: calc(14 / 375 * 100vw);
  line-height: 1.7;
  margin: calc(10 / 375 * 100vw) 0 0;
  text-align: center;
}
@media (min-width: 782px) {
  .p-top-services__body > p:not(.p-top-services__bar) {
    font-size: min(18px, 18 / 960 * 100vw);
    margin-top: min(12px, 12 / 960 * 100vw);
  }
  .p-top-services__body > p:not(.p-top-services__bar) br {
    display: none;
  }
}

/*# sourceMappingURL=style.css.map */