/* R2 Immobilien — Seiten- & Komponenten-Stile (Ergänzung zu r2.css):
   Hero, Impressum, Angebots-Slider, Objekt-Detailseite, Responsive. */

/* ---------------------------------------------------------- Hero (Variante A) */
.hero-a { position: relative; height: 800px; padding: 0; overflow: hidden; }
.hero-a img.bg { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-a .scrim { position: absolute; inset: 0; background: linear-gradient(to top, rgba(15, 14, 11, 0.72) 0%, rgba(15, 14, 11, 0.25) 45%, rgba(15, 14, 11, 0.12) 100%); }
.hero-a .content { position: absolute; left: 0; right: 0; bottom: 0; padding-bottom: 88px; color: #fff; }
.hero-a .eyebrow { color: rgba(255, 255, 255, 0.75); }
.hero-a h1 { color: #faf9f6; max-width: 13ch; margin-top: 24px; }
.hero-a .sub { font-size: 19px; color: rgba(255, 255, 255, 0.82); max-width: 52ch; margin-top: 28px; text-wrap: pretty; }
.hero-a .ctas { display: flex; gap: 16px; margin-top: 44px; }

/* Hero-Einblendung beim Laden: gestaffeltes Text-Fade-up + dezenter Kamera-Zoom.
   Nur transform/opacity (kein CLS); das Hintergrundbild paintet sofort (LCP bleibt gut).
   In @media reduced-motion gekapselt -> bei Bewegungsreduktion erscheint alles sofort. */
@media (prefers-reduced-motion: no-preference) {
	@keyframes hero-rise {
		from { opacity: 0; transform: translateY(28px); }
		to { opacity: 1; transform: none; }
	}
	@keyframes hero-zoom {
		from { transform: scale(1.06); }
		to { transform: scale(1); }
	}
	.hero-a img.bg { animation: hero-zoom 1.6s cubic-bezier(0.22, 0.61, 0.36, 1) both; }
	.hero-a .eyebrow,
	.hero-a h1,
	.hero-a .sub,
	.hero-a .ctas { animation: hero-rise 0.8s cubic-bezier(0.22, 0.61, 0.36, 1) both; }
	.hero-a .eyebrow { animation-delay: 0.15s; }
	.hero-a h1 { animation-delay: 0.28s; }
	.hero-a .sub { animation-delay: 0.42s; }
	.hero-a .ctas { animation-delay: 0.56s; }
}

/* -------------------------------------------------- Referenz-/Beleglink */
.cred-link {
	color: var(--ink);
	text-decoration: none;
	border-bottom: 1px solid var(--line);
	white-space: nowrap;
	transition: border-color 0.2s;
}
.cred-link:hover { border-color: var(--ink); }

/* --------------------------------------------------------- Angebots-Slider */
.objects-section { padding: 120px 0; }
.objects-slider {
	display: flex;
	gap: 28px;
	margin-top: 64px;
	overflow-x: auto;
	scroll-snap-type: x mandatory;
	-webkit-overflow-scrolling: touch;
	padding-bottom: 10px;
	scrollbar-width: thin;
	scrollbar-color: var(--line) transparent;
}
.objects-slider::-webkit-scrollbar { height: 6px; }
.objects-slider::-webkit-scrollbar-thumb { background: var(--line); border-radius: 3px; }

.obj-card {
	flex: 0 0 clamp(280px, 78vw, 364px);
	scroll-snap-align: start;
	background: var(--surface);
	border: 1px solid var(--line);
	display: flex;
	flex-direction: column;
}
.obj-card-media { position: relative; display: block; aspect-ratio: 3 / 2; overflow: hidden; background: var(--ink); }
.obj-card-media img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
.obj-card:hover .obj-card-media img { transform: scale(1.04); }
.obj-card-noimg { display: flex; align-items: center; justify-content: center; height: 100%; font-family: var(--serif); font-style: italic; font-size: 52px; color: var(--dark-ink-2); }
.obj-badge {
	position: absolute; top: 14px; left: 14px;
	background: rgba(25, 24, 19, 0.82); color: var(--dark-ink);
	font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
	font-weight: 500; padding: 6px 12px;
}
.obj-card-body { padding: 24px 26px 26px; display: flex; flex-direction: column; gap: 10px; flex: 1; }
.obj-card-loc { font-size: 12px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); }
.obj-card-title { font-size: 25px; line-height: 1.15; }
.obj-card-title a { text-decoration: none; transition: color 0.15s; }
.obj-card-title a:hover { color: var(--ink-2); }
.obj-card-facts { display: flex; flex-wrap: wrap; align-items: baseline; gap: 6px 16px; font-size: 14.5px; color: var(--ink-2); }
.obj-card-price { font-family: var(--serif); font-size: 22px; font-weight: 600; color: var(--ink); margin-left: auto; }
.obj-card-link { margin-top: auto; padding-top: 10px; font-size: 14px; font-weight: 500; text-decoration: none; color: var(--ink); }
.obj-card-link span { transition: margin-left 0.2s; display: inline-block; }
.obj-card-link:hover span { margin-left: 4px; }

.objects-controls { display: flex; gap: 12px; margin-top: 32px; }
.obj-nav { width: 48px; height: 48px; border: 1px solid var(--ink); background: transparent; color: var(--ink); cursor: pointer; font-size: 18px; line-height: 1; transition: background 0.2s, color 0.2s, opacity 0.2s; }
.obj-nav:hover:not(:disabled) { background: var(--ink); color: var(--bg); }
.obj-nav:disabled { opacity: 0.25; cursor: default; }

/* --------------------------------------------------------- Objekt-Detailseite */
.obj-detail { padding: 52px 0 120px; }
.obj-back { display: inline-block; font-size: 14px; font-weight: 500; color: var(--ink-2); text-decoration: none; margin-bottom: 40px; }
.obj-back:hover { color: var(--ink); }

.obj-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; flex-wrap: wrap; margin-bottom: 44px; }
.obj-head-main { max-width: 60ch; }
.obj-head-main h1 { font-size: 48px; margin-top: 14px; }
.obj-subtitle { font-size: 19px; color: var(--ink-2); margin-top: 16px; text-wrap: pretty; }
.obj-location { font-size: 15px; color: var(--ink-2); margin-top: 14px; }
.obj-head-price { text-align: right; flex-shrink: 0; }
.obj-price-caption { display: block; font-size: 12px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ink-2); }
.obj-price-value { display: block; font-family: var(--serif); font-size: 40px; font-weight: 600; margin-top: 6px; line-height: 1.1; }

