/*!
Theme Name: customtheme
Theme URI: http://underscores.me/
Author: Underscores.me
Author URI: http://underscores.me/
Description: Description
Version: 1.0.0
Tested up to: 5.4
Requires PHP: 5.6
License: GNU General Public License v2 or later
License URI: LICENSE
Text Domain: customtheme
Tags: custom-background, custom-logo, custom-menu, featured-images, threaded-comments, translation-ready

This theme, like WordPress, is licensed under the GPL.
Use it to make something cool, have fun, and share what you've learned.

customtheme is based on Underscores https://underscores.me/, (C) 2012-2020 Automattic, Inc.
Underscores is distributed under the terms of the GNU GPL v2 or later.

Normalizing styles have been helped along thanks to the fine work of
Nicolas Gallagher and Jonathan Neal https://necolas.github.io/normalize.css/
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------
# Generic
	- Normalize
	- Box sizing
# Base
	- Typography
	- Elements
	- Links
	- Forms
## Layouts
# Components
	- Navigation
	- Posts and pages
	- Comments
	- Widgets
	- Media
	- Captions
	- Galleries
# plugins
	- Jetpack infinite scroll
# Utilities
	- Accessibility
	- Alignments

--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Generic
--------------------------------------------------------------*/

:root {
	--color-bg: #ffffff;
	--color-surface: #f7f7f9;
	--color-text: #404040;
	--color-text-strong: #111111;
	--color-border: #dcdcdc;
	--color-hr: #cccccc;
	--color-pre-bg: #eeeeee;
	--color-link: #4169e1;
	--color-link-visited: #800080;
	--color-link-hover: #191970;
	--color-button-bg: #e6e6e6;
	--color-button-text: rgba(0, 0, 0, 0.8);
	--color-toggle-bg: rgba(0, 0, 0, 0.05);
	--color-toggle-border: rgba(0, 0, 0, 0.2);
}

html[data-theme="dark"] {
	--color-bg: #11131a;
	--color-surface: #1b1e26;
	--color-text: #e7e9f1;
	--color-text-strong: #ffffff;
	--color-border: #2f3544;
	--color-hr: #2a2f3c;
	--color-pre-bg: #1f2531;
	--color-link: #9ab6ff;
	--color-link-visited: #c19bff;
	--color-link-hover: #f5f5f5;
	--color-button-bg: #2a3141;
	--color-button-text: #ffffff;
	--color-toggle-bg: rgba(255, 255, 255, 0.05);
	--color-toggle-border: rgba(255, 255, 255, 0.25);
	color-scheme: dark;
}

/* Normalize
--------------------------------------------- */

/*! normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css */

/* Document
	 ========================================================================== */

/**
 * 1. Correct the line height in all browsers.
 * 2. Prevent adjustments of font size after orientation changes in iOS.
 */
html {
	line-height: 1.15;
	-webkit-text-size-adjust: 100%;
}

/* Sections
	 ========================================================================== */

/**
 * Remove the margin in all browsers.
 */
body {
	margin: 0;
}

/**
 * Render the `main` element consistently in IE.
 */
main {
	display: block;
}

/**
 * Correct the font size and margin on `h1` elements within `section` and
 * `article` contexts in Chrome, Firefox, and Safari.
 */
h1 {
	font-size: 2em;
	margin: 0.67em 0;
}

/* Grouping content
	 ========================================================================== */

/**
 * 1. Add the correct box sizing in Firefox.
 * 2. Show the overflow in Edge and IE.
 */
hr {
	box-sizing: content-box;
	height: 0;
	overflow: visible;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
pre {
	font-family: monospace, monospace;
	font-size: 1em;
}

/* Text-level semantics
	 ========================================================================== */

/**
 * Remove the gray background on active links in IE 10.
 */
a {
	background-color: transparent;
}

/**
 * 1. Remove the bottom border in Chrome 57-
 * 2. Add the correct text decoration in Chrome, Edge, IE, Opera, and Safari.
 */
abbr[title] {
	border-bottom: none;
	text-decoration: underline;
	text-decoration: underline dotted;
}

/**
 * Add the correct font weight in Chrome, Edge, and Safari.
 */
b,
strong {
	font-weight: bolder;
}

/**
 * 1. Correct the inheritance and scaling of font size in all browsers.
 * 2. Correct the odd `em` font sizing in all browsers.
 */
code,
kbd,
samp {
	font-family: monospace, monospace;
	font-size: 1em;
}

/**
 * Add the correct font size in all browsers.
 */
small {
	font-size: 80%;
}

/**
 * Prevent `sub` and `sup` elements from affecting the line height in
 * all browsers.
 */
sub,
sup {
	font-size: 75%;
	line-height: 0;
	position: relative;
	vertical-align: baseline;
}

sub {
	bottom: -0.25em;
}

sup {
	top: -0.5em;
}

/* Embedded content
	 ========================================================================== */

/**
 * Remove the border on images inside links in IE 10.
 */
img {
	border-style: none;
}

/* Forms
	 ========================================================================== */

/**
 * 1. Change the font styles in all browsers.
 * 2. Remove the margin in Firefox and Safari.
 */
button,
input,
optgroup,
select,
textarea {
	font-family: inherit;
	font-size: 100%;
	line-height: 1.15;
	margin: 0;
}

/**
 * Show the overflow in IE.
 * 1. Show the overflow in Edge.
 */
button,
input {
	overflow: visible;
}

/**
 * Remove the inheritance of text transform in Edge, Firefox, and IE.
 * 1. Remove the inheritance of text transform in Firefox.
 */
button,
select {
	text-transform: none;
}

/**
 * Correct the inability to style clickable types in iOS and Safari.
 */
button,
[type="button"],
[type="reset"],
[type="submit"] {
	-webkit-appearance: button;
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
	border-style: none;
	padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
	outline: 1px dotted ButtonText;
}

/**
 * Correct the padding in Firefox.
 */
fieldset {
	padding: 0.35em 0.75em 0.625em;
}

/**
 * 1. Correct the text wrapping in Edge and IE.
 * 2. Correct the color inheritance from `fieldset` elements in IE.
 * 3. Remove the padding so developers are not caught out when they zero out
 *		`fieldset` elements in all browsers.
 */
legend {
	box-sizing: border-box;
	color: inherit;
	display: table;
	max-width: 100%;
	padding: 0;
	white-space: normal;
}

/**
 * Add the correct vertical alignment in Chrome, Firefox, and Opera.
 */
progress {
	vertical-align: baseline;
}

/**
 * Remove the default vertical scrollbar in IE 10+.
 */
textarea {
	overflow: auto;
}

/**
 * 1. Add the correct box sizing in IE 10.
 * 2. Remove the padding in IE 10.
 */
[type="checkbox"],
[type="radio"] {
	box-sizing: border-box;
	padding: 0;
}

/**
 * Correct the cursor style of increment and decrement buttons in Chrome.
 */
[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Correct the odd appearance in Chrome and Safari.
 * 2. Correct the outline style in Safari.
 */
[type="search"] {
	-webkit-appearance: textfield;
	outline-offset: -2px;
}

/**
 * Remove the inner padding in Chrome and Safari on macOS.
 */
[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * 1. Correct the inability to style clickable types in iOS and Safari.
 * 2. Change font properties to `inherit` in Safari.
 */
::-webkit-file-upload-button {
	-webkit-appearance: button;
	font: inherit;
}

/* Interactive
	 ========================================================================== */

/*
 * Add the correct display in Edge, IE 10+, and Firefox.
 */
details {
	display: block;
}

/*
 * Add the correct display in all browsers.
 */
summary {
	display: list-item;
}

/* Misc
	 ========================================================================== */

/**
 * Add the correct display in IE 10+.
 */
template {
	display: none;
}

/**
 * Add the correct display in IE 10.
 */
[hidden] {
	display: none;
}

/* Box sizing
--------------------------------------------- */

/* Inherit box-sizing to more easily change it's value on a component level.
@link http://css-tricks.com/inheriting-box-sizing-probably-slightly-better-best-practice/ */
*,
*::before,
*::after {
	box-sizing: inherit;
}

html {
	box-sizing: border-box;
}

/*--------------------------------------------------------------
# Base
--------------------------------------------------------------*/

/* Typography
--------------------------------------------- */
body,
button,
input,
select,
optgroup,
textarea {
	color: var( --color-text );
	font-family: 'Merriweather', serif;
	font-size: 1rem;
	line-height: 1.5;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	clear: both;
	font-family: 'Inter', sans-serif;
	font-weight: 700;
	color: var( --color-text-strong );
}

p {
	margin-bottom: 1.5em;
}

dfn,
cite,
em,
i {
	font-style: italic;
}

blockquote {
	margin: 0 1.5em;
}

address {
	margin: 0 0 1.5em;
}

pre {
	background: var( --color-pre-bg );
	font-family: "Courier 10 Pitch", courier, monospace;
	line-height: 1.6;
	margin-bottom: 1.6em;
	max-width: 100%;
	overflow: auto;
	padding: 1.6em;
}

code,
kbd,
tt,
var {
	font-family: monaco, consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

abbr,
acronym {
	border-bottom: 1px dotted #666;
	cursor: help;
}

mark,
ins {
	background: #fff9c0;
	text-decoration: none;
}

big {
	font-size: 125%;
}

/* Elements
--------------------------------------------- */
body {
	background: var( --color-bg );
	color: var( --color-text );
}

hr {
	background-color: var( --color-hr );
	border: 0;
	height: 1px;
	margin-bottom: 1.5em;
}

ul,
ol {
	margin: 0 0 1.5em 3em;
}

ul {
	list-style: disc;
}

ol {
	list-style: decimal;
}

li > ul,
li > ol {
	margin-bottom: 0;
	margin-left: 1.5em;
}

dt {
	font-weight: 700;
}

dd {
	margin: 0 1.5em 1.5em;
}

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
	max-width: 100%;
}

img {
	height: auto;
	max-width: 100%;
}

figure {
	margin: 1em 0;
}

table {
	margin: 0 0 1.5em;
	width: 100%;
}

/* Links
--------------------------------------------- */
a {
	color: var( --color-link );
}

/* a:visited {
	color: var( --color-link-visited );
} */

/* a:hover,
a:focus,
a:active {
	color: var( --color-link-hover );
} */

/* a:focus {
	outline: thin dotted;
} */
a:hover{
	text-decoration: none;
}
a:hover,
a:active {
	outline: 0;
}

.container{
	max-width: 80rem !important;
}
/* Forms
--------------------------------------------- */
button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	border: 1px solid;
	border-color: var( --color-border );
	border-radius: 3px;
	background: var( --color-button-bg );
	color: var( --color-button-text );
	line-height: 1;
	padding: 0.6em 1em 0.4em;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	border-color: var( --color-link );
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	border-color: var( --color-border );
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	color: var( --color-text );
	background:transparent;
	border: none;
	border-radius: 3px;
	padding: 3px;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: var( --color-text-strong );
}

select {
	border: 1px solid var( --color-border );
}

textarea {
	width: 100%;
}

/*--------------------------------------------------------------
# Layouts
--------------------------------------------------------------*/

/*--------------------------------------------------------------
# Components
--------------------------------------------------------------*/

/* Navigation
--------------------------------------------- */
.site-header,
#masthead {
	background: var( --color-bg );
	border-bottom: 1px solid var( --color-border );
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
	margin-bottom: 0;
	padding: 1.25rem 0;
	position: -webkit-sticky !important;
	position: sticky !important;
	top: 0 !important;
	transition: all 0.3s ease;
	z-index: 10000 !important;
	overflow: visible;
	width: 100%;
	left: 0;
	right: 0;
}

.site-header .navbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

html[data-theme="dark"] .site-header,
html[data-theme="dark"] #masthead {
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

/* Sticky header effect (Desktop only - disabled on mobile/tablet) */
@media screen and (min-width: 992px) {
	.site-header.sticky-active,
	#masthead.sticky-active {
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
		padding: 0.75rem 0;
		position: -webkit-sticky !important;
		position: sticky !important;
		top: 0 !important;
	}

	html[data-theme="dark"] .site-header.sticky-active,
	html[data-theme="dark"] #masthead.sticky-active {
		box-shadow: 0 4px 12px rgba(0, 0, 0, 0.5);
	}

	.site-header.sticky-active .site-logo-wrapper img,
	#masthead.sticky-active .site-logo-wrapper img {
		max-height: 2.5rem;
		width: auto;
		transition: max-height 0.3s ease;
	}

	.site-header.sticky-active .site-title,
	#masthead.sticky-active .site-title {
		font-size: 1.25rem;
	}

	.site-header.sticky-active .site-description,
	#masthead.sticky-active .site-description {
		display: none;
	}
}

.site-header.sticky-active .navbar,
#masthead.sticky-active .navbar {
	min-height: 3rem;
}

.site-header .navbar {
	min-height: 4rem;
	transition: min-height 0.3s ease;
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
}

.site-header .navbar-brand {
	flex-shrink: 0;
	margin-right: auto;
	overflow: visible;
	max-width: 100%;
}

@media screen and (max-width: 991.98px) {
	.site-header .navbar {
		flex-wrap: nowrap;
	}
	
	.site-header .navbar-brand {
		flex: 0 0 auto;
		margin-right: auto;
	}
}

.site-logo-wrapper {
	display: inline-block;
	margin-right: 0.75rem;
	vertical-align: middle;
	position: relative;
	overflow: visible;
	max-width: 100%;
}

.site-logo-wrapper img {
	height: auto;
	max-height: 3.5rem;
	transition: max-height 0.3s ease, opacity 0.3s ease;
	width: auto;
	max-width: 100%;
	display: block;
}

.site-logo-wrapper .custom-logo-link {
	display: inline-block;
	line-height: 1;
	position: relative;
	overflow: visible;
	max-width: 100%;
}

/* Light/Dark Theme Logo Switching */
.site-logo-wrapper .custom-logo-link {
	position: relative;
	display: inline-block;
}

.site-logo-wrapper .logo-light,
.site-logo-wrapper .logo-dark {
	max-width: 100%;
	height: auto;
	width: auto;
	transition: opacity 0.3s ease, visibility 0.3s ease;
	display: block;
	object-fit: contain;
}

/* Light Theme - Show Light Logo, Hide Dark Logo */
.site-logo-wrapper .logo-light:not(.logo-single) {
	opacity: 1 !important;
	visibility: visible !important;
	position: relative !important;
	display: block !important;
	max-width: 100% !important;
	width: auto !important;
	height: auto !important;
	object-fit: contain !important;
}

.site-logo-wrapper .logo-dark:not(.logo-single) {
	opacity: 0 !important;
	visibility: hidden !important;
	position: absolute !important;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: none !important;
	pointer-events: none !important;
}

/* Override for dark theme - ensure dark logo shows */
html[data-theme="dark"] .site-logo-wrapper .logo-dark:not(.logo-single) {
	opacity: 1 !important;
	visibility: visible !important;
	position: relative !important;
	display: block !important;
	pointer-events: auto !important;
	top: auto !important;
	left: auto !important;
	width: auto !important;
	height: auto !important;
	max-width: 100% !important;
	object-fit: contain !important;
}

/* Ensure dark logo is hidden in light theme (no data-theme attribute) */
html:not([data-theme="dark"]) .site-logo-wrapper .logo-dark:not(.logo-single) {
	display: none !important;
	visibility: hidden !important;
	opacity: 0 !important;
	position: absolute !important;
	pointer-events: none !important;
}

/* Dark Theme - Show Dark Logo, Hide Light Logo */
html[data-theme="dark"] .site-logo-wrapper .logo-light:not(.logo-single) {
	opacity: 0 !important;
	visibility: hidden !important;
	position: absolute !important;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
	display: none !important;
	pointer-events: none !important;
}

html[data-theme="dark"] .site-logo-wrapper .logo-dark:not(.logo-single) {
	opacity: 1 !important;
	visibility: visible !important;
	position: relative !important;
	display: block !important;
	pointer-events: auto !important;
	max-width: 100% !important;
	width: auto !important;
	height: auto !important;
	object-fit: contain !important;
}

/* If only one logo is set (same logo for both themes), show it in both themes */
.site-logo-wrapper .logo-single {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
	display: block !important;
	max-width: 100% !important;
	width: auto !important;
	height: auto !important;
	object-fit: contain !important;
}

html[data-theme="dark"] .site-logo-wrapper .logo-single {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
	display: block !important;
	max-width: 100% !important;
	width: auto !important;
	height: auto !important;
	object-fit: contain !important;
}

/* Fallback for browsers that don't support :has() */
.site-logo-wrapper .custom-logo-link .logo-dark:only-child,
.site-logo-wrapper .custom-logo-link .logo-light:only-child {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
}

