/* リセットとベーススタイル */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.6;
  overflow-x: hidden;
}

/* ヒーローセクション */
.hero-section {
  position: relative;
  width: 100%;
  height: 440px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 150px;
  overflow: hidden;
}

/* 背景画像コンテナ */
.hero-background {
  position: absolute;
  top: 0;
  left: 1px;
  width: 100%;
  height: 100%;
  z-index: 1;
}

/* 背景画像 */
.hero-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-image: url("../media/hero-base.png");
  /* 20250825_画像配置修正 */
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  overflow: hidden;
}

.hero-image::after {
  content: "";
  position: absolute;
  bottom: -353px;
  left: 50%;
  top: -78px;
  transform: translateX(-50%);
  width: 1440px;
}

/* 正しい背景 */
.hero-image-first {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_201_tokyorinri.webp");
}
.hero-image-about {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_202_tokyorinri.webp");
}
.hero-image-activities {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_203_tokyorinri.webp");
}
.hero-image-voice {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_204_tokyorinri.webp");
}
.hero-image-value {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_205_tokyorinri.webp");
}
.hero-image-join {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_207_tokyorinri.webp");
}
.hero-image-message {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_208_tokyorinri.webp");
}
.hero-image-history {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_209_tokyorinri.webp");
}
.hero-image-organization {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_210_tokyorinri.webp");
}
.hero-image-mynumbers {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_211_tokyorinri.webp");
}
.hero-image-philosophy {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_212_tokyorinri.webp");
}
.hero-image-members {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_214_tokyorinri.webp");
}
.hero-image-staff {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_100_tokyorinri.webp");
}
.hero-image-contact {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_215_tokyorinri.webp");
}
.hero-image-committee {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_216_tokyorinri.webp");
}
.hero-image-ms {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_115_tokyorinri.webp");
}
.hero-image-chourei {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_101_tokyorinri.webp");
}
.hero-image-kenshu {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_107_tokyorinri.webp");
}
.hero-image-pr {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_112_tokyorinri.webp");
}
.hero-image-josei {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_116_tokyorinri.webp");
}
.hero-image-career {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_108_tokyorinri.webp");
}
.hero-image-koukeisha {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_103_tokyorinri.webp");
}
.hero-image-rinrikeiei {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_104_tokyorinri.webp");
}
.hero-image-seinen {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_113_tokyorinri.webp");
}
.hero-image-teichaku {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_109_tokyorinri.webp");
}
.hero-image-event {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_206_tokyorinri.webp");
}
.hero-image-news {
  background-image: url("https://tokyo-rinri.net/wp-content/uploads/2025/08/page_mv_bandicoot_213_tokyorinri.webp");
}

/* グラデーションオーバーレイ */
.hero-gradient {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  z-index: 2;
}

/* コンテンツコンテナ */
.hero-content {
  position: relative;
  z-index: 3;
  width: 1080px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 0;
}

/* テキストコンテナ */
.hero-text-container {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* ヒーロータイトル */
.hero-title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-size: 48px;
  line-height: 49.28px;
  letter-spacing: 0.704px;
  color: #ffffff;
  text-align: left;
  white-space: nowrap;
  margin: 0;
  padding: 0;
}