.obj-gallery { margin-bottom: 64px; }
.obj-gallery-main img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; background: var(--ink); }
.obj-gallery-thumbs { display: flex; gap: 12px; margin-top: 12px; flex-wrap: wrap; }
.obj-thumb { width: 108px; height: 74px; padding: 0; border: 1px solid var(--line); background: none; cursor: pointer; overflow: hidden; opacity: 0.65; transition: opacity 0.2s, border-color 0.2s; }
.obj-thumb img { width: 100%; height: 100%; object-fit: cover; }
.obj-thumb.is-active, .obj-thumb:hover { opacity: 1; border-color: var(--ink); }

.obj-grid { display: grid; grid-template-columns: 1fr 380px; gap: 72px; align-items: start; }
.obj-prose { padding: 0; }  /* globale section{padding:120px} aufheben */
.obj-prose + .obj-prose { margin-top: 44px; }
.obj-prose h2 { font-size: 30px; margin-bottom: 16px; }
.obj-prose p { color: var(--ink-2); text-wrap: pretty; }
.obj-prose p + p { margin-top: 1em; }
.obj-features { display: flex; flex-wrap: wrap; gap: 10px; }
.obj-chip { font-size: 14px; padding: 8px 16px; background: var(--surface); border: 1px solid var(--line); color: var(--ink); }

.obj-aside { display: flex; flex-direction: column; gap: 24px; position: sticky; top: 104px; }
.obj-card-box { background: var(--surface); border: 1px solid var(--line); padding: 26px 28px; }
.obj-card-box h3 { font-family: var(--sans); font-size: 13px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-2); margin-bottom: 16px; }
.obj-facts { display: block; }
.obj-fact { display: flex; justify-content: space-between; gap: 16px; padding: 11px 0; border-top: 1px solid var(--line); font-size: 15px; }
.obj-fact:first-child { border-top: none; padding-top: 0; }
.obj-fact dt { color: var(--ink-2); }
.obj-fact dd { font-weight: 500; text-align: right; }
.energy-class { display: inline-block; background: var(--ink); color: var(--bg); padding: 2px 10px; font-weight: 600; letter-spacing: 0.04em; }

