/* ===== GoogleFontsChecker — Theme Tokens & Components ===== */

:root {
	/* Indigo/violet — bewusst unterschieden von Google-Brand-Blau (#4285F4). */
	--gfc-bg: #f5f5fa;
	--gfc-surface: #ffffff;
	--gfc-surface-alt: #ecebf5;
	--gfc-ink: #0f1320;
	--gfc-ink-soft: #2a2d44;
	--gfc-muted: #5b5d77;
	--gfc-line: #e3e2ee;

	--gfc-primary: #4338ca;       /* indigo-700 */
	--gfc-primary-deep: #3730a3;  /* indigo-800 */
	--gfc-primary-ink: #ffffff;
	--gfc-primary-soft: #ece9fe;  /* indigo-100 */

	--gfc-accent: #f59e0b;        /* amber-500 — distinctly non-Google */
	--gfc-accent-soft: #fef3c7;

	--gfc-danger: #b91c1c;
	--gfc-danger-soft: #fef2f2;
	--gfc-success: #047857;
	--gfc-success-soft: #ecfdf5;
	--gfc-warning: #b45309;

	--gfc-radius: 14px;
	--gfc-radius-sm: 10px;
	--gfc-shadow: 0 8px 28px rgba(15, 22, 32, .08);
	--gfc-shadow-sm: 0 2px 10px rgba(15, 22, 32, .06);

	--gfc-container: 1100px;
	--gfc-stack: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial,
		"Noto Sans", "Apple Color Emoji", "Segoe UI Emoji", sans-serif;
	--gfc-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
}

/* ===== Reset (light) ===== */
* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
[hidden] { display: none !important; }
body.gfc-root {
	margin: 0;
	background: var(--gfc-bg);
	color: var(--gfc-ink);
	font-family: var(--gfc-stack);
	font-size: 16px;
	line-height: 1.55;
	-webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: var(--gfc-primary); text-decoration: none; }
a:hover { text-decoration: underline; }
button { font: inherit; cursor: pointer; }

/* ===== Layout ===== */
.gfc-container { max-width: var(--gfc-container); margin: 0 auto; padding: 0 20px; }
.gfc-section { padding: 64px 0; }
.gfc-section-alt { background: var(--gfc-surface-alt); }

.gfc-skip {
	position: absolute; left: -9999px;
	background: var(--gfc-ink); color: #fff; padding: 8px 14px; border-radius: 8px;
}
.gfc-skip:focus { left: 12px; top: 12px; z-index: 100; }

.gfc-visually-hidden {
	position: absolute !important;
	width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden;
	clip: rect(0,0,0,0); white-space: nowrap; border: 0;
}

