/* ============================================================
 *  Pluffie Base CSS
 *  Reset, body, typografie, focus states, accessibility.
 * ============================================================ */

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

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

body {
	margin: 0;
	font-family: var(--pluffie-font-body);
	font-size: var(--pluffie-fs-xs);
	font-weight: var(--pluffie-fw-regular);
	line-height: var(--pluffie-lh-base);
	color: var(--pluffie-text);
	background-color: var(--pluffie-cream);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	text-rendering: optimizeLegibility;
}

/* Typografie */

h1, h2, h3, h4, h5, h6,
.pluffie-h1, .pluffie-h2, .pluffie-h3, .pluffie-h4 {
	font-family: var(--pluffie-font-display);
	font-weight: var(--pluffie-fw-bold);
	line-height: var(--pluffie-lh-tight);
	letter-spacing: var(--pluffie-tracking-tight);
	color: var(--pluffie-fg);
	margin: 0 0 var(--pluffie-space-md);
}

h1, .pluffie-h1 { font-size: var(--pluffie-fs-hero); font-weight: var(--pluffie-fw-bold); }
h2, .pluffie-h2 { font-size: var(--pluffie-fs-2xl); }
h3, .pluffie-h3 { font-size: var(--pluffie-fs-xl); }
h4, .pluffie-h4 { font-size: var(--pluffie-fs-lg); }
h5            { font-size: var(--pluffie-fs-md); }
h6            { font-size: var(--pluffie-fs-sm); }

p {
	margin: 0 0 var(--pluffie-space-md);
	max-width: 65ch;
}

a {
	color: var(--pluffie-mokka-dark);
	text-decoration: underline;
	text-decoration-color: var(--pluffie-peach);
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
	transition: color var(--pluffie-transition-base), text-decoration-color var(--pluffie-transition-base);
}

a:hover,
a:focus-visible {
	color: var(--pluffie-mokka);
	text-decoration-color: var(--pluffie-mokka);
}

strong, b {
	font-weight: var(--pluffie-fw-bold);
	color: var(--pluffie-mokka-dark);
}

em, i {
	font-style: italic;
}

small {
	font-size: var(--pluffie-fs-2xs);
	color: var(--pluffie-text-muted);
}

ul, ol {
	margin: 0 0 var(--pluffie-space-md);
	padding-left: var(--pluffie-space-md);
}

li {
	margin-bottom: var(--pluffie-space-2xs);
}

blockquote {
	margin: var(--pluffie-space-lg) 0;
	padding: var(--pluffie-space-md) var(--pluffie-space-lg);
	background: var(--pluffie-peach-light);
	border-left: 4px solid var(--pluffie-peach-dark);
	border-radius: var(--pluffie-radius-md);
	font-style: italic;
	color: var(--pluffie-mokka-dark);
}

hr {
	border: 0;
	height: 2px;
	background: var(--pluffie-border);
	border-radius: var(--pluffie-radius-pill);
	margin: var(--pluffie-space-xl) 0;
}

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

img {
	border-radius: var(--pluffie-radius-md);
}

/* Forms en focus */

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

:focus-visible {
	outline: 3px solid var(--pluffie-peach-dark);
	outline-offset: 2px;
	border-radius: var(--pluffie-radius-sm);
}

::selection {
	background: var(--pluffie-peach);
	color: var(--pluffie-mokka-dark);
}

/* Skip-link voor toegankelijkheid */
.skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: var(--pluffie-z-toast);
	padding: var(--pluffie-space-sm) var(--pluffie-space-md);
	background: var(--pluffie-mokka-dark);
	color: var(--pluffie-soft-white);
	border-radius: 0 0 var(--pluffie-radius-md) 0;
	font-weight: var(--pluffie-fw-bold);
}

.skip-link:focus {
	left: 0;
}

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

/* Decoratie helpers */

.pluffie-paw {
	display: inline-block;
	color: var(--pluffie-mokka-light);
	vertical-align: middle;
}

.pluffie-heart {
	display: inline-block;
	color: var(--pluffie-peach-dark);
	vertical-align: middle;
}
