.newsletter {
  display: grid;
  position: relative;
}

.newsletter__container {
  align-items: center;
  display: flex;
  position: relative;
  width: min(100%, 16em);
}

.newsletter__container form {
  align-items: center;
  background: rgba(var(--rgb-black), 0.02);
  border: none;
  border-radius: 0.25em;
  box-shadow:
    0 0 0 1px rgba(var(--rgb-black), 0.85),
    0 0 0.1em 0.02em rgba(var(--rgb-black), 0.05)
  ;
  display: flex;
  flex: 1;
  font-size: var(--font-size-xxx-small);
  grid-auto-flow: column;
  grid-template-columns: 1fr auto;
  letter-spacing: var(--letter-spacing);
  line-height: 1.4em;
  transition:
    background var(--transition),
    box-shadow var(--transition)
  ;
}

.newsletter__container form input,
.newsletter__container form button {
  display: flex;
  padding: 0.5625em 0.95em 0.65em 0.95em;
  user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
}

.newsletter__container form input {
  appearance: none;
  border: none;
  flex: 1;
  padding-right: 0;
  transition: color var(--transition);
  vertical-align: middle;
}

.newsletter__container form input::placeholder {
  color: rgba(var(--rgb-black), 0.35);
  transition: color var(--transition);
}

.newsletter__container form input:focus::placeholder {
  color: transparent;
}

.newsletter__container form button {
  cursor: pointer;
  font-weight: 600;
  transition: color var(--transition);
}

.newsletter__container form:has(input:placeholder-shown) {
  box-shadow:
    0 0 0 1px rgba(var(--rgb-black), 0.1),
    0 0 0.1em 0.02em rgba(var(--rgb-black), 0.05)
  ;
}

.newsletter__container form:has(input:focus) {
  background: var(--color-white);
  box-shadow:
    0 0 0 1px rgba(var(--rgb-black), 0.85),
    0 0 0.1em 0.02em rgba(var(--rgb-black), 0.05)
  ;
}

.newsletter__container:after {
  align-items: center;
  background: url('/assets/images/general/icon-checkmark.svg') center center/0.55em auto no-repeat var(--color-green);
  border-radius: 100%;
  content: '';
  display: flex;
  font-size: var(--font-size-xx-small);
  height: 1.175em;
  justify-content: center;
  line-height: 1;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  right: -0.5875em;
  top: -0.5875em;
  transform: scale(0.5);
  transition:
    opacity var(--transition),
    transform var(--transition)
  ;
  width: 1.175em;
  will-change: transform;
}



.newsletter--page {
  margin-left: var(--space-neutral);
  margin-right: var(--space-neutral);
}

.newsletter--page .newsletter__container {
  margin-inline: auto;
}

.newsletter--success .newsletter__container:after {
  opacity: 1;
  transform: scale(1);
}

.newsletter--error .newsletter__container form {
  box-shadow:
    0 0 0 1px var(--color-red),
    0 0 0.1em 0.02em rgba(var(--rgb-black), 0.05)
  ;
}

.newsletter--error .newsletter__container form input,
.newsletter--error .newsletter__container form button {
  color: var(--color-red);
}