/* ===== Header ===== */
.gfc-header {
	position: sticky; top: 0; z-index: 30;
	background: rgba(255, 255, 255, .92);
	backdrop-filter: saturate(140%) blur(8px);
	border-bottom: 1px solid var(--gfc-line);
}
.gfc-header-inner {
	display: flex; align-items: center; justify-content: space-between;
	gap: 16px; padding: 14px 20px;
}
.gfc-logo {
	display: inline-flex; align-items: center; gap: 10px;
	color: var(--gfc-ink); font-size: 17px; letter-spacing: -.01em;
	text-decoration: none;
}
.gfc-logo:hover { text-decoration: none; }
.gfc-logo-mark {
	display: inline-flex; align-items: center; justify-content: center;
	width: 32px; height: 32px;
	background: linear-gradient(135deg, #4338ca, #7c3aed);
	color: #fff; border-radius: 9px;
}
.gfc-logo-text strong { font-weight: 800; }
.gfc-logo-tld { color: var(--gfc-muted); font-weight: 500; margin-left: 1px; }

.gfc-nav { display: flex; gap: 22px; }
.gfc-nav a { color: var(--gfc-ink-soft); font-weight: 500; font-size: 14.5px; }
.gfc-nav a:hover { color: var(--gfc-primary); text-decoration: none; }

/* ===== Burger + Mobile-Menü ===== */
.gfc-burger {
	display: none;
	background: transparent;
	border: 1px solid var(--gfc-line);
	border-radius: 8px;
	padding: 8px 10px;
	cursor: pointer;
	flex-direction: column;
	gap: 4px;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
}
.gfc-burger-bar {
	display: block;
	width: 18px;
	height: 2px;
	background: var(--gfc-ink);
	border-radius: 2px;
	transition: transform .2s ease, opacity .2s ease;
}
.gfc-burger[aria-expanded="true"] .gfc-burger-bar:nth-child(1) {
	transform: translateY(6px) rotate(45deg);
}
.gfc-burger[aria-expanded="true"] .gfc-burger-bar:nth-child(2) {
	opacity: 0;
}
.gfc-burger[aria-expanded="true"] .gfc-burger-bar:nth-child(3) {
	transform: translateY(-6px) rotate(-45deg);
}

.gfc-mobile-menu {
	display: none;
	background: var(--gfc-surface);
	border-top: 1px solid var(--gfc-line);
	box-shadow: 0 8px 24px rgba(15, 22, 32, .06);
}
.gfc-mobile-menu nav {
	display: flex;
	flex-direction: column;
	padding: 8px 20px 16px;
}
.gfc-mobile-menu nav a {
	display: block;
	padding: 14px 4px;
	color: var(--gfc-ink);
	font-weight: 500;
	font-size: 16px;
	border-bottom: 1px solid var(--gfc-line);
	text-decoration: none;
}
.gfc-mobile-menu nav a:last-child { border-bottom: 0; }
.gfc-mobile-menu nav a:hover { color: var(--gfc-primary); text-decoration: none; }
.gfc-mobile-menu-cta {
	margin-top: 8px;
	background: var(--gfc-primary);
	color: var(--gfc-primary-ink) !important;
	border-radius: 10px;
	text-align: center;
	padding: 14px 16px !important;
	font-weight: 600 !important;
}
.gfc-mobile-menu-cta:hover { background: var(--gfc-primary-deep); color: #fff !important; }
body.gfc-menu-open { overflow: hidden; }

@media (max-width: 720px) {
	.gfc-nav,
	.gfc-header .gfc-header-cta,
	a.gfc-header-cta { display: none !important; }
	.gfc-burger { display: flex !important; }
	.gfc-mobile-menu:not([hidden]) { display: block; }
}

/* ===== Buttons ===== */
.gfc-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 11px 18px;
	border-radius: 10px; border: 1px solid transparent;
	font-weight: 600; font-size: 15px; line-height: 1;
	transition: transform .08s ease, background .15s ease, border-color .15s ease;
	text-decoration: none;
}
.gfc-btn:active { transform: translateY(1px); }
.gfc-btn-primary {
	background: var(--gfc-primary); color: var(--gfc-primary-ink);
	border-color: var(--gfc-primary);
}
.gfc-btn-primary:hover { background: #3730a3; text-decoration: none; }
.gfc-btn-ghost {
	background: transparent; color: var(--gfc-primary); border-color: var(--gfc-primary);
}
.gfc-btn-ghost:hover { background: var(--gfc-primary-soft); text-decoration: none; }

/* ===== Hero ===== */
.gfc-hero {
	padding: 72px 0 48px;
	background:
		radial-gradient(70% 60% at 80% 0%, rgba(31, 78, 216, .14) 0%, transparent 60%),
		radial-gradient(80% 60% at 0% 100%, rgba(91, 108, 255, .12) 0%, transparent 60%),
		var(--gfc-surface);
	border-bottom: 1px solid var(--gfc-line);
}
.gfc-hero-pill {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 6px 12px; border-radius: 999px;
	background: var(--gfc-primary-soft); color: #3730a3;
	font-size: 13px; font-weight: 600;
	margin-bottom: 18px;
}
.gfc-hero-title {
	margin: 0; font-size: clamp(28px, 4.4vw, 46px);
	line-height: 1.12; letter-spacing: -.02em; font-weight: 800;
	color: var(--gfc-ink); max-width: 880px;
}
.gfc-hero-accent { color: var(--gfc-primary); }
.gfc-hero-sub {
	margin: 16px 0 28px; max-width: 720px;
	font-size: 17px; line-height: 1.55; color: var(--gfc-ink-soft);
}

.gfc-scan-form { max-width: 720px; }
.gfc-input-group {
	display: flex; align-items: center; gap: 8px;
	background: var(--gfc-surface);
	border: 1px solid var(--gfc-line);
	border-radius: 14px;
	padding: 8px 8px 8px 14px;
	box-shadow: var(--gfc-shadow);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.gfc-input-group:focus-within {
	border-color: var(--gfc-primary);
	box-shadow: 0 0 0 4px rgba(31, 78, 216, .14), var(--gfc-shadow);
}
.gfc-input-icon { color: var(--gfc-muted); display: inline-flex; }
.gfc-input-group input[type=url] {
	flex: 1; min-width: 0;
	border: 0; outline: 0; background: transparent;
	padding: 14px 6px;
	font-size: 16px; color: var(--gfc-ink);
	font-family: var(--gfc-mono);
}
.gfc-input-group .gfc-btn { flex-shrink: 0; }
.gfc-btn[disabled] { opacity: .65; cursor: progress; }

.gfc-hero-meta {
	margin: 14px 0 0;
	display: inline-flex; align-items: center; gap: 8px;
	color: var(--gfc-muted); font-size: 13.5px;
}

@media (max-width: 560px) {
	.gfc-input-group { padding: 6px; }
	.gfc-input-group input[type=url] { padding: 12px 6px; font-size: 15.5px; }
	.gfc-btn-label { display: none; }
	.gfc-input-group .gfc-btn { padding: 12px 14px; }
}

/* ===== Result card ===== */
.gfc-result { margin-top: 28px; }
.gfc-result-card {
	background: var(--gfc-surface);
	border: 1px solid var(--gfc-line);
	border-radius: var(--gfc-radius);
	padding: 24px;
	box-shadow: var(--gfc-shadow);
}
.gfc-result-card[data-status="critical"] {
	border-color: #f3bdb6;
	background: linear-gradient(180deg, #fff7f6 0%, #ffffff 60%);
}
.gfc-result-card[data-status="ok"] {
	border-color: #b8e2ca;
	background: linear-gradient(180deg, #f0fbf4 0%, #ffffff 60%);
}
.gfc-result-head {
	display: flex; align-items: center; gap: 14px;
	margin-bottom: 12px;
}
.gfc-badge {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 6px 12px; border-radius: 999px;
	font-weight: 700; font-size: 13.5px; letter-spacing: .01em;
}
.gfc-badge-critical { background: var(--gfc-danger); color: #fff; }
.gfc-badge-ok       { background: var(--gfc-success); color: #fff; }
.gfc-badge-error    { background: var(--gfc-warning); color: #fff; }
.gfc-result-host { font-weight: 700; font-size: 18px; color: var(--gfc-ink); word-break: break-all; }
.gfc-result-meta { color: var(--gfc-muted); font-size: 13px; margin-top: 2px; }
.gfc-result-summary { color: var(--gfc-ink-soft); font-size: 15.5px; margin: 6px 0 16px; }

.gfc-result-findings h3 { font-size: 15px; margin: 6px 0 8px; }
.gfc-result-findings ul {
	list-style: none; padding: 0; margin: 0;
	border: 1px solid var(--gfc-line); border-radius: var(--gfc-radius-sm);
	overflow: hidden; background: #fff;
}
.gfc-result-findings li {
	padding: 12px 14px; border-bottom: 1px solid var(--gfc-line);
}
.gfc-result-findings li:last-child { border-bottom: 0; }
.gfc-result-findings .gfc-find-msg { font-weight: 600; color: var(--gfc-ink); }
.gfc-result-findings .gfc-find-evidence {
	margin-top: 4px; font-family: var(--gfc-mono); font-size: 12.5px;
	color: var(--gfc-muted); word-break: break-all;
}
.gfc-result-findings .gfc-find-source {
	margin-top: 2px; font-size: 12px; color: #8a93a3;
}

.gfc-result-empty {
	display: flex; align-items: center; gap: 10px;
	background: #fff; border: 1px solid var(--gfc-line);
	border-radius: var(--gfc-radius-sm); padding: 14px 16px;
	color: var(--gfc-ink-soft); font-size: 14.5px;
}
.gfc-result-empty svg { color: var(--gfc-success); flex-shrink: 0; }

.gfc-result-actions {
	display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px;
}

/* ===== Extended scan ===== */
.gfc-extended-trigger {
	margin-top: 22px; padding: 16px 18px;
	border: 1px dashed var(--gfc-line);
	border-radius: var(--gfc-radius-sm);
	background: #fafafe;
}
.gfc-extended-pitch {
	margin: 0 0 12px; font-size: 14.5px; line-height: 1.55;
	color: var(--gfc-ink-soft);
}
.gfc-extended-pitch strong { color: var(--gfc-ink); }

.gfc-result-extended {
	margin-top: 22px; padding: 18px;
	border: 1px solid var(--gfc-line);
	border-radius: var(--gfc-radius-sm);
	background: #fff;
}
.gfc-result-extended h3 { font-size: 15px; margin: 0 0 6px; }
.gfc-ext-list {
	list-style: none; padding: 0; margin: 0;
}
.gfc-ext-cat {
	font-size: 11px; text-transform: uppercase; letter-spacing: .04em;
	color: var(--gfc-muted); font-weight: 600;
	margin: 14px 0 6px; padding: 0;
}
.gfc-ext-cat:first-child { margin-top: 0; }
.gfc-ext-finding {
	padding: 10px 12px; margin-bottom: 6px;
	border: 1px solid var(--gfc-line);
	border-radius: var(--gfc-radius-sm);
	background: #fff;
}
.gfc-ext-finding .gfc-find-msg { font-weight: 600; color: var(--gfc-ink); }
.gfc-ext-finding .gfc-find-why {
	margin-top: 3px; color: var(--gfc-ink-soft); font-size: 13px; line-height: 1.5;
}
.gfc-ext-finding .gfc-find-evidence {
	margin-top: 4px; font-family: var(--gfc-mono); font-size: 12px;
	color: var(--gfc-muted); word-break: break-all;
}

.gfc-ext-actions {
	margin-top: 18px; padding-top: 16px;
	border-top: 1px solid var(--gfc-line);
	display: flex; flex-direction: column; gap: 8px;
}
.gfc-ext-actions .gfc-btn-primary {
	align-self: flex-start;
}
.gfc-ext-cta-note {
	margin: 0; font-size: 13px; line-height: 1.5;
	color: var(--gfc-muted);
}

/* ===== Lead form ===== */
.gfc-lead-form {
	margin-top: 22px; padding: 18px;
	border: 1px dashed #c8d3eb;
	border-radius: var(--gfc-radius-sm);
	background: var(--gfc-primary-soft);
}
.gfc-lead-head { display: flex; gap: 12px; align-items: flex-start; }
.gfc-lead-head svg { color: var(--gfc-primary); flex-shrink: 0; margin-top: 2px; }
.gfc-lead-head strong { display: block; color: var(--gfc-ink); font-size: 16px; }
.gfc-lead-head p { margin: 4px 0 0; color: var(--gfc-ink-soft); font-size: 14px; }

.gfc-lead-row {
	display: flex; gap: 8px; margin-top: 14px;
}
.gfc-lead-row input[type=email] {
	flex: 1; min-width: 0;
	padding: 12px 14px; border: 1px solid var(--gfc-line);
	border-radius: 10px; background: #fff; font-size: 15px;
}
.gfc-lead-row input[type=email]:focus {
	outline: 0; border-color: var(--gfc-primary);
	box-shadow: 0 0 0 3px rgba(31, 78, 216, .15);
}

.gfc-honey {
	position: absolute; left: -9999px; opacity: 0;
	width: 1px; height: 1px; pointer-events: none;
}

.gfc-lead-consent {
	display: flex; gap: 8px; align-items: flex-start;
	margin-top: 12px; font-size: 13px; color: var(--gfc-ink-soft);
}
.gfc-lead-consent input { margin-top: 2px; }
.gfc-lead-legal {
	margin: 10px 0 0; font-size: 12px; color: var(--gfc-muted);
}
.gfc-lead-status {
	margin-top: 12px; padding: 10px 12px; border-radius: 8px; font-size: 14px;
}
.gfc-lead-status[data-kind="ok"] { background: var(--gfc-success-soft); color: var(--gfc-success); }
.gfc-lead-status[data-kind="err"] { background: var(--gfc-danger-soft); color: var(--gfc-danger); }

@media (max-width: 560px) {
	.gfc-lead-row { flex-direction: column; }
}

/* ===== Generic sections ===== */
.gfc-h2 {
	margin: 0 0 24px; font-size: clamp(24px, 3vw, 32px);
	letter-spacing: -.015em; font-weight: 800; color: var(--gfc-ink);
}
.gfc-eyebrow {
	font-size: 12.5px; font-weight: 700; letter-spacing: .08em;
	text-transform: uppercase; color: var(--gfc-primary); margin-bottom: 8px;
}
.gfc-lead { font-size: 17px; line-height: 1.55; color: var(--gfc-ink-soft); margin: 0 0 18px; }

.gfc-grid { display: grid; gap: 18px; }
.gfc-grid-3 { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 880px) { .gfc-grid-3 { grid-template-columns: 1fr; } }

.gfc-card {
	background: var(--gfc-surface);
	border: 1px solid var(--gfc-line);
	border-radius: var(--gfc-radius);
	padding: 22px;
	box-shadow: var(--gfc-shadow-sm);
}
.gfc-card h3 { margin: 8px 0 6px; font-size: 17px; }
.gfc-card p { margin: 0; color: var(--gfc-ink-soft); font-size: 14.5px; }
.gfc-step {
	display: inline-flex; align-items: center; justify-content: center;
	width: 30px; height: 30px;
	background: var(--gfc-primary-soft); color: var(--gfc-primary);
	border-radius: 8px; font-weight: 800;
}

.gfc-split {
	display: grid; grid-template-columns: 1.2fr 1fr; gap: 36px; align-items: center;
}
@media (max-width: 880px) { .gfc-split { grid-template-columns: 1fr; } }

.gfc-checks { list-style: none; padding: 0; margin: 0 0 22px; }
.gfc-checks li {
	display: flex; gap: 10px; align-items: flex-start;
	padding: 8px 0; color: var(--gfc-ink-soft); font-size: 15px;
}
.gfc-checks svg { color: var(--gfc-success); margin-top: 3px; flex-shrink: 0; }

.gfc-cta-row { display: flex; gap: 10px; flex-wrap: wrap; }

.gfc-quote {
	background: var(--gfc-surface);
	border: 1px solid var(--gfc-line);
	border-left: 4px solid var(--gfc-danger);
	border-radius: var(--gfc-radius);
	padding: 22px;
	box-shadow: var(--gfc-shadow-sm);
	display: grid; gap: 12px;
}
.gfc-quote svg { color: var(--gfc-danger); }
.gfc-quote blockquote {
	margin: 0; font-size: 16px; font-style: italic; color: var(--gfc-ink);
	line-height: 1.55;
}
.gfc-quote cite {
	font-style: normal; font-size: 13px; color: var(--gfc-muted);
}

/* ===== FAQ ===== */
#faq .gfc-h2 { text-align: center; }
.gfc-faq { display: grid; gap: 8px; max-width: 820px; margin-left: auto; margin-right: auto; }
.gfc-faq details {
	background: var(--gfc-surface);
	border: 1px solid var(--gfc-line);
	border-radius: var(--gfc-radius-sm);
	padding: 14px 18px;
	transition: border-color .15s ease;
}
.gfc-faq details[open] { border-color: var(--gfc-primary); }
.gfc-faq summary {
	cursor: pointer; font-weight: 600; color: var(--gfc-ink);
	list-style: none; display: flex; justify-content: space-between; gap: 12px;
	font-size: 15.5px;
}
.gfc-faq summary::-webkit-details-marker { display: none; }
.gfc-faq summary::after {
	content: "+"; font-weight: 600; color: var(--gfc-muted);
}
.gfc-faq details[open] summary::after { content: "−"; }
.gfc-faq p { margin: 10px 0 0; color: var(--gfc-ink-soft); font-size: 14.5px; line-height: 1.6; }

/* ===== Footer ===== */
.gfc-footer {
	background: var(--gfc-ink); color: #c5cbd5;
	padding: 48px 0 24px;
}
.gfc-footer .gfc-logo, .gfc-footer .gfc-logo-text { color: #fff; }
.gfc-footer .gfc-logo-tld { color: #8b94a3; }
.gfc-footer-inner {
	display: grid; grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
	gap: 28px; align-items: flex-start;
}
@media (max-width: 880px) { .gfc-footer-inner { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .gfc-footer-inner { grid-template-columns: 1fr; } }

.gfc-footer-col h4 { margin: 0 0 10px; font-size: 13px; letter-spacing: .08em;
	text-transform: uppercase; color: #8b94a3; font-weight: 700; }
.gfc-footer-col a { display: block; padding: 4px 0; color: #d2d8e2; font-size: 14.5px; }
.gfc-footer-col a:hover { color: #fff; }
.gfc-footer-col p { margin: 0; color: #c5cbd5; font-size: 14px; line-height: 1.55; }
.gfc-footer-bottom {
	display: flex; justify-content: space-between; align-items: center;
	margin-top: 28px; padding-top: 18px;
	border-top: 1px solid #2a3340;
	color: #8b94a3; font-size: 13px;
}
.gfc-muted { color: #8b94a3; }
.gfc-tiny { font-size: 12px; line-height: 1.5; }
.gfc-footer .gfc-muted { color: #8b94a3; }

/* ===== Prose pages ===== */
.gfc-prose { max-width: 760px; }
.gfc-prose h1 { font-size: clamp(28px, 4vw, 38px); letter-spacing: -.015em; }
.gfc-prose h2 { font-size: 22px; margin-top: 32px; }
.gfc-prose p, .gfc-prose li { color: var(--gfc-ink-soft); font-size: 15.5px; line-height: 1.65; }
.gfc-prose a:not(.gfc-btn) { color: var(--gfc-primary); }
.gfc-prose .gfc-btn-primary { color: var(--gfc-primary-ink); text-decoration: none; }
.gfc-prose .gfc-btn-ghost   { color: var(--gfc-primary); text-decoration: none; }

/* ===== Trademark ribbon ===== */
.gfc-ribbon {
	background: #0f1320;
	color: #d2d4e8;
	font-size: 12.5px;
	line-height: 1.45;
}
.gfc-ribbon-inner {
	display: flex; align-items: flex-start; gap: 8px;
	padding: 8px 20px; flex-wrap: nowrap;
}
.gfc-ribbon svg {
	color: var(--gfc-accent);
	flex-shrink: 0;
	margin-top: 3px;
}
.gfc-ribbon strong { color: #ffffff; }
.gfc-ribbon a { color: #c4b5fd; }

/* ===== Trust bar (hero icons) ===== */
.gfc-trust {
	list-style: none; padding: 0; margin: 28px 0 0;
	display: flex; flex-wrap: wrap; gap: 18px;
	color: var(--gfc-muted); font-size: 13.5px;
}
.gfc-trust li { display: inline-flex; align-items: center; gap: 6px; }
.gfc-trust svg { color: var(--gfc-success); }

/* ===== Breadcrumbs ===== */
.gfc-breadcrumb {
	font-size: 13px; color: var(--gfc-muted);
	display: flex; gap: 8px; align-items: center;
	margin-bottom: 18px;
}
.gfc-breadcrumb a { color: var(--gfc-muted); text-decoration: none; }
.gfc-breadcrumb a:hover { color: var(--gfc-primary); text-decoration: underline; }
.gfc-breadcrumb span[aria-hidden] { color: var(--gfc-line); }

/* ===== Steps as ordered list (semantic) ===== */
.gfc-steps { list-style: none; padding: 0; }

.gfc-card-feature h3 { margin-top: 0; font-size: 16px; }
.gfc-prose-list { margin: 8px 0 0; padding-left: 18px; color: var(--gfc-ink-soft); font-size: 14.5px; line-height: 1.6; }
.gfc-prose-list li { margin-bottom: 6px; }

/* ===== Wider prose for SEO long-form ===== */
.gfc-prose-wide { max-width: 880px; }
.gfc-prose-wide h3 { font-size: 19px; margin: 28px 0 8px; color: var(--gfc-ink); }
.gfc-lead-narrow { max-width: 720px; margin: 0 0 28px; }

/* ===== Footer disclaimer block ===== */
.gfc-footer-disclaimer {
	margin-top: 36px;
	padding-top: 22px;
	border-top: 1px solid #2a2d44;
	color: #8b8db0;
	font-size: 12.5px;
	line-height: 1.55;
}
.gfc-footer-disclaimer p { margin: 0 0 8px; }
.gfc-footer-disclaimer strong { color: #d2d4e8; }

/* ===== Blog ===== */
.gfc-archive-title { font-size: clamp(28px, 4vw, 38px); margin: 0 0 6px; letter-spacing: -.015em; }
.gfc-archive-sub { color: var(--gfc-muted); margin: 0 0 32px; font-size: 16px; }

.gfc-post-list {
	list-style: none; padding: 0; margin: 0;
	display: grid; gap: 22px;
	grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 760px) { .gfc-post-list { grid-template-columns: 1fr; } }

.gfc-post-card {
	background: var(--gfc-surface);
	border: 1px solid var(--gfc-line);
	border-radius: var(--gfc-radius);
	padding: 22px;
	transition: border-color .15s ease, transform .15s ease;
	display: flex;
	flex-direction: column;
}
.gfc-post-card:hover { border-color: var(--gfc-primary); transform: translateY(-2px); }
.gfc-post-card h2 { margin: 0 0 6px; font-size: 19px; line-height: 1.3; }
.gfc-post-card h2 a { color: var(--gfc-ink); text-decoration: none; }
.gfc-post-card h2 a:hover { color: var(--gfc-primary); }
.gfc-post-card p { margin: 0 0 12px; color: var(--gfc-ink-soft); font-size: 14.5px; line-height: 1.55; }
/* Button immer am unteren Rand der Card — auch bei kurzem Excerpt. */
.gfc-post-card > .gfc-btn { margin-top: auto; align-self: flex-start; }
.gfc-post-meta { color: var(--gfc-muted); font-size: 12.5px; }

.gfc-single-meta {
	color: var(--gfc-muted); font-size: 13.5px;
	display: flex; gap: 12px; margin: 0 0 24px;
	border-bottom: 1px solid var(--gfc-line); padding-bottom: 18px;
}

.gfc-single-cta {
	margin-top: 36px; padding: 24px;
	background: var(--gfc-primary-soft);
	border-left: 4px solid var(--gfc-primary);
	border-radius: var(--gfc-radius-sm);
}
.gfc-single-cta h3 { margin: 0 0 6px; color: var(--gfc-primary-deep); }
.gfc-single-cta p { margin: 0 0 12px; color: var(--gfc-ink-soft); }

/* ===== Reduced motion ===== */
@media (prefers-reduced-motion: reduce) {
	* { transition: none !important; animation: none !important; }
}
