/* ===============
  fv
  ================== */
.p-hero {
  position: relative;
  color: #fff;
  height: 765px;
  overflow: hidden;
}
.p-hero__media {
  position: absolute;
  inset: 0;
}
/* 黒マスク */
.p-hero__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6); /* ←ここで濃さ調整 */
  pointer-events: none;
  z-index: 1;
}
/* videoに変える */
.p-hero__video {
  width: 100vw;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: center;
  z-index: 0;
}
/* .p-hero__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
} */
.p-hero__shade {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.p-hero__container {
  height: 100%;
  max-width: 1328px;
  margin-inline: 3.88vw;
  display: flex;
  align-items: center;
}
.p-hero__content {
  max-width: 760px;
  position: absolute;
  top: clamp(216px, 22.3vw, 22.3vw);
  z-index: 2;
}
.p-hero__title {
  margin: 0 0 32px;
  font-size: 40px;
  line-height: 1.4;
  font-weight: 500;
  letter-spacing: 0.4px;
  font-family: "Noto Sans JP";
}
.p-hero__lead {
  margin: 0;
  font-size: 15px;
  line-height: 1.9;
  color: #fff;
}
.p-hero__actions {
  margin-top: 64px;
}

/* ===============
  セクション共通css
  ================== */
.c-section {
  width: 92%;
  margin: 0 auto;
  padding-block: 144px;
}
/* ===============
  NEWS　お知らせ
  ================== */
.p-news {
  display: flex;
  gap: 6.11vw;
}
.p-news__heading {
  margin-left: 0;
}

.p-news__introText {
  margin: 0;
  color: rgba(255, 255, 255, 0.78);
  line-height: 1.9;
}

/* 一覧グリッド（PC：3カラム） */
.p-news__grid {
  width: 100%;
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px; /* カード間 */
}

/* カード骨格 */
.c-card--news .c-card__link {
  display: block;
  color: inherit;
  text-decoration: none;
}
.c-card--news .c-card__media {
  margin: 0 0 18px;
  overflow: hidden;
}
.c-card--news .c-card__img {
  width: 100%;
  height: 13.89vw;
}
.c-card--news .c-card__img:hover {
  opacity: 0.8;
}
.c-card--news .c-card__body {
  padding: 0;
}
.c-card--news .c-card__meta {
  margin-bottom: 8px;
  font-family: "Noto Sans JP";
  font-size: clamp(8px, 0.83vw, 12px);
  line-height: 1.4;
  letter-spacing: 0;
  color: #909295;
}
.p-news__date {
  margin-right: 16px;
}
.c-card--news .c-card__title {
  margin: 0;
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 15px;
  line-height: 1.8;
  letter-spacing: 0;
  color: #3e4042;
}

/* 一覧ボタン周辺の余白（ボタン自体は別定義） */
.p-news__actions {
  margin: 89px auto 0;
}
/* ===============
  ABOUT　TRIBAWLについて
  ================== */
.p-about__features {
  margin-block: 80px 88px;
}
.c-card--feature {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.c-cardGrid--3col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.66vw;
  width: 100%;
}
.p-card__media--about {
  margin: 0;
}
.p-card__media--about img {
  width: 29.62vw;
}
.c-card__body--about {
  display: flex;
  flex-direction: column;
  gap: 16px;
  font-family: "Noto Sans JP";
  margin-inline: 4px;
}
.p-card__title--about {
  font-weight: 500;
  font-size: 20px;
  line-height: 1.5;
  letter-spacing: 0;
  color: #3e4042;
}
.p-card__text--about {
  font-weight: 400;
  font-size: 15px;
  line-height: 1.9;
  letter-spacing: 0;
  color: #3d3f42;
}

/* ===============
  SERVICE 事業内容
  ================== */
.bg-gray {
  background-color: #fbfbfb;
}
.serviceOverview__list {
  margin-top: 80px;
}
.p-service__gridflex {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
  margin-bottom: 72px;
}

/* .avatar-gpt__item {
  width: 49%;
  margin-bottom: 129px;
} */
.c-card--service {
  display: flex;
  flex-direction: column;
  gap: 40px;
}
.p-service__item-half {
  width: 50%;
}
.p-service__media {
  margin: 0;
}
.p-service__media img {
  width: 45.28vw;
}
.p-service__body {
  margin-inline: 8px;
}
.p-service__kicker {
  font-size: 18px;
  line-height: 1.5;
  letter-spacing: 0;
  color: #909295;
  margin-bottom: 4px;
  font-family: "Noto Sans JP";
}
.p-service__name {
  font-size: 36px;
  font-weight: 500;
  line-height: 1.5;
  letter-spacing: 0;
  margin-bottom: 40px;
  font-family: "Montserrat";
  color: #3e4042;
}
.p-service__textLead {
  font-size: 20px;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  margin-bottom: 24px;
  color: #3d3f42;
}
.p-service__textNote {
  font-size: 14px;
  font-weight: 400;
  line-height: 2.1;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  margin-bottom: 64px;
  color: #3d3f42;
}

/* ==================================
  CORE TECHNOLOGY　TRIBAWL独自のコア技術
  =================================== */

.technology-title,
.technology-textBlock {
  color: #fff;
}
.bg-black {
  background: #000000;
}
.technology__container {
  gap: 3.5vw;
}
.technology__col--head {
  width: 95%;
}
.p-coreTech__surface {
  width: 100%;
  margin: 88px auto 73px;
  padding: 56px 0;
  border-radius: 32px;
  background: linear-gradient(to bottom, #1c1c1c 0%, #000000 100%);
}
.p-coreTech__mediaBlock {
  display: flex;
  width: 92.2%;
  margin: 0 auto 88px;
  gap: 9.58vw;
  align-items: center;
}
.coreTechOverview__mediaBody {
  margin-left: 16px;
}
.p-coreTech__leadTitle {
  margin: 0 0 24px;
  font-size: 32px;
  line-height: 1.5;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  color: #fff;
}
.p-coreTech__leadSub {
  margin: 0;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.5;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  color: #fff;
}

.p-coreTech__leadVisual {
  margin: 0;
}
.p-coreTech__leadImg {
  display: block;
  width: 49.8vw;
  height: 33.1vw;
  object-fit: cover;
}
.p-coreTech__featureGrid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  position: relative;
  width: 90.36%;
  margin: 0 auto;
}
.p-coreTech__feature {
  display: grid;
  grid-template-columns: 1fr 4fr;
  grid-template-rows: 3049fr 4000fr;
  column-gap: 16px;
  row-gap: 24px;
  padding: 3.33vw 3.2vw 5.2vw;
  position: relative;
  z-index: 1;

  grid-template-areas:
    "icon title"
    "text text";
}
.coreTechOverview__featureIcon {
  grid-area: icon;
}
.coreTechOverview__featureTitle {
  grid-area: title;
}
.coreTechOverview__featureText {
  grid-area: text;
}

.p-coreTech__featureIcon {
  width: 86.32px;
  height: 79.47px;
}
.p-coreTech__featureIconImg {
  width: 86.32px;
  height: 79.47px;
}
.p-coreTech__featureTitle {
  margin: 10.74px 0;
  font-size: 20px;
  line-height: 1.6;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  color: #fff;
}
.p-coreTech__featureText {
  margin: 0;
  font-size: 15px;
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  color: #fff;
}
/* --- ここから十字線 --- */

/* 共通（疑似要素ベース） */
.p-coreTech__featureGrid::before,
.p-coreTech__featureGrid::after {
  content: "";
  position: absolute;
  pointer-events: none;
  z-index: 0;
}
/* 縦線：上下でフェード */
.p-coreTech__featureGrid::before {
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1px;
  transform: translateX(-0.5px);
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.16) 20%,
    rgba(255, 255, 255, 0.16) 80%,
    rgba(255, 255, 255, 0) 100%
  );
}
/* 横線：左右でフェード */
.p-coreTech__featureGrid::after {
  left: 0;
  right: 0;
  top: 50%;
  height: 1px;
  transform: translateY(-6.5px);
  background: linear-gradient(
    to right,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.16) 20%,
    rgba(255, 255, 255, 0.16) 80%,
    rgba(255, 255, 255, 0) 100%
  );
}

