/* ==========================================================================
   Le Ratier Bretonnien — Components CSS
   Dark Fantasy Theme — Site Components
   ========================================================================== */

/* ==========================================================================
   HEADER
   ========================================================================== */

/* ==========================================================================
   HEADER — Hero version with background banner image
   ========================================================================== */

.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background-color: var(--rb-bg) !important;
	padding-top: 0 !important;
	padding-bottom: 0 !important;
	box-shadow: 0 2px 16px rgba(80, 55, 20, 0.18), 0 2px 0 rgba(138, 21, 21, 0.25);
	/* Expose header height for sticky sidebar offset */
	--rb-header-height: 210px;
}

/* Hero: override heading tokens locally — background is the dark castle image */
.site-header-hero {
	--rb-heading:     #d8d0c0;
	--rb-heading-dim: #a8a098;
}

/* ——— Hero zone ——— */
.site-header-hero {
	position: relative;
	background-image:
		/* gradient : vignette sombre, centre ouvert sur le château */
		linear-gradient(to bottom,
			rgba(10, 8, 8, 0.88) 0%,
			rgba(10, 8, 8, 0.35) 35%,
			rgba(10, 8, 8, 0.30) 65%,
			rgba(10, 8, 8, 0.88) 100%),
		url('../images/banner-header.jpg');
	background-size: cover;
	background-position: center 30%;
	background-repeat: no-repeat;
	overflow: hidden;
}

/* Crimson ember line at bottom of hero */
.site-header-hero::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	right: 0;
	height: 2px;
	background: linear-gradient(to right,
		transparent,
		rgba(160, 24, 24, 0.5) 20%,
		var(--rb-crimson) 50%,
		rgba(160, 24, 24, 0.5) 80%,
		transparent);
}

/* ——— Branding inside hero ——— */
.site-branding-hero {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: 1.5rem var(--wp--preset--spacing--m) !important;
}

/* Fade-in animation on page load */
@keyframes rb-fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-12px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.site-branding-hero .wp-block-site-title,
.site-branding-hero .wp-block-site-tagline,
.site-branding-hero .site-logo {
	animation: rb-fadeInDown 0.9s ease-out both;
}

.site-branding-hero .wp-block-site-tagline {
	animation-delay: 0.15s;
}

/* Site title — overlaid on image, prominent — ivoire sur fond de château */
.site-branding-hero .wp-block-site-title a,
.site-branding-hero .wp-block-site-title {
	font-family: var(--rb-font-display) !important;
	font-weight: 900;
	font-size: clamp(1.7rem, 4.5vw, 3rem) !important;
	color: var(--rb-heading) !important;
	text-decoration: none !important;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	line-height: 1.15;
	text-shadow:
		0 2px 20px rgba(0, 0, 0, 0.95),
		0 0 50px rgba(240, 232, 208, 0.08),
		0 1px 3px rgba(0, 0, 0, 1);
	transition: color var(--rb-transition), text-shadow var(--rb-transition);
}

.site-branding-hero .wp-block-site-title a:hover {
	color: #fff !important;
	text-shadow:
		0 2px 20px rgba(0, 0, 0, 0.95),
		0 0 60px rgba(240, 232, 208, 0.2);
}

.site-branding-hero .wp-block-site-tagline {
	font-style: italic;
	font-size: 0.85rem !important;
	letter-spacing: 0.12em;
	color: var(--rb-heading-dim) !important;
	opacity: 0.8;
	text-shadow: 0 1px 6px rgba(0, 0, 0, 0.9);
}

/* Site logo above title */
.site-branding-hero .site-logo img,
.site-branding-hero .wp-block-site-logo img {
	filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.8)) drop-shadow(0 0 20px rgba(240, 232, 208, 0.15));
}

/* ——— Nav bar ——— */
.site-nav-bar {
	background-color: var(--rb-surface) !important;
	border-top: 1px solid var(--rb-crimson) !important;
	border-bottom: 1px solid var(--rb-border) !important;
	padding: 0.6rem var(--wp--preset--spacing--m) !important;
}

.site-nav-bar .wp-block-navigation,
.site-nav-bar .primary-nav {
	justify-content: center;
}

/* Fallback: keep old branding rules working if present */
.site-branding .site-title a,
.wp-block-site-title a {
	font-family: var(--rb-font-display) !important;
	font-weight: 900;
	color: var(--rb-heading) !important;
	text-decoration: none !important;
	letter-spacing: 0.04em;
	transition: color var(--rb-transition);
}

.wp-block-site-tagline {
	font-style: italic;
	color: var(--rb-text-muted) !important;
	letter-spacing: 0.08em;
}

/* Navigation principale */
.wp-block-navigation,
.primary-nav {
	gap: 0 !important;
}