html[data-theme="dark"] .site-logo-wrapper .custom-logo-link .logo-dark:only-child,
html[data-theme="dark"] .site-logo-wrapper .custom-logo-link .logo-light:only-child {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.site-branding .site-title a,
.site-branding .site-description {
	color: var( --color-text ) !important;
}

/* Override Bootstrap navbar-light for dark mode */
html[data-theme="dark"] .navbar-light .navbar-brand,
html[data-theme="dark"] .navbar-light .navbar-nav .nav-link,
html[data-theme="dark"] .navbar-light .navbar-nav .dropdown-toggle {
	color: var( --color-text ) !important;
}

html[data-theme="dark"] .navbar-light .navbar-nav .nav-link:hover,
html[data-theme="dark"] .navbar-light .navbar-nav .nav-link:focus {
	color: var( --color-link ) !important;
}

/* Header Actions Wrapper */
.header-actions-wrapper {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	flex-shrink: 0;
	margin-left: auto;
}

/* Desktop: Navigation inline, search and toggle on right */
@media screen and (min-width: 992px) {
	.header-actions-wrapper {
		margin-left: 1rem;
		order: 3;
	}
	
	.header-actions-wrapper .hamburger-menu {
		display: none !important;
	}
	
	.navbar-collapse {
		display: flex !important;
		flex-basis: auto;
		order: 2;
		margin-left: auto;
		margin-right: 1rem;
	}
	
	.site-header .navbar {
		justify-content: space-between;
	}
	
	.site-header .navbar-brand {
		order: 1;
		margin-right: 0;
	}
}

/* Mobile: Logo left, hamburger/search/toggle right, menu bottom */
@media screen and (max-width: 991.98px) {
	/* Add padding to body for fixed header */
	body {
		padding-top: 5rem;
	}
	
	.site-header {
		overflow: visible;
		padding-bottom: 0;
		z-index: 10000 !important;
		position: fixed !important;
		top: 0 !important;
		width: 100%;
		left: 0;
		right: 0;
		padding: 1rem 0 !important; /* Fixed padding, no change on scroll */
	}
	
	/* Disable sticky effect on mobile/tablet */
	.site-header.sticky-active,
	#masthead.sticky-active {
		padding: 1rem 0 !important; /* Same as default */
		box-shadow: none !important; /* No shadow change */
	}
	
	/* Logo should not change size on mobile/tablet */
	.site-header.sticky-active .site-logo-wrapper img,
	#masthead.sticky-active .site-logo-wrapper img,
	.site-header .site-logo-wrapper img,
	#masthead .site-logo-wrapper img {
		max-height: 3rem !important; /* Fixed size */
		width: auto;
		transition: none !important; /* No transition */
	}
	
	.site-header .navbar {
		flex-wrap: wrap;
		justify-content: space-between;
		overflow: visible;
		position: relative;
		z-index: 10001;
		background: var(--color-bg);
	}
	
	.site-header .navbar-brand {
		flex-shrink: 0;
		margin-right: 0;
		position: relative;
		z-index: 10002;
		overflow: visible;
		max-width: 100%;
	}
	
	.header-actions-wrapper {
		gap: 0.5rem;
		margin-left: auto;
		position: relative;
		z-index: 10002;
	}
	
	.navbar-collapse {
		order: 4;
		width: 100%;
		flex-basis: 100%;
		margin-top: 1rem;
		background: var(--color-bg);
		border-top: 1px solid var(--color-border);
		padding: 1rem 0;
		padding-bottom: 1.5rem;
		margin-bottom: 0;
		z-index: 9998;
		position: relative;
		overflow: visible !important;
		max-height: none !important;
		transition: opacity 0.25s ease, visibility 0.25s ease;
	}
	
	.navbar-collapse.collapse:not(.show) {
		display: none;
	}
	
	.navbar-collapse.collapse.show {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		height: calc(100vh - 5rem) !important;
		min-height: calc(100vh - 5rem) !important;
		max-height: calc(100vh - 5rem) !important;
		position: fixed !important;
		top: 6.7rem !important;
		left: 0 !important;
		right: 0 !important;
		bottom: 0 !important;
		width: 100vw !important;
		margin: 0 !important;
		margin-top: 0 !important;
		padding-top: 0 !important; /* Remove top padding for proper alignment */
		padding-bottom: 2rem;
		padding-left: 1rem;
		padding-right: 1rem;
		overflow-y: auto !important;
		overflow-x: hidden !important;
		-webkit-overflow-scrolling: touch !important;
		scrollbar-width: none;
		-ms-overflow-style: none;
		z-index: 9998 !important;
		background: var(--color-bg) !important;
		box-shadow: 0 4px 20px rgba(0, 0, 0, 0.1);
	}
	
	/* Add overlay background when menu is open */
	body:has(.navbar-collapse.show)::before,
	html:has(.navbar-collapse.show)::before,
	body.menu-open::before,
	html.menu-open::before {
		content: '';
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		background: rgba(0, 0, 0, 0.5);
		z-index: 9997;
		pointer-events: none;
	}
	
	/* Ensure header stays above menu and remains fixed */
	.site-header,
	#masthead {
		z-index: 10000 !important;
		position: fixed !important;
		top: 0 !important;
		background: var(--color-bg) !important;
		left: 0;
		right: 0;
	}
	
	/* When menu is open, ensure header stays on top */
	body:has(.navbar-collapse.show) .site-header,
	html:has(.navbar-collapse.show) .site-header,
	body:has(.navbar-collapse.show) #masthead,
	html:has(.navbar-collapse.show) #masthead,
	body.menu-open .site-header,
	html.menu-open .site-header,
	body.menu-open #masthead,
	html.menu-open #masthead {
		z-index: 10000 !important;
		position: fixed !important;
		top: 0 !important;
		background: var(--color-bg) !important;
		left: 0;
		right: 0;
	}
	
	.site-header .navbar {
		position: relative;
		z-index: 10001;
		background: var(--color-bg);
	}
	
	/* Ensure navbar has background when menu is open */
	body:has(.navbar-collapse.show) .site-header .navbar,
	html:has(.navbar-collapse.show) .site-header .navbar,
	body.menu-open .site-header .navbar,
	html.menu-open .site-header .navbar {
		background: var(--color-bg) !important;
		z-index: 10001 !important;
	}
	
	.site-header .navbar-brand {
		position: relative;
		z-index: 10002;
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	.site-header .navbar-brand .site-logo-wrapper,
	.site-header .navbar-brand .site-logo-wrapper img,
	.site-header .navbar-brand .custom-logo-link {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	.site-header .header-actions-wrapper {
		position: relative;
		z-index: 10002;
		display: flex !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	.navbar-collapse.collapse.show::-webkit-scrollbar {
		display: none;
		width: 0;
		height: 0;
	}
	
	/* Ensure logo and header buttons are visible when menu is open */
	body:has(.navbar-collapse.show) .site-header .navbar-brand,
	html:has(.navbar-collapse.show) .site-header .navbar-brand,
	body:has(.navbar-collapse.show) #masthead .navbar-brand,
	html:has(.navbar-collapse.show) #masthead .navbar-brand {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		z-index: 10002 !important;
		position: relative !important;
	}
	
	body:has(.navbar-collapse.show) .site-header .navbar-brand .site-logo-wrapper,
	html:has(.navbar-collapse.show) .site-header .navbar-brand .site-logo-wrapper,
	body:has(.navbar-collapse.show) .site-header .navbar-brand .custom-logo-link,
	html:has(.navbar-collapse.show) .site-header .navbar-brand .custom-logo-link {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	body:has(.navbar-collapse.show) .site-header .navbar-brand img,
	html:has(.navbar-collapse.show) .site-header .navbar-brand img {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	/* Ensure only one logo is visible at a time */
	body:has(.navbar-collapse.show) .site-header .navbar-brand .logo-light:not(.logo-single),
	html:has(.navbar-collapse.show) .site-header .navbar-brand .logo-light:not(.logo-single) {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	body:has(.navbar-collapse.show) .site-header .navbar-brand .logo-dark:not(.logo-single),
	html:has(.navbar-collapse.show) .site-header .navbar-brand .logo-dark:not(.logo-single) {
		display: none !important;
		visibility: hidden !important;
		opacity: 0 !important;
	}
	
	html[data-theme="dark"] body:has(.navbar-collapse.show) .site-header .navbar-brand .logo-light:not(.logo-single),
	html[data-theme="dark"] html:has(.navbar-collapse.show) .site-header .navbar-brand .logo-light:not(.logo-single) {
		display: none !important;
		visibility: hidden !important;
		opacity: 0 !important;
	}
	
	html[data-theme="dark"] body:has(.navbar-collapse.show) .site-header .navbar-brand .logo-dark:not(.logo-single),
	html[data-theme="dark"] html:has(.navbar-collapse.show) .site-header .navbar-brand .logo-dark:not(.logo-single) {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		position: relative !important;
		pointer-events: auto !important;
	}
	
	html[data-theme="dark"] body:has(.navbar-collapse.show) .site-header .navbar-brand .logo-light:not(.logo-single),
	html[data-theme="dark"] html:has(.navbar-collapse.show) .site-header .navbar-brand .logo-light:not(.logo-single) {
		display: none !important;
		visibility: hidden !important;
		opacity: 0 !important;
		position: absolute !important;
		pointer-events: none !important;
	}
	
	body:has(.navbar-collapse.show) .site-header .header-actions-wrapper,
	html:has(.navbar-collapse.show) .site-header .header-actions-wrapper,
	body:has(.navbar-collapse.show) #masthead .header-actions-wrapper,
	html:has(.navbar-collapse.show) #masthead .header-actions-wrapper {
		display: flex !important;
		visibility: visible !important;
		opacity: 1 !important;
		z-index: 10002 !important;
		position: relative !important;
	}
	
	/* Fallback for browsers without :has() */
	body.menu-open .site-header .navbar-brand,
	html.menu-open .site-header .navbar-brand,
	body.menu-open #masthead .navbar-brand,
	html.menu-open #masthead .navbar-brand {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
		z-index: 10002 !important;
		position: relative !important;
	}
	
	body.menu-open .site-header .navbar-brand .site-logo-wrapper,
	html.menu-open .site-header .navbar-brand .site-logo-wrapper,
	body.menu-open .site-header .navbar-brand .custom-logo-link,
	html.menu-open .site-header .navbar-brand .custom-logo-link {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	body.menu-open .site-header .navbar-brand img,
	html.menu-open .site-header .navbar-brand img {
		display: block !important;
		visibility: visible !important;
		opacity: 1 !important;
	}
	
	body.menu-open .site-header .header-actions-wrapper,
	html.menu-open .site-header .header-actions-wrapper,
	body.menu-open #masthead .header-actions-wrapper,
	html.menu-open #masthead .header-actions-wrapper {
		display: flex !important;
		visibility: visible !important;
		opacity: 1 !important;
		z-index: 10002 !important;
		position: relative !important;
	}
	
	/* Smooth transition for menu content */
	.navbar-collapse .navbar-nav {
		transition: opacity 0.2s ease, visibility 0.2s ease;
		opacity: 1;
		visibility: visible;
	}
	
	/* Ensure background and content fade together during collapse */
	.navbar-collapse.collapsing {
		opacity: 1;
		transition: opacity 0.3s ease, height 0.3s ease;
	}
	
	.navbar-collapse.collapsing .navbar-nav {
		opacity: 0;
		visibility: hidden;
		transition: opacity 0.25s ease 0.05s, visibility 0.25s ease 0.05s;
	}
	
	/* When fully closed, ensure everything is hidden */
	.navbar-collapse:not(.show):not(.collapsing) {
		opacity: 0;
		visibility: hidden;
	}
	
	.navbar-collapse:not(.show):not(.collapsing) .navbar-nav {
		opacity: 0;
		visibility: hidden;
	}
	
	.navbar-collapse .navbar-nav {
		flex-direction: column;
		width: 100%;
		margin: 0;
		padding: 0;
		padding-top: 0 !important; /* Ensure no extra top padding */
		overflow: visible;
		scrollbar-width: none;
		-ms-overflow-style: none;
	}
	
	/* First menu item should align to top */
	.navbar-collapse .navbar-nav .nav-item:first-child {
		margin-top: 0 !important;
		padding-top: 0 !important;
	}
	
	.navbar-collapse .navbar-nav .nav-item:first-child .nav-link {
		margin-top: 0 !important;
		padding-top: 1rem !important;
	}
	
	.navbar-collapse .navbar-nav::-webkit-scrollbar {
		display: none;
		width: 0;
		height: 0;
	}
	
	/* Hide body scrollbar when menu is open */
	body:has(.navbar-collapse.show),
	html:has(.navbar-collapse.show) {
		overflow: hidden !important;
	}
	
	/* Ensure body is scrollable when menu is closed */
	body:not(:has(.navbar-collapse.show)):not(.menu-open),
	html:not(:has(.navbar-collapse.show)):not(.menu-open) {
		overflow: visible !important;
	}
	
	/* Ensure header stays fixed even when menu is open */
	body:has(.navbar-collapse.show) .site-header,
	html:has(.navbar-collapse.show) .site-header {
		position: fixed !important;
		top: 0 !important;
		left: 0;
		right: 0;
	}
	
	.navbar-collapse .navbar-nav .nav-item {
		width: 100%;
		border-bottom: 1px solid var(--color-border);
		margin: 0;
	}
	
	 
	
	.navbar-collapse .navbar-nav .nav-item:last-child {
		border-bottom: none;
	}
	
	.navbar-collapse .navbar-nav .nav-link {
		padding: 0.75rem 1rem;
		width: 100%;
		display: block;
		text-align: left;
	}
	
	.navbar-collapse .navbar-nav .dropdown-menu {
		position: static;
		float: none;
		width: 100%;
		margin-top: 0;
		background: var(--color-surface);
		border: none;
		border-top: 1px solid var(--color-border);
		box-shadow: none;
		padding: 0.5rem 0;
		/* Override base hidden state for mobile - show when .show class is added */
		display: none;
		opacity: 1;
		visibility: visible;
		transform: none;
	}
	
	.navbar-collapse .navbar-nav .dropdown.show .dropdown-menu,
	.navbar-collapse .navbar-nav .dropdown-menu.show {
		display: block !important;
	}
	
	.navbar-collapse .navbar-nav .dropdown-item {
		padding: 0.5rem 2rem;
	}
	
	/* Hide scroll-top button when menu is open */
	.navbar-collapse.show ~ * .scroll-top-btn,
	body:has(.navbar-collapse.show) .scroll-top-btn {
		display: none !important;
		opacity: 0 !important;
		visibility: hidden !important;
		pointer-events: none !important;
		z-index: -1 !important;
	}
	
	/* Alternative selector for hiding scroll-top button */
	body .navbar-collapse.show ~ * .scroll-top-btn.is-visible {
		display: none !important;
		opacity: 0 !important;
		visibility: hidden !important;
	}
	
	/* Hide body scrollbar when menu is open - fallback for browsers without :has() */
	body.menu-open,
	html.menu-open {
		overflow: hidden !important;
		/* Don't use position: fixed to keep content visible */
	}
	
	/* Ensure body is normal when menu is closed */
	body:not(.menu-open):not(:has(.navbar-collapse.show)),
	html:not(.menu-open):not(:has(.navbar-collapse.show)) {
		overflow: visible !important;
		height: auto !important;
		position: static !important;
		width: auto !important;
		left: auto !important;
		right: auto !important;
		top: auto !important;
	}
	
	/* Ensure header stays fixed even when menu is open - fallback */
	body.menu-open .site-header,
	html.menu-open .site-header {
		position: fixed !important;
		top: 0 !important;
		left: 0;
		right: 0;
	}
}

.navbar-actions {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	width: 100%;
}

@media screen and (min-width: 62rem) {
	.navbar-actions {
		align-items: center;
		flex-direction: row;
		justify-content: flex-end;
		width: auto;
		gap: 1rem;
	}
}

/* Header Search Icon Button */
.header-search-toggle {
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: 50%;
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: all 0.3s ease;
	color: var(--color-text);
	padding: 0;
}

.header-search-toggle:hover {
	background: var(--color-link);
	border-color: var(--color-link);
	color: #ffffff;
	transform: scale(1.1);
}

.header-search-toggle svg {
	width: 20px;
	height: 20px;
	stroke: currentColor;
	fill: none;
}

/* Header Actions - Search, Theme Toggle & Hamburger */
.header-actions-wrapper .header-search-toggle,
.header-actions-wrapper .theme-toggle {
	background: transparent;
	border: 1px solid var(--color-border);
	border-radius: 50%;
	color: var(--color-text);
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0.5rem;
	width: 2.5rem;
	height: 2.5rem;
	transition: all 0.2s ease;
	flex-shrink: 0;
}

.header-actions-wrapper .header-search-toggle:hover,
.header-actions-wrapper .theme-toggle:hover {
	border-color: var(--color-link);
	color: var(--color-link);
	background: var(--color-surface);
}

.header-actions-wrapper .header-search-toggle svg {
	width: 20px;
	height: 20px;
	stroke: currentColor;
	fill: none;
}

.header-actions-wrapper .theme-toggle {
	position: relative;
}

.header-actions-wrapper .theme-toggle .theme-icon {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: opacity 0.3s ease, transform 0.3s ease;
	opacity: 0;
	pointer-events: none;
}

.header-actions-wrapper .theme-toggle .theme-icon.active {
	opacity: 1;
}

.header-actions-wrapper .theme-toggle .theme-icon-sun.active {
	transform: translate(-50%, -50%) rotate(0deg);
}

.header-actions-wrapper .theme-toggle .theme-icon-moon.active {
	transform: translate(-50%, -50%) rotate(-15deg);
}

.header-actions-wrapper .theme-toggle .theme-icon:not(.active) {
	opacity: 0;
	transform: translate(-50%, -50%) scale(0.8);
}

/* Header Search Overlay */
.header-search-overlay {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(0, 0, 0, 0.85);
	backdrop-filter: blur(8px);
	z-index: 9999;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	padding-top: 8rem;
	opacity: 0;
	visibility: hidden;
	transition: all 0.3s ease;
}

.header-search-overlay.active {
	opacity: 1;
	visibility: visible;
}

.header-search-container {
	width: 100%;
}

.header-search-box {
	position: relative;
	background: var(--color-bg);
	border-radius: 1rem;
	padding: 2rem;
	padding-top: 3.5rem;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.3);
	transform: translateY(-20px);
	transition: transform 0.3s ease;
}

.header-search-overlay.active .header-search-box {
	transform: translateY(0);
}

.header-search-close {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	color: var(--color-text);
	transition: all 0.2s ease;
	border-radius: 50%;
	z-index: 10;
	padding: 0;
	margin: 0;
}

.header-search-close:hover {
	background: var(--color-link);
	border-color: var(--color-link);
	color: #ffffff;
	transform: rotate(90deg);
}

.header-search-close:focus {
	outline: 2px solid var(--color-link);
	outline-offset: 2px;
}

.header-search-close svg {
	width: 18px;
	height: 18px;
	stroke: currentColor;
	stroke-width: 2.5;
	fill: none;
	pointer-events: none;
}

.header-search-form {
	width: 100%;
}

.header-search-input-wrapper {
	display: flex;
	align-items: center;
	background: var(--color-surface);
	border: 2px solid var(--color-border);
	border-radius: 0.75rem;
	padding: 1rem 1.25rem;
	transition: all 0.3s ease;
}

.header-search-input-wrapper:focus-within {
	border-color: var(--color-link);
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.1);
}

.header-search-icon {
	color: var(--color-text);
	opacity: 0.5;
	margin-right: 1rem;
	flex-shrink: 0;
}

.header-search-input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: 1.125rem;
	color: var(--color-text-strong);
	padding: 0;
	outline: none;
}

.header-search-input::placeholder {
	color: var(--color-text);
	opacity: 0.6;
}

.header-search-submit {
	background: var(--color-link);
	color: #ffffff;
	border: none;
	padding: 0.75rem 2rem;
	border-radius: 0.5rem;
	font-weight: 600;
	font-size: 1rem;
	cursor: pointer;
	transition: all 0.2s ease;
	margin-left: 1rem;
}

.header-search-submit:hover {
	background: var(--color-link-hover);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

.category-dropdown .dropdown-menu {
	min-width: 14rem;
}

.category-dropdown .dropdown-item {
	white-space: nowrap;
}

.main-navigation {
	display: block;
	width: 100%;
}

.main-navigation ul {
	display: none;
	list-style: none;
	margin: 0;
	padding-left: 0;
}

.main-navigation ul ul {
	box-shadow: 0 3px 3px rgba(0, 0, 0, 0.2);
	float: left;
	position: absolute;
	top: 100%;
	left: -999em;
	z-index: 99999;
}

.main-navigation ul ul ul {
	left: -999em;
	top: 0;
}

.main-navigation ul ul li:hover > ul,
.main-navigation ul ul li.focus > ul {
	display: block;
	left: auto;
}

.main-navigation ul ul a {
	width: 200px;
}

.main-navigation ul li:hover > ul,
.main-navigation ul li.focus > ul {
	left: auto;
}

.main-navigation li {
	position: relative;
}

.main-navigation a {
	display: block;
	text-decoration: none;
}

/* Small menu. */
.menu-toggle,
.main-navigation.toggled ul {
	display: block;
}

@media screen and (min-width: 37.5em) {

	.menu-toggle {
		display: none;
	}

	.main-navigation ul {
		display: flex;
	}
}

.site-main .comment-navigation,
.site-main
.posts-navigation,
.site-main
.post-navigation {
	margin: 0 0 1.5em;
}

.comment-navigation .nav-links,
.posts-navigation .nav-links,
.post-navigation .nav-links {
	display: flex;
}

.comment-navigation .nav-previous,
.posts-navigation .nav-previous,
.post-navigation .nav-previous {
	flex: 1 0 50%;
}

.comment-navigation .nav-next,
.posts-navigation .nav-next,
.post-navigation .nav-next {
	text-align: end;
	flex: 1 0 50%;
}

/* Posts and pages
--------------------------------------------- */
.sticky {
	display: block;
}

.post,
.page {
	margin: 0 0 1.5em;
}

.updated:not(.published) {
	display: none;
}

.page-content,
.entry-content,
.entry-summary {
	margin: 1.5em 0 0;
}

.page-links {
	clear: both;
	margin: 0 0 1.5em;
}

/* Comments
--------------------------------------------- */
.comments-area {
	margin: 3rem 0;
	padding: 2rem 0;
	border-top: 1px solid var( --color-border );
}

.comments-title {
	color: var( --color-text-strong ) !important;
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 2rem;
}

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

.comment {
	margin-bottom: 2rem;
	padding: 1.5rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
}

.comment-content {
	color: var( --color-text ) !important;
	line-height: 1.7;
	margin-top: 1rem;
}

.comment-content a {
	word-wrap: break-word;
	color: var( --color-link );
}

.comment-content p {
	margin-bottom: 1rem;
}

.comment-meta {
	margin-bottom: 1rem;
}

.comment-author {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 0.5rem;
}

.comment-author .avatar {
	border-radius: 50%;
	width: 50px;
	height: 50px;
}

.comment-author .fn {
	color: var( --color-text-strong ) !important;
	font-weight: 600;
	font-size: 1rem;
	font-style: normal;
}

.comment-author .fn a {
	color: var( --color-text-strong ) !important;
	text-decoration: none;
}

.comment-author .fn a:hover {
	color: var( --color-link ) !important;
}

.comment-metadata {
	color: var( --color-text );
	font-size: 0.875rem;
	opacity: 0.8;
}

.comment-metadata a {
	color: var( --color-text );
	text-decoration: none;
}

.comment-metadata a:hover {
	color: var( --color-link );
}

.bypostauthor {
	display: block;
	background: var( --color-bg );
	border-left: 3px solid var( --color-link );
}

/* Comment Form */
.comment-form {
	margin-top: 0;
}

.comment-form-title,
#reply-title {
	color: var( --color-text-strong ) !important;
	font-size: 1.75rem;
	font-weight: 700;
	margin-bottom: 1.5rem;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var( --color-border );
}

.comment-form-comment label,
.comment-form-author label,
.comment-form-email label,
.comment-form-url label {
	display: block;
	color: var( --color-text-strong ) !important;
	font-weight: 600;
	font-size: 0.9375rem;
	margin-bottom: 0.5rem;
}

.comment-form-comment textarea,
.comment-form-author input,
.comment-form-email input,
.comment-form-url input {
	width: 100%;
	padding: 0.875rem 1rem;
	border: 2px solid var( --color-border );
	border-radius: 0.5rem;
	background: var( --color-bg );
	color: var( --color-text ) !important;
	font-size: 0.9375rem;
	line-height: 1.5;
	transition: all 0.3s ease;
	font-family: inherit;
}

.comment-form-comment textarea {
	min-height: 150px;
	resize: vertical;
}

.comment-form-comment textarea:focus,
.comment-form-author input:focus,
.comment-form-email input:focus,
.comment-form-url input:focus {
	outline: none;
	border-color: var( --color-link );
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.1);
	background: var( --color-bg );
	color: var( --color-text ) !important;
}

.comment-form-comment textarea::placeholder,
.comment-form-author input::placeholder,
.comment-form-email input::placeholder,
.comment-form-url input::placeholder {
	color: var( --color-text );
	opacity: 0.6;
}

/* Form Fields Container */
.comment-form-author,
.comment-form-email,
.comment-form-url {
	margin-bottom: 1.5rem;
}

/* Name and Email in 2 columns - Desktop */
@media screen and (min-width: 48rem) {
	.comment-form .comment-form-author,
	.comment-form .comment-form-email {
		display: inline-block;
		width: calc(50% - 0.75rem);
		vertical-align: top;
		margin-bottom: 1.5rem;
	}
	
	.comment-form .comment-form-author {
		margin-right: 1.5rem;
	}
}

/* Mobile - Stack vertically */
@media screen and (max-width: 47.9375rem) {
	.comment-form .comment-form-author,
	.comment-form .comment-form-email {
		display: block;
		width: 100%;
		margin-right: 0;
	}
}

.comment-form-comment {
	margin-bottom: 1.5rem;
}

.comment-form-cookies-consent {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
}

.comment-form-cookies-consent input[type="checkbox"] {
	width: auto;
	margin-top: 0.25rem;
	cursor: pointer;
	accent-color: var( --color-link );
}

.comment-form-cookies-consent label {
	margin: 0;
	font-weight: normal;
	font-size: 0.9375rem;
	color: var( --color-text ) !important;
	cursor: pointer;
}

.comment-form .form-submit {
	margin: 0;
}

.comment-form .submit {
	background: var( --color-link );
	border: 2px solid var( --color-link );
	border-radius: 0.5rem;
	color: #ffffff;
	cursor: pointer;
	font-size: 1rem;
	font-weight: 600;
	padding: 0.875rem 2.5rem;
	transition: all 0.3s ease;
	text-transform: none;
	display: inline-block;
	position: relative;
	overflow: hidden;
}

.comment-form .submit::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 0;
	height: 0;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	transform: translate(-50%, -50%);
	transition: width 0.6s ease, height 0.6s ease;
	z-index: 1;
}

.comment-form .submit:hover::before {
	width: 300px;
	height: 300px;
}

.comment-form .submit:hover {
	background: var( --color-link-hover );
	border-color: var( --color-link-hover );
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

.comment-form .submit:active {
	transform: translateY(0);
}

.comment-form .submit span {
	position: relative;
	z-index: 2;
}

/* Required Field Indicator */
.required {
	color: #dc3545;
	margin-left: 0.25rem;
}

/* Form Fields Grid - Already defined above */

/* Comment Reply Link */
.comment-reply-link {
	display: inline-block;
	padding: 0.5rem 1rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	color: var( --color-text );
	text-decoration: none;
	font-size: 0.875rem;
	font-weight: 500;
	margin-top: 1rem;
	transition: all 0.2s ease;
	border-radius: 0.5rem;
}

.comment-reply-link:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
}

/* Nested Comments */
.children {
	list-style: none;
	margin: 1.5rem 0 0 2rem;
	padding: 0;
}

.children .comment {
	background: var( --color-bg );
	border-left: 3px solid var( --color-border );
}

/* Comment Navigation */
.comment-navigation {
	margin: 2rem 0;
	padding: 1rem 0;
	border-top: 1px solid var( --color-border );
	border-bottom: 1px solid var( --color-border );
}

.comment-navigation .nav-links a {
	color: var( --color-link );
	text-decoration: none;
	font-weight: 500;
}

.comment-navigation .nav-links a:hover {
	text-decoration: underline;
}

.no-comments {
	color: var( --color-text );
	font-style: italic;
	text-align: center;
	padding: 2rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
}

/* Comment Respond Container */
.comment-respond {
	margin-top: 3rem;
	padding: 2rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
}

/* Logged In Message */
.logged-in-as {
	color: var( --color-text ) !important;
	font-size: 0.9375rem;
	margin-bottom: 1.5rem;
	padding: 0.75rem 1rem;
	background: var( --color-bg );
	border-left: 3px solid var( --color-link );
}

.logged-in-as a {
	color: var( --color-link );
	text-decoration: none;
}

.logged-in-as a:hover {
	text-decoration: underline;
}

/* Must Log In Message */
.must-log-in {
	color: var( --color-text ) !important;
	text-align: center;
	padding: 1.5rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
}

.must-log-in a {
	color: var( --color-link );
	text-decoration: none;
	font-weight: 600;
}

.must-log-in a:hover {
	text-decoration: underline;
}

/* Comment Notes */
.comment-notes {
	color: var( --color-text ) !important;
	font-size: 0.875rem;
	margin-bottom: 1.5rem;
	padding: 0.75rem 1rem;
	background: var( --color-bg );
	border-left: 3px solid var( --color-border );
	border-radius: 0.5rem;
	opacity: 0.9;
}

/* Cancel Reply Link */
#cancel-comment-reply-link {
	color: var( --color-text );
	text-decoration: none;
	font-size: 0.875rem;
	margin-left: 1rem;
	padding: 0.25rem 0.75rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	transition: all 0.2s ease;
}

#cancel-comment-reply-link:hover {
	color: var( --color-link );
	border-color: var( --color-link );
	background: var( --color-bg );
}

/* Form Field Focus States */
.comment-form input:focus,
.comment-form textarea:focus {
	background: var( --color-bg ) !important;
}

/* Submit Button Enhancement */
.comment-form .submit {
	position: relative;
	overflow: hidden;
}

.comment-form .submit::after {
	content: '→';
	position: absolute;
	right: -20px;
	top: 50%;
	transform: translateY(-50%);
	transition: right 0.3s ease;
	opacity: 0;
}

.comment-form .submit:hover::after {
	right: 1.5rem;
	opacity: 1;
}

.comment-form .submit:hover span {
	transform: translateX(-5px);
	transition: transform 0.3s ease;
}

/* Comment Form Responsive */
@media screen and (max-width: 48rem) {
	.comment-respond {
		padding: 1.5rem;
	}
	
	.comment-form-author,
	.comment-form-email {
		width: 100% !important;
		margin-right: 0 !important;
	}
	
	.comment-form .submit {
		width: 100%;
	}
}

/* Widgets
--------------------------------------------- */
.widget {
	margin: 0 0 1.5em;
	background: var( --color-surface );
	padding: 1.25rem;
	border-radius: 6px;
	border: 1px solid var( --color-border );
}

.widget select {
	max-width: 100%;
}

/* Theme toggle */
.theme-toggle {
	align-items: center;
	background: var( --color-toggle-bg );
	border: 1px solid var( --color-toggle-border );
	border-radius: 999px;
	color: var( --color-text );
	cursor: pointer;
	display: inline-flex;
	font-size: 0.875rem;
	gap: 0.35rem;
	padding: 0.4rem 0.85rem;
	transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.theme-toggle:hover {
	border-color: var( --color-link );
	color: var( --color-link );
}

.theme-toggle svg {
	height: 1rem;
	width: 1rem;
	fill: currentColor;
}

/* Icon-only theme toggle */
.theme-toggle-icon-only {
	padding: 0.5rem;
	width: 2.5rem;
	height: 2.5rem;
	justify-content: center;
	position: relative;
}

.theme-toggle-icon-only .theme-icon {
	height: 1.25rem;
	width: 1.25rem;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	transition: opacity 0.3s ease, transform 0.3s ease;
	opacity: 0;
	pointer-events: none;
}

.theme-toggle-icon-only .theme-icon.active {
	opacity: 1;
	transform: translate(-50%, -50%) rotate(0deg);
}

.theme-toggle-icon-only .theme-icon-sun.active {
	transform: translate(-50%, -50%) rotate(0deg);
}

.theme-toggle-icon-only .theme-icon-moon.active {
	transform: translate(-50%, -50%) rotate(-15deg);
}

.theme-toggle-icon-only .theme-icon:not(.active) {
	opacity: 0;
	transform: translate(-50%, -50%) scale(0.8);
}

/* Animated Hamburger Menu
--------------------------------------------- */
.hamburger-menu {
	background: transparent;
	border: none;
	cursor: pointer;
	display: inline-block;
	padding: 0.5rem;
	position: relative;
	width: 2.5rem;
	height: 2.5rem;
}

.hamburger-box {
	display: inline-block;
	height: 1.5rem;
	position: relative;
	width: 1.5rem;
}

.hamburger-inner {
	background-color: var( --color-text );
	border-radius: 0.25rem;
	display: block;
	height: 0.1875rem;
	margin-top: -0.09375rem;
	position: absolute;
	top: 50%;
	transition-duration: 0.15s;
	transition-property: transform;
	transition-timing-function: ease;
	width: 1.5rem;
}

.hamburger-inner::before,
.hamburger-inner::after {
	background-color: var( --color-text );
	border-radius: 0.25rem;
	content: "";
	display: block;
	height: 0.1875rem;
	position: absolute;
	transition-duration: 0.15s;
	transition-property: transform;
	transition-timing-function: ease;
	width: 1.5rem;
}

.hamburger-inner::before {
	top: -0.5rem;
	transition: top 0.1s 0.14s ease, opacity 0.1s ease;
}

.hamburger-inner::after {
	bottom: -0.5rem;
	transition: bottom 0.1s 0.14s ease, transform 0.1s cubic-bezier(0.55, 0.055, 0.675, 0.19);
}

/* Active/Open State */
.hamburger-menu[aria-expanded="true"] .hamburger-inner {
	transform: rotate(45deg);
	transition-delay: 0.14s;
	transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}

.hamburger-menu[aria-expanded="true"] .hamburger-inner::before {
	opacity: 0;
	top: 0;
	transition: top 0.1s ease, opacity 0.1s 0.14s ease;
}

.hamburger-menu[aria-expanded="true"] .hamburger-inner::after {
	bottom: 0;
	transform: rotate(-90deg);
	transition: bottom 0.1s ease, transform 0.1s 0.14s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.hamburger-menu:hover .hamburger-inner,
.hamburger-menu:hover .hamburger-inner::before,
.hamburger-menu:hover .hamburger-inner::after {
	background-color: var( --color-link );
}

/* Override Bootstrap navbar-toggler for dark mode */
html[data-theme="dark"] .navbar-toggler {
	border-color: var( --color-border );
}

html[data-theme="dark"] .navbar-toggler-icon {
	background-image: none;
}

/* Navigation Dropdown Styles */
.navbar-nav .dropdown {
	position: relative;
}

.navbar-nav .dropdown-menu {
	background: var( --color-bg ) !important;
	border: 1px solid var( --color-border ) !important;
	border-radius: 0.375rem;
	box-shadow: 0 0.25rem 0.5rem rgba(0, 0, 0, 0.1);
	margin-top: 0.5rem;
	padding: 0.5rem 0;
	display: none;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 1000;
	min-width: 200px;
}

.navbar-nav .dropdown.show .dropdown-menu,
.navbar-nav .dropdown-menu.show {
	display: block !important;
	opacity: 1 !important;
	visibility: visible !important;
	transform: translateY(0);
}

.navbar-nav .dropdown-item {
	color: var( --color-text ) !important;
	padding: 0.5rem 1rem;
	transition: background-color 0.15s ease, color 0.15s ease;
}

.navbar-nav .dropdown-item:hover,
.navbar-nav .dropdown-item:focus {
	background-color: var( --color-surface ) !important;
	color: var( --color-link ) !important;
}

.navbar-nav .nav-link {
	color: var( --color-text ) !important;
	font-weight: 500;
	padding: 0.5rem 1rem;
	transition: color 0.15s ease;
}

.navbar-nav .nav-link:hover,
.navbar-nav .nav-link:focus {
	color: var( --color-link ) !important;
}

.navbar-nav .dropdown-toggle::after {
	border-top-color: var( --color-text );
	transition: transform 0.3s ease;
	transform: rotate(0deg);
}

.navbar-nav .dropdown.show .dropdown-toggle::after,
.navbar-nav .dropdown-toggle[aria-expanded="true"]::after {
	transform: rotate(180deg);
}

html[data-theme="dark"] .navbar-nav .dropdown-toggle::after {
	border-top-color: var( --color-text );
}

/* Media
--------------------------------------------- */
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
	border: none;
	margin-bottom: 0;
	margin-top: 0;
	padding: 0;
}

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
	display: inline-block;
}

