﻿/*
Theme Name: Twenty Twenty-Three
Theme URI: https://wordpress.org/themes/twentytwentythree
Author: the WordPress team
Author URI: https://wordpress.org
Description: Twenty Twenty-Three is designed to take advantage of the new design tools introduced in WordPress 6.1. With a clean, blank base as a starting point, this default theme includes ten diverse style variations created by members of the WordPress community. Whether you want to build a complex or incredibly simple website, you can do it quickly and intuitively through the bundled styles or dive into creation and full customization yourself.
Requires at least: 6.1
Tested up to: 6.9
Requires PHP: 5.6
Version: 1.6
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/old-licenses/gpl-2.0.html
Text Domain: twentytwentythree
Tags: one-column, custom-colors, custom-menu, custom-logo, editor-style, featured-images, full-site-editing, block-patterns, rtl-language-support, sticky-post, threaded-comments, translation-ready, wide-blocks, block-styles, style-variations, accessibility-ready, blog, portfolio, news
*/

/* ============================================================
   CoderZPy Theme â€” Light Professional Design System
   A clean, readable coding blog theme.
   Accent: #16a34a (green-600) Â· Base: #ffffff Â· Text: #111827
   Fonts: DM Sans (UI) + IBM Plex Mono (code)
   ============================================================ */

/* â”€â”€ CSS Custom Properties â”€â”€ */
:root {
	/* Accent â€” deep green, works perfectly on white */
	--czpy-accent:        #16a34a;
	--czpy-accent-mid:    #15803d;
	--czpy-accent-dark:   #14532d;
	--czpy-accent-glow:   rgba(22, 163, 74, 0.18);
	--czpy-accent-subtle: rgba(22, 163, 74, 0.08);
	--czpy-accent-badge:  rgba(22, 163, 74, 0.1);

	/* Backgrounds */
	--czpy-bg:            #ffffff;
	--czpy-bg-soft:       #f9fafb;
	--czpy-bg-muted:      #f3f4f6;
	--czpy-hero-bg:       #0f172a;   /* dark navy hero only */

	/* Text */
	--czpy-text:          #111827;
	--czpy-text-muted:    #6b7280;
	--czpy-text-faint:    #9ca3af;
	--czpy-white:         #ffffff;

	/* Borders */
	--czpy-border:        #e5e7eb;
	--czpy-border-mid:    #d1d5db;

	/* Cards */
	--czpy-card-bg:       #ffffff;
	--czpy-card-border:   #e5e7eb;

	/* Header */
	--czpy-header-bg:     #ffffff;
	--czpy-header-border: #e5e7eb;

	/* Radius & Shadow */
	--czpy-radius:        10px;
	--czpy-radius-lg:     16px;
	--czpy-shadow-sm:     0 1px 3px rgba(0,0,0,0.07), 0 1px 2px rgba(0,0,0,0.05);
	--czpy-shadow:        0 4px 16px rgba(0,0,0,0.08);
	--czpy-shadow-hover:  0 12px 32px rgba(0,0,0,0.13);
	--czpy-transition:    all 0.22s cubic-bezier(0.4, 0, 0.2, 1);

	/* Fonts */
	--czpy-font-ui:       "DM Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
	--czpy-font-mono:     "IBM Plex Mono", "Fira Code", "Consolas", monospace;
}

/* â”€â”€ Base Reset & Typography â”€â”€ */
*, *::before, *::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
}

