:host { display: block; max-width: 400px; margin: 100px auto; padding: 40px; background: white; border-radius: 8px; box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1); } h1 { text-align: center; margin-bottom: 30px; color: #2c3e50; } form { display: flex; flex-direction: column; gap: 15px; } label { font-weight: 600; margin-bottom: 5px; } input { padding: 10px; border: 1px solid #ddd; border-radius: 4px; font-size: 14px; &:focus { outline: none; border-color: #3498db; } } button { padding: 12px; background: #3498db; color: white; border: none; border-radius: 4px; font-size: 16px; font-weight: 600; cursor: pointer; transition: background 0.2s; &:hover:not(:disabled) { background: #2980b9; } &:disabled { opacity: 0.6; cursor: not-allowed; } } .error { color: #e74c3c; font-size: 14px; min-height: 20px; }