@media (max-width: 768px) {
    .site-header {
        padding: 10px 20px;
    }
    .header-inner {
        flex-direction: column;
        align-items: center;
        padding: 15px;
    }
    .main-nav .nav-list {
        flex-direction: column;
        gap: 10px;
    }
    .header-buttons {
        margin-left: 0 !important;
        margin-top: 10px;
    }
}

/* レスポンシブ例 */
@media (max-width: 768px) {
    .article-intro {
      flex-direction: column;
      align-items: flex-start;
      gap: 10px;
    }
  
    .article-categories-grid {
      flex-wrap: wrap;
      margin-top: 0; /* スマホでは余計なズレをなくす */
    }
  
    .category-box {
      width: 100%;
      height: auto; /* 必要に応じて高さ調整 */
      margin-bottom: 20px;
    }
  }

  /* レスポンシブ例 */
@media (max-width: 768px) {
    .latest-articles {
      width: 100%;
      padding: 0 20px;  /* 画面幅が狭いときは内側に余白 */
    }
    .latest-articles-grid {
      flex-wrap: wrap;
      justify-content: center; /* 中央寄せ */
    }
    .latest-article {
      width: 100%;
      margin-bottom: 20px;
      height: auto; /* 高さ固定を解除して可変に */
    }
  }

  /* レスポンシブ対応 */
@media (max-width: 768px) {
    .kizuna-app-inner {
      flex-direction: column;
      height: auto;
      justify-content: flex-start;
      padding: 20px;
    }
  
    .kizuna-app-left,
    .kizuna-app-right {
      width: 100%;
    }
  
    .kizuna-app-right {
      display: flex;
      justify-content: center;
      align-items: center;
      overflow: visible;
    }
  
    .kizuna-app-image {
      position: relative;
      width: 100%;
      height: auto;
      object-fit: contain;
      margin-top: 20px;
      top: 0; /* モバイルでははみ出さないように */
    }
  }

  /* レスポンシブ対応 */
@media (max-width: 768px) {
    .contact-form {
      width: 100%;
    }
  }

  /* レスポンシブ対応 */
@media (max-width: 768px) {
    .footer-line {
      width: 80%; /* 画面幅に合わせる */
    }
  
    .footer-menu {
      width: 80%;
      flex-wrap: wrap;
      justify-content: center;
    }
  
    .footer-menu .footer-nav-list {
      flex-wrap: wrap;
      justify-content: center;
      gap: 15px; /* スマホ時は間隔を狭める */
    }
  }

  