/* ============================================================
Feldstein Family Law — Consultation Popup
Single source of truth for popup CSS. Loaded by templates that
opt in via functions.php enqueue.

Architecture:
1. CONSULTATION POPUP — backdrop, modal, header, close, body, disclaimer
2. GRAVITY FORMS — POPUP — compact light-theme GF form inside the modal
============================================================ */

/* =========================================
1. CONSULTATION POPUP
========================================= */

/* Suppress body scroll when popup is open */
body.popup-open { overflow: hidden; }

#ffl-popup-backdrop {
	position: fixed;
	inset: 0;
	background: rgba(12, 23, 43, 0.72);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	opacity: 0;
	pointer-events: none;
	z-index: 9998;
	transition: opacity .35s var(--ease);
}
#ffl-popup-backdrop.is-visible {
	opacity: 1;
	pointer-events: auto;
}

#ffl-popup-modal {
	position: fixed;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -48%) scale(0.96);
	width: calc(100% - 32px);
	max-width: 560px;
	max-height: calc(100vh - 32px);
	overflow-y: auto;
	background: var(--cream);
	border: 1px solid var(--border);
	border-top: 4px solid var(--wine);
	border-radius: 4px;
	box-shadow: 0 32px 80px rgba(0, 0, 0, 0.32), 0 4px 16px rgba(0, 0, 0, 0.12);
	opacity: 0;
	pointer-events: none;
	z-index: 9999;
	transition: opacity .35s var(--ease), transform .35s var(--ease);
}
#ffl-popup-modal.is-visible {
	opacity: 1;
	pointer-events: auto;
	transform: translate(-50%, -50%) scale(1);
}

.popup-header {
	padding: 36px 40px 20px;
	text-align: left;
	border-bottom: 1px solid var(--border);
}
.popup-eyebrow {
	font-family: var(--sans);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 2.5px;
	text-transform: uppercase;
	color: var(--wine);
	margin: 0 0 12px;
}
.popup-headline {
	font-family: var(--serif);
	font-size: clamp(1.5rem, 3vw, 1.95rem);
	font-weight: 500;
	line-height: 1.2;
	color: var(--ink);
	margin: 0 0 12px;
	letter-spacing: -0.2px;
}
.popup-headline em { color: var(--wine); font-style: italic; }
.popup-subhead {
	font-family: var(--sans);
	font-size: 0.98rem;
	line-height: 1.65;
	color: var(--ink-soft);
	margin: 0;
}

#ffl-popup-close {
	position: absolute;
	top: 14px;
	right: 14px;
	width: 36px;
	height: 36px;
	border: none;
	background: transparent;
	color: var(--ink-muted);
	cursor: pointer;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 22px;
	line-height: 1;
	padding: 0;
	transition: background .25s var(--ease), color .25s var(--ease);
	z-index: 1;
}
#ffl-popup-close:hover {
	background: rgba(137, 46, 83, 0.08);
	color: var(--wine);
}
#ffl-popup-close:focus-visible {
	outline: 2px solid var(--wine);
	outline-offset: 2px;
}

.popup-body {
	padding: 28px 40px 32px;
}

.popup-disclaimer {
	font-size: 0.78rem;
	color: var(--ink-soft);
	line-height: 1.55;
	margin: 18px 0 0;
	padding-top: 16px;
	border-top: 1px solid var(--border-light);
}

@media (max-width: 600px) {
	.popup-header { padding: 28px 24px 16px; }
	.popup-body { padding: 22px 24px 28px; }
	.popup-headline { font-size: 1.35rem; }
	#ffl-popup-modal {
		top: 51%;
	}
}

/* =========================================
2. GRAVITY FORMS — POPUP
Compact light-theme GF form inside the modal.
Hides GF's own heading/title/description — popup-header carries them.
========================================= */

.popup-body .gform_heading,
.popup-body .gform_title,
.popup-body .gform_description,
.popup-body .gform_required_legend { display: none !important; }

.popup-body .gform_wrapper { font-family: var(--sans); }
.popup-body .gform_wrapper form { margin: 0; padding: 0; }

