/* sql-formatter — tool-specific styles */

/* ── Code input area ── */
.evvy-sql-input-wrap {
  position: relative;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  overflow: hidden;
  background: var(--evvy-surface, #fff);
}
.evvy-sql-input-wrap:focus-within {
  border-color: var(--cluster-dark, #1A2333);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--cluster-dark) 12%, transparent);
}
.evvy-sql-textarea {
  width: 100%;
  min-height: 200px;
  max-height: 420px;
  padding: 0.875rem 1rem 0.875rem 3.5rem;
  border: none;
  outline: none;
  resize: vertical;
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--evvy-text-primary, #333);
  background: transparent;
  tab-size: 4;
  white-space: pre;
  overflow-wrap: normal;
  overflow-x: auto;
}
.evvy-sql-textarea::placeholder {
  color: var(--evvy-text-tertiary, #aaa);
}
.evvy-sql-line-numbers {
  position: absolute;
  top: 0;
  left: 0;
  width: 3rem;
  padding: 0.875rem 0.5rem 0.875rem 0;
  text-align: right;
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--evvy-text-tertiary, #aaa);
  user-select: none;
  pointer-events: none;
  border-right: 1px solid var(--evvy-border-color, #DEE2E6);
  background: color-mix(in srgb, var(--cluster-dark) 3%, transparent);
  overflow: hidden;
}

/* ── Dialect chip row ── */
.evvy-sql-options-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.75rem;
  align-items: flex-start;
  margin-top: 0.25rem;
}
.evvy-sql-options-row .evvy-input-section {
  margin-bottom: 0;
}

/* ── Collapsible format options ── */
.evvy-sql-format-options {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
  padding: 0.875rem 1rem;
  margin-top: 0.5rem;
  background: color-mix(in srgb, var(--cluster-dark) 3%, transparent);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
}
.evvy-sql-format-options.evvy-collapsed {
  display: none;
}
.evvy-sql-format-options .evvy-input-label {
  font-size: 0.75rem;
  margin-bottom: 0.25rem;
}
.evvy-sql-format-options select {
  font-size: 0.8125rem;
  padding: 0.35rem 0.5rem;
  border-radius: var(--evvy-radius-sm, 6px);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  background: var(--evvy-surface, #fff);
  color: var(--evvy-text-primary, #333);
}

/* ── Action button row ── */
.evvy-sql-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
  flex-wrap: wrap;
}
.evvy-sql-actions .btn {
  min-width: 100px;
}

/* ── Output area ── */
.evvy-sql-output-wrap {
  position: relative;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  overflow: hidden;
  background: var(--evvy-surface, #fff);
  margin-top: 1rem;
}
.evvy-sql-output-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.5rem 1rem;
  border-bottom: 1px solid var(--evvy-border-color, #DEE2E6);
  background: color-mix(in srgb, var(--cluster-dark) 3%, transparent);
}
.evvy-sql-output-header .evvy-chip {
  padding: 0.15rem 0.5rem;
  font-size: 0.6875rem;
}
.evvy-sql-output-title {
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--evvy-text-secondary, #666);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.evvy-sql-copy-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.25rem 0.6rem;
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--evvy-text-secondary, #666);
  background: transparent;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-sm, 6px);
  cursor: pointer;
  transition: all 0.15s ease;
}
.evvy-sql-copy-btn:hover {
  background: color-mix(in srgb, var(--cluster-dark) 8%, transparent);
  color: var(--evvy-text-primary, #333);
}
.evvy-sql-output-body {
  padding: 0.875rem 1rem 0.875rem 3.5rem;
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 0.8125rem;
  line-height: 1.6;
  white-space: pre;
  overflow-x: auto;
  overflow-y: auto;
  max-height: 500px;
  min-height: 60px;
  color: var(--evvy-text-primary, #333);
  position: relative;
}
.evvy-sql-output-lines {
  position: absolute;
  top: 0;
  left: 0;
  width: 3rem;
  padding: 0.875rem 0.5rem 0.875rem 0;
  text-align: right;
  font-family: 'SFMono-Regular', Consolas, 'Liberation Mono', Menlo, monospace;
  font-size: 0.8125rem;
  line-height: 1.6;
  color: var(--evvy-text-tertiary, #aaa);
  user-select: none;
  pointer-events: none;
  border-right: 1px solid var(--evvy-border-color, #DEE2E6);
  background: color-mix(in srgb, var(--cluster-dark) 3%, transparent);
}

/* ── Syntax highlighting ── */
.evvy-sql-kw { color: #7c3aed; font-weight: 600; }
.evvy-sql-fn { color: #0891b2; }
.evvy-sql-str { color: #16a34a; }
.evvy-sql-num { color: #ea580c; }
.evvy-sql-op { color: #64748b; }
.evvy-sql-comment { color: #94a3b8; font-style: italic; }
.evvy-sql-ident { color: var(--evvy-text-primary, #333); }

/* ── Toggle tabs (formatted / original) ── */
.evvy-sql-view-toggle {
  display: inline-flex;
  gap: 0.25rem;
}

/* ── Issue detection card ── */
.evvy-sql-issues {
  margin-top: 0.75rem;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  overflow: hidden;
}
.evvy-sql-issues-header {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 1rem;
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--evvy-text-primary, #333);
  background: color-mix(in srgb, var(--cluster-dark) 3%, transparent);
  border-bottom: 1px solid var(--evvy-border-color, #DEE2E6);
}
.evvy-sql-issues-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.evvy-sql-issues-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.5rem 1rem;
  font-size: 0.8125rem;
  color: var(--evvy-text-secondary, #666);
  border-bottom: 1px solid var(--evvy-border-color, #DEE2E6);
}
.evvy-sql-issues-list li:last-child {
  border-bottom: none;
}
.evvy-sql-issue-icon {
  flex-shrink: 0;
  margin-top: 0.1rem;
}
.evvy-sql-issue-warn { color: #f59e0b; }
.evvy-sql-issue-info { color: #3b82f6; }
.evvy-sql-no-issues {
  padding: 0.75rem 1rem;
  font-size: 0.8125rem;
  color: #22c55e;
  display: flex;
  align-items: center;
  gap: 0.4rem;
}

/* ── Stats card ── */
.evvy-sql-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0.5rem;
  margin-top: 0.75rem;
}
.evvy-sql-stat {
  text-align: center;
  padding: 0.6rem 0.5rem;
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  background: var(--evvy-surface, #fff);
}
.evvy-sql-stat-value {
  font-size: 1.25rem;
  font-weight: 700;
  color: var(--evvy-text-primary, #333);
  line-height: 1.2;
}
.evvy-sql-stat-label {
  font-size: 0.6875rem;
  color: var(--evvy-text-secondary, #666);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 0.15rem;
}

/* ── Premium: Explain / Complexity / Performance ── */
.evvy-sql-explain {
  margin-top: 0.75rem;
}
.evvy-sql-explain-title {
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--evvy-text-primary, #333);
  margin-bottom: 0.4rem;
}
.evvy-sql-complexity-bar {
  height: 8px;
  border-radius: 4px;
  background: var(--evvy-border-color, #DEE2E6);
  overflow: hidden;
  margin: 0.5rem 0 0.25rem;
}
.evvy-sql-complexity-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.5s ease;
}
.evvy-sql-complexity-low { background: #22c55e; }
.evvy-sql-complexity-medium { background: #f59e0b; }
.evvy-sql-complexity-high { background: #ef4444; }

.evvy-sql-perf-list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.evvy-sql-perf-list li {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  padding: 0.4rem 0;
  font-size: 0.8125rem;
  color: var(--evvy-text-secondary, #666);
}

/* ── Callout ── */
.evvy-sql-callout {
  background: color-mix(in srgb, var(--cluster-dark) 6%, transparent);
  border: 1px solid var(--evvy-border-color, #DEE2E6);
  border-radius: var(--evvy-radius-lg, 12px);
  padding: 0.875rem 1rem;
  margin-top: 1rem;
  font-size: 0.8125rem;
  color: var(--evvy-text-secondary, #666);
  line-height: 1.55;
}
.evvy-sql-callout strong {
  color: var(--evvy-text-primary, #333);
}

/* ── Toggle options link ── */
.evvy-sql-toggle-opts {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  color: var(--evvy-text-secondary, #666);
  cursor: pointer;
  background: none;
  border: none;
  padding: 0.25rem 0;
  transition: color 0.15s ease;
}
.evvy-sql-toggle-opts:hover {
  color: var(--evvy-text-primary, #333);
}
.evvy-sql-toggle-opts i {
  transition: transform 0.2s ease;
}
.evvy-sql-toggle-opts.evvy-expanded i {
  transform: rotate(180deg);
}

/* ── Dark mode ── */
[data-bs-theme="dark"] .evvy-sql-textarea {
  color: #e0e0e0;
}
[data-bs-theme="dark"] .evvy-sql-output-body {
  color: #e0e0e0;
}
[data-bs-theme="dark"] .evvy-sql-kw { color: #a78bfa; }
[data-bs-theme="dark"] .evvy-sql-fn { color: #22d3ee; }
[data-bs-theme="dark"] .evvy-sql-str { color: #4ade80; }
[data-bs-theme="dark"] .evvy-sql-num { color: #fb923c; }
[data-bs-theme="dark"] .evvy-sql-op { color: #94a3b8; }
[data-bs-theme="dark"] .evvy-sql-comment { color: #64748b; }
[data-bs-theme="dark"] .evvy-sql-ident { color: #e0e0e0; }
[data-bs-theme="dark"] .evvy-sql-copy-btn {
  color: #aaa;
}
[data-bs-theme="dark"] .evvy-sql-copy-btn:hover {
  color: #e0e0e0;
}
[data-bs-theme="dark"] .evvy-sql-callout {
  background: color-mix(in srgb, var(--cluster-dark) 12%, transparent);
}
[data-bs-theme="dark"] .evvy-sql-format-options select {
  background: var(--evvy-surface-dark, #1a1a2e);
  color: #e0e0e0;
  border-color: var(--evvy-border-color, #333);
}

/* ── Responsive ── */
@media (max-width: 575.98px) {
  .evvy-sql-format-options {
    grid-template-columns: 1fr;
  }
  .evvy-sql-stats {
    grid-template-columns: repeat(2, 1fr);
  }
  .evvy-sql-actions {
    flex-direction: column;
  }
  .evvy-sql-actions .btn {
    width: 100%;
  }
  .evvy-sql-options-row {
    flex-direction: column;
  }
}
