/**
 * Idrozn — Custom Styles
 * Complement au theme.json pour les styles qui ne peuvent pas
 * etre definis via les blocs Gutenberg natifs.
 */

/* ============================================
   Reset & Base
   ============================================ */

*,
*::before,
*::after {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* ============================================
   Header
   ============================================ */

.wp-block-site-logo img {
	object-fit: contain;
}

/* Navigation CTA style */
.is-style-idrozn-nav-cta > a,
.is-style-idrozn-nav-cta .wp-block-navigation-item__content {
	background-color: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white) !important;
	padding: 0.5em 1.25em;
	border-radius: 4px;
	font-weight: 600;
	transition: background-color 0.2s ease;
}

.is-style-idrozn-nav-cta > a:hover,
.is-style-idrozn-nav-cta .wp-block-navigation-item__content:hover {
	background-color: var(--wp--preset--color--secondary);
}

/* Header sticky effect */
header.wp-block-template-part {
	position: sticky;
	top: 0;
	z-index: 100;
	background: var(--wp--preset--color--white);
}

/* ============================================
   Buttons
   ============================================ */

.wp-block-button__link {
	transition: background-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease;
}

.wp-block-button__link:hover {
	box-shadow: 0 2px 8px rgba(30, 45, 61, 0.12);
}

/* Outline buttons */
.is-style-outline .wp-block-button__link {
	border: 2px solid var(--wp--preset--color--primary);
	color: var(--wp--preset--color--primary);
	background: transparent;
}

.is-style-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--primary);
	color: var(--wp--preset--color--white);
}

/* ============================================
   Footer
   ============================================ */

.is-style-idrozn-footer-nav {
	list-style: none;
}

.is-style-idrozn-footer-nav li {
	list-style: none;
}

.is-style-idrozn-footer-nav a {
	color: var(--wp--preset--color--surface-alt);
	text-decoration: none;
	transition: color 0.2s ease;
}

.is-style-idrozn-footer-nav a:hover {
	color: var(--wp--preset--color--white);
}

/* ============================================
   Cards & Groups with hover
   ============================================ */

.wp-block-group[style*="border-left-width: 3px"],
.wp-block-group[style*="border-left-width:3px"],
.wp-block-group[style*="border-top-width: 3px"],
.wp-block-group[style*="border-top-width:3px"] {
	transition: box-shadow 0.2s ease, transform 0.15s ease;
}

.wp-block-group[style*="border-left-width: 3px"]:hover,
.wp-block-group[style*="border-left-width:3px"]:hover,
.wp-block-group[style*="border-top-width: 3px"]:hover,
.wp-block-group[style*="border-top-width:3px"]:hover {
	box-shadow: 0 4px 12px rgba(30, 45, 61, 0.08);
}

/* ============================================
   Hero Cover
   ============================================ */

.wp-block-cover {
	overflow: hidden;
}

.wp-block-cover .wp-block-cover__image-background,
.wp-block-cover video.wp-block-cover__video-background {
	object-fit: cover;
	object-position: center center;
}

/* Outline button override inside cover (white border) */
.wp-block-cover .is-style-outline .wp-block-button__link:hover {
	background: rgba(255, 255, 255, 0.15);
	border-color: rgba(255, 255, 255, 0.8);
	color: #fff;
}

/* ============================================
   Separator
   ============================================ */

.wp-block-separator {
	opacity: 1;
}

/* ============================================
   Quotes
   ============================================ */

.wp-block-quote {
	margin-left: 0;
	margin-right: 0;
}

.wp-block-quote cite {
	font-size: 0.85rem;
	color: var(--wp--preset--color--text-muted);
	font-style: normal;
}

/* ============================================
   Responsive adjustments
   ============================================ */

@media (max-width: 781px) {

	/* Stack columns on mobile */
	.wp-block-columns {
		flex-wrap: wrap;
	}

	.wp-block-column {
		flex-basis: 100% !important;
	}

	/* Reduce section padding on mobile */
	.wp-block-group.alignfull {
		padding-left: var(--wp--preset--spacing--20) !important;
		padding-right: var(--wp--preset--spacing--20) !important;
	}

	/* Full-width buttons on mobile */
	.wp-block-buttons .wp-block-button {
		width: 100%;
	}

	.wp-block-button__link {
		width: 100%;
		text-align: center;
	}
}

@media (max-width: 480px) {

	/* Even tighter mobile padding */
	.wp-block-group.alignfull {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}
}

/* ============================================
   Animations (subtle, performance-safe)
   ============================================ */

@media (prefers-reduced-motion: no-preference) {

	/* Fade in sections on scroll - preparatory classes */
	.wp-block-group.alignfull > .wp-block-group,
	.wp-block-group.alignfull > .wp-block-columns,
	.wp-block-group.alignfull > .wp-block-heading,
	.wp-block-group.alignfull > .wp-block-paragraph,
	.wp-block-group.alignfull > .wp-block-buttons {
		animation: idrozn-fade-in 0.6s ease both;
	}

	@keyframes idrozn-fade-in {
		from {
			opacity: 0;
			transform: translateY(12px);
		}
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}
}

/* ============================================
   Print styles
   ============================================ */

@media print {

	header.wp-block-template-part,
	.wp-block-template-part[data-area="footer"],
	.wp-block-buttons {
		display: none !important;
	}

	body {
		font-size: 12pt;
		color: #000;
	}
}