.wp-block-navigation a,
.primary-nav a {
	font-family: var(--rb-font-heading);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--rb-text-sepia);
	text-decoration: none;
	padding: 0.6em 0.9em !important;
	position: relative;
	transition: color var(--rb-transition);
}

.wp-block-navigation a::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%) scaleX(0);
	width: 60%;
	height: 2px;
	background: var(--rb-crimson);
	transition: transform var(--rb-transition);
}

.wp-block-navigation a:hover,
.wp-block-navigation .current-menu-item > a {
	color: var(--rb-crimson-light) !important;
}

.wp-block-navigation a:hover::after,
.wp-block-navigation .current-menu-item > a::after {
	transform: translateX(-50%) scaleX(1);
}

/* Sous-menus */
.wp-block-navigation .wp-block-navigation__submenu-container {
	background: var(--rb-surface) !important;
	border: 1px solid var(--rb-border) !important;
	border-top: 2px solid var(--rb-crimson) !important;
	box-shadow: var(--rb-shadow-deep) !important;
	min-width: 200px;
}

.wp-block-navigation .wp-block-navigation__submenu-container a {
	padding: 0.5em 1em !important;
	border-bottom: 1px solid var(--rb-border);
}

.wp-block-navigation .wp-block-navigation__submenu-container a:last-child {
	border-bottom: none;
}

/* Menu mobile */
.wp-block-navigation__responsive-dialog {
	background: var(--rb-surface) !important;
}

.wp-block-navigation__responsive-container-open,
.wp-block-navigation__responsive-container-close {
	color: var(--rb-crimson-light) !important;
}

/* Ligne ornementale sous le header */
.header-ornament .ornament-line {
	font-size: 0.8rem !important;
	letter-spacing: 0.3em;
	color: var(--rb-border) !important;
	margin: 0 !important;
	padding: 0 !important;
}

/* ==========================================================================
   MAIN LAYOUT
   ========================================================================== */

.site-main {
	min-height: 60vh;
	background: var(--rb-bg);
	padding-top: var(--wp--preset--spacing--s) !important;
	padding-bottom: var(--wp--preset--spacing--xl);
	margin-top: 0 !important;
}

/* Template-specific padding overrides */
.error-404-template {
	padding-top: var(--wp--preset--spacing--xxl);
	padding-bottom: var(--wp--preset--spacing--xxl);
}

.page-no-sidebar {
	padding-top: var(--wp--preset--spacing--xl);
	padding-bottom: var(--wp--preset--spacing--xl);
}

.content-sidebar-wrap {
	align-items: flex-start !important;
}

.content-column {
	flex-basis: 67% !important;
	flex-shrink: 1;
	flex-grow: 0;
	min-width: 0;
}

.sidebar-column {
	flex-basis: 33% !important;
	flex-shrink: 1;
	flex-grow: 0;
	min-width: 0;
}

/* ==========================================================================
   CONTENT PANELS — Zones structurelles avec bordures et fond
   ========================================================================== */

/* En-têtes de page, article, archive, recherche */
.post-header,
.page-header,
.archive-header,
.search-header {
	border: 1px solid var(--rb-border) !important;
	border-bottom: 2px solid var(--rb-crimson) !important;
	background-color: var(--rb-surface) !important;
	padding: var(--wp--preset--spacing--s) var(--wp--preset--spacing--l);
}

.page-header {
	margin-bottom: var(--wp--preset--spacing--m);
}

.archive-header,
.search-header {
	margin-bottom: var(--wp--preset--spacing--m);
}

/* Corps de l'article / page */
.entry-body {
	border: 1px solid var(--rb-border) !important;
	background-color: var(--rb-surface) !important;
	padding-top: var(--wp--preset--spacing--xl);
	padding-right: var(--wp--preset--spacing--m);
	padding-bottom: var(--wp--preset--spacing--xl);
	padding-left: var(--wp--preset--spacing--m);
}

.page-no-sidebar .entry-body {
	padding: var(--wp--preset--spacing--xl);
}

/* Pied d'article (catégories, tags) */
.post-footer {
	border: 1px solid var(--rb-border) !important;
	border-top: 2px solid var(--rb-crimson) !important;
	background-color: var(--rb-surface) !important;
	margin-top: var(--wp--preset--spacing--l);
	padding: var(--wp--preset--spacing--l);
}

/* Navigation article précédent / suivant */
.post-navigation {
	border: 1px solid var(--rb-border) !important;
	background-color: var(--rb-surface) !important;
	margin-top: var(--wp--preset--spacing--l);
	padding: var(--wp--preset--spacing--m) var(--wp--preset--spacing--l);
}

/* Zone commentaires */
.comments-area {
	margin-top: var(--wp--preset--spacing--xl);
}

