/* =========================================================================
 * ClearSkyPress - Material Design 3 component styles.
 *
 * Implements the card / button / ripple / navigation / typography building
 * blocks. All colors reference CSS variables defined in style.css and
 * overridden live by the Customizer.
 * ========================================================================= */

/* -------------------------------------------------------------------------
 * Layout containers.
 * ------------------------------------------------------------------------- */
.site {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}

.site-content {
	flex: 1 0 auto;
	padding: 0;
}

.csp-container,
.csp-container-full {
	width: 100%;
	max-width: var(--csp-max-width);
	margin-inline: auto;
	padding-inline: clamp(16px, 4vw, 32px);
}

.csp-container-full {
	max-width: 100%;
}

.csp-blog-section {
	padding-block: clamp(24px, 5vw, 56px);
}

.csp-section-header {
	margin-bottom: clamp(16px, 4vw, 32px);
	text-align: center;
}

.csp-section-title {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	font-size: clamp(1.4rem, 3vw, 2rem);
	color: var(--csp-text);
}

.csp-section-title .material-symbols-rounded {
	color: var(--csp-primary);
}

/* Content grid: posts + sidebar */
.csp-content-grid-wrap {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(20px, 3vw, 36px);
}

@media (min-width: 992px) {
	.csp-content-grid-wrap {
		grid-template-columns: minmax(0, 1fr) 320px;
	}
	body.layout-full .csp-content-grid-wrap {
		grid-template-columns: minmax(0, 1fr) 340px;
	}
}

/* -------------------------------------------------------------------------
 * Material Symbols defaults.
 * ------------------------------------------------------------------------- */
.material-symbols-rounded {
	font-family: 'Material Symbols Rounded';
	font-weight: normal;
	font-style: normal;
	line-height: 1;
	letter-spacing: normal;
	text-transform: none;
	display: inline-block;
	white-space: nowrap;
	word-wrap: normal;
	direction: ltr;
	font-variation-settings: 'FILL' 0, 'wght' 400, 'GRAD' 0, 'opsz' 24;
	vertical-align: middle;
	font-size: 20px;
}

/* -------------------------------------------------------------------------
 * Header / Navigation bar.
 * ------------------------------------------------------------------------- */
.site-header {
	z-index: 100;
	background: var(--csp-surface);
	box-shadow: var(--csp-shadow-1);
	transition: background var(--csp-transition), box-shadow var(--csp-transition);
}

.csp-header-inner {
	width: 100%;
	margin-inline: auto;
	padding-inline: clamp(16px, 4vw, 32px);
}

.csp-header-row {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	padding-block: 14px;
}

/* Branding */
.site-branding {
	display: flex;
	align-items: center;
	gap: 12px;
	min-width: 0;
}

.custom-logo-link {
	display: inline-flex;
	align-items: center;
}

.custom-logo {
	max-height: 48px;
	width: auto;
}

.csp-text-logo {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-weight: 700;
	font-size: 1.25rem;
	color: var(--csp-text);
}

.csp-text-logo-mark {
	color: var(--csp-primary);
	font-size: 28px;
}

.csp-text-logo-text {
	white-space: nowrap;
}

.site-description {
	display: none;
}

body.transparent-nav .site-header {
	background: transparent;
	box-shadow: none;
}

body.transparent-nav .site-header.scrolled {
	background: var(--csp-surface);
	box-shadow: var(--csp-shadow-1);
}

/* Desktop nav */
.main-navigation {
	display: flex;
	align-items: center;
}

.csp-nav-menu {
	display: none;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: 4px;
}

@media (min-width: 992px) {
	.csp-nav-menu {
		display: flex;
	}
}

.csp-nav-item {
	position: relative;
}

.csp-nav-link {
	position: relative;
	display: inline-flex;
	align-items: center;
	padding: 10px 16px;
	border-radius: var(--csp-radius-sm);
	color: var(--csp-text);
	font-weight: 500;
	font-size: 0.95rem;
	overflow: hidden;
	transition: background var(--csp-transition), color var(--csp-transition);
}

.csp-nav-link:hover,
.csp-nav-item.is-active > .csp-nav-link {
	background: color-mix(in srgb, var(--csp-primary) 10%, transparent);
	color: var(--csp-primary-dark);
}

.csp-nav-label {
	position: relative;
	z-index: 1;
}

/* Ripple element */
.csp-ripple-mask {
	position: absolute;
	inset: 0;
	overflow: hidden;
	pointer-events: none;
}

.csp-ripple {
	position: absolute;
	border-radius: 50%;
	transform: scale(0);
	background: color-mix(in srgb, var(--csp-primary) 30%, transparent);
	opacity: 0;
}

.ripple.is-rippling .csp-ripple,
.csp-nav-link.is-rippling .csp-ripple {
	animation: csp-ripple 0.6s ease-out forwards;
}

@keyframes csp-ripple {
	from { transform: scale(0); opacity: 0.6; }
	to   { transform: scale(2.4); opacity: 0; }
}

/* Header actions */
.csp-header-actions {
	display: flex;
	align-items: center;
	gap: 8px;
	margin-left: auto;
}

@media (min-width: 992px) {
	.csp-header-actions {
		margin-left: 0;
	}
}

.csp-icon-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: none;
	background: transparent;
	border-radius: 50%;
	color: var(--csp-text);
	cursor: pointer;
	position: relative;
	overflow: hidden;
	transition: background var(--csp-transition);
}

.csp-icon-btn:hover {
	background: color-mix(in srgb, var(--csp-primary) 12%, transparent);
}

.csp-icon-btn .material-symbols-rounded {
	font-size: 24px;
}

/* Slide-down search bar */
.csp-search-bar {
	position: absolute;
	top: 100%;
	left: 0;
	right: 0;
	background: var(--csp-surface);
	box-shadow: var(--csp-shadow-2);
	padding: 16px clamp(16px, 4vw, 32px);
	z-index: 99;
	border-top: 1px solid var(--csp-border);
}

.csp-search-bar[hidden] { display: none; }

/* Hamburger toggle */
.csp-menu-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	border: none;
	background: transparent;
	border-radius: 50%;
	color: var(--csp-text);
	cursor: pointer;
	overflow: hidden;
	position: relative;
	transition: background var(--csp-transition);
}

.csp-menu-toggle:hover { background: color-mix(in srgb, var(--csp-primary) 12%, transparent); }

.csp-menu-toggle .csp-menu-icon { font-size: 26px; }

.csp-menu-toggle .csp-menu-icon-close { display: none; }

body.csp-drawer-open .csp-menu-toggle .csp-menu-icon-open { display: none; }
body.csp-drawer-open .csp-menu-toggle .csp-menu-icon-close { display: inline-block; }

@media (min-width: 992px) {
	.csp-menu-toggle { display: none; }
}

/* Mobile drawer */
.csp-mobile-nav {
	position: fixed;
	top: 0;
	right: 0;
	bottom: 0;
	width: min(320px, 85vw);
	background: var(--csp-surface);
	box-shadow: var(--csp-shadow-3);
	z-index: 200;
	transform: translateX(100%);
	transition: transform var(--csp-transition);
	overflow-y: auto;
	padding: 80px 16px 24px;
	display: flex !important;
	flex-direction: column;
	gap: 16px;
}

.csp-mobile-nav[hidden] { display: flex !important; transform: translateX(100%); pointer-events: none; visibility: hidden; }

body.csp-drawer-open .csp-mobile-nav {
	transform: translateX(0);
	pointer-events: auto;
	visibility: visible;
}

.csp-mobile-menu {
	list-style: none;
	margin: 0;
	padding: 0;
}

.csp-mobile-menu li {
	border-bottom: 1px solid var(--csp-border);
}

.csp-mobile-menu a {
	display: block;
	padding: 14px 12px;
	color: var(--csp-text);
	font-weight: 500;
}

.csp-mobile-menu a:hover { background: color-mix(in srgb, var(--csp-primary) 8%, transparent); }

.csp-mobile-nav .csp-search-form {
	margin-top: 8px;
}

/* Backdrop */
.csp-nav-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(15, 23, 42, 0.45);
	z-index: 150;
	opacity: 0;
	transition: opacity var(--csp-transition);
}

.csp-nav-backdrop[hidden] { display: block; opacity: 0; pointer-events: none; }

body.csp-drawer-open .csp-nav-backdrop {
	opacity: 1;
	pointer-events: auto;
}

body.csp-drawer-open { overflow: hidden; }

@media (min-width: 992px) {
	body.csp-drawer-open { overflow: auto; }
}

/* -------------------------------------------------------------------------
 * Hero section.
 * ------------------------------------------------------------------------- */
.csp-hero {
	padding-block: clamp(48px, 10vw, 96px) clamp(32px, 6vw, 56px);
	background: linear-gradient(160deg, color-mix(in srgb, var(--csp-primary-light) 25%, transparent), color-mix(in srgb, var(--csp-primary) 12%, transparent));
	border-radius: 0 0 var(--csp-radius-lg) var(--csp-radius-lg);
	text-align: center;
	margin-bottom: clamp(20px, 4vw, 40px);
}

.csp-hero-inner {
	max-width: 760px;
	margin-inline: auto;
}