body {
	font-family: var(--czpy-font-ui);
	background-color: var(--czpy-bg);
	color: var(--czpy-text);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Remove any default top/bottom spacing around site blocks */
.wp-site-blocks,
body > .wp-site-blocks {
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	margin-bottom: 0 !important;
}

footer.wp-block-group,
.czpy-footer {
	margin-bottom: 0 !important;
}

/* ============================================================
   HEADER
   ============================================================ */
header.wp-block-group,
header > .wp-block-group,
.site-header {
	background: var(--czpy-header-bg) !important;
	border-bottom: 1px solid var(--czpy-header-border);
	position: sticky;
	top: 0;
	z-index: 1000;
	box-shadow: 0 1px 0 var(--czpy-border), 0 2px 8px rgba(0,0,0,0.04);
	margin: 0 !important;
	padding: 0 !important;
}

/* WP constrained layout inner-container — centers content horizontally,
   sets the row height, and vertically centers everything */
.site-header > .wp-block-group__inner-container,
.site-header > div {
	max-width: 1200px !important;
	width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	height: 48px !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	box-sizing: border-box !important;
}

/* The actual inner flex row (brand + nav) */
.site-header .wp-block-group[style*="padding"] {
	display: flex !important;
	align-items: center !important;
	justify-content: space-between !important;
	width: 100% !important;
	height: 48px !important;
	min-height: unset !important;
	max-height: 48px !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
}

/* Nav pushed to the right */
.site-nav,
header .wp-block-navigation,
.site-header .wp-block-navigation {
	margin-left: auto !important;
	display: flex !important;
	align-items: center !important;
	justify-content: flex-end !important;
}

/* Brand / site title */
.site-brand-name .wp-block-site-title,
.site-brand-name,
header .wp-block-site-title {
	font-family: var(--czpy-font-mono) !important;
	font-size: 1.1rem !important;
	font-weight: 700 !important;
	letter-spacing: -0.3px;
	line-height: 1 !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* Brand group — vertically centered */
.site-brand {
	display: flex !important;
	align-items: center !important;
	gap: 0.6rem !important;
	height: 100%;
}

/* Nav — vertically centered */
.site-nav,
header .wp-block-navigation {
	display: flex !important;
	align-items: center !important;
	height: 100%;
}

header .wp-block-site-title a,
.site-brand-name a {
	color: var(--czpy-text) !important;
	text-decoration: none !important;
	display: inline-flex;
	align-items: center;
	gap: 0.15rem;
	transition: color 0.2s ease;
}

/* The "Coder" part stays dark, "Z" gets accent */
header .wp-block-site-title a::before {
	content: '</';
	font-family: var(--czpy-font-mono);
	color: var(--czpy-accent);
	font-size: 0.85em;
	font-weight: 400;
	margin-right: 0.1rem;
	opacity: 0.8;
}

header .wp-block-site-title a::after {
	content: '>';
	font-family: var(--czpy-font-mono);
	color: var(--czpy-accent);
	font-size: 0.85em;
	font-weight: 400;
	margin-left: 0.1rem;
	opacity: 0.8;
}

header .wp-block-site-title a:hover {
	color: var(--czpy-accent) !important;
}

/* Nav links */
.site-nav .wp-block-navigation-item__content,
header .wp-block-navigation a,
header .wp-block-navigation__submenu-container a {
	font-family: var(--czpy-font-ui) !important;
	color: var(--czpy-text-muted) !important;
	text-decoration: none !important;
	font-size: 0.88rem !important;
	font-weight: 500;
	padding: 0.4rem 0.75rem !important;
	border-radius: 6px;
	transition: var(--czpy-transition);
	letter-spacing: 0.1px;
}

header .wp-block-navigation a:hover,
.site-nav .wp-block-navigation-item__content:hover {
	color: var(--czpy-accent) !important;
	background: var(--czpy-accent-subtle) !important;
}

/* Active nav item */
header .wp-block-navigation-item.current-menu-item > a {
	color: var(--czpy-accent) !important;
	background: var(--czpy-accent-badge) !important;
	font-weight: 600;
}

/* ── Dropdown / Submenu ── */

/* Parent item that has children — make it a positioning context */
header .wp-block-navigation-item.has-child {
	position: relative;
	/* Bottom padding creates a hover bridge so the mouse doesn't
	   leave the parent element while travelling toward the dropdown */
	padding-bottom: 12px !important;
	margin-bottom: -12px !important;
}

/* The submenu container — hidden by default */
header .wp-block-navigation__submenu-container {
	position: absolute !important;
	/* Sits flush with the bottom of the padded parent — no gap */
	top: 100% !important;
	left: 0 !important;
	/* Extra top padding so the mouse is still "inside" the dropdown
	   as it crosses from the parent into the panel */
	padding-top: 12px !important;
	min-width: 200px;
	background: transparent !important;
	z-index: 9999 !important;
	/* Hidden state */
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translateY(4px);
	transition: opacity 0.18s ease, transform 0.18s ease, visibility 0.18s ease;
	display: flex !important;
	flex-direction: column !important;
	gap: 0 !important;
}

/* Inner panel — the visible card, separated from the bridge padding */
header .wp-block-navigation__submenu-container > * {
	background: var(--czpy-bg);
}

/* Wrap the actual dropdown items in a visible card */
header .wp-block-navigation__submenu-container::before {
	content: '';
	position: absolute;
	top: 12px; /* matches the padding-top bridge above */
	left: 0;
	right: 0;
	bottom: 0;
	background: var(--czpy-bg);
	border: 1px solid var(--czpy-border);
	border-radius: 10px;
	box-shadow: 0 8px 24px rgba(0,0,0,0.10);
	z-index: -1;
	pointer-events: none;
}

/* Show on hover — the padded parent keeps hover alive across the gap */
header .wp-block-navigation-item.has-child:hover > .wp-block-navigation__submenu-container,
header .wp-block-navigation-item.has-child:focus-within > .wp-block-navigation__submenu-container {
	opacity: 1 !important;
	visibility: visible !important;
	pointer-events: auto !important;
	transform: translateY(0) !important;
}

/* Submenu links */
header .wp-block-navigation__submenu-container .wp-block-navigation-item__content {
	display: block !important;
	padding: 0.5rem 0.85rem !important;
	border-radius: 7px !important;
	font-size: 0.85rem !important;
	color: var(--czpy-text-muted) !important;
	background: transparent !important;
	white-space: nowrap;
	width: 100%;
}

header .wp-block-navigation__submenu-container .wp-block-navigation-item__content:hover {
	color: var(--czpy-accent) !important;
	background: var(--czpy-accent-subtle) !important;
}

/* Chevron arrow on parent items */
header .wp-block-navigation-item.has-child > .wp-block-navigation-item__content .wp-block-navigation__submenu-icon {
	display: inline-flex !important;
	align-items: center;
	margin-left: 0.2rem;
	opacity: 0.55;
	transition: transform 0.18s ease, opacity 0.18s ease;
}

header .wp-block-navigation-item.has-child:hover > .wp-block-navigation-item__content .wp-block-navigation__submenu-icon {
	transform: rotate(180deg);
	opacity: 1;
}

header .wp-block-navigation__submenu-icon svg {
	width: 10px !important;
	height: 10px !important;
	fill: currentColor !important;
}

/* Nested (3rd-level) submenu — opens to the right */
header .wp-block-navigation__submenu-container .wp-block-navigation__submenu-container {
	top: 0 !important;
	left: calc(100% + 4px) !important;
	padding-top: 0 !important;
}

header .wp-block-navigation__submenu-container .wp-block-navigation__submenu-container::before {
	top: 0;
}

/* Mobile hamburger */
header .wp-block-navigation__responsive-container {
	background: var(--czpy-bg);
}

header .wp-block-navigation__responsive-container-open,
header .wp-block-navigation__responsive-container-close {
	color: var(--czpy-text) !important;
}

/* Mobile: submenus stack inline instead of floating */
@media (max-width: 600px) {
	header .wp-block-navigation__submenu-container {
		position: static !important;
		opacity: 1 !important;
		visibility: visible !important;
		pointer-events: auto !important;
		transform: none !important;
		box-shadow: none !important;
		border: none !important;
		border-left: 2px solid var(--czpy-border) !important;
		border-radius: 0 !important;
		background: transparent !important;
		padding: 0 0 0 0.75rem !important;
		margin-top: 0.15rem;
	}
}

/* ============================================================
   HERO SECTION
   ============================================================ */
.hero-section {
	background:
		radial-gradient(ellipse 70% 50% at 80% 10%, rgba(22, 163, 74, 0.12) 0%, transparent 55%),
		radial-gradient(ellipse 60% 40% at 15% 90%, rgba(22, 163, 74, 0.07) 0%, transparent 50%),
		var(--czpy-hero-bg) !important;
	text-align: center;
	position: relative;
	overflow: hidden;
	margin-top: 0 !important;
	padding-top: clamp(32px, 5vw, 60px) !important;
	padding-bottom: clamp(32px, 5vw, 60px) !important;
}

/* Subtle grid */
.hero-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
	background-size: 48px 48px;
	pointer-events: none;
}

.hero-section > * {
	position: relative;
	z-index: 1;
}

/* Override WP constrained layout inner max-width inside hero */
.hero-section > .wp-block-group__inner-container,
.hero-section > [class*="__inner-container"],
.hero-section .wp-block-group__inner-container {
	max-width: 1100px !important;
	width: 100% !important;
}

/* Eyebrow tag */
.hero-eyebrow {
	display: inline-block !important;
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.78rem !important;
	font-weight: 400 !important;
	color: var(--czpy-accent) !important;
	background: rgba(22, 163, 74, 0.12) !important;
	border: 1px solid rgba(22, 163, 74, 0.3) !important;
	padding: 0.35rem 1rem !important;
	border-radius: 100px !important;
	letter-spacing: 1.5px;
	text-transform: uppercase;
	margin-bottom: 1.5rem !important;
}

.hero-section h1 {
	color: var(--czpy-white) !important;
	font-family: var(--czpy-font-ui) !important;
	font-size: clamp(1.6rem, 3.8vw, 3.2rem) !important;
	font-weight: 800 !important;
	line-height: 1.1 !important;
	letter-spacing: -2px;
	white-space: nowrap;
	margin-bottom: 1.25rem;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
	animation: czpy-fadeUp 0.65s cubic-bezier(0.16, 1, 0.3, 1) both;
}

.hero-section h1 strong {
	color: var(--czpy-accent);
	font-style: normal;
}

.hero-section p {
	color: rgba(255,255,255,0.65) !important;
	font-size: clamp(1rem, 1.8vw, 1.2rem) !important;
	line-height: 1.8;
	max-width: 780px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 2.25rem;
	animation: czpy-fadeUp 0.65s cubic-bezier(0.16, 1, 0.3, 1) 0.08s both;
}

/* CTA Buttons */
.wp-block-buttons {
	animation: czpy-fadeUp 0.65s cubic-bezier(0.16, 1, 0.3, 1) 0.18s both;
}

.cta-button .wp-block-button__link,
.cta-button.wp-block-button .wp-block-button__link {
	background: var(--czpy-accent) !important;
	color: #ffffff !important;
	font-family: var(--czpy-font-ui) !important;
	font-weight: 600 !important;
	font-size: 0.9rem !important;
	padding: 12px 28px !important;
	border-radius: 8px !important;
	border: none !important;
	text-decoration: none !important;
	letter-spacing: 0.2px;
	box-shadow: 0 2px 12px rgba(22, 163, 74, 0.35);
	transition: var(--czpy-transition);
}

.cta-button .wp-block-button__link:hover {
	background: var(--czpy-accent-mid) !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(22, 163, 74, 0.4) !important;
}

.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent !important;
	color: rgba(255,255,255,0.8) !important;
	border: 1.5px solid rgba(255,255,255,0.25) !important;
	font-family: var(--czpy-font-ui) !important;
	font-weight: 600 !important;
	font-size: 0.9rem !important;
	padding: 12px 28px !important;
	border-radius: 8px !important;
	text-decoration: none !important;
	transition: var(--czpy-transition);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	border-color: var(--czpy-accent) !important;
	color: var(--czpy-accent) !important;
	transform: translateY(-2px);
}