/* Captions
--------------------------------------------- */
.wp-caption {
	margin-bottom: 1.5em;
	max-width: 100%;
}

.wp-caption img[class*="wp-image-"] {
	display: block;
	margin-left: auto;
	margin-right: auto;
}

.wp-caption .wp-caption-text {
	margin: 0.8075em 0;
}

.wp-caption-text {
	text-align: center;
}

/* Galleries
--------------------------------------------- */
.gallery {
	margin-bottom: 1.5em;
	display: grid;
	grid-gap: 1.5em;
}

.gallery-item {
	display: inline-block;
	text-align: center;
	width: 100%;
}

.gallery-columns-2 {
	grid-template-columns: repeat(2, 1fr);
}

.gallery-columns-3 {
	grid-template-columns: repeat(3, 1fr);
}

.gallery-columns-4 {
	grid-template-columns: repeat(4, 1fr);
}

.gallery-columns-5 {
	grid-template-columns: repeat(5, 1fr);
}

.gallery-columns-6 {
	grid-template-columns: repeat(6, 1fr);
}

.gallery-columns-7 {
	grid-template-columns: repeat(7, 1fr);
}

.gallery-columns-8 {
	grid-template-columns: repeat(8, 1fr);
}

.gallery-columns-9 {
	grid-template-columns: repeat(9, 1fr);
}

.gallery-caption {
	display: block;
}

/*--------------------------------------------------------------
# Plugins
--------------------------------------------------------------*/

/* Jetpack infinite scroll
--------------------------------------------- */

/* Hide the Posts Navigation and the Footer when Infinite Scroll is in use. */
.infinite-scroll .posts-navigation,
.infinite-scroll.neverending .site-footer {
	display: none;
}

/* Re-display the Theme Footer when Infinite Scroll has reached its end. */
.infinity-end.neverending .site-footer {
	display: block;
}

/*--------------------------------------------------------------
# Utilities
--------------------------------------------------------------*/

/* Accessibility
--------------------------------------------- */

/* Text meant only for screen readers. */
.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}

/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}

/* Alignments
--------------------------------------------- */
.alignleft {

	/*rtl:ignore*/
	float: left;

	/*rtl:ignore*/
	margin-right: 1.5em;
	margin-bottom: 1.5em;
}

.alignright {

	/*rtl:ignore*/
	float: right;

	/*rtl:ignore*/
	margin-left: 1.5em;
	margin-bottom: 1.5em;
}

.aligncenter {
	clear: both;
	display: block;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 1.5em;
}








/*--------------------------------------------------------------
# scroll-top-btn
--------------------------------------------------------------*/

.scroll-top-btn {
	position: fixed;
	right: 1.5rem;
	bottom: 1.5rem;
	width: 3.5rem;
	height: 3.5rem;
	border-radius: 50%;
	border: none;
	background: linear-gradient(135deg, var(--color-link), var(--color-link-hover));
	box-shadow: 0 12px 30px rgba(65, 105, 225, 0.35);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transform: translate3d(0, 15px, 0) scale(0.9);
	transition: opacity 0.3s 
ease, transform 0.3s 
ease, visibility 0.3s 
ease;
	z-index: 1200;
}
.scroll-top-btn.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translate3d(0, 0, 0) scale(1);
}
.scroll-top-btn:hover {
	transform: translate3d(0, -4px, 0) scale(1.03);
	box-shadow: 0 16px 35px rgba(65, 105, 225, 0.45);
}





/*--------------------------------------------------------------
# Footer
--------------------------------------------------------------*/

.site-footer {
	background: var( --color-surface );
	border-top: 1px solid var( --color-border );
	margin-top: 4rem;
	padding-top: 3rem;
}

.footer-main {
	padding-bottom: 2rem;
}

.footer-brand {
	margin-bottom: 1.5rem;
}

.footer-brand .custom-logo-link {
	display: inline-block;
	margin-bottom: 1rem;
}

.footer-logo-wrapper {
	display: inline-block;
	position: relative;
	margin-bottom: 1rem;
	width: 12rem;
}

.footer-logo-wrapper .custom-logo-link {
	position: relative;
	display: inline-block;
}

.footer-logo-wrapper .logo-light,
.footer-logo-wrapper .logo-dark {
	display: block;
	max-width: 100%;
	height: auto;
	transition: opacity 0.3s ease, visibility 0.3s ease;
}

/* Light Theme - Show Light Logo, Hide Dark Logo */
.footer-logo-wrapper .logo-light {
	opacity: 1;
	visibility: visible;
	position: relative;
}

.footer-logo-wrapper .logo-dark {
	opacity: 0;
	visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* Dark Theme - Show Dark Logo, Hide Light Logo */
html[data-theme="dark"] .footer-logo-wrapper .logo-light {
	opacity: 0;
	visibility: hidden;
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: contain;
}

html[data-theme="dark"] .footer-logo-wrapper .logo-dark {
	opacity: 1;
	visibility: visible;
	position: relative;
}

/* If only one logo is set (same logo for both themes), show it in both themes */
.footer-logo-wrapper .logo-single {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
}

html[data-theme="dark"] .footer-logo-wrapper .logo-single {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
}

/* Fallback for browsers that don't support :has() */
.footer-logo-wrapper .custom-logo-link .logo-dark:only-child,
.footer-logo-wrapper .custom-logo-link .logo-light:only-child {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
}

html[data-theme="dark"] .footer-logo-wrapper .custom-logo-link .logo-dark:only-child,
html[data-theme="dark"] .footer-logo-wrapper .custom-logo-link .logo-light:only-child {
	position: relative !important;
	opacity: 1 !important;
	visibility: visible !important;
}

.footer-logo-text {
	font-size: 1.5rem;
	font-weight: 700;
	margin: 0 0 1rem;
}

.footer-logo-text a {
	color: var( --color-text-strong );
	text-decoration: none;
	transition: color 0.2s ease;
}

.footer-logo-text a:hover {
	color: var( --color-link );
}

.footer-description {
	color: var( --color-text );
	font-size: 0.9375rem;
	line-height: 1.6;
	margin: 0 0 1.5rem;
	max-width: 20rem;
}

.footer-widget-title {
	color: var( --color-text-strong );
	font-size: 1.125rem;
	font-weight: 600;
	margin: 0 0 1.25rem;
}

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

.footer-links li {
	margin-bottom: 0.75rem;
}

.footer-links a {
	color: var( --color-text );
	text-decoration: none;
	transition: color 0.2s ease;
	display: inline-block;
}

.footer-links a:hover {
	color: var( --color-link );
	padding-left: 0.25rem;
}

.footer-social-description {
	color: var( --color-text );
	font-size: 0.875rem;
	margin: 0 0 1.25rem;
}

.footer-social-icons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.social-icon {
	align-items: center;
	background: var( --color-toggle-bg );
	border: 1px solid var( --color-toggle-border );
	border-radius: 50%;
	color: var( --color-text );
	cursor: pointer;
	display: inline-flex;
	height: 2.5rem;
	justify-content: center;
	transition: all 0.2s ease;
	width: 2.5rem;
	text-decoration: none;
}

.social-icon svg {
	fill: currentColor;
	height: 1.25rem;
	width: 1.25rem;
	display: block;
}

.social-icon span {
	display: inline-flex;
}

.social-icon:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
}

.social-icon.social-facebook:hover {
	background: #1877f2;
	border-color: #1877f2;
}

.social-icon.social-twitter:hover {
	background: #1da1f2;
	border-color: #1da1f2;
}

.social-icon.social-instagram:hover {
	background: linear-gradient(45deg, #f09433 0%, #e6683c 25%, #dc2743 50%, #cc2366 75%, #bc1888 100%);
	border-color: #bc1888;
}

.social-icon.social-linkedin:hover {
	background: #0077b5;
	border-color: #0077b5;
}

.social-icon.social-youtube:hover {
	background: #ff0000;
	border-color: #ff0000;
}

.social-icon.social-pinterest:hover {
	background: #bd081c;
	border-color: #bd081c;
}

.footer-bottom {
	background: var( --color-bg );
	border-top: 1px solid var( --color-border );
	padding: 1.5rem 0;
}

.footer-copyright,
.footer-credits {
	color: var( --color-text );
	font-size: 0.875rem;
}

.footer-copyright a,
.footer-credits a {
	color: var( --color-link );
	text-decoration: none;
}

.footer-copyright a:hover,
.footer-credits a:hover {
	text-decoration: underline;
}

@media screen and (max-width: 48rem) {
	.footer-bottom .text-md-right {
		text-align: left !important;
		margin-top: 0.75rem;
	}
}

/*--------------------------------------------------------------
# Home Page Template
--------------------------------------------------------------*/

/* Hero Section */
.home-hero {
	background: var( --color-bg );
	padding: 4rem 0;
	margin-bottom: 3rem;
	border-radius: 0;
}

.hero-content {
	padding: 2rem 0;
}

.hero-title {
	color: var( --color-text-strong ) !important;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 1.5rem;
}

html[data-theme="dark"] .hero-title {
	color: var( --color-text-strong ) !important;
}

.hero-description {
	color: var( --color-text ) !important;
	font-size: 1.25rem;
	line-height: 1.6;
	margin-bottom: 2rem;
}

html[data-theme="dark"] .hero-description {
	color: var( --color-text ) !important;
}

.hero-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

/* Animated Button Styles */
.btn-animated {
	position: relative;
	overflow: hidden;
	transition: all 0.3s ease;
	border-radius: 0.5rem;
	font-weight: 600;
	padding: 0.875rem 2rem;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-decoration: none;
	border: 2px solid transparent;
}

.btn-animated .btn-text {
	position: relative;
	z-index: 2;
	transition: transform 0.3s ease;
}

.btn-animated .btn-icon {
	position: relative;
	z-index: 2;
	transition: transform 0.3s ease;
	font-size: 1.25rem;
	line-height: 1;
}

.btn-animated::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 0;
	height: 0;
	background: rgba(255, 255, 255, 0.2);
	border-radius: 50%;
	transform: translate(-50%, -50%);
	transition: width 0.6s ease, height 0.6s ease;
	z-index: 1;
}

.btn-animated:hover::before {
	width: 300px;
	height: 300px;
}

.btn-animated:hover .btn-icon {
	transform: translateX(4px);
}

.btn-animated:hover {
	transform: translateY(-2px);
	box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.btn-primary.btn-animated {
	background: linear-gradient(135deg, var( --color-link ) 0%, var( --color-link-hover ) 100%);
	color: #ffffff;
	border-color: var( --color-link );
}

.btn-primary.btn-animated:hover {
	background: linear-gradient(135deg, var( --color-link-hover ) 0%, var( --color-link ) 100%);
	box-shadow: 0 8px 25px rgba(65, 105, 225, 0.4);
}

.btn-outline-primary.btn-animated {
	background: transparent;
	color: var( --color-link );
	border-color: var( --color-link );
}

.btn-outline-primary.btn-animated:hover {
	background: var( --color-link );
	color: #ffffff;
	border-color: var( --color-link );
	box-shadow: 0 8px 25px rgba(65, 105, 225, 0.3);
}

.btn-animated:active {
	transform: translateY(0);
}

/* Custom Button Variants - Base Styles */
/* These styles are enhanced by dynamic CSS from Customizer */
.btn-variant-1,
.btn-variant-2,
.btn-variant-3 {
	display: inline-block;
	text-align: center;
	white-space: nowrap;
	vertical-align: middle;
	user-select: none;
	border: 2px solid;
	text-decoration: none;
	cursor: pointer;
	transition: all 0.3s ease;
	line-height: 1.5;
}

.btn-variant-1:focus,
.btn-variant-2:focus,
.btn-variant-3:focus {
	outline: 2px solid rgba(65, 105, 225, 0.5);
	outline-offset: 2px;
}

.btn-variant-1:active,
.btn-variant-2:active,
.btn-variant-3:active {
	transform: translateY(0);
}

/* Button Variant Sizes (Optional) */
.btn-variant-1.btn-small,
.btn-variant-2.btn-small,
.btn-variant-3.btn-small {
	padding: 0.5rem 1rem;
	font-size: 0.875rem;
}

.btn-variant-1.btn-large,
.btn-variant-2.btn-large,
.btn-variant-3.btn-large {
	padding: 1rem 2.5rem;
	font-size: 1.125rem;
}

/* Hero Image Styles */
.hero-image-wrapper {
	text-align: center;
	padding: 1rem;
}

.hero-image {
	text-align: center;
	position: relative;
	animation: fadeInUp 0.8s ease;
}

.hero-image img {
	border-radius: 0.75rem;
	box-shadow: 0 15px 40px rgba(0, 0, 0, 0.15);
	max-width: 100%;
	height: auto;
	display: block;
	transition: transform 0.3s ease;
}

.hero-image:hover img {
	transform: scale(1.02);
}

html[data-theme="dark"] .hero-image img {
	box-shadow: 0 15px 40px rgba(0, 0, 0, 0.4);
}

.hero-image-placeholder {
	background: var( --color-surface );
	border: 2px dashed var( --color-border );
	border-radius: 0.75rem;
	padding: 3rem 2rem;
	min-height: 300px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.placeholder-content {
	text-align: center;
	color: var( --color-text );
}

.placeholder-content svg {
	width: 4rem;
	height: 4rem;
	margin: 0 auto 1rem;
	opacity: 0.5;
	color: var( --color-text );
}

.placeholder-content p {
	margin: 0;
	font-size: 0.875rem;
	opacity: 0.7;
}

/* Categories Section */
.home-categories {
	padding: 4rem 0 3rem;
	background: var( --color-bg );
}

.home-categories .section-description {
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
}

.category-grid {
	row-gap: 2rem;
}

.category-card {
	position: relative;
	height: 100%;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 1.25rem;
	padding: 1.5rem;
	box-shadow: 0 20px 50px rgba( 0, 0, 0, 0.05 );
	overflow: hidden;
	transition: transform 0.3s ease, box-shadow 0.3s ease, border-color 0.3s ease;
}

html[data-theme="dark"] .category-card {
	box-shadow: 0 20px 45px rgba( 0, 0, 0, 0.4 );
}

.category-card::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(circle at top right, rgba(65, 105, 225, 0.12), transparent 45%);
	opacity: 0;
	transition: opacity 0.3s ease;
}

.category-card:hover {
	transform: translateY(-6px);
	border-color: var( --color-link );
	box-shadow: 0 25px 60px rgba(65, 105, 225, 0.25);
}

.category-card:hover::before {
	opacity: 1;
}

.category-card-link {
	position: absolute;
	inset: 0;
	z-index: 3;
}

.category-media {
	position: relative;
	border-radius: 1rem;
	overflow: hidden;
	padding-top: 60%;
	margin-bottom: 1.25rem;
	background: var( --color-bg );
}

.category-media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.category-card:hover .category-media img {
	transform: scale(1.05);
}

.category-media-placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(65, 105, 225, 0.15), rgba(65, 105, 225, 0.3));
	color: var( --color-link );
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.category-content {
	position: relative;
	z-index: 2;
}

.category-meta {
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var( --color-text );
	margin-bottom: 0.35rem;
	gap: 0.75rem;
}

.category-pill,
.post-category-badge a,
.search-result-category-badge a,
.work-type-badge,
.work-type-badge a {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.35rem 0.95rem;
	border-radius: 999px;
	background: linear-gradient(135deg, rgba(65, 105, 225, 0.18), rgba(65, 105, 225, 0.32));
	color: var(--color-link);
	font-size: 0.78rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	border: 1px solid rgba(65, 105, 225, 0.25);
	box-shadow: 0 6px 18px rgba(65, 105, 225, 0.18);
	transition: transform 0.2s ease, box-shadow 0.2s ease, background 0.2s ease;
}

.category-pill:hover,
.post-category-badge a:hover,
.search-result-category-badge a:hover,
.work-type-badge:hover,
.work-type-badge a:hover {
	background: linear-gradient(135deg, rgba(65, 105, 225, 0.28), rgba(65, 105, 225, 0.45));
	box-shadow: 0 10px 25px rgba(65, 105, 225, 0.25);
	transform: translateY(-2px);
	color: var(--color-link-hover);
}

.work-type-badge svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	fill: none;
}

.category-title {
	font-size: 1.35rem;
	font-weight: 700;
	margin-bottom: 0.35rem;
	color: var( --color-text-strong );
}

.category-description {
	color: var( --color-text );
	margin-bottom: 1.1rem;
	line-height: 1.65;
}

.category-link-text {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-weight: 600;
	color: var( --color-link );
	font-size: 0.95rem;
}

.category-link-text svg {
	width: 1rem;
	height: 1rem;
	stroke: currentColor;
	transition: transform 0.3s ease;
}

.category-card:hover .category-link-text svg {
	transform: translateX(4px);
}

.no-categories-message {
	color: var( --color-text );
	opacity: 0.7;
	font-size: 1rem;
}

@media (max-width: 992px) {
	.category-card {
		padding: 1.25rem;
	}
}

@media (max-width: 768px) {
	.home-categories {
		padding: 3rem 0 2rem;
	}

	.category-media {
		margin-bottom: 1rem;
	}
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@media screen and (max-width: 48rem) {
	.hero-title {
		font-size: 2rem;
	}
	
	.hero-description {
		font-size: 1rem;
	}
	
	.home-hero {
		padding: 2rem 0;
	}
}

/* Features Section */
.home-features {
	background: var( --color-surface );
	padding: 4rem 0;
	margin-bottom: 3rem;
	border-radius: 0;
}

.section-header {
	margin-bottom: 3rem;
}

.section-title {
	color: var( --color-text-strong ) !important;
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
}

html[data-theme="dark"] .section-title {
	color: var( --color-text-strong ) !important;
}

.section-description {
	color: var( --color-text ) !important;
	font-size: 1.125rem;
	margin: 0;
}

html[data-theme="dark"] .section-description {
	color: var( --color-text ) !important;
}

.feature-card {
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	padding: 2rem;
	text-align: center;
	transition: all 0.3s ease;
	height: 100%;
}

.feature-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

html[data-theme="dark"] .feature-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.feature-icon {
	font-size: 3rem;
	margin-bottom: 1rem;
	line-height: 1;
}

.feature-title {
	color: var( --color-text-strong );
	font-size: 1.5rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

.feature-description {
	color: var( --color-text );
	font-size: 1rem;
	line-height: 1.6;
	margin: 0;
}

/* Work Section */
.home-work {
	background: var( --color-bg );
	padding: 4rem 0;
	margin-bottom: 3rem;
	border-radius: 0;
}

/* Posts Section */
.home-posts {
	background: var( --color-bg );
	padding: 4rem 0;
	margin-bottom: 3rem;
	border-radius: 0;
}

.post-card {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	overflow: hidden;
	transition: all 0.3s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
}

.post-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

html[data-theme="dark"] .post-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.3);
}

.post-thumbnail {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding-top: 56.25%; /* 16:9 aspect ratio */
}

.post-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.post-card:hover .post-thumbnail img {
	transform: scale(1.05);
}

/* Category Badge */
.post-category-badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
}

.post-category-badge a {
	display: inline-block;
	padding: 0.5rem 1rem;
	background: rgba(0, 0, 0, 0.75);
	color: #ffffff;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.5px;
	text-transform: uppercase;
	border-radius: 999px;
	text-decoration: none;
	transition: all 0.2s ease;
}

.post-category-badge a:hover {
	background: rgba(0, 0, 0, 0.9);
	transform: translateY(-2px);
}

html[data-theme="dark"] .post-category-badge a {
	background: rgba(255, 255, 255, 0.2);
}

/* Post meta line */
.post-meta-line {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 1rem;
	color: var( --color-text );
	font-size: 0.875rem;
}

.post-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	opacity: 0.85;
}

.post-meta-item svg {
	width: 16px;
	height: 16px;
	stroke: currentColor;
	fill: none;
}

.post-meta-separator {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var( --color-border );
}

.post-content {
	padding: 1.5rem;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.post-meta {
	color: var( --color-text );
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	font-size: 0.875rem;
	margin-bottom: 1rem;
}

.post-date {
	opacity: 0.8;
}

.post-category a {
	color: var( --color-link );
	text-decoration: none;
}

.post-category a:hover {
	text-decoration: underline;
}

.post-title {
	color: var( --color-text-strong );
	font-size: 1.5rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

.post-title a {
	color: inherit;
	text-decoration: none;
	transition: color 0.2s ease;
}

.post-title a:hover {
	color: var( --color-link );
}

.post-excerpt {
	color: var( --color-text );
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: 1rem;
	flex-grow: 1;
}

.post-read-more-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: transparent;
	color: var( --color-link );
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	border: none;
	padding: 0;
	transition: all 0.3s ease;
	margin-top: auto;
	width: fit-content;
}

.post-read-more-btn:hover {
	background: transparent;
	color: var( --color-link-hover );
	transform: translateX(4px);
	box-shadow: none;
}

.post-read-more-btn svg {
	width: 1rem;
	height: 1rem;
	stroke: currentColor;
	fill: none;
	transition: transform 0.3s ease;
}

.post-read-more-btn:hover svg {
	transform: translateX(4px);
}

/* Overlay elements on blog cards */
.post-category-badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
}

.post-category-badge a {
	display: inline-block;
	padding: 0.45rem 1.1rem;
	background: rgba(0, 0, 0, 0.75);
	color: #ffffff;
	font-size: 0.8125rem;
	font-weight: 600;
	letter-spacing: 0.4px;
	text-transform: uppercase;
	border-radius: 999px;
	text-decoration: none;
	transition: all 0.2s ease;
}

.post-category-badge a:hover {
	background: rgba(0, 0, 0, 0.9);
	transform: translateY(-2px);
}

html[data-theme="dark"] .post-category-badge a {
	background: rgba(255, 255, 255, 0.2);
}

.post-date-badge {
	position: absolute;
	bottom: 1rem;
	left: 1rem;
	z-index: 2;
}

.post-date-badge span {
	display: inline-block;
	padding: 0.45rem 1rem;
	background: rgba(0, 0, 0, 0.7);
	color: #ffffff;
	font-size: 0.8125rem;
	border-radius: 0.35rem;
}

html[data-theme="dark"] .post-date-badge span {
	background: rgba(0, 0, 0, 0.8);
}

.post-read-more-overlay {
	position: absolute;
	top: 1rem;
	right: 1rem;
	z-index: 2;
}

.read-more-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.55rem 1.1rem;
	background: rgba(255, 255, 255, 0.95);
	color: var( --color-text-strong );
	font-size: 0.8125rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 0.4rem;
	box-shadow: 0 3px 12px rgba(0, 0, 0, 0.15);
	transition: all 0.2s ease;
}

.read-more-btn:hover {
	color: var( --color-link );
	transform: translateY(-2px);
}

.read-more-btn svg {
	width: 15px;
	height: 15px;
	stroke: currentColor;
	fill: none;
	transition: transform 0.2s ease;
}

.read-more-btn:hover svg {
	transform: translateX(2px);
}

.post-read-more {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: transparent;
	color: var( --color-link );
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	border: none;
	padding: 0;
	transition: all 0.3s ease;
}

.post-read-more:hover {
	background: transparent;
	color: var( --color-link-hover );
	transform: translateX(4px);
	padding-left: 0;
}

.post-read-more svg {
	width: 1rem;
	height: 1rem;
	stroke: currentColor;
	fill: none;
	transition: transform 0.3s ease;
}

