body {
  font-family: Arial, sans-serif;
  margin: 0; padding: 0;
  background: #f7f9fb;
  color: #333;
}
header, footer {
  background: #3b4b61;
  color: white;
  padding: 1em;
  text-align: center;
}
header img { display: block; margin: 0 auto 10px auto; }
.btn, .btn-large {
  background: #4a90e2;
  color: white;
  padding: 10px 20px;
  border-radius: 5px;
  text-decoration: none;
}
.btn-large { font-size: 1.2em; padding: 15px 30px; margin: 10px; display: inline-block; }
.section { padding: 40px 20px; text-align: center; }
.steps { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px; }
.step {
  background: #fff;
  border: 1px solid #ccc;
  border-radius: 10px;
  padding: 20px;
  width: 250px;
  box-shadow: 0 2px 5px rgba(0,0,0,0.1);
}
.hero {
  background: linear-gradient(to right, #4a90e2, #3b4b61);
  color: white;
  text-align: center;
  padding: 60px 20px;
}
#editor, #notary-editor {
  margin: 20px;
  padding: 10px;
  border: 1px solid #ccc;
  background: white;
  min-height: 400px;
  position: relative;
}
.draggable { position: absolute; cursor: move; max-width: 200px; }
