/* API Keys page
   ------------------------------------------------------------ */

.api-keys-page {
  max-width: 960px;
}

.page-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1.5rem;
}

.page-header h1 {
  margin-bottom: 0.25rem;
}

.page-subtext {
  color: var(--text-muted);
  font-size: 0.95rem;
}

.page-header-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

/* Buttons extending global .btn */

.btn-secondary {
  border: 1px solid var(--outline);
  background: var(--bg-muted);
  color: var(--text);
}

.btn-secondary:hover {
  border-color: var(--primary);
}

.btn-inline {
  padding-inline: 0.9rem;
  font-size: 0.9rem;
}

/* Primary API key card */

.api-key-section {
  margin-top: 2rem;
}

.api-key-card {
  background: var(--card);
  border-radius: var(--radius-lg);
  border: 1px solid var(--outline);
  padding: 1.75rem;
  box-shadow: 0 0 16px rgba(0, 0, 0, 0.4);
}

.api-key-card-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 1rem;
  margin-bottom: 1.25rem;
}

.api-key-card h2 {
  margin-bottom: 0.25rem;
}

.muted {
  color: var(--text-muted);
  font-size: 0.9rem;
}

/* Status pill */

.status-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.2rem 0.65rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 600;
  border: 1px solid transparent;
}

.status-pill--live {
  background: rgba(0, 200, 120, 0.1);
  color: #48e0a2;
  border-color: rgba(0, 200, 120, 0.45);
}

/* Key row */

.field-label {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 0.35rem;
}

.api-key-row {
  display: flex;
  align-items: stretch;
  gap: 0.6rem;
  margin-bottom: 1rem;
}

.api-key-input {
  flex: 1;
  border-radius: var(--radius);
  border: 1px solid var(--outline);
  background: var(--bg-muted);
  color: var(--text);
  padding: 0.75rem 0.85rem;
  font-family: var(--font-mono, monospace);
  font-size: 0.92rem;
  letter-spacing: 0.04em;
}

.api-key-input:focus-visible {
  outline: 1px solid var(--primary);
  outline-offset: 1px;
}

/* Meta row */

.api-key-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 1.25rem;
  margin-bottom: 1.25rem;
}

.meta-label {
  display: block;
  font-size: 0.8rem;
  color: var(--text-muted);
  margin-bottom: 0.1rem;
}

.meta-value {
  font-size: 0.9rem;
}

/* Warning */

.api-key-warning {
  margin-top: 0.5rem;
  padding: 0.85rem 1rem;
  border-radius: var(--radius);
  background: rgba(255, 102, 0, 0.08);
  border: 1px solid rgba(255, 102, 0, 0.5);
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.warning-icon {
  min-width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, 0.35);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
}

/* Secondary cards */

.api-keys-secondary {
  margin-top: 2rem;
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr);
  gap: 1.25rem;
}

.info-card {
  background: var(--bg-muted);
  border-radius: var(--radius-lg);
  border: 1px solid var(--outline);
  padding: 1.25rem 1.5rem;
}

.info-card h3 {
  margin-bottom: 0.4rem;
}

.info-card ul {
  margin-top: 0.4rem;
  padding-left: 1.1rem;
  color: var(--text-muted);
  font-size: 0.9rem;
}

/* ------------------------------------------------------------
   MOBILE FIXES
------------------------------------------------------------ */

@media (max-width: 820px) {

  .page-header {
    flex-direction: column;
    align-items: flex-start;
  }

  /* STACK input + buttons to prevent overlap */
  .api-key-row {
    flex-direction: column;
    align-items: stretch;
  }

  .api-key-row button {
    width: 100%;
  }

  .api-keys-secondary {
    grid-template-columns: minmax(0, 1fr);
  }
}
