/* ====================================================================
   awi-detail.css — Detailseiten-Layout "Detail AWI Modern"
   Premium-Look für Aller-Weser Immobilien
   ====================================================================
   Aufbau:
   1. Design-Tokens (erbt von .awi-detail – analog .awi-overview)
   2. Hero (Hauptbild + 4er-Grid)
   3. Preis-Block
   4. Karte + Eckdaten-Strip
   5. 3-Card-Grid (Ausstattung / Objektinfo / Energie)
   6. Beschreibungs-Tabs
   7. Ansprechpartner + Kontaktformular
   8. Responsive
   ==================================================================== */

/* 1) ----------------------- Design-Tokens ---------------------------- */
.awi-detail {
	--awi-serif: 'Playfair Display', 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
	--awi-sans:  'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;

	--awi-ink:        #1a1a1a;
	--awi-ink-soft:   #4a4a4a;
	--awi-ink-muted:  #6b6b6b;
	--awi-line:       #e4e1dc;
	--awi-bg:         #ffffff;
	--awi-bg-soft:    #f4f1ec;
	--awi-bg-card:    #faf8f4;
	--awi-accent:     #8a6d3b;
	--awi-accent-hov: #6b5429;
	--awi-success:    #2d6a3d;
	--awi-warning:    #b8860b;
	--awi-danger:     #8b1e1e;

	--awi-radius:   4px;
	--awi-shadow:   0 2px 8px rgba(0,0,0,0.06);
	--awi-shadow-h: 0 8px 24px rgba(0,0,0,0.12);

	font-family: var(--awi-sans);
	color: var(--awi-ink);
	max-width: 1240px;
	margin: 0 auto;
	padding: 1rem 0 3rem;
}

/* 2) ------------------------- Hero ----------------------------------- */
.awi-hero {
	display: grid;
	grid-template-columns: 2fr 1fr;
	gap: 0.5rem;
	margin-bottom: 2rem;
	position: relative;
}

.awi-hero__main {
	position: relative;
	display: block;
	aspect-ratio: 16 / 10;
	overflow: hidden;
	border-radius: var(--awi-radius);
	background: var(--awi-bg-soft);
	cursor: zoom-in;
}
.awi-hero__main img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.6s ease;
}
.awi-hero__main:hover img { transform: scale(1.03); }

.awi-hero__grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	grid-template-rows: 1fr 1fr;
	gap: 0.5rem;
}
.awi-hero__thumb {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: var(--awi-radius);
	background: var(--awi-bg-soft);
	aspect-ratio: 4 / 3;
	cursor: zoom-in;
}
.awi-hero__thumb img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
	transition: transform 0.6s ease;
}
.awi-hero__thumb:hover img { transform: scale(1.05); }

