*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

/* VARIABLES GLOBALES — cambiando aquí se actualiza todo el panel */
:root {
  --verde: #4a7c1f;
  --verde-hover: #3b6316;
  --negro: #1a1a1a;
  --gris-fondo: #f7f7f5;
  --gris-borde: #e0e0e0;
  --gris-input: #fafafa;
  --gris-label: #555;
  --gris-placeholder: #aaa;
  --blanco: #ffffff;
  --radius: 8px;
  --radius-card: 16px;
}

/* Centra la tarjeta en toda la pantalla */
body {
  font-family: 'Helvetica Neue', Arial, sans-serif;
  background: var(--gris-fondo);
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Tarjeta blanca central */
.login-card {
  background: var(--blanco);
  border-radius: var(--radius-card);
  border: 0.5px solid var(--gris-borde);
  /* Dos sombras apiladas: una grande y suave, otra pequeña y sutil */
  box-shadow: 0 4px 32px rgba(0,0,0,0.08), 0 1px 4px rgba(0,0,0,0.04);
  padding: 32px 36px 28px;
  width: 300px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

/* Recuadro placeholder del logo */
.logo-placeholder {
  width: 72px;
  height: 38px;
  background: #f0f0ee;
  border-radius: 6px;
  border: 1.5px dashed #c8c8c4;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 22px;
}

.logo-placeholder span {
  font-size: 10px;
  color: var(--gris-placeholder);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

/* Cada bloque label + input */
.field-group {
  width: 100%;
  margin-bottom: 12px;
}

.field-label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--gris-label);
  margin-bottom: 6px;
}

/* position: relative permite que el icono se posicione dentro del input */
.field-wrap {
  position: relative;
}

/* El icono se posiciona en absoluto respecto al field-wrap */
.field-icon {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: #bbb;
  pointer-events: none; /* El icono no interfiere con los clics */
}

.field-input {
  width: 100%;
  height: 38px;
  border: 1px solid var(--gris-borde);
  border-radius: var(--radius);
  padding: 0 12px 0 34px; /* El padding izquierdo de 34px deja espacio al icono */
  font-size: 14px;
  color: var(--negro);
  background: var(--gris-input);
  outline: none;
  transition: border-color 0.15s;
}

/* Cuando el usuario hace clic en el input, el borde cambia a verde */
.field-input:focus {
  border-color: var(--verde);
  background: var(--blanco);
}

.login-btn {
  width: 100%;
  height: 40px;
  background: var(--verde);
  color: var(--blanco);
  border: none;
  border-radius: var(--radius);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  margin-top: 6px;
  transition: background 0.15s;
}

/* Al pasar el ratón el verde se oscurece ligeramente */
.login-btn:hover {
  background: var(--verde-hover);
}

.login-footer {
  margin-top: 18px;
  font-size: 11px;
  color: #bbb;
  text-align: center;
}