.hero-title-sub {
  margin-top: 40px;
  color: var(--text-inverse, #fff);
  font-size: 32px;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 24px;
}

/* TODO : レスポンシブ */
.hero-title-sub::before {
  content: "";
  width: 64px;
  height: 1px;
  background: var(--text-inverse, #fff);
  display: block;
}

/* レスポンシブデザイン */
@media (max-width: 1440px) {
  .hero-section {
    padding: 100px 50px;
  }

  .hero-background {
    left: 0;
    width: 100%;
  }

  .hero-content {
    width: 100%;
    max-width: 1080px;
  }
}

@media (max-width: 768px) {
  .hero-section {
    height: 300px;
    padding: 50px 20px;
  }

  .hero-title {
    font-size: 32px;
    line-height: 1.3;
    letter-spacing: 0.5px;
  }
}

@media (max-width: 480px) {
  .hero-section {
    height: 240px;
    padding: 30px 15px;
    margin-top: 80px;
  }

  .hero-title {
    font-size: 24px;
    line-height: 1.4;
    letter-spacing: 0.3px;
  }

  .hero-title-sub {
    font-size: 16px;
    text-align: center;
    padding: 0 24px;
    margin-top: 24px;
  }

  .hero-title-sub::before {
    display: none;
  }

  .hero-text-container {
    width: 100%;
    align-items: center;
  }
}

/* ---------- 共通パーツ ---------- */
.section-base {
  padding: 104px 0;
}

.section-gray {
  padding: 104px 0;
  background: var(--bg-secondary, #f8f9fa);
}

.section-skyblue {
  padding: 104px 0;
  background: var(--Linear, linear-gradient(180deg, #e3f2fd 0%, #f8fbff 100%));
}

.section-deepblue {
  padding: 104px 0;
  background: var(
    --Linear2,
    linear-gradient(167deg, #2c5aa0 2.53%, #1b4f72 95.63%)
  );
}

.section-container {
  max-width: 1080px;
  margin: 80px auto 0;
}

.section-title,
.section-title-white {
  text-align: center;
  font-size: 40px;
  padding-bottom: 20px;
  position: relative;
}

.section-title {
  color: var(--text-primary, #333);
}

.section-title-white {
  color: var(--text-inverse, #fff);
}

.section-title::before,
.section-title-white::before {
  content: "";
  width: 60px;
  height: 2px;
  border-radius: 1px;
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
}

.section-title::before {
  background: var(
    --Linear4,
    linear-gradient(
      90deg,
      var(--edo-ai, #4a90e2) 0%,
      var(--hanada, #5dade2) 100%
    )
  );
}

.section-title-white::before {
  background: var(--text-inverse, #fff);
}

.section-title::after {
  display: none;
}

@media screen and (max-width: 480px) {
  .section-title,
  .section-title-white {
    font-size: 24px;
  }

  .section-container {
    max-width: 100%;
    margin: 64px 16px 0;
  }

  .section-base,
  .section-gray,
  .section-skyblue,
  .section-deepblue {
    padding: 64px 0;
  }
}

.sp-db {
  display: none;
}

.sp-dn {
  display: block;
}

@media screen and (max-width: 480px) {
  .sp-db {
    display: block;
  }

  .sp-dn {
    display: none;
  }
}

/* ---------- 参加企業紹介 ---------- */

.member-info {
  background: var(--Linear, linear-gradient(180deg, #e3f2fd 0%, #f8fbff 100%));
  padding: 104px 0;
}

.member-info-container {
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
  margin: 0 auto;
  padding: 80px 32px;
}

.member-info-name {
  color: var(--text-primary, #333);
  text-align: center;
  font-size: 48px;
}

.member-info-tag {
  display: inline-block;
  padding: 16px 32px;
  text-align: center;
  border-radius: 32px;
  background: var(
    --Linear4,
    linear-gradient(
      90deg,
      var(--edo-ai, #4a90e2) 0%,
      var(--hanada, #5dade2) 100%
    )
  );
  color: var(--text-inverse, #fff);
  font-size: 20px;
  font-weight: bold;
}

.member-info-leader {
  margin-top: 32px;
  color: var(--text-primary, #333);
  text-align: center;
  font-size: 32px;
  font-weight: bold;
}

.member-info-tag-wrapper {
  text-align: center;
  margin-top: 32px;
}

.member-info-content {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
  margin-top: 80px;
}

.member-info-img-wrapper {
  width: 50%;
  height: 300px;
}

.member-info-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 16px;
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.member-info-table-wrapper {
  width: 50%;
}

.member-info-tr {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  border-bottom: 1px solid var(--text-muted, #999);
}

.member-info-th,
.member-info-td {
  padding: 16px 0;
}

.member-info-th {
  min-width: 120px;
  text-align: left;
  font-weight: bold;
}

.member-info-table-text {
  margin-top: 32px;
}

.member-interview {
  padding: 104px 0;
  position: relative;
}

.member-interview::before {
  content: "";
  width: 572px;
  height: 488px;
  background: url(../media/ring-top.png) center / cover;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
}

.member-interview::after {
  content: "";
  width: 572px;
  height: 583px;
  background: url(../media/ring-bottom.png) center / cover;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: -1;
}

.member-interview-circle {
  width: 375px;
  height: 510px;
  background: url(../media/circle.png) center / cover;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  z-index: -1;
}

.member-interview-question,
.member-interview-last {
  color: var(--text-primary, #333);
  font-size: 32px;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 24px;
}

.member-interview-question::before,
.member-interview-last::before {
  content: "";
  width: 64px;
  height: 1px;
  background: var(--text-primary, #333);
  display: block;
}

.member-interview-answer {
  margin-top: 40px;
}

.member-interview-flex {
  display: flex;
  justify-content: space-between;
  margin-top: 40px;
}

.member-interview-flex > .member-interview-answer {
  width: 45%;
  margin-top: 0;
}

.member-interview-img {
  width: 45%;
  flex-shrink: 0;
}

@media screen and (max-width: 480px) {
  .member-info {
    padding: 64px 16px;
  }

  .member-info-container {
    padding: 40px 16px;
  }

  .member-info-name {
    font-size: 24px;
  }

  .member-info-leader {
    font-size: 20px;
  }

  .member-info-tag {
    font-size: 16px;
  }

  .member-info-content {
    flex-direction: column;
  }

  .member-info-img-wrapper {
    width: 100%;
  }

  .member-info-table-wrapper {
    width: 100%;
  }

  .member-info-tr {
    flex-direction: column;
    align-items: flex-start;
    justify-content: flex-start;
  }

  .member-info-td {
    padding-top: 0;
  }

  .member-interview-question {
    font-size: 20px;
  }

  .member-interview-flex {
    flex-direction: column;
    gap: 24px;
  }

  .member-interview-flex > .member-interview-answer {
    width: 100%;
  }

  .member-interview-img {
    width: 100%;
  }

  .member-interview-last {
    font-size: 20px;
  }
}

/* ---------- どんな人が参加しているのか ---------- */
.member-description {
  padding: 104px 0;
  background: var(--bg-secondary, #f8f9fa);
}

.member-description-container {
  margin: 0 auto;
}

.member-description-title {
  color: var(--text-primary, #333);
  text-align: center;
  font-size: 32px;
}

.member-description-title-line {
  padding: 0 40px;
  position: relative;
}

.member-description-title-line::before {
  content: "";
  width: 100px;
  height: 1px;
  background: var(--text-primary, #333);
  position: absolute;
  top: 50%;
  right: 100%;
  transform: translateY(-50%);
}

.member-description-title-line::after {
  content: "";
  width: 100px;
  height: 1px;
  background: var(--text-primary, #333);
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
}

.member-description-text {
  margin-top: 24px;
  text-align: center;
}

.member-description-text-first {
  margin-top: 80px;
}

.member-join {
  padding-top: 0;
}

.member-join-list {
  margin-top: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 40px;
}

.member-join-item {
  overflow: hidden;
  width: calc((100% - 80px) / 3);
  border-radius: 12px;
  background: var(--text-inverse, #fff);
  box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.08);
}

.member-join-item-img {
  width: 100%;
  height: 220px;
  object-fit: cover;
}

.member-join-item-content {
  padding: 16px 24px 24px;
  text-align: left;
}

.member-join-item-name {
  color: var(--text-primary, #333);
  font-size: 18px;
  font-weight: bold;
}

.member-join-item-leader {
  color: var(--kon-iro, #2e86c1);
  font-size: 14px;
}

.member-join-btn-wrapper {
  margin-top: 80px;
  display: flex;
  justify-content: center;
}

.member-join-btn {
  padding: 20px 48px;
  color: var(--edo-ai, #4a90e2);
  text-align: center;
  font-weight: bold;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
  display: flex;
  align-items: center;
  justify-content: center;
}

.member-join-btn::after {
  content: "";
  display: inline-block;
  width: 6px;
  height: 6px;
  border: 0;
  border-bottom: solid 1px var(--edo-ai, #4a90e2);
  border-right: solid 1px var(--edo-ai, #4a90e2);
  transform: rotate(45deg);
  margin-left: 16px;
  margin-bottom: 3px;
}

@media screen and (max-width: 480px) {
  .member-description-title {
    font-size: 24px;
  }

  .member-description-title-line {
    position: static;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
    padding: 0;
  }

  .member-description-title-line::before,
  .member-description-title-line::after {
    position: static;
    width: 200px;
  }

  .member-description-text {
    text-align: left;
    margin-left: 16px;
    margin-right: 16px;
  }

  .member-join-list {
    flex-direction: column;
    gap: 24px;
  }

  .member-join-item {
    width: 100%;
  }
}

/* ---------- 経営者にとっての価値 ---------- */
.value-message {
  padding: 104px 0;
  background: var(--bg-secondary, #f8f9fa);
}

.value-message-content {
  margin-top: 80px;
}

.value-message-text {
  margin-top: 24px;
  text-align: center;
  line-height: 1.8;
}

.value-message-text-bold {
  font-weight: bold;
}

.value-effect {
  padding: 104px 0;
  background: var(--Linear, linear-gradient(180deg, #e3f2fd 0%, #f8fbff 100%));
}

.value-effect-content {
  position: relative;
  display: flex;
  gap: 104px;
}

.value-effect-content::before {
  content: "";
  width: 64px;
  height: 57px;
  background: url(../media/value-arrow.png) center / cover;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.value-effect-list {
  width: 50%;
  border-radius: 0 0 16px 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.value-effect-list-title {
  padding: 16px 0;
  color: var(--text-inverse, #fff);
  text-align: center;
  font-size: 24px;
  border-radius: 16px 16px 0 0;
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.value-effect-list-before > .value-effect-list-title {
  background: var(--text-secondary, #666);
}

.value-effect-list-after > .value-effect-list-title {
  background: var(--kon-iro, #2e86c1);
}

.value-effect-list-wrap {
  padding: 32px;
}

.value-effect-list-item {
  color: var(--text-primary, #333);
  font-size: 20px;
  display: flex;
  align-items: center;
  gap: 11px;
}

.value-effect-list-item:not(:first-child) {
  margin-top: 16px;
}

.value-effect-list-item::before {
  content: "";
  width: 24px;
  height: 24px;
  background: url(../media/check.png) center / cover;
}

.value-voice-sub {
  margin-top: 80px;
  color: var(--text-inverse, #fff);
  text-align: center;
  font-size: 32px;
  font-weight: 700;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
}

.value-voice-sub::before {
  content: "";
  width: 100px;
  height: 1px;
  background: var(--text-inverse, #fff);
}

.value-voice-sub::after {
  content: "";
  width: 100px;
  height: 1px;
  background: var(--text-inverse, #fff);
}

.value-voice-list {
  display: flex;
  justify-content: space-between;
}

.value-voice-item {
  width: 32%;
  padding: 32px;
  display: flex;
  flex-direction: column;
  align-items: center;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.value-voice-img {
  display: block;
  width: 96px;
  height: 96px;
  border-radius: 50%;
  object-fit: cover;
}

.value-voice-info,
.value-voice-text {
  margin-top: 16px;
}

.value-unique {
  padding: 104px 0;
  background: var(--Linear, linear-gradient(180deg, #e3f2fd 0%, #f8fbff 100%));
}

.value-unique-text {
  margin-top: 80px;
  text-align: center;
}

.value-unique-text-bold {
  font-weight: bold;
}

.value-unique-table,
.value-unique-th,
.value-unique-th,
.value-unique-td {
  border: 1px solid var(--text-muted, #999);
  border-collapse: collapse;
}

.value-unique-table {
  margin: 40px auto 0;
  width: 1080px;
  text-align: center;
  border-radius: 4px;
}

.value-unique-th {
  width: 50%;
  height: 72px;
  color: var(--text-inverse, #fff);
  font-size: 24px;
}

.value-unique-th:first-child {
  border-right: 1px solid var(--bg-primary, #fff);
  background: var(--text-muted, #999);
}

.value-unique-th:last-child {
  background: linear-gradient(
      0deg,
      var(--kon-iro, #2e86c1) 0%,
      var(--kon-iro, #2e86c1) 100%
    ),
    var(--bg-primary, #fff);
}

.value-unique-td {
  height: 72px;
  color: var(--text-primary, #333);
  font-size: 20px;
}

.value-unique-td:first-child {
  background: var(--bg-secondary, #f8f9fa);
}

.value-unique-td:last-child {
  background: var(--bg-primary, #fff);
}

.value-five {
  padding: 104px 0;
}

.value-five-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 40px;
}

.value-five-item {
  width: calc((100% - 80px) / 3);
  padding: 30px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.2);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
  flex-shrink: 0;
  position: relative;
}

.value-five-item::before {
  color: rgba(93, 173, 226, 0.2);
  font-size: 56px;
  font-weight: bold;
  position: absolute;
  top: 16px;
  right: 24px;
}

.value-five-item:nth-child(1):before {
  content: "01";
}
.value-five-item:nth-child(2):before {
  content: "02";
}
.value-five-item:nth-child(3):before {
  content: "03";
}
.value-five-item:nth-child(4):before {
  content: "04";
}
.value-five-item:nth-child(5):before {
  content: "05";
}

.value-five-item-title {
  color: var(--edo-ai, #4a90e2);
  margin-top: 36px;
  font-size: 28px;
}

.value-five-item-text {
  margin-top: 32px;
}

.value-five-comment {
  margin: 24px auto 0;
  text-align: right;
  color: var(--text-muted, #999);
}

.value-last-content {
  margin-top: 80px;
  text-align: center;
}

.value-last-text {
  color: var(--text-inverse, #fff);
  line-height: 2;
}

.value-last-text-bold {
  font-weight: bold;
}

.value-last-text:last-child {
  margin-top: 24px;
}

/* ---------- 単会一覧 ---------- */
.tankai-location {
  position: relative;
}

.tankai-location::before {
  content: url(../media/tokyo.png);
  /* background: url(../media/tokyo.png) center / cover; */
  position: absolute;
  top: 50%;
  height: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 480px) {
  .value-message-content {
    margin: 0 16px;
  }

  .value-message-text {
    text-align: left;
  }

  .value-effect-content {
    flex-direction: column;
    gap: 120px;
  }

  .value-effect-list {
    width: 100%;
  }

  .value-effect-list-wrap {
    padding: 24px 16px;
  }

  .value-effect-list-item {
    font-size: 16px;
  }

  .value-effect-content::before {
    top: 48%;
    left: 32%;
    transform: rotate(90deg) translate(-50%, -50%);
    transform-origin: center;
  }

  .value-voice-sub {
    font-size: 20px;
    flex-direction: column;
    gap: 24px;
  }

  .value-voice-sub::before,
  .value-voice-sub::after {
    width: 200px;
  }

  .value-voice-list {
    flex-direction: column;
    gap: 24px;
  }

  .value-voice-item {
    width: 100%;
  }

  .value-unique-table-wrapper {
    margin-left: 16px;
    overflow-x: scroll;
  }

  .value-unique-table {
    margin-right: 16px;
  }

  .value-five-list {
    flex-direction: column;
  }

  .value-five-item {
    width: 100%;
  }

  .value-last-text {
    margin-left: 16px;
    margin-right: 16px;
    text-align: left;
  }
}

/* ---------- 入会を考えている方へ ---------- */
.consider-message {
  padding: 104px 0;
  background: var(--bg-secondary, #f8f9fa);
}

.consider-message-content {
  margin-top: 80px;
}

.consider-message-text {
  margin-top: 24px;
  text-align: center;
  line-height: 1.8;
}

.consider-message-text-bold {
  font-weight: bold;
}

.consider-merit {
  padding: 104px 0;
  background: var(--Linear, linear-gradient(180deg, #e3f2fd 0%, #f8fbff 100%));
}

.consider-merit-text {
  text-align: center;
  margin-top: 80px;
}

.consider-merit-text:nth-of-type(2) {
  margin-top: 40px;
}

.consider-merit-list {
  margin: 40px auto 0;
  padding: 40px 120px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px 4%;
}

.consider-merit-item {
  width: 48%;
  display: flex;
  align-items: center;
  gap: 12px;
}

.consider-merit-item::before {
  content: "";
  width: 20px;
  height: 20px;
  background: url(../media/check-blue.png) center / cover;
}

.consider-flow {
  padding: 104px 0;
}

.consider-flow-content {
  padding: 0 80px;
  display: flex;
  gap: 40px;
}

.consider-flow-img {
  width: 400px;
  object-fit: cover;
}

.consider-flow-list {
  display: flex;
  flex-direction: column;
}

.consider-flow-item {
  flex: 1;
  display: flex;
  align-items: center;
}

.consider-faq {
  padding: 104px 0;
  background: var(--Linear, linear-gradient(180deg, #e3f2fd 0%, #f8fbff 100%));
}

.consider-faq-item {
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.consider-faq-item:not(:first-child) {
  margin-top: 40px;
}

.consider-faq-question,
.consider-faq-answer {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 32px;
  height: 96px;
}

.consider-faq-question {
  color: var(--text-primary, #333);
  font-size: 20px;
  font-weight: bold;
  background: rgba(174, 214, 241, 0.5);
  position: relative;
}

.consider-faq-question::before {
  content: "";
  width: 24px;
  height: 4px;
  background: var(--edo-ai, #4a90e2);
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translateY(-50%);
}

.consider-faq-answer {
  background: #fff;
}

.consider-faq-question-tag,
.consider-faq-answer-tag {
  width: 96px;
  height: 96px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 32px;
  font-weight: bold;
}

.consider-faq-question-tag {
  color: var(--text-inverse, #fff);
  background: var(--edo-ai, #4a90e2);
}

.consider-faq-answer-tag {
  color: var(--edo-ai, #4a90e2);
}

.consider-last-text {
  margin-top: 80px;
  text-align: center;
  color: var(--text-inverse, #fff);
  line-height: 2;
}

.consider-last-button-wrapper {
  margin-top: 80px;
  display: flex;
  justify-content: center;
}

.consider-last-button {
  display: flex;
  width: 288px;
  height: 72px;
  padding: 0 44px;
  justify-content: space-between;
  align-items: center;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
  color: var(--edo-ai, #4a90e2);
  font-size: 18px;
  font-weight: bold;
  cursor: pointer;
  transition: 0.5s box-shadow, 0.3s border;
  position: relative;
}

.consider-last-button:hover {
  border: 1px solid #fff;
  box-shadow: 0 0 36px 0 rgba(74, 144, 226, 0.4);
}

.consider-last-button::after {
  content: "→";
}

@media screen and (max-width: 480px) {
  .consider-message-content {
    margin-left: 16px;
    margin-right: 16px;
  }

  .consider-message-text {
    text-align: left;
  }

  .consider-merit-text {
    margin-left: 16px;
    margin-right: 16px;
  }

  .consider-merit-list {
    margin-left: 16px;
    margin-right: 16px;
    flex-direction: column;
    gap: 32px 4%;
    padding: 24px 16px;
  }

  .consider-merit-item {
    width: 100%;
  }

  .consider-flow-content {
    flex-direction: column;
    padding: 0;
  }

  .consider-flow-img {
    width: 100%;
  }

  .consider-flow-item:not(:first-child) {
    margin-top: 32px;
  }

  .consider-faq-question,
  .consider-faq-answer {
    height: auto;
    padding: 8px 0;
    gap: 16px;
  }

  .consider-faq-question {
    font-size: 16px;
    padding-right: 24px;
  }

  .consider-faq-question::before {
    right: 8px;
    width: 16px;
  }

  .consider-faq-question-tag,
  .consider-faq-answer-tag {
    width: 40px;
    height: 40px;
    margin-left: 8px;
    flex-shrink: 0;
    font-size: 16px;
  }

  .consider-last-text {
    margin-left: 16px;
    margin-right: 16px;
  }
}

/* ---------- 憲章 ---------- */
.charter-message-content {
  width: 800px;
  margin: 80px auto 0;
}

.charter-message-text {
  text-align: center;
  line-height: 2;
}

.charter-active-list,
.charter-knowledge-list {
  padding: 48px 64px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.charter-active-item,
.charter-knowledge-item {
  color: var(--edo-ai, #4a90e2);
  font-size: 18px;
  font-weight: bold;
  display: flex;
  gap: 16px;
}

.charter-active-item:not(:first-child),
.charter-knowledge-item:not(:first-child) {
  margin-top: 24px;
}

@media screen and (max-width: 480px) {
  .charter-message-content {
    width: 100%;
  }

  .charter-message-text {
    margin: 0 16px;
  }

  .charter-active-list,
  .charter-knowledge-list {
    padding: 32px 16px;
  }

  .charter-active-item,
  .charter-knowledge-item {
    gap: 8px;
  }
}

/* ---------- 組織図 ---------- */

.organize-map {
  border-radius: 16px;
  box-shadow: 0 10px 30px 0 rgba(74, 144, 226, 0.08);
  overflow: hidden;
}

.organize-map-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

@media screen and (max-width: 480px) {
  .organize .organize-map {
    margin-left: 16px;
    margin-right: 16px;
  }
}

/* ---------- 歴史と沿革 ---------- */
.history-first-message,
.history-launch-message,
.history-passion-message {
  text-align: center;
  line-height: 2;
}

.history-passion-list {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 80px;
}

.history-passion-item {
  width: 288px;
}

.history-passion-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.history-spread-text {
  margin-top: 80px;
  text-align: center;
}

.history-spread-map {
  padding: 0 120px;
}

.history-spread-map-item {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  position: relative;
}

.history-spread-map-item::before {
  content: "";
  width: 4px;
  height: calc(100% - 135px);
  background: var(--hanada, #5dade2);
  position: absolute;
  bottom: 0;
  left: calc(136px / 2);
  transform: translateX(-50%);
}

.history-spread-map-item:last-child:before {
  display: none;
}

.history-spread-map-num {
  width: 136px;
  height: 136px;
  border-radius: 16px;
  background: var(--hanada, #5dade2);
  color: var(--text-inverse, #fff);
  text-align: center;
  font-size: 24px;
  font-weight: bold;
  margin-right: 108px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  position: relative;
}

.history-spread-map-num::before {
  content: "";
  width: 80px;
  height: 1px;
  background: var(--hanada, #5dade2);
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
}

.history-spread-map-text {
  height: 136px;
  display: flex;
  align-items: center;
}

.history-spread-map-img {
  width: 384px;
  height: 272px;
  object-fit: cover;
}

.history-project-message {
  text-align: center;
  line-height: 2;
}

.history-project-img-wrapper {
  margin-top: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 80px;
}

.history-project-img {
  width: 384px;
  height: 272px;
  object-fit: cover;
}

.history-future-message {
  color: var(--text-inverse, #fff);
  text-align: center;
  line-height: 2;
}

@media screen and (max-width: 480px) {
  .history-launch-message {
    text-align: left;
  }

  .history-passion-list {
    flex-direction: column;
    gap: 24px;
  }

  .history-passion-item {
    width: 70%;
  }

  .history-passion-message {
    text-align: left;
  }

  .history-spread-text {
    margin-left: 16px;
    margin-right: 16px;
  }

  .history-spread-map {
    padding: 0;
  }

  .history-spread-map-item::before {
    height: calc(100% - 79px);
    left: calc(80px / 2);
  }

  .history-spread-map-img {
    width: 100%;
    height: 140px;
    margin-bottom: 24px;
  }

  .history-spread-map-num {
    width: 80px;
    height: 80px;
    font-size: 16px;
    margin-right: 40px;
  }

  .history-spread-map-num::before {
    width: 24px;
  }

  .history-spread-map-text {
    height: auto;
    margin-top: 24px;
    margin-bottom: 16px;
  }

  .history-project-img-wrapper {
    flex-direction: column;
    gap: 24px;
  }

  .history-project-img {
    width: 100%;
    padding: 0 16px;
  }

  .history-future-message {
    text-align: left;
  }
}

/* ---------- お知らせ ---------- */
.news-content {
  margin-top: 48px;
}

.news-item {
  border-bottom: 1px solid #e0dede;
}

.news-item-link {
  padding: 32px 0;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 40px;
  transition: 0.4s opacity;
}

.news-item-link:hover {
  opacity: 0.7;
}

.news-item-time {
  flex-shrink: 0;
}

.news-item-cat {
  display: block;
  width: 160px;
  text-align: center;
  color: var(--text-inverse, #fff);
  border-radius: 16px;
  background: var(--edo-ai, #4a90e2);
  flex-shrink: 0;
}

.news-item-title {
  font-size: 16px;
  font-weight: normal;
}

.news-page-list {
  margin-top: 32px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
}

.news-page-item {
  width: 40px;
  height: 56px;
  background: #fff;
  border: 1px solid #e0dede;
  line-height: 56px;
}

.news-page-item:not(:first-child) {
  border-left: none;
}

.news-page-item-current {
  color: var(--bg-primary, #fff);
  background: var(--edo-ai, #4a90e2);
}

.news-page-link {
  display: block;
  width: 100%;
  height: 100%;
  transition: 0.4s;
}

.news-page-link:hover {
  color: var(--bg-primary, #fff);
  background: var(--edo-ai, #4a90e2);
}

@media screen and (max-width: 480px) {
  .news-item-link {
    flex-wrap: wrap;
  }

  .news-item-link {
    gap: 16px;
  }

  .news-item-cat {
    width: auto;
    padding: 0 16px;
  }

  .news-page-list {
    margin-top: 64px;
  }
}

/* ---------- 委員会活動について ---------- */
.committees-text {
  text-align: center;
}

.committees-text:not(:first-child) {
  margin-top: 32px;
}

.committees-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 40px;
}

.committees-item {
  width: calc((100% - 80px) / 3);
  border-radius: 12px;
  padding: 24px 0;
  background: #fff;
  box-shadow: 0 8px 24px 0 rgba(0, 0, 0, 0.05);
  overflow: hidden;
  transition: opacity 0.4s;
}

.committees-item:hover {
  opacity: 0.7;
}

.committees-item-link {
  display: block;
  width: 100%;
  height: 100%;
}

.committees-item-img {
  display: block;
  width: 115px;
  height: 115px;
  margin: 0 auto;
  border-radius: 50%;
  object-fit: cover;
  border: 2px solid #fff;
  background: #f5f5f5;
  box-shadow: 0 4px 12px 0 rgba(0, 0, 0, 0.1);
}

.committees-item-title {
  font-size: 18px;
  text-align: center;
  margin-top: 40px;
}

@media screen and (max-width: 480px) {
  .committees-text {
    margin: 0 16px;
    text-align: left;
    line-height: 2;
  }

  .committees-list {
    gap: 24px;
  }

  .committees-item {
    width: 100%;
  }
}

/* ---------- モーニングセミナー委員会 ---------- */
.ms-message-text {
  text-align: center;
}

.ms-message-text:not(:first-child) {
  margin-top: 32px;
}

.ms-greet-content {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 80px;
}

.ms-greet-img-wrapper {
  width: 320px;
  height: 320px;
  flex-shrink: 0;
  margin-left: 80px;
}

.ms-greet-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

.ms-greet-name {
  font-size: 20px;
}

.ms-greet-post {
  margin-top: 8px;
}

.ms-greet-desc {
  margin-top: 40px;
}

.ms-active-list {
  padding: 48px 64px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.ms-active-item {
  color: var(--edo-ai, #4a90e2);
  font-size: 18px;
  font-weight: bold;
  display: flex;
  gap: 16px;
}

.ms-active-item:not(:first-child) {
  margin-top: 24px;
}

.ms-flow-map {
  padding: 0 120px;
}

.ms-flow-map-item {
  display: flex;
  justify-content: flex-start;
  align-items: flex-start;
  position: relative;
}

.ms-flow-map-item::before {
  content: "";
  width: 4px;
  height: calc(100% - 135px);
  background: var(--hanada, #5dade2);
  position: absolute;
  bottom: 0;
  left: calc(136px / 2);
  transform: translateX(-50%);
}

.ms-flow-map-item:last-child:before {
  display: none;
}

.ms-flow-map-num {
  width: 136px;
  height: 136px;
  border-radius: 16px;
  background: var(--hanada, #5dade2);
  color: var(--text-inverse, #fff);
  text-align: center;
  font-size: 24px;
  font-weight: bold;
  margin-right: 108px;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-shrink: 0;
  position: relative;
}

.ms-flow-map-num::before {
  content: "";
  width: 80px;
  height: 1px;
  background: var(--hanada, #5dade2);
  position: absolute;
  top: 50%;
  left: 100%;
  transform: translateY(-50%);
}

.ms-flow-map-content {
  padding-bottom: 40px;
}

.ms-flow-map-text {
  height: 136px;
  display: flex;
  align-items: center;
}

.ms-vice-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 40px;
}

.ms-flow-map-img {
  width: 384px;
  height: 272px;
  object-fit: cover;
}

.ms-vice-img-wrapper {
  width: 320px;
  height: 320px;
  flex-shrink: 0;
}

.ms-vice-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
}

@media screen and (max-width: 768px) {
  .ms-message-text,
  .ms-greet-desc {
    text-align: left;
    line-height: 2;
  }

  .ms-greet-content {
    flex-direction: column;
    gap: 40px;
  }

  .ms-greet-img-wrapper {
    width: calc(100vw - 32px);
    height: calc(100vw - 32px);
    margin-left: 0;
  }

  .ms-active-list {
    padding: 32px 16px;
  }

  .ms-active-item {
    font-size: 16px;
  }

  .ms-active-item:not(:first-child) {
    margin-top: 32px;
  }

  .ms-flow-map {
    padding: 0 16px;
  }

  .ms-flow-map-item::before {
    height: calc(100% - 79px);
    left: calc(80px / 2);
  }

  .ms-flow-map-num {
    width: 80px;
    height: 80px;
    font-size: 16px;
    margin-right: 40px;
  }

  .ms-flow-map-num::before {
    width: 24px;
  }

  .ms-flow-map-text {
    height: 80px;
  }
}

/* ---------- イベントスケジュール ---------- */
.event-list {
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
}

.event-item {
  width: calc((100% - 80px) / 3);
  border-radius: 8px;
  border: 1px solid #f3f4f6;
  background: var(--bg-primary, #fff);
  box-shadow: 0 1px 3px 0 rgba(0, 0, 0, 0.1), 0 1px 2px 0 rgba(0, 0, 0, 0.06);
  padding: 32px;
}

.event-item-timing {
  display: flex;
  align-items: center;
  gap: 20px;
}

.event-item-week {
  width: 48px;
  height: 48px;
  border-radius: 6px;
  border: 1px solid #e0dede;
  background: var(--bg-secondary, #f8f9fa);
  box-shadow: 0 2px 8px 0 rgba(0, 0, 0, 0.04);
  line-height: 48px;
  color: #805ad5;
  font-size: 20px;
  font-weight: bold;
  text-align: center;
}

.event-item-date-wrapper {
  display: flex;
  flex-direction: column;
}

.event-item-day {
  color: #263238;
  font-size: 24px;
  font-weight: bold;
}

.event-item-time {
  color: var(--text-secondary, #666);
  font-size: 14px;
  margin-top: -4px;
}

.event-item-title {
  margin-top: 24px;
  color: var(--text-primary, #333);
  font-size: 20px;
  font-weight: bold;
}

.event-item-tag {
  margin-top: 24px;
}

.event-item-venue,
.event-item-cat {
  display: flex;
  align-items: center;
  gap: 12px;
}

.event-item-cat {
  margin-top: 20px;
}

.event-item-tag-title {
  width: 120px;
  font-size: 14px;
  color: #fff;
  text-align: center;
  border-radius: 2px;
  background: #0e3a58;
  padding: 6px 0;
}

.event-item-desc {
  margin-top: 24px;
}

.event-item-link {
  display: block;
  margin-top: 24px;
  width: 100%;
  padding: 16px 0;
  text-align: center;
  border-radius: 4px;
  border: 1px solid #6b7280;
  color: #374151;
  font-size: 14px;
  font-weight: bold;
  transition: background 0.3s, color 0.3s;
}

.event-item-link:hover {
  color: #fff;
  background: #0e3a58;
}

@media screen and (max-width: 480px) {
  .event .section-container {
    overflow: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }

  .content::-webkit-scrollbar {
    display: none;
  }

  .event-list {
    flex-wrap: nowrap;
    /* width: calc(((100vw - 32px) * 6) + 24px); */
  }

  .event-item {
    width: calc(100vw - 32px);
    flex-shrink: 0;
  }
}

/* ---------- お知らせ個別 ---------- */
.s-news-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.s-news-item-time {
  flex-shrink: 0;
}

.s-news-item-cat {
  display: block;
  padding: 0 24px;
  text-align: center;
  color: var(--text-inverse, #fff);
  border-radius: 16px;
  background: var(--edo-ai, #4a90e2);
  flex-shrink: 0;
}

.s-news .section-title {
  margin-top: 40px;
}

.s-news-img-wrapper {
  margin-top: 64px;
}

.s-news-img {
  width: 100%;
  object-fit: cover;
}

.s-news-h2 {
  margin: 40px 0 16px;
  font-size: 24px;
  padding-left: 12px;
  color: #1b4f72;
  border-left: 8px solid #1b4f72;
}

.s-news-h3 {
  margin: 32px 0 16px;
  font-size: 20px;
  text-decoration: underline;
}

.s-news-text {
  margin: 16px 0;
}

.s-news-link-wrapper {
  margin: 80px auto;
  text-align: center;
}

.s-news-link {
  padding: 16px 32px;
  font-weight: bold;
  color: #fff;
  border-radius: 4px;
  border: 1px solid var(--bg-primary, #fff);
  background: var(
    --Linear2,
    linear-gradient(167deg, #2c5aa0 2.53%, #1b4f72 95.63%)
  );
}

.s-news-link:hover {
  opacity: 0.7;
}

@media screen and (max-width: 480px) {
  .s-news-item-cat {
    width: auto;
    padding: 0 16px;
  }

  .s-news .section-title {
    text-align: left;
  }

  .s-news-img-wrapper {
    margin-top: 40px;
  }

  .s-news-h2 {
    font-size: 20px;
  }

  .s-news-h3 {
    font-size: 18px;
  }

  .s-news-text {
    line-height: 1.8;
  }

  .s-news-link-wrapper {
    margin-bottom: 0;
  }

  .s-news-link {
    display: block;
    width: calc(100% - 32px);
    margin: 0 auto;
  }
}

/* ---------- 倫理法人会とは ---------- */
.about-first-text,
.about-detail-text,
.about-pure-text,
.about-last-text {
  text-align: center;
  line-height: 2;
}

.about-first-text-bold {
  font-weight: bold;
}

.about-detail-table {
  width: 100%;
  margin: 40px 0;
}

.about-detail-tr {
  height: 72px;
  display: flex;
  border-top: 1px solid var(--text-muted, #999);
}

.about-detail-tr:last-child {
  border-bottom: 1px solid var(--text-muted, #999);
}

.about-detail-th,
.about-detail-td {
  text-align: left;
  padding-left: 32px;
  line-height: 72px;
  flex-shrink: 0;
}

.about-detail-th {
  width: 40%;
  background: var(--bg-secondary, #f8f9fa);
}

.about-detail-td {
  width: 60%;
  background: #fff;
}

.about-pure-list {
  margin-top: 40px;
  display: flex;
  justify-content: center;
  gap: 40px;
}

.about-pure-item {
  flex: 1;
  flex-shrink: 0;
  padding: 24px 32px;
  background: #fff;
  border-radius: 16px;
}

.about-pure-item-title {
  color: var(--text-primary, #333);
  font-size: 32px;
  font-weight: bold;
  display: flex;
  align-items: center;
  gap: 10px;
}

.about-pure-item-title::before {
  content: "";
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #4a90e2;
  flex-shrink: 0;
}

.about-pure-item-img {
  width: 100%;
  object-fit: cover;
  padding: 0 48px;
  margin-top: 32px;
}

.about-pure-item-text {
  margin-top: 32px;
  line-height: 2;
  text-align: center;
}

.about-merit {
  padding: 104px 0;
}

.about-merit-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 40px;
}

.about-merit-item {
  width: calc((100% - 80px) / 3);
  padding: 30px;
  border-radius: 16px;
  background: #fff;
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
  flex-shrink: 0;
  position: relative;
}

.about-merit-item::before {
  color: rgba(93, 173, 226, 0.2);
  font-size: 56px;
  font-weight: bold;
  position: absolute;
  top: 16px;
  right: 24px;
}

.about-merit-item:nth-child(1):before {
  content: "01";
}
.about-merit-item:nth-child(2):before {
  content: "02";
}
.about-merit-item:nth-child(3):before {
  content: "03";
}
.about-merit-item:nth-child(4):before {
  content: "04";
}
.about-merit-item:nth-child(5):before {
  content: "05";
}
.about-merit-item:nth-child(6):before {
  content: "06";
}
.about-merit-item:nth-child(7):before {
  content: "07";
}
.about-merit-item:nth-child(8):before {
  content: "08";
}

.about-merit-item-title {
  color: var(--edo-ai, #4a90e2);
  margin-top: 36px;
  font-size: 28px;
}

.about-merit-item-text {
  margin-top: 32px;
}

.about-merit-comment {
  margin: 24px auto 0;
  text-align: right;
  color: var(--text-muted, #999);
}

.about-faq-wrapper {
  margin-top: 80px;
}

.about-faq-title {
  background: var(--bar-background, #2c5aa0);
  color: var(--text-inverse, #fff);
  font-size: 24px;
  font-weight: bold;
  padding: 8px 35px;
  margin-bottom: 40px;
}

.about-faq-item {
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.about-faq-item:not(:first-child) {
  margin-top: 40px;
}

.about-faq-question,
.about-faq-answer {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 32px;
  height: 72px;
}

.about-faq-question {
  color: var(--text-primary, #333);
  font-size: 20px;
  font-weight: bold;
  background: rgba(174, 214, 241, 0.5);
  position: relative;
}

.about-faq-question::before {
  content: "";
  width: 24px;
  height: 4px;
  background: var(--edo-ai, #4a90e2);
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translateY(-50%);
}

.about-faq-answer {
  background: #fff;
}

.about-faq-question-tag,
.about-faq-answer-tag {
  width: 72px;
  height: 72px;
  display: flex;
  justify-content: center;
  align-items: center;
  text-align: center;
  font-size: 24px;
  font-weight: bold;
}

.about-faq-question-tag {
  color: var(--text-inverse, #fff);
  background: var(--edo-ai, #4a90e2);
}

.about-faq-answer-tag {
  color: var(--edo-ai, #4a90e2);
}

.about-last-text {
  color: #fff;
}

.about-last-button-wrapper {
  text-align: center;
  margin-top: 80px;
}

.about-last-button {
  display: inline-block;
  color: var(--kon-iro, #2e86c1);
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  border-radius: 4px;
  border: 1px solid var(--bg-primary, #fff);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 4px 16px 0 rgba(74, 144, 226, 0.15);
  padding: 0 24px;
  line-height: 72px;
}

.about-last-button:hover {
  opacity: 0.7;
}

@media screen and (max-width: 480px) {
  .about-first-text {
    text-align: left;
  }

  .about-detail-table-wrapper {
    overflow-x: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .content::-webkit-scrollbar {
    display: none;
  }

  .about-detail-th,
  .about-detail-td {
    padding-left: 16px;
  }

  .about-detail-th {
    width: 200px;
  }

  .about-detail-td {
    width: 500px;
  }

  .about-detail-text {
    text-align: left;
  }

  .about-detail-text br {
    display: none;
  }

  .about-pure-list {
    flex-direction: column;
  }

  .about-pure-item-title {
    font-size: 20px;
  }

  .about-pure-item-img {
    padding: 0;
  }

  .about-pure-item-text {
    text-align: left;
  }

  .about-merit-list {
    flex-direction: column;
  }

  .about-merit-item {
    width: 100%;
  }

  .about-faq-question,
  .about-faq-answer {
    height: auto;
    padding: 8px 0;
    gap: 16px;
  }

  .about-faq-question {
    font-size: 16px;
    padding-right: 24px;
  }

  .about-faq-question::before {
    right: 8px;
    width: 16px;
  }

  .about-faq-question-tag,
  .about-faq-answer-tag {
    width: 40px;
    height: 40px;
    margin-left: 8px;
    flex-shrink: 0;
    font-size: 16px;
  }

  .about-last-button {
    font-size: 14px;
  }
}

/* ---------- 倫理法人会の活動内容 ---------- */
.active-title {
  text-align: center;
  color: var(--text-primary, #333);
  font-size: 32px;
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
}

.active-title::before,
.active-title::after {
  content: "";
  width: 100px;
  height: 1px;
  background: var(--text-primary, #333);
}

.active-main-text {
  text-align: center;
  line-height: 2;
}

.active-main-list {
  margin-top: 80px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 60px;
}

.active-main-item {
  width: calc((100% - 60px) / 2);
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
  overflow: hidden;
}

.active-main-item-title {
  text-align: center;
  padding: 12px 0;
  color: var(--text-inverse, #fff);
  font-size: 28px;
  font-weight: bold;
  background: var(--kon-iro, #2e86c1);
}

.active-main-item:nth-child(2) .active-main-item-title,
.active-main-item:nth-child(3) .active-main-item-title,
.active-main-item:nth-child(6) .active-main-item-title {
  background: var(--sora-iro, #85c1e9);
}

.active-main-item-img {
  width: 100%;
  height: 256px;
  object-fit: cover;
}

.active-main-item-content {
  padding: 32px;
}

.active-main-item-bold {
  color: var(--edo-ai, #4a90e2);
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}

.active-main-item-text {
  margin-top: 24px;
}

.active-main-bigcopy {
  margin-top: 80px;
  color: var(--text-primary, #333);
  text-align: center;
  font-size: 32px;
  font-weight: bold;
}

.active-main-bigcopy + .active-main-text {
  margin-top: 80px;
}

.active-last-text {
  color: #fff;
  text-align: center;
  line-height: 2;
}

.active-last-button-wrapper {
  text-align: center;
  margin-top: 80px;
}

.active-last-button {
  display: inline-block;
  color: var(--kon-iro, #2e86c1);
  text-align: center;
  font-size: 18px;
  font-weight: bold;
  border-radius: 4px;
  border: 1px solid var(--bg-primary, #fff);
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 4px 16px 0 rgba(74, 144, 226, 0.15);
  padding: 0 24px;
  line-height: 72px;
}

.active-last-button:hover {
  opacity: 0.7;
}

@media screen and (max-width: 480px) {
  .active-title {
    margin: 0 16px;
    font-size: 20px;
    flex-direction: column;
    gap: 16px;
  }

  .active-main-list {
    flex-direction: column;
  }

  .active-main-item {
    width: 100%;
  }

  .active-main-bigcopy {
    text-align: left;
  }
}

/* ---------- 会長メッセージ・役員紹介 ---------- */
.leader-top-content {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 44px;
}

.leader-top-img {
  width: 450px;
  height: 800px;
  object-fit: cover;
  /* border-radius: 50%; */
  flex-shrink: 0;
}

.leader-top-bigcopy {
  color: var(--text-primary, #333);
  font-size: 24px;
  font-weight: bold;
}

.leader-top-text {
  text-align-last: left;
  margin-top: 32px;
  line-height: 2;
}

.leader-top-name {
  margin-top: 32px;
  text-align: right;
  font-weight: bold;
}

.leader-chief-list {
  display: flex;
  gap: 80px;
}

.leader-chief-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
  flex: 1;
}

.leader-chief-img {
  width: 200px;
  height: 200px;
  object-fit: cover;
  /* border-radius: 50%; */
  flex-shrink: 0;
}

.leader-chief-name {
  font-weight: bold;
}

.leader-chief-text {
  margin-top: 40px;
}

.leader-venue-content {
  text-align: center;
}

.leader-venue-list {
  display: inline-block;
  text-align: left;
  padding: 40px 80px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.leader-venue-item:not(:first-child) {
  margin-top: 16px;
}

.leader-venue-table {
  width: 100%;
  margin: 40px 0;
}

.leader-venue-tr {
  height: 72px;
  display: flex;
  border-top: 1px solid var(--text-muted, #999);
}

.leader-venue-tr:last-child {
  border-bottom: 1px solid var(--text-muted, #999);
}

.leader-venue-th,
.leader-venue-td {
  text-align: left;
  padding-left: 32px;
  line-height: 72px;
  flex-shrink: 0;
}

.leader-venue-th {
  width: 40%;
  background: var(--bg-secondary, #f8f9fa);
}

.leader-venue-td {
  width: 60%;
  background: #fff;
}

@media screen and (max-width: 480px) {
  .leader-top-content {
    flex-direction: column;
  }

  .leader-top-img {
    width: 300px;
    height: 300px;
  }

  .leader-chief-list {
    flex-direction: column;
    gap: 64px;
  }

  .leader-chief-item {
    flex-direction: column;
  }

  .leader-chief-text {
    margin-top: 24px;
  }

  .leader-venue-list {
    padding: 40px 24px;
  }

  .leader-venue-table-wrapper {
    overflow-x: scroll;
  }

  .leader-venue-table-wrapper {
    overflow-x: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .content::-webkit-scrollbar {
    display: none;
  }

  .leader-venue-tr {
    height: auto;
  }

  .leader-venue-th,
  .leader-venue-td {
    padding: 16px;
    line-height: 1.75;
  }

  .leader-venue-th {
    width: 200px;
  }

  .leader-venue-td {
    width: 500px;
  }

  .organize-map {
    overflow-x: scroll;
    margin: 40px 0 0;
  }

  .organize-map-img {
    width: 800px;
    height: auto;
  }
}

/* ---------- 単会一覧ページ ---------- */
.tankai-main .section-container {
  text-align: center;
}

.tankai-section-text {
  text-align: center;
  line-height: 2;
}

.tankai-num-list-wrapper {
  display: inline-block;
}

.tankai-num-list {
  margin-top: 80px;
  padding: 12px 0 28px;
  border-top: 0.8px solid var(--edo-ai, #4a90e2);
  border-bottom: 0.8px solid var(--edo-ai, #4a90e2);
  display: flex;
  justify-content: center;
  gap: 80px;
}

.tankai-num-item {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  color: var(--text-secondary, #666);
}

.tankai-num-big {
  color: var(--edo-ai, #4a90e2);
  text-align: center;
  font-size: 64px;
  font-weight: bold;
  margin-bottom: -12px;
}

.tankai-area {
  max-width: 800px;
  margin: 80px auto 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 80px;
  position: relative;
  z-index: 10;
}

.tankai-area::before {
  content: "";
  width: 100vw;
  height: 100%;
  background: url(../media/tokyo.png) center / contain;
  background-repeat: no-repeat;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  opacity: 0.3;
  z-index: -1;
}

.tankai-area-box {
  width: calc((100% - 80px) / 2);
}

.tankai-area-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.tankai-area-title {
  color: var(--edo-ai, #4a90e2);
  font-size: 20px;
  font-weight: bold;
  border-left: 3px solid var(--edo-ai, #4a90e2);
  padding: 4px 0 8px 16px;
}

.tankai-area-num {
  color: var(--text-secondary, #666);
  font-size: 14px;
}

.tankai-area-list {
  margin-top: 24px;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}

.tankai-area-item {
  width: 120px;
  /* min-width: 100px; */
  text-align: center;
  padding: 8px 24px;
  border-radius: 4px;
  border: 1px solid var(--kon-iro, #2e86c1);
  background: var(--bg-primary, #fff);
  box-shadow: 0 4px 16px 0 rgba(74, 144, 226, 0.15);
  color: var(--edo-ai, #4a90e2);
  font-size: 14px;
}

.tankai-area-over {
  width: 150px;
  text-align: center;
  padding: 8px 24px;
  border-radius: 4px;
  border: 1px solid var(--kon-iro, #2e86c1);
  background: var(--bg-primary, #fff);
  box-shadow: 0 4px 16px 0 rgba(74, 144, 226, 0.15);
  color: var(--edo-ai, #4a90e2);
  font-size: 14px;
}

@media screen and (max-width: 480px) {
  .tankai-section-text {
    text-align: left;
  }

  .tankai-area {
    margin-left: 16px;
    margin-right: 16px;
    flex-direction: column;
    gap: 64px;
  }

  .tankai-area-box {
    width: 100%;
  }
}

/* ---------- 数字でわかる倫理法人会 ---------- */
.statistics-section {
  background: url(../media/statistics-bg.png) center / cover;
}

.statistics-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 32px;
}

.statistics-item {
  width: calc((100% - 64px) / 3);
  padding: 40px;
  border-radius: 16px;
  border: 1px solid rgba(74, 144, 226, 0.25);
  background: rgba(255, 255, 255, 0.6);
  backdrop-filter: blur(7.5px);
}

.statistics-item-num-wrapper {
  color: var(--kon-iro, #2e86c1);
  text-align: center;
  font-size: 20px;
}

.statistics-item-num {
  font-size: 50px;
  font-weight: bold;
  letter-spacing: -0.512px;
  background: var(
    --Linear3,
    linear-gradient(
      109deg,
      var(--kon-iro, #2e86c1) 14.37%,
      var(--hanada, #5dade2) 89.14%
    )
  );
  background-clip: text;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.statistics-item-title {
  margin-top: 16px;
  color: var(--text-primary, #333);
  text-align: center;
  text-shadow: 2px 2px 2px rgba(0, 0, 0, 0.2);
  font-size: 18px;
  font-weight: bold;
}

.statistics-item-text {
  margin-top: 16px;
  text-align: center;
}

@media screen and (max-width: 480px) {
  .statistics-list {
    flex-direction: column;
  }

  .statistics-item {
    width: 100%;
  }
}

/* ---------- 役職者専用ページ ---------- */
.official-news-text {
  text-align: center;
}

.official-use-list {
  padding: 48px 64px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.official-use-item {
  color: var(--edo-ai, #4a90e2);
  font-size: 18px;
  font-weight: bold;
  display: flex;
  gap: 16px;
}

.official-use-item:not(:first-child) {
  margin-top: 24px;
}

.official-doc .section-title {
  margin-top: 80px;
}

.official-doc-wrapper {
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.official-doc-wrapper:not(:first-child) {
  margin-top: 40px;
}

.official-doc-title {
  height: 72px;
  line-height: 72px;
  padding-left: 40px;
  background: var(--edo-ai, #4a90e2);
  color: var(--text-inverse, #fff);
  font-size: 24px;
  font-weight: bold;
  position: relative;
}

.official-doc-title::before {
  content: "";
  width: 24px;
  height: 4px;
  background: #fff;
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translateY(-50%);
}

.official-doc-content {
  padding: 40px;
}

.official-doc-table {
  width: 100%;
}

.official-doc-tr {
  padding: 24px;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 40px;
  border: 1px solid #e0dede;
}

.official-doc-tr:nth-child(odd) {
  background: var(--bg-tertiary, #f5f7fa);
}

.official-doc-tr:not(:first-child) {
  border-top: none;
}

.official-doc-th {
  flex: 3;
  text-align: left;
  flex-shrink: 0;
  font-weight: normal;
}

.official-doc-td {
  flex: 1;
}

.official-doc-btn-wrapper {
  margin-top: 16px;
  text-align: center;
}

.official-doc-btn {
  display: inline-block;
  padding: 24px 56px;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
  color: var(--edo-ai, #4a90e2);
  text-align: center;
  font-family: "Noto Sans JP";
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 27px; /* 150% */
  letter-spacing: 0.18px;
}

.official-ano {
  padding: 40px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.official-ano-title {
  text-align: center;
  color: var(--text-primary, #333);
  text-align: center;
  font-size: 32px;
}

.official-ano-title:nth-of-type(2) {
  margin-top: 40px;
}

.official-ano-list {
  margin-top: 40px;
  padding: 0 80px;
}

.official-ano-item {
  color: var(--edo-ai, #4a90e2);
  font-weight: bold;
}

.official-ano-item:not(:first-child) {
  margin-top: 16px;
}

@media screen and (max-width: 480px) {
  .official-use-list {
    padding: 32px 16px;
  }

  .official-use-item {
    gap: 8px;
  }

  .official-news-text {
    margin: 0 16px;
  }

  .official-doc-title {
    font-size: 20px;
    padding-left: 16px;
  }

  .official-doc-title::before {
    right: 16px;
  }

  .official-doc-content {
    padding: 16px;
  }

  .official-doc-tr {
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  .official-doc-th {
    font-weight: bold;
  }

  .official-ano {
    padding: 40px 16px;
  }

  .official-ano-list {
    padding: 0;
  }
}

/* ---------- 会員専用ページ ---------- */
.exclusive-first-text {
  text-align: center;
  line-height: 2;
}

.exclusive-training-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 40px;
}

.exclusive-training-item {
  width: calc((100% - 80px) / 3);
  padding: 32px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.exclusive-training-item:last-child {
  width: 100%;
  position: relative;
}

.exclusive-training-item:last-child::before {
  content: "";
  width: 270px;
  height: 142px;
  background: url(../media/treasure.png) center / cover;
  position: absolute;
  bottom: 40px;
  left: 64px;
}

.exclusive-training-item-title {
  color: var(--edo-ai, #4a90e2);
  text-align: center;
  font-size: 28px;
}

.exclusive-training-item-text {
  margin-top: 24px;
  line-height: 1.8;
}

.exclusive-training-item-link {
  display: block;
  margin-top: 24px;
  padding: 20px 0;
  text-align: center;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
  color: var(--edo-ai, #4a90e2);
  font-size: 18px;
  font-weight: bold;
}

.exclusive-training-item-link-wrapper {
  display: flex;
  gap: 40px;
}

.exclusive-training-item-link-wrapper .exclusive-training-item-link {
  padding: 24px 80px;
}

.exclusive-training-item:last-child .exclusive-training-item-text,
.exclusive-training-item:last-child .exclusive-training-item-link-wrapper {
  padding-left: 360px;
}

.exclusive-doc-list {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 50px;
}

.exclusive-doc-item,
.exclusive-other-item {
  padding: 32px;
}

.exclusive-doc-item {
  width: calc((100% - 50px) / 2);
  flex-shrink: 0;
}

.exclusive-doc-title,
.exclusive-other-title {
  color: var(--text-primary, #333);
  font-size: 32px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.exclusive-doc-title::before,
.exclusive-other-title::before {
  content: "";
  width: 18px;
  height: 18px;
  flex-shrink: 0;
  background: var(--edo-ai, #4a90e2);
  border-radius: 50%;
}

.exclusive-doc-text,
.exclusive-other-text {
  margin-top: 32px;
}

.exclusive-doc-link-wrapper,
.exclusive-other-link-wrapper {
  text-align: center;
  margin-top: 24px;
}

.exclusive-doc-link,
.exclusive-other-link {
  display: inline-block;
  min-width: 272px;
  padding: 20px 36px;
  font-size: 18px;
  font-weight: bold;
  color: var(--edo-ai, #4a90e2);
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
}

.exclusive-doc-item:last-child .exclusive-doc-link {
  width: 400px;
}

.exclusive-other-item:not(:first-child) {
  margin-top: 72px;
}

@media screen and (max-width: 480px) {
  .exclusive-training-list {
    flex-direction: column;
  }

  .exclusive-training-item {
    width: 100%;
  }

  .exclusive-training-item:last-child {
  }

  .exclusive-training-item:last-child::before {
    display: none;
  }

  .exclusive-training-item:last-child .exclusive-training-item-text,
  .exclusive-training-item:last-child .exclusive-training-item-link-wrapper {
    padding-left: 0;
  }

  .exclusive-training-item-link-wrapper {
    flex-direction: column;
    gap: 0;
  }

  .exclusive-training-item-link-wrapper .exclusive-training-item-link {
    padding: 24px 0;
    text-align: center;
  }

  .exclusive-doc-list {
    flex-direction: column;
  }

  .exclusive-doc-item,
  .exclusive-other-item {
    width: 100%;
    padding: 16px;
  }

  .exclusive-doc-title,
  .exclusive-other-title {
    font-size: 24px;
  }

  .exclusive-doc-item:last-child .exclusive-doc-link {
    width: auto;
  }

  .exclusive-other-item:not(:first-child) {
    margin-top: 40px;
  }
}

/* ---------- お問い合わせ ---------- */
.contact-privacy-text,
.contact-form-text {
  text-align: center;
  line-height: 2;
}

.contact-privacy-btn-wrapper {
  margin-top: 40px;
  text-align: center;
}

.contact-privacy-btn {
  min-width: 320px;
  padding: 24px;
  display: inline-block;
  color: var(--edo-ai, #4a90e2);
  font-family: "Noto Sans JP";
  font-size: 18px;
  font-weight: bold;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
}

.contact-form-area {
  margin-top: 40px;
  padding: 40px 80px;
  color: var(--c-text);
  font-size: 16px;
  border-radius: 16px;
  background: var(--bg-secondary, #f8f9fa);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.contact-form-area dl {
  margin: 0 0 var(--gap-lg);
  padding: 0;
  padding-top: 32px;
  border-bottom: 1px dotted var(--c-border);
  padding-bottom: var(--gap);
}
.contact-form-area dt {
  margin: 0 0 6px;
  font-weight: 700;
  display: flex;
  align-items: center;
  gap: 8px;
}
.contact-form-area dd {
  margin: 0;
}

.form-label {
  color: var(--text-primary, #333);
  font-size: 20px;
  font-weight: bold;
}
.required {
  display: inline-block;
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 4px;
  color: #fff;
  background: var(--c-accent);
}
.hint {
  display: block;
  font-weight: 400;
  color: var(--c-muted);
  font-size: 12px;
}

.contact-form-area input[type="text"],
.contact-form-area input[type="email"],
.contact-form-area input[type="tel"],
.contact-form-area textarea {
  width: 100%;
  border: 1px solid var(--c-border);
  border-radius: var(--radius);
  padding: 12px 14px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
  background: #fff;
}
.contact-form-area textarea {
  resize: vertical;
  min-height: 140px;
}

.contact-form-area input:focus,
.contact-form-area textarea:focus {
  border-color: var(--c-primary);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--c-primary) 20%, transparent);
}

.radio-group {
  display: grid;
  grid-template-columns: repeat(2, minmax(280px, 1fr));
  gap: 10px 16px;
}
.radio-group label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  user-select: none;
  color: var(--c-text);
}

.need {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.need::after {
  content: "必須";
  font-size: 14px;
  font-weight: bold;
  padding: 4px 8px;
  border-radius: 2px;
  border: 1px solid var(--must, #f00);
  color: var(--must, #f00);
}

.form-row--split {
  display: inline-block;
  vertical-align: top;
  width: calc(50% - 12px);
  margin-right: 16px;
}
.form-row--split + .form-row--split {
  margin-right: 0;
}

.checkbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: bold;
  font-size: 20px;
}
.checkbox input {
  width: auto;
}

.email-note {
  font-weight: normal;
}

.contact-submit-wrapper {
  margin-top: 32px;
  text-align: center;
}

.contact-submit {
  min-width: 242px;
  text-align: center;
  padding: 24px 0;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
  color: var(--edo-ai, #4a90e2);
  font-size: 18px;
  font-weight: bold;
}

.contact-direct {
  margin-top: 80px;
  padding: 40px 80px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.contact-direct-title {
  font-size: 20px;
  margin-bottom: 16px;
}

.contact-direct-text {
  font-size: 20px;
  line-height: 2;
}

.contact-last-text {
  text-align: center;
  margin-top: 80px;
}

.contact-last-link-wrapper {
  margin-top: 40px;
  display: flex;
  justify-content: space-between;
}

.contact-last-link {
  min-width: calc((100% - 96px) / 3);
  flex-shrink: 0;
  padding: 16px 8px;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
  text-align: center;
  color: var(--edo-ai, #4a90e2);
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
}

.contact-last-link::after {
  content: "→";
}

@media screen and (max-width: 480px) {
  .contact-privacy-text,
  .contact-form-text {
    text-align: left;
  }

  .contact-privacy-text {
    margin-top: 0;
  }

  .contact-form-area {
    padding: 16px;
  }

  .radio-group {
    display: flex;
    flex-direction: column;
  }

  .contact-form-area dt {
    flex-direction: column;
    align-items: flex-start;
  }

  .form-row--split {
    width: 100%;
  }

  .checkbox {
    font-size: 16px;
    gap: 16px;
  }

  .contact-direct {
    padding: 16px;
  }

  .contact-direct-text {
    font-size: 16px;
  }

  .contact-last-link-wrapper {
    flex-direction: column;
    gap: 24px;
  }

  .contact-last-link {
    width: 100%;
  }
}

/* ---------- 初めての方へ ---------- */
.hero-first {
  height: 600px;
}

.hero-first .hero-content {
  justify-content: center;
}

.hero-first .hero-title {
  color: var(--text-inverse, #fff);
  text-shadow: 0 1px 3px rgba(0, 0, 0, 0.4);
  font-size: 40px;
  font-weight: bold;
  text-align: center;
  line-height: 2;
  margin-top: 80px;
}

.hero-first .hero-text-container {
  width: 100%;
}

.hero-first .hero-title-sub {
  justify-content: flex-end;
}

.hero-first .hero-title-name {
  width: 100%;
}

.first-btn-content {
  margin-top: 0;
}

.first-btn-wrapper,
.first-next-wrapper {
  max-width: 800px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
}

.first-btn,
.first-next,
.first-join-btn {
  color: var(--edo-ai, #4a90e2);
  text-align: center;
  padding: 24px 48px;
  font-size: 18px;
  font-weight: bold;
  border-radius: 5px;
  border: 1px solid var(--edo-ai, #4a90e2);
  background: var(--bg-primary, #fff);
  display: flex;
  align-items: center;
  gap: 24px;
}

.first-btn::after,
.first-next::after,
.first-join-btn::after {
  content: "→";
}

.first-about-list {
  padding: 48px 64px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 10px 10px 20px 0 rgba(74, 144, 226, 0.08);
}

.first-about-item {
  color: var(--edo-ai, #4a90e2);
  font-size: 18px;
  font-weight: bold;
  display: flex;
  gap: 16px;
}

.first-about-item:not(:first-child) {
  margin-top: 24px;
}

.first-about-text {
  margin-top: 40px;
  color: var(--text-primary, #333);
  font-size: 28px;
  font-weight: bold;
  text-align: center;
}

.first-active-text {
  text-align: center;
  line-height: 2;
}

.first-active-list {
  margin-top: 80px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 32px;
}

.first-active-item {
  width: calc((100% - 64px) / 3);
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
  overflow: hidden;
}

.first-active-item-title {
  text-align: center;
  padding: 12px 0;
  color: var(--text-inverse, #fff);
  font-size: 28px;
  font-weight: bold;
  background: var(--kon-iro, #2e86c1);
}

.first-active-item:nth-child(even) .first-active-item-title {
  background: var(--sora-iro, #85c1e9);
}

.first-active-item-img {
  width: 100%;
  height: 200px;
  object-fit: cover;
}

.first-active-item-content {
  padding: 32px;
}

.first-active-item-bold {
  color: var(--edo-ai, #4a90e2);
  text-align: center;
  font-size: 20px;
  font-weight: bold;
}

.first-active-item-text {
  margin-top: 24px;
}

.first-active-bigcopy {
  margin-top: 80px;
  color: var(--text-primary, #333);
  text-align: center;
  font-size: 32px;
  font-weight: bold;
}

.first-active-bigcopy + .first-active-text {
  margin-top: 80px;
}

.first-next-section {
  background: var(
    --Linear3,
    linear-gradient(
      109deg,
      var(--kon-iro, #2e86c1) 14.37%,
      var(--hanada, #5dade2) 89.14%
    )
  );
}

.first-join-text {
  color: var(--text-inverse, #fff);
  text-align: center;
  text-shadow: 0 0 4px rgba(30, 79, 138, 0.76);
  font-size: 28px;
  font-weight: bold;
  line-height: 2;
}

.first-join-wrapper {
  margin-top: 80px;
  display: flex;
  justify-content: center;
  align-items: center;
}

.first-join-desc {
  margin-top: 80px;
}

.first-join-desc-title {
  text-align: center;
  color: var(--text-inverse, #fff);
  font-size: 28px;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 40px;
}

.first-join-desc-title::before {
  content: "\\";
}

.first-join-desc-title::after {
  content: "/";
}

.first-join-desc-list {
  margin-top: 40px;
  display: flex;
  justify-content: center;
  padding: 32px;
  border-radius: 16px;
  background: var(--bg-primary, #fff);
  box-shadow: 0 10px 30px 0 rgba(74, 123, 167, 0.08);
}

.first-join-desc-item {
  width: calc(100% / 3);
  text-align: center;
  padding: 0 32px;
}

.first-join-desc-item:not(:first-child) {
  border-left: 1px solid var(--text-muted, #999);
}

.first-join-desc-img {
  width: 200px;
  height: 200px;
  object-fit: cover;
}

.first-join-desc-text {
  color: var(--text-primary, #333);
  text-align: center;
  font-weight: bold;
  margin-top: 16px;
}

.first-join-desc-item:nth-child(2) .first-join-desc-text {
  margin-top: 32px;
}

@media screen and (max-width: 480px) {
  .hero-first {
    height: 320px;
  }

  .hero-first .hero-title {
    font-size: 20px;
    margin-top: 40px;
  }

  .first-btn-wrapper,
  .first-next-wrapper {
    gap: 24px;
  }

  .first-btn,
  .first-next {
    width: 100%;
  }

  .first-btn,
  .first-next,
  .first-join-btn {
    padding: 24px 0;
    justify-content: center;
  }

  .first-about-list {
    padding: 32px 16px;
    margin-left: 0;
    margin-right: 0;
  }

  .first-about-item {
    gap: 8px;
    font-size: 16px;
  }

  .first-about-text {
    font-size: 20px;
  }

  .first-active-list {
    flex-direction: column;
  }

  .first-active-item {
    width: 100%;
  }

  .first-active-bigcopy {
    text-align: left;
  }

  .first-join-text {
    font-size: 20px;
  }

  .first-join-btn {
    width: 100%;
  }

  .first-join-desc-list {
    margin-left: 0;
    margin-right: 0;
    flex-direction: column;
  }

  .first-join-desc-item {
    width: 100%;
  }

  .first-join-desc-item:not(:first-child) {
    margin-top: 40px;
    border-top: 1px solid var(--text-muted, #999);
    border-left: none;
  }

  .first-join-desc-text {
    margin-top: 0;
  }

  .first-join-desc-item:nth-child(2) .first-join-desc-text {
    margin-top: 0;
  }
}

/* ---------- JSアニメーション用コード ---------- */

/* フェードイン */
.fade-in {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.6s ease-out, transform 0.6s ease-out;
}

.fade-in.fade-active {
  opacity: 1;
  transform: translateY(0);
}

/* Q&A */
.js-faq-question {
  cursor: pointer;
}

.js-faq .js-faq-answer {
  height: auto;
  max-height: 0;
  overflow: hidden;
  padding-block: 0;
  transition: max-height 0.3s ease, padding 0.3s ease;
}

.js-faq.is-open .js-faq-answer {
  max-height: 5000px;
  padding-block: 16px;
}

/* ---------- WordPress対策 ---------- */
.customize-support {
  padding: 0 !important;
}

.sns-links-section {
  padding: 40px 0;
  /* background-color: #f8f9fa; */
}

.container {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 20px;
}

/* snsアイコン（フッター） */
.sns-links {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  justify-content: center;
  align-items: center;
}

.sns-link-btn {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 20px;
  background-color: #fff;
  border: 2px solid #e1e5e9;
  border-radius: 8px;
  text-decoration: none;
  color: #333;
  font-weight: 600;
  transition: all 0.3s ease;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
}

.sns-link-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.sns-icon {
  width: 24px;
  height: 24px;
  transition: transform 0.3s ease;
}

.sns-link-btn:hover .sns-icon {
  transform: scale(1.1);
}

/* 各SNSのブランドカラー */
/* Facebook */
.sns-link-btn[href*="facebook"] .sns-icon {
  fill: #1877f2;
}

/* Instagram */
.sns-link-btn[href*="instagram"] .sns-icon {
  fill: #e4405f;
}

/* YouTube */
.sns-link-btn[href*="youtube"] .sns-icon {
  fill: #ff0000;
}

/* LINE */
.sns-link-btn[href*="line.me"] .sns-icon {
  fill: #00c300;
}

/* レスポンシブデザイン */
@media (max-width: 768px) {
  .sns-links {
    flex-direction: column;
    align-items: stretch;
  }

  .sns-link-btn {
    justify-content: center;
  }
}

/* 2025/08/28 上田　歴史と沿革 */
.history-passion {
  display: flex;
  align-items: flex-start; /* 上端を揃える */
  gap: 20px; /* 写真と本文の間隔 */
}

.history-photo {
  flex: 0 0 180px; /* 固定幅 */
  text-align: center;
}

.history-photo img {
  width: 100%;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.15);
}

.history-name {
  margin-top: 8px;
  font-weight: bold;
  font-size: 14px;
  color: #333;
}

.history-message {
  flex: 1; /* 右側は余白いっぱいに広がる */
}

.history-message p {
  text-align: left;
}
