/**
 * GBF Estate Planning Questionnaire — Generosity Maximizer layer
 * Scoped styles for the optional Generosity Discovery screen, educational
 * tooltip bubbles, and the thank-you popup recommendation cards.
 *
 * Every selector is namespaced under .epq-gen-* (or descends from an EPQ
 * container) so nothing here can leak into or override the stable EPQ UI.
 * Palette mirrors the GBF Generosity Maximizer skin:
 *   charcoal #353535 / #262626 / #1f1f1f, gold #d8aa4d (hover #b88f49),
 *   cream #ead7b8 / #fbf5ec, white #fff.
 *
 * @package EPQ\Generosity
 * @since 4.7.0
 */

:root {
	--epq-gen-charcoal: #353535;
	--epq-gen-charcoal-deep: #262626;
	--epq-gen-ink: #1f1f1f;
	--epq-gen-gold: #d8aa4d;
	--epq-gen-gold-deep: #b88f49;
	--epq-gen-cream: #fbf5ec;
	--epq-gen-cream-deep: #ead7b8;
	--epq-gen-line: #e4ddcf;
	--epq-gen-muted: #5d6675;
	--epq-gen-white: #ffffff;
	--epq-gen-radius: 14px;
	--epq-gen-radius-sm: 10px;
}

/* ------------------------------------------------------------------ *
 * Phase 1 — Generosity Discovery screen (inside an .epq-v2-screen)
 * ------------------------------------------------------------------ */

.epq-gen-discovery {
	display: block;
	width: 100%;
	max-width: min(1400px, 100%);
	margin: 0 auto;
}

.epq-gen-discovery-intro {
	margin: 0 0 2.4rem;
	padding: 1.35rem 1.75rem;
	border-left: 32px solid #4d8fce;
	background: #dce1eb;
	border-radius: var(--epq-gen-radius-sm);
	color: var(--epq-gen-charcoal);
	font-size: 1.35rem;
	line-height: 1.55;
}

.epq-gen-field {
	margin: 0 0 2.55rem;
}

.epq-gen-field:last-child {
	margin-bottom: 0;
}

.epq-gen-field > label,
.epq-gen-field .epq-gen-field-label {
	display: block;
	margin: 0 0 0.55rem;
	font-weight: 600;
	color: var(--epq-gen-ink);
	font-size: 1.6rem;
	line-height: 1.35;
}

.epq-gen-optional {
	margin-left: 0.4rem;
	font-weight: 400;
	font-size: 0.82rem;
	color: var(--epq-gen-muted);
	text-transform: uppercase;
	letter-spacing: 0.04em;
}

.epq-gen-field textarea,
.epq-gen-field input[type="text"] {
	width: 100%;
	box-sizing: border-box;
	padding: 0.7rem 0.85rem;
	border: 1px solid var(--epq-gen-line);
	border-radius: var(--epq-gen-radius-sm);
	background: var(--epq-gen-white);
	font: inherit;
	color: var(--epq-gen-ink);
	transition: border-color 0.15s ease, box-shadow 0.15s ease;
}

.epq-gen-field textarea {
	min-height: 96px;
	resize: vertical;
}

.epq-gen-field textarea:focus,
.epq-gen-field input[type="text"]:focus {
	outline: none;
	border-color: var(--epq-gen-gold);
	box-shadow: 0 0 0 3px rgba(216, 170, 77, 0.18);
}

/* Checkbox grid + radio pills */
.epq-gen-options {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
	gap: 0.55rem;
}

.epq-gen-options.epq-gen-options-inline {
	grid-template-columns: repeat(auto-fit, minmax(120px, max-content));
}

.epq-gen-option {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	margin: 0;
	padding: 0.7rem 0.9rem;
	border: 1px solid var(--epq-gen-line);
	border-radius: 999px;
	background: var(--epq-gen-white);
	cursor: pointer;
	font-size: 1.05rem;
	color: var(--epq-gen-charcoal);
	white-space: nowrap;
	transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}

.epq-gen-option:hover {
	border-color: var(--epq-gen-gold);
	background: #f7efe0;
}

.epq-gen-option input {
	margin: 0;
	accent-color: var(--epq-gen-gold-deep);
	flex: 0 0 auto;
}

