@charset "UTF-8";
.p-section-list {
  margin-top: var(--section-gap);
}
.p-section-list__inner {
  container-type: inline-size;
}
.p-section-list__grid {
  display: grid;
  grid-template-columns: 1fr;
  padding: max(5cqw, 1.5em) max(6cqw, 1em);
  border: 1px solid currentcolor;
  border-radius: var(--radius-md);
}
.p-section-list__item + .p-section-list__item {
  padding-top: var(--section-gap-sm);
  margin-top: var(--section-gap-sm);
  border-top: 1px solid currentcolor;
}

.p-pattern01 {
  margin-top: var(--section-gap);
}
.p-pattern01__list {
  --column-count: 4;
  --column-gap: 1.25em;
  --row-gap: 1.25em;
}
@media (max-width: 1024px) {
  .p-pattern01__list {
    --column-count: 3;
  }
}
@media (max-width: 768px) {
  .p-pattern01__list {
    --column-count: 2;
  }
}
.p-pattern01__list a {
  min-width: unset;
}

.p-pattern02 {
  margin-top: var(--section-gap);
}
.p-pattern02__heading {
  margin-bottom: var(--header-gap);
}
.p-pattern02__list {
  --prefix-color: var(--color-primary);
  font-size: var(--font-size-xl);
}
.p-pattern02__list + .p-pattern02__list {
  margin-top: 1em;
}
.p-pattern02__column {
  padding: max(3cqw, 2em) max(4cqw, 1.5em);
  margin-top: var(--section-gap-xs);
  background-color: var(--color-secondary);
  border-radius: var(--radius-md);
}

.p-pattern03 {
  margin-top: var(--section-gap);
}
.p-pattern03__heading {
  margin-bottom: var(--header-gap-lg);
}
.p-pattern03__item + .p-pattern03__item {
  margin-top: var(--section-gap-sm);
}

.p-pattern03-02 {
  margin-top: var(--section-gap);
}
.p-pattern03-02__heading {
  margin-bottom: var(--header-gap-lg);
}
.p-pattern03-02__item + .p-pattern03-02__item {
  margin-top: var(--section-gap-sm);
}
.p-pattern03-02__item__header {
  background-color: var(--color-primary);
}
.p-pattern03-02__item__heading {
  color: var(--color-text-contrast);
}

.p-pattern04 {
  margin-top: var(--section-gap-lg);
}
.p-pattern04__inner {
  container: inner/inline-size;
}
.p-pattern04__grid {
  display: flex;
  column-gap: 5cqw;
}
@container inner (width <= 800px) {
  .p-pattern04__grid {
    flex-direction: column;
    row-gap: 2.5em;
  }
}
@container inner (width > 800px) {
  .p-pattern04__header {
    display: flex;
    justify-content: center;
    min-width: 3em;
  }
}
@container inner (width > 800px) {
  .p-pattern04__heading {
    letter-spacing: 0.2em;
    writing-mode: vertical-rl;
    text-orientation: upright;
  }
}
.p-pattern04__body {
  flex: 1;
}
.p-pattern04__item + .p-pattern04__item {
  margin-top: var(--section-gap-sm);
}
.p-pattern04__item__heading {
  margin-bottom: var(--header-gap-xs);
}