.awi-hero__gallery-btn {
	position: absolute;
	bottom: 0.75rem;
	right: 0.75rem;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	padding: 0.55rem 0.9rem;
	background: rgba(0,0,0,0.65);
	color: #fff;
	font-size: 0.85rem;
	font-weight: 500;
	border: none;
	border-radius: var(--awi-radius);
	cursor: pointer;
	backdrop-filter: blur(4px);
	transition: background 0.15s;
}
.awi-hero__gallery-btn:hover { background: rgba(0,0,0,0.85); color: #fff; }
.awi-hero__gallery-btn svg { flex: none; }

.awi-hero__share {
	position: absolute;
	top: 0.75rem;
	right: 0.75rem;
	display: flex;
	gap: 0.4rem;
	z-index: 2;
}
.awi-hero__share button {
	width: 2.25rem;
	height: 2.25rem;
	border: none;
	border-radius: var(--awi-radius);
	background: rgba(255,255,255,0.92);
	color: var(--awi-ink);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background 0.15s;
}
.awi-hero__share button:hover { background: #fff; }

/* 3) -------------------- Preis + Titel ------------------------------- */
.awi-headline {
	display: grid;
	grid-template-columns: minmax(auto, 18rem) 1fr;
	gap: 2rem;
	align-items: start;
	padding: 1rem 0 2rem;
	border-bottom: 1px solid var(--awi-line);
	margin-bottom: 2rem;
}
.awi-headline__price {
	font-family: var(--awi-serif);
	font-size: clamp(1.6rem, 3vw, 2.4rem);
	font-weight: 700;
	color: var(--awi-ink);
	line-height: 1.1;
	letter-spacing: -0.01em;
}
.awi-headline__price-label {
	display: block;
	font-family: var(--awi-sans);
	font-size: 0.75rem;
	font-weight: 500;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--awi-ink-muted);
	margin-bottom: 0.3rem;
}
.awi-headline__title {
	font-family: var(--awi-serif);
	font-size: clamp(1.2rem, 2vw, 1.65rem);
	font-weight: 400;
	color: var(--awi-ink);
	letter-spacing: 0.02em;
	text-transform: uppercase;
	line-height: 1.3;
	margin: 0 0 0.4rem;
}
.awi-headline__subtitle {
	font-family: var(--awi-serif);
	font-style: italic;
	font-size: 1.05rem;
	color: var(--awi-ink-soft);
	margin: 0;
	line-height: 1.4;
}

/* 4) --------------------- Karte + Eckdaten --------------------------- */
.awi-mapfacts {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 1.5rem;
	margin-bottom: 2.5rem;
}
.awi-map {
	height: 280px;
	border-radius: var(--awi-radius);
	overflow: hidden;
	background: var(--awi-bg-soft);
	position: relative;
}
.awi-map__placeholder {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	color: var(--awi-ink-muted);
	font-style: italic;
	font-size: 0.9rem;
	text-align: center;
	padding: 1rem;
}

.awi-facts {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem 1.5rem;
	align-content: center;
}
.awi-fact {
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}
.awi-fact__icon {
	flex: none;
	width: 2.2rem;
	height: 2.2rem;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: var(--awi-bg-soft);
	border-radius: 50%;
	color: var(--awi-accent);
}
.awi-fact__icon svg { width: 1.1rem; height: 1.1rem; }
.awi-fact__body {
	display: flex;
	flex-direction: column;
	line-height: 1.2;
}
.awi-fact__label {
	font-size: 0.75rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--awi-ink-muted);
	margin-bottom: 0.1rem;
}
.awi-fact__value {
	font-family: var(--awi-serif);
	font-size: 1.15rem;
	color: var(--awi-ink);
	font-weight: 500;
}

/* 5) ----------------------- 3-Card-Grid ------------------------------ */
.awi-cards {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.25rem;
	margin-bottom: 2.5rem;
}
.awi-card-info {
	background: var(--awi-bg-card);
	border: 1px solid var(--awi-line);
	border-radius: var(--awi-radius);
	padding: 1.5rem 1.4rem 1.6rem;
	display: flex;
	flex-direction: column;
}
.awi-card-info__title {
	font-family: var(--awi-serif);
	font-size: 0.85rem;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--awi-ink);
	margin: 0 0 1.2rem;
	font-weight: 500;
	padding-bottom: 0.7rem;
	border-bottom: 1px solid var(--awi-line);
}

/* Ausstattungs-Icons-Grid */
.awi-feat {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1rem 0.5rem;
	margin: 0;
}
.awi-feat__item {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 0.4rem;
	color: var(--awi-ink-soft);
	font-size: 0.78rem;
	line-height: 1.2;
}
.awi-feat__item svg {
	width: 1.8rem;
	height: 1.8rem;
	color: var(--awi-accent);
	flex: none;
}

