/* blog.css
   BLOG / NOTE 専用スタイル（company.html 文字体系に完全統一）
*/

/* =========================================================
   基本レイアウト
========================================================= */
#blog_c {
  width: 100%;
  margin: 90px auto 40px;
  text-align: center;
}

.blog_lead {
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 700;
  font-size: 16px; /* companyと合わせる */
  line-height: 2.0;
  margin: 30px auto 60px;
  color: #000;
}

/* =========================================================
   記事一覧
========================================================= */
.blog_list {
  width: 75%;
  margin: 0 auto 80px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
}

.blog_card {
  display: block;
  text-align: left;
  border-radius: 20px;
  border: 1px solid #000;
  padding: 34px 36px;
  background: #fff;
  color: #000;
  text-decoration: none;
  transition: transform .3s ease, box-shadow .3s ease;
}

.blog_card:hover {
  transform: translateY(-4px);
  box-shadow: 0 10px 24px rgba(0,0,0,.15);
  background: #faf7f0;
}

/* メタ情報 */
.blog_meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 14px; /* companyの本文に合わせる */
  margin-bottom: 12px;
  font-family: 'Hind', sans-serif;
}

.blog_cat {
  padding: 4px 12px;
  border-radius: 999px;
  border: 1px solid #000;
  font-size: 13px; 
}

/* タイトル */
.blog_ttl {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 20px;  /* company のH2/H3相当 */
  line-height: 1.7;
  margin: 10px 0 14px;
  font-weight: 700;
}

/* 本文 */
.blog_txt {
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 16px; /* 会社概要表のサイズに統一 */
  line-height: 2.0;
  margin: 0 0 18px;
}

.blog_more {
  font-family: 'Hind', sans-serif;
  font-size: 14px;
  letter-spacing: 0.08em;
  border-bottom: 1px solid #000;
  text-transform: uppercase;
}

/* =========================================================
   PC（1025px〜）
========================================================= */
@media screen and (min-width: 1025px) {

  .blog_list {
    width: 70%;
    grid-template-columns: repeat(3, 1fr);
  }

  .blog_txt {
    min-height: 4.4em;
  }
}

/* =========================================================
   タブレット
========================================================= */
@media screen and (min-width: 481px) and (max-width: 1024px) {

  #blog_c {
    margin: 70px auto 30px;
  }

  .blog_list {
    width: 85%;
    grid-template-columns: repeat(2, 1fr);
  }

  .blog_card {
    padding: 30px 28px;
  }
}

/* =========================================================
   スマホ
========================================================= */
@media screen and (max-width: 480px) {

  #blog_c {
    margin: 60px auto 20px;
  }

  .blog_lead {
    width: 88%;
    font-size: 15px;
    margin: 20px auto 40px;
  }

  .blog_list {
    width: 90%;
    gap: 22px;
    margin-bottom: 60px;
  }

  .blog_card {
    padding: 26px 22px;
  }

  .blog_ttl {
    font-size: 18px;
  }

  .blog_txt {
    font-size: 15px;
  }

  .blog_meta {
    font-size: 12px;
  }

  .blog_more {
    font-size: 13px;
  }
}

/* =========================================================
   CONTACT（調整版）
========================================================= */

#contact_c {
  width: 100%;
  margin: 80px auto 120px; /* 余白をしっかり */
}

#contact_c .cc_container {
  width: 70%;
  max-width: 720px; /* 読みやすい幅に限定 */
  margin: 0 auto;
  text-align: center;
}

/* CONTACT タイトル */
#contact_c .text_tag {
  font-size: 20px; /* 目立たせる */
  letter-spacing: 0.15em;
  font-weight: 700;
  margin-bottom: 32px;
}

/* 説明テキスト（上段） */
#contact_c .cc_container p:first-of-type {
  font-size: 18px;
  line-height: 2.1;
  font-weight: 700;
  margin-bottom: 28px;
}

/* 説明テキスト（下段） */
#contact_c .cc_container p:nth-of-type(2),
#contact_c .cc_container p:nth-of-type(3) {
  font-size: 17px;
  line-height: 2.1;
  margin-bottom: 10px;
}

/* ボタン */
#contact_c .button3 {
  width: 360px;
  max-width: 100%;
  margin: 40px auto 0; /* 上に余白追加 */
  font-size: 18px;
}

/* SP */
@media screen and (max-width: 480px) {
  #contact_c {
    margin: 60px auto 80px;
  }

  #contact_c .cc_container {
    width: 90%;
  }

  #contact_c .text_tag {
    font-size: 18px;
  }

  #contact_c .cc_container p:first-of-type {
    font-size: 17px;
  }

  #contact_c .cc_container p:nth-of-type(2),
  #contact_c .cc_container p:nth-of-type(3) {
    font-size: 15.5px;
  }

  #contact_c .button3 {
    width: 100%;
    font-size: 17px;
  }
}