/**
 * Tory SEO – Campaign pages (e.g. Gas Dome 300)
 *
 * Visually rich product campaign pages under /products/more/{slug}/.
 * All colors/fonts pull from the Fresenius design system (header menu / tory-seo vars).
 */

:root {
	--tory-c-primary:        #00737d;
	--tory-c-primary-light:  #00B9BC;
	--tory-c-primary-glow:   rgba(0, 185, 188, 0.35);
	--tory-c-secondary:      #203556;
	--tory-c-secondary-deep: #142141;
	--tory-c-ink:            #0c1216;
	--tory-c-cloud:          #f5f7f8;
	--tory-c-line:           rgba(255, 255, 255, 0.12);
	--tory-c-amber:          #E8A33D;
	--tory-c-grey:           #6B7280;

	--tory-font-heading: 'Geist', 'Roboto', system-ui, sans-serif;
	--tory-font-body:    'Roboto', system-ui, sans-serif;

	--tory-radius:      18px;
	--tory-radius-pill: 9999px;
}

/* ──────────────────────────────────────────────────────────────────────────
   Page chrome
   ────────────────────────────────────────────────────────────────────────── */

body.tory-seo-campaign-page {
	/* Match the hero's top gradient stop so the gap between the fixed header
	   and the hero (where body's padding-top reserves space) is invisible. */
	background: var(--tory-c-secondary-deep);
	color: var(--tory-c-cloud);
	font-family: var(--tory-font-body);
}

body.tory-seo-campaign-page #primary,
body.tory-seo-campaign-page #content,
body.tory-seo-campaign-page .tory-seo-main,
body.tory-seo-campaign-page .site-main,
body.tory-seo-campaign-page .content-area {
	padding: 0 !important;
	margin: 0 !important;
	max-width: none !important;
}

/* On mobile/tablet the theme keeps a fixed body padding-top (~88px) for the
   desktop header, but the actual mobile header is only ~61px tall — leaving
   a dark gap. Drop body padding and let the hero clear the header itself.
   padding-top = 61px Header + ~30px atmen — schlank gehalten, sonst klafft
   blauer Space zwischen Header und Eyebrow. */
@media (max-width: 991px) {
	body.tory-seo-campaign-page {
		padding-top: 0 !important;
	}
	.tory-seo-campaign-hero {
		padding-top: clamp(80px, 11vh, 110px) !important;
	}
}

.tory-seo-campaign {
	display: block;
	width: 100%;
}

/* Hide visually any default site-header title injection for our fake post. */
body.tory-seo-campaign-page .page-title,
body.tory-seo-campaign-page .entry-title {
	display: none;
}

/* ──────────────────────────────────────────────────────────────────────────
   Hero
   ────────────────────────────────────────────────────────────────────────── */

.tory-seo-campaign-hero {
	position: relative;
	padding: clamp(28px, 4vh, 48px) clamp(20px, 5vw, 80px) clamp(56px, 7vh, 88px);
	background:
		radial-gradient(ellipse 80% 60% at 20% 0%,  rgba(0, 185, 188, 0.18) 0%, transparent 60%),
		radial-gradient(ellipse 90% 70% at 90% 100%, rgba(32, 53, 86, 0.55) 0%, transparent 65%),
		linear-gradient(180deg, var(--tory-c-secondary-deep) 0%, var(--tory-c-ink) 100%);
	overflow: hidden;
	isolation: isolate;
}

.tory-seo-campaign-hero::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(to right, rgba(255, 255, 255, 0.04) 1px, transparent 1px),
		linear-gradient(to bottom, rgba(255, 255, 255, 0.04) 1px, transparent 1px);
	background-size: 80px 80px;
	mask-image: radial-gradient(ellipse 70% 50% at 50% 50%, #000 30%, transparent 80%);
	pointer-events: none;
	z-index: 0;
}

.tory-seo-campaign-hero__inner {
	position: relative;
	z-index: 1;
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(40px, 6vh, 72px);
}

@media (min-width: 1024px) {
	.tory-seo-campaign-hero__inner {
		grid-template-columns: minmax(0, 1fr) minmax(0, 1.2fr);
		align-items: center;
	}
}

/* Hero text column */

.tory-seo-campaign-hero__text {
	display: flex;
	flex-direction: column;
	gap: clamp(16px, 2vh, 24px);
	max-width: 640px;
}

/* Eyebrow above H1 — typographic, no pill/glow */
.tory-seo-campaign-hero__kicker {
	display: flex;
	align-items: baseline;
	gap: 14px;
	margin: 0;
	color: rgba(255, 255, 255, 0.62);
	font-family: var(--tory-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.tory-seo-campaign-hero__kicker::before {
	content: '';
	width: 28px;
	height: 1px;
	background: var(--tory-c-primary-light);
	flex-shrink: 0;
	transform: translateY(-3px);
}

.tory-seo-campaign-hero__h1 {
	margin: 0;
	font-family: var(--tory-font-heading);
	font-weight: 700;
	font-size: clamp(48px, 8vw, 104px);
	line-height: 0.95;
	letter-spacing: -0.025em;
	color: #fff;
	background: linear-gradient(180deg, #fff 0%, #cfe6e8 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

.tory-seo-campaign-hero__lead {
	margin: 0;
	font-family: var(--tory-font-body);
	font-size: clamp(16px, 1.4vw, 19px);
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.78);
	max-width: 56ch;
}

/* Gas spec strip — datasheet typography, no pills, no glows. */
.tory-seo-campaign-hero__gases {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 0;
	margin: 24px 0 0;
	padding: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.16);
	list-style: none;
	max-width: 520px;
}

.tory-seo-campaign-hero__gases li {
	padding: 16px 18px 16px 0;
	border-right: 1px solid rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.92);
}

.tory-seo-campaign-hero__gases li:last-child {
	border-right: 0;
	padding-right: 0;
}

.tory-seo-campaign-hero__gases li + li {
	padding-left: 18px;
}

.tory-seo-campaign-hero__gas-formula {
	display: block;
	font-family: var(--tory-font-heading);
	font-weight: 600;
	font-size: 22px;
	letter-spacing: -0.01em;
	color: #fff;
	line-height: 1;
}

.tory-seo-campaign-hero__gas-name {
	display: block;
	margin-top: 4px;
	font-size: 13px;
	color: rgba(255, 255, 255, 0.6);
}

.tory-seo-campaign-hero__gas-gwp {
	display: block;
	margin-top: 10px;
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--tory-c-primary-light);
}

