/* --- Encryptcontent form: Material look --- */
.ec-form {
  max-width: 520px;
}

.ec-help {
  margin: 0 0 0.75rem 0;
  color: var(--md-default-fg-color--light);
  font-size: 0.95rem;
}

/* Input + button aligned */
.ec-row {
  display: flex;
  gap: 0.6rem;
  align-items: center;
}

/* Input matches Material surfaces */
.ec-input {
  flex: 1;
  height: 2.25rem;
  padding: 0 0.75rem;
  color: var(--md-default-fg-color);
  background: var(--md-default-bg-color);
  border: 1px solid var(--md-default-fg-color--lighter);
  border-radius: 0.35rem;
  outline: none;
}

.ec-input:focus {
  border-color: var(--md-primary-fg-color);
  box-shadow: 0 0 0 2px color-mix(in srgb, var(--md-primary-fg-color) 25%, transparent);
}

/* Button styled like a Material action */
.ec-btn {
  height: 2.25rem;
  padding: 0 1rem;
  border: 1px solid transparent;
  border-radius: 0.35rem;
  background: var(--md-primary-fg-color);
  color: var(--md-primary-bg-color);
  font-weight: 600;
  letter-spacing: 0.02em;
  cursor: pointer;
  user-select: none;
  transition: transform 120ms ease, opacity 120ms ease;
}

.ec-btn:hover {
  opacity: 0.92;
}

.ec-btn:active {
  transform: translateY(1px);
}

/* Optional: error text hook if you later wire it */
.ec-error {
  margin-top: 0.6rem;
  color: var(--md-typeset-color);
}