.csp-hero-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	background: var(--csp-surface);
	color: var(--csp-primary-dark);
	font-weight: 600;
	font-size: 0.8rem;
	padding: 6px 14px;
	border-radius: 999px;
	box-shadow: var(--csp-shadow-1);
	margin-bottom: 18px;
	letter-spacing: 0.04em;
	text-transform: uppercase;
}

.csp-hero-title {
	font-size: clamp(2rem, 5vw, 3.2rem);
	line-height: 1.15;
	margin-bottom: 16px;
}

.csp-hero-subtitle {
	font-size: clamp(1.05rem, 2vw, 1.3rem);
	color: var(--csp-text-muted);
	max-width: 560px;
	margin-inline: auto;
}

.csp-hero-actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 12px;
	margin-top: 28px;
}

/* -------------------------------------------------------------------------
 * Homepage bottom CTA banner.
 * ------------------------------------------------------------------------- */
.csp-homepage-cta {
	margin-top: clamp(40px, 6vw, 64px);
	border-radius: var(--csp-radius-lg);
	background: linear-gradient(135deg, var(--csp-primary), var(--csp-primary-dark));
	color: var(--csp-on-primary);
	box-shadow: var(--csp-shadow-3);
	overflow: hidden;
}

.csp-homepage-cta-inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
	padding: clamp(24px, 5vw, 44px);
}

.csp-homepage-cta-text {
	display: flex;
	align-items: center;
	gap: 16px;
	flex: 1;
	min-width: 240px;
}

.csp-cta-icon {
	font-size: 40px;
	color: var(--csp-on-primary);
	flex-shrink: 0;
	opacity: 0.9;
}

.csp-cta-title {
	color: var(--csp-on-primary);
	font-size: clamp(1.3rem, 3vw, 1.8rem);
	margin: 0 0 4px;
}

.csp-cta-subtitle {
	color: rgba(255, 255, 255, 0.85);
	margin: 0;
}

.csp-homepage-cta-action .csp-btn {
	background: var(--csp-surface);
	color: var(--csp-primary-dark);
	box-shadow: var(--csp-shadow-2);
}

.csp-homepage-cta-action .csp-btn:hover {
	background: var(--csp-surface);
	color: var(--csp-primary);
	transform: translateY(-2px);
}

/* -------------------------------------------------------------------------
 * Buttons.
 * ------------------------------------------------------------------------- */
.csp-btn {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	padding: 12px 22px;
	min-height: 44px;
	border: none;
	border-radius: var(--csp-radius);
	font-family: inherit;
	font-size: 0.95rem;
	font-weight: 500;
	cursor: pointer;
	text-decoration: none;
	overflow: hidden;
	transition: box-shadow var(--csp-transition), background var(--csp-transition), transform var(--csp-transition);
	white-space: nowrap;
}

.csp-btn:active { transform: translateY(1px); }

.csp-btn-filled {
	background: var(--csp-primary);
	color: var(--csp-on-primary);
	box-shadow: var(--csp-shadow-1);
}

.csp-btn-filled:hover {
	background: var(--csp-primary-dark);
	color: var(--csp-on-primary);
	box-shadow: var(--csp-shadow-2);
}

.csp-btn-tonal {
	background: color-mix(in srgb, var(--csp-primary) 12%, var(--csp-surface));
	color: var(--csp-primary-dark);
}

.csp-btn-tonal:hover {
	background: color-mix(in srgb, var(--csp-primary) 18%, var(--csp-surface));
	color: var(--csp-primary-dark);
}

.csp-btn-text {
	background: transparent;
	color: var(--csp-primary-dark);
	padding-inline: 12px;
}

.csp-btn-text:hover {
	background: color-mix(in srgb, var(--csp-primary) 10%, transparent);
}

.csp-btn-outlined {
	background: transparent;
	color: var(--csp-primary-dark);
	border: 1px solid color-mix(in srgb, var(--csp-primary) 40%, transparent);
}

.csp-btn-outlined:hover {
	background: color-mix(in srgb, var(--csp-primary) 8%, transparent);
}

.csp-btn .material-symbols-rounded { font-size: 20px; }

.csp-spinner {
	display: none;
	animation: csp-spin 1s linear infinite;
}

@keyframes csp-spin {
	from { transform: rotate(0deg); }
	to   { transform: rotate(360deg); }
}

.is-loading .csp-spinner { display: inline-block; }
.is-loading .csp-btn-label { opacity: 0.6; }

/* -------------------------------------------------------------------------
 * Cards.
 * ------------------------------------------------------------------------- */
.csp-card {
	background: var(--csp-surface);
	border-radius: var(--csp-radius);
	box-shadow: var(--csp-shadow-1);
	overflow: hidden;
	transition: box-shadow var(--csp-transition), transform var(--csp-transition);
}

.widget.csp-card { padding: 20px; }

/* -------------------------------------------------------------------------
 * Posts grid + cards.
 * ------------------------------------------------------------------------- */
.csp-posts-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(16px, 3vw, 28px);
}

@media (min-width: 768px) {
	.csp-posts-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 992px) {
	.csp-posts-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* When sidebar is present the main grid is narrower, so collapse to 2 cols on desktop */
@media (min-width: 992px) {
	body:not(.layout-full) .csp-content-grid-wrap .csp-posts-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

.csp-post-card {
	display: flex;
	flex-direction: column;
}

.csp-post-card:hover {
	box-shadow: var(--csp-shadow-3);
	transform: translateY(-2px);
}

.csp-post-card-media {
	position: relative;
	aspect-ratio: 16 / 9;
	overflow: hidden;
	background: color-mix(in srgb, var(--csp-primary) 10%, var(--csp-bg));
}

.csp-post-card-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform var(--csp-transition);
}

.csp-post-card:hover .csp-post-card-media img {
	transform: scale(1.04);
}

.csp-post-card-placeholder {
	width: 100%;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: color-mix(in srgb, var(--csp-primary) 50%, transparent);
}

.csp-post-card-placeholder .material-symbols-rounded {
	font-size: 48px;
}

.csp-post-card-cat-wrap {
	position: absolute;
	top: 12px;
	left: 12px;
}

.csp-chip,
.csp-card-cat {
	display: inline-flex;
	align-items: center;
	padding: 5px 12px;
	background: color-mix(in srgb, var(--csp-primary) 14%, var(--csp-surface));
	color: var(--csp-primary-dark);
	font-size: 0.78rem;
	font-weight: 600;
	border-radius: 999px;
	text-decoration: none;
	box-shadow: var(--csp-shadow-1);
	transition: background var(--csp-transition);
}

.csp-chip:hover,
.csp-card-cat:hover {
	background: color-mix(in srgb, var(--csp-primary) 22%, var(--csp-surface));
	color: var(--csp-primary-dark);
}

.csp-post-card-body {
	display: flex;
	flex-direction: column;
	gap: 10px;
	padding: 20px;
	flex: 1;
}

.csp-post-card-title {
	font-size: 1.2rem;
	line-height: 1.35;
	margin: 0;
}

.csp-post-card-title a {
	color: var(--csp-text);
}

.csp-post-card-title a:hover {
	color: var(--csp-primary-dark);
}

.csp-post-card-excerpt {
	color: var(--csp-text-muted);
	font-size: 0.95rem;
	margin: 0;
}

.csp-post-card-excerpt p { margin: 0; }

.csp-post-card-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	font-size: 0.83rem;
	color: var(--csp-text-muted);
	margin-top: auto;
	padding-top: 8px;
}

.csp-post-card-meta .material-symbols-rounded,
.entry-meta .material-symbols-rounded {
	font-size: 16px;
	vertical-align: -3px;
	margin-right: 4px;
	color: var(--csp-primary);
}

.csp-post-card-meta a { color: var(--csp-text-muted); }
.csp-post-card-meta a:hover { color: var(--csp-primary-dark); }

.csp-post-card-action {
	padding-top: 4px;
}

.csp-post-card-action .csp-btn-text {
	padding: 6px 8px;
	margin: -6px -8px 0;
}

/* -------------------------------------------------------------------------
 * Load more.
 * ------------------------------------------------------------------------- */
.csp-load-more-wrap {
	display: flex;
	justify-content: center;
	margin-top: clamp(28px, 4vw, 48px);
}

.csp-load-more[disabled],
.csp-load-more.is-loading {
	cursor: default;
	opacity: 0.85;
}

/* -------------------------------------------------------------------------
 * Single post.
 * ------------------------------------------------------------------------- */
.csp-single,
.csp-page {
	padding: clamp(20px, 4vw, 40px);
	margin-bottom: clamp(24px, 4vw, 40px);
}

.entry-header { margin-bottom: 24px; }
.entry-title { margin-block: 6px 12px; }

.csp-single .entry-title { font-size: clamp(1.8rem, 4vw, 2.6rem); }

.csp-entry-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 16px;
	font-size: 0.9rem;
	color: var(--csp-text-muted);
	margin-top: 12px;
}

.entry-featured {
	margin-block: 0 28px;
	border-radius: var(--csp-radius);
	overflow: hidden;
}

.entry-featured img {
	width: 100%;
	height: auto;
}

.entry-content {
	font-size: 1.05rem;
	line-height: 1.8;
	color: var(--csp-text);
}

.entry-content > *:first-child { margin-top: 0; }

.entry-content h2,
.entry-content h3,
.entry-content h4 { margin-top: 1.6em; }

.entry-content img { border-radius: var(--csp-radius-sm); }