/* Chaque commentaire individuel */
.comments-area .wp-block-comment-template .wp-block-group {
	border: 1px solid var(--rb-border) !important;
	background-color: var(--rb-surface) !important;
	padding: var(--wp--preset--spacing--m);
}

/* Avatar dans les commentaires */
.comments-area .wp-block-avatar img {
	border-radius: 50%;
	border: 1px solid var(--rb-border);
}

/* Titre de la section commentaires */
.comments-title {
	color: var(--rb-gold) !important;
	font-family: var(--rb-font-heading) !important;
	letter-spacing: 0.06em !important;
}

/* ==========================================================================
   POST CARDS (liste d'articles)
   ========================================================================== */

.post-card {
	border: 1px solid var(--rb-border) !important;
	background-color: var(--rb-surface) !important;
	transition: box-shadow var(--rb-transition), transform var(--rb-transition);
	overflow: hidden;
}

/* Corps interne de la carte */
.post-card-body {
	padding: var(--wp--preset--spacing--l);
}

/* Carte dans la page de recherche */
.search-card {
	padding: var(--wp--preset--spacing--m) var(--wp--preset--spacing--l);
}

.post-card:hover {
	box-shadow: var(--rb-shadow-crimson);
	transform: translateY(-2px);
}

/* Image à la une */
.post-thumbnail img,
.post-card .wp-block-post-featured-image img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform 0.4s ease, filter 0.4s ease;
	filter: saturate(0.92);
}

.post-card:hover .post-thumbnail img,
.post-card:hover .wp-block-post-featured-image img {
	transform: scale(1.03);
	filter: saturate(1);
}

/* Catégories */
.post-categories,
.wp-block-post-terms {
	font-family: var(--rb-font-heading) !important;
	font-size: 0.7rem !important;
	font-weight: 700 !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	color: var(--rb-crimson-light) !important;
}

.post-categories a,
.wp-block-post-terms a {
	color: var(--rb-crimson-light) !important;
	text-decoration: none;
	transition: color var(--rb-transition);
}

.post-categories a:hover,
.wp-block-post-terms a:hover {
	color: var(--rb-heading) !important;
}

/* Titre d'article dans la liste */
.post-card .entry-title,
.post-card .wp-block-post-title {
	font-family: var(--rb-font-display) !important;
	color: var(--rb-heading) !important;
	font-size: clamp(1.1rem, 2.5vw, 1.5rem) !important;
	line-height: 1.3;
	margin: 0.4em 0 0.6em;
	transition: color var(--rb-transition);
}

.post-card .entry-title a,
.post-card .wp-block-post-title a {
	color: var(--rb-heading) !important;
	text-decoration: none !important;
}

.post-card .entry-title a:hover,
.post-card .wp-block-post-title a:hover {
	color: var(--rb-crimson-light) !important;
}

/* Méta-données */
.post-meta,
.wp-block-post-author-name,
.wp-block-post-date {
	font-family: var(--rb-font-heading) !important;
	font-size: 0.75rem !important;
	color: var(--rb-text-muted) !important;
	letter-spacing: 0.05em;
}

.post-meta .wp-block-post-author-name::before {
	content: '✍ ';
	opacity: 0.6;
}

.post-meta .wp-block-post-date::before {
	content: '📅 ';
	opacity: 0.6;
}

/* Extrait */
.entry-excerpt,
.wp-block-post-excerpt {
	color: var(--rb-text-sepia) !important;
	font-size: 1rem !important;
	line-height: 1.75;
	margin: 0.75em 0 1em;
}

.wp-block-post-excerpt__more-text {
	display: none; /* Géré par le bouton read-more */
}

/* Bouton Lire la suite */
.read-more-btn .wp-block-read-more,
.read-more-btn,
a.read-more {
	display: inline-block;
	font-family: var(--rb-font-heading) !important;
	font-size: 0.75rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.1em !important;
	text-transform: uppercase !important;
	color: var(--rb-heading) !important;
	border: 1px solid var(--rb-crimson) !important;
	border-radius: 2px !important;
	padding: 0.5em 1.2em !important;
	text-decoration: none !important;
	transition: background-color var(--rb-transition), color var(--rb-transition), box-shadow var(--rb-transition) !important;
	background: transparent !important;
}

.read-more-btn .wp-block-read-more:hover,
.read-more-btn:hover,
a.read-more:hover {
	background: var(--rb-crimson) !important;
	color: var(--rb-heading) !important;
	box-shadow: var(--rb-shadow-crimson) !important;
}

/* ==========================================================================
   SINGLE POST
   ========================================================================== */

.single-title.entry-title,
.single-post .wp-block-post-title {
	font-size: clamp(1.5rem, 4vw, 2.5rem) !important;
}

