/*
Theme Name: Cocoon Child
Template: cocoon-master
Version: 1.0
*/
/* ===== ヘッダー・ナビ非表示 ===== */
.site-name, .site-name-text-link { display: none !important; }
#header-container, .header-container { display: none !important; }
#navi, .navi, #navi-in { display: none !important; }

/* ===== TOPページ 余白消し ===== */
body.home #main { padding: 0 !important; margin: 0 !important; }
body.home #wrap { padding: 0 !important; }
body.home #main > img { display: block; width: 100%; margin: 0; }

/* ===== まずは基本セクション ===== */
.home-basic-section {
  position: relative;
  overflow: hidden;
  background: #fdf6e8 !important;
  padding: 40px 20px;
  width: 100%;
  box-sizing: border-box;
}
.home-basic-section h2 {
  text-align: center;
  font-size: 22px;
  margin-bottom: 24px;
  color: #5a3e1b;
}
.home-basic-cards {
  display: flex !important;
  flex-direction: column !important;
  gap: 20px !important;
  max-width: 700px;
  margin: 0 auto;
}
.home-basic-card {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  border-radius: 20px !important;
  border: 2px solid #d4b896 !important;
  overflow: hidden !important;
  background: #fff;
  text-decoration: none;
  color: inherit;
}
.home-basic-thumb {
  flex: 0 0 140px !important;
  width: 140px !important;
  overflow: hidden !important;
  position: relative !important;
  min-height: 100px;
}
.home-basic-thumb img {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
.home-basic-body {
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.home-basic-body h3 {
  font-size: 16px;
  font-weight: 700;
  margin: 0 0 6px;
  color: #333;
}
.home-basic-body p {
  display: none !important;
}

/* ===== カテゴリーセクション ===== */
.home-cat-section {
  padding: 40px 20px;
  background: #fff;
  box-sizing: border-box;
}
.home-cat-section h2 {
  text-align: center;
  font-size: 22px;
  margin-bottom: 24px;
  color: #333;
}
.home-cat-grid {
  display: grid !important;
  grid-template-columns: repeat(4, 1fr) !important;
  gap: 16px !important;
  max-width: 900px;
  margin: 0 auto;
}
.home-cat-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-decoration: none;
  color: inherit;
  background: #fdf6e8;
  border-radius: 16px;
  padding: 20px 10px;
  border: 2px solid #d4b896;
  transition: transform 0.2s;
}
.home-cat-card:hover { transform: translateY(-3px); }
.home-cat-card img {
  width: 80px;
  height: 80px;
  object-fit: contain;
  margin-bottom: 10px;
}
.home-cat-card span {
  font-size: 13px;
  font-weight: 700;
  text-align: center;
  color: #333;
}

/* ===== 新着記事セクション ===== */
.home-recent-section {
  padding: 40px 20px;
  background: #fdf6e8;
  box-sizing: border-box;
}
.home-recent-section h2 {
  text-align: center;
  font-size: 22px;
  margin-bottom: 24px;
  color: #333;
}
.home-recent-list {
  max-width: 700px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.home-recent-item {
  display: flex !important;
  align-items: stretch !important;
  background: #fff;
  border-radius: 16px;
  border: 2px solid #d4b896;
  text-decoration: none;
  color: inherit;
  overflow: hidden !important;
  padding: 0 !important;
}
.home-recent-thumb {
  flex: 0 0 120px !important;
  width: 120px !important;
  min-width: 120px !important;
  max-width: 120px !important;
  overflow: hidden !important;
}
.home-recent-thumb img {
  width: 120px !important;
  height: 100% !important;
  min-height: 80px !important;
  object-fit: cover !important;
  display: block !important;
}
.home-recent-body {
  padding: 12px !important;
  flex: 1 !important;
  min-width: 0 !important;
}
.home-recent-title {
  font-size: 14px;
  font-weight: 700;
  color: #333;
  line-height: 1.5;
}
.home-recent-date {
  font-size: 12px;
  color: #999;
  margin-top: 4px;
}

/* ===== 記事一覧カード（TOPページ以外） ===== */
.entry-card-wrap {
  background: transparent !important;
  border-radius: 0 !important;
  border: none !important;
  border-bottom: 1px solid #eee !important;
  overflow: visible !important;
  margin-bottom: 0 !important;
  margin-top: 0 !important;
}
.entry-card .entry-card-thumb img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
}
.entry-card .entry-title {
  font-size: 15px !important;
  font-weight: 700 !important;
}
.entry-card .entry-card-meta { display: none !important; }
.entry-card .entry-card-snippet { display: none !important; }

/* ===== カテゴリー・アーカイブページ カード ===== */
body.archive .entry-card-wrap,
body.category .entry-card-wrap {
  display: flex !important;
  flex-direction: row !important;
  align-items: stretch !important;
  background: transparent !important;
  border-radius: 0 !important;
  border: none !important;
  border-bottom: 1px solid #eee !important;
  overflow: visible !important;
  margin-bottom: 12px !important;
  padding: 0 !important;
}
body.archive .entry-card-thumb,
body.category .entry-card-thumb {
  flex: 0 0 30% !important;
  width: 30% !important;
  min-width: 30% !important;
  max-width: 30% !important;
  overflow: hidden !important;
  margin: 0 !important;
  padding: 0 !important;
}
body.archive .entry-card-thumb img,
body.category .entry-card-thumb img {
  width: 100% !important;
  height: 90px !important;
  object-fit: cover !important;
  display: block !important;
}
body.archive .entry-card-content,
body.category .entry-card-content {
  padding: 12px !important;
  flex: 1 !important;
  min-width: 0 !important;
}
body.archive .entry-card-title,
body.category .entry-card-title {
  font-size: 14px !important;
  font-weight: 700 !important;
  color: #333 !important;
  line-height: 1.5 !important;
  padding-left: 8px !important;
}
body.archive .entry-card-snippet,
body.archive .entry-card-meta,
body.category .entry-card-snippet,
body.category .entry-card-meta {
  display: none !important;
}
body.archive .cat-label,
body.category .cat-label {
  display: none !important;
}

/* ===== 記事ページ非表示 ===== */
.single .site-header,
.single .sidebar,
.single nav.bottom-nav { display: none !important; }

/* ===== カテゴリーページのサイドバー非表示 ===== */
body.archive #sidebar,
body.category #sidebar,
body.tag #sidebar {
  display: none !important;
}
body.archive #main,
body.category #main,
body.tag #main {
  width: 100% !important;
  max-width: 100% !important;
  float: none !important;
  margin: 0 auto !important;
}
body.archive .content-in,
body.category .content-in,
body.tag .content-in {
  display: block !important;
}

