/* ============================================================
   blog.css — Blog listing (home.php) + single article (single.php)
   Scoped via .page-blog-home and .page-blog-single body classes.
   ============================================================ */

/* =============================================================
   LISTING (home.php)
   ============================================================= */

.page-blog-home .hero { padding: 48px 0 60px; position: relative; }
.page-blog-home .hero h1 {
	font-family: var(--font-serif); font-weight: 400;
	font-size: 120px; line-height: .98; letter-spacing: -.025em;
	color: var(--ink); text-wrap: balance;
}
.page-blog-home .hero h1 .i { font-style: italic; color: var(--forest); }
.page-blog-home .hero h1 .t { font-style: italic; color: var(--terra-text); }
.page-blog-home .hero-lead {
	margin-top: 32px; font-size: 21px; line-height: 1.6;
	color: var(--ink2); max-width: 780px; text-wrap: pretty;
}
.page-blog-home .hero-lead strong { color: var(--ink); font-weight: 600; }
.page-blog-home .hero-lead em { font-style: italic; color: var(--forest); }
.page-blog-home .hero .squiggle {
	position: absolute; top: 70px; right: 80px;
	font-family: var(--font-script); font-size: 32px;
	color: var(--terra-text); transform: rotate(8deg);
	line-height: 1.2; text-align: center;
}
.page-blog-home .hero .squiggle .arr {
	display: block; font-size: 48px; margin-top: 4px; line-height: .6;
}

/* FEATURED ARTICLE */
.page-blog-home .featured { padding: 10px 0 80px; }
.page-blog-home .feat-card {
	background: var(--cream3); border-radius: 28px;
	padding: 38px;
	border: 1px solid rgba(31,26,23,.05);
	box-shadow: 0 1px 0 rgba(31,26,23,.04), 0 20px 50px -28px rgba(31,26,23,.2);
	display: grid; grid-template-columns: 1.1fr 1fr;
	gap: 48px; align-items: center;
	position: relative; text-decoration: none; color: inherit;
}
.page-blog-home .feat-card::before {
	content: "★ najčítanejšie tento mesiac";
	position: absolute; top: -14px; left: 40px;
	background: var(--terra); color: #fff;
	padding: 6px 18px; border-radius: 999px;
	font-family: var(--font-sans); font-size: 11px; font-weight: 700;
	letter-spacing: .14em; text-transform: uppercase;
}
.page-blog-home .feat-img {
	background: var(--cream); border-radius: 18px;
	aspect-ratio: 4/3;
	border: 2px dashed rgba(31,26,23,.2);
	display: flex; align-items: center; justify-content: center;
	position: relative; overflow: hidden; transform: rotate(-1deg);
}
.page-blog-home .feat-img::before {
	content: ""; position: absolute; inset: 0;
	background:
		radial-gradient(circle at 30% 40%, rgba(201,122,91,.15), transparent 45%),
		radial-gradient(circle at 70% 70%, rgba(45,74,54,.1), transparent 50%);
}
.page-blog-home .feat-img img {
	width: 100%; height: 100%; object-fit: cover;
	position: relative; z-index: 1;
}
.page-blog-home .feat-img .ph {
	font-family: var(--font-serif); font-style: italic;
	font-size: 22px; color: var(--ink3); text-align: center;
	padding: 30px; z-index: 1; position: relative; line-height: 1.4;
}
.page-blog-home .feat-img .ph .sm {
	display: block; font-family: var(--font-sans); font-style: normal;
	font-size: 11px; font-weight: 700; letter-spacing: .16em;
	text-transform: uppercase; color: var(--terra-text); margin-bottom: 12px;
}
.page-blog-home .feat-img .tape {
	position: absolute; top: -18px; left: 50%;
	transform: translateX(-50%) rotate(-3deg);
	width: 140px; height: 24px;
	background: rgba(201,122,91,.3); border: 1px dashed rgba(201,122,91,.5);
	z-index: 2;
}
.page-blog-home .feat-meta {
	display: flex; align-items: center; gap: 14px;
	margin-bottom: 18px; flex-wrap: wrap;
}
.page-blog-home .cat-pill {
	background: var(--terra-soft); color: var(--terra-text);
	padding: 6px 14px; border-radius: 999px;
	font-family: var(--font-serif); font-style: italic; font-size: 14px;
}
.page-blog-home .meta-line {
	font-family: var(--font-serif); font-style: italic;
	font-size: 15px; color: var(--ink3);
}
.page-blog-home .meta-line .dot { margin: 0 8px; color: var(--terra-text); }
.page-blog-home .feat-card h2 {
	font-family: var(--font-serif); font-weight: 400;
	font-size: 46px; line-height: 1.08; letter-spacing: -.01em;
	color: var(--ink); text-wrap: balance;
}
.page-blog-home .feat-card h2 .i { font-style: italic; color: var(--forest); }
.page-blog-home .feat-card h2 .t { font-style: italic; color: var(--terra-text); }
.page-blog-home .feat-card .perex {
	margin-top: 18px; font-size: 18px; line-height: 1.6;
	color: var(--ink2); font-family: var(--font-serif);
	font-style: italic; max-width: 560px;
}
.page-blog-home .feat-card .cta { margin-top: 28px; }

