/**
 * Rosult — Styles personnalisés du thème enfant GeneratePress
 * Site vitrine immobilier - rosult.adnmac.be
 *
 * Table des matières :
 * 1.  Variables CSS — Palette moderne/épurée
 * 2.  Base + Conteneur
 * 3.  Hero
 * 4.  Sections (titres, CTA bloc)
 * 5.  Fiche résumé du bien
 * 6.  Grille des pièces
 * 7.  Carte d'une pièce (single)
 * 8.  Boutons CTA
 * 9.  Points forts
 * 10. Galerie photo (lightbox)
 * 11. Page localisation
 * 12. Page contact
 * 13. Badge DPE
 * 14. En-têtes de pages
 * 15. Contenu éditeur
 * 16. Plan de la maison
 * 17. Titres de niveaux (RDC / Étage)
 * 18. Placeholder pièce
 * 19. Caractéristiques
 * 20. Carte OpenStreetMap
 * 21. Atouts région
 * 22. Fil d'Ariane
 * 23. Navigation pièces
 * 24. Divider
 * 25. Notices
 * 26. Formulaire natif (fallback)
 * 27. Responsive
 */

/* ============================================================
   1. Variables CSS globales — Palette moderne/épurée
   ============================================================ */
:root {
	--rosult-primary:      #1E3A5F;  /* Bleu nuit profond */
	--rosult-accent:       #D97706;  /* Ambre chaud — immo prestige */
	--rosult-dark:         #0F172A;  /* Texte quasi-noir */
	--rosult-light:        #F8FAFC;  /* Fond sections alternées */
	--rosult-white:        #FFFFFF;
	--rosult-gray:         #64748B;  /* Texte secondaire */
	--rosult-border:       #E2E8F0;

	--rosult-font:         system-ui, -apple-system, 'Segoe UI', Arial, sans-serif;

	--rosult-radius:       4px;
	--rosult-shadow:       0 1px 3px rgba(0,0,0,.08), 0 4px 16px rgba(0,0,0,.04);
	--rosult-shadow-hover: 0 4px 12px rgba(0,0,0,.12), 0 12px 32px rgba(0,0,0,.08);
}

/* ============================================================
   2. Base + Conteneur
   ============================================================ */
body {
	font-family: var(--rosult-font);
	color: var(--rosult-dark);
	font-size: 1.0625rem;
	line-height: 1.7;
}

/* Conteneur centré — remplace ast-container */
.rosult-container {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
	padding-left: 1.5rem;
	padding-right: 1.5rem;
}

/* ============================================================
   3. Hero — Section d'accueil pleine hauteur
   ============================================================ */
.rosult-hero {
	position: relative;
	min-height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background-color: var(--rosult-dark);
}

.rosult-hero__bg {
	position: absolute;
	inset: 0;
	object-fit: cover;
	width: 100%;
	height: 100%;
	opacity: 0.45;
}

/* Overlay gradient sombre */
.rosult-hero::after {
	content: '';
	position: absolute;
	inset: 0;
	background: linear-gradient(
		160deg,
		rgba(15, 23, 42, 0.35) 0%,
		rgba(30, 58, 95, 0.60) 100%
	);
	pointer-events: none;
}

.rosult-hero__content {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 2rem;
	max-width: 820px;
}

.rosult-hero__titre {
	font-family: var(--rosult-font);
	font-size: clamp(2.2rem, 5vw, 3.8rem);
	font-weight: 700;
	color: var(--rosult-white);
	margin-bottom: 1.25rem;
	line-height: 1.15;
	letter-spacing: -0.02em;
	text-shadow: 0 2px 12px rgba(0, 0, 0, 0.35);
}

.rosult-hero__accroche {
	font-size: clamp(1rem, 2.5vw, 1.2rem);
	color: rgba(255, 255, 255, 0.88);
	margin-bottom: 2.5rem;
	line-height: 1.7;
}

.rosult-hero__ctas {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
	margin-top: 2rem;
}

/* ============================================================
   4. Sections — titres et CTA bloc
   ============================================================ */
.rosult-section {
	margin: 5rem 0;
}

