/*
 * sadi-theme — couche "pixel" superposée au thème parent.
 * Pas d'images : tout est CSS pur (perf + RGPD, aucune requête tierce).
 */

:root {
	--sadi-shadow-pixel:
		0 4px 0 0 var(--wp--preset--color--border),
		4px 0 0 0 var(--wp--preset--color--border),
		0 -4px 0 0 var(--wp--preset--color--border),
		-4px 0 0 0 var(--wp--preset--color--border);
	--sadi-shadow-pixel-glow:
		0 0 0 2px var(--wp--preset--color--turquoise),
		0 0 24px -4px var(--wp--preset--color--turquoise);
	--sadi-shake-distance: 1px;
}

/* Anti-anti-aliasing pour images web-comic */
.wp-block-image.is-style-pixel img,
.sadi-pixel-img img {
	image-rendering: pixelated;
	image-rendering: -moz-crisp-edges;
	image-rendering: crisp-edges;
}

/* Bordures "pixel" pour cartes et boutons */
.wp-block-button .wp-block-button__link,
.wp-block-quote,
.wp-block-pullquote,
.wp-block-code,
.sadi-pixel-card {
	border-radius: 0 !important;
	position: relative;
}

.wp-block-button .wp-block-button__link {
	box-shadow: var(--sadi-shadow-pixel);
	transition: transform 80ms steps(2), box-shadow 80ms steps(2);
}

.wp-block-button .wp-block-button__link:hover,
.wp-block-button .wp-block-button__link:focus-visible {
	background-image: none;
	background-color: var(--wp--preset--color--turquoise) !important;
	color: #0a0e14 !important;
	box-shadow: var(--sadi-shadow-pixel-glow);
	outline: none;
}

/* Titre Hero — soulignement dégradé rouge-orange */
h1.has-hero-font-size,
.sadi-hero-title {
	background-image: var(--wp--preset--gradient--fire);
	-webkit-background-clip: text;
	background-clip: text;
	color: transparent;
	display: inline-block;
	padding-bottom: 0.15em;
	border-bottom: 4px solid;
	border-image: var(--wp--preset--gradient--fire) 1;
}

/* Liens : underline pixel au survol */
a {
	text-underline-offset: 0.2em;
	text-decoration-thickness: 2px;
}
a:hover {
	color: var(--wp--preset--color--green);
}

/* Effet "shake" léger sur interactions, désactivé si reduced motion */
@media (prefers-reduced-motion: no-preference) {
	.wp-block-button .wp-block-button__link:active,
	.sadi-shake:hover {
		animation: sadi-shake 240ms steps(4) 1;
	}
}

@keyframes sadi-shake {
	0%   { transform: translate(0, 0); }
	25%  { transform: translate(calc(var(--sadi-shake-distance) * -1), var(--sadi-shake-distance)); }
	50%  { transform: translate(var(--sadi-shake-distance), calc(var(--sadi-shake-distance) * -1)); }
	75%  { transform: translate(calc(var(--sadi-shake-distance) * -1), calc(var(--sadi-shake-distance) * -1)); }
	100% { transform: translate(0, 0); }
}

/* Embed Privacy placeholder : aspect cohérent avec le thème */
.embed-privacy-overlay {
	background-color: var(--wp--preset--color--bg-card) !important;
	border: 2px solid var(--wp--preset--color--border) !important;
	color: var(--wp--preset--color--text) !important;
	box-shadow: var(--sadi-shadow-pixel);
}
.embed-privacy-content .embed-privacy-enable {
	background-image: var(--wp--preset--gradient--fire) !important;
	color: #0a0e14 !important;
	border: 2px solid var(--wp--preset--color--border) !important;
	border-radius: 0 !important;
	font-family: var(--wp--preset--font-family--pixel-display);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Cards d'articles (archives) */
.wp-block-post-template > .wp-block-post {
	background-color: var(--wp--preset--color--bg-card);
	border: 2px solid var(--wp--preset--color--border);
	padding: 1.5rem;
	margin-bottom: 1.5rem;
	box-shadow: var(--sadi-shadow-pixel);
}

.wp-block-post-title a:hover {
	color: var(--wp--preset--color--turquoise);
}

/* Commentaires : look terminal */
.wp-block-comments,
.wp-block-comment-template li {
	background-color: var(--wp--preset--color--bg-card);
	border-left: 4px solid var(--wp--preset--color--turquoise);
	padding: 1rem 1.25rem;
	margin-bottom: 1rem;
}

.comment-form textarea,
.comment-form input[type="text"],
.comment-form input[type="email"] {
	background-color: var(--wp--preset--color--bg-deep);
	color: var(--wp--preset--color--text);
	border: 2px solid var(--wp--preset--color--border);
	border-radius: 0;
	font-family: var(--wp--preset--font-family--pixel-text);
	padding: 0.6rem 0.8rem;
}

.comment-form textarea:focus,
.comment-form input:focus {
	outline: none;
	border-color: var(--wp--preset--color--turquoise);
	box-shadow: 0 0 0 2px var(--wp--preset--color--turquoise);
}

/* Sélection texte teintée Undertale */
::selection {
	background: var(--wp--preset--color--turquoise);
	color: var(--wp--preset--color--bg-deep);
}

/* Header collant au scroll — chasse les overflow ancêtres qui cassent sticky */
html,
body,
.wp-site-blocks,
.wp-site-blocks > .is-layout-flow,
.wp-site-blocks > .wp-block-group {
	overflow: visible !important;
}

html {
	overflow-x: clip;
}

.wp-site-blocks > header,
.wp-site-blocks > .wp-block-template-part,
header.wp-block-template-part,
header.wp-block-group.alignfull {
	position: sticky !important;
	top: 0;
	z-index: 100;
	backdrop-filter: blur(4px);
}

/* Scrollbar discrète sombre */
* {
	scrollbar-color: var(--wp--preset--color--border) var(--wp--preset--color--bg-deep);
	scrollbar-width: thin;
}
