/* Promatch Inscripciones — frontend modal styles.
 * Branding: azul oscuro #071529 + verde lima #C4FF00 + blanco.
 * Sin emojis, Font Awesome para íconos.
 *
 * IMPORTANTE: todos los selectores van scopeados bajo #pmfi-modal-root para
 * blindar contra estilos heredados de Elementor/Jeg Kit/Hello Elementor theme.
 * Donde el tema pinta con alta especificidad, usamos !important.
 */

#pmfi-modal-root {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 16px;
	box-sizing: border-box;
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif !important;
}
#pmfi-modal-root.pmfi-hidden { display: none !important; }
#pmfi-modal-root *,
#pmfi-modal-root *::before,
#pmfi-modal-root *::after {
	box-sizing: border-box !important;
	font-family: inherit !important;
	text-transform: none !important;
	letter-spacing: normal !important;
	font-weight: normal;
	max-width: 100%;
	overflow-wrap: anywhere;
	word-break: normal;
}

/* RESET de botones e inputs (Elementor/Jeg los pinta con fucsia, gradient, etc) */
#pmfi-modal-root button,
#pmfi-modal-root input,
#pmfi-modal-root select,
#pmfi-modal-root textarea {
	background: transparent;
	background-image: none !important;
	color: inherit;
	font: inherit;
	border: none;
	outline: none;
	box-shadow: none !important;
	margin: 0;
	text-align: left;
	text-shadow: none !important;
	letter-spacing: normal !important;
}
#pmfi-modal-root button { cursor: pointer; }
#pmfi-modal-root a { color: inherit; text-decoration: none; box-shadow: none !important; }

.pmfi-overlay {
	position: absolute;
	inset: 0;
	background: rgba(7, 21, 41, 0.78);
	backdrop-filter: blur(6px);
	-webkit-backdrop-filter: blur(6px);
	animation: pmfi-fade-in 0.2s ease-out;
}

.pmfi-modal {
	position: relative;
	background: #ffffff !important;
	color: #001213 !important;
	border-radius: 14px;
	width: 100%;
	max-width: 640px;
	max-height: 92vh;
	display: flex;
	flex-direction: column;
	overflow: hidden;
	box-shadow: 0 20px 60px rgba(0,0,0,0.45);
	animation: pmfi-pop-in 0.25s cubic-bezier(0.2, 0.9, 0.3, 1.2);
}

@keyframes pmfi-fade-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes pmfi-pop-in  { from { opacity: 0; transform: scale(0.92) translateY(20px); } to { opacity: 1; transform: scale(1) translateY(0); } }

#pmfi-modal-root .pmfi-close {
	position: absolute;
	top: 16px;
	right: 16px;
	width: 36px;
	height: 36px;
	border-radius: 50% !important;
	border: none;
	background: rgba(255,255,255,0.15) !important;
	color: #ffffff !important;
	cursor: pointer;
	font-size: 16px !important;
	line-height: 1 !important;
	z-index: 5;
	transition: background 0.15s;
	padding: 0 !important;
	display: flex;
	align-items: center;
	justify-content: center;
}
#pmfi-modal-root .pmfi-close:hover { background: rgba(255,255,255,0.3) !important; }

#pmfi-modal-root .pmfi-modal__header {
	background: #071529 !important;
	color: #ffffff !important;
	padding: 24px 28px 18px;
}
#pmfi-modal-root .pmfi-brand { display: flex; align-items: baseline; gap: 10px; }
#pmfi-modal-root .pmfi-brand__mark {
	font-weight: 800 !important;
	letter-spacing: 2px !important;
	color: #C4FF00 !important;
	font-size: 18px !important;
}
#pmfi-modal-root .pmfi-brand__sub {
	font-size: 13px !important;
	color: #ffffff !important;
	opacity: 0.75;
	letter-spacing: 0.5px !important;
}
#pmfi-modal-root .pmfi-progress {
	margin-top: 16px;
	height: 4px;
	background: rgba(255,255,255,0.12);
	border-radius: 4px;
	overflow: hidden;
}
#pmfi-modal-root .pmfi-progress__bar {
	height: 100%;
	background: #C4FF00 !important;
	transition: width 0.35s ease-out;
	border-radius: 4px;
}

