/* ==========================================================================
   Can.ac Theme - Ported from Ecliqse
   ========================================================================== */

:root {
	/* ===========================================
	   Z-HIERARCHY (darkest to lightest)
	   Level 0: Base/recessed  - code blocks, inputs
	   Level 1: Ground         - main background
	   Level 2: Surface        - sidebar, cards
	   Level 3: Elevated       - dropdowns, hover states
	   =========================================== */

	/* Core surfaces - clear hierarchy */
	--level-0: hsl(225 13% 3%);
	--level-1: hsl(225 15% 4%);
	--level-2: hsl(225 15% 5%);
	--level-3: hsl(225 15% 9%);

	/* Semantic mapping */
	--main-bg: var(--level-1);
	--sidebar-bg: var(--level-2);
	--card-bg: var(--level-2);
	--code-bg: var(--level-0);
	--input-bg: var(--level-0);

	/* Borders - subtle, consistent */
	--border-subtle: rgba(255, 255, 255, 0.06);
	--border-default: rgba(255, 255, 255, 0.1);
	--border-strong: rgba(255, 255, 255, 0.15);

	/* Legacy border aliases */
	--border: var(--border-default);
	--sidebar-border: var(--border-subtle);

	/* Text hierarchy */
	--text-primary: #e2e4e6;
	--text-secondary: rgba(226, 228, 230, 0.72);
	--text-muted: rgba(226, 228, 230, 0.4);
	--text-faint: rgba(226, 228, 230, 0.25);

	/* Legacy text aliases */
	--sidebar-text: var(--text-secondary);
	--sidebar-text-hover: var(--text-primary);
	--sidebar-text-muted: var(--text-muted);
	--sidebar-heading: var(--text-primary);
	--social-text: var(--text-secondary);
	--meta-text: var(--text-muted);
	--author-bio: var(--text-secondary);
	--line-number: var(--text-faint);

	/* Primary accent - use sparingly */
	--accent: #e95378;
	--accent-hover: #f06a8d;
	--accent-muted: rgba(233, 83, 120, 0.15);

	/* Category colors - HSV(H, 81%, 83%) */
	--cat-exploits: #d32828;
	--cat-reverse-engineering: #7d28d3;
	--cat-software: #d38c28;
	--cat-web3: #28d39a;
	--cat-windows: #28a8d3;
	--cat-x86: #d3289a;
	--cat-uncategorised: var(--text-muted);

	/* Code accent */
	--code-inline-bg: var(--level-3);
	--code-text: #f09483;

	/* Legacy color aliases (for code syntax) */
	--purple: #b877db;
	--cyan: #25b0bc;
	--peach: #fab795;
	--coral: #f09483;
	--gold: #fac29a;

	/* Scrollbar */
	--scrollbar-bg: var(--level-0);
	--scrollbar-thumb: var(--level-3);
	--scrollbar-thumb-hover: hsl(225 15% 14%);

	/* Table */
	--table-row-alt: var(--level-0);

	/* Social brand colors */
	--brand-facebook: #3b5998;
	--brand-twitter: #000;
	--brand-linkedin: #0077b5;
	--brand-linkedin-hover: #005a8c;
	--brand-pinterest: #bd081c;
	--brand-tumblr: #35465c;

	/* Elevation shadows - subtle */
	--shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.15);
	--shadow-md: 0 2px 8px rgba(0, 0, 0, 0.2);
	--shadow-lg: 0 4px 16px rgba(0, 0, 0, 0.25);

	/* Typography */
	--font-heading: "Poppins", sans-serif;
	--font-body: "Roboto", sans-serif;
	--font-mono: "MonoLisa", "JetBrains Mono", "Menlo", "Consolas", monospace;

	/* Layout */
	--sidebar-width: 280px;

	/* Transitions */
	--transition-fast: 0.15s ease;
	--transition-base: 0.2s ease;
}

/* ==========================================================================
   Reset & Base
   ========================================================================== */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 17px;
	scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-bg);
}

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

::-webkit-scrollbar-track {
	background: var(--scrollbar-bg);
}

::-webkit-scrollbar-thumb {
	background: var(--scrollbar-thumb);
	border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--scrollbar-thumb-hover);
}

::-webkit-scrollbar-corner {
	background: var(--scrollbar-bg);
}

body {
	font-family: var(--font-body);
	background: var(--main-bg);
	color: var(--text-primary);
	min-height: 100vh;
}

::selection {
	background: var(--accent-muted);
	color: var(--text-primary);
}

a {
	color: var(--text-primary);
	text-decoration: none;
	transition: color 0.2s ease;
}

a:hover {
	color: var(--accent);
}

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

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--text-primary);
}

/* ==========================================================================
   Tables
   ========================================================================== */