.single-featured-image img {
	filter: saturate(0.92);
}

/* Contenu de l'article */
.entry-content {
	font-size: clamp(1rem, 1.5vw, 1.125rem);
	line-height: 1.9;
}

.entry-content > * + * {
	margin-top: 1.5em;
}

.entry-content h2,
.entry-content h3,
.entry-content h4 {
	margin-top: 2.5em;
	margin-bottom: 0.75em;
	padding-bottom: 0.3em;
	border-bottom: 1px solid var(--rb-border);
}

.entry-content h2::before,
.entry-content h3::before {
	content: '❧ ';
	font-size: 0.7em;
	opacity: 0.5;
	color: var(--rb-heading);
}

.entry-content ul,
.entry-content ol {
	margin-left: 1.25em;
}

/* Blockquote — barre cramoisi latérale */
.entry-content blockquote,
.wp-block-quote {
	border-left: 3px solid var(--rb-crimson) !important;
	padding: 0.8em 1.2em !important;
	margin: 1.5em 0 !important;
	background: var(--rb-surface) !important;
	border-radius: 0 2px 2px 0 !important;
}

.entry-content blockquote p,
.wp-block-quote p {
	color: var(--rb-text) !important;
	font-style: italic;
}

/* Liens dans le contenu */
.entry-content a {
	color: var(--rb-crimson-light);
	text-decoration: underline;
	text-decoration-color: var(--rb-crimson-dim);
	transition: color var(--rb-transition);
}

.entry-content a:hover {
	color: var(--rb-heading);
}

.entry-content li {
	margin-bottom: 0.5em;
}

.entry-content img {
	border: 1px solid var(--rb-border);
	box-shadow: var(--rb-shadow-card);
}

/* Galerie WordPress */
.gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
	gap: 0.75rem;
	margin: 2em 0;
}

.gallery-item img {
	width: 100%;
	height: auto;
	border: 1px solid var(--rb-border);
	transition: border-color var(--rb-transition), transform var(--rb-transition);
}

.gallery-item img:hover {
	border-color: var(--rb-crimson);
	transform: scale(1.02);
}

/* Navigation article précédent/suivant */
.post-navigation .wp-block-post-navigation-link a {
	font-family: var(--rb-font-heading) !important;
	font-size: 0.75rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: var(--rb-heading) !important;
	text-decoration: none !important;
	transition: color var(--rb-transition) !important;
}

.post-navigation .wp-block-post-navigation-link a:hover {
	color: var(--rb-crimson-light) !important;
}

/* ==========================================================================
   COMMENTAIRES
   ========================================================================== */

.comments-area {
	margin-top: 3rem;
}

.comments-title.wp-block-comments-title {
	font-family: var(--rb-font-heading) !important;
	font-size: 1.1rem !important;
	color: var(--rb-heading) !important;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	border-bottom: 2px solid var(--rb-crimson);
	padding-bottom: 0.5em;
	margin-bottom: 1.5rem;
}

/* Formulaire de commentaire */
.wp-block-post-comments-form label {
	font-family: var(--rb-font-heading);
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--rb-text-sepia);
}

.wp-block-post-comments-form .comment-form-comment textarea {
	min-height: 160px;
}

.wp-block-post-comments-form .submit {
	background: transparent;
	color: var(--rb-crimson-light);
	border: 1px solid var(--rb-crimson);
	font-family: var(--rb-font-heading);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.6em 1.5em;
	cursor: pointer;
	border-radius: 2px;
	transition: background-color var(--rb-transition), color var(--rb-transition);
}

.wp-block-post-comments-form .submit:hover {
	background: var(--rb-crimson);
	color: var(--rb-heading);
}

/* ==========================================================================
   PAGINATION
   ========================================================================== */

.pagination .wp-block-query-pagination {
	margin-top: 3rem;
}

.wp-block-query-pagination {
	gap: 0.5rem !important;
	justify-content: space-between;
	align-items: center;
}

.wp-block-query-pagination-previous,
.wp-block-query-pagination-next {
	font-family: var(--rb-font-heading) !important;
	font-size: 0.75rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: var(--rb-heading) !important;
	border: 1px solid var(--rb-border) !important;
	padding: 0.5em 1em !important;
	border-radius: 2px !important;
	text-decoration: none !important;
	transition: border-color var(--rb-transition), background-color var(--rb-transition) !important;
}

.wp-block-query-pagination-previous:hover,
.wp-block-query-pagination-next:hover {
	border-color: var(--rb-crimson) !important;
	background: var(--rb-surface) !important;
}