#pmfi-modal-root .pmfi-modal__body {
	padding: 28px;
	overflow-y: auto;
	overflow-x: hidden;
	flex: 1 1 auto;
	min-height: 0;
}

/* Headings dentro del modal */
#pmfi-modal-root .pmfi-step__title {
	margin: 0 0 6px !important;
	font-size: 22px !important;
	font-weight: 700 !important;
	color: #071529 !important;
	line-height: 1.25 !important;
	font-style: normal !important;
}
#pmfi-modal-root .pmfi-step__subtitle {
	margin: 0 0 22px !important;
	color: #3B4547 !important;
	font-size: 14px !important;
	line-height: 1.5 !important;
}

/* Cards de servicio */
#pmfi-modal-root .pmfi-service-grid {
	display: grid;
	gap: 12px;
}
#pmfi-modal-root .pmfi-service-card {
	display: flex !important;
	align-items: flex-start !important;
	gap: 14px;
	background: #ffffff !important;
	border: 2px solid #e7ebf0 !important;
	border-radius: 10px !important;
	padding: 16px 18px !important;
	cursor: pointer;
	transition: border-color 0.15s, background 0.15s, transform 0.1s;
	text-align: left !important;
	width: 100% !important;
	min-width: 0 !important;
	color: #001213 !important;
}
#pmfi-modal-root .pmfi-service-card:hover {
	border-color: #C4FF00 !important;
	background: #fafbf0 !important;
}
#pmfi-modal-root .pmfi-service-card.is-selected {
	border-color: #C4FF00 !important;
	background: #f5fce0 !important;
}
#pmfi-modal-root .pmfi-service-card__icon {
	flex: 0 0 44px !important;
	width: 44px !important;
	height: 44px !important;
	border-radius: 50% !important;
	background: #071529 !important;
	color: #C4FF00 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 20px !important;
	line-height: 1 !important;
}
#pmfi-modal-root .pmfi-service-card__icon i { color: #C4FF00 !important; font-size: 20px !important; line-height: 1 !important; }
#pmfi-modal-root .pmfi-service-card__body { flex: 1 1 auto !important; min-width: 0 !important; }
#pmfi-modal-root .pmfi-service-card__title {
	display: block !important;
	font-weight: 700 !important;
	color: #071529 !important;
	font-size: 16px !important;
	margin-bottom: 4px !important;
}
#pmfi-modal-root .pmfi-service-card__desc {
	display: block !important;
	color: #3B4547 !important;
	font-size: 13px !important;
	line-height: 1.4 !important;
	margin-bottom: 6px !important;
}
#pmfi-modal-root .pmfi-service-card__price {
	display: inline-block !important;
	background: #071529 !important;
	color: #C4FF00 !important;
	font-size: 12px !important;
	padding: 3px 10px !important;
	border-radius: 12px !important;
	font-weight: 600 !important;
	letter-spacing: 0.3px !important;
}

/* Radios grandes (paso edad) */
#pmfi-modal-root .pmfi-radio-group { display: grid; gap: 10px; }
#pmfi-modal-root .pmfi-radio-card {
	display: flex !important;
	align-items: center !important;
	gap: 14px !important;
	padding: 16px 18px !important;
	border: 2px solid #e7ebf0 !important;
	border-radius: 10px !important;
	cursor: pointer;
	background: #ffffff !important;
	transition: border-color 0.15s, background 0.15s;
	color: #001213 !important;
}
#pmfi-modal-root .pmfi-radio-card:hover { border-color: #C4FF00 !important; background: #fafbf0 !important; }
#pmfi-modal-root .pmfi-radio-card input {
	margin: 0 !important;
	accent-color: #071529 !important;
	transform: scale(1.3);
	width: auto !important;
}
#pmfi-modal-root .pmfi-radio-card.is-selected { border-color: #C4FF00 !important; background: #f5fce0 !important; }
#pmfi-modal-root .pmfi-radio-card__label { font-weight: 600 !important; color: #071529 !important; font-size: 14px !important; }