.entry-content blockquote {
	margin: 1.5em 0;
	padding: 16px 22px;
	border-left: 4px solid var(--csp-primary);
	background: color-mix(in srgb, var(--csp-primary) 6%, transparent);
	border-radius: var(--csp-radius-sm);
	color: var(--csp-text);
	font-style: italic;
}

.entry-content code {
	background: color-mix(in srgb, var(--csp-text) 8%, transparent);
	padding: 2px 6px;
	border-radius: 4px;
	font-size: 0.9em;
}

.entry-content pre {
	background: color-mix(in srgb, var(--csp-text) 6%, transparent);
	padding: 16px;
	border-radius: var(--csp-radius-sm);
	overflow-x: auto;
}

.entry-content pre code { background: transparent; padding: 0; }

.entry-content a {
	color: var(--csp-primary-dark);
	text-decoration: underline;
	text-underline-offset: 2px;
}

.entry-content a:hover { color: var(--csp-primary); }

.entry-footer {
	margin-top: 32px;
	padding-top: 16px;
	border-top: 1px solid var(--csp-border);
	font-size: 0.9rem;
	color: var(--csp-text-muted);
}

.csp-tag-list a {
	display: inline-block;
	margin: 0 6px 6px 0;
	padding: 4px 10px;
	background: color-mix(in srgb, var(--csp-text) 6%, transparent);
	border-radius: 999px;
	font-size: 0.82rem;
	color: var(--csp-text-muted);
}

.csp-tag-list a:hover {
	background: color-mix(in srgb, var(--csp-primary) 14%, transparent);
	color: var(--csp-primary-dark);
}

/* Breadcrumbs */
.csp-breadcrumbs {
	font-size: 0.85rem;
	color: var(--csp-text-muted);
	margin-bottom: 14px;
}

.csp-breadcrumbs ol {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	padding: 0;
	margin: 0;
	gap: 4px;
}

.csp-breadcrumbs li { display: inline-flex; align-items: center; }
.csp-breadcrumbs a { color: var(--csp-text-muted); }
.csp-breadcrumbs a:hover { color: var(--csp-primary-dark); }
.csp-breadcrumbs .sep { color: var(--csp-primary); font-size: 18px; }
.csp-breadcrumbs [aria-current="page"] { color: var(--csp-text); font-weight: 500; }

/* Post navigation */
.navigation.post-navigation {
	margin: 32px 0;
	display: grid;
	gap: 12px;
}

@media (min-width: 768px) {
	.navigation.post-navigation {
		grid-template-columns: 1fr 1fr;
	}
}

.navigation.post-navigation .nav-previous,
.navigation.post-navigation .nav-next {
	background: var(--csp-surface);
	padding: 16px 20px;
	border-radius: var(--csp-radius);
	box-shadow: var(--csp-shadow-1);
	transition: box-shadow var(--csp-transition);
}

.navigation.post-navigation .nav-previous:hover,
.navigation.post-navigation .nav-next:hover {
	box-shadow: var(--csp-shadow-2);
}

.navigation.post-navigation .nav-next { text-align: right; }

.navigation.post-navigation .nav-subtitle {
	font-size: 0.8rem;
	color: var(--csp-primary);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.navigation.post-navigation .nav-title {
	color: var(--csp-text);
	font-weight: 600;
	font-size: 1rem;
}

/* -------------------------------------------------------------------------
 * Author box.
 * ------------------------------------------------------------------------- */
.csp-author-box {
	display: flex;
	gap: 20px;
	align-items: flex-start;
	padding: 24px;
	margin-bottom: clamp(24px, 4vw, 40px);
	flex-wrap: wrap;
}

.csp-author-avatar { flex-shrink: 0; }

.csp-avatar {
	border-radius: 50%;
	box-shadow: var(--csp-shadow-1);
}

.csp-author-info { flex: 1; min-width: 200px; }

.csp-author-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 0.78rem;
	color: var(--csp-primary);
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-weight: 600;
}

.csp-author-name { margin: 4px 0 8px; font-size: 1.3rem; }
.csp-author-name a { color: var(--csp-text); }
.csp-author-name a:hover { color: var(--csp-primary-dark); }

.csp-author-bio { color: var(--csp-text-muted); }

.csp-author-meta {
	display: flex;
	gap: 16px;
	margin-top: 12px;
	font-size: 0.85rem;
	color: var(--csp-text-muted);
}

.csp-author-stat .material-symbols-rounded {
	color: var(--csp-primary);
	font-size: 16px;
	vertical-align: -3px;
	margin-right: 4px;
}

/* -------------------------------------------------------------------------
 * Comments.
 * ------------------------------------------------------------------------- */
.csp-comments {
	padding: 24px;
	margin-bottom: clamp(24px, 4vw, 40px);
}

.comments-title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 1.4rem;
	margin-bottom: 20px;
}

.comments-title .material-symbols-rounded { color: var(--csp-primary); }

.comment-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.comment-list .children {
	list-style: none;
	padding-left: 0;
	margin-left: 0;
}

@media (min-width: 768px) {
	.comment-list .children { padding-left: 40px; }
}

.csp-comment {
	padding: 16px 0;
	border-bottom: 1px solid var(--csp-border);
}

.csp-comment:last-child { border-bottom: none; }

.csp-comment-meta {
	display: flex;
	align-items: center;
	margin-bottom: 8px;
}

.csp-comment-author {
	display: flex;
	align-items: center;
	gap: 10px;
}

.csp-comment-author img {
	border-radius: 50%;
}

.csp-comment-author-info { display: flex; flex-direction: column; }
.csp-comment-author-info .fn { color: var(--csp-text); }
.csp-comment-author-info .fn a { color: var(--csp-primary-dark); }
.csp-comment-time { color: var(--csp-text-muted); font-size: 0.82rem; }

.csp-comment-content { padding-left: 58px; color: var(--csp-text); }
.csp-comment-content p { margin: 0 0 8px; }

.csp-comment-actions {
	padding-left: 58px;
	margin-top: 6px;
	font-size: 0.85rem;
}

.csp-comment-actions a {
	color: var(--csp-primary-dark);
	margin-right: 14px;
	font-weight: 500;
}

.csp-comment-awaiting-moderation {
	display: inline-block;
	padding: 4px 12px;
	background: color-mix(in srgb, #f59e0b 14%, transparent);
	color: #b45309;
	border-radius: 999px;
	font-size: 0.82rem;
	margin-bottom: 6px;
}

/* Comment form */
.comment-reply-title {
	display: flex;
	align-items: center;
	gap: 8px;
	font-size: 1.2rem;
	margin-bottom: 14px;
}

.comment-reply-title .material-symbols-rounded { color: var(--csp-primary); }

.csp-field label {
	display: block;
	font-size: 0.85rem;
	font-weight: 500;
	margin-bottom: 6px;
	color: var(--csp-text);
}

.csp-field input[type="text"],
.csp-field input[type="email"],
.csp-field input[type="url"],
.csp-field input[type="search"],
.csp-field textarea,
.csp-search-field,
input[type="search"] {
	width: 100%;
	padding: 12px 14px;
	border: 1px solid var(--csp-border);
	border-radius: var(--csp-radius-sm);
	background: var(--csp-surface);
	color: var(--csp-text);
	font-family: inherit;
	font-size: 0.95rem;
	transition: border-color var(--csp-transition), box-shadow var(--csp-transition);
}

.csp-field input:focus,
.csp-field textarea:focus,
.csp-search-field:focus {
	outline: none;
	border-color: var(--csp-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--csp-primary) 22%, transparent);
}

.csp-field { margin-bottom: 14px; }

.comment-form-cookies-consent { display: flex; align-items: center; gap: 8px; }
.comment-form-cookies-consent input { width: auto; }

/* -------------------------------------------------------------------------
 * Search form (sidebar / general).
 * ------------------------------------------------------------------------- */
.csp-search-form { width: 100%; }

.csp-search-input-wrap {
	display: flex;
	align-items: center;
	gap: 0;
	border: 1px solid var(--csp-border);
	border-radius: 999px;
	background: var(--csp-surface);
	padding: 4px 4px 4px 14px;
	transition: border-color var(--csp-transition), box-shadow var(--csp-transition);
}

.csp-search-input-wrap:focus-within {
	border-color: var(--csp-primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--csp-primary) 22%, transparent);
}

.csp-search-icon { color: var(--csp-text-muted); font-size: 20px; }

.csp-search-input-wrap .csp-search-field {
	border: none;
	background: transparent;
	border-radius: 0;
	padding: 8px 10px;
	flex: 1;
	box-shadow: none;
}

.csp-search-submit {
	flex-shrink: 0;
	padding: 8px 18px;
	border-radius: 999px;
	min-height: 38px;
}

/* -------------------------------------------------------------------------
 * Sidebar / Widgets.
 * ------------------------------------------------------------------------- */
