/* ==================================================================
   マネフリ ブログカード (Cocoon 出力を .manefuri-blogcard でラップ)
   デザイントークンは design-system.css(:root) を参照(フォールバック付き)
   ================================================================== */

/* 外枠: 夜の書斎の地色＋1px 金。角丸ゼロ。ホバーは枠色のみ( transform なし ) */
.manefuri-blogcard {
    --manefuri-color-warm-offwhite: #F5F1E8;
    --manefuri-color-gold: #C9A961;
    position: relative;
    max-width: 100%;
    margin: 24px 0;
    padding: 16px;
    background-color: var(--manefuri-color-warm-offwhite, var(--color-bg, #F5F1E8));
    border: 1px solid var(--manefuri-color-gold, var(--color-accent, #C9A961));
    border-radius: 0;
    box-shadow: none;
    box-sizing: border-box;
    transition: border-color 0.2s ease;
}

.manefuri-blogcard:hover {
    border-color: #B8860B;
}

/* 内部リンク: Cocoon 既定のカード上ラベルはタグ行に移したので非表示 */
.manefuri-blogcard--internal .blogcard-label,
.manefuri-blogcard--internal .internal-blogcard-label,
.manefuri-blogcard--internal .external-blogcard-label {
    display: none !important;
}

/* 外部: 同様。サムネ上の重複バッジを抑止 */
.manefuri-blogcard--external .blogcard-label,
.manefuri-blogcard--external .internal-blogcard-label,
.manefuri-blogcard--external .external-blogcard-label {
    display: none !important;
}

/* タグ行: 全文表示。幅超過時ははみ出しを隠し2個目が視覚的に切り捨て(ellipsis は付けない) */
.manefuri-blogcard__tags {
    display: flex;
    flex-wrap: nowrap;
    gap: 6px;
    margin: 0 0 8px;
    width: 100%;
    min-width: 0;
    box-sizing: border-box;
    overflow: hidden;
}

/* BEM: フォント明示(継承禁止) / テキストは PHP esc_html */
.manefuri-blogcard__tag {
    flex: 0 0 auto;
    padding: 2px 8px;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 11px;
    font-weight: 400;
    line-height: 1.3;
    color: var(--manefuri-color-gold, var(--color-accent, #C9A961));
    white-space: nowrap;
    background: transparent;
    border: 1px solid var(--manefuri-color-gold, var(--color-accent, #C9A961));
    border-radius: 0;
}

/* クリック層: 枠を div に持たせた分、リンクは透明にして従来の a-wrap ホバー背景を穏やかに上書き */
.manefuri-blogcard .blogcard-wrap {
    display: block;
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: none !important;
    border-radius: 0;
    box-shadow: none;
}

.manefuri-blogcard .blogcard-wrap:hover {
    background-color: transparent !important;
    transition: none;
    color: inherit;
}

/* 本体内レイアウト: Cocoon の float ベース(figure + content)を維持 */
.manefuri-blogcard .blogcard {
    position: relative;
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
    border-radius: 0;
    line-height: 1.65;
    box-shadow: none;
}

/* 4:3 固定。Cocoon entry-content の 16/9 指定を上書き */
.manefuri-blogcard .blogcard-thumbnail {
    position: relative;
    float: left;
    width: 160px;
    min-height: 0;
    margin: 0 10px 0 0;
    overflow: hidden;
    aspect-ratio: 4 / 3;
}

.manefuri-blogcard .ib-right .blogcard-thumbnail,
.manefuri-blogcard .eb-right .blogcard-thumbnail {
    float: right;
    margin: 0 0 0 10px;
}

.manefuri-blogcard .blogcard-thumbnail img,
.manefuri-blogcard .blogcard-thumbnail .blogcard-thumb-image,
.manefuri-blogcard .blogcard-thumbnail .internal-blogcard-thumb-image,
.manefuri-blogcard .blogcard-thumbnail .external-blogcard-thumb-image {
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: auto;
    object-fit: cover;
    object-position: center;
}

/* Cocoon: .blogcard-title 系。フォント明示(継承禁止) — 700 相当を 500 へ上書き */
.manefuri-blogcard .blogcard-title,
.manefuri-blogcard .internal-blogcard-title,
.manefuri-blogcard .external-blogcard-title {
    font-family: "Shippori Mincho", "Noto Serif JP", serif;
    font-size: 1rem;
    font-weight: 500 !important;
    line-height: 1.5;
    color: #2C2C2C;
}

/* 抜粋: Noto 400。本文階層用の色はテーマ変数(朱赤にしない) */
.manefuri-blogcard .blogcard-snippet,
.manefuri-blogcard .internal-blogcard-snippet,
.manefuri-blogcard .external-blogcard-snippet {
    font-family: "Noto Sans JP", var(--font-sans, sans-serif);
    font-size: 0.8em;
    font-weight: 400;
    line-height: 1.6;
    color: var(--color-text-sub, #6B6560);
}

.manefuri-blogcard .blogcard-content {
    margin-left: 170px;
    margin-right: 0;
    min-height: 100px;
    max-height: 140px;
    overflow: hidden;
}

.manefuri-blogcard .ib-right .blogcard-content,
.manefuri-blogcard .eb-right .blogcard-content {
    margin-left: 0;
    margin-right: 170px;
}

.manefuri-blogcard .blogcard-footer {
    clear: both;
    padding-top: 8px;
    font-size: 0.8rem;
    color: var(--color-text-sub, #6B6560);
}

.manefuri-blogcard .blogcard-site,
.manefuri-blogcard .internal-blogcard-site,
.manefuri-blogcard .external-blogcard-site {
    float: left;
    display: flex;
    align-items: center;
    font-family: "Noto Sans JP", var(--font-sans, sans-serif);
    font-size: 0.78rem;
    color: var(--color-text-sub, #6B6560);
}

.manefuri-blogcard .internal-blogcard-date,
.manefuri-blogcard .blogcard-date,
.manefuri-blogcard .internal-blogcard-post-date,
.manefuri-blogcard .blogcard-post-date {
    float: right;
    font-family: "Inter", var(--font-number, sans-serif);
    font-size: 0.75rem;
    font-weight: 400;
    font-variant-numeric: tabular-nums;
    color: var(--color-text-sub, #6B6560);
}

/* 狭い表示(nwa)で Cocoon が 120px を当てる帯: 意図どおり 160/170 へ戻す */
@media screen and (min-width: 768px) and (max-width: 834px) {
    .manefuri-blogcard .blogcard-thumbnail {
        width: 160px;
        aspect-ratio: 4 / 3;
    }

    .manefuri-blogcard .blogcard-content {
        margin-left: 170px;
        min-height: 100px;
        max-height: 140px;
    }

    .manefuri-blogcard .ib-right .blogcard-content,
    .manefuri-blogcard .eb-right .blogcard-content {
        margin-left: 0;
        margin-right: 170px;
    }
}

/* スマートフォン: 100×75(4:3)・本文 110 オフセット */
@media screen and (max-width: 767px) {
    .manefuri-blogcard {
        padding: 12px 14px;
    }

    .manefuri-blogcard .blogcard-thumbnail {
        width: 100px;
        aspect-ratio: 4 / 3;
    }

    .manefuri-blogcard .blogcard-content {
        margin-left: 110px;
        min-height: 70px;
        max-height: 120px;
    }

    .manefuri-blogcard .ib-right .blogcard-content,
    .manefuri-blogcard .eb-right .blogcard-content {
        margin-left: 0;
        margin-right: 110px;
    }
}