table {
	width: 100%;
	border-collapse: collapse;
	margin: 1.5rem 0;
}

th {
	background: var(--level-3);
	color: var(--text-primary);
	padding: 0.75rem 1rem;
	text-align: left;
	font-weight: 500;
}

td {
	padding: 0.75rem 1rem;
	border-bottom: 1px solid var(--border);
}

tr:nth-child(even) {
	background: var(--table-row-alt);
}

h1 {
	font-family: var(--font-heading);
	font-size: 40px;
	font-weight: 700;
	line-height: 1.07;
	letter-spacing: -1.6px;
	text-transform: capitalize;
	margin-bottom: 10px;
}

h2 {
	font-family: var(--font-heading);
	font-size: 32px;
	line-height: 1.2;
	margin-bottom: 10px;
}

h3 {
	font-family: var(--font-heading);
	font-size: 28px;
	line-height: 1.2;
	margin-bottom: 8px;
}

h4 {
	font-family: var(--font-heading);
	font-size: 24px;
	line-height: 1.2;
	margin-bottom: 4px;
}

h5 {
	font-family: var(--font-heading);
	font-size: 20px;
	line-height: 1.2;
	margin-bottom: 4px;
}

h6 {
	font-family: var(--font-heading);
	font-size: 16px;
	line-height: 1.2;
}

/* ==========================================================================
   Layout - Sidebar + Main
   ========================================================================== */

.site-wrapper {
	display: flex;
	min-height: 100vh;
}

/* ==========================================================================
   Sidebar
   ========================================================================== */

.sidebar {
	width: var(--sidebar-width);
	background: var(--sidebar-bg);
	border-right: 1px solid var(--border-subtle);
	box-shadow: var(--shadow-lg);
	position: fixed;
	top: 0;
	left: 0;
	height: 100vh;
	overflow-y: auto;
	z-index: 100;
}

.sidebar-inner {
	padding: 2rem 0;
	display: flex;
	flex-direction: column;
	min-height: 100%;
	font-family: var(--font-heading);
}

.site-logo {
	font-family: var(--font-heading);
	font-size: 2.5rem;
	font-weight: 200;
	color: var(--sidebar-text-hover);
	margin-bottom: 1.5rem;
	padding: 0 30px;
	display: block;
}

.site-logo:hover {
	color: var(--sidebar-text-hover);
}

/* Sidebar Search */
.sidebar-search {
	padding: 0 30px;
	margin-bottom: 1rem;
}

.sidebar-search input[type="text"] {
	width: 100%;
	padding: 0.6rem 0.8rem;
	background: var(--input-bg);
	border: 1px solid var(--border-subtle);
	border-radius: 4px;
	color: var(--text-primary);
	font-size: 14px;
	transition: border-color var(--transition-fast);
}

.sidebar-search input[type="text"]::placeholder {
	color: var(--sidebar-text-muted);
}

.sidebar-search input[type="text"]:focus {
	outline: none;
	border-color: var(--accent);
}

/* Pagefind overrides for dark sidebar */
.sidebar-search {
	position: relative;
}

.sidebar-search .pagefind-ui {
	--pagefind-ui-scale: 0.8;
	--pagefind-ui-primary: var(--accent);
	--pagefind-ui-text: var(--sidebar-text);
	--pagefind-ui-background: var(--card-bg);
	--pagefind-ui-border: var(--sidebar-border);
	--pagefind-ui-tag: var(--sidebar-border);
	--pagefind-ui-border-width: 1px;
	--pagefind-ui-border-radius: 4px;
	--pagefind-ui-font: var(--font-body);
}

.sidebar-search .pagefind-ui__search-input,
.sidebar-search input[type="text"].pagefind-ui__search-input {
	background: var(--card-bg) !important;
	color: var(--sidebar-text) !important;
	padding-left: 2.5rem !important;
	padding-right: 4rem !important;
}

.sidebar-search .pagefind-ui__drawer {
	position: fixed;
	left: 30px;
	width: 400px;
	z-index: 1000;
	background: var(--level-3);
	border: 1px solid var(--border-default);
	border-radius: 6px;
	max-height: 70vh;
	overflow-y: auto;
	box-shadow: var(--shadow-lg);
}

.sidebar-search .pagefind-ui__results-area {
	margin-top: 0;
	padding: 0.75rem 1rem;
}

.sidebar-search .pagefind-ui__result {
	padding: 0.75rem;
	border-bottom: 1px solid var(--sidebar-border);
}

.sidebar-search .pagefind-ui__result-link {
	color: var(--sidebar-text-hover);
}

.sidebar-search .pagefind-ui__result-excerpt {
	color: var(--sidebar-text-muted);
}

