/**
 * Homepage V7 — převzato z handoff designu homepage-v2.html (Claude Design)
 *
 * Prefixy:
 *   .hp7-*     — page-local komponenty pro tuto stránku
 *   .re-*      — sdílené BEM komponenty z design systému (ui-kit.css)
 *
 * Rytmus pozadí:
 *   navy hero → cream-50 (stats) → white (služby) → cream-100 (ROI rating) →
 *   image-dark (tým) → cream-50 (proč věřit) → white (reference) →
 *   navy (podcast) → cream-200 (e-book) → white (nabídky) → cream-50 (blog) →
 *   image-dark (bonus) → cream-50 (kontakt) → cream-100 (press)
 */

/* Doplňující tokeny z handoff design systému, které vibe-style nemá. */
:root {
	--cream-50:  #FAF7F3;
	--cream-100: #F5F2EF;
	--cream-200: #ECE4D8;
	--cream-300: #DDD0BB;

	--ff-sans: "Source Sans 3", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;

	--h1-size: clamp(3.6rem, 2.2rem + 2.4vw, 4.87rem);
	--h2-size: clamp(2.4rem, 1.8rem + 1.2vw, 2.95rem);
	--h3-size: 2.95rem;
	--h4-size: 2.03rem;

	--heading-font-weight: 700;
	--text-font-weight: 500;
	--btn-font-weight: 500;
	--btn-letter-spacing: 0.01em;
	--btn-font-size: clamp(1.9rem, calc(0.208vw + 1.833rem), 2.1rem);

	--section-space-xs: clamp(1.92rem, 2.12vw + 1.13rem, 3.84rem);
	--section-space-xxl: clamp(5.86rem, 6.47vw + 3.43rem, 11.719rem);

	--section-padding-x: var(--gutter);
	--section-padding-block: var(--section-space-m);

	--border-size: 1px;
	--action-hover: #1F47C9;
	--link-color: var(--primary);

	--box-shadow-xl:
		2.8px 2.8px 2.2px rgba(0,0,0,0.02),
		0 6.7px 5.3px -5px rgba(0,0,0,0.04),
		0 12.5px 10px -5px rgba(0,0,0,0.06),
		0 22.3px 17.9px -5px rgba(0,0,0,0.08),
		0 41.8px 33.4px -5px rgba(0,0,0,0.10),
		0 80px 80px -5px rgba(0,0,0,0.105);

	--transition-duration: 0.3s;
	--transition-timing: ease-in-out;
}

/* ---------- Local util ---------- */
.hp7-sechead { max-width: 70ch; margin: 0 auto var(--section-space-m); text-align: center; }
.hp7-sechead--left { margin-inline: 0; text-align: left; }
.hp7-sechead p.re-text { color: color-mix(in srgb, var(--base) 72%, transparent); margin-top: var(--space-l); }

/* ---------- Hero ---------- */
.hp7-hero {
	position: relative;
	background: var(--base);
	color: var(--white);
	overflow: hidden;
	isolation: isolate;
}
.hp7-hero::before {
	content: "";
	position: absolute; inset: 0; z-index: 0;
	background-image:
		radial-gradient(ellipse at 75% 30%, rgba(206, 170, 98, 0.18) 0%, transparent 55%),
		radial-gradient(ellipse at 20% 90%, rgba(53, 100, 242, 0.20) 0%, transparent 55%);
}
.hp7-hero__inner {
	position: relative; z-index: 2;
	padding-block: clamp(10rem, 14vw, 14rem) clamp(6rem, 8vw, 10rem);
	display: grid;
	grid-template-columns: 1.15fr 1fr;
	gap: var(--space-xxl);
	align-items: center;
}
.hp7-hero__eyebrow {
	display: inline-flex; align-items: center; gap: 1rem;
	font-family: monospace; font-size: var(--text-xs);
	letter-spacing: 0.14em; text-transform: uppercase;
	color: var(--secondary);
	margin-bottom: var(--space-m);
}
.hp7-hero__eyebrow::before {
	content: ""; display: inline-block; width: 3rem; height: 1px; background: var(--secondary);
}
.hp7-hero__title {
	font-size: clamp(3.6rem, 1.4rem + 3vw, 6rem);
	line-height: 1.02;
	font-weight: 300;
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-l);
	text-wrap: balance;
}
.hp7-hero__title em {
	font-style: normal;
	color: var(--secondary);
	font-weight: 700;
	display: block;
}
.hp7-hero__title-dot {
	color: var(--white);
}
.hp7-hero__lead {
	font-size: var(--text-l);
	line-height: 1.55;
	color: color-mix(in srgb, var(--white) 82%, transparent);
	max-width: 54ch;
	margin-bottom: var(--space-xxl);
}
.hp7-hero__actions { display: flex; gap: var(--space-m); flex-wrap: wrap; }

/* 3-tile CTA — vyšší tlačítka s ikonkami v jednom řádku */
.hp7-hero__actions--tiles {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-m);
	width: 100%;
}
.hp7-hero-tile {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	gap: 1.2rem;
	min-height: 14rem;
	padding: 2.2rem 1.6rem;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.16);
	border-radius: var(--radius);
	color: var(--white);
	text-decoration: none;
	transition: transform 180ms ease, border-color 180ms ease, background-color 180ms ease;
}
.hp7-hero-tile:hover,
.hp7-hero-tile:focus-visible {
	transform: translateY(-2px);
	border-color: var(--primary);
	background: rgba(255, 255, 255, 0.10);
	color: var(--white);
}
.hp7-hero-tile:focus-visible {
	outline: 2px solid var(--primary);
	outline-offset: 3px;
}
.hp7-hero-tile__icon {
	flex: 0 0 auto;
	width: 6.6rem;
	height: 6.6rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: var(--white);
}
.hp7-hero-tile__icon svg { width: 100%; height: 100%; display: block; }
.hp7-hero-tile__icon-accent { opacity: 0.55; }
.hp7-hero-tile__label {
	font-size: var(--text-m);
	font-weight: 600;
	line-height: 1.25;
	letter-spacing: -0.01em;
}

.hp7-hero__visual {
	position: relative;
	width: 100%;
	max-width: 42rem;
	margin-left: auto;
	aspect-ratio: 9/16;
}

.hp7-hero__social-proof {
	position: absolute; top: 7rem; left: 1rem; z-index: 4;
	background: var(--white);
	color: var(--base);
	border-radius: 999px;
	padding: 1rem 2rem 1rem 1rem;
	display: inline-flex; align-items: center; gap: 1rem;
	box-shadow: var(--box-shadow-l);
	font-size: var(--text-s); font-weight: 600;
	transition: opacity 0.45s ease;
}
/* Při přehrávání videa skrýt — stejně jako ostatní HUD prvky v .re-video. */
.hp7-hero__visual:has(.re-video--playing) .hp7-hero__social-proof {
	opacity: 0;
	pointer-events: none;
}
.hp7-hero__social-proof::before {
	content: "9/10"; display: inline-flex; align-items: center; justify-content: center;
	width: 3.6rem; height: 3.6rem; border-radius: 50%;
	background: var(--secondary); color: var(--white);
	font-weight: 800; font-size: 1.2rem; letter-spacing: 0;
}