.epq-gen-option.is-selected {
	border-color: var(--epq-gen-gold-deep);
	background: var(--epq-gen-cream);
	box-shadow: inset 0 0 0 1px var(--epq-gen-gold-deep);
}

/* ------------------------------------------------------------------ *
 * Phase 2 — Educational tooltip bubbles
 * ------------------------------------------------------------------ */

.epq-gen-tip {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 1.25rem;
	height: 1.25rem;
	margin-left: 0.5rem;
	border-radius: 50%;
	background: var(--epq-gen-gold);
	color: var(--epq-gen-charcoal-deep);
	font-size: 0.78rem;
	font-weight: 700;
	font-style: normal;
	line-height: 1;
	cursor: pointer;
	vertical-align: middle;
	border: none;
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.15);
	transition: transform 0.12s ease, background 0.12s ease;
}

.epq-gen-tip:hover,
.epq-gen-tip:focus {
	background: var(--epq-gen-gold-deep);
	transform: translateY(-1px);
	outline: none;
}

.epq-gen-tip-bubble {
	position: absolute;
	z-index: 60;
	top: calc(100% + 8px);
	left: 50%;
	transform: translateX(-50%);
	width: min(320px, 78vw);
	padding: 0.85rem 1rem;
	border-radius: var(--epq-gen-radius-sm);
	background: var(--epq-gen-charcoal);
	color: #f4eee2;
	font-size: 1.15rem;
	font-weight: 400;
	line-height: 1.5;
	text-align: left;
	box-shadow: 0 12px 30px rgba(0, 0, 0, 0.28);
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transition: opacity 0.14s ease, visibility 0.14s ease;
}

.epq-gen-tip-bubble::before {
	content: "";
	position: absolute;
	bottom: 100%;
	left: 50%;
	transform: translateX(-50%);
	border: 7px solid transparent;
	border-bottom-color: var(--epq-gen-charcoal);
}

.epq-gen-tip.is-open .epq-gen-tip-bubble {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
}

.epq-gen-tip-bubble strong {
	color: var(--epq-gen-gold);
}

/* ------------------------------------------------------------------ *
 * Phase 6 — Thank-you popup recommendation block
 * Injected into #epq-v2-modal-content or #epq-modal-content.
 * ------------------------------------------------------------------ */

.epq-gen-results {
	margin-top: 1.6rem;
	padding-top: 1.4rem;
	border-top: 1px solid var(--epq-gen-line);
	text-align: left;
}

.epq-gen-downloads {
	display: flex;
	flex-wrap: wrap;
	gap: 0.7rem;
	margin-bottom: 1.5rem;
}

.epq-gen-download {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	padding: 0.7rem 1.1rem;
	border-radius: var(--epq-gen-radius-sm);
	background: var(--epq-gen-charcoal);
	color: var(--epq-gen-white);
	text-decoration: none;
	font-weight: 600;
	font-size: 0.92rem;
	transition: background 0.15s ease;
}

.epq-gen-download:hover {
	background: var(--epq-gen-charcoal-deep);
	color: var(--epq-gen-white);
}

.epq-gen-download--plan {
	background: var(--epq-gen-gold-deep);
	color: var(--epq-gen-charcoal-deep);
}

.epq-gen-download--plan:hover {
	background: var(--epq-gen-gold);
	color: var(--epq-gen-charcoal-deep);
}

.epq-gen-section {
	margin-bottom: 1.5rem;
}

.epq-gen-section-title {
	margin: 0 0 0.75rem;
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.09em;
	text-transform: uppercase;
	color: var(--epq-gen-gold-deep);
}

.epq-gen-cards {
	display: grid;
	gap: 0.7rem;
}

.epq-gen-card {
	padding: 0.95rem 1.05rem;
	border: 1px solid var(--epq-gen-line);
	border-radius: var(--epq-gen-radius);
	background: var(--epq-gen-cream);
}

.epq-gen-card-name {
	margin: 0 0 0.3rem;
	font-size: 1.02rem;
	font-weight: 700;
	color: var(--epq-gen-ink);
}

.epq-gen-card-summary {
	margin: 0 0 0.5rem;
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--epq-gen-charcoal);
}