.sidebar-search .pagefind-ui__result-tag {
	font-family: var(--font-mono);
	font-size: 0.65rem;
	letter-spacing: 0.05em;
	padding: 0.25rem 0.6rem;
	border-radius: 3px;
	text-transform: uppercase;
	background: var(--level-3);
	border: 1px solid var(--border-subtle);
	color: var(--text-secondary);
}

.sidebar-search .pagefind-ui__result-tag:hover {
	border-color: var(--border-default);
	color: var(--text-primary);
}

.site-logo .mirror {
	display: inline-block;
	transform: scaleX(-1);
	font-family: "Arial", sans-serif;
}

/* Sidebar Nav */
.sidebar-nav {
	margin-bottom: 1rem;
}

.sidebar-nav a {
	display: block;
	padding: 0 30px;
	line-height: 45px;
	height: 45px;
	color: var(--sidebar-text);
	font-size: 15px;
	font-weight: 200;
	letter-spacing: 0.99px;
	text-transform: capitalize;
	transition: color 0.2s ease;
}

.sidebar-nav a:hover {
	color: var(--sidebar-text-hover);
}

/* Sidebar Sections */
.sidebar-section {
	margin-bottom: 0.5rem;
}

.sidebar-section h3 {
	padding: 0 30px;
	line-height: 45px;
	font-family: var(--font-heading);
	font-size: 15px;
	font-weight: 700;
	text-transform: capitalize;
	letter-spacing: 0.99px;
	color: var(--sidebar-heading);
}

.category-list {
	list-style: none;
}

.category-list li {
	margin: 0;
}

.category-list a {
	display: flex;
	align-items: center;
	padding: 0 30px;
	line-height: 45px;
	height: 45px;
	color: var(--sidebar-text);
	font-size: 15px;
	font-weight: 200;
	letter-spacing: 0.99px;
	text-transform: capitalize;
	transition: all 0.4s ease;
}

.category-list a::before {
	content: "━";
	margin-right: 0.6rem;
	font-weight: 700;
}

.category-list .cat-x86::before {
	color: var(--cat-x86);
}
.category-list .cat-windows-internals::before {
	color: var(--cat-windows);
}
.category-list .cat-software-analysis::before {
	color: var(--cat-software);
}
.category-list .cat-exploits::before {
	color: var(--cat-exploits);
}
.category-list .cat-reverse-engineering::before {
	color: var(--cat-reverse-engineering);
}
.category-list .cat-web3::before {
	color: var(--cat-web3);
}
.category-list .cat-security::before {
	color: var(--cat-windows);
}

.category-list a:hover {
	color: var(--sidebar-text-hover);
}

/* Social Links */
.social-links a {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0 30px;
	height: 36px;
	color: var(--social-text);
	font-family: var(--font-body);
	font-size: 10.5px;
	font-weight: 300;
	letter-spacing: 0.99px;
	text-transform: capitalize;
}

.social-links a:hover {
	color: var(--sidebar-text-hover);
}

.social-links svg {
	width: 16px;
	height: 16px;
	opacity: 0.9;
	flex-shrink: 0;
}

/* Sidebar Footer */
.sidebar-footer {
	margin-top: auto;
	padding: 2rem 30px 0;
}

.sidebar-footer p {
	font-size: 0.75rem;
	color: var(--sidebar-text-muted);
}

/* ==========================================================================
   Main Content
   ========================================================================== */

.main-content {
	flex: 1;
	margin-left: var(--sidebar-width);
	padding: 0;
	max-width: calc(100% - var(--sidebar-width));
}

/* ==========================================================================
   Posts Grid / Cards
   ========================================================================== */

.posts-grid {
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
	padding: 60px 90px 10px;
}

.post-card {
	background: var(--card-bg);
	border: 1px solid var(--border-subtle);
	border-radius: 6px;
	padding: 24px;
	position: relative;
	box-shadow: var(--shadow-md);
	transition: box-shadow var(--transition-base), border-color var(--transition-base);
}

.post-card:hover {
	border-color: var(--border-default);
	box-shadow: var(--shadow-lg);
}

.post-card-header {
	margin-bottom: 0.75rem;
}

.category-badge {
	display: inline-block;
	padding: 0.25rem 0.6rem;
	border-radius: 3px;
	font-size: 0.65rem;
	font-weight: 600;
	letter-spacing: 0.03em;
	color: #fff;
	background: var(--cat-uncategorised);
}

.category-badge.cat-x86,
.category-badge.cat-x86-internals {
	background: var(--cat-x86);
}
.category-badge.cat-windows-internals {
	background: var(--cat-windows);
}
.category-badge.cat-software-analysis {
	background: var(--cat-software);
}
.category-badge.cat-exploits {
	background: var(--cat-exploits);
}
.category-badge.cat-reverse-engineering {
	background: var(--cat-reverse-engineering);
}
.category-badge.cat-web3 {
	background: var(--cat-web3);
}
.category-badge.cat-uncategorised {
	background: var(--cat-uncategorised);
}