.csp-sidebar {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.widget {
	margin: 0 0 20px;
}

.widget:last-child { margin-bottom: 0; }

.widget-title {
	font-size: 1.05rem;
	margin: 0 0 14px;
	padding-bottom: 8px;
	border-bottom: 2px solid color-mix(in srgb, var(--csp-primary) 20%, transparent);
	color: var(--csp-text);
}

.widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.widget li {
	padding: 8px 0;
	border-bottom: 1px solid var(--csp-border);
	font-size: 0.93rem;
}

.widget li:last-child { border-bottom: none; }

.widget_recent_entries ul li,
.widget_recent_comments ul li { padding-block: 10px; }

.widget_recent_entries .post-date {
	display: block;
	font-size: 0.8rem;
	color: var(--csp-text-muted);
	margin-top: 2px;
}

.csp-recent-posts { list-style: none; padding: 0; margin: 0; }

.csp-recent-post {
	border-bottom: 1px solid var(--csp-border);
	padding: 8px 0;
}

.csp-recent-post:last-child { border-bottom: none; }

.csp-recent-post-link {
	display: flex;
	gap: 12px;
	align-items: center;
	color: var(--csp-text);
}

.csp-recent-thumb {
	flex-shrink: 0;
	width: 56px;
	height: 56px;
	border-radius: var(--csp-radius-sm);
	overflow: hidden;
}

.csp-recent-thumb img { width: 100%; height: 100%; object-fit: cover; }

.csp-recent-text { display: flex; flex-direction: column; min-width: 0; }

.csp-recent-title {
	font-size: 0.92rem;
	font-weight: 500;
	line-height: 1.3;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.csp-recent-date { font-size: 0.78rem; color: var(--csp-text-muted); margin-top: 2px; }

.csp-category-list,
.widget_categories ul { list-style: none; padding: 0; }

.widget_categories li,
.csp-category-list li {
	padding: 6px 0;
	display: flex;
	justify-content: space-between;
	gap: 8px;
}

.widget_tag_cloud a,
.tagcloud a {
	display: inline-block;
	margin: 2px 4px 2px 0;
	padding: 4px 10px;
	background: color-mix(in srgb, var(--csp-primary) 10%, transparent);
	color: var(--csp-primary-dark);
	border-radius: 999px;
	font-size: 0.82rem !important;
}

/* -------------------------------------------------------------------------
 * Footer.
 * ------------------------------------------------------------------------- */
.site-footer {
	margin-top: clamp(40px, 6vw, 80px);
	background: var(--csp-surface);
	border-top: 1px solid var(--csp-border);
}

.csp-footer-widgets {
	padding-block: clamp(32px, 5vw, 56px);
	border-bottom: 1px solid var(--csp-border);
}

.csp-footer-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
}

@media (min-width: 768px) {
	.csp-footer-grid { grid-template-columns: repeat(3, 1fr); }
}

.footer-widget-title {
	font-size: 1rem;
	color: var(--csp-text);
	margin-bottom: 14px;
}

.csp-footer-bottom {
	padding-block: 20px;
	background: color-mix(in srgb, var(--csp-text) 4%, var(--csp-surface));
}

.csp-footer-bottom-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
}

.csp-copyright-area { flex: 1; min-width: 200px; }

.csp-copyright { margin: 0; font-size: 0.88rem; color: var(--csp-text-muted); }
.csp-copyright a { color: var(--csp-primary-dark); }

.csp-social-links {
	display: flex;
	gap: 8px;
}

.csp-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--csp-primary) 8%, transparent);
	color: var(--csp-primary-dark);
	overflow: hidden;
	transition: background var(--csp-transition), transform var(--csp-transition);
}

.csp-social-link:hover {
	background: var(--csp-primary);
	color: var(--csp-on-primary);
	transform: translateY(-2px);
}

.csp-social-icon {
	width: 20px;
	height: 20px;
	fill: currentColor;
}

.csp-footer-menu-list {
	list-style: none;
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin: 0;
	padding: 0;
}

.csp-footer-menu-list a { color: var(--csp-text-muted); font-size: 0.88rem; }
.csp-footer-menu-list a:hover { color: var(--csp-primary-dark); }

/* -------------------------------------------------------------------------
 * FAB: back to top.
 * ------------------------------------------------------------------------- */
.csp-fab {
	position: fixed;
	right: 22px;
	bottom: 22px;
	z-index: 90;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border: none;
	border-radius: 16px;
	background: var(--csp-primary);
	color: var(--csp-on-primary);
	box-shadow: var(--csp-shadow-3);
	cursor: pointer;
	overflow: hidden;
	opacity: 0;
	transform: translateY(20px) scale(0.8);
	pointer-events: none;
	transition: opacity var(--csp-transition), transform var(--csp-transition), background var(--csp-transition);
}

.csp-fab.is-visible {
	opacity: 1;
	transform: translateY(0) scale(1);
	pointer-events: auto;
}

.csp-fab:hover { background: var(--csp-primary-dark); }

/* -------------------------------------------------------------------------
 * Empty / 404 states.
 * ------------------------------------------------------------------------- */
.csp-empty-state,
.csp-404 {
	text-align: center;
	padding: clamp(40px, 6vw, 80px) 24px;
	margin: clamp(24px, 4vw, 48px) 0;
}

.csp-empty-icon,
.csp-404-icon {
	font-size: 64px;
	color: var(--csp-primary);
	margin-bottom: 16px;
}

.csp-empty-state .csp-search-form,
.csp-404 .csp-search-form {
	max-width: 480px;
	margin: 24px auto 0;
}

.csp-404-widgets {
	display: grid;
	gap: 24px;
	margin-top: 32px;
	max-width: 600px;
	margin-inline: auto;
	text-align: left;
}

@media (min-width: 768px) {
	.csp-404-widgets { grid-template-columns: 1fr 1fr; }
}

/* -------------------------------------------------------------------------
 * Archive headers.
 * ------------------------------------------------------------------------- */
.csp-archive-header {
	text-align: center;
	margin-bottom: clamp(24px, 4vw, 40px);
	padding: clamp(24px, 4vw, 40px);
	background: linear-gradient(160deg, color-mix(in srgb, var(--csp-primary-light) 18%, transparent), color-mix(in srgb, var(--csp-primary) 8%, transparent));
	border-radius: var(--csp-radius-lg);
}

.csp-archive-icon {
	font-size: 40px;
	color: var(--csp-primary);
}

.csp-archive-header .page-title { margin: 8px 0; }
.csp-archive-header .archive-description { color: var(--csp-text-muted); margin: 0 auto; max-width: 600px; }

.csp-search-term {
	color: var(--csp-primary-dark);
	background: color-mix(in srgb, var(--csp-primary) 12%, transparent);
	padding: 2px 10px;
	border-radius: 6px;
}

/* -------------------------------------------------------------------------
 * Pagination.
 * ------------------------------------------------------------------------- */
.pagination,
.navigation.pagination {
	margin-top: clamp(28px, 4vw, 40px);
	display: flex;
	justify-content: center;
}

.pagination .nav-links {
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
	justify-content: center;
}

.pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 12px;
	border-radius: var(--csp-radius-sm);
	background: var(--csp-surface);
	color: var(--csp-text);
	box-shadow: var(--csp-shadow-1);
	font-weight: 500;
	transition: background var(--csp-transition), color var(--csp-transition);
}

.pagination .page-numbers.current {
	background: var(--csp-primary);
	color: var(--csp-on-primary);
}

.pagination .page-numbers:not(.current):hover {
	background: color-mix(in srgb, var(--csp-primary) 12%, transparent);
	color: var(--csp-primary-dark);
}

.pagination .page-numbers.dots { background: transparent; box-shadow: none; }

/* -------------------------------------------------------------------------
 * Responsive tweaks.
 * ------------------------------------------------------------------------- */
@media (max-width: 768px) {
	.csp-post-card-body { padding: 16px; }
	.csp-author-box { padding: 18px; }
	.csp-comment-content,
	.csp-comment-actions { padding-left: 0; }
	.csp-comment-author { align-items: flex-start; }
}

/* Fade-in for AJAX-loaded cards */
.csp-fade-in {
	opacity: 0;
	transform: translateY(12px);
	transition: opacity 0.4s ease, transform 0.4s ease;
}

.csp-fade-in.csp-fade-in-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Reduce motion: respect user preference. */
@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* =========================================================================
 * v1.1 UI Polish — refined Material Design 3 enhancements.
 * These layered rules sit last so they win cascade ties without rewriting
 * the whole stylesheet. Safe to extend; everything degrades gracefully.
 * ========================================================================= */

/* ---- Typography refinement ---- */
body {
	font-feature-settings: "kern" 1, "liga" 1;
	letter-spacing: -0.005em;
}

h1, h2, h3, h4, h5, h6 {
	letter-spacing: -0.015em;
}

/* ---- Header: subtle gradient border & smoother blur ---- */
.site-header {
	backdrop-filter: saturate(180%) blur(8px);
	-webkit-backdrop-filter: saturate(180%) blur(8px);
}

body:not(.transparent-nav) .site-header {
	background: color-mix(in srgb, var(--csp-surface) 92%, transparent) !important;
}

.csp-text-logo-text {
	background: linear-gradient(135deg, var(--csp-primary), var(--csp-primary-dark));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	font-weight: 700;
}

/* Active nav link: filled pill */
.csp-nav-link {
	border-radius: 999px;
	font-weight: 500;
}

.csp-nav-item.is-active > .csp-nav-link {
	background: var(--csp-primary);
	color: var(--csp-on-primary) !important;
	box-shadow: var(--csp-shadow-1);
}