.wp-block-query-pagination-numbers .page-numbers {
	font-family: var(--rb-font-heading) !important;
	font-size: 0.75rem !important;
	color: var(--rb-text-muted) !important;
	padding: 0.3em 0.6em !important;
	border: 1px solid transparent !important;
	border-radius: 2px !important;
	text-decoration: none !important;
	transition: color var(--rb-transition), border-color var(--rb-transition) !important;
}

.wp-block-query-pagination-numbers .page-numbers:hover,
.wp-block-query-pagination-numbers .page-numbers.current {
	color: var(--rb-crimson-light) !important;
	border-color: var(--rb-crimson) !important;
}

/* ==========================================================================
   SIDEBAR
   ========================================================================== */

.sidebar,
.widget-area {
	border: 1px solid var(--rb-border) !important;
	background-color: var(--rb-surface) !important;
	padding: var(--wp--preset--spacing--l) var(--wp--preset--spacing--m) !important;
	position: sticky;
	top: calc(var(--rb-header-height, 170px) + 1rem);
	max-height: calc(100vh - var(--rb-header-height, 170px) - 2rem);
	overflow-y: auto;
	scrollbar-width: thin;
	scrollbar-color: var(--rb-border) transparent;
}

.sidebar::-webkit-scrollbar {
	width: 4px;
}

.sidebar::-webkit-scrollbar-track {
	background: transparent;
}

.sidebar::-webkit-scrollbar-thumb {
	background: var(--rb-border);
	border-radius: 2px;
}

/* Widget titles */
.widget-title {
	font-family: var(--rb-font-heading) !important;
	font-size: var(--wp--preset--font-size--small) !important;
	font-weight: 700 !important;
	letter-spacing: 0.12em !important;
	text-transform: uppercase !important;
	color: var(--rb-gold) !important;
	padding-bottom: 0.6em;
	margin-bottom: 0.8em !important;
	position: relative;
}

.widget-title::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 1px;
	background: linear-gradient(to right, var(--rb-crimson-dim), var(--rb-crimson), transparent);
}

/* Séparateurs entre widgets */
.widget-divider {
	border-top: 1px solid var(--rb-border) !important;
	background-color: var(--rb-border) !important;
	margin: 0 !important;
}

/* Formulaire de recherche sidebar */
.widget-search .wp-block-search__inside-wrapper {
	display: flex;
	gap: 0;
	border: 1px solid var(--rb-border);
	border-radius: 2px;
	overflow: hidden;
	transition: border-color var(--rb-transition);
}

.widget-search .wp-block-search__inside-wrapper:focus-within {
	border-color: var(--rb-crimson);
}

.widget-search .wp-block-search__input {
	background: var(--rb-bg);
	border: none !important;
	color: var(--rb-text) !important;
	font-family: var(--rb-font-body) !important;
	font-size: 0.875rem;
	padding: 0.55em 0.8em !important;
	flex: 1;
	outline: none !important;
	box-shadow: none !important;
}

.widget-search .wp-block-search__input::placeholder {
	color: var(--rb-text-muted);
	font-style: italic;
}

.widget-search .wp-block-search__button {
	background: var(--rb-surface) !important;
	border: none !important;
	border-left: 1px solid var(--rb-border) !important;
	color: var(--rb-heading) !important;
	padding: 0 0.75em !important;
	cursor: pointer;
	transition: background-color var(--rb-transition) !important;
}

.widget-search .wp-block-search__button:hover {
	background: var(--rb-crimson) !important;
	color: var(--rb-heading) !important;
}

/* Liste de catégories */
.fantasy-categories.wp-block-categories-list,
.wp-block-categories {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.wp-block-categories li,
.fantasy-categories li {
	border-bottom: 1px solid var(--rb-border);
	margin: 0 !important;
}

.wp-block-categories li:last-child,
.fantasy-categories li:last-child {
	border-bottom: none;
}

.wp-block-categories a,
.fantasy-categories a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.45em 0;
	font-family: var(--rb-font-heading) !important;
	font-size: 0.8125rem !important;
	color: var(--rb-text-sepia) !important;
	text-decoration: none !important;
	transition: color var(--rb-transition), padding-left var(--rb-transition) !important;
}

.wp-block-categories a:hover,
.fantasy-categories a:hover {
	color: var(--rb-crimson-light) !important;
	padding-left: 0.4em;
}

.wp-block-categories .wp-block-categories-list-count,
.fantasy-categories .wp-block-categories-list-count {
	font-size: 0.7rem;
	color: var(--rb-text-muted);
	background: var(--rb-elevated);
	border: 1px solid var(--rb-border);
	padding: 0.1em 0.4em;
	border-radius: 2px;
	font-family: var(--rb-font-heading);
}

/* Articles récents */
.fantasy-recent-posts.wp-block-latest-posts {
	list-style: none !important;
	padding: 0 !important;
	margin: 0 !important;
}

