/**
 * 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: 3.84rem;
	--section-space-xxl: 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(--space-xxl); 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-m); }

/* ---------- 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(4.4rem, 2rem + 4vw, 7.8rem);
	line-height: 0.98;
	font-weight: 300;
	letter-spacing: -0.02em;
	margin: 0 0 var(--space-l);
}
.hp7-hero__title em {
	font-style: normal;
	color: var(--secondary);
	font-weight: 700;
	display: block;
}
.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; }

.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 split ---------- */
.hp7-services {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: var(--space-xl);
	margin-top: var(--space-xxl);
}
.hp7-service {
	position: relative;
	border-radius: var(--radius);
	overflow: hidden;
	min-height: 38rem;
	color: var(--white);
	display: flex; flex-direction: column; justify-content: flex-end;
	padding: var(--space-xxl);
	text-decoration: none;
	isolation: isolate;
	transition: transform .35s ease;
}
.hp7-service:hover,
.hp7-service:focus-visible { color: var(--white); transform: translateY(-6px); }
.hp7-service--sell:hover,
.hp7-service--sell:focus-visible { color: var(--base); }
.hp7-service__eyebrow { font-family: monospace; font-size: var(--text-xs); letter-spacing: 0.14em; text-transform: uppercase; color: var(--secondary); margin-bottom: var(--space-s); }
.hp7-service__title { font-size: clamp(2.8rem, 1.8rem + 1.5vw, 4rem); font-weight: 700; line-height: 1.05; margin: 0 0 var(--space-l); }
.hp7-service__cta { display: inline-flex; align-items: center; gap: .8rem; font-weight: 600; font-size: var(--text-m); border-bottom: 1px solid rgba(255, 255, 255, 0.4); padding-bottom: .6rem; width: max-content; }
.hp7-service__cta::after { content: "→"; font-size: 1.4em; transition: transform .35s ease; }
.hp7-service:hover .hp7-service__cta::after { transform: translateX(8px); }
.hp7-service__art { position: absolute; inset: 0; z-index: -1; overflow: hidden; pointer-events: none; }
.hp7-service__art svg { width: 100%; height: 100%; display: block; }

/* Variant solid-art (default pro v7) */
.hp7-service--invest { background: var(--base); color: var(--white); }
.hp7-service--sell   { background: var(--secondary); color: var(--base); }
.hp7-service--sell .hp7-service__eyebrow { color: var(--base); opacity: .7; }
.hp7-service--sell .hp7-service__cta { border-bottom-color: rgba(14, 28, 57, 0.35); }

.hp7-service--invest .hp7-service__art { color: var(--secondary); opacity: 1; }
.hp7-service--invest .hp7-service__windows { fill: var(--secondary); opacity: 0.5; }
.hp7-service--sell .hp7-service__art { color: var(--base); opacity: 0.85; }

