/* ============================================================
   Freebie-Landingpage (at-freebie) – /sehstaerke-selber-messen/
   ============================================================ */

/* Überschriften-Schrift wie online (Blocksy lieferte Merriweather), jetzt SELBST GEHOSTET
   statt Google-CDN (0 externe Requests). Bewusst nur normal 700+900 (variabler Faces-Bereich),
   damit die "300 italic"-Hervorhebung (__hl) wie online aus dem 700er faux-kursiviert wird. */
@font-face{font-family:'Merriweather';font-style:normal;font-weight:700 900;font-display:swap;src:url('/assets/fonts/merriweather-normal-latin-ext.woff2') format('woff2');unicode-range:U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF}
@font-face{font-family:'Merriweather';font-style:normal;font-weight:700 900;font-display:swap;src:url('/assets/fonts/merriweather-normal-latin.woff2') format('woff2');unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD}

/* Header hell einfärben, solange er transparent über dem dunklen Hero liegt.
   body.at-freebie-page wird in functions.php per body_class-Filter gesetzt (inhalts-
   basiert erkannt, unabhängig von Page-ID/Slug).
   Blocksy: data-sticky="fixed…" = transparent oben, "yes…" = weiß nach Scroll. */
body.at-freebie-page #header [data-sticky^="fixed"] a {
	color: #fff !important;
}

body.at-freebie-page #header [data-sticky^="fixed"] {
	--linkInitialColor: #fff;
	--linkHoverColor: #5fd2b4;
}

body.at-freebie-page #header [data-sticky^="fixed"] .site-branding img {
	filter: invert(1);
}

body.at-freebie-page #header [data-sticky^="fixed"] svg {
	fill: currentColor;
}

body.at-freebie-page #header [data-sticky^="fixed"] .ct-header-search.ct-toggle {
	--theme-icon-color: #fff;
	--theme-icon-hover-color: #5fd2b4;
	color: #fff;
}

.at-freebie,
.at-freebie * {
	box-sizing: border-box;
}

.at-freebie {
	--freebie-navy: #0f1f3a;
	--freebie-navy-2: #1c365f;
	--freebie-deep: #0a1730;
	--freebie-mint: #5fd2b4;
	--freebie-mint-dark: #2f9c81;
	--freebie-ice: #eaf4f2;
	--freebie-ink: #16243a;
	--freebie-muted: #5a6b86;
	--freebie-line: #dbe4ec;
	--freebie-maxw: 1120px;
	--freebie-pad: 22px;
	color: var(--freebie-ink);
	overflow-x: clip;
}

.entry-content > .at-freebie {
	width: 100% !important;
	max-width: none !important;
	margin: 0 !important;
}

.at-freebie h1,
.at-freebie h2,
.at-freebie h3 {
	font-family: "Merriweather", serif;
	letter-spacing: -0.4px;
	border-bottom: 0 !important;
	padding-bottom: 0 !important;
	margin: 0;
}

.at-freebie .at-freebie__hl {
	font-family: "Merriweather", serif;
	font-style: italic;
	font-weight: 300;
	letter-spacing: 0;
}

.at-freebie p {
	margin: 0 0 5px 0;
}

/* ---------- Hero ---------- */

.at-freebie__hero {
	position: relative;
	width: 100vw;
	margin-left: calc(50% - 50vw);
	background:
		radial-gradient(900px 480px at 78% -10%, rgba(95, 210, 180, 0.16), transparent 60%),
		radial-gradient(700px 420px at 12% 110%, rgba(40, 90, 150, 0.35), transparent 65%),
		linear-gradient(160deg, var(--freebie-navy-2) 0%, var(--freebie-navy) 45%, var(--freebie-deep) 100%);
	overflow: clip;
}

.at-freebie__hero-deco {
	position: absolute;
	top: 40px;
	right: max(18px, calc((100vw - var(--freebie-maxw)) / 2 - 70px));
	text-align: right;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.05);
	line-height: 1.18;
	letter-spacing: 0.3em;
	user-select: none;
	pointer-events: none;
}