.obj-cta { background: var(--ink); color: var(--dark-ink); padding: 28px; }
.obj-cta .eyebrow { color: var(--dark-ink-2); }
.obj-cta-text { color: var(--dark-ink-2); font-size: 15px; margin: 10px 0 20px; text-wrap: pretty; }
.obj-cta-btn { background: var(--surface); color: var(--ink); border-color: var(--surface); width: 100%; }
.obj-cta-btn:hover { background: #fff; border-color: #fff; }
.obj-cta-mail { display: block; margin-top: 16px; font-size: 14px; color: var(--dark-ink); text-align: center; text-decoration: none; border-bottom: 1px solid rgba(237, 235, 228, 0.3); padding-bottom: 8px; }
.obj-cta-mail:hover { border-color: var(--dark-ink); }
.obj-ref { margin-top: 18px; font-size: 12.5px; color: var(--dark-ink-2); letter-spacing: 0.04em; }

/* ----------------------------------------------------------------- Impressum */
.imp-main { max-width: 760px; margin: 0 auto; padding: 100px 64px 140px; }
.imp-main h1 { font-size: 56px; margin-top: 20px; }
.imp-block { margin-top: 56px; border-top: 1px solid var(--line); padding-top: 28px; }
.imp-block h2 { font-size: 26px; font-family: var(--serif); margin-bottom: 14px; }
.imp-block p { color: var(--ink-2); font-size: 16.5px; }
.imp-block a { color: var(--ink); }
.back { display: inline-block; margin-top: 64px; font-size: 14.5px; font-weight: 500; color: var(--ink); text-decoration: none; border-bottom: 1px solid var(--ink); padding-bottom: 2px; }

/* ----------------------------------------------------------------- Responsive */
@media (max-width: 900px) {
	.container, .nav-inner, .contact .inner, .footer-inner { padding-left: 28px; padding-right: 28px; }
	h1 { font-size: 50px; }
	h2 { font-size: 38px; }
	section, .objects-section { padding: 80px 0; }
	.hero-a { height: 620px; }
	.nav-links { display: none; }
	.pillars, .why-grid { grid-template-columns: 1fr; gap: 32px; }
	.bio-grid { grid-template-columns: 1fr; gap: 40px; }
	.service { grid-template-columns: 60px 1fr; gap: 18px 28px; }
	.service p { grid-column: 1 / -1; }
	.ref-grid { grid-template-columns: 1fr 1fr; }
	.ref-quote { grid-template-columns: 1fr; gap: 32px; }
	.contact-phone { font-size: 38px; }
	.contact-rows { flex-direction: column; gap: 12px; }
	.imp-main { padding: 64px 28px 100px; }

	.obj-card { flex-basis: clamp(260px, 84vw, 340px); }
	.obj-head { gap: 24px; }
	.obj-head-main h1 { font-size: 38px; }
	.obj-head-price { text-align: left; }
	.obj-price-value { font-size: 34px; }
	.obj-grid { grid-template-columns: 1fr; gap: 48px; }
	.obj-aside { position: static; }
}

/* ---------------------------------------------------- Scroll-Reveal-Animationen */
/* Greift nur, wenn das Init-Script in inc/header.php .reveal-on gesetzt hat
   (flackerfrei vor dem Paint, und nie bei deaktiviertem JS oder reduced-motion).
   Die Selektorliste ist deckungsgleich mit dem Script. */
.reveal-on .sec-head,
.reveal-on .pillar,
.reveal-on .bio-photo,
.reveal-on .bio-text,
.reveal-on .why-item,
.reveal-on .service,
.reveal-on .ref-grid > figure,
.reveal-on .ref-quote,
.reveal-on .ba-wrap,
.reveal-on .obj-card,
.reveal-on .objects-controls,
.reveal-on .obj-gallery,
.reveal-on .obj-prose,
.reveal-on .obj-card-box,
.reveal-on .obj-cta {
	opacity: 0;
	transform: translateY(26px);
	transition:
		opacity 0.85s cubic-bezier(0.22, 0.61, 0.36, 1),
		transform 0.85s cubic-bezier(0.22, 0.61, 0.36, 1);
}
/* !important, damit der sichtbare Zustand auch Versteck-Regeln mit Element-
   Selektor (z. B. .ref-grid > figure, Spezifität 0,2,1) sicher überschreibt. */
.reveal-on .is-in {
	opacity: 1 !important;
	transform: none !important;
}