/* SECTION TITLE for article grid */
.page-blog-home .section { padding: 20px 0 70px; }
.page-blog-home .sec-head {
	margin-bottom: 40px; display: flex;
	align-items: baseline; justify-content: space-between;
	gap: 32px; flex-wrap: wrap;
}
.page-blog-home .sec-head .lt .kicker { margin-bottom: 12px; }
.page-blog-home .sec-head .lt h3 {
	font-family: var(--font-serif); font-weight: 400;
	font-size: 44px; line-height: 1.1; letter-spacing: -.01em;
	color: var(--ink);
}
.page-blog-home .sec-head .lt h3 .i { font-style: italic; color: var(--forest); }
.page-blog-home .sec-head .rt {
	font-family: var(--font-serif); font-style: italic;
	color: var(--ink3); font-size: 16px;
}

/* ARTICLE GRID */
.page-blog-home .grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.page-blog-home .card {
	background: var(--cream3); border-radius: 20px;
	padding: 22px;
	border: 1px solid rgba(31,26,23,.05);
	box-shadow: 0 1px 0 rgba(31,26,23,.04);
	display: flex; flex-direction: column;
	transition: all .18s; position: relative;
	text-decoration: none; color: inherit;
}
.page-blog-home .card:hover {
	transform: translateY(-4px);
	box-shadow: 0 1px 0 rgba(31,26,23,.04), 0 18px 40px -24px rgba(31,26,23,.25);
}
.page-blog-home .card .thumb {
	aspect-ratio: 4/3;
	background: var(--cream2);
	border-radius: 12px;
	border: 1.5px dashed rgba(31,26,23,.18);
	display: flex; align-items: center; justify-content: center;
	margin-bottom: 18px; position: relative; overflow: hidden;
}
.page-blog-home .card .thumb img {
	width: 100%; height: 100%; object-fit: cover;
}
.page-blog-home .card .thumb .icon {
	font-family: var(--font-serif); font-style: italic;
	font-size: 60px; color: var(--terra-text); opacity: .5; line-height: 1;
}
.page-blog-home .card .thumb .corner {
	position: absolute; top: 10px; right: 12px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 13px; color: var(--ink3); transform: rotate(3deg);
}
.page-blog-home .card .thumb.a { background: linear-gradient(135deg, #F4DCCE 0%, #FFFDF8 100%); }
.page-blog-home .card .thumb.b { background: linear-gradient(135deg, #EDE6D8 0%, #FFFDF8 100%); }
.page-blog-home .card .thumb.c { background: linear-gradient(135deg, #E8EFE9 0%, #FFFDF8 100%); }
.page-blog-home .card .thumb.d { background: linear-gradient(135deg, #F5F1EA 0%, #F4DCCE 100%); }
.page-blog-home .card .cat-pill { align-self: flex-start; margin-bottom: 10px; }
.page-blog-home .card h4 {
	font-family: var(--font-serif); font-weight: 400;
	font-size: 22px; line-height: 1.25; letter-spacing: -.005em;
	color: var(--ink); text-wrap: balance; flex: 1;
}
.page-blog-home .card h4 .i { font-style: italic; color: var(--forest); }
.page-blog-home .card h4 .t { font-style: italic; color: var(--terra-text); }
.page-blog-home .card .meta {
	margin-top: 16px; padding-top: 14px;
	border-top: 1px dashed var(--dash);
	display: flex; align-items: center;
	justify-content: space-between;
	font-family: var(--font-serif); font-style: italic;
	font-size: 14px; color: var(--ink3);
}
.page-blog-home .card .meta .rd { color: var(--terra-text); font-weight: 600; }

/* CATEGORIES CLOUD */
.page-blog-home .cats {
	background: var(--cream3); border-radius: 24px;
	padding: 42px 44px;
	border: 1px solid rgba(31,26,23,.06);
	box-shadow: 0 1px 0 rgba(31,26,23,.04);
	display: grid; grid-template-columns: 1fr 2fr;
	gap: 48px; align-items: center;
}
.page-blog-home .cats .lt h4 {
	font-family: var(--font-serif); font-size: 34px; line-height: 1.1;
	color: var(--ink); letter-spacing: -.005em; margin-top: 10px;
}
.page-blog-home .cats .lt h4 .i { font-style: italic; color: var(--forest); }
.page-blog-home .cats .lt p {
	margin-top: 12px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 15px; color: var(--ink3); line-height: 1.55;
}
.page-blog-home .cats .rt { display: flex; flex-wrap: wrap; gap: 12px; }
.page-blog-home .cat-chip {
	background: var(--cream);
	border: 1.5px solid var(--terra-soft);
	padding: 12px 20px; border-radius: 999px;
	display: inline-flex; align-items: center; gap: 10px;
	transition: all .15s; cursor: pointer;
	text-decoration: none; color: inherit;
}
.page-blog-home .cat-chip:hover {
	background: var(--terra-soft); border-color: var(--terra);
}
.page-blog-home .cat-chip .nm {
	font-family: var(--font-serif); font-size: 17px;
	color: var(--ink); letter-spacing: -.005em;
}
.page-blog-home .cat-chip .nm .i { font-style: italic; color: var(--forest); }
.page-blog-home .cat-chip .ct {
	font-family: var(--font-sans); font-size: 12px; font-weight: 700;
	color: var(--terra-text); background: var(--terra-soft);
	padding: 3px 8px; border-radius: 999px;
	min-width: 24px; text-align: center;
}
.page-blog-home .cat-chip:hover .ct { background: var(--terra); color: #fff; }

/* NEWSLETTER (listing) */
.page-blog-home .news {
	background: var(--forest); color: var(--cream);
	border-radius: 32px; padding: 72px 64px;
	position: relative; overflow: hidden;
	display: grid; grid-template-columns: 1fr 1.1fr;
	gap: 56px; align-items: center;
}
.page-blog-home .news::after {
	content: ""; position: absolute; right: -140px; top: -140px;
	width: 360px; height: 360px; border-radius: 50%;
	background: rgba(201,122,91,.18);
}
.page-blog-home .news::before {
	content: "✎"; position: absolute; left: 40px; bottom: 30px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 180px; color: rgba(245,241,234,.07); line-height: .8;
}
.page-blog-home .news > * { position: relative; z-index: 1; }
.page-blog-home .news .kicker { color: var(--terra-l); }
.page-blog-home .news .kicker .orn { color: var(--terra-l); }
.page-blog-home .news h3 {
	font-family: var(--font-serif); font-weight: 400;
	font-size: 52px; line-height: 1.05; letter-spacing: -.015em;
	color: var(--cream); margin-top: 18px; text-wrap: balance;
}
.page-blog-home .news h3 .i { font-style: italic; color: var(--terra-l); }
.page-blog-home .news p {
	margin-top: 18px; font-size: 17px; line-height: 1.6;
	color: var(--cream2); max-width: 500px;
}
.page-blog-home .news p em { font-style: italic; color: var(--terra-l); }
.page-blog-home .news-box {
	background: var(--cream3); border-radius: 20px;
	padding: 32px;
	box-shadow: 0 20px 50px -20px rgba(0,0,0,.3);
	transform: rotate(1.2deg); position: relative;
}
.page-blog-home .news-box::before {
	content: ""; position: absolute; top: -16px; left: 50%;
	transform: translateX(-50%) rotate(-3deg);
	width: 120px; height: 22px;
	background: rgba(201,122,91,.3); border: 1px dashed rgba(201,122,91,.5);
}
.page-blog-home .news-box label {
	font-family: var(--font-sans); font-size: 11px; font-weight: 700;
	letter-spacing: .16em; text-transform: uppercase;
	color: var(--terra-text); display: block; margin-bottom: 10px;
}
.page-blog-home .news-box .row { display: flex; gap: 10px; }
.page-blog-home .news-box input {
	flex: 1; background: var(--cream);
	border: 1.5px solid rgba(31,26,23,.12);
	border-radius: 999px;
	padding: 14px 20px;
	font-family: var(--font-sans); font-size: 15px;
	color: var(--ink); outline: none; transition: border .15s;
}
.page-blog-home .news-box input:focus { border-color: var(--terra); }
.page-blog-home .news-box button {
	background: var(--terra); color: #fff;
	border: none; border-radius: 999px;
	padding: 14px 24px;
	font-family: var(--font-sans); font-size: 15px; font-weight: 600;
	cursor: pointer;
	box-shadow: 0 4px 0 var(--terra-shadow);
	transition: all .15s; white-space: nowrap;
}
.page-blog-home .news-box button:hover {
	transform: translateY(2px);
	box-shadow: 0 2px 0 var(--terra-shadow);
}
.page-blog-home .news-box .fine {
	margin-top: 14px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 13px; color: var(--ink3); line-height: 1.4;
}
.page-blog-home .news-box .sig {
	margin-top: 20px; padding-top: 14px;
	border-top: 1px dashed var(--dash);
	font-family: var(--font-script); font-size: 22px; color: var(--terra-text);
}

/* =============================================================
   SINGLE ARTICLE (single.php)
   ============================================================= */

.page-blog-single .art-head { padding: 36px 0 48px; }
.page-blog-single .cat-badge {
	display: inline-flex; align-items: center; gap: 10px;
	padding: 8px 18px; border-radius: 999px;
	background: var(--terra-soft); color: var(--terra-text);
	font-family: var(--font-sans); font-size: 12px; font-weight: 700;
	letter-spacing: .16em; text-transform: uppercase;
	text-decoration: none;
}
.page-blog-single .cat-badge::before {
	content: "❦"; font-family: var(--font-serif); font-style: italic;
	font-size: 15px; letter-spacing: 0;
}
.page-blog-single .art-title {
	margin-top: 26px;
	font-family: var(--font-serif); font-weight: 400;
	font-size: 68px; line-height: 1.06; letter-spacing: -.015em;
	color: var(--ink); text-wrap: balance; max-width: 960px;
}
.page-blog-single .art-title .i { font-style: italic; color: var(--forest); }
.page-blog-single .art-title .t { font-style: italic; color: var(--terra-text); }
.page-blog-single .art-lead {
	margin-top: 28px;
	font-family: var(--font-serif); font-size: 24px; line-height: 1.45;
	color: var(--ink2); max-width: 780px;
	letter-spacing: -.003em; text-wrap: pretty;
}
.page-blog-single .art-lead strong { color: var(--ink); font-weight: 600; }
.page-blog-single .art-lead em { font-style: italic; color: var(--forest); }
.page-blog-single .art-meta {
	margin-top: 36px; padding: 22px 0;
	border-top: 1px dashed var(--dash); border-bottom: 1px dashed var(--dash);
	display: flex; flex-wrap: wrap; align-items: center;
	max-width: 780px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 16px; color: var(--ink3);
}
.page-blog-single .art-meta .dot { margin: 0 14px; color: var(--terra-text); }
.page-blog-single .art-meta .author-n {
	color: var(--ink); font-style: normal; font-weight: 600;
	font-family: var(--font-sans); font-size: 15px;
}
.page-blog-single .art-meta .tag {
	font-family: var(--font-sans); font-style: normal;
	font-size: 12px; font-weight: 700;
	letter-spacing: .14em; text-transform: uppercase; color: var(--terra-text);
}

/* AUTHOR CARD + HERO IMAGE */
.page-blog-single .art-hero {
	padding: 20px 0 48px;
}
.page-blog-single .art-hero .wrap {
	display: grid; grid-template-columns: 280px 1fr;
	gap: 44px; align-items: start;
}
.page-blog-single .author-card {
	background: var(--cream3); padding: 22px 22px 42px;
	border: 1px solid rgba(31,26,23,.06);
	box-shadow: 0 2px 0 rgba(31,26,23,.04), 0 14px 32px -18px rgba(31,26,23,.2);
	transform: rotate(-2deg); position: relative;
}
.page-blog-single .author-card::before {
	content: ""; position: absolute; top: -10px; left: 60px;
	transform: rotate(-3deg);
	width: 90px; height: 20px;
	background: rgba(201,122,91,.3); border: 1px dashed rgba(201,122,91,.55);
}
.page-blog-single .author-card .photo {
	width: 100%; aspect-ratio: 1;
	background: var(--cream2); border: 1px solid var(--hair);
	position: relative; overflow: hidden;
}
.page-blog-single .author-card .photo img {
	width: 100%; height: 100%; object-fit: cover;
}
.page-blog-single .author-card .photo::after {
	content: "Filip"; position: absolute; inset: 0;
	display: flex; align-items: center; justify-content: center;
	font-family: var(--font-serif); font-style: italic;
	font-size: 42px; color: var(--ink3); letter-spacing: -.01em;
}
.page-blog-single .author-card .photo img + .photo::after,
.page-blog-single .author-card .photo:has(img)::after { display: none; }
.page-blog-single .author-card .nm {
	margin-top: 16px;
	font-family: var(--font-serif); font-size: 20px;
	color: var(--ink); letter-spacing: -.005em; line-height: 1.2;
}
.page-blog-single .author-card .role {
	margin-top: 4px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 14px; color: var(--terra-text);
}
.page-blog-single .author-card .caption {
	position: absolute; bottom: 14px; left: 22px; right: 22px;
	font-family: var(--font-script); font-size: 20px;
	color: var(--ink3); line-height: 1.2;
}

.page-blog-single .hero-image {
	background: var(--cream3); padding: 24px;
	border: 1px solid rgba(31,26,23,.06);
	box-shadow: 0 2px 0 rgba(31,26,23,.04), 0 20px 50px -22px rgba(31,26,23,.22);
	transform: rotate(0.8deg); position: relative;
}
.page-blog-single .hero-image::before {
	content: ""; position: absolute; top: -10px; right: 60px;
	transform: rotate(3deg);
	width: 110px; height: 22px;
	background: rgba(45,74,54,0.25); border: 1px dashed rgba(45,74,54,0.5);
}
.page-blog-single .hero-image .ph {
	width: 100%; aspect-ratio: 16/9;
	background: linear-gradient(135deg, var(--cream2) 0%, var(--terra-soft) 50%, var(--cream2) 100%);
	border: 1px dashed var(--dash);
	position: relative; display: flex;
	align-items: center; justify-content: center;
}
.page-blog-single .hero-image .ph img {
	width: 100%; height: 100%; object-fit: cover;
	position: relative; z-index: 1;
}
.page-blog-single .hero-image .ph::after {
	content: "— illustration placeholder —";
	font-family: var(--font-serif); font-style: italic;
	font-size: 18px; color: var(--ink3);
}
.page-blog-single .hero-image .ph:has(img)::after { display: none; }
.page-blog-single .hero-image .cap {
	margin-top: 14px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 14px; color: var(--ink3);
	display: flex; justify-content: space-between;
}
.page-blog-single .hero-image .cap .mini {
	font-family: var(--font-sans); font-style: normal;
	font-size: 11px; font-weight: 700; letter-spacing: .14em;
	text-transform: uppercase; color: var(--terra-text);
}

/* ARTICLE BODY */
.page-blog-single .art-body { padding: 40px 0 60px; }
.page-blog-single .art-body .wrap-read {
	max-width: 820px;
	margin: 0 auto;
	padding: 0 48px;
}
.page-blog-single .art-body p {
	font-size: 18px; line-height: 1.75; color: var(--ink2);
	margin-bottom: 22px; max-width: 720px;
}
.page-blog-single .art-body p strong { color: var(--ink); font-weight: 600; }
.page-blog-single .art-body p em { font-style: italic; color: var(--forest); }
.page-blog-single .art-body h2 {
	margin: 56px 0 22px;
	font-family: var(--font-serif); font-weight: 400;
	font-size: 42px; line-height: 1.15; letter-spacing: -.01em;
	color: var(--ink); text-wrap: balance; max-width: 720px;
	position: relative; padding-bottom: 16px;
}
.page-blog-single .art-body h2::after {
	content: ""; position: absolute; left: 0; bottom: 0;
	width: 80px; height: 3px;
	background: var(--forest); border-radius: 2px;
}
.page-blog-single .art-body h2 .i { font-style: italic; color: var(--forest); }
.page-blog-single .art-body h2 .n {
	font-family: var(--font-serif); font-style: italic;
	color: var(--terra-text); font-size: 36px; margin-right: 10px;
}
.page-blog-single .art-body h3 {
	margin: 40px 0 16px;
	font-family: var(--font-serif); font-size: 28px; line-height: 1.25;
	color: var(--ink); letter-spacing: -.005em; max-width: 720px;
}
.page-blog-single .art-body h3 .i { font-style: italic; color: var(--forest); }
.page-blog-single .art-body .lede::first-letter,
.page-blog-single .art-body > .wrap-read > p:first-of-type::first-letter {
	font-family: var(--font-serif); font-style: italic;
	font-size: 92px; line-height: .8; float: left;
	color: var(--terra-text); padding: 10px 14px 0 0; font-weight: 400;
}
.page-blog-single .art-body ul {
	margin: 8px 0 26px; padding-left: 0;
	list-style: none; max-width: 720px;
}
.page-blog-single .art-body ul li {
	position: relative; padding-left: 28px;
	font-size: 18px; line-height: 1.65; color: var(--ink2);
	margin-bottom: 12px;
}
.page-blog-single .art-body ul li::before {
	content: "❦"; position: absolute; left: 0; top: 2px;
	color: var(--terra-text); font-family: var(--font-serif);
	font-style: italic; font-size: 16px;
}
.page-blog-single .art-body ul li strong { color: var(--ink); font-weight: 600; }

/* PULL QUOTE */
.page-blog-single .pq {
	margin: 48px 0; padding: 0 0 0 36px;
	border-left: 4px solid var(--terra);
	max-width: 720px; position: relative;
}
.page-blog-single .pq::before {
	content: "„"; position: absolute; left: -16px; top: -28px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 110px; color: var(--terra-soft);
	line-height: 1; z-index: -1;
}
.page-blog-single .pq .q {
	font-family: var(--font-serif); font-style: italic;
	font-size: 30px; line-height: 1.35;
	color: var(--ink); letter-spacing: -.005em; text-wrap: balance;
}
.page-blog-single .pq .q .i { color: var(--forest); }
.page-blog-single .pq .attr {
	margin-top: 18px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 15px; color: var(--ink3);
}
.page-blog-single .pq .attr .name {
	color: var(--terra-text); font-style: normal; font-weight: 600;
	font-family: var(--font-sans); font-size: 13px;
	letter-spacing: .08em; text-transform: uppercase;
}

/* SIGN-OFF */
.page-blog-single .signoff {
	margin: 56px 0 0; padding-top: 28px;
	border-top: 2px dashed var(--dash); max-width: 720px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 20px; color: var(--ink3); line-height: 1.5;
}
.page-blog-single .signoff .name {
	display: block; margin-top: 14px;
	font-family: var(--font-script); font-size: 36px;
	color: var(--terra-text); font-style: normal; line-height: 1;
}

/* RELATED ARTICLES */
.page-blog-single .related {
	padding: 80px 0 40px; background: var(--cream2);
}
.page-blog-single .related-head { margin-bottom: 36px; }
.page-blog-single .related-head h2 {
	font-family: var(--font-serif); font-size: 40px; line-height: 1.1;
	color: var(--ink); letter-spacing: -.01em; margin-top: 14px;
}
.page-blog-single .related-head h2 .i { font-style: italic; color: var(--forest); }
.page-blog-single .related-grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px;
}
.page-blog-single .rc {
	background: var(--cream3); border-radius: 20px;
	padding: 28px 28px 26px;
	border: 1px solid rgba(31,26,23,.05);
	box-shadow: 0 1px 0 rgba(31,26,23,.04);
	transition: transform .15s; cursor: pointer;
	display: block; color: inherit; text-decoration: none;
}
.page-blog-single .rc:hover { transform: translateY(-3px); }
.page-blog-single .rc .mini-cat {
	font-family: var(--font-sans); font-size: 11px; font-weight: 700;
	letter-spacing: .14em; text-transform: uppercase; color: var(--terra-text);
}
.page-blog-single .rc h3 {
	margin-top: 12px;
	font-family: var(--font-serif); font-size: 24px; line-height: 1.2;
	color: var(--ink); letter-spacing: -.005em; min-height: 58px;
}
.page-blog-single .rc h3 .i { font-style: italic; color: var(--forest); }
.page-blog-single .rc .ex {
	margin-top: 14px; font-size: 15px; line-height: 1.55; color: var(--ink2);
}
.page-blog-single .rc .foot {
	margin-top: 18px; padding-top: 14px;
	border-top: 1px dashed var(--dash);
	display: flex; justify-content: space-between; align-items: center;
	font-family: var(--font-serif); font-style: italic;
	font-size: 13px; color: var(--ink3);
}
.page-blog-single .rc .foot .arr { color: var(--terra-text); }

/* NEWSLETTER (single) */
.page-blog-single .newsletter { padding: 80px 0 60px; }
.page-blog-single .nl-card {
	background: var(--cream3); border-radius: 28px;
	padding: 56px 60px;
	display: grid; grid-template-columns: 1.1fr 1fr;
	gap: 48px; align-items: center;
	border: 1px solid rgba(31,26,23,.06);
	box-shadow: 0 1px 0 rgba(31,26,23,.04), 0 16px 40px -22px rgba(31,26,23,.15);
	position: relative; overflow: hidden;
	max-width: 1080px; margin: 0 auto;
}
.page-blog-single .nl-card::after {
	content: ""; position: absolute; right: -50px; bottom: -50px;
	width: 180px; height: 180px; border-radius: 50%;
	background: var(--terra-soft); opacity: .6;
}
.page-blog-single .nl-card > * { position: relative; z-index: 1; }
.page-blog-single .nl-card h3 {
	font-family: var(--font-serif); font-size: 40px; line-height: 1.1;
	color: var(--ink); letter-spacing: -.01em; text-wrap: balance;
}
.page-blog-single .nl-card h3 .i { font-style: italic; color: var(--terra-text); }
.page-blog-single .nl-card p {
	margin-top: 14px; font-size: 16px; line-height: 1.6;
	color: var(--ink2); max-width: 420px;
}
.page-blog-single .nl-form {
	display: flex; flex-direction: column; gap: 12px;
}
.page-blog-single .nl-form input {
	padding: 16px 22px; border-radius: 14px;
	border: 2px solid var(--hair);
	background: var(--cream);
	font-family: var(--font-sans); font-size: 16px;
	color: var(--ink); outline: none;
	transition: border-color .15s;
}
.page-blog-single .nl-form input:focus { border-color: var(--terra); }
.page-blog-single .nl-form input::placeholder {
	color: var(--ink3); font-style: italic;
	font-family: var(--font-serif); font-size: 17px;
}
.page-blog-single .nl-form button {
	background: var(--forest); color: var(--cream);
	border: none; border-radius: 999px;
	padding: 16px 28px;
	font-family: var(--font-sans); font-size: 16px; font-weight: 600;
	cursor: pointer; box-shadow: 0 4px 0 var(--forest2);
	transition: all .15s;
}
.page-blog-single .nl-form button:hover {
	transform: translateY(2px); box-shadow: 0 2px 0 var(--forest2);
}
.page-blog-single .nl-form .sub {
	font-family: var(--font-serif); font-style: italic;
	font-size: 14px; color: var(--ink3); margin-top: 4px;
}

/* COMMENTS PLACEHOLDER */
.page-blog-single .comments {
	padding: 20px 0 80px; text-align: center;
}
.page-blog-single .comments .placeholder {
	display: inline-flex; align-items: center; gap: 14px;
	padding: 20px 28px;
	background: var(--cream3); border: 1px dashed var(--dash);
	border-radius: 999px;
	font-family: var(--font-serif); font-style: italic;
	font-size: 16px; color: var(--ink3);
}
.page-blog-single .comments .placeholder .orn { color: var(--terra-text); }

/* RESPONSIVE */
@media (max-width: 1024px) {
	.page-blog-home .hero h1 { font-size: 72px; }
	.page-blog-home .hero .squiggle { display: none; }
	.page-blog-home .feat-card { grid-template-columns: 1fr; }
	.page-blog-home .grid { grid-template-columns: repeat(2, 1fr); }
	.page-blog-home .cats { grid-template-columns: 1fr; padding: 32px; }
	.page-blog-home .news { grid-template-columns: 1fr; padding: 48px 32px; }

	.page-blog-single .art-title { font-size: 44px; }
	.page-blog-single .art-hero .wrap { grid-template-columns: 1fr; }
	.page-blog-single .author-card { max-width: 280px; margin: 0 auto; }
	.page-blog-single .related-grid { grid-template-columns: 1fr; }
	.page-blog-single .nl-card { grid-template-columns: 1fr; padding: 40px 32px; }
}
@media (max-width: 640px) {
	.page-blog-home .hero h1 { font-size: 48px; }
	.page-blog-home .feat-card { padding: 24px; }
	.page-blog-home .feat-card h2 { font-size: 30px; }
	.page-blog-home .grid { grid-template-columns: 1fr; }
	.page-blog-home .news-box .row { flex-direction: column; }

	.page-blog-single .art-title { font-size: 32px; }
	.page-blog-single .art-body h2 { font-size: 28px; }
	.page-blog-single .art-body h2 .n { font-size: 24px; }
	.page-blog-single .pq .q { font-size: 22px; }
	.page-blog-single .art-body .wrap-read { padding: 0 20px; }
}