/* ---- Hero: layered glow + entrance animation ---- */
.csp-hero {
	position: relative;
	overflow: hidden;
	border-radius: 0 0 var(--csp-radius-lg) var(--csp-radius-lg);
	animation: csp-hero-rise 0.6s cubic-bezier(0.2, 0, 0, 1);
}

.csp-hero::before {
	content: "";
	position: absolute;
	top: -40%;
	right: -10%;
	width: 60%;
	height: 180%;
	background: radial-gradient(circle, color-mix(in srgb, var(--csp-primary-light) 35%, transparent), transparent 65%);
	pointer-events: none;
	z-index: 0;
}

.csp-hero::after {
	content: "";
	position: absolute;
	bottom: -50%;
	left: -10%;
	width: 50%;
	height: 150%;
	background: radial-gradient(circle, color-mix(in srgb, var(--csp-primary) 18%, transparent), transparent 60%);
	pointer-events: none;
	z-index: 0;
}

.csp-hero-inner { position: relative; z-index: 1; }

.csp-hero-title {
	background: linear-gradient(135deg, var(--csp-text) 30%, var(--csp-primary-dark));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	font-weight: 800;
}

@keyframes csp-hero-rise {
	from { opacity: 0; transform: translateY(20px); }
	to   { opacity: 1; transform: translateY(0); }
}

/* ---- Section title: refined icon chip ---- */
.csp-section-title .material-symbols-rounded {
	background: linear-gradient(135deg, var(--csp-primary), var(--csp-primary-dark));
	color: #fff;
	width: 36px;
	height: 36px;
	font-size: 20px;
	line-height: 36px;
	text-align: center;
	border-radius: 50%;
	box-shadow: var(--csp-shadow-1);
}

/* ---- Buttons: refined hover lift + smoother ripple ---- */
.csp-btn {
	font-weight: 600;
	letter-spacing: 0.01em;
}

.csp-btn-filled {
	background: linear-gradient(135deg, var(--csp-primary), var(--csp-primary-dark));
	background-size: 200% 200%;
	background-position: 0% 0%;
	transition: background-position var(--csp-transition), box-shadow var(--csp-transition), transform var(--csp-transition);
}

.csp-btn-filled:hover {
	background: linear-gradient(135deg, var(--csp-primary), var(--csp-primary-dark));
	background-position: 100% 100%;
	transform: translateY(-2px);
	box-shadow: var(--csp-shadow-3);
}

/* ---- Post cards: gradient overlay on hover, refined shadow ---- */
.csp-post-card {
	border-radius: var(--csp-radius);
	position: relative;
}

.csp-post-card::after {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: var(--csp-radius);
	pointer-events: none;
	box-shadow: 0 0 0 1px transparent inset;
	transition: box-shadow var(--csp-transition);
}

.csp-post-card:hover::after {
	box-shadow: 0 0 0 1px color-mix(in srgb, var(--csp-primary) 25%, transparent) inset;
}

.csp-post-card-media::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(to top, rgba(15, 23, 42, 0.35), transparent 40%);
	opacity: 0;
	transition: opacity var(--csp-transition);
	pointer-events: none;
}

.csp-post-card:hover .csp-post-card-media::after {
	opacity: 1;
}

/* Category chip floats above overlay with shadow */
.csp-post-card-cat-wrap { z-index: 2; }

.csp-card-cat {
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	background: color-mix(in srgb, var(--csp-surface) 88%, transparent) !important;
}

.csp-post-card-title a {
	background-image: linear-gradient(var(--csp-primary), var(--csp-primary));
	background-size: 0% 2px;
	background-repeat: no-repeat;
	background-position: 0 100%;
	transition: background-size var(--csp-transition), color var(--csp-transition);
}

.csp-post-card-title a:hover {
	background-size: 100% 2px;
	color: var(--csp-primary-dark);
}

/* ---- Pagination: pill numbers ---- */
.pagination .page-numbers {
	border-radius: 999px;
	font-weight: 600;
	transition: all var(--csp-transition);
}

/* ---- Comments: avatars with subtle ring ---- */
.csp-comment-author img,
.csp-avatar {
	box-shadow: 0 0 0 2px var(--csp-surface), 0 0 0 4px color-mix(in srgb, var(--csp-primary) 35%, transparent);
}

/* ---- Inputs: refined focus ring ---- */
.csp-field input:focus,
.csp-field textarea:focus,
.csp-search-field:focus,
.csp-search-input-wrap:focus-within {
	border-color: var(--csp-primary);
	box-shadow: 0 0 0 4px color-mix(in srgb, var(--csp-primary) 18%, transparent);
}

/* ---- Author box: gradient avatar backdrop ---- */
.csp-author-avatar {
	position: relative;
}

.csp-author-avatar::before {
	content: "";
	position: absolute;
	inset: -8px;
	background: radial-gradient(circle, color-mix(in srgb, var(--csp-primary) 25%, transparent), transparent 70%);
	border-radius: 50%;
	z-index: -1;
}

/* ---- Breadcrumbs: refined separator ---- */
.csp-breadcrumbs .sep {
	background: linear-gradient(135deg, var(--csp-primary-light), var(--csp-primary-dark));
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* ---- Footer: subtle top gradient line ---- */
.site-footer {
	position: relative;
}

.site-footer::before {
	content: "";
	position: absolute;
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 90%;
	max-width: var(--csp-max-width);
	height: 1px;
	background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--csp-primary) 50%, transparent), transparent);
}

.csp-social-link {
	transition: all var(--csp-transition);
}

.csp-social-link:hover {
	transform: translateY(-3px) scale(1.08);
	box-shadow: var(--csp-shadow-2);
}

/* ---- FAB back-to-top: smoother reveal + hover ---- */
.csp-fab {
	border-radius: 16px;
	background: linear-gradient(135deg, var(--csp-primary), var(--csp-primary-dark));
}

.csp-fab:hover {
	transform: translateY(0) scale(1.08);
}

/* ---- Homepage CTA banner: animated shimmer on hover ---- */
.csp-homepage-cta {
	position: relative;
	overflow: hidden;
	transition: transform var(--csp-transition), box-shadow var(--csp-transition);
}

.csp-homepage-cta:hover {
	transform: translateY(-3px);
	box-shadow: 0 20px 40px -10px rgba(44, 107, 191, 0.4);
}

.csp-homepage-cta::before {
	content: "";
	position: absolute;
	top: -50%;
	left: -50%;
	width: 200%;
	height: 200%;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.18), transparent 50%);
	transform: translateX(-100%);
	transition: transform 0.8s ease;
	pointer-events: none;
}

.csp-homepage-cta:hover::before {
	transform: translateX(100%);
}

.csp-cta-icon {
	animation: csp-pulse 2.4s ease-in-out infinite;
}

@keyframes csp-pulse {
	0%, 100% { transform: scale(1); opacity: 0.9; }
	50%      { transform: scale(1.08); opacity: 1; }
}

/* ---- Sidebar widgets: subtle accent strip ---- */
.widget.csp-card {
	position: relative;
	overflow: hidden;
}

.widget.csp-card::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 4px;
	height: 100%;
	background: linear-gradient(180deg, var(--csp-primary), var(--csp-primary-light));
	opacity: 0.85;
}

.widget.csp-card { padding-left: 24px; }

/* ---- 404 / empty state: floating animation ---- */
.csp-404-icon,
.csp-empty-icon {
	animation: csp-float 3.5s ease-in-out infinite;
}

@keyframes csp-float {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-8px); }
}

/* ---- Search bar: smoother slide-down ---- */
.csp-search-bar {
	transition: transform var(--csp-transition), opacity var(--csp-transition);
	transform: translateY(-8px);
	opacity: 0;
}

/* The toggle removes [hidden] in JS; here we ensure smooth appearance */
.csp-search-bar:not([hidden]) {
	transform: translateY(0);
	opacity: 1;
}

/* ---- Mobile drawer: refined shadow + smoother slide ---- */
.csp-mobile-nav {
	box-shadow: -10px 0 40px -10px rgba(15, 23, 42, 0.25);
}

.csp-mobile-menu a {
	border-radius: var(--csp-radius-sm);
	transition: all var(--csp-transition);
}

.csp-mobile-menu a:hover {
	padding-left: 18px;
}

/* ---- Archive header: subtle inner glow ---- */
.csp-archive-header {
	position: relative;
	overflow: hidden;
}

.csp-archive-header::before {
	content: "";
	position: absolute;
	top: -40%;
	right: -10%;
	width: 50%;
	height: 180%;
	background: radial-gradient(circle, color-mix(in srgb, var(--csp-primary-light) 25%, transparent), transparent 60%);
	pointer-events: none;
}

/* ---- Reading progress hint on single posts ---- */
.csp-single .entry-title {
	position: relative;
	display: inline-block;
}

.csp-single .entry-title::after {
	content: "";
	display: block;
	width: 48px;
	height: 4px;
	border-radius: 2px;
	background: linear-gradient(90deg, var(--csp-primary), var(--csp-primary-light));
	margin-top: 10px;
}

/* ---- Selection color ---- */
::selection {
	background: color-mix(in srgb, var(--csp-primary) 30%, transparent);
	color: var(--csp-text);
}