/* ---------- 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;
	aspect-ratio: 1/1;
	max-width: 56rem;
	/* Vše uvnitř se škáluje k této velikosti (kroužek, chipsy, core). */
	container-type: inline-size;
}
.hp7-rating__ring {
	position: absolute; inset: 0;
	border: max(1rem, 2.5cqi) solid var(--cream-200);
	border-radius: 50%;
}
.hp7-rating__ring--gold {
	position: absolute; inset: 0;
	border-radius: 50%;
	background: conic-gradient(var(--secondary) 0deg 280deg, transparent 280deg 360deg);
	-webkit-mask: radial-gradient(circle, transparent 62%, #000 62%, #000 80%, transparent 80%);
	mask: radial-gradient(circle, transparent 62%, #000 62%, #000 80%, transparent 80%);
}
.hp7-rating__core {
	position: absolute; inset: 20%;
	background: var(--white);
	border-radius: 50%;
	display: flex; align-items: center; justify-content: center; flex-direction: column;
	box-shadow: var(--box-shadow-l);
	text-align: center;
	padding: clamp(1.2rem, 5cqi, 3rem);
}
.hp7-rating__core b      { font-size: clamp(2.8rem, 12cqi, 6.4rem); font-weight: 700; line-height: 1; color: var(--base); }
.hp7-rating__core span   { font-size: clamp(1rem, 3cqi, 1.42rem); text-transform: uppercase; letter-spacing: 0.12em; color: var(--secondary); font-weight: 600; margin-top: .6rem; }
.hp7-rating__core em     { font-style: normal; font-size: clamp(.95rem, 2.6cqi, 1.26rem); color: color-mix(in srgb, var(--base) 60%, transparent); margin-top: .8rem; }

.hp7-rating__chip {
	position: absolute;
	background: var(--white);
	padding: clamp(.5rem, 1.8cqi, 1rem) clamp(.8rem, 3cqi, 1.6rem);
	border-radius: 999px;
	box-shadow: var(--box-shadow-m);
	font-size: clamp(1.05rem, 3cqi, 1.42rem);
	font-weight: 600;
	color: var(--base);
	display: inline-flex; align-items: center; gap: clamp(.3rem, 1.4cqi, .8rem);
	white-space: nowrap;
}
.hp7-rating__chip i { font-style: normal; font-size: 1.4em; line-height: 1; }
.hp7-rating__chip--1 { top: 4%;  left: 2%; }
.hp7-rating__chip--2 { top: -2%; right: 6%; }
.hp7-rating__chip--3 { top: 44%; right: -4%; }
.hp7-rating__chip--4 { bottom: 4%; right: 0%; }
.hp7-rating__chip--5 { bottom: -2%; left: 20%; }
.hp7-rating__chip--6 { top: 40%; left: -6%; }

/* ---------- 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%);
}

/* ---------- Stats (why trust us) ---------- */
.hp7-stats-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	border-top: 1px solid rgba(14, 28, 57, 0.14);
	border-bottom: 1px solid rgba(14, 28, 57, 0.14);
	margin-top: var(--space-xxl);
}
.hp7-stat {
	padding: var(--space-xl) var(--space-l);
	border-left: 1px solid rgba(14, 28, 57, 0.14);
}
.hp7-stat:first-child { border-left: 0; }
.hp7-stat b {
	display: block;
	font-size: clamp(4rem, 3rem + 2vw, 6.4rem);
	font-weight: 700; color: var(--base);
	line-height: 1;
	letter-spacing: -0.02em;
}
.hp7-stat span {
	display: block; margin-top: 1rem;
	font-size: var(--text-s);
	color: color-mix(in srgb, var(--base) 70%, transparent);
	line-height: 1.4;
}

/* ---------- 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 {
	display: grid;
	grid-template-columns: 7rem 1fr auto;
	gap: var(--space-m);
	align-items: center;
	padding: var(--space-m);
	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__play {
	width: 5rem; height: 5rem;
	border-radius: 50%;
	background: var(--secondary);
	display: inline-flex; align-items: center; justify-content: center;
	color: var(--base); font-size: 1.6rem; margin-left: 1rem;
}
.hp7-ep__play::after { content: "▶"; }
.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 {
	aspect-ratio: 3/4;
	max-width: 32rem;
	margin: 0 auto;
	border-radius: var(--radius);
	overflow: hidden;
	position: relative;
	background: var(--base);
}
.hp7-ebook__cover img { width: 100%; height: 100%; object-fit: cover; 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;
}
.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-flex; align-items: center; gap: .5rem; }
.hp7-listing__loc svg { width: 1.4rem; height: 1.4rem; flex-shrink: 0; color: var(--secondary); }
.hp7-listing__verified {
	position: absolute; top: 1rem; left: 1rem;
	background: var(--secondary); color: var(--base);
	font-size: var(--text-xs); font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
	padding: .6rem 1rem; border-radius: 4px;
	display: inline-flex; align-items: center; gap: .5rem;
}
.hp7-listing__verified::before { content: "✓"; font-weight: 800; }
.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); }
.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; }

/* ---------- 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: clamp(4.2rem, 2.2rem + 3.6vw, 6.8rem);
	line-height: 0.98;
	letter-spacing: -0.028em;
	font-weight: 700;
	color: var(--base);
}
.hp7-contact-head__title em {
	font-style: italic;
	font-family: Georgia, "Times New Roman", serif;
	font-weight: 400;
	color: var(--secondary);
	padding-right: .1em;
}
.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; }
	.hp7-services { grid-template-columns: 1fr; }
	.hp7-listings { grid-auto-columns: 85%; }
	.hp7-testi-grid { grid-template-columns: 1fr; }
	.hp7-stats-grid { grid-template-columns: 1fr 1fr; }
	.hp7-stat:nth-child(3) { border-left: 0; }
	.hp7-stat:nth-child(n+3) { border-top: 1px solid rgba(14, 28, 57, 0.14); }
	/* Na mobilu ať se kroužek plynule zmenšuje, ale vezme většinu šířky — okraje
	   nechají místo chipsům, které přesahují ring o pár procent. */
	.hp7-rating__visual {
		margin: 0 auto;
		width: min(88vw, 44rem);
		max-width: none;
	}
	.hp7-hero__visual { max-width: 42rem; margin: 0 auto; }
}
@media (max-width: 560px) {
	.hp7-stats-grid { grid-template-columns: 1fr; }
	.hp7-stat { border-left: 0; }
	.hp7-stat + .hp7-stat { border-top: 1px solid rgba(14, 28, 57, 0.14); }
	.hp7-listing { grid-template-columns: 1fr; }
	.hp7-listing__img { min-height: 20rem; }
	.hp7-contact__row { grid-template-columns: 1fr; }

	/* Service karty: art (SVG ikona) zmenšit na horní polovinu, text dole. */
	.hp7-service { min-height: 36rem; padding: var(--space-xl); }
	.hp7-service__art { inset: 0 0 auto 0; height: 55%; }
	.hp7-service__art svg { height: 100%; width: 100%; }
	.hp7-service--invest .hp7-service__art { opacity: 0.85; }
	.hp7-service--sell .hp7-service__art { opacity: 0.7; }
}