.post-read-more:hover svg {
	transform: translateX(4px);
}

/* Responsive adjustments for post cards */
@media screen and (max-width: 48rem) {
	.post-category-badge {
		top: 0.75rem;
		left: 0.75rem;
	}
	
	.post-category-badge a {
		padding: 0.375rem 0.75rem;
		font-size: 0.8125rem;
	}
	
	.post-content {
		padding-top: 1.25rem;
		padding: 1rem;
	}
	
	.post-title {
		font-size: 1.25rem;
	}
	
	.post-excerpt {
		font-size: 0.9375rem;
	}
	
	.post-read-more-btn {
		padding: 0.625rem 1.25rem;
		font-size: 0.875rem;
	}
}

/* CTA Section */
.home-cta {
	background: linear-gradient(135deg, var( --color-link ) 0%, var( --color-link-hover ) 100%);
	padding: 5rem 0;
	margin: 4rem 0 3rem;
	position: relative;
	overflow: hidden;
	border-radius: 0;
}

.cta-background-pattern {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	opacity: 0.1;
	background-image: 
		radial-gradient(circle at 20% 50%, rgba(255, 255, 255, 0.3) 0%, transparent 50%),
		radial-gradient(circle at 80% 80%, rgba(255, 255, 255, 0.2) 0%, transparent 50%),
		radial-gradient(circle at 40% 20%, rgba(255, 255, 255, 0.15) 0%, transparent 50%);
	pointer-events: none;
}

.home-cta .container {
	position: relative;
	z-index: 2;
}

.cta-wrapper {
	background: rgba(255, 255, 255, 0.05);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 0;
	padding: 3rem 2rem;
	box-shadow: 0 20px 60px rgba(0, 0, 0, 0.2);
}

.cta-content {
	max-width: 100%;
	margin: 0 auto;
}

.cta-icon-wrapper {
	margin-bottom: 1.5rem;
	animation: float 3s ease-in-out infinite;
}

.cta-icon {
	font-size: 4rem;
	display: inline-block;
	filter: drop-shadow(0 4px 8px rgba(0, 0, 0, 0.2));
}

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

.cta-title {
	color: #ffffff;
	font-size: 2.75rem;
	font-weight: 700;
	margin-bottom: 1rem;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
	line-height: 1.2;
}

.cta-description {
	color: rgba(255, 255, 255, 0.95);
	font-size: 1.25rem;
	margin-bottom: 2rem;
	line-height: 1.6;
}

.cta-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
	margin-bottom: 2rem;
}

.cta-primary-btn {
	background: #ffffff;
	border-color: #ffffff;
	color: var( --color-link );
	box-shadow: 0 4px 15px rgba(255, 255, 255, 0.3);
}

.cta-primary-btn:hover {
	background: rgba(255, 255, 255, 0.95);
	border-color: rgba(255, 255, 255, 0.95);
	box-shadow: 0 8px 30px rgba(255, 255, 255, 0.4);
	transform: translateY(-3px);
}

.cta-secondary-btn {
	background: transparent;
	border-color: rgba(255, 255, 255, 0.5);
	color: #ffffff;
}

.cta-secondary-btn:hover {
	background: rgba(255, 255, 255, 0.1);
	border-color: rgba(255, 255, 255, 0.8);
	color: #ffffff;
	box-shadow: 0 8px 25px rgba(255, 255, 255, 0.2);
}


@media screen and (max-width: 48rem) {
	.section-title {
		font-size: 2rem;
	}
	
	.cta-title {
		font-size: 2rem;
	}
	
	.cta-wrapper {
		padding: 2rem 1.5rem;
	}
	
	.cta-icon {
		font-size: 3rem;
	}
	
	.home-features,
	.home-work,
	.home-posts,
	.home-cta {
		padding: 2rem 0;
	}
	
	.feature-card,
	.post-card {
		margin-bottom: 1.5rem;
	}

	/* Work Section Responsive */
	.work-posts-grid {
		margin: 0 -10px;
	}

	.work-posts-grid > [class*="col-"] {
		padding-left: 10px;
		padding-right: 10px;
	}

	.work-card {
		margin-bottom: 1.5rem;
	}

	.work-card-content {
		padding: 1.5rem;
	}

	.work-card-title {
		font-size: 1.25rem;
	}

	.work-card-excerpt {
		font-size: 0.9375rem;
	}
}

/*--------------------------------------------------------------
# Blog List Page
--------------------------------------------------------------*/

.blog-hero-section {
	background: linear-gradient(135deg, var( --color-surface ) 0%, var( --color-bg ) 100%);
	padding: 5rem 0 4rem;
	position: relative;
	overflow: hidden;
}

.blog-hero-title {
	font-size: 3rem;
	font-weight: 700;
	color: var( --color-text-strong );
	margin-bottom: 1rem;
}

.blog-hero-description {
	font-size: 1.15rem;
	line-height: 1.8;
	color: var( --color-text );
	opacity: 0.9;
}

.blog-hero-image {
	position: relative;
	min-height: 320px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.blog-hero-image img {
	max-width: 100%;
	border-radius: 1rem;
	box-shadow: 0 25px 60px rgba(0, 0, 0, 0.15);
}

.blog-hero-pattern {
	position: relative;
	width: 100%;
	height: 320px;
}

.blog-hero-pattern .pattern-circle {
	position: absolute;
	border-radius: 50%;
	background: var( --color-link );
	opacity: 0.12;
	animation: float 6s ease-in-out infinite;
}

.blog-hero-pattern .pattern-circle-1 {
	width: 200px;
	height: 200px;
	top: 15%;
	right: 20%;
}

.blog-hero-pattern .pattern-circle-2 {
	width: 140px;
	height: 140px;
	bottom: 10%;
	left: 25%;
	animation-duration: 8s;
}

.blog-filter-section {
	padding: 3rem 0 5rem;
	background: var( --color-bg );
}

.blog-filter-form {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
	margin-bottom: 2rem;
	align-items: flex-end;
}

.filter-group {
	flex: 1;
	min-width: 200px;
}

.filter-group label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.5rem;
	color: var( --color-text-strong );
}

.filter-select {
	position: relative;
}

.filter-select select {
	width: 100%;
	padding: 0.85rem 1rem;
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	background: var( --color-surface );
	color: var( --color-text );
	appearance: none;
	font-size: 1rem;
}

.filter-select::after {
	content: '';
	position: absolute;
	right: 1rem;
	top: 50%;
	transform: translateY(-50%);
	border-left: 6px solid transparent;
	border-right: 6px solid transparent;
	border-top: 6px solid var( --color-text );
	pointer-events: none;
}

.filter-search-input {
	position: relative;
	display: flex;
	align-items: center;
}

.filter-search-input input {
	width: 100%;
	padding: 0.85rem 1rem 0.85rem 2.75rem;
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	background: var( --color-surface );
	color: var( --color-text );
}

.filter-search-input svg {
	position: absolute;
	left: 0.85rem;
	color: var( --color-text );
	opacity: 0.6;
}

.blog-infinite-loading {
	display: none;
	text-align: center;
	padding: 2rem 0;
	margin-top: 2rem;
}

.blog-infinite-loading.active {
	display: block;
}

.blog-infinite-loading .loading-spinner {
	display: inline-block;
	width: 40px;
	height: 40px;
	border: 4px solid var(--color-border);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
	margin-bottom: 1rem;
}

.blog-infinite-loading span {
	display: block;
	color: var(--color-text-secondary);
	font-size: 0.9rem;
}

/* Category Page Loading Overlay */
.category-page-loading {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 9999;
	display: none;
}

.category-page-loading.active {
	display: block;
}

.category-page-loading .loading-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: rgba(255, 255, 255, 0.9);
	backdrop-filter: blur(2px);
}

html[data-theme="dark"] .category-page-loading .loading-overlay {
	background: rgba(0, 0, 0, 0.9);
}

.category-page-loading .loading-content {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
	z-index: 10000;
}

.category-page-loading .loading-content .loading-spinner {
	display: inline-block;
	width: 50px;
	height: 50px;
	border: 5px solid var(--color-border);
	border-top-color: var(--color-primary);
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
	margin-bottom: 1rem;
}

.category-page-loading .loading-content span {
	display: block;
	color: var(--color-text);
	font-size: 1rem;
	font-weight: 500;
}

.blog-filter-loading {
	display: none;
	align-items: center;
	gap: 0.65rem;
	margin-bottom: 1.5rem;
	color: var( --color-text );
	font-weight: 500;
}

.blog-filter-loading.active {
	display: inline-flex;
}

.loading-spinner {
	width: 18px;
	height: 18px;
	border: 3px solid rgba(0, 0, 0, 0.1);
	border-top-color: var( --color-link );
	border-radius: 50%;
	animation: spin 0.8s linear infinite;
}

.blog-posts-grid.is-loading {
	opacity: 0.6;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

.no-posts-message {
	text-align: center;
	font-size: 1rem;
	padding: 2rem 0;
	color: var( --color-text );
}

@media screen and (max-width: 48rem) {
	.blog-hero-section {
		padding: 3rem 0;
	}

	.blog-hero-title {
		font-size: 2.25rem;
	}

	.blog-hero-image {
		min-height: 220px;
		margin-top: 2rem;
	}

	.blog-filter-form {
		flex-direction: column;
	}

	.filter-group {
		width: 100%;
	}
}

/*--------------------------------------------------------------
# Default Page Template
--------------------------------------------------------------*/

/* Page Hero Section */
.page-hero-section {
	background: linear-gradient(135deg, var( --color-surface ) 0%, var( --color-bg ) 100%);
	padding: 5rem 0;
	margin-bottom: 3rem;
	border-bottom: 1px solid var( --color-border );
	position: relative;
	overflow: hidden;
}

.page-hero-content {
	padding-right: 2rem;
}

.page-hero-title {
	color: var( --color-text-strong ) !important;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 1.5rem;
}

.page-hero-description {
	color: var( --color-text ) !important;
	font-size: 1.25rem;
	line-height: 1.7;
	margin: 0;
	opacity: 0.9;
}

.page-hero-image {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.page-featured-image-wrapper {
	width: 100%;
	overflow: hidden;
	border-radius: 0.75rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
	transition: transform 0.3s ease;
}

.page-featured-image-wrapper:hover {
	transform: scale(1.02);
}

.page-featured-image-wrapper img {
	width: 100%;
	height: auto;
	display: block;
}

.page-hero-pattern {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 400px;
}

.page-hero-pattern .pattern-circle {
	position: absolute;
	border-radius: 50%;
	background: var( --color-link );
	opacity: 0.1;
	animation: float 6s ease-in-out infinite;
}

.page-hero-pattern .pattern-circle-1 {
	width: 200px;
	height: 200px;
	top: 10%;
	right: 10%;
	animation-delay: 0s;
}

.page-hero-pattern .pattern-circle-2 {
	width: 150px;
	height: 150px;
	bottom: 20%;
	right: 20%;
	animation-delay: 2s;
}

/* Page Content Section */
.page-content-section {
	padding: 3rem 0 4rem;
}

.page-article {
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	padding: 3rem;
	border-radius: 0;
}

.page-article .entry-content {
	color: var( --color-text ) !important;
	line-height: 1.8;
	font-size: 1.125rem;
}

.page-article .entry-content h2,
.page-article .entry-content h3,
.page-article .entry-content h4 {
	color: var( --color-text-strong ) !important;
	margin-top: 2rem;
	margin-bottom: 1rem;
	font-weight: 600;
}

.page-article .entry-content h2 {
	font-size: 2rem;
}

.page-article .entry-content h3 {
	font-size: 1.75rem;
}

.page-article .entry-content h4 {
	font-size: 1.5rem;
}

.page-article .entry-content p {
	margin-bottom: 1.5rem;
}

.page-article .entry-content img {
	max-width: 100%;
	height: auto;
	margin: 1.5rem 0;
}

.page-article .entry-content ul,
.page-article .entry-content ol {
	margin-bottom: 1.5rem;
	padding-left: 2rem;
}

.page-article .entry-content li {
	margin-bottom: 0.5rem;
}

.page-article .entry-footer {
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid var( --color-border );
}

.page-article .edit-link a {
	color: var( --color-link );
	text-decoration: none;
	font-size: 0.875rem;
}

.page-article .edit-link a:hover {
	text-decoration: underline;
}

@media screen and (max-width: 48rem) {
	.page-hero-section {
		padding: 3rem 0;
	}
	
	.page-hero-content {
		padding-right: 0;
		margin-bottom: 2rem;
	}
	
	.page-hero-title {
		font-size: 2rem;
	}
	
	.page-hero-description {
		font-size: 1.125rem;
	}
	
	.page-hero-image {
		min-height: 300px;
	}
	
	.page-hero-pattern .pattern-circle {
		display: none;
	}
	
	.page-article {
		padding: 2rem 1.5rem;
	}
	
	.page-article .entry-content {
		font-size: 1rem;
	}
}

/*--------------------------------------------------------------
# About Page
--------------------------------------------------------------*/

/* About Hero Section */
.about-hero-section {
	background: linear-gradient(135deg, var( --color-surface ) 0%, var( --color-bg ) 100%);
	padding: 5rem 0;
	margin-bottom: 3rem;
	border-bottom: 1px solid var( --color-border );
	position: relative;
	overflow: hidden;
}

.about-hero-content {
	padding-right: 2rem;
}

.about-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	background: var( --color-link );
	color: #ffffff;
	font-size: 0.875rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 1.5rem;
	border-radius: 0.5rem;
}

.about-badge svg {
	width: 18px;
	height: 18px;
	stroke: currentColor;
	fill: none;
}

.about-hero-title {
	color: var( --color-text-strong ) !important;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 1rem;
}

.about-hero-subtitle {
	color: var( --color-text ) !important;
	font-size: 1.25rem;
	line-height: 1.7;
	margin: 0;
	opacity: 0.9;
}

.about-hero-image {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.about-image-wrapper {
	width: 100%;
	overflow: hidden;
	border-radius: 0.75rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
	transition: transform 0.3s ease;
}

.about-image-wrapper:hover {
	transform: scale(1.02);
}

.about-image-wrapper img {
	width: 100%;
	height: auto;
	display: block;
}

.about-hero-pattern {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 400px;
}

.about-hero-pattern .pattern-circle {
	position: absolute;
	border-radius: 50%;
	background: var( --color-link );
	opacity: 0.1;
	animation: float 6s ease-in-out infinite;
}

.about-hero-pattern .pattern-circle-1 {
	width: 200px;
	height: 200px;
	top: 10%;
	right: 10%;
	animation-delay: 0s;
}

.about-hero-pattern .pattern-circle-2 {
	width: 150px;
	height: 150px;
	bottom: 20%;
	right: 20%;
	animation-delay: 2s;
}

/* About Content Section */
.about-content-section {
	padding: 3rem 0;
	background: var( --color-bg );
}

.about-main-content {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	padding: 3rem;
	border-radius: 0.75rem;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.about-content {
	color: var( --color-text ) !important;
	line-height: 1.8;
	font-size: 1.125rem;
}

.about-content p {
	margin-bottom: 1.5rem;
}

.about-content h2,
.about-content h3,
.about-content h4 {
	color: var( --color-text-strong ) !important;
	margin-top: 2rem;
	margin-bottom: 1rem;
	font-weight: 600;
}

.about-content h2 {
	font-size: 2rem;
}

.about-content h3 {
	font-size: 1.75rem;
}

.about-content h4 {
	font-size: 1.5rem;
}

.about-content img {
	max-width: 100%;
	height: auto;
	margin: 1.5rem 0;
}

.about-content ul,
.about-content ol {
	margin-bottom: 1.5rem;
	padding-left: 2rem;
}

.about-content li {
	margin-bottom: 0.5rem;
}

/* About Me Section */
.about-me-section {
	padding: 4rem 0;
	background: var( --color-surface );
	border-top: 1px solid var( --color-border );
	border-bottom: 1px solid var( --color-border );
}

.about-me-image {
	text-align: center;
}

.about-me-image-wrapper {
	width: 100%;
	overflow: hidden;
	border-radius: 0.75rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
	transition: transform 0.3s ease;
}

.about-me-image-wrapper:hover {
	transform: scale(1.02);
}

.about-me-image-wrapper img {
	width: 100%;
	height: auto;
	display: block;
}

.about-me-placeholder {
	width: 100%;
	min-height: 400px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background: var(--color-surface);
	border: 2px dashed var(--color-border);
	border-radius: 0.75rem;
	color: var(--color-text);
	opacity: 0.6;
}

.about-me-placeholder svg {
	margin-bottom: 1rem;
	opacity: 0.5;
}

.about-me-placeholder p {
	margin: 0;
	font-size: 0.875rem;
}

.about-me-image-placeholder {
	background: var( --color-bg );
	border: 2px dashed var( --color-border );
	padding: 4rem 2rem;
	text-align: center;
	color: var( --color-text );
	opacity: 0.6;
	border-radius: 0.75rem;
}

.about-me-image-placeholder svg {
	width: 120px;
	height: 120px;
	margin: 0 auto 1rem;
	stroke: currentColor;
	fill: none;
	opacity: 0.5;
}

.about-me-content {
	padding-left: 2rem;
}

.about-me-text p {
	color: var( --color-text ) !important;
	font-size: 1.125rem;
	line-height: 1.8;
	margin-bottom: 1.5rem;
}

.about-me-signature {
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid var( --color-border );
}

.signature-name {
	color: var( --color-text-strong ) !important;
	font-size: 1.25rem;
	font-weight: 600;
	font-style: italic;
	margin: 0;
}

/* Skills Section */
.about-skills-section {
	padding: 4rem 0;
	background: var( --color-bg );
}

.skill-card {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	padding: 2rem;
	text-align: center;
	transition: all 0.3s ease;
	border-radius: 0.75rem;
	height: 100%;
}

.skill-card:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
	border-color: var( --color-link );
}

.skill-icon {
	width: 80px;
	height: 80px;
	margin: 0 auto 1.5rem;
	background: var( --color-link );
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
}

.skill-icon svg {
	width: 40px;
	height: 40px;
	stroke: currentColor;
	fill: none;
}

.skill-title {
	color: var( --color-text-strong ) !important;
	font-size: 1.5rem;
	font-weight: 600;
	margin: 0 0 1rem;
}

.skill-description {
	color: var( --color-text ) !important;
	line-height: 1.7;
	margin: 0;
}

/* Experience/Timeline Section */
.about-experience-section {
	padding: 4rem 0;
	background: var( --color-surface );
	border-top: 1px solid var( --color-border );
	border-bottom: 1px solid var( --color-border );
}

.timeline {
	position: relative;
	padding: 2rem 0;
}

.timeline::before {
	content: '';
	position: absolute;
	left: 30px;
	top: 0;
	bottom: 0;
	width: 2px;
	background: var( --color-border );
}

.timeline-item {
	position: relative;
	padding-left: 80px;
	margin-bottom: 3rem;
}

.timeline-item:last-child {
	margin-bottom: 0;
}

.timeline-year {
	position: absolute;
	left: 0;
	top: 0;
	width: 60px;
	height: 60px;
	background: var( --color-link );
	color: #ffffff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1rem;
	font-weight: 700;
	z-index: 2;
}

.timeline-content {
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	padding: 1.5rem;
	border-radius: 0.75rem;
}

.timeline-title {
	color: var( --color-text-strong ) !important;
	font-size: 1.25rem;
	font-weight: 600;
	margin: 0 0 0.75rem;
}

.timeline-description {
	color: var( --color-text ) !important;
	line-height: 1.7;
	margin: 0;
}

/* Services Section */
.about-services-section {
	padding: 4rem 0;
	background: var( --color-bg );
}

.service-card {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	padding: 2rem;
	transition: all 0.3s ease;
	border-radius: 0.75rem;
	height: 100%;
}

.service-card:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
	border-color: var( --color-link );
}

.service-title {
	color: var( --color-text-strong ) !important;
	font-size: 1.5rem;
	font-weight: 600;
	margin: 0 0 1rem;
}

.service-description {
	color: var( --color-text ) !important;
	line-height: 1.7;
	margin: 0;
}

/* CTA Section */
.about-cta-section {
	padding: 5rem 0;
	background: var( --color-surface );
	text-align: center;
	border-top: 1px solid var( --color-border );
}

.about-cta-content {
	padding: 3rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
}

.cta-title {
	color: var( --color-text-strong ) !important;
	font-size: 2.5rem;
	font-weight: 700;
	margin: 0 0 1rem;
}

.cta-description {
	color: var( --color-text ) !important;
	font-size: 1.125rem;
	line-height: 1.7;
	margin: 0 0 2rem;
}

.cta-buttons {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

.cta-buttons .btn {
	border-radius: 0.5rem;
	padding: 0.875rem 2rem;
	font-weight: 600;
}

@media screen and (max-width: 48rem) {
	.about-hero-section {
		padding: 3rem 0;
	}
	
	.about-hero-content {
		padding-right: 0;
		margin-bottom: 2rem;
	}
	
	.about-hero-title {
		font-size: 2rem;
	}
	
	.about-hero-subtitle {
		font-size: 1.125rem;
	}
	
	.about-main-content {
		padding: 2rem 1.5rem;
	}
	
	.about-me-content {
		padding-left: 0;
		margin-top: 2rem;
	}
	
	.about-me-section {
		padding: 3rem 0;
	}
	
	.about-skills-section,
	.about-experience-section,
	.about-services-section,
	.about-cta-section {
		padding: 3rem 0;
	}
	
	.timeline::before {
		left: 20px;
	}
	
	.timeline-item {
		padding-left: 60px;
	}
	
	.timeline-year {
		width: 40px;
		height: 40px;
		font-size: 0.875rem;
	}
	
	.cta-title {
		font-size: 2rem;
	}
	
	.cta-buttons {
		flex-direction: column;
	}
	
	.cta-buttons .btn {
		width: 100%;
	}
	
	.skill-card,
	.service-card {
		margin-bottom: 1.5rem;
	}
}

/*--------------------------------------------------------------
# Category Page
--------------------------------------------------------------*/

/* Category Hero Section */
.category-hero-section {
	background: linear-gradient(135deg, var( --color-surface ) 0%, var( --color-bg ) 100%);
	padding: 5rem 0;
	margin-bottom: 3rem;
	border-bottom: 1px solid var( --color-border );
	position: relative;
	overflow: hidden;
}

.category-hero-content {
	padding-right: 2rem;
}

.category-hero-content {
	padding-right: 2rem;
}

.category-hero-name {
	color: var( --color-text-strong ) !important;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 1rem;
}

.category-hero-description {
	color: var( --color-text ) !important;
	font-size: 1.125rem;
	line-height: 1.7;
	margin-bottom: 2rem;
	opacity: 0.9;
}

.category-hero-stats {
	margin-bottom: 0;
}

.category-stat-item {
	display: inline-flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.5rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	transition: all 0.3s ease;
}

.category-stat-item:hover {
	border-color: var( --color-link );
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.1);
	transform: translateY(-2px);
}

.category-stat-item .stat-number {
	color: var( --color-link );
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
}

.category-stat-item .stat-label {
	color: var( --color-text );
	font-size: 0.875rem;
	opacity: 0.8;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-left: 0.5rem;
}

.category-hero-image {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 300px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.category-image-wrapper {
	width: 100%;
	overflow: hidden;
	border-radius: 0.75rem;
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.15);
	transition: transform 0.3s ease;
}

.category-image-wrapper:hover {
	transform: scale(1.02);
}

.category-image-wrapper img {
	width: 100%;
	height: auto;
	display: block;
}

html[data-theme="dark"] .category-image-wrapper {
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
}

.category-hero-pattern {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 300px;
}

.category-hero-pattern .pattern-circle {
	position: absolute;
	border-radius: 50%;
	background: var( --color-link );
	opacity: 0.1;
	animation: float 6s ease-in-out infinite;
}

.category-hero-pattern .pattern-circle-1 {
	width: 200px;
	height: 200px;
	top: 10%;
	right: 10%;
	animation-delay: 0s;
}

.category-hero-pattern .pattern-circle-2 {
	width: 150px;
	height: 150px;
	bottom: 20%;
	right: 20%;
	animation-delay: 2s;
}

/* Category Content Section */
.category-content-section {
	padding: 2rem 0 4rem;
}

.category-sidebar {
	position: sticky;
	top: 100px;
	align-self: start;
}

/* Category Filter Widget */
.category-filter-widget {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	margin-bottom: 2rem;
	padding: 1.5rem;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

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

.category-filter-list li {
	margin-bottom: 0.5rem;
}

.category-filter-list li.active .category-filter-link {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
}

.category-filter-list li.active .category-count {
	color: #ffffff;
}

.category-filter-link {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem 1rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
	border-radius: 0.5rem;
}

.category-filter-link:hover {
	background: var( --color-surface );
	border-color: var( --color-link );
	color: var( --color-link );
	transform: translateX(4px);
}

.category-name {
	font-weight: 500;
}

.category-count {
	color: var( --color-link );
	font-weight: 600;
	font-size: 0.875rem;
}

/* Category Posts Header */
.category-posts-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 2rem;
	padding-bottom: 1rem;
	border-bottom: 2px solid var( --color-border );
}

.category-posts-title {
	color: var( --color-text-strong ) !important;
	font-size: 2rem;
	font-weight: 700;
	margin: 0;
}

.category-posts-count {
	color: var( --color-text );
	font-size: 0.9375rem;
	opacity: 0.8;
}

.category-posts-header .category-header-top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: 1.5rem;
	width: 100%;
}

.category-posts-header .category-header-left {
	flex: 1;
	min-width: 200px;
}

.category-posts-header .category-header-controls {
	display: flex;
	align-items: flex-end;
	gap: 1rem;
}

.category-posts-header .category-filter-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.category-posts-header .category-filter-group label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-text-secondary);
	margin: 0;
}