.fantasy-recent-posts li,
.wp-block-latest-posts li {
	border-bottom: 1px solid var(--rb-border);
	padding: 0.5em 0;
	margin: 0 !important;
}

.fantasy-recent-posts li:last-child,
.wp-block-latest-posts li:last-child {
	border-bottom: none;
}

.fantasy-recent-posts a,
.wp-block-latest-posts__post-title {
	font-family: var(--rb-font-body) !important;
	font-size: 0.875rem !important;
	color: var(--rb-text-sepia) !important;
	text-decoration: none !important;
	line-height: 1.45;
	transition: color var(--rb-transition) !important;
	display: block;
}

.fantasy-recent-posts a:hover,
.wp-block-latest-posts__post-title:hover {
	color: var(--rb-crimson-light) !important;
}

.wp-block-latest-posts__post-date {
	display: block;
	font-family: var(--rb-font-heading) !important;
	font-size: 0.7rem !important;
	color: var(--rb-text-muted) !important;
	letter-spacing: 0.04em;
	margin-top: 0.2em;
}

/* Nuage de tags */
.fantasy-tags.wp-block-tag-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 0.4rem;
}

.wp-block-tag-cloud a {
	font-family: var(--rb-font-heading) !important;
	font-size: 0.7rem !important;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--rb-text-muted) !important;
	border: 1px solid var(--rb-border);
	padding: 0.2em 0.55em;
	border-radius: 2px;
	text-decoration: none !important;
	transition: color var(--rb-transition), border-color var(--rb-transition), background-color var(--rb-transition) !important;
	white-space: nowrap;
}

.wp-block-tag-cloud a:hover {
	color: var(--rb-crimson-light) !important;
	border-color: var(--rb-crimson-dim) !important;
	background: var(--rb-elevated) !important;
}

/* ==========================================================================
   FOOTER
   ========================================================================== */

.site-footer {
	background: var(--rb-bg) !important;
	border-top: 2px solid var(--rb-crimson) !important;
	padding-top: var(--wp--preset--spacing--xl) !important;
	padding-bottom: var(--wp--preset--spacing--l) !important;
}

/* Ornement typographique en haut du footer */
.footer-ornament {
	margin-bottom: var(--wp--preset--spacing--l);
}

.footer-ornament p {
	color: var(--rb-border);
	font-size: 1.5rem;
	letter-spacing: 0.4em;
	text-align: center;
}

/* Description du blog dans le footer */
.footer-about p {
	color: var(--rb-text-muted);
	font-size: var(--wp--preset--font-size--small);
}

.footer-site-title a {
	font-family: var(--rb-font-display) !important;
	font-size: 1.1rem !important;
	color: var(--rb-heading) !important;
	text-decoration: none !important;
}

.footer-widget-title {
	font-family: var(--rb-font-heading) !important;
	font-size: var(--wp--preset--font-size--small) !important;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--rb-gold) !important;
	border-bottom: 1px solid var(--rb-border);
	padding-bottom: 0.6em;
	margin-bottom: 1rem !important;
}

.footer-nav .wp-block-navigation a {
	font-size: 0.8125rem;
	padding: 0.3em 0 !important;
	letter-spacing: 0.05em;
}

.footer-nav .wp-block-navigation a::after {
	display: none;
}

/* Bande de bas de footer (copyright + crédits) */
.footer-bottom {
	max-width: var(--rb-wide-width);
	margin-left: auto;
	margin-right: auto;
	border-top: 1px solid var(--rb-border) !important;
	padding-top: var(--wp--preset--spacing--m) !important;
	margin-top: var(--wp--preset--spacing--l) !important;
}

.footer-bottom p {
	color: var(--rb-text-muted) !important;
	font-size: var(--wp--preset--font-size--x-small) !important;
}

/* ==========================================================================
   ARCHIVE / SEARCH HEADERS
   ========================================================================== */

.archive-title.wp-block-query-title,
.search-title.wp-block-query-title {
	font-family: var(--rb-font-display) !important;
	color: var(--rb-heading) !important;
	font-size: clamp(1.3rem, 3vw, 2rem) !important;
}

.archive-description {
	font-style: italic;
	color: var(--rb-text-muted) !important;
}

/* ==========================================================================
   PAGE 404
   ========================================================================== */

.error-404-content {
	max-width: 640px;
	margin: 0 auto;
	text-align: center;
	border: 2px solid var(--rb-crimson) !important;
	background-color: var(--rb-surface) !important;
	padding: var(--wp--preset--spacing--xl) !important;
}

/* Grand chiffre "404" */
.error-number {
	color: var(--rb-heading) !important;
	font-size: clamp(5rem, 15vw, 10rem) !important;
	font-family: var(--rb-font-display) !important;
	font-weight: 900 !important;
	line-height: 1 !important;
	letter-spacing: 0.1em !important;
	background: linear-gradient(135deg, var(--rb-elevated), var(--rb-bg));
	-webkit-background-clip: text;
	background-clip: text;
}