.post-card-title {
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 30px;
	line-height: 36px;
	letter-spacing: -1.2px;
	text-transform: capitalize;
	margin-bottom: 5px;
}

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

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

.post-card-excerpt {
	color: var(--text-secondary);
	font-size: 0.95rem;
	line-height: 1.7;
	margin-bottom: 1.25rem;
}

.post-card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: 1rem;
	border-top: 1px solid var(--border);
}

.post-author {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

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

.author-info {
	display: flex;
	flex-direction: column;
}

.author-name {
	font-size: 0.85rem;
	color: var(--text-primary);
}

.post-date {
	font-size: 0.8rem;
	color: var(--text-muted);
}

.comment-count {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 0.35rem;
	background: var(--level-0);
	min-width: 40px;
	height: 28px;
	padding: 0 0.6rem;
	border-radius: 6px;
	font-size: 0.8rem;
	color: var(--text-secondary);
}

.comment-count svg {
	width: 12px;
	height: 12px;
}

/* ==========================================================================
   Single Post
   ========================================================================== */

.post {
	background: var(--main-bg);
	border-radius: 8px;
	padding: 60px 90px 10px;
	box-shadow: none;
}

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

.breadcrumbs a {
	color: var(--text-secondary);
}

.breadcrumbs a:hover {
	color: var(--accent);
}

.breadcrumbs .sep {
	margin: 0 0.5rem;
	color: var(--text-muted);
}

.breadcrumbs .current {
	color: var(--text-muted);
}

/* Post Header */
.post-header {
	margin-bottom: 2rem;
}

.post-categories {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1rem;
}

.post-header .post-title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 40px;
	line-height: 1.07;
	letter-spacing: -1.6px;
	text-transform: capitalize;
	margin-bottom: 10px;
}

/* Author/Meta Row */
.post-meta-row {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 1.5rem;
	padding-bottom: 1.5rem;
	border-bottom: 1px solid var(--border);
}

.post-author {
	display: flex;
	align-items: center;
	gap: 0.6rem;
}

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

.post-author .author-name {
	font-size: 0.9rem;
	color: var(--text-primary);
	font-weight: 500;
}

.post-meta-item {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.85rem;
	color: var(--text-secondary);
}

.post-meta-item svg {
	opacity: 0.7;
}

.post-content {
	font-size: 17px;
	font-weight: 300;
	line-height: 31.45px;
	color: var(--text-secondary);
}

.post-content p {
	margin-bottom: 20px;
}

.post-content h2 {
	font-weight: 500;
	margin: 2.5rem 0 1rem;
}

.post-content h3 {
	font-weight: 500;
	margin: 2rem 0 0.75rem;
}

.post-content p {
	margin-bottom: 1.25rem;
}

.post-content ul,
.post-content ol {
	margin-bottom: 1.25rem;
	padding-left: 2.5rem;
}

.post-content li {
	margin-bottom: 0.25rem;
	line-height: 1.6;
}

.post-content figure {
	margin: 1.5rem 0;
}