.category-posts-header .category-filter-select {
	position: relative;
}

.category-posts-header .category-filter-select select {
	appearance: none;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.5rem;
	padding: 0.5rem 2.5rem 0.5rem 0.75rem;
	font-size: 0.875rem;
	color: var(--color-text);
	cursor: pointer;
	transition: all 0.2s ease;
	min-width: 150px;
}

.category-posts-header .category-filter-select select:hover {
	border-color: var(--color-primary);
}

.category-posts-header .category-filter-select select:focus {
	outline: none;
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.1);
}

.category-posts-header .category-filter-select::after {
	content: '';
	position: absolute;
	right: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 6px solid var(--color-text-secondary);
	pointer-events: none;
}

.category-posts-grid {
	margin-bottom: 3rem;
}

.no-posts-message {
	text-align: center;
	padding: 3rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	color: var( --color-text );
	font-size: 1.125rem;
}

@media screen and (max-width: 48rem) {
	.category-hero-section {
		padding: 3rem 0;
	}
	
	.category-hero-content {
		padding-right: 0;
		margin-bottom: 2rem;
	}
	
	.category-hero-name {
		font-size: 2rem;
	}
	
	.category-hero-description {
		font-size: 1rem;
	}
	
	.category-sidebar {
		position: static;
		margin-bottom: 2rem;
	}
	
	.category-posts-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}
	
	.category-posts-header .category-header-top {
		flex-direction: column;
		gap: 1rem;
	}
	
	.category-posts-header .category-header-controls {
		width: 100%;
	}
	
	.category-posts-title {
		font-size: 1.75rem;
	}
	
	.category-hero-pattern .pattern-circle {
		display: none;
	}
}

/*--------------------------------------------------------------
# Tag Page
--------------------------------------------------------------*/

/* Tag Hero Section */
.tag-hero-section {
	background: linear-gradient(135deg, var( --color-surface ) 0%, var( --color-bg ) 100%);
	padding: 5rem 0;
	margin-bottom: 3rem;
	border-bottom: 1px solid var( --color-border );
	position: relative;
	overflow: hidden;
}

.tag-hero-content {
	padding-right: 2rem;
}

.tag-hero-name {
	color: var( --color-text-strong ) !important;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 1rem;
}

.tag-hero-description {
	color: var( --color-text ) !important;
	font-size: 1.125rem;
	line-height: 1.7;
	margin-bottom: 2rem;
	opacity: 0.9;
}

.tag-hero-stats {
	margin-bottom: 0;
}

.tag-stat-item {
	display: inline-flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.5rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	transition: all 0.3s ease;
}

.tag-stat-item:hover {
	border-color: var( --color-link );
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.1);
	transform: translateY(-2px);
}

.tag-stat-item .stat-number {
	color: var( --color-link );
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
}

.tag-stat-item .stat-label {
	color: var( --color-text );
	font-size: 0.875rem;
	opacity: 0.8;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-left: 0.5rem;
}

.tag-hero-image {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 300px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.tag-hero-pattern {
	position: relative;
	width: 100%;
	height: 100%;
	min-height: 300px;
}

.tag-hero-pattern .pattern-circle {
	position: absolute;
	border-radius: 50%;
	background: var( --color-link );
	opacity: 0.1;
	animation: float 6s ease-in-out infinite;
}

.tag-hero-pattern .pattern-circle-1 {
	width: 200px;
	height: 200px;
	top: 10%;
	right: 10%;
	animation-delay: 0s;
}

.tag-hero-pattern .pattern-circle-2 {
	width: 150px;
	height: 150px;
	bottom: 20%;
	right: 20%;
	animation-delay: 2s;
}

/* Tag Content Section */
.tag-content-section {
	padding: 2rem 0 4rem;
}

.tag-sidebar {
	position: sticky;
	top: 100px;
	align-self: start;
}

/* Tag Filter Widget */
.tag-filter-widget {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	margin-bottom: 2rem;
	padding: 1.5rem;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.tag-filter-select {
	position: relative;
}

.tag-filter-select.custom-dropdown {
	position: relative;
}

.tag-dropdown-toggle {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	padding: 0.75rem 1rem;
	font-size: 0.9375rem;
	color: var( --color-text );
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: left;
}

.tag-dropdown-toggle:hover {
	border-color: var( --color-link );
}

.tag-dropdown-toggle:focus {
	outline: none;
	border-color: var( --color-link );
	box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.1);
}

.tag-dropdown-text {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.tag-dropdown-arrow {
	margin-left: 0.5rem;
	font-size: 0.75rem;
	transition: transform 0.3s ease;
	color: var( --color-text-secondary );
}

.tag-filter-select:hover .tag-dropdown-arrow,
.tag-filter-select.active .tag-dropdown-arrow {
	transform: rotate(180deg);
}

.tag-dropdown-menu {
	position: absolute;
	top: calc(100% + 0.5rem);
	left: 0;
	right: 0;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0.5rem 0;
	max-height: 300px;
	overflow-y: auto;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	z-index: 1000;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

.tag-filter-select:hover .tag-dropdown-menu,
.tag-filter-select.active .tag-dropdown-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.tag-dropdown-item {
	margin: 0;
}

.tag-dropdown-link {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem 1rem;
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
}

.tag-dropdown-link:hover {
	background: var( --color-bg );
	color: var( --color-link );
}

.tag-dropdown-item.active .tag-dropdown-link {
	background: var( --color-link );
	color: #ffffff;
}

.tag-dropdown-item.active .tag-dropdown-link .tag-count {
	color: #ffffff;
}

.tag-dropdown-link .tag-name {
	flex: 1;
}

.tag-dropdown-link .tag-count {
	color: var( --color-link );
	font-weight: 600;
	font-size: 0.875rem;
}

.tag-dropdown-item.active .tag-dropdown-link .tag-count {
	color: #ffffff;
}

/* Legacy select styles for backward compatibility */
.tag-filter-select select {
	width: 100%;
	appearance: none;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	padding: 0.75rem 2.5rem 0.75rem 1rem;
	font-size: 0.9375rem;
	color: var( --color-text );
	cursor: pointer;
	transition: all 0.2s ease;
}

.tag-filter-select select:hover {
	border-color: var( --color-link );
}

.tag-filter-select select:focus {
	outline: none;
	border-color: var( --color-link );
	box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.1);
}

/* Legacy styles for backward compatibility (if needed) */
.tag-filter-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.tag-filter-list li {
	margin-bottom: 0.75rem;
}

.tag-filter-link {
	color: var( --color-text );
	text-decoration: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	transition: all 0.2s ease;
}

.tag-filter-link:hover {
	color: var( --color-link );
	border-color: var( --color-link );
	background: var( --color-surface );
	transform: translateX(4px);
}

.tag-filter-list li.active .tag-filter-link {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
}

.tag-filter-list li.active .tag-filter-link .tag-count {
	color: #ffffff;
}

.tag-filter-link .tag-name {
	flex: 1;
}

.tag-filter-link .tag-count {
	color: var( --color-link );
	font-weight: 600;
	font-size: 0.875rem;
}

.tag-filter-list li.active .tag-filter-link .tag-count {
	color: #ffffff;
}

/* Tag Posts Header */
.tag-posts-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 2rem;
}

.tag-posts-title {
	color: var( --color-text-strong ) !important;
	font-size: 2rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
}

.tag-name-highlight {
	color: var( --color-link );
}

.tag-posts-count {
	color: var( --color-text );
	font-size: 0.9375rem;
	opacity: 0.8;
}

.tag-posts-header .tag-header-top {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	width: 100%;
	gap: 2rem;
}

.tag-posts-header .tag-header-left {
	flex: 1;
	min-width: 200px;
}

.tag-posts-header .tag-header-controls {
	display: flex;
	align-items: flex-end;
	gap: 1rem;
}

.tag-posts-header .tag-filter-group {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.tag-posts-header .tag-filter-group label {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-text);
}

.tag-posts-header .tag-filter-select {
	position: relative;
}

.tag-posts-header .tag-filter-select select {
	appearance: none;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.5rem;
	padding: 0.5rem 2.5rem 0.5rem 0.75rem;
	font-size: 0.875rem;
	color: var(--color-text);
	cursor: pointer;
	transition: all 0.2s ease;
	min-width: 150px;
}

.tag-posts-header .tag-filter-select select:hover {
	border-color: var(--color-link);
}

.tag-posts-header .tag-filter-select select:focus {
	outline: none;
	border-color: var(--color-link);
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.1);
}

.tag-posts-header .tag-filter-select::after {
	content: '';
	position: absolute;
	right: 0.75rem;
	top: 50%;
	transform: translateY(-50%);
	width: 0;
	height: 0;
	border-left: 5px solid transparent;
	border-right: 5px solid transparent;
	border-top: 6px solid var(--color-text);
	pointer-events: none;
}

.tag-posts-grid {
	margin-bottom: 3rem;
}

@media screen and (max-width: 48rem) {
	.tag-hero-section {
		padding: 3rem 0;
	}
	
	.tag-hero-content {
		padding-right: 0;
		margin-bottom: 2rem;
	}
	
	.tag-hero-name {
		font-size: 2rem;
	}
	
	.tag-hero-description {
		font-size: 1rem;
	}
	
	.tag-sidebar {
		position: static;
		margin-bottom: 2rem;
	}
	
	.tag-posts-header {
		flex-direction: column;
		align-items: flex-start;
		gap: 1rem;
	}
	
	.tag-posts-header .tag-header-top {
		flex-direction: column;
		gap: 1rem;
	}
	
	.tag-posts-header .tag-header-controls {
		width: 100%;
	}
	
	.tag-posts-title {
		font-size: 1.75rem;
	}
	
	.tag-hero-pattern .pattern-circle {
		display: none;
	}
}

/*--------------------------------------------------------------
# Author Page
--------------------------------------------------------------*/

/* Author Hero Section */
.author-hero-section {
	background: linear-gradient(135deg, var( --color-surface ) 0%, var( --color-bg ) 100%);
	padding: 5rem 0;
	margin-bottom: 3rem;
	border-bottom: 1px solid var( --color-border );
	position: relative;
	overflow: hidden;
}

.author-hero-content {
	padding-right: 2rem;
}

.author-hero-header {
	display: flex;
	align-items: flex-start;
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.author-hero-avatar-wrapper {
	position: relative;
	flex-shrink: 0;
}

.author-hero-avatar {
	position: relative;
}

.author-hero-avatar img {
	border-radius: 50%;
	width: 120px;
	height: 120px;
	object-fit: cover;
	border: 4px solid var( --color-link );
	box-shadow: 0 8px 24px rgba(65, 105, 225, 0.2);
	transition: transform 0.3s ease;
}

.author-hero-avatar:hover img {
	transform: scale(1.05);
}

.author-verified-badge {
	position: absolute;
	bottom: 0;
	right: 0;
	width: 36px;
	height: 36px;
	background: var( --color-link );
	border: 3px solid var( --color-bg );
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

.author-verified-badge svg {
	width: 18px;
	height: 18px;
	stroke: currentColor;
	fill: none;
}

.author-hero-info {
	flex: 1;
}

.author-hero-name {
	color: var( --color-text-strong ) !important;
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 1.2;
	margin: 0 0 0.75rem;
}

.author-hero-role {
	margin-bottom: 0.5rem;
}

.author-hero-description {
	color: var( --color-text ) !important;
	font-size: 1.125rem;
	line-height: 1.7;
	margin-bottom: 2rem;
	opacity: 0.9;
}

.author-hero-stats {
	margin-bottom: 2rem;
}

.author-stat-item {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.5rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0;
	transition: all 0.3s ease;
}

.author-stat-item:hover {
	border-color: var( --color-link );
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.1);
	transform: translateY(-2px);
}

.stat-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 48px;
	height: 48px;
	background: var( --color-link );
	border-radius: 50%;
	color: #ffffff;
	flex-shrink: 0;
}

.stat-icon svg {
	width: 24px;
	height: 24px;
	stroke: currentColor;
	fill: none;
}

.stat-content {
	display: flex;
	flex-direction: column;
}

.stat-number {
	color: var( --color-text-strong ) !important;
	font-size: 2rem;
	font-weight: 700;
	line-height: 1;
	margin-bottom: 0.25rem;
}

.stat-label {
	color: var( --color-text );
	font-size: 0.875rem;
	opacity: 0.8;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.author-hero-social {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding-top: 1.5rem;
	border-top: 1px solid var( --color-border );
}

.social-label {
	color: var( --color-text );
	font-size: 0.9375rem;
	font-weight: 600;
	opacity: 0.8;
}

.social-links {
	display: flex;
	gap: 0.75rem;
}

.author-hero-social .author-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 50%;
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
}

.author-hero-social .author-social-link svg {
	width: 1.125rem;
	height: 1.125rem;
	fill: currentColor;
}

.author-hero-social .author-social-link:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

/* Author Hero Image/Pattern */
.author-hero-image {
	position: relative;
	height: 100%;
	min-height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.author-hero-pattern {
	position: relative;
	width: 100%;
	height: 100%;
}

.pattern-circle {
	position: absolute;
	border-radius: 50%;
	background: var( --color-link );
	opacity: 0.1;
	animation: float 6s ease-in-out infinite;
}

.pattern-circle-1 {
	width: 200px;
	height: 200px;
	top: 10%;
	right: 10%;
	animation-delay: 0s;
}

.pattern-circle-2 {
	width: 150px;
	height: 150px;
	bottom: 20%;
	right: 20%;
	animation-delay: 2s;
}

.pattern-circle-3 {
	width: 100px;
	height: 100px;
	top: 50%;
	right: 5%;
	animation-delay: 4s;
}

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

/*--------------------------------------------------------------
# Social Share Buttons
--------------------------------------------------------------*/

/* Hero Section Share Buttons */
.hero-share-buttons {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-top: 1.5rem;
	padding-top: 1.5rem;
	border-top: 1px solid var( --color-border );
}

.share-label {
	color: var( --color-text );
	font-size: 0.9375rem;
	font-weight: 600;
	opacity: 0.8;
}

.share-buttons {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.share-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 50%;
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
	cursor: pointer;
	position: relative;
}

.share-btn button {
	border: none;
	background: transparent;
	padding: 0;
	width: 100%;
	height: 100%;
}

.share-btn svg {
	width: 18px;
	height: 18px;
	fill: currentColor;
	stroke: currentColor;
}

.share-btn:hover {
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.15);
}

.share-btn.share-facebook:hover {
	background: #1877f2;
	border-color: #1877f2;
	color: #ffffff;
}

.share-btn.share-twitter:hover {
	background: #1da1f2;
	border-color: #1da1f2;
	color: #ffffff;
}

.share-btn.share-linkedin:hover {
	background: #0077b5;
	border-color: #0077b5;
	color: #ffffff;
}

.share-btn.share-whatsapp:hover {
	background: #25d366;
	border-color: #25d366;
	color: #ffffff;
}

.share-btn.share-copy:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
}

.share-btn.share-copy.copied {
	background: #10b981;
	border-color: #10b981;
	color: #ffffff;
}

.copy-tooltip {
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%);
	margin-bottom: 0.5rem;
	padding: 0.25rem 0.5rem;
	background: var( --color-text-strong );
	color: var( --color-bg );
	font-size: 0.75rem;
	white-space: nowrap;
	border-radius: 0.25rem;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease;
}

.share-btn.share-copy:hover .copy-tooltip,
.share-btn.share-copy.copied .copy-tooltip {
	opacity: 1;
}

/* Sidebar Share Widget */
.share-widget {
	margin-bottom: 2rem;
}

.sidebar-share-buttons {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: flex-start;
}

.sidebar-share-buttons .share-btn {
	width: 2.5rem;
	height: 2.5rem;
	padding: 0;
	border-radius: 50%;
	justify-content: center;
	align-items: center;
	text-align: center;
}

.sidebar-share-buttons .share-btn.share-copy.copied {
	background: #10b981;
	border-color: #10b981;
	color: #ffffff;
}

/* Responsive Share Buttons */
@media (max-width: 991.98px) {
	.sidebar-share-buttons {
		justify-content: flex-start;
		gap: 0.5rem;
	}
	
	.sidebar-share-buttons .share-btn {
		width: 2.25rem;
		height: 2.25rem;
		flex-shrink: 0;
	}
	
	.sidebar-share-buttons .share-btn svg {
		width: 16px;
		height: 16px;
	}
}

@media (max-width: 768px) {
	.share-widget {
		margin-bottom: 1.5rem;
	}
	
	.sidebar-share-buttons {
		justify-content: center;
		gap: 0.75rem;
	}
	
	.sidebar-share-buttons .share-btn {
		width: 2.5rem;
		height: 2.5rem;
	}
	
	.sidebar-share-buttons .share-btn svg {
		width: 18px;
		height: 18px;
	}
}

@media (max-width: 576px) {
	.sidebar-share-buttons {
		gap: 0.5rem;
	}
	
	.sidebar-share-buttons .share-btn {
		width: 2.25rem;
		height: 2.25rem;
	}
	
	.sidebar-share-buttons .share-btn svg {
		width: 16px;
		height: 16px;
	}
}


/* Share button icons styling */
.share-btn svg {
	transition: transform 0.2s ease;
	flex-shrink: 0;
}

.share-btn:hover svg {
	transform: scale(1.1);
}

/* Copy button tooltip improvements */
.share-btn.share-copy {
	position: relative;
}

.copy-tooltip {
	position: absolute;
	bottom: calc(100% + 0.5rem);
	left: 50%;
	transform: translateX(-50%);
	padding: 0.375rem 0.625rem;
	background: var( --color-text-strong );
	color: var( --color-bg );
	font-size: 0.75rem;
	font-weight: 500;
	white-space: nowrap;
	border-radius: 0.25rem;
	opacity: 0;
	pointer-events: none;
	transition: opacity 0.2s ease;
	z-index: 10;
}

.copy-tooltip::after {
	content: '';
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 4px solid transparent;
	border-top-color: var( --color-text-strong );
}

.share-btn.share-copy:hover .copy-tooltip,
.share-btn.share-copy.copied .copy-tooltip {
	opacity: 1;
}

/* Responsive adjustments */
@media screen and (max-width: 48rem) {
	.hero-share-buttons {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}
	
	.share-buttons {
		width: 100%;
		justify-content: flex-start;
	}
	
	.share-btn {
		width: 2.25rem;
		height: 2.25rem;
	}
	
	.sidebar-share-buttons {
		justify-content: flex-start;
	}
	
	.sidebar-share-buttons .share-btn {
		width: 2.25rem;
		height: 2.25rem;
	}
	
	.sidebar-share-buttons .share-btn svg {
		width: 18px;
		height: 18px;
	}
}

.sidebar-share-buttons .share-btn svg {
	width: 20px;
	height: 20px;
	flex-shrink: 0;
}

@media screen and (max-width: 48rem) {
	.hero-share-buttons {
		flex-direction: column;
		align-items: flex-start;
	}
	
	.share-buttons {
		width: 100%;
	}
	
	.share-btn {
		flex: 0;
		min-width: 2.5rem;
	}
}

/* Author Posts Section */
.author-posts-section {
	padding: 2rem 0 4rem;
}

.author-posts-title {
	color: var( --color-text-strong ) !important;
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 2rem;
	text-align: center;
}

.no-posts-message {
	color: var( --color-text );
	text-align: center;
	padding: 3rem;
	font-size: 1.125rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
}

/* Posts Pagination */
.posts-pagination {
	margin: 3rem 0;
	padding: 2rem 0;
	text-align: center;
}

.posts-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.posts-pagination .page-numbers li {
	margin: 0;
}

.posts-pagination .page-numbers a,
.posts-pagination .page-numbers span {
	display: inline-block;
	padding: 0.5rem 1rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
	border-radius: 0;
	min-width: 2.5rem;
	text-align: center;
}

.posts-pagination .page-numbers a:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
}

.posts-pagination .page-numbers .current {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	font-weight: 600;
}

.posts-pagination .page-numbers .prev,
.posts-pagination .page-numbers .next {
	font-weight: 600;
}

@media screen and (max-width: 48rem) {
	.author-hero-section {
		padding: 3rem 0;
	}
	
	.author-hero-content {
		padding-right: 0;
		margin-bottom: 2rem;
	}
	
	.author-hero-header {
		flex-direction: column;
		align-items: center;
		text-align: center;
	}
	
	.author-hero-info {
		text-align: center;
	}
	
	.author-hero-name {
		font-size: 2rem;
	}
	
	.author-hero-description {
		font-size: 1rem;
		text-align: center;
	}
	
	.author-hero-stats {
		margin-bottom: 1.5rem;
	}
	
	.stat-number {
		font-size: 1.75rem;
	}
	
	.author-hero-social {
		flex-direction: column;
		align-items: flex-start;
	}
	
	.social-links {
		width: 100%;
		justify-content: center;
	}
	
	.author-hero-image {
		min-height: 300px;
	}
	
	.pattern-circle {
		display: none;
	}
	
	.author-posts-title {
		font-size: 2rem;
	}
}

/*--------------------------------------------------------------
# Single Post Page
--------------------------------------------------------------*/

/* Hero Section */
.single-post-hero {
	background: var( --color-surface );
	padding: 4rem 0;
	margin-bottom: 3rem;
	border-bottom: 1px solid var( --color-border );
}

.hero-content-left {
	padding-right: 2rem;
}

.hero-post-title {
	color: var( --color-text-strong ) !important;
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 1.5rem;
}

.hero-post-description {
	color: var( --color-text ) !important;
	font-size: 1.125rem;
	line-height: 1.7;
	margin-bottom: 2rem;
	opacity: 0.9;
}

.hero-author-info {
	display: flex;
	align-items: center;
	gap: 1.25rem;
	margin-bottom: 1.5rem;
}

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

.author-avatar img {
	border-radius: 50%;
	width: 80px;
	height: 80px;
	object-fit: cover;
	border: 3px solid var( --color-border );
	transition: border-color 0.2s ease;
}

.author-avatar a:hover img {
	border-color: var( --color-link );
}

.author-details {
	flex: 1;
}

.author-name {
	margin-bottom: 0.5rem;
}

.author-name a {
	color: var( --color-text-strong ) !important;
	font-size: 1.25rem;
	font-weight: 600;
	text-decoration: none;
	transition: color 0.2s ease;
}

.author-name a:hover {
	color: var( --color-link ) !important;
}

.author-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	font-size: 0.9375rem;
	color: var( --color-text );
}

.author-meta .post-date {
	opacity: 0.8;
}

.author-meta .post-category a {
	color: var( --color-link );
	text-decoration: none;
}

.author-meta .post-category a:hover {
	text-decoration: underline;
}

/* Reading Time Styling */
.post-reading-time {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	color: var( --color-text );
	opacity: 0.8;
	transition: opacity 0.2s ease;
}

.post-reading-time:hover {
	opacity: 1;
}

.post-reading-time svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	stroke: currentColor;
	fill: none;
	opacity: 0.7;
	transition: all 0.2s ease;
}

.post-reading-time:hover svg {
	opacity: 1;
	transform: rotate(360deg);
	stroke: var( --color-link );
}

.reading-time-text {
	font-size: 0.9375rem;
	font-weight: 500;
	color: var( --color-text );
	white-space: nowrap;
}

.post-reading-time:hover .reading-time-text {
	color: var( --color-link );
}

.author-social-links {
	display: flex;
	gap: 0.75rem;
	margin-top: 1rem;
}

.author-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 50%;
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
}

.author-social-link svg {
	width: 1.125rem;
	height: 1.125rem;
	fill: currentColor;
}

.author-social-link:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

.hero-image-right {
	text-align: center;
}

.featured-image-wrapper {
	position: relative;
	overflow: hidden;
	border-radius: 0.75rem;
	box-shadow: 0 15px 35px rgba(0, 0, 0, 0.12);
}

.featured-image-wrapper img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform 0.3s ease;
}

.featured-image-wrapper:hover img {
	transform: scale(1.02);
}

html[data-theme="dark"] .featured-image-wrapper {
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.4);
}

.single-post-wrapper {
	padding: 2rem 0;
}

/* Left Sidebar */
.single-sidebar {
	position: sticky;
	top: 100px;
	align-self: start;
	margin-bottom: 2rem;
}

.sidebar-widget {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	margin-bottom: 2rem;
	padding: 1.5rem;
}

.widget-title {
	color: var( --color-text-strong );
	font-size: 1.25rem;
	font-weight: 600;
	margin: 0 0 1.25rem;
	padding-bottom: 0.75rem;
	border-bottom: 2px solid var( --color-border );
}

/* Search Widget */
.search-widget {
	background: var( --color-surface ) !important;
	border: 1px solid var( --color-border ) !important;
	border-radius: 0.75rem !important;
	margin-bottom: 2rem !important;
	padding: 1.5rem !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.search-widget .search-form {
	margin: 0;
}

.search-input-wrapper {
	position: relative;
	display: flex;
	align-items: center;
	background: var( --color-bg );
	border: 2px solid var( --color-border );
	border-radius: 0.5rem;
	transition: all 0.3s ease;
	overflow: hidden;
}

.search-input-wrapper:focus-within {
	border-color: var( --color-link );
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.1);
}

.search-input {
	flex: 1;
	border: none;
	outline: none;
	color: var( --color-text ) !important;
	background: transparent;
	padding: 0.875rem 1rem;
	font-size: 0.9375rem;
	width: 100%;
}

.search-input::placeholder {
	color: var( --color-text );
	opacity: 0.6;
}

.search-submit-btn {
	background: var( --color-link );
	border: none;
	color: #ffffff;
	padding: 0.875rem 1.25rem;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s ease;
	flex-shrink: 0;
	border-radius: 0 0.5rem 0.5rem 0;
}