/* Hero video karta: sdílená komponenta .re-video (assets/css/re-video.css). */

/* ---------- Services grid (5 dlaždic) ---------- */
/* Anchor scroll offset kvůli sticky headeru */
#jak-pomuzeme { scroll-margin-top: 8rem; }

.hp7-svc-lead {
	margin: var(--space-l) auto 0;
	max-width: 54ch;
	color: color-mix(in srgb, var(--base) 70%, transparent);
}
.hp7-sechead--wide { max-width: none; }
.hp7-sechead--wide .hp7-svc-lead { max-width: none; }
.hp7-svc-lead__link {
	color: inherit;
	text-decoration: underline;
	text-underline-offset: .3em;
	text-decoration-thickness: 1px;
	text-decoration-color: var(--secondary);
	transition: color .25s ease, text-decoration-color .25s ease;
}
.hp7-svc-lead__link:hover {
	color: var(--base);
	text-decoration-color: var(--primary);
}

/* ---------- Services grid v2 — split investor / majitel ---------- */
.hp7-svc-groups {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-xxl);
	margin-top: var(--space-xxl);
}

/* Mono label nad sloupečkem (Pro investory / Pro majitele) — jen na mobilu,
   na desktopu skryté (sloupce stojí vedle sebe a porovnání je čitelné z karet). */
.hp7-svc-group__label {
	display: none;
	margin: 0 0 var(--space-m);
	text-align: center;
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--base) 55%, transparent);
}

.hp7-svc-group__list {
	display: grid;
	gap: 1.2rem;
}

/* ---- Card baseline ---- */
.hp7-svc__card {
	position: relative;
	background: var(--white);
	border: 1px solid color-mix(in srgb, var(--base) 8%, transparent);
	border-radius: var(--radius);
	padding: 2.4rem 2.6rem;
	text-decoration: none;
	color: var(--base);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	transition: transform .3s ease, border-color .3s ease, box-shadow .3s ease, background .3s ease;
	overflow: hidden;
}
.hp7-svc__card:hover {
	transform: translateY(-2px);
	border-color: color-mix(in srgb, var(--base) 22%, transparent);
	box-shadow: 0 12px 36px -18px rgba(14, 28, 57, 0.18);
}

.hp7-svc__card-body {
	display: flex;
	flex-direction: column;
	gap: .4rem;
	min-width: 0;
}

.hp7-svc__title {
	font-size: clamp(1.8rem, 1.4rem + 0.4vw, 2.2rem);
	font-weight: 600;
	line-height: 1.2;
	letter-spacing: -0.005em;
	margin: 0;
	color: var(--base);
}

.hp7-svc__cta {
	font-size: var(--text-xs);
	font-weight: 600;
	color: var(--primary);
	display: inline-flex;
	align-items: center;
	gap: .6rem;
	flex-shrink: 0;
	letter-spacing: 0;
}
.hp7-svc__cta-arrow {
	font-size: 1.3em;
	line-height: 1;
	transition: transform .3s ease;
}
.hp7-svc__card:hover .hp7-svc__cta-arrow { transform: translateX(4px); }

/* Highlight chip */
.hp7-svc__highlight {
	display: inline-flex;
	align-items: flex-start;
	gap: .6rem;
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: 1.05rem;
	line-height: 1.2;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--base) 55%, transparent);
	font-weight: 600;
	margin-bottom: .2rem;
}
.hp7-svc__highlight::before {
	content: "";
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--secondary);
	flex-shrink: 0;
	margin-top: 0.2em;
}

/* ---- Featured card: navy bg, gold flag, larger ---- */
.hp7-svc__card--feature {
	background: var(--base);
	color: var(--white);
	border-color: var(--base);
	padding: 3.2rem 3rem;
	flex-direction: column;
	align-items: flex-start;
	justify-content: space-between;
	gap: 2rem;
	min-height: 28rem;
}
.hp7-svc__card--feature .hp7-svc__title {
	color: var(--white);
	font-size: clamp(2.6rem, 1.8rem + 1vw, 3.2rem);
	font-weight: 700;
	line-height: 1.1;
	letter-spacing: -0.01em;
}
.hp7-svc__card--feature .hp7-svc__cta {
	color: var(--secondary);
	font-size: var(--text-s);
}
.hp7-svc__card--feature .hp7-svc__highlight {
	color: color-mix(in srgb, var(--white) 75%, transparent);
}
.hp7-svc__card--feature .hp7-svc__highlight::before { background: var(--secondary); }
.hp7-svc__card--feature .hp7-svc__card-body { gap: 1rem; }
.hp7-svc__card--feature .hp7-svc__lead {
	font-size: var(--text-s);
	line-height: 1.55;
	color: color-mix(in srgb, var(--white) 75%, transparent);
	margin: 0;
	max-width: 36ch;
}

/* Owner featured = gold variant */
.hp7-svc__card--feature.hp7-svc__card--gold {
	background: var(--secondary);
	color: var(--base);
	border-color: var(--secondary);
}
.hp7-svc__card--gold .hp7-svc__title { color: var(--base); }
.hp7-svc__card--gold .hp7-svc__cta { color: var(--base); }
.hp7-svc__card--gold .hp7-svc__highlight { color: color-mix(in srgb, var(--base) 70%, transparent); }
.hp7-svc__card--gold .hp7-svc__highlight::before { background: var(--base); }
.hp7-svc__card--gold .hp7-svc__lead { color: color-mix(in srgb, var(--base) 78%, transparent); }
.hp7-svc__card--gold .hp7-svc__flag {
	background: var(--base);
	color: var(--secondary);
}
.hp7-svc__card--gold .hp7-svc__art { opacity: .22; }

/* Owner small-card CTA — gold */
.hp7-svc-group--owner .hp7-svc__card:not(.hp7-svc__card--feature) .hp7-svc__cta {
	color: color-mix(in srgb, var(--secondary) 80%, var(--base) 20%);
}

.hp7-svc__flag {
	position: absolute;
	top: 0;
	right: 2.4rem;
	background: var(--secondary);
	color: var(--base);
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: 1.05rem;
	letter-spacing: 0.18em;
	font-weight: 700;
	padding: .7rem 1.1rem .8rem;
	text-transform: uppercase;
}

