/* ========================================
   ä¸‹å±¤ãƒšãƒ¼ã‚¸ç”¨ã‚¹ã‚¿ã‚¤ãƒ« - çµ±åˆç‰ˆ
   ãƒ’ãƒ¼ãƒ­ãƒ¼ã‚»ã‚¯ã‚·ãƒ§ãƒ³ã€ãƒ‘ãƒ³ããšãƒªã‚¹ãƒˆã€ã‚ªãƒ¼ãƒãƒ¼ãƒ©ã‚¤ãƒ‰ã‚’çµ±åˆç®¡ç†
   ======================================== */

/* ãƒ‘ãƒ³ããšãƒªã‚¹ãƒˆã®ã‚¹ã‚¿ã‚¤ãƒ« */
.breadcrumb {
  background: transparent !important;
  padding: var(--spacing-2) 0 !important;
  border: none !important;
  margin-top: var(--header-height) !important;
  position: relative !important;
  z-index: 10 !important;
}

.breadcrumb__list {
  display: flex;
  align-items: center;
  gap: var(--spacing-2);
  margin: 0;
  padding: 0;
  list-style: none;
  flex-wrap: nowrap; /* 改行を許可しない */
  min-width: 0;      /* 子要素の省略可 */
}

.breadcrumb__item {
  display: flex;
  align-items: center;
  font-size: var(--font-size-sm);
  color: var(--color-neutral-600);
  white-space: nowrap; /* 先頭～中間は折り返さない */
  flex: 0 0 auto;      /* 幅を固定して縮まない */
}

.breadcrumb__item:not(:last-child)::after {
  content: '>';
  margin-left: var(--spacing-2);
  color: var(--color-neutral-400);
}

.breadcrumb__link {
  color: var(--color-neutral-400);
  text-decoration: none;
  transition: color var(--animation-duration-base) var(--animation-easing-ease);
  white-space: nowrap;     /* リンク文字列の改行禁止 */
  display: inline-block;   /* 省略時のレイアウト安定化 */
}

.breadcrumb__link:hover {
  color: var(--color-primary-600);
  text-decoration: underline;
}

.breadcrumb__item--current {
  color: var(--color-neutral-700);
  font-weight: 500;
  /* 末尾のみ可変幅にして省略可能にする */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1 1 auto;
  max-width: calc(100% - 160px);
}

/* ä¸‹å±¤ãƒšãƒ¼ã‚¸ãƒ˜ãƒ­ãƒ¼ã®ãƒ™ãƒ¼ã‚¹ã‚¹ã‚¿ã‚¤ãƒ« - çµ±åˆç‰ˆ */
.hero--subpage {
  position: relative;
  background: linear-gradient(135deg, 
    var(--color-primary-50) 0%, 
    var(--color-neutral-50) 50%, 
    var(--color-primary-50) 100%);
  /* ç¸¦å¹…ã‚’æœ€å°åŒ– */
  padding: var(--spacing-6) 0 var(--spacing-8);
  overflow: hidden;
  /* ä¸‹å±¤ãƒšãƒ¼ã‚¸å°‚ç”¨ï¼šé«˜ã•ã‚’æœ€å°é™ã«åˆ¶é™ */
  min-height: auto;
  max-height: none;
  /* ãƒˆãƒƒãƒ—ãƒšãƒ¼ã‚¸ã®ãƒ•ãƒ«ã‚¹ã‚¯ãƒªãƒ¼ãƒ³ãƒ’ãƒ¼ãƒ­ãƒ¼ã‚’ç„¡åŠ¹åŒ– */
  height: auto !important;
  /* ãƒ¬ã‚¤ã‚¢ã‚¦ãƒˆè¨­å®š */
  display: flex;
  align-items: center;
  text-align: left;
}

/* ãƒˆãƒƒãƒ—ãƒšãƒ¼ã‚¸ã®ãƒ’ãƒ¼ãƒ­ãƒ¼è¦ç´ ã‚’éžè¡¨ç¤ºã«ã™ã‚‹ */
.hero--subpage .hero__staff-background,
.hero--subpage .hero__main-copy,
.hero--subpage .hero__scroll-indicator {
  display: none !important;
}

/* ãƒ‡ã‚¸ã‚¿ãƒ«èª¿ã®èƒŒæ™¯ãƒ‘ã‚¿ãƒ¼ãƒ³ */
.hero--subpage::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-image: 
    radial-gradient(circle at 25% 25%, var(--color-primary-100) 0%, transparent 50%),
    radial-gradient(circle at 75% 75%, var(--color-secondary-100) 0%, transparent 50%),
    linear-gradient(45deg, transparent 30%, var(--color-neutral-100) 50%, transparent 70%);
  opacity: 0.3;
  z-index: 1;
}