.search-submit-btn:hover {
	background: var( --color-link-hover );
	transform: scale(1.05);
}

.search-submit-btn svg {
	width: 18px;
	height: 18px;
	stroke: currentColor;
	fill: none;
}

/* Table of Contents */
.toc-widget {
	display: block;
	background: var( --color-surface ) !important;
	border: 1px solid var( --color-border ) !important;
	border-radius: 0.75rem !important;
	margin-bottom: 2rem !important;
	padding: 1.5rem !important;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.toc-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 0;
}

.toc-header .widget-title {
	margin: 0;
	padding-bottom: 0;
	border-bottom: none;
}

.toc-toggle-btn {
	background: transparent;
	border: none;
	border-radius: 0.5rem;
	color: var( --color-text );
	cursor: pointer;
	padding: 0.5rem;
	width: 2.5rem;
	height: 2.5rem;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.3s ease;
}

.toc-toggle-btn:hover {
	background: transparent;
	border-color: transparent;
	color: var( --color-link );
}

.toc-toggle-btn.active {
	background: transparent;
	border-color: transparent;
	color: #ffffff;
}

.toc-toggle-icon {
	display: flex;
	flex-direction: column;
	gap: 4px;
	width: 20px;
	height: 16px;
	position: relative;
}

.toc-toggle-icon span {
	display: block;
	height: 2px;
	width: 100%;
	background: currentColor;
	transition: all 0.3s ease;
	border-radius: 2px;
}

.toc-toggle-btn.active .toc-toggle-icon span:nth-child(1) {
	transform: rotate(45deg) translate(6px, 6px);
}

.toc-toggle-btn.active .toc-toggle-icon span:nth-child(2) {
	opacity: 0;
}

.toc-toggle-btn.active .toc-toggle-icon span:nth-child(3) {
	transform: rotate(-45deg) translate(6px, -6px);
}

.toc-nav {
	display: none;
	margin-top: 1.25rem;
	padding-top: 1.25rem;
	border-top: 1px solid var( --color-border );
}

.toc-nav.active,
.toc-nav[style*="block"] {
	display: block !important;
	max-height: 55vh;
	overflow-y: auto;
	overflow-x: hidden;
	padding-right: 0.5rem;
}

/* Scrollbar styling for TOC */
.toc-nav.active::-webkit-scrollbar {
	width: 6px;
}

.toc-nav.active::-webkit-scrollbar-track {
	background: var(--color-bg);
	border-radius: 3px;
}

.toc-nav.active::-webkit-scrollbar-thumb {
	background: var(--color-border);
	border-radius: 3px;
}

.toc-nav.active::-webkit-scrollbar-thumb:hover {
	background: var(--color-link);
}

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

.toc-list > li {
	margin-bottom: 0.5rem;
}

/* H2 Main Items */
.toc-h2-item {
	margin-bottom: 0.75rem;
}

.toc-h2-wrapper {
	display: flex;
	align-items: center;
	justify-content: space-between;
	cursor: pointer;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	padding: 0.5rem 0.75rem;
	transition: all 0.2s ease;
}

.toc-h2-wrapper:hover {
	background: var( --color-surface );
	border-color: var( --color-link );
}

.toc-h2-item.toc-open .toc-h2-wrapper {
	border-color: var( --color-link );
	background: var( --color-surface );
}

.toc-link {
	color: var( --color-text );
	text-decoration: none;
	display: block;
	transition: all 0.2s ease;
	font-size: 0.9375rem;
	line-height: 1.5;
	flex: 1;
}

.toc-link:hover {
	color: var( --color-link );
}

.toc-link.active {
	color: var( --color-link );
	font-weight: 600;
}

.toc-link.toc-h2 {
	font-weight: 600;
	font-size: 1rem;
}

.toc-toggle-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 1.5rem;
	height: 1.5rem;
	color: var( --color-text );
	transition: transform 0.3s ease;
	flex-shrink: 0;
	margin-left: 0.5rem;
}

.toc-toggle-icon svg {
	width: 12px;
	height: 12px;
	stroke: currentColor;
	fill: none;
}

.toc-h2-item.toc-open .toc-toggle-icon {
	color: var( --color-link );
}

/* Nested Sublist */
.toc-sublist {
	list-style: none;
	margin: 0.5rem 0 0 0;
	padding: 0.5rem 0 0 0;
	border-top: 1px solid var( --color-border );
	display: none;
}

.toc-h2-item.toc-open .toc-sublist {
	display: block;
}

.toc-nested-item {
	margin-bottom: 0.5rem;
	padding-left: 1rem;
}

.toc-nested-item .toc-link {
	padding: 0.4rem 0.75rem;
	border-left: 2px solid transparent;
	transition: all 0.2s ease;
}

.toc-nested-item .toc-link:hover {
	border-left-color: var( --color-link );
	background: var( --color-bg );
	padding-left: 1rem;
}

.toc-nested-item .toc-link.active {
	border-left-color: var( --color-link );
	background: var( --color-bg );
}

/* Nested Level Indentation */
.toc-nested-item.toc-level-3 .toc-link {
	padding-left: 1rem;
}

.toc-nested-item.toc-level-4 .toc-link {
	padding-left: 1.5rem;
}

.toc-nested-item.toc-level-5 .toc-link {
	padding-left: 2rem;
}

.toc-nested-item.toc-level-6 .toc-link {
	padding-left: 2.5rem;
}

/* Categories Widget */
.categories-list {
	list-style: none;
	margin: 0;
	padding: 0;
}

.categories-list li {
	margin-bottom: 0.75rem;
}

.categories-list a {
	color: var( --color-text );
	text-decoration: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	transition: all 0.2s ease;
}

.categories-list a:hover {
	color: var( --color-link );
	border-color: var( --color-link );
	background: var( --color-surface );
	transform: translateX(4px);
}

.category-count {
	color: var( --color-link );
	font-weight: 600;
	font-size: 0.875rem;
}

/* Category Dropdown (Single Post Page) */
.category-filter-select.custom-dropdown {
	position: relative;
}

.category-dropdown-toggle {
	width: 100%;
	display: flex;
	justify-content: space-between;
	align-items: center;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	padding: 0.75rem 1rem;
	font-size: 0.9375rem;
	color: var( --color-text );
	cursor: pointer;
	transition: all 0.2s ease;
	text-align: left;
}

.category-dropdown-toggle:hover {
	border-color: var( --color-link );
}

.category-dropdown-toggle:focus {
	outline: none;
	border-color: var( --color-link );
	box-shadow: 0 0 0 3px rgba(var(--color-primary-rgb), 0.1);
}

.category-dropdown-text {
	flex: 1;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.category-dropdown-arrow {
	margin-left: 0.5rem;
	font-size: 0.75rem;
	transition: transform 0.3s ease;
	color: var( --color-text-secondary );
}

.category-filter-select:hover .category-dropdown-arrow,
.category-filter-select.active .category-dropdown-arrow {
	transform: rotate(180deg);
}

.category-dropdown-menu {
	position: absolute;
	top: calc(100% + 0.5rem);
	left: 0;
	right: 0;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.5rem;
	list-style: none;
	margin: 0;
	padding: 0.5rem 0;
	max-height: 300px;
	overflow-y: auto;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	z-index: 1000;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-10px);
	transition: opacity 0.3s ease, visibility 0.3s ease, transform 0.3s ease;
}

.category-filter-select:hover .category-dropdown-menu,
.category-filter-select.active .category-dropdown-menu {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.category-dropdown-item {
	margin: 0;
}

.category-dropdown-link {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.75rem 1rem;
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
}

.category-dropdown-link:hover {
	background: var( --color-bg );
	color: var( --color-link );
}

.category-dropdown-item.active .category-dropdown-link {
	background: var( --color-link );
	color: #ffffff;
}

.category-dropdown-item.active .category-dropdown-link .category-count {
	color: #ffffff;
}

.category-dropdown-link .category-name {
	flex: 1;
}

.category-dropdown-link .category-count {
	color: var( --color-link );
	font-weight: 600;
	font-size: 0.875rem;
}

.category-dropdown-item.active .category-dropdown-link .category-count {
	color: #ffffff;
}

/* Single Post Content */
.single-content {
	margin-bottom: 2rem;
}

.single-post-article {
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	padding: 2rem;
	margin-bottom: 2rem;
}

.entry-header {
	margin-bottom: 1.5rem;
}

.entry-title {
	color: var( --color-text-strong ) !important;
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
	line-height: 1.2;
}

.entry-meta {
	color: var( --color-text );
	font-size: 0.9375rem;
	margin-bottom: 1rem;
}

.entry-content {
	color: var( --color-text ) !important;
	line-height: 1.8;
}

.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
	color: var( --color-text-strong ) !important;
	margin-top: 2rem;
	margin-bottom: 1rem;
	font-weight: 600;
}

.entry-content h2 {
	font-size: 2rem;
}

.entry-content h3 {
	font-size: 1.75rem;
}

.entry-content h4 {
	font-size: 1.5rem;
}

.entry-content h5 {
	font-size: 1.25rem;
}

.entry-content h6 {
	font-size: 1.125rem;
}

.entry-content p {
	margin-bottom: 1.5rem;
	line-height: 1.8;
}

.entry-content a {
	color: var(--color-link);
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}

.entry-content a:hover {
	color: var(--color-link-hover);
	text-decoration-thickness: 2px;
}

.entry-content img {
	max-width: 100%;
	height: auto;
	margin: 2rem 0;
	border-radius: 0.5rem;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

/* Lists Styling */
.entry-content ul,
.entry-content ol {
	margin: 1.5rem 0;
	padding-left: 2.5rem;
	line-height: 1.8;
}

.entry-content ul {
	list-style-type: disc;
	list-style-position: outside;
}

.entry-content ol {
	list-style-type: decimal;
	list-style-position: outside;
}

.entry-content li {
	margin-bottom: 0.75rem;
	padding-left: 0.5rem;
	color: var(--color-text);
}

.entry-content li::marker {
	color: var(--color-link);
	font-weight: 600;
}

.entry-content ul ul,
.entry-content ol ol,
.entry-content ul ol,
.entry-content ol ul {
	margin: 0.75rem 0;
	padding-left: 2rem;
}

.entry-content ul ul {
	list-style-type: circle;
}

.entry-content ul ul ul {
	list-style-type: square;
}

/* Blockquote Styling */
.entry-content blockquote {
	margin: 2rem 0;
	padding: 1.5rem 1.5rem 1.5rem 2rem;
	background: var(--color-surface);
	border-left: 4px solid var(--color-link);
	border-radius: 0.5rem;
	font-style: italic;
	color: var(--color-text);
}

.entry-content blockquote p:last-child {
	margin-bottom: 0;
}

.entry-content blockquote cite {
	display: block;
	margin-top: 1rem;
	font-size: 0.9375rem;
	font-style: normal;
	color: var(--color-text);
	opacity: 0.8;
}

/* Strong and Emphasis */
.entry-content strong,
.entry-content b {
	font-weight: 700;
	color: var(--color-text-strong);
}

.entry-content em,
.entry-content i {
	font-style: italic;
}

/* Tables */
.entry-content table {
	width: 100%;
	margin: 2rem 0;
	border-collapse: collapse;
	border: 1px solid var(--color-border);
	border-radius: 0.5rem;
	overflow: hidden;
}

.entry-content table th,
.entry-content table td {
	padding: 0.875rem 1rem;
	border: 1px solid var(--color-border);
	text-align: left;
}

.entry-content table th {
	background: var(--color-surface);
	font-weight: 600;
	color: var(--color-text-strong);
	border-bottom: 2px solid var(--color-border);
}

.entry-content table tr:nth-child(even) {
	background: var(--color-surface);
}

.entry-content table tr:hover {
	background: var(--color-bg);
}

/* Horizontal Rule */
.entry-content hr {
	margin: 2.5rem 0;
	border: none;
	border-top: 2px solid var(--color-border);
	opacity: 0.5;
}

/* Figure and Caption */
.entry-content figure {
	margin: 2rem 0;
}

.entry-content figcaption {
	margin-top: 0.75rem;
	font-size: 0.9375rem;
	color: var(--color-text);
	opacity: 0.8;
	text-align: center;
	font-style: italic;
}

/* Code Blocks with Copy Button */
.code-block-wrapper {
	position: relative;
	margin: 1.5rem 0;
}

.entry-content pre,
.entry-content code {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0;
	color: var( --color-text );
	font-family: 'Courier New', Courier, monospace;
	font-size: 0.875rem;
	line-height: 1.6;
}

.entry-content pre {
	padding: 1.5rem;
	overflow-x: auto;
	margin: 0;
}

.entry-content code {
	padding: 0.25rem 0.5rem;
	border-radius: 0;
}

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

/* Copy Code Button */
.copy-code-btn {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	display: flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	background: var( --color-link );
	border: 1px solid var( --color-link );
	color: #ffffff;
	font-size: 0.875rem;
	font-weight: 600;
	cursor: pointer;
	transition: all 0.3s ease;
	border-radius: 0;
	z-index: 10;
	opacity: 0;
	pointer-events: none;
}

.code-block-wrapper:hover .copy-code-btn {
	opacity: 1;
	pointer-events: auto;
}

.copy-code-btn:hover {
	background: var( --color-link-hover );
	border-color: var( --color-link-hover );
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

.copy-code-btn:active {
	transform: translateY(0);
}

.copy-code-btn svg {
	width: 16px;
	height: 16px;
	stroke: currentColor;
	fill: none;
	flex-shrink: 0;
}

.copy-code-btn .copy-text,
.copy-code-btn .copied-text {
	display: inline-block;
	transition: opacity 0.2s ease;
}

.copy-code-btn .copied-text {
	display: none;
}

.copy-code-btn.copied .copy-text {
	display: none;
}

.copy-code-btn.copied .copied-text {
	display: inline-block;
}

.copy-code-btn.copied {
	background: #28a745;
	border-color: #28a745;
}

/* Inline code styling */
.entry-content p code,
.entry-content li code,
.entry-content td code {
	background: var( --color-surface );
	padding: 0.2rem 0.4rem;
	border-radius: 0;
	font-size: 0.9em;
}

/* Content Bottom Navigation */
.content-bottom-navigation {
	margin: 2rem 0;
	padding: 1.5rem 0;
	border-top: 1px solid var( --color-border );
	border-bottom: 1px solid var( --color-border );
}

.content-bottom-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
}

.nav-btn {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1rem 1.5rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.3s ease;
	flex: 1;
	max-width: calc(50% - 0.5rem);
	border-radius: 0;
}

.nav-btn:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

.nav-prev-btn {
	text-align: left;
}

.nav-next-btn {
	text-align: right;
	flex-direction: row-reverse;
}

.nav-btn-icon {
	font-size: 1.5rem;
	font-weight: 700;
	line-height: 1;
	flex-shrink: 0;
}

.nav-btn-text {
	display: flex;
	flex-direction: column;
	flex: 1;
	overflow: hidden;
}

.nav-btn-label {
	font-size: 0.875rem;
	opacity: 0.8;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	margin-bottom: 0.25rem;
}

.nav-btn-title {
	font-size: 1rem;
	font-weight: 600;
	color: var( --color-text-strong );
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.nav-btn:hover .nav-btn-title {
	color: #ffffff;
}

/* Post Tags */
.post-tags {
	margin: 2rem 0;
	padding: 1.5rem 0;
	border-top: 1px solid var( --color-border );
	border-bottom: 1px solid var( --color-border );
}

.tags-title {
	color: var( --color-text-strong ) !important;
	font-size: 1.125rem;
	font-weight: 600;
	margin: 0 0 1rem;
}

.tags-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
}

.tag-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.5rem 1rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	color: var( --color-text );
	text-decoration: none;
	font-size: 0.875rem;
	border-radius: 0.5rem;
	transition: all 0.2s ease;
}

.tag-link:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 2px 8px rgba(65, 105, 225, 0.3);
}

.tag-count {
	color: var( --color-link );
	font-weight: 600;
	font-size: 0.875rem;
}

.tag-link:hover .tag-count {
	color: #ffffff;
}

/* Author Profile Section */
.author-profile-section {
	margin: 3rem 0;
	padding: 2rem 0;
	border-top: 1px solid var( --color-border );
}

.author-profile-card {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	padding: 2rem;
}

.author-profile-header {
	display: flex;
	gap: 1.5rem;
	margin-bottom: 1.5rem;
}

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

.author-profile-avatar img {
	border-radius: 50%;
	width: 100px;
	height: 100px;
	object-fit: cover;
	border: 3px solid var( --color-border );
	transition: border-color 0.2s ease;
}

.author-profile-avatar a:hover img {
	border-color: var( --color-link );
}

.author-profile-info {
	flex: 1;
}

.author-profile-name {
	margin: 0 0 0.75rem;
	font-size: 1.5rem;
	font-weight: 700;
}

.author-profile-name a {
	color: var( --color-text-strong ) !important;
	text-decoration: none;
	transition: color 0.2s ease;
}

.author-profile-name a:hover {
	color: var( --color-link ) !important;
}

.author-profile-bio {
	color: var( --color-text ) !important;
	font-size: 1rem;
	line-height: 1.7;
	margin: 0;
}

.author-profile-social {
	display: flex;
	gap: 0.75rem;
	margin-bottom: 1.5rem;
	padding-top: 1.5rem;
	border-top: 1px solid var( --color-border );
}

.author-profile-social-link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	background: var( --color-bg );
	border: 1px solid var( --color-border );
	border-radius: 50%;
	color: var( --color-text );
	text-decoration: none;
	transition: all 0.2s ease;
}

.author-profile-social-link svg {
	width: 1.125rem;
	height: 1.125rem;
	fill: currentColor;
}

.author-profile-social-link:hover {
	background: var( --color-link );
	border-color: var( --color-link );
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

.author-profile-link {
	margin-top: 1rem;
}

.author-profile-link .btn {
	border-radius: 0.5rem;
}

/* Post Navigation */
.post-navigation {
	margin: 3rem 0;
	padding: 2rem 0;
	border-top: 1px solid var( --color-border );
	border-bottom: 1px solid var( --color-border );
}

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

.nav-previous,
.nav-next {
	display: flex;
}

.nav-previous a,
.nav-next a {
	color: var( --color-text );
	text-decoration: none;
	display: flex;
	flex-direction: column;
	padding: 1.5rem;
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	transition: all 0.2s ease;
	width: 100%;
}

.nav-previous a:hover,
.nav-next a:hover {
	color: var( --color-link );
	border-color: var( --color-link );
	background: var( --color-bg );
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
}

.nav-subtitle {
	font-size: 0.75rem;
	color: var( --color-text );
	opacity: 0.7;
	margin-bottom: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
	font-weight: 400;
	line-height: 1.2;
}

.nav-title {
	font-size: 1.125rem;
	font-weight: 600;
	color: var( --color-text-strong );
	line-height: 1.4;
	overflow: hidden;
	text-overflow: ellipsis;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
}

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

.nav-next a {
	align-items: flex-end;
}

/* Related Posts */
.related-posts {
	margin: 3rem 0;
	padding: 2rem 0;
	border-top: 1px solid var( --color-border );
}

.related-posts-title {
	color: var( --color-text-strong ) !important;
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 2rem;
}

.related-posts-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.5rem;
}

/* Blog Format Posts (Related Posts) */
.blog-format-posts .post-card {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0.75rem;
	overflow: hidden;
	transition: all 0.3s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
}

.blog-format-posts .post-card:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

.blog-format-posts .post-thumbnail {
	overflow: hidden;
	position: relative;
	padding-top: 56.25%; /* 16:9 */
	border-radius: 0.75rem 0.75rem 0 0;
}

.blog-format-posts .post-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
	border-radius: 0.75rem 0.75rem 0 0;
}

.blog-format-posts .post-card:hover .post-thumbnail img {
	transform: scale(1.05);
}

.blog-format-posts .post-content {
	padding: 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}

.blog-format-posts .post-meta {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1rem;
	font-size: 0.875rem;
	color: var( --color-text );
	opacity: 0.8;
}

.blog-format-posts .post-date {
	color: var( --color-text );
}

.blog-format-posts .post-category a {
	color: var( --color-link );
	text-decoration: none;
}

.blog-format-posts .post-category a:hover {
	text-decoration: underline;
}

.blog-format-posts .post-title {
	margin: 0 0 1rem;
	font-size: 1.25rem;
	font-weight: 600;
	line-height: 1.4;
}

.blog-format-posts .post-title a {
	color: var( --color-text-strong ) !important;
	text-decoration: none;
	transition: color 0.2s ease;
}

.blog-format-posts .post-title a:hover {
	color: var( --color-link ) !important;
}

.blog-format-posts .post-excerpt {
	color: var( --color-text ) !important;
	font-size: 0.9375rem;
	line-height: 1.6;
	margin-bottom: 1rem;
	flex: 1;
}

.blog-format-posts .post-read-more {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: transparent;
	color: var( --color-link );
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	border: none;
	padding: 0;
	transition: all 0.3s ease;
	margin-top: auto;
}

.blog-format-posts .post-read-more:hover {
	background: transparent;
	color: var( --color-link-hover );
	transform: translateX(4px);
}

.blog-format-posts .post-read-more svg {
	width: 1rem;
	height: 1rem;
	stroke: currentColor;
	fill: none;
	transition: transform 0.3s ease;
}

.blog-format-posts .post-read-more:hover svg {
	transform: translateX(4px);
}

.related-post-item {
	background: var( --color-surface );
	border: 1px solid var( --color-border );
	border-radius: 0;
	overflow: hidden;
	transition: all 0.3s ease;
}

.related-post-item:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

.related-post-thumbnail {
	overflow: hidden;
	position: relative;
	padding-top: 56.25%; /* 16:9 */
}

.related-post-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.related-post-item:hover .related-post-thumbnail img {
	transform: scale(1.05);
}

.related-post-content {
	padding: 1.25rem;
}

.related-post-title {
	margin: 0 0 0.75rem;
	font-size: 1.125rem;
	font-weight: 600;
}

.related-post-title a {
	color: var( --color-text-strong );
	text-decoration: none;
	transition: color 0.2s ease;
}

.related-post-title a:hover {
	color: var( --color-link );
}

.related-post-meta {
	color: var( --color-text );
	font-size: 0.875rem;
	opacity: 0.7;
}

@media screen and (max-width: 62rem) {
	.single-sidebar {
		position: static;
		margin-bottom: 2rem;
	}
	
	.post-navigation .nav-links {
		grid-template-columns: 1fr;
		gap: 1rem;
	}
	
	.nav-next {
		text-align: left;
	}
	
	.nav-next a {
		align-items: flex-start;
	}
	
	.related-posts-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}




/*--------------------------------------------------------------
# Search Results Page
--------------------------------------------------------------*/
.search-results-hero {
	padding: 4.5rem 0;
	background: radial-gradient(120% 120% at 0% 0%, rgba(65, 105, 225, 0.15) 0%, rgba(65, 105, 225, 0) 55%), var(--color-bg);
	position: relative;
	overflow: hidden;
}

.search-results-hero::after {
	content: '';
	position: absolute;
	width: 180px;
	height: 180px;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.35) 0%, rgba(255, 255, 255, 0) 65%);
	top: -40px;
	right: -40px;
	filter: blur(10px);
	opacity: 0.5;
}

.search-hero-wrapper {
	position: relative;
	z-index: 2;
	background: var(--color-surface);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 1.5rem;
	padding: 2.75rem;
	box-shadow: 0 25px 60px rgba(15, 23, 42, 0.12);
}

.search-hero-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.search-hero-search {
	width: 100%;
	max-width: 600px;
	margin-bottom: 2rem;
}

.search-hero-panel {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: 1.25rem;
	padding: 1.75rem;
	width: 100%;
	box-shadow: 0 20px 45px rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
	align-items: center;
}

.search-hero-hint {
	margin-top: 1rem;
	font-size: 0.9rem;
	color: var(--color-text);
	opacity: 0.85;
	text-align: center;
}

.search-hero-header {
	text-align: center;
	margin-bottom: 2rem;
	width: 100%;
}


.search-hero-title {
	font-size: 2.75rem;
	font-weight: 700;
	color: var(--color-text-strong);
	line-height: 1.15;
	margin-bottom: 0.75rem;
}

.search-hero-title .search-query {
	color: var(--color-link);
	font-style: italic;
}

.search-hero-subtitle {
	font-size: 1.1rem;
	color: var(--color-text);
	opacity: 0.85;
	margin: 0 auto;
	max-width: 720px;
}

.search-hero-stats {
	display: flex;
	justify-content: center;
	margin-top: 1.5rem;
}

.search-stat-card {
	background: rgba(65, 105, 225, 0.08);
	border: 1px solid rgba(65, 105, 225, 0.15);
	border-radius: 1rem;
	padding: 1.25rem;
	text-align: center;
}

.search-stat-value {
	display: block;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--color-text-strong);
}

.search-stat-label {
	display: block;
	margin-top: 0.35rem;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text);
	opacity: 0.75;
}

.search-hero-form {
	width: 100%;
}

.search-hero-input-wrapper {
	display: flex;
	align-items: center;
	background: var(--color-bg);
	border: 2px solid var(--color-border);
	border-radius: 999px;
	padding: 0.35rem 0.35rem 0.35rem 1rem;
	transition: all 0.3s ease;
}

.search-hero-input-wrapper:focus-within {
	border-color: var(--color-link);
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.15);
}

.search-hero-icon {
	color: var(--color-text);
	opacity: 0.5;
	margin-right: 0.75rem;
	flex-shrink: 0;
}

.search-hero-input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: 1rem;
	color: var(--color-text-strong);
	padding: 0.75rem 0;
	outline: none;
}

.search-hero-input::placeholder {
	color: var(--color-text);
	opacity: 0.6;
}