/* Objektinfo-Tabelle */
.awi-info-table {
	margin: 0;
	padding: 0;
	list-style: none;
	font-size: 0.9rem;
}
.awi-info-table li {
	display: flex;
	justify-content: space-between;
	gap: 1rem;
	padding: 0.45rem 0;
	border-bottom: 1px dashed var(--awi-line);
}
.awi-info-table li:last-child { border-bottom: none; }
.awi-info-table .name {
	color: var(--awi-ink-soft);
}
.awi-info-table .value {
	color: var(--awi-ink);
	font-weight: 500;
	text-align: right;
	word-break: break-word;
}

/* Energie-Block (SVG-Tachometer) */
.awi-energy {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	align-items: center;
}
.awi-energy__gauge {
	width: 100%;
	max-width: 280px;
}
.awi-energy__gauge svg {
	width: 100%;
	height: auto;
	display: block;
}
.awi-energy__caption {
	font-size: 0.8rem;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: var(--awi-ink-muted);
	text-align: center;
	margin: 0;
	line-height: 1.4;
}

/* Toggle / Accordion innerhalb der Cards */
.awi-toggle {
	margin-top: 1rem;
	border-top: 1px solid var(--awi-line);
	padding-top: 0.6rem;
}
.awi-toggle summary {
	cursor: pointer;
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--awi-accent);
	letter-spacing: 0.04em;
	padding: 0.35rem 0;
	list-style: none;
	display: flex;
	align-items: center;
	gap: 0.4rem;
}
.awi-toggle summary::-webkit-details-marker { display: none; }
.awi-toggle summary::after {
	content: '+';
	font-size: 1.1rem;
	line-height: 1;
	margin-left: auto;
	transition: transform 0.2s;
}
.awi-toggle[open] summary::after { content: '−'; }
.awi-toggle .awi-info-table {
	margin-top: 0.5rem;
	font-size: 0.85rem;
}

/* 6) -------------------- Beschreibungs-Tabs -------------------------- */
.awi-prose {
	margin-bottom: 2.5rem;
}
.awi-prose__nav {
	display: flex;
	flex-wrap: wrap;
	gap: 0.25rem;
	border-bottom: 1px solid var(--awi-line);
	margin-bottom: 1.25rem;
}
.awi-prose__tab {
	background: none;
	border: none;
	padding: 0.65rem 1.2rem;
	font-family: var(--awi-serif);
	font-size: 0.85rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--awi-ink-muted);
	cursor: pointer;
	border-bottom: 2px solid transparent;
	margin-bottom: -1px;
	transition: color 0.15s, border-color 0.15s;
}
.awi-prose__tab:hover { color: var(--awi-ink); }
.awi-prose__tab.is-active {
	color: var(--awi-ink);
	border-bottom-color: var(--awi-accent);
}
.awi-prose__panel {
	display: none;
	font-size: 0.95rem;
	line-height: 1.65;
	color: var(--awi-ink-soft);
	max-width: 70ch;
}
.awi-prose__panel.is-active { display: block; }
.awi-prose__panel p { margin: 0 0 1rem; }

/* 7) --------------------- Ansprechpartner ---------------------------- */
.awi-contact {
	display: grid;
	grid-template-columns: 1fr 1.5fr;
	gap: 2rem;
	padding: 2rem;
	background: var(--awi-bg-soft);
	border-radius: var(--awi-radius);
	margin-bottom: 2rem;
}
.awi-contact__card {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 0.5rem;
}
.awi-contact__photo {
	width: 7rem;
	height: 7rem;
	border-radius: 50%;
	object-fit: cover;
	margin-bottom: 0.5rem;
	background: var(--awi-bg);
}
.awi-contact__role {
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: var(--awi-ink-muted);
}
.awi-contact__name {
	font-family: var(--awi-serif);
	font-size: 1.25rem;
	color: var(--awi-ink);
	margin: 0;
}
.awi-contact__lines {
	font-size: 0.9rem;
	color: var(--awi-ink-soft);
	line-height: 1.5;
	margin-top: 0.4rem;
}
.awi-contact__lines a {
	color: var(--awi-accent);
	text-decoration: none;
}
.awi-contact__lines a:hover { color: var(--awi-accent-hov); text-decoration: underline; }