.popup-body .gform_wrapper .gform_fields {
	list-style: none;
	padding: 0;
	margin: 0;
}
.popup-body .gform_wrapper .gform_fields > .gfield {
	grid-column: 1 / -1 !important;
	max-width: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
.popup-body .gform_wrapper .gform_fields > .gfield.ffl-gf-half {
	grid-column: span 6 !important;
}

.popup-body .gfield_label {
	display: block;
	font-family: var(--sans);
	font-size: 0.7rem;
	font-weight: 600;
	letter-spacing: 1.8px;
	text-transform: uppercase;
	color: var(--wine);
	margin-bottom: 6px;
}
.popup-body .gfield_required { color: var(--wine); margin-left: 4px; }

.popup-body .ginput_container input[type="text"],
.popup-body .ginput_container input[type="email"],
.popup-body .ginput_container input[type="tel"],
.popup-body .ginput_container input[type="number"],
.popup-body .ginput_container input[type="url"],
.popup-body .ginput_container select,
.popup-body .ginput_container textarea {
	width: 100%;
	font-family: var(--sans);
	font-size: 0.95rem;
	padding: 11px 14px;
	border: 1px solid var(--border);
	border-radius: 2px;
	background-color: #fff;
	color: var(--ink);
	outline: none;
	appearance: none;
	-webkit-appearance: none;
	box-shadow: none;
	line-height: 1.4;
	height: auto;
	min-height: 44px;
	box-sizing: border-box;
	transition: border-color .25s var(--ease), box-shadow .25s var(--ease);
}
.popup-body .ginput_container select {
	cursor: pointer;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23892e53' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
	background-repeat: no-repeat;
	background-position: right 14px center;
	background-size: 12px 8px;
	padding-right: 38px;
	text-overflow: ellipsis;
	white-space: nowrap;
	overflow: hidden;
}
.popup-body .ginput_container textarea {
	resize: vertical;
	min-height: 80px;
	line-height: 1.55;
}
.popup-body .ginput_container input::placeholder,
.popup-body .ginput_container textarea::placeholder {
	color: var(--ink-muted);
	opacity: 1;
}
.popup-body .ginput_container input:focus,
.popup-body .ginput_container select:focus,
.popup-body .ginput_container textarea:focus {
	border-color: var(--wine);
	box-shadow: 0 0 0 3px rgba(137, 46, 83, 0.12);
}

/* Autofill — kill yellow tint */
.popup-body .ginput_container input:-webkit-autofill {
	-webkit-box-shadow: 0 0 0 100px #fff inset !important;
	-webkit-text-fill-color: var(--ink) !important;
	caret-color: var(--ink);
}

/* Submit — full width wine */
.popup-body .gform_footer,
.popup-body .gform-footer {
	display: block !important;
	margin-top: 12px !important;
	padding: 0 !important;
}
.popup-body button[type="submit"],
.popup-body input[type="submit"],
.popup-body .gform_button {
	display: block !important;
	width: 100% !important;
	background: var(--wine) !important;
	color: #fff !important;
	font-family: var(--sans) !important;
	font-size: 12px !important;
	font-weight: 600 !important;
	letter-spacing: 2.5px !important;
	text-transform: uppercase !important;
	padding: 16px 20px !important;
	border: none !important;
	border-radius: 2px !important;
	cursor: pointer !important;
	transition: background .25s, transform .25s, box-shadow .25s !important;
	appearance: none !important;
	-webkit-appearance: none !important;
}
.popup-body button[type="submit"]:hover,
.popup-body input[type="submit"]:hover,
.popup-body .gform_button:hover {
	background: var(--wine-deep) !important;
	transform: translateY(-1px);
	box-shadow: 0 12px 32px rgba(137, 46, 83, 0.24) !important;
}

.popup-body .gform_validation_container,
.popup-body .gfield_visibility_hidden { display: none !important; }
.popup-body .gform_confirmation_message,
.popup-body .gform_confirmation_wrapper {
	font-size: 1rem;
	color: var(--ink);
	line-height: 1.7;
}

/* =========================================
DARK MODE — popup
========================================= */
[data-theme="dark"] #ffl-popup-modal {
	background: #111f2e;
	border-color: #1e3549;
	border-top-color: var(--wine);
	box-shadow: 0 32px 80px rgba(0, 0, 0, 0.6), 0 4px 16px rgba(0, 0, 0, 0.3);
}
[data-theme="dark"] .popup-header { border-bottom-color: #1e3549; }
[data-theme="dark"] .popup-headline { color: #e8f0f5; }
[data-theme="dark"] .popup-subhead { color: #b8cbd6; }
[data-theme="dark"] .popup-disclaimer { color: #b8cbd6; border-top-color: #1e3549; }
[data-theme="dark"] #ffl-popup-close { color: #7a9aac; }
[data-theme="dark"] #ffl-popup-close:hover { background: rgba(137, 46, 83, 0.18); color: #e8b6c6; }

[data-theme="dark"] .popup-body .gfield_label { color: #d99fb5; }
[data-theme="dark"] .popup-body .ginput_container input[type="text"],
[data-theme="dark"] .popup-body .ginput_container input[type="email"],
[data-theme="dark"] .popup-body .ginput_container input[type="tel"],
[data-theme="dark"] .popup-body .ginput_container input[type="number"],
[data-theme="dark"] .popup-body .ginput_container input[type="url"],
[data-theme="dark"] .popup-body .ginput_container select,
[data-theme="dark"] .popup-body .ginput_container textarea {
	background-color: #0a1520;
	border-color: #1e3549;
	color: #e8f0f5;
}
[data-theme="dark"] .popup-body .ginput_container input::placeholder,
[data-theme="dark"] .popup-body .ginput_container textarea::placeholder { color: #7a9aac; }
[data-theme="dark"] .popup-body .ginput_container select option { background-color: #0a1520; color: #e8f0f5; }
[data-theme="dark"] .popup-body .ginput_container select {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%23d99fb5' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}
[data-theme="dark"] .popup-body .ginput_container input:-webkit-autofill {
	-webkit-box-shadow: 0 0 0 100px #0a1520 inset !important;
	-webkit-text-fill-color: #e8f0f5 !important;
	caret-color: #e8f0f5;
}
