/**
 * Base — premium typography scale, consistent rhythm.
 */

html { font-size: 16px; }

/* Tighter scale at 1440px+ (no more 17/18px body — premium look holds at 16px) */

body {
	font-size: var(--evde-fs-base);
	line-height: var(--evde-lh-normal);
	color: var(--evde-text);
	background: var(--evde-bg);
}

h1 { font-size: clamp(1.875rem, 2.2vw + 1rem, 2.75rem); line-height: var(--evde-lh-tight); letter-spacing: -0.02em; }
h2 { font-size: clamp(1.5rem, 1.4vw + 1rem, 2.125rem); line-height: var(--evde-lh-tight); letter-spacing: -0.015em; }
h3 { font-size: clamp(1.125rem, 0.6vw + 1rem, 1.375rem); line-height: var(--evde-lh-snug); }
h4 { font-size: var(--evde-fs-lg); line-height: var(--evde-lh-snug); }
h5 { font-size: var(--evde-fs-base); font-weight: var(--evde-fw-bold); }
h6 { font-size: var(--evde-fs-sm); letter-spacing: 0.04em; text-transform: uppercase; color: var(--evde-text-soft); }

p {
	color: var(--evde-text-muted);
	max-width: 70ch;
	line-height: var(--evde-lh-relaxed);
}

.lead {
	font-size: var(--evde-fs-lg);
	color: var(--evde-text-muted);
	line-height: var(--evde-lh-relaxed);
}

small {
	font-size: var(--evde-fs-sm);
	color: var(--evde-text-soft);
}

strong, b {
	font-weight: var(--evde-fw-semibold);
	color: var(--evde-text);
}

a {
	color: var(--evde-accent-700);
	text-underline-offset: 3px;
	text-decoration-thickness: 1px;
}

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

hr {
	border: 0;
	border-top: 1px solid var(--evde-border);
	margin: var(--evde-sp-6) 0;
}

blockquote {
	border-left: 3px solid var(--evde-accent);
	padding: var(--evde-sp-2) var(--evde-sp-5);
	color: var(--evde-text);
	font-size: var(--evde-fs-lg);
	font-style: italic;
	margin: var(--evde-sp-5) 0;
}

code, pre, kbd, samp {
	font-family: var(--evde-font-mono);
	font-size: 0.95em;
}

code {
	background: var(--evde-brand-50);
	padding: 2px 6px;
	border-radius: var(--evde-r-xs);
}

pre {
	background: var(--evde-brand-50);
	padding: var(--evde-sp-4);
	border-radius: var(--evde-r-md);
	overflow-x: auto;
}

img { border-radius: var(--evde-r-md); }
figure { margin: var(--evde-sp-5) 0; }
figcaption { font-size: var(--evde-fs-sm); color: var(--evde-text-soft); margin-top: var(--evde-sp-2); }

/* Skip link */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	background: var(--evde-brand);
	color: var(--evde-text-invert);
	padding: var(--evde-sp-3) var(--evde-sp-4);
	z-index: var(--evde-z-toast);
	border-radius: 0 0 var(--evde-r-md) 0;
	text-decoration: none;
}
.skip-link:focus { left: 0; }

