/* Site-specific styles for password-generator. Shared chrome (vars, base reset,
 * .btn, .topbar, .status colors, .footer) lives in /_chrome.css and is loaded
 * ahead of this file. */

.layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 360px);
  gap: 16px;
  padding: 16px;
  max-width: 1100px;
  margin: 0 auto;
}

@media (max-width: 720px) {
  .layout {
    grid-template-columns: 1fr;
  }
}

.card {
  background: var(--bg-pane);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px;
}

.card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}

.card-head label {
  font-size: 12px;
  color: var(--fg-mute);
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.card-title {
  margin: 0 0 12px;
  font-size: 12px;
  color: var(--fg-mute);
  text-transform: uppercase;
  letter-spacing: 0.6px;
  font-weight: 600;
}

/* Pwgen uses a larger button than the chrome default (13px / 8-14px) so the
 * single Generate action feels prominent. */
.btn {
  font-size: 13px;
  padding: 8px 14px;
}

.password {
  display: block;
  padding: 16px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 8px;
  font-family: var(--mono);
  font-size: 18px;
  word-break: break-all;
  min-height: 56px;
  user-select: all;
  letter-spacing: 0.5px;
  white-space: pre-wrap;
}

.password:empty::before {
  content: "—";
  color: var(--fg-mute);
  letter-spacing: 0;
}

.strength {
  margin-top: 12px;
}

.strength-bar {
  width: 100%;
  height: 6px;
  background: var(--bg-elev);
  border-radius: 4px;
  overflow: hidden;
  border: 1px solid var(--border);
}

.strength-fill {
  height: 100%;
  background: var(--err);
  transition: width 120ms ease, background 120ms ease;
}

.strength-fill.level-0 { background: var(--err); }
.strength-fill.level-1 { background: var(--err); }
.strength-fill.level-2 { background: var(--warn); }
.strength-fill.level-3 { background: var(--ok); }
.strength-fill.level-4 { background: var(--ok); }

.strength-meta {
  margin-top: 6px;
  font-family: var(--mono);
  font-size: 12px;
  color: var(--fg-mute);
}

.row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}

.row > label,
.row-label {
  font-size: 12px;
  color: var(--fg-mute);
  text-transform: uppercase;
  letter-spacing: 0.6px;
}

.length-controls {
  display: flex;
  align-items: center;
  gap: 10px;
}

.length-controls input[type="range"] {
  flex: 1;
  accent-color: var(--accent-strong);
}

.length-controls input[type="number"] {
  width: 72px;
  font-family: var(--mono);
  font-size: 14px;
  padding: 6px 8px;
  background: var(--bg-elev);
  color: var(--fg);
  border: 1px solid var(--border);
  border-radius: 6px;
}

.checks {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 14px;
}

@media (max-width: 480px) {
  .checks {
    grid-template-columns: 1fr;
  }
}

.check {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--fg);
  cursor: pointer;
}

.check input {
  accent-color: var(--accent-strong);
}

.check code {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--fg-mute);
}

/* Override of the shared .status (which is just typography) — the card layout
 * wants the status bar to span edge-to-edge inside the card. */
.status {
  padding: 10px 12px;
  border-top: 1px solid var(--border);
  margin: 12px -16px -16px;
}

.status kbd {
  font-family: var(--mono);
  font-size: 11px;
  padding: 1px 5px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: var(--bg-elev);
  color: var(--fg);
}