/* --- 下段の面（導入メリット） --- */
.p-coreTech__benefitSurface {
  max-width: 100%;
  margin: 0 auto;
  padding: 88px 4.44vw 56px;
  border-radius: 32px;
  background: linear-gradient(to bottom, #1c1c1c 0%, #000000 100%);
}
.p-coreTech__benefitHead {
  margin: 0 0 40px 0;
  font-size: 32px !important;
  line-height: 1.5;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  color: #fff;
}

.p-coreTech__benefitList {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  counter-reset: coreBenefit;
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
}
.p-coreTech__benefitList::before,
.p-coreTech__benefitList::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: 1px;
  pointer-events: none;
  z-index: 0;
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 0) 0%,
    rgba(255, 255, 255, 0.16) 20%,
    rgba(255, 255, 255, 0.16) 80%,
    rgba(255, 255, 255, 0) 100%
  );
}
/* 1本目：1/3 */
.p-coreTech__benefitList::before {
  left: calc(100% / 3);
  transform: translateX(-0.5px);
}
/* 2本目：2/3 */
.p-coreTech__benefitList::after {
  left: calc(100% * 2 / 3);
  transform: translateX(-0.5px);
}
.p-coreTech__benefitItem {
  padding: 2.78vw;
}
.p-coreTech__benefitNum {
  font-size: 11px;
  line-height: 1.5;
  letter-spacing: 0;
  color: #7c7c7c;
  margin-bottom: 32px;
  font-family: "Noto Sans JP";

  display: inline-flex;
  align-items: center;
  gap: 10px;
}
.p-coreTech__benefitNum::before {
  content: "";
  width: 5px; /* 丸のサイズ */
  height: 5px;
  border-radius: 50%;
  background: #fff;
  flex: 0 0 5px; /* つぶれ防止 */
}
.p-coreTech__benefitHeading {
  margin: 0 0 24px;
  font-size: 18px;
  line-height: 1.6;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
  color: #fff;
}
.p-coreTech__benefitText {
  margin: 0;
  color: #909295;
  font-size: 14px;
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0;
  font-family: "Noto Sans JP";
}