/* ============================================================
   MAIN / PAGE BACKGROUND
   ============================================================ */
main.wp-block-group,
body,
.wp-site-blocks {
	background: var(--czpy-bg);
}

main.wp-block-group {
	margin-top: 0 !important;
	padding-top: 0 !important;
}

/* Articles section */
.articles-section {
	background: var(--czpy-bg-soft);
	padding-top: clamp(3rem, 5vw, 4.5rem) !important;
	padding-bottom: clamp(3rem, 5vw, 4.5rem) !important;
}

/* Section heading */
.articles-section h2.wp-block-heading,
.section-heading {
	font-family: var(--czpy-font-ui) !important;
	font-weight: 800 !important;
	font-size: clamp(1.5rem, 3vw, 2.2rem) !important;
	color: var(--czpy-text) !important;
	text-align: center;
	margin-bottom: 2.75rem !important;
	letter-spacing: -0.5px;
	position: relative;
	padding-bottom: 1rem;
}

.articles-section h2.wp-block-heading::after,
.section-heading::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 40px;
	height: 3px;
	background: var(--czpy-accent);
	border-radius: 2px;
}

/* ============================================================
   ARTICLE CARDS
   ============================================================ */
.posts-grid,
.wp-block-post-template {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 1.5rem !important;
	width: 100%;
	align-items: start;
}