.epq-gen-card-why {
	margin: 0 0 0.6rem;
	font-size: 0.88rem;
	line-height: 1.5;
	color: var(--epq-gen-muted);
}

.epq-gen-card-why strong {
	color: var(--epq-gen-charcoal);
}

.epq-gen-card-link {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.88rem;
	font-weight: 600;
	color: var(--epq-gen-gold-deep);
	text-decoration: none;
}

.epq-gen-card-link:hover {
	color: var(--epq-gen-charcoal);
	text-decoration: underline;
}

.epq-gen-steps {
	margin: 0;
	padding-left: 1.2rem;
}

.epq-gen-steps li {
	margin-bottom: 0.45rem;
	font-size: 0.92rem;
	line-height: 1.5;
	color: var(--epq-gen-charcoal);
}

.epq-gen-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 0.7rem;
	margin-top: 1.6rem;
	padding-top: 1.3rem;
	border-top: 1px solid var(--epq-gen-line);
}

.epq-gen-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: 0.8rem 1.3rem;
	border-radius: var(--epq-gen-radius-sm);
	font-weight: 700;
	font-size: 0.94rem;
	text-decoration: none;
	cursor: pointer;
	border: 2px solid transparent;
	transition: background 0.15s ease, border-color 0.15s ease, color 0.15s ease;
}

.epq-gen-btn--primary {
	background: var(--epq-gen-gold);
	color: var(--epq-gen-charcoal-deep);
}

.epq-gen-btn--primary:hover {
	background: var(--epq-gen-gold-deep);
	color: var(--epq-gen-charcoal-deep);
}

.epq-gen-btn--secondary {
	background: transparent;
	border-color: var(--epq-gen-charcoal);
	color: var(--epq-gen-charcoal);
}

.epq-gen-btn--secondary:hover {
	background: var(--epq-gen-charcoal);
	color: var(--epq-gen-white);
}


/* v4.7.1 requested discovery-screen polish and rich tooltip content. */
#epq-v2-app .epq-v2-screen[data-screen-key="generosity-discovery"] {
	max-width: none;
}

#epq-v2-app .epq-v2-screen[data-screen-key="generosity-discovery"] .epq-v2-screen-header h2,
#epq-v2-app .epq-v2-screen[data-screen-key="generosity-discovery"] .epq-v2-unified-title {
	text-align: center;
	font-size: clamp(3.2rem, 5vw, 5.25rem);
	line-height: 1;
	margin-bottom: 2.4rem;
}

.epq-gen-tip-bubble h3 {
	margin: 0 0 0.65rem;
	color: var(--epq-gen-gold);
	font-size: 1.25rem;
	line-height: 1.25;
}

.epq-gen-tip-bubble p {
	margin: 0 0 0.75rem;
}

.epq-gen-tip-bubble p:last-child {
	margin-bottom: 0;
}

.epq-gen-tip-bubble ul {
	margin: 0 0 0.75rem;
	padding: 0;
	list-style: none;
}

.epq-gen-tip-bubble li {
	margin: 0 0 0.35rem;
}

@media (max-width: 760px) {
	.epq-gen-option {
		white-space: normal;
	}
}

@media (max-width: 540px) {
	.epq-gen-downloads,
	.epq-gen-actions {
		flex-direction: column;
	}

	.epq-gen-download,
	.epq-gen-btn {
		width: 100%;
		box-sizing: border-box;
	}

	.epq-gen-options {
		grid-template-columns: 1fr;
	}
}

/* ------------------------------------------------------------------ *
 * v4.7.2 refinements: stable tooltip portal, no-children rest/residue
 * layout, and readable/scrollable recommendation popup.
 * ------------------------------------------------------------------ */

/* The visible tooltip is rendered in #epq-gen-tip-portal so it is never
   clipped by the EPQ stage/modal overflow and always stacks above the site. */
.epq-gen-tip > .epq-gen-tip-bubble {
	display: none !important;
}