/* コア技術の紹介セクション */

.c-techFlow {
  display: flex;
  flex-direction: column;
  gap: 2.77vw;
  align-items: center;
}
.c-techFlow__row {
  display: flex;
  gap: 2.77vw;
  align-items: center;
}
.c-techFlow__item {
  display: flex;
  flex-direction: column;
  gap: 1.66vw;
}

.c-techFlow__icon {
  width: 38.6vw;
  height: auto;
}

.c-techFlow__arrow-down {
  display: none;
}

.c-techFlow__text {
  font-size: 24px;
  font-family: "Noto Sans JP";
  font-weight: 500;
  color: #f5f5f7;
}

/* ==================================
  SOLUTIONS ソリューション・活用領域
  =================================== */
.p-solutions {
  width: 100%;
  margin: 0;
}
.solutionsOverview__split {
  width: 92%;
  margin: 0 auto;
}
.p-solutions__list {
  margin-top: 92px;
  display: flex;
  flex-direction: column;
  gap: 137px;
  margin-inline: auto 0;
}
.p-solutions {
  /* margin-inline: auto 0; */
}
.p-solutions__item {
  display: flex;
  gap: 5.27vw;
  width: 93%;
  margin-inline: auto 0;
}
.p-solutions__body {
  margin: 24px 0 0 6.94vw;
}
.p-solutions__media {
  margin: 0;
  width: 38.8vw;
}
.p-solutions__img {
  width: 38.8vw;
}
.p-solutions__solutionNo {
  font-family: "Noto Sans JP";
  font-size: 12px;
  line-height: 1.5;
  letter-spacing: 0;
  color: #909295;
  margin-bottom: 24px;
}
.p-solutions__itemTitle {
  font-family: "Noto Sans JP";
  font-size: 30px;
  line-height: 1.5;
  letter-spacing: 0;
  margin-bottom: 24px;
  color: #3e4042;
}
.p-solutions__itemLead {
  font-family: "Noto Sans JP";
  font-weight: 300;
  font-size: 16px;
  line-height: 1.9;
  letter-spacing: 0;
  margin-bottom: 56px;
  color: #474a4f;
}
/* dlのリセット */
.c-kvList {
  margin: 0;
  padding: 0;
}

