/* =========================================================
   地区記事表示用スタイル
   ========================================================= */

/* 各記事セクション */
.introduction-block {
    background: #F8F8F3;
    border-radius: 16px;
    padding: 30px 40px;
    margin-bottom: 46px;
  }
  
  /* 記事タイトル */
  .introduction-block h3 {
  color: #FF6A30;
  font-size: 20px;
  }
  
  #article-title {
  color: #2c5aa0;
  font-size: 24px;
  font-weight: bold;
  margin-bottom: 20px;
  padding-bottom: 10px;
  border-bottom: 2px solid #2c5aa0;
  }
  
  /* 記事本文 */
  #article-content {
  line-height: 1.8;
  margin-bottom: 30px;
  }
  
  #article-content h1 {
  font-size: 22px;
  }
  
  #article-content p {
  margin-bottom: 15px;
  }
  
  #article-content p:last-child {
  margin-bottom: 0;
  }
  
  #article-content ul,
  #article-content ol {
  margin-bottom: 15px;
  padding-left: 20px;
  }
  
  #article-content li {
  margin-bottom: 5px;
  }
  
  /* 地図セクション */
  .map-container {
  margin: 30px 0;
  padding: 20px;
  background: #f8f9fa;
  border-radius: 6px;
  border: 1px solid #e9ecef;
  }
  
  .map-container h3 {
  color: #2c5aa0;
  margin-bottom: 15px;
  font-size: 18px;
  }
  
  .map-info {
  background: #fff;
  padding: 15px;
  border-radius: 4px;
  border: 1px solid #dee2e6;
  }
  
  .map-info p {
  margin: 5px 0;
  font-size: 14px;
  color: #666;
  }
  
  /* 問い合わせ先セクション */
  .inquiries-section {
  margin: 30px 0;
  padding: 20px;
  background: #f8f9fa;
  border-radius: 6px;
  border: 1px solid #e9ecef;
  }
  
  .inquiries-section h3 {
  color: #2c5aa0;
  margin-bottom: 20px;
  font-size: 18px;
  }
  
  .inquiry-item {
  background: #fff;
  padding: 15px;
  margin-bottom: 15px;
  border-radius: 4px;
  border: 1px solid #dee2e6;
  }
  
  .inquiry-item h4 {
  color: #2c5aa0;
  margin-bottom: 10px;
  font-size: 16px;
  }
  
  .inquiry-item p {
  margin: 5px 0;
  font-size: 14px;
  color: #666;
  }
  
  /* ファイルセクション */
  .files-section {
  margin: 30px 0;
  padding: 20px;
  background: #f8f9fa;
  border-radius: 6px;
  border: 1px solid #e9ecef;
  }
  
  .files-section h3 {
  color: #2c5aa0;
  margin-bottom: 20px;
  font-size: 18px;
  }
  
  .file-item {
  background: #fff;
  padding: 15px;
  margin-bottom: 10px;
  border-radius: 4px;
  border: 1px solid #dee2e6;
  }
  
  .file-item a {
  color: #2c5aa0;
  text-decoration: none;
  font-weight: 500;
  }
  
  .file-item a:hover {
  text-decoration: underline;
  color: #1e3d6f;
  }
  
  
  /* 主要推進組織表 */
  .organization-table {
  background-color: #fff;
  margin-top: 30px;
  width: 100%;
  }
  
  .organization-table th,
  .organization-table td {
  border: 1px solid #BEBEBE;
  padding: 10px 15px;
  }
  
  .organization-table th {
  background-color: rgba(255,228,79,0.2);
  font-weight: normal;
  width: 180px;
  }
  
  .sns-list {
  align-items: center;
  display: flex;
  gap: 24px;
  }
  
  .sns-list a {
  color: #000000;
  display: block;
  }
  
  .sns-list a:hover {
  color: #4C91EB;
  text-decoration: none;
  }
  
  .sns-list a:hover .link-icon img {
  opacity: .6;
  }
  
  .website-flex {
    align-items: center;
    display: flex;
    gap: 30px;
    & a {
        color: #000000;
        &:hover {
            text-decoration: none;
        }
    }
  }
  
  .website a:hover,
  .sns-list a:hover {
    opacity: .7;
  }
  
  .website img {
  margin-right: 6px;
  height: 30px;
  }
  
  .link-icon {
  width: 36px;
  }
  
  .activity-item {
    margin-bottom: 36px;
  }
  
  .activity-categories {
    font-size: 16px;
    text-align: right;
    margin-bottom: 5px;
  }
  
  .activity-categories strong {
    color: #ff6a30;
  }
  
  .activity-title {
    background: #fbefaa;
    font-size: 18px;
    font-weight: bold;
    padding: 5px 10px;
    margin-bottom: 10px;
  }
  
  .activity-item:last-child {
    margin-bottom: 0;
  }
  
  .info-articles {
    background-color: #fff;
    border-radius: 16px;
    max-width: 1120px;
    margin-inline: auto;
    padding: 30px 40px;
    overflow-wrap: break-word;
  
    & h2 {
      font-size: 40px;
      margin-bottom: 40px;
      text-align: center;
    }
  }
  
  .activity-body img,
  .area-summary img {
    display: block;
    margin-inline: auto;
    max-width: 600px;
    width: 100% !important;
    height: auto !important;
  }
  
  
  
  
  /* レスポンシブデザイン */
  @media (max-width: 768px) {
  .area-article-section {
    padding: 15px;
    margin: 10px;
  }
  
  .info-articles {
    padding: 30px 0;
  }

  #article-title {
    font-size: 20px;
  }
  
  .map-container,
  .inquiries-section,
  .files-section {
    padding: 15px;
  }
  
  .inquiry-item,
  .file-item {
    padding: 12px;
  }
  }
  
  /* アクセシビリティ */
  .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
  }
  
  /* フォーカス表示 */
  .file-item a:focus,
  .inquiry-item:focus {
  outline: 2px solid #2c5aa0;
  outline-offset: 2px;
  }
  
  /* 印刷用スタイル */
  @media print {
  .area-article-section {
    box-shadow: none;
    border: 1px solid #ccc;
  }
  
  .map-container,
  .inquiries-section,
  .files-section {
    background: #fff;
    border: 1px solid #ccc;
  }
  }

  @media (max-width: 600px) {
    .website-flex {
        gap: 20px;
        flex-direction: column;
        align-items: stretch;
    }
    .organization-table th,
    .organization-table td {
        display: block;
        width: 100%;
    }
    .area-wrap {
        & .area-sec-head {
            padding-right: 0 !important;
        }
    }
  }