/* Self-hosted fonts */
@font-face {
	font-family: 'Inter';
	font-style: normal;
	font-weight: 100 900;
	font-display: swap;
	src: url('../fonts/inter-var.woff2') format('woff2-variations'),
		 url('../fonts/inter-var.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0100-017F, U+0180-024F, U+1E00-1EFF, U+0300-036F;
}

@font-face {
	font-family: 'Manrope';
	font-style: normal;
	font-weight: 400 800;
	font-display: swap;
	src: url('../fonts/manrope-display.woff2') format('woff2-variations'),
		 url('../fonts/manrope-display.woff2') format('woff2');
	unicode-range: U+0000-00FF, U+0100-017F, U+0180-024F, U+1E00-1EFF, U+0300-036F;
}

/* Prose (single post) */
.evde-prose {
	font-size: var(--evde-fs-base);
	color: var(--evde-text);
	line-height: var(--evde-lh-relaxed);
}
.evde-prose h2 {
	margin-top: var(--evde-sp-10);
	margin-bottom: var(--evde-sp-4);
	scroll-margin-top: 100px;
	font-size: clamp(1.375rem, 1.2vw + 1rem, 1.875rem);
}
.evde-prose h3 {
	margin-top: var(--evde-sp-7);
	margin-bottom: var(--evde-sp-3);
	scroll-margin-top: 100px;
	color: var(--evde-brand);
}
.evde-prose h4 { margin-top: var(--evde-sp-5); margin-bottom: var(--evde-sp-2); color: var(--evde-brand-500); }
.evde-prose p, .evde-prose ul, .evde-prose ol { margin: var(--evde-sp-4) 0; }
.evde-prose p { max-width: none; color: var(--evde-text); }
.evde-prose ul, .evde-prose ol { padding-left: 1.25rem; }
.evde-prose ul li { list-style: disc; }
.evde-prose ol li { list-style: decimal; }
.evde-prose li { margin: var(--evde-sp-1) 0; color: var(--evde-text); }
.evde-prose li::marker { color: var(--evde-accent); }
.evde-prose a { color: var(--evde-accent-700); text-decoration: underline; text-underline-offset: 3px; }
.evde-prose a:hover { color: var(--evde-brand); }
.evde-prose img { margin: var(--evde-sp-5) 0; width: 100%; }
.evde-prose table { margin: var(--evde-sp-5) 0; border: 1px solid var(--evde-border); border-radius: var(--evde-r-md); overflow: hidden; }
.evde-prose table th { background: var(--evde-brand-50); padding: 10px 12px; text-align: left; font-size: var(--evde-fs-sm); color: var(--evde-brand); font-weight: var(--evde-fw-semibold); }
.evde-prose table td { padding: 10px 12px; border-top: 1px solid var(--evde-border-subtle); font-size: var(--evde-fs-sm); }
.evde-prose details {
	background: var(--evde-surface);
	border: 1px solid var(--evde-border);
	border-radius: var(--evde-r-md);
	padding: 14px 18px;
	margin: 10px 0;
	transition: all var(--evde-d-base);
}
.evde-prose details[open] { box-shadow: var(--evde-shadow-sm); border-color: var(--evde-accent-200); }
.evde-prose details summary {
	font-weight: var(--evde-fw-semibold);
	cursor: pointer;
	color: var(--evde-brand);
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 10px;
	font-size: var(--evde-fs-base);
}
.evde-prose details summary::-webkit-details-marker { display: none; }
.evde-prose details summary::after {
	content: "+";
	font-weight: var(--evde-fw-regular);
	font-size: 1.25rem;
	color: var(--evde-accent);
	transition: transform var(--evde-d-base);
	width: 22px; height: 22px;
	display: grid; place-items: center;
	border-radius: 50%;
	background: var(--evde-accent-50);
	flex-shrink: 0;
}
.evde-prose details[open] summary::after { transform: rotate(45deg); }
.evde-prose details > *:not(summary) { margin-top: 10px; }

/* Form inputs */
label {
	display: inline-block;
	font-size: var(--evde-fs-sm);
	font-weight: var(--evde-fw-semibold);
	color: var(--evde-text);
	margin-bottom: var(--evde-sp-2);
}

input[type=text],
input[type=email],
input[type=tel],
input[type=url],
input[type=search],
input[type=number],
input[type=date],
textarea,
select {
	width: 100%;
	background: var(--evde-surface);
	border: 1.5px solid var(--evde-border);
	border-radius: var(--evde-r-md);
	padding: 0.65rem 0.85rem;
	font-size: var(--evde-fs-sm);
	color: var(--evde-text);
	transition: border-color var(--evde-d-base), box-shadow var(--evde-d-base);
	min-height: 44px;
}
textarea { min-height: 110px; resize: vertical; }

input:focus, textarea:focus, select:focus {
	border-color: var(--evde-accent);
	box-shadow: var(--evde-shadow-glow);
	outline: none;
}

input:invalid:not(:placeholder-shown),
textarea:invalid:not(:placeholder-shown) {
	border-color: var(--evde-danger);
}

input[type=checkbox],
input[type=radio] {
	width: auto;
	min-height: auto;
	accent-color: var(--evde-accent);
}

/* Global link styling: no underline by default, only inside prose */
a:not(.evde-prose a):not(:hover) { text-decoration: none; }