.at-freebie__hero-deco span {
	display: block;
}

.at-freebie__hero-deco span:nth-child(1) { font-size: 58px; }
.at-freebie__hero-deco span:nth-child(2) { font-size: 44px; }
.at-freebie__hero-deco span:nth-child(3) { font-size: 33px; }
.at-freebie__hero-deco span:nth-child(4) { font-size: 25px; }
.at-freebie__hero-deco span:nth-child(5) { font-size: 18px; }

.at-freebie__hero-inner {
	position: relative;
	z-index: 1;
	width: min(var(--freebie-maxw), calc(100% - 2 * var(--freebie-pad)));
	margin: 0 auto;
	padding: clamp(28px, 4vw, 52px) 0 clamp(56px, 7vw, 96px);
	display: grid;
	grid-template-columns: minmax(0, 1.04fr) minmax(0, 0.96fr);
	gap: clamp(28px, 5vw, 64px);
	align-items: center;
}

.at-freebie__hero-copy > * {
	animation: at-freebie-rise 0.7s cubic-bezier(0.22, 0.8, 0.3, 1) both;
}

.at-freebie__hero-copy > *:nth-child(2) { animation-delay: 0.07s; }
.at-freebie__hero-copy > *:nth-child(3) { animation-delay: 0.14s; }
.at-freebie__hero-copy > *:nth-child(4) { animation-delay: 0.21s; }
.at-freebie__hero-copy > *:nth-child(5) { animation-delay: 0.28s; }

@keyframes at-freebie-rise {
	from {
		opacity: 0;
		transform: translateY(16px);
	}
	to {
		opacity: 1;
		transform: none;
	}
}

.at-freebie__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	padding: 7px 14px;
	border: 1px solid rgba(95, 210, 180, 0.35);
	border-radius: 999px;
	background: rgba(95, 210, 180, 0.08);
	color: var(--freebie-mint);
	font-size: 12.5px;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.at-freebie__eyebrow-dot {
	width: 7px;
	height: 7px;
	border-radius: 50%;
	background: var(--freebie-mint);
	box-shadow: 0 0 0 4px rgba(95, 210, 180, 0.18);
}

svg.at-freebie__eyebrow-icon {
	width: 15px;
	height: 15px;
	flex: none;
}

.at-freebie__hero h1 {
	margin-top: 18px;
	color: #fff;
	font-size: clamp(2.3rem, 4.6vw, 3.55rem);
	font-weight: 800;
	line-height: 1.06;
}

.at-freebie p.at-freebie__lead {
	margin-top: 26px;
	color: rgba(255, 255, 255, 0.84);
	font-size: clamp(1.02rem, 1.4vw, 1.15rem);
	line-height: 1.65;
	max-width: 34em;
}

.at-freebie__benefits {
	list-style: none;
	margin: 22px 0 0;
	padding: 0;
	display: grid;
	gap: 10px;
}

.at-freebie__benefits li {
	display: flex;
	align-items: baseline;
	gap: 11px;
	color: rgba(255, 255, 255, 0.92);
	font-size: 15.5px;
	line-height: 1.5;
}

.at-freebie__benefits svg {
	flex: 0 0 17px;
	width: 17px;
	height: 17px;
	transform: translateY(2px);
	color: var(--freebie-mint);
}

/* ---------- Formular-Karte ---------- */

.at-freebie__form-card {
	margin-top: 28px;
	background: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: 12px;
	padding: 22px;
	backdrop-filter: blur(8px);
	scroll-margin-top: 110px;
}

.at-freebie p.at-freebie__form-title {
	font-weight: 700;
	font-size: 15.5px;
	color: #fff;
	margin: 2px 0 18px;
}