/* Sous-titre "Contrée Inconnue" */
.error-subtitle {
	color: var(--rb-gold) !important;
	font-size: var(--wp--preset--font-size--x-large) !important;
	font-family: var(--rb-font-display) !important;
	font-weight: 700 !important;
	letter-spacing: 0.04em !important;
}

/* Texte de lore */
.error-message {
	color: var(--rb-text-sepia) !important;
	font-style: italic !important;
	font-size: var(--wp--preset--font-size--large) !important;
	font-family: var(--rb-font-body) !important;
}

/* Astuce de recherche */
.error-hint {
	color: var(--rb-text-muted) !important;
	font-size: var(--wp--preset--font-size--normal) !important;
	font-family: var(--rb-font-heading) !important;
}

/* Bouton "Retour à l'accueil" */
.return-home-btn .wp-block-button__link {
	border: 1px solid var(--rb-crimson) !important;
	border-radius: 2px !important;
	background: transparent !important;
	color: var(--rb-gold) !important;
	font-family: var(--rb-font-heading) !important;
	font-size: var(--wp--preset--font-size--small) !important;
	letter-spacing: 0.1em !important;
	text-transform: uppercase !important;
	padding: 0.7em 2em !important;
	text-decoration: none !important;
	transition: background-color var(--rb-transition), color var(--rb-transition) !important;
}

.return-home-btn .wp-block-button__link:hover {
	background: var(--rb-crimson) !important;
	color: var(--rb-surface) !important;
}

/* ==========================================================================
   ORNEMENTS DÉCORATIFS
   ========================================================================== */

/* Dividers ornementaux */
.wp-block-separator {
	border: none !important;
	text-align: center;
	position: relative;
	margin: 2em auto !important;
	height: 1px;
	background: linear-gradient(to right, transparent, var(--rb-border), transparent) !important;
}

.wp-block-separator::after {
	content: '⚜';
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: var(--rb-bg);
	color: var(--rb-crimson-dim);
	padding: 0 0.75em;
	font-size: 0.9em;
}

/* Décor de coin sur les cartes — cramoisi */
.post-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 24px;
	height: 24px;
	border-top: 2px solid var(--rb-crimson-dim);
	border-left: 2px solid var(--rb-crimson-dim);
	opacity: 0;
	transition: opacity var(--rb-transition);
	pointer-events: none;
}

.post-card::after {
	content: '';
	position: absolute;
	bottom: 0;
	right: 0;
	width: 24px;
	height: 24px;
	border-bottom: 2px solid var(--rb-crimson-dim);
	border-right: 2px solid var(--rb-crimson-dim);
	opacity: 0;
	transition: opacity var(--rb-transition);
	pointer-events: none;
}

.post-card:hover::before,
.post-card:hover::after {
	opacity: 1;
}

.post-card {
	position: relative;
}

/* ==========================================================================
   GALERIE ET MÉDIAS
   ========================================================================== */

.wp-block-image img {
	border: 1px solid var(--rb-border);
	box-shadow: var(--rb-shadow-card);
}

.wp-block-image figcaption {
	font-family: var(--rb-font-heading);
	font-size: 0.75rem;
	color: var(--rb-text-muted);
	letter-spacing: 0.04em;
	font-style: italic;
	text-align: center;
	margin-top: 0.5em;
}

.wp-block-gallery {
	gap: 0.5rem !important;
}

.wp-block-gallery .wp-block-image img {
	transition: filter var(--rb-transition);
}

.wp-block-gallery .wp-block-image:hover img {
	filter: brightness(1.1);
}

/* Embeds responsive */
.wp-block-embed {
	max-width: 100%;
}

.wp-block-embed__wrapper {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}

.wp-block-embed__wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: 1px solid var(--rb-border);
}

/* ==========================================================================
   COVER BLOCK
   ========================================================================== */

.wp-block-cover {
	border: 1px solid var(--rb-border) !important;
	box-shadow: var(--rb-shadow-deep) !important;
}

.wp-block-cover .wp-block-cover__inner-container {
	position: relative;
	z-index: 1;
}

/* ==========================================================================
   BOUTONS (Blocks WordPress)
   ========================================================================== */

.wp-block-button__link {
	font-family: var(--rb-font-heading) !important;
	font-size: 0.8rem !important;
	font-weight: 600 !important;
	letter-spacing: 0.1em !important;
	text-transform: uppercase !important;
	border-radius: 2px !important;
	transition: background-color var(--rb-transition), color var(--rb-transition), box-shadow var(--rb-transition) !important;
}