#epq-gen-tip-portal.epq-gen-tip-portal {
	position: fixed !important;
	z-index: 2147483000 !important;
	width: min(520px, calc(100vw - 44px)) !important;
	max-height: min(72vh, 620px) !important;
	overflow-y: auto !important;
	padding: 1.1rem 1.25rem !important;
	border-radius: 12px !important;
	background: var(--epq-gen-charcoal) !important;
	color: #f4eee2 !important;
	font-size: 1.15rem !important;
	font-weight: 400 !important;
	line-height: 1.55 !important;
	text-align: left !important;
	box-shadow: 0 22px 52px rgba(0, 0, 0, 0.42) !important;
	opacity: 0 !important;
	visibility: hidden !important;
	pointer-events: none !important;
	box-sizing: border-box !important;
}

#epq-gen-tip-portal.epq-gen-tip-portal.is-open {
	opacity: 1 !important;
	visibility: visible !important;
	pointer-events: auto !important;
}

#epq-gen-tip-portal h3 {
	margin: 0 0 0.75rem !important;
	color: var(--epq-gen-gold) !important;
	font-size: 1.24rem !important;
	line-height: 1.25 !important;
}

#epq-gen-tip-portal p {
	margin: 0 0 0.8rem !important;
	color: #f4eee2 !important;
}

#epq-gen-tip-portal ul {
	margin: 0 0 0.8rem !important;
	padding-left: 1.1rem !important;
	color: #f4eee2 !important;
}

#epq-gen-tip-portal li {
	margin: 0.25rem 0 !important;
}

/* No-children rest/residue screen: image smaller/further left, right column vertical. */
#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-options-layout {
	display: grid !important;
	grid-template-columns: minmax(220px, 0.82fr) minmax(360px, 1.18fr) !important;
	align-items: center !important;
	gap: clamp(28px, 5vw, 72px) !important;
	width: 100% !important;
	max-width: 980px !important;
	margin: 2.2rem auto 0 !important;
}

#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-options-media {
	justify-self: start !important;
	transform: translateX(-8%) !important;
	max-width: 300px !important;
}

#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-options-media img {
	width: 70% !important;
	max-width: 260px !important;
	height: auto !important;
	display: block !important;
	margin: 0 auto !important;
}

#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-option-cards {
	display: flex !important;
	flex-direction: column !important;
	align-items: stretch !important;
	justify-content: center !important;
	gap: 18px !important;
	width: 100% !important;
}

#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-option-card-charity {
	display: grid !important;
	grid-template-columns: 96px minmax(0, 1fr) !important;
	align-items: center !important;
	gap: 20px !important;
	width: 100% !important;
	max-width: 560px !important;
	padding: 24px !important;
	box-sizing: border-box !important;
}

#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-option-card-charity .epq-v2-rest-option-icon {
	width: 76px !important;
	height: 76px !important;
}

#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-card-fields-charity {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
}

@media (max-width: 860px) {
	#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-options-layout {
		grid-template-columns: 1fr !important;
		gap: 22px !important;
	}
	#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-options-media {
		justify-self: center !important;
		transform: none !important;
		text-align: center !important;
	}
	#epq-v2-app section[data-screen-key="section3-rest-residue-no-children"] .epq-v2-rest-option-card-charity {
		max-width: 100% !important;
	}
}

/* Recommendation/thank-you popup: scrollable, larger, roomier, more GBF-styled. */
#epq-v2-modal-overlay .epq-v2-modal-content,
#epq-modal-overlay #epq-modal-content {
	max-height: min(86vh, 920px) !important;
	overflow-y: auto !important;
	-webkit-overflow-scrolling: touch !important;
	max-width: min(860px, calc(100vw - 48px)) !important;
	padding: clamp(28px, 4vw, 48px) !important;
	box-sizing: border-box !important;
}

#epq-v2-modal-content .epq-gen-results,
#epq-modal-content .epq-gen-results {
	margin-top: 2rem !important;
	padding-top: 2rem !important;
	border-top: 2px solid #e8dcc7 !important;
}

#epq-v2-modal-content .epq-gen-downloads,
#epq-modal-content .epq-gen-downloads {
	gap: 1rem !important;
	margin-bottom: 2.1rem !important;
}

#epq-v2-modal-content .epq-gen-section,
#epq-modal-content .epq-gen-section {
	margin-bottom: 2.4rem !important;
}

