/* public/css/taxonomy/fandom-synonyms.css */

.syn-main {
  max-width: 1120px;
  margin: 0 auto;
  padding: 10px 10px 24px;
}

.syn-title {
  margin: 10px 0 14px;
  color: var(--text, #111827);
  font-size: clamp(1.3rem, 2.5vw, 1.8rem);
  line-height: 1.2;
  font-weight: 900;
}

.syn-actions {
  margin: 0 0 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.syn-toolbar {
  margin: 0 0 14px;
  padding: 12px;
  border-radius: 14px;
  border: 1px solid var(--border-subtle, rgba(148,163,184,.5));
  background-color: var(--surface-elevated, rgba(255,255,255,.78));
  background: var(--surface-elevated, rgba(255,255,255,.78));
  backdrop-filter: blur(6px);
}

.dark-theme .syn-toolbar {
  background-color: rgba(15,23,42,.85);
  background: rgba(15,23,42,.85);
  border-color: rgba(51,65,85,.9);
}

.syn-search-form {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  margin: 0 0 8px;
}

.syn-input {
  width: 100%;
  min-width: 0;
  border-radius: 9999px;
  border: 1px solid var(--border-subtle, rgba(148,163,184,.8));
  padding: 9px 12px;
  background-color: var(--surface, #fff);
  background: var(--surface, #fff);
  color: var(--text, #111827);
  font-size: .95rem;
}

.dark-theme .syn-input {
  background-color: #020617;
  background: #020617;
  color: #e5e7eb;
  border-color: rgba(148,163,184,.9);
}

.syn-meta {
  margin: 0;
  color: var(--muted, #6b7280);
  font-size: .92rem;
}

.syn-meta strong {
  color: var(--text, #111827);
  font-weight: 800;
}

.dark-theme .syn-meta { color: #9ca3af; }
.dark-theme .syn-meta strong { color: #e5e7eb; }

.syn-alert {
  border-radius: 12px;
  padding: 10px 12px;
  margin: 0 0 12px;
  border: 1px solid transparent;
  font-size: .95rem;
}

.syn-alert--success {
  background: rgba(16,185,129,.12);
  border-color: rgba(16,185,129,.45);
  color: #065f46;
}
.syn-alert--info {
  background: rgba(59,130,246,.10);
  border-color: rgba(59,130,246,.45);
  color: #1e40af;
}
.syn-alert--error {
  background: rgba(239,68,68,.10);
  border-color: rgba(239,68,68,.45);
  color: #991b1b;
}

.dark-theme .syn-alert--success {
  background: rgba(16,185,129,.18);
  border-color: rgba(16,185,129,.55);
  color: #d1fae5;
}
.dark-theme .syn-alert--info {
  background: rgba(59,130,246,.18);
  border-color: rgba(59,130,246,.55);
  color: #dbeafe;
}
.dark-theme .syn-alert--error {
  background: rgba(239,68,68,.18);
  border-color: rgba(239,68,68,.55);
  color: #fee2e2;
}

.syn-empty-block {
  border-radius: 12px;
  border: 1px dashed var(--border-subtle, rgba(148,163,184,.65));
  padding: 16px;
  color: var(--muted, #6b7280);
  background-color: var(--surface, #fff);
  background: var(--surface, #fff);
}

.dark-theme .syn-empty-block {
  background-color: #0b1224;
  background: #0b1224;
  color: #9ca3af;
  border-color: rgba(148,163,184,.45);
}

.syn-grid {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 12px;
}

.syn-card {
  border-radius: 14px;
  border: 1px solid var(--border-subtle, rgba(148,163,184,.5));
  background-color: var(--surface-elevated, rgba(255,255,255,.82));
  background: var(--surface-elevated, rgba(255,255,255,.82));
  padding: 12px;
}

.dark-theme .syn-card {
  background-color: rgba(15,23,42,.88);
  background: rgba(15,23,42,.88);
  border-color: rgba(51,65,85,.9);
}

.syn-card__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
}

.syn-card__title {
  margin: 0;
  font-size: 1.03rem;
  color: var(--text, #111827);
  font-weight: 850;
}

.syn-count {
  font-size: .82rem;
  color: var(--muted, #6b7280);
}

.dark-theme .syn-count { color: #9ca3af; }

.syn-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.syn-chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 4px 10px;
  border-radius: 9999px;
  border: 1px solid var(--border-subtle, rgba(148,163,184,.7));
  background-color: var(--surface, #fff);
  background: var(--surface, #fff);
  color: var(--text, #111827);
  font-size: .87rem;
}

.dark-theme .syn-chip {
  background-color: #020617;
  background: #020617;
  color: #e5e7eb;
  border-color: rgba(148,163,184,.7);
}

.syn-muted {
  margin: 0;
  color: var(--muted, #6b7280);
  font-size: .92rem;
}

.dark-theme .syn-muted { color: #9ca3af; }

.syn-card__foot {
  margin-top: 10px;
}

.syn-add-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px;
  margin: 0 0 10px;
}

.syn-admin-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 8px;
}

.syn-admin-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  flex-wrap: wrap;
}

.syn-danger-btn {
  border-color: rgba(239,68,68,.45) !important;
}

.syn-pager {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.syn-page-current {
  color: var(--muted, #6b7280);
  font-size: .92rem;
}

.syn-page-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 9999px;
  text-decoration: none;
  border: 1px solid var(--border-subtle, rgba(148,163,184,.75));
  background-color: var(--surface, #fff);
  background: var(--surface, #fff);
  color: var(--text, #111827);
  font-size: .9rem;
  font-weight: 700;
}

.dark-theme .syn-page-btn {
  background-color: #020617;
  background: #020617;
  color: #e5e7eb;
  border-color: rgba(148,163,184,.75);
}

.syn-page-btn.is-disabled {
  opacity: .55;
  pointer-events: none;
}

@media (min-width: 760px) {
  .syn-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 740px) {
  .syn-search-form {
    grid-template-columns: 1fr;
  }

  .syn-add-form {
    grid-template-columns: 1fr;
  }

  .syn-admin-item {
    align-items: stretch;
  }

  .syn-admin-item form,
  .syn-admin-item .button {
    width: 100%;
  }
}