.p-pattern05 {
  --gradation-height: var(--section-gap-lg);
  position: relative;
  z-index: 0;
  padding-block: var(--section-gap);
  margin-top: var(--section-gap);
}
.p-pattern05__bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  display: flex;
  justify-content: center;
  width: 100%;
  height: 100%;
  overflow: hidden;
  -webkit-mask-image: linear-gradient(to bottom, transparent, #000 var(--gradation-height), #000 calc(100% - var(--gradation-height)), transparent);
          mask-image: linear-gradient(to bottom, transparent, #000 var(--gradation-height), #000 calc(100% - var(--gradation-height)), transparent);
}
.p-pattern05__bg > img {
  display: block;
  width: 100%;
  min-width: 600px;
  height: 100%;
  opacity: 0.34;
}
.p-pattern05__heading {
  margin-bottom: var(--header-gap-lg);
}
.p-pattern05__item__heading {
  margin-bottom: var(--header-gap-xs);
}

.p-pattern06 {
  margin-top: var(--section-gap);
}
.p-pattern06__heading {
  margin-bottom: var(--header-gap);
}

.p-pattern07 {
  margin-top: var(--section-gap);
}
.p-pattern07__heading {
  margin-bottom: var(--header-gap);
}
.p-pattern07__item + .p-pattern07__item {
  margin-top: var(--section-gap-sm);
}
.p-pattern07__item__main {
  container: main/inline-size;
}
@container main (width > 480px) {
  .p-pattern07__item__body:is(.p-pattern07__item--alt *) {
    display: flex;
  }
}
.p-pattern07__item__heading {
  margin-bottom: var(--header-gap-xs);
}
@container main (width > 480px) {
  .p-pattern07__item__heading:is(.p-pattern07__item--alt *) {
    margin-right: max(var(--header-gap-xs), 1em);
    margin-bottom: unset;
    writing-mode: vertical-rl;
    text-orientation: upright;
  }
}
.p-pattern07__item__content {
  flex: 1;
}

.p-pattern08 {
  margin-top: var(--section-gap);
}
.p-pattern08__heading {
  margin-bottom: var(--header-gap);
}
.p-pattern08__body {
  container: body/inline-size;
}
.p-pattern08__list {
  --column-count: 3;
  --column-gap: max(4cqw, 2.2em);
  --row-gap: var(--section-gap-sm);
}
@container body (width <= 900px) {
  .p-pattern08__list {
    --column-count: 2;
  }
}
@container body (width <= 530px) {
  .p-pattern08__list {
    --column-count: 1;
  }
}
.p-pattern08__item__heading {
  margin-bottom: 0.5em;
  text-align: center;
}
.p-pattern08__item__image {
  max-width: 380px;
  margin-inline: auto;
}

.p-pattern09 {
  margin-top: var(--section-gap);
}
.p-pattern09__inner {
  container: inner/inline-size;
}
.p-pattern09__heading {
  margin-bottom: var(--header-gap);
}
.p-pattern09__body {
  padding: max(6cqw, 1.5em) max(7cqw, 1em);
  margin-inline: calc(var(--container-padding) / -2);
  background-color: var(--color-secondary);
  border-radius: var(--radius-md);
}
.p-pattern09__item + .p-pattern09__item {
  margin-top: var(--section-gap-sm);
}
.p-pattern09__item__heading {
  margin-bottom: var(--header-gap-xs);
}

.p-pattern10 {
  margin-top: var(--section-gap);
}
.p-pattern10__heading {
  margin-bottom: var(--header-gap-xs);
}
@container image-section (width > 750px) {
  .p-pattern10__main {
    padding: 4cqw 5cqw;
    margin-top: var(--section-gap-xs);
    margin-left: calc((var(--column-gap) + 1em) * -1);
    border: 1px solid currentcolor;
    border-radius: var(--radius-md);
  }
}
.p-pattern10__image {
  z-index: 2;
}

.p-pattern11 {
  margin-top: var(--section-gap);
}
.p-pattern11__main {
  padding: max(4cqw, 1.5em) max(6cqw, 1em);
  background-color: rgba(var(--color-primary-rgb), 15%);
  border-radius: var(--radius-md);
}
.p-pattern11__heading {
  margin-bottom: var(--header-gap-sm);
  color: var(--color-primary);
  text-align: center;
}
.p-pattern11__list {
  --prefix-color: var(--color-primary);
  width: -moz-fit-content;
  width: fit-content;
  margin-inline: auto;
  margin-top: var(--section-gap-sm);
  font-size: var(--font-size-xl);
}

.p-pattern12__heading {
  --prefix-size: 1em;
  display: flex;
  gap: 0.5em;
  align-items: flex-start;
  margin-bottom: var(--header-gap-xs);
}
.p-pattern12__heading::before {
  color: var(--color-primary);
  content: "■";
}
.p-pattern12__list {
  --prefix-color: var(--color-primary);
  --row-gap: 0.75em;
  font-size: var(--font-size-lg);
}

.p-pattern13__heading {
  display: flex;
  gap: 0.5em;
  align-items: flex-start;
  margin-bottom: var(--header-gap-xs);
}
.p-pattern13__heading::before {
  color: var(--color-primary);
  content: "■";
}




.u-ta--center {
    text-align: center;
}
.tb-sm {
    min-width: auto;
    border: 1px solid var(--border-color);
}
.c-table th:first-child {
    width: 25em;
    min-width: 10em;
}
.c-table th {
    position: relative;
    padding: 0.85em 1em;
    font-size: var(--font-size-lg);
    font-weight: bold;
    text-align: center;
    word-break: keep-all;
    overflow-wrap: anywhere;
}
.border-r {
    border-right: 1px solid var(--border-color);
}
span.text-r {
    padding-left: 570px;
}

/* --- 既存のコードの末尾に追加 --- */

@media (max-width: 768px) {
  /* テーブル本体をブロック要素にして枠線を調整 */
  .p-pattern06__table .c-table,
  .p-pattern06__table .c-table thead,
  .p-pattern06__table .c-table tbody,
  .p-pattern06__table .c-table tr,
  .p-pattern06__table .c-table th,
  .p-pattern06__table .c-table td {
    display: block;
    width: 100% !important;
  }
.border-r {
    border-right: none;
}
span.text-r {
    padding-left: unset;
}
}


/* 動画埋め込みエリアのスタイル */
.p-video-container {
  max-width: 800px; /* 他の画像セクションのサイズ（800px）に合わせています */
  margin: 0 auto var(--header-gap);
}

.p-video-wrapper {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9の比率を維持するための数値 */
}

.p-video-wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border-radius: var(--radius-md); /* 他の要素に合わせて角を少し丸くします */
}
table.c-table.u-ta--center.tb-sm {
    width: 770px;
}