#epq-v2-modal-content .epq-gen-section-title,
#epq-modal-content .epq-gen-section-title {
	margin-bottom: 1rem !important;
	font-size: 1rem !important;
	letter-spacing: 0.13em !important;
	color: #b37a2c !important;
}

#epq-v2-modal-content .epq-gen-cards,
#epq-modal-content .epq-gen-cards {
	gap: 1.15rem !important;
}

#epq-v2-modal-content .epq-gen-card,
#epq-modal-content .epq-gen-card {
	padding: 1.45rem 1.55rem !important;
	border-radius: 18px !important;
	background: #fbf5ec !important;
	border-color: #e8dcc7 !important;
	box-shadow: 0 10px 24px rgba(31, 31, 31, 0.06) !important;
}

#epq-v2-modal-content .epq-gen-card-name,
#epq-modal-content .epq-gen-card-name {
	font-size: 1.28rem !important;
	line-height: 1.25 !important;
	margin-bottom: 0.7rem !important;
	color: #252525 !important;
}

#epq-v2-modal-content .epq-gen-card-summary,
#epq-v2-modal-content .epq-gen-card-why,
#epq-modal-content .epq-gen-card-summary,
#epq-modal-content .epq-gen-card-why {
	font-size: 1.05rem !important;
	line-height: 1.65 !important;
	margin-bottom: 0.85rem !important;
}

#epq-v2-modal-content .epq-gen-card-link,
#epq-modal-content .epq-gen-card-link {
	font-size: 1.02rem !important;
	font-weight: 800 !important;
	color: #bf6d21 !important;
}

#epq-v2-modal-content .epq-gen-steps,
#epq-modal-content .epq-gen-steps {
	font-size: 1.05rem !important;
	line-height: 1.65 !important;
	padding-left: 1.45rem !important;
}

#epq-v2-modal-content .epq-gen-actions,
#epq-modal-content .epq-gen-actions {
	display: flex !important;
	flex-wrap: wrap !important;
	gap: 1rem !important;
	margin-top: 2.2rem !important;
}

#epq-v2-modal-content .epq-gen-btn,
#epq-modal-content .epq-gen-btn {
	font-size: 1.03rem !important;
	padding: 0.95rem 1.25rem !important;
	border-radius: 999px !important;
}

/* v4.7.5 fixes: charitable beneficiary repeater, close button pinning, and final recommendation screen. */
#epq-v2-app .epq-v2-charitable-beneficiaries {
	display: flex !important;
	flex-direction: column !important;
	gap: 16px !important;
	width: 100% !important;
}
#epq-v2-app .epq-v2-charitable-beneficiary-row {
	display: grid !important;
	grid-template-columns: minmax(0, 1fr) auto auto !important;
	align-items: end !important;
	gap: 24px !important;
	width: 100% !important;
	box-sizing: border-box !important;
}
#epq-v2-app .epq-v2-charitable-beneficiary-row + .epq-v2-charitable-beneficiary-row {
	padding-top: 12px !important;
	border-top: 1px solid rgba(216, 174, 102, 0.22) !important;
}
#epq-v2-app .epq-v2-charitable-add-beneficiary,
#epq-v2-app .epq-v2-charitable-remove-beneficiary {
	height: 48px !important;
	align-self: end !important;
	border: 0 !important;
	border-radius: 999px !important;
	padding: 0 26px !important;
	font-size: 16px !important;
	font-weight: 900 !important;
	white-space: nowrap !important;
	cursor: pointer !important;
}
#epq-v2-app .epq-v2-charitable-add-beneficiary {
	background: #e0b65d !important;
	color: #fff !important;
}
#epq-v2-app .epq-v2-charitable-add-beneficiary.is-disabled,
#epq-v2-app .epq-v2-charitable-add-beneficiary:disabled {
	background: #d8d2c5 !important;
	color: #6b7280 !important;
	cursor: default !important;
}
#epq-v2-app .epq-v2-charitable-remove-beneficiary {
	background: #f3eee7 !important;
	color: #8a5a1d !important;
}
@media (max-width: 900px) {
	#epq-v2-app .epq-v2-charitable-beneficiary-row {
		grid-template-columns: 1fr !important;
		gap: 14px !important;
	}
	#epq-v2-app .epq-v2-charitable-add-beneficiary,
	#epq-v2-app .epq-v2-charitable-remove-beneficiary {
		width: 100% !important;
	}
}