/* 1行（term / desc） */
.c-kvList__item {
  display: grid;
  grid-template-columns: 120px 1fr;
  column-gap: 24px;
  align-items: start;
  color: #3e4042;
}

/* dt / dd の余白リセット */
.c-kvList__term,
.c-kvList__desc {
  margin: 0;
}

.c-kvList__term {
  font-family: "Noto Sans JP";
  font-weight: 500;
  font-size: 16px;
  line-height: 1.5;
  letter-spacing: 0;
}

.c-kvList__desc {
  font-family: "Noto Sans JP";
  font-weight: 300;
  font-size: 15px;
  line-height: 1.5;
  letter-spacing: 0;
}
.case__kvItem {
  position: relative;
  padding-bottom: 56px;
  margin-bottom: 45px;
}
.implementation__kvItem {
  padding-bottom: 50px;
}
.case__kvItem::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 1px;
  pointer-events: none;

  /* 背景が薄グレーなら白より黒の方が見えること多い */
  background: linear-gradient(
    to right,
    rgba(0, 0, 0, 0.1) 0%,
    rgba(0, 0, 0, 0.24) 18%,
    rgba(0, 0, 0, 0.24) 82%,
    rgba(0, 0, 0, 0.1) 100%
  );
}
.c-kvList__item:nth-of-type(2) {
  position: relative;
  padding-bottom: 52px;
}
.c-kvList__item:nth-of-type(2)::before {
  content: "↓";
  position: absolute;
  left: 50%;
  bottom: 18px;
  transform: translateX(-50%);
  color: #bfbfbf;
  font-size: 18px;
  line-height: 1;
}
/* ========================
  CLIENTS 導入企業・パートナー
  ========================= */
.c-logoGrid {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}
.c-logoGrid--responsive {
  grid-template-columns: repeat(6, 1fr);
  margin-top: 78px;
}

.c-logoGrid__figure {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 80px; /* プレート高さ */
  margin: 0;
  overflow: hidden;
}
.c-logoGrid__img {
  width: 100%;
  display: block;
  object-fit: contain;
}

/* ========================
  cta
========================= */
.p-joinCta__hero {
  position: relative;
  height: 563px;
  overflow: hidden;
}
.p-joinCta__media {
  position: absolute;
  inset: 0;
}
.p-joinCta__figure,
.p-joinCta__img {
  width: 100%;
  height: 563px;
  display: block;
}
.p-joinCta__figure {
  margin: 0;
}
.p-joinCta__img {
  object-fit: cover;
}
.p-joinCta__sideLabel {
  position: absolute;
  top: 26.6%;
  right: 2.7vw;
  transform: translateY(-50%) rotate(90deg);
  transform-origin: center;
  color: #fff;
  font-family: "Montserrat";
  font-size: 14px;
  letter-spacing: 0;
  line-height: 1.5;
}
.p-joinCta__container {
  position: relative;
  width: 92.2%;
  margin-inline: auto;
  padding-block: 120px;
  display: flex;
  align-items: center;
}
.p-joinCta__content {
  max-width: 680px;
}
.p-joinCta__heading {
  margin: 0 0 32px;
}
.p-joinCta__title {
  font-family: "Noto Sans JP";
  font-size: 30px;
  line-height: 1.5;
  letter-spacing: 0;
  color: #fff;
}
.p-joinCta__leadText {
  margin: 0;
  color: #fff;
  font-size: 16px;
  font-weight: 300;
  line-height: 1.9;
  letter-spacing: 0;
}
.p-joinCta__actions {
  margin-top: 56px;
}
/* ====================
  画像をふわっとさせる(共通)
  ======================= */
.js-fadein {
  opacity: 0;
  transform: translateY(6px);
  transition: opacity 0.35s linear, transform 0.35s ease-out;
  will-change: opacity, transform;
}