/* ──────────────────────────────────────────────────────────────────────────
   Hero — YouTube Lite Embed
   ────────────────────────────────────────────────────────────────────────── */

.tory-seo-lite-yt {
	position: relative;
	display: block;
	width: 100%;
	max-width: 720px;
	margin: 0 auto;
	aspect-ratio: 16 / 9;
	border-radius: var(--tory-radius);
	overflow: hidden;
	cursor: pointer;
	background: #000;
	box-shadow:
		0 0 0 1px rgba(255, 255, 255, 0.08),
		0 30px 80px -20px rgba(0, 0, 0, 0.55),
		0 0 80px -10px var(--tory-c-primary-glow);
	transition: transform .35s ease, box-shadow .35s ease;
}

.tory-seo-lite-yt:hover {
	transform: translateY(-2px);
	box-shadow:
		0 0 0 1px rgba(0, 185, 188, 0.35),
		0 40px 100px -20px rgba(0, 0, 0, 0.65),
		0 0 100px -10px var(--tory-c-primary-glow);
}

.tory-seo-lite-yt__poster {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	filter: brightness(0.85);
	transition: filter .3s ease;
}

.tory-seo-lite-yt:hover .tory-seo-lite-yt__poster {
	filter: brightness(0.95);
}

.tory-seo-lite-yt__button {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	width: clamp(72px, 9vw, 96px);
	height: clamp(72px, 9vw, 96px);
	border-radius: 50%;
	background: rgba(0, 115, 125, 0.92);
	border: 0;
	display: grid;
	place-items: center;
	cursor: pointer;
	transition: background .25s ease, transform .25s ease, box-shadow .25s ease;
	box-shadow:
		0 0 0 8px rgba(0, 185, 188, 0.12),
		0 0 0 16px rgba(0, 185, 188, 0.05);
}

.tory-seo-lite-yt:hover .tory-seo-lite-yt__button {
	background: var(--tory-c-primary-light);
	transform: translate(-50%, -50%) scale(1.06);
	box-shadow:
		0 0 0 10px rgba(0, 185, 188, 0.18),
		0 0 0 22px rgba(0, 185, 188, 0.08);
}

.tory-seo-lite-yt__button svg {
	width: 38%;
	height: 38%;
	fill: #fff;
	margin-left: 8%; /* visual centering for the triangle */
}

.tory-seo-lite-yt__caption {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	padding: 16px 20px;
	background: linear-gradient(180deg, transparent 0%, rgba(0, 0, 0, 0.75) 100%);
	color: #fff;
	font-size: 13px;
	font-weight: 500;
	letter-spacing: 0.02em;
	display: flex;
	align-items: center;
	gap: 10px;
	pointer-events: none;
}

.tory-seo-lite-yt__caption svg {
	width: 16px;
	height: 16px;
	flex-shrink: 0;
	opacity: 0.85;
}

.tory-seo-lite-yt iframe {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	border: 0;
}

/* ──────────────────────────────────────────────────────────────────────────
   Hero — scroll cue
   ────────────────────────────────────────────────────────────────────────── */

.tory-seo-campaign-hero__scrollcue {
	position: absolute;
	left: 50%;
	bottom: 24px;
	transform: translateX(-50%);
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	color: rgba(255, 255, 255, 0.5);
	font-size: 11px;
	font-weight: 500;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	pointer-events: none;
	z-index: 2;
}

.tory-seo-campaign-hero__scrollcue::after {
	content: '';
	width: 1px;
	height: 36px;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.5), transparent);
	animation: tsCampaignScrollCue 2.2s ease-in-out infinite;
	transform-origin: top;
}

