/* ================================================================
   KSC サイトマップ リデザイン — siteMap_redesign.css
   company_redesign.css の後に読み込み、ページ固有のコンポーネントを追加。
   ================================================================ */

/* カテゴリカードのグリッド */
.ksc-sitemap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(264px, 1fr));
  gap: 22px;
  align-items: start;
}

/* カテゴリカード */
.ksc-sitemap-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--bg);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 30px 28px 26px;
  overflow: hidden;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}
/* 左の細いアクセントバー（ホバーで上から伸びる） */
.ksc-sitemap-card::before {
  content: '';
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--accent);
  transform: scaleY(0);
  transform-origin: top;
  transition: transform var(--transition);
}
.ksc-sitemap-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-md);
  border-color: var(--accent-line);
}
.ksc-sitemap-card:hover::before { transform: scaleY(1); }

/* カード番号（右上） */
.ksc-sitemap-num {
  position: absolute;
  top: 22px; right: 24px;
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  letter-spacing: 0.08em;
  color: var(--text-muted);
}

/* カテゴリ英語ラベル */
.ksc-sitemap-cat-en {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 6px;
}
/* カテゴリ見出し（日本語） */
.ksc-sitemap-cat {
  font-family: 'Noto Serif JP', serif;
  font-size: 19px;
  font-weight: 600;
  color: var(--text-head);
  margin: 0 0 16px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}

/* リンクリスト */
.ksc-sitemap-links {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}
.ksc-sitemap-links li + li { border-top: 1px dashed var(--border); }
.ksc-sitemap-links a {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 0;
  font-size: 14px;
  color: var(--text-body);
  line-height: 1.5;
  transition: color var(--transition), gap var(--transition), padding var(--transition);
}
/* リンク頭の山括弧（chevron） */
.ksc-sitemap-links a::before {
  content: '';
  flex: 0 0 14px;
  width: 14px; height: 14px;
  background: var(--accent);
  opacity: 0.5;
  transition: opacity var(--transition), transform var(--transition);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18l6-6-6-6'/%3E%3C/svg%3E") no-repeat center / contain;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M9 18l6-6-6-6'/%3E%3C/svg%3E") no-repeat center / contain;
}
.ksc-sitemap-links a:hover {
  color: var(--accent-deep);
  gap: 13px;
  padding-left: 4px;
}
.ksc-sitemap-links a:hover::before { opacity: 1; transform: translateX(2px); }

/* 外部リンク・PDF には外部アイコンを自動付与 */
.ksc-sitemap-links a[target="_blank"]::after {
  content: '';
  width: 11px; height: 11px;
  margin-left: 1px;
  background: var(--text-muted);
  transition: background var(--transition);
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpath d='M15 3h6v6M10 14L21 3'/%3E%3C/svg%3E") no-repeat center / contain;
          mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M18 13v6a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2h6'/%3E%3Cpath d='M15 3h6v6M10 14L21 3'/%3E%3C/svg%3E") no-repeat center / contain;
}
.ksc-sitemap-links a[target="_blank"]:hover::after { background: var(--accent-deep); }

/* レスポンシブ */
@media (max-width: 640px) {
  .ksc-sitemap-grid { grid-template-columns: 1fr; gap: 16px; }
  .ksc-sitemap-card { padding: 26px 22px 22px; }
}
