/* Smart Access Gate — front-end popup.
   Every rule is scoped under #sag-overlay (an ID, specificity 1,0,0) so theme
   styles (WoodMart etc., which use class selectors) cannot override the popup.
   A reset block neutralises inherited form-control styling. The popup's own
   styles are fully self-contained and never affect the rest of the site. */

/* ============================ RESET (isolation) ============================ */
#sag-overlay,
#sag-overlay *,
#sag-overlay *::before,
#sag-overlay *::after { box-sizing: border-box; }

#sag-overlay a,
#sag-overlay p,
#sag-overlay h2,
#sag-overlay span,
#sag-overlay div,
#sag-overlay label,
#sag-overlay input,
#sag-overlay button {
	margin: 0;
	padding: 0;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
	font-weight: 400;
	color: var(--sag-text, #1f2937);
	line-height: normal;
	letter-spacing: normal;
	text-transform: none;
	text-align: left;
	text-shadow: none;
	float: none;
	max-width: none;
}

/* Form-control reset — kill theme borders, backgrounds, shadows, sizing. */
#sag-overlay input,
#sag-overlay button {
	font-size: 100%;
	border: 0 !important;
	border-radius: 0;
	background: transparent !important;
	box-shadow: none !important;
	outline: none;
	width: auto;
	height: auto;
	min-height: 0 !important;
	min-width: 0;
	transition: none;
	vertical-align: baseline;
	-webkit-text-fill-color: currentColor; /* stop theme fill-color from hiding typed text */
	caret-color: auto;
	opacity: 1;
}
#sag-overlay input:not([type="checkbox"]):not([type="radio"]) {
	-webkit-appearance: none;
	appearance: none;
}
#sag-overlay input[type="checkbox"],
#sag-overlay input[type="radio"] {
	-webkit-appearance: auto;
	appearance: auto;
}
#sag-overlay button { cursor: pointer; }
#sag-overlay a { text-decoration: none; box-shadow: none; }
#sag-overlay a:hover { color: var(--sag-accent, #c8862b); }
#sag-overlay img { max-width: 100%; height: auto; border: 0; }
#sag-overlay svg { display: block; }

/* ============================ OVERLAY ============================ */
#sag-overlay.sag-overlay {
	position: fixed;
	inset: 0;
	z-index: 2147483000;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
	margin: 0;
	overflow-y: auto;
	background: var(--sag-overlay, rgba(10, 15, 25, 0.6));
	/* No backdrop-filter: it causes inputs inside the overlay to stop repainting
	   (text vanishes after scroll/animation/idle) and adds scroll lag on the GPU. */
}

#sag-overlay .sag-modal {
	position: relative;
	display: flex;
	width: 100%;
	max-width: var(--sag-maxw, 880px);
	max-height: 94vh;
	margin: auto;
	background: var(--sag-bg, #fff);
	border-radius: var(--sag-radius, 18px);
	box-shadow: 0 30px 80px rgba(0, 0, 0, 0.35);
	overflow: hidden;
	isolation: isolate;
	animation: sag-pop 0.2s ease-out both;
}
#sag-overlay .sag-modal.sag-side-right { flex-direction: row-reverse; }
#sag-overlay .sag-modal.no-brand { max-width: 440px; }

@keyframes sag-pop {
	from { transform: translateY(10px) scale(0.985); opacity: 0; }
	to   { transform: translateY(0) scale(1); opacity: 1; }
}

/* ============================ BRANDING PANEL ============================ */
#sag-overlay .sag-brand {
	flex: 0 0 42%;
	background-color: var(--sag-brand-bg, #f2ece4);
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 36px 28px;
}
#sag-overlay .sag-brand-inner { text-align: center; max-width: 280px; }
#sag-overlay .sag-logo { max-width: 120px; max-height: 120px; margin: 0 auto 18px; display: block; }
#sag-overlay .sag-brand-name {
	font-size: 26px;
	line-height: 1.15;
	font-weight: 800;
	letter-spacing: 0.04em;
	color: var(--sag-primary, #16263f);
	text-transform: uppercase;
}
#sag-overlay .sag-brand-rule { display: block; width: 64px; height: 2px; background: var(--sag-accent, #c8862b); margin: 16px auto; }
#sag-overlay .sag-tagline { font-size: 15px; line-height: 1.5; color: var(--sag-primary, #16263f); opacity: 0.85; }