/* Formulario inputs */
#pmfi-modal-root .pmfi-field { margin-bottom: 16px; }
#pmfi-modal-root .pmfi-field__label {
	display: block !important;
	font-weight: 600 !important;
	color: #071529 !important;
	font-size: 13px !important;
	margin-bottom: 6px !important;
}
#pmfi-modal-root .pmfi-field__label .pmfi-required { color: #d6312e !important; }
#pmfi-modal-root .pmfi-field__input,
#pmfi-modal-root .pmfi-field__select,
#pmfi-modal-root .pmfi-field__textarea {
	width: 100% !important;
	padding: 10px 12px !important;
	border: 1.5px solid #e7ebf0 !important;
	border-radius: 6px !important;
	font-size: 14px !important;
	color: #001213 !important;
	background: #ffffff !important;
	font-family: inherit !important;
	transition: border-color 0.12s;
	height: auto !important;
	min-height: 0 !important;
	box-shadow: none !important;
}
#pmfi-modal-root .pmfi-field__input:focus,
#pmfi-modal-root .pmfi-field__select:focus,
#pmfi-modal-root .pmfi-field__textarea:focus {
	outline: none;
	border-color: #C4FF00 !important;
	box-shadow: 0 0 0 3px rgba(196, 255, 0, 0.25) !important;
}
#pmfi-modal-root .pmfi-field__textarea { min-height: 70px !important; resize: vertical; }
#pmfi-modal-root .pmfi-field__error {
	color: #d6312e !important;
	font-size: 12px !important;
	margin-top: 4px !important;
	min-height: 16px;
}
#pmfi-modal-root .pmfi-field.has-error .pmfi-field__input,
#pmfi-modal-root .pmfi-field.has-error .pmfi-field__select,
#pmfi-modal-root .pmfi-field.has-error .pmfi-field__textarea { border-color: #d6312e !important; }

#pmfi-modal-root .pmfi-checkbox-group { display: flex; flex-wrap: wrap; gap: 10px; }
#pmfi-modal-root .pmfi-checkbox-group label {
	display: inline-flex !important;
	align-items: center !important;
	gap: 6px !important;
	padding: 8px 12px !important;
	border: 1.5px solid #e7ebf0 !important;
	border-radius: 20px !important;
	font-size: 13px !important;
	cursor: pointer;
	background: #ffffff !important;
	color: #001213 !important;
	transition: border-color 0.12s, background 0.12s;
	margin: 0 !important;
}
#pmfi-modal-root .pmfi-checkbox-group label:has(input:checked) { background: #f5fce0 !important; border-color: #C4FF00 !important; }
#pmfi-modal-root .pmfi-checkbox-group input { margin: 0 !important; accent-color: #071529 !important; width: auto !important; }

#pmfi-modal-root .pmfi-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 540px) { #pmfi-modal-root .pmfi-row { grid-template-columns: 1fr; } }

/* Honeypot oculto */
#pmfi-modal-root .pmfi-honeypot {
	position: absolute !important;
	left: -9999px !important;
	width: 1px !important;
	height: 1px !important;
	opacity: 0 !important;
	pointer-events: none !important;
}

/* Privacy checkbox final */
#pmfi-modal-root .pmfi-privacy {
	background: #f9fafb !important;
	border-left: 3px solid #C4FF00 !important;
	padding: 14px 16px !important;
	border-radius: 6px !important;
	margin: 14px 0 18px !important;
}
#pmfi-modal-root .pmfi-privacy label {
	display: flex !important;
	gap: 10px !important;
	align-items: flex-start !important;
	cursor: pointer;
	margin: 0 !important;
}
#pmfi-modal-root .pmfi-privacy input { margin-top: 3px !important; accent-color: #071529 !important; transform: scale(1.15); width: auto !important; }
#pmfi-modal-root .pmfi-privacy__text { font-size: 13px !important; color: #3B4547 !important; line-height: 1.5 !important; }
#pmfi-modal-root .pmfi-privacy__text a { color: #071529 !important; text-decoration: underline !important; }