.search-hero-submit {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	background: var(--color-link);
	color: #ffffff;
	border: none;
	padding: 0.85rem 1.75rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.95rem;
	cursor: pointer;
	transition: all 0.2s ease;
}

.search-hero-submit svg {
	width: 18px;
	height: 18px;
	stroke: currentColor;
}

.search-hero-submit:hover {
	background: var(--color-link-hover);
	transform: translateX(4px);
	box-shadow: 0 10px 20px rgba(65, 105, 225, 0.35);
}











@media screen and (max-width: 48rem) {
	.single-post-hero {
		padding: 2rem 0;
	}
	
	.hero-content-left {
		padding-right: 0;
		margin-bottom: 2rem;
	}
	
	.hero-post-title {
		font-size: 2rem;
	}
	
	.hero-post-description {
		font-size: 1rem;
	}
	
	.hero-author-info {
		flex-direction: column;
		text-align: center;
	}
	
	.author-details {
		text-align: center;
	}
	
	.author-meta {
		justify-content: center;
		flex-wrap: wrap;
		gap: 0.75rem;
	}
	
	.post-reading-time {
		font-size: 0.875rem;
	}
	
	.post-reading-time svg {
		width: 14px;
		height: 14px;
	}
	
	.author-social-links {
		justify-content: center;
	}
	
	.author-profile-header {
		flex-direction: column;
		text-align: center;
	}

/*--------------------------------------------------------------
# New Home Page Sections - Programming Theme
--------------------------------------------------------------*/

/* Hero Section - Programming */
.home-hero-programming {
	padding: 6rem 0 4rem;
	background: linear-gradient(135deg, var(--color-bg) 0%, var(--color-surface) 100%);
	position: relative;
	overflow: hidden;
}

.home-hero-programming::before {
	content: '';
	position: absolute;
	top: -50%;
	right: -20%;
	width: 600px;
	height: 600px;
	background: radial-gradient(circle, rgba(65, 105, 225, 0.1) 0%, transparent 70%);
	border-radius: 50%;
	pointer-events: none;
}

.hero-content-programming {
	position: relative;
	z-index: 2;
}

.hero-title-programming {
	font-size: 3.5rem;
	font-weight: 800;
	line-height: 1.1;
	margin-bottom: 1.5rem;
	color: var(--color-text-strong);
	letter-spacing: -0.02em;
}

.hero-subtitle-programming {
	font-size: 1.25rem;
	line-height: 1.7;
	color: var(--color-text);
	margin-bottom: 2.5rem;
	opacity: 0.9;
	max-width: 90%;
}

/* Hero Search Bar */
.hero-search-wrapper {
	margin-bottom: 2rem;
}

.hero-search-form {
	width: 100%;
}

.hero-search-input-wrapper {
	display: flex;
	align-items: center;
	background: var(--color-surface);
	border: 2px solid var(--color-border);
	border-radius: 0.75rem;
	padding: 0.75rem 1rem;
	transition: all 0.3s ease;
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

.hero-search-input-wrapper:focus-within {
	border-color: var(--color-link);
	box-shadow: 0 6px 20px rgba(65, 105, 225, 0.15);
	transform: translateY(-2px);
}

.hero-search-icon {
	color: var(--color-text);
	opacity: 0.5;
	margin-right: 0.75rem;
	flex-shrink: 0;
}

.hero-search-input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: 1rem;
	color: var(--color-text-strong);
	padding: 0;
	outline: none;
}

.hero-search-input::placeholder {
	color: var(--color-text);
	opacity: 0.6;
}

.hero-search-submit {
	background: var(--color-link);
	color: #ffffff;
	border: none;
	padding: 0.625rem 1.5rem;
	border-radius: 0.5rem;
	font-weight: 600;
	font-size: 0.9375rem;
	cursor: pointer;
	transition: all 0.2s ease;
	margin-left: 0.75rem;
}

.hero-search-submit:hover {
	background: var(--color-link-hover);
	transform: translateY(-1px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.3);
}

/* Hero CTA Buttons */
.hero-cta-buttons {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.btn-hero-primary {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 1rem 2rem;
	background: var(--color-link);
	color: #ffffff;
	font-size: 1.0625rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 0.5rem;
	transition: all 0.3s ease;
	box-shadow: 0 4px 16px rgba(65, 105, 225, 0.3);
}

.btn-hero-primary:hover {
	background: var(--color-link-hover);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(65, 105, 225, 0.4);
}

.btn-hero-primary svg {
	transition: transform 0.3s ease;
}

.btn-hero-primary:hover svg {
	transform: translateX(4px);
}

.btn-hero-secondary {
	display: inline-flex;
	align-items: center;
	padding: 1rem 2rem;
	background: transparent;
	color: var(--color-link);
	font-size: 1.0625rem;
	font-weight: 600;
	text-decoration: none;
	border: 2px solid var(--color-link);
	border-radius: 0.5rem;
	transition: all 0.3s ease;
}

.btn-hero-secondary:hover {
	background: var(--color-link);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(65, 105, 225, 0.2);
}

.hero-image-programming {
	position: relative;
	height: 500px;
}

.hero-pattern-bg {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, rgba(65, 105, 225, 0.1) 0%, rgba(65, 105, 225, 0.05) 100%);
	border-radius: 1rem;
	position: relative;
	overflow: hidden;
}

.hero-pattern-bg::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-image: 
		radial-gradient(circle at 20% 30%, rgba(65, 105, 225, 0.15) 0%, transparent 50%),
		radial-gradient(circle at 80% 70%, rgba(65, 105, 225, 0.1) 0%, transparent 50%);
}

/* Trending Articles Section */
.trending-articles-section {
	padding: 5rem 0;
	background: var(--color-bg);
}

.section-header-trending {
	margin-bottom: 3rem;
}

.section-title-trending {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-text-strong);
	margin-bottom: 1rem;
	line-height: 1.2;
}

.section-intro-trending {
	font-size: 1.125rem;
	color: var(--color-text);
	opacity: 0.8;
	line-height: 1.7;
	max-width: 800px;
}

.trending-articles-grid {
	margin: 0 -15px;
}

.trending-article-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.75rem;
	overflow: hidden;
	transition: all 0.3s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.trending-article-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

.trending-article-thumbnail {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.trending-article-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.trending-article-card:hover .trending-article-thumbnail img {
	transform: scale(1.05);
}

.trending-article-content {
	padding: 1.5rem;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.trending-article-category {
	display: inline-block;
	padding: 0.35rem 0.75rem;
	background: var(--color-link);
	color: #ffffff;
	font-size: 0.75rem;
	font-weight: 600;
	border-radius: 0.25rem;
	margin-bottom: 0.75rem;
	width: fit-content;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.trending-article-title {
	font-size: 1.375rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
	line-height: 1.4;
	flex-grow: 1;
}

.trending-article-title a {
	color: var(--color-text-strong);
	text-decoration: none;
	transition: color 0.2s ease;
}

.trending-article-title a:hover {
	color: var(--color-link);
}

.trending-article-meta {
	font-size: 0.875rem;
	color: var(--color-text);
	opacity: 0.7;
}

/* Top Categories Section */
.top-categories-section {
	padding: 5rem 0;
	background: var(--color-surface);
}

.section-header-categories {
	text-align: center;
	margin-bottom: 3rem;
}

.section-title-categories {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-text-strong);
	margin-bottom: 1rem;
	line-height: 1.2;
}

.section-intro-categories {
	font-size: 1.125rem;
	color: var(--color-text);
	opacity: 0.8;
	line-height: 1.7;
	max-width: 600px;
	margin: 0 auto;
}

.categories-grid {
	margin: 0 -15px;
}

.category-card {
	background: var(--color-bg);
	border: 2px solid var(--color-border);
	border-radius: 0.75rem;
	padding: 1rem;
	transition: all 0.3s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
	position: relative;
	overflow: hidden;
}

.category-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--color-link), var(--color-link-hover));
	transform: scaleX(0);
	transition: transform 0.3s ease;
}

.category-card:hover::before {
	transform: scaleX(1);
}

.category-card:hover {
	border-color: var(--color-link);
	box-shadow: 0 8px 24px rgba(65, 105, 225, 0.1);
	transform: translateY(-4px);
}

.category-icon {
	width: 64px;
	height: 64px;
	background: linear-gradient(135deg, var(--color-link), var(--color-link-hover));
	border-radius: 0.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
	color: #ffffff;
}

.category-card-title {
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
	line-height: 1.3;
}

.category-card-title a {
	color: var(--color-text-strong);
	text-decoration: none;
	transition: color 0.2s ease;
}

.category-card-title a:hover {
	color: var(--color-link);
}

.category-sub-items {
	list-style: none;
	padding: 0;
	margin: 0 0 1.5rem;
	flex-grow: 1;
}

.category-sub-items li {
	padding: 0.5rem 0;
	color: var(--color-text);
	font-size: 0.9375rem;
	opacity: 0.8;
	position: relative;
	padding-left: 1.5rem;
}

.category-sub-items li::before {
	content: '→';
	position: absolute;
	left: 0;
	color: var(--color-link);
	font-weight: 600;
}

.category-link {
	color: var(--color-link);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9375rem;
	transition: all 0.2s ease;
	display: inline-block;
}

.category-link:hover {
	color: var(--color-link-hover);
	transform: translateX(4px);
}

/* Latest Posts Section */
.latest-posts-section {
	padding: 5rem 0;
	background: var(--color-bg);
}

.section-header-latest {
	text-align: center;
	margin-bottom: 3rem;
}

.section-title-latest {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-text-strong);
	margin-bottom: 1rem;
	line-height: 1.2;
}

.section-intro-latest {
	font-size: 1.125rem;
	color: var(--color-text);
	opacity: 0.8;
	line-height: 1.7;
	max-width: 700px;
	margin: 0 auto;
}

.latest-posts-grid {
	margin: 0 -15px;
}

.latest-post-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.75rem;
	overflow: hidden;
	transition: all 0.3s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.latest-post-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

.latest-post-thumbnail {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.latest-post-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.latest-post-card:hover .latest-post-thumbnail img {
	transform: scale(1.05);
}

.latest-post-category-badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
}

.latest-post-category-badge a {
	display: inline-block;
	padding: 0.45rem 1rem;
	background: rgba(0, 0, 0, 0.75);
	color: #ffffff;
	font-size: 0.8125rem;
	font-weight: 600;
	border-radius: 999px;
	text-decoration: none;
	transition: all 0.2s ease;
}

.latest-post-category-badge a:hover {
	background: rgba(0, 0, 0, 0.9);
}

.latest-post-content {
	padding: 1.5rem;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.latest-post-title {
	font-size: 1.375rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
	line-height: 1.4;
}

.latest-post-title a {
	color: var(--color-text-strong);
	text-decoration: none;
	transition: color 0.2s ease;
}

.latest-post-title a:hover {
	color: var(--color-link);
}

.latest-post-excerpt {
	color: var(--color-text);
	font-size: 0.9375rem;
	line-height: 1.7;
	margin-bottom: 1rem;
	opacity: 0.8;
	flex-grow: 1;
}

.latest-post-meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--color-text);
	opacity: 0.7;
	margin-bottom: 1rem;
}

.latest-post-separator {
	opacity: 0.5;
}

.latest-post-read-more {
	color: var(--color-link);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9375rem;
	transition: all 0.2s ease;
	display: inline-block;
	width: fit-content;
}

.latest-post-read-more:hover {
	color: var(--color-link-hover);
	transform: translateX(4px);
}

.btn-view-all-posts {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 1rem 2rem;
	background: var(--color-link);
	color: #ffffff;
	font-size: 1.0625rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 0.5rem;
	transition: all 0.3s ease;
	box-shadow: 0 4px 16px rgba(65, 105, 225, 0.3);
}

.btn-view-all-posts:hover {
	background: var(--color-link-hover);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(65, 105, 225, 0.4);
}

.btn-view-all-posts svg {
	transition: transform 0.3s ease;
}

.btn-view-all-posts:hover svg {
	transform: translateX(4px);
}

/* About Story Section */
.about-story-section {
	padding: 5rem 0;
	background: var(--color-surface);
}

.about-story-content {
	position: relative;
	z-index: 2;
}

.about-story-title {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-text-strong);
	margin-bottom: 1.5rem;
	line-height: 1.2;
}

.about-story-text {
	font-size: 1.125rem;
	line-height: 1.8;
	color: var(--color-text);
	margin-bottom: 2rem;
	opacity: 0.9;
}

.btn-about-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 1rem 2rem;
	background: var(--color-link);
	color: #ffffff;
	font-size: 1.0625rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 0.5rem;
	transition: all 0.3s ease;
	box-shadow: 0 4px 16px rgba(65, 105, 225, 0.3);
}

.btn-about-cta:hover {
	background: var(--color-link-hover);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(65, 105, 225, 0.4);
}

.about-story-image {
	position: relative;
	height: 400px;
}

.about-pattern-bg {
	width: 100%;
	height: 100%;
	background: linear-gradient(135deg, rgba(65, 105, 225, 0.1) 0%, rgba(65, 105, 225, 0.05) 100%);
	border-radius: 1rem;
	position: relative;
	overflow: hidden;
}

.about-pattern-bg::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-image: 
		radial-gradient(circle at 30% 40%, rgba(65, 105, 225, 0.15) 0%, transparent 50%),
		radial-gradient(circle at 70% 60%, rgba(65, 105, 225, 0.1) 0%, transparent 50%);
}

/* Responsive Design */
@media (max-width: 992px) {
	.hero-title-programming {
		font-size: 2.5rem;
	}

	.hero-subtitle-programming {
		font-size: 1.125rem;
		max-width: 100%;
	}

	.hero-search-input-wrapper {
		flex-direction: column;
		gap: 0.75rem;
	}

	.hero-search-submit {
		width: 100%;
		margin-left: 0;
	}

	.hero-cta-buttons {
		flex-direction: column;
	}

	.btn-hero-primary,
	.btn-hero-secondary {
		width: 100%;
		justify-content: center;
	}

	.section-title-trending,
	.section-title-categories,
	.section-title-latest,
	.about-story-title {
		font-size: 2rem;
	}
}

@media (max-width: 768px) {
	.home-hero-programming {
		padding: 4rem 0 3rem;
	}

	.hero-title-programming {
		font-size: 2rem;
	}

	.trending-articles-section,
	.top-categories-section,
	.latest-posts-section,
	.about-story-section {
		padding: 3rem 0;
	}

	.section-title-trending,
	.section-title-categories,
	.section-title-latest,
	.about-story-title {
		font-size: 1.75rem;
	}
}

/*--------------------------------------------------------------
# Search Results Page
--------------------------------------------------------------*/
.search-results-hero {
	padding: 4.5rem 0;
	background: radial-gradient(120% 120% at 0% 0%, rgba(65, 105, 225, 0.15) 0%, rgba(65, 105, 225, 0) 55%), var(--color-bg);
	position: relative;
	overflow: hidden;
}

.search-results-hero::after {
	content: '';
	position: absolute;
	width: 180px;
	height: 180px;
	background: radial-gradient(circle, rgba(255, 255, 255, 0.35) 0%, rgba(255, 255, 255, 0) 65%);
	top: -40px;
	right: -40px;
	filter: blur(10px);
	opacity: 0.5;
}

.search-hero-wrapper {
	position: relative;
	z-index: 2;
	background: var(--color-surface);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 1.5rem;
	padding: 2.75rem;
	box-shadow: 0 25px 60px rgba(15, 23, 42, 0.12);
}

.search-hero-content {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.search-hero-search {
	width: 100%;
	max-width: 600px;
	margin-bottom: 2rem;
}

.search-hero-panel {
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	border-radius: 1.25rem;
	padding: 1.75rem;
	width: 100%;
	box-shadow: 0 20px 45px rgba(0, 0, 0, 0.05);
	display: flex;
	flex-direction: column;
	align-items: center;
}

.search-hero-hint {
	margin-top: 1rem;
	font-size: 0.9rem;
	color: var(--color-text);
	opacity: 0.85;
	text-align: center;
}

.search-hero-header {
	text-align: center;
	margin-bottom: 2rem;
	width: 100%;
}


.search-hero-title {
	font-size: 2.75rem;
	font-weight: 700;
	color: var(--color-text-strong);
	line-height: 1.15;
	margin-bottom: 0.75rem;
}

.search-hero-title .search-query {
	color: var(--color-link);
	font-style: italic;
}

.search-hero-subtitle {
	font-size: 1.1rem;
	color: var(--color-text);
	opacity: 0.85;
	margin: 0 auto;
	max-width: 720px;
}

.search-hero-stats {
	display: flex;
	justify-content: center;
	margin-top: 1.5rem;
}

.search-stat-card {
	background: rgba(65, 105, 225, 0.08);
	border: 1px solid rgba(65, 105, 225, 0.15);
	border-radius: 1rem;
	padding: 1.25rem;
	text-align: center;
}

.search-stat-value {
	display: block;
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--color-text-strong);
}

.search-stat-label {
	display: block;
	margin-top: 0.35rem;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text);
	opacity: 0.75;
}

.search-hero-form {
	width: 100%;
}

.search-hero-input-wrapper {
	display: flex;
	align-items: center;
	background: var(--color-bg);
	border: 2px solid var(--color-border);
	border-radius: 999px;
	padding: 0.35rem 0.35rem 0.35rem 1rem;
	transition: all 0.3s ease;
}

.search-hero-input-wrapper:focus-within {
	border-color: var(--color-link);
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.15);
}

.search-hero-icon {
	color: var(--color-text);
	opacity: 0.5;
	margin-right: 0.75rem;
	flex-shrink: 0;
}

.search-hero-input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: 1rem;
	color: var(--color-text-strong);
	padding: 0.75rem 0;
	outline: none;
}

.search-hero-input::placeholder {
	color: var(--color-text);
	opacity: 0.6;
}

.search-hero-submit {
	display: inline-flex;
	align-items: center;
	gap: 0.45rem;
	background: var(--color-link);
	color: #ffffff;
	border: none;
	padding: 0.85rem 1.75rem;
	border-radius: 999px;
	font-weight: 600;
	font-size: 0.95rem;
	cursor: pointer;
	transition: all 0.2s ease;
}

.search-hero-submit svg {
	width: 18px;
	height: 18px;
	stroke: currentColor;
}

.search-hero-submit:hover {
	background: var(--color-link-hover);
	transform: translateX(4px);
	box-shadow: 0 10px 20px rgba(65, 105, 225, 0.35);
}

@media (max-width: 768px) {
	.search-hero-wrapper {
		padding: 2rem;
	}

	.search-hero-title {
		font-size: 2rem;
	}

	.search-hero-content {
		gap: 2rem;
	}

	.search-hero-input-wrapper {
		flex-direction: column;
		border-radius: 1rem;
		padding: 0.85rem 1rem;
		gap: 0.75rem;
	}

	.search-hero-submit {
		width: 100%;
		justify-content: center;
	}
}

.search-results-grid {
	margin: 0 -15px;
}

.search-result-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.75rem;
	overflow: hidden;
	transition: all 0.3s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.search-result-card:hover {
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.1);
	transform: translateY(-4px);
}

.search-result-thumbnail {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}

.search-result-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.search-result-card:hover .search-result-thumbnail img {
	transform: scale(1.05);
}

.search-result-category-badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
}

.search-result-category-badge a {
	display: inline-block;
	padding: 0.45rem 1rem;
	background: rgba(0, 0, 0, 0.75);
	color: #ffffff;
	font-size: 0.8125rem;
	font-weight: 600;
	border-radius: 999px;
	text-decoration: none;
	transition: all 0.2s ease;
}

.search-result-category-badge a:hover {
	background: rgba(0, 0, 0, 0.9);
}

.search-result-content {
	padding: 1.5rem;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.search-result-meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--color-text);
	opacity: 0.7;
	margin-bottom: 0.75rem;
}

.search-result-meta svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	fill: none;
}

.search-result-date,
.search-result-read-time {
	display: inline-flex;
	align-items: center;
	gap: 0.3rem;
}

.search-result-separator {
	opacity: 0.5;
}

.search-result-title {
	font-size: 1.375rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
	line-height: 1.4;
}

.search-result-title a {
	color: var(--color-text-strong);
	text-decoration: none;
	transition: color 0.2s ease;
}

.search-result-title a:hover {
	color: var(--color-link);
}

.search-result-excerpt {
	color: var(--color-text);
	font-size: 0.9375rem;
	line-height: 1.7;
	margin-bottom: 1rem;
	opacity: 0.8;
	flex-grow: 1;
}

.search-result-read-more {
	color: var(--color-link);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.9375rem;
	transition: all 0.2s ease;
	display: inline-block;
	width: fit-content;
}

.search-result-read-more:hover {
	color: var(--color-link-hover);
	transform: translateX(4px);
}

.search-pagination {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--color-border);
}

/* No Search Results */
.no-search-results-wrapper {
	padding: 4rem 0;
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.no-search-results {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
}

.no-results-content {
	text-align: center;
	padding: 3rem 2rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 1rem;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.05);
}

.no-results-icon-wrapper {
	position: relative;
	display: inline-block;
	margin-bottom: 2rem;
}

.no-results-icon {
	color: var(--color-link);
	opacity: 0.8;
	position: relative;
	z-index: 2;
	animation: float 3s ease-in-out infinite;
}

.no-results-icon svg {
	width: 120px;
	height: 120px;
	stroke: currentColor;
	fill: none;
}

.no-results-icon-bg {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: 160px;
	height: 160px;
	background: radial-gradient(circle, rgba(65, 105, 225, 0.1) 0%, transparent 70%);
	border-radius: 50%;
	z-index: 1;
}

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

.no-results-title {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-text-strong);
	margin-bottom: 1rem;
	line-height: 1.2;
}

.no-results-text {
	font-size: 1.125rem;
	color: var(--color-text);
	line-height: 1.7;
	margin-bottom: 2.5rem;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
	opacity: 0.9;
}

.no-results-text strong {
	color: var(--color-link);
	font-weight: 600;
}

/* No Results Search Form */
.no-results-search-form-wrapper {
	margin-bottom: 3rem;
}

.no-results-search-form {
	width: 100%;
	max-width: 600px;
	margin: 0 auto;
}

.no-results-search-input-wrapper {
	display: flex;
	align-items: center;
	background: var(--color-bg);
	border: 2px solid var(--color-border);
	border-radius: 0.75rem;
	padding: 1rem 1.25rem;
	transition: all 0.3s ease;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.05);
}

.no-results-search-input-wrapper:focus-within {
	border-color: var(--color-link);
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.1), 0 4px 12px rgba(0, 0, 0, 0.1);
	transform: translateY(-2px);
}

.no-results-search-icon {
	color: var(--color-text);
	opacity: 0.5;
	margin-right: 1rem;
	flex-shrink: 0;
}

.no-results-search-input {
	flex: 1;
	border: none;
	background: transparent;
	font-size: 1.0625rem;
	color: var(--color-text-strong);
	padding: 0;
	outline: none;
}

.no-results-search-input::placeholder {
	color: var(--color-text);
	opacity: 0.6;
}

.no-results-search-submit {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	background: var(--color-link);
	color: #ffffff;
	border: none;
	padding: 0.75rem 1.75rem;
	border-radius: 0.5rem;
	font-weight: 600;
	font-size: 1rem;
	cursor: pointer;
	transition: all 0.3s ease;
	margin-left: 1rem;
	box-shadow: 0 2px 8px rgba(65, 105, 225, 0.2);
}

.no-results-search-submit:hover {
	background: var(--color-link-hover);
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(65, 105, 225, 0.3);
}

.no-results-search-submit svg {
	width: 18px;
	height: 18px;
	stroke: currentColor;
	fill: none;
	transition: transform 0.3s ease;
}

.no-results-search-submit:hover svg {
	transform: translateX(2px);
}

.scroll-top-btn {
	position: fixed;
	right: 1.5rem;
	bottom: 1.5rem;
	width: 3.5rem;
	height: 3.5rem;
	border-radius: 50%;
	border: none;
	background: linear-gradient(135deg, var(--color-link), var(--color-link-hover));
	box-shadow: 0 12px 30px rgba(65, 105, 225, 0.35);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	opacity: 0;
	visibility: hidden;
	transform: translate3d(0, 15px, 0) scale(0.9);
	transition: opacity 0.3s ease, transform 0.3s ease, visibility 0.3s ease;
	z-index: 1200;
}

.scroll-top-btn::after {
	content: '';
	position: absolute;
	inset: -8px;
	border-radius: 50%;
	border: 1px solid rgba(65, 105, 225, 0.2);
	opacity: 0;
	transform: scale(0.8);
	transition: opacity 0.3s ease, transform 0.3s ease;
}

.scroll-top-btn .scroll-top-icon svg {
	width: 1.4rem;
	height: 1.4rem;
	stroke: currentColor;
}

.scroll-top-btn.is-visible {
	opacity: 1;
	visibility: visible;
	transform: translate3d(0, 0, 0) scale(1);
}

.scroll-top-btn:hover {
	transform: translate3d(0, -4px, 0) scale(1.03);
	box-shadow: 0 16px 35px rgba(65, 105, 225, 0.45);
}

.scroll-top-btn:hover::after {
	opacity: 1;
	transform: scale(1);
}

.scroll-top-btn:focus {
	outline: none;
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.3);
}

.scroll-top-btn.is-pulsing {
	animation: scrollTopPulse 0.8s ease;
}

@keyframes scrollTopPulse {
	0% {
		transform: scale(1);
	}
	50% {
		transform: scale(1.1);
	}
	100% {
		transform: scale(1);
	}
}

@media (max-width: 768px) {
	.scroll-top-btn {
		right: 1rem;
		bottom: 1rem;
	}
}

/* Popular Categories */
.no-results-categories {
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid var(--color-border);
}

