.newsletter-container {
  width: 100%;
}

.newsletter-container label {
  display: block;
  margin-bottom: 8px;
  color: var(--color-text-1);
}

.input-wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 8px;
  background-color: white;
  border: 1px solid white;
  border-radius: 12px;
  box-sizing: border-box;
  transition: border-color 0.4s ease-in-out;
}

.newsletter-container:hover .input-wrapper {
  border: 1px solid var(--blue);
}
.newsletter-container:focus-within .input-wrapper {
  border: 2px solid var(--blue);
}

.newsletter-container
  input:not(:focus):not(:placeholder-shown)
  + .input-wrapper {
  border: 1px solid var(--color-border-1);
}

.newsletter-container .input-wrapper.error {
  border-color: var(--color-danger);
}

.newsletter-container:hover .subscribe-btn,
.newsletter-container:focus-within .subscribe-btn {
  background-color: var(--blue);
}

.newsletter-container input,
.newsletter-container:hover input,
.newsletter-container:focus input,
.newsletter-container:focus-within input {
  border: none !important;
}

.newsletter-container
  input:not(:focus):not(:placeholder-shown)
  + .subscribe-btn {
  background-color: var(--blue);
}

.newsletter-container .input-wrapper.error {
  border-color: var(--color-danger);
}

.input-wrapper input[type="text"] {
  width: 80%;
  padding: 0 8px;
  border: none;
  border-radius: 8px;
  box-sizing: border-box;
  transition: border-color 0.4s ease-in-out;
}

.input-wrapper input[type="text"]:focus {
  outline: none;
}

.subscribe-btn {
  padding: 11px 20px;
  background-color: var(--disabled);
  color: white;
  border: none;
  border-radius: 12px;
  cursor: pointer;
  margin-left: 10px;
  transition: background-color 0.4s ease-in-out;
  display: flex;
  align-items: center;
  gap: 8px;
}

.subscribe-btn:hover {
  background-color: var(--blue);
}

.helper-error-text {
  display: block;
  margin-top: 5px;
  font-size: 12px;
  color: var(--color-danger);
  visibility: hidden;
}

.newsletter-container .input-wrapper.error + .helper-error-text {
  visibility: visible;
}