.post-content figure img {
	display: block;
	border-radius: 6px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.post-content figcaption {
	font-size: 0.9rem;
	color: var(--text-muted);
	font-style: italic;
	margin-top: 0.75rem;
	text-align: center;
}

.post-content blockquote {
	border-left: 4px solid var(--accent);
	padding-left: 1.5rem;
	margin: 1.5rem 0;
	color: var(--text-secondary);
	font-style: italic;
}

.post-content img {
	max-width: 100%;
	height: auto;
	vertical-align: middle;
}

/* Inline images in headings (emojis, icons) */
.post-content h1 img,
.post-content h2 img,
.post-content h3 img,
.post-content h4 img,
.post-content h5 img,
.post-content h6 img {
	display: inline;
	height: 1em;
	width: auto;
	max-width: none;
	vertical-align: -0.1em;
	margin: 0;
	border-radius: 0;
	box-shadow: none;
}

.post-content p > img:only-child,
.post-content > img {
	display: block;
	margin: 2rem 0;
	border-radius: 6px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.post-content p:has(> img:only-child) {
	margin: 2rem 0;
}

/* Centered images - use ![alt](img){.center} in markdown */
.post-content img.center,
.post-content p:has(> img.center) img {
	margin-left: auto;
	margin-right: auto;
}

.post-content a {
	color: var(--accent);
}

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

/* ==========================================================================
   Code Blocks
   ========================================================================== */

.post-content code {
	font-family: var(--font-mono);
	font-size: 0.9em;
}

.post-content :not(pre) > code {
	background: var(--code-inline-bg);
	padding: 0.2em 0.4em;
	border-radius: 4px;
	color: var(--code-text);
}

/* Code blocks */
.post-content pre,
.highlight pre {
	background: var(--code-bg);
	border: 1px solid var(--border);
	border-radius: 6px;
	padding: 1rem 1.25rem;
	margin: 1.5rem 0;
	overflow-x: auto;
	line-height: 1.6;
	font-size: 0.8rem;
	tab-size: 3;
}

.post-content pre code,
.highlight code {
	background: none;
	padding: 0;
	font-family: var(--font-mono);
}

.highlight {
	margin: 1.5rem 0;
}

.highlight pre {
	margin: 0;
}

/* Inline line numbers */
.chroma .ln {
	margin-right: 1em;
	color: var(--line-number);
}

/* ==========================================================================
   Post Footer & Tags
   ========================================================================== */

.post-footer {
	margin-top: 2rem;
	padding-top: 1.5rem;
	border-top: 1px solid var(--border);
}

.post-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.tag {
	font-size: 0.85rem;
	color: var(--text-muted);
}

.tag:hover {
	color: var(--accent);
}

/* ==========================================================================
   Comments
   ========================================================================== */

.comments {
	margin-top: 2rem;
	padding-top: 2rem;
	border-top: 1px solid var(--border);
}

/* ==========================================================================
   Archive / List Pages
   ========================================================================== */

.archive {
	background: transparent;
	padding: 0;
	max-width: 900px;
}

.archive-title {
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 2rem;
	margin-bottom: 0.5rem;
	color: var(--text-primary);
}

.archive-description {
	color: var(--text-secondary);
	margin-bottom: 1.5rem;
}

/* Posts List */
.posts-list {
	display: flex;
	flex-direction: column;
}

.posts-list .post-card {
	padding: 24px;
	margin-bottom: 0;
	background: var(--card-bg);
	border: 1px solid var(--border-subtle);
	border-radius: 6px;
	box-shadow: var(--shadow-md);
	text-align: center;
	transition: box-shadow var(--transition-base), border-color var(--transition-base);
}

.posts-list .post-card:hover {
	border-color: var(--border-default);
	box-shadow: var(--shadow-lg);
}

.posts-list .post-meta {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	margin-bottom: 0.5rem;
	font-size: 0.85rem;
}

.posts-list .post-meta time {
	color: var(--text-muted);
}

.posts-list .post-category {
	display: inline-block;
	padding: 0.15rem 0.45rem;
	border-radius: 3px;
	font-size: 0.6rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.03em;
	color: #fff;
	background: var(--cat-uncategorised);
}

.posts-list .post-category.cat-x86,
.posts-list .post-category.cat-x86-internals {
	background: var(--cat-x86);
}

.posts-list .post-category.cat-windows-internals {
	background: var(--cat-windows);
}

.posts-list .post-category.cat-software-analysis {
	background: var(--cat-software);
}

.posts-list .post-category.cat-exploits {
	background: var(--cat-exploits);
}

.posts-list .post-category.cat-reverse-engineering {
	background: var(--cat-reverse-engineering);
}

.posts-list .post-category.cat-web3 {
	background: var(--cat-web3);
}

.posts-list .post-category.cat-uncategorised {
	background: var(--cat-uncategorised);
}

.posts-list .post-category:hover {
	filter: brightness(1.15);
}

.posts-list .post-title {
	font-family: var(--font-heading);
	font-weight: 700;
	font-size: 1.5rem;
	margin-bottom: 0.6rem;
	line-height: 1.25;
	letter-spacing: -0.5px;
}

.posts-list .post-title a {
	color: var(--text-primary);
}

.posts-list .post-title a:hover {
	color: var(--accent);
}

.posts-list .post-excerpt {
	color: var(--text-secondary);
	font-size: 0.9rem;
	line-height: 1.7;
	margin: 0 0 1rem;
}

/* Post card footer with author and comment count */
.posts-list .post-card-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-top: 1rem;
}

.posts-list .post-author {
	display: flex;
	align-items: center;
	gap: 0.6rem;
}

.posts-list .post-author-avatar {
	width: 28px;
	height: 28px;
	border-radius: 50%;
}

.posts-list .post-author-info {
	display: flex;
	flex-direction: column;
	font-size: 0.8rem;
	line-height: 1.3;
}

.posts-list .post-author-name {
	color: var(--text-primary);
}

.posts-list .post-author-date {
	color: var(--text-muted);
}

.posts-list .post-comment-count {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.35rem 0.6rem;
	background: var(--level-0);
	border-radius: 4px;
	font-size: 0.8rem;
	color: var(--text-secondary);
}

.posts-list .post-comment-count svg {
	opacity: 0.7;
}

/* ==========================================================================
   Responsive
   ========================================================================== */

@media (max-width: 1024px) {
	.main-content {
		padding: 1.5rem 2rem;
	}

	.post {
		padding: 2rem;
	}
}

@media (max-width: 768px) {
	.sidebar {
		transform: translateX(-100%);
		transition: transform 0.3s ease;
	}

	.sidebar.open {
		transform: translateX(0);
	}

	.main-content {
		margin-left: 0;
		max-width: 100%;
		padding: 1rem;
	}

	.posts-list .post-card {
		padding: 1.25rem 0;
	}

	.posts-list .post-card-footer {
		flex-direction: column;
		align-items: flex-start;
		gap: 0.75rem;
	}

	.archive {
		padding: 1.5rem;
	}

	.post {
		padding: 1.5rem;
	}

	.post-header .post-title {
		font-size: 1.5rem;
	}

	.related-grid {
		grid-template-columns: 1fr;
	}
}

/* ==========================================================================
   Share Button
   ========================================================================== */

.post-share {
	position: relative;
	display: flex;
	justify-content: flex-end;
	margin: 2rem 0;
}

.share-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	padding: 0;
	background: var(--brand-linkedin);
	color: var(--text-primary);
	border: none;
	border-radius: 50%;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.2s ease;
}