.article-card,
.wp-block-post-template li {
	background: var(--czpy-card-bg) !important;
	border: 1px solid var(--czpy-card-border);
	border-radius: var(--czpy-radius-lg);
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
	position: relative;
	transition: transform 0.25s ease, box-shadow 0.25s ease, border-color 0.25s ease;
	list-style: none !important;
	box-shadow: var(--czpy-shadow-sm);
}

.article-card:hover,
.wp-block-post-template li:hover {
	transform: translateY(-5px);
	box-shadow: var(--czpy-shadow-hover);
	border-color: var(--czpy-accent);
}

/* Featured image */
.article-card .wp-block-post-featured-image img,
.wp-block-post-template li .wp-block-post-featured-image img {
	width: 100%;
	height: 210px;
	object-fit: cover;
	display: block;
	transition: transform 0.35s ease;
}

.article-card:hover .wp-block-post-featured-image img,
.wp-block-post-template li:hover .wp-block-post-featured-image img {
	transform: scale(1.04);
}

/* Card content */
.card-content {
	display: flex !important;
	flex-direction: column !important;
	flex-grow: 1;
	padding: 1.25rem 1.4rem 0 !important;
	gap: 0.6rem;
	background: var(--czpy-card-bg);
}

/* Post title */
.article-card h3,
.article-card .wp-block-post-title,
.wp-block-post-template li .wp-block-post-title {
	font-family: var(--czpy-font-ui) !important;
	font-size: 1rem !important;
	font-weight: 700 !important;
	line-height: 1.5 !important;
	color: var(--czpy-text) !important;
	margin: 0 !important;
	transition: color 0.2s ease;
}

.article-card h3 a,
.article-card .wp-block-post-title a,
.wp-block-post-template li .wp-block-post-title a {
	color: inherit !important;
	text-decoration: none !important;
}

.article-card:hover h3,
.article-card:hover .wp-block-post-title,
.wp-block-post-template li:hover .wp-block-post-title {
	color: var(--czpy-accent) !important;
}

/* Excerpt */
.post-excerpt,
.article-card .wp-block-post-excerpt,
.wp-block-post-template li .wp-block-post-excerpt {
	color: var(--czpy-text-muted) !important;
	font-size: 0.875rem !important;
	line-height: 1.65;
	flex-grow: 1;
	margin: 0 !important;
}

.post-excerpt p,
.wp-block-post-excerpt__excerpt {
	margin: 0 !important;
	color: var(--czpy-text-muted) !important;
}

.wp-block-post-excerpt__more-link {
	color: var(--czpy-accent) !important;
	font-size: 0.8rem !important;
	font-weight: 600;
	text-decoration: none !important;
	display: inline-flex;
	align-items: center;
	gap: 0.25rem;
	margin-top: 0.4rem;
	transition: gap 0.2s ease;
}

.wp-block-post-excerpt__more-link:hover {
	gap: 0.5rem;
}

/* Category tags */
.post-categories,
.wp-block-post-terms {
	display: flex !important;
	gap: 0.35rem;
	flex-wrap: wrap;
	margin: 0 !important;
}

.post-categories a,
.wp-block-post-terms a,
.czpy-cat-badge {
	display: inline-block;
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.68rem !important;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.6px;
	color: var(--czpy-accent) !important;
	background: var(--czpy-accent-badge);
	border: 1px solid rgba(22, 163, 74, 0.2);
	padding: 0.2rem 0.55rem !important;
	border-radius: 4px;
	text-decoration: none !important;
	transition: background 0.2s ease, border-color 0.2s ease;
	white-space: nowrap;
}

/* Category card link — no underline, inherits card hover */
.czpy-cat-card-link {
	text-decoration: none !important;
	display: block;
}

.czpy-cat-card-link:hover .wp-block-post-title {
	color: var(--czpy-accent) !important;
}

.czpy-cat-card-link:hover .article-card {
	transform: translateY(-5px);
	box-shadow: var(--czpy-shadow-hover);
	border-color: var(--czpy-accent);
}

/* Strip ghost card from the <li> wrapper — only .article-card inside is the visual card */
/* More specific selector to beat .wp-block-post-template li (0,1,1) with (0,2,1) */
.wp-block-post-template li.czpy-cat-li {
	background: transparent !important;
	border: none !important;
	box-shadow: none !important;
	border-radius: 0 !important;
	padding: 0 !important;
	height: auto !important;
}