/* ===== フッター非表示 ===== */
#footer-widget-area {
  display: none !important;
}
.footer-bottom {
  display: none !important;
}

/* ===== リンクのアンダーライン非表示 ===== */
a.home-cat-card,
a.home-cat-card:hover,
a.home-cat-card:visited {
  text-decoration: none !important;
  border-bottom: none !important;
}
#mobile-footer-buttons,
.mobile-footer-buttons {
  display: none !important;
}

/* ===== モバイル対応 ===== */
@media (max-width: 640px) {
  .home-basic-thumb {
    flex: 0 0 110px !important;
    width: 110px !important;
    min-height: 80px;
  }
  .home-cat-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 12px !important;
  }
  .home-cat-card img {
    width: 60px;
    height: 60px;
  }
  .home-recent-thumb {
    flex: 0 0 90px;
    width: 90px;
    height: 60px;
  }
  .home-recent-title {
    font-size: 13px;
  }
  .home-basic-section h2,
  .home-cat-section h2,
  .home-recent-section h2 {
    font-size: 18px;
  }
}

/* ===== 関連記事ブロック ===== */
.asukun-related-posts {
  margin: 40px 0 20px;
  padding: 0;
}
.asukun-related-title {
  font-size: 15px;
  font-weight: bold;
  color: #333;
  border: none;
  margin: 0 0 12px;
  padding: 0;
  background: none;
}
.asukun-related-title a {
  color: #2d9e4e;
  text-decoration: none;
}
.asukun-related-title a:hover {
  text-decoration: underline;
}
.asukun-related-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.asukun-related-card {
  display: block;
  text-decoration: none;
  color: #333;
  border: none;
}
.asukun-related-card:hover .asukun-related-card-title {
  color: #2d9e4e;
}
.asukun-related-thumb {
  width: 100%;
  padding-top: 56.25%; /* 16:9固定 */
  position: relative;
  overflow: hidden;
  margin-bottom: 8px;
  background: #eee;
}
.asukun-related-thumb img {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}
.asukun-related-noimg {
  width: 100%;
  height: 100%;
  background: #ddd;
}
.asukun-related-card-title {
  font-size: 13px;
  line-height: 1.5;
  margin: 0 0 4px;
  font-weight: bold;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.asukun-related-date {
  font-size: 12px;
  color: #888;
}
@media (max-width: 600px) {
  .asukun-related-grid {
    grid-template-columns: 1fr 1fr;
    gap: 10px;
  }
  .asukun-related-card-title {
    font-size: 12px;
  }
}