.rosult-section__titre {
	text-align: center;
	font-family: var(--rosult-font);
	font-size: clamp(1.5rem, 3vw, 2.2rem);
	font-weight: 700;
	letter-spacing: -0.01em;
	margin-bottom: 0.5rem;
	color: var(--rosult-dark);
}

.rosult-section__titre--left {
	text-align: left;
}

.rosult-section__sous-titre {
	text-align: center;
	color: var(--rosult-gray);
	margin-bottom: 2.5rem;
	font-size: 1.05rem;
}

.rosult-section__cta {
	text-align: center;
	margin-top: 2.5rem;
}

/* Bloc CTA (fond bleu primaire) */
.rosult-cta-bloc {
	background: var(--rosult-primary);
	border-radius: var(--rosult-radius);
	padding: 3.5rem 2rem;
	text-align: center;
	margin: 5rem 0;
}

.rosult-cta-bloc__titre {
	font-family: var(--rosult-font);
	font-size: clamp(1.4rem, 3vw, 2rem);
	font-weight: 700;
	color: var(--rosult-white);
	margin-bottom: 1rem;
}

.rosult-cta-bloc__texte {
	color: rgba(255, 255, 255, 0.82);
	margin-bottom: 2rem;
	max-width: 500px;
	margin-left: auto;
	margin-right: auto;
}

/* ============================================================
   5. Fiche résumé du bien — barre horizontale, bordure fine
   ============================================================ */
.rosult-fiche-bien {
	background: var(--rosult-white);
	border: 1px solid var(--rosult-border);
	border-radius: var(--rosult-radius);
	box-shadow: var(--rosult-shadow);
	padding: 1.75rem 2rem;
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	justify-content: center;
	margin: 3rem auto;
	max-width: 960px;
}

.rosult-fiche-bien__item {
	text-align: center;
	padding: 0.75rem 2rem;
	flex: 1;
	min-width: 140px;
}

.rosult-fiche-bien__valeur {
	font-family: var(--rosult-font);
	font-size: 1.75rem;
	font-weight: 700;
	color: var(--rosult-primary);
	line-height: 1.1;
}

.rosult-fiche-bien__label {
	font-size: 0.75rem;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: var(--rosult-gray);
	margin-top: 0.3rem;
}

.rosult-fiche-bien__sep {
	width: 1px;
	background: var(--rosult-border);
	align-self: stretch;
	margin: 0.5rem 0;
}

/* Mise en valeur du prix — flat, accent ambre */
.rosult-prix {
	display: inline-block;
	font-family: var(--rosult-font);
	font-size: clamp(1.5rem, 3vw, 2.5rem);
	font-weight: 700;
	color: var(--rosult-white);
	background: var(--rosult-accent);
	padding: 0.5rem 1.75rem;
	border-radius: var(--rosult-radius);
}

/* ============================================================
   6. Grille des pièces / espaces — 3 colonnes
   ============================================================ */
.rosult-pieces-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 1.75rem;
	margin: 2.5rem 0;
}

.rosult-piece-card {
	background: var(--rosult-white);
	border: 1px solid var(--rosult-border);
	border-radius: var(--rosult-radius);
	overflow: hidden;
	box-shadow: var(--rosult-shadow);
	transition: box-shadow 0.2s ease, transform 0.2s ease;
	text-decoration: none;
	color: inherit;
	display: flex;
	flex-direction: column;
}

.rosult-piece-card:hover {
	box-shadow: var(--rosult-shadow-hover);
	transform: translateY(-3px);
	text-decoration: none;
}

.rosult-piece-card__image {
	aspect-ratio: 4 / 3;
	object-fit: cover;
	width: 100%;
	display: block;
}

.rosult-piece-card__body {
	padding: 1.25rem 1.5rem;
	flex: 1;
}

.rosult-piece-card__titre {
	font-family: var(--rosult-font);
	font-size: 1.05rem;
	font-weight: 600;
	margin: 0 0 0.5rem;
	color: var(--rosult-dark);
}

