/* ==========================================================================
   Grave details slide-in panel.

   BASE styles below apply to the DEFAULT theme (original light look).
   The MEMORIAL theme (dark gold redesign) is layered at the bottom, scoped
   under `body.theme-memorial`, and only adds/overrides — so DEFAULT renders
   exactly as it did before the redesign.
   ========================================================================== */

/* ---- Base image (shared / default) ------------------------------------- */

.grave-image-wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	overflow: hidden;
}

.grave-image-wrap-thumb {
	height: 400px;
}

.grave-image-thumb {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}

.grave-image-wrap-detail {
	max-height: 450px;
	min-height: 200px;
}

.grave-image-detail {
	display: block;
	max-width: 100%;
	max-height: 450px;
	width: auto;
	height: auto;
}

.js-img-link:focus {
	outline: none !important;
	box-shadow: none !important;
}
.js-img-link:focus-visible {
	outline: none !important;
}

/* ---- Panel width (both themes) ----------------------------------------- */
/* Mobile: span the full viewport; desktop: fixed side panel. The selector
   beats Bootstrap's .modal-dialog max-width rules. */

#grave-info-modal .modal-dialog.grave-info-modal {
	width: 100vw;
	max-width: 100%;
}

@media (min-width: 768px) {
	#grave-info-modal .modal-dialog.grave-info-modal {
		width: 500px;
		max-width: 500px;
	}
}

/* ==========================================================================
   MEMORIAL theme — dark gold redesign (colors from themes.css tokens)
   ========================================================================== */

/* ---- Panel shell -------------------------------------------------------- */

body.theme-memorial #grave-info-modal .modal-content {
	height: 100%;
	border: 0;
	border-radius: 0;
	border-left: 1px solid var(--gd-border);
	background: linear-gradient(180deg, var(--gd-bg-2) 0%, var(--gd-bg) 38%);
	color: var(--gd-text) !important;
	box-shadow: var(--gd-panel-shadow);
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

body.theme-memorial #grave-info-modal .gd-body {
	flex: 1 1 auto;
	overflow-y: auto;
	overflow-x: hidden;
	padding: 0 22px 22px;
	scrollbar-width: thin;
	scrollbar-color: var(--gd-gold-muted) transparent;
}

body.theme-memorial #grave-info-modal .gd-body::-webkit-scrollbar {
	width: 8px;
}

body.theme-memorial #grave-info-modal .gd-body::-webkit-scrollbar-thumb {
	background: var(--gd-scroll-thumb);
	border-radius: 8px;
}

/* ---- Section label (eyebrow) ------------------------------------------- */

body.theme-memorial #grave-info-modal .gd-eyebrow {
	display: flex;
	align-items: center;
	gap: 9px;
	margin: 0 0 14px;
	font-family: 'Open Sans', sans-serif;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--gd-gold);
}

body.theme-memorial #grave-info-modal .gd-eyebrow > i {
	font-size: 12px;
	opacity: 0.85;
}

body.theme-memorial #grave-info-modal .gd-eyebrow::after {
	content: "";
	flex: 1 1 auto;
	height: 1px;
	background: linear-gradient(90deg, var(--gd-border) 0%, transparent 100%);
}

/* ---- Header ------------------------------------------------------------- */

body.theme-memorial #grave-info-modal .gd-header {
	position: relative;
	padding: 26px 22px 18px;
	border-bottom: 1px solid var(--gd-border);
}

body.theme-memorial #grave-info-modal .gd-header .gd-eyebrow {
	margin-bottom: 8px;
}

body.theme-memorial #grave-info-modal .gd-header .gd-eyebrow::after {
	display: none;
}

body.theme-memorial #grave-info-modal .gd-title {
	margin: 0;
	font-family: var(--gd-serif);
	font-weight: 600;
	font-size: 30px;
	line-height: 1.15;
	letter-spacing: 0.01em;
	color: var(--gd-title-color);
}

