/* GFF blog index + single post styles — editorial dark layout */

/* ============================================================
   Blog index (home.php)
   ============================================================ */
/* Wrap the chip bar in clear breathing room. The pseudo-eyebrow needs a clean
   page-bg contrast slot to be readable, so we push it down with margin-top. */
.gff-blog-index .gff-content { padding-top: clamp(56px, 7vw, 96px); }

.gff-blog-index .gff-blog-chips {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 48px 0 64px;
	justify-content: center;
	padding: 22px 0 40px;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	position: relative;
}
.gff-blog-index .gff-blog-chips::before {
	content: "Browse by topic";
	position: absolute;
	top: -10px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--bg);
	padding: 0 16px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	color: var(--brand-2);
	line-height: 1;
	white-space: nowrap;
}
.gff-blog-index .gff-blog-chips .gff-chip {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 10px 18px 10px 22px;
	background: var(--panel);
	border: 1px solid var(--line);
	color: var(--text);
	font-family: var(--font-display);
	font-size: 15px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
	text-decoration: none;
	line-height: 1;
	transition: background 0.25s var(--ease-out),
	            border-color 0.25s var(--ease-out),
	            color 0.25s var(--ease-out),
	            transform 0.25s var(--ease-out),
	            box-shadow 0.25s var(--ease-out);
	position: relative;
}
.gff-blog-index .gff-blog-chips .gff-chip::before {
	content: "";
	width: 4px;
	height: 4px;
	background: var(--brand-2);
	border-radius: 50%;
	margin-right: 4px;
	opacity: 0.4;
	transition: opacity 0.25s var(--ease-out), transform 0.25s var(--ease-out);
}
.gff-blog-index .gff-blog-chips .gff-chip span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 22px;
	height: 22px;
	padding: 0 7px;
	background: rgba(61, 125, 255, 0.12);
	color: var(--brand-2);
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.04em;
	border-radius: 999px;
	opacity: 1;
}
.gff-blog-index .gff-blog-chips .gff-chip:hover {
	border-color: var(--brand-2);
	color: var(--brand-2);
	transform: translateY(-2px);
	box-shadow: 0 6px 18px -8px var(--brand-glow);
}
.gff-blog-index .gff-blog-chips .gff-chip:hover::before {
	opacity: 1;
	transform: scale(1.6);
}
.gff-blog-index .gff-blog-chips .gff-chip--active {
	background: var(--brand-2);
	border-color: var(--brand-2);
	color: #001127;
	box-shadow: 0 6px 18px -8px var(--brand-glow);
}
.gff-blog-index .gff-blog-chips .gff-chip--active::before {
	background: #001127;
	opacity: 1;
}
.gff-blog-index .gff-blog-chips .gff-chip--active span {
	background: rgba(0, 17, 39, 0.2);
	color: #001127;
}

/* Featured (top) post on page 1 — full-width hero card */
.gff-blog-featured {
	display: grid;
	grid-template-columns: 1.4fr 1fr;
	gap: 0;
	margin-bottom: 48px;
	border: 1px solid var(--line);
	background: var(--panel);
	transition: border-color 0.25s var(--ease-out), transform 0.4s var(--ease-out);
	color: var(--text);
	text-decoration: none;
	overflow: hidden;
}
.gff-blog-featured:hover { border-color: var(--brand-2); transform: translateY(-4px); }
.gff-blog-featured__media {
	position: relative;
	overflow: hidden;
	min-height: 380px;
	background: #1a1a1a;
}
.gff-blog-featured__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	position: absolute;
	inset: 0;
	transition: transform 0.8s var(--ease-out);
}
.gff-blog-featured:hover .gff-blog-featured__media img { transform: scale(1.04); }
.gff-blog-featured__overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(110deg, rgba(7,16,31,0) 50%, rgba(7,16,31,0.6) 100%);
	pointer-events: none;
}
.gff-blog-featured__chip {
	position: absolute;
	top: 18px;
	left: 18px;
	background: var(--brand-2);
	color: #001127;
	font-family: var(--font-mono);
	font-size: 10px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 6px 12px;
	z-index: 2;
}
.gff-blog-featured__body {
	padding: 48px clamp(28px, 4vw, 56px);
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 18px;
}
.gff-blog-featured__meta {
	font-size: 11px;
	letter-spacing: 0.14em;
	color: var(--brand-2);
	text-transform: uppercase;
}
.gff-blog-featured__title {
	font-size: clamp(32px, 4vw, 52px);
	line-height: 1;
	letter-spacing: 0.01em;
	text-transform: uppercase;
	margin: 0;
	color: var(--text);
}
.gff-blog-featured__excerpt {
	color: var(--dim);
	font-size: 16px;
	line-height: 1.6;
	margin: 0;
}
.gff-blog-featured__cta {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--brand-2);
	margin-top: 6px;
}
.gff-blog-featured__cta .arrow {
	width: 22px;
	height: 1.5px;
	background: currentColor;
	position: relative;
	transition: width 0.25s var(--ease-out);
}
.gff-blog-featured__cta .arrow::after {
	content: "";
	position: absolute;
	right: -1px;
	top: -3px;
	width: 8px;
	height: 8px;
	border-top: 1.5px solid currentColor;
	border-right: 1.5px solid currentColor;
	transform: rotate(45deg);
}
.gff-blog-featured:hover .gff-blog-featured__cta .arrow { width: 30px; }
@media (max-width: 820px) {
	.gff-blog-featured { grid-template-columns: 1fr; }
	.gff-blog-featured__media { min-height: 260px; }
}

/* Card grid (rest of posts) */
.gff-blog-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
@media (max-width: 980px) { .gff-blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .gff-blog-grid { grid-template-columns: 1fr; } }