@keyframes tsCampaignScrollCue {
	0%   { transform: scaleY(0);   opacity: 0; }
	30%  {                         opacity: 1; }
	100% { transform: scaleY(1);   opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
	.tory-seo-campaign-hero__scrollcue::after { animation: none; opacity: 0.5; transform: none; }
}

/* ──────────────────────────────────────────────────────────────────────────
   Scroll-typo section — three lines (GAS / DOME / 300) stacked, each slides
   IN from alternating sides as the user scrolls the section into view.
   Once landed, they stay put.
   ────────────────────────────────────────────────────────────────────────── */

.tory-seo-campaign-scrolltypo {
	position: relative;
	padding: clamp(96px, 14vh, 180px) clamp(20px, 5vw, 80px);
	background: var(--tory-c-ink);
	overflow: hidden;
}

.tory-seo-campaign-scrolltypo__sticky {
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	gap: clamp(24px, 4vh, 56px);
}

.tory-seo-campaign-scrolltypo__eyebrow {
	display: flex;
	align-items: baseline;
	gap: 14px;
	margin: 0;
	color: rgba(255, 255, 255, 0.62);
	font-family: var(--tory-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.tory-seo-campaign-scrolltypo__eyebrow::before {
	content: '';
	width: 28px;
	height: 1px;
	background: var(--tory-c-primary-light);
	transform: translateY(-3px);
	flex-shrink: 0;
}

.tory-seo-campaign-scrolltypo__wordmark {
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: 0;
	font-family: var(--tory-font-heading);
	font-weight: 700;
	font-size: clamp(72px, 17vw, 280px);
	line-height: 0.85;
	letter-spacing: -0.04em;
	color: #fff;
}

/* Lines start off-screen + invisible. Stagger direction via data-dir, all land
   LEFT-aligned. A single IntersectionObserver in campaign.js adds .is-visible
   to the section when it enters the viewport — staggered CSS transitions then
   slide each line in. Same in every browser (no animation-timeline quirks). */
.tory-seo-campaign-scrolltypo__line {
	display: block;
	align-self: flex-start;
	opacity: 0;
	transform: translateX(var(--slide-from, -110%));
	will-change: transform, opacity;
	transition:
		opacity 0.9s cubic-bezier(.22, 1, .36, 1),
		transform 1.1s cubic-bezier(.22, 1, .36, 1);
	transition-delay: calc(var(--i, 0) * 220ms);
}

.tory-seo-campaign-scrolltypo__line[data-dir="right"] {
	--slide-from: 110%;
}

.tory-seo-campaign-scrolltypo.is-visible .tory-seo-campaign-scrolltypo__line {
	opacity: 1;
	transform: translateX(0);
}

.tory-seo-campaign-scrolltypo__claim {
	margin: 0;
	max-width: 720px;
	font-family: var(--tory-font-body);
	font-size: clamp(16px, 1.4vw, 19px);
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.78);
}

@media (prefers-reduced-motion: reduce) {
	.tory-seo-campaign-scrolltypo__line {
		opacity: 1;
		transform: none;
		animation: none;
		transition: none;
	}
}

/* ──────────────────────────────────────────────────────────────────────────
   Gallery section — three 16:9 placeholder tiles, stacked with alternating
   horizontal offset. Stagger-reveal on entry (no header — directly follows
   the GAS DOME 300 scroll-typo).
   ────────────────────────────────────────────────────────────────────────── */

.tory-seo-campaign-gallery {
	position: relative;
	padding: clamp(40px, 6vh, 80px) clamp(20px, 5vw, 80px) clamp(80px, 12vh, 140px);
	background: var(--tory-c-ink);
	overflow: hidden;
}

.tory-seo-campaign-gallery__stack {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: flex;
	flex-direction: column;
	gap: clamp(28px, 5vh, 64px);
}

.tory-seo-campaign-gallery__tile {
	margin: 0;
	width: 72%;
	opacity: 0;
	transform: translateY(40px);
	will-change: transform, opacity;
	transition:
		opacity 0.9s cubic-bezier(.22, 1, .36, 1),
		transform 1s cubic-bezier(.22, 1, .36, 1);
	transition-delay: calc(var(--i, 0) * 180ms);
}

/* Alternating horizontal offset for a staircase effect. */
.tory-seo-campaign-gallery__tile:nth-child(1) { align-self: flex-start; margin-left: 0; }
.tory-seo-campaign-gallery__tile:nth-child(2) { align-self: flex-end;   margin-right: 0; }
.tory-seo-campaign-gallery__tile:nth-child(3) { align-self: flex-start; margin-left: 14%; }

@media (max-width: 900px) {
	.tory-seo-campaign-gallery__tile {
		width: 100%;
		margin: 0 !important;
		align-self: stretch !important;
	}
}

.tory-seo-campaign-gallery.is-visible .tory-seo-campaign-gallery__tile {
	opacity: 1;
	transform: translateY(0);
}

.tory-seo-campaign-gallery__placeholder,
.tory-seo-campaign-gallery__figure {
	position: relative;
	aspect-ratio: 16 / 9;
	border-radius: var(--tory-radius);
	overflow: hidden;
	margin: 0;
	box-shadow:
		inset 0 0 0 1px rgba(255, 255, 255, 0.08),
		0 18px 48px -16px rgba(0, 0, 0, 0.6);
	transition: transform .35s ease, box-shadow .35s ease;
}

.tory-seo-campaign-gallery__placeholder {
	background:
		radial-gradient(ellipse 80% 70% at 30% 20%, rgba(0, 185, 188, 0.35) 0%, transparent 65%),
		linear-gradient(160deg, var(--tory-c-primary) 0%, var(--tory-c-secondary-deep) 100%);
}

.tory-seo-campaign-gallery__img {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .8s ease;
}

.tory-seo-campaign-gallery__tile:hover .tory-seo-campaign-gallery__placeholder,
.tory-seo-campaign-gallery__tile:hover .tory-seo-campaign-gallery__figure {
	transform: translateY(-3px);
	box-shadow:
		inset 0 0 0 1px rgba(0, 185, 188, 0.35),
		0 28px 60px -18px rgba(0, 0, 0, 0.7);
}

.tory-seo-campaign-gallery__tile:hover .tory-seo-campaign-gallery__img {
	transform: scale(1.03);
}

.tory-seo-campaign-gallery__index {
	position: absolute;
	top: 18px;
	left: 18px;
	font-family: var(--tory-font-heading);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 0.06em;
	color: rgba(255, 255, 255, 0.6);
}

.tory-seo-campaign-gallery__chip {
	position: absolute;
	bottom: 18px;
	left: 18px;
	padding: 5px 10px;
	border-radius: 6px;
	background: rgba(0, 0, 0, 0.35);
	border: 1px solid rgba(255, 255, 255, 0.16);
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.78);
}

@media (prefers-reduced-motion: reduce) {
	.tory-seo-campaign-gallery__tile {
		opacity: 1;
		transform: none;
		transition: none;
	}
}

.tory-seo-campaign-gallery__disclaimer {
	max-width: 1280px;
	margin: clamp(24px, 4vh, 40px) auto 0;
	padding-left: 4px;
	font-family: var(--tory-font-body);
	font-size: 12px;
	font-style: italic;
	letter-spacing: 0.02em;
	color: rgba(255, 255, 255, 0.48);
	text-align: left;
}

/* ──────────────────────────────────────────────────────────────────────────
   Plant-animation section — SVG cross-section of WWTP basin + hood + tube +
   analyzer, with rising particle clusters (CH4 / N2O / CO2) flowing from
   the basin up under the hood and across to the analyzer display.
   ────────────────────────────────────────────────────────────────────────── */

.tory-seo-campaign-plant {
	position: relative;
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
	background: linear-gradient(180deg, var(--tory-c-ink) 0%, var(--tory-c-secondary-deep) 100%);
	overflow: hidden;
}

.tory-seo-campaign-plant__head {
	max-width: 1280px;
	margin: 0 auto clamp(40px, 6vh, 64px);
	display: grid;
	gap: 14px;
}

.tory-seo-campaign-plant__eyebrow {
	display: flex;
	align-items: baseline;
	gap: 14px;
	margin: 0;
	color: rgba(255, 255, 255, 0.62);
	font-family: var(--tory-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.tory-seo-campaign-plant__eyebrow::before {
	content: '';
	width: 28px;
	height: 1px;
	background: var(--tory-c-primary-light);
	transform: translateY(-3px);
	flex-shrink: 0;
}

.tory-seo-campaign-plant__title {
	margin: 0;
	font-family: var(--tory-font-heading);
	font-weight: 600;
	font-size: clamp(28px, 3.6vw, 48px);
	line-height: 1.1;
	letter-spacing: -0.015em;
	color: #fff;
	max-width: 24ch;
}

.tory-seo-campaign-plant__stage {
	max-width: 1280px;
	margin: 0 auto;
	padding: clamp(20px, 3vw, 40px);
	border-radius: var(--tory-radius);
	background: rgba(255, 255, 255, 0.02);
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.06);
}

.tory-seo-campaign-plant__svg {
	display: block;
	width: 100%;
	height: auto;
	max-width: 1100px;
	margin: 0 auto;
}

.tory-seo-campaign-plant__caption {
	max-width: 880px;
	margin: clamp(24px, 4vh, 40px) auto 0;
	font-family: var(--tory-font-body);
	font-size: clamp(15px, 1.2vw, 17px);
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.72);
}

/* Particle animation — rise from water, gather under hood, flow through
   tube to the analyzer, fade.
   Translation values are in SVG user units (the viewBox is 1200x620, so the
   transforms compose with `transform-box: fill-box` on each <circle>). */
.tory-seo-campaign-plant__p {
	transform-box: fill-box;
	transform-origin: center;
	animation: tsPlantParticle 6s linear infinite;
	animation-delay: var(--d, 0s);
	opacity: 0;
}

/* Gas colors */
.tory-seo-campaign-plant__p[data-gas="CH4"] { fill: #00B9BC; } /* petrol */
.tory-seo-campaign-plant__p[data-gas="N2O"] { fill: #E8A33D; } /* amber */
.tory-seo-campaign-plant__p[data-gas="CO2"] { fill: #6B7280; } /* grey */

/* Tube path mapped to translate offsets (from each particle's start at y=540):
   - y=540 → y=350 under hood             : Δy = -190
   - y=350 → y=265 gather at collar         : Δy = -275, x merges to 500 (use --tx)
   - y=265 → y=80  ascend in vertical tube  : Δy = -460
   - y=80  travel right to x=1062           : Δx = +562 (from x=500)
   - y=80  → y=46  descend into post        : Δy = -494 total, Δx kept */
@keyframes tsPlantParticle {
	0%   { transform: translate(0, 0)                                            scale(0.7);  opacity: 0; }
	6%   { opacity: 0.85; }
	28%  { transform: translate(var(--x, 0), -190px)                              scale(1);    opacity: 1; }  /* rise + drift */
	38%  { transform: translate(var(--tx, 0), -275px)                             scale(0.85); opacity: 1; }  /* converge under hood */
	60%  { transform: translate(var(--tx, 0), -480px)                             scale(0.85); opacity: 1; }  /* up the vertical tube (to y=60) */
	80%  { transform: translate(calc(var(--tx, 0) + 545px), -480px)               scale(0.85); opacity: 1; }  /* across to x=1045, y=60 */
	92%  { transform: translate(calc(var(--tx, 0) + 545px), -440px)               scale(0.7);  opacity: 0.8; } /* down into post (to y=100) */
	100% { transform: translate(calc(var(--tx, 0) + 545px), -440px)               scale(0.5);  opacity: 0; }
}

/* Operational LED pulse on the analyzer */
.tory-seo-campaign-plant__led {
	animation: tsPlantLed 2s ease-in-out infinite;
}
@keyframes tsPlantLed {
	0%, 100% { opacity: 1; }
	50%      { opacity: 0.45; }
}

/* ── Water details ─────────────────────────────────────────────────────── */

/* Light rays — gently sway + brighten/dim like real volumetric god rays */
.tory-seo-campaign-plant__rays polygon {
	transform-box: fill-box;
	transform-origin: top center;
	animation: tsPlantRay 7s ease-in-out infinite;
	animation-delay: var(--rd, 0s);
}
@keyframes tsPlantRay {
	0%,100% { opacity: 0.55; transform: skewX(0deg); }
	50%     { opacity: 1;    transform: skewX(2.5deg); }
}

/* Caustic glow spots — drift sideways along the floor + breathe brightness */
.tory-seo-campaign-plant__caustics ellipse {
	transform-box: fill-box;
	transform-origin: center;
	animation: tsPlantCaustic 6s ease-in-out infinite;
	animation-delay: var(--cd, 0s);
}
@keyframes tsPlantCaustic {
	0%,100% { transform: translateX(-12px) scale(0.92); opacity: 0.7; }
	50%     { transform: translateX(12px)  scale(1.08); opacity: 1; }
}

/* Surface sparkle dots — twinkle */
.tory-seo-campaign-plant__sparkles circle {
	animation: tsPlantSparkle 3s ease-in-out infinite;
	animation-delay: var(--sd, 0s);
}
@keyframes tsPlantSparkle {
	0%,100% { opacity: 0.15; }
	50%     { opacity: 1; }
}

/* Aerator bubbles — slow rise from the floor toward the hood entry */
.tory-seo-campaign-plant__bubbles circle {
	transform-box: fill-box;
	transform-origin: center;
	animation: tsPlantBubble 4s ease-in infinite;
	animation-delay: var(--bd, 0s);
}
@keyframes tsPlantBubble {
	0%   { transform: translateY(20px) scale(0.6); opacity: 0; }
	15%  { opacity: 0.8; }
	100% { transform: translateY(-150px) scale(1); opacity: 0; }
}

@media (prefers-reduced-motion: reduce) {
	.tory-seo-campaign-plant__rays polygon,
	.tory-seo-campaign-plant__caustics ellipse,
	.tory-seo-campaign-plant__sparkles circle,
	.tory-seo-campaign-plant__bubbles circle {
		animation: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.tory-seo-campaign-plant__p,
	.tory-seo-campaign-plant__led {
		animation: none;
	}
	.tory-seo-campaign-plant__p {
		opacity: 0.85;
	}
}

@media (max-width: 700px) {
	.tory-seo-campaign-plant__stage {
		padding: 12px;
	}
	.tory-seo-campaign-plant__caption {
		font-size: 14px;
	}
}

/* ──────────────────────────────────────────────────────────────────────────
   Shared eyebrow / title block for campaign sub-sections
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-section-head {
	max-width: 1280px;
	margin: 0 auto clamp(40px, 6vh, 64px);
	display: grid;
	gap: 14px;
}

/* ──────────────────────────────────────────────────────────────────────────
   Hood specs grid
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-specs {
	background: var(--tory-c-secondary-deep);
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
}

.tory-seo-campaign-specs__head {
	max-width: 1280px;
	margin: 0 auto clamp(40px, 6vh, 64px);
	display: grid;
	gap: 14px;
}

.tory-seo-campaign-specs__eyebrow,
.tory-seo-campaign-mt__eyebrow,
.tory-seo-campaign-tory__eyebrow,
.tory-seo-campaign-cck__eyebrow {
	display: flex;
	align-items: baseline;
	gap: 14px;
	margin: 0;
	color: rgba(255, 255, 255, 0.62);
	font-family: var(--tory-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}
.tory-seo-campaign-specs__eyebrow::before,
.tory-seo-campaign-mt__eyebrow::before,
.tory-seo-campaign-tory__eyebrow::before,
.tory-seo-campaign-cck__eyebrow::before {
	content: '';
	width: 28px;
	height: 1px;
	background: var(--tory-c-primary-light);
	transform: translateY(-3px);
	flex-shrink: 0;
}

.tory-seo-campaign-specs__title,
.tory-seo-campaign-mt__title,
.tory-seo-campaign-tory__title,
.tory-seo-campaign-cck__title {
	margin: 0;
	font-family: var(--tory-font-heading);
	font-weight: 600;
	font-size: clamp(28px, 3.6vw, 48px);
	line-height: 1.1;
	letter-spacing: -0.015em;
	color: #fff;
	max-width: 24ch;
}

.tory-seo-campaign-specs__grid {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	border-left: 1px solid rgba(255, 255, 255, 0.1);
}

@media (max-width: 900px) {
	.tory-seo-campaign-specs__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 540px) {
	.tory-seo-campaign-specs__grid { grid-template-columns: 1fr; }
}

.tory-seo-campaign-specs__cell {
	padding: 28px 24px;
	border-right: 1px solid rgba(255, 255, 255, 0.1);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	display: grid;
	grid-template-rows: auto auto auto;
	gap: 8px;
	transition: background .25s ease;
}

.tory-seo-campaign-specs__cell:hover {
	background: rgba(0, 185, 188, 0.04);
}

.tory-seo-campaign-specs__icon {
	display: inline-flex;
	width: 32px;
	height: 32px;
	color: var(--tory-c-primary-light);
}

.tory-seo-campaign-specs__icon svg {
	width: 100%;
	height: 100%;
}

.tory-seo-campaign-specs__label {
	margin: 0;
	font-family: var(--tory-font-body);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.58);
}

.tory-seo-campaign-specs__value {
	margin: 0;
	font-family: var(--tory-font-heading);
	font-size: clamp(18px, 1.4vw, 21px);
	font-weight: 500;
	line-height: 1.35;
	color: #fff;
}

/* ──────────────────────────────────────────────────────────────────────────
   Measurement-tech tabs (pure CSS — radio inputs drive the panels)
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-mt {
	background: var(--tory-c-ink);
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
}

.tory-seo-campaign-mt__head {
	max-width: 1280px;
	margin: 0 auto clamp(40px, 6vh, 64px);
	display: grid;
	gap: 14px;
}

.tory-seo-campaign-mt__tabs {
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 8px;
}

/* Radios are hidden but kept in DOM so `:checked ~ .panels .panel:nth-of-type()`
   still toggles the active panel. `display: none` removes them from grid
   placement entirely, so the labels lay out as 5 equal cells. */
.tory-seo-campaign-mt__radio {
	display: none;
}

.tory-seo-campaign-mt__tab {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 18px 16px;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 12px;
	font-family: var(--tory-font-heading);
	font-weight: 500;
	font-size: clamp(14px, 1.2vw, 16px);
	color: rgba(255, 255, 255, 0.72);
	cursor: pointer;
	transition: background .2s ease, color .2s ease, border-color .2s ease;
	user-select: none;
}

.tory-seo-campaign-mt__tab:hover {
	background: rgba(0, 185, 188, 0.06);
	color: #fff;
}

.tory-seo-campaign-mt__radio:focus-visible + .tory-seo-campaign-mt__tab {
	outline: 2px solid var(--tory-c-primary-light);
	outline-offset: 2px;
}

.tory-seo-campaign-mt__radio:checked + .tory-seo-campaign-mt__tab {
	background: rgba(0, 185, 188, 0.12);
	border-color: rgba(0, 185, 188, 0.5);
	color: #fff;
}

.tory-seo-campaign-mt__panels {
	grid-column: 1 / -1;
	margin-top: 24px;
	position: relative;
	background: rgba(255, 255, 255, 0.02);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--tory-radius);
	padding: clamp(28px, 4vw, 48px);
	min-height: 220px;
}

.tory-seo-campaign-mt__panel {
	display: none;
	max-width: 920px;
	color: rgba(255, 255, 255, 0.85);
}

/* Each radio toggles a panel via order of inputs/labels.
   Pattern: 5 radios in order (ndir, nduv, paramagnetic, electrochemical, tdlas),
   followed by 5 labels, followed by the panel container. We use sibling matching
   with :nth-of-type on the panel articles. */
.tory-seo-campaign-mt__radio:nth-of-type(1):checked ~ .tory-seo-campaign-mt__panels .tory-seo-campaign-mt__panel:nth-of-type(1),
.tory-seo-campaign-mt__radio:nth-of-type(2):checked ~ .tory-seo-campaign-mt__panels .tory-seo-campaign-mt__panel:nth-of-type(2),
.tory-seo-campaign-mt__radio:nth-of-type(3):checked ~ .tory-seo-campaign-mt__panels .tory-seo-campaign-mt__panel:nth-of-type(3),
.tory-seo-campaign-mt__radio:nth-of-type(4):checked ~ .tory-seo-campaign-mt__panels .tory-seo-campaign-mt__panel:nth-of-type(4),
.tory-seo-campaign-mt__radio:nth-of-type(5):checked ~ .tory-seo-campaign-mt__panels .tory-seo-campaign-mt__panel:nth-of-type(5) {
	display: block;
}

.tory-seo-campaign-mt__panel-subtitle {
	margin: 0 0 14px;
	color: var(--tory-c-primary-light);
	font-family: var(--tory-font-body);
	font-size: 13px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.tory-seo-campaign-mt__panel-desc {
	margin: 0 0 24px;
	font-family: var(--tory-font-body);
	font-size: clamp(15px, 1.2vw, 17px);
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.85);
}

.tory-seo-campaign-mt__panel-meta {
	display: grid;
	grid-template-columns: max-content 1fr;
	column-gap: 24px;
	row-gap: 6px;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	padding-top: 18px;
	margin: 0;
}

.tory-seo-campaign-mt__panel-meta dt {
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.55);
}

.tory-seo-campaign-mt__panel-meta dd {
	margin: 0;
	font-family: var(--tory-font-heading);
	font-size: 16px;
	color: #fff;
}

@media (max-width: 900px) {
	.tory-seo-campaign-mt__tabs {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* ──────────────────────────────────────────────────────────────────────────
   Tory chat banner
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-tory {
	background:
		radial-gradient(ellipse 70% 80% at 80% 20%, rgba(0, 185, 188, 0.22) 0%, transparent 60%),
		var(--tory-c-secondary-deep);
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
}

.tory-seo-campaign-tory__inner {
	max-width: 1280px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
	gap: clamp(40px, 6vw, 80px);
	align-items: center;
}

@media (max-width: 900px) {
	.tory-seo-campaign-tory__inner { grid-template-columns: 1fr; }
}

.tory-seo-campaign-tory__copy {
	display: grid;
	gap: 18px;
}

.tory-seo-campaign-tory__lead {
	margin: 0;
	font-family: var(--tory-font-body);
	font-size: clamp(15px, 1.2vw, 17px);
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.78);
	max-width: 56ch;
}

.tory-seo-campaign-tory__bullets {
	margin: 8px 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 10px;
}

.tory-seo-campaign-tory__bullets li {
	display: flex;
	align-items: flex-start;
	gap: 10px;
	color: rgba(255, 255, 255, 0.88);
	font-size: 15px;
}

.tory-seo-campaign-tory__bullets svg {
	width: 18px;
	height: 18px;
	color: var(--tory-c-primary-light);
	flex-shrink: 0;
	margin-top: 3px;
}

.tory-seo-campaign-tory__cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 14px 24px;
	margin-top: 12px;
	width: max-content;
	background: var(--tory-c-primary);
	border: 0;
	border-radius: var(--tory-radius-pill);
	color: #fff;
	font-family: var(--tory-font-body);
	font-size: 15px;
	font-weight: 500;
	cursor: pointer;
	transition: background .2s ease, transform .2s ease;
}

.tory-seo-campaign-tory__cta:hover {
	background: var(--tory-c-primary-light);
	transform: translateY(-2px);
}

.tory-seo-campaign-tory__cta svg { width: 18px; height: 18px; }

.tory-seo-campaign-tory__visual {
	position: relative;
	display: grid;
	place-items: center;
}

.tory-seo-campaign-tory__visual img {
	position: relative;
	z-index: 1;
	max-width: 100%;
	height: auto;
	border-radius: var(--tory-radius);
}

.tory-seo-campaign-tory__halo {
	position: absolute;
	inset: 8% 8%;
	background: radial-gradient(circle, rgba(0, 185, 188, 0.4) 0%, transparent 65%);
	filter: blur(40px);
	z-index: 0;
}

/* Tory chat bubble — pulses to draw attention to the floating chat widget */
.tory-seo-campaign-tory__bubble {
	position: absolute;
	top: 6%;
	right: -6%;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	gap: 12px;
	padding: 12px 18px 12px 14px;
	border-radius: var(--tory-radius-pill);
	background: var(--tory-c-primary);
	color: #fff;
	font-family: var(--tory-font-body);
	white-space: nowrap;
	box-shadow: 0 8px 28px -10px rgba(0, 115, 125, 0.5);
	animation: tsCampaignBubbleFloat 5s ease-in-out infinite;
}

.tory-seo-campaign-tory__bubble::after {
	content: '';
	position: absolute;
	right: -8px;
	bottom: 12px;
	width: 16px;
	height: 16px;
	background: var(--tory-c-primary);
	clip-path: polygon(0 0, 100% 50%, 0 100%);
}

.tory-seo-campaign-tory__bubble-emoji {
	font-size: 22px;
	line-height: 1;
}

.tory-seo-campaign-tory__bubble-text {
	display: grid;
	gap: 2px;
	line-height: 1.2;
}

.tory-seo-campaign-tory__bubble-text strong {
	font-weight: 600;
	font-size: 14px;
}

.tory-seo-campaign-tory__bubble-text small {
	font-size: 11px;
	opacity: 0.78;
	letter-spacing: 0.04em;
}

@keyframes tsCampaignBubbleFloat {
	0%, 100% { transform: translateY(0); }
	50%      { transform: translateY(-3px); }
}

@media (max-width: 900px) {
	.tory-seo-campaign-tory__bubble {
		top: -8px;
		right: 0;
	}
}

@media (prefers-reduced-motion: reduce) {
	.tory-seo-campaign-tory__bubble {
		animation: none;
	}
}

/* ──────────────────────────────────────────────────────────────────────────
   Cloud Connect Kit flow
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-cck {
	background: linear-gradient(180deg, var(--tory-c-secondary-deep) 0%, var(--tory-c-ink) 100%);
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
}

.tory-seo-campaign-cck__top {
	max-width: 1280px;
	margin: 0 auto clamp(48px, 7vh, 80px);
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
	gap: clamp(28px, 4vw, 48px);
	align-items: center;
}

.tory-seo-campaign-cck__head {
	display: grid;
	gap: 14px;
}

@media (max-width: 900px) {
	.tory-seo-campaign-cck__top { grid-template-columns: 1fr; }
}

.tory-seo-campaign-cck__visual {
	justify-self: center; /* center the small image within its own column */
}

.tory-seo-campaign-cck__visual {
	position: relative;
	display: grid;
	place-items: center;
}

.tory-seo-campaign-cck__visual {
	max-width: 140px;
	width: 100%;
	position: relative;
	display: grid;
	place-items: center;
}

.tory-seo-campaign-cck__visual img {
	position: relative;
	z-index: 1;
	max-width: 100% !important;
	width: 100%;
	height: auto;
	border-radius: var(--tory-radius);
}

.tory-seo-campaign-cck__halo {
	position: absolute;
	inset: 5% 5%;
	background: radial-gradient(circle, rgba(0, 185, 188, 0.35) 0%, transparent 65%);
	filter: blur(48px);
	z-index: 0;
}

.tory-seo-campaign-cck__lead {
	margin: 0;
	max-width: 760px;
	font-family: var(--tory-font-body);
	font-size: clamp(15px, 1.2vw, 17px);
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.78);
}

.tory-seo-campaign-cck__flow {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: clamp(20px, 2vw, 28px);
	counter-reset: cck-step;
}

@media (max-width: 900px) {
	.tory-seo-campaign-cck__flow { grid-template-columns: 1fr; }
}

.tory-seo-campaign-cck__step {
	position: relative;
	padding: 28px 24px;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--tory-radius);
	display: grid;
	gap: 12px;
	align-content: start;
}