.rosult-piece-card__surface {
	display: inline-block;
	background: var(--rosult-light);
	border: 1px solid var(--rosult-border);
	border-radius: var(--rosult-radius);
	padding: 0.1rem 0.6rem;
	font-size: 0.78rem;
	color: var(--rosult-primary);
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.rosult-piece-card__extrait {
	font-size: 0.875rem;
	color: var(--rosult-gray);
	line-height: 1.65;
	margin: 0;
}

/* ============================================================
   7. Carte d'une pièce — placeholder
   ============================================================ */
.rosult-piece-card__placeholder {
	background: var(--rosult-light);
	display: flex;
	align-items: center;
	justify-content: center;
	aspect-ratio: 4 / 3;
}

.rosult-piece-card__placeholder span {
	font-size: 3rem;
}

/* ============================================================
   8. Boutons CTA — flat moderne, border-radius 4px
   ============================================================ */
.rosult-btn {
	display: inline-block;
	padding: 0.8rem 1.75rem;
	border-radius: var(--rosult-radius);
	font-family: var(--rosult-font);
	font-size: 0.95rem;
	font-weight: 600;
	text-decoration: none;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
	border: 2px solid transparent;
	line-height: 1;
}

.rosult-btn--primary {
	background-color: var(--rosult-primary);
	color: var(--rosult-white);
	border-color: var(--rosult-primary);
}

.rosult-btn--primary:hover {
	background-color: #162d4d;
	border-color: #162d4d;
	color: var(--rosult-white);
	text-decoration: none;
}

.rosult-btn--secondary {
	background-color: var(--rosult-accent);
	color: var(--rosult-white);
	border-color: var(--rosult-accent);
}

.rosult-btn--secondary:hover {
	background-color: #b45309;
	border-color: #b45309;
	color: var(--rosult-white);
	text-decoration: none;
}

.rosult-btn--outline {
	background-color: transparent;
	color: var(--rosult-primary);
	border-color: var(--rosult-primary);
}

.rosult-btn--outline:hover {
	background-color: var(--rosult-primary);
	color: var(--rosult-white);
	text-decoration: none;
}

/* Bouton outline sur fond sombre (Hero) */
.rosult-btn--hero-outline {
	background-color: transparent;
	color: var(--rosult-white);
	border: 2px solid rgba(255, 255, 255, 0.75);
}

.rosult-btn--hero-outline:hover {
	background-color: rgba(255, 255, 255, 0.15);
	color: var(--rosult-white);
	text-decoration: none;
}

/* Variante petite taille */
.rosult-btn--sm {
	padding: 0.5rem 1.1rem;
	font-size: 0.875rem;
}

/* ============================================================
   9. Points forts de la maison
   ============================================================ */
.rosult-points-forts {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
	gap: 1.5rem;
	margin: 2.5rem 0;
}

.rosult-point {
	text-align: center;
	padding: 1.75rem 1rem;
	background: var(--rosult-white);
	border: 1px solid var(--rosult-border);
	border-radius: var(--rosult-radius);
}

.rosult-point__icone {
	font-size: 2.2rem;
	margin-bottom: 0.75rem;
	display: block;
}

.rosult-point__titre {
	font-size: 0.95rem;
	font-weight: 700;
	color: var(--rosult-dark);
	margin-bottom: 0.4rem;
}

.rosult-point__texte {
	font-size: 0.875rem;
	color: var(--rosult-gray);
	line-height: 1.6;
}

/* ============================================================
   10. Galerie photo (lightbox)
   ============================================================ */
.rosult-galerie {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
	gap: 1rem;
	margin: 2rem 0;
}

.rosult-galerie__item {
	aspect-ratio: 4 / 3;
	overflow: hidden;
	border-radius: var(--rosult-radius);
	cursor: zoom-in;
}

.rosult-galerie__item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.4s ease;
}

.rosult-galerie__item:hover img {
	transform: scale(1.04);
}

/* ============================================================
   11. Page localisation
   ============================================================ */
.rosult-localisation {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	align-items: start;
	margin: 2rem 0;
}

.rosult-proximites {
	list-style: none;
	padding: 0;
	margin: 1rem 0;
}