/* ---- Custom scrollbar (webkit) ---- */
@media (min-width: 768px) {
	* {
		scrollbar-width: thin;
		scrollbar-color: color-mix(in srgb, var(--csp-primary) 35%, transparent) transparent;
	}

	*::-webkit-scrollbar {
		width: 10px;
		height: 10px;
	}

	*::-webkit-scrollbar-track {
		background: transparent;
	}

	*::-webkit-scrollbar-thumb {
		background-color: color-mix(in srgb, var(--csp-primary) 35%, transparent);
		border-radius: 999px;
		border: 2px solid transparent;
		background-clip: content-box;
	}

	*::-webkit-scrollbar-thumb:hover {
		background-color: color-mix(in srgb, var(--csp-primary) 55%, transparent);
		background-clip: content-box;
	}
}


/* -------------------------------------------------------------------------
 * Material Design 3 deep polish layer.
 * ------------------------------------------------------------------------- */
.site-header {
	background: color-mix(in srgb, var(--csp-surface-container-low) 86%, transparent);
	border-bottom: 1px solid color-mix(in srgb, var(--csp-outline-variant) 62%, transparent);
	box-shadow: none;
	backdrop-filter: blur(18px) saturate(1.25);
	-webkit-backdrop-filter: blur(18px) saturate(1.25);
}

body.transparent-nav .site-header.scrolled,
.site-header.scrolled,
body.sticky-nav-active .site-header { box-shadow: var(--csp-elevation-2); }

.csp-header-row { min-height: 72px; padding-block: 10px; }

.csp-text-logo {
	min-height: 48px;
	padding: 6px 12px 6px 6px;
	border-radius: var(--csp-radius-full);
	background: color-mix(in srgb, var(--csp-primary-container) 58%, transparent);
	color: var(--csp-on-primary-container);
}

.csp-text-logo-mark {
	display: inline-grid;
	place-items: center;
	width: 36px;
	height: 36px;
	border-radius: var(--csp-radius-full);
	background: var(--csp-primary);
	color: var(--csp-on-primary);
	box-shadow: var(--csp-elevation-1);
}

.csp-nav-menu {
	gap: 8px;
	padding: 4px;
	border-radius: var(--csp-radius-full);
	background: color-mix(in srgb, var(--csp-surface-container) 74%, transparent);
}

.csp-nav-link {
	min-height: 40px;
	padding: 8px 18px;
	border-radius: var(--csp-radius-full);
	color: var(--csp-text-muted);
}

.csp-nav-link::before,
.csp-btn::before,
.csp-icon-btn::before,
.csp-fab::before,
.csp-social-link::before,
.pagination .page-numbers::before,
.page-links a::before,
.page-links .post-page-numbers::before {
	content: "";
	position: absolute;
	inset: 0;
	border-radius: inherit;
	background: currentColor;
	opacity: 0;
	pointer-events: none;
	transition: opacity var(--csp-transition);
}

.csp-nav-link:hover::before,
.csp-btn:hover::before,
.csp-icon-btn:hover::before,
.csp-fab:hover::before,
.csp-social-link:hover::before,
.pagination .page-numbers:hover::before,
.page-links a:hover::before { opacity: var(--csp-state-hover); }

.csp-nav-link:active::before,
.csp-btn:active::before,
.csp-icon-btn:active::before,
.csp-fab:active::before { opacity: var(--csp-state-pressed); }

.csp-nav-item.is-active > .csp-nav-link,
.current-menu-item > .csp-nav-link,
.current_page_item > .csp-nav-link {
	background: var(--csp-secondary-container);
	color: var(--csp-on-secondary-container);
	box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--csp-primary) 12%, transparent);
}

.csp-icon-btn,
.csp-menu-toggle {
	border-radius: var(--csp-radius-full);
	background: var(--csp-surface-container-high);
	color: var(--csp-primary-dark);
	box-shadow: none;
}

.csp-mobile-nav {
	background: var(--csp-surface-container-low);
	border-left: 1px solid var(--csp-outline-variant);
	border-radius: var(--csp-radius-xl) 0 0 var(--csp-radius-xl);
}

.csp-mobile-menu a {
	min-height: 48px;
	padding: 12px 16px;
	border-radius: var(--csp-radius-full);
	color: var(--csp-text);
}

.csp-mobile-menu .current-menu-item > a,
.csp-mobile-menu .current_page_item > a,
.csp-mobile-menu a:hover {
	background: var(--csp-secondary-container);
	color: var(--csp-on-secondary-container);
}

.csp-btn {
	min-height: 40px;
	padding: 10px 24px;
	border-radius: var(--csp-radius-full);
	letter-spacing: 0.01em;
	isolation: isolate;
	box-shadow: none;
}

.csp-btn > * { position: relative; z-index: 1; }

.csp-btn-filled {
	background: var(--csp-primary);
	color: var(--csp-on-primary);
	box-shadow: var(--csp-elevation-1);
}

.csp-btn-filled:hover {
	background: var(--csp-primary);
	box-shadow: var(--csp-elevation-2);
	transform: translateY(-1px);
}

.csp-btn-tonal {
	background: var(--csp-secondary-container);
	color: var(--csp-on-secondary-container);
}

.csp-btn-tonal:hover { background: var(--csp-secondary-container); box-shadow: var(--csp-elevation-1); }
.csp-btn-outlined { border: 1px solid var(--csp-outline); color: var(--csp-primary-dark); }
.csp-btn-text { color: var(--csp-primary-dark); }

.csp-card,
.csp-single,
.csp-page,
.csp-comments,
.csp-author-box,
.csp-empty-state,
.csp-404,
.widget.csp-card {
	border: 1px solid color-mix(in srgb, var(--csp-outline-variant) 72%, transparent);
	background: color-mix(in srgb, var(--csp-surface-container-low) 88%, var(--csp-surface));
	border-radius: var(--csp-radius-lg);
	box-shadow: var(--csp-elevation-1);
}

.csp-post-card {
	position: relative;
	border-radius: var(--csp-radius-lg);
	background: var(--csp-surface-container-lowest);
	box-shadow: var(--csp-elevation-1);
	isolation: isolate;
}

.csp-post-card:hover { box-shadow: var(--csp-elevation-3); transform: translateY(-4px); }

.csp-post-card-media {
	margin: 10px 10px 0;
	border-radius: calc(var(--csp-radius-lg) - 6px);
	background: linear-gradient(135deg, var(--csp-primary-container), var(--csp-tertiary-container));
}

.csp-post-card-body { padding: 20px 22px 22px; gap: 12px; }
.csp-post-card-title { font-size: clamp(1.12rem, 1.4vw, 1.32rem); font-weight: 650; }
.csp-post-card-excerpt, .entry-summary { color: var(--csp-text-muted); }
.entry-meta, .csp-post-card-meta, .csp-entry-meta { color: var(--csp-text-muted); font-size: 0.9rem; }

.csp-chip,
.csp-card-cat,
.tags-links a,
.tagcloud a {
	min-height: 32px;
	padding: 6px 13px;
	border-radius: var(--csp-radius-sm);
	background: var(--csp-primary-container) !important;
	color: var(--csp-on-primary-container) !important;
	box-shadow: none;
}

.csp-hero {
	position: relative;
	margin: clamp(18px, 3vw, 32px) clamp(12px, 3vw, 28px) 0;
	border-radius: var(--csp-radius-xl);
	background: linear-gradient(135deg, color-mix(in srgb, var(--csp-primary-container) 80%, var(--csp-surface)), color-mix(in srgb, var(--csp-tertiary-container) 62%, var(--csp-surface)));
	box-shadow: var(--csp-elevation-2);
	overflow: hidden;
}

.csp-hero-title,
.csp-archive-header .page-title,
.csp-single .entry-title,
.csp-page .entry-title {
	letter-spacing: -0.03em;
	color: var(--csp-text);
}

.csp-homepage-cta,
.csp-archive-header {
	border-radius: var(--csp-radius-xl);
	background: linear-gradient(135deg, var(--csp-primary), color-mix(in srgb, var(--csp-tertiary) 45%, var(--csp-primary-dark)));
	box-shadow: var(--csp-elevation-3);
}

.csp-single, .csp-page { padding: clamp(22px, 4vw, 44px); }
.entry-content { font-size: clamp(1rem, 0.7vw + 0.9rem, 1.1rem); line-height: 1.82; }
.entry-content h2, .entry-content h3, .entry-content h4 { margin-top: 1.7em; letter-spacing: -0.02em; }

.entry-content blockquote {
	margin: 1.8em 0;
	padding: 20px 24px;
	border-left: 5px solid var(--csp-primary);
	border-radius: 0 var(--csp-radius-lg) var(--csp-radius-lg) 0;
	background: var(--csp-primary-container);
	color: var(--csp-on-primary-container);
}

.entry-content pre,
.entry-content code,
.entry-content kbd { border-radius: var(--csp-radius-sm); background: var(--csp-surface-container-high); }
.entry-content pre { padding: 18px 20px; overflow-x: auto; border: 1px solid var(--csp-outline-variant); }

.entry-content table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	border: 1px solid var(--csp-outline-variant);
	border-radius: var(--csp-radius);
	overflow: hidden;
}

.entry-content th,
.entry-content td { padding: 12px 14px; border-bottom: 1px solid var(--csp-outline-variant); }
.entry-content th { background: var(--csp-surface-container-high); font-weight: 650; }

.csp-search-input-wrap,
.csp-field input,
.csp-field textarea {
	border: 1px solid var(--csp-outline);
	border-radius: var(--csp-radius-sm);
	background: var(--csp-surface-container-lowest);
	box-shadow: none;
}