.tory-seo-campaign-cck__step:not(:last-child)::after {
	content: '';
	position: absolute;
	right: -16px;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
	height: 1px;
	background: rgba(0, 185, 188, 0.6);
}

@media (max-width: 900px) {
	.tory-seo-campaign-cck__step:not(:last-child)::after {
		right: 50%;
		top: auto;
		bottom: -16px;
		transform: translateX(50%);
		width: 1px;
		height: 16px;
	}
}

.tory-seo-campaign-cck__step-num {
	font-family: var(--tory-font-heading);
	font-weight: 600;
	font-size: 14px;
	letter-spacing: 0.08em;
	color: var(--tory-c-primary-light);
}

.tory-seo-campaign-cck__step-title {
	margin: 0;
	font-family: var(--tory-font-heading);
	font-weight: 600;
	font-size: clamp(18px, 1.6vw, 22px);
	color: #fff;
	line-height: 1.3;
}

.tory-seo-campaign-cck__step-text {
	margin: 0;
	font-family: var(--tory-font-body);
	font-size: 15px;
	line-height: 1.55;
	color: rgba(255, 255, 255, 0.75);
}

/* ──────────────────────────────────────────────────────────────────────────
   FAQ — accordion built on native <details>/<summary>
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-faq {
	background: var(--tory-c-ink);
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
}

.tory-seo-campaign-faq__head {
	max-width: 1280px;
	margin: 0 auto clamp(40px, 6vh, 64px);
	display: grid;
	gap: 14px;
}

.tory-seo-campaign-faq__eyebrow,
.tory-seo-campaign-cta__eyebrow,
.tory-seo-campaign-related__eyebrow {
	display: flex;
	align-items: baseline;
	gap: 14px;
	margin: 0;
	color: rgba(255, 255, 255, 0.62);
	font-family: var(--tory-font-body);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.tory-seo-campaign-faq__eyebrow::before,
.tory-seo-campaign-cta__eyebrow::before,
.tory-seo-campaign-related__eyebrow::before {
	content: '';
	width: 28px;
	height: 1px;
	background: var(--tory-c-primary-light);
	transform: translateY(-3px);
	flex-shrink: 0;
}

.tory-seo-campaign-faq__title,
.tory-seo-campaign-cta__title,
.tory-seo-campaign-related__title {
	margin: 0;
	font-family: var(--tory-font-heading);
	font-weight: 600;
	font-size: clamp(28px, 3.6vw, 48px);
	line-height: 1.1;
	letter-spacing: -0.015em;
	color: #fff;
}

.tory-seo-campaign-faq__list {
	max-width: 1080px;
	margin: 0 auto;
	display: grid;
	gap: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.tory-seo-campaign-faq__item {
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.tory-seo-campaign-faq__q {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 16px;
	padding: 22px 0;
	cursor: pointer;
	color: #fff;
	font-family: var(--tory-font-heading);
	font-weight: 500;
	font-size: clamp(16px, 1.4vw, 19px);
	line-height: 1.35;
	list-style: none;
	user-select: none;
	transition: color .2s ease;
}

.tory-seo-campaign-faq__q::-webkit-details-marker { display: none; }
.tory-seo-campaign-faq__q::marker { content: ''; }

.tory-seo-campaign-faq__q:hover {
	color: var(--tory-c-primary-light);
}

.tory-seo-campaign-faq__chev {
	width: 22px;
	height: 22px;
	flex-shrink: 0;
	color: var(--tory-c-primary-light);
	transition: transform .25s ease;
	margin-top: 2px;
}

.tory-seo-campaign-faq__item[open] .tory-seo-campaign-faq__chev {
	transform: rotate(180deg);
}

.tory-seo-campaign-faq__a {
	padding: 0 28px 22px 0;
	font-family: var(--tory-font-body);
	font-size: clamp(15px, 1.2vw, 17px);
	line-height: 1.65;
	color: rgba(255, 255, 255, 0.78);
}

/* ──────────────────────────────────────────────────────────────────────────
   CTA banner
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-cta {
	background:
		radial-gradient(ellipse 80% 100% at 90% 50%, rgba(0, 185, 188, 0.18) 0%, transparent 60%),
		var(--tory-c-secondary-deep);
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
}

.tory-seo-campaign-cta__inner {
	max-width: 920px;
	margin: 0 auto;
	display: grid;
	gap: 20px;
	text-align: left;
}

.tory-seo-campaign-cta__lead {
	margin: 0;
	font-family: var(--tory-font-body);
	font-size: clamp(16px, 1.3vw, 18px);
	line-height: 1.6;
	color: rgba(255, 255, 255, 0.82);
	max-width: 60ch;
}

.tory-seo-campaign-cta__btn {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	padding: 16px 26px;
	margin-top: 12px;
	width: max-content;
	background: var(--tory-c-primary-light);
	border-radius: var(--tory-radius-pill);
	color: #0c1216;
	font-family: var(--tory-font-body);
	font-weight: 600;
	font-size: 15px;
	text-decoration: none;
	transition: background .2s ease, transform .2s ease, box-shadow .2s ease;
	box-shadow: 0 12px 32px -10px rgba(0, 185, 188, 0.55);
}

.tory-seo-campaign-cta__btn:hover {
	background: #fff;
	transform: translateY(-2px);
	box-shadow: 0 18px 40px -12px rgba(0, 185, 188, 0.6);
}

.tory-seo-campaign-cta__btn svg { width: 18px; height: 18px; }

/* ──────────────────────────────────────────────────────────────────────────
   Related links
   ────────────────────────────────────────────────────────────────────────── */