.hp7-svc__art {
	position: absolute;
	inset: auto -3rem -3rem auto;
	width: 16rem;
	height: 16rem;
	pointer-events: none;
	opacity: .14;
}

/* ---- Passage row (Katalog / Pronájmy) ---- */
.hp7-svc-passages__heading {
	margin: var(--space-xxl) 0 var(--space-m);
	text-align: center;
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: var(--text-xs);
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--base) 55%, transparent);
}
.hp7-svc-passages {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
}
.hp7-svc-passage {
	background: var(--cream-100);
	border: 1px solid color-mix(in srgb, var(--base) 8%, transparent);
	border-radius: var(--radius);
	padding: 2.4rem 3rem;
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 2rem;
	text-decoration: none;
	color: var(--base);
	transition: background .3s ease, transform .3s ease;
}
.hp7-svc-passage:hover {
	background: var(--cream-200);
	transform: translateY(-2px);
}
.hp7-svc-passage__label {
	font-family: ui-monospace, Menlo, Consolas, monospace;
	font-size: 1.1rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--base) 55%, transparent);
	margin-bottom: .4rem;
	display: block;
}
.hp7-svc-passage__title {
	font-size: clamp(1.8rem, 1.4rem + 0.4vw, 2.2rem);
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1.2;
}
.hp7-svc-passage__arrow {
	width: 4.4rem;
	height: 4.4rem;
	border-radius: 50%;
	background: var(--white);
	display: grid;
	place-items: center;
	color: var(--base);
	font-size: 1.8rem;
	transition: background .3s ease, border-color .3s ease, transform .3s ease;
	flex-shrink: 0;
	border: 1px solid color-mix(in srgb, var(--base) 12%, transparent);
}
.hp7-svc-passage:hover .hp7-svc-passage__arrow {
	background: var(--secondary);
	border-color: var(--secondary);
	transform: translateX(2px);
}


/* ---------- ROI Rating section ---------- */
.hp7-rating {
	display: grid;
	grid-template-columns: 1.05fr 1fr;
	gap: var(--space-xxl);
	align-items: center;
}
.hp7-rating__visual {
	position: relative;
	width: 100%;
	max-width: 56rem;
	margin: 0 auto;
	perspective: 120rem;
}
.hp7-rating__flipper {
	/* button reset */
	appearance: none;
	background: transparent;
	border: 0;
	padding: 0;
	margin: 0;
	color: inherit;
	font: inherit;
	cursor: pointer;
	/* flip mechanika */
	position: relative;
	display: block;
	width: 100%;
	aspect-ratio: 1 / 1;
	transform-style: preserve-3d;
	transition: transform 0.9s cubic-bezier(0.22, 0.61, 0.36, 1);
	will-change: transform;
}
.hp7-rating__flipper.is-flipped {
	transform: rotateY(180deg);
}
.hp7-rating__flipper:focus-visible {
	outline: 2px solid var(--primary);
	outline-offset: 6px;
	border-radius: 1rem;
}
.hp7-rating__face {
	position: absolute;
	inset: 0;
	-webkit-backface-visibility: hidden;
	backface-visibility: hidden;
}
.hp7-rating__face--back {
	transform: rotateY(180deg);
}
.hp7-rating__face img,
.hp7-rating__visual img {
	width: 100%;
	height: auto;
	display: block;
}

/* Decentní pulzující majáček, který naznačuje, že je odznak interaktivní.
   Po prvním kliknutí dostává třídu .is-hidden a fade-out. */
.hp7-rating__hint {
	position: absolute;
	top: 6%;
	right: 4%;
	width: 4.4rem;
	height: 4.4rem;
	border-radius: 50%;
	display: grid;
	place-items: center;
	background: var(--secondary);
	color: var(--base);
	pointer-events: none;
	box-shadow: 0 0.6rem 1.6rem rgba(14, 28, 57, 0.18);
	animation: hp7-rating-hint-pulse 1.8s ease-out infinite;
	transition: opacity 0.4s ease, transform 0.4s ease;
	z-index: 2;
}
.hp7-rating__hint svg {
	width: 2rem;
	height: 2rem;
}
.hp7-rating__hint.is-hidden {
	opacity: 0;
	transform: scale(0.6);
	animation: none;
}

@keyframes hp7-rating-hint-pulse {
	0%   { box-shadow: 0 0.6rem 1.6rem rgba(14, 28, 57, 0.18), 0 0 0 0 rgba(206, 170, 98, 0.55); }
	70%  { box-shadow: 0 0.6rem 1.6rem rgba(14, 28, 57, 0.18), 0 0 0 1.6rem rgba(206, 170, 98, 0); }
	100% { box-shadow: 0 0.6rem 1.6rem rgba(14, 28, 57, 0.18), 0 0 0 0 rgba(206, 170, 98, 0); }
}

@media (prefers-reduced-motion: reduce) {
	.hp7-rating__flipper { transition: none !important; }
	.hp7-rating__hint { animation: none !important; }
}

/* ---------- Team CTA (image-backed) ---------- */
.hp7-team {
	position: relative;
	color: var(--white);
	overflow: hidden;
	isolation: isolate;
	padding-block: clamp(10rem, 14vw, 18rem);
	text-align: center;
}
.hp7-team::before {
	content: ""; position: absolute; inset: 0; z-index: -2;
	background: url('../images/tym-roi-estate.jpg') center/cover;
}
.hp7-team::after {
	content: ""; position: absolute; inset: 0; z-index: -1;
	background: linear-gradient(135deg, rgba(14, 28, 57, 0.85) 0%, rgba(14, 28, 57, 0.65) 100%);
}

/* ---------- Vitom ecosystem band ---------- */
.hp7-vitom-band {
	background: var(--cream-50);
	padding-block: var(--section-space-s);
	border-top: 1px solid color-mix(in srgb, var(--base) 8%, transparent);
	border-bottom: 1px solid color-mix(in srgb, var(--base) 8%, transparent);
}
.hp7-vitom-band__inner {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-l);
	flex-wrap: wrap;
	text-align: center;
}
.hp7-vitom-band__label {
	font-size: var(--text-l);
	font-weight: 500;
	color: color-mix(in srgb, var(--base) 78%, transparent);
	letter-spacing: -0.005em;
}
.hp7-vitom-band__logo {
	height: 3.6rem;
	width: auto;
	display: block;
}

