/* Base reset + entry content + layout primitives */

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

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; }

body {
	margin: 0;
	background: var(--vl-bg);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img, svg, video { max-width: 100%; height: auto; }
img { display: block; }

button, input, select, textarea {
	font-family: inherit;
	font-size: inherit;
	color: inherit;
}

/* Skip link */
.vl-skip-link {
	position: absolute;
	left: -9999px;
	top: 12px;
	background: var(--vl-primary);
	color: #fff;
	padding: 10px 16px;
	border-radius: var(--vl-radius);
	font-weight: var(--vl-fw-semibold);
	z-index: 999;
}
.vl-skip-link:focus {
	left: 12px;
}

/* Site layout wrapper (header + main + footer stack) */
.vl-site {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
}
.vl-site__main {
	flex: 1 0 auto;
}

/* Entry content (pages/posts default) */
.vl-entry {
	padding-block: clamp(48px, 6vw, 80px);
}
.vl-entry__header {
	max-width: 820px;
	margin: 0 auto var(--vl-sp-6);
	text-align: left;
}
.vl-entry__title {
	font-size: clamp(32px, 4.5vw, var(--vl-fs-3xl));
	margin: 0 0 var(--vl-sp-3);
}
.vl-entry__meta {
	color: var(--vl-muted);
	font-size: var(--vl-fs-sm);
}
.vl-entry__content {
	max-width: 780px;
	margin: 0 auto;
	font-size: var(--vl-fs-md);
	line-height: var(--vl-lh-relaxed);
}
.vl-entry__content h2 { font-size: var(--vl-fs-2xl); margin-top: 2em; }
.vl-entry__content h3 { font-size: var(--vl-fs-xl); margin-top: 1.6em; }
.vl-entry__content p,
.vl-entry__content ul,
.vl-entry__content ol,
.vl-entry__content blockquote,
.vl-entry__content pre,
.vl-entry__content figure { margin: 1em 0; }
.vl-entry__content a { text-decoration: underline; }
.vl-entry__content img,
.vl-entry__content figure { border-radius: var(--vl-radius); }
.vl-entry__content blockquote {
	border-left: 3px solid var(--vl-accent);
	padding: var(--vl-sp-3) var(--vl-sp-5);
	color: var(--vl-ink-700);
	background: var(--vl-bg-soft);
	border-radius: 0 var(--vl-radius) var(--vl-radius) 0;
}
.vl-entry__content code {
	font-family: var(--vl-font-mono);
	background: var(--vl-bg-soft);
	padding: 2px 6px;
	border-radius: var(--vl-radius-sm);
	font-size: 0.9em;
}
.vl-entry__content pre {
	font-family: var(--vl-font-mono);
	background: var(--vl-ink);
	color: #fff;
	padding: var(--vl-sp-5);
	border-radius: var(--vl-radius);
	overflow-x: auto;
	font-size: var(--vl-fs-sm);
}
.vl-entry__content pre code {
	background: transparent;
	padding: 0;
	color: inherit;
}

/* Archive grid (posts listing) */
.vl-archive {
	padding-block: clamp(48px, 6vw, 80px);
}
.vl-archive__header {
	margin-bottom: var(--vl-sp-7);
}
.vl-archive__grid {
	display: grid;
	gap: var(--vl-sp-6);
	grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}
.vl-archive-card {
	display: flex;
	flex-direction: column;
	gap: var(--vl-sp-3);
	border: 1px solid var(--vl-border);
	border-radius: var(--vl-radius-lg);
	overflow: hidden;
	background: var(--vl-bg);
	transition: transform .18s var(--vl-ease), box-shadow .18s var(--vl-ease), border-color .18s var(--vl-ease);
}
.vl-archive-card:hover {
	transform: translateY(-3px);
	box-shadow: var(--vl-shadow);
	border-color: transparent;
}
.vl-archive-card__thumb img {
	aspect-ratio: 16 / 10;
	object-fit: cover;
	width: 100%;
	height: auto;
}
.vl-archive-card__body {
	padding: 0 var(--vl-sp-5) var(--vl-sp-5);
	display: flex;
	flex-direction: column;
	gap: var(--vl-sp-2);
}
.vl-archive-card__title {
	margin: 0;
	font-size: var(--vl-fs-lg);
	font-weight: var(--vl-fw-bold);
	line-height: var(--vl-lh-snug);
}
.vl-archive-card__title a { color: inherit; text-decoration: none; }
.vl-archive-card__meta {
	color: var(--vl-muted);
	font-size: var(--vl-fs-sm);
}

/* Pagination */
.vl-pagination {
	display: flex;
	justify-content: center;
	gap: var(--vl-sp-2);
	margin-top: var(--vl-sp-7);
}
.vl-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 40px;
	height: 40px;
	padding: 0 var(--vl-sp-3);
	border-radius: var(--vl-radius);
	border: 1px solid var(--vl-border);
	color: var(--vl-ink);
	text-decoration: none;
	font-weight: var(--vl-fw-medium);
}
.vl-pagination .page-numbers.current {
	background: var(--vl-primary);
	color: #fff;
	border-color: var(--vl-primary);
}
.vl-pagination .page-numbers:hover:not(.current) {
	border-color: var(--vl-primary);
	color: var(--vl-primary);
}

/* 404 / search */
.vl-message {
	padding-block: clamp(64px, 10vw, 120px);
	text-align: center;
	max-width: 640px;
	margin: 0 auto;
}
.vl-message h1 {
	font-size: clamp(32px, 5vw, var(--vl-fs-3xl));
	margin-bottom: var(--vl-sp-3);
}
.vl-message p {
	color: var(--vl-muted);
	margin-bottom: var(--vl-sp-5);
}

/* Search form */
.vl-search-form {
	display: flex;
	gap: var(--vl-sp-2);
	max-width: 480px;
	margin: 0 auto;
}
.vl-search-form input[type="search"] {
	flex: 1;
	padding: 12px 14px;
	border: 1px solid var(--vl-border);
	border-radius: var(--vl-radius);
	font-size: var(--vl-fs-base);
	background: #fff;
}
.vl-search-form input[type="search"]:focus {
	outline: 2px solid var(--vl-primary);
	outline-offset: 1px;
	border-color: var(--vl-primary);
}
