/* --- 1. General Container & Card Base --- */
.custom-blog-card-v12-container {
    display: block;
    margin-left: auto;
    margin-right: auto;
    margin-top: var(--card-margin-top, 1.5rem);
    margin-bottom: var(--card-margin-bottom, 1.5rem);
    max-width: var(--card-max-width, 600px);
    line-height: 1.5;
    border: none !important; /* 保留先前的修正 */
    padding: 0 !important;   /* 保留先前的修正 */
}
.custom-blog-card-v12-container * { box-sizing: border-box; }
.custom-blog-card-v12 { position: relative; background: var(--card-bg-color, #fff);  border: var(--card-border-width, 1px) solid var(--card-border-color, #e2e8f0); border-radius: var(--card-border-radius, 8px); box-shadow: 0 4px 16px rgba(0,0,0,.08); overflow: hidden; transition: transform .3s ease, box-shadow .3s ease; min-height: 100px; height: 100%; }
.custom-blog-card-v12.has-hover-effect:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,.12); }
.custom-blog-card-v12.error { background: #fee2e2; padding: 1rem; color: #b91c1c; text-align: center; }
/* --- Label Styles --- */
.blog-card-v12-label { position: absolute; padding: 4px 10px; font-size: var(--label-font-size, 12px); font-weight: 600; line-height: 1.2; border-radius: 4px; z-index: 10; background-color: var(--label-bg-color, #e53e3e); color: var(--label-text-color, #fff); transition: transform .3s ease; }
.custom-blog-card-v12.has-hover-effect:hover .blog-card-v12-label { transform: translateY(-2px); }
.label-pos-top-right { top: 12px; right: 12px; } .label-pos-top-left { top: 12px; left: 12px; }
.label-pos-bottom-right { bottom: 12px; right: 12px; } .label-pos-bottom-left { bottom: 12px; left: 12px; }
/* --- Core Flexbox Layout (CRITICAL) --- */
.blog-card-v12-link { display: flex !important; width: 100% !important; height: 100% !important; text-decoration: none !important; color: inherit !important; align-items: stretch !important; flex-wrap: nowrap !important; float: none !important; }
/* --- Image & Content Blocks --- */
.blog-card-v12-image { flex-shrink: 0; background-color: #f1f5f9; display: flex; align-items: center; justify-content: center; overflow: hidden; margin: 0; padding: 0; position: relative; }
.blog-card-v12-content { display: flex; flex-direction: column; flex-grow: 1; min-width: 0; justify-content: center; padding: 1.25rem; align-self: stretch; }
.blog-card-v12-image img { display: block; transition: transform .3s ease; }
.custom-blog-card-v12.has-hover-effect:hover .blog-card-v12-image img { transform: scale(1.05); }
/* --- Text & Footer --- */
.blog-card-v12-title, .blog-card-v12-excerpt, .blog-card-v12-source { overflow-wrap: break-word; word-break: break-word; }
.blog-card-v12-title, .blog-card-v12-excerpt { overflow: hidden; text-overflow: ellipsis; display: -webkit-box; -webkit-box-orient: vertical; }
.blog-card-v12-title { font-size: var(--card-title-font-size, 1.2rem); text-align: var(--card-title-align, left); font-weight: 700; line-height: 1.4; margin: 0 0 .5rem 0; color: var(--card-title-color, #2d3748); }
.blog-card-v12-excerpt { font-size: var(--card-excerpt-font-size, 0.9rem); text-align: var(--card-excerpt-align, left); line-height: 1.6; margin: 0; color: var(--card-text-color, #4a5568); flex-grow: 1; }
/* 1. Footer 主容器：只負責定位和 overflow */
.blog-card-v12-footer {
    display: flex; /* 讓 wrapper 能在裡面正常運作 */
    margin-top: .75rem;
    font-size: .8rem;
    color: var(--card-source-color, #718096);
    overflow: hidden; /* 隱藏任何意外超出的內容 */
}
/* 2. Meta 包裹容器：這是所有佈局的核心 */
.blog-card-v12-meta-wrapper {
    display: flex;
    flex-wrap: nowrap; /* 核心：強制內部不換行 */
    align-items: center; /* 垂直居中對齊 */
    min-width: 0; /* flexbox hack，讓壓縮生效 */
}
/* 3. Favicon 圖示 */
.blog-card-v12-favicon {
    flex-shrink: 0; /* 圖示不壓縮 */
    margin-right: 8px; /* 與右邊的元素保持間距 */
}
/* 4. 作者、日期、分類等 Meta 標籤 */
.blog-card-v12-meta {
    background-color: #f1f5f9;
    padding: 2px 6px;
    border-radius: 4px;
    font-size: .75rem;
    white-space: nowrap;
    flex-shrink: 0; /* Meta 標籤不壓縮 */
    margin: 0 4px; /* 互相之間的間距 */
}
.blog-card-v12-source {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    margin-left: 4px;
    display: var(--show-source-mobile, inline);
}
@media (min-width:768px) {
    .blog-card-v12-source {
        display: var(--show-source-tablet, inline);
    }
}
@media (min-width:1025px) {
    .blog-card-v12-source {
        display: var(--show-source-desktop, inline);
    }
}
.custom-blog-card-v12 .blog-card-v12-favicon,
#si-single-content .custom-blog-card-v12 .blog-card-v12-favicon {
    width: 16px !important;
    height: 16px !important;
    min-width: 16px;
    max-width: 16px !important;
    margin: 0 4px 0 0 !important;
    border: none !important;
    flex-shrink: 0;
    border-radius: 2px;
    object-fit: contain;
}
a.blog-card-v12-meta { text-decoration: none; color: inherit; }
a.blog-card-v12-meta:hover { background-color: #e2e8f0; }
/* --- Responsive Layouts --- */
.blog-card-v12-link { flex-direction: var(--flex-direction-mobile, column); }
.blog-card-v12-title { -webkit-line-clamp: var(--title-lines-mobile, 2); }
.blog-card-v12-excerpt { -webkit-line-clamp: var(--excerpt-lines-mobile, 3); }
.custom-blog-card-v12-container[data-mobile-layout*="column"] .blog-card-v12-image { width: 100%; aspect-ratio: var(--aspect-ratio-mobile, 16/9); }
.custom-blog-card-v12-container[data-mobile-layout*="column"] .blog-card-v12-image img { width: 100%; height: 100%; object-fit: contain; max-height: 100%;}
.custom-blog-card-v12-container[data-mobile-layout*="row"] .blog-card-v12-image { width: var(--img-w-mobile, 40%); height: auto; aspect-ratio: unset; align-self: stretch; }
.custom-blog-card-v12-container[data-mobile-layout*="row"] .blog-card-v12-image img { width: 100%; height: 100%; object-fit: contain; max-height: 150px; }
/* --- Editor Panel Responsive Fixes --- */
.components-panel__body .components-panel__body-content {
    display: flex;
    flex-direction: column;
}
.custom-blog-card-v12-color-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
}
@supports (display: grid) {
    .custom-blog-card-v12-color-grid {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    }
}
@media (min-width:768px){
    .blog-card-v12-link { flex-direction: var(--flex-direction-tablet, column); }
    .blog-card-v12-title { -webkit-line-clamp: var(--title-lines-tablet, 2); font-size: 1.25rem; }
    .blog-card-v12-excerpt { -webkit-line-clamp: var(--excerpt-lines-tablet, 3); }
    .custom-blog-card-v12-container[data-tablet-layout*="column"] .blog-card-v12-image { width: 100%; aspect-ratio: var(--aspect-ratio-tablet, 16/9); }
    .custom-blog-card-v12-container[data-tablet-layout*="column"] .blog-card-v12-image img { width: 100%; height: 100%; object-fit: contain; max-height: 100%;}
    .custom-blog-card-v12-container[data-tablet-layout*="row"] .blog-card-v12-image { width: var(--img-w-tablet, 40%); height: auto; aspect-ratio: unset; align-self: stretch; }
    .custom-blog-card-v12-container[data-tablet-layout*="row"] .blog-card-v12-image img { width: 100%; height: 100%; object-fit: contain; max-height: 180px; }
}
@media (min-width:1025px){
    .blog-card-v12-link { flex-direction: var(--flex-direction-desktop, column); }
    .blog-card-v12-title { -webkit-line-clamp: var(--title-lines-desktop, 2); }
    .blog-card-v12-excerpt { -webkit-line-clamp: var(--excerpt-lines-desktop, 3); }
    .custom-blog-card-v12-container[data-desktop-layout*="column"] .blog-card-v12-image { width: 100%; aspect-ratio: var(--aspect-ratio-desktop, 16/9); }
    .custom-blog-card-v12-container[data-desktop-layout*="column"] .blog-card-v12-image img { width: 100%; height: 100%; object-fit: contain; max-height: 100%;}
    .custom-blog-card-v12-container[data-desktop-layout*="row"] .blog-card-v12-image { width: var(--img-w-desktop, 40%); height: auto; aspect-ratio: unset; align-self: stretch; }
    .custom-blog-card-v12-container[data-desktop-layout*="row"] .blog-card-v12-image img { width: 100%; height: 100%; object-fit: contain; max-height: 220px; }
}