/* ---------- Testimonials ---------- */
.hp7-testi-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-xl);
}
.hp7-testi {
	background: var(--white);
	border: 1px solid var(--border-color-dark);
	padding: var(--space-xl);
	border-radius: var(--radius);
	display: flex; flex-direction: column;
	gap: var(--space-l);
	position: relative;
}
.hp7-testi::before {
	content: "\201E";
	position: absolute; top: -3.5rem; left: 2rem;
	font-size: 9rem; line-height: 1;
	color: var(--secondary);
	font-family: "Source Sans 3"; font-weight: 700;
	pointer-events: none;
}
.hp7-testi p {
	margin: 0;
	font-size: var(--text-m);
	line-height: 1.6;
	color: color-mix(in srgb, var(--base) 85%, transparent);
	font-style: italic;
	padding-top: var(--space-xl);
}
.hp7-testi__author {
	margin-top: auto;
	padding-top: var(--space-m);
	border-top: 1px solid var(--border-color-light);
}
.hp7-testi__author b { display: block; color: var(--base); font-weight: 700; font-size: var(--text-m); }
.hp7-testi__author span { display: block; font-size: var(--text-s); color: color-mix(in srgb, var(--base) 60%, transparent); margin-top: .3rem; }

/* ---------- Podcast (navy) ---------- */
.hp7-podcast { display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--space-xxl); align-items: flex-start; }
.hp7-podcast__header { color: var(--white); }
.hp7-podcast__header h2 { color: var(--white); }
.hp7-podcast__platforms {
	display: flex; gap: var(--space-s); flex-wrap: wrap;
	margin-top: var(--space-l);
}
.hp7-podcast__platform {
	display: inline-flex; align-items: center; gap: .9rem;
	font-size: var(--text-xs); letter-spacing: 0.12em; text-transform: uppercase;
	padding: .8rem 1.6rem .8rem 1.2rem;
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 999px;
	color: color-mix(in srgb, var(--white) 80%, transparent);
	text-decoration: none;
	transition: var(--transition);
}
.hp7-podcast__platform svg { width: 1.8rem; height: 1.8rem; flex-shrink: 0; }
.hp7-podcast__platform:hover { border-color: var(--secondary); color: var(--secondary); }
.hp7-podcast__list { display: grid; gap: 1.2rem; }
.hp7-ep {
	position: relative; /* obal pro fallback `.hp7-ep__play` bez `.hp7-ep__thumb` */
	display: grid;
	grid-template-columns: 11rem 1fr auto;
	gap: var(--space-m);
	align-items: center;
	padding: var(--space-s);
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--radius);
	color: var(--white);
	text-decoration: none;
	transition: var(--transition);
}
.hp7-ep:hover { background: rgba(255, 255, 255, 0.08); border-color: rgba(206, 170, 98, 0.4); }
.hp7-ep__thumb {
	position: relative;
	display: block;
	width: 11rem;
	aspect-ratio: 16 / 9;
	border-radius: calc(var(--radius) * 0.6);
	overflow: hidden;
	background: rgba(255, 255, 255, 0.06);
	flex-shrink: 0;
}
.hp7-ep__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
.hp7-ep__play {
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
	width: 3.2rem; height: 3.2rem;
	border-radius: 50%;
	background: var(--secondary);
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--base); font-size: 1.1rem;
	box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.35);
}
.hp7-ep__play::after { content: "▶"; }
.hp7-ep:hover .hp7-ep__play { background: var(--white); }
.hp7-ep__body b { display: block; font-weight: 600; line-height: 1.35; font-size: var(--text-m); }
.hp7-ep__body span { display: block; font-size: var(--text-xs); color: color-mix(in srgb, var(--white) 55%, transparent); margin-top: .3rem; letter-spacing: 0.08em; text-transform: uppercase; }
.hp7-ep__time { font-variant-numeric: tabular-nums; font-weight: 600; color: var(--secondary); font-size: var(--text-s); padding-right: 1rem; }

/* ---------- E-book ---------- */
.hp7-ebook { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-xl); align-items: center; }
.hp7-ebook__cover {
	margin: 0 auto;
	max-width: 56rem;
}
.hp7-ebook__cover img { width: 100%; height: auto; display: block; }
.hp7-ebook__bullets { list-style: none; padding: 0; margin: var(--space-l) 0; display: grid; gap: 1.2rem; }
.hp7-ebook__bullets li { display: flex; gap: 1rem; align-items: flex-start; font-size: var(--text-m); }
.hp7-ebook__bullets li::before {
	content: ""; width: 2rem; height: 2rem; flex-shrink: 0; margin-top: .4rem;
	background: var(--secondary);
	-webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path d='M4 10l4 4 8-8' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
	        mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 20 20'><path d='M4 10l4 4 8-8' fill='none' stroke='black' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'/></svg>") center/contain no-repeat;
}

/* ---------- Listings (tabs + slider) ---------- */
.hp7-tabs { display: flex; gap: 0; justify-content: center; margin-bottom: var(--space-xl); }
.hp7-tab {
	background: none; border: 0; border-bottom: 2px solid transparent;
	padding: 1.2rem 2.4rem;
	font-size: var(--text-m); font-weight: 600;
	color: color-mix(in srgb, var(--base) 55%, transparent);
	cursor: pointer; transition: var(--transition); letter-spacing: 0.02em;
	white-space: nowrap;
}
.hp7-tab.is-active { color: var(--base); border-bottom-color: var(--primary); }

.hp7-listings {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(56rem, 1fr);
	gap: var(--space-l);
	overflow-x: auto;
	overflow-y: visible;
	scroll-snap-type: x mandatory;
	scroll-padding-inline: 0.5rem;
	padding: 2rem 0.5rem 3rem;
	margin: -2rem -0.5rem -1rem;
	scrollbar-width: none;
}
.hp7-listings::-webkit-scrollbar { display: none; }
.hp7-listing { scroll-snap-align: start; }

.hp7-slider__head {
	display: flex; justify-content: space-between; align-items: flex-end;
	gap: var(--space-m);
	margin-bottom: var(--space-xl);
}
.hp7-slider__nav {
	display: flex; gap: 0.8rem;
	flex-shrink: 0;
}
.hp7-slider__btn {
	width: 5rem; height: 5rem;
	border-radius: 50%;
	border: 1px solid var(--border-color-dark);
	background: var(--white);
	color: var(--base);
	cursor: pointer;
	display: grid; place-items: center;
	transition: var(--transition);
	font-size: 1.8rem;
}
.hp7-slider__btn:hover:not(:disabled) {
	background: var(--base);
	color: var(--white);
	border-color: var(--base);
	transform: translateY(-2px);
}
.hp7-slider__btn:disabled { opacity: 0.4; cursor: not-allowed; }

.hp7-slider-panel { display: none; }
.hp7-slider-panel.is-active { display: block; }

