/* ==========================================================================
   ImmoWP DPE GES - Pure CSS Energy Diagnostic Charts
   ========================================================================== */

.immowp-diagnostic-dpe-ges-wrapper {
	max-width: 700px;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	font-size: 14px;
	line-height: 1.4;
}

/* ---------- Side by side on desktop ---------- */

.immowp-diagnostic-dpe-ges-charts {
	display: flex;
	gap: 40px;
	flex-wrap: wrap;
}

/* ---------- Chart Headers ---------- */

.immowp-dpe-chart,
.immowp-ges-chart {
	flex: 1 1 280px;
	max-width: 320px;
	margin-bottom: 24px;
}

.immowp-dpe-chart-header,
.immowp-ges-chart-header {
	margin-bottom: 8px;
}

.immowp-dpe-chart-title,
.immowp-ges-chart-title {
	display: block;
	font-weight: 700;
	font-size: 15px;
	text-transform: uppercase;
	color: #333;
}

.immowp-dpe-chart-subtitle,
.immowp-ges-chart-subtitle {
	display: block;
	font-size: 12px;
	color: #666;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

/* ---------- Legends ---------- */

.immowp-dpe-chart-legend,
.immowp-ges-chart-legend {
	font-size: 11px;
	color: #888;
	font-style: italic;
	padding: 2px 0;
}

.immowp-dpe-chart-legend-top,
.immowp-ges-chart-legend-top {
	text-align: left;
}

.immowp-dpe-chart-legend-bottom,
.immowp-ges-chart-legend-bottom {
	text-align: right;
}

/* ---------- Unit ---------- */

.immowp-dpe-chart-unit,
.immowp-ges-chart-unit {
	font-size: 11px;
	color: #888;
	text-align: right;
	margin-top: 2px;
}

/* ---------- Scale Container ---------- */

.immowp-dpe-scale,
.immowp-ges-scale {
	display: flex;
	flex-direction: column;
	gap: 3px;
}

/* ---------- Individual Bars ---------- */

.immowp-dpe-bar,
.immowp-ges-bar {
	display: flex;
	align-items: center;
	width: var(--bar-width);
	min-height: 28px;
	background-color: var(--bar-color);
	color: var(--bar-text-color);
	border-radius: 3px 0 0 3px;
	position: relative;
	padding: 2px 8px;
	box-sizing: border-box;
	transition: all 0.2s ease;
	opacity: 0.45;
}

/* Arrow shape via ::after */
.immowp-dpe-bar::after,
.immowp-ges-bar::after {
	content: "";
	position: absolute;
	right: -14px;
	top: 0;
	width: 0;
	height: 0;
	border-top: 14px solid transparent;
	border-bottom: 14px solid transparent;
	border-left: 14px solid var(--bar-color);
}

/* ---------- Bar Content ---------- */

.immowp-dpe-bar-letter,
.immowp-ges-bar-letter {
	font-weight: 700;
	font-size: 15px;
	min-width: 16px;
}

.immowp-dpe-bar-threshold,
.immowp-ges-bar-threshold {
	font-size: 11px;
	margin-left: auto;
	padding-right: 4px;
	opacity: 0.85;
}

/* ---------- Active Bar ---------- */

.immowp-dpe-bar-active,
.immowp-ges-bar-active {
	min-height: 40px;
	font-size: 16px;
	z-index: 1;
	opacity: 1;
}

.immowp-dpe-bar-active::after,
.immowp-ges-bar-active::after {
	border-top-width: 20px;
	border-bottom-width: 20px;
	border-left-width: 16px;
	right: -16px;
}

/* Value badge on active bar */
.immowp-dpe-bar-value,
.immowp-ges-bar-value {
	position: absolute;
	right: -58px;
	top: 50%;
	transform: translateY(-50%);
	background-color: var(--bar-color);
	color: var(--bar-text-color);
	font-weight: 700;
	font-size: 16px;
	padding: 4px 10px;
	border-radius: 4px;
	white-space: nowrap;
	min-width: 24px;
	text-align: center;
}

/* ---------- Info Block ---------- */

.immowp-diagnostic-dpe-ges-info {
	margin-top: 16px;
	padding-top: 16px;
	border-top: 1px solid #e0e0e0;
	font-size: 12px;
	color: #555;
}

.immowp-diagnostic-dpe-ges-info p {
	margin: 0 0 8px;
	line-height: 1.5;
}

.immowp-diagnostic-dpe-ges-info p:last-child {
	margin-bottom: 0;
}

.immowp-diagnostic-dpe-ges-info a {
	color: #0073aa;
	text-decoration: underline;
}

.immowp-diagnostic-dpe-ges-info a:hover {
	color: #005177;
}

/* ---------- Passoire énergétique (F/G) ---------- */

.immowp-dpe-passoire-energetique,
.immowp-ges-passoire-energetique {
	margin-top: 10px;
	padding: 8px 12px;
	background-color: #fef3f2;
	border: 1px solid #e30613;
	border-radius: 4px;
	color: #b91c1c;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.4;
}

.immowp-ges-passoire-energetique {
	border-color: #561256;
	background-color: #fdf2fd;
	color: #561256;
}

.immowp-dpe-passoire-icon,
.immowp-ges-passoire-icon {
	font-size: 14px;
}

/* ---------- Non soumis ---------- */

.immowp-diagnostic-dpe-ges-non-soumis {
	padding: 12px 16px;
	background: #f7f7f7;
	border-left: 4px solid #ccc;
	color: #555;
	font-style: italic;
}

/* ---------- Responsive ---------- */

@media (max-width: 860px) {
	.immowp-diagnostic-dpe-ges-charts {
		flex-direction: column;
		gap: 0;
	}

	.immowp-dpe-chart,
	.immowp-ges-chart {
		max-width: 500px;
	}
}

@media (max-width: 480px) {
	.immowp-diagnostic-dpe-ges-wrapper {
		max-width: 100%;
	}

	.immowp-dpe-bar,
	.immowp-ges-bar {
		min-height: 24px;
		padding: 2px 6px;
	}

	.immowp-dpe-bar::after,
	.immowp-ges-bar::after {
		right: -12px;
		border-top-width: 12px;
		border-bottom-width: 12px;
		border-left-width: 12px;
	}

	.immowp-dpe-bar-active,
	.immowp-ges-bar-active {
		min-height: 34px;
	}

	.immowp-dpe-bar-active::after,
	.immowp-ges-bar-active::after {
		border-top-width: 17px;
		border-bottom-width: 17px;
		border-left-width: 14px;
		right: -14px;
	}

	.immowp-dpe-bar-value,
	.immowp-ges-bar-value {
		right: -50px;
		font-size: 13px;
		padding: 3px 8px;
	}

	.immowp-dpe-bar-threshold,
	.immowp-ges-bar-threshold {
		font-size: 10px;
	}
}