.no-results-categories-title {
	font-size: 1rem;
	font-weight: 600;
	color: var(--color-text);
	margin-bottom: 1rem;
	opacity: 0.8;
}

.no-results-categories-list {
	display: flex;
	flex-wrap: wrap;
	gap: 0.75rem;
	justify-content: center;
}

.no-results-category-tag {
	display: inline-block;
	padding: 0.625rem 1.25rem;
	background: var(--color-bg);
	border: 1px solid var(--color-border);
	color: var(--color-text);
	font-size: 0.9375rem;
	font-weight: 500;
	text-decoration: none;
	border-radius: 0.5rem;
	transition: all 0.2s ease;
}

.no-results-category-tag:hover {
	background: var(--color-link);
	border-color: var(--color-link);
	color: #ffffff;
	transform: translateY(-2px);
	box-shadow: 0 4px 12px rgba(65, 105, 225, 0.2);
}

/* Responsive */
@media (max-width: 768px) {
	.no-search-results-wrapper {
		padding: 2rem 0;
	}

	.no-results-content {
		padding: 2rem 1.5rem;
	}

	.no-results-icon svg {
		width: 80px;
		height: 80px;
	}

	.no-results-icon-bg {
		width: 120px;
		height: 120px;
	}

	.no-results-title {
		font-size: 1.75rem;
	}

	.no-results-text {
		font-size: 1rem;
	}

	.no-results-search-input-wrapper {
		flex-direction: column;
		gap: 0.75rem;
		padding: 1rem;
	}

	.no-results-search-submit {
		width: 100%;
		margin-left: 0;
		justify-content: center;
	}
}

/* Responsive for Header Search */
@media (max-width: 768px) {
	.header-search-box {
		padding: 1.5rem;
		margin: 0 1rem;
	}

	.header-search-input-wrapper {
		flex-direction: column;
		gap: 0.75rem;
	}

	.header-search-submit {
		width: 100%;
		margin-left: 0;
	}

	.search-results-title {
		font-size: 1.75rem;
	}
}

/*--------------------------------------------------------------
# Work Posts Section
--------------------------------------------------------------*/
.work-posts-section {
	padding: 4rem 0;
	background: var(--color-bg);
}

.work-posts-grid {
	margin: 0 -15px;
}

.work-card {
	background: transparent;
	border: none;
	border-radius: 0.75rem;
	overflow: hidden;
	transition: all 0.3s ease;
	height: 100%;
	display: flex;
	flex-direction: column;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.08);
}

.work-card:hover {
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.15);
	transform: translateY(-6px);
}

html[data-theme="dark"] .work-card {
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.3);
}

html[data-theme="dark"] .work-card:hover {
	box-shadow: 0 12px 32px rgba(0, 0, 0, 0.5);
}

.work-thumbnail {
	overflow: hidden;
	position: relative;
	width: 100%;
	padding-top: 56.25%; /* 16:9 aspect ratio */
	border-radius: 0.75rem;
}

.work-thumbnail img {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.work-card:hover .work-thumbnail img {
	transform: scale(1.05);
}

/* Work Thumbnail Overlay - Bottom Heading */
.work-thumbnail-overlay {
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	background: linear-gradient(to top, rgba(0, 0, 0, 0.9) 0%, rgba(0, 0, 0, 0.6) 60%, transparent 100%);
	padding: 2.5rem 1.5rem 1.5rem;
	transform: translateY(0);
	transition: all 0.3s ease;
}

.work-card:hover .work-thumbnail-overlay {
	background: linear-gradient(to top, rgba(0, 0, 0, 0.95) 0%, rgba(0, 0, 0, 0.7) 60%, transparent 100%);
}

.work-title-overlay {
	margin: 0;
	font-size: 1.75rem;
	font-weight: 700;
	line-height: 1.2;
}

.work-title-overlay a {
	color: #ffffff;
	text-decoration: none;
	transition: all 0.2s ease;
	display: block;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.5);
	letter-spacing: -0.02em;
}

.work-title-overlay a:hover {
	color: var(--color-link);
	text-shadow: 0 2px 16px rgba(0, 0, 0, 0.7);
	transform: translateX(4px);
}

/* Make entire card clickable */
.work-card a {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	z-index: 1;
}

.work-thumbnail > a {
	z-index: 0;
}

.work-title-overlay a {
	position: relative;
	z-index: 2;
}

/* Work Type Badge - Overlay on thumbnail */
.work-type-badge {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
}

/* Work Date Badge - Top Right */
.work-date-badge {
	position: absolute;
	top: 1rem;
	right: 1rem;
	z-index: 3;
}

.work-date-badge span {
	display: inline-block;
	padding: 0.45rem 1rem;
	background: rgba(255, 255, 255, 0.95);
	color: var(--color-text-strong);
	font-size: 0.8125rem;
	font-weight: 600;
	border-radius: 0.35rem;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
}

html[data-theme="dark"] .work-date-badge span {
	background: rgba(255, 255, 255, 0.15);
	color: #ffffff;
}

/* No Work Found Message */
.no-work-found {
	text-align: center;
	padding: 4rem 2rem;
	color: var(--color-text);
	opacity: 0.7;
}

.no-work-found svg {
	width: 64px;
	height: 64px;
	margin: 0 auto 1.5rem;
	stroke: currentColor;
	fill: none;
	opacity: 0.5;
}

.no-work-found p {
	font-size: 1.125rem;
	margin: 0;
}

/* Work Read More Overlay - Top Right */
.work-read-more-overlay {
	position: absolute;
	top: 1rem;
	right: 1rem;
	z-index: 2;
}

.work-read-more-overlay .read-more-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.55rem 1.1rem;
	background: rgba(255, 255, 255, 0.95);
	color: var(--color-text-strong);
	font-size: 0.8125rem;
	font-weight: 600;
	text-decoration: none;
	border-radius: 0.4rem;
	box-shadow: 0 3px 12px rgba(0, 0, 0, 0.15);
	transition: all 0.2s ease;
}

.work-read-more-overlay .read-more-btn:hover {
	color: var(--color-link);
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
}

.work-read-more-overlay .read-more-btn svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	fill: none;
	transition: transform 0.2s ease;
}

.work-read-more-overlay .read-more-btn:hover svg {
	transform: translateX(2px);
}

html[data-theme="dark"] .work-read-more-overlay .read-more-btn {
	background: rgba(255, 255, 255, 0.1);
	color: #ffffff;
}

/* Single Work Hero Section */
.single-work-hero {
	padding: 4rem 0;
	background: var(--color-surface);
}

.hero-work-title {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--color-text-strong);
	margin-bottom: 1.5rem;
	line-height: 1.2;
}

.hero-work-description {
	font-size: 1.125rem;
	color: var(--color-text);
	line-height: 1.7;
	margin-bottom: 2rem;
	opacity: 0.9;
}

.hero-work-meta {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 2rem;
	font-size: 0.9375rem;
	color: var(--color-text);
}

.hero-work-meta svg {
	width: 16px;
	height: 16px;
	stroke: currentColor;
	fill: none;
	opacity: 0.7;
}

.work-date,
.work-author {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
}

.work-author a {
	color: var(--color-link);
	text-decoration: none;
	transition: color 0.2s ease;
}

.work-author a:hover {
	color: var(--color-link-hover);
}

.work-meta-separator {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-border);
}

/* Single Work Wrapper */
.single-work-wrapper {
	padding: 4rem 0;
}

.single-work-article {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.75rem;
	padding: 3rem;
	margin-bottom: 3rem;
}

.single-work-article .entry-content {
	font-size: 1.0625rem;
	line-height: 1.8;
	color: var(--color-text);
}

.single-work-article .entry-content h2,
.single-work-article .entry-content h3,
.single-work-article .entry-content h4 {
	margin-top: 2rem;
	margin-bottom: 1rem;
	color: var(--color-text-strong);
}

/* Work Navigation */
.work-navigation {
	margin-top: 3rem;
	padding-top: 2rem;
	border-top: 1px solid var(--color-border);
}

.work-navigation .nav-links {
	display: flex;
	justify-content: space-between;
	gap: 2rem;
}

.work-navigation .nav-previous,
.work-navigation .nav-next {
	flex: 1;
}

.work-navigation .nav-previous a,
.work-navigation .nav-next a {
	display: block;
	padding: 1.5rem;
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.5rem;
	text-decoration: none;
	transition: all 0.3s ease;
}

.work-navigation .nav-previous a:hover,
.work-navigation .nav-next a:hover {
	background: var(--color-bg);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
	transform: translateY(-2px);
}

.work-navigation .nav-subtitle {
	display: block;
	font-size: 0.8125rem;
	color: var(--color-text);
	opacity: 0.7;
	margin-bottom: 0.5rem;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.work-navigation .nav-title {
	display: block;
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-text-strong);
	line-height: 1.4;
}

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

/* Related Works Section */
.related-works {
	margin-top: 4rem;
	padding-top: 3rem;
	border-top: 1px solid var(--color-border);
}

.related-works-title {
	font-size: 2rem;
	font-weight: 700;
	color: var(--color-text-strong);
	margin-bottom: 2rem;
	text-align: center;
}

/* Responsive adjustments for work cards */
@media (max-width: 768px) {
	.work-posts-section {
		padding: 2rem 0;
	}
	
	.work-content {
		padding: 1.25rem;
	}
	
	.work-title {
		font-size: 1.125rem;
	}

	.work-type-badge {
		top: 0.75rem;
		left: 0.75rem;
	}

	.work-type-badge {
		padding: 0.375rem 0.75rem;
		font-size: 0.75rem;
	}

	.work-date-badge {
		top: 0.75rem;
		right: 0.75rem;
	}

	.work-date-badge span {
		padding: 0.35rem 0.75rem;
		font-size: 0.75rem;
	}

	.work-title-overlay {
		font-size: 1.375rem;
	}

	.work-thumbnail-overlay {
		padding: 2rem 1.25rem 1.25rem;
	}

	.work-read-more-overlay {
		top: 0.75rem;
		right: 0.75rem;
	}

	.work-read-more-overlay .read-more-btn {
		padding: 0.45rem 0.9rem;
		font-size: 0.75rem;
	}

	.hero-work-title {
		font-size: 1.75rem;
	}

	.hero-work-description {
		font-size: 1rem;
	}

	.single-work-article {
		padding: 2rem 1.5rem;
	}

	.work-navigation .nav-links {
		flex-direction: column;
	}

	.work-navigation .nav-next {
		text-align: left;
	}
}
	
	.author-profile-info {
		text-align: center;
	}
	
	.author-profile-social {
		justify-content: center;
	}
	
	.entry-title {
		font-size: 2rem;
	}
	
	.single-post-article {
		padding: 1.5rem;
	}
	
	.related-posts-grid {
		grid-template-columns: 1fr;
	}
	
	.sidebar-widget {
		padding: 1.25rem;
	}
	
	.toc-header {
		flex-wrap: wrap;
	}
	
	.search-input-wrapper {
		flex-direction: column;
	}
	
	.search-submit-btn {
		width: 100%;
		margin-top: 0.5rem;
	}
	
	.content-bottom-navigation .nav-links {
		flex-direction: column;
	}
	
	.nav-btn {
		max-width: 100%;
	}
	
	.nav-btn-title {
		font-size: 0.9375rem;
	}
	
	.copy-code-btn {
		opacity: 1;
		pointer-events: auto;
		font-size: 0.75rem;
		padding: 0.4rem 0.75rem;
		top: 0.5rem;
		right: 0.5rem;
	}
	
	.copy-code-btn .copy-text,
	.copy-code-btn .copied-text {
		display: none;
	}
	
	.code-block-wrapper {
		margin: 1rem 0;
	}
	
	.entry-content pre {
		padding: 1rem;
		font-size: 0.8125rem;
	}
}

/* -------------------------------------------------------------
# Work Card Redesign
------------------------------------------------------------- */
.work-card {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 1.25rem;
	overflow: hidden;
	display: flex;
	flex-direction: column;
	height: 100%;
	box-shadow: 0 22px 45px rgba(0, 0, 0, 0.06);
	transition: transform 0.35s ease, box-shadow 0.35s ease, border-color 0.35s ease;
}

.work-card:hover {
	transform: translateY(-8px);
	border-color: var(--color-link);
	box-shadow: 0 30px 60px rgba(65, 105, 225, 0.25);
}

html[data-theme="dark"] .work-card {
	box-shadow: 0 22px 45px rgba(0, 0, 0, 0.4);
}

html[data-theme="dark"] .work-card:hover {
	box-shadow: 0 30px 60px rgba(0, 0, 0, 0.5);
}

.work-card-media {
	position: relative;
	padding-top: 62%;
	overflow: hidden;
	background: var(--color-bg);
}

.work-card-media img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s cubic-bezier(0.19, 1, 0.22, 1);
}

.work-card:hover .work-card-media img {
	transform: scale(1.08);
}

.work-card-media::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(160deg, rgba(15, 23, 42, 0.4) 0%, rgba(15, 23, 42, 0) 65%);
	opacity: 0;
	transition: opacity 0.35s ease;
}

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

.work-card-media-placeholder {
	position: absolute;
	inset: 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	color: var(--color-link);
	background: linear-gradient(135deg, rgba(65, 105, 225, 0.12), rgba(65, 105, 225, 0.35));
	text-align: center;
	letter-spacing: 0.08em;
	font-weight: 600;
	text-transform: uppercase;
}

.work-card-media-placeholder span {
	font-size: 0.9rem;
}

.work-card-pill {
	position: absolute;
	top: 1rem;
	left: 1rem;
	z-index: 2;
	background: rgba(0, 0, 0, 0.75);
	color: #ffffff;
	padding: 0.35rem 0.85rem;
	border-radius: 999px;
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 600;
}

html[data-theme="dark"] .work-card-pill {
	background: rgba(255, 255, 255, 0.2);
	color: #ffffff;
}

.work-card-content {
	padding: 1.75rem;
	display: flex;
	flex-direction: column;
	height: 100%;
}

.work-card-meta {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	font-size: 0.85rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--color-text);
	margin-bottom: 0.75rem;
	opacity: 0.85;
}

.work-card-meta-item {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
}

.work-card-meta-item svg {
	width: 16px;
	height: 16px;
	stroke: currentColor;
}

.work-card-title {
	font-size: 1.45rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
	line-height: 1.3;
}

.work-card-title a {
	color: var(--color-text-strong);
	text-decoration: none;
	transition: color 0.2s ease;
}

.work-card-title a:hover {
	color: var(--color-link);
}

.work-card-excerpt {
	color: var(--color-text);
	line-height: 1.65;
	margin-bottom: 1.25rem;
	font-size: 0.98rem;
	opacity: 0.9;
	flex: 1;
}

.work-card-actions {
	margin-top: auto;
}

.work-card-btn {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	background: transparent;
	color: var( --color-link );
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	border: none;
	padding: 0;
	transition: all 0.3s ease;
}

.work-card-btn svg {
	width: 1rem;
	height: 1rem;
	stroke: currentColor;
	fill: none;
	transition: transform 0.3s ease;
}

.work-card-btn:hover {
	background: transparent;
	color: var( --color-link-hover );
	transform: translateX(4px);
	box-shadow: none;
}

.work-card-btn:focus {
	outline: 2px solid rgba(65, 105, 225, 0.5);
	outline-offset: 2px;
}

/*--------------------------------------------------------------
# FAQ Section
--------------------------------------------------------------*/
.home-faq-section {
	padding: 5rem 0;
	background: var(--color-bg);
}

/*--------------------------------------------------------------
# Contact Page
--------------------------------------------------------------*/

.contact-section {
	padding: 4rem 0;
	background: var(--color-bg);
}

.contact-form-wrapper {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.75rem;
	padding: 2.5rem;
	margin-bottom: 2rem;
}

.contact-form-title {
	color: var(--color-text-strong);
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
	line-height: 1.3;
}

.contact-form-description {
	color: var(--color-text);
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: 2rem;
	opacity: 0.85;
}

.contact-form .form-group {
	margin-bottom: 1.5rem;
}

.contact-form .form-label {
	display: block;
	color: var(--color-text-strong);
	font-size: 0.9375rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.contact-form .form-label .required {
	color: #dc3545;
	margin-left: 0.25rem;
}

.contact-form .form-control {
	width: 100%;
	padding: 0.75rem 1rem;
	border: 1px solid var(--color-border);
	border-radius: 0.5rem;
	background: var(--color-bg);
	color: var(--color-text);
	font-size: 1rem;
	transition: all 0.3s ease;
}

.contact-form .form-control:focus {
	outline: none;
	border-color: var(--color-link);
	box-shadow: 0 0 0 3px rgba(65, 105, 225, 0.1);
}

.contact-form textarea.form-control {
	resize: vertical;
	min-height: 120px;
}

.contact-form .form-row {
	display: flex;
	gap: 1rem;
	margin-bottom: 0;
}

.contact-form .form-row .form-group {
	flex: 1;
	margin-bottom: 1.5rem;
}

.contact-form .btn {
	margin-top: 0.5rem;
}

.form-message {
	margin-top: 1.5rem;
	padding: 1rem;
	border-radius: 0.5rem;
	font-size: 0.9375rem;
	display: none;
}

.form-message.success {
	background: #d4edda;
	color: #155724;
	border: 1px solid #c3e6cb;
	display: block;
}

.form-message.error {
	background: #f8d7da;
	color: #721c24;
	border: 1px solid #f5c6cb;
	display: block;
}

.contact-info-wrapper {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.75rem;
	padding: 2.5rem;
	height: fit-content;
	position: sticky;
	top: 2rem;
}

.contact-info-title {
	color: var(--color-text-strong);
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 0.75rem;
	line-height: 1.3;
}

.contact-info-description {
	color: var(--color-text);
	font-size: 1rem;
	line-height: 1.6;
	margin-bottom: 2rem;
	opacity: 0.85;
}

.contact-info-items {
	display: flex;
	flex-direction: column;
	gap: 2rem;
}

.contact-info-item {
	display: flex;
	gap: 1.25rem;
	align-items: flex-start;
}

.contact-info-icon {
	width: 48px;
	height: 48px;
	min-width: 48px;
	background: linear-gradient(135deg, var(--color-link), var(--color-link-hover));
	border-radius: 0.75rem;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #ffffff;
	flex-shrink: 0;
}

.contact-info-icon svg {
	width: 24px;
	height: 24px;
	stroke: currentColor;
	fill: none;
}

.contact-info-content {
	flex: 1;
}

.contact-info-label {
	color: var(--color-text-strong);
	font-size: 0.9375rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
	line-height: 1.4;
}

.contact-info-value {
	color: var(--color-text);
	font-size: 1rem;
	line-height: 1.6;
	text-decoration: none;
	display: block;
	transition: color 0.2s ease;
}

.contact-info-value:hover {
	color: var(--color-link);
}

.contact-info-value:not(a) {
	color: var(--color-text);
	opacity: 0.9;
}

@media (max-width: 991.98px) {
	.contact-info-wrapper {
		position: static;
		margin-top: 2rem;
	}
}

@media (max-width: 768px) {
	.contact-section {
		padding: 3rem 0;
	}

	.contact-form-wrapper,
	.contact-info-wrapper {
		padding: 2rem 1.5rem;
	}

	.contact-form-title,
	.contact-info-title {
		font-size: 1.75rem;
	}

	.contact-form .form-row {
		flex-direction: column;
		gap: 0;
	}

	.contact-info-items {
		gap: 1.5rem;
	}

	.contact-info-icon {
		width: 40px;
		height: 40px;
		min-width: 40px;
	}

	.contact-info-icon svg {
		width: 20px;
		height: 20px;
	}
}

.faq-accordion {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.faq-item {
	background: var(--color-surface);
	border: 1px solid var(--color-border);
	border-radius: 0.75rem;
	overflow: hidden;
	transition: all 0.3s ease;
}

.faq-item:hover {
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

.faq-question {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 1.5rem;
	cursor: pointer;
	transition: all 0.3s ease;
	background: transparent;
	border: none;
	width: 100%;
	text-align: left;
}

.faq-question:hover {
	background: var(--color-bg);
}

.faq-question[aria-expanded="true"] {
	background: var(--color-bg);
}

.faq-question[aria-expanded="true"] .faq-icon {
	transform: rotate(180deg);
}

.faq-question-text {
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-text-strong);
	margin: 0;
	line-height: 1.5;
	flex: 1;
	padding-right: 1rem;
}

.faq-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 32px;
	height: 32px;
	border-radius: 50%;
	background: var(--color-bg);
	color: var(--color-link);
	transition: all 0.3s ease;
	flex-shrink: 0;
}

.faq-icon svg {
	width: 20px;
	height: 20px;
	stroke: currentColor;
	fill: none;
}

.faq-question[aria-expanded="true"] .faq-icon {
	background: var(--color-link);
	color: #ffffff;
}

.faq-answer {
	padding: 0 1.5rem 1.5rem;
	color: var(--color-text);
	line-height: 1.7;
	font-size: 1rem;
}

.faq-answer p {
	margin-bottom: 1rem;
}

.faq-answer p:last-child {
	margin-bottom: 0;
}

@media (max-width: 768px) {
	.faq-question {
		padding: 1.25rem;
	}

	.faq-question-text {
		font-size: 1rem;
	}

	.faq-answer {
		padding: 0 1.25rem 1.25rem;
		font-size: 0.95rem;
	}

	/* Work Section Responsive */
	.home-work {
		padding: 3rem 0;
	}

	.work-posts-grid {
		margin: 0;
		display: flex;
		flex-wrap: wrap;
	}

	.work-posts-grid .col-lg-4,
	.work-posts-grid .col-md-6 {
		padding-left: 15px;
		padding-right: 15px;
		margin-bottom: 2rem;
		flex: 0 0 100%;
		max-width: 100%;
	}

	.work-card {
		margin-bottom: 0;
		width: 100%;
		display: flex;
		flex-direction: column;
	}

	.work-card-content {
		padding: 1.5rem;
		flex: 1;
		display: flex;
		flex-direction: column;
	}

	.work-card-title {
		font-size: 1.25rem;
		margin-bottom: 0.75rem;
	}

	.work-card-excerpt {
		font-size: 0.9375rem;
		margin-bottom: 1rem;
		line-height: 1.6;
	}

	.work-card-meta {
		font-size: 0.8125rem;
		flex-wrap: wrap;
		gap: 0.75rem;
		margin-bottom: 0.75rem;
		justify-content: flex-start;
	}

	.work-card-meta-item {
		font-size: 0.8125rem;
		white-space: nowrap;
	}

	.work-card-meta-item svg {
		width: 14px;
		height: 14px;
	}

	.work-card-pill {
		font-size: 0.6875rem;
		padding: 0.3rem 0.75rem;
		top: 0.75rem;
		left: 0.75rem;
	}

	.work-card-media {
		padding-top: 65%;
		width: 100%;
	}

	.work-card-media img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}

	.work-card-actions {
		margin-top: auto;
		padding-top: 0.5rem;
	}

	.work-card-btn {
		font-size: 0.9375rem;
		width: 100%;
		justify-content: flex-start;
	}
}

@media (max-width: 576px) {
	.work-posts-grid .col-lg-4,
	.work-posts-grid .col-md-6 {
		padding-left: 10px;
		padding-right: 10px;
		margin-bottom: 1.5rem;
	}

	.work-card-content {
		padding: 1.25rem;
	}

	.work-card-title {
		font-size: 1.125rem;
		line-height: 1.4;
	}

	.work-card-excerpt {
		font-size: 0.875rem;
		line-height: 1.6;
	}

	.work-card-meta {
		flex-direction: row;
		align-items: center;
		gap: 0.75rem;
		font-size: 0.75rem;
	}

	.work-card-meta-item {
		font-size: 0.75rem;
	}

	.work-card-meta-item svg {
		width: 12px;
		height: 12px;
	}

	.work-card-btn {
		font-size: 0.875rem;
	}
}

/* Blog Content Responsive */
@media (max-width: 768px) {
	.entry-content {
		font-size: 1rem;
	}
	
	.entry-content h2 {
		font-size: 1.75rem;
		margin-top: 2rem;
	}
	
	.entry-content h3 {
		font-size: 1.5rem;
	}
	
	.entry-content h4 {
		font-size: 1.25rem;
	}
	
	.entry-content h5 {
		font-size: 1.125rem;
	}
	
	.entry-content h6 {
		font-size: 1rem;
	}
	
	.entry-content ul,
	.entry-content ol {
		padding-left: 1.75rem;
	}
	
	.entry-content li {
		margin-bottom: 0.5rem;
	}
	
	.entry-content blockquote {
		padding: 1rem 1rem 1rem 1.5rem;
		margin: 1.5rem 0;
	}
	
	.entry-content table {
		font-size: 0.9375rem;
	}
	
	.entry-content table th,
	.entry-content table td {
		padding: 0.625rem 0.75rem;
	}
}

@media (max-width: 576px) {
	.entry-content {
		font-size: 0.9375rem;
	}
	
	.entry-content h2 {
		font-size: 1.5rem;
		margin-top: 1.5rem;
		margin-bottom: 1rem;
	}
	
	.entry-content h3 {
		font-size: 1.375rem;
	}
	
	.entry-content h4 {
		font-size: 1.125rem;
	}
	
	.entry-content ul,
	.entry-content ol {
		padding-left: 1.5rem;
		margin: 1.25rem 0;
	}
	
	.entry-content li {
		padding-left: 0.25rem;
	}
	
	.entry-content blockquote {
		padding: 0.875rem 0.875rem 0.875rem 1.25rem;
		font-size: 0.9375rem;
	}
	
	.entry-content table {
		font-size: 0.875rem;
		display: block;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
	
	.entry-content table th,
	.entry-content table td {
		padding: 0.5rem 0.625rem;
		white-space: nowrap;
	}
}