html body .breakdance-popup-close-button,
html body .bde-popup__close-button,
html body .breakdance-popup .breakdance-popup-close-button,
html body [class*="breakdance-popup-close"],
html body [class*="bde-popup__close"] {
	position: fixed !important;
	top: max(18px, env(safe-area-inset-top)) !important;
	right: max(18px, env(safe-area-inset-right)) !important;
	left: auto !important;
	bottom: auto !important;
	transform: none !important;
	margin: 0 !important;
	z-index: 2147483647 !important;
}

#epq-v2-modal-content .epq-gen-results,
#epq-modal-content .epq-gen-results {
	width: min(720px, 100%) !important;
	margin: 2rem auto 0 !important;
	padding: 0 !important;
	border-top: 0 !important;
	text-align: left !important;
	font-family: inherit !important;
}
#epq-v2-modal-content .epq-gen-downloads,
#epq-modal-content .epq-gen-downloads {
	display: flex !important;
	justify-content: flex-start !important;
	gap: 18px !important;
	margin: 22px 0 42px !important;
}
#epq-v2-modal-content .epq-gen-download,
#epq-modal-content .epq-gen-download {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	min-height: 34px !important;
	padding: 9px 20px !important;
	border-radius: 999px !important;
	background: #d8ae66 !important;
	color: #2f2d2b !important;
	font-size: 0.84rem !important;
	font-weight: 900 !important;
	line-height: 1.1 !important;
	text-decoration: none !important;
	text-transform: uppercase !important;
}
#epq-v2-modal-content .epq-gen-download--plan,
#epq-modal-content .epq-gen-download--plan {
	background: #2f2d2b !important;
	color: #d8ae66 !important;
}
#epq-v2-modal-content .epq-gen-section,
#epq-modal-content .epq-gen-section {
	margin: 0 0 58px !important;
}
#epq-v2-modal-content .epq-gen-section-title,
#epq-modal-content .epq-gen-section-title {
	font-size: 0.95rem !important;
	font-weight: 900 !important;
	letter-spacing: 0.08em !important;
	text-transform: uppercase !important;
	color: #2f2d2b !important;
	padding-bottom: 12px !important;
	margin: 0 0 28px !important;
	border-bottom: 3px solid #d7ad56 !important;
}
#epq-v2-modal-content .epq-gen-cards,
#epq-modal-content .epq-gen-cards {
	display: flex !important;
	flex-direction: column !important;
	gap: 30px !important;
}
#epq-v2-modal-content .epq-gen-card,
#epq-modal-content .epq-gen-card {
	display: grid !important;
	grid-template-columns: 58px minmax(0, 1fr) !important;
	gap: 22px !important;
	align-items: start !important;
	padding: 0 !important;
	border: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
}
#epq-v2-modal-content .epq-gen-card-number,
#epq-modal-content .epq-gen-card-number {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	width: 44px !important;
	height: 44px !important;
	border-radius: 999px !important;
	border: 4px solid #d7ad56 !important;
	color: #2f2d2b !important;
	font-size: 1.5rem !important;
	font-weight: 900 !important;
	line-height: 1 !important;
}
#epq-v2-modal-content .epq-gen-card-name,
#epq-modal-content .epq-gen-card-name {
	font-size: 1.18rem !important;
	font-weight: 900 !important;
	line-height: 1.24 !important;
	margin: 0 0 8px !important;
	color: #2c2c2c !important;
}
#epq-v2-modal-content .epq-gen-card-summary,
#epq-v2-modal-content .epq-gen-card-why,
#epq-modal-content .epq-gen-card-summary,
#epq-modal-content .epq-gen-card-why {
	font-size: 1rem !important;
	line-height: 1.58 !important;
	margin: 0 0 12px !important;
	color: #3e4147 !important;
}
#epq-v2-modal-content .epq-gen-card-why,
#epq-modal-content .epq-gen-card-why {
	padding-left: 16px !important;
	border-left: 6px solid #d7ad56 !important;
}
#epq-v2-modal-content .epq-gen-card-link,
#epq-modal-content .epq-gen-card-link {
	display: inline-block !important;
	color: #da8e66 !important;
	font-size: 1rem !important;
	font-weight: 900 !important;
	line-height: 1.45 !important;
	text-decoration: none !important;
}
#epq-v2-modal-content .epq-gen-section:has(.epq-gen-steps),
#epq-modal-content .epq-gen-section:has(.epq-gen-steps) {
	background: #eeeeec !important;
	padding: 28px 34px !important;
	margin-top: 12px !important;
}
#epq-v2-modal-content .epq-gen-section:has(.epq-gen-steps) .epq-gen-section-title,
#epq-modal-content .epq-gen-section:has(.epq-gen-steps) .epq-gen-section-title {
	border: 0 !important;
	font-size: 1.9rem !important;
	letter-spacing: 0 !important;
	text-transform: none !important;
	margin-bottom: 12px !important;
	padding-bottom: 0 !important;
}
#epq-v2-modal-content .epq-gen-steps,
#epq-modal-content .epq-gen-steps {
	font-size: 1rem !important;
	line-height: 1.65 !important;
	padding-left: 22px !important;
	margin: 0 !important;
}
#epq-v2-modal-content .epq-gen-actions,
#epq-modal-content .epq-gen-actions {
	justify-content: flex-start !important;
	margin-top: 22px !important;
}
#epq-v2-modal-content .epq-gen-btn,
#epq-modal-content .epq-gen-btn {
	background: #d8ae66 !important;
	color: #2f2d2b !important;
	font-size: 0.92rem !important;
	font-weight: 900 !important;
	padding: 12px 22px !important;
	border-radius: 999px !important;
	text-decoration: none !important;
}
#epq-v2-modal-content .epq-gen-btn--secondary,
#epq-modal-content .epq-gen-btn--secondary {
	background: #2f2d2b !important;
	color: #d8ae66 !important;
}
@media (max-width: 640px) {
	#epq-v2-modal-content .epq-gen-card,
	#epq-modal-content .epq-gen-card {
		grid-template-columns: 1fr !important;
		gap: 12px !important;
	}
	#epq-v2-modal-content .epq-gen-downloads,
	#epq-modal-content .epq-gen-downloads {
		flex-direction: column !important;
	}
}