.csp-search-input-wrap { min-height: 56px; padding: 6px 6px 6px 16px; }
.csp-field { position: relative; margin-bottom: 18px; }

.csp-field label {
	display: inline-flex;
	margin: 0 0 -1px 12px;
	padding-inline: 6px;
	background: var(--csp-surface-container-low);
	color: var(--csp-primary-dark);
	font-size: 0.82rem;
	font-weight: 600;
	transform: translateY(50%);
	position: relative;
	z-index: 1;
}

.csp-field input,
.csp-field textarea { width: 100%; padding: 16px 15px 12px; color: var(--csp-text); }
.csp-field input:focus, .csp-field textarea:focus, .csp-search-input-wrap:focus-within { border-color: var(--csp-primary); box-shadow: 0 0 0 3px color-mix(in srgb, var(--csp-primary) 18%, transparent); }

.csp-comments { padding: clamp(20px, 4vw, 34px); }
.csp-comment-body { border-radius: var(--csp-radius-lg); background: var(--csp-surface-container-lowest); border: 1px solid var(--csp-outline-variant); }

.pagination .page-numbers,
.page-links a,
.page-links .post-page-numbers,
.navigation.comment-navigation a,
.navigation.post-navigation a {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	min-height: 40px;
	padding: 8px 14px;
	border-radius: var(--csp-radius-full);
	background: var(--csp-surface-container-high);
	color: var(--csp-primary-dark);
	overflow: hidden;
}

.pagination .current,
.page-links .current,
.page-links .post-page-numbers.current { background: var(--csp-primary); color: var(--csp-on-primary); }
.page-links { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 28px; }

.widget.csp-card { background: var(--csp-surface-container-low); }
.widget-title { color: var(--csp-text); letter-spacing: -0.02em; }
.site-footer { background: var(--csp-surface-container-high); color: var(--csp-text); }
.csp-social-link { position: relative; border-radius: var(--csp-radius-full); background: var(--csp-surface-container-highest); color: var(--csp-primary-dark); overflow: hidden; }

.csp-fab {
	border-radius: var(--csp-radius-lg);
	background: var(--csp-primary-container);
	color: var(--csp-on-primary-container);
	box-shadow: var(--csp-elevation-3);
}

@media (prefers-color-scheme: dark) {
	:root {
		--csp-primary: #9DCAFF;
		--csp-primary-light: #CFE5FF;
		--csp-primary-dark: #D6E9FF;
		--csp-on-primary: #003258;
		--csp-primary-container: #124A7D;
		--csp-on-primary-container: #D6E9FF;
		--csp-secondary: #BAC8DA;
		--csp-on-secondary: #243140;
		--csp-secondary-container: #3A4858;
		--csp-on-secondary-container: #D6E4F7;
		--csp-tertiary: #D6BEE4;
		--csp-tertiary-container: #523F5F;
		--csp-on-tertiary-container: #F1DAFF;
		--csp-bg: #101418;
		--csp-surface: #101418;
		--csp-surface-dim: #101418;
		--csp-surface-bright: #36393E;
		--csp-surface-container-lowest: #0B0F13;
		--csp-surface-container-low: #181C20;
		--csp-surface-container: #1C2024;
		--csp-surface-container-high: #272A2F;
		--csp-surface-container-highest: #32353A;
		--csp-text: #E1E7EF;
		--csp-text-muted: #BFC7D1;
		--csp-border: #42474E;
		--csp-outline: #8E939B;
		--csp-outline-variant: #42474E;
		--csp-shadow-1: 0 1px 2px rgba(0, 0, 0, 0.38);
		--csp-shadow-2: 0 4px 12px rgba(0, 0, 0, 0.42);
		--csp-shadow-3: 0 12px 28px rgba(0, 0, 0, 0.48);
		--csp-elevation-1: 0 1px 3px rgba(0, 0, 0, 0.45);
		--csp-elevation-2: 0 4px 12px rgba(0, 0, 0, 0.48);
		--csp-elevation-3: 0 10px 28px rgba(0, 0, 0, 0.52);
	}

	body { color-scheme: dark; }
	.site-header { background: color-mix(in srgb, var(--csp-surface-container) 88%, transparent); }
	.csp-post-card, .csp-card, .widget.csp-card { background: var(--csp-surface-container); }
	.csp-field label { background: var(--csp-surface-container-low); }
	.entry-content img, .csp-post-card-media img { filter: saturate(0.94) brightness(0.9); }
}


/* -------------------------------------------------------------------------
 * Feature expansion: reading tools, theme toggle, sharing and related posts.
 * ------------------------------------------------------------------------- */
html[data-theme="dark"] {
	--csp-primary: #9DCAFF;
	--csp-primary-light: #CFE5FF;
	--csp-primary-dark: #D6E9FF;
	--csp-on-primary: #003258;
	--csp-primary-container: #124A7D;
	--csp-on-primary-container: #D6E9FF;
	--csp-secondary: #BAC8DA;
	--csp-secondary-container: #3A4858;
	--csp-on-secondary-container: #D6E4F7;
	--csp-tertiary: #D6BEE4;
	--csp-tertiary-container: #523F5F;
	--csp-on-tertiary-container: #F1DAFF;
	--csp-bg: #101418;
	--csp-surface: #101418;
	--csp-surface-container-lowest: #0B0F13;
	--csp-surface-container-low: #181C20;
	--csp-surface-container: #1C2024;
	--csp-surface-container-high: #272A2F;
	--csp-surface-container-highest: #32353A;
	--csp-text: #E1E7EF;
	--csp-text-muted: #BFC7D1;
	--csp-border: #42474E;
	--csp-outline: #8E939B;
	--csp-outline-variant: #42474E;
	color-scheme: dark;
}
html[data-theme="light"] { color-scheme: light; }
html[data-theme="light"] body { color-scheme: light; }
html[data-theme="dark"] .entry-content img,
html[data-theme="dark"] .csp-post-card-media img { filter: saturate(0.94) brightness(0.9); }

.csp-reading-progress { position: absolute; left: 0; right: 0; bottom: 0; height: 3px; background: color-mix(in srgb, var(--csp-primary) 10%, transparent); overflow: hidden; }
.csp-reading-progress span { display: block; width: 100%; height: 100%; transform: scaleX(0); transform-origin: left center; background: linear-gradient(90deg, var(--csp-primary), var(--csp-tertiary)); transition: transform 0.12s linear; }
.csp-theme-toggle .csp-theme-icon { transition: transform var(--csp-transition); }
.csp-theme-toggle:hover .csp-theme-icon { transform: rotate(18deg) scale(1.08); }
.csp-post-views, .reading-time, .posted-on, .byline { display: inline-flex; align-items: center; gap: 4px; }

.csp-toc { padding: 18px 20px; margin: 0 0 28px; background: var(--csp-surface-container-lowest); }
.csp-toc-title, .csp-share-title { display: flex; align-items: center; gap: 8px; font-weight: 700; color: var(--csp-text); margin-bottom: 12px; }
.csp-toc-title .material-symbols-rounded, .csp-share-title .material-symbols-rounded { color: var(--csp-primary); }
.csp-toc-list { display: grid; gap: 6px; list-style: none; padding: 0; margin: 0; }
.csp-toc-item a { display: block; padding: 8px 12px; border-radius: var(--csp-radius-sm); color: var(--csp-text-muted); text-decoration: none; transition: background var(--csp-transition), color var(--csp-transition), transform var(--csp-transition); }
.csp-toc-level-3 a { padding-left: 28px; font-size: 0.95em; }
.csp-toc-item a:hover, .csp-toc-item a.is-active { background: var(--csp-secondary-container); color: var(--csp-on-secondary-container); transform: translateX(2px); }
.entry-content h2, .entry-content h3 { scroll-margin-top: 110px; }
.csp-heading-anchor { display: inline-flex; margin-right: 8px; text-decoration: none !important; opacity: 0; color: var(--csp-primary) !important; transition: opacity var(--csp-transition); }
.entry-content h2:hover .csp-heading-anchor, .entry-content h3:hover .csp-heading-anchor, .csp-heading-anchor:focus { opacity: 1; }

.entry-content pre.csp-code-block { position: relative; padding-top: 54px; }
.csp-code-copy { position: absolute; top: 10px; right: 10px; display: inline-flex; align-items: center; gap: 6px; min-height: 34px; padding: 6px 10px; border: 0; border-radius: var(--csp-radius-sm); background: var(--csp-secondary-container); color: var(--csp-on-secondary-container); cursor: pointer; font: inherit; font-size: 0.82rem; overflow: hidden; }
.csp-code-copy.is-copied { background: var(--csp-primary); color: var(--csp-on-primary); }

.csp-share { margin-bottom: 20px; }
.csp-share-actions { display: flex; flex-wrap: wrap; gap: 10px; }
.csp-share-btn { position: relative; display: inline-flex; align-items: center; gap: 7px; min-height: 40px; padding: 8px 14px; border: 1px solid var(--csp-outline-variant); border-radius: var(--csp-radius-full); background: var(--csp-surface-container-high); color: var(--csp-primary-dark); text-decoration: none; cursor: pointer; font: inherit; overflow: hidden; transition: transform var(--csp-transition), box-shadow var(--csp-transition), background var(--csp-transition); }
.csp-share-btn:hover, .csp-share-btn.is-copied { transform: translateY(-1px); box-shadow: var(--csp-elevation-1); background: var(--csp-primary-container); color: var(--csp-on-primary-container); }