.wp-block-post-template li.czpy-cat-li:hover {
	transform: none !important;
	box-shadow: none !important;
	border-color: transparent !important;
}

/* Compact category cards */
.czpy-cat-card-link .article-card {
	height: auto !important;
	min-height: unset !important;
}

.czpy-cat-card-link .card-content {
	padding: 0.65rem 0.85rem 0 !important;
	gap: 0.25rem !important;
	flex-grow: 0 !important;
}

.czpy-cat-card-link .wp-block-post-title {
	font-size: 0.88rem !important;
}

.czpy-cat-card-link .post-date {
	font-size: 0.68rem !important;
	margin-top: 0.2rem !important;
}

.post-categories a:hover,
.wp-block-post-terms a:hover {
	background: rgba(22, 163, 74, 0.15);
	border-color: rgba(22, 163, 74, 0.4);
}

/* Archive post card link — full-size cards (no compact overrides) */
.czpy-post-card-link {
	text-decoration: none !important;
	display: block;
}

.czpy-post-card-link:hover .wp-block-post-title {
	color: var(--czpy-accent) !important;
}

.czpy-post-card-link:hover .article-card {
	transform: translateY(-5px);
	box-shadow: var(--czpy-shadow-hover);
	border-color: var(--czpy-accent);
}

/* Pagination */
/* Archive post cards — shrink to content, no stretch */
.czpy-post-card-link .article-card {
	height: auto !important;
	min-height: unset !important;
}

.czpy-post-card-link .card-content {
	flex-grow: 0 !important;
	padding-bottom: 0 !important;
}

.czpy-post-card-link .post-excerpt,
.czpy-post-card-link .wp-block-post-excerpt {
	flex-grow: 0 !important;
}

.czpy-pagination {
	margin-top: 2.5rem;
	display: flex;
	justify-content: center;
}

.czpy-pagination .page-numbers {
	display: flex;
	gap: 0.4rem;
	list-style: none;
	padding: 0;
	margin: 0;
	align-items: center;
}

.czpy-pagination .page-numbers li a,
.czpy-pagination .page-numbers li span {
	display: inline-flex;
	align-items: center;
	padding: 0.45rem 0.85rem;
	border-radius: 7px;
	font-size: 0.85rem;
	font-family: var(--czpy-font-ui);
	border: 1px solid var(--czpy-card-border);
	color: var(--czpy-text-muted);
	text-decoration: none;
	transition: var(--czpy-transition);
}

.czpy-pagination .page-numbers li a:hover {
	border-color: var(--czpy-accent);
	color: var(--czpy-accent);
	background: var(--czpy-accent-subtle);
}

.czpy-pagination .page-numbers li span.current {
	background: var(--czpy-accent);
	color: #fff;
	border-color: var(--czpy-accent);
	font-weight: 600;
}

/* Archive section heading */
.archive-section .wp-block-query-title {
	font-family: var(--czpy-font-ui) !important;
	font-weight: 800 !important;
	font-size: clamp(1.5rem, 3vw, 2.2rem) !important;
	color: var(--czpy-text) !important;
	text-align: center;
	margin-bottom: 2.75rem !important;
	letter-spacing: -0.5px;
	position: relative;
	padding-bottom: 1rem;
}

.archive-section .wp-block-query-title::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 40px;
	height: 3px;
	background: var(--czpy-accent);
	border-radius: 2px;
}

/* Post date */
.post-date,
.wp-block-post-date {
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.75rem !important;
	color: var(--czpy-text-faint) !important;
	margin: 0 !important;
}

.post-date time,
.wp-block-post-date time {
	color: inherit !important;
}

/* ============================================================
   PAGINATION
   ============================================================ */
.wp-block-query-pagination {
	display: flex !important;
	justify-content: center;
	align-items: center;
	gap: 0.4rem;
	margin-top: 3rem !important;
	flex-wrap: wrap;
}

.wp-block-query-pagination-previous,
.wp-block-query-pagination-next,
.wp-block-query-pagination-numbers a,
.wp-block-query-pagination-numbers span {
	font-family: var(--czpy-font-mono);
	font-size: 0.82rem;
	font-weight: 600;
	color: var(--czpy-text-muted);
	background: var(--czpy-bg);
	border: 1px solid var(--czpy-border);
	padding: 0.45rem 0.9rem;
	border-radius: 7px;
	text-decoration: none !important;
	transition: var(--czpy-transition);
	display: inline-flex;
	align-items: center;
}

.wp-block-query-pagination-previous:hover,
.wp-block-query-pagination-next:hover,
.wp-block-query-pagination-numbers a:hover {
	border-color: var(--czpy-accent);
	color: var(--czpy-accent) !important;
	transform: translateY(-1px);
}

.wp-block-query-pagination-numbers .current,
.wp-block-query-pagination-numbers span.page-numbers {
	background: var(--czpy-accent);
	color: #fff !important;
	border-color: var(--czpy-accent);
}

/* ============================================================
   SINGLE POST
   ============================================================ */

/* Keep single post body readable — constrain to 740px centered */
.single .wp-block-post-content,
.single main.wp-block-group > .wp-block-post-content,
.wp-block-post-content {
	max-width: 740px;
	margin-left: auto;
	margin-right: auto;
	color: var(--czpy-text) !important;
}