.js-fadein.is-show {
  opacity: 1;
  transform: translateY(0);
}

.big-pc {
  display: none;
}
@media (min-width: 1500px) {
  .big-pc {
    display: block;
  }
}
.core-br {
  display: none;
}
@media (max-width: 768px) {
  .core-br {
    display: block;
  }
}

@media (min-width: 1441px) {
  .p-hero__content {
    top: 250px;
  }
}

@media (max-width: 768px) {
  /* ===============
  fv
  ================== */
  .p-hero {
    height: 603px;
  }
  .p-hero__title {
    font-size: clamp(20px, 5.2vw, 5.2vw);
  }
  .p-hero__lead {
    font-size: 15px;
  }

  /* ===============
  NEWS　お知らせ
  ================== */
  .p-news {
    flex-direction: column;
    gap: 32px;
  }
  .p-news__grid {
    display: flex;
    flex-direction: column;
    gap: 40px;
  }
  .c-card--news .c-card__img {
    height: 46.93vw;
  }
  .c-card--news .c-card__meta {
    font-size: 11px;
  }
  .p-news__actions {
    margin: 51px auto 0;
  }

  /* ===============
  ABOUT　TRIBAWLについて
  ================== */
  .p-card__title--about {
    font-size: 2.08vw;
  }
  .p-card__text--about {
    font-size: 1.83vw;
  }

  /* ===============
  SERVICE 事業内容
  ================== */
  .p-service {
    width: 87.2%;
    margin: 56px auto 0;
    padding-bottom: 72px;
  }
  .p-service__gridflex {
    display: flex;
    flex-direction: column;
    gap: 70px;
  }
  .p-service__item-half {
    width: 100%;
  }
  .p-service__media img {
    width: 100%;
  }
  .p-service__name {
    font-size: 3.8vw;
    margin-bottom: 24px;
  }
  .p-service__textLead {
    font-size: 2.34vw;
  }

  /* ==================================
  CORE TECHNOLOGY　TRIBAWL独自のコア技術
  =================================== */
  .p-coreTech__mediaBlock {
    display: block;
    width: 88.3%;

    margin: 0 auto 40px;
  }
  .coreTechOverview__mediaBody {
    margin: 0 0 32px 4px;
  }
  .p-coreTech__leadTitle {
    margin-bottom: 10px;
  }
  .p-coreTech__leadImg {
    width: 100%;
  }
  .p-coreTech__featureGrid {
    display: block;
    width: 100%;
  }
  .p-coreTech__featureGrid::before,
  .p-coreTech__featureGrid::after {
    display: none;
  }
  .p-coreTech__feature:last-child::after {
    display: none;
  }

  .p-coreTech__feature::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    pointer-events: none;

    /* 左右でフェード（外側が薄い） */
    background: linear-gradient(
      to right,
      rgba(255, 255, 255, 0.08) 0%,
      rgba(255, 255, 255, 0.16) 18%,
      rgba(255, 255, 255, 0.16) 82%,
      rgba(255, 255, 255, 0.08) 100%
    );
  }
  .p-coreTech__feature {
    padding: 32px 24px;
    column-gap: 32px;
    row-gap: 24px;
  }
  .p-coreTech__surface {
    margin: 46px auto 0;
    padding: 40px 0 64px;
  }
  .p-coreTech__benefitList {
    display: block;
  }
  .p-coreTech__benefitList::before,
  .p-coreTech__benefitList::after {
    display: none;
  }
  .p-coreTech__benefitItem {
    position: relative;
  }

  /* 最後以外に区切り線を入れる */
  .p-coreTech__benefitItem:not(:last-child)::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    pointer-events: none;

    /* 端も薄く見える＋中央少し濃い */
    background: linear-gradient(
      to right,
      rgba(255, 255, 255, 0.08) 0%,
      rgba(255, 255, 255, 0.16) 18%,
      rgba(255, 255, 255, 0.16) 82%,
      rgba(255, 255, 255, 0.08) 100%
    );
  }
  .p-coreTech__surface {
    border-radius: 20px;
  }
  .p-coreTech__benefitSurface {
    padding: 40px 36px 80px;
    border-radius: 20px;
  }

  .coreTechOverview {
    padding-bottom: 0;
  }

  /* コア技術の紹介セクション */

  /* コア技術の紹介セクション */

  .c-techFlow {
    display: flex;
    flex-direction: column;
    gap: 8.53vw;
    align-items: center;
  }
  .c-techFlow__row {
    display: flex;
    flex-direction: column;
    gap: 8.53vw;
    align-items: center;
  }
  .c-techFlow__item {
    display: flex;
    flex-direction: column;
    gap: 4.26vw;
  }

  .c-techFlow__text {
    font-size: 16px;
  }

  .c-techFlow__arrow-right {
    display: none;
  }

  .c-techFlow__arrow-down {
    display: block;
  }

  .c-techFlow__icon {
    width: 76.7vw;
    height: auto;
  }
  /* ==================================
  SOLUTIONS ソリューション・活用領域
  =================================== */
  .p-solutions {
    width: 92%;
    margin: 0 auto;
  }
  .c-splitSection__container {
    margin-inline: 0;
  }
  .p-solutions__item {
    display: block;
    width: 100%;
    margin: 64px 0 0;
  }
  .p-solutions__list {
    margin-top: 0;
    gap: 72px;
  }
  .p-solutions__body {
    margin: 0;
    margin-bottom: 32px;
  }
  .p-solutions__media,
  .p-solutions__img {
    width: 100%;
    height: 42.66vw;
    object-fit: cover;
  }

  /* ======================
  CLIENTS 導入企業・パートナー
  ========================= */
  .p-clients__split {
    grid-template-columns: 1fr; /* 1カラム */
    row-gap: 16px;
    column-gap: 0;
    margin-bottom: 34px;
  }

  .c-logoGrid--responsive {
    grid-template-columns: repeat(2, minmax(0, 1fr)); /* 2列 */
    gap: 25px 0;
    margin-top: 26px;
    margin-bottom: 12px;
  }
  .c-logoGrid__figure {
    height: 12.8vw;
  }
  .c-logoGrid__img {
    width: 80%;
  }

  /* ========================
  cta
  ========================= */
  .p-joinCta__hero,
  .p-joinCta__figure,
  .p-joinCta__img {
    height: 466px;
  }
  .p-joinCta__container {
    width: 87.2%;
  }
  .p-joinCta__sideLabel {
    top: 14%;
    left: 6vw;
    transform: translateY(-50%) rotate(0deg);
    font-size: 11px;
  }
  .p-joinCta__container {
    padding-block: 104px 60px;
  }
  .p-joinCta__title {
    font-size: 18px;
    line-height: 1.6;
  }
  .p-joinCta__heading {
    margin: 0 0 27px;
  }
  .p-joinCta__leadText {
    font-size: 13px;
  }
  .p-joinCta__actions {
    margin-top: 35px;
  }
}

