/**
 * InterSecs Login CSS
 * CHECKPOINT 9
 */

@import url('https://fonts.googleapis.com/css2?family=Comfortaa:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap');

.intersecs-login-shell {
	position: relative;
	width: 100%;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	gap: 16px;
	padding: 68px 20px 48px;
	overflow: hidden;
	font-family: 'Manrope', sans-serif;
	background:
		radial-gradient(circle at 20% 20%, rgba(203, 20, 91, 0.16), transparent 32%),
		radial-gradient(circle at 80% 15%, rgba(110, 193, 228, 0.20), transparent 36%),
		linear-gradient(135deg, #ffffff 0%, #f7f9fc 52%, #fdf4f8 100%);
	color: #151827;
	box-sizing: border-box;
}

.intersecs-login-shell *,
.intersecs-login-shell *::before,
.intersecs-login-shell *::after {
	box-sizing: border-box;
}

.intersecs-login-bg-orb {
	position: absolute;
	border-radius: 999px;
	filter: blur(16px);
	opacity: 0.65;
	pointer-events: none;
}

.intersecs-login-bg-orb-one {
	width: 280px;
	height: 280px;
	top: 8%;
	left: 10%;
	background: linear-gradient(135deg, rgba(203, 20, 91, 0.26), rgba(110, 193, 228, 0.14));
}

.intersecs-login-bg-orb-two {
	width: 340px;
	height: 340px;
	right: 8%;
	bottom: 8%;
	background: linear-gradient(135deg, rgba(110, 193, 228, 0.22), rgba(203, 20, 91, 0.12));
}

.intersecs-login-card {
	position: relative;
	z-index: 2;
	width: 100%;
	max-width: 460px;
	padding: 40px 34px 34px;
	border: 1px solid rgba(255, 255, 255, 0.72);
	border-radius: 30px;
	background: rgba(255, 255, 255, 0.74);
	backdrop-filter: blur(22px);
	-webkit-backdrop-filter: blur(22px);
	box-shadow:
		0 24px 70px rgba(20, 24, 39, 0.12),
		inset 0 1px 0 rgba(255, 255, 255, 0.74);
}

.intersecs-login-card-small {
	text-align: center;
}

.intersecs-login-head {
	text-align: center;
	margin-bottom: 26px;
}

.intersecs-login-head h1,
.intersecs-login-card h2,
.intersecs-modal-card h2 {
	margin: 0 !important;
	font-family: 'Comfortaa', cursive !important;
	font-weight: 700 !important;
	color: #151827 !important;
	letter-spacing: -0.04em !important;
}

.intersecs-login-head h1 {
	font-size: 30px !important;
	line-height: 1.18 !important;
}

.intersecs-login-card h2,
.intersecs-modal-card h2 {
	font-size: 26px !important;
	line-height: 1.2 !important;
}

.intersecs-login-head p,
.intersecs-login-card p,
.intersecs-modal-card p {
	margin: 12px 0 0;
	font-family: 'Manrope', sans-serif;
	font-size: 15px;
	line-height: 1.6;
	color: #626a7c;
}

.intersecs-login-form {
	display: flex;
	flex-direction: column;
	gap: 16px;
}

.intersecs-login-field {
	display: flex;
	flex-direction: column;
	gap: 8px;
}

.intersecs-login-field label {
	font-family: 'Manrope', sans-serif;
	font-size: 13px;
	font-weight: 800;
	color: #2b3040;
	letter-spacing: -0.01em;
}

.intersecs-login-field input {
	width: 100% !important;
	height: 50px !important;
	min-height: 50px !important;
	max-height: 50px !important;
	border: 1px solid rgba(21, 24, 39, 0.10) !important;
	border-radius: 18px !important;
	background: rgba(255, 255, 255, 0.78) !important;
	padding: 0 16px !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 15px !important;
	font-weight: 600 !important;
	color: #151827 !important;
	outline: none !important;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
	transition: 0.22s ease !important;
	line-height: 50px !important;
}

.intersecs-login-field input::placeholder {
	color: #a4aabc;
	font-weight: 500;
}

.intersecs-login-field input:focus {
	border-color: rgba(203, 20, 91, 0.42) !important;
	box-shadow:
		0 0 0 4px rgba(203, 20, 91, 0.10),
		inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
	background: rgba(255, 255, 255, 0.95) !important;
}

.intersecs-password-wrap {
	position: relative;
	width: 100%;
}

.intersecs-password-wrap input {
	padding-right: 58px !important;
}

.intersecs-password-toggle {
	position: absolute !important;
	top: 50% !important;
	right: 8px !important;
	transform: translateY(-50%) !important;
	width: 40px !important;
	height: 40px !important;
	min-width: 40px !important;
	max-width: 40px !important;
	min-height: 40px !important;
	max-height: 40px !important;
	padding: 0 !important;
	margin: 0 !important;
	display: flex !important;
	align-items: center !important;
	justify-content: center !important;
	border: 1px solid rgba(21, 24, 39, 0.08) !important;
	border-radius: 14px !important;
	background: rgba(255, 255, 255, 0.62) !important;
	color: #626a7c !important;
	cursor: pointer !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 0 !important;
	line-height: 1 !important;
	box-shadow:
		0 8px 20px rgba(21, 24, 39, 0.10),
		inset 0 1px 0 rgba(255, 255, 255, 0.9) !important;
	transition: 0.2s ease !important;
	appearance: none !important;
	-webkit-appearance: none !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
}

.intersecs-password-toggle:hover,
.intersecs-password-toggle:focus {
	background: rgba(255, 255, 255, 0.88) !important;
	border-color: rgba(203, 20, 91, 0.20) !important;
	color: #CB145B !important;
	outline: none !important;
}

.intersecs-eye-icon {
	position: relative;
	display: block;
	width: 18px;
	height: 12px;
	border: 2px solid currentColor;
	border-radius: 70% 70% 70% 70%;
	transform: rotate(-4deg);
}

.intersecs-eye-icon::before {
	content: '';
	position: absolute;
	top: 50%;
	left: 50%;
	width: 6px;
	height: 6px;
	background: currentColor;
	border-radius: 50%;
	transform: translate(-50%, -50%);
}

.intersecs-password-toggle.is-visible .intersecs-eye-icon::after {
	content: '';
	position: absolute;
	top: 50%;
	left: -4px;
	width: 26px;
	height: 2px;
	background: currentColor;
	transform: rotate(-38deg);
	border-radius: 99px;
}

.intersecs-login-options {
	display: flex;
	align-items: center;
	justify-content: space-between;
	margin-top: -2px;
}

.intersecs-login-remember {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	cursor: pointer;
	font-family: 'Manrope', sans-serif;
	font-size: 13px;
	font-weight: 700;
	color: #626a7c;
	user-select: none;
}

.intersecs-login-remember input {
	width: 16px !important;
	height: 16px !important;
	min-width: 16px !important;
	min-height: 16px !important;
	accent-color: #CB145B;
	margin: 0 !important;
	padding: 0 !important;
}

.intersecs-login-message {
	display: none;
	padding: 12px 14px;
	border-radius: 16px;
	font-family: 'Manrope', sans-serif;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.4;
}

.intersecs-login-message.is-error {
	display: block;
	background: rgba(203, 20, 91, 0.10);
	color: #a30d45;
	border: 1px solid rgba(203, 20, 91, 0.16);
}

.intersecs-login-message.is-success {
	display: block;
	background: rgba(110, 193, 228, 0.14);
	color: #166981;
	border: 1px solid rgba(110, 193, 228, 0.22);
}

/**
 * Botões textuais padrão InterSecs
 */

.intersecs-login-main-btn,
.intersecs-login-secondary-btn,
.intersecs-modal-whatsapp-btn {
	width: 100% !important;
	height: 52px !important;
	min-height: 52px !important;
	max-height: 52px !important;
	border-radius: 14px !important;
	display: inline-flex !important;
	align-items: center !important;
	justify-content: center !important;
	text-align: center !important;
	text-decoration: none !important;
	font-family: 'Comfortaa', cursive !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	letter-spacing: 0.04em !important;
	line-height: 20px !important;
	cursor: pointer !important;
	transition: transform 0.18s ease, box-shadow 0.18s ease, opacity 0.18s ease, background 0.18s ease !important;
	appearance: none !important;
	-webkit-appearance: none !important;
	box-sizing: border-box !important;
}

.intersecs-login-main-btn,
.intersecs-modal-whatsapp-btn {
	border: 0 !important;
	background: linear-gradient(135deg, #CB145B, #6EC1E4) !important;
	color: #ffffff !important;
	box-shadow: 0 16px 34px rgba(203, 20, 91, 0.22) !important;
	padding: 0 18px !important;
}

.intersecs-login-main-btn:hover,
.intersecs-modal-whatsapp-btn:hover {
	transform: translateY(-1px) !important;
	box-shadow: 0 20px 42px rgba(203, 20, 91, 0.28) !important;
	color: #ffffff !important;
}

.intersecs-login-main-btn.is-loading {
	pointer-events: none;
	opacity: 0.72;
}

.intersecs-login-btn-text {
	font-family: 'Comfortaa', cursive !important;
	font-size: 14px !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	line-height: 20px !important;
	letter-spacing: 0.04em !important;
}

.intersecs-login-spinner {
	display: none;
	width: 18px;
	height: 18px;
	margin-left: 10px;
	border-radius: 50%;
	border: 2px solid rgba(255, 255, 255, 0.45);
	border-top-color: #ffffff;
	animation: intersecs-login-spin 0.8s linear infinite;
}

.intersecs-login-main-btn.is-loading .intersecs-login-spinner {
	display: inline-block;
}

@keyframes intersecs-login-spin {
	to {
		transform: rotate(360deg);
	}
}

.intersecs-login-divider {
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 12px;
	margin: 24px 0 16px;
}

.intersecs-login-divider span {
	height: 1px;
	background: rgba(21, 24, 39, 0.10);
}

.intersecs-login-divider p {
	margin: 0;
	font-family: 'Comfortaa', cursive;
	font-size: 11px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: #8c93a5;
}

.intersecs-login-secondary-btn {
	background: rgba(255, 255, 255, 0.66) !important;
	color: #CB145B !important;
	border: 1px solid rgba(203, 20, 91, 0.22) !important;
	box-shadow:
		0 10px 22px rgba(21, 24, 39, 0.10),
		inset 0 1px 0 rgba(255, 255, 255, 0.85) !important;
	padding: 0 18px !important;
}

.intersecs-login-secondary-btn:hover {
	transform: translateY(-1px) !important;
	background: rgba(255, 255, 255, 0.88) !important;
	color: #CB145B !important;
	box-shadow: 0 14px 30px rgba(21, 24, 39, 0.12) !important;
}

.intersecs-login-footnote {
	text-align: center;
	font-family: 'Manrope', sans-serif;
	font-size: 12px !important;
	margin-top: 16px !important;
	color: #8c93a5 !important;
}


/* CHECKPOINT 20.12-A.2 — link manual do app abaixo do login com box preto neon */
.intersecs-login-app-link {
	position: relative;
	z-index: 2;
	display: block !important;
	width: 100% !important;
	max-width: 460px !important;
	margin: 0 auto !important;
	padding: 18px 22px !important;
	border-radius: 18px !important;
	background: #030306 !important;
	border: 1.5px solid #CB145B !important;
	box-shadow:
		0 0 0 1px rgba(203, 20, 91, 0.26),
		0 0 18px rgba(203, 20, 91, 0.34),
		0 14px 34px rgba(203, 20, 91, 0.18) !important;
	text-align: center !important;
	font-family: 'Manrope', sans-serif !important;
	font-size: 13px !important;
	font-weight: 700 !important;
	line-height: 1.55 !important;
	color: rgba(255, 255, 255, 0.90) !important;
}

.intersecs-login-app-link::before {
	content: '';
	position: absolute;
	inset: -2px;
	z-index: -1;
	border-radius: 20px;
	background: linear-gradient(90deg, rgba(203, 20, 91, 0.78), rgba(110, 193, 228, 0.24), rgba(203, 20, 91, 0.78));
	filter: blur(13px);
	opacity: 0.42;
	pointer-events: none;
}

.intersecs-login-app-link span,
.intersecs-login-app-link a {
	display: inline !important;
	font-family: 'Manrope', sans-serif !important;
}

.intersecs-login-app-link span {
	color: rgba(255, 255, 255, 0.90) !important;
}

.intersecs-login-app-link a {
	margin-left: 5px !important;
	padding: 0 !important;
	border: 0 !important;
	border-radius: 0 !important;
	background: transparent !important;
	box-shadow: none !important;
	color: #6EC1E4 !important;
	font-weight: 900 !important;
	text-decoration: none !important;
	text-transform: uppercase !important;
	letter-spacing: 0.02em !important;
}

.intersecs-login-app-link a:hover,
.intersecs-login-app-link a:focus {
	transform: none !important;
	color: #CB145B !important;
	text-decoration: none !important;
	box-shadow: none !important;
	outline: none !important;
}

.intersecs-login-app-link.is-installed {
	border-color: rgba(110, 193, 228, 0.78) !important;
	box-shadow:
		0 0 0 1px rgba(110, 193, 228, 0.22),
		0 0 18px rgba(110, 193, 228, 0.30),
		0 14px 34px rgba(7, 9, 18, 0.18) !important;
	color: rgba(255, 255, 255, 0.90) !important;
}

.intersecs-login-app-link.is-installed::before {
	background: linear-gradient(90deg, rgba(110, 193, 228, 0.58), rgba(203, 20, 91, 0.18), rgba(110, 193, 228, 0.58));
	opacity: 0.36;
}

.intersecs-login-app-link.is-installed span {
	color: rgba(255, 255, 255, 0.90) !important;
}

/* CHECKPOINT 20.12-A.3 — se estiver aberto como APP/PWA, o bloco manual some imediatamente */
@media all and (display-mode: standalone),
	all and (display-mode: fullscreen),
	all and (display-mode: minimal-ui),
	all and (display-mode: window-controls-overlay) {
	.intersecs-login-app-link {
		display: none !important;
	}
}

@media (max-width: 640px) {
	.intersecs-login-app-link {
		max-width: 100% !important;
		padding: 16px 18px !important;
		font-size: 12px !important;
		border-radius: 16px !important;
	}

	.intersecs-login-app-link::before {
		border-radius: 18px !important;
	}
}

/**
 * Modal
 */

.intersecs-modal-overlay {
	position: fixed;
	inset: 0;
	z-index: 999999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 22px;
	background: rgba(15, 18, 30, 0.42);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
}

.intersecs-modal-overlay.is-open {
	display: flex;
}

.intersecs-modal-card {
	position: relative;
	width: 100%;
	max-width: 460px;
	padding: 34px;
	text-align: center;
	border-radius: 30px;
	border: 1px solid rgba(255, 255, 255, 0.72);
	background:
		radial-gradient(circle at 15% 10%, rgba(203, 20, 91, 0.12), transparent 36%),
		radial-gradient(circle at 90% 20%, rgba(110, 193, 228, 0.18), transparent 40%),
		rgba(255, 255, 255, 0.88);
	box-shadow: 0 30px 90px rgba(0, 0, 0, 0.18);
	backdrop-filter: blur(26px);
	-webkit-backdrop-filter: blur(26px);
	animation: intersecs-modal-in 0.22s ease both;
}

@keyframes intersecs-modal-in {
	from {
		opacity: 0;
		transform: translateY(12px) scale(0.98);
	}
	to {
		opacity: 1;
		transform: translateY(0) scale(1);
	}
}

.intersecs-modal-close {
	position: absolute !important;
	top: 14px !important;
	right: 14px !important;
	width: 40px !important;
	height: 40px !important;
	min-width: 40px !important;
	max-width: 40px !important;
	min-height: 40px !important;
	max-height: 40px !important;
	padding: 0 !important;
	margin: 0 !important;
	border: 0 !important;
	border-radius: 50% !important;
	background-color: transparent !important;
	background-image: url('https://intersecs.com.br/wp-content/uploads/2026/05/chat_close.png') !important;
	background-repeat: no-repeat !important;
	background-position: center !important;
	background-size: 40px 40px !important;
	box-shadow: none !important;
	cursor: pointer !important;
	font-size: 0 !important;
	line-height: 0 !important;
	color: transparent !important;
	appearance: none !important;
	-webkit-appearance: none !important;
	transition: transform 0.18s ease, opacity 0.18s ease !important;
	text-transform: none !important;
	letter-spacing: 0 !important;
}

.intersecs-modal-close:hover,
.intersecs-modal-close:focus {
	transform: scale(1.04) !important;
	opacity: 0.88 !important;
	background-color: transparent !important;
	outline: none !important;
}

.intersecs-modal-icon {
	width: 64px;
	height: 64px;
	margin: 0 auto 18px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 22px;
	background: linear-gradient(135deg, rgba(203, 20, 91, 0.14), rgba(110, 193, 228, 0.18));
	color: #CB145B;
	font-size: 28px;
	box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
}

.intersecs-modal-whatsapp-btn {
	margin-top: 24px !important;
}

.intersecs-modal-warning {
	margin-top: 22px;
	padding: 14px 16px;
	border-radius: 18px;
	background: rgba(203, 20, 91, 0.10);
	border: 1px solid rgba(203, 20, 91, 0.16);
	color: #a30d45;
	font-family: 'Manrope', sans-serif;
	font-size: 13px;
	font-weight: 800;
	line-height: 1.5;
}

/**
 * Mobile
 */

@media (max-width: 767px) {
	.intersecs-login-shell {
		padding: 54px 0 34px;
		gap: 14px;
	}

	.intersecs-login-card,
	.intersecs-modal-card {
		width: 90%;
		max-width: 90%;
		padding: 26px 20px;
		border-radius: 26px;
	}

	.intersecs-login-app-link {
		width: 90% !important;
		max-width: 90% !important;
		padding: 15px 16px !important;
	}

	.intersecs-login-head h1 {
		font-size: 25px !important;
	}

	.intersecs-login-card h2,
	.intersecs-modal-card h2 {
		font-size: 23px !important;
	}

	.intersecs-login-head p,
	.intersecs-login-card p,
	.intersecs-modal-card p {
		font-size: 14px;
	}

	.intersecs-login-bg-orb-one {
		width: 220px;
		height: 220px;
		left: -80px;
	}

	.intersecs-login-bg-orb-two {
		width: 260px;
		height: 260px;
		right: -100px;
	}
}