/* ============================ FORM PANEL ============================ */
#sag-overlay .sag-panel { flex: 1 1 auto; min-width: 0; padding: 40px 40px 34px; overflow-y: auto; }

#sag-overlay .sag-close {
	position: absolute;
	top: 16px;
	right: 18px;
	width: 34px;
	height: 34px !important;
	padding: 5px;
	color: var(--sag-text, #1f2937);
	opacity: 0.5;
}
#sag-overlay .sag-close:hover { opacity: 1; }
#sag-overlay .sag-close svg { width: 100%; height: 100%; }

#sag-overlay .sag-header { text-align: center; margin-bottom: 22px; }
#sag-overlay .sag-title { margin: 0 0 8px; font-size: 32px; line-height: 1.1; font-weight: 700; color: var(--sag-primary, #16263f); text-align: center; }
#sag-overlay .sag-title--serif { font-family: Georgia, "Times New Roman", serif; }
#sag-overlay .sag-title--sans { letter-spacing: -0.01em; }
#sag-overlay .sag-subtitle { font-size: 15px; line-height: 1.45; color: var(--sag-text, #1f2937); opacity: 0.7; text-align: center; }

/* ---- Tabs ---- */
#sag-overlay .sag-tabs { display: flex; gap: 8px; background: #f1f2f4; padding: 6px; border-radius: 12px; margin-bottom: 22px; }
#sag-overlay .sag-tab {
	flex: 1;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 8px;
	height: auto !important;
	padding: 12px 0 !important;
	border-radius: 8px !important;
	font-size: 14px;
	font-weight: 700;
	letter-spacing: 0.05em;
	text-transform: uppercase !important;
	color: #6b7280;
	background: transparent !important;
	box-shadow: none !important;
}
#sag-overlay .sag-tab .sag-tab-ic svg { width: 18px; height: 18px; }
#sag-overlay .sag-tab .sag-tab-ic { display: inline-flex; }
#sag-overlay .sag-tab.is-active { background: var(--sag-primary, #16263f) !important; color: #fff !important; box-shadow: 0 6px 16px rgba(var(--sag-primary-rgb, 22, 38, 63), 0.3) !important; }
#sag-overlay .sag-tab.is-active .sag-tab-ic { color: var(--sag-accent, #c8862b); }

/* ---- Forms & fields ---- */
#sag-overlay .sag-form { display: none; flex-direction: column; gap: 16px; }
#sag-overlay .sag-form.is-active { display: flex; }

#sag-overlay .sag-field { display: flex; flex-direction: column; gap: 7px; }
#sag-overlay .sag-label { font-size: 14px; font-weight: 700; color: var(--sag-primary, #16263f); text-align: left; }

#sag-overlay .sag-input {
	position: relative;
	display: flex;
	align-items: center;
	border: 1px solid var(--sag-border, #d9dde3);
	border-radius: 999px;
	background: #fff;
	transition: border-color 0.15s, box-shadow 0.15s;
}
#sag-overlay .sag-input:focus-within {
	border-color: var(--sag-accent, #c8862b);
	box-shadow: 0 0 0 3px rgba(var(--sag-accent-rgb, 200, 134, 43), 0.18);
}
#sag-overlay .sag-input-ic { display: flex; align-items: center; padding-left: 16px; color: #9aa1ab; }
#sag-overlay .sag-input-ic svg { width: 20px; height: 20px; }
#sag-overlay .sag-input input {
	flex: 1 1 auto;
	width: 100%;
	position: relative;
	z-index: 1;
	height: auto !important;
	padding: 14px !important;
	font-size: 15px !important;
	color: #1f2433 !important;
	-webkit-text-fill-color: #1f2433 !important; /* visible text on WebKit/mobile */
	caret-color: #1f2433 !important;
	opacity: 1 !important;
	background: transparent !important;
	border: 0 !important;
	border-radius: 999px !important;
}
#sag-overlay .sag-input input::placeholder { color: #aab0b9; -webkit-text-fill-color: #aab0b9; opacity: 1; }
/* keep autofilled text legible and stop the yellow box from masking it */
#sag-overlay .sag-input input:-webkit-autofill,
#sag-overlay .sag-input input:-webkit-autofill:hover,
#sag-overlay .sag-input input:-webkit-autofill:focus {
	-webkit-text-fill-color: #1f2433 !important;
	caret-color: #1f2433 !important;
	transition: background-color 100000s ease-in-out 0s;
}
#sag-overlay .sag-input input[type="date"] { padding-right: 12px !important; }
#sag-overlay .sag-eye { color: #9aa1ab; padding: 0 16px 0 6px !important; height: auto !important; display: flex; align-items: center; background: transparent !important; }
#sag-overlay .sag-eye svg { width: 20px; height: 20px; }
#sag-overlay .sag-eye.is-on { color: var(--sag-accent, #c8862b); }

