/* Modal styles */
body.command-palette-open {
  overflow: hidden;
}

#modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.55);
  z-index: 1000;
  align-items: center;
  justify-content: center;
}
#modal-overlay.open {
  display: flex;
}

#batch-modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.62);
  z-index: 1010;
  align-items: center;
  justify-content: center;
}

#batch-modal-overlay.open {
  display: flex;
}

#command-palette-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.62);
  z-index: 1020;
  align-items: flex-start;
  justify-content: center;
  padding: 8vh 20px 20px;
}

#command-palette-overlay.open {
  display: flex;
}

#modal {
  background: var(--modal-bg);
  border-radius: 8px;
  width: 680px;
  max-width: 95vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.2);
  border: 1px solid var(--modal-border);
}

#batch-modal {
  background: var(--modal-bg);
  border-radius: 12px;
  width: 760px;
  max-width: 95vw;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  border: 1px solid var(--modal-border);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.35);
  overflow: hidden;
}

#command-palette {
  width: min(720px, 100%);
  max-height: min(72vh, 760px);
  display: flex;
  flex-direction: column;
  background: var(--modal-bg);
  border: 1px solid var(--modal-border);
  border-radius: 14px;
  box-shadow: var(--glass-shadow-heavy);
  overflow: hidden;
}

#modal-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--modal-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#batch-modal-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--modal-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
}

#command-palette-header {
  padding: 16px 18px 12px;
  border-bottom: 1px solid var(--modal-border);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}

#batch-modal-header h2 {
  font-size: 16px;
  color: var(--modal-title);
}
#modal-header h2 {
  font-size: 16px;
  color: var(--modal-title);
}

#command-palette-title {
  font-size: 16px;
  font-weight: 700;
  color: var(--modal-title);
}

#command-palette-subtitle {
  margin-top: 4px;
  font-size: 12px;
  color: var(--text-secondary);
}

#modal-close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--modal-close);
  line-height: 1;
}
#batch-modal-close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--modal-close);
  line-height: 1;
}

#command-palette-close {
  background: none;
  border: none;
  font-size: 20px;
  cursor: pointer;
  color: var(--modal-close);
  line-height: 1;
}

#modal-close:hover {
  color: var(--modal-close-hover);
}
#batch-modal-close:hover {
  color: var(--modal-close-hover);
}
#command-palette-close:hover {
  color: var(--modal-close-hover);
}

#modal-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
  overflow: hidden;
}

#batch-modal-body {
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  flex: 1;
  min-height: 0;
  overflow: auto;
}

#command-palette-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 16px 18px 18px;
  min-height: 0;
}

#modal-body label {
  font-size: 13px;
  font-weight: 600;
  color: var(--modal-label);
  display: block;
  margin-bottom: 5px;
}

#batch-modal-body label {
  font-size: 13px;
  font-weight: 600;
  color: var(--modal-label);
  display: block;
  margin-bottom: 6px;
}

#spec-name-input,
#source-url-input,
#command-palette-input {
  width: 100%;
  padding: 9px 12px;
  background: var(--modal-input-bg);
  color: var(--modal-input);
  border: 1px solid var(--modal-input-border);
  border-radius: 4px;
  font-size: 14px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.spec-source-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  font-size: 12px;
  color: var(--text-secondary);
  padding: 10px 12px;
  border: 1px solid var(--modal-input-border);
  border-radius: 6px;
  background: rgba(59, 130, 246, 0.05);
}
#spec-name-input:focus,
#source-url-input:focus,
#command-palette-input:focus {
  border-color: var(--modal-textarea-border-focus);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.3);
}

.command-palette-input-row {
  display: flex;
}

#command-palette-results {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
  max-height: 50vh;
  overflow: auto;
}

.command-palette-section {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.command-palette-section-title {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-secondary);
  padding: 0 4px;
}

.command-palette-section-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.command-palette-option {
  width: 100%;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  text-align: left;
  background: transparent;
  color: var(--text);
  border: 1px solid var(--modal-input-border);
  border-radius: 10px;
  cursor: pointer;
  transition: border-color 0.18s, background 0.18s;
}

.command-palette-option:hover,
.command-palette-option.active {
  border-color: var(--accent);
  background: rgba(59, 130, 246, 0.09);
}

.command-palette-option-main {
  min-width: 0;
}

.command-palette-option-label {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
  overflow-wrap: anywhere;
}

.command-palette-option-description {
  margin-top: 3px;
  font-size: 12px;
  color: var(--text-secondary);
}

.command-palette-breadcrumb {
  color: var(--text-secondary);
}

.command-palette-meta {
  flex-shrink: 0;
  font-size: 11px;
  color: var(--text-secondary);
  padding: 3px 6px;
  border-radius: 999px;
  border: 1px solid var(--modal-input-border);
  background: var(--modal-input-bg);
}