.hp7-listing {
	background: var(--white); border: 1px solid var(--border-color-dark); border-radius: var(--radius);
	overflow: hidden; display: grid; grid-template-columns: 28rem 1fr;
	transition: var(--transition);
	text-decoration: none;
	color: inherit;
}
.hp7-listing:hover { box-shadow: 0 6px 14px rgba(14, 28, 57, 0.08); transform: translateY(-1px); border-color: var(--primary); }
.hp7-listing__img { position: relative; align-self: stretch; min-height: 22rem; background-size: cover; background-position: center; }
.hp7-listing__loc { display: inline; }
.hp7-listing__loc svg { width: 1.4rem; height: 1.4rem; flex-shrink: 0; color: var(--secondary); display: inline-block; vertical-align: -0.2em; margin-right: 0.4rem; }
.hp7-listing__rating-badge {
	position: absolute; top: 1rem; left: 1rem;
	width: 7rem; height: 7rem;
	display: block;
	pointer-events: none;
	z-index: 2;
}
.hp7-listing__rating-badge img,
.hp7-listing__rating-badge .re-roi-rating-badge {
	width: 100%; height: 100%; display: block;
}
.hp7-listing__roi-badge {
	--re-roi-badge-size: 7rem;
}
.hp7-listing__body { padding: var(--space-m) var(--space-l); display: flex; flex-direction: column; gap: var(--space-xs); }
.hp7-listing__title {
	font-size: var(--text-l);
	font-weight: 700;
	line-height: 1.3;
	margin: 0;
	color: var(--base);
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
	min-height: 2.6em;
}
.hp7-listing__meta { display: flex; flex-direction: column; align-items: flex-start; gap: 0.8rem; margin-top: auto; padding-top: var(--space-m); border-top: 1px solid var(--border-color-light); }
.hp7-listing__price { font-size: var(--text-xl); font-weight: 700; color: var(--secondary); }
.hp7-listing__arrow { color: var(--primary); font-weight: 600; font-size: var(--text-s); display: inline-flex; align-items: center; gap: .4rem; }

/* ---------- Blog slider ---------- */
.hp7-blog {
	display: grid;
	grid-auto-flow: column;
	grid-auto-columns: minmax(38rem, 1fr);
	gap: var(--space-xl);
	overflow-x: auto;
	overflow-y: visible;
	scroll-snap-type: x mandatory;
	scroll-padding-inline: 0.5rem;
	padding: 2rem 0.5rem 3rem;
	margin: -2rem -0.5rem -1rem;
	scrollbar-width: none;
}
.hp7-blog::-webkit-scrollbar { display: none; }
.hp7-blog-card { scroll-snap-align: start; }
.hp7-blog-card {
	background: var(--white); border-radius: var(--radius); overflow: hidden;
	border: 1px solid var(--border-color-dark); display: flex; flex-direction: column;
	transition: var(--transition); text-decoration: none; color: inherit;
}
.hp7-blog-card:hover { box-shadow: 0 6px 14px rgba(14, 28, 57, 0.08); transform: translateY(-2px); border-color: var(--primary); }
.hp7-blog-card__img { aspect-ratio: 16/9; background-size: cover; background-position: center; background-color: var(--cream-100); }
.hp7-blog-card__body { padding: var(--space-xl); display: flex; flex-direction: column; gap: var(--space-m); flex-grow: 1; }
.hp7-blog-card__date { font-family: monospace; font-size: var(--text-xs); letter-spacing: 0.1em; text-transform: uppercase; color: color-mix(in srgb, var(--base) 55%, transparent); }
.hp7-blog-card h3 { margin: 0; font-size: var(--text-xl); font-weight: 700; line-height: 1.3; color: var(--base); }
.hp7-blog-card p { margin: 0; font-size: var(--text-m); color: color-mix(in srgb, var(--base) 72%, transparent); line-height: 1.5; }
.hp7-blog-card__cta { margin-top: auto; color: var(--primary); font-weight: 600; font-size: var(--text-s); display: inline-flex; align-items: center; gap: .4rem; }

/* ---------- Referral (image-backed) ---------- */
.hp7-referral {
	position: relative;
	color: var(--white);
	padding-block: clamp(8rem, 12vw, 14rem);
	overflow: hidden;
	isolation: isolate;
	text-align: center;
}
.hp7-referral::before {
	content: ""; position: absolute; inset: 0; z-index: -2;
	background: url('https://images.unsplash.com/photo-1600880292203-757bb62b4baf?w=1600&q=80') center/cover;
}
.hp7-referral::after {
	content: ""; position: absolute; inset: 0; z-index: -1;
	background: linear-gradient(180deg, rgba(14, 28, 57, 0.75) 0%, rgba(14, 28, 57, 0.9) 100%);
}
.hp7-referral__amount {
	display: inline-block;
	font-size: clamp(4rem, 3rem + 2vw, 6.4rem);
	font-weight: 700;
	color: var(--secondary);
	line-height: 1;
	margin-block: var(--space-m);
	letter-spacing: -0.02em;
}
.hp7-referral__amount small { display: block; font-size: var(--text-s); color: color-mix(in srgb, var(--white) 70%, transparent); font-weight: 400; letter-spacing: 0.1em; text-transform: uppercase; margin-top: .8rem; }

.hp7-referral__cta { margin-top: var(--space-l); }

.hp7-referral-steps {
	list-style: none;
	margin: var(--space-xl) auto 0;
	padding: 0;
	max-width: 96rem;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--space-m);
	text-align: left;
	counter-reset: hp7-ref-step;
}
.hp7-referral-steps__item {
	position: relative;
	padding: var(--space-l);
	background: color-mix(in srgb, var(--white) 6%, transparent);
	border: 1px solid color-mix(in srgb, var(--white) 14%, transparent);
	border-radius: var(--radius);
	display: grid;
	gap: .8rem;
	align-content: start;
}
.hp7-referral-steps__item::after {
	content: "→";
	position: absolute;
	right: -1.4rem;
	top: 50%;
	transform: translateY(-50%);
	font-size: 2rem;
	color: var(--secondary);
	z-index: 1;
}
.hp7-referral-steps__item:last-child::after { content: none; }
.hp7-referral-steps__num {
	font-size: var(--text-s);
	font-weight: 700;
	letter-spacing: 0.18em;
	color: var(--secondary);
}
.hp7-referral-steps__title {
	font-size: var(--text-l);
	font-weight: 700;
	color: var(--white);
	line-height: 1.25;
}
.hp7-referral-steps__desc {
	font-size: var(--text-s);
	color: color-mix(in srgb, var(--white) 75%, transparent);
	line-height: 1.5;
}

@media (max-width: 768px) {
	.hp7-referral-steps {
		grid-template-columns: 1fr;
		max-width: 48rem;
	}
	.hp7-referral-steps__item::after {
		content: "↓";
		right: 50%;
		top: auto;
		bottom: -1.6rem;
		transform: translateX(50%);
	}
}