/* Footer botones */
#pmfi-modal-root .pmfi-footer {
	display: flex !important;
	gap: 10px !important;
	justify-content: space-between;
	margin-top: 24px !important;
	padding-top: 18px !important;
	border-top: 1px solid #e7ebf0 !important;
}
#pmfi-modal-root .pmfi-btn {
	flex: 1 1 auto !important;
	padding: 12px 24px !important;
	border: none !important;
	border-radius: 30px !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	cursor: pointer;
	letter-spacing: 0.4px !important;
	transition: transform 0.08s, box-shadow 0.15s, background 0.15s !important;
	font-family: inherit !important;
	text-align: center !important;
	text-transform: none !important;
	line-height: 1.2 !important;
	min-height: 0 !important;
	height: auto !important;
	box-shadow: none !important;
	background-image: none !important;
	width: auto !important;
}
#pmfi-modal-root .pmfi-btn:disabled { opacity: 0.4 !important; cursor: not-allowed; }
#pmfi-modal-root .pmfi-btn--primary {
	background: #C4FF00 !important;
	background-color: #C4FF00 !important;
	color: #071529 !important;
}
#pmfi-modal-root .pmfi-btn--primary:hover:not(:disabled) {
	background: #d4ff33 !important;
	background-color: #d4ff33 !important;
	box-shadow: 0 4px 14px rgba(196,255,0,0.45) !important;
}
#pmfi-modal-root .pmfi-btn--primary:active:not(:disabled) { transform: translateY(1px); }
#pmfi-modal-root .pmfi-btn--secondary {
	background: #ffffff !important;
	color: #071529 !important;
	border: 1.5px solid #e7ebf0 !important;
}
#pmfi-modal-root .pmfi-btn--secondary:hover:not(:disabled) { border-color: #071529 !important; background: #f9fafb !important; }

/* Mensaje de éxito final */
#pmfi-modal-root .pmfi-success {
	text-align: center !important;
	padding: 20px 0 !important;
}
#pmfi-modal-root .pmfi-success__icon {
	width: 80px !important;
	height: 80px !important;
	margin: 0 auto 16px !important;
	border-radius: 50% !important;
	background: #C4FF00 !important;
	color: #071529 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	font-size: 36px !important;
}
#pmfi-modal-root .pmfi-success__title {
	color: #071529 !important;
	font-size: 24px !important;
	font-weight: 700 !important;
	margin: 0 0 10px !important;
}
#pmfi-modal-root .pmfi-success__msg {
	color: #3B4547 !important;
	font-size: 14px !important;
	line-height: 1.6 !important;
	max-width: 460px !important;
	margin: 0 auto 20px !important;
}

/* Error global */
#pmfi-modal-root .pmfi-global-error {
	background: #fdecea !important;
	color: #b71c1c !important;
	border-left: 3px solid #d6312e !important;
	padding: 10px 14px !important;
	border-radius: 6px !important;
	font-size: 13px !important;
	margin-bottom: 14px !important;
}

/* Mobile tweaks */
@media (max-width: 540px) {
	#pmfi-modal-root { padding: 0 !important; }
	#pmfi-modal-root .pmfi-modal { max-width: 100% !important; max-height: 100vh !important; height: 100vh; border-radius: 0 !important; }
	#pmfi-modal-root .pmfi-modal__header { padding: 18px 20px 14px !important; }
	#pmfi-modal-root .pmfi-modal__body { padding: 20px !important; }
	#pmfi-modal-root .pmfi-step__title { font-size: 20px !important; }
	#pmfi-modal-root .pmfi-service-card { padding: 12px 14px !important; }
	#pmfi-modal-root .pmfi-service-card__icon { width: 38px !important; height: 38px !important; font-size: 16px !important; flex-basis: 38px !important; }
	#pmfi-modal-root .pmfi-footer { flex-direction: column-reverse !important; }
	#pmfi-modal-root .pmfi-btn { width: 100% !important; }
}