/* ã‚°ãƒªãƒƒãƒ‰ãƒ‘ã‚¿ãƒ¼ãƒ³ã®ã‚ªãƒ¼ãƒãƒ¼ãƒ¬ã‚¤ - å‰Šé™¤ï¼ˆæ‰“ã¡æ¶ˆã—ç·šã®åŽŸå› ã¨ãªã‚‹ãŸã‚ï¼‰ */
.hero--subpage::after {
  display: none; /* ã‚°ãƒªãƒƒãƒ‰ãƒ‘ã‚¿ãƒ¼ãƒ³ã‚’å®Œå…¨ã«éžè¡¨ç¤ºã«ã—ã¦æ‰“ã¡æ¶ˆã—ç·šã‚’é˜²ã */
}

/* ãƒ˜ãƒ­ãƒ¼ã‚³ãƒ³ãƒ†ãƒ³ãƒ„ã®ã‚³ãƒ³ãƒ†ãƒŠ */
.hero--subpage .container {
  position: relative;
  z-index: 3;
}

/* ä¸‹å±¤ãƒšãƒ¼ã‚¸ãƒ˜ãƒ­ãƒ¼ã®ã‚³ãƒ³ãƒ†ãƒ³ãƒ„ãƒ¬ã‚¤ã‚¢ã‚¦ãƒˆ - çµ±åˆç‰ˆ */
.hero--subpage .hero__content {
  /* ãƒ¬ã‚¤ã‚¢ã‚¦ãƒˆè¨­å®š */
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  
  /* ã‚µã‚¤ã‚ºè¨­å®š - ãƒ‡ã‚¹ã‚¯ãƒˆãƒƒãƒ—ç‰ˆã®ã¿1200pxã€ãƒ¬ã‚¹ãƒãƒ³ã‚·ãƒ–å¯¾å¿œ */
  width: 1200px;
  max-width: 1200px;
  min-height: auto;
  box-sizing: border-box;
  
  /* ä½ç½®ãƒ»ä½™ç™½è¨­å®š */
  position: relative;
  margin: 0;
  padding: 0;
  
  /* è¡¨ç¤ºè¨­å®š */
  text-align: left;
  z-index: 10;
  background: none;
  
  /* ã‚¢ãƒ‹ãƒ¡ãƒ¼ã‚·ãƒ§ãƒ³ */
  animation: fadeInUp 0.8s ease-out;
}

/* ãƒ‡ã‚¹ã‚¯ãƒˆãƒƒãƒ—ç‰ˆã®å¹…åˆ¶é™ã‚’é©åˆ‡ã«è¨­å®š */
@media (min-width: 769px) {
  .hero--subpage .hero__content {
    width: 1200px;
    max-width: 1200px;
  }
}

/* ãƒ’ãƒ¼ãƒ­ãƒ¼ãƒ˜ãƒƒãƒ€ãƒ¼ã‚’æ¨ªä¸¦ã³ãƒ¬ã‚¤ã‚¢ã‚¦ãƒˆã«ã™ã‚‹ */
.hero--subpage .hero__header {
  display: flex;
  align-items: baseline;
  gap: var(--spacing-4);
  margin-bottom: var(--spacing-2);
  flex-wrap: wrap;
}

/* ã‚¿ã‚¤ãƒˆãƒ«ã¨ã‚µãƒ–ã‚¿ã‚¤ãƒˆãƒ«ã®åŸºæœ¬è¨­å®š */
.hero--subpage .hero__title,
.hero--subpage .hero__subtitle {
  margin-bottom: 0;
}

/* ãƒˆãƒƒãƒ—ãƒšãƒ¼ã‚¸ã®ãƒ’ãƒ¼ãƒ­ãƒ¼ã‚³ãƒ³ãƒ†ãƒ³ãƒ„èƒŒæ™¯ã‚ªãƒ¼ãƒãƒ¼ãƒ¬ã‚¤ã‚’ç„¡åŠ¹åŒ– */
.hero--subpage .hero__content::before {
  display: none !important;
}

/* ä¸‹å±¤ãƒšãƒ¼ã‚¸ã‚¿ã‚¤ãƒˆãƒ«ãƒ‡ã‚¶ã‚¤ãƒ³ - çµ±åˆç‰ˆ */
.hero--subpage .hero__title {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  color: var(--color-primary-500); /* ãƒˆãƒƒãƒ—ãƒšãƒ¼ã‚¸ã®ã‚»ã‚¯ã‚·ãƒ§ãƒ³ã‚¿ã‚¤ãƒˆãƒ«ã¨åŒæ§˜ã®ã‚«ãƒ©ãƒ¼ */
  margin-bottom: 0;
  position: relative;
  z-index: 15;
}