body.theme-memorial #grave-info-modal .gd-close {
	position: absolute;
	top: 22px;
	right: 22px;
	width: 34px;
	height: 34px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0;
	border: 1px solid var(--gd-border);
	border-radius: 4px;
	background: transparent;
	color: var(--gd-text-muted);
	font-size: 20px;
	line-height: 1;
	opacity: 1;
	transition: all 0.18s ease;
}

body.theme-memorial #grave-info-modal .gd-close:hover {
	border-color: var(--gd-border-strong);
	color: var(--gd-gold);
	background: var(--gd-surface-hover);
}

/* ---- Image -------------------------------------------------------------- */

body.theme-memorial #grave-info-modal .gd-image-block {
	margin: 22px 0 8px;
}

body.theme-memorial .grave-image-wrap {
	background: var(--gd-image-bg);
	border: 1px solid var(--gd-border);
	border-radius: 6px;
}

body.theme-memorial .grave-image-wrap-thumb {
	height: 230px;
}

body.theme-memorial #grave-info-modal .gd-image-caption {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 7px;
	margin-top: 10px;
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--gd-gold-muted);
}

/* ---- Generic section spacing ------------------------------------------- */

body.theme-memorial #grave-info-modal .gd-section {
	padding-top: 22px;
	margin-top: 22px;
	border-top: 1px solid var(--gd-border);
}

body.theme-memorial #grave-info-modal .gd-section:first-of-type {
	border-top: 0;
}

/* ---- Free-for-sale notice ---------------------------------------------- */

body.theme-memorial #grave-info-modal .gd-free {
	padding: 14px 16px;
	border: 1px solid var(--gd-border);
	border-left: 3px solid var(--gd-gold);
	border-radius: 6px;
	background: var(--gd-surface);
	color: var(--gd-text);
	font-size: 13.5px;
	line-height: 1.55;
}

/* ---- Person card -------------------------------------------------------- */

body.theme-memorial #grave-info-modal .g-person {
	position: relative;
	display: flex;
	gap: 14px;
	padding: 16px 16px;
	margin-bottom: 12px;
	border: 1px solid var(--gd-border);
	border-radius: 7px;
	background: var(--gd-surface);
}

body.theme-memorial #grave-info-modal .g-person:last-child {
	margin-bottom: 0;
}

body.theme-memorial #grave-info-modal .g-person-icon {
	flex: 0 0 auto;
	width: 34px;
	height: 34px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--gd-border-strong);
	border-radius: 6px;
	color: var(--gd-gold);
	font-size: 14px;
}

body.theme-memorial #grave-info-modal .g-person-body {
	flex: 1 1 auto;
	min-width: 0;
}

body.theme-memorial #grave-info-modal .js-fullname {
	margin: 0 0 10px;
	font-family: var(--gd-serif);
	font-size: 19px;
	font-weight: 500;
	color: var(--gd-name-color);
}

body.theme-memorial #grave-info-modal .g-person-dates {
	display: flex;
	flex-wrap: wrap;
	gap: 8px 26px;
	margin: 0;
	padding: 0;
	list-style: none;
}

body.theme-memorial #grave-info-modal .g-person-dates li {
	display: flex;
	flex-direction: column;
	gap: 2px;
}

body.theme-memorial #grave-info-modal .g-date-label {
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--gd-gold-muted);
}

body.theme-memorial #grave-info-modal .g-date-value {
	font-size: 14px;
	color: var(--gd-text);
}

body.theme-memorial #grave-info-modal .g-person-age {
	display: flex;
	align-items: center;
	gap: 7px;
	margin-top: 11px;
	font-size: 12.5px;
	font-style: italic;
	color: var(--gd-text-muted);
}

body.theme-memorial #grave-info-modal .g-person-age > i {
	font-size: 9px;
	color: var(--gd-gold);
	font-style: normal;
}

/* ---- Owner card --------------------------------------------------------- */