.wp-block-post-content h1,
.wp-block-post-content h2,
.wp-block-post-content h3,
.wp-block-post-content h4,
.wp-block-post-content h5 {
	font-family: var(--czpy-font-ui) !important;
	color: var(--czpy-text) !important;
	font-weight: 700;
	line-height: 1.3;
	margin-top: 2rem;
	margin-bottom: 0.9rem;
}

.wp-block-post-content h2 { font-size: 1.6rem; }
.wp-block-post-content h3 { font-size: 1.3rem; }
.wp-block-post-content h4 { font-size: 1.1rem; }

.wp-block-post-content p {
	color: var(--czpy-text);
	line-height: 1.85;
	margin-bottom: 1.2rem;
}

.wp-block-post-content a {
	color: var(--czpy-accent);
	text-decoration: underline;
	text-decoration-color: rgba(22, 163, 74, 0.4);
	text-underline-offset: 3px;
	transition: text-decoration-color 0.2s ease;
}

.wp-block-post-content a:hover {
	text-decoration-color: var(--czpy-accent);
}

/* Inline code */
.wp-block-post-content code,
code {
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.86em;
	background: #f0fdf4;
	color: var(--czpy-accent-dark);
	padding: 0.15em 0.45em;
	border-radius: 4px;
	border: 1px solid rgba(22, 163, 74, 0.2);
}

/* Code blocks */
.wp-block-code,
pre {
	font-family: var(--czpy-font-mono) !important;
	background: #0f172a !important;
	border: 1px solid #1e293b;
	border-radius: var(--czpy-radius);
	padding: 1.5rem !important;
	overflow-x: auto;
	font-size: 0.875rem !important;
	line-height: 1.7;
	color: #e2e8f0 !important;
	margin: 1.5rem 0;
	position: relative;
}

.wp-block-code::before {
	content: '';
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--czpy-accent), transparent);
	border-radius: var(--czpy-radius) var(--czpy-radius) 0 0;
}

.wp-block-code code,
pre code {
	background: transparent !important;
	border: none !important;
	padding: 0 !important;
	font-size: inherit !important;
	color: inherit !important;
}

/* Blockquote */
.wp-block-quote,
blockquote {
	border-left: 3px solid var(--czpy-accent) !important;
	background: var(--czpy-bg-soft);
	border-radius: 0 var(--czpy-radius) var(--czpy-radius) 0;
	padding: 1.1rem 1.4rem !important;
	margin: 1.5rem 0 !important;
	font-style: italic;
}

.wp-block-quote p,
blockquote p {
	color: var(--czpy-text-muted) !important;
	margin: 0 !important;
}

/* Lists */
.wp-block-post-content ul,
.wp-block-post-content ol {
	color: var(--czpy-text);
	padding-left: 1.4rem;
	margin-bottom: 1.2rem;
	line-height: 1.85;
}

.wp-block-post-content li { margin-bottom: 0.35rem; }

/* Post title (single) */
.wp-block-post-title {
	font-family: var(--czpy-font-ui) !important;
	font-weight: 800 !important;
	color: var(--czpy-text) !important;
	line-height: 1.2 !important;
	font-size: clamp(1.75rem, 4vw, 2.75rem) !important;
	letter-spacing: -0.5px;
}

/* Featured image (single) */
.wp-block-post-featured-image {
	border-radius: var(--czpy-radius-lg);
	overflow: hidden;
}

.wp-block-post-featured-image img {
	width: 100%;
	display: block;
}

/* ============================================================
   SINGLE POST – ARTICLE PAGE LAYOUT
   ============================================================ */

/* Article header: constrained, centered */
.czpy-article-header {
	max-width: 740px;
	margin-left: auto;
	margin-right: auto;
}

.czpy-article-header .post-categories,
.czpy-article-header .wp-block-post-terms {
	margin-top: 2.5rem !important;
}

.czpy-article-header .wp-block-post-title {
	font-size: clamp(1.75rem, 4vw, 2.6rem) !important;
	line-height: 1.2 !important;
	letter-spacing: -0.5px;
}

/* Meta row — date · author on same line */
.czpy-meta-row {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0;
}

.czpy-meta-row .post-date,
.czpy-meta-row .wp-block-post-date {
	font-size: 0.8rem !important;
}

/* Separator dot between date and author */
.czpy-meta-row .post-date::after,
.czpy-meta-row .wp-block-post-date::after {
	content: '·';
	margin: 0 0.6rem;
	color: var(--czpy-text-faint);
}

.czpy-meta-row .czpy-author-inline,
.czpy-meta-row .wp-block-post-author {
	display: flex !important;
	align-items: center !important;
	gap: 0.4rem !important;
	padding: 0 !important;
	background: transparent !important;
	border: none !important;
	margin: 0 !important;
}

.czpy-meta-row .wp-block-post-author__name,
.czpy-meta-row .wp-block-post-author__name a {
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.8rem !important;
	font-weight: 600 !important;
	color: var(--czpy-text-faint) !important;
	text-decoration: none !important;
}

/* Hero image: subtle shadow */
.czpy-hero-image .wp-block-post-featured-image,
.czpy-hero-image.wp-block-post-featured-image {
	box-shadow: 0 8px 40px rgba(0, 0, 0, 0.12) !important;
	border-radius: 14px !important;
	overflow: hidden !important;
}