/* v4.7.6: force the charitable beneficiary Add Beneficiary control to appear at the end of the active record row. */
#epq-v2-app .epq-v2-charitable-beneficiary-actions {
	display: flex !important;
	align-items: end !important;
	justify-content: flex-end !important;
	gap: 10px !important;
	min-width: 210px !important;
}
#epq-v2-app .epq-v2-charitable-beneficiary-actions .epq-v2-charitable-add-beneficiary {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	visibility: visible !important;
	opacity: 1 !important;
	position: static !important;
}
#epq-v2-app .epq-v2-charitable-beneficiary-actions .epq-v2-charitable-remove-beneficiary {
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	visibility: visible !important;
	opacity: 1 !important;
	position: static !important;
}
@media (max-width: 1100px) {
	#epq-v2-app .epq-v2-charitable-beneficiary-row {
		grid-template-columns: minmax(0, 1fr) auto !important;
	}
	#epq-v2-app .epq-v2-charitable-beneficiary-actions {
		grid-column: 1 / -1 !important;
		justify-content: flex-start !important;
	}
}

/* v5.0.5 recommendation popup mobile visibility and link color fixes */
#epq-v2-modal-content .epq-gen-card-link,
#epq-modal-content .epq-gen-card-link { color: #da8e66 !important; }
@media (max-width: 767px) {
  #epq-v2-modal-overlay,
  #epq-modal-overlay { overflow-y: auto !important; -webkit-overflow-scrolling: touch !important; align-items: flex-start !important; }
  #epq-v2-modal-content,
  #epq-modal-content { max-height: none !important; overflow: visible !important; }
  #epq-v2-modal-content .epq-gen-results,
  #epq-modal-content .epq-gen-results { display: block !important; visibility: visible !important; opacity: 1 !important; }
  #epq-v2-modal-content .epq-gen-section,
  #epq-modal-content .epq-gen-section { display: block !important; visibility: visible !important; height: auto !important; max-height: none !important; overflow: visible !important; }
}