#sag-overlay .sag-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; font-size: 14px; }
#sag-overlay .sag-checkbox { display: inline-flex; align-items: center; gap: 9px; color: var(--sag-text); font-size: 14px; }
#sag-overlay .sag-checkbox input { width: 18px !important; height: 18px !important; margin: 0; accent-color: var(--sag-primary, #16263f); }

#sag-overlay .sag-link-accent {
	color: var(--sag-accent, #c8862b) !important;
	font-weight: 600;
	font-size: inherit;
	background: transparent !important;
	height: auto !important;
	padding: 0 !important;
}
#sag-overlay .sag-link-accent:hover { text-decoration: underline; }

#sag-overlay .sag-submit {
	width: 100%;
	margin-top: 4px;
	padding: 15px !important;
	background: var(--sag-primary, #16263f) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 999px !important;
	box-shadow: none !important;
	font-size: 15px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase !important;
	transition: filter 0.15s, transform 0.05s;
	line-height: 1.3;
}
#sag-overlay .sag-submit:hover { filter: brightness(1.12); }
#sag-overlay .sag-submit:active { transform: translateY(1px); }
#sag-overlay .sag-submit:disabled { opacity: 0.65; cursor: default; }

#sag-overlay .sag-or { display: flex; align-items: center; text-align: center; color: #9aa1ab; font-size: 13px; margin: 4px 0; }
#sag-overlay .sag-or::before, #sag-overlay .sag-or::after { content: ""; flex: 1; height: 1px; background: #e5e7eb; }
#sag-overlay .sag-or span { padding: 0 14px; }
#sag-overlay .sag-switch { text-align: center; font-size: 14px; color: var(--sag-text); opacity: 0.85; }

#sag-overlay .sag-recaptcha { margin: 2px 0; display: flex; justify-content: center; }

#sag-overlay .sag-message { font-size: 14px; margin-bottom: 14px; text-align: left; }
#sag-overlay .sag-message:empty { margin-bottom: 0; }
#sag-overlay .sag-message.is-error { color: #b91c1c; }
#sag-overlay .sag-message.is-success { color: #15803d; }

#sag-overlay .sag-hp { position: absolute !important; left: -9999px !important; width: 1px !important; height: 1px !important; opacity: 0; }

/* scroll-lock helper (global, intentional) */
body.sag-no-scroll { overflow: hidden !important; }

/* ============================ RESPONSIVE ============================ */
@media (max-width: 720px) {
	#sag-overlay .sag-modal,
	#sag-overlay .sag-modal.sag-side-right { flex-direction: column; max-width: 460px; }
	#sag-overlay .sag-brand { flex: 0 0 auto; padding: 26px 24px 22px; }
	#sag-overlay .sag-brand-inner { max-width: none; }
	#sag-overlay .sag-logo { max-width: 76px; max-height: 76px; margin-bottom: 10px; }
	#sag-overlay .sag-brand-name { font-size: 20px; }
	#sag-overlay .sag-brand-rule { margin: 12px auto; }
	#sag-overlay .sag-tagline { display: none; }
	#sag-overlay .sag-panel { padding: 26px 22px 24px; }
	#sag-overlay .sag-title { font-size: 26px; }
}

@media (max-width: 420px) {
	#sag-overlay.sag-overlay { padding: 0; align-items: stretch; }
	#sag-overlay .sag-modal { max-height: 100vh; border-radius: 0; }
	#sag-overlay .sag-brand { padding: 22px 20px 18px; }
	#sag-overlay .sag-panel { padding: 22px 18px 22px; }
}
