/* =====================================================
   The See of Peter — Reader Mode
   ===================================================== */

/* ── Entry button (injected at top of post body) ───── */
.sop-reader-entry {
	display: flex;
	justify-content: flex-end;
	margin: 0 0 1.5em 0;
}
.sop-reader-enter {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	padding: 0.4em 0.85em;
	font-size: 0.85rem;
	font-family: inherit;
	font-weight: 500;
	color: #5a4a2c;
	background: transparent;
	border: 1px solid #d4bc8a;
	border-radius: 3px;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}
.sop-reader-enter:hover {
	background: #f6efe0;
	color: #2a2010;
}
.sop-reader-enter:focus-visible {
	outline: 2px solid #9E824B;
	outline-offset: 2px;
}

/* ── Overlay ───────────────────────────────────────── */
.sop-reader-overlay {
	position: fixed;
	inset: 0;
	z-index: 99998;
	overflow-y: auto;
	background: #faf6ef;
	color: #2a2620;
	display: none;
	font-family: "Source Serif 4", "Source Serif Pro", Charter, Georgia, Cambria, serif;
}
.sop-reader-overlay.is-active {
	display: block;
}
.sop-reader-overlay.is-dark {
	background: #1a1814;
	color: #e8e2d5;
}

/* ── Content column ────────────────────────────────── */
.sop-reader-content {
	max-width: 720px;
	margin: 0 auto;
	padding: 4rem 1.5rem 8rem;
}
.sop-reader-article {
	font-size: 19px;
	line-height: 1.65;
}
.sop-reader-overlay[data-fontsize="small"]  .sop-reader-article { font-size: 16px; }
.sop-reader-overlay[data-fontsize="medium"] .sop-reader-article { font-size: 19px; }
.sop-reader-overlay[data-fontsize="large"]  .sop-reader-article { font-size: 22px; }
.sop-reader-overlay[data-fontsize="xlarge"] .sop-reader-article { font-size: 26px; }

/* ── Title ─────────────────────────────────────────── */
.sop-reader-title {
	font-size: 1.7em;
	line-height: 1.25;
	font-weight: 600;
	margin: 0 0 1.5em 0;
	color: #1f1c17;
	border-bottom: 1px solid #d4bc8a;
	padding-bottom: 0.6em;
}
.sop-reader-overlay.is-dark .sop-reader-title {
	color: #f4eedc;
	border-bottom-color: #5a4a2c;
}

/* ── Synopsis ──────────────────────────────────────── */
.sop-reader-synopsis {
	font-size: 0.95em;
	font-style: italic;
	color: #5a4a2c;
	margin-bottom: 2em;
	padding-left: 1em;
	border-left: 3px solid #9E824B;
}
.sop-reader-overlay.is-dark .sop-reader-synopsis {
	color: #b8a880;
}
.sop-reader-synopsis p { margin: 0 0 0.6em 0; }
.sop-reader-synopsis p:last-child { margin-bottom: 0; }
.sop-reader-synopsis:empty { display: none; }

/* The cloned synopsis sits inside an Elementor wrapper; flatten it. */
.sop-reader-synopsis .elementor-widget-container {
	all: unset;
	display: block;
}

/* ── Body ──────────────────────────────────────────── */
.sop-reader-body p {
	margin: 0 0 1.1em 0;
}
.sop-reader-body h2,
.sop-reader-body h3,
.sop-reader-body h4 {
	font-weight: 600;
	margin: 2em 0 0.75em 0;
	line-height: 1.3;
	color: #1f1c17;
}
.sop-reader-body h2 { font-size: 1.25em; }
.sop-reader-body h3 { font-size: 1.15em; }
.sop-reader-body h4 { font-size: 1.05em; }
.sop-reader-overlay.is-dark .sop-reader-body h2,
.sop-reader-overlay.is-dark .sop-reader-body h3,
.sop-reader-overlay.is-dark .sop-reader-body h4 {
	color: #f4eedc;
}
.sop-reader-body em,
.sop-reader-body i,
.sop-reader-synopsis em,
.sop-reader-commentary em {
	font-style: italic;
}
.sop-reader-body strong,
.sop-reader-body b {
	font-weight: 700;
	color: #1f1c17;
}
.sop-reader-overlay.is-dark .sop-reader-body strong,
.sop-reader-overlay.is-dark .sop-reader-body b {
	color: #f4eedc;
}
.sop-reader-body a {
	color: #7a6138;
	text-decoration: underline;
	text-decoration-thickness: 1px;
	text-underline-offset: 2px;
}
.sop-reader-overlay.is-dark .sop-reader-body a {
	color: #c9aa6e;
}

