/**
 * Greenfork Theme – Aanvullende CSS
 * Bevat componenten die buiten Elementor vallen (WordPress blokken, comments, etc.)
 */

/* ==========================================================================
   WordPress Blok Editor Stijlen
   ========================================================================== */

.wp-block-image img {
	border-radius: 0;
}

.wp-block-quote {
	border-left: 4px solid var(--gf-primary);
	padding: 1rem 1.5rem;
	font-style: italic;
	font-family: var(--gf-font-head);
	font-size: 1.2rem;
	color: var(--gf-secondary);
	background: rgba(74, 124, 89, 0.05);
}

.wp-block-pullquote {
	border-top: 4px solid var(--gf-accent);
	border-bottom: 4px solid var(--gf-accent);
	padding: 2rem;
	text-align: center;
}

.wp-block-pullquote blockquote {
	font-family: var(--gf-font-head);
	font-size: 1.5rem;
	color: var(--gf-secondary);
}

.wp-block-separator {
	border-top: 2px solid var(--gf-accent);
	opacity: 0.5;
}

.wp-block-button .wp-block-button__link {
	background-color: var(--gf-primary);
	color: var(--gf-white);
	border-radius: 0;
	padding: 0.85em 2.2em;
	font-family: var(--gf-font-body);
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	font-size: 0.9rem;
	transition: background-color 0.25s;
}

.wp-block-button .wp-block-button__link:hover {
	background-color: var(--gf-secondary);
}

.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent;
	border: 2px solid var(--gf-primary);
	color: var(--gf-primary);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--gf-primary);
	color: var(--gf-white);
}

/* ==========================================================================
   Archief / Blog
   ========================================================================== */

.post-card {
	background: var(--gf-white);
	border: 1px solid rgba(0,0,0,0.07);
	transition: box-shadow 0.25s ease, transform 0.25s ease;
}

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

.post-card .post-thumbnail img {
	width: 100%;
	height: 220px;
	object-fit: cover;
}

/* ==========================================================================
   Enkele post
   ========================================================================== */

.single-post-header {
	padding: 4rem 0 2rem;
	border-bottom: 1px solid rgba(0,0,0,0.07);
	margin-bottom: 2rem;
}

.post-meta {
	display: flex;
	gap: 1.5rem;
	align-items: center;
	font-size: 0.85rem;
	color: var(--gf-text-muted);
	margin-bottom: 1rem;
}

.post-meta a {
	color: var(--gf-primary);
}

.post-categories a {
	display: inline-block;
	background: var(--gf-primary);
	color: var(--gf-white);
	padding: 0.25em 0.75em;
	font-size: 0.75rem;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	margin-right: 0.5rem;
	transition: background-color 0.2s;
}

.post-categories a:hover {
	background: var(--gf-secondary);
	color: var(--gf-white);
}

/* ==========================================================================
   Navigatie / Paginering
   ========================================================================== */

.nav-links {
	display: flex;
	gap: 1rem;
	justify-content: space-between;
	margin: 3rem 0;
	padding: 1.5rem 0;
	border-top: 1px solid rgba(0,0,0,0.07);
}

.page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	border: 1px solid rgba(0,0,0,0.15);
	font-size: 0.9rem;
	font-weight: 600;
	color: var(--gf-text);
	transition: all 0.2s;
}

.page-numbers:hover,
.page-numbers.current {
	background: var(--gf-primary);
	border-color: var(--gf-primary);
	color: var(--gf-white);
}

/* ==========================================================================
   Formulieren
   ========================================================================== */

input[type="text"],
input[type="email"],
input[type="tel"],
input[type="url"],
input[type="search"],
input[type="number"],
input[type="password"],
textarea,
select {
	width: 100%;
	padding: 0.75em 1em;
	border: 1px solid rgba(0,0,0,0.2);
	border-radius: 0;
	background: var(--gf-white);
	font-family: var(--gf-font-body);
	font-size: 1rem;
	color: var(--gf-text);
	transition: border-color 0.2s;
	appearance: none;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="tel"]:focus,
textarea:focus,
select:focus {
	outline: none;
	border-color: var(--gf-primary);
	box-shadow: 0 0 0 3px rgba(74, 124, 89, 0.12);
}

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

label {
	display: block;
	font-weight: 600;
	margin-bottom: 0.4rem;
	font-size: 0.9rem;
	color: var(--gf-secondary);
}

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

.comments-area {
	margin-top: 4rem;
	padding-top: 3rem;
	border-top: 2px solid rgba(0,0,0,0.07);
}

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

.comment-body {
	display: grid;
	grid-template-columns: 60px 1fr;
	gap: 1.5rem;
	padding: 1.5rem 0;
	border-bottom: 1px solid rgba(0,0,0,0.07);
}

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

.comment-meta {
	font-size: 0.85rem;
	color: var(--gf-text-muted);
	margin-bottom: 0.5rem;
}

/* ==========================================================================
   WooCommerce basis
   ========================================================================== */

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit {
	background-color: var(--gf-primary) !important;
	color: var(--gf-white) !important;
	border-radius: 0 !important;
	padding: 0.85em 2.2em !important;
	font-family: var(--gf-font-body) !important;
	font-weight: 700 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	font-size: 0.9rem !important;
}

.woocommerce a.button:hover,
.woocommerce button.button:hover {
	background-color: var(--gf-secondary) !important;
}

/* ==========================================================================
   Utilities
   ========================================================================== */

.text-center { text-align: center; }
.text-left   { text-align: left; }
.text-right  { text-align: right; }

.text-primary  { color: var(--gf-primary); }
.text-secondary { color: var(--gf-secondary); }
.text-accent   { color: var(--gf-accent); }
.text-muted    { color: var(--gf-text-muted); }

.bg-primary   { background-color: var(--gf-primary); }
.bg-secondary { background-color: var(--gf-secondary); }
.bg-accent    { background-color: var(--gf-accent); }
.bg-light     { background-color: var(--gf-bg); }

.mt-0 { margin-top: 0; }
.mb-0 { margin-bottom: 0; }

/* Decoratieve streep */
.section-divider {
	width: 60px;
	height: 3px;
	background: var(--gf-accent);
	margin: 1rem 0 1.5rem;
}

.section-divider.centered {
	margin-left: auto;
	margin-right: auto;
}

/* Screen reader tekst */
.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;
	width: 1px;
	word-wrap: normal !important;
}

.screen-reader-text:focus {
	background-color: var(--gf-white);
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0,0,0,0.6);
	clip: auto !important;
	clip-path: none;
	color: var(--gf-text);
	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;
}