/* ã‚¿ã‚¤ãƒˆãƒ«ã®ã‚¢ãƒ³ãƒ€ãƒ¼ãƒ©ã‚¤ãƒ³ï¼ˆãƒ‡ã‚¸ã‚¿ãƒ«èª¿ï¼‰ */
.hero--subpage .hero__title::after {
  /* content: ''; */
  /* position: absolute; */
  /* bottom: -8px; */
  /* left: 50%; */
  /* transform: translateX(-50%); */
  /* width: 60px; */
  /* height: 3px; */
  /* background: linear-gradient(90deg, 
    var(--color-primary-500) 0%, 
    var(--color-secondary-500) 100%); */
  /* border-radius: var(--radius-full); */
}

/* ä¸‹å±¤ãƒšãƒ¼ã‚¸ã‚µãƒ–ã‚¿ã‚¤ãƒˆãƒ«ãƒ‡ã‚¶ã‚¤ãƒ³ - çµ±åˆç‰ˆ */
.hero--subpage .hero__subtitle {
  font-size: var(--font-size-base);
  font-weight: var(--font-weight-medium);
  color: var(--color-neutral-500); /* èƒŒæ™¯è‰²ãªã—ã§èª­ã¿ã‚„ã™ã */
  margin-bottom: 0;
  letter-spacing: var(--letter-spacing-wide);
  text-transform: uppercase;
  position: relative;
  z-index: 15;
  /* èƒŒæ™¯è‰²ã‚’å‰Šé™¤ */
  background: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
  /* border-bottomã‚’å‰Šé™¤ */
  border-bottom: none !important;
  padding-bottom: 0 !important;
}

/* ã‚µãƒ–ã‚¿ã‚¤ãƒˆãƒ«ã®è£…é£¾ç·š - å‰Šé™¤ï¼ˆæ‰“ã¡æ¶ˆã—ç·šã®åŽŸå› ã¨ãªã‚‹ãŸã‚ï¼‰ */
.hero--subpage .hero__subtitle::before,
.hero--subpage .hero__subtitle::after {
  display: none; /* è£…é£¾ç·šã‚’éžè¡¨ç¤ºã«ã—ã¦æ‰“ã¡æ¶ˆã—ç·šã‚’é˜²ã */
}

/* ä¸‹å±¤ãƒšãƒ¼ã‚¸èª¬æ˜Žæ–‡ãƒ‡ã‚¶ã‚¤ãƒ³ - çµ±åˆç‰ˆ */
.hero--subpage .hero__description {
  font-size: var(--font-size-base);
  line-height: var(--line-height-relaxed);
  color: var(--color-neutral-700);
  max-width: var(--content-max-width);
  margin: 0;
  word-wrap: break-word; /* é•·ã„å˜èªžã®æ”¹è¡Œã‚’è¨±å¯ */
  overflow-wrap: break-word; /* ã‚ˆã‚Šç¢ºå®Ÿãªæ”¹è¡Œ */
  text-align: left;
  position: relative;
  z-index: 15;
  display: block;
  width: 100%;
  /* ãƒ¬ã‚¹ãƒãƒ³ã‚·ãƒ–å¯¾å¿œ */
  word-wrap: break-word;
  overflow-wrap: break-word;
  hyphens: auto;
  /* èƒŒæ™¯è‰²ã‚’å‰Šé™¤ */
  background: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  box-shadow: none !important;
}


