/* =========================================================
   Fancy Text Generator — tool-specific styles.
   Layered on /tools/_shared/tool.css.
   ========================================================= */

/* ---------- Input ---------- */
.fancy-input { margin-bottom: var(--space-6); }

.fancy-input textarea {
  width: 100%;
  resize: vertical;
  min-height: 80px;
  padding: var(--space-4);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface-inset);
  color: var(--text);
  font: inherit;
  font-size: 16px;
  line-height: 1.55;
  transition: var(--transition-colors);
}
.fancy-input textarea::placeholder { color: var(--text-subtle); }
.fancy-input textarea:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-ring);
}

/* ---------- Styles list ---------- */
.styles-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.style-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
  padding: var(--space-4);
  background: var(--surface-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  transition: var(--transition-colors);
}
@media (min-width: 520px) {
  .style-row {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: var(--space-4);
  }
}

.style-name {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-muted);
}

.style-output {
  display: block;
  font-size: 17px;
  color: var(--text);
  line-height: 1.4;
  word-break: break-word;
  user-select: all;
  min-height: 24px;
  margin-top: 2px;
}

.style-info {
  min-width: 0;
}

.style-copy {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  min-height: 36px;
  padding: var(--space-2) var(--space-4);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
  font-size: 13px;
  font-weight: 600;
  background: var(--surface);
  color: var(--text);
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease,
              border-color 0.15s ease, transform 0.06s ease;
  flex-shrink: 0;
}
.style-copy:hover {
  border-color: var(--accent);
  color: var(--accent);
}
.style-copy:active { transform: translateY(1px); }
.style-copy.is-success {
  background: var(--success);
  color: var(--success-fg);
  border-color: var(--success);
}
.style-copy .icon { width: 14px; height: 14px; }
