/* Tool-specific: Bcrypt Generator
   Layout-only. All colors come from src/shared/css/base.css tokens. */

#bcrypt-generate #password-input,
#bcrypt-verify #password-verify-input,
#bcrypt-verify #hash-verify-input,
#hash-output {
  font-family: var(--font-mono, monospace);
}

/* Mode toggle — same segmented control pattern as Hash Generator. */
.bcrypt-options {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-4);
  margin-top: var(--space-4);
}

.bcrypt-options .segmented {
  display: inline-flex;
  border: 1px solid var(--color-rule);
  border-radius: var(--radius-0);
  overflow: hidden;
  background: var(--color-bg-elevated);
}

.bcrypt-options .segmented input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.bcrypt-options .segmented label {
  padding: var(--space-2) var(--space-4);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-ink-muted);
  cursor: pointer;
  border-right: 1px solid var(--color-rule);
  user-select: none;
}

.bcrypt-options .segmented label:last-of-type {
  border-right: 0;
}

.bcrypt-options .segmented input[type="radio"]:checked + label {
  background: var(--color-signal-soft);
  color: var(--color-signal);
  font-weight: 600;
}

/* Input fields */
.bcrypt-field {
  margin-top: var(--space-4);
}

.bcrypt-field label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-1);
}

.bcrypt-field input[type="password"],
.bcrypt-field input[type="text"] {
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg);
  border: 1px solid var(--color-rule);
  border-radius: var(--radius-0);
  color: var(--color-ink);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  outline: none;
  transition: border-color 120ms ease;
}

.bcrypt-field input:focus {
  border-color: var(--color-signal);
}

/* Cost factor row */
.bcrypt-options__row {
  margin-top: var(--space-4);
}

.bcrypt-cost label {
  display: block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: var(--space-1);
}

.bcrypt-cost input[type="range"] {
  width: 100%;
  margin-top: var(--space-1);
  accent-color: var(--color-signal);
}

.bcrypt-cost__display {
  display: flex;
  align-items: baseline;
  gap: var(--space-2);
  margin-top: var(--space-1);
}

.bcrypt-cost__value {
  font-family: var(--font-mono);
  font-size: var(--text-lg);
  font-weight: 700;
  color: var(--color-signal);
}

.bcrypt-cost__rounds {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-ink-faint);
}

/* Hash output textarea */
#hash-output {
  width: 100%;
  min-height: 72px;
  margin-top: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg);
  border: 1px solid var(--color-rule);
  border-radius: var(--radius-0);
  color: var(--color-ink);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  word-break: break-all;
  resize: vertical;
}

/* Busy/progress indicator — shown during worker hash/verify operations */
.busy-indicator[hidden] {
  display: none;
}
.busy-indicator {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--color-signal-soft);
  border: 1px solid var(--color-signal);
  border-radius: var(--radius-0);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  color: var(--color-signal);
}

.busy-indicator__spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid var(--color-signal);
  border-top-color: transparent;
  border-radius: 50%;
  animation: busy-spin 700ms linear infinite;
  flex-shrink: 0;
}

@keyframes busy-spin {
  to {
    transform: rotate(360deg);
  }
}

.busy-indicator__message {
  font-weight: 600;
}

/* Disabled state for inputs during busy */
.bcrypt-field input:disabled,
.bcrypt-cost input[type="range"]:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

/* Verify result panel */
#verify-result {
  margin-top: var(--space-4);
  padding: var(--space-3);
  border-radius: var(--radius-0);
  font-family: var(--font-mono);
  font-size: var(--text-sm);
}

#verify-result.verify-match {
  background: rgba(40, 167, 69, 0.1);
  border: 1px solid var(--color-signal);
  color: var(--color-signal);
}

#verify-result.verify-no-match {
  background: var(--color-signal-soft);
  border: 1px solid var(--color-signal);
  color: var(--color-signal);
}

#verify-result.verify-error {
  background: var(--color-signal-soft);
  border: 1px solid var(--color-signal);
  color: var(--color-signal);
}

.verify-result__message {
  margin: 0;
  font-weight: 600;
}

/* Actions row */
#bcrypt-generate .actions-row,
#bcrypt-verify .actions-row {
  margin-top: var(--space-4);
}

/* RTL adjustments */
[dir="rtl"] .bcrypt-cost__display {
  flex-direction: row-reverse;
}

[dir="rtl"] .bcrypt-options .segmented label {
  border-right: 0;
  border-left: 1px solid var(--color-rule);
}

[dir="rtl"] .bcrypt-options .segmented label:last-of-type {
  border-left: 0;
}