.share-btn:hover {
	background: var(--brand-linkedin-hover);
	transform: scale(1.1);
}

.share-btn svg {
	width: 16px;
	height: 16px;
}

.share-popup {
	position: absolute;
	top: 100%;
	right: 0;
	margin-top: 0.5rem;
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
	opacity: 0;
	visibility: hidden;
	transform: translateY(-8px);
	transition: opacity 0.2s ease, transform 0.2s ease, visibility 0.2s ease;
}

.post-share.open .share-popup {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.share-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	color: #fff;
	opacity: 0;
	transform: scale(0.5);
	transition: opacity 0.15s ease, transform 0.15s ease;
}

.post-share.open .share-icon {
	opacity: 1;
	transform: scale(1);
}

.post-share.open .share-icon:nth-child(1) {
	transition-delay: 0.05s;
}
.post-share.open .share-icon:nth-child(2) {
	transition-delay: 0.1s;
}
.post-share.open .share-icon:nth-child(3) {
	transition-delay: 0.15s;
}
.post-share.open .share-icon:nth-child(4) {
	transition-delay: 0.2s;
}
.post-share.open .share-icon:nth-child(5) {
	transition-delay: 0.25s;
}

.share-icon:hover {
	transform: scale(1.15);
	color: var(--text-primary);
}

.share-facebook {
	background: var(--brand-facebook);
}
.share-twitter {
	background: var(--brand-twitter);
}
.share-linkedin {
	background: var(--brand-linkedin);
}
.share-pinterest {
	background: var(--brand-pinterest);
}
.share-tumblr {
	background: var(--brand-tumblr);
}

/* ==========================================================================
   Prev/Next Navigation
   ========================================================================== */

.post-nav {
	display: flex;
	justify-content: space-between;
	gap: 1.5rem;
	margin: 2rem 0;
	padding: 1.5rem 0;
	border-top: 1px solid var(--border);
	border-bottom: 1px solid var(--border);
}

.post-nav-item {
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.25rem;
}

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

.post-nav-label {
	font-size: 0.8rem;
	color: var(--text-muted);
}

.post-nav-title {
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 1rem;
	color: var(--text-primary);
	line-height: 1.4;
}

.post-nav-item:hover .post-nav-title {
	color: var(--accent);
}

/* ==========================================================================
   Author Box
   ========================================================================== */

.author-box {
	display: flex;
	gap: 1.5rem;
	padding: 1.75rem 2rem;
	margin: 2rem 0;
	background: var(--card-bg);
	border: 1px solid var(--border-subtle);
	border-radius: 8px;
	box-shadow: var(--shadow-sm);
}

.author-box-avatar {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	flex-shrink: 0;
}

.author-box-info {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.author-box-name {
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 1.25rem;
	margin-bottom: 0.25rem;
	color: var(--text-primary);
}

.author-box-bio {
	color: var(--author-bio);
	font-size: 0.95rem;
	line-height: 1.6;
	margin: 0;
}

/* ==========================================================================
   Related Articles
   ========================================================================== */

.related-posts {
	margin: 2rem 0;
	padding-top: 2rem;
	border-top: 1px solid var(--border);
}

.related-title {
	font-family: var(--font-heading);
	font-weight: 600;
	font-size: 1.25rem;
	margin-bottom: 1.25rem;
}

.related-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
}

.related-item {
	padding: 1.5rem;
	background: var(--card-bg);
	border: 1px solid var(--border-subtle);
	border-left: 3px solid var(--border-default);
	border-radius: 6px;
	box-shadow: var(--shadow-sm);
	transition: border-color var(--transition-base), box-shadow var(--transition-base);
}

