/* ======================================================
   REGISTRATE — Tienda Inglesa Panel Online
   ====================================================== */

html,
body {
	background: #ffffff;
	font-family: 'Inter', sans-serif;
}

/* ======================================================
   SECTION TITLE — igual al resto del sitio
   ====================================================== */

.sc_registrate {
	background:
		radial-gradient(circle at 82% 50%, rgba(0, 71, 149, 0.06) 0, rgba(0, 71, 149, 0) 34%),
		linear-gradient(180deg, #F7F9FC 0%, #ffffff 100%);
	border-bottom: 1px solid #EEF1F5;
}

.sc_registrate > .inner_section_container {
	width: 100%;
	max-width: 1180px;
	margin: 0 auto;
	padding: 48px 40px;
	box-sizing: border-box;
}

.sc_registrate .section_title {
	display: flex !important;
	align-items: center;
	justify-content: flex-start;
	margin: 0;
	padding: 0;
}

.sc_registrate .stc_title_side {
	display: flex !important;
	align-items: center;
	padding: 0 !important;
}

.sc_registrate .stc_image_side {
	display: none !important;
}

.sc_registrate img.st_icon {
	width: 42px;
	height: auto;
	margin: 0 14px 0 0;
	opacity: 0.14;
	filter: grayscale(1);
}

.sc_registrate img.st_left_arrow {
	display: none !important;
}

.sc_registrate p.st_title_box {
	margin: 0;
	padding: 0;
	background: transparent;
	border-radius: 0;
	font-family: 'Inter', sans-serif;
	font-size: 44px;
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: -1.2px;
	color: #004795;
}

.sc_registrate p.st_title_box::after {
	content: "";
	display: block;
	width: 68px;
	height: 4px;
	margin: 22px 0 0 0;
	background: #F6323E;
	border-radius: 999px;
}

/* ======================================================
   CONTENT
   ====================================================== */

.sc_registrate + .section_container {
	background:
		radial-gradient(circle at 82% 45%, rgba(0, 71, 149, 0.05) 0, rgba(0, 71, 149, 0) 34%),
		linear-gradient(180deg, #ffffff 0%, #F7F9FC 100%);
}

.sc_registrate + .section_container > .inner_section_container {
	width: 100%;
	max-width: 980px;
	margin: 0 auto;
	padding: 42px 32px 64px 32px;
	box-sizing: border-box;
}

/* Intro */
.registrate_text {
	max-width: 820px;
	margin: 0 0 38px 0;
	padding: 0;
	font-family: 'Inter', sans-serif;
	font-size: 17px;
	font-weight: 400;
	line-height: 1.7;
	color: #4B5563;
}

.registrate_text span {
	display: inline-block;
	margin-top: 4px;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 800;
	color: #004795;
}

.registrate_text a {
	font-family: 'Inter', sans-serif !important;
	font-size: 17px !important;
	font-weight: 800 !important;
	color: #004795 !important;
	text-decoration: none !important;
	border-bottom: 2px solid rgba(246, 50, 62, 0.55);
}

.registrate_text a:hover {
	color: #F6323E !important;
	border-color: #F6323E;
}

/* ======================================================
   LAYOUT PRINCIPAL
   Form izquierda / items derecha
   ====================================================== */

.st_register {
	display: grid !important;
	grid-template-columns: 520px 1fr;
	gap: 56px;
	align-items: center;
	width: 100%;
	margin: 0;
	padding: 0;
}

.st_register > .st_cell {
	width: 100% !important;
}

/* Cambia orden visual sin tocar PHP */
.st_register .st_right_side {
	grid-column: 1;
	grid-row: 1;
}

.st_register .st_left_side {
	grid-column: 2;
	grid-row: 1;
}

/* ======================================================
   FORM CARD — izquierda
   ====================================================== */

.st_register .st_right_side {
	display: block !important;
	width: 100% !important;
	padding: 0 !important;
	background: transparent;
}

.register_form {
	width: 100%;
	margin: 0;
	padding: 40px;
	background: #ffffff;
	border: 1px solid #E5EAF1;
	border-radius: 18px;
	box-shadow: 0 18px 48px rgba(0, 71, 149, 0.09);
	box-sizing: border-box;
}

/* Error */
.register_form .div_error {
	margin: 0 0 22px 0 !important;
	padding: 14px 16px;
	background: #FFF1F2;
	border: 1px solid rgba(246, 50, 62, 0.28) !important;
	border-radius: 12px;
}

.register_form .div_error p {
	margin: 0;
	font-family: 'Inter', sans-serif;
	font-size: 14px;
	font-weight: 700;
	color: #D92B35 !important;
	text-transform: none;
	letter-spacing: 0;
}

/* Campos */
.register_form .form_group {
	position: relative;
	margin: 0 0 20px 0;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	gap: 7px;
}

.register_form p {
	margin: 0;
	padding: 0;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 800;
	line-height: 1;
	letter-spacing: 0.7px;
	text-transform: uppercase;
	color: #004795;
	text-align: left !important;
}

.register_form input,
.register_form select {
	display: block !important;
	width: 100% !important;
	max-width: none !important;
	height: 48px;
	margin: 0 !important;
	padding: 0 16px;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 400;
	color: #111827;
	background: #ffffff;
	border: 1px solid #DDE3EC;
	border-radius: 10px;
	outline: none;
	box-sizing: border-box;
	transition: border-color .2s ease, box-shadow .2s ease, background-color .2s ease;
}

.register_form input:focus,
.register_form select:focus {
	border-color: #004795;
	box-shadow: 0 0 0 4px rgba(0, 71, 149, 0.10);
	background: #ffffff;
}

.register_form input.valid {
	border-color: #22C55E;
}

.register_form input.invalid,
.register_form input.error {
	border-color: #F6323E;
	background: #FFF8F8;
}

/* Spinners */
.register_form .css-spinner {
	position: absolute;
	right: 12px;
	top: 31px;
}

/* Captcha */
.register_form .form_security_code {
	margin: 0 0 22px 0;
	display: grid;
	grid-template-columns: 1fr 112px;
	grid-template-areas:
		"label label"
		"input captcha";
	gap: 10px;
	width: 100%;
	height: auto;
	overflow: visible;
}

.register_form .form_security_code .fsc_fix {
	grid-area: label;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
	width: 100%;
}

.register_form .form_security_code .fsc_fix p {
	width: 100%;
	text-align: left !important;
}

.register_form .form_security_code input[type="text"] {
	grid-area: input;
	width: 100% !important;
	max-width: none !important;
}

.register_form .form_security_code img.captcha {
	grid-area: captcha;
	width: 112px;
	height: 48px !important;
	margin: 0 !important;
	object-fit: cover;
	border: 1px solid #DDE3EC;
	border-radius: 10px;
}

/* Botón */
.register_form center {
	display: block;
	text-align: left;
}

.register_form button {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 48px;
	margin: 0;
	padding: 0 24px;
	border: none;
	border-radius: 10px;
	background: #F6323E;
	color: #ffffff;
	font-family: 'Inter', sans-serif;
	font-size: 15px;
	font-weight: 800;
	line-height: 1;
	cursor: pointer;
	box-shadow: 0 10px 24px rgba(246, 50, 62, 0.26);
	transition: background-color .2s ease, transform .2s ease, box-shadow .2s ease;
}

.register_form button:hover {
	background: #D92B35;
	transform: translateY(-1px);
	box-shadow: 0 14px 30px rgba(246, 50, 62, 0.34);
}

/* Ocultar sello viejo */
.register_form div[title*="Click to Verify"] {
	display: none !important;
}

/* Validación */
.register_form label.error {
	display: block;
	margin: 6px 0 0 0;
	font-family: 'Inter', sans-serif;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.35;
	color: #F6323E !important;
	text-align: left !important;
}

/* ======================================================
   ITEMS / BENEFICIOS — derecha
   ====================================================== */

.st_register .st_left_side {
	display: flex !important;
	flex-direction: column;
	gap: 18px;
	align-items: flex-start !important;
	justify-content: center;
	padding: 40px !important;
	border: 1px solid #E5EAF1;
	border-radius: 18px;
	background:
		radial-gradient(circle at 95% 15%, rgba(246, 50, 62, 0.08) 0, rgba(246, 50, 62, 0) 30%),
		linear-gradient(180deg, #F7F9FC 0%, #ffffff 100%);
	box-shadow: 0 18px 48px rgba(0, 71, 149, 0.06);
	box-sizing: border-box;
}

.st_register .st_left_side > .section_table {
	display: flex !important;
	align-items: center;
	gap: 14px;
	width: 100%;
	margin: 0;
	padding: 0;
}

.st_register .st_left_side .st_cell {
	display: flex !important;
	align-items: center;
	padding: 0 !important;
}

.st_register .st_left_side .st_icon_side {
	width: 30px !important;
	min-width: 30px !important;
	max-width: 30px !important;
}

.st_register .st_left_side .st_icon_side img {
	width: 20px;
	height: 20px;
	object-fit: contain;
	filter: brightness(0) saturate(100%) invert(29%) sepia(94%) saturate(3545%) hue-rotate(339deg) brightness(102%) contrast(97%);
}

.st_register .st_left_side p {
	margin: 0;
	font-family: 'Inter', sans-serif;
	font-size: 17px;
	font-weight: 700;
	line-height: 1.45;
	color: #111827;
}

/* ======================================================
   FOOTER POLÍTICAS
   ====================================================== */

.registrate_bottom_text {
	max-width: 820px;
	margin: 34px 0 0 0;
	font-family: 'Inter', sans-serif;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.5;
	color: #6B7280;
}

.registrate_bottom_text span {
	font-family: 'Inter', sans-serif;
	font-weight: 800;
	color: #004795;
	cursor: pointer;
	text-decoration: none;
	border-bottom: 2px solid rgba(246, 50, 62, 0.55);
}

.registrate_bottom_text span:hover {
	color: #F6323E;
	border-color: #F6323E;
}

/* ======================================================
   RESPONSIVE
   ====================================================== */

@media only screen and (max-width: 980px) {
	.sc_registrate > .inner_section_container {
		padding: 42px 28px;
	}

	.sc_registrate p.st_title_box {
		font-size: 36px;
	}

	.st_register {
		grid-template-columns: 1fr;
		gap: 34px;
	}

	.st_register .st_left_side,
	.st_register .st_right_side {
		grid-column: auto;
		grid-row: auto;
	}

	.register_form {
		max-width: 560px;
		margin: 0 auto;
	}

	.st_register .st_left_side {
		max-width: 560px;
		margin: 0 auto;
		padding: 30px !important;
	}

	.st_register .st_left_side p {
		font-size: 15px;
	}
}

@media only screen and (max-width: 680px) {
	.sc_registrate > .inner_section_container {
		padding: 34px 20px;
	}

	.sc_registrate img.st_icon {
		display: none !important;
	}

	.sc_registrate p.st_title_box {
		font-size: 32px;
	}

	.sc_registrate + .section_container > .inner_section_container {
		padding: 34px 18px 46px 18px;
	}

	.registrate_text {
		font-size: 15px;
	}

	.registrate_text a {
		font-size: 15px !important;
	}

	.register_form {
		padding: 24px 20px;
		border-radius: 16px;
	}

	.register_form .form_security_code {
		grid-template-columns: 1fr 104px;
	}

	.register_form .form_security_code img.captcha {
		width: 104px;
	}

	.st_register .st_left_side {
		padding: 24px 20px !important;
		border-radius: 16px;
	}

	.registrate_bottom_text {
		font-size: 12px;
	}
}

/* ======================================================
   RESPONSIVE REGISTRATE
   ====================================================== */

@media only screen and (max-width: 900px) {
	.sc_registrate > .inner_section_container {
		padding: 42px 28px;
	}

	.sc_registrate p.st_title_box {
		font-size: 36px;
	}

	.sc_registrate + .section_container > .inner_section_container {
		padding: 38px 24px 56px;
	}

	.registrate_text {
		max-width: 100%;
		font-size: 16px;
		margin-bottom: 32px;
	}

	.st_register {
		grid-template-columns: 1fr;
		gap: 28px;
	}

	.st_register .st_right_side,
	.st_register .st_left_side {
		grid-column: auto;
		grid-row: auto;
		max-width: 560px;
		margin: 0 auto;
	}

	.register_form {
		padding: 32px;
	}

	.st_register .st_left_side {
		padding: 28px !important;
	}

	.st_register .st_left_side p {
		font-size: 15px;
	}
}

@media only screen and (max-width: 560px) {
	.sc_registrate > .inner_section_container {
		padding: 34px 20px;
	}

	.sc_registrate img.st_icon {
		display: none !important;
	}

	.sc_registrate p.st_title_box {
		font-size: 32px;
	}

	.sc_registrate + .section_container > .inner_section_container {
		padding: 32px 16px 48px;
	}

	.registrate_text,
	.registrate_text a {
		font-size: 15px !important;
	}

	.register_form {
		padding: 24px 18px;
		border-radius: 16px;
	}

	.register_form input,
	.register_form select {
		height: 46px;
		font-size: 14px;
	}

	.register_form .form_security_code {
		grid-template-columns: 1fr 104px;
		gap: 8px;
	}

	.register_form .form_security_code img.captcha {
		width: 104px;
		height: 46px !important;
	}

	.register_form button {
		height: 48px;
	}

	.st_register .st_left_side {
		padding: 22px 18px !important;
		border-radius: 16px;
	}

	.registrate_bottom_text {
		font-size: 12px;
	}
}