.tory-seo-campaign-related {
	background: var(--tory-c-ink);
	padding: clamp(80px, 12vh, 140px) clamp(20px, 5vw, 80px);
}

.tory-seo-campaign-related__head {
	max-width: 1280px;
	margin: 0 auto clamp(40px, 6vh, 64px);
	display: grid;
	gap: 14px;
}

.tory-seo-campaign-related__list {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

@media (max-width: 900px) {
	.tory-seo-campaign-related__list { grid-template-columns: 1fr; }
}

.tory-seo-campaign-related__card {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 12px;
	padding: 22px 24px;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--tory-radius);
	color: #fff;
	font-family: var(--tory-font-heading);
	font-weight: 500;
	font-size: clamp(15px, 1.2vw, 17px);
	text-decoration: none;
	transition: background .2s ease, border-color .2s ease, transform .2s ease;
}

.tory-seo-campaign-related__card svg {
	width: 18px;
	height: 18px;
	color: var(--tory-c-primary-light);
	transition: transform .2s ease;
}

.tory-seo-campaign-related__card:hover {
	background: rgba(0, 185, 188, 0.06);
	border-color: rgba(0, 185, 188, 0.5);
	transform: translateY(-2px);
}

.tory-seo-campaign-related__card:hover svg {
	transform: translateX(4px);
}