/* Article footer: tags + author card */
.czpy-article-footer {
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}

/* Tags row with top divider */
.czpy-tags-row {
	border-top: 1px solid var(--czpy-border);
}

/* Author card */
.czpy-author-card.wp-block-post-author {
	display: flex !important;
	flex-direction: row !important;
	align-items: flex-start !important;
	gap: 1.25rem !important;
	background: var(--czpy-bg-soft) !important;
	border: 1px solid var(--czpy-border) !important;
	border-left: 3px solid var(--czpy-accent) !important;
	border-radius: var(--czpy-radius-lg) !important;
	padding: 1.5rem !important;
	margin: 0 !important;
}

.czpy-author-card .wp-block-post-author__avatar img {
	border-radius: 50% !important;
	border: 2px solid var(--czpy-border) !important;
	width: 64px !important;
	height: 64px !important;
	object-fit: cover;
	flex-shrink: 0;
}

.czpy-author-card .wp-block-post-author__content {
	flex: 1;
}

.czpy-author-card .wp-block-post-author__name,
.czpy-author-card .wp-block-post-author__name a {
	font-family: var(--czpy-font-ui) !important;
	font-size: 0.95rem !important;
	font-weight: 700 !important;
	color: var(--czpy-text) !important;
	text-decoration: none !important;
	display: block;
	margin-bottom: 0.35rem !important;
}

.czpy-author-card .wp-block-post-author__bio {
	font-size: 0.875rem !important;
	color: var(--czpy-text-muted) !important;
	line-height: 1.65 !important;
	margin: 0 !important;
}

/* Post navigation bar */
.czpy-post-nav {
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
	border-top: 1px solid var(--czpy-border);
	padding-top: 2rem;
}

.czpy-post-nav .wp-block-post-navigation-link a {
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.82rem !important;
	font-weight: 600;
	color: var(--czpy-text-muted) !important;
	background: var(--czpy-bg);
	border: 1px solid var(--czpy-border);
	border-radius: var(--czpy-radius);
	padding: 0.55rem 1rem !important;
	text-decoration: none !important;
	transition: var(--czpy-transition);
	display: inline-block;
}

.czpy-post-nav .wp-block-post-navigation-link a:hover {
	border-color: var(--czpy-accent);
	color: var(--czpy-accent) !important;
}

@media (max-width: 600px) {
	.czpy-author-card.wp-block-post-author {
		flex-direction: column !important;
	}
	.czpy-post-nav {
		flex-direction: column;
		align-items: stretch;
	}
}

/* ============================================================
   FOOTER
   ============================================================ */
footer.wp-block-group,
.czpy-footer {
	background: #0f172a !important;
	color: #cbd5e1 !important;
	border-top: 3px solid var(--czpy-accent);
	position: relative;
}

/* Column headings */
footer .czpy-footer-col-heading,
footer .wp-block-heading {
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.68rem !important;
	font-weight: 700 !important;
	letter-spacing: 1.8px;
	text-transform: uppercase;
	color: #94a3b8 !important;
	margin-bottom: 1.1rem !important;
}

/* Body text */
footer p,
footer li {
	color: #94a3b8 !important;
	font-size: 0.875rem;
	line-height: 1.8;
}

/* Links */
footer a {
	color: #94a3b8 !important;
	text-decoration: none !important;
	transition: color 0.2s ease;
}

footer a:hover {
	color: var(--czpy-accent) !important;
}

/* Brand title */
footer .czpy-footer-brand a,
footer .czpy-footer-brand,
footer .wp-block-site-title a,
footer .wp-block-site-title {
	font-family: var(--czpy-font-mono) !important;
	font-size: 1.05rem !important;
	font-weight: 700 !important;
	color: #f1f5f9 !important;
	text-decoration: none !important;
	letter-spacing: -0.2px;
}

/* Brand tagline */
footer .czpy-footer-tagline {
	color: #94a3b8 !important;
	font-size: 0.855rem !important;
	line-height: 1.75 !important;
	max-width: 320px;
}

