/* =========================
   CN — Catholic News v3.0 (Dark Blue + Royal Navy Header)
   Header v3 gộp + Hero 5 bài + Be Vietnam Pro + Mobile Latest 20
   ========================= */

:root {
	--cn-primary: #0a2540;
	--cn-primary-700: #061a30;
	--cn-primary-900: #04111f;
	--cn-secondary: #c9a961;
	--cn-secondary-700: #a78938;
	--cn-accent: #8b1a1a;
	--cn-text: #1a1a1a;
	--cn-muted: #5a6573;
	--cn-border: #e2e5ec;
	--cn-bg: #ffffff;
	--cn-surface: #f4f6fa;
	--cn-radius: 8px;
	--cn-radius-lg: 12px;
	--cn-shadow: 0 2px 8px rgba(10,37,64,0.06);
	--cn-shadow-lg: 0 8px 24px rgba(10,37,64,0.12);
	--cn-font-sans: 'Be Vietnam Pro', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	--cn-font-serif: 'Be Vietnam Pro', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
	--cn-nav-bg: #1e3a8a;
	--cn-nav-bg-dark: #162d6b;
	--cn-nav-border: rgba(255,255,255,0.08);
}

/* ===== RESET / BASE ===== */
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--cn-font-sans); font-size: 16px; line-height: 1.6; color: var(--cn-text); background: var(--cn-bg); -webkit-font-smoothing: antialiased; }
img { max-width: 100%; height: auto; display: block; }
a { color: var(--cn-primary); text-decoration: none; transition: color 0.15s; }
a:hover { color: var(--cn-primary-700); }
h1, h2, h3, h4 { font-family: var(--cn-font-sans); font-weight: 700; line-height: 1.3; margin: 0 0 0.5em; color: var(--cn-primary); }
p { margin: 0 0 1em; }
.cn-skip { position: absolute; left: -9999px; }
.cn-skip:focus { left: 0; top: 0; padding: 8px 16px; background: var(--cn-primary); color: #fff; z-index: 9999; }
.container { max-width: 1140px; margin: 0 auto; padding: 0 16px; }
.container-narrow { max-width: 760px; }
body a:not(.cn-article-content a):not(.cn-article-tags a):not(.cn-admin-notice a) { text-decoration: none; }

/* ===== HEADER v3 (gộp — Royal Navy) ===== */
.cn-header, .cn-header-v3 { position: sticky; top: 0; z-index: 100; background: #fff; box-shadow: 0 2px 12px rgba(10,20,60,0.15); }
.cn-header-top { background: linear-gradient(135deg, var(--cn-nav-bg) 0%, var(--cn-nav-bg-dark) 100%); color: #fff; }
.cn-header-top-inner {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 12px 16px;
	min-height: 64px;
}
.cn-branding, .cn-logo { margin-right: auto; }

/* Logo / Branding */
.cn-branding, .cn-logo { display: inline-flex; align-items: center; gap: 10px; text-decoration: none !important; color: #fff; flex: 0 0 auto; }
.cn-branding:hover, .cn-logo:hover { color: #fff; }
.cn-cross { font-size: 26px; line-height: 1; color: var(--cn-secondary); }
.cn-site-title { font-size: 20px; font-weight: 800; color: #fff !important; text-transform: uppercase; letter-spacing: 1px; line-height: 1; }
.custom-logo { max-height: 44px; width: auto; display: block; }
.custom-logo-link { display: block; }

/* Top nav inline (Giáo hội Hoàn vũ | Giáo hội Việt Nam | Menu ▾) */
.cn-top-nav { display: flex; align-items: center; gap: 12px; flex-wrap: nowrap; }
.cn-top-link { color: #fff; font-weight: 600; font-size: 14px; text-decoration: none !important; padding: 6px 4px; transition: color 0.15s; }
.cn-top-link:hover { color: var(--cn-secondary); }
.cn-top-sep { color: rgba(255,255,255,0.35); font-weight: 300; }

/* Menu dropdown */
.cn-menu-drop { position: relative; }
.cn-menu-trigger { background: transparent; border: 0; color: #fff; font: inherit; font-weight: 600; font-size: 14px; cursor: pointer; padding: 6px 4px; display: inline-flex; align-items: center; gap: 4px; transition: color 0.15s; }
.cn-menu-trigger:hover, .cn-menu-drop:hover .cn-menu-trigger { color: var(--cn-secondary); }
.cn-menu-caret { font-size: 10px; transition: transform 0.2s; }
.cn-menu-drop:hover .cn-menu-caret { transform: rotate(180deg); }
.cn-menu-list {
	position: absolute; top: 100%; left: 0;
	min-width: 220px; background: #fff;
	border: 1px solid var(--cn-border); border-radius: 10px;
	box-shadow: 0 10px 30px rgba(10,37,64,0.15);
	padding: 8px; margin: 6px 0 0;
	list-style: none; display: none; z-index: 200;
}
.cn-menu-drop:hover .cn-menu-list,
.cn-menu-drop:focus-within .cn-menu-list { display: block; }
.cn-menu-list li { margin: 0; }
.cn-menu-list a { display: block; padding: 9px 12px; color: var(--cn-text) !important; font-size: 14px; font-weight: 500; text-decoration: none !important; border-radius: 6px; transition: background 0.15s, color 0.15s; }
.cn-menu-list a:hover { background: var(--cn-surface); color: var(--cn-primary) !important; }

/* Search PC (ngắn 220px) */
.cn-search-form { display: flex; align-items: center; background: rgba(255,255,255,0.12); border: 1px solid rgba(255,255,255,0.25); border-radius: 999px; padding: 2px 4px 2px 14px; width: 220px; transition: 0.15s; }
.cn-search-form:focus-within { background: #fff; border-color: var(--cn-secondary); }
.cn-search-form input[type="search"] { flex: 1; border: 0; outline: 0; background: transparent; color: #fff; font-size: 13.5px; height: 30px; min-width: 0; padding: 0; }
.cn-search-form input[type="search"]::placeholder { color: rgba(255,255,255,0.7); }
.cn-search-form:focus-within input[type="search"] { color: var(--cn-text); }
.cn-search-form:focus-within input[type="search"]::placeholder { color: var(--cn-muted); }
.cn-search-form button { background: transparent; border: 0; color: #fff; cursor: pointer; padding: 4px 8px; display: flex; align-items: center; justify-content: center; border-radius: 50%; transition: 0.15s; }
.cn-search-form:focus-within button { color: var(--cn-primary); }
.cn-search-form button:hover { background: rgba(255,255,255,0.1); }

/* Ngày tháng */
.cn-header-date { color: rgba(255,255,255,0.9); font-size: 13px; font-weight: 500; white-space: nowrap; }

/* Mobile actions (ẩn PC) */
.cn-mobile-actions { display: none; gap: 4px; }
.cn-icon-btn { background: transparent; border: 0; color: #fff; padding: 8px; cursor: pointer; display: flex; align-items: center; justify-content: center; border-radius: 8px; transition: 0.15s; }
.cn-icon-btn:hover { background: rgba(255,255,255,0.1); }
.cn-mobile-search { background: var(--cn-nav-bg-dark); padding: 12px 0; border-top: 1px solid var(--cn-nav-border); }
.cn-mobile-search .cn-search-form { box-shadow: none; width: 100%; }

/* ===== Mobile drawer menu ===== */
.cn-mobile-menu { display: none; position: fixed; inset: 0 0 0 auto; width: 82%; max-width: 320px; background: #fff; z-index: 200; box-shadow: var(--cn-shadow-lg); transform: translateX(100%); transition: transform 0.25s; overflow-y: auto; }
.cn-mobile-menu.is-open { display: block; transform: translateX(0); }
.cn-mobile-menu-head { display: flex; justify-content: space-between; align-items: center; background: var(--cn-nav-bg); color: #fff; font-weight: 700; font-size: 16px; text-transform: uppercase; letter-spacing: 0.5px; padding: 18px 20px; }
.cn-mobile-close { color: #fff; font-size: 32px; line-height: 1; background: transparent; border: none; cursor: pointer; padding: 8px; }
.cn-mobile-nav-list { list-style: none; padding: 0; margin: 0; }
.cn-mobile-nav-list li { border-bottom: 1px solid var(--cn-border); }
.cn-mobile-nav-list a { display: block; padding: 14px 20px; color: var(--cn-text) !important; font-weight: 600; font-size: 15px; text-decoration: none !important; }
.cn-mobile-nav-list a:hover, .cn-mobile-nav-list .current-menu-item > a { background: var(--cn-surface); color: var(--cn-nav-bg) !important; }
.cn-mobile-nav-list .sub-menu { list-style: none; padding: 0; margin: 0; background: var(--cn-surface); }
.cn-mobile-nav-list .sub-menu a { padding-left: 40px; font-size: 14px; font-weight: 500; }
.cn-overlay { display: none; position: fixed; inset: 0; background: rgba(0,0,0,0.4); z-index: 150; }
.cn-overlay.is-open { display: block; }

/* ===== BADGE / DATE ===== */
.cn-badge { display: inline-block; padding: 4px 10px; background: var(--cn-secondary); color: var(--cn-primary-900); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; border-radius: 4px; }
.cn-badge-sm { font-size: 10px; padding: 2px 8px; }
.cn-badge:hover { background: var(--cn-secondary-700); color: #fff; }
.cn-date { color: var(--cn-muted); font-size: 13px; }

/* ===== HERO 5 BÀI (PC) ===== */
.cn-hero { padding: 24px 0 12px; background: linear-gradient(180deg, var(--cn-surface) 0%, #fff 100%); }
.cn-hero-grid { display: grid; grid-template-columns: 1.55fr 1fr; gap: 18px; }
.cn-hero-item.is-feature { background: #fff; border: 1px solid var(--cn-border); border-radius: 14px; overflow: hidden; box-shadow: 0 6px 20px rgba(10,37,64,0.08); }
.cn-hero-item.is-feature .cn-hero-thumb { aspect-ratio: 16/10; }
.cn-hero-item.is-feature .cn-hero-body { padding: 16px 18px 18px; }
.cn-hero-item.is-feature .cn-hero-title { font-size: 24px; line-height: 1.3; margin: 8px 0 10px; }
.cn-hero-item.is-feature .cn-hero-excerpt { color: #475569; font-size: 14.5px; line-height: 1.6; margin: 0 0 10px; }
.cn-hero-item.is-feature .cn-hero-meta { font-size: 13px; color: #64748b; }
.cn-hero-side { display: grid; grid-template-rows: repeat(4, 1fr); gap: 12px; }
.cn-hero-item.is-small { background: #fff; border: 1px solid var(--cn-border); border-radius: 12px; overflow: hidden; display: grid; grid-template-columns: 110px 1fr; gap: 10px; padding: 8px; transition: border-color 0.15s, box-shadow 0.15s; align-items: center; }
.cn-hero-item.is-small:hover { border-color: var(--cn-primary); box-shadow: 0 4px 14px rgba(10,37,64,0.08); }
.cn-hero-item.is-small .cn-hero-thumb { width: 110px; height: 75px; border-radius: 8px; overflow: hidden; background: var(--cn-surface); flex-shrink: 0; }
.cn-hero-item.is-small .cn-hero-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cn-hero-item.is-small .cn-hero-body { padding: 2px 4px 2px 0; min-width: 0; }
.cn-hero-item.is-small .cn-hero-title { font-size: 14.5px; line-height: 1.35; margin: 4px 0 0; display: block; overflow: visible; }
.cn-hero-item.is-small .cn-hero-title a { color: #0f172a; text-decoration: none !important; }
.cn-hero-meta.sm { font-size: 12px; color: #64748b; margin-top: 4px; }
.cn-hero-date { white-space: nowrap; }
.cn-hero-thumb-link { display: block; }
.cn-hero-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.cn-hero-title a { color: var(--cn-primary); text-decoration: none !important; }
.cn-hero-cat { display: inline-block; padding: 2px 10px; border-radius: 999px; background: #fef3c7; color: #92400e; font-size: 12px; font-weight: 700; text-decoration: none !important; text-transform: uppercase; letter-spacing: 0.5px; }
.cn-hero-cat.sm { padding: 1px 8px; font-size: 11px; }
.cn-hero-cat:hover { background: #fde68a; color: #78350f; }
.cn-card-placeholder { width: 100%; height: 100%; min-height: 160px; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--cn-primary) 0%, var(--cn-primary-900) 100%); color: rgba(201,169,97,0.4); font-size: 64px; }
.cn-card-placeholder.sm { font-size: 36px; min-height: 75px; }

/* ===== GOSPEL BANNER ===== */
.cn-gospel { background: linear-gradient(135deg, var(--cn-primary) 0%, var(--cn-primary-700) 100%); color: #fff; padding: 36px 0; position: relative; overflow: hidden; }
.cn-gospel::before { content: ""; position: absolute; top: -30%; right: -10%; width: 400px; height: 400px; background: radial-gradient(circle, rgba(201,169,97,0.12) 0%, transparent 70%); pointer-events: none; }
.cn-gospel::after { content: ""; position: absolute; bottom: -20%; left: -5%; width: 300px; height: 300px; background: radial-gradient(circle, rgba(201,169,97,0.08) 0%, transparent 70%); pointer-events: none; }
.cn-gospel-inner { display: flex; align-items: center; gap: 24px; position: relative; z-index: 1; }
.cn-gospel-icon { font-size: 56px; font-weight: 400; color: var(--cn-secondary); line-height: 1; flex: 0 0 auto; }
.cn-gospel-label { display: block; font-size: 12px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--cn-secondary); margin-bottom: 4px; }
.cn-gospel-quote { font-size: 20px; font-style: italic; margin: 0; line-height: 1.4; }

/* ===== SECTION ===== */
.cn-section { padding: 40px 0; }
.cn-section + .cn-section { padding-top: 0; }
.cn-section-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 24px; }
.cn-section-title { margin: 0; font-size: 22px; color: var(--cn-primary); position: relative; padding-left: 16px; }
.cn-section-title::before { content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%); width: 4px; height: 28px; background: var(--cn-secondary); border-radius: 2px; }
.cn-section-more { font-size: 14px; font-weight: 600; color: var(--cn-primary); text-decoration: none !important; }
.cn-section-more:hover { color: var(--cn-accent); }
.cn-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
.cn-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }

/* ===== CARD ===== */
.cn-card { background: #fff; border: 1px solid var(--cn-border); border-radius: var(--cn-radius); overflow: hidden; box-shadow: var(--cn-shadow); transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s; }
.cn-card:hover { transform: translateY(-4px); box-shadow: var(--cn-shadow-lg); border-color: var(--cn-primary); }
.cn-card-thumb { display: block; aspect-ratio: 16/9; overflow: hidden; background: var(--cn-surface); }
.cn-card-thumb img { width: 100%; height: 100%; object-fit: cover; transition: 0.3s; }
.cn-card:hover .cn-card-thumb img { transform: scale(1.05); }
.cn-card-body { padding: 14px; display: flex; flex-direction: column; gap: 6px; }
.cn-card-title { font-size: 15px; line-height: 1.4; margin: 4px 0; }
.cn-card-title a { color: var(--cn-text); text-decoration: none !important; }
.cn-card-title a:hover { color: var(--cn-primary); }

/* ===== CATEGORY SECTION ===== */
.cn-cat-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 24px; }
.cn-cat-feature { background: #fff; border-radius: var(--cn-radius-lg); overflow: hidden; box-shadow: var(--cn-shadow); }
.cn-cat-feature a { display: block; color: var(--cn-text); text-decoration: none !important; }
.cn-cat-feature-thumb { aspect-ratio: 16/9; overflow: hidden; }
.cn-cat-feature-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cn-cat-feature-body { padding: 20px; }
.cn-cat-feature-body h3 { font-size: 20px; margin: 0 0 8px; color: var(--cn-text); }
.cn-cat-feature:hover .cn-cat-feature-body h3 { color: var(--cn-primary); }
.cn-cat-feature-body p { color: var(--cn-muted); font-size: 14px; margin-bottom: 6px; }
.cn-cat-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 12px; }
.cn-cat-list-item { background: #fff; border-radius: var(--cn-radius); box-shadow: var(--cn-shadow); }
.cn-cat-list-item a { display: grid; grid-template-columns: 100px 1fr; gap: 12px; padding: 8px; color: var(--cn-text); text-decoration: none !important; }
.cn-cat-list-thumb img { width: 100px; height: 75px; object-fit: cover; border-radius: 6px; }
.cn-cat-list-body { padding: 4px 4px 4px 0; }
.cn-cat-list-body h4 { font-size: 14px; line-height: 1.4; margin: 4px 0; color: var(--cn-text); }
.cn-cat-list-item:hover .cn-cat-list-body h4 { color: var(--cn-primary); }

/* ===== NEWSLETTER ===== */
.cn-newsletter { background: linear-gradient(135deg, var(--cn-primary-700) 0%, var(--cn-primary-900) 100%); color: #fff; padding: 48px 0; position: relative; overflow: hidden; }
.cn-newsletter::before { content: "✠"; position: absolute; top: -40px; right: 40px; font-size: 240px; color: rgba(201,169,97,0.06); pointer-events: none; line-height: 1; }
.cn-newsletter-inner { text-align: center; max-width: 600px; margin: 0 auto; position: relative; z-index: 1; }
.cn-newsletter-inner h2 { color: #fff; font-size: 26px; margin-bottom: 8px; }
.cn-newsletter-inner p { color: rgba(255,255,255,0.85); margin-bottom: 24px; }
.cn-newsletter-form { display: flex; gap: 8px; }
.cn-newsletter-form input { flex: 1; padding: 12px 16px; border: none; border-radius: var(--cn-radius); font-size: 15px; }
.cn-newsletter-form button { padding: 12px 24px; background: var(--cn-secondary); color: var(--cn-primary-900); border: none; border-radius: var(--cn-radius); font-weight: 700; cursor: pointer; transition: 0.2s; }
.cn-newsletter-form button:hover { background: #fff; }

/* ===== BREADCRUMB ===== */
.cn-breadcrumb { background: var(--cn-surface); padding: 12px 0; font-size: 13px; color: var(--cn-muted); }
.cn-breadcrumb a { color: var(--cn-muted); text-decoration: none !important; }
.cn-breadcrumb a:hover { color: var(--cn-primary); }

/* ===== ADMIN NOTICE ===== */
.cn-admin-notice { background: linear-gradient(135deg, #fff8e1 0%, #fff3c4 100%); border-left: 4px solid var(--cn-secondary); padding: 16px 20px; margin: 20px 0; font-size: 14px; color: #5a4a1a; border-radius: 0 var(--cn-radius) var(--cn-radius) 0; line-height: 1.6; }
.cn-admin-notice strong { color: var(--cn-primary); }
.cn-admin-notice a { color: var(--cn-primary); font-weight: 700; text-decoration: underline; }

/* ===== SINGLE ARTICLE ===== */
.cn-single .container { padding-top: 24px; }
.cn-article-grid { display: grid; grid-template-columns: 1fr 320px; gap: 40px; }
.cn-article-main { min-width: 0; }
.cn-article-header { margin-bottom: 24px; }
.cn-article-title { font-size: 34px; line-height: 1.2; margin: 12px 0 16px; }
.cn-article-lede { font-size: 18px; color: var(--cn-muted); font-style: italic; line-height: 1.5; }
.cn-article-meta { display: flex; gap: 16px; align-items: center; padding: 12px 0; border-top: 1px solid var(--cn-border); border-bottom: 1px solid var(--cn-border); font-size: 14px; color: var(--cn-muted); flex-wrap: wrap; }
.cn-author { display: flex; gap: 8px; align-items: center; color: var(--cn-text); font-weight: 600; }
.cn-author img { border-radius: 50%; }
.cn-article-thumb { margin: 24px 0; }
.cn-article-thumb img { width: 100%; border-radius: var(--cn-radius-lg); }
.cn-article-thumb figcaption { font-size: 13px; color: var(--cn-muted); text-align: center; margin-top: 8px; font-style: italic; }
.cn-share { display: flex; gap: 8px; align-items: center; padding: 12px 0; margin-bottom: 24px; border-bottom: 1px solid var(--cn-border); font-size: 14px; flex-wrap: wrap; }
.cn-share span { color: var(--cn-muted); margin-right: 8px; }
.cn-share a, .cn-share button { padding: 6px 12px; background: var(--cn-surface); color: var(--cn-primary); border: none; border-radius: var(--cn-radius); font-size: 13px; cursor: pointer; font-weight: 600; }
.cn-share a:hover, .cn-share button:hover { background: var(--cn-primary); color: #fff; }
.cn-article-content { font-size: 17px; line-height: 1.75; color: var(--cn-text); }
.cn-article-content p { margin-bottom: 1.2em; }
.cn-article-content h2 { font-size: 24px; margin: 2em 0 0.6em; }
.cn-article-content h3 { font-size: 20px; margin: 1.8em 0 0.5em; }
.cn-article-content blockquote { border-left: 4px solid var(--cn-secondary); padding: 12px 20px; margin: 1.5em 0; font-style: italic; color: var(--cn-muted); background: var(--cn-surface); border-radius: 0 var(--cn-radius) var(--cn-radius) 0; }
.cn-article-content img { border-radius: var(--cn-radius); margin: 1.5em 0; }
.cn-article-content ul, .cn-article-content ol { padding-left: 1.5em; margin-bottom: 1.2em; }
.cn-article-content a { color: var(--cn-primary); text-decoration: underline; }
.cn-article-content a:hover { color: var(--cn-accent); }
.cn-article-tags { margin: 24px 0; }
.cn-article-tags a { display: inline-block; padding: 4px 10px; margin: 2px; background: var(--cn-surface); border-radius: 20px; font-size: 13px; color: var(--cn-primary); }
.cn-article-tags a:hover { background: var(--cn-primary); color: #fff; }
.cn-related { margin: 48px 0 24px; padding-top: 24px; border-top: 2px solid var(--cn-border); }
.cn-related h2 { font-size: 22px; margin-bottom: 20px; }
.cn-article-sidebar { position: sticky; top: 100px; align-self: start; }
.cn-widget { background: var(--cn-surface); border-radius: var(--cn-radius); padding: 20px; margin-bottom: 20px; }
.cn-widget h3 { font-size: 16px; margin-bottom: 12px; padding-bottom: 8px; border-bottom: 2px solid var(--cn-secondary); color: var(--cn-primary); }
.cn-widget-list { list-style: none; padding: 0; margin: 0; }
.cn-widget-list li { padding: 8px 0; border-bottom: 1px solid var(--cn-border); }
.cn-widget-list li:last-child { border: none; }
.cn-widget-list a { color: var(--cn-text); font-size: 14px; text-decoration: none !important; }
.cn-widget-list a:hover { color: var(--cn-primary); }

/* ===== PAGE TEMPLATE ===== */
.cn-page-article { padding: 2px 0 2px; }
.cn-page-title { font-size: 32px; margin: 8px 0; }
.cn-page-thumb { margin: 8px 0; }
.cn-page-thumb img { width: 100%; border-radius: var(--cn-radius-lg); }
.cn-page-content { font-size: 17px; line-height: 1.75; }
.cn-page-content h2 { margin-top: 1.8em; }
.cn-edit-link a { font-size: 13px; color: var(--cn-muted); }

/* ===== FOOTER v2.2 ===== */
.cn-footer { background: linear-gradient(135deg, var(--cn-primary) 0%, var(--cn-primary-900) 100%); color: rgba(255,255,255,0.85); padding: 56px 0 0; margin-top: 56px; position: relative; }
.cn-footer::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 3px; background: linear-gradient(90deg, var(--cn-secondary) 0%, var(--cn-secondary-700) 100%); }
.cn-footer h4 { color: var(--cn-secondary) !important; font-size: 14px; text-transform: uppercase; letter-spacing: 1.5px; margin: 0 0 16px; padding-bottom: 10px; border-bottom: 1px solid rgba(201,169,97,0.3); font-weight: 700; }
.cn-footer a { color: rgba(255,255,255,0.85); text-decoration: none !important; transition: 0.2s; }
.cn-footer a:hover { color: var(--cn-secondary); }
.cn-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1.2fr; gap: 40px; padding-bottom: 32px; border-bottom: 1px solid rgba(255,255,255,0.1); }
.cn-footer-col p { color: rgba(255,255,255,0.75); font-size: 14px; line-height: 1.6; margin: 0 0 10px; }
.cn-footer-brand { color: #fff !important; font-size: 22px !important; text-transform: none !important; letter-spacing: 0 !important; border-bottom: none !important; padding-bottom: 0 !important; margin-bottom: 8px !important; }
.cn-footer-tagline { color: var(--cn-secondary) !important; font-style: italic; font-size: 14px !important; margin-bottom: 16px !important; }
.cn-footer-list, .cn-footer-contact { list-style: none; padding: 0; margin: 0; }
.cn-footer-list li, .cn-footer-contact li { padding: 6px 0; font-size: 14px; color: rgba(255,255,255,0.75); }
.cn-footer-list a, .cn-footer-contact a { display: inline-block; }
.cn-footer-list .post-count { color: rgba(255,255,255,0.4); font-size: 12px; margin-left: 4px; }
.cn-footer-social { display: flex; gap: 10px; margin-top: 16px; flex-wrap: wrap; }
.cn-footer-social a { font-size: 13px; font-weight: 600; padding: 6px 14px; border: 1px solid rgba(201,169,97,0.4); border-radius: 20px; transition: 0.2s; }
.cn-footer-social a:hover { background: var(--cn-secondary); color: var(--cn-primary-900) !important; border-color: var(--cn-secondary); }
.cn-footer-bottom { text-align: center; padding: 24px 0; }
.cn-footer-bottom p { margin: 4px 0; font-size: 16px; color: rgba(255,255,255,0.6); }
.cn-footer-bottom strong { color: rgba(255,255,255,0.85); }
.cn-footer-credo { font-style: italic; color: var(--cn-secondary) !important; font-size: 13px !important; letter-spacing: 1px; }

/* ===== MOBILE LATEST 20 (PC ẩn, Mobile hiện) ===== */
.cn-m-latest { display: none; }
.cn-m-latest-head { margin: 4px 0 10px; }
.cn-m-latest-title { font-size: 16px; margin: 0; color: var(--cn-primary); }
.cn-m-feature { background: #fff; border: 1px solid var(--cn-border); border-radius: 12px; overflow: hidden; box-shadow: 0 6px 18px rgba(10,37,64,0.08); }
.cn-m-feature-thumb-link { display: block; }
.cn-m-feature-thumb { aspect-ratio: 16/10; background: var(--cn-surface); overflow: hidden; }
.cn-m-feature-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cn-m-feature-body { padding: 12px 12px 10px; }
.cn-m-feature-title { margin: 0 0 6px; font-size: 17px; line-height: 1.35; }
.cn-m-feature-title a { color: #0a2540; text-decoration: none !important; }
.cn-m-feature-title a:hover { color: var(--cn-accent); }
.cn-m-feature-excerpt { margin: 0 0 8px; font-size: 13px; line-height: 1.55; color: #475569; }
.cn-m-feature-meta { display: flex; gap: 6px; align-items: center; font-size: 12.5px; color: #64748b; flex-wrap: wrap; }
.cn-m-cat { display: inline-flex; align-items: center; gap: 6px; color: #b45309 !important; font-weight: 700; text-decoration: none !important; }
.cn-m-cat:hover { color: #92400e !important; }
.cn-m-cat:hover .cn-m-cat-ico { background: #fcd34d; }
.cn-m-cat-ico { width: 18px; height: 18px; display: inline-flex; align-items: center; justify-content: center; border-radius: 999px; background: #fde68a; color: #92400e; font-size: 11px; line-height: 1; flex: 0 0 auto; transition: background 0.15s; }
.cn-m-cat-text { white-space: nowrap; }
.cn-m-date { color: #64748b; font-weight: 600; }
.cn-m-sep { color: #cbd5e1; }
.cn-m-list { list-style: none; padding: 10px 0 0; margin: 0; display: grid; gap: 10px; }
.cn-m-item { background: #fff; border: 1px solid var(--cn-border); border-radius: 12px; overflow: hidden; display: grid; grid-template-columns: 86px 1fr; gap: 10px; padding: 10px; transition: border-color 0.15s, box-shadow 0.15s; }
.cn-m-item:hover { border-color: var(--cn-primary); box-shadow: 0 4px 14px rgba(10,37,64,0.08); }
.cn-m-item-thumb-link { display: block; }
.cn-m-item-thumb { width: 86px; height: 86px; border-radius: 10px; overflow: hidden; background: var(--cn-surface); }
.cn-m-item-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cn-m-item-body { min-width: 0; }
.cn-m-item-title { margin: 0 0 6px; font-size: 14.5px; line-height: 1.35; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.cn-m-item-title a { color: #0f172a; text-decoration: none !important; }
.cn-m-item-title a:hover { color: var(--cn-primary); }
.cn-m-item-meta { display: flex; gap: 6px; align-items: center; font-size: 12px; color: #64748b; flex-wrap: wrap; }
.cn-m-thumb-placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; background: linear-gradient(135deg, var(--cn-primary) 0%, var(--cn-primary-900) 100%); color: rgba(201,169,97,0.45); font-size: 42px; }
.cn-m-thumb-placeholder.sm { font-size: 32px; }

/* Nút Xem thêm » */
.cn-m-more { margin: 16px 0 4px; text-align: center; }
.cn-m-more-btn { display: inline-flex; align-items: center; gap: 6px; padding: 12px 28px; background: linear-gradient(135deg, var(--cn-primary) 0%, var(--cn-primary-700) 100%); color: #fff !important; font-weight: 700; font-size: 14px; border-radius: 999px; text-decoration: none !important; letter-spacing: 0.5px; box-shadow: 0 4px 14px rgba(10,37,64,0.18); transition: 0.2s; }
.cn-m-more-btn:hover { background: var(--cn-secondary); color: var(--cn-primary-900) !important; box-shadow: 0 6px 18px rgba(201,169,97,0.35); transform: translateY(-1px); }

/* ===== Trang Tin mới (archive) — PC + Mobile ===== */
.cn-archive { padding-top: 24px; }
.cn-archive .cn-section-title { font-size: 26px; }
.cn-archive-list { max-width: 760px; margin: 0 auto; }

/* ===== Phân trang ===== */
.cn-pagination { margin: 28px 0 8px; }
.cn-pagination .page-numbers { list-style: none; padding: 0; margin: 0; display: flex; justify-content: center; gap: 6px; flex-wrap: wrap; }
.cn-pagination .page-numbers li { display: inline-flex; }
.cn-pagination a.page-numbers, .cn-pagination span.page-numbers { display: inline-flex; align-items: center; justify-content: center; min-width: 40px; height: 40px; padding: 0 14px; border: 1px solid var(--cn-border); border-radius: 8px; font-size: 14px; font-weight: 600; color: var(--cn-text); text-decoration: none !important; background: #fff; transition: 0.15s; }
.cn-pagination a.page-numbers:hover { background: var(--cn-primary); color: #fff !important; border-color: var(--cn-primary); }
.cn-pagination span.current { background: var(--cn-primary); color: #fff !important; border-color: var(--cn-primary); }
.cn-pagination span.dots { border-color: transparent; background: transparent; }

/* ===== Hover tiêu đề — đỏ pastel ===== */
.cn-card-title a:hover,
.cn-hero-title a:hover,
.cn-feature-title a:hover,
.cn-m-feature-title a:hover,
.cn-m-item-title a:hover,
.cn-article-title:hover,
article h2 a:hover,
article h3 a:hover {
	color: #ef4444 !important;
	transition: color 0.15s;
}

/* ===== Đồng bộ font Be Vietnam Pro toàn trang (rào chắn cuối) ===== */
body, body * {
	font-family: 'Be Vietnam Pro', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif !important;
}

/* ============================================
   RESPONSIVE — Tablet → Mobile → Tiny
   ============================================ */

/* ===== TABLET (≤ 1023px) ===== */
@media (max-width: 1023px) {
	.cn-grid-4 { grid-template-columns: repeat(3, 1fr); }
	.cn-article-grid { grid-template-columns: 1fr; }
	.cn-article-sidebar { position: static; }
	.cn-cat-grid { grid-template-columns: 1fr; }
	.cn-footer-grid { grid-template-columns: 1fr 1fr; gap: 32px; }
	.cn-footer-col-brand { grid-column: 1 / -1; }

	/* Header: ẩn top nav inline + ngày, hiện mobile actions */
	.cn-header-top-inner { gap: 10px; padding: 10px 16px; }
    .cn-top-nav, .cn-header-top-inner > .cn-search-form { display: none; }
    .cn-mobile-actions { display: flex; }
	.cn-site-title { font-size: 18px; letter-spacing: 0.5px; }
	.cn-cross { font-size: 22px; }

	/* Hero → 1 cột */
	.cn-hero-grid { grid-template-columns: 1fr; }
	.cn-hero-side { grid-template-rows: none; }
}

/* ===== MOBILE (≤ 767px) ===== */
@media (max-width: 767px) {
	body { font-size: 15px; }

	/* Tắt khối PC home, bật khối mobile 20 bài */
	.cn-desktop-home, .cn-hero { display: none !important; }
	.cn-m-latest { display: block !important; padding: 12px 0 4px; }

	/* Lời Chúa */
	.cn-gospel { padding: 20px 0; }
	.cn-gospel-inner { gap: 14px; }
	.cn-gospel-icon { font-size: 36px; }
	.cn-gospel-quote { font-size: 16px; }

	/* Sections */
	.cn-section { padding: 24px 0; }
	.cn-section-head { margin-bottom: 14px; }
	.cn-section-title { font-size: 18px; }
	.cn-grid-4, .cn-grid-3 { grid-template-columns: 1fr 1fr; gap: 12px; }

	/* Chuyên mục */
	.cn-cat-grid { gap: 14px; }
	.cn-cat-feature-body { padding: 14px; }
	.cn-cat-feature-body h3 { font-size: 16px; }
	.cn-cat-feature-body p { display: none; }

	/* Single article */
	.cn-article-title { font-size: 24px; }
	.cn-article-lede { font-size: 15px; }
	.cn-article-content { font-size: 16px; line-height: 1.7; }
	.cn-article-content h2 { font-size: 20px; }
	.cn-article-content h3 { font-size: 17px; }

	/* Newsletter */
	.cn-newsletter { padding: 28px 0; }
	.cn-newsletter-form { flex-direction: column; }

	/* Page */
	.cn-page-title { font-size: 22px; }

	/* Footer mobile: chỉ giữ dòng bản quyền + slogan */
	.cn-footer { padding: 0; margin-top: 32px; }
	.cn-footer-grid { display: none; }
	.cn-footer-bottom { padding: 18px 16px; border-top: none; }
	.cn-footer-bottom p { font-size: 12px; }
	.cn-footer-credo { font-size: 12px !important; letter-spacing: 0.5px; }

	/* Archive list trong tin-moi */
	.cn-archive-list { max-width: 100%; }
}

/* ===== TINY (≤ 380px) ===== */
@media (max-width: 380px) {
	.cn-grid-4, .cn-grid-3 { grid-template-columns: 1fr; }
}

/* =========================================================
   v4 — Row Hero + Tin đọc nhiều + Category blocks
========================================================= */

/* ===== Row 1: Hero (3fr) + Popular (2fr) ===== */
.cn-row-hero { padding: 20px 0 12px; }
.cn-row-grid { display: grid; grid-template-columns: 3fr 2fr; gap: 24px; align-items: start; }
.cn-row-col { min-width: 0; }
.cn-row-head { margin: 0 0 12px; }
.cn-row-title {
	margin: 0; font-size: 18px; color: var(--cn-primary); font-weight: 700;
	position: relative; padding-left: 14px; text-transform: uppercase; letter-spacing: 0.5px;
}
.cn-row-title::before {
	content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
	width: 4px; height: 20px; background: var(--cn-secondary); border-radius: 2px;
}

/* Tin đọc nhiều — list dox */
.cn-popular-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 10px; counter-reset: pop; }
.cn-popular-item {
	background: #fff; border: 1px solid var(--cn-border); border-radius: 10px;
	display: grid; grid-template-columns: 86px 1fr; gap: 10px; padding: 8px;
	transition: border-color 0.15s, box-shadow 0.15s;
}
.cn-popular-item:hover { border-color: var(--cn-primary); box-shadow: 0 4px 14px rgba(10,37,64,0.08); }
.cn-popular-thumb-link { display: block; }
.cn-popular-thumb {
	position: relative; width: 86px; height: 86px;
	border-radius: 8px; overflow: hidden; background: var(--cn-surface);
}
.cn-popular-thumb img { width: 100%; height: 100%; object-fit: cover; }
.cn-popular-rank {
	position: absolute; top: 4px; left: 4px; z-index: 2;
	width: 22px; height: 22px; border-radius: 50%;
	background: var(--cn-accent); color: #fff;
	display: flex; align-items: center; justify-content: center;
	font-size: 12px; font-weight: 800;
	box-shadow: 0 2px 6px rgba(139,26,26,0.35);
}
.cn-popular-body { min-width: 0; padding: 2px 4px 2px 0; }
.cn-popular-title {
	margin: 0 0 6px; font-size: 14px; line-height: 1.35; font-weight: 600;
	display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
}
.cn-popular-title a { color: #0f172a; text-decoration: none !important; }
.cn-popular-title a:hover { color: var(--cn-primary); }
.cn-popular-meta { display: flex; gap: 6px; align-items: center; font-size: 12px; color: #64748b; flex-wrap: wrap; }

/* ===== Row 3 & 4: Category 2 cột 50/50 ===== */
.cn-cat-row { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; }
.cn-cat-block { display: flex; flex-direction: column; }

/* Responsive */
@media (max-width: 1023px) {
	.cn-row-grid, .cn-cat-row { grid-template-columns: 1fr; }
}
/* =========================================================
   v4.1 — Fix khoảng trắng dưới feature Hero
   Stretch feature thumb cho cao bằng .cn-hero-side
========================================================= */
.cn-hero-grid {
	align-items: stretch;
}
.cn-hero-item.is-feature {
	display: flex;
	flex-direction: column;
	height: 100%;
}
.cn-hero-item.is-feature .cn-hero-thumb-link {
	flex: 1;
	min-height: 0;
}
.cn-hero-item.is-feature .cn-hero-thumb {
	width: 100%;
	height: 100%;
	min-height: 280px;
	aspect-ratio: auto;
}
.cn-hero-item.is-feature .cn-hero-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Cột phải: giãn 4 item dãn đều hết chiều cao */
.cn-hero-side {
	display: flex;
	flex-direction: column;
	gap: 12px;
	height: 100%;
}
.cn-hero-item.is-small {
	flex: 1;
	min-height: 0;
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 10px;
	align-items: center;
}
.cn-hero-item.is-small .cn-hero-thumb {
	width: 110px;
	height: 80px;
	aspect-ratio: auto;
}

/* Tablet/Mobile fallback */
@media (max-width: 1023px) {
	.cn-hero-item.is-feature .cn-hero-thumb {
		aspect-ratio: 16/9;
		min-height: 0;
	}
}
/* Logo size header v3 */
.cn-branding .cn-logo-img {
	height: 54px;
	width: auto;
	max-width: 320px;
	display: block;
	object-fit: contain;
}

@media (max-width: 767px) {
	.cn-branding .cn-logo-img {
		height: 54px;
		max-width: 240px;
	}
}
/* ============================================================
   Category block v5 — ribbon header + red title style
   Áp dụng: Row 3 (Sự thật, Giáo dân) + Row 4 (Kinh CG, Lịch PV)
============================================================ */

.cn-cat-block {
	background: #fff;
	border: 1px solid var(--cn-border, #e2e5ec);
	border-radius: 8px;
	overflow: hidden;
	padding: 0 16px 16px;
	height: 100%;
}

/* ===== Ribbon header ===== */
.cn-cat-block .cn-section-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin: 0 -16px 16px;
	padding: 0 16px 0 0;
	border-bottom: 3px solid var(--cn-accent, #8b1a1a);
}
.cn-cat-block .cn-section-title {
	display: inline-block;
	background: var(--cn-accent, #8b1a1a);
	color: #fff;
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	padding: 10px 28px 10px 18px;
	margin: 0;
	line-height: 1.2;
	clip-path: polygon(0 0, 100% 0, calc(100% - 14px) 100%, 0 100%);
}
.cn-cat-block .cn-section-more {
	color: var(--cn-muted, #5a6573);
	font-size: 13px;
	text-decoration: none;
	padding-bottom: 10px;
	font-weight: 500;
	transition: color 0.2s;
}
.cn-cat-block .cn-section-more:hover {
	color: var(--cn-accent, #8b1a1a);
}

/* ===== Feature ===== */
.cn-cat-block .cn-mini-hero {
	display: flex;
	flex-direction: column;
}
.cn-cat-block .cn-mini-feature {
	margin-bottom: 4px;
	padding-bottom: 16px;
	border-bottom: 1px solid var(--cn-border, #e2e5ec);
}
.cn-cat-block .cn-mini-thumb-link { display: block; }
.cn-cat-block .cn-mini-thumb {
	border-radius: 4px;
	overflow: hidden;
	aspect-ratio: 16/9;
	background: #f4f6fa;
}
.cn-cat-block .cn-mini-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}
.cn-cat-block .cn-mini-feature:hover .cn-mini-thumb img { transform: scale(1.03); }
.cn-cat-block .cn-mini-body { padding: 12px 0 0; }
.cn-cat-block .cn-mini-title {
	font-size: 19px;
	font-weight: 800;
	line-height: 1.25;
	margin: 0 0 8px;
	text-transform: uppercase;
}
.cn-cat-block .cn-mini-title a {
	color: var(--cn-accent, #8b1a1a);
	text-decoration: none;
}
.cn-cat-block .cn-mini-title a:hover {
	color: #ef4444;
}
.cn-cat-block .cn-mini-excerpt {
	font-size: 14.5px;
	color: var(--cn-text, #1a1a1a);
	line-height: 1.5;
	margin: 0 0 8px;
	font-weight: 500;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-cat-block .cn-mini-meta {
	font-size: 12px;
	color: var(--cn-muted, #94a3b8);
}

/* ===== Small items list ===== */
.cn-cat-block .cn-mini-list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.cn-cat-block .cn-mini-item {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 14px;
	padding: 14px 0;
	border-bottom: 1px dashed var(--cn-border, #e2e5ec);
	align-items: flex-start;
}
.cn-cat-block .cn-mini-item:last-child {
	border-bottom: 0;
	padding-bottom: 4px;
}
.cn-cat-block .cn-mini-item-thumb-link { display: block; }
.cn-cat-block .cn-mini-item-thumb {
	border-radius: 4px;
	overflow: hidden;
	aspect-ratio: 16/9;
	background: #f4f6fa;
}
.cn-cat-block .cn-mini-item-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.cn-cat-block .cn-mini-item-body { padding-top: 2px; }
.cn-cat-block .cn-mini-item-title {
	font-size: 14px;
	font-weight: 600;
	line-height: 1.45;
	margin: 0;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-cat-block .cn-mini-item-title a {
	color: var(--cn-text, #1a1a1a);
	text-decoration: none;
	transition: color 0.2s;
}
.cn-cat-block .cn-mini-item-title a:hover {
	color: var(--cn-accent, #8b1a1a);
}

/* ===== Responsive ===== */
@media (max-width: 767px) {
	.cn-cat-block { padding: 0 12px 12px; }
	.cn-cat-block .cn-section-head { margin: 0 -12px 14px; padding-right: 14px; }
	.cn-cat-block .cn-section-title { font-size: 13px; padding: 9px 24px 9px 14px; }
	.cn-cat-block .cn-mini-title { font-size: 17px; }
	.cn-cat-block .cn-mini-excerpt { font-size: 14px; }
	.cn-cat-block .cn-mini-item { grid-template-columns: 90px 1fr; gap: 10px; padding: 12px 0; }
}
/* ============================================================
   Category block v5.1 — Fix căn chỉnh padding + thumb
============================================================ */

/* 1. Card: thêm padding-top để ảnh không dính ribbon */
.cn-cat-block {
	padding: 16px;
	border: 1px solid #d4d8e0;
	box-shadow: 0 1px 3px rgba(0,0,0,0.04);
}

/* 2. Section head bù lại padding-top + mở rộng full width */
.cn-cat-block .cn-section-head {
	margin: -16px -16px 16px;
}

/* 3. Feature thumb bo tròn mềm hơn */
.cn-cat-block .cn-mini-thumb {
	border-radius: 6px;
}

/* 4. Small item — FORCE fixed dimension cho thumb */
.cn-cat-block .cn-mini-item {
	grid-template-columns: 120px 1fr;
	gap: 12px;
	padding: 12px 0;
	align-items: flex-start;
}
.cn-cat-block .cn-mini-item-thumb {
	width: 120px;
	height: 68px; /* 16:9 của 120 = 67.5 → làm tròn 68 */
	aspect-ratio: unset;
	flex-shrink: 0;
}
.cn-cat-block .cn-mini-item-thumb img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block;
}

/* 5. Đảm bảo cn-cat-row giãn cách đẹp */
.cn-cat-row {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 24px;
	align-items: stretch;
}

/* 6. Responsive mobile */
@media (max-width: 767px) {
	.cn-cat-row {
		grid-template-columns: 1fr;
		gap: 16px;
	}
	.cn-cat-block { padding: 12px; }
	.cn-cat-block .cn-section-head { margin: -12px -12px 14px; }
	.cn-cat-block .cn-mini-item {
		grid-template-columns: 100px 1fr;
		gap: 10px;
	}
	.cn-cat-block .cn-mini-item-thumb {
		width: 100px;
		height: 56px;
	}
}
/* ============================================================
   Category block v5.2 — Fix padding bài feature (bài 1)
============================================================ */

/* Body của feature: thêm padding ngang để title/excerpt/date không dính viền */
.cn-cat-block .cn-mini-feature .cn-mini-body {
	padding: 14px 6px 4px;
}

/* Tăng khoảng cách dưới feature đến divider */
.cn-cat-block .cn-mini-feature {
	padding-bottom: 18px;
	margin-bottom: 8px;
}

/* Feature title: tăng line-height + margin-bottom cho đẹp */
.cn-cat-block .cn-mini-feature .cn-mini-title {
	margin: 0 0 10px;
	line-height: 1.3;
}

/* Excerpt: line-height thoải mái hơn + margin-bottom rõ */
.cn-cat-block .cn-mini-feature .cn-mini-excerpt {
	margin: 0 0 10px;
	line-height: 1.55;
}

/* Meta (ngày): thêm padding-top nhẹ để tách khỏi excerpt */
.cn-cat-block .cn-mini-feature .cn-mini-meta {
	margin-top: 2px;
}

/* Mobile: giảm padding ngang một chút */
@media (max-width: 767px) {
	.cn-cat-block .cn-mini-feature .cn-mini-body {
		padding: 12px 2px 2px;
	}
}
/* ============================================================
   Category block v8 — Namespace .cn-cb-* (sạch xung khắc)
   1 feature đỏ uppercase trên + 4 bài nhỏ list dưới (thumb inset)
============================================================ */

/* ===== Card ngoài ===== */
.cn-cb {
	background: #fff;
	border: 1px solid #d4d8e0;
	border-radius: 8px;
	overflow: hidden;
	padding: 16px 18px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.04);
	height: 100%;
	display: flex;
	flex-direction: column;
}

/* ===== Ribbon header ===== */
.cn-cb-head {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
	margin: -16px -18px 16px;
	padding: 0 18px 0 0;
	border-bottom: 3px solid #1e3a8a;
}
.cn-cb-title {
	display: inline-block;
	background: #1e3a8a;
	color: #fff;
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	padding: 10px 28px 10px 18px;
	margin: 0;
	line-height: 1.2;
	clip-path: polygon(0 0, 100% 0, calc(100% - 14px) 100%, 0 100%);
}
.cn-cb-more {
	color: #5a6573;
	font-size: 13px;
	text-decoration: none !important;
	padding-bottom: 10px;
	font-weight: 500;
	transition: color 0.2s;
}
.cn-cb-more:hover { color: #1e3a8a; }

/* ===== FEATURE (bài 1) ===== */
.cn-cb-feature {
	margin-bottom: 14px;
	padding-bottom: 14px;
	border-bottom: 1px solid #e2e5ec;
	background: transparent;
	border-top: 0;
	border-left: 0;
	border-right: 0;
	border-radius: 0;
	box-shadow: none;
}
.cn-cb-feature-thumb-link { display: block; }
.cn-cb-feature-thumb {
	border-radius: 6px;
	overflow: hidden;
	aspect-ratio: 16/9;
	background: #f4f6fa;
	width: 100%;
}
.cn-cb-feature-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s ease;
}
.cn-cb-feature:hover .cn-cb-feature-thumb img { transform: scale(1.03); }
.cn-cb-feature-body { padding: 12px 0 0; }
.cn-cb-feature-title {
	font-size: 18px;
	font-weight: 800;
	line-height: 1.3;
	margin: 0 0 8px;
	text-transform: transparent;
	color: #1e3a8a;
}
.cn-cb-feature-title a {
	color: #1e3a8a !important;
	text-decoration: none !important;
}
.cn-cb-feature-title a:hover { color: #ef4444 !important; }
.cn-cb-feature-excerpt {
	font-size: 14px;
	color: #1a1a1a;
	line-height: 1.55;
	margin: 0 0 8px;
	font-weight: 500;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-cb-feature-meta { font-size: 12px; color: #94a3b8; }

/* ===== 4 BÀI NHỈ (LIST KHÔNG CARD RIÊNG) ===== */
.cn-cb-list {
	list-style: none;
	margin: 0;
	padding: 0 0 0 20px; /* ← INSET 20px từ viền trái card */
	display: block;
	gap: 0;
}
.cn-cb-row {
	display: grid;
	grid-template-columns: 110px 1fr;
	gap: 12px;
	padding: 12px 0;
	border-bottom: 1px dashed #e2e5ec;
	align-items: flex-start;
	/* QUAN TRỌNG: reset hoàn toàn mọi card-style cũ */
	background: transparent;
	border-top: 0;
	border-left: 0;
	border-right: 0;
	border-radius: 0;
	box-shadow: none;
	margin: 0;
	transition: none;
}
.cn-cb-row:hover {
	border-color: #e2e5ec;
	border-bottom-color: #cbd5e1;
	box-shadow: none;
}
.cn-cb-row:last-child {
	border-bottom: 0;
	padding-bottom: 0;
}
.cn-cb-row-thumb-link { display: block; }
.cn-cb-row-thumb {
	width: 110px;
	height: 62px; /* 16:9 */
	border-radius: 4px;
	overflow: hidden;
	background: #f4f6fa;
	flex-shrink: 0;
}
.cn-cb-row-thumb img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block;
	transition: transform 0.3s ease;
	border-radius: 0;
}
.cn-cb-row:hover .cn-cb-row-thumb img { transform: scale(1.05); }
.cn-cb-row-body { padding: 0; min-width: 0; }
.cn-cb-row-title {
	font-size: 14px;
	font-weight: 600;
	line-height: 1.4;
	margin: 0 0 5px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-cb-row-title a {
	color: #1a1a1a !important;
	text-decoration: none !important;
	transition: color 0.2s;
}
.cn-cb-row-title a:hover { color: #ef4444 !important; }
.cn-cb-row-meta { font-size: 12px; color: #94a3b8; }

/* ===== Placeholder ===== */
.cn-cb-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, #0a2540 0%, #04111f 100%);
	color: rgba(201,169,97,0.4);
	font-size: 48px;
}
.cn-cb-placeholder.sm { font-size: 28px; }

/* ===== Mobile ===== */
@media (max-width: 767px) {
	.cn-cb {
		padding: 12px 14px;
	}
	.cn-cb-head {
		margin: -12px -14px 14px;
		padding-right: 14px;
	}
	.cn-cb-title {
		font-size: 13px;
		padding: 9px 24px 9px 14px;
	}
	.cn-cb-feature-title { font-size: 16px; }
	.cn-cb-list { padding-left: 12px; }
	.cn-cb-row {
		grid-template-columns: 95px 1fr;
		gap: 10px;
		padding: 10px 0;
	}
	.cn-cb-row-thumb {
		width: 95px;
		height: 53px;
	}
}
/* ===== Mobile Latest 20 — Meta cố định ở đáy (bài 2 → 20) ===== */
.cn-m-item {
	align-items: stretch; /* body cao bằng thumb 86px */
}
.cn-m-item-body {
	display: flex;
	flex-direction: column;
	min-height: 0;
}
.cn-m-item-title {
	margin: 0 0 6px;
	/* giữ nguyên 2 dòng clamp */
}
.cn-m-item-meta {
	margin-top: auto; /* ← Đẩy meta xuống đáy body */
	padding-bottom: 2px;
}
/* ===== Mobile Latest 20 — Title hiện đầy đủ (bỏ clamp 2 dòng) ===== */
.cn-m-item-title {
	display: block;
	-webkit-line-clamp: unset;
	-webkit-box-orient: unset;
	overflow: visible;
}
.cn-m-item-thumb-link {
	align-self: flex-start; /* Thumb stick top khi title dài */
}
/* ===== Mobile Latest 20 — Meta chữ thường (bài 2 → 20) ===== */
.cn-m-item-meta .cn-m-cat,
.cn-m-item-meta .cn-m-date {
	font-weight: 400;
}
/* ===== Footer — Đồng bộ màu nền với Header ===== */
.cn-footer {
	background: linear-gradient(135deg, var(--cn-nav-bg) 0%, var(--cn-nav-bg-dark) 100%);
}
/* ===== Footer Credo — Chữ thường (không nghiêng) ===== */
.cn-footer-credo {
	font-style: normal !important;
}
/* ===== Footer Mobile — Cỡ chữ = title bài mới (14.5px) ===== */
@media (max-width: 767px) {
	.cn-footer-bottom p,
	.cn-footer-credo {
		font-size: 14.5px !important;
	}
}
/* ===== Footer Mobile — Static links (Liên hệ | Góp ý | Điều khoản) ===== */
.cn-footer-mlinks { display: none; } /* Ẩn ở PC */

@media (max-width: 767px) {
	.cn-footer-mlinks {
		display: flex;
		justify-content: center;
		align-items: center;
		gap: 10px;
		flex-wrap: wrap;
		margin: 10px 0 4px;
		font-size: 13px;
	}
	.cn-footer-mlinks a {
		color: rgba(255,255,255,0.85) !important;
		text-decoration: none !important;
		font-weight: 500;
		transition: color 0.15s;
	}
	.cn-footer-mlinks a:hover {
		color: var(--cn-secondary) !important;
	}
	.cn-footer-mlinks-sep {
		color: rgba(255,255,255,0.4);
		user-select: none;
	}
}
/* ===== Mobile Latest 20 — Nút "Xem thêm" pastel ===== */
.cn-m-more-btn {
	background: #dbeafe !important; /* xanh pastel nhạt */
	color: var(--cn-primary) !important;
	box-shadow: 0 2px 8px rgba(10,37,64,0.08) !important;
	font-weight: 600;
}
.cn-m-more-btn:hover {
	background: #bfdbfe !important; /* đậm nhẹ khi hover */
	color: var(--cn-primary-900) !important;
	box-shadow: 0 4px 12px rgba(10,37,64,0.12) !important;
	transform: translateY(-1px);
}
/* ============================================================
   Single Article v2 — Điều chỉnh theo yêu cầu
   - Share cuối bài, sidebar widget thumb, related 6/5
   - Ảnh trong bài vừa màn hình, ẩn sidebar mobile
============================================================ */

/* ===== ẢNH TRONG BÀI — cố định không vỡ khung ===== */
.cn-article-content img {
	max-width: 100% !important;
	height: auto !important;
	display: block;
	margin: 1.5em auto;
	border-radius: 8px;
	box-shadow: 0 2px 8px rgba(10,37,64,0.08);
}
.cn-article-content figure {
	max-width: 100% !important;
	margin: 1.5em 0;
}
.cn-article-content figure img { margin: 0 auto; }
.cn-article-content figcaption {
	text-align: center;
	font-size: 13px;
	color: var(--cn-muted);
	font-style: italic;
	margin-top: 8px;
}
.cn-article-content iframe,
.cn-article-content video {
	max-width: 100%;
	height: auto;
}

/* ===== SHARE CUỐI BÀI ===== */
.cn-share-bottom {
	margin: 28px 0 0;
	padding: 16px 0;
	border-top: 1px solid var(--cn-border);
	border-bottom: 1px solid var(--cn-border);
}

/* ===== WIDGET TIN NỔI BẬT — có thumb 64×64 bo góc ===== */
.cn-widget-popular-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.cn-widget-popular-item {
	display: grid;
	grid-template-columns: 64px 1fr;
	gap: 12px;
	align-items: flex-start;
	padding: 10px 0;
	border-bottom: 1px solid var(--cn-border);
}
.cn-widget-popular-item:last-child { border-bottom: 0; padding-bottom: 0; }
.cn-widget-popular-thumb {
	display: block;
	width: 64px;
	height: 64px;
	border-radius: 8px;
	overflow: hidden;
	background: var(--cn-surface);
	flex-shrink: 0;
}
.cn-widget-popular-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.3s;
}
.cn-widget-popular-item:hover .cn-widget-popular-thumb img { transform: scale(1.05); }
.cn-widget-popular-body { min-width: 0; }
.cn-widget-popular-title {
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	color: var(--cn-text) !important;
	font-size: 13.5px;
	line-height: 1.4;
	font-weight: 600;
	text-decoration: none !important;
	margin: 0 0 4px;
}
.cn-widget-popular-title:hover { color: var(--cn-primary) !important; }
.cn-widget-popular-meta {
	font-size: 11.5px;
	color: #94a3b8;
}

/* ===== WIDGET CHUYÊN MỤC — hiện cả 0 bài ===== */
.cn-widget-cats .cn-widget-list li a + .post-count,
.cn-widget-cats .cn-widget-list li {
	font-size: 14px;
}
.cn-widget-cats .cn-widget-list li {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.cn-widget-cats .cn-widget-list a {
	flex: 1;
}

/* ===== BÀI LIÊN QUAN PC — grid 3×2 = 6 bài ===== */
.cn-related-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 18px;
}
.cn-related-card {
	background: #fff;
	border: 1px solid var(--cn-border);
	border-radius: 10px;
	overflow: hidden;
	transition: 0.2s;
}
.cn-related-card:hover {
	border-color: var(--cn-primary);
	transform: translateY(-2px);
	box-shadow: 0 6px 16px rgba(10,37,64,0.1);
}
.cn-related-thumb {
	display: block;
	aspect-ratio: 16/9;
	overflow: hidden;
	background: var(--cn-surface);
}
.cn-related-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s;
}
.cn-related-card:hover .cn-related-thumb img { transform: scale(1.05); }
.cn-related-body { padding: 10px 12px 12px; }
.cn-related-title {
	margin: 0 0 6px;
	font-size: 14.5px;
	line-height: 1.4;
	font-weight: 600;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-related-title a {
	color: var(--cn-text) !important;
	text-decoration: none !important;
}
.cn-related-title a:hover { color: #ef4444; }
.cn-related-meta { font-size: 12px; color: #94a3b8; }
.cn-related-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, var(--cn-primary), var(--cn-primary-900));
	color: rgba(201,169,97,0.4);
	font-size: 36px;
}
.cn-related-placeholder.sm { font-size: 24px; }

/* Mobile list (ẩn mặc định) */
.cn-related-mlist { display: none; }

/* ===== MOBILE OVERRIDES ===== */
@media (max-width: 1023px) {
	/* Sidebar xuống dưới article hoặc ẩn */
	.cn-article-grid { grid-template-columns: 1fr; gap: 24px; }
}

@media (max-width: 767px) {
	/* Ẩn sidebar toàn bộ (Tìn nổi bật + Chuyên mục) */
	.cn-article-sidebar { display: none !important; }

	/* Bài liên quan: ẩn grid PC, hiện list 5 bài mobile */
	.cn-related-grid { display: none; }
	.cn-related-mlist {
		display: block;
		list-style: none;
		margin: 0;
		padding: 0;
	}
	.cn-related-mrow {
		display: grid;
		grid-template-columns: 80px 1fr;
		gap: 12px;
		padding: 12px 0;
		border-bottom: 1px dashed var(--cn-border);
		align-items: flex-start;
	}
	.cn-related-mrow:last-child {
		border-bottom: 0;
		padding-bottom: 0;
	}
	.cn-related-mthumb {
		display: block;
		width: 80px;
		height: 80px;
		border-radius: 8px;
		overflow: hidden;
		background: var(--cn-surface);
		flex-shrink: 0;
	}
	.cn-related-mthumb img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
		transition: transform 0.3s;
	}
	.cn-related-mrow:hover .cn-related-mthumb img { transform: scale(1.05); }
	.cn-related-mtitle {
		margin: 0 0 5px;
		font-size: 14.5px;
		line-height: 1.4;
		font-weight: 600;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}
	.cn-related-mtitle a {
		color: var(--cn-text) !important;
		text-decoration: none !important;
	}
	.cn-related-mmeta { font-size: 12px; color: #94a3b8; }

	/* Share cuối bài mobile */
	.cn-share-bottom { padding: 12px 0; }
	.cn-share-bottom a, .cn-share-bottom button {
		font-size: 12.5px;
		padding: 6px 10px;
	}

	/* Ảnh trong bài mobile — rõ ràng vừa khung */
	.cn-article-content img {
		margin: 1.2em auto;
		border-radius: 6px;
	}
}
/* ============================================================
   Single v2 — Fix 2 khoảng trống thừa (PC + Mobile)
============================================================ */

/* === (1) Khoảng trống ĐẦU bài viết (header navy → tiêu đề) === */
.cn-single .container { padding-top: 0 !important; }
.cn-single .cn-breadcrumb { padding: 6px 0; margin: 0; }
.cn-single .cn-breadcrumb .container {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}
/* Ẩn breadcrumb nếu rỗng (post chưa có chuyên mục cha) */
.cn-single .cn-breadcrumb:empty,
.cn-single .cn-breadcrumb .container:empty { display: none; }
.cn-single .cn-article > .container { padding-top: 12px !important; }
.cn-article-header { margin-top: 0; padding-top: 0; }
.cn-article-header .cn-badge { margin-top: 0; }
.cn-article-title { margin-top: 6px !important; }

/* === (2) Khoảng trống giữa Chia sẻ ↔ Bài liên quan === */
.cn-share-bottom {
	margin: 18px 0 0 !important;
	padding: 12px 0 !important;
	border-bottom: 0 !important;  /* bỏ border dưới của share */
}
.cn-related {
	margin: 16px 0 24px !important; /* trước là 48px */
	padding-top: 14px !important;   /* trước là 24px */
	border-top: 0 !important;       /* bỏ luôn border-top vì share đã có border-bottom */
}
.cn-related h2 {
	margin: 0 0 12px !important;
}

/* === Mobile === */
@media (max-width: 767px) {
	.cn-single .cn-article > .container { padding-top: 8px !important; }
	.cn-share-bottom { margin: 14px 0 0 !important; padding: 10px 0 !important; }
	.cn-related { margin: 12px 0 16px !important; padding-top: 10px !important; }
}
/* ===== Author cố định (Paul G) ===== */
.cn-author-fixed {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	color: var(--cn-muted);
	font-size: 13.5px;
}
.cn-author-fixed .cn-author-avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	object-fit: cover;
	border: 1px solid var(--cn-border);
	display: block;
}
.cn-author-fixed span { font-weight: 500; color: var(--cn-text); }
/* ============================================================
   Category Archive — Hero + List dọc, full width
============================================================ */
.cn-cat .container { padding-top: 16px; padding-bottom: 40px; }

/* ===== Header chuyên mục ===== */
.cn-cat-header {
	margin: 8px 0 24px;
	padding: 20px 24px;
	background: linear-gradient(135deg, var(--cn-primary), var(--cn-primary-900));
	border-radius: 12px;
	color: #fff;
	position: relative;
	overflow: hidden;
}
.cn-cat-header::before {
	content: "✠";
	position: absolute;
	right: 20px;
	top: 50%;
	transform: translateY(-50%);
	font-size: 96px;
	color: rgba(201,169,97,0.18);
	line-height: 1;
}
.cn-cat-eyebrow {
	display: inline-block;
	font-size: 12px;
	text-transform: uppercase;
	letter-spacing: 1px;
	color: var(--cn-accent, #c9a961);
	font-weight: 600;
	margin-bottom: 4px;
}
.cn-cat-title {
	margin: 0 0 6px;
	font-size: 30px;
	font-weight: 700;
	line-height: 1.2;
	color: #fff;
}
.cn-cat-desc {
	margin: 0;
	font-size: 14.5px;
	line-height: 1.55;
	color: rgba(255,255,255,0.88);
	max-width: 720px;
}

/* ===== HERO ===== */
.cn-cat-hero {
	display: grid;
	grid-template-columns: 1.1fr 1fr;
	gap: 24px;
	margin: 0 0 28px;
	padding-bottom: 24px;
	border-bottom: 1px solid var(--cn-border);
}
.cn-cat-hero-thumb {
	display: block;
	aspect-ratio: 16/9;
	border-radius: 12px;
	overflow: hidden;
	background: var(--cn-surface);
}
.cn-cat-hero-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s;
}
.cn-cat-hero:hover .cn-cat-hero-thumb img { transform: scale(1.04); }
.cn-cat-hero-body { display: flex; flex-direction: column; justify-content: center; }
.cn-cat-hero-body .cn-badge { align-self: flex-start; margin-bottom: 10px; }
.cn-cat-hero-title {
	margin: 0 0 10px;
	font-size: 24px;
	line-height: 1.3;
	font-weight: 700;
}
.cn-cat-hero-title a {
	color: var(--cn-text) !important;
	text-decoration: none !important;
}
.cn-cat-hero-title a:hover { color: var(--cn-primary) !important; }
.cn-cat-hero-excerpt {
	margin: 0 0 12px;
	font-size: 14.5px;
	line-height: 1.6;
	color: var(--cn-muted);
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-cat-hero-meta {
	font-size: 12.5px;
	color: #94a3b8;
	display: flex;
	gap: 14px;
	align-items: center;
}

/* ===== LIST 19 bài ===== */
.cn-cat-list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.cn-cat-item {
	display: grid;
	grid-template-columns: 140px 1fr;
	gap: 18px;
	padding: 16px 0;
	border-bottom: 1px dashed var(--cn-border);
	align-items: flex-start;
}
.cn-cat-item:last-child { border-bottom: 0; }
.cn-cat-item-thumb {
	display: block;
	width: 140px;
	height: 140px;
	border-radius: 10px;
	overflow: hidden;
	background: var(--cn-surface);
	flex-shrink: 0;
}
.cn-cat-item-thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s;
}
.cn-cat-item:hover .cn-cat-item-thumb img { transform: scale(1.05); }
.cn-cat-item-body { min-width: 0; }
.cn-cat-item-title {
	margin: 0 0 6px;
	font-size: 17px;
	line-height: 1.35;
	font-weight: 600;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-cat-item-title a {
	color: var(--cn-text) !important;
	text-decoration: none !important;
}
.cn-cat-item-title a:hover { color: var(--cn-primary) !important; }
.cn-cat-item-excerpt {
	margin: 0 0 6px;
	font-size: 13.5px;
	line-height: 1.55;
	color: var(--cn-muted);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.cn-cat-item-meta {
	font-size: 12px;
	color: #94a3b8;
	display: flex;
	gap: 12px;
}

/* ===== Pagination ===== */
.cn-pagination {
	margin: 32px 0 0;
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	justify-content: center;
}
.cn-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 38px;
	height: 38px;
	padding: 0 12px;
	border: 1px solid var(--cn-border);
	border-radius: 8px;
	background: #fff;
	color: var(--cn-text);
	text-decoration: none;
	font-size: 14px;
	font-weight: 500;
	transition: 0.2s;
}
.cn-pagination .page-numbers:hover {
	border-color: var(--cn-primary);
	color: var(--cn-primary);
}
.cn-pagination .page-numbers.current {
	background: var(--cn-primary);
	border-color: var(--cn-primary);
	color: #fff;
}
.cn-pagination .page-numbers.dots {
	border: 0;
	background: transparent;
}

/* ===== Empty state ===== */
.cn-cat-empty {
	padding: 60px 20px;
	text-align: center;
	color: var(--cn-muted);
}
.cn-cat-empty .cn-btn {
	display: inline-block;
	margin-top: 16px;
	padding: 10px 20px;
	background: var(--cn-primary);
	color: #fff !important;
	border-radius: 8px;
	text-decoration: none !important;
	font-weight: 600;
}

/* ===== Mobile ===== */
@media (max-width: 767px) {
	.cn-cat-header {
		padding: 16px 18px;
		border-radius: 10px;
	}
	.cn-cat-header::before { font-size: 64px; right: 12px; }
	.cn-cat-title { font-size: 22px; }
	.cn-cat-desc { font-size: 13.5px; }

	/* Hero stack dọc */
	.cn-cat-hero {
		grid-template-columns: 1fr;
		gap: 12px;
		padding-bottom: 18px;
		margin-bottom: 20px;
	}
	.cn-cat-hero-title { font-size: 19px; }
	.cn-cat-hero-excerpt { -webkit-line-clamp: 2; font-size: 14px; }

	/* List item — thumb nhỏ hơn */
	.cn-cat-item {
		grid-template-columns: 96px 1fr;
		gap: 12px;
		padding: 12px 0;
	}
	.cn-cat-item-thumb { width: 96px; height: 96px; border-radius: 8px; }
	.cn-cat-item-title { font-size: 14.5px; }
	.cn-cat-item-excerpt { display: none; }
	.cn-cat-item-meta { font-size: 11.5px; }

	.cn-pagination .page-numbers {
		min-width: 34px;
		height: 34px;
		font-size: 13px;
		padding: 0 8px;
	}
}
/* ============================================================
   Category v2 — Tinh chỉnh: bỏ khoảng trống top, header phẳng,
   meta sát đáy
============================================================ */

/* (1) Xóa khoảng trống đầu trang */
.cn-cat .container { padding-top: 0 !important; padding-bottom: 40px; }
.cn-cat .cn-breadcrumb { padding: 6px 0; }
.cn-cat .cn-breadcrumb .container { padding-top: 0 !important; padding-bottom: 0 !important; }
.cn-cat .cn-breadcrumb:empty,
.cn-cat .cn-breadcrumb .container:empty { display: none; }

/* (2) Header phẳng — 2 dòng riêng, không bọc khối */
.cn-cat-header { all: unset; display: contents; } /* vô hiệu hoá CSS cũ của .cn-cat-header */
.cn-cat-title-line {
	margin: 4px 0 6px;
	font-size: 28px;
	font-weight: 800;
	line-height: 1.2;
	color: var(--cn-primary);
	letter-spacing: 0.5px;
}
.cn-cat-desc-line {
	margin: 0 0 24px;
	font-size: 14.5px;
	line-height: 1.6;
	color: var(--cn-muted);
	max-width: 820px;
}

/* (3) Hero: flex để meta đẩy sát đáy */
.cn-cat-hero-body {
	display: flex !important;
	flex-direction: column !important;
	justify-content: flex-start !important;
}
.cn-cat-hero-meta {
	margin-top: auto !important;  /* đẩy sát đáy */
	padding-top: 12px;
}

/* (4) List item: meta sát đáy của body */
.cn-cat-item { align-items: stretch !important; }
.cn-cat-item-body {
	display: flex;
	flex-direction: column;
	min-height: 100%;
}
.cn-cat-item-meta {
	margin-top: auto;  /* đẩy ngày xuống sát đáy thumb */
	padding-top: 6px;
}

/* Mobile */
@media (max-width: 767px) {
	.cn-cat-title-line { font-size: 22px; margin: 2px 0 4px; }
	.cn-cat-desc-line { font-size: 13.5px; margin-bottom: 18px; }
}
/* ============================================================
   Category v3 — Title icon + Grid sidebar + Mobile compact
============================================================ */

/* ===== Tiêu đề Chuyên mục với gold bar + ✨ ===== */
.cn-cat-title-line {
	display: flex !important;
	align-items: center;
	gap: 10px;
	margin: 14px 0 8px !important;
	padding: 6px 0 6px 14px;
	font-size: 22px !important;
	font-weight: 800 !important;
	line-height: 1.2;
	color: var(--cn-primary) !important;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	position: relative;
	border-left: 4px solid var(--cn-secondary, #c9a961);
	border-radius: 2px;
}
.cn-cat-title-icon { font-size: 20px; line-height: 1; }
.cn-cat-title-text { display: inline-block; }
.cn-cat-desc-line { margin: 0 0 22px !important; }

/* ===== Dùng chung style heading cho widget Tin nổi bật + Chuyên mục ===== */
.cn-widget-heading {
	display: flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 14px;
	padding: 4px 0 4px 12px;
	font-size: 16px;
	font-weight: 800;
	color: var(--cn-primary);
	text-transform: uppercase;
	letter-spacing: 0.5px;
	border-left: 4px solid var(--cn-secondary, #c9a961);
}
.cn-widget-heading-icon { font-size: 18px; line-height: 1; }

/* ===== Grid Main + Sidebar ===== */
.cn-cat-grid {
	display: grid;
	grid-template-columns: 1fr 320px;
	gap: 32px;
	align-items: start;
}
.cn-cat-main { min-width: 0; } /* tránh overflow grid */
.cn-cat-sidebar {
	position: sticky;
	top: 88px;
}
.cn-cat-sidebar .cn-widget {
	background: #fff;
	border: 1px solid var(--cn-border);
	border-radius: 10px;
	padding: 18px;
	margin-bottom: 18px;
}

/* ===== Mobile ===== */
@media (max-width: 1023px) {
	.cn-cat-grid { grid-template-columns: 1fr; gap: 0; }
	.cn-cat-sidebar { display: none; } /* ẨN sidebar trên tablet + mobile */
}

@media (max-width: 767px) {
	.cn-cat-title-line {
		font-size: 18px !important;
		margin: 10px 0 6px !important;
		padding: 4px 0 4px 10px;
		gap: 8px;
		border-left-width: 3px;
	}
	.cn-cat-title-icon { font-size: 16px; }
	.cn-cat-desc-line { margin-bottom: 16px !important; font-size: 13px; }

	/* Hero stack — không đổi */

	/* 19 bài: NHỎ lại để xem được nhiều */
	.cn-cat-item {
		grid-template-columns: 78px 1fr !important;
		gap: 10px !important;
		padding: 8px 0 !important;
	}
	.cn-cat-item-thumb {
		width: 78px !important;
		height: 78px !important;
		border-radius: 6px !important;
	}
	.cn-cat-item-title {
		font-size: 13.5px !important;
		line-height: 1.35 !important;
		-webkit-line-clamp: 2 !important;
		margin-bottom: 4px !important;
	}
	.cn-cat-item-excerpt { display: none !important; }
	.cn-cat-item-meta {
		font-size: 11px !important;
		padding-top: 2px !important;
		gap: 8px !important;
	}
}
/* ============================================================
   Category v4 — Sidebar sát top, bỏ icon/bar widget, mobile all small
============================================================ */

/* (1) Bỏ gold bar + padding-left của widget heading (sidebar) */
.cn-cat-sidebar .cn-widget-heading {
	border-left: 0 !important;
	padding-left: 0 !important;
	margin: 0 0 12px !important;
}
.cn-cat-sidebar .cn-widget-heading-icon { display: none !important; }

/* (2) PC: Sidebar SÁT đỉnh content area (cùng Y với title chính) */
.cn-cat-grid { align-items: start !important; }
.cn-cat-sidebar {
	margin-top: 0 !important;
	padding-top: 0 !important;
	top: 16px !important; /* sticky offset khi scroll */
}
.cn-cat-sidebar > *:first-child { margin-top: 0 !important; }
.cn-cat-sidebar .cn-widget:first-child {
	margin-top: 0 !important;
	padding-top: 16px;
}
/* Title chính cũng pull lên sát top để cân với sidebar */
.cn-cat-title-line { margin-top: 4px !important; }
.cn-cat-main > *:first-child { margin-top: 0 !important; }

/* ============================================================
   (3) MOBILE: 20 bài đều NHỎ — biến hero thành item bình thường
============================================================ */
@media (max-width: 767px) {
	/* Hero → trông như cat-item compact */
	.cn-cat-hero {
		display: grid !important;
		grid-template-columns: 78px 1fr !important;
		gap: 10px !important;
		padding: 8px 0 !important;
		margin: 0 !important;
		border-bottom: 1px dashed var(--cn-border) !important;
		border-radius: 0 !important;
		background: transparent !important;
		align-items: stretch !important;
	}
	.cn-cat-hero-thumb {
		aspect-ratio: 1/1 !important;
		width: 78px !important;
		height: 78px !important;
		min-width: 78px !important;
		border-radius: 6px !important;
	}
	.cn-cat-hero-thumb img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
	}
	.cn-cat-hero-body {
		display: flex !important;
		flex-direction: column !important;
		justify-content: flex-start !important;
		gap: 0 !important;
		padding: 0 !important;
	}
	/* Bỏ badge nếu còn */
	.cn-cat-hero-body .cn-badge { display: none !important; }
	.cn-cat-hero-title {
		font-size: 13.5px !important;
		line-height: 1.35 !important;
		font-weight: 600 !important;
		margin: 0 0 4px !important;
		display: -webkit-box !important;
		-webkit-line-clamp: 2 !important;
		-webkit-box-orient: vertical !important;
		overflow: hidden !important;
	}
	.cn-cat-hero-excerpt { display: none !important; }
	.cn-cat-hero-meta {
		font-size: 11px !important;
		padding-top: 2px !important;
		margin-top: auto !important;
		gap: 8px !important;
		color: #94a3b8 !important;
	}

	/* Đảm bảo list 19 bài liền mạch với hero (cùng style border-bottom dashed) */
	.cn-cat-list { margin-top: 0 !important; }
	.cn-cat-item:first-child { padding-top: 8px !important; }
}
/* ============================================================
   Fix khoảng trắng trên chân trang (toàn site)
============================================================ */
.cn-footer { margin-top: 0 !important; }

main#primary,
main.cn-single,
main.cn-cat,
main.cn-home {
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

.cn-single,
.cn-cat,
.cn-home,
.cn-archive {
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

/* Để content vẫn có 1 chút thở trước footer */
.cn-single > .container:last-of-type,
.cn-cat > .container:last-of-type,
.cn-home > .container:last-of-type {
	padding-bottom: 32px !important;
}

@media (max-width: 767px) {
	.cn-single > .container:last-of-type,
	.cn-cat > .container:last-of-type,
	.cn-home > .container:last-of-type {
		padding-bottom: 20px !important;
	}
}
/* ============================================================
   Fix Category Sidebar bị thụt (PC only)
============================================================ */
@media (min-width: 1024px) {

	/* Reset cột sidebar về sát mép phải */
	.cn-cat-sidebar {
		margin: 0 !important;
		padding: 0 !important;
		width: 100% !important;
		display: block !important;
	}

	/* Reset card widget — về sát mép trái cột sidebar */
	.cn-cat-sidebar .cn-widget {
		margin: 0 0 18px 0 !important;
		padding: 18px !important;
		width: 100% !important;
		box-sizing: border-box;
	}

	/* Reset heading widget — bỏ padding/margin trái */
	.cn-cat-sidebar .cn-widget-heading,
	.cn-cat-sidebar .cn-widget h3 {
		margin: 0 0 12px 0 !important;
		padding: 0 !important;
		border-left: 0 !important;
	}

	/* Reset TẤT CẢ <ul> trong sidebar — bỏ indent default 40px của browser */
	.cn-cat-sidebar ul,
	.cn-cat-sidebar .cn-widget-popular-list,
	.cn-cat-sidebar .cn-widget-list {
		list-style: none !important;
		margin: 0 !important;
		padding: 0 !important;
	}

	/* Reset <li> + <a> bên trong */
	.cn-cat-sidebar ul li,
	.cn-cat-sidebar .cn-widget-popular-item,
	.cn-cat-sidebar .cn-widget-list li {
		margin-left: 0 !important;
		padding-left: 0 !important;
	}

	/* wp_list_categories tạo children — cho thụt nhẹ 14px nếu có sub-category */
	.cn-cat-sidebar .children {
		padding-left: 14px !important;
		margin-top: 6px !important;
		list-style: none;
	}

	/* Thu hẹp gap grid để sidebar gần main column hơn */
	.cn-cat-grid {
		grid-template-columns: 1fr 320px !important;
		gap: 24px !important;
	}
}
/* ============================================================
   Category — Hở lề trên (giữa menu bar và title)
============================================================ */
.cn-cat .container {
	padding-top: 20px !important;
}

@media (max-width: 767px) {
	.cn-cat .container {
		padding-top: 12px !important;
	}
}
/* ============================================================
   Tag — kế thừa từ .cn-cat, chỉ chỉnh icon #
============================================================ */
.cn-tag .cn-cat-title-icon {
	font-size: 24px;
	font-weight: 800;
	color: var(--cn-secondary, #c9a961);
	line-height: 1;
	margin-right: 2px;
}

@media (max-width: 767px) {
	.cn-tag .cn-cat-title-icon { font-size: 20px; }
}
/* ============================================================
   Search — bật excerpt + style empty form
============================================================ */

/* Mô tả luôn hiện trong item (cả PC + Mobile, override category) */
.cn-search .cn-cat-item-excerpt {
	display: -webkit-box !important;
	-webkit-line-clamp: 2 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
	margin: 0 0 6px !important;
	font-size: 13.5px !important;
	line-height: 1.5 !important;
	color: var(--cn-muted) !important;
}

/* Icon kính lúp */
.cn-search .cn-cat-title-icon {
	font-size: 20px;
	line-height: 1;
}

/* Tên chuyên mục nhỏ kế ngày (inline) */
.cn-search .cn-cat-item-cat a {
	color: var(--cn-primary) !important;
	text-decoration: none !important;
	font-weight: 500;
}
.cn-search .cn-cat-item-cat a:hover { text-decoration: underline !important; }

/* Empty state form */
.cn-search-form-empty {
	display: flex;
	gap: 8px;
	margin-top: 18px;
	max-width: 480px;
	margin-left: auto;
	margin-right: auto;
}
.cn-search-form-empty input[type="search"] {
	flex: 1;
	padding: 10px 14px;
	border: 1px solid var(--cn-border);
	border-radius: 8px;
	font-size: 14px;
	font-family: inherit;
}
.cn-search-form-empty input[type="search"]:focus {
	outline: none;
	border-color: var(--cn-primary);
}
.cn-search-form-empty button {
	padding: 10px 20px;
	background: var(--cn-primary);
	color: #fff;
	border: 0;
	border-radius: 8px;
	font-weight: 600;
	cursor: pointer;
	font-family: inherit;
}
.cn-search-form-empty button:hover {
	background: var(--cn-primary-900, #061a30);
}

/* Mobile — excerpt nhỏ hơn, không ẩn */
@media (max-width: 767px) {
	.cn-search .cn-cat-item-excerpt {
		font-size: 12.5px !important;
		-webkit-line-clamp: 2 !important;
	}
	.cn-search-form-empty {
		flex-direction: column;
	}
}
/* ===== Search — đồng bộ size date với category name ===== */
.cn-search .cn-cat-item-meta,
.cn-search .cn-cat-item-meta .cn-date,
.cn-search .cn-cat-item-meta .cn-cat-item-cat,
.cn-search .cn-cat-item-meta .cn-cat-item-cat a {
	font-size: 12px !important;
	font-weight: 400 !important;
	line-height: 1.4 !important;
}

@media (max-width: 767px) {
	.cn-search .cn-cat-item-meta,
	.cn-search .cn-cat-item-meta .cn-date,
	.cn-search .cn-cat-item-meta .cn-cat-item-cat,
	.cn-search .cn-cat-item-meta .cn-cat-item-cat a {
		font-size: 11px !important;
	}
}
/* ============================================================
   Global — Tất cả link hover/active → đỏ pastel
============================================================ */
a {
	transition: color 0.15s ease;
}

a:hover,
a:focus,
a:active,
a:hover *,
a:focus *,
a:active * {
	color: #f87171 !important;
}

/* Mobile/tablet — kích hoạt khi chạm (vì hover không có) */
@media (hover: none) {
	a:active,
	a:active * {
		color: #f87171 !important;
	}
}
/* ============================================================
   Force ALL iframes responsive (brute-force)
============================================================ */
iframe[src*="youtube"],
iframe[src*="youtu.be"],
iframe[src*="vimeo"],
iframe[src*="facebook"],
.cn-single iframe,
article iframe,
.entry-content iframe {
	width: 100% !important;
	max-width: 100% !important;
	height: auto !important;
	aspect-ratio: 16 / 9 !important;
	display: block !important;
	margin: 20px auto !important;
	border: 0 !important;
	border-radius: 10px !important;
}
/* ============================================================
   Video section — Play icon overlay (auto match via /category/video/)
============================================================ */
.cn-section:has(.cn-section-more[href*="/category/video"]) .cn-card-thumb,
.cn-section:has(.cn-section-title:is(:has(+ a[href*="/category/video"]))) .cn-card-thumb {
	position: relative;
	overflow: hidden;
}

.cn-section:has(.cn-section-more[href*="/category/video"]) .cn-card-thumb::after {
	content: "▶";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 52px;
	height: 52px;
	background: rgba(0, 0, 0, 0.65);
	color: #fff;
	font-size: 20px;
	line-height: 52px;
	text-align: center;
	padding-left: 3px;
	box-sizing: border-box;
	border-radius: 50%;
	transition: all 0.2s ease;
	pointer-events: none;
	z-index: 2;
}

.cn-section:has(.cn-section-more[href*="/category/video"]) .cn-card-thumb:hover::after {
	background: rgba(239, 68, 68, 0.92);
	width: 60px;
	height: 60px;
	line-height: 60px;
	font-size: 24px;
}

@media (max-width: 767px) {
	.cn-section:has(.cn-section-more[href*="/category/video"]) .cn-card-thumb::after {
		width: 42px;
		height: 42px;
		font-size: 16px;
		line-height: 42px;
	}
}
/* PC — Cột trái (5 bài) lấn sang cột phải (Tin đọc nhiều) */
@media (min-width: 1024px) {
	/* Universal selector — target parent có .cn-row-left */
	*:has(> .cn-row-left) {
		grid-template-columns: 2.4fr 1fr !important;
	}
}
/* ============================================================
   PC — Ép 2 khối "Tin mới nhất" và "Tin đọc nhiều" cao bằng nhau
============================================================ */
@media (min-width: 1024px) {
	/* Parent grid: stretch cả 2 cột */
	*:has(> .cn-row-left) {
		align-items: stretch !important;
	}

	/* 2 cột: full chiều cao + flex column */
	.cn-row-left,
	.cn-row-right {
		height: 100% !important;
		display: flex !important;
		flex-direction: column !important;
	}

	/* Bọc 4 bài nhỏ — giãn đều dọc */
	.cn-hero-side {
		flex: 1 !important;
		display: flex !important;
		flex-direction: column !important;
		justify-content: space-between !important;
		gap: 10px !important;
	}

	/* List Tin đọc nhiều — giãn đều dọc */
	.cn-row-right > ul,
	.cn-row-right .cn-popular-list,
	.cn-row-right .cn-cb-list,
	.cn-row-right .cn-section > ul {
		flex: 1 !important;
		display: flex !important;
		flex-direction: column !important;
		justify-content: space-between !important;
		gap: 0 !important;
	}

	/* Đảm bảo các item bên trong không bị stretch méo (giữ chiều cao tự nhiên) */
	.cn-hero-side > .cn-hero-item,
	.cn-row-right > ul > li,
	.cn-row-right .cn-popular-list > li,
	.cn-row-right .cn-cb-list > li {
		flex-shrink: 0;
	}
}
/* ============================================================
   Home PC — Zoom thumb on hover (Tin mới + Tin đọc nhiều)
============================================================ */
@media (min-width: 1024px) {
	/* Transition mượt cho tất cả thumb img trong 2 khối */
	.cn-row-left .cn-hero-thumb img,
	.cn-row-right img {
		transition: transform 0.45s cubic-bezier(0.2, 0.6, 0.2, 1);
		will-change: transform;
		display: block;
	}

	/* Đảm bảo container có overflow hidden để zoom không tràn */
	.cn-row-left .cn-hero-thumb,
	.cn-row-left .cn-hero-thumb-link,
	.cn-row-right .cn-card-thumb,
	.cn-row-right .cn-cb-row-thumb,
	.cn-row-right .cn-popular-thumb,
	.cn-row-right a[href] img {
		overflow: hidden;
	}

	/* Zoom khi hover thumb hoặc link cha */
	.cn-row-left .cn-hero-thumb:hover img,
	.cn-row-left .cn-hero-thumb-link:hover img,
	.cn-row-left .cn-hero-item:hover .cn-hero-thumb img,
	.cn-row-right .cn-card-thumb:hover img,
	.cn-row-right .cn-cb-row-thumb:hover img,
	.cn-row-right .cn-popular-thumb:hover img,
	.cn-row-right li:hover img,
	.cn-row-right article:hover img {
		transform: scale(1.08);
	}
}
/* Mobile — Phân trang trang /tin-moi/ cách footer 1 khoảng thoáng */
@media (max-width: 767px) {
	.cn-tinmoi .cn-pagination,
	.page-template-tinmoi .cn-pagination,
	.cn-tinmoi-pagination,
	.cn-pagination {
		margin-bottom: 32px !important;
		padding-bottom: 8px !important;
	}
}
@media (min-width: 1024px) {
	.cn-row-grid {
		align-items: stretch;
	}
	.cn-row-left,
	.cn-row-right {
		display: flex;
		flex-direction: column;
	}
	.cn-row-left .cn-hero-grid,
	.cn-row-right .cn-popular-list {
		flex: 1;
	}
	.cn-hero-side {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		height: 100%;
	}
	.cn-popular-list {
		display: flex;
		flex-direction: column;
		justify-content: space-between;
		height: 100%;
	}
}
/* ============================================================
   Home — Row head với title + link "Xem thêm" (PC only)
============================================================ */
@media (min-width: 1024px) {
	.cn-row-head {
		display: flex !important;
		align-items: center;
		justify-content: space-between;
		gap: 12px;
		margin-bottom: 14px;
	}
	.cn-row-more {
		font-size: 13.5px;
		font-weight: 600;
		color: var(--cn-primary, #0a2540);
		text-decoration: none !important;
		white-space: nowrap;
		padding: 4px 10px;
		border-radius: 6px;
		transition: all 0.15s ease;
	}
	.cn-row-more:hover {
		color: #fff !important;
		background: #f87171;
	}
}

/* Ẩn link "Xem thêm" trên mobile/tablet */
@media (max-width: 1023px) {
	.cn-row-more {
		display: none !important;
	}
}
/* ============================================================
   Video — Play icon "ảo" (frosted glass + gradient overlay)
============================================================ */
.cn-cb-video .cn-card-thumb {
	position: relative;
	overflow: hidden;
}

/* Lớp gradient phủ nhẹ phía dưới thumb */
.cn-cb-video .cn-card-thumb::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(180deg, rgba(0,0,0,0) 40%, rgba(0,0,0,0.4) 100%);
	z-index: 1;
	transition: background 0.3s ease;
	pointer-events: none;
}

/* Nút play tròn frosted glass giữa thumb */
.cn-cb-video .cn-card-thumb::after {
	content: "▶";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) scale(1);
	width: 56px;
	height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(255, 255, 255, 0.92);
	color: #1a1a1a;
	font-size: 18px;
	padding-left: 4px; /* nudge mũi tên cho cân giữa */
	border-radius: 50%;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.35);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	z-index: 2;
	transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
	pointer-events: none;
}

/* Hover: nút đỏ + zoom 1.1x + overlay đậm hơn */
.cn-cb-video .cn-card:hover .cn-card-thumb::before {
	background: linear-gradient(180deg, rgba(0,0,0,0.15) 0%, rgba(0,0,0,0.6) 100%);
}
.cn-cb-video .cn-card:hover .cn-card-thumb::after {
	background: #ef4444;
	color: #fff;
	transform: translate(-50%, -50%) scale(1.1);
	box-shadow: 0 6px 22px rgba(239, 68, 68, 0.55);
}

/* Mobile: nút nhỏ hơn */
@media (max-width: 767px) {
	.cn-cb-video .cn-card-thumb::after {
		width: 44px;
		height: 44px;
		font-size: 14px;
		padding-left: 3px;
	}
}
/* ===== VIDEO GRID 3 CỘT (PC) ===== */
.cn-grid-3{
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}

/* Tablet: 2 cột */
@media (max-width: 991px){
	.cn-grid-3{
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

/* Mobile: 1 cột */
@media (max-width: 575px){
	.cn-grid-3{
		grid-template-columns: 1fr;
	}
}
/* Row VIDEO + LỊCH (2/3 - 1/3) */
.cn-vcal-row{
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 16px;
	align-items: start;
}

/* VIDEO grid 3 cột */
.cn-grid-3{
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 14px;
}

/* Card bên phải */
.cn-side-card{
	background: #0b1220;          /* nếu theme bạn nền dark */
	border: 1px solid rgba(148,163,184,.18);
	border-radius: 12px;
	overflow: hidden;
}
.cn-side-card + .cn-side-card{ margin-top: 14px; }

.cn-side-card-head{
	padding: 12px 14px;
	border-bottom: 1px solid rgba(148,163,184,.18);
}
.cn-side-card-title{ margin: 0; font-size: 16px; }

.cn-side-card-body{ padding: 12px 14px; }

/* Responsive */
@media (max-width: 991px){
	.cn-vcal-row{ grid-template-columns: 1fr; }
	.cn-grid-3{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 575px){
	.cn-grid-3{ grid-template-columns: 1fr; }
}
/* ===== LỊCH PHỤNG VỤ card ===== */
.tcg-lpv{ font-family: inherit; }
.tcg-lpv-head{
	display:flex; align-items:center; justify-content:space-between;
	padding:10px 0 8px;
	border-bottom:1px solid rgba(148,163,184,.18);
}
.tcg-lpv-title{ font-weight:800; text-transform:uppercase; color:#22c55e; }
.tcg-lpv-nav button{
	width:32px;height:32px;border-radius:999px;
	border:1px solid rgba(148,163,184,.18);
	background:transparent;color:inherit; cursor:pointer;
}
.tcg-lpv-month{ padding:10px 0; font-weight:700; color:#22c55e; }

.tcg-lpv-week{
	display:grid; grid-template-columns:repeat(7,1fr);
	gap:6px; font-size:12px; opacity:.85;
}
.tcg-lpv-week > div{ text-align:center; padding:6px 0; }

.tcg-lpv-grid{
	display:grid; grid-template-columns:repeat(7,1fr);
	gap:6px; padding-top:8px;
}
.tcg-lpv-cell{
	height:34px; border-radius:10px;
	display:flex; align-items:center; justify-content:center;
	border:1px solid rgba(148,163,184,.18);
	background:transparent; color:inherit;
}
.tcg-lpv-cell.is-empty{ border:none; background:transparent; }
.tcg-lpv-day{ cursor:pointer; }
.tcg-lpv-day.has-data{ border-color: rgba(34,197,94,.35); }
.tcg-lpv-day.is-today{ background: rgba(34,197,94,.18); border-color: rgba(34,197,94,.55); }

/* ===== Modal ===== */
.tcg-lpv-modal[hidden]{ display:none; }
.tcg-lpv-modal{ position:fixed; inset:0; z-index:9999; }
.tcg-lpv-modal-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.55); }
.tcg-lpv-modal-card{
	position:relative;
	max-width:560px; width:calc(100% - 24px);
	margin:60px auto 0;
	background:#0b1220;
	border:1px solid rgba(148,163,184,.18);
	border-radius:14px;
	overflow:hidden;
}
.tcg-lpv-modal-head{
	display:flex; justify-content:space-between; align-items:center;
	padding:12px 14px;
	border-bottom:1px solid rgba(148,163,184,.18);
}
.tcg-lpv-modal-title{ font-weight:800; }
.tcg-lpv-modal-close{
	border:1px solid rgba(148,163,184,.18);
	background:transparent; color:inherit;
	border-radius:10px; padding:6px 10px; cursor:pointer;
}
.tcg-lpv-modal-body{ padding:12px 14px; }
.tcg-lpv-field{ margin:10px 0; line-height:1.5; }
.tcg-lpv-empty{ margin-top:12px; color:#fca5a5; font-weight:700; }
/* Ép card bên phải về nền trắng */
.cn-side-card{
	background:#fff !important;
	color:#0f172a !important;
	border:1px solid #e5e7eb !important;
}

/* đường kẻ header */
.cn-side-card-head{
	border-bottom:1px solid #e5e7eb !important;
}

/* tiêu đề */
.cn-side-card-title{
	color:#0f172a !important;
}
.cn-side-card-body{
	display: block;
}
.cn-side-card-body iframe{
	width: 100% !important;
}
/* FB Page Plugin: luôn full width trong card */
.cn-side-card-body .fb-page,
.cn-side-card-body .fb-page span,
.cn-side-card-body .fb-page iframe{
	width: 100% !important;
	max-width: 100% !important;
	display: block !important;
}
.cn-side-card-body .fb-page,
.cn-side-card-body .fb-page > span,
.cn-side-card-body .fb-page iframe{
	height: 320px !important;
}
/* ===== FIX POPUP LỊCH PHỤNG VỤ: NỀN TRẮNG + GIỮA MÀN HÌNH ===== */

/* backdrop giữ tối nhẹ cho nổi popup */
.tcg-lpv-modal-backdrop{
	background: rgba(0,0,0,.45) !important;
}

/* đưa card ra giữa màn hình */
.tcg-lpv-modal-card{
	position: fixed !important;
	top: 50% !important;
	left: 50% !important;
	transform: translate(-50%, -50%) !important;

	margin: 0 !important;              /* bỏ margin cũ 60px */
	max-width: 560px;
	width: calc(100% - 24px);

	background: #fff !important;       /* nền trắng */
	color: #0f172a !important;         /* chữ tối */
	border: 1px solid #e5e7eb !important;
	border-radius: 14px;
	overflow: hidden;
}

/* header popup */
.tcg-lpv-modal-head{
	border-bottom: 1px solid #e5e7eb !important;
}

/* nút đóng */
.tcg-lpv-modal-close{
	border: 1px solid #e5e7eb !important;
	background: #fff !important;
	color: #0f172a !important;
}

/* text trong body */
.tcg-lpv-modal-body{
	color: #0f172a !important;
}

/* dòng "Dữ liệu chưa có" */
.tcg-lpv-empty{
	color: #dc2626 !important;
}
/* ===== LỊCH: header kiểu cn-cb + dòng tháng cùng hàng nút ===== */
.tcg-lpv-top{ margin-bottom: 10px; }

/* Dòng tháng + nav */
.tcg-lpv-month-row{
	display:flex;
	align-items:center;
	justify-content:space-between;
	gap: 10px;
	padding: 8px 0 10px;
	border-bottom: 1px solid #e5e7eb;
}

.tcg-lpv-month{
	padding: 0;                /* bỏ padding cũ */
	margin: 0;
	font-weight: 800;
	color: #0f172a;
}

.tcg-lpv-nav{
	display:flex;
	gap: 6px;
	flex-shrink: 0;
}

.tcg-lpv-nav button{
	width: 32px;
	height: 32px;
	border-radius: 999px;
	border: 1px solid #e5e7eb;
	background: #fff;
	color: #0f172a;
	cursor: pointer;
}

/* Nếu bạn đang có CSS cũ cho .tcg-lpv-head thì có thể bỏ luôn */
.tcg-lpv-head{ display:none; }
.cn-fb-wrap{
	width: 100%;
}

/* ép Facebook plugin ăn full width */
.cn-fb-wrap .fb-page,
.cn-fb-wrap .fb-page > span,
.cn-fb-wrap .fb-page iframe{
	width: 100% !important;
	max-width: 100% !important;
	display: block !important;
}
.cn-side-card-body{ padding: 12px 14px; } /* nếu bạn đang để padding khác */
.cn-side-card-body .cn-fb-wrap{ margin: 0; }
/* Row 2 cột: luôn stretch cho 2 bên bằng chiều cao nhau */
.cn-vcal-row{
	align-items: stretch; /* quan trọng */
}

/* Mỗi cột cũng stretch */
.cn-vcal-left,
.cn-vcal-right{
	display: flex;
}

/* Box trong mỗi cột cao bằng cột */
.cn-vcal-left > .cn-cb,
.cn-vcal-right > .cn-cb{
	width: 100%;
	height: 100%;
	display: flex;
	flex-direction: column;
}

/* Phần body trong box tự giãn để lấp chiều cao còn lại */
.cn-vcal-left > .cn-cb .cn-grid-3,
.cn-vcal-right > .cn-cb .cn-side-card-body{
	flex: 1;
}
/* Tin-moi / cn-cat: ẩn sidebar trên mobile để không tạo khoảng hở */
@media (max-width: 767px){
	.cn-cat-sidebar{
		display: none !important;
	}
	.cn-cat-grid{
		gap: 0 !important; /* optional: bỏ khoảng cách giữa main và (sidebar đã ẩn) */
	}
}
/* Tin-moi (template cn-cat): ẩn sidebar trên tablet + mobile để khỏi tạo khoảng trắng */
@media (max-width: 1023px){
	.cn-cat-sidebar{
		display: none !important;
	}
	.cn-cat-grid{
		grid-template-columns: 1fr !important;
		gap: 0 !important;
	}
}
@media (max-width: 1023px){
	.cn-footer{ margin-top: 16px !important; }
}
@media (max-width: 1023px){
	/* bỏ khoảng hở trắng quanh phân trang */
	.cn-pagination{
		margin: 12px 0 0 !important;
		padding: 0 !important;
	}
	.cn-pagination .cn-page-item{
		margin: 0 !important;
		padding: 0 !important;
	}
	.cn-pagination .page-numbers{
		margin: 0 !important;
		padding: 0 !important;
		gap: 6px;
	}
}
.cn-more-pager{
	display:flex;
	justify-content:center;
	gap: 10px;
	flex-wrap: wrap;
}
/* ============================================================
   Category page — Hover tiêu đề đỏ pastel #8b1a1a (PC + mobile)
============================================================ */

/* Hero bài đầu */
.cn-cat-hero-title a:hover,
.cn-cat-hero-title a:focus {
	color: #ef4444 !important;
}

/* 19 bài chuyên mục */
.cn-cat-item-title a:hover,
.cn-cat-item-title a:focus {
	color: #ef4444 !important;
}

/* Sidebar — Tin nổi bật */
.cn-widget-popular-title:hover,
.cn-widget-popular-title:focus {
	color: #ef4444 !important;
}

/* Sidebar — Chuyên mục (từ wp_list_categories) */
.cn-widget-cats .cn-widget-list a:hover,
.cn-widget-cats .cn-widget-list a:focus {
	color: #ef4444 !important;
}
/* ============================================================
   Mobile — BÀI VIẾT MỚI: thumb rộng hơn (16:9 cn-thumb)
   Áp dụng cho cả trang chủ (.cn-m-item) và /tin-moi/ (.cn-cat-item)
============================================================ */
@media (max-width: 1023px) {

	.cn-m-item,
	.cn-cat-item {
		grid-template-columns: 150px 1fr !important;
		gap: 12px;
	}

	.cn-m-item-thumb,
	.cn-cat-item-thumb {
		width: 150px !important;
		aspect-ratio: 16 / 9;
		height: auto !important;
		flex-shrink: 0;
	}

	.cn-m-item-thumb img,
	.cn-cat-item-thumb img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover;
		display: block;
	}
}
/* ============================================================
   Mobile — Unify bài 1 hero + mini items: cùng compact layout
   Áp dụng: home (.cn-m-item), /tin-moi/, /chuyên-mục/, /tag/
============================================================ */
@media (max-width: 1023px) {

	/* Container: tất cả items dùng grid 2 cột giống nhau */
	.cn-m-item,
	.cn-cat-item,
	.cn-cat-hero {
		display: grid !important;
		grid-template-columns: 150px 1fr !important;
		gap: 12px !important;
		margin: 0 0 12px !important;
		padding: 0 0 12px 0 !important;
		background: transparent !important;
		border: 0 !important;
		border-bottom: 1px solid #e2e5ec !important;
		border-radius: 0 !important;
		box-shadow: none !important;
		align-items: start !important;
	}

	/* Thumb: cùng size, cùng aspect ratio */
	.cn-m-item-thumb,
	.cn-cat-item-thumb,
	.cn-cat-hero-thumb {
		width: 150px !important;
		aspect-ratio: 16 / 9 !important;
		height: auto !important;
		margin: 0 !important;
		padding: 0 !important;
		border-radius: 6px !important;
		overflow: hidden !important;
		flex-shrink: 0;
	}

	.cn-m-item-thumb img,
	.cn-cat-item-thumb img,
	.cn-cat-hero-thumb img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		display: block !important;
	}

	/* Body: padding 0, content flush left */
	.cn-m-item-body,
	.cn-cat-item-body,
	.cn-cat-hero-body {
		padding: 0 !important;
		min-width: 0;
	}

	/* Title: cùng font, line-clamp 3 */
	.cn-m-item-title,
	.cn-cat-item-title,
	.cn-cat-hero-title {
		font-size: 14px !important;
		font-weight: 600 !important;
		line-height: 1.4 !important;
		margin: 0 0 6px !important;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	/* Ẩn excerpt (hero + item) trên mobile vì không đủ chỗ */
	.cn-cat-hero-excerpt,
	.cn-cat-item-excerpt {
		display: none !important;
	}
}
/* ============================================================
   Mobile — Bài viết liên quan: cùng compact layout
============================================================ */
@media (max-width: 1023px) {

	.cn-related-mlist {
		list-style: none !important;
		margin: 0 !important;
		padding: 0 !important;
		display: block !important;
	}

	.cn-related-mrow {
		display: grid !important;
		grid-template-columns: 150px 1fr !important;
		gap: 12px !important;
		margin: 0 0 12px !important;
		padding: 0 0 12px 0 !important;
		background: transparent !important;
		border: 0 !important;
		border-bottom: 1px solid #e2e5ec !important;
		border-radius: 0 !important;
		box-shadow: none !important;
		align-items: start !important;
		list-style: none !important;
	}

	.cn-related-mrow:last-child {
		border-bottom: 0 !important;
	}

	.cn-related-mthumb {
		display: block !important;
		width: 150px !important;
		aspect-ratio: 16 / 9 !important;
		height: auto !important;
		margin: 0 !important;
		padding: 0 !important;
		border-radius: 6px !important;
		overflow: hidden !important;
		flex-shrink: 0;
	}

	.cn-related-mthumb img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		display: block !important;
	}

	.cn-related-mthumb .cn-related-placeholder {
		width: 100% !important;
		height: 100% !important;
		display: flex !important;
		align-items: center;
		justify-content: center;
		background: #f1f5f9;
		color: #94a3b8;
		font-size: 24px;
	}

	.cn-related-mbody {
		padding: 0 !important;
		min-width: 0;
	}

	.cn-related-mtitle {
		font-size: 14px !important;
		font-weight: 600 !important;
		line-height: 1.4 !important;
		margin: 0 0 6px !important;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.cn-related-mtitle a {
		color: inherit;
		text-decoration: none;
	}

	.cn-related-mtitle a:hover,
	.cn-related-mtitle a:focus {
		color: #ef4444 !important;
	}

	.cn-related-mmeta {
		font-size: 12px !important;
		color: #94a3b8 !important;
		line-height: 1.4 !important;
	}
}
/* ============================================================
   Mobile — Bài #1 (feature) trang chủ: full-width thumb stacked
   Áp dụng: front-page.php — chỉ trang chủ
============================================================ */
@media (max-width: 1023px) {

	.cn-m-feature {
		display: block !important;
		margin: 0 0 16px !important;
		padding: 0 0 16px 0 !important;
		border-bottom: 1px solid #e2e5ec !important;
		background: transparent !important;
		box-shadow: none !important;
		border-radius: 0 !important;
	}

	.cn-m-feature-thumb-link {
		display: block !important;
		width: 100% !important;
		margin: 0 0 10px !important;
	}

	.cn-m-feature-thumb {
		width: 100% !important;
		max-width: 100% !important;
		aspect-ratio: 16 / 9 !important;
		height: auto !important;
		margin: 0 !important;
		padding: 0 !important;
		border-radius: 8px !important;
		overflow: hidden !important;
		display: block !important;
	}

	.cn-m-feature-thumb img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		display: block !important;
	}

	.cn-m-thumb-placeholder {
		width: 100% !important;
		height: 100% !important;
		display: flex !important;
		align-items: center;
		justify-content: center;
		background: #f1f5f9;
		color: #94a3b8;
		font-size: 32px;
	}

	.cn-m-feature-body {
		padding: 0 !important;
	}

	.cn-m-feature-title {
		font-size: 18px !important;
		font-weight: 700 !important;
		line-height: 1.35 !important;
		margin: 0 0 8px !important;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.cn-m-feature-title a {
		color: inherit;
		text-decoration: none;
	}

	.cn-m-feature-title a:hover,
	.cn-m-feature-title a:focus {
		color: #ef4444 !important;
	}

	.cn-m-feature-excerpt {
		font-size: 13px !important;
		color: #475569 !important;
		line-height: 1.5 !important;
		margin: 0 0 8px !important;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.cn-m-feature-meta {
		font-size: 12px !important;
		color: #94a3b8 !important;
		display: flex;
		align-items: center;
		gap: 6px;
		flex-wrap: wrap;
	}

	.cn-m-cat {
		display: inline-flex;
		align-items: center;
		gap: 4px;
		color: #1e3a8a !important;
		text-decoration: none;
		font-weight: 600;
	}

	.cn-m-cat:hover {
		color: #ef4444 !important;
	}

	.cn-m-sep {
		color: #cbd5e1;
	}
}
@media (max-width: 1023px) {

	.cn-m-feature {
		display: block !important;
		margin: 0 0 16px !important;
		padding: 0 !important;
		background: #fff !important;
		border: 1px solid #e2e5ec !important;
		border-radius: 12px !important;
		overflow: hidden !important;
		box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04) !important;
	}

	.cn-m-feature-thumb-link {
		display: block !important;
		width: 100% !important;
		margin: 0 !important;
	}

	.cn-m-feature-thumb {
		width: 100% !important;
		max-width: 100% !important;
		aspect-ratio: 16 / 9 !important;
		height: auto !important;
		margin: 0 !important;
		padding: 0 !important;
		border-radius: 0 !important;
		overflow: hidden !important;
		display: block !important;
	}

	.cn-m-feature-thumb img {
		width: 100% !important;
		height: 100% !important;
		object-fit: cover !important;
		display: block !important;
	}

	.cn-m-thumb-placeholder {
		width: 100% !important;
		height: 100% !important;
		display: flex !important;
		align-items: center;
		justify-content: center;
		background: #f1f5f9;
		color: #94a3b8;
		font-size: 32px;
	}

	.cn-m-feature-body {
		padding: 14px 14px 14px !important;
	}

	.cn-m-feature-title {
		font-size: 17px !important;
		font-weight: 700 !important;
		line-height: 1.35 !important;
		margin: 0 0 8px !important;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.cn-m-feature-title a {
		color: inherit;
		text-decoration: none;
	}

	.cn-m-feature-title a:hover,
	.cn-m-feature-title a:focus {
		color: #8b1a1a !important;
	}

	.cn-m-feature-excerpt {
		font-size: 13px !important;
		color: #475569 !important;
		line-height: 1.5 !important;
		margin: 0 0 10px !important;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.cn-m-feature-meta {
		font-size: 12px !important;
		color: #94a3b8 !important;
		display: flex;
		align-items: center;
		gap: 6px;
		flex-wrap: wrap;
		margin: 0 !important;
	}

	.cn-m-cat {
		display: inline-flex;
		align-items: center;
		gap: 4px;
		color: #1e3a8a !important;
		text-decoration: none;
		font-weight: 600;
	}

	.cn-m-cat:hover {
		color: #8b1a1a !important;
	}

	.cn-m-sep {
		color: #cbd5e1;
	}
}
/* Vatican Media Live embed */
.cn-vatican-live {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 9;
	background: #000;
	border-radius: 8px;
	overflow: hidden;
}
.cn-vatican-live iframe {
	position: absolute;
	margin: 0px 0 12px 0 !important;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
	display: block;
}
/* Vatican Live description */
.cn-vatican-desc {
	margin: 0px 0 12px 0 !important;
	padding: 0 !important;
	font-size: 13px;
	line-height: 1.55;
	color: #475569;
	text-align: justify;
}
/* Vatican Live (RIGHT only): thu nhỏ padding card outer */
.cn-vcal-right .cn-cb {
	padding: 8px !important;
}

.cn-vcal-right .cn-cb .cn-cb-head {
	margin: -8px -8px 12px !important;
	padding: 0 8px 0 0 !important;
}

.cn-vcal-right .cn-side-card-body {
	padding: 0 !important;
}

.cn-vcal-right .cn-vatican-desc {
	margin: 8px 0 12px 0 !important;
	font-size: 13px;
	line-height: 1.55;
	color: #475569;
	text-align: justify;
}
/* Block Đức Giáo Hoàng: excerpt + date pin đáy */
.cn-vcal-left .cn-cb-pope .cn-grid-3 {
	align-items: stretch;
}

.cn-vcal-left .cn-cb-pope .cn-card {
	display: flex;
	flex-direction: column;
	height: 100%;
}

.cn-vcal-left .cn-cb-pope .cn-card-body {
	display: flex;
	flex-direction: column;
	flex: 1;
	padding: 12px 4px 4px;
}

.cn-vcal-left .cn-cb-pope .cn-card-title {
	font-size: 15px;
	font-weight: 700;
	line-height: 1.35;
	margin: 0 0 8px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cn-vcal-left .cn-cb-pope .cn-card-excerpt {
	font-size: 13px;
	color: #475569;
	line-height: 1.5;
	margin: 0 0 12px;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cn-vcal-left .cn-cb-pope .cn-card .cn-date {
	margin-top: auto !important;
	font-size: 12px;
	color: #94a3b8;
	display: block;
}
.cn-vcal-left .cn-cb-pope .cn-card-body {
	padding: 8px 8px 8px 8px !important;
	/* top: 12px gap với thumb
	   left/right: 12px lề text
	   bottom: 12px lề dưới date */
}

/* Block Đức Giáo Hoàng: 3 cột ngang, KHÔNG card viền */
.cn-vcal-left .cn-cb-pope .cn-grid-3 {
	align-items: stretch;
}

.cn-vcal-left .cn-cb-pope .cn-card {
	display: flex;
	flex-direction: column;
	height: 100%;
	/* Reset hết card style */
	background: transparent !important;
	border: 0 !important;
	border-radius: 0 !important;
	box-shadow: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.cn-vcal-left .cn-cb-pope .cn-card-thumb {
	display: block;
	border-radius: 6px;
	overflow: hidden;
}

.cn-vcal-left .cn-cb-pope .cn-card-thumb img {
	width: 100%;
	height: auto;
	display: block;
	border-radius: 6px;
}

.cn-vcal-left .cn-cb-pope .cn-card-title {
	font-size: 15px;
	font-weight: 700;
	line-height: 1.35;
	margin: 6px 0 6px;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cn-vcal-left .cn-cb-pope .cn-card-excerpt {
	font-size: 13px;
	color: #475569;
	line-height: 1.5;
	margin: 0 0 6px;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.cn-vcal-left .cn-cb-pope .cn-card .cn-date {
	margin-top: auto !important;
	margin-bottom: 0 !important;
	font-size: 12px;
	color: #94a3b8;
	display: block;
}
/* Floating tooltip theo chuột — full màn ngang, vượt khỏi mọi card */
.cn-tooltip-floating {
	position: fixed;
	background: #1a1a1a;
	color: #fff;
	padding: 10px 16px;
	font-size: 14px;
	font-weight: 500;
	line-height: 1.4;
	border-radius: 6px;
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
	max-width: 90vw;
	white-space: nowrap;
	z-index: 99999;
	pointer-events: none;
	opacity: 0;
	transform: translateY(-50%);
	transition: opacity 0.15s ease;
}
.cn-tooltip-floating.visible {
	opacity: 1;
}
/* TIN NỔI BẬT (sidebar PC) — thumb trái wider, body phải
   Áp dụng: category.php, single.php, tag.php */
.cn-widget-popular-item {
	display: grid !important;
	grid-template-columns: 140px 1fr !important;
	gap: 12px !important;
	margin: 0 0 16px !important;
	padding: 0 0 16px !important;
	border-bottom: 1px solid #e2e5ec !important;
	align-items: start !important;
}

.cn-widget-popular-item:last-child {
	border-bottom: 0 !important;
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

.cn-widget-popular-thumb {
	display: block !important;
	width: 140px !important;
	max-width: 140px !important;
	aspect-ratio: 16 / 9 !important;
	height: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	border-radius: 6px !important;
	overflow: hidden !important;
	flex-shrink: 0;
}

.cn-widget-popular-thumb img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
}

.cn-widget-popular-body {
	padding: 0 !important;
	min-width: 0;
}

.cn-widget-popular-title {
	display: block !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	line-height: 1.4 !important;
	color: #1a1a1a !important;
	text-decoration: none !important;
	margin: 0 0 6px !important;
	display: -webkit-box !important;
	-webkit-line-clamp: 3 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
}

.cn-widget-popular-title:hover,
.cn-widget-popular-title:focus {
	color: #ef4444 !important;
}

.cn-widget-popular-meta {
	font-size: 12px !important;
	color: #94a3b8 !important;
}
/* TIN ĐỌC NHIỀU (home Row 1) — thumb trái wider, body phải */
.cn-popular-item {
	display: grid !important;
	grid-template-columns: 140px 1fr !important;
	gap: 12px !important;
	margin: 6px 6px 6px 6px !important;
	padding: 6px 6px 6px 6px !important;
	border-bottom: 1px solid #e2e5ec !important;
	align-items: start !important;
	list-style: none !important;
}

.cn-popular-item:last-child {
	border-bottom: 0 !important;
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

.cn-popular-thumb {
	display: block !important;
	width: 140px !important;
	max-width: 140px !important;
	aspect-ratio: 16 / 9 !important;
	height: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	border-radius: 6px !important;
	overflow: hidden !important;
	flex-shrink: 0;
}

.cn-popular-thumb img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
}

.cn-popular-body {
	padding: 0 !important;
	min-width: 0;
}

.cn-popular-title {
	display: -webkit-box !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	line-height: 1.4 !important;
	color: #1a1a1a !important;
	text-decoration: none !important;
	margin: 0 0 6px !important;
	-webkit-line-clamp: 3 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
}

.cn-popular-title:hover,
.cn-popular-title:focus {
	color: #8b1a1a !important;
}

.cn-popular-meta,
.cn-popular-date {
	font-size: 12px !important;
	color: #94a3b8 !important;
}
/* Cho list cách heading 1 chút */
.cn-popular-list {
	margin-top: 12px !important;
	padding-top: 0 !important;
	list-style: none !important;
}
/* TIN MỚI NHẤT - 4 bài nhỏ (home Row 1 left, PC): mỗi bài 1 card */
.cn-hero-side {
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
	margin-top: 12px !important;
}

.cn-hero-item.is-small {
	display: grid !important;
	grid-template-columns: 140px 1fr !important;
	gap: 12px !important;
	margin: 0 !important;
	padding: 10px !important;
	background: #fff !important;
	border: 1px solid #e2e5ec !important;
	border-radius: 10px !important;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04) !important;
	align-items: center !important;
	transition: box-shadow 0.2s ease, transform 0.2s ease;
}

.cn-hero-item.is-small:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important;
}

.cn-hero-item.is-small .cn-hero-thumb-link {
	display: block !important;
	width: 140px !important;
	max-width: 140px !important;
	margin: 0 !important;
	padding: 0 !important;
	flex-shrink: 0;
}

.cn-hero-item.is-small .cn-hero-thumb {
	width: 140px !important;
	max-width: 140px !important;
	aspect-ratio: 16 / 9 !important;
	height: auto !important;
	margin: 0 !important;
	padding: 0 !important;
	border-radius: 6px !important;
	overflow: hidden !important;
}

.cn-hero-item.is-small .cn-hero-thumb img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
}

.cn-hero-item.is-small .cn-card-placeholder.sm {
	width: 100% !important;
	height: 100% !important;
	display: flex !important;
	align-items: center;
	justify-content: center;
	background: #f1f5f9;
	color: #94a3b8;
	font-size: 24px;
}

.cn-hero-item.is-small .cn-hero-body {
	padding: 0 !important;
	min-width: 0;
}

.cn-hero-item.is-small .cn-hero-title.sm {
	display: block !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	line-height: 1.4 !important;
	margin: 0 !important;
	padding: 0 !important;
	-webkit-line-clamp: unset !important;
	overflow: visible !important;
}

.cn-hero-item.is-small .cn-hero-title.sm a {
	color: #1a1a1a !important;
	text-decoration: none !important;
	transition: color 0.2s ease;
}

.cn-hero-item.is-small .cn-hero-title.sm a:hover,
.cn-hero-item.is-small .cn-hero-title.sm a:focus {
	color: #ef4444 !important;
}
/* Row 1: Equal height columns
   Hero feature LEFT + 4 small MIDDLE + Popular RIGHT */

/* Cột chứa 4 bài nhỏ stretch full height */
.cn-row-left,
.cn-hero-grid {
	display: flex !important;
	align-items: stretch !important;
}

.cn-hero-grid {
	display: grid !important;
	grid-template-columns: 2fr 1fr !important;
	gap: 16px !important;
	align-items: stretch !important;
}

/* Feature card bên trái: full chiều cao cột */
.cn-hero-item.is-feature {
	display: flex !important;
	flex-direction: column !important;
	height: 100% !important;
}

/* Cột chứa 4 bài nhỏ */
.cn-hero-side {
	display: flex !important;
	flex-direction: column !important;
	gap: 12px !important;
	margin-top: 0 !important;
	height: 100% !important;
}

/* 4 bài nhỏ chia đều chiều cao cột */
.cn-hero-item.is-small {
	flex: 1 1 0 !important;
	min-height: 0 !important;
	display: grid !important;
	grid-template-columns: 100px 1fr !important;
	gap: 12px !important;
	margin: 0 !important;
	padding: 10px !important;
	background: #fff !important;
	border: 1px solid #e2e5ec !important;
	border-radius: 10px !important;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04) !important;
	align-items: center !important;
}

/* Thumb co theo chiều cao card (vẫn 16:9 nếu đủ chỗ) */
.cn-hero-item.is-small .cn-hero-thumb-link,
.cn-hero-item.is-small .cn-hero-thumb {
	width: 100px !important;       /* ← khớp với grid */
	max-width: 100px !important;
}

.cn-hero-item.is-small .cn-hero-thumb img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
}

/* Popular list bên phải: 5 bài chia đều chiều cao */
.cn-row-right {
	display: flex !important;
	flex-direction: column !important;
}

.cn-popular-list {
	display: flex !important;
	flex-direction: column !important;
	flex: 1 !important;
	gap: 0 !important;
	margin: 12px 0 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.cn-popular-item {
	flex: 1 1 0 !important;
	min-height: 0 !important;
}
/* Title clamp 3 dòng + font nhỏ vừa khớp thumb */
.cn-hero-item.is-small .cn-hero-title.sm {
	display: -webkit-box !important;
	font-size: 15px !important;
	line-height: 1.35 !important;
	-webkit-line-clamp: 3 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
	margin: 0 !important;
}

/* Body căn giữa theo cột trái (thumb + date) */
.cn-hero-item.is-small .cn-hero-body {
	align-self: center !important;
}

/* Align items center toàn card */
.cn-hero-item.is-small {
	align-items: center !important;
}
/* ============ TIN ĐỌC NHIỀU (home Row 1 right) ============ */

/* Fix lề trên: đảm bảo right column align top với left */
.cn-row-hero .cn-row-grid {
	align-items: start !important;
}

.cn-row-hero .cn-row-right {
	margin-top: 0 !important;
	padding-top: 0 !important;
}

.cn-row-hero .cn-row-right > .cn-row-head {
	margin: 0 0 12px !important;
	padding: 0 !important;
}

/* List 5 card */
.cn-popular-list {
	display: flex !important;
	flex-direction: column !important;
	gap: 10px !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

/* Item card */
.cn-popular-item {
	display: grid !important;
	grid-template-columns: 100px 1fr !important;
	gap: 12px !important;
	margin: 0 !important;
	padding: 10px !important;
	background: #fff !important;
	border: 1px solid #e2e5ec !important;
	border-radius: 10px !important;
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04) !important;
	align-items: center !important;
	overflow: visible !important;
	height: auto !important;
	min-height: 0 !important;
}

/* Thumb */
.cn-popular-item .cn-popular-thumb-link {
	display: block !important;
	width: 100px !important;
	max-width: 100px !important;
}

.cn-popular-item .cn-popular-thumb {
	position: relative !important;
	width: 100px !important;
	max-width: 100px !important;
	aspect-ratio: 16 / 9 !important;
	height: auto !important;
	border-radius: 6px !important;
	overflow: hidden !important;
	margin: 0 !important;
}

.cn-popular-item .cn-popular-thumb img {
	width: 100% !important;
	height: 100% !important;
	object-fit: cover !important;
	display: block !important;
}

/* Rank badge */
.cn-popular-item .cn-popular-rank {
	position: absolute !important;
	top: 4px !important;
	left: 4px !important;
	width: 20px;
	height: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.75);
	color: #fff;
	font-size: 11px;
	font-weight: 700;
	border-radius: 4px;
	line-height: 1;
}

/* Body */
.cn-popular-item .cn-popular-body {
	padding: 0 !important;
	min-width: 0;
	overflow: hidden;
}

/* Title clamp 2 dòng */
.cn-popular-item .cn-popular-title {
	margin: 0 0 6px !important;
	padding: 0 !important;
	font-size: 14px !important;
	font-weight: 600 !important;
	line-height: 1.4 !important;
}

.cn-popular-item .cn-popular-title a {
	display: -webkit-box !important;
	-webkit-line-clamp: 2 !important;
	-webkit-box-orient: vertical !important;
	overflow: hidden !important;
	color: #1a1a1a !important;
	text-decoration: none !important;
}

.cn-popular-item .cn-popular-title a:hover {
	color: #ef4444 !important;
}

/* Meta: cat | date — KHÔNG wrap, cat ellipsis nếu dài */
.cn-popular-item .cn-popular-meta {
	display: flex !important;
	align-items: center !important;
	gap: 6px !important;
	flex-wrap: nowrap !important;     /* ← KEY: chống vỡ card #5 */
	font-size: 12px !important;
	line-height: 1.3 !important;
	margin: 0 !important;
	padding: 0 !important;
	min-width: 0;
	overflow: hidden;
}

.cn-popular-item .cn-m-cat {
	flex: 0 1 auto !important;        /* ← shrink nếu hẹp */
	min-width: 0;
	color: #8b1a1a !important;
	text-decoration: none !important;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.cn-popular-item .cn-m-cat-text {
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
	display: inline-block;
	max-width: 100%;
	vertical-align: bottom;
}

.cn-popular-item .cn-m-sep {
	flex: 0 0 auto !important;
	color: #cbd5e1 !important;
}

.cn-popular-item .cn-m-date {
	flex: 0 0 auto !important;        /* ← date LUÔN hiện full */
	color: #94a3b8 !important;
	white-space: nowrap;
}
/* RESET stretch — card cao đúng theo content */
.cn-row-hero .cn-row-right {
	display: block !important;
	height: auto !important;
}

.cn-row-hero .cn-row-right > .cn-row-head {
	display: flex !important;
	align-items: center !important;
	margin: 0 0 12px !important;
	padding: 0 !important;
}

.cn-popular-list {
	display: flex !important;
	flex-direction: column !important;
	flex: 0 0 auto !important;
	height: auto !important;
	gap: 10px !important;
	justify-content: flex-start !important;
	align-items: stretch !important;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none !important;
}

.cn-popular-item {
	flex: 0 0 auto !important;
	height: auto !important;
	min-height: 0 !important;
	max-height: none !important;
}
/* ============ TIN MỚI template v4 — PC 3 cột × 5 hàng ============ */

/* Default (mobile ≤1023px): hiện .cn-tm-mobile, ẩn .cn-tm-pc */
.cn-tm-main .cn-tm-pc {
	display: none;
}

/* PC ≥1024px: ẩn mobile view, hiện PC grid */
@media (min-width: 1024px) {

	.cn-tm-main .cn-tm-mobile {
		display: none;
	}

	.cn-tm-main .cn-tm-pc {
		display: block;
	}

	/* Grid 3 cột */
	.cn-tm-main .cn-tm-grid {
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		gap: 20px;
		margin: 16px 0 24px;
	}

	/* Card đồng nhất */
	.cn-tm-main .cn-tm-grid .cn-card {
		display: flex;
		flex-direction: column;
		background: #fff;
		border: 1px solid #e2e5ec;
		border-radius: 10px;
		padding: 12px;
		box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
		transition: box-shadow 0.2s ease, transform 0.2s ease;
	}

	.cn-tm-main .cn-tm-grid .cn-card:hover {
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
	}

	/* Thumb 16:9 */
	.cn-tm-main .cn-tm-grid .cn-card-thumb {
		display: block;
		width: 100%;
		aspect-ratio: 16 / 9;
		border-radius: 6px;
		overflow: hidden;
		margin: 0 0 10px;
	}

	.cn-tm-main .cn-tm-grid .cn-card-thumb img {
		width: 100%;
		height: 100%;
		object-fit: cover;
		display: block;
		transition: transform 0.3s ease;
	}

	.cn-tm-main .cn-tm-grid .cn-card:hover .cn-card-thumb img {
		transform: scale(1.05);
	}

	/* Placeholder fallback */
	.cn-tm-main .cn-tm-grid .cn-card-placeholder {
		width: 100%;
		height: 100%;
		display: flex;
		align-items: center;
		justify-content: center;
		background: #f1f5f9;
		color: #94a3b8;
		font-size: 32px;
	}

	/* Title clamp 2 dòng */
	.cn-tm-main .cn-tm-grid .cn-card-title {
		font-size: 15px;
		font-weight: 700;
		line-height: 1.4;
		margin: 0 0 6px;
	}

	.cn-tm-main .cn-tm-grid .cn-card-title a {
		color: #1a1a1a;
		text-decoration: none;
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.cn-tm-main .cn-tm-grid .cn-card-title a:hover {
		color: #8b1a1a;
	}

	/* Excerpt clamp 3 dòng */
	.cn-tm-main .cn-tm-grid .cn-card-excerpt {
		font-size: 13px;
		color: #475569;
		line-height: 1.5;
		margin: 0 0 8px;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	/* Date đáy card */
	.cn-tm-main .cn-tm-grid .cn-date {
		font-size: 12px;
		color: #94a3b8;
		margin-top: auto;
	}
}
/* Meta block (cat | date) trong PC card */
@media (min-width: 1024px) {
	.cn-tm-main .cn-tm-grid .cn-card-meta {
		display: flex;
		align-items: center;
		gap: 6px;
		font-size: 12px;
		margin-top: auto;
		flex-wrap: nowrap;
		min-width: 0;
	}

	.cn-tm-main .cn-tm-grid .cn-card-meta .cn-m-cat {
		color: #8b1a1a;
		font-weight: 600;
		text-decoration: none;
		flex: 0 1 auto;
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}

	.cn-tm-main .cn-tm-grid .cn-card-meta .cn-m-cat:hover {
		text-decoration: underline;
	}

	.cn-tm-main .cn-tm-grid .cn-card-meta .cn-m-sep {
		color: #cbd5e1;
		flex: 0 0 auto;
	}

	.cn-tm-main .cn-tm-grid .cn-card-meta .cn-m-date {
		color: #94a3b8;
		flex: 0 0 auto;
		white-space: nowrap;
	}
}
/* ===== SEARCH: thumb 16:9 cho cả ảnh thực và placeholder ===== */
.cn-search .cn-cat-item-thumb {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: 6px;
    background: var(--cn-surface);
}
.cn-search .cn-cat-item-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.cn-search .cn-cat-item-thumb .cn-card-placeholder {
    width: 100%;
    height: 100%;
    min-height: 0;
    border-radius: 0;
    font-size: 48px;
}

/* Sidebar TIN NỔI BẬT trong search (giữ 16:9 đồng bộ) */
.cn-search .cn-widget-popular-thumb {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    overflow: hidden;
    border-radius: 6px;
    background: var(--cn-surface);
}
.cn-search .cn-widget-popular-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.cn-search .cn-widget-popular-thumb .cn-card-placeholder {
    width: 100%;
    height: 100%;
    min-height: 0;
    border-radius: 0;
    font-size: 32px;
}
/* ===== ĐỒNG BỘ THUMB 16:9 — Category + Tag + Search + Tin-moi ===== */
body.category .cn-cat-item,
body.tag .cn-cat-item,
body.search .cn-cat-item,
body.page-template-template-tinmoi .cn-cat-item {
    grid-template-columns: 200px 1fr !important;
    gap: 16px !important;
}

body.category .cn-cat-item-thumb,
body.tag .cn-cat-item-thumb,
body.search .cn-cat-item-thumb,
body.page-template-template-tinmoi .cn-cat-item-thumb {
    width: 200px !important;
    height: auto !important;
    aspect-ratio: 16 / 9 !important;
    border-radius: 8px;
    overflow: hidden;
    background: var(--cn-surface);
    display: block;
}

body.category .cn-cat-item-thumb img,
body.tag .cn-cat-item-thumb img,
body.search .cn-cat-item-thumb img,
body.page-template-template-tinmoi .cn-cat-item-thumb img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
    display: block;
}

body.category .cn-cat-item-thumb .cn-related-placeholder,
body.tag .cn-cat-item-thumb .cn-related-placeholder,
body.search .cn-cat-item-thumb .cn-related-placeholder,
body.page-template-template-tinmoi .cn-cat-item-thumb .cn-related-placeholder {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    font-size: 32px;
    border-radius: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--cn-primary) 0%, var(--cn-primary-900) 100%);
    color: rgba(201, 169, 97, 0.4);
}

body.category .cn-cat-item-title,
body.tag .cn-cat-item-title,
body.search .cn-cat-item-title,
body.page-template-template-tinmoi .cn-cat-item-title {
    font-size: 15.5px;
}
/* ===== HERO MOBILE FULL-WIDTH — Category + Tag + Tin-moi ===== */
@media (max-width: 1023px) {
    body.category .cn-cat-hero,
    body.tag .cn-cat-hero,
    body.page-template-template-tinmoi .cn-cat-hero {
        display: block !important;
        grid-template-columns: 1fr !important;
        width: 100% !important;
        margin: 0 0 20px !important;
        padding: 0 !important;
        gap: 0 !important;
    }
    body.category .cn-cat-hero-thumb,
    body.tag .cn-cat-hero-thumb,
    body.page-template-template-tinmoi .cn-cat-hero-thumb {
        display: block !important;
        width: 100% !important;
        max-width: none !important;
        height: auto !important;
        aspect-ratio: 16 / 9 !important;
        border-radius: 10px !important;
        overflow: hidden !important;
        background: var(--cn-surface);
        margin: 0 0 12px !important;
    }
    body.category .cn-cat-hero-thumb img,
    body.tag .cn-cat-hero-thumb img,
    body.page-template-template-tinmoi .cn-cat-hero-thumb img {
        width: 100% !important;
        height: 100% !important;
        object-fit: cover !important;
        display: block !important;
    }
    body.category .cn-cat-hero-body,
    body.tag .cn-cat-hero-body,
    body.page-template-template-tinmoi .cn-cat-hero-body {
        padding: 0 !important;
        width: 100% !important;
    }
    body.category .cn-cat-hero-title,
    body.tag .cn-cat-hero-title,
    body.page-template-template-tinmoi .cn-cat-hero-title {
        font-size: 19px !important;
        line-height: 1.35 !important;
        font-weight: 700 !important;
        margin: 0 0 8px !important;
    }
    body.category .cn-cat-hero-excerpt,
    body.tag .cn-cat-hero-excerpt,
    body.page-template-template-tinmoi .cn-cat-hero-excerpt {
        font-size: 14px !important;
        line-height: 1.5 !important;
        margin: 0 0 8px !important;
        display: block !important;
    }
}
/* ===== List item: excerpt clamp 2 dòng — body cao bằng thumb 16:9 ===== */
body.category .cn-cat-item,
body.tag .cn-cat-item,
body.search .cn-cat-item,
body.page-template-template-tinmoi .cn-cat-item {
    align-items: stretch !important;
}

body.category .cn-cat-item-body,
body.tag .cn-cat-item-body,
body.search .cn-cat-item-body,
body.page-template-template-tinmoi .cn-cat-item-body {
    display: flex !important;
    flex-direction: column !important;
    justify-content: space-between !important;
    gap: 4px;
    min-width: 0;
}

body.category .cn-cat-item-title,
body.tag .cn-cat-item-title,
body.search .cn-cat-item-title,
body.page-template-template-tinmoi .cn-cat-item-title {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    font-size: 15.5px !important;
    line-height: 1.35 !important;
    margin: 0 !important;
}

body.category .cn-cat-item-excerpt,
body.tag .cn-cat-item-excerpt,
body.search .cn-cat-item-excerpt,
body.page-template-template-tinmoi .cn-cat-item-excerpt {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    font-size: 13px !important;
    line-height: 1.45 !important;
    color: #475569 !important;
    margin: 0 !important;
}

body.category .cn-cat-item-meta,
body.tag .cn-cat-item-meta,
body.search .cn-cat-item-meta,
body.page-template-template-tinmoi .cn-cat-item-meta {
    font-size: 12px !important;
    color: #94a3b8 !important;
    margin: 0 !important;
}
.cn-iframe-wrap {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    background: #fff;
    border-radius: 8px;
    overflow: hidden;
    box-shadow: 0 1px 3px rgba(0,0,0,0.08);
}
.cn-iframe-wrap iframe {
    width: 100% !important;
    min-height: 800px;
    border: 0;
    display: block;
}
@media (max-width: 767px) {
    .cn-iframe-wrap iframe { min-height: 600px; }
}
/* ===== IFRAME FULL-WIDTH (phá khung content) ===== */
.cn-iframe-fullwidth {
    position: relative;
    width: 100vw;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;
    max-width: 100vw;
    background: #fff;
    overflow: hidden;
}
.cn-iframe-fullwidth iframe {
    display: block;
    width: 100%;
    border: 0;
    margin: 0 auto;
    min-height: 1000px;
}

/* PC: rộng tối đa bằng container của web (1140-1200px) */
@media (min-width: 1024px) {
    .cn-iframe-fullwidth iframe {
        max-width: 1140px;  /* khớp với --cn-container-max của mày */
        min-height: 1100px;
    }
}

/* Mobile: full width, height vừa phải */
@media (max-width: 1023px) {
    .cn-iframe-fullwidth iframe {
        max-width: 100%;
        min-height: 700px;
    }
}
/* ===== CATEGORY v5.1: PC grid 3 cột — Mobile hero+list ===== */
@media (min-width: 1024px) {
    .cn-cat-pc { display: grid; }
    .cn-cat-mobile { display: none; }
}
@media (max-width: 1023px) {
    .cn-cat-pc { display: none; }
    .cn-cat-mobile { display: block; }
}

/* .cn-grid-3 trong category PC (nếu chưa có chung) */
.cn-cat-pc.cn-grid-3 {
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 28px;
}
/* ===== CATEGORY PC card: excerpt + meta nhỏ ===== */
@media (min-width: 1024px) {
    .cn-cat-pc .cn-card-excerpt {
        font-size: 13px;
        line-height: 1.5;
        color: #475569;
        margin: 6px 0 8px;
        display: -webkit-box;
        -webkit-line-clamp: 3;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }
    .cn-cat-pc .cn-card-meta {
        font-size: 11.5px;
        color: #94a3b8;
        margin-top: auto;
    }
    .cn-cat-pc .cn-card-date {
        color: #94a3b8;
    }
}