.hp7-referral-form {
	max-width: 72rem;
	margin: var(--space-xl) auto 0;
	padding: clamp(2.4rem, 1.6rem + 2vw, 4rem);
	background: var(--white);
	color: var(--base);
	border-radius: calc(var(--radius) * 1.6);
	box-shadow: 0 2.4rem 6rem -1.6rem rgba(0, 0, 0, .45);
	text-align: left;
	display: grid;
	gap: var(--space-l);
	animation: hp7-referral-form-in .28s ease-out;
}
.hp7-referral-form[hidden] { display: none; }

.hp7-referral .re-form-success {
	max-width: 72rem;
	margin: var(--space-xl) auto 0;
	padding: clamp(3.2rem, 2.4rem + 2vw, 4.8rem);
	background: var(--white);
	color: var(--base);
	border-radius: calc(var(--radius) * 1.6);
	box-shadow: 0 2.4rem 6rem -1.6rem rgba(0, 0, 0, .45);
	animation: hp7-referral-form-in .28s ease-out;
}

@keyframes hp7-referral-form-in {
	from { opacity: 0; transform: translateY(-1rem); }
	to   { opacity: 1; transform: translateY(0); }
}

.hp7-referral-form__group { display: grid; gap: var(--space-m); }
.hp7-referral-form__heading {
	margin: 0;
	font-size: var(--text-s);
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--primary);
}
.hp7-referral-form__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-m); }
.hp7-referral-form .re-field,
.hp7-referral-form .re-field--textarea { display: grid; gap: .8rem; }
.hp7-referral-form label {
	font-size: var(--text-s);
	font-weight: 600;
	color: var(--base);
}
.hp7-referral-form__optional {
	font-weight: 400;
	color: color-mix(in srgb, var(--base) 55%, transparent);
	margin-left: .4rem;
}
.hp7-referral-form__hint {
	margin: 0;
	font-size: var(--text-s);
	color: color-mix(in srgb, var(--base) 65%, transparent);
	line-height: 1.5;
}
.hp7-referral-form input,
.hp7-referral-form textarea {
	width: 100%;
	padding: 1.4rem 1.6rem;
	font: inherit;
	font-size: var(--text-m);
	color: var(--base);
	background: var(--cream-50);
	border: 1px solid color-mix(in srgb, var(--base) 12%, transparent);
	border-radius: var(--radius);
	transition: border-color .2s, box-shadow .2s, background .2s;
}
.hp7-referral-form input::placeholder,
.hp7-referral-form textarea::placeholder { color: color-mix(in srgb, var(--base) 45%, transparent); }
.hp7-referral-form input:focus,
.hp7-referral-form textarea:focus {
	outline: none;
	border-color: var(--primary);
	background: var(--white);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 18%, transparent);
}
.hp7-referral-form textarea { min-height: 9rem; resize: vertical; }

.hp7-referral-form__submit {
	display: flex;
	flex-direction: column;
	gap: var(--space-m);
	align-items: flex-start;
}
.hp7-referral-form__submit .re-btn { align-self: flex-start; }
.hp7-referral-form__gdpr {
	margin: 0;
	font-size: var(--text-s);
	color: color-mix(in srgb, var(--base) 65%, transparent);
	line-height: 1.5;
}
.hp7-referral-form__gdpr a { color: var(--primary); text-decoration: underline; }

@media (max-width: 640px) {
	.hp7-referral-form__row { grid-template-columns: 1fr; }
}

/* ---------- Contact section (editorial) ---------- */
.hp7-contact-section { position: relative; overflow: hidden; isolation: isolate; }
.hp7-contact-section__inner { position: relative; z-index: 1; }
.hp7-contact-section__watermark {
	position: absolute;
	right: -4rem;
	bottom: -8rem;
	z-index: 0;
	font-family: Georgia, "Times New Roman", serif;
	font-style: italic;
	font-weight: 400;
	font-size: clamp(36rem, 52vw, 72rem);
	line-height: 0.8;
	letter-spacing: -0.06em;
	color: var(--secondary);
	opacity: 0.08;
	pointer-events: none;
	user-select: none;
}

/* Header — asymmetric editorial layout */
.hp7-contact-head {
	display: grid;
	grid-template-columns: 1.25fr 1fr;
	gap: var(--space-xxl);
	align-items: end;
	margin-bottom: clamp(var(--space-xxl), 9vw, 9.6rem);
}
.hp7-contact-head__eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 1.1rem;
	margin-bottom: var(--space-l);
	font-size: 1.25rem;
	font-weight: 700;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: color-mix(in srgb, var(--base) 65%, transparent);
}
.hp7-contact-head__arrow {
	width: 2rem;
	height: 2rem;
	color: var(--secondary);
	flex-shrink: 0;
}

.hp7-contact-steps {
	list-style: none;
	padding: 0;
	margin: 0;
	display: grid;
	gap: 0;
	counter-reset: step;
}
.hp7-contact-steps li {
	display: grid;
	grid-template-columns: auto 1fr;
	column-gap: 1.6rem;
	align-items: baseline;
	padding: 1.2rem 0;
	border-top: 1px dashed color-mix(in srgb, var(--base) 22%, transparent);
	transition: padding-left .35s ease;
}
.hp7-contact-steps li:last-child { border-bottom: 1px dashed color-mix(in srgb, var(--base) 22%, transparent); }
.hp7-contact-steps li:hover { padding-left: .6rem; }
.hp7-contact-steps b {
	font-size: 1.8rem;
	font-weight: 300;
	font-variant-numeric: tabular-nums;
	color: var(--secondary);
	letter-spacing: 0.04em;
}
.hp7-contact-steps span {
	font-size: var(--text-m);
	font-weight: 600;
	color: var(--base);
}

.hp7-contact-head__lead { min-width: 0; }
.hp7-contact-head__title {
	margin: 0;
	font-size: var(--h2-size);
	font-weight: 600;
	letter-spacing: -0.01em;
	line-height: 1.15;
	color: var(--base);
}
.hp7-contact-head__title em {
	font-style: normal;
	font-weight: inherit;
	color: var(--primary);
}
.hp7-contact-head__sub {
	margin: var(--space-l) 0 0;
	max-width: 54ch;
	font-size: var(--text-l);
	line-height: 1.55;
	color: color-mix(in srgb, var(--base) 68%, transparent);
}

/* Layout grid */
.hp7-contact {
	display: grid;
	grid-template-columns: 1.25fr 1fr;
	gap: var(--space-xxl);
	align-items: start;
}