body.theme-memorial #grave-info-modal .g-owner {
	display: flex;
	align-items: center;
	gap: 14px;
	padding: 14px 16px;
	margin-bottom: 10px;
	border: 1px solid var(--gd-border);
	border-radius: 7px;
	background: var(--gd-surface);
}

body.theme-memorial #grave-info-modal .g-owner:last-child {
	margin-bottom: 0;
}

body.theme-memorial #grave-info-modal .g-owner-icon {
	flex: 0 0 auto;
	width: 34px;
	height: 34px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--gd-border-strong);
	border-radius: 6px;
	color: var(--gd-gold);
	font-size: 14px;
}

body.theme-memorial #grave-info-modal .g-owner-body {
	min-width: 0;
}

body.theme-memorial #grave-info-modal .g-owner-label {
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--gd-gold-muted);
	margin-bottom: 3px;
}

body.theme-memorial #grave-info-modal .js-owner {
	margin: 0;
	font-size: 15px;
	font-weight: 600;
	color: var(--gd-text);
}

/* ---- Buttons ------------------------------------------------------------ */

body.theme-memorial #grave-info-modal .gd-share {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 10px;
}

body.theme-memorial #grave-info-modal .gd-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	width: 100%;
	padding: 11px 12px;
	border: 1px solid var(--gd-border);
	border-radius: 5px;
	background: transparent;
	color: var(--gd-text);
	font-family: 'Open Sans', sans-serif;
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	cursor: pointer;
	transition: all 0.18s ease;
}

body.theme-memorial #grave-info-modal .gd-btn:hover,
body.theme-memorial #grave-info-modal .gd-btn:focus {
	border-color: var(--gd-border-strong);
	color: var(--gd-gold-soft);
	background: var(--gd-surface-hover);
	outline: none;
}

body.theme-memorial #grave-info-modal .gd-btn-primary {
	border-color: var(--gd-btn-primary-border);
	color: var(--gd-btn-primary-text);
	background: var(--gd-btn-primary-bg);
}

body.theme-memorial #grave-info-modal .gd-btn-primary:hover,
body.theme-memorial #grave-info-modal .gd-btn-primary:focus {
	border-color: var(--gd-btn-primary-border);
	color: var(--gd-btn-primary-hover-text);
	background: var(--gd-btn-primary-hover-bg);
}

body.theme-memorial #grave-info-modal .gd-btn-ghost {
	border-color: transparent;
	color: var(--gd-text-muted);
}

body.theme-memorial #grave-info-modal .gd-btn-ghost:hover,
body.theme-memorial #grave-info-modal .gd-btn-ghost:focus {
	border-color: var(--gd-border);
	color: var(--gd-gold-soft);
	background: transparent;
}

body.theme-memorial #grave-info-modal .gd-actions {
	display: flex;
	flex-direction: column;
	gap: 10px;
}

/* ---- Footer ------------------------------------------------------------- */

body.theme-memorial #grave-info-modal .gd-footer {
	flex: 0 0 auto;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 14px 22px;
	border-top: 1px solid var(--gd-border);
	background: var(--gd-footer-bg);
}

body.theme-memorial #grave-info-modal .gd-footer-brand {
	font-family: var(--gd-serif);
	font-size: 16px;
	color: var(--gd-gold);
	letter-spacing: 0.02em;
}

body.theme-memorial #grave-info-modal .gd-footer-nav {
	display: flex;
	align-items: center;
	gap: 10px;
	font-size: 10px;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--gd-text-muted);
}

body.theme-memorial #grave-info-modal .gd-footer-arrow {
	width: 26px;
	height: 26px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border: 1px solid var(--gd-border);
	border-radius: 4px;
	background: transparent;
	color: var(--gd-text-muted);
	transition: all 0.18s ease;
}

body.theme-memorial #grave-info-modal .gd-footer-arrow:hover {
	border-color: var(--gd-border-strong);
	color: var(--gd-gold);
}