.gff-blog-card {
	background: var(--panel);
	border: 1px solid var(--line);
	display: flex;
	flex-direction: column;
	color: var(--text);
	text-decoration: none;
	overflow: hidden;
	transition: border-color 0.25s var(--ease-out), transform 0.4s var(--ease-out);
}
.gff-blog-card:hover { border-color: var(--brand-2); transform: translateY(-4px); }
.gff-blog-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	background: #1a1a1a;
}
.gff-blog-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.8s var(--ease-out);
}
.gff-blog-card:hover .gff-blog-card__media img { transform: scale(1.05); }
.gff-blog-card__chip {
	position: absolute;
	top: 12px;
	left: 12px;
	background: rgba(0, 0, 0, 0.55);
	backdrop-filter: blur(6px);
	border: 1px solid var(--line);
	color: var(--text);
	font-family: var(--font-mono);
	font-size: 9px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	padding: 5px 10px;
	z-index: 2;
}
.gff-blog-card__body {
	padding: 22px;
	display: flex;
	flex-direction: column;
	gap: 10px;
	flex: 1;
}
.gff-blog-card__meta {
	font-size: 10px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--dim);
}
.gff-blog-card__title {
	font-family: var(--font-body);
	font-weight: 700;
	font-size: 17px;
	line-height: 1.3;
	letter-spacing: 0;
	text-transform: none;
	margin: 0;
	color: var(--text);
}
.gff-blog-card:hover .gff-blog-card__title { color: var(--brand-2); }

/* Pagination */
.gff-blog-pagination {
	margin-top: 56px;
	text-align: center;
	display: flex;
	gap: 8px;
	justify-content: center;
	flex-wrap: wrap;
}
.gff-blog-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 14px;
	background: var(--panel);
	border: 1px solid var(--line);
	color: var(--text);
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	text-decoration: none;
	transition: all 0.25s var(--ease-out);
}
.gff-blog-pagination .page-numbers.current,
.gff-blog-pagination .page-numbers:hover {
	background: var(--brand-2);
	border-color: var(--brand-2);
	color: #001127;
}

/* ============================================================
   Single post (single.php)
   ============================================================ */
.gff-post-hero {
	padding: clamp(64px, 8vw, 100px) 0 clamp(32px, 4vw, 56px);
}
.gff-post-hero__title {
	font-size: clamp(40px, 6vw, 80px);
	line-height: 0.95;
	letter-spacing: 0.01em;
	margin: 14px 0 28px;
	color: var(--text);
}
.gff-post-hero__meta {
	display: flex;
	align-items: center;
	gap: 14px;
	flex-wrap: wrap;
	font-size: 11px;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--dim);
}
.gff-post-hero__sep {
	display: inline-block;
	width: 4px;
	height: 4px;
	background: var(--brand-2);
	border-radius: 50%;
}

.gff-post-featured {
	margin-bottom: clamp(40px, 6vw, 72px);
}
.gff-post-featured__img {
	width: 100%;
	height: auto;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	display: block;
	border: 1px solid var(--line);
}

.gff-post-content {
	padding-top: 0;
	padding-bottom: clamp(48px, 6vw, 80px);
}
.gff-post-content .gff-content__prose {
	font-size: 17px;
	line-height: 1.75;
	color: var(--text);
}
.gff-post-content .gff-content__prose p { margin: 0 0 1.4em; color: var(--text); }
.gff-post-content .gff-content__prose h2 {
	font-family: var(--font-display);
	font-size: clamp(28px, 3.5vw, 40px);
	letter-spacing: 0.02em;
	text-transform: uppercase;
	line-height: 1.05;
	margin: 2em 0 0.6em;
	color: var(--text);
}
.gff-post-content .gff-content__prose h3 {
	font-family: var(--font-display);
	font-size: clamp(22px, 2.5vw, 28px);
	letter-spacing: 0.02em;
	text-transform: uppercase;
	margin: 1.6em 0 0.5em;
	color: var(--text);
}
.gff-post-content .gff-content__prose a { color: var(--brand-2); border-bottom: 1px solid currentColor; }
.gff-post-content .gff-content__prose a:hover { color: #fff; }
.gff-post-content .gff-content__prose ul,
.gff-post-content .gff-content__prose ol { margin: 0 0 1.4em; padding-left: 1.4em; }
.gff-post-content .gff-content__prose li { margin-bottom: 0.4em; }
.gff-post-content .gff-content__prose strong { color: var(--text); font-weight: 700; }

.gff-post-tags {
	display: flex;
	gap: 8px;
	flex-wrap: wrap;
	padding: 24px 0;
	border-top: 1px solid var(--line);
	margin-top: 48px;
}

.gff-post-share {
	display: flex;
	align-items: center;
	gap: 12px;
	padding: 24px 0;
	border-top: 1px solid var(--line);
	border-bottom: 1px solid var(--line);
	margin: 0 0 48px;
	font-size: 11px;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--dim);
}
.gff-post-share a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid var(--line-strong);
	color: var(--text);
	font-family: var(--font-mono);
	font-size: 11px;
	letter-spacing: 0.06em;
	text-decoration: none;
	transition: border-color 0.25s var(--ease-out), color 0.25s var(--ease-out), background 0.25s var(--ease-out);
}
.gff-post-share a:hover { border-color: var(--brand-2); color: var(--brand-2); background: rgba(61, 125, 255, 0.06); }

.gff-post-related { padding: clamp(56px, 8vw, 96px) 0; }

.gff-post-cta {
	padding: clamp(56px, 8vw, 96px) 0;
	background: linear-gradient(180deg, var(--bg) 0%, #060d1c 100%);
	border-top: 1px solid var(--line);
}