.csp-related-posts { padding: clamp(20px, 4vw, 34px); margin-bottom: clamp(24px, 4vw, 40px); }
.csp-related-header { text-align: left; margin-bottom: 20px; }
.csp-related-grid { grid-template-columns: 1fr; }
@media (min-width: 760px) { .csp-related-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
.csp-related-grid .csp-post-card-title { font-size: 1.05rem; }
.csp-related-grid .csp-post-card-excerpt { display: none; }

.csp-search-form { position: relative; }
.csp-search-history { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 10px; }
.csp-search-history-title { color: var(--csp-text-muted); font-size: 0.82rem; font-weight: 600; }
.csp-history-chip, .csp-history-clear { border: 0; border-radius: var(--csp-radius-full); padding: 6px 10px; background: var(--csp-surface-container-high); color: var(--csp-primary-dark); cursor: pointer; font: inherit; font-size: 0.82rem; }
.csp-history-chip:hover, .csp-history-clear:hover { background: var(--csp-primary-container); color: var(--csp-on-primary-container); }

@media (max-width: 640px) {
	.csp-share-actions { flex-direction: column; align-items: stretch; }
	.csp-share-btn { justify-content: center; }
	.csp-toc { padding: 16px; }
}


/* -------------------------------------------------------------------------
 * Mobile access experience optimization.
 * ------------------------------------------------------------------------- */
@media (hover: none), (pointer: coarse) {
	.csp-post-card:hover,
	.csp-homepage-cta:hover,
	.csp-fab:hover,
	.csp-share-btn:hover,
	.csp-toc-item a:hover {
		transform: none;
	}

	.csp-post-card:hover .csp-post-card-media img,
	.csp-mobile-menu a:hover {
		transform: none;
	}

	.csp-mobile-menu a:hover { padding-left: 16px; }
}

@media (hover: hover) and (pointer: fine) {
	.csp-post-card:hover { transform: translateY(-4px); }
	.csp-post-card:hover .csp-post-card-media img { transform: scale(1.04); }
}

@media (max-width: 768px) {
	.csp-container,
	.csp-container-full,
	.csp-header-inner {
		padding-inline: max(14px, env(safe-area-inset-left));
		padding-right: max(14px, env(safe-area-inset-right));
	}

	.csp-header-row {
		min-height: 62px;
		padding-block: 8px;
		gap: 10px;
	}

	.site-branding { flex: 1 1 auto; }
	.main-navigation { order: 3; }
	.csp-header-actions { flex: 0 0 auto; gap: 6px; }

	.csp-icon-btn,
	.csp-menu-toggle {
		width: 42px;
		height: 42px;
		min-width: 42px;
	}

	.csp-search-bar {
		position: fixed;
		top: var(--wp-admin--admin-bar--height, 0px);
		left: 0;
		right: 0;
		z-index: 180;
		padding: 72px max(14px, env(safe-area-inset-left)) 16px max(14px, env(safe-area-inset-right));
		border-radius: 0 0 var(--csp-radius-lg) var(--csp-radius-lg);
	}

	.csp-mobile-nav {
		width: min(360px, 88vw);
		padding: calc(72px + env(safe-area-inset-top)) 14px calc(20px + env(safe-area-inset-bottom));
	}

	.csp-mobile-menu a {
		min-height: 48px;
		display: flex;
		align-items: center;
	}

	.csp-single,
	.csp-page {
		padding: 20px;
	}

	.csp-single .entry-title,
	.csp-page .entry-title {
		font-size: clamp(1.72rem, 8vw, 2.25rem);
		line-height: 1.16;
	}

	.entry-meta,
	.csp-post-card-meta,
	.csp-entry-meta {
		gap: 8px 12px;
		flex-wrap: wrap;
	}

	.entry-content {
		font-size: 1rem;
		line-height: 1.76;
	}

	.entry-content h2,
	.entry-content h3 {
		scroll-margin-top: 88px;
	}

	.csp-toc {
		margin-bottom: 22px;
		padding: 16px;
		border-radius: var(--csp-radius);
	}

	.csp-toc-list {
		max-height: 42vh;
		overflow-y: auto;
		padding-right: 2px;
	}

	.entry-content pre.csp-code-block {
		margin-inline: -4px;
		padding: 50px 14px 16px;
	}

	.csp-code-copy {
		top: 8px;
		right: 8px;
	}

	.csp-related-posts,
	.csp-comments,
	.csp-author-box {
		margin-bottom: 22px;
	}
}

@media (max-width: 640px) {
	.csp-text-logo {
		max-width: min(52vw, 220px);
		gap: 6px;
	}

	.csp-text-logo-mark {
		width: 34px;
		height: 34px;
		font-size: 23px;
	}

	.csp-text-logo-text {
		display: block;
		overflow: hidden;
		text-overflow: ellipsis;
		white-space: nowrap;
		font-size: 1.05rem;
	}

	.csp-header-actions > .csp-btn {
		display: none;
	}

	.csp-search-input-wrap {
		min-height: 52px;
		padding: 5px 5px 5px 12px;
	}

	.csp-search-input-wrap .csp-search-field {
		min-width: 0;
		font-size: 16px;
	}

	.csp-search-submit {
		min-height: 40px;
		padding-inline: 13px;
	}

	.csp-search-history {
		max-height: 104px;
		overflow-y: auto;
		padding-bottom: 2px;
	}

	.csp-search-bar .csp-search-history .csp-history-chip:nth-of-type(n+5),
	.csp-mobile-nav .csp-search-history .csp-history-chip:nth-of-type(n+4) {
		display: none;
	}

	.csp-post-card-media {
		margin: 8px 8px 0;
	}

	.csp-post-card-body {
		padding: 15px;
		gap: 10px;
	}

	.csp-post-card-title {
		font-size: 1.08rem;
		line-height: 1.3;
	}

	.csp-post-card-excerpt {
		display: -webkit-box;
		-webkit-line-clamp: 2;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}

	.csp-post-card .csp-btn,
	.csp-load-more-wrap .csp-btn {
		width: 100%;
		justify-content: center;
	}

	.csp-related-grid {
		gap: 14px;
	}

	.csp-share-actions {
		gap: 8px;
	}

	.csp-share-btn {
		min-height: 46px;
	}

	.navigation.post-navigation .nav-links {
		display: grid;
		grid-template-columns: 1fr;
		gap: 12px;
	}
}

@media (max-width: 480px) {
	.csp-container,
	.csp-container-full,
	.csp-header-inner {
		padding-inline: max(12px, env(safe-area-inset-left));
		padding-right: max(12px, env(safe-area-inset-right));
	}

	.csp-header-row {
		min-height: 58px;
		gap: 6px;
	}

	.csp-icon-btn,
	.csp-menu-toggle {
		width: 40px;
		height: 40px;
		min-width: 40px;
	}

	.csp-icon-btn .material-symbols-rounded,
	.csp-menu-toggle .csp-menu-icon {
		font-size: 23px;
	}

	.csp-text-logo {
		max-width: 42vw;
		padding: 4px 8px 4px 4px;
	}

	.csp-text-logo-text { font-size: 0.96rem; }

	.custom-logo { max-height: 40px; }

	.csp-search-bar {
		padding-top: 66px;
		padding-bottom: 14px;
	}

	.csp-search-input-wrap {
		align-items: stretch;
		border-radius: var(--csp-radius-lg);
	}

	.csp-search-submit {
		border-radius: var(--csp-radius);
		padding-inline: 11px;
	}

	.csp-mobile-nav {
		width: min(336px, 92vw);
		padding-inline: 12px;
	}

	.csp-single,
	.csp-page,
	.csp-related-posts,
	.csp-comments,
	.csp-author-box {
		padding: 16px;
		border-radius: var(--csp-radius);
	}

	.csp-breadcrumbs {
		overflow-x: auto;
		white-space: nowrap;
		padding-bottom: 2px;
	}

	.csp-entry-meta .material-symbols-rounded,
	.csp-post-card-meta .material-symbols-rounded {
		font-size: 18px;
	}

	.entry-content img,
	.wp-caption {
		border-radius: var(--csp-radius-sm);
	}

	.csp-toc-title,
	.csp-share-title {
		margin-bottom: 10px;
	}

	.csp-toc-item a {
		padding: 9px 10px;
	}

	.csp-toc-level-3 a {
		padding-left: 20px;
	}

	.csp-heading-anchor {
		opacity: 0.65;
		margin-right: 4px;
	}

	.comment-form-cookies-consent {
		align-items: flex-start;
	}
}

@media (max-width: 380px) {
	.csp-text-logo-text {
		max-width: 0;
		opacity: 0;
	}

	.csp-text-logo {
		padding-right: 4px;
	}

	.csp-header-actions {
		gap: 4px;
	}

	.csp-icon-btn,
	.csp-menu-toggle {
		width: 38px;
		height: 38px;
		min-width: 38px;
	}

	.csp-search-submit span:not(.material-symbols-rounded) {
		display: none;
	}

	.csp-single .entry-title,
	.csp-page .entry-title {
		font-size: 1.58rem;
	}
}
