/**
 * Bandeau de session démo (front + admin) — fixé en haut, NON dismissible.
 * + Bouton WhatsApp flottant bas-droite.
 */
.danz-demo-banner {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 99999;
	background: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);
	color: #fff;
	font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
	font-size: 13.5px;
	font-weight: 500;
	padding: 10px 18px;
	display: flex;
	align-items: center;
	gap: 16px;
	box-shadow: 0 6px 20px rgba(239, 68, 68, .35);
	flex-wrap: wrap;
}

.danz-demo-banner__icon {
	width: 28px; height: 28px;
	border-radius: 50%;
	background: rgba(255, 255, 255, .18);
	display: grid; place-items: center;
	font-size: 16px;
	flex-shrink: 0;
}

.danz-demo-banner__title { font-weight: 600; }
.danz-demo-banner__title strong { font-weight: 800; }

.danz-demo-banner__sep { opacity: .45; margin: 0 2px; }

.danz-demo-banner__timer {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(0, 0, 0, .22);
	padding: 5px 12px;
	border-radius: 999px;
	font-variant-numeric: tabular-nums;
	font-weight: 700;
	letter-spacing: .04em;
}

.danz-demo-banner__timer-pulse {
	width: 8px; height: 8px;
	border-radius: 50%;
	background: #fde047;
	box-shadow: 0 0 0 0 rgba(253, 224, 71, .7);
	animation: dsbpulse 1.4s ease-out infinite;
}
@keyframes dsbpulse {
	0% { box-shadow: 0 0 0 0 rgba(253,224,71,.7); }
	70% { box-shadow: 0 0 0 8px rgba(253,224,71,0); }
	100% { box-shadow: 0 0 0 0 rgba(253,224,71,0); }
}

/* Contact link inside banner */
.danz-demo-banner__contact {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(255,255,255,.14);
	padding: 6px 14px;
	border-radius: 999px;
	color: #fff !important;
	text-decoration: none !important;
	font-size: 13px;
	transition: background .15s, transform .15s;
}
.danz-demo-banner__contact:hover {
	background: rgba(255,255,255,.24);
	transform: translateY(-1px);
	color: #fff !important;
}
.danz-demo-banner__contact-icon { font-size: 13px; }
.danz-demo-banner__contact-label { opacity: .85; font-weight: 500; }
.danz-demo-banner__contact strong { font-weight: 700; letter-spacing: .02em; }

.danz-demo-banner__actions { margin-left: auto; display: flex; gap: 8px; align-items: center; }

.danz-demo-banner__btn {
	background: rgba(255, 255, 255, .16);
	color: #fff !important;
	border: 1px solid rgba(255, 255, 255, .18);
	border-radius: 999px;
	padding: 6px 14px;
	font-size: 12.5px;
	font-weight: 600;
	cursor: pointer;
	transition: background .15s, transform .1s;
	text-decoration: none !important;
}
.danz-demo-banner__btn:hover { background: rgba(255, 255, 255, .28); }
.danz-demo-banner__btn--solid {
	background: #fff;
	color: #ef4444 !important;
	border-color: transparent;
	font-weight: 700;
}
.danz-demo-banner__btn--solid:hover {
	background: #f9fafb;
	transform: translateY(-1px);
}

@media (max-width: 900px) {
	.danz-demo-banner {
		font-size: 11.5px;
		padding: 6px 10px;
		gap: 6px;
		flex-wrap: nowrap;
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
	.danz-demo-banner::-webkit-scrollbar { display: none; }
	.danz-demo-banner__icon { width: 22px; height: 22px; font-size: 13px; flex-shrink: 0; }
	.danz-demo-banner__title { white-space: nowrap; flex-shrink: 0; font-size: 11px; }
	.danz-demo-banner__sep { display: none; }
	.danz-demo-banner__timer { font-size: 10.5px; padding: 3px 8px; gap: 5px; flex-shrink: 0; white-space: nowrap; }
	.danz-demo-banner__timer-pulse { width: 6px; height: 6px; }
	.danz-demo-banner__contact { padding: 4px 9px; font-size: 11px; gap: 5px; flex-shrink: 0; }
	.danz-demo-banner__contact-label { display: none; }
	.danz-demo-banner__contact strong { font-size: 11px; }
	.danz-demo-banner__actions { gap: 4px; margin-left: auto; flex-shrink: 0; }
	.danz-demo-banner__btn { padding: 4px 9px; font-size: 11px; }
}
@media (max-width: 540px) {
	.danz-demo-banner__title { display: none; }
	.danz-demo-banner__contact { display: none; }
	.danz-demo-banner__icon { display: none; }
}

/* Pousse le contenu du body sous le banner. JS (countdown.js) ajuste
 * dynamiquement la hauteur réelle pour ZÉRO overlap, ces valeurs sont
 * juste un fallback initial avant que le JS ne tourne. */
body.has-danz-demo-banner { padding-top: 44px; }
@media (max-width: 900px) { body.has-danz-demo-banner { padding-top: 36px; } }

/* Compat WP admin bar */
body.admin-bar.has-danz-demo-banner #wpadminbar { top: 44px; }
@media (max-width: 900px) { body.admin-bar.has-danz-demo-banner #wpadminbar { top: 36px; } }

/* ============================== Bouton WhatsApp flottant ============================== */
.danz-demo-whatsapp {
	position: fixed;
	right: 20px;
	bottom: 20px;
	z-index: 99998;
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background: #25d366;
	display: grid;
	place-items: center;
	box-shadow: 0 14px 30px -10px rgba(37, 211, 102, .55);
	transition: transform .2s, box-shadow .2s;
	text-decoration: none !important;
}
.danz-demo-whatsapp:hover {
	transform: translateY(-3px) scale(1.05);
	box-shadow: 0 20px 38px -10px rgba(37, 211, 102, .7);
}
.danz-demo-whatsapp svg { display: block; }
.danz-demo-whatsapp__pulse {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	border: 3px solid #25d366;
	opacity: 0;
	animation: dzWaPulse 2s ease-out infinite;
	pointer-events: none;
}
@keyframes dzWaPulse {
	0%   { transform: scale(.95); opacity: .8; }
	70%  { transform: scale(1.5); opacity: 0; }
	100% { transform: scale(1.5); opacity: 0; }
}

@media (max-width: 720px) {
	.danz-demo-whatsapp { right: 14px; bottom: 14px; width: 52px; height: 52px; }
}
