/* File: assets/hero.css */
.hero {
	position: relative;
	height: 100vh;
	width: 100vw;
	max-width: 100vw !important;
	margin-left: 50% !important;
	transform: translateX(-50%);
	overflow: hidden;
	isolation: isolate;
}

.entry-content {
	padding: 0 !important;
	margin: 0 !important;
}

.hero-zoom {
	position: absolute;
	inset: 0;
}

.hero-slide {
	position: absolute;
	inset: 0;
	opacity: 0;
	transition: opacity 1.5s ease;
	z-index: 0;
	will-change: opacity;
	pointer-events: none;
}

.hero-slide.active {
	opacity: 1;
	z-index: 1;
}
.hero-slide.entering {
	z-index: 2;
}
.hero-bg,
.hero-bg-img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	background-size: cover;
	background-position: center;
	backface-visibility: hidden;
	transform: scale(1.06) translate3d(0, 0, 0);
	transform-origin: center center;
	will-change: transform;
}

.hero-bg.is-zooming,
.hero-bg-img.is-zooming {
	animation: heroKenBurns 10s ease-out forwards;
}

@keyframes heroKenBurns {
	from {
		transform: scale(1.06) translate3d(0, 0, 0);
	}
	to {
		transform: scale(1.18) translate3d(-1.5%, -1%, 0);
	}
}

.hero::before {
	content: "";
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	opacity: 0;
	transition: opacity 0.6s ease;
	z-index: 3;
	pointer-events: none;
}

.hero.hero-loaded::before {
	opacity: 1;
}

.hero-overlay {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 4;
	text-align: center;
}

.hero-overlay-inner {
	will-change: transform;
}

.hero-logo {
	display: block;
	margin: 0 auto;
	animation:
		fadeUp 1.2s ease forwards,
		floating 6s ease-in-out infinite;
	animation-delay: 0.3s, 1.5s;
	width: clamp(260px, 32vw, 520px);
	max-width: 90vw;
	height: auto;
}

.hero-tagline {
	margin-top: 40px !important;
	font-size: 65px;
	color: #fff;
	max-width: 90vw;
	margin: 0 auto;
	white-space: nowrap;
	text-align: center;
	animation: fadeUp 1.2s ease forwards;
	animation-delay: 0.8s;
}

.hero-logo,
.hero-tagline {
	opacity: 0;
	transform: translateY(40px);
}

@keyframes fadeUp {
	from {
		opacity: 0;
		transform: translateY(40px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes floating {
	0%   { transform: translate(0px, 0px); }
	20%  { transform: translate(2px, -6px); }
	40%  { transform: translate(-3px, -10px); }
	60%  { transform: translate(4px, -7px); }
	80%  { transform: translate(-2px, -12px); }
	100% { transform: translate(0px, 0px); }
}

@media (max-width: 768px) {
	.hero-tagline {
		font-size: 32px;
		line-height: 1.2;
		white-space: normal;
		max-width: 90vw;
	}

	.hero-logo {
		width: clamp(300px, 40vw, 420px);
	}
}

/* Hero canvas: header superposé */
.page-template-hero-home-canvas-php .site-header,
.page-template-hero-home-canvas-php .top-sticky {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	z-index: 100;
	background: transparent !important;
	box-shadow: none !important;
}

.page-template-hero-home-canvas-php .site-header-container,
.page-template-hero-home-canvas-php .site-header-placeholder {
	background: transparent !important;
	box-shadow: none !important;
}

.page-template-hero-home-canvas-php #content.site-content {
	padding-top: 0 !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	padding-bottom: 0 !important;
}

.page-template-hero-home-canvas-php .hero {
	margin-top: 0 !important;
}
/* Hero canvas: header clair sur image */
.page-template-hero-home-canvas-php .site-header,
.page-template-hero-home-canvas-php .site-header a,
.page-template-hero-home-canvas-php .site-header .menu-item > a,
.page-template-hero-home-canvas-php .site-header .site-title a,
.page-template-hero-home-canvas-php .site-header .site-description,
.page-template-hero-home-canvas-php .site-header .custom-logo-link,
.page-template-hero-home-canvas-php .site-header .custom-logo-link img,
.page-template-hero-home-canvas-php .top-sticky,
.page-template-hero-home-canvas-php .top-sticky a {
	color: #fff !important;
}

.page-template-hero-home-canvas-php .site-header svg,
.page-template-hero-home-canvas-php .site-header i,
.page-template-hero-home-canvas-php .top-sticky svg,
.page-template-hero-home-canvas-php .top-sticky i {
	fill: #fff !important;
	color: #fff !important;
}

.page-template-hero-home-canvas-php .site-header .custom-logo,
.page-template-hero-home-canvas-php .top-sticky .custom-logo {
	filter: brightness(0) invert(1);
}