/* FAQ全体のスタイル */
.p-faq-group + .p-faq-group {
  margin-top: var(--section-gap-sm);
}
.p-faq-group__title {
  font-size: var(--font-size-xl);
  color: var(--color-primary);
  margin-bottom: 1.5em;
  padding-bottom: 0.5em;
  border-bottom: 2px solid var(--color-primary);
}

.p-faq-item {
  margin-bottom: 2em;
}
.p-faq-item__question {
  position: relative;
  padding: 1em 1.25em;
  background-color: rgba(var(--color-primary-rgb), 10%); /* 薄いメインカラー */
  border-radius: var(--radius-md);
  font-weight: bold;
  font-size: var(--font-size-lg);
  line-height: 1.5;
}
.p-faq-item__answer {
  padding: 1.25em 1.25em 0;
  line-height: 1.8;
}

@media (max-width: 768px) {
  .p-faq-item__question {
    padding: 0.8em 1em;
    font-size: var(--font-size-md);
  }
  .p-faq-item__answer {
    padding: 1em 1em 0;
  }
}

/* バナーエリアのスタイル */
.p-banner-link {
  margin-top: 1.5em;

}

.p-banner-link a {
  display: inline-block;
  width: 55%; /* PCでのサイズ（お好みで40%〜50%程度に調整してください） */
  transition: opacity 0.3s ease;
}

.p-banner-link a:hover {
  opacity: 0.8;
}

.p-banner-link img {
  width: 100%;
  height: auto;
  border-radius: var(--radius-md); /* 既存の角丸設定を適用 */
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1); /* 軽い影でバナーを際立たせる */
}

/* スマホ（画面幅768px以下）の設定 */
@media (max-width: 768px) {
  .p-banner-link a {
    width: 100%; /* スマホでは横幅いっぱいに表示 */
  }
}