/* Flatten Elementor wrappers inside the cloned body */
.sop-reader-body .elementor-widget-container {
	all: unset;
	display: block;
}

/* ── Footnotes (live snippet markup) ───────────────── */
/* Page CSS already styles these; tweak only what reader-mode needs */
.sop-reader-overlay .sop-footnotes {
	margin-top: 3em;
	padding-top: 1.5em;
	border-top: 1px solid #d4bc8a;
}
.sop-reader-overlay.is-dark .sop-footnotes {
	border-top-color: #5a4a2c;
	color: #d8cfb6;
}
.sop-reader-overlay.is-dark .sop-footnotes h3 {
	color: #f4eedc;
}
.sop-reader-overlay.is-dark .sop-footnotes a {
	color: #c9aa6e;
}
/* Older "footnotes" markup, just in case */
.sop-reader-overlay .footnotes {
	margin-top: 3em;
	padding-top: 1.5em;
	border-top: 1px solid #d4bc8a;
}
.sop-reader-overlay.is-dark .footnotes {
	border-top-color: #5a4a2c;
	color: #d8cfb6;
}

/* Tooltip styling override for dark mode (tooltip is appended to body, not overlay) */
body.sop-reader-active.sop-reader-is-dark .sop-fn-tooltip {
	background: #2a2620;
	color: #e8e2d5;
	border-color: #5a4a2c;
	border-left-color: #c9aa6e;
}
body.sop-reader-active.sop-reader-is-dark .sop-fn-tooltip-number {
	color: #c9aa6e;
}

/* ── Commentary ────────────────────────────────────── */
.sop-reader-commentary {
	margin-top: 3em;
	padding: 2em 1.5em 1.5em;
	background: rgba(158, 130, 75, 0.06);
	border-top: 1px solid #d4bc8a;
	border-radius: 3px;
	font-size: 0.95em;
}
.sop-reader-overlay.is-dark .sop-reader-commentary {
	background: rgba(158, 130, 75, 0.12);
	border-top-color: #5a4a2c;
}
.sop-reader-commentary-heading {
	font-size: 0.85em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.06em;
	color: #5a4a2c;
	margin: 0 0 1em 0;
}
.sop-reader-overlay.is-dark .sop-reader-commentary-heading {
	color: #b8a880;
}
.sop-reader-commentary-inner p {
	margin: 0 0 1em 0;
}
.sop-reader-overlay .sop-reader-commentary.is-hidden,
.sop-reader-overlay .sop-reader-commentary:not(.is-loaded) {
	display: none;
}

/* If the cloned commentary brings along jet-unfold UI, hide the toggle button */
.sop-reader-commentary .jet-unfold__toggle,
.sop-reader-commentary .jet-unfold__top {
	display: none !important;
}
.sop-reader-commentary .jet-unfold__content {
	max-height: none !important;
	overflow: visible !important;
	display: block !important;
}
.sop-reader-commentary .elementor-widget-container {
	all: unset;
	display: block;
}

/* ── Reference link (bottom of overlay) ────────────── */
.sop-reader-reference {
	margin-top: 3em;
	display: flex;
	justify-content: center;
}
.sop-reader-reference:empty,
.sop-reader-reference[hidden] {
	display: none;
}
.sop-reader-reference-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	padding: 0.65em 1.2em;
	font-size: 0.9em;
	font-family: inherit;
	font-weight: 500;
	color: #5a4a2c;
	background: transparent;
	border: 1px solid #9E824B;
	border-radius: 3px;
	text-decoration: none;
	transition: background-color 0.15s ease, color 0.15s ease;
}
.sop-reader-reference-link:hover {
	background: #f1e7ce;
	color: #2a2010;
}
.sop-reader-overlay.is-dark .sop-reader-reference-link {
	color: #d8cfb6;
	border-color: #b8a880;
}
.sop-reader-overlay.is-dark .sop-reader-reference-link:hover {
	background: rgba(184, 168, 128, 0.15);
	color: #f4eedc;
}
.sop-reader-reference-link svg {
	flex: 0 0 auto;
}

