@charset "utf-8";


:root {
	--login-navy: #06324a;
	--login-navy-2: #0b4b70;
	--login-blue: #139bd7;
	--login-cyan: #60d8ff;
	--login-bg: #eaf2fb;
	--login-card: #ffffff;
	--login-text: #102337;
	--login-muted: #668093;
	--login-border: #d7e5f2;
}

* { box-sizing: border-box; }

html,
body { min-height: 100%; }

body {
	margin: 0;
	font-family: "Segoe UI", "Trebuchet MS", Tahoma, sans-serif;
	color: var(--login-text);
	background:
		radial-gradient(circle at 10% 15%, rgba(19, 155, 215, .24), transparent 28rem),
		radial-gradient(circle at 90% 10%, rgba(96, 216, 255, .18), transparent 30rem),
		linear-gradient(135deg, #f7fbff 0%, var(--login-bg) 48%, #dce9f7 100%);
}

.login-page {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 100vh;
	padding: 32px 18px;
	overflow: hidden;
}

.login-page::before,
.login-page::after {
	content: "";
	position: absolute;
	border-radius: 999px;
	pointer-events: none;
}

.login-page::before {
	width: 420px;
	height: 420px;
	left: -140px;
	bottom: -160px;
	background: rgba(6, 50, 74, .12);
}

.login-page::after {
	width: 300px;
	height: 300px;
	right: -90px;
	top: -110px;
	background: rgba(19, 155, 215, .18);
}

.login-shell {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(280px, .95fr) minmax(320px, 1fr);
	width: min(980px, 100%);
	min-height: 560px;
	background: var(--login-card);
	border: 1px solid rgba(255, 255, 255, .72);
	border-radius: 28px;
	box-shadow: 0 28px 80px rgba(6, 50, 74, .18);
	overflow: hidden;
}

.login-brand {
	position: relative;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 40px;
	color: #fff;
	background:
		radial-gradient(circle at 80% 15%, rgba(96, 216, 255, .2), transparent 20rem),
		linear-gradient(145deg, rgba(6, 50, 74, .98), rgba(11, 75, 112, .98));
	overflow: hidden;
}

.login-brand::before {
	content: "";
	position: absolute;
	width: 270px;
	height: 270px;
	right: -105px;
	bottom: -105px;
	border: 34px solid rgba(255, 255, 255, .08);
	border-radius: 50%;
}

.login-logo-card {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 230px;
	max-width: 100%;
	padding: 18px 20px;
	background: #fff;
	border-radius: 22px;
	box-shadow: 0 18px 40px rgba(0, 0, 0, .18);
}

.login-logo-card-wide {
	width: min(360px, 100%);
	padding: 30px 34px;
}

.login-logo-card img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 110px;
	object-fit: contain;
}

.login-kicker {
	position: relative;
	margin-top: 36px;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: .14em;
	text-transform: uppercase;
	color: var(--login-cyan);
}

.login-brand h1 {
	position: relative;
	margin: 12px 0 14px;
	font-size: clamp(34px, 4vw, 50px);
	line-height: 1.02;
	letter-spacing: -.04em;
}

.login-brand p {
	position: relative;
	max-width: 340px;
	margin: 0;
	color: rgba(255, 255, 255, .78);
	font-size: 15px;
	line-height: 1.65;
}

.login-brand-footer {
	position: relative;
	display: grid;
	gap: 10px;
	margin-top: 34px;
	color: rgba(255, 255, 255, .74);
	font-size: 13px;
}

.login-feature {
	display: flex;
	align-items: center;
	gap: 10px;
}

.login-feature span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 9px;
	background: rgba(255, 255, 255, .12);
	color: var(--login-cyan);
}

.login-panel {
	display: flex;
	align-items: center;
	padding: 42px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(248, 251, 255, .98)),
		repeating-linear-gradient(135deg, rgba(6, 50, 74, .035) 0 1px, transparent 1px 16px);
}

.login-form-wrap {
	width: 100%;
	max-width: 420px;
	margin: 0 auto;
}

.login-version {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	margin-bottom: 20px;
	border: 1px solid var(--login-border);
	border-radius: 999px;
	background: #fff;
	color: var(--login-muted);
	font-size: 12px;
	font-weight: 700;
}

.login-form-wrap h2 {
	margin: 0 0 8px;
	font-size: 30px;
	letter-spacing: -.03em;
}

.login-form-wrap .subtitle {
	margin: 0 0 28px;
	color: var(--login-muted);
	font-size: 14px;
	line-height: 1.55;
}

.field-group {
	margin-bottom: 16px;
}

.field-group label {
	display: block;
	margin-bottom: 7px;
	color: #284257;
	font-size: 13px;
	font-weight: 800;
}

