/* Password Generator (CSS) */
.pwgen {
  max-width: 680px;
  margin: 24px auto;
  padding: 16px;
  border: 1px solid #ddd;
  border-radius: 12px;
  background: #fff;
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}

.pwgen__title {
  margin: 0 0 12px;
  font-size: 22px;
}

.pwgen__controls {
  display: grid;
  gap: 12px;
}

.pwgen__row {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.pwgen__row label {
  font-weight: 600;
}

.pwgen__row input[type="number"] {
  width: 80px;
  padding: 6px 8px;
  border: 1px solid #ccc;
  border-radius: 6px;
}

.pwgen__checkboxes {
  gap: 18px;
}

.pwgen__actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.btn {
  padding: 10px 16px;
  font-size: 15px;
  border: none;
  border-radius: 8px;
  cursor: pointer;
  color: #fff;
}

.btn-primary { background-color: #007bff; }
.btn-success { background-color: #28a745; }
.btn-warn    { background-color: #ffc107; color: #111; }

.pwgen__result {
  margin-top: 18px;
  border-top: 1px solid #eee;
  padding-top: 14px;
}

.pwgen__password {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, "Liberation Mono", monospace;
  font-size: 24px;
  word-break: break-all;
  padding: 8px 10px;
  background: #f8f9fa;
  border: 1px dashed #cfd4da;
  border-radius: 8px;
  margin-bottom: 10px;
}

.pwgen__strength {
  display: grid;
  gap: 8px;
}

.pwgen__meter {
  height: 10px;
  background: #eee;
  border-radius: 999px;
  overflow: hidden;
}

.pwgen__meter-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, #ff4d4f, #ffa940, #52c41a);
  transition: width 0.25s ease;
}

.pwgen__strength-text {
  font-weight: 700;
}

/* Small screens */
@media (max-width: 480px) {
  .pwgen { padding: 12px; }
  .pwgen__password { font-size: 20px; }
}