/* ── Prev / next navigation ────────────────────────── */
.sop-reader-nav {
	display: flex;
	gap: 1em;
	margin-top: 2.5em;
	padding-top: 1.75em;
	border-top: 1px solid #d4bc8a;
}
.sop-reader-overlay.is-dark .sop-reader-nav {
	border-top-color: #5a4a2c;
}
.sop-reader-nav-spacer {
	flex: 1 1 0;
}
.sop-reader-nav-btn {
	flex: 1 1 0;
	display: flex;
	align-items: center;
	gap: 0.7em;
	padding: 0.85em 1em;
	font-family: inherit;
	color: #5a4a2c;
	background: transparent;
	border: 1px solid #d4bc8a;
	border-radius: 4px;
	text-decoration: none;
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
	min-width: 0;
}
.sop-reader-nav-btn:hover {
	background: #f1e7ce;
	color: #2a2010;
	border-color: #9E824B;
}
.sop-reader-overlay.is-dark .sop-reader-nav-btn {
	color: #d8cfb6;
	border-color: #5a4a2c;
}
.sop-reader-overlay.is-dark .sop-reader-nav-btn:hover {
	background: rgba(184, 168, 128, 0.15);
	color: #f4eedc;
	border-color: #b8a880;
}
.sop-reader-nav-prev {
	text-align: left;
}
.sop-reader-nav-next {
	text-align: right;
	justify-content: flex-end;
}
.sop-reader-nav-meta {
	display: flex;
	flex-direction: column;
	min-width: 0;
	flex: 1 1 0;
}
.sop-reader-nav-label {
	font-size: 0.72em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #9E824B;
	line-height: 1.2;
}
.sop-reader-overlay.is-dark .sop-reader-nav-label {
	color: #b8a880;
}
.sop-reader-nav-title {
	display: block;
	font-size: 0.95em;
	font-weight: 500;
	line-height: 1.3;
	margin-top: 0.2em;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}
.sop-reader-nav-chevron {
	flex: 0 0 auto;
	color: #9E824B;
}
.sop-reader-overlay.is-dark .sop-reader-nav-chevron {
	color: #b8a880;
}

/* ── Toolbar ───────────────────────────────────────── */
.sop-reader-toolbar {
	position: fixed;
	bottom: 1.5rem;
	right: 1.5rem;
	display: flex;
	gap: 0.35em;
	padding: 0.4em;
	background: rgba(255, 253, 247, 0.95);
	border: 1px solid #d4bc8a;
	border-radius: 6px;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
	backdrop-filter: blur(6px);
	z-index: 99999;
}
.sop-reader-overlay.is-dark .sop-reader-toolbar {
	background: rgba(42, 38, 32, 0.95);
	border-color: #5a4a2c;
}
.sop-reader-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.2em;
	height: 2.2em;
	padding: 0;
	font-family: inherit;
	font-size: 0.95rem;
	color: #5a4a2c;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 4px;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}
.sop-reader-overlay.is-dark .sop-reader-btn {
	color: #d8cfb6;
}
.sop-reader-btn:hover {
	background: rgba(158, 130, 75, 0.18);
}
.sop-reader-btn:focus-visible {
	outline: 2px solid #9E824B;
	outline-offset: 1px;
}
.sop-reader-btn-label {
	font-weight: 600;
	line-height: 1;
}
.sop-reader-btn-label small {
	font-size: 0.75em;
	margin-left: 0.05em;
}

/* Theme icon swap */
.sop-reader-icon-dark { display: none; }
.sop-reader-overlay.is-dark .sop-reader-icon-light { display: none; }
.sop-reader-overlay.is-dark .sop-reader-icon-dark { display: inline; }