.awi-contact__form { display: flex; flex-direction: column; }
.awi-contact__form h3 {
	font-family: var(--awi-serif);
	font-size: 1.15rem;
	margin: 0 0 1rem;
	color: var(--awi-ink);
	font-weight: 400;
	letter-spacing: 0.04em;
}
.awi-contact__form input,
.awi-contact__form textarea,
.awi-contact__form select {
	width: 100%;
	padding: 0.65rem 0.85rem;
	border: 1px solid var(--awi-line);
	background: var(--awi-bg);
	border-radius: var(--awi-radius);
	font-family: var(--awi-sans);
	font-size: 0.9rem;
	margin-bottom: 0.75rem;
	color: var(--awi-ink);
}
.awi-contact__form textarea { min-height: 6rem; resize: vertical; }
.awi-contact__form button,
.awi-contact__form input[type="submit"] {
	background: var(--awi-ink);
	color: #fff;
	border: none;
	padding: 0.75rem 1.6rem;
	font-size: 0.85rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	cursor: pointer;
	border-radius: var(--awi-radius);
	transition: background 0.15s;
	align-self: flex-start;
}
.awi-contact__form button:hover,
.awi-contact__form input[type="submit"]:hover { background: var(--awi-accent); }

/* --- Galerie-Modal (Fotorama-Lightbox) ------------------------------- */
.awi-gallery-overlay {
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.94);
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 2rem;
}
.awi-gallery-overlay.is-open { display: flex; }

.awi-gallery-inner {
	width: 100%;
	max-width: 1400px;
	height: 90vh;
	max-height: 900px;
	position: relative;
	background: #000;
}

.awi-gallery-fotorama,
.awi-gallery-fotorama .fotorama__wrap {
	width: 100% !important;
	height: 100% !important;
}

.awi-gallery-fotorama .fotorama__stage,
.awi-gallery-fotorama .fotorama__stage__frame {
	width: 100% !important;
}

.awi-gallery-close {
	position: absolute;
	top: -3rem;
	right: 0;
	width: 2.5rem;
	height: 2.5rem;
	background: rgba(255, 255, 255, 0.12);
	border: none;
	border-radius: 50%;
	color: #fff;
	font-size: 1.6rem;
	line-height: 1;
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: background 0.15s;
	z-index: 2;
}
.awi-gallery-close:hover { background: rgba(255, 255, 255, 0.25); }

@media (max-width: 700px) {
	.awi-gallery-overlay { padding: 1rem; }
	.awi-gallery-inner { height: 85vh; }
	.awi-gallery-close { top: -2.5rem; }
}

/* 8) ----------------------- Responsive ------------------------------- */
@media (max-width: 1024px) {
	.awi-cards { grid-template-columns: 1fr; }
	.awi-facts { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 900px) {
	.awi-hero { grid-template-columns: 1fr; }
	.awi-hero__grid { grid-template-columns: repeat(4, 1fr); grid-template-rows: 1fr; }
	.awi-headline { grid-template-columns: 1fr; gap: 1rem; }
	.awi-mapfacts { grid-template-columns: 1fr; }
	.awi-contact { grid-template-columns: 1fr; padding: 1.25rem; }
	.awi-feat { grid-template-columns: repeat(4, 1fr); }
}

@media (max-width: 560px) {
	.awi-facts { grid-template-columns: 1fr; }
	.awi-feat { grid-template-columns: repeat(3, 1fr); }
	.awi-hero__grid { grid-template-columns: repeat(2, 1fr); grid-template-rows: 1fr 1fr; }
	.awi-prose__tab { padding: 0.5rem 0.8rem; font-size: 0.75rem; }
}

/* Print */
@media print {
	.awi-hero__share, .awi-hero__gallery-btn, .awi-contact__form, .awi-prose__nav { display: none; }
	.awi-card-info { break-inside: avoid; }
}