.related-item:hover {
	border-left-color: var(--accent);
	box-shadow: var(--shadow-md);
}

.related-item-title {
	font-family: var(--font-heading);
	font-weight: 500;
	font-size: 1rem;
	line-height: 1.4;
	margin-bottom: 0.75rem;
	color: var(--text-primary);
}

.related-item:hover .related-item-title {
	color: var(--text-hover);
}

.related-item-meta {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.8rem;
	color: var(--meta-text);
}

.related-item-avatar {
	width: 24px;
	height: 24px;
	border-radius: 50%;
}

.related-item-date::before {
	content: "\2022";
	margin: 0 0.4rem;
}

/* ==========================================================================
   Chronicle - Category Page
   ========================================================================== */

.chronicle {
	--category-color: var(--accent);
	min-height: 100vh;
}

/* Header */
.chronicle-header {
	position: relative;
	padding: 80px 90px 60px;
	overflow: hidden;
}

.chronicle-header-inner {
	display: flex;
	gap: 2rem;
	position: relative;
	z-index: 2;
}

.chronicle-accent {
	width: 6px;
	background: var(--category-color);
	border-radius: 3px;
	flex-shrink: 0;
	box-shadow: 0 0 20px color-mix(in srgb, var(--category-color) 40%, transparent);
}

.chronicle-title-block {
	display: flex;
	flex-direction: column;
	gap: 0.5rem;
}

.chronicle-label {
	font-family: var(--font-mono);
	font-size: 0.7rem;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--category-color);
}

.chronicle-title {
	font-family: var(--font-heading);
	font-size: clamp(2.5rem, 6vw, 4rem);
	font-weight: 700;
	letter-spacing: -0.03em;
	line-height: 1;
	color: var(--text-primary);
	margin: 0;
}

.chronicle-desc {
	font-size: 1.1rem;
	color: var(--text-secondary);
	max-width: 600px;
	line-height: 1.6;
	margin: 0.5rem 0 0;
}

.chronicle-socials {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-top: 1rem;
}

.chronicle-socials a {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 36px;
	height: 36px;
	border-radius: 50%;
	background: var(--level-0);
	border: 1px solid var(--border-subtle);
	color: var(--text-muted);
	transition: all 0.2s ease;
}

.chronicle-socials a:hover {
	color: var(--text-primary);
	border-color: var(--border-default);
	transform: translateY(-2px);
}

.chronicle-meta {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	margin-top: 1rem;
}

.chronicle-count {
	font-family: var(--font-mono);
	font-size: 0.8rem;
	color: var(--text-muted);
	padding: 0.4rem 0.8rem;
	background: var(--level-0);
	border-radius: 4px;
	border: 1px solid var(--border-subtle);
}

/* Pattern overlay */
.chronicle-pattern {
	position: absolute;
	inset: 0;
	opacity: 0.03;
	background-image: repeating-linear-gradient(
			90deg,
			var(--text-primary) 0px,
			var(--text-primary) 1px,
			transparent 1px,
			transparent 60px
		),
		repeating-linear-gradient(0deg, var(--text-primary) 0px, var(--text-primary) 1px, transparent 1px, transparent 60px);
	pointer-events: none;
}

/* Timeline */
.chronicle-timeline {
	position: relative;
	padding: 0 90px 60px;
	padding-left: 90px;
}

.timeline-line {
	position: absolute;
	left: 170px;
	top: 0;
	bottom: 60px;
	width: 1px;
	background: linear-gradient(
		to bottom,
		var(--category-color),
		var(--border-subtle) 100px,
		var(--border-subtle) calc(100% - 100px),
		transparent
	);
}

/* Entry */
.timeline-entry {
	display: grid;
	grid-template-columns: 80px 1fr;
	gap: 60px;
	position: relative;
	padding-bottom: 2.5rem;
	opacity: 0;
	transform: translateY(20px);
	animation: timeline-enter 0.5s ease forwards;
	animation-delay: calc(var(--delay) * 0.08s);
}

@keyframes timeline-enter {
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Marker */
.timeline-marker {
	position: absolute;
	left: 80px;
	top: 8px;
	width: 1px;
	display: flex;
	justify-content: center;
	z-index: 2;
}

.timeline-dot {
	width: 11px;
	height: 11px;
	background: var(--level-1);
	border: 2px solid var(--category-color);
	border-radius: 50%;
	transition: all 0.2s ease;
}

.timeline-entry:hover .timeline-dot {
	background: var(--category-color);
	box-shadow: 0 0 12px color-mix(in srgb, var(--category-color) 50%, transparent);
}

/* Date column */
.timeline-date-col {
	text-align: right;
	padding-top: 4px;
	padding-right: 20px;
}

.timeline-date {
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	font-family: var(--font-mono);
	line-height: 1.2;
}

.date-month {
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--text-muted);
}