/* Footer nav links */
footer .czpy-footer-nav .wp-block-navigation__container,
footer .czpy-footer-nav ul {
	display: flex !important;
	flex-direction: column !important;
	gap: 0.5rem !important;
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

footer .czpy-footer-nav a {
	font-size: 0.875rem !important;
	color: #94a3b8 !important;
	transition: color 0.2s ease, padding-left 0.2s ease;
	display: inline-block;
}

footer .czpy-footer-nav a:hover {
	color: var(--czpy-accent) !important;
	padding-left: 3px;
}

/* Categories list */
footer .czpy-footer-cats {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

footer .czpy-footer-cats li {
	margin-bottom: 0.5rem !important;
	color: #94a3b8 !important;
}

footer .czpy-footer-cats li a {
	font-size: 0.875rem !important;
	color: #94a3b8 !important;
	transition: color 0.2s ease, padding-left 0.2s ease;
	display: inline-block;
}

footer .czpy-footer-cats li a:hover {
	color: var(--czpy-accent) !important;
	padding-left: 3px;
}

/* Separator */
footer .czpy-footer-sep,
footer .wp-block-separator {
	background: #1e293b !important;
	border-color: #1e293b !important;
	height: 1px !important;
	margin: 2.5rem 0 1.5rem !important;
	opacity: 1 !important;
}

/* Bottom bar copyright */
footer .czpy-footer-copy {
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.77rem !important;
	color: #64748b !important;
	margin: 0 !important;
}

/* ============================================================
   MISC: SEARCH, TAG CLOUD, COMMENTS, SEPARATOR
   ============================================================ */
.wp-block-search__input {
	background: var(--czpy-bg) !important;
	border: 1px solid var(--czpy-border-mid) !important;
	border-radius: 8px !important;
	color: var(--czpy-text) !important;
	padding: 0.6rem 1rem !important;
	font-family: var(--czpy-font-ui) !important;
	font-size: 0.9rem !important;
	transition: border-color 0.2s ease;
}

.wp-block-search__input:focus {
	border-color: var(--czpy-accent) !important;
	outline: none !important;
	box-shadow: 0 0 0 3px var(--czpy-accent-glow) !important;
}

.wp-block-search__button {
	background: var(--czpy-accent) !important;
	color: #fff !important;
	border: none !important;
	border-radius: 8px !important;
	padding: 0.6rem 1.2rem !important;
	font-weight: 700 !important;
	font-family: var(--czpy-font-ui) !important;
	cursor: pointer;
	transition: var(--czpy-transition);
}

.wp-block-search__button:hover {
	background: var(--czpy-accent-mid) !important;
}

.wp-block-tag-cloud a {
	font-family: var(--czpy-font-mono) !important;
	font-size: 0.78rem !important;
	color: var(--czpy-text-muted) !important;
	background: var(--czpy-bg-muted);
	border: 1px solid var(--czpy-border);
	padding: 0.3rem 0.7rem !important;
	border-radius: 6px;
	text-decoration: none !important;
	transition: var(--czpy-transition);
	display: inline-block;
	margin: 0.15rem;
}

.wp-block-tag-cloud a:hover {
	color: var(--czpy-accent) !important;
	border-color: rgba(22, 163, 74, 0.4);
	background: var(--czpy-accent-badge);
}

.wp-block-separator {
	background: var(--czpy-border) !important;
	border-color: var(--czpy-border) !important;
	height: 1px !important;
	opacity: 1;
}

.wp-block-image figcaption {
	font-family: var(--czpy-font-mono);
	font-size: 0.78rem;
	color: var(--czpy-text-faint);
	text-align: center;
	margin-top: 0.5rem;
}

.wp-block-comments .wp-block-heading {
	font-family: var(--czpy-font-ui) !important;
	font-weight: 700;
	color: var(--czpy-text) !important;
	font-size: 1.2rem !important;
	border-bottom: 1px solid var(--czpy-border);
	padding-bottom: 0.75rem;
	margin-bottom: 1.5rem !important;
}

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes czpy-fadeUp {
	from { opacity: 0; transform: translateY(18px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   RESPONSIVE â€” TABLET (â‰¤ 1024px)
   ============================================================ */
@media (max-width: 1024px) {
	.posts-grid,
	.wp-block-post-template {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 1.25rem !important;
	}
}

/* ============================================================
   RESPONSIVE â€” TABLET (â‰¤ 768px)
   ============================================================ */
@media (max-width: 768px) {
	.posts-grid,
	.wp-block-post-template {
		grid-template-columns: repeat(2, 1fr) !important;
		gap: 1rem !important;
	}

	.hero-section h1 { letter-spacing: -0.75px; }

	.wp-block-post-content h2 { font-size: 1.4rem; }
	.wp-block-post-content h3 { font-size: 1.2rem; }

	footer .wp-block-columns {
		flex-direction: column;
		gap: 2rem !important;
	}
}

/* ============================================================
   RESPONSIVE â€” MOBILE (â‰¤ 600px)
   ============================================================ */
@media (max-width: 600px) {
	.posts-grid,
	.wp-block-post-template {
		grid-template-columns: 1fr !important;
		gap: 1rem !important;
	}

	.hero-section {
		padding-top: 3.5rem !important;
		padding-bottom: 3.5rem !important;
		padding-left: 1.25rem !important;
		padding-right: 1.25rem !important;
	}

	.hero-section h1 {
		font-size: 1.9rem !important;
		letter-spacing: -0.5px;
	}

	.hero-section p { font-size: 0.92rem !important; }

	.cta-button .wp-block-button__link {
		padding: 11px 22px !important;
		font-size: 0.85rem !important;
	}

	.article-card .wp-block-post-featured-image img,
	.wp-block-post-template li .wp-block-post-featured-image img {
		height: 175px;
	}

	.card-content { padding: 1rem !important; }

	.wp-block-code,
	pre { font-size: 0.78rem !important; padding: 1rem !important; }

	header .wp-block-site-title a::before,
	header .wp-block-site-title a::after { display: none; }
}

/* ============================================================
   RESPONSIVE â€” SMALL (â‰¤ 380px)
   ============================================================ */
@media (max-width: 380px) {
	.hero-section h1 { font-size: 1.4rem !important; white-space: normal !important; letter-spacing: -0.5px; }
}

/* ============================================================
   ACCESSIBILITY
   ============================================================ */
@media (prefers-reduced-motion: reduce) {
	*, *::before, *::after {
		animation-duration: 0.01ms !important;
		transition-duration: 0.01ms !important;
	}
}

:focus-visible {
	outline: 2px solid var(--czpy-accent);
	outline-offset: 3px;
	border-radius: 4px;
}
