/* ═══════════════════════════════════
   HashForge — Tool-specific styles
   Requires: toolbox-theme.css
   ═══════════════════════════════════ */

.result-output {
    word-break: break-all;
}

/* ── Password Generator ── */
.gen-options {
    display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-bottom: 18px;
}

.length-row {
    display: flex; align-items: center; gap: 14px; margin-bottom: 18px;
}
.length-row label {
    font-family: var(--font-mono); font-size: 11px;
    letter-spacing: 2px; text-transform: uppercase;
    color: var(--text-muted); white-space: nowrap;
}

.length-slider {
    flex: 1; -webkit-appearance: none; appearance: none;
    height: 6px; border-radius: 3px; background: var(--border); outline: none;
}
.length-slider::-webkit-slider-thumb {
    -webkit-appearance: none; width: 20px; height: 20px; border-radius: 50%;
    background: var(--accent); cursor: pointer; box-shadow: 0 0 10px var(--accent-mid);
}

.length-value {
    font-family: var(--font-mono); font-size: 1.1rem; font-weight: 700;
    color: var(--accent); min-width: 30px; text-align: center;
}

.generated-pw {
    font-size: 1.05rem; min-height: 54px; letter-spacing: 0.5px;
    border-radius: 10px; padding: 16px 18px;
}

/* ── Password Strength Test ── */
.criteria-grid { display: flex; flex-direction: column; gap: 8px; margin-top: 16px; }

.criteria-row {
    display: flex; align-items: center; gap: 10px;
    padding: 10px 14px; background: var(--bg-input);
    border: 1px solid var(--border); border-radius: 8px;
    font-size: 0.85rem; transition: all 0.3s;
}
.criteria-row.pass { border-color: #22c55e44; }
.criteria-row.fail { border-color: #ef444444; }

.criteria-icon {
    width: 22px; height: 22px; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 12px; flex-shrink: 0; transition: all 0.3s;
}
.criteria-row.pass .criteria-icon { background: #22c55e22; color: var(--success); }
.criteria-row.fail .criteria-icon { background: #ef444422; color: #ef4444; }
.criteria-text { color: var(--text-secondary); }
.criteria-row.pass .criteria-text { color: var(--text-primary); }

.time-display {
    text-align: center; padding: 20px;
    background: var(--bg-input); border: 1px solid var(--border); border-radius: 12px;
    margin-top: 16px;
}
.time-value { font-family: var(--font-mono); font-size: 1.4rem; font-weight: 700; margin-bottom: 4px; }
.time-label {
    font-family: var(--font-mono); font-size: 11px;
    color: var(--text-muted); text-transform: uppercase; letter-spacing: 2px;
}

/* ── Hash diff ── */
.diff-display {
    background: var(--bg-input); border: 1px solid var(--border); border-radius: 10px;
    padding: 16px 18px; font-family: var(--font-mono); font-size: 0.85rem;
    line-height: 1.8; word-break: break-all; margin-bottom: 12px;
}
.diff-display .diff-label {
    font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
    color: var(--text-muted); margin-bottom: 8px; display: block;
}
.diff-char-match { color: var(--text-muted); }
.diff-char-diff { color: var(--accent2); background: #ff2d7522; border-radius: 3px; padding: 1px 2px; font-weight: 700; }
.diff-char-extra { color: var(--warning); background: #f59e0b22; border-radius: 3px; padding: 1px 2px; }

.verify-summary {
    display: flex; align-items: center; gap: 12px;
    padding: 14px 20px; border-radius: 10px;
    font-family: var(--font-mono); font-size: 0.88rem; font-weight: 600;
}
.verify-summary.match { background: #22c55e11; border: 1px solid var(--success); color: var(--success); }
.verify-summary.no-match { background: #ff2d7511; border: 1px solid var(--accent2); color: var(--accent2); }
.verify-icon { font-size: 1.3rem; }

/* ── Responsive ── */
@media (max-width: 600px) {
    .gen-options { grid-template-columns: 1fr; }
}