.date-day {
	font-size: 1.8rem;
	font-weight: 600;
	color: var(--text-primary);
	letter-spacing: -0.02em;
}

.date-year {
	font-size: 0.7rem;
	color: var(--text-faint);
}

/* Card */
.timeline-content {
	min-width: 0;
}

.timeline-card {
	background: var(--card-bg);
	border: 1px solid var(--border-subtle);
	border-left: 3px solid var(--category-color);
	border-radius: 0 8px 8px 0;
	padding: 1.5rem 2rem;
	transition: all 0.25s ease;
}

.timeline-entry:hover .timeline-card {
	border-color: var(--border-default);
	border-left-color: var(--category-color);
	box-shadow: var(--shadow-lg);
	transform: translateX(4px);
}

.timeline-badges {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 0.75rem;
}

.timeline-badge {
	font-family: var(--font-mono);
	font-size: 0.65rem;
	letter-spacing: 0.05em;
	padding: 0.25rem 0.6rem;
	border-radius: 3px;
	color: var(--text-primary);
	background: var(--level-3);
	border: 1px solid var(--border-subtle);
	transition: all 0.15s ease;
}

.timeline-badge:hover {
	border-color: var(--border-default);
	color: var(--text-primary);
}

.timeline-badge.cat-x86 {
	border-color: var(--cat-x86);
	color: var(--cat-x86);
}
.timeline-badge.cat-windows-internals {
	border-color: var(--cat-windows);
	color: var(--cat-windows);
}
.timeline-badge.cat-software-analysis {
	border-color: var(--cat-software);
	color: var(--cat-software);
}
.timeline-badge.cat-exploits {
	border-color: var(--cat-exploits);
	color: var(--cat-exploits);
}
.timeline-badge.cat-reverse-engineering {
	border-color: var(--cat-reverse-engineering);
	color: var(--cat-reverse-engineering);
}
.timeline-badge.cat-web3 {
	border-color: var(--cat-web3);
	color: var(--cat-web3);
}
.timeline-badge.cat-security {
	border-color: var(--cat-windows);
	color: var(--cat-windows);
}

.timeline-title {
	font-family: var(--font-heading);
	font-size: 1.5rem;
	font-weight: 600;
	line-height: 1.3;
	letter-spacing: -0.02em;
	margin: 0 0 0.75rem;
}

.timeline-title a {
	color: var(--text-primary);
	transition: color 0.15s ease;
}

.timeline-title a:hover {
	color: var(--category-color);
}

.timeline-excerpt {
	font-size: 0.95rem;
	line-height: 1.7;
	color: var(--text-secondary);
	margin: 0 0 1.25rem;
}

.timeline-footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-top: 1rem;
	border-top: 1px solid var(--border-subtle);
}

.timeline-author {
	display: flex;
	align-items: center;
	gap: 0.6rem;
}

.timeline-avatar {
	width: 32px;
	height: 32px;
	border-radius: 50%;
	border: 2px solid var(--border-subtle);
}

.timeline-author-name {
	font-size: 0.85rem;
	color: var(--text-secondary);
}

.timeline-footer-right {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.timeline-comments {
	display: flex;
	align-items: center;
	gap: 0.4rem;
	font-family: var(--font-mono);
	font-size: 0.75rem;
	color: var(--text-muted);
	padding: 0.3rem 0.6rem;
	background: var(--level-0);
	border-radius: 4px;
}

.timeline-comments svg {
	opacity: 0.6;
}

/* Responsive */
@media (max-width: 1024px) {
	.chronicle-header {
		padding: 60px 40px 40px;
	}

	.chronicle-timeline {
		padding: 0 40px 40px;
	}

	.timeline-line {
		left: 120px;
	}

	.timeline-entry {
		gap: 40px;
	}

	.timeline-marker {
		left: 80px;
	}
}

@media (max-width: 768px) {
	.chronicle-header {
		padding: 40px 20px 30px;
	}

	.chronicle-accent {
		width: 4px;
	}

	.chronicle-title {
		font-size: 2rem;
	}

	.chronicle-timeline {
		padding: 0 20px 30px;
	}

	.timeline-line {
		display: none;
	}

	.timeline-marker {
		display: none;
	}

	.timeline-entry {
		grid-template-columns: 1fr;
		gap: 0;
	}

	.timeline-date-col {
		text-align: left;
		margin-bottom: 0.75rem;
	}

	.timeline-date {
		flex-direction: row;
		align-items: baseline;
		gap: 0.5rem;
	}

	.date-day {
		font-size: 1.25rem;
	}

	.timeline-card {
		padding: 1.25rem;
		border-radius: 6px;
		border-left-width: 3px;
	}

	.timeline-entry:hover .timeline-card {
		transform: none;
	}
}
