/* @import url('http://example.com/example_style.css'); */

/***********************************************/
/* CSS @imports must be at the top of the file */
/* Add them above this section                 */
/***********************************************/

/*****************************************/
/* Start your style declarations here    */
/*****************************************/

/* ==========================================================================
   1. 共通レイアウト：Shopifyとブログの横幅を統一
   ========================================================================== */

#growfast-main-content,
.growfast-body-container-wrapper,
.growfast-body-container {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

.growfast-blog__header,
.growfast-blog-post__header {
  max-width: 1200px !important;
  margin-left: auto !important;
  margin-right: auto !important;
}

/* 記事詳細の本文幅制限 */
.growfast-blog-post__body,
.growfast-blog-post__body--content {
  max-width: 900px !important;
  margin-left: auto !important;
  margin-right: auto !important;
  padding-left: 20px !important;
  padding-right: 20px !important;
}

/* スマホ用の左右余白 */
@media (max-width: 1200px) {
  #growfast-main-content {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
}

/* ==========================================================================
   2. 一覧ページ（Index）：タイトル装飾と高さの統一（3行固定）
   ========================================================================== */

/* タイトルの色と下線消去 */
body .growfast-theme .growfast-blog-listing1__title a,
body .growfast-theme .growfast-blog-listing1__title a:visited {
  color: #000000 !important;
  text-decoration: none !important;
  border-bottom: none !important;
  box-shadow: none !important;
}

/* タイトルの高さを3行分に固定してカードのガタつきを防止 */
.growfast-blog-listing1__title {
  line-height: 1.5 !important;      /* 行間設定 */
  height: 4.5em !important;         /* 1.5行間 × 3行 = 4.5em */
  display: -webkit-box !important;
  -webkit-line-clamp: 3 !important; /* 3行を超えたら ... で省略 */
  -webkit-box-orient: vertical !important;
  overflow: hidden !important;
  margin-bottom: 15px !important;
}

body .growfast-theme .growfast-blog-listing1__title a:hover {
  color: #666666 !important;
  opacity: 0.8 !important;
}

/* ==========================================================================
   3. 記事詳細ページ（blog-post）：デザイン装飾
   ========================================================================== */

.growfast-blog-post__header__content-inner {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

/* タイトル上の日付 */
.growfast-blog-post-meta-dates {
  display: flex;
  gap: 20px;
  font-size: 14px !important;
  color: #666666 !important;
  margin-top: 40px !important;
  margin-bottom: 10px !important;
}

.growfast-blog-post-date-published::before { content: "作成日："; }
.growfast-blog-post-date-updated::before { content: "更新日："; }

/* 記事メインタイトル */
.growfast-theme .growfast-blog-post__title {
  color: #000000 !important;
  font-size: 32px !important;
  font-weight: bold !important;
  line-height: 1.4 !important;
  margin: 0 !important;
}

/* 著者・タグ・罫線 */
.growfast-blog-post-meta-info {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-top: 15px !important;
  padding-bottom: 20px !important;
  border-bottom: 1px solid #eeeeee !important;
  margin-bottom: 40px !important;
}

/* 著者ラベルとアイコン */
.growfast-blog-post-author-wrapper {
  display: flex;
  align-items: center;
  font-size: 16px !important;
  color: #333333 !important;
}
.growfast-blog-post-author-wrapper::before { display: none !important; }
.growfast-blog-post-author-name::before {
  content: "";
  display: inline-block;
  width: 16px; height: 16px;
  margin-right: 8px;
  vertical-align: middle;
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="