@media (max-width: 600px) {
  /* ===============
  ABOUT　TRIBAWLについて
  ================== */
  .c-cardGrid--3col {
    display: flex;
    flex-direction: column;
    gap: 41px;
  }
  .p-card__media--about img {
    width: 100%;
  }
  .p-card__title--about {
    font-size: clamp(16px, 3.16vw, 3.16vw);
  }
  .p-card__text--about {
    font-size: clamp(13px, 2.33vw, 2.33vw);
  }
  .p-about__features {
    margin-block: 48px 56px;
  }
  .c-card--feature {
    gap: 19px;
  }
}

@media (max-width: 425px) {
  /* ===============
  fv
  ================== */
  .p-hero__container {
    margin-inline: 7.5vw;
  }
  .topHero__lead-br {
    display: none;
  }
  .p-hero__actions {
    margin-top: 53px;
  }
  .p-hero__content {
    left: 7.46vw;
    width: 86.1vw;
  }

  /* ===============
  セクション共通css
  ================== */
  .c-section {
    width: 87.3%;
    margin: 0 auto;
    padding-block: 56px 72px;
  }
  /* ===============
  NEWS お知らせ
  ================== */
  .c-card--news .c-card__title {
    font-size: 15px;
  }
  .c-card--news .c-card__body {
    margin-left: 5px;
  }

  /* ===============
  ABOUT　TRIBAWLについて
  ================== */
  .c-card__media img {
    height: 42.6vw;
    object-fit: cover;
  }

  /* ===============
  SERVICE 事業内容
  ================== */
  .p-clients {
    padding-bottom: 56px;
  }
  .serviceOverview__list {
    margin-top: 48px;
  }
  .c-card--service {
    gap: 17px;
  }

  .p-service__kicker {
    font-size: 12px;
  }
  .p-service__name {
    font-size: 22px;
  }
  .p-service__textLead {
    font-size: 15px;
  }
  .p-service__textNote {
    font-size: 13px;
    line-height: 1.9;
    margin-bottom: 36px;
  }
  .p-service__textLead-br {
    display: none;
  }
  .c-cardGrid--top {
    margin-bottom: 37px;
  }
  /* .avatar-gpt__item {
    margin-bottom: 72px;
  } */
  .robotics__textNote,
  .atraction__textNote {
    margin-bottom: 4px;
  }
  .serviceOverview__atraction {
    font-size: 20px;
  }

  /* ==================================
  CORE TECHNOLOGY　TRIBAWL独自のコア技術
  =================================== */
  .c-splitSection__container {
    gap: 28px;
  }
  .p-headingBlock--technology {
    margin-left: 0;
  }
  .technology-textBlock {
    margin: 0;
  }
  .coreTechOverview {
    width: 91.46%;
    padding-bottom: 0;
  }
  .p-coreTech__leadTitle {
    font-size: 18px;
  }
  .p-coreTech__leadSub {
    font-size: 13px;
    line-height: 1.7;
  }
  .p-coreTech__leadImg {
    object-fit: cover;
    width: 80vw;
    height: 199px;
  }
  .p-coreTech__feature {
    grid-template-columns: 78fr 217fr;
    grid-template-rows: 8fr 16fr;
    column-gap: 9px;
    row-gap: 6px;
    align-items: start;
  }
  .p-coreTech__featureIconImg,
  .p-coreTech__featureIcon {
    width: 66px;
    height: 60px;
  }
  .p-coreTech__featureTitle {
    font-size: 15px;
    margin: 6px 0;
  }
  .p-coreTech__featureText {
    font-size: 13px;
    margin-top: 5px;
  }
  .br-pc {
    display: none;
  }
  .p-coreTech__benefitHead {
    font-size: 20px !important;
    margin-left: 0;
    margin-bottom: 40px;
  }
  .p-coreTech__benefitItem {
    padding: 28px 24px;
  }
  .p-coreTech__benefitNum {
    font-size: 10px;
    margin-bottom: 16px;
  }
  .p-coreTech__benefitNum::before {
    width: 3px;
    height: 3px;
  }
  .p-coreTech__benefitHeading {
    font-size: 15px;
    margin-bottom: 16px;
  }
  .p-coreTech__benefitText {
    font-size: 13px;
  }

  /* ==================================
  SOLUTIONS ソリューション・活用領域
  =================================== */
  .p-solutions {
    width: 87.3%;
    margin: 0 auto;
    padding-top: 62px;
  }
  .solutionsOverview__split {
    width: 100%;
  }
  .p-solutions__list {
    gap: 11px;
  }
  .p-solutions__body {
    margin-inline: 10px;
  }
  .p-solutions__solutionNo {
    margin-bottom: 15px;
  }
  .p-solutions__itemTitle {
    font-size: 18px;
    margin-bottom: 16px;
  }
  .p-solutions__itemLead {
    font-size: 13px;
    margin-bottom: 31px;
  }
  .c-kvList__item {
    grid-template-columns: 72px 1fr;
  }
  .c-kvList__term {
    font-size: 12px;
  }
  .c-kvList__desc {
    font-size: 12px;
  }
  .case__kvItem {
    padding-bottom: 24px;
    margin-bottom: 24px;
  }
  .c-kvList__item:nth-of-type(2) {
    padding-bottom: 37px;
  }
  .c-kvList__item:nth-of-type(2)::before {
    font-size: 7px;
  }
}
