/* company.css — 会社ページ専用スタイル（薄いグリーン基調・可読性向上版） */

:root {
  --brand-50:  #f5fbf3;
  --brand-100: #e6f6e1;
  --brand-500: #a3d9a5;
  --brand-600: #7ac47f;
  --brand-700: #5ca85f;
  --primary-color: var(--brand-600);
}

/* ---------- パンくず（緑なし） ---------- */
.breadcrumb-section {
  background: var(--gray-100);
  border-bottom: 1px solid var(--gray-200);
}
.breadcrumb-nav {
  display: flex;
  align-items: center;
  gap: .5rem;
  padding: .5rem 0;
  font-size: .875rem;
  color: var(--gray-600);
}
.breadcrumb-nav a { color: var(--gray-700); }
.breadcrumb-nav a:hover { color: var(--gray-900); }
.breadcrumb-separator { color: var(--gray-400); }
.breadcrumb-current { color: var(--gray-500); }

/* ---------- ページヘッダー ---------- */
.page-header { margin: 1.5rem 0 1rem; }
.page-title {
  font-size: 1.7rem;
  font-weight: 800;
  color: var(--gray-900);
  letter-spacing: .02em;
}
.page-subtitle {
  color: var(--gray-700);
  margin-top: .25rem;
}

/* ---------- タイポグラフィ ---------- */
.content-area {
  max-width: 740px;
  margin: 0 auto;
  padding: 0 1rem;
  font-size: 0.95rem;
  line-height: 1.85;
  font-family: 'Noto Sans JP', sans-serif;
}
.content-area p {
  margin-bottom: 1.25em;
}
.prose { max-width: 68ch; }
.prose p + p { margin-top: .75rem; }
.prose h3 {
  font-size: 1.5rem;
  margin: 1.5em 0 0.5em;
  color: var(--gray-900);
}
.prose ul {
  padding-left: 1.25rem;
  margin: .5rem 0 1rem;
}
.prose li {
  margin: .25rem 0;
}

.note {
  background: var(--brand-50);
  border: 1px solid var(--brand-100);
  padding: .75rem 1rem;
  border-radius: .5rem;
  color: var(--gray-800);
}

/* ---------- セクション ---------- */
.company-section {
  margin-bottom: 2rem;
  opacity: 1;
  transform: none;
}
.section-card {
  background: var(--white);
  border: 1px solid var(--gray-200);
  border-radius: .75rem;
  box-shadow: 0 1px 3px rgba(0,0,0,.06);
  overflow: hidden;
}
.company-section:nth-of-type(even) .section-card {
  background: var(--brand-50);
}
.section-title {
  display: flex;
  align-items: center;
  gap: .5rem;
  font-size: 1.125rem;
  font-weight: 700;
  padding: .75rem 1rem;
  color: var(--gray-900);
  background: linear-gradient(90deg, var(--brand-50), var(--white));
  border-bottom: 1px solid var(--gray-200);
  border-left: 4px solid var(--brand-600);
  margin-bottom: 0.25rem;
}
.section-icon { color: var(--brand-700); }

.section-block {
  margin-bottom: 2.5em;
}
.section-subtitle {
  font-size: 1.3em;
  margin-top: 1em;
  margin-bottom: 0.5em;
}
.section-block p {
  margin-bottom: 1.25em;
}

ul, ol {
  margin-left: 1.25rem;
  margin-bottom: 1em;
}
li {
  margin-bottom: 0.5em;
}

/* ---------- 表 ---------- */
.info-table {
  width: 100%;
  border-collapse: collapse;
  margin-top: 1.5em;
  font-size: 0.95rem;
}
.info-table th,
.info-table td {
  border: 1px solid #ccc;
  padding: 0.75em 1em;
  text-align: left;
  vertical-align: top;
}
.info-table thead {
  background-color: #f5f5f5;
  font-weight: bold;
}

/* ---------- イメージ ---------- */
.img-embed {
  max-width: 400px;
  width: 100%;
  height: auto;
  display: block;
  margin: 1.5em auto;
}
.image-row {
  display: flex;
  gap: 1em;
  flex-wrap: wrap;
  margin: 1em 0;
}

/* ---------- その他 ---------- */
.section-index {
  list-style: none;
  padding: 0;
  margin: 1em 0 2em;
}
.section-index li {
  margin-bottom: 0.25em;
}
.section-index a {
  color: var(--brand-600);
  text-decoration: none;
}
.section-index a:hover {
  text-decoration: underline;
}

/* 不要なマージン調整 */
.company-section:first-of-type {
  margin-top: 0;
}