.rosult-proximites li {
	padding: 0.6rem 0;
	border-bottom: 1px solid var(--rosult-border);
	display: flex;
	justify-content: space-between;
	font-size: 0.95rem;
}

.rosult-proximites li:last-child {
	border-bottom: none;
}

.rosult-proximites__distance {
	color: var(--rosult-accent);
	font-weight: 600;
}

/* ============================================================
   12. Page contact
   ============================================================ */
.rosult-contact-wrapper {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
	align-items: start;
	margin: 2rem 0;
}

.rosult-contact-info {
	background: var(--rosult-light);
	border: 1px solid var(--rosult-border);
	border-radius: var(--rosult-radius);
	padding: 2rem;
}

.rosult-contact-info__tel {
	font-family: var(--rosult-font);
	font-size: 1.5rem;
	font-weight: 700;
	color: var(--rosult-primary);
	text-decoration: none;
	display: block;
	margin: 0.5rem 0;
}

/* ============================================================
   13. Badge DPE
   ============================================================ */
.rosult-dpe {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-weight: 700;
	font-size: 1.1rem;
}

.rosult-dpe__badge {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2rem;
	height: 2rem;
	border-radius: 4px;
	color: #fff;
	font-weight: 700;
	font-size: 1rem;
}

.rosult-dpe--A .rosult-dpe__badge { background: #00A550; }
.rosult-dpe--B .rosult-dpe__badge { background: #4CAF50; }
.rosult-dpe--C .rosult-dpe__badge { background: #8BC34A; }
.rosult-dpe--D .rosult-dpe__badge { background: #FFC107; color: #333; }
.rosult-dpe--E .rosult-dpe__badge { background: #FF9800; }
.rosult-dpe--F .rosult-dpe__badge { background: #FF5722; }
.rosult-dpe--G .rosult-dpe__badge { background: #D32F2F; }

/* ============================================================
   14. En-têtes de pages
   ============================================================ */
.rosult-page-header {
	text-align: center;
	padding: 3.5rem 0 2rem;
	border-bottom: 1px solid var(--rosult-border);
	margin-bottom: 3rem;
}

.rosult-page-header__titre {
	font-family: var(--rosult-font);
	font-size: clamp(1.8rem, 4vw, 2.8rem);
	font-weight: 700;
	letter-spacing: -0.02em;
	margin-bottom: 1rem;
	color: var(--rosult-dark);
}

.rosult-page-header__sous-titre {
	color: var(--rosult-gray);
	font-size: 1.1rem;
	max-width: 600px;
	margin: 0 auto;
	line-height: 1.65;
}

/* ============================================================
   15. Contenu éditeur
   ============================================================ */
.rosult-entry-content {
	margin: 2rem 0;
	line-height: 1.8;
	font-size: 1.0625rem;
}

/* ============================================================
   16. Plan de la maison
   ============================================================ */
.rosult-plan {
	margin: 0;
}

.rosult-plan__image {
	max-width: 100%;
	height: auto;
	border-radius: var(--rosult-radius);
	box-shadow: var(--rosult-shadow);
	display: block;
}

.rosult-plan__legende {
	text-align: center;
	color: var(--rosult-gray);
	margin-top: 0.5rem;
	font-size: 0.875rem;
	font-style: italic;
}

/* ============================================================
   17. Titres de niveaux (RDC / Étage)
   ============================================================ */
.rosult-niveau-titre {
	color: var(--rosult-gray);
	font-size: 0.8rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin: 3rem 0 1rem;
	padding-bottom: 0.5rem;
	border-bottom: 2px solid var(--rosult-accent);
	display: inline-block;
}

/* ============================================================
   18. Caractéristiques (section single pièce)
   ============================================================ */
.rosult-caracteristiques {
	background: var(--rosult-light);
	border: 1px solid var(--rosult-border);
	border-radius: var(--rosult-radius);
	padding: 1.5rem 2rem;
	margin: 2.5rem 0;
}

.rosult-caracteristiques__liste {
	margin: 0;
	padding-left: 1.25rem;
	line-height: 2;
	color: var(--rosult-dark);
}

/* ============================================================
   19. Carte OpenStreetMap
   ============================================================ */
.rosult-carte-wrapper {
	border-radius: var(--rosult-radius);
	overflow: hidden;
	box-shadow: var(--rosult-shadow);
}

/* ============================================================
   20. Section atouts région (fond gris clair)
   ============================================================ */
.rosult-atouts-region {
	background: var(--rosult-light);
	border: 1px solid var(--rosult-border);
	padding: 3rem;
	border-radius: var(--rosult-radius);
}

/* ============================================================
   21. Fil d'Ariane
   ============================================================ */
.rosult-breadcrumb {
	margin: 1.5rem 0;
	font-size: 0.875rem;
	color: var(--rosult-gray);
}

.rosult-breadcrumb a {
	color: var(--rosult-gray);
	text-decoration: none;
}

.rosult-breadcrumb a:hover {
	color: var(--rosult-primary);
	text-decoration: underline;
}

.rosult-breadcrumb span[aria-hidden] {
	margin: 0 0.4rem;
}

/* ============================================================
   22. Navigation pièces (précédente / suivante)
   ============================================================ */
.rosult-nav-pieces {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 1rem;
	margin: 3rem 0;
	padding: 2rem 0;
	border-top: 1px solid var(--rosult-border);
	flex-wrap: wrap;
}

/* ============================================================
   23. Divider
   ============================================================ */
.rosult-divider {
	border: none;
	border-top: 1px solid var(--rosult-border);
	margin: 1.5rem 0;
}

/* ============================================================
   24. Notices (messages d'avertissement / info)
   ============================================================ */
.rosult-notice {
	padding: 1rem 1.5rem;
	border-radius: var(--rosult-radius);
	margin-bottom: 1.5rem;
	font-size: 0.95rem;
}

.rosult-notice--warning {
	background: #FFF3CD;
	border-left: 4px solid var(--rosult-accent);
}

.rosult-notice--info {
	background: #EFF6FF;
	border-left: 4px solid var(--rosult-primary);
}

/* ============================================================
   25. Formulaire natif (fallback si CF7 absent)
   ============================================================ */
.rosult-form-natif {
	display: flex;
	flex-direction: column;
	gap: 1.25rem;
}

.rosult-form-natif__champ {
	display: flex;
	flex-direction: column;
	gap: 0.4rem;
}

.rosult-form-natif__champ label {
	font-weight: 600;
	font-size: 0.9rem;
	color: var(--rosult-dark);
}

.rosult-form-natif__champ input,
.rosult-form-natif__champ textarea {
	border: 1px solid var(--rosult-border);
	border-radius: var(--rosult-radius);
	padding: 0.75rem 1rem;
	font-size: 1rem;
	font-family: var(--rosult-font);
	width: 100%;
	transition: border-color 0.15s;
	background: var(--rosult-white);
}

.rosult-form-natif__champ input:focus,
.rosult-form-natif__champ textarea:focus {
	outline: none;
	border-color: var(--rosult-primary);
	box-shadow: 0 0 0 3px rgba(30, 58, 95, 0.1);
}

/* ============================================================
   26. Responsive
   ============================================================ */
@media (max-width: 1024px) {
	.rosult-pieces-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 768px) {
	.rosult-localisation,
	.rosult-contact-wrapper {
		grid-template-columns: 1fr;
	}

	.rosult-atouts-region {
		padding: 1.5rem;
	}

	.rosult-pieces-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.rosult-fiche-bien {
		flex-direction: column;
		align-items: center;
	}

	.rosult-fiche-bien__sep {
		width: 100%;
		height: 1px;
	}

	.rosult-pieces-grid {
		grid-template-columns: 1fr;
	}

	.rosult-galerie {
		grid-template-columns: 1fr 1fr;
	}

	.rosult-nav-pieces {
		flex-direction: column;
		align-items: stretch;
		text-align: center;
	}

	.rosult-hero__ctas {
		flex-direction: column;
		align-items: center;
	}

	.rosult-hero {
		min-height: 100svh;
	}
}