#command-palette-empty {
  font-size: 13px;
  color: var(--text-secondary);
  padding: 24px 6px 10px;
}

.source-url-group {
  display: flex;
  gap: 8px;
}
.source-url-group #source-url-input {
  flex: 1;
}

#fetch-url-btn {
  padding: 9px 14px;
  background: var(--modal-import-bg);
  color: var(--modal-import);
  border: 1px solid var(--modal-import-border);
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  white-space: nowrap;
  transition: background 0.15s;
}
#fetch-url-btn:hover {
  background: var(--modal-import-hover);
}

#modal-editor-container {
  width: 100%;
  flex: 1;
  min-height: 320px;
  background: var(--modal-input-bg);
  color: var(--modal-input);
  border: 1px solid var(--modal-input-border);
  border-radius: 4px;
  font-family: 'Consolas', 'Monaco', monospace;
  font-size: 13px;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}
#modal-editor-container:focus, #modal-editor-container.ace_focus {
  border-color: var(--modal-textarea-border-focus);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.3);
}

#modal-footer {
  padding: 14px 20px;
  border-top: 1px solid var(--modal-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

#batch-modal-footer {
  padding: 14px 20px;
  border-top: 1px solid var(--modal-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

#modal-error {
  font-size: 13px;
  color: var(--modal-error);
  flex: 1;
}

#batch-modal-error {
  font-size: 13px;
  color: var(--modal-error);
  flex: 1;
}

.modal-btn {
  padding: 9px 20px;
  border-radius: 4px;
  border: none;
  cursor: pointer;
  font-size: 14px;
  font-weight: 500;
  transition: background 0.15s;
}
.modal-btn.secondary {
  background: var(--modal-secondary-bg);
  color: var(--modal-secondary);
}
.modal-btn.secondary:hover {
  background: var(--modal-secondary-hover);
}
.modal-btn.primary {
  background: var(--accent);
  color: #fff;
}
.modal-btn.primary:hover {
  background: var(--accent-hover);
}

#import-btn {
  padding: 7px 14px;
  background: var(--modal-import-bg);
  color: var(--modal-import);
  border: 1px solid var(--modal-import-border);
  border-radius: 4px;
  cursor: pointer;
  font-size: 13px;
  transition: background 0.15s;
}
#import-btn:hover {
  background: var(--modal-import-hover);
}
#file-input {
  display: none;
}

#batch-file-input {
  display: none;
}

.batch-step {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-height: 0;
}

.batch-step[hidden] {
  display: none !important;
}

.batch-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.batch-inline-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.batch-hint {
  font-size: 12px;
  color: var(--text-secondary);
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.batch-pill {
  display: inline-flex;
  align-items: center;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(59, 130, 246, 0.12);
  border: 1px solid rgba(59, 130, 246, 0.24);
}

.batch-textarea {
  width: 100%;
  min-height: 140px;
  resize: vertical;
  padding: 12px;
  background: var(--modal-input-bg);
  color: var(--modal-input);
  border: 1px solid var(--modal-input-border);
  border-radius: 8px;
  font: inherit;
}

.batch-summary-card {
  padding: 14px 16px;
  border-radius: 10px;
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid rgba(59, 130, 246, 0.16);
  line-height: 1.5;
  color: var(--text);
}

.batch-scroll-panel {
  overflow: auto;
  border: 1px solid var(--modal-input-border);
  border-radius: 10px;
  padding: 10px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: rgba(255, 255, 255, 0.02);
  min-height: 0;
}

.batch-scroll-panel.subtle {
  max-height: 180px;
}

.batch-review-item {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border-radius: 10px;
  border: 1px solid var(--modal-input-border);
  background: rgba(255, 255, 255, 0.02);
}

.batch-review-item.failure {
  border-color: rgba(248, 113, 113, 0.35);
  background: rgba(248, 113, 113, 0.08);
}

.batch-review-copy {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

.batch-review-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
}

.batch-review-meta {
  font-size: 12px;
  color: var(--text-secondary);
}

.batch-select {
  min-width: 130px;
  align-self: center;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid var(--modal-input-border);
  background: var(--modal-input-bg);
  color: var(--modal-input);
}

.batch-empty-subtle {
  font-size: 12px;
  color: var(--text-secondary);
  padding: 8px 4px;
}

.batch-footer-actions {
  display: flex;
  gap: 10px;
}

@media (max-width: 768px) {
  #batch-modal {
    width: 95vw;
  }

  #command-palette-overlay {
    padding: 14px;
  }

  #command-palette {
    width: 100%;
    max-height: calc(100vh - 28px);
  }

  .batch-review-item,
  #batch-modal-footer,
  .batch-inline-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .batch-select {
    width: 100%;
  }
}
