/* ============================================================
   Les Résumés — child theme styles (Proposition 1, "Claude Design")
   Editorial identity · brand orange #F79220 · warm paper · espresso ink
   serif display (Newsreader) + grotesque body (Hanken Grotesk)
   Self-hosted fonts (no remote calls). Built clean for the rebuild.
   All custom classes are namespaced `lr-` to avoid GP/Elementor clashes.
   ============================================================ */

/* ----------------------------------------------------------------
   Self-hosted variable fonts (latin + latin-ext, font-display:swap)
   ---------------------------------------------------------------- */
@font-face {
	font-family: "Newsreader";
	font-style: normal;
	font-weight: 200 700;
	font-display: swap;
	src: url("../fonts/newsreader-var-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Newsreader";
	font-style: normal;
	font-weight: 200 700;
	font-display: swap;
	src: url("../fonts/newsreader-var-latinext.woff2") format("woff2");
	unicode-range: U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: "Newsreader";
	font-style: italic;
	font-weight: 200 700;
	font-display: swap;
	src: url("../fonts/newsreader-italic-var-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Newsreader";
	font-style: italic;
	font-weight: 200 700;
	font-display: swap;
	src: url("../fonts/newsreader-italic-var-latinext.woff2") format("woff2");
	unicode-range: U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
@font-face {
	font-family: "Hanken Grotesk";
	font-style: normal;
	font-weight: 100 900;
	font-display: swap;
	src: url("../fonts/hanken-var-latin.woff2") format("woff2");
	unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
@font-face {
	font-family: "Hanken Grotesk";
	font-style: normal;
	font-weight: 100 900;
	font-display: swap;
	src: url("../fonts/hanken-var-latinext.woff2") format("woff2");
	unicode-range: U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

/* ----------------------------------------------------------------
   Design tokens (Proposition 1 — locked)
   ---------------------------------------------------------------- */
:root {
	--lr-accent: #F79220;
	--lr-accent-hover: #E07E10;
	--lr-accent-soft: #FCEBD3;
	--lr-accent-ring: rgba(247, 146, 32, .32);

	--lr-black: #181410;
	--lr-ink: #231C15;
	--lr-charcoal: #2E2519;
	--lr-graphite: #574E44;
	--lr-mute: #948B7E;
	--lr-line: #ECE4D8;
	--lr-surface: #FAF6EF;
	--lr-white: #FFFFFF;

	--lr-cream: #F6E7CC;
	--lr-gold-ink: #8A5A16;

	--lr-grad-shell: linear-gradient(180deg, #241C15 0%, #181410 100%);
	--lr-grad-card: linear-gradient(155deg, #2E2519 0%, #191309 88%);

	--lr-font-sans: "Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
	--lr-font-serif: "Newsreader", Georgia, "Times New Roman", serif;

	--lr-r-sm: 6px;
	--lr-r-md: 9px;
	--lr-r-lg: 14px;
	--lr-r-pill: 999px;

	--lr-shadow-soft: 0 8px 26px rgba(35, 28, 21, .08);
	--lr-shadow-pop: 0 16px 44px rgba(35, 28, 21, .16);

	--lr-ease: cubic-bezier(.25, .8, .25, 1);
	--lr-dur-fast: .15s;
	--lr-dur: .25s;

	--lr-wrap: 1280px;
	--lr-pad: 40px;
}

/* ----------------------------------------------------------------
   Base / reset on top of GeneratePress
   ---------------------------------------------------------------- */
/* Raised specificity (html body / body h1…) to win over GeneratePress' dynamic
   typography/colour CSS without resorting to !important. */
html body {
	font-family: var(--lr-font-sans);
	font-size: 16px;
	line-height: 1.5;
	color: var(--lr-ink);
	background: var(--lr-surface);
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
body button,
body input,
body select,
body textarea {
	font-family: var(--lr-font-sans);
}
body h1, body h2, body h3, body h4,
.entry-content h1,
.entry-content h2,
.entry-content h3,
.entry-content h4 {
	font-family: var(--lr-font-serif);
	font-weight: 600;
	color: var(--lr-ink);
}
body a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; }

/* Let our full-bleed sections and 1280px wraps control width (override GP container). */
.generate-page-header,
.site-content .container,
#page.grid-container,
.site.grid-container {
	max-width: 100%;
}
#content.site-content {
	display: block;
	padding: 0;
	margin: 0;
	max-width: 100%;
	overflow-x: clip; /* contain stray wide children without breaking position:sticky */
}
.lr-wrap {
	max-width: var(--lr-wrap);
	margin: 0 auto;
	padding: 0 var(--lr-pad);
}

/* Accessibility */
a:focus-visible,
button:focus-visible,
input:focus-visible {
	outline: 2px solid var(--lr-accent);
	outline-offset: 2px;
}
.lr-skip-link {
	position: absolute;
	left: -9999px;
	top: 0;
	z-index: 999;
	background: var(--lr-ink);
	color: #fff;
	padding: 10px 16px;
	border-radius: 0 0 var(--lr-r-sm) 0;
}
.lr-skip-link:focus { left: 0; }

/* Scrollbar polish */
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-thumb { background: #e0d6c6; border-radius: 999px; border: 3px solid var(--lr-surface); }
::-webkit-scrollbar-thumb:hover { background: #d0c4b0; }

/* ----------------------------------------------------------------
   Shared primitives
   ---------------------------------------------------------------- */
.lr-wordmark {
	font-family: var(--lr-font-serif);
	display: inline-flex;
	align-items: baseline;
	gap: .5px;
	font-weight: 600;
	letter-spacing: -.01em;
	line-height: 1;
	white-space: nowrap;
}
.lr-wordmark .lr-dot { color: var(--lr-accent); }

.lr-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	background: var(--lr-accent);
	color: #fff;
	border: none;
	font-weight: 600;
	font-size: 15px;
	letter-spacing: .5px;
	border-radius: var(--lr-r-lg);
	padding: 14px 26px;
	cursor: pointer;
	transition: background var(--lr-dur) var(--lr-ease), box-shadow var(--lr-dur) var(--lr-ease);
}
.lr-cta:hover { background: var(--lr-accent-hover); box-shadow: 0 8px 22px var(--lr-accent-ring); color: #fff; }
.lr-cta svg { width: 18px; height: 18px; }

.lr-cta-ghost {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	background: var(--lr-white);
	color: var(--lr-ink);
	border: 1px solid var(--lr-line);
	font-weight: 600;
	font-size: 15px;
	border-radius: var(--lr-r-lg);
	padding: 13px 22px;
	cursor: pointer;
	transition: border-color var(--lr-dur) var(--lr-ease), color var(--lr-dur) var(--lr-ease);
}
.lr-cta-ghost:hover { border-color: var(--lr-accent); color: var(--lr-accent); }

.lr-card {
	background: var(--lr-white);
	border: 1px solid var(--lr-line);
	border-radius: var(--lr-r-lg);
}

/* 3D book cover (used in listings + related); takes a --cov background var */
.lr-book {
	position: relative;
	flex: none;
	border-radius: 2px 4px 4px 2px;
	transform: perspective(260px) rotateY(-22deg);
	transform-origin: left center;
	box-shadow: 2px 5px 13px rgba(35, 28, 21, .32);
	background: var(--cov, var(--lr-grad-card));
	background-size: cover;
	background-position: center;
	transition: transform var(--lr-dur) var(--lr-ease), box-shadow var(--lr-dur);
	overflow: hidden;
}
.lr-book::before {
	content: "";
	position: absolute;
	left: 0; top: 0; bottom: 0;
	width: 5px;
	border-radius: 2px 0 0 2px;
	background: rgba(0, 0, 0, .32);
	box-shadow: inset -1px 0 1px rgba(255, 255, 255, .14);
	z-index: 2;
}
.lr-book img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	display: block;
}
/* tighten cooked white margins on legacy 750×390 cover artwork */
@supports (object-view-box: inset(0)) {
	.lr-book img { object-view-box: inset(4% 24% 4% 24%); }
}

/* ----------------------------------------------------------------
   Dark chrome header
   ---------------------------------------------------------------- */
.lr-hd {
	position: sticky;
	top: 0;
	z-index: 50;
	background: var(--lr-black);
	border-bottom: 1px solid rgba(255, 255, 255, .07);
}
.lr-hd-in {
	max-width: var(--lr-wrap);
	margin: 0 auto;
	display: flex;
	align-items: center;
	gap: 28px;
	padding: 0 var(--lr-pad);
	height: 70px;
}
.lr-brand { font-size: 21px; color: #fff; }
.lr-nav { display: flex; gap: 4px; flex-wrap: wrap; }
.lr-nav a {
	padding: 8px 14px;
	font-size: 14px;
	font-weight: 500;
	color: #CBC3B8;
	border-radius: var(--lr-r-sm);
	transition: color var(--lr-dur), background var(--lr-dur);
}
.lr-nav a:hover { color: #fff; background: rgba(255, 255, 255, .08); }
.lr-nav a.lr-active,
.lr-nav .current-menu-item > a { color: var(--lr-accent); }

.lr-search {
	margin-left: auto;
	display: flex;
	align-items: center;
	gap: 9px;
	background: rgba(255, 255, 255, .07);
	border: 1px solid transparent;
	border-radius: var(--lr-r-pill);
	padding: 9px 16px;
	width: 300px;
	transition: border-color var(--lr-dur), background var(--lr-dur);
}
.lr-search:focus-within { background: rgba(255, 255, 255, .12); border-color: rgba(255, 255, 255, .18); }
.lr-search svg { color: #9c9488; flex: none; }
.lr-search input {
	border: none;
	background: none;
	outline: none;
	font-size: 14px;
	width: 100%;
	color: #fff;
}
.lr-search input::placeholder { color: #9c9488; }
.lr-search button { display: none; }

.lr-reassure {
	margin-left: auto;
	display: inline-flex;
	align-items: center;
	gap: 9px;
	font-size: 14px;
	color: #CBC3B8;
	white-space: nowrap;
}
.lr-reassure svg { color: var(--lr-accent); flex: none; }
.lr-reassure b { color: #fff; font-weight: 500; }

.lr-burger { display: none; }

/* ----------------------------------------------------------------
   Dark chrome footer
   ---------------------------------------------------------------- */
.lr-ft {
	background: var(--lr-grad-shell);
	color: var(--lr-surface);
	margin-top: 72px;
}
.lr-ft-in {
	max-width: var(--lr-wrap);
	margin: 0 auto;
	padding: 54px var(--lr-pad) 30px;
	display: grid;
	grid-template-columns: 1.6fr 1fr 1fr;
	gap: 40px;
}
.lr-ft .lr-brand-lg { font-size: 24px; color: #fff; margin-bottom: 14px; display: inline-block; }
.lr-ft p { font-size: 14px; color: #9a938a; max-width: 320px; line-height: 1.55; }
.lr-ft h4 { color: var(--lr-accent); font-size: 13px; text-transform: uppercase; letter-spacing: .1em; font-weight: 500; margin: 0 0 16px; }
.lr-ft ul { list-style: none; margin: 0; padding: 0; }
.lr-ft li { margin-bottom: 11px; }
.lr-ft li a { font-size: 14px; color: #cfc6ba; }
.lr-ft li a:hover { color: #fff; }
.lr-ft-bottom { border-top: 1px solid rgba(255, 255, 255, .08); }
.lr-ft-bottom-in {
	max-width: var(--lr-wrap);
	margin: 0 auto;
	padding: 20px var(--lr-pad);
	display: flex;
	justify-content: space-between;
	align-items: center;
	font-size: 13px;
	color: #8c8378;
	gap: 20px;
	flex-wrap: wrap;
}

/* ----------------------------------------------------------------
   Homepage
   ---------------------------------------------------------------- */
.lr-hero { padding: 64px 0 26px; text-align: center; }
.lr-hero .lr-eyebrow {
	font-size: 13px;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: .12em;
	color: var(--lr-accent);
	margin-bottom: 16px;
	display: inline-block;
}
.lr-hero h1 {
	font-size: 50px;
	line-height: 1.05;
	letter-spacing: -.015em;
	font-weight: 600;
	max-width: 820px;
	margin: 0 auto 16px;
}
.lr-hero > p {
	font-size: 18px;
	color: var(--lr-graphite);
	max-width: 560px;
	margin: 0 auto 34px;
}
.lr-bigsearch { max-width: 740px; margin: 0 auto; position: relative; }
.lr-bigsearch-bar {
	display: flex;
	align-items: center;
	gap: 14px;
	background: var(--lr-white);
	border: 1px solid var(--lr-line);
	border-radius: var(--lr-r-lg);
	padding: 7px 7px 7px 22px;
	box-shadow: var(--lr-shadow-soft);
	transition: border-color var(--lr-dur), box-shadow var(--lr-dur);
}
.lr-bigsearch-bar:focus-within { border-color: var(--lr-accent); box-shadow: 0 12px 32px var(--lr-accent-ring); }
.lr-bigsearch-bar svg { color: var(--lr-mute); flex: none; }
.lr-bigsearch-bar input {
	flex: 1;
	min-width: 0;
	border: none;
	outline: none;
	font-size: 17px;
	padding: 15px 0;
	background: none;
	color: var(--lr-ink);
}
.lr-bs-go {
	flex: none;
	background: var(--lr-accent);
	color: #fff;
	border: none;
	border-radius: var(--lr-r-md);
	padding: 14px 28px;
	font-weight: 600;
	font-size: 15px;
	cursor: pointer;
	transition: background var(--lr-dur);
}
.lr-bs-go:hover { background: var(--lr-accent-hover); }
.lr-bigsearch-meta {
	margin-top: 18px;
	font-size: 14px;
	color: var(--lr-mute);
	display: flex;
	gap: 12px;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
}
.lr-bigsearch-meta b { color: var(--lr-ink); font-weight: 600; }
.lr-bigsearch-meta .lr-d { color: var(--lr-line); }

/* live results dropdown (reused from REST live-search) */
.lr-live-results {
	position: absolute;
	left: 0; right: 0;
	top: calc(100% + 8px);
	z-index: 60;
	background: #fff;
	border: 1px solid var(--lr-line);
	border-radius: var(--lr-r-lg);
	box-shadow: var(--lr-shadow-pop);
	overflow: hidden;
	text-align: left;
}
.lr-live-results ul { list-style: none; margin: 0; padding: 6px; }
.lr-live-results li a { display: block; padding: 11px 14px; border-radius: var(--lr-r-sm); color: var(--lr-ink); font-weight: 500; line-height: 1.35; }
.lr-live-results li a:hover { background: var(--lr-accent-soft); color: var(--lr-accent-hover); }
.lr-live-empty { margin: 0; padding: 14px; color: var(--lr-mute); }

/* category cards (hover-invert) */
.lr-cats {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 14px;
	padding: 38px 0 8px;
	list-style: none;
	margin: 0;
}
.lr-cat {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	min-height: 104px;
	background: var(--lr-white);
	border: 1px solid var(--lr-line);
	border-radius: var(--lr-r-lg);
	padding: 16px 18px;
	transition: background var(--lr-dur), color var(--lr-dur), border-color var(--lr-dur);
}
.lr-cat:hover { background: var(--lr-accent); border-color: var(--lr-accent); color: #fff; }
.lr-cat:hover .lr-cat-c { color: rgba(255, 255, 255, .8); }
.lr-cat .lr-cat-n { font-size: 18px; font-weight: 500; }
.lr-cat .lr-cat-c { font-size: 13px; color: var(--lr-mute); }

/* index A→Z */
.lr-index-head { display: flex; align-items: center; gap: 18px; margin: 54px 0 0; }
.lr-index-head h2 { font-size: 26px; font-weight: 600; letter-spacing: -.01em; margin: 0; }
.lr-index-head .lr-hr { flex: 1; height: 1px; background: var(--lr-line); }
.lr-index-head .lr-count { font-size: 13px; color: var(--lr-mute); }

.lr-alpha {
	position: sticky;
	top: 70px;
	z-index: 30;
	background: var(--lr-surface);
	display: flex;
	flex-wrap: wrap;
	gap: 4px;
	padding: 18px 0;
	margin-bottom: 10px;
}
.lr-alpha a {
	width: 32px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 14px;
	font-weight: 500;
	color: var(--lr-graphite);
	border-radius: var(--lr-r-sm);
	transition: background var(--lr-dur), color var(--lr-dur);
}
.lr-alpha a:hover { background: var(--lr-ink); color: #fff; }
.lr-alpha a.lr-empty { color: #c9c0b2; pointer-events: none; }

.lr-letter-block { padding: 18px 0 8px; border-top: 1px solid var(--lr-line); }
.lr-letter-block:first-of-type { border-top: none; }
.lr-lh { display: flex; align-items: baseline; gap: 14px; margin-bottom: 18px; }
.lr-lh .lr-big { font-size: 34px; font-weight: 600; color: var(--lr-ink); line-height: 1; font-family: var(--lr-font-serif); }
.lr-lh .lr-rule { flex: 1; height: 2px; background: var(--lr-accent); opacity: .18; }

.lr-works { display: grid; grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 10px; }
.lr-work {
	display: flex;
	align-items: center;
	gap: 13px;
	padding: 10px 12px;
	border-radius: var(--lr-r-md);
	border: 1px solid transparent;
	transition: background var(--lr-dur) var(--lr-ease), border-color var(--lr-dur), box-shadow var(--lr-dur), transform var(--lr-dur);
}
.lr-work:hover { background: var(--lr-white); border-color: var(--lr-line); box-shadow: var(--lr-shadow-soft); transform: translateY(-1px); }
.lr-work .lr-book { width: 40px; height: 54px; }
.lr-work:hover .lr-book { transform: perspective(260px) rotateY(-14deg) translateY(-1px); box-shadow: 3px 8px 18px rgba(35, 28, 21, .38); }
.lr-work .lr-info { flex: 1; min-width: 0; }
.lr-work .lr-au { display: block; font-size: 13px; color: var(--lr-mute); text-transform: uppercase; letter-spacing: .05em; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lr-work .lr-ti { display: block; font-size: 16px; color: var(--lr-ink); font-weight: 500; transition: color var(--lr-dur); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.lr-work:hover .lr-ti { color: var(--lr-accent); }
.lr-work .lr-arr { flex: none; color: var(--lr-mute); opacity: 0; transform: translateX(-4px); transition: opacity var(--lr-dur), transform var(--lr-dur), color var(--lr-dur); }
.lr-work:hover .lr-arr { opacity: 1; transform: none; color: var(--lr-accent); }

.lr-noresult { display: none; padding: 40px 0; color: var(--lr-mute); font-size: 18px; }
.lr-noresult.is-shown { display: block; }

/* ----------------------------------------------------------------
   Category / tag listing
   ---------------------------------------------------------------- */
.lr-crumb { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--lr-mute); padding: 26px 0 0; flex-wrap: wrap; }
.lr-crumb a:hover { color: var(--lr-accent); }
.lr-crumb svg { opacity: .5; }
/* Yoast breadcrumb reuse */
.lr-breadcrumb { font-size: 13px; color: var(--lr-mute); padding: 26px 0 0; }
.lr-breadcrumb a { color: var(--lr-mute); }
.lr-breadcrumb a:hover { color: var(--lr-accent); }

.lr-cat-hero {
	padding: 18px 0 28px;
	border-bottom: 1px solid var(--lr-line);
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
	gap: 30px;
}
.lr-cat-hero .lr-eyebrow { font-size: 13px; font-weight: 500; text-transform: uppercase; letter-spacing: .12em; color: var(--lr-accent); }
.lr-cat-hero h1 { font-size: 42px; font-weight: 600; letter-spacing: -.015em; margin: 10px 0 12px; }
.lr-cat-hero p { font-size: 17px; color: var(--lr-graphite); max-width: 560px; margin: 0; }
.lr-cat-hero .lr-num { font-size: 14px; color: var(--lr-mute); white-space: nowrap; }

.lr-layout { display: grid; grid-template-columns: 1fr 288px; gap: 48px; padding: 24px 0 0; align-items: start; }
.lr-layout > * { min-width: 0; }

.lr-main-head { display: flex; align-items: center; justify-content: space-between; margin: 4px 0 6px; }
.lr-main-head .lr-cnt { font-size: 14px; color: var(--lr-mute); }

.lr-row {
	display: flex;
	align-items: center;
	gap: 16px;
	padding: 14px 4px;
	border-bottom: 1px solid var(--lr-line);
	transition: background var(--lr-dur);
}
.lr-row:hover { background: var(--lr-white); }
.lr-row .lr-book { width: 44px; height: 60px; }
.lr-row:hover .lr-book { transform: perspective(300px) rotateY(-14deg) translateY(-1px); box-shadow: 4px 9px 20px rgba(35, 28, 21, .36); }
.lr-row .lr-info { flex: 1; min-width: 0; }
.lr-row .lr-au { display: block; font-size: 13px; color: var(--lr-mute); text-transform: uppercase; letter-spacing: .05em; }
.lr-row .lr-ti { display: block; font-size: 18px; font-weight: 500; color: var(--lr-ink); transition: color var(--lr-dur); }
.lr-row:hover .lr-ti { color: var(--lr-accent); }
.lr-row .lr-tags { display: flex; gap: 6px; flex: none; }
.lr-row .lr-tags .lr-t { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--lr-mute); border: 1px solid var(--lr-line); border-radius: var(--lr-r-pill); padding: 4px 10px; }
.lr-row .lr-arr { flex: none; color: var(--lr-mute); transition: color var(--lr-dur), transform var(--lr-dur); }
.lr-row:hover .lr-arr { color: var(--lr-accent); transform: translateX(3px); }

/* right rail */
.lr-rail { position: sticky; top: 96px; display: flex; flex-direction: column; gap: 18px; }
.lr-rail-card { background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 18px; }
.lr-rail-card h3 { font-size: 13px; text-transform: uppercase; letter-spacing: .1em; color: var(--lr-mute); font-weight: 600; margin: 0 0 12px; }
.lr-catnav { display: flex; flex-direction: column; gap: 1px; }
.lr-catnav a { display: flex; align-items: center; justify-content: space-between; padding: 9px 12px; border-radius: var(--lr-r-sm); font-size: 16px; color: var(--lr-graphite); transition: background var(--lr-dur), color var(--lr-dur); }
.lr-catnav a:hover { background: var(--lr-surface); color: var(--lr-ink); }
.lr-catnav a.lr-active { background: var(--lr-ink); color: #fff; font-weight: 500; }
.lr-catnav .lr-subwrap { display: flex; flex-direction: column; gap: 1px; border-left: 1px solid var(--lr-line); margin: 2px 0 2px 14px; padding-left: 4px; }
.lr-catnav a.lr-sub { font-size: 14px; color: var(--lr-mute); padding-left: 22px; }
.lr-catnav a.lr-sub:hover { color: var(--lr-ink); }

/* ----------------------------------------------------------------
   Single article (fiche)
   ---------------------------------------------------------------- */
.lr-article .lr-layout { grid-template-columns: 1fr 312px; }

.lr-a-eyebrow { font-size: 13px; font-weight: 500; text-transform: uppercase; letter-spacing: .12em; color: var(--lr-accent); }
.lr-a-title { font-size: 40px; line-height: 1.08; letter-spacing: -.015em; font-weight: 600; margin: 10px 0 0; }
.lr-a-meta { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 16px; font-size: 14px; color: var(--lr-graphite); }
.lr-a-meta .lr-av { display: flex; align-items: center; gap: 8px; }
.lr-a-meta .lr-av .lr-avdot { width: 26px; height: 26px; border-radius: 50%; background: var(--lr-ink); color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; font-family: var(--lr-font-serif); }
.lr-a-meta .lr-sep { width: 3px; height: 3px; border-radius: 50%; background: var(--lr-line); }
.lr-a-meta .lr-star { color: var(--lr-accent); font-weight: 600; }
.lr-a-meta .lr-muted { color: var(--lr-mute); }

.lr-hero-card { display: flex; gap: 28px; align-items: center; background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 26px 28px; margin-top: 22px; }
.lr-hero-card .lr-hc-right { flex: 1; }
.lr-hero-card h2 { font-size: 18px; font-weight: 600; margin: 0 0 6px; }
.lr-hero-card p { font-size: 14px; color: var(--lr-graphite); margin: 0 0 16px; line-height: 1.5; }
.lr-pdf-row { display: flex; gap: 10px; flex-wrap: wrap; }

.lr-book-hero {
	position: relative;
	flex: none;
	width: 150px;
	height: 212px;
	border-radius: 3px 7px 7px 3px;
	transform: perspective(900px) rotateY(-19deg);
	transform-origin: left center;
	box-shadow: 10px 16px 34px rgba(35, 28, 21, .34);
	background: var(--cov, var(--lr-grad-card));
	background-size: cover;
	background-position: center;
	overflow: hidden;
}
.lr-book-hero::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 9px; border-radius: 3px 0 0 3px; background: rgba(0, 0, 0, .34); box-shadow: inset -2px 0 2px rgba(255, 255, 255, .16); z-index: 2; }
.lr-book-hero img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
@supports (object-view-box: inset(0)) {
	.lr-book-hero img { object-view-box: inset(4% 24% 4% 24%); }
}

/* facts grid (theme-injected "points essentiels" wrapper around content table is NOT used;
   this styles our own optional facts block if present) */
.lr-facts { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--lr-line); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); overflow: hidden; margin-top: 26px; }
.lr-facts .lr-f { background: var(--lr-white); padding: 16px 18px; }
.lr-facts .lr-f .lr-k { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--lr-mute); }
.lr-facts .lr-f .lr-v { font-size: 16px; font-weight: 500; margin-top: 4px; }

/* article body: style the_content (real HTML) to match the charte */
.lr-entry { padding: 30px 0 0; }
.lr-entry .entry-content { max-width: none; font-size: 16px; line-height: 1.7; color: var(--lr-ink); overflow-wrap: break-word; }
.lr-entry .entry-content > h2,
.lr-entry .entry-content > h3 { scroll-margin-top: 90px; }
.lr-entry .entry-content h2 { font-size: 28px; font-weight: 600; letter-spacing: -.01em; margin: 40px 0 18px; padding-bottom: 10px; position: relative; }
.lr-entry .entry-content h2::after { content: ""; position: absolute; left: 0; bottom: 0; width: 54px; height: 3px; background: var(--lr-accent); border-radius: 2px; }
.lr-entry .entry-content h3 { font-size: 20px; font-weight: 600; margin: 26px 0 10px; }
.lr-entry .entry-content h4 { font-size: 17px; font-weight: 600; margin: 22px 0 8px; }
.lr-entry .entry-content p { margin: 0 0 16px; }
.lr-entry .entry-content a { color: var(--lr-accent-hover); text-decoration: underline; text-decoration-color: var(--lr-accent-ring); text-underline-offset: 2px; }
.lr-entry .entry-content a:hover { color: var(--lr-accent); }
.lr-entry .entry-content ul,
.lr-entry .entry-content ol { margin: 0 0 18px; padding-left: 22px; }
.lr-entry .entry-content li { margin-bottom: 8px; line-height: 1.6; }
.lr-entry .entry-content img { border-radius: var(--lr-r-lg); border: 1px solid var(--lr-line); margin: 18px 0; }
.lr-entry .entry-content blockquote {
	border-left: 3px solid var(--lr-accent);
	padding: 6px 0 6px 22px;
	margin: 22px 0;
	font-family: var(--lr-font-serif);
	font-size: 21px;
	line-height: 1.4;
	font-style: italic;
	color: var(--lr-ink);
}
.lr-entry .entry-content blockquote p { margin: 0; }
/* tables (Points essentiels / personnages / etc., authored in content) */
.lr-entry .entry-content table {
	width: 100%;
	border-collapse: collapse;
	background: var(--lr-white);
	border: 1px solid var(--lr-line);
	border-radius: var(--lr-r-lg);
	overflow: hidden;
	margin: 22px 0;
	font-size: 14px;
}
.lr-entry .entry-content th { text-align: left; font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--lr-mute); font-weight: 600; padding: 12px 18px; background: var(--lr-surface); border-bottom: 1px solid var(--lr-line); font-family: var(--lr-font-sans); }
.lr-entry .entry-content td { padding: 14px 18px; border-bottom: 1px solid var(--lr-line); line-height: 1.55; color: var(--lr-graphite); vertical-align: top; }
.lr-entry .entry-content tr:last-child td { border-bottom: none; }
.lr-entry .entry-content table strong,
.lr-entry .entry-content td strong { color: var(--lr-ink); }

/* video embed (ACF lien_video_youtube) */
.lr-video { margin: 30px 0; }
.lr-video h2 { font-size: 22px; font-weight: 600; margin: 0 0 14px; padding-bottom: 8px; position: relative; }
.lr-video h2::after { content: ""; position: absolute; left: 0; bottom: 0; width: 54px; height: 3px; background: var(--lr-accent); border-radius: 2px; }
.lr-video__frame { position: relative; aspect-ratio: 16 / 9; border-radius: var(--lr-r-lg); overflow: hidden; border: 1px solid var(--lr-line); background: var(--lr-grad-card); display: flex; align-items: center; justify-content: center; }
.lr-video__frame iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.lr-video__play { width: 76px; height: 76px; border-radius: 50%; border: none; background: var(--lr-accent); color: #fff; display: flex; align-items: center; justify-content: center; cursor: pointer; box-shadow: var(--lr-shadow-pop); transition: transform var(--lr-dur) var(--lr-ease), background var(--lr-dur); }
.lr-video__play:hover { transform: scale(1.08); background: var(--lr-accent-hover); }

/* rating widget */
.lr-rating { display: flex; align-items: center; gap: 16px; background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 20px 24px; margin-top: 30px; flex-wrap: wrap; }
.lr-rating .lr-lbl { font-weight: 500; }
.lr-stars { display: flex; gap: 4px; }
.lr-stars button { background: none; border: none; padding: 0; cursor: pointer; color: #d8cdbb; transition: color var(--lr-dur-fast), transform var(--lr-dur-fast); line-height: 0; }
.lr-stars button:hover { transform: scale(1.12); }
.lr-stars button.lr-on { color: var(--lr-accent); }
.lr-stars[aria-disabled="true"] button { cursor: default; }
.lr-rating .lr-score { margin-left: auto; font-size: 14px; color: var(--lr-mute); }
.lr-rating .lr-thanks { color: var(--lr-accent-hover); font-weight: 500; }

/* tags */
.lr-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 24px; }
.lr-tags a { font-size: 13px; color: var(--lr-graphite); background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-pill); padding: 6px 13px; transition: border-color var(--lr-dur), color var(--lr-dur); }
.lr-tags a:hover { border-color: var(--lr-accent); color: var(--lr-accent); }

/* paywall CTA (shown when the content preview is gated) */
.lr-paywall {
	position: relative;
	margin-top: -90px;
	padding: 110px 24px 32px;
	text-align: center;
	background: linear-gradient(180deg, rgba(250, 246, 239, 0) 0%, var(--lr-surface) 38%);
}
.lr-paywall__title { font-size: 24px; font-weight: 600; margin: 0 0 8px; }
.lr-paywall__lead { color: var(--lr-graphite); margin: 0 0 18px; }
.lr-paywall__btn { font-size: 16px; }
.lr-paywall__msg { margin: 12px 0 0; font-size: 14px; color: var(--lr-graphite); }

/* PDF block */
.lr-pdf-block { display: flex; gap: 22px; align-items: center; background: var(--lr-grad-card); border-radius: var(--lr-r-lg); padding: 28px 30px; margin-top: 30px; color: #fff; flex-wrap: wrap; }
.lr-pdf-block .lr-cta-ghost,
.lr-pdf-block a.lr-cta { text-decoration: none; }
.lr-pdf-block .lr-pic { flex: none; width: 46px; height: 46px; border-radius: var(--lr-r-sm); background: rgba(255, 255, 255, .1); display: flex; align-items: center; justify-content: center; color: #fff; }
.lr-pdf-block .lr-pt { flex: 1; min-width: 200px; }
.lr-pdf-block h2 { font-size: 20px; font-weight: 600; margin: 0 0 4px; color: #fff; }
.lr-pdf-block p { font-size: 14px; color: #cfc6ba; margin: 0; }

/* related */
.lr-related-sec { padding: 40px 0 0; }
.lr-related-sec > h2 { font-size: 22px; font-weight: 600; margin: 0 0 6px; position: relative; padding-bottom: 10px; }
.lr-related-sec > h2::after { content: ""; position: absolute; left: 0; bottom: 0; width: 54px; height: 3px; background: var(--lr-accent); border-radius: 2px; }
.lr-related { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; list-style: none; padding: 0; margin: 18px 0 0; }
.lr-rel { display: flex; gap: 14px; align-items: center; background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 14px; transition: transform var(--lr-dur), box-shadow var(--lr-dur), border-color var(--lr-dur); }
.lr-rel:hover { transform: translateY(-3px); box-shadow: var(--lr-shadow-soft); border-color: #ddd2bf; }
.lr-rel .lr-book { width: 40px; height: 54px; }
.lr-rel .lr-au { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--lr-mute); display: block; }
.lr-rel .lr-ti { font-size: 15px; font-weight: 500; color: var(--lr-ink); line-height: 1.2; }

/* author box */
.lr-author { display: flex; gap: 16px; align-items: center; background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 20px 22px; margin-top: 30px; }
.lr-author .lr-ava { flex: none; width: 48px; height: 48px; border-radius: 50%; background: var(--lr-ink); color: #fff; display: flex; align-items: center; justify-content: center; font-family: var(--lr-font-serif); font-weight: 600; }
.lr-author .lr-at .lr-k { font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: var(--lr-mute); }
.lr-author .lr-at h2 { font-size: 18px; font-weight: 600; margin: 2px 0; }
.lr-author .lr-at p { font-size: 13px; color: var(--lr-graphite); margin: 0; }

/* sidebar widgets */
.lr-toc { background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 18px; }
.lr-toc h2 { font-size: 11px; text-transform: uppercase; letter-spacing: .1em; color: var(--lr-mute); font-weight: 600; margin: 0 0 12px; font-family: var(--lr-font-sans); }
.lr-toc ul { list-style: none; margin: 0; padding: 0; }
.lr-toc a { display: flex; align-items: center; gap: 10px; padding: 7px 10px; border-radius: var(--lr-r-sm); font-size: 14px; color: var(--lr-graphite); transition: background var(--lr-dur), color var(--lr-dur); border-left: 2px solid transparent; }
.lr-toc a:hover { background: var(--lr-surface); color: var(--lr-ink); }
.lr-toc a.lr-toc-active { color: var(--lr-accent); font-weight: 500; border-left-color: var(--lr-accent); background: var(--lr-surface); }
.lr-toc .lr-toc--h3 { padding-left: 22px; font-size: 13px; }

.lr-widget { background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 18px; }
.lr-widget h2 { font-size: 11px; text-transform: uppercase; letter-spacing: .1em; color: var(--lr-accent); font-weight: 600; margin: 0 0 12px; font-family: var(--lr-font-sans); }
.lr-widget ul { list-style: none; margin: 0; padding: 0; }
.lr-pop { display: flex; gap: 11px; padding: 9px 0; border-bottom: 1px solid var(--lr-line); align-items: center; }
.lr-pop:last-child { border-bottom: none; }
.lr-pop .lr-r { flex: none; width: 22px; font-family: var(--lr-font-serif); font-size: 18px; font-weight: 600; color: var(--lr-accent); }
.lr-pop .lr-pt { font-size: 14px; color: var(--lr-ink); line-height: 1.3; }
.lr-pop:hover .lr-pt { color: var(--lr-accent); }
.lr-catlist a { display: block; padding: 8px 0; border-bottom: 1px solid var(--lr-line); font-size: 14px; color: var(--lr-graphite); }
.lr-catlist a:last-child { border-bottom: none; }
.lr-catlist a:hover { color: var(--lr-accent); }
.lr-recent-c { padding: 9px 0; border-bottom: 1px solid var(--lr-line); }
.lr-recent-c:last-child { border-bottom: none; }
.lr-recent-c p { margin: 0; }
.lr-recent-c .lr-rc-text { font-size: 13px; color: var(--lr-graphite); line-height: 1.45; }
.lr-recent-c .lr-rc-meta { font-size: 12px; color: var(--lr-mute); margin-top: 3px; }
.lr-recent-c .lr-rc-meta a { color: var(--lr-accent-hover); }

/* "leave a comment" CTA in sidebar */
.lr-rail-cta { display: block; text-align: center; }

/* ----------------------------------------------------------------
   Comments (single)
   ---------------------------------------------------------------- */
.comments-area { margin-top: 40px; }
.comments-area .comments-title,
.comments-area .comment-reply-title { font-size: 24px; font-weight: 600; }
.comments-area .comment-meta time,
.comments-area .comment-metadata { display: none; }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea { border: 1px solid var(--lr-line); border-radius: var(--lr-r-md); background: #fff; }

/* ----------------------------------------------------------------
   Search / 404 / sitemap / legal pages on the charte
   ---------------------------------------------------------------- */
.lr-page { padding: 40px 0 20px; }
.lr-page-head h1 { font-size: 40px; font-weight: 600; letter-spacing: -.015em; margin: 0 0 12px; }
.lr-page-head p { font-size: 17px; color: var(--lr-graphite); margin: 0 0 24px; max-width: 640px; }
.lr-page .entry-content,
.lr-legal .entry-content { max-width: 760px; font-size: 16px; line-height: 1.7; }
.lr-legal .entry-content h2 { font-size: 24px; margin: 32px 0 12px; }

.lr-search-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; margin: 24px 0; list-style: none; padding: 0; }
.lr-result { display: flex; gap: 14px; align-items: center; background: var(--lr-white); border: 1px solid var(--lr-line); border-radius: var(--lr-r-lg); padding: 14px; transition: transform var(--lr-dur), box-shadow var(--lr-dur); }
.lr-result:hover { transform: translateY(-2px); box-shadow: var(--lr-shadow-soft); }
.lr-result .lr-book { width: 40px; height: 54px; }
.lr-result .lr-au { font-size: 11px; text-transform: uppercase; letter-spacing: .05em; color: var(--lr-mute); display: block; }
.lr-result .lr-ti { font-size: 16px; font-weight: 500; color: var(--lr-ink); line-height: 1.25; }

.lr-cat-links { columns: 2; gap: 1.5rem; list-style: none; padding: 0; }
.lr-cat-links li { margin-bottom: 8px; break-inside: avoid; }
.lr-cat-links a { color: var(--lr-graphite); }
.lr-cat-links a:hover { color: var(--lr-accent); }
.lr-home-link { font-weight: 600; color: var(--lr-accent-hover); }

.lr-sitemap-cat { margin: 1.75rem 0; }
.lr-sitemap-cat h2 { font-size: 24px; padding-bottom: 8px; position: relative; }
.lr-sitemap-cat h2::after { content: ""; position: absolute; left: 0; bottom: 0; width: 54px; height: 3px; background: var(--lr-accent); border-radius: 2px; }
.lr-sitemap-count { color: var(--lr-mute); font-weight: 400; font-size: .7em; }
.lr-sitemap-list { columns: 2; gap: 2rem; list-style: none; padding: 0; margin-top: 14px; }
.lr-sitemap-list li { break-inside: avoid; margin-bottom: 6px; }
.lr-sitemap-list a:hover { color: var(--lr-accent); }
@media (max-width: 700px) { .lr-cat-links, .lr-sitemap-list { columns: 1; } }

.lr-form { display: flex; gap: 10px; max-width: 560px; margin: 0 0 24px; }
.lr-form input[type="search"] { flex: 1; border: 1px solid var(--lr-line); border-radius: var(--lr-r-md); padding: 13px 16px; font-size: 16px; background: #fff; }

/* ----------------------------------------------------------------
   Ad slots — reserved, anti-CLS; invisible until activated
   ---------------------------------------------------------------- */
.lr-ad {
	margin: 30px 0 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}
.lr-ad--leader { min-height: 0; }
.lr-ad--rect { min-height: 0; }
.lr-ad--tower { min-height: 0; }
.lr-ad__inner { width: 100%; display: flex; align-items: center; justify-content: center; }
/* When ads are enabled, reserve heights to keep CLS ≈ 0 */
.lr-ads-on .lr-ad--leader .lr-ad__inner { min-height: 90px; }
.lr-ads-on .lr-ad--rect .lr-ad__inner { min-height: 250px; }
.lr-ads-on .lr-ad--tower .lr-ad__inner { min-height: 600px; }
.lr-ad__label { font-size: 10px; text-transform: uppercase; letter-spacing: .12em; color: var(--lr-mute); align-self: flex-start; margin-bottom: 4px; display: none; }
.lr-ads-on .lr-ad__label { display: block; }

/* CMP consent banner */
.lr-cmp { position: fixed; left: 16px; right: 16px; bottom: 16px; z-index: 200; max-width: 720px; margin: 0 auto; background: var(--lr-ink); color: #fff; border-radius: var(--lr-r-lg); box-shadow: var(--lr-shadow-pop); padding: 20px 22px; display: flex; gap: 18px; align-items: center; flex-wrap: wrap; }
.lr-cmp p { margin: 0; font-size: 14px; color: #e6ded3; flex: 1; min-width: 220px; line-height: 1.5; }
.lr-cmp p a { color: var(--lr-accent); text-decoration: underline; }
.lr-cmp__btns { display: flex; gap: 10px; flex-wrap: wrap; }
.lr-cmp__btns button { border: none; border-radius: var(--lr-r-md); padding: 11px 18px; font-weight: 600; font-size: 14px; cursor: pointer; }
.lr-cmp__accept { background: var(--lr-accent); color: #fff; }
.lr-cmp__accept:hover { background: var(--lr-accent-hover); }
.lr-cmp__refuse { background: rgba(255, 255, 255, .12); color: #fff; }
.lr-cmp__refuse:hover { background: rgba(255, 255, 255, .2); }

/* ----------------------------------------------------------------
   Responsive
   ---------------------------------------------------------------- */
@media (max-width: 1080px) {
	.lr-cats { grid-template-columns: repeat(2, 1fr); }
	.lr-layout,
	.lr-article .lr-layout { grid-template-columns: 1fr; }
	.lr-rail { position: static; }
	.lr-row .lr-tags { display: none; }
}
@media (max-width: 900px) {
	:root { --lr-pad: 22px; }
	.lr-nav { display: none; }
	.lr-nav.lr-nav--open { display: flex; position: absolute; top: 70px; left: 0; right: 0; background: var(--lr-black); flex-direction: column; padding: 10px var(--lr-pad) 18px; gap: 2px; border-bottom: 1px solid rgba(255,255,255,.08); }
	.lr-nav.lr-nav--open a { padding: 12px 10px; }
	.lr-burger { display: inline-flex; align-items: center; justify-content: center; margin-left: auto; width: 42px; height: 42px; border-radius: var(--lr-r-sm); background: rgba(255,255,255,.07); border: none; color: #fff; cursor: pointer; }
	.lr-reassure { display: none; }
	.lr-search { margin-left: 12px; width: auto; flex: 1; max-width: 240px; }
	.lr-hd-in .lr-search + .lr-burger { margin-left: 8px; }
	.lr-hero h1 { font-size: 34px; }
	.lr-cat-hero { flex-direction: column; align-items: flex-start; }
	.lr-cat-hero h1 { font-size: 32px; }
	.lr-a-title { font-size: 28px; }
	.lr-hero-card { flex-direction: column; align-items: flex-start; }
	.lr-book-hero { width: 120px; height: 170px; align-self: center; }
	.lr-facts { grid-template-columns: repeat(2, 1fr); }
	.lr-related { grid-template-columns: 1fr; }
	.lr-ft-in { grid-template-columns: 1fr; gap: 28px; }
	.lr-works { grid-template-columns: 1fr; }
	.lr-entry .entry-content table { display: block; overflow-x: auto; }
}
@media (max-width: 560px) {
	.lr-cats { grid-template-columns: 1fr; }
	.lr-bs-go { padding: 14px 16px; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce) {
	* { scroll-behavior: auto !important; }
	.lr-book, .lr-work, .lr-row, .lr-rel { transition: none; }
}

/* ----------------------------------------------------------------
   Print stylesheet (clean "Save as PDF") — single articles
   ---------------------------------------------------------------- */
@media print {
	.lr-hd, .lr-ft, .lr-rail, .lr-ad, .lr-cmp, .lr-pdf-block, .lr-rating,
	.lr-related-sec, .lr-author, .lr-tags, .lr-pdf-row, .comments-area,
	.lr-burger, .lr-search, .post-navigation, .lr-video { display: none !important; }
	body { background: #fff; color: #000; font-size: 12pt; }
	.lr-wrap { max-width: none; padding: 0; }
	.lr-article .lr-layout { display: block; }
	.lr-hero-card { border: none; padding: 0; margin: 0 0 12pt; }
	.lr-book-hero { display: none; }
	.lr-a-title { font-size: 22pt; }
	.lr-entry .entry-content { max-width: none; font-size: 12pt; line-height: 1.5; }
	.lr-entry .entry-content h2::after { display: none; }
	a { color: #000; text-decoration: none; }
	.lr-entry .entry-content a { text-decoration: none; }
	.lr-print-note { display: block !important; margin-top: 16pt; font-size: 9pt; color: #555; }
}
.lr-print-note { display: none; }

/* ----------------------------------------------------------------
   Article hero — parité prod : couverture CENTRÉE + image ENTIÈRE
   (au lieu du livre 3D zoom-croppé à gauche). L'image entière rend
   le watermark "www.lesresumes.com" aussi discret que sur la prod.
   ---------------------------------------------------------------- */
.lr-hero-card {
	flex-direction: column;
	align-items: center;
	text-align: center;
	gap: 18px;
}
.lr-fiche-cover {
	margin: 0 auto;
	width: 100%;
	max-width: 520px;
	background: #fff;
	border: 1px solid var(--lr-line);
	border-radius: var(--lr-r-md);
	overflow: hidden;
	box-shadow: var(--lr-shadow-soft);
}
.lr-fiche-cover img {
	display: block;
	width: 100%;
	height: auto;            /* image entière, ratio natif 750×390 — aucun crop/zoom */
}
.lr-hero-card .lr-hc-right {
	flex: none;
	max-width: 560px;
}
.lr-hero-card .lr-pdf-row {
	justify-content: center;
}