/* Pressed state for toggleable buttons (commentary toggle, settings) */
.sop-reader-btn[aria-pressed="true"] {
	background: rgba(158, 130, 75, 0.32);
	color: #2a2010;
}
.sop-reader-overlay.is-dark .sop-reader-btn[aria-pressed="true"] {
	background: rgba(184, 168, 128, 0.28);
	color: #f4eedc;
}
/* Off-state for the commentary toggle: muted icon so the on/off
   contrast is obvious at a glance */
.sop-reader-btn[data-action="commentary-toggle"][aria-pressed="false"] {
	opacity: 0.45;
}

/* Make sure clicks on the icon hit the button, not the SVG path */
.sop-reader-btn svg,
.sop-reader-enter svg {
	pointer-events: none;
}

/* ── Settings popover ──────────────────────────────── */
.sop-reader-settings {
	position: fixed;
	bottom: 5.5rem;
	right: 1.5rem;
	width: 260px;
	padding: 1em 1.1em;
	background: rgba(255, 253, 247, 0.98);
	border: 1px solid #d4bc8a;
	border-radius: 6px;
	box-shadow: 0 6px 24px rgba(0, 0, 0, 0.18);
	z-index: 99999;
	display: none;
	color: #2a2620;
	font-family: "Source Serif 4", "Source Serif Pro", Charter, Georgia, Cambria, serif;
	font-size: 0.95rem;
}
.sop-reader-settings.is-open {
	display: block;
}
.sop-reader-overlay.is-dark ~ .sop-reader-settings,
.sop-reader-overlay.is-dark .sop-reader-settings {
	background: rgba(42, 38, 32, 0.98);
	border-color: #5a4a2c;
	color: #e8e2d5;
}
.sop-reader-settings-header {
	font-size: 0.75em;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #5a4a2c;
	margin-bottom: 0.85em;
}
.sop-reader-overlay.is-dark .sop-reader-settings-header {
	color: #b8a880;
}
.sop-reader-settings-row {
	display: flex;
	align-items: center;
	gap: 0.65em;
	padding: 0.4em 0;
	cursor: pointer;
	user-select: none;
	font-size: 0.95em;
}
.sop-reader-settings-row input[type="checkbox"] {
	flex: 0 0 auto;
	width: 1.05em;
	height: 1.05em;
	accent-color: #9E824B;
	cursor: pointer;
}
.sop-reader-reset {
	display: block;
	width: 100%;
	margin-top: 1em;
	padding: 0.55em 0.9em;
	font-family: inherit;
	font-size: 0.85em;
	font-weight: 500;
	color: #5a4a2c;
	background: transparent;
	border: 1px solid #d4bc8a;
	border-radius: 3px;
	cursor: pointer;
	transition: background-color 0.15s ease, color 0.15s ease;
}
.sop-reader-reset:hover {
	background: #f6efe0;
	color: #2a2010;
}
.sop-reader-overlay.is-dark ~ .sop-reader-settings .sop-reader-reset,
.sop-reader-overlay.is-dark .sop-reader-reset {
	color: #d8cfb6;
	border-color: #5a4a2c;
}
.sop-reader-overlay.is-dark ~ .sop-reader-settings .sop-reader-reset:hover,
.sop-reader-overlay.is-dark .sop-reader-reset:hover {
	background: rgba(184, 168, 128, 0.15);
	color: #f4eedc;
}

/* ── Body lock while reader mode is active ────────── */
body.sop-reader-active {
	overflow: hidden;
}
body.sop-reader-active #wpadminbar {
	display: none !important;
}
html.sop-reader-html {
	margin-top: 0 !important;
}

/* ── Mobile ────────────────────────────────────────── */
@media ( max-width: 600px ) {
	.sop-reader-content {
		padding: 2.5rem 1.25rem 7rem;
	}
	.sop-reader-toolbar {
		bottom: 1rem;
		right: 1rem;
		left: 1rem;
		justify-content: center;
	}
	.sop-reader-settings {
		bottom: 5rem;
		right: 1rem;
		left: 1rem;
		width: auto;
	}
	.sop-reader-nav {
		flex-direction: column;
	}
	.sop-reader-nav-spacer {
		display: none;
	}
}