/* Form — white card with gold accent strip and underline-only fields */
.hp7-contact__form {
	position: relative;
	display: grid;
	gap: var(--space-l);
	background: var(--white);
	padding: clamp(var(--space-l), 3.2vw, var(--space-xxl)) clamp(var(--space-l), 3.2vw, var(--space-xl));
	border-radius: calc(var(--radius) * 1.4);
	box-shadow:
		0 1px 0 rgba(14, 28, 57, 0.04),
		0 30px 60px -30px rgba(14, 28, 57, 0.18);
	overflow: hidden;
}
.hp7-contact__form::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 3px;
	background: linear-gradient(90deg, var(--secondary) 0%, color-mix(in srgb, var(--secondary) 55%, transparent) 55%, transparent 100%);
}
.hp7-contact__form .re-field,
.hp7-contact__form .re-field--select,
.hp7-contact__form .re-field--textarea { display: grid; gap: .8rem; }
.hp7-contact__form label {
	font-size: clamp(1.5rem, calc(0.208vw + 1.433rem), 1.7rem);
	font-weight: 600;
	color: var(--base);
	letter-spacing: 0;
	text-transform: none;
}
.hp7-contact__form input,
.hp7-contact__form select,
.hp7-contact__form textarea {
	width: 100%;
	background: var(--white);
	border: 1px solid var(--border-color-dark, rgba(14, 28, 57, 0.15));
	border-radius: var(--radius);
	color: var(--base);
	padding: 1.4rem 1.6rem;
	font: inherit;
	font-size: var(--text-m);
	transition: var(--transition);
}
.hp7-contact__form input::placeholder,
.hp7-contact__form textarea::placeholder {
	color: color-mix(in srgb, var(--base) 45%, transparent);
}
.hp7-contact__form input:focus,
.hp7-contact__form select:focus,
.hp7-contact__form textarea:focus {
	outline: none;
	border-color: var(--primary);
	box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary) 20%, transparent);
}
.hp7-contact__form textarea { min-height: 12rem; resize: vertical; }
.hp7-contact__row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-m); }
.hp7-contact__check {
	display: flex;
	gap: 1.1rem;
	align-items: flex-start;
	font-size: var(--text-s);
	line-height: 1.5;
	color: color-mix(in srgb, var(--base) 70%, transparent);
	padding: 1.4rem 1.6rem;
	background: color-mix(in srgb, var(--secondary) 8%, transparent);
	border-radius: calc(var(--radius) * 0.8);
}
.hp7-contact__check input { width: auto; accent-color: var(--secondary); margin-top: .3rem; }
.hp7-contact__check a { color: var(--primary); font-weight: 600; text-decoration: underline; text-underline-offset: 3px; }
.hp7-contact__submit { display: flex; flex-direction: column; gap: var(--space-s); }
.hp7-contact__gdpr {
	margin: 0;
	font-size: var(--text-xs);
	line-height: 1.5;
	color: color-mix(in srgb, var(--base) 55%, transparent);
}
.hp7-contact__gdpr a { color: var(--primary); text-decoration: underline; text-underline-offset: 2px; }

/* Aside — navy editorial panel */
.hp7-contact__aside {
	position: relative;
	background: var(--base);
	color: var(--white);
	border-radius: calc(var(--radius) * 1.4);
	padding: clamp(var(--space-l), 3vw, var(--space-xl));
	overflow: hidden;
	isolation: isolate;
}
.hp7-contact__aside::before {
	content: "";
	position: absolute;
	top: 0; bottom: 0; left: 0;
	width: 4px;
	background: var(--secondary);
	border-radius: 0 4px 4px 0;
}
.hp7-contact__aside::after {
	content: "";
	position: absolute;
	right: -12rem;
	bottom: -12rem;
	width: 28rem;
	height: 28rem;
	border-radius: 50%;
	background: radial-gradient(circle at center, color-mix(in srgb, var(--secondary) 28%, transparent) 0%, transparent 68%);
	z-index: -1;
	pointer-events: none;
}
.hp7-contact__aside-mark {
	position: absolute;
	top: -2rem;
	right: 1.6rem;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 16rem;
	line-height: 1;
	color: var(--secondary);
	opacity: 0.18;
	pointer-events: none;
	user-select: none;
}
.hp7-contact__aside-badge {
	display: inline-flex;
	align-items: center;
	gap: .9rem;
	padding: .7rem 1.3rem;
	background: color-mix(in srgb, var(--secondary) 16%, transparent);
	color: var(--secondary);
	border: 1px solid color-mix(in srgb, var(--secondary) 35%, transparent);
	border-radius: 999px;
	font-size: 1.2rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin-bottom: var(--space-l);
}
.hp7-contact__aside-pulse {
	position: relative;
	width: .8rem; height: .8rem;
	border-radius: 50%;
	background: var(--secondary);
	box-shadow: 0 0 0 0 color-mix(in srgb, var(--secondary) 65%, transparent);
	animation: hp7-contact-pulse 2s ease-out infinite;
}
.hp7-contact__aside h3 {
	margin: 0 0 var(--space-m);
	font-size: clamp(2.4rem, 1.6rem + 1.2vw, 3.2rem);
	line-height: 1.05;
	letter-spacing: -0.02em;
	color: var(--white);
	font-weight: 700;
}
.hp7-contact__person {
	display: flex;
	gap: var(--space-m);
	align-items: center;
	padding: var(--space-m) 0;
}
.hp7-contact__avatar--support {
	width: 6.4rem; height: 6.4rem; border-radius: 50%;
	background: color-mix(in srgb, var(--secondary) 14%, transparent);
	border: 1px solid color-mix(in srgb, var(--secondary) 32%, transparent);
	color: var(--secondary);
	display: inline-flex; align-items: center; justify-content: center;
	flex-shrink: 0;
}
.hp7-contact__avatar--support svg { width: 3rem; height: 3rem; }
.hp7-contact__person b { display: block; color: var(--white); font-weight: 700; font-size: var(--text-m); letter-spacing: -0.005em; }
.hp7-contact__person span { display: block; font-size: var(--text-s); color: var(--secondary); margin-top: .2rem; }
.hp7-contact__person span small {
	display: block;
	font-size: 1.2rem;
	color: color-mix(in srgb, var(--white) 55%, transparent);
	letter-spacing: 0.12em;
	text-transform: uppercase;
	margin-top: .4rem;
	font-weight: 600;
}
.hp7-contact__details {
	display: grid;
	gap: 0;
	padding-top: var(--space-m);
	border-top: 1px solid color-mix(in srgb, var(--white) 15%, transparent);
	font-size: var(--text-s);
	color: color-mix(in srgb, var(--white) 80%, transparent);
}
.hp7-contact__details a {
	color: color-mix(in srgb, var(--white) 88%, transparent);
	text-decoration: none;
	display: flex;
	gap: 1.4rem;
	align-items: center;
	padding: 1.4rem 0;
	border-bottom: 1px dashed color-mix(in srgb, var(--white) 12%, transparent);
	transition: color .3s ease, padding .3s ease;
	font-weight: 500;
	font-size: var(--text-m);
}
.hp7-contact__details a:last-child { border-bottom: 0; }
.hp7-contact__details a:hover { color: var(--secondary); padding-left: .6rem; }
.hp7-contact__icon {
	width: 4rem; height: 4rem; flex-shrink: 0;
	border-radius: 50%;
	background: color-mix(in srgb, var(--secondary) 14%, transparent);
	color: var(--secondary);
	display: inline-flex; align-items: center; justify-content: center;
	transition: background .3s ease, color .3s ease, transform .3s ease;
}
.hp7-contact__icon svg { width: 1.8rem; height: 1.8rem; display: block; }
.hp7-contact__details a:hover .hp7-contact__icon {
	background: var(--secondary);
	color: var(--base);
	transform: rotate(-6deg) scale(1.05);
}

