/* ============================================================
   INTRANET RANCHO S — login.css
   Tela de login / autenticação
   ============================================================ */

#screen-login,
#screen-recovery {
  background: linear-gradient(160deg, #1a3009 0%, #2d5016 55%, #3d6e1e 100%);
  align-items: center;
  justify-content: center;
  position: relative;
  overflow: hidden;
}

/* — Efeitos decorativos de fundo — */
#screen-login::before {
  content: '';
  position: absolute;
  width: 500px; height: 500px;
  background: radial-gradient(circle, rgba(255,255,255,0.05) 0%, transparent 70%);
  top: -80px; left: -80px;
  pointer-events: none;
}
#screen-login::after {
  content: '';
  position: absolute;
  width: 400px; height: 400px;
  background: radial-gradient(circle, rgba(141,198,63,0.09) 0%, transparent 70%);
  bottom: -40px; right: -40px;
  pointer-events: none;
}

/* — Card de login — */
.login-card {
  background: #fff;
  border: 1px solid #c5d9a8;
  border-radius: var(--radius-lg);
  padding: 44px 38px;
  width: 100%;
  max-width: 420px;
  box-shadow: 0 16px 64px rgba(0,0,0,0.28);
  position: relative;
  z-index: 1;
  animation: fadeUp 0.45s ease;
}

/* — Logo no login — */
.login-logo {
  text-align: center;
  margin-bottom: 32px;
}

.login-logo img {
  width: 160px;
  height: auto;
  border-radius: 8px;
  margin-bottom: 14px;
}

.login-logo h1 {
  font-family: 'Syne', sans-serif;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--verde-escuro);
}

.login-logo p {
  font-size: 12px;
  color: var(--text2);
  margin-top: 4px;
  font-style: italic;
}

/* — Divisor — */
.login-divider {
  height: 1px;
  background: var(--border);
  margin: 0 0 24px;
}

/* — Botão de login — */
.btn-login {
  width: 100%;
  background: linear-gradient(135deg, var(--verde-escuro), var(--verde-medio));
  color: #fff;
  border: none;
  border-radius: var(--radius-sm);
  padding: 14px;
  font-family: 'Syne', sans-serif;
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.1s;
  margin-top: 8px;
}
.btn-login:hover { opacity: 0.9; }
.btn-login:active { transform: scale(0.99); }

/* — Erro de login — */
.login-error {
  background: rgba(192,57,43,0.08);
  border: 1px solid rgba(192,57,43,0.25);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  font-size: 13px;
  color: var(--danger);
  margin-top: 14px;
  display: none;
}

/* — Rodapé do card — */
.login-footer {
  text-align: center;
  font-size: 11px;
  color: var(--text3);
  margin-top: 22px;
}

@media (max-width: 460px) {
  .login-card { padding: 32px 22px; margin: 16px; }
  .login-logo img { width: 130px; }
}