.at-freebie__form {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

.at-freebie input.at-freebie__input {
	flex: 1 1 calc(50% - 5px);
	min-width: 0;
	padding: 13px 16px;
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 4px;
	font-size: 15.5px;
	color: var(--freebie-ink);
	background: #fff;
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.at-freebie input.at-freebie__input:focus {
	outline: none;
	border-color: var(--freebie-mint);
	box-shadow: 0 0 0 3px rgba(95, 210, 180, 0.3);
}

.at-freebie input.at-freebie__input[name="firstname"] {
	flex: 1 1 35%;
}

.at-freebie input.at-freebie__input[name="email"] {
	flex: 2 1 50%;
}

.at-freebie button.at-freebie__btn {
	flex: 1 1 100%;
	padding: 13px 22px;
	border: 0;
	border-radius: 4px;
	background: var(--freebie-mint);
	color: var(--freebie-navy);
	font-size: 15.5px;
	font-weight: 700;
	cursor: pointer;
	white-space: nowrap;
	transition: background 0.15s ease;
}

.at-freebie button.at-freebie__btn:hover {
	background: #4cc7a8;
}

.at-freebie p.at-freebie__consent {
	margin: 16px 2px 2px;
	font-size: 12.5px;
	line-height: 1.5;
	color: rgba(255, 255, 255, 0.6);
}

/* ---------- Mockup-Bühne ---------- */

.at-freebie__stage {
	position: relative;
	min-height: 470px;
	perspective: 1300px;
}

.at-freebie__stage-glow {
	position: absolute;
	inset: 12% 6% 8%;
	background: radial-gradient(closest-side, rgba(95, 210, 180, 0.22), transparent 70%);
	filter: blur(8px);
}

.at-freebie__cover,
.at-freebie__page {
	position: absolute;
	border-radius: 10px;
	overflow: hidden;
}

.at-freebie__cover img,
.at-freebie__page img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: inherit;
}

.at-freebie__cover {
	width: min(340px, 66%);
	left: 50%;
	top: 50%;
	transform: translate(-50%, -51%) rotateY(-9deg) rotateX(2deg);
	box-shadow:
		0 50px 90px rgba(3, 10, 25, 0.62),
		0 14px 30px rgba(3, 10, 25, 0.4);
	outline: 1px solid rgba(255, 255, 255, 0.12);
	animation: at-freebie-float 7s ease-in-out infinite alternate;
}

.at-freebie__page {
	width: min(205px, 42%);
	background: #fff;
	box-shadow: 0 26px 50px rgba(3, 10, 25, 0.45);
	outline: 1px solid rgba(255, 255, 255, 0.25);
}

.at-freebie__page--left {
	left: -1%;
	top: 16%;
	transform: rotate(-9deg);
	animation: at-freebie-float 8s ease-in-out 0.6s infinite alternate;
}

.at-freebie__page--right {
	right: -1%;
	top: 30%;
	transform: rotate(8deg);
	animation: at-freebie-float 8.5s ease-in-out 1.1s infinite alternate;
}

@keyframes at-freebie-float {
	from {
		translate: 0 -5px;
	}
	to {
		translate: 0 6px;
	}
}

.at-freebie__badge {
	position: absolute;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: #fff;
	color: var(--freebie-ink);
	font-size: 13.5px;
	font-weight: 700;
	padding: 10px 14px;
	border-radius: 999px;
	box-shadow: 0 16px 36px rgba(3, 10, 25, 0.4);
}

.at-freebie__badge svg {
	width: 17px;
	height: 17px;
	color: var(--freebie-mint-dark);
}

.at-freebie__badge--pages {
	left: 5%;
	bottom: 6%;
	animation: at-freebie-float 7.5s ease-in-out 0.9s infinite alternate;
}

.at-freebie__badge--free {
	right: 2%;
	top: 7%;
	animation: at-freebie-float 8s ease-in-out 0.3s infinite alternate;
}

.at-freebie__badge--chart {
	left: 0;
	top: 2%;
	animation: at-freebie-float 9s ease-in-out 1.4s infinite alternate;
}

.at-freebie__badge svg.at-freebie__chart {
	width: 112px;
	height: 52px;
	margin-bottom: 3px;
	color: inherit;
}

.at-freebie__badge-strong {
	max-width: 150px;
	font-size: 12.5px;
	font-weight: 700;
	line-height: 1.3;
	white-space: normal;
}

/* ---------- Fakten-Leiste ---------- */

.at-freebie__facts {
	position: relative;
	z-index: 2;
	width: min(var(--freebie-maxw), calc(100% - 2 * var(--freebie-pad)));
	margin: -30px auto 0;
}

.at-freebie__facts ul {
	list-style: none;
	margin: 0;
	padding: 18px 26px;
	background: #fff;
	border: 1px solid var(--freebie-line);
	border-radius: 16px;
	box-shadow: 0 18px 44px rgba(15, 31, 58, 0.1);
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 12px 26px;
}

.at-freebie__facts li {
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-size: 14.5px;
	font-weight: 650;
	color: var(--freebie-ink);
}

.at-freebie__facts svg {
	width: 19px;
	height: 19px;
	color: var(--freebie-mint-dark);
}

/* ---------- Sektionen allgemein ---------- */

.at-freebie__section {
	width: min(var(--freebie-maxw), calc(100% - 2 * var(--freebie-pad)));
	margin: 0 auto;
	padding: clamp(52px, 7vw, 84px) 0 0;
}

.at-freebie p.at-freebie__kicker {
	color: var(--freebie-mint-dark);
	font-size: 12.5px;
	font-weight: 800;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	margin: 0 0 10px;
}

.at-freebie__section h2 {
	font-size: clamp(1.65rem, 3vw, 2.3rem);
	font-weight: 800;
	line-height: 1.15;
	color: var(--freebie-ink);
}


.at-freebie__section-head {
	text-align: center;
	max-width: 720px;
	margin: 0 auto;
}

.at-freebie p.at-freebie__section-sub {
	margin-top: 14px;
	color: var(--freebie-muted);
	font-size: 16.5px;
	line-height: 1.7;
}

/* ---------- Schritte ---------- */

.at-freebie__steps {
	margin-top: 40px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.at-freebie__step {
	background: #fff;
	border: 1px solid var(--freebie-line);
	border-radius: 16px;
	overflow: hidden;
	box-shadow: 0 10px 26px rgba(15, 31, 58, 0.06);
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

.at-freebie__step:hover {
	transform: translateY(-4px);
	box-shadow: 0 20px 44px rgba(15, 31, 58, 0.12);
}

.at-freebie__step-preview {
	position: relative;
	background: linear-gradient(180deg, var(--freebie-ice), #f6fbfa);
	padding: 20px 22px 0;
	height: 216px;
	overflow: hidden;
}

.at-freebie__step-preview img {
	display: block;
	width: 100%;
	height: auto;
	border-radius: 8px 8px 0 0;
	box-shadow: 0 10px 30px rgba(15, 31, 58, 0.18);
	outline: 1px solid rgba(15, 31, 58, 0.08);
}

.at-freebie__step h3 {
	font-size: 18px;
	font-weight: 750;
	padding: 18px 20px 0;
}

.at-freebie__step p {
	padding: 8px 20px 22px;
	color: var(--freebie-muted);
	font-size: 15px;
	line-height: 1.65;
}

/* ---------- Für wen ---------- */

.at-freebie__who-grid {
	background: var(--freebie-ice);
	border-radius: 22px;
	padding: clamp(28px, 4.5vw, 52px);
	display: grid;
	grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
	gap: clamp(24px, 4vw, 48px);
}

.at-freebie__who .at-freebie__section-head {
	text-align: left;
	margin: 0;
}

.at-freebie__who-copy h2 {
	font-size: clamp(1.55rem, 2.7vw, 2.1rem);
}

.at-freebie__who-copy .at-freebie__section-sub {
	font-size: 15.5px;
}

.at-freebie__who-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 10px;
}

.at-freebie__who-list li {
	display: flex;
	align-items: baseline;
	gap: 12px;
	background: #fff;
	border-radius: 12px;
	padding: 13px 16px;
	font-size: 15px;
	line-height: 1.5;
	color: var(--freebie-ink);
	box-shadow: 0 4px 14px rgba(15, 31, 58, 0.05);
}

.at-freebie__who-list svg {
	flex: 0 0 16px;
	width: 16px;
	height: 16px;
	transform: translateY(2px);
	color: var(--freebie-mint-dark);
}

/* ---------- Kontrast ---------- */

.at-freebie__contrast-grid {
	margin-top: 38px;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 22px;
	align-items: stretch;
}

.at-freebie__contrast-card {
	border-radius: 18px;
	padding: 28px 28px 24px;
}

.at-freebie__contrast-card--no {
	background: #fff;
	border: 1px solid var(--freebie-line);
}

.at-freebie__contrast-card--yes {
	background:
		radial-gradient(420px 240px at 90% -20%, rgba(95, 210, 180, 0.25), transparent 70%),
		linear-gradient(155deg, var(--freebie-navy-2), var(--freebie-navy));
	color: #fff;
	box-shadow: 0 22px 50px rgba(15, 31, 58, 0.3);
}

.at-freebie p.at-freebie__contrast-title {
	font-size: 18px;
	font-weight: 750;
	margin: 0 0 6px;
}

.at-freebie__contrast-card--no .at-freebie__contrast-title {
	color: var(--freebie-muted);
}

.at-freebie p.at-freebie__contrast-desc {
	font-size: 15px;
	line-height: 1.55;
	margin: 0 0 18px;
}

.at-freebie__contrast-card--no .at-freebie__contrast-desc {
	color: var(--freebie-muted);
}

.at-freebie__contrast-card--yes .at-freebie__contrast-desc {
	color: rgba(255, 255, 255, 0.78);
}

.at-freebie__contrast-card ul {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 11px;
}

.at-freebie__contrast-card li {
	position: relative;
	padding-left: 28px;
	font-size: 15px;
	line-height: 1.55;
}

.at-freebie__contrast-card--no li {
	color: var(--freebie-muted);
}

.at-freebie__contrast-card--no li::before {
	content: "✕";
	position: absolute;
	left: 2px;
	top: 0;
	color: #c2553f;
	font-size: 13px;
	font-weight: 800;
}

.at-freebie__contrast-card--yes li {
	color: rgba(255, 255, 255, 0.92);
}

.at-freebie__contrast-card--yes li::before {
	content: "✓";
	position: absolute;
	left: 0;
	top: 0;
	color: var(--freebie-mint);
	font-size: 15px;
	font-weight: 800;
}

/* ---------- Finaler CTA ---------- */

.at-freebie__final {
	width: 100vw;
	margin: clamp(56px, 8vw, 92px) calc(50% - 50vw) 0;
	background:
		radial-gradient(760px 420px at 14% -20%, rgba(95, 210, 180, 0.18), transparent 65%),
		linear-gradient(150deg, var(--freebie-navy-2) 0%, var(--freebie-navy) 50%, var(--freebie-deep) 100%);
}

.at-freebie__final-inner {
	width: min(var(--freebie-maxw), calc(100% - 2 * var(--freebie-pad)));
	margin: 0 auto;
	padding: clamp(48px, 6vw, 76px) 0;
	display: grid;
	grid-template-columns: minmax(0, 0.42fr) minmax(0, 0.58fr);
	gap: clamp(28px, 5vw, 60px);
	align-items: center;
}

.at-freebie__final-book {
	position: relative;
	width: min(300px, 88%);
	margin: 0 auto;
}

.at-freebie__final-book img {
	display: block;
	width: 100%;
	border-radius: 10px;
}

.at-freebie__final-cover {
	position: relative;
	z-index: 1;
	transform: rotate(-3deg);
	box-shadow: 0 36px 70px rgba(3, 10, 25, 0.55);
	outline: 1px solid rgba(255, 255, 255, 0.14);
	transition: transform 0.55s cubic-bezier(0.22, 1, 0.36, 1);
}

.at-freebie__final-page {
	position: absolute;
	width: 86%;
	background: #fff;
	box-shadow: 0 22px 44px rgba(3, 10, 25, 0.45);
	outline: 1px solid rgba(255, 255, 255, 0.2);
	transform: rotate(-3deg);
	opacity: 0;
	transition:
		transform 0.6s cubic-bezier(0.22, 1, 0.36, 1) 0.05s,
		opacity 0.35s ease 0.05s;
}

/* Ausklapp-Animation nur auf Geräten mit echtem Mauszeiger. Auf Touch würde der
   :hover-Zustand beim Antippen hängenbleiben und die herausragenden Seiten würden
   den Viewport scrollbar machen. */
@media (hover: hover) {
	.at-freebie__final:hover .at-freebie__final-page {
		opacity: 1;
	}

	.at-freebie__final:hover .at-freebie__final-cover {
		transform: rotate(-4deg) translateX(-14px) translateY(-8px);
	}

	.at-freebie__final:hover .at-freebie__final-page--left {
		transform: translateX(-46%) translateY(5%) rotate(-12deg);
	}

	.at-freebie__final:hover .at-freebie__final-page--right {
		transform: translateX(18%) translateY(-7%) rotate(9deg);
	}
}

.at-freebie__final-copy {
	position: relative;
	z-index: 2;
}

@media (prefers-reduced-motion: reduce) {
	.at-freebie__final-cover,
	.at-freebie__final-page {
		transition: none;
	}
}

.at-freebie__final-copy h2 {
	color: #fff;
	font-size: clamp(1.7rem, 3vw, 2.3rem);
	font-weight: 800;
	line-height: 1.12;
}

.at-freebie__final-copy > p {
	margin-top: 14px;
	color: rgba(255, 255, 255, 0.84);
	font-size: 16.5px;
	line-height: 1.65;
	max-width: 34em;
}

.at-freebie__final .at-freebie__form-card {
	margin-top: 24px;
}

/* ---------- Hinweis ---------- */

/* ---------- Gut zu wissen & FAQ ---------- */

.at-freebie__wissen-grid {
	margin-top: 38px;
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 30px 40px;
}

.at-freebie__wissen-grid h3 {
	font-size: 19px;
	font-weight: 750;
	margin: 0 0 10px;
}

.at-freebie .at-freebie__wissen-grid p {
	color: var(--freebie-muted);
	font-size: 15.5px;
	line-height: 1.7;
	margin: 0;
}

/* ---------- Werkzeug-Übersicht (grafisch) ---------- */

.at-freebie__tools-grid {
	margin-top: 38px;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.at-freebie__tool {
	display: flex;
	flex-direction: column;
	padding: 20px 22px;
	background: #fff;
	border: 1px solid var(--freebie-line);
	border-radius: 16px;
}

.at-freebie__tool--feature {
	grid-column: 1 / -1;
	flex-direction: row;
	align-items: center;
	gap: 24px;
}

.at-freebie__tool--feature .at-freebie__tool-head {
	margin-bottom: 0;
	flex: 0 0 auto;
}

.at-freebie .at-freebie__tool--feature p {
	flex: 1 1 auto;
}

.at-freebie__tool-head {
	display: flex;
	align-items: center;
	gap: 12px;
	margin-bottom: 8px;
}

.at-freebie__tool-ico {
	flex: 0 0 auto;
	display: inline-flex;
	color: var(--freebie-mint-dark);
}

.at-freebie__tool-ico svg {
	width: 30px;
	height: 30px;
}

.at-freebie__tool h3 {
	font-size: 17px;
	font-weight: 750;
	margin: 0;
}

.at-freebie .at-freebie__tool p {
	color: var(--freebie-muted);
	font-size: 14.5px;
	line-height: 1.6;
	margin: 0;
}

/* FAQ-Accordion: Struktur-Basis 1:1 aus dem WP-Theme (blocksy-child content-blocks.css).
   --at-*-Tokens auf die Freebie-Palette gemappt; die .at-freebie-Overrides weiter unten
   verfeinern die Farben (höhere Spezifität). Collapse via max-height, Toggle via .is-open. */
.at-freebie {
	--at-radius: 12px;
	--at-radius-small: 10px;
	--at-surface: #fff;
	--at-soft-surface: transparent;
	--at-border-soft: var(--freebie-line);
	--at-text: var(--freebie-ink);
	--at-muted: var(--freebie-muted);
	--at-accent: var(--freebie-mint-dark);
}

.at-faq__list {
	display: grid;
	gap: 12px;
}

.at-faq__item {
	overflow: hidden;
	border: 1px solid var(--at-border-soft);
	border-radius: var(--at-radius-small);
	background: var(--at-surface);
	box-shadow: 0 10px 28px color-mix(in srgb, var(--at-text) 5%, transparent);
}

.at-faq__question {
	display: grid;
	grid-template-columns: 1fr auto;
	align-items: center;
	width: 100%;
	padding: 18px 20px;
	gap: 16px;
	appearance: none;
	border: 0;
	background: transparent;
	color: var(--at-text);
	cursor: pointer;
	font: inherit;
	font-size: 18px;
	font-weight: 700;
	line-height: 1.35;
	text-align: left;
}

.at-faq__question:focus-visible {
	outline: 2px solid var(--at-accent);
	outline-offset: -4px;
}

.at-faq__toggle {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 30px;
	height: 30px;
	border-radius: 50%;
	background: color-mix(in srgb, var(--at-accent) 12%, var(--at-surface));
	color: var(--at-accent);
	transition: background 0.18s ease, color 0.18s ease;
}

.at-faq__toggle::before,
.at-faq__toggle::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	width: 12px;
	height: 2px;
	border-radius: 2px;
	background: currentColor;
	transform: translate(-50%, -50%);
}

.at-faq__toggle::after {
	transform: translate(-50%, -50%) rotate(90deg);
	transition: opacity 0.18s ease;
}

.at-faq__item.is-open .at-faq__question {
	padding-bottom: 10px;
}

.at-faq__item.is-open .at-faq__toggle {
	background: var(--at-accent);
	color: var(--at-surface);
}

.at-faq__item.is-open .at-faq__toggle::after {
	opacity: 0;
}

.at-faq__answer {
	overflow: hidden;
	max-height: 0;
	padding: 0 20px;
	color: var(--at-muted);
	font-size: 15px;
	line-height: 1.65;
	transition: max-height 0.3s ease, padding-bottom 0.3s ease;
}

.at-faq__item.is-open .at-faq__answer {
	max-height: 520px;
	padding-bottom: 19px;
}

.at-faq__answer p {
	margin: 0;
}

@media (prefers-reduced-motion: reduce) {
	.at-faq__answer,
	.at-faq__toggle,
	.at-faq__toggle::after {
		transition: none;
	}
}

.at-freebie .at-faq {
	margin: 34px 0 0;
	padding: 0;
	background: transparent;
	border-radius: 0;
}

.at-freebie .at-faq__inner {
	max-width: 820px;
	margin: 0 auto;
}

.at-freebie .at-faq__item {
	border-color: var(--freebie-line);
	box-shadow: 0 10px 28px rgba(15, 31, 58, 0.05);
}

.at-freebie .at-faq__question {
	color: var(--freebie-ink);
	font-size: 17px;
}

.at-freebie .at-faq__toggle {
	background: rgba(95, 210, 180, 0.16);
	color: var(--freebie-mint-dark);
}

.at-freebie .at-faq__item.is-open .at-faq__toggle {
	background: var(--freebie-mint);
	color: var(--freebie-navy);
}

.at-freebie .at-faq__answer {
	color: var(--freebie-muted);
}

.at-freebie__note {
	width: min(760px, calc(100% - 2 * var(--freebie-pad)));
	margin: 0 auto;
	padding: clamp(36px, 5vw, 56px) 0 clamp(56px, 7vw, 84px);
}

.at-freebie__note p {
	color: var(--freebie-muted);
	font-size: 13.5px;
	line-height: 1.7;
	text-align: left;
}

.at-freebie__note strong {
	color: var(--freebie-ink);
}

/* ---------- Toolbox-Variante ---------- */

.at-freebie--toolbox .at-freebie__cover {
	background: #fff;
}

.at-freebie--toolbox .at-freebie__step-preview img {
	max-width: 78%;
	margin: 0 auto;
}

.at-freebie--toolbox .at-freebie__step:nth-child(3) .at-freebie__step-preview img {
	max-width: 92%;
}

.at-freebie--toolbox .at-freebie__final-cover {
	background: #fff;
}

/* ---------- Sticky CTA (mobil) ---------- */

.at-freebie__sticky-cta {
	display: none;
}

/* ---------- Responsive ---------- */

@media (max-width: 980px) {
	.at-freebie__hero-inner {
		grid-template-columns: 1fr;
		padding-bottom: 64px;
	}

	.at-freebie__hero-deco {
		display: none;
	}

	.at-freebie__stage {
		min-height: 430px;
		max-width: 520px;
		margin: 8px auto 0;
		width: 100%;
	}

	.at-freebie__who-grid,
	.at-freebie__contrast-grid,
	.at-freebie__wissen-grid,
	.at-freebie__tools-grid,
	.at-freebie__final-inner {
		grid-template-columns: 1fr;
	}

	.at-freebie__tool--feature {
		flex-direction: column;
		align-items: flex-start;
		gap: 0;
	}

	.at-freebie__tool--feature .at-freebie__tool-head {
		margin-bottom: 8px;
	}

	.at-freebie__steps {
		grid-template-columns: 1fr;
		max-width: 560px;
		margin-left: auto;
		margin-right: auto;
	}

	.at-freebie__final-visual {
		order: 2;
	}

	.at-freebie__final-book {
		width: min(240px, 70%);
	}
}

@media (max-width: 620px) {
	.at-freebie__form {
		flex-direction: column;
	}

	.at-freebie button.at-freebie__btn {
		width: 100%;
	}

	.at-freebie__stage {
		min-height: 0;
		padding: 16px 0 10px;
	}

	.at-freebie__stage-glow,
	.at-freebie__page {
		display: none;
	}

	.at-freebie__cover {
		position: static;
		width: min(250px, 76%);
		margin: 0 auto;
		transform: rotate(-2deg);
	}

	.at-freebie__badge--chart {
		left: 2%;
		top: 2%;
	}

	.at-freebie__badge--pages {
		left: 4%;
		bottom: 4%;
	}

	.at-freebie__badge--free {
		right: 2%;
		top: 10%;
	}

	.at-freebie__facts ul {
		justify-content: flex-start;
		padding: 16px 18px;
	}

	.at-freebie {
		padding-bottom: 76px;
	}

	.at-freebie__sticky-cta {
		display: block;
		position: fixed;
		left: 14px;
		right: 14px;
		bottom: 14px;
		z-index: 60;
		padding: 15px 18px;
		text-align: center;
		background: var(--freebie-mint);
		color: var(--freebie-navy) !important;
		font-size: 15.5px;
		font-weight: 700;
		border-radius: 5px;
		text-decoration: none !important;
		box-shadow: 0 14px 34px rgba(15, 31, 58, 0.35);
	}
}

@media (prefers-reduced-motion: reduce) {
	.at-freebie *,
	.at-freebie *::before,
	.at-freebie *::after {
		animation: none !important;
		transition: none !important;
	}
}