/* ãƒ¬ã‚¹ãƒãƒ³ã‚·ãƒ–ãƒ‡ã‚¶ã‚¤ãƒ³ - çµ±åˆç‰ˆ */
@media (max-width: 767px) {
  /* ãƒ‘ãƒ³ããšãƒªã‚¹ãƒˆã®ãƒ¬ã‚¹ãƒãƒ³ã‚·ãƒ–èª¿æ•´ */
  .breadcrumb {
    padding: var(--spacing-1) 0 !important;
    margin-top: var(--header-height-tablet) !important;
  }
  
  .breadcrumb__item {
    font-size: var(--font-size-xs) !important;
  }
  .breadcrumb__item--current {
    max-width: calc(100% - 120px);
  }
  
  .hero--subpage {
    padding: var(--spacing-3) 0 var(--spacing-4);
    /* ã‚¿ãƒ–ãƒ¬ãƒƒãƒˆç‰ˆï¼šç¸¦å¹…ã‚’æœ€å°åŒ– */
    min-height: auto;
    max-height: none;
    height: auto;
  }
  
  /* ã‚¿ãƒ–ãƒ¬ãƒƒãƒˆç‰ˆãƒ’ãƒ¼ãƒ­ãƒ¼ã‚³ãƒ³ãƒ†ãƒ³ãƒ„ */
  .hero--subpage .hero__content {
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
  }
  
  .hero--subpage .hero__header {
    gap: var(--spacing-2);
    margin-bottom: var(--spacing-1);
  }
  
  .hero--subpage .hero__title {
    font-size: var(--font-size-2xl);
    z-index: 15;
  }
  
  .hero--subpage .hero__subtitle {
    font-size: var(--font-size-sm);
    z-index: 15;
    border-bottom: none !important;
    padding-bottom: 0 !important;
  }
  
  .hero--subpage .hero__subtitle::before,
  .hero--subpage .hero__subtitle::after {
    display: none;
  }
  
  .hero--subpage .hero__description {
    font-size: var(--font-size-sm);
    z-index: 15;
    display: block;
    width: 100%;
    max-width: 100%;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
  }
  
}

@media (max-width: 480px) {
  /* ãƒ‘ãƒ³ããšãƒªã‚¹ãƒˆã®ã‚¹ãƒžãƒ¼ãƒˆãƒ•ã‚©ãƒ³èª¿æ•´ */
  .breadcrumb {
    padding: var(--spacing-1) 0 !important;
    margin-top: var(--header-height-mobile) !important;
  }
  .breadcrumb__item--current {
    max-width: calc(100% - 100px);
  }
  
  .hero--subpage {
    padding: var(--spacing-2) 0 var(--spacing-3);
    /* ã‚¹ãƒžãƒ¼ãƒˆãƒ•ã‚©ãƒ³ç‰ˆï¼šç¸¦å¹…ã‚’æœ€å°åŒ– */
    min-height: auto;
    max-height: none;
    height: auto;
  }
  
  /* ã‚¹ãƒžãƒ¼ãƒˆãƒ•ã‚©ãƒ³ç‰ˆãƒ’ãƒ¼ãƒ­ãƒ¼ã‚³ãƒ³ãƒ†ãƒ³ãƒ„ */
  .hero--subpage .hero__content {
    width: 100% !important;
    max-width: 100% !important;
    min-height: auto !important;
  }
  
  .hero--subpage .hero__header {
    gap: var(--spacing-1);
    margin-bottom: var(--spacing-1);
  }
  
  .hero--subpage .hero__title {
    font-size: var(--font-size-xl);
    z-index: 15;
  }
  
  .hero--subpage .hero__title::after {
    width: 30px;
    height: 2px;
  }
  
  .hero--subpage .hero__description {
    font-size: var(--font-size-sm);
    z-index: 15;
    display: block;
    width: 100%;
    max-width: 100%;
    word-wrap: break-word;
    overflow-wrap: break-word;
    hyphens: auto;
    line-height: var(--line-height-normal);
  }
  
}

/* çµ±ä¸€ã•ã‚ŒãŸãƒ’ãƒ¼ãƒ­ãƒ¼ã‚»ã‚¯ã‚·ãƒ§ãƒ³ã‚¹ã‚¿ã‚¤ãƒ« */
/* ã‚«ãƒ†ã‚´ãƒªåˆ¥ã®ãƒãƒªã‚¨ãƒ¼ã‚·ãƒ§ãƒ³ã¯å‰Šé™¤ã—ã€ã™ã¹ã¦ã®ä¸‹å±¤ãƒšãƒ¼ã‚¸ã§çµ±ä¸€ã•ã‚ŒãŸã‚¹ã‚¿ã‚¤ãƒ«ã‚’ä½¿ç”¨ */

/* ã‚³ãƒ³ãƒ†ãƒ³ãƒ„è¡¨ç¤ºã®ç¢ºå®Ÿæ€§ã‚’ä¿è¨¼ */
.hero--subpage .hero__content * {
  opacity: 1 !important;
  visibility: visible !important;
}

/* ã‚¢ãƒ‹ãƒ¡ãƒ¼ã‚·ãƒ§ãƒ³åŠ¹æžœ */
@keyframes fadeInUp {
  from {
    opacity: 0;
    transform: translateY(30px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}



/* ãƒ›ãƒãƒ¼åŠ¹æžœ */
.hero--subpage .hero__title:hover::after {
  width: 80px;
  transition: width 0.3s ease;
}