.input-shell {
	display: flex;
	align-items: center;
	border: 1px solid var(--login-border);
	border-radius: 14px;
	background: #fff;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

.input-shell:focus-within {
	border-color: var(--login-blue);
	box-shadow: 0 0 0 4px rgba(19, 155, 215, .12);
	transform: translateY(-1px);
}

.input-shell i {
	width: 44px;
	text-align: center;
	color: var(--login-blue);
}

.imput {
	width: 100%;
	height: 48px;
	border: 0;
	outline: 0;
	background: transparent;
	padding: 0 14px 0 0;
	color: var(--login-text);
	font-size: 15px;
}

.imput::placeholder {
	color: #9aacb9;
}

.login-actions {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 14px;
	margin-top: 22px;
}

.botao {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 142px;
	height: 48px;
	border: 0;
	border-radius: 14px;
	background: linear-gradient(135deg, var(--login-blue), var(--login-navy-2));
	color: #fff;
	font-size: 15px;
	font-weight: 800;
	cursor: pointer;
	box-shadow: 0 14px 26px rgba(19, 155, 215, .25);
	transition: transform .2s ease, box-shadow .2s ease;
}

.botao:hover {
	transform: translateY(-2px);
	box-shadow: 0 18px 32px rgba(19, 155, 215, .3);
}

.rec {
	color: var(--login-navy-2);
	font-size: 13px;
	font-weight: 800;
	text-decoration: none;
}

.rec:hover {
	color: var(--login-blue);
	text-decoration: underline;
}

.login-error {
	margin-top: 18px;
	padding: 12px 14px;
	border: 1px solid rgba(220, 53, 69, .22);
	border-radius: 14px;
	background: rgba(220, 53, 69, .08);
	color: #9d1c2b;
	font-size: 13px;
	font-weight: 700;
}

@media (max-width: 860px) {
	.login-shell {
		grid-template-columns: 1fr;
		min-height: auto;
	}

	.login-brand {
		padding: 28px;
	}

	.login-logo-card {
		width: 190px;
	}

	.login-kicker {
		margin-top: 24px;
	}

	.login-brand-footer {
		display: none;
	}

	.login-panel {
		padding: 28px;
	}
}

@media (max-width: 460px) {
	.login-page {
		align-items: stretch;
		padding: 12px;
	}

	.login-shell {
		border-radius: 22px;
	}

	.login-brand,
	.login-panel {
		padding: 22px;
	}

	.login-form-wrap h2 {
		font-size: 25px;
	}

	.login-actions {
		align-items: stretch;
		flex-direction: column;
	}

	.botao,
	.rec {
		width: 100%;
		text-align: center;
	}
}

/* Compatibilidade com o index antigo caso o servidor esteja com cache/FTP parcial. */
#topo {
	display: none;
}

#entrada {
	position: fixed;
	left: 50%;
	top: 50%;
	transform: translate(-50%, -50%);
	display: grid;
	grid-template-columns: minmax(260px, 1fr) minmax(220px, .75fr);
	width: min(760px, calc(100vw - 32px));
	min-height: 420px;
	overflow: hidden;
	background: #fff;
	border: 1px solid rgba(255, 255, 255, .72);
	border-radius: 28px;
	box-shadow: 0 28px 80px rgba(6, 50, 74, .18);
}

#top {
	position: absolute;
	left: 32px;
	top: 30px;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 12px;
	border: 1px solid var(--login-border);
	border-radius: 999px;
	background: #fff;
	color: var(--login-muted);
	font-size: 12px;
	font-weight: 700;
}

#form {
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 88px 32px 32px;
	background:
		linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(248, 251, 255, .98)),
		repeating-linear-gradient(135deg, rgba(6, 50, 74, .035) 0 1px, transparent 1px 16px);
}

#form::before {
	content: "Acessar sistema";
	display: block;
	margin-bottom: 8px;
	font-size: 30px;
	font-weight: 800;
	letter-spacing: -.03em;
}

#form form::before {
	content: "Informe suas credenciais para entrar no painel de gestao.";
	display: block;
	margin-bottom: 22px;
	color: var(--login-muted);
	font-size: 14px;
	line-height: 1.55;
}

.texto {
	display: block;
	margin: 0 0 7px;
	color: #284257;
	font-size: 13px;
	font-weight: 800;
}

#form .imput {
	display: block;
	width: 100%;
	height: 48px;
	margin: 0 0 16px;
	padding: 0 14px;
	border: 1px solid var(--login-border);
	border-radius: 14px;
	background: #fff;
	color: var(--login-text);
	font-size: 15px;
	transition: border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}

#form .imput:focus {
	border-color: var(--login-blue);
	box-shadow: 0 0 0 4px rgba(19, 155, 215, .12);
	transform: translateY(-1px);
}

#logar {
	margin-top: 6px;
}

#logo {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 32px;
	background:
		radial-gradient(circle at 80% 15%, rgba(96, 216, 255, .2), transparent 20rem),
		linear-gradient(145deg, rgba(6, 50, 74, .98), rgba(11, 75, 112, .98));
}

#logo::after {
	content: "";
	display: block;
	width: min(300px, 100%);
	height: 150px;
	padding: 30px 34px;
	background: #fff url("../img/logo-reetek-azul.png") center center / contain no-repeat;
	border-radius: 22px;
	box-shadow: 0 18px 40px rgba(0, 0, 0, .18);
}

#logo::before {
	content: "Gestao Reetek";
	position: absolute;
	left: 32px;
	bottom: 34px;
	color: var(--login-cyan);
	font-size: 13px;
	font-weight: 800;
	letter-spacing: .14em;
	text-transform: uppercase;
}

#logo img {
	display: none !important;
}

#rec {
	position: absolute;
	left: 32px;
	bottom: 30px;
	z-index: 3;
}

#rec .rec {
	color: var(--login-navy-2);
}

#erross {
	margin-top: 14px;
	padding: 12px 14px;
	border: 1px solid rgba(220, 53, 69, .22);
	border-radius: 14px;
	background: rgba(220, 53, 69, .08);
	color: #9d1c2b;
	font-size: 13px;
	font-weight: 700;
}

@media (max-width: 760px) {
	#entrada {
		position: relative;
		left: auto;
		top: auto;
		transform: none;
		grid-template-columns: 1fr;
		margin: 16px auto;
	}

	#top {
		left: 22px;
		top: 22px;
	}

	#form {
		padding: 82px 22px 28px;
	}

	#logo {
		order: -1;
		min-height: 210px;
		padding: 28px 22px 56px;
	}

	#logo::before {
		left: 22px;
		bottom: 24px;
	}

	#rec {
		position: static;
		padding: 0 22px 24px;
		background: rgba(248, 251, 255, .98);
	}
}