@keyframes hp7-contact-pulse {
	0%   { box-shadow: 0 0 0 0 color-mix(in srgb, var(--secondary) 55%, transparent); }
	80%  { box-shadow: 0 0 0 12px color-mix(in srgb, var(--secondary) 0%, transparent); }
	100% { box-shadow: 0 0 0 0 color-mix(in srgb, var(--secondary) 0%, transparent); }
}
@media (prefers-reduced-motion: reduce) {
	.hp7-contact__aside-pulse { animation: none; }
}

/* ---------- Press marquee ---------- */
.hp7-press {
	padding-block: var(--space-xxl);
	background: var(--cream-100);
	overflow: hidden;
}
.hp7-press__label { text-align: center; font-family: monospace; font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase; color: color-mix(in srgb, var(--base) 55%, transparent); margin-bottom: var(--space-l); }
.hp7-press__track {
	display: flex; gap: var(--space-xxl);
	animation: hp7-press-scroll 40s linear infinite;
	width: max-content;
}
.hp7-press__logo {
	font-weight: 700; font-size: var(--text-l);
	color: color-mix(in srgb, var(--base) 55%, transparent);
	letter-spacing: -0.01em;
	white-space: nowrap;
}
@keyframes hp7-press-scroll {
	from { transform: translateX(0); }
	to   { transform: translateX(-50%); }
}
@media (prefers-reduced-motion: reduce) {
	.hp7-press__track { animation: none; flex-wrap: wrap; justify-content: center; }
}

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
	.hp7-hero__inner,
	.hp7-rating,
	.hp7-ebook,
	.hp7-podcast,
	.hp7-contact,
	.hp7-contact-head { grid-template-columns: 1fr; }
	.hp7-contact-head { gap: var(--space-l); align-items: start; }
	.hp7-contact-section__watermark { font-size: clamp(24rem, 80vw, 42rem); right: -6rem; bottom: -4rem; }
	/* Tablet/mobil: služby do jednoho sloupce, ať mají featured karty prostor */
	.hp7-svc-groups { grid-template-columns: 1fr; gap: var(--space-xl); }
	.hp7-svc-passages { grid-template-columns: 1fr; }
	/* Když sloupce stojí pod sebou, ukaž centrovaný label nad každým z nich. */
	.hp7-svc-group__label { display: block; }
	.hp7-listings { grid-auto-columns: 85%; }
	.hp7-testi-grid { grid-template-columns: 1fr; }
	.hp7-rating__visual {
		width: min(88vw, 44rem);
		max-width: none;
	}
	.hp7-hero__visual { max-width: 42rem; margin: 0 auto; }
}
@media (max-width: 560px) {
	.hp7-listing { grid-template-columns: 1fr; }
	.hp7-listing__img { min-height: 20rem; }
	.hp7-contact__row { grid-template-columns: 1fr; }
	.hp7-slider__nav { display: none; }

	/* Mobil: kompaktnější karty + jednosloupcový stack (eyebrow/titulek nad CTA) */
	.hp7-svc__card {
		padding: 2rem 2rem;
		flex-direction: column;
		align-items: flex-start;
		gap: 1.2rem;
	}
	.hp7-svc__card--feature { padding: 5rem 2.4rem 2.6rem; min-height: 24rem; gap: 2rem; }
	.hp7-svc-passage { padding: 2rem 2.2rem; }
	.hp7-svc__art { width: 12rem; height: 12rem; inset: auto -2rem -2rem auto; }
	.hp7-svc__flag { right: 1.6rem; }

	/* #17 — podcast: thumbnail na vlastní řádek */
	.hp7-ep {
		grid-template-columns: 1fr auto;
	}
	.hp7-ep__thumb {
		grid-column: 1 / -1;
		width: 100%;
		aspect-ratio: 16 / 9;
	}
	.hp7-ep__time { padding-right: 0; }

	/* #19 — blog slider: jedna karta + peek další karty (~10 %) */
	.hp7-blog { grid-auto-columns: 78vw; gap: var(--space-m); }
	.hp7-listings { grid-auto-columns: 78vw; gap: var(--space-m); }

	/* #18 — ebook: grid items nesmí expandovat přes min-content tlačítka */
	.hp7-ebook > * { min-width: 0; }
	.hp7-ebook .re-btn { width: 100%; justify-content: center; }

	/* #20 — referral toggle tlačítko přes celou šířku */
	.hp7-referral__cta .re-btn { width: 100%; justify-content: center; }

	/* Hero CTA tiles — stack na mobilu, ikona vlevo + label vpravo */
	.hp7-hero__actions--tiles { grid-template-columns: 1fr; gap: 1.2rem; }
	.hp7-hero-tile {
		flex-direction: row;
		justify-content: flex-start;
		text-align: left;
		min-height: 8.4rem;
		padding: 1.4rem 1.6rem;
		gap: 1.4rem;
	}
	.hp7-hero-tile__icon { width: 5.2rem; height: 5.2rem; }
}

/* Lišta parametrů — kompaktní bez ikon */
.re-featurestrip-band {
	padding-block: var(--section-space-xs);
}
@media (max-width: 560px) {
	.re-featurestrip-band {
		padding-block: 1rem;
	}
}

/* Sekční h2 — sjednocení dle Design Systému (Homepage V2):
   jednolitá váha 700, em je jen barevné zvýraznění (žádný mix tenké + tučné). */
.homepage-v7 {
	/* Větší H2 (až 50px na desktopu) a vzdušnější sekce */
	--h2-size: clamp(3rem, 1.8rem + 2.4vw, 5rem);
	--section-padding-block: var(--section-space-xl);
}
.homepage-v7 .re-h2 {
	font-size: var(--h2-size);
	font-weight: 700;
	letter-spacing: -0.01em;
	line-height: 1.15;
}
.homepage-v7 .re-h2 em { font-weight: inherit; }