/* Bouton outline */
.is-style-outline .wp-block-button__link {
	background: transparent !important;
	border-color: var(--rb-crimson) !important;
	color: var(--rb-heading) !important;
}

.is-style-outline .wp-block-button__link:hover {
	background: var(--rb-crimson) !important;
	color: var(--rb-heading) !important;
	box-shadow: var(--rb-shadow-crimson) !important;
}

/* ==========================================================================
   PAGE COVER (page-cover.html template)
   ========================================================================== */

.page-cover-hero {
	min-height: 500px !important;
	border-bottom: 3px solid var(--rb-crimson) !important;
}

.page-cover-hero .wp-block-cover__background {
	background-color: var(--rb-bg) !important;
}

/* ==========================================================================
   POST META (author, date, terms in meta bar)
   ========================================================================== */

.post-meta-bar .wp-block-post-author-name,
.post-meta-bar .wp-block-post-date,
.post-meta-bar .wp-block-post-terms {
	color: var(--rb-text-muted) !important;
	font-family: var(--rb-font-heading) !important;
	font-size: var(--wp--preset--font-size--x-small) !important;
}

/* Post navigation prev/next links */
.nav-previous a,
.nav-next a {
	font-family: var(--rb-font-heading) !important;
	font-size: var(--wp--preset--font-size--small) !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: var(--rb-gold) !important;
	text-decoration: none !important;
}

.nav-previous a:hover,
.nav-next a:hover {
	color: var(--rb-crimson) !important;
}

/* Post terms (categories/tags) in the post footer */
.post-footer .wp-block-post-terms {
	color: var(--rb-text-sepia) !important;
	font-size: var(--wp--preset--font-size--small) !important;
}

/* Featured image separator */
.single-featured-image {
	border-bottom: 2px solid var(--rb-crimson) !important;
	margin-bottom: 0 !important;
}

/* ==========================================================================
   EMPTY STATES
   ========================================================================== */

.empty-state p,
.no-posts-message p,
.search-no-results p {
	color: var(--rb-text-muted) !important;
	font-style: italic !important;
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

/* Tablette */
@media (max-width: 1024px) {
	.content-sidebar-wrap {
		gap: 2rem !important;
	}

	.sidebar {
		position: static !important;
		max-height: none !important;
		overflow-y: visible !important;
	}
}

/* Mobile */
@media (max-width: 768px) {

	.wp-block-columns.content-sidebar-wrap {
		flex-direction: column !important;
	}

	.wp-block-column.content-column,
	.wp-block-column.sidebar-column {
		width: 100% !important;
		flex-basis: 100% !important;
		max-width: 100% !important;
	}

	/* Hero header on mobile: reduce height, smaller title */
	.site-header {
		--rb-header-height: 160px;
	}

	.site-branding-hero .wp-block-site-title a,
	.site-branding-hero .wp-block-site-title {
		font-size: clamp(1.2rem, 6vw, 1.8rem) !important;
	}

	.site-branding-hero .wp-block-site-tagline {
		font-size: 0.75rem !important;
		letter-spacing: 0.08em;
	}

	.site-branding-hero {
		padding-top: 1rem !important;
		padding-bottom: 1rem !important;
	}

	/* Fallback old layout */
	.site-branding .site-title,
	.wp-block-site-title {
		font-size: clamp(1.1rem, 5vw, 1.5rem) !important;
	}

	.post-card-body {
		padding: 1.25rem !important;
	}

	.entry-body {
		padding: 1.5rem 1.25rem !important;
	}

	.footer-columns.wp-block-columns {
		flex-direction: column !important;
	}

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

/* Très petit mobile */
@media (max-width: 480px) {
	.post-card .entry-title,
	.post-card .wp-block-post-title {
		font-size: 1.1rem !important;
	}
}

/* ==========================================================================
   ACCESSIBILITÉ & FOCUS
   ========================================================================== */

:focus-visible {
	outline: 2px solid var(--rb-crimson);
	outline-offset: 3px;
}

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
}

/* Mode contraste élevé */
@media (forced-colors: active) {
	.site-header,
	.post-card,
	.widget-area {
		border: 2px solid ButtonText;
	}
}

/* ==========================================================================
   PRINT
   ========================================================================== */

@media print {
	.site-header,
	.sidebar-column,
	.site-footer,
	.post-navigation,
	.comments-area,
	.pagination {
		display: none !important;
	}

	body {
		background: white !important;
		color: black !important;
		font-size: 12pt;
	}

	.entry-body {
		border: none !important;
		background: white !important;
		padding: 0 !important;
	}

	a[href]::after {
		content: " (" attr(href) ")";
		font-size: 0.7em;
		color: var(--rb-text-muted);
	}
}
