/* ═══════════════════════════════════════════════════════════════════════════
   The Fathoming — Wiki Styles
══════════════════════════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Libre+Baskerville:ital,wght@0,400;0,700;1,400;1,700&display=swap');

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg: #0e130d;
  --bg-card: #1c2517;
  --bg-row: #161e13;
  --bg-row-hover: #212b1b;
  --border: rgba(255,255,255,0.1);
  --border-bright: rgba(255,255,255,0.25);
  --text: #c8d0c0;
  --text-dim: #6a7a62;
  --text-bright: #ffffff;
  --gold: #c9a84c;
  --green: #40a060;
  --red: #c04040;
  --purple: #8040c0;
  --teal: #30a0b0;
  --blue: #4a80d4;
  --font-title: 'Libre Baskerville', Georgia, serif;
  --font-body: 'Inter', system-ui, sans-serif;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  line-height: 1.6;
  min-height: 100vh;
}

a { color: var(--gold); text-decoration: none; }
a:hover { text-decoration: underline; }

/* ── Navigation ─────────────────────────────────────────────────────────── */

.wiki-nav {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 12px 32px;
  background: #111a0e;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 100;
}

.wiki-nav-logo {
  font-family: var(--font-title);
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--gold) !important;
  letter-spacing: 1.5px;
  text-decoration: none !important;
}

.wiki-nav-links {
  display: flex;
  gap: 20px;
}

.wiki-nav-links a {
  color: var(--text-dim);
  font-size: 0.9rem;
  font-weight: 500;
  text-decoration: none;
  padding: 4px 0;
  border-bottom: 2px solid transparent;
  transition: color 0.2s, border-color 0.2s;
}

.wiki-nav-links a:hover,
.wiki-nav-links a.active {
  color: var(--text-bright);
  border-bottom-color: var(--gold);
  text-decoration: none;
}

/* ── Main Layout ────────────────────────────────────────────────────────── */

.wiki-main {
  max-width: 1100px;
  margin: 0 auto;
  padding: 32px 24px 64px;
}

.wiki-main h1 {
  font-family: var(--font-title);
  font-size: 2rem;
  color: var(--text-bright);
  margin-bottom: 8px;
}

.wiki-subtitle {
  color: var(--text-dim);
  font-size: 1rem;
  margin-bottom: 40px;
}

.wiki-breadcrumb {
  font-size: 0.85rem;
  color: var(--text-dim);
  margin-bottom: 20px;
}

.wiki-breadcrumb a {
  color: var(--text-dim);
}

.wiki-breadcrumb a:hover {
  color: var(--gold);
}

/* ── Set Grid (Home) ────────────────────────────────────────────────────── */

.wiki-sets, .wiki-classes {
  margin-bottom: 40px;
}

.wiki-sets h2, .wiki-classes h2 {
  font-family: var(--font-title);
  font-size: 1.3rem;
  color: var(--text-bright);
  margin-bottom: 16px;
}

.set-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}

.set-card {
  display: block;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 24px;
  text-decoration: none !important;
  transition: border-color 0.2s, transform 0.15s;
}

.set-card:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
}

.set-card-name {
  font-family: var(--font-title);
  font-size: 1.25rem;
  color: var(--text-bright);
  margin-bottom: 4px;
}

.set-card-count {
  font-size: 1.1rem;
  color: var(--gold);
  margin-bottom: 12px;
}

.set-card-breakdown {
  display: flex;
  gap: 12px;
  font-size: 0.8rem;
  color: var(--text-dim);
}

/* ── Class Grid (Home) ──────────────────────────────────────────────────── */

.class-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.class-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  border-radius: 20px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-bright);
  text-decoration: none !important;
  border: 1px solid var(--border);
  background: var(--bg-card);
  transition: border-color 0.2s, transform 0.15s;
}

.class-pill:hover {
  border-color: var(--gold);
  transform: translateY(-1px);
}

.class-pill-icon {
  width: 20px;
  height: 20px;
  filter: invert(1);
}

/* ── Set Summary ────────────────────────────────────────────────────────── */

.set-summary {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  margin-bottom: 32px;
  font-size: 0.9rem;
}

.set-summary-total {
  color: var(--gold);
  font-weight: 700;
  font-size: 1rem;
}

.set-summary-stat {
  color: var(--text-dim);
}

/* ── Card Table ─────────────────────────────────────────────────────────── */

.card-section {
  margin-bottom: 40px;
}

.card-section h2 {
  font-family: var(--font-title);
  font-size: 1.2rem;
  color: var(--text-bright);
  margin-bottom: 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

.card-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.85rem;
}

.card-table thead {
  position: sticky;
  top: 49px;
  z-index: 10;
}

.card-table th {
  text-align: left;
  padding: 8px 10px;
  background: #111a0e;
  color: var(--text-dim);
  font-weight: 600;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border);
}

.card-table td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  vertical-align: middle;
}

.card-row {
  cursor: pointer;
  transition: background 0.15s;
}

.card-row:hover {
  background: var(--bg-row-hover);
}

.card-row:hover .col-name a {
  color: var(--text-bright);
}

.col-img { width: 48px; }
.col-name { font-weight: 600; }
.col-name a { color: var(--text); text-decoration: none; }
.col-class { width: 110px; }
.col-cost { width: 50px; text-align: center; }
.col-stat { width: 50px; text-align: center; }
.col-ability-type { width: 100px; }
.col-ability-text { color: var(--text-dim); font-size: 0.8rem; max-width: 320px; }

.card-thumb {
  width: 40px;
  height: 56px;
  object-fit: cover;
  object-position: center 18%;
  border-radius: 4px;
  border: 1px solid var(--border);
}

/* ── Class Badge ────────────────────────────────────────────────────────── */

.class-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 10px;
  font-size: 0.75rem;
  font-weight: 600;
  background: rgba(255,255,255,0.06);
  color: var(--text);
  white-space: nowrap;
}

.class-badge-icon {
  width: 14px;
  height: 14px;
  filter: invert(1);
}

/* Class-specific badge colors */
.class-fairy     { background: rgba(200,180,255,0.12); color: #d0b8ff; }
.class-goblin    { background: rgba(180,150,100,0.15); color: #c8a878; }
.class-human     { background: rgba(180,180,180,0.12); color: #b0b0b0; }
.class-mermaid   { background: rgba(100,200,220,0.12); color: #80d0e0; }
.class-pixie     { background: rgba(255,200,100,0.12); color: #ffd070; }
.class-vampire   { background: rgba(220,100,100,0.12); color: #e08080; }
.class-werewolf  { background: rgba(220,140,60,0.15); color: #e0a050; }
.class-wiccan    { background: rgba(80,180,100,0.12); color: #70c080; }
.class-divine    {
  background: linear-gradient(135deg, rgba(255,100,100,0.15), rgba(255,200,50,0.15), rgba(100,255,100,0.15), rgba(100,150,255,0.15), rgba(200,100,255,0.15));
  color: #fff;
  text-shadow: 0 0 6px rgba(255,200,100,0.4);
}
.class-action    { background: rgba(100,180,200,0.12); color: #80c0d0; }
.class-item      { background: rgba(200,180,100,0.12); color: #d0c070; }

/* ── Ability Badge ──────────────────────────────────────────────────────── */

.ability-badge {
  display: inline-block;
  padding: 2px 8px;
  border-radius: 8px;
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
  white-space: nowrap;
}

.ability-constant    { background: rgba(64,160,96,0.2); color: #60c080; }
.ability-when-played { background: rgba(74,128,212,0.2); color: #6aa0e4; }
.ability-activate    { background: rgba(200,168,76,0.2); color: #d0b850; }
.ability-action      { background: rgba(48,160,176,0.2); color: #50c0d0; }
.ability-on-destroyed { background: rgba(192,64,64,0.2); color: #e06060; }
.ability-on-attack   { background: rgba(220,120,40,0.2); color: #e09040; }
.ability-on-attacked { background: rgba(180,80,180,0.2); color: #d080d0; }
.ability-item        { background: rgba(200,180,100,0.2); color: #d0c070; }
.ability-equip       { background: rgba(200,180,100,0.2); color: #d0c070; }
.ability-none        { background: rgba(255,255,255,0.04); color: var(--text-dim); }

/* ── Card Detail Page ───────────────────────────────────────────────────── */

.card-detail {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 40px;
  align-items: start;
}

.card-detail-image img {
  width: 100%;
  border-radius: 10px;
  border: 2px solid var(--border);
  box-shadow: 0 8px 30px rgba(0,0,0,0.5);
}

.card-detail-no-image {
  width: 100%;
  aspect-ratio: 2/3;
  background: var(--bg-card);
  border: 2px solid var(--border);
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-dim);
}

.card-detail-info h1 {
  font-size: 1.8rem;
  margin-bottom: 12px;
}

.card-detail-meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 24px;
}

.section-type-icon {
  width: 20px;
  height: 20px;
  vertical-align: middle;
  margin-right: 4px;
  filter: invert(1);
  opacity: 0.7;
}

.type-badge-icon {
  width: 14px;
  height: 14px;
  vertical-align: middle;
  margin-right: 2px;
  filter: invert(1);
}

.detail-type-badge, .detail-set-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 10px;
  font-size: 0.8rem;
  font-weight: 600;
}

.detail-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  background: rgba(255,255,255,0.08);
  color: var(--text);
}

.detail-set-badge {
  background: rgba(201,168,76,0.15);
  color: var(--gold);
}

.detail-stats-table {
  width: 100%;
  max-width: 300px;
  border-collapse: collapse;
  margin-bottom: 24px;
}

.detail-stats-table th {
  text-align: left;
  padding: 8px 12px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  border-bottom: 1px solid var(--border);
  width: 120px;
}

.detail-stats-table td {
  padding: 8px 12px;
  font-size: 1rem;
  font-weight: 700;
  color: var(--text-bright);
  border-bottom: 1px solid var(--border);
}

.detail-ability {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 20px;
  margin-bottom: 28px;
}

.detail-ability-header {
  margin-bottom: 8px;
}

.detail-ability-text {
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.6;
}

/* ── Card Navigation (Prev / Next) ──────────────────────────────────────── */

.card-nav {
  display: flex;
  justify-content: space-between;
  gap: 16px;
}

.card-nav-link {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--bg-card);
  text-decoration: none !important;
  font-size: 0.85rem;
  color: var(--text);
  transition: border-color 0.2s;
  max-width: 48%;
}

.card-nav-link:hover {
  border-color: var(--gold);
}

.card-nav-disabled {
  visibility: hidden;
}

.card-nav-thumb {
  width: 32px;
  height: 44px;
  object-fit: cover;
  object-position: center 18%;
  border-radius: 3px;
  flex-shrink: 0;
}

.card-nav-next {
  margin-left: auto;
  text-align: right;
}

/* ── Card Grid (Class Page) ─────────────────────────────────────────────── */

.class-header {
  display: flex;
  align-items: center;
  gap: 16px;
  margin-bottom: 12px;
}

.class-header-icon {
  width: 48px;
  height: 48px;
  filter: invert(1);
}

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 12px;
}

.card-grid-item {
  display: block;
  text-decoration: none !important;
  border-radius: 8px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-card);
  transition: border-color 0.2s, transform 0.15s;
}

.card-grid-item:hover {
  border-color: var(--gold);
  transform: translateY(-3px);
}

.card-grid-item img {
  width: 100%;
  aspect-ratio: 2/3;
  object-fit: cover;
  object-position: center 18%;
  display: block;
}

.card-grid-fallback {
  width: 100%;
  aspect-ratio: 2/3;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-size: 0.8rem;
  color: var(--text-dim);
  padding: 8px;
}

.card-grid-name {
  padding: 6px 8px 2px;
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--text-bright);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.card-grid-meta {
  padding: 0 8px 6px;
  font-size: 0.7rem;
  color: var(--text-dim);
}

/* ── Rules Page ─────────────────────────────────────────────────────────── */

.rules-content h2 {
  font-family: var(--font-title);
  font-size: 1.3rem;
  color: var(--text-bright);
  margin: 32px 0 12px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}

.rules-content h3 {
  font-size: 1rem;
  color: var(--gold);
  margin: 20px 0 8px;
}

.rules-content p, .rules-content li {
  margin-bottom: 8px;
  line-height: 1.7;
}

.rules-content ul, .rules-content ol {
  padding-left: 24px;
  margin-bottom: 16px;
}

.rules-content table {
  width: 100%;
  border-collapse: collapse;
  margin: 12px 0 20px;
}

.rules-content th, .rules-content td {
  padding: 8px 12px;
  border: 1px solid var(--border);
  text-align: left;
}

.rules-content th {
  background: var(--bg-card);
  color: var(--text-bright);
  font-weight: 600;
}

/* ── Changelog ──────────────────────────────────────────────────────────── */

.changelog-entry {
  border-left: 3px solid var(--accent, #c8a84b);
  padding-left: 20px;
  margin-bottom: 40px;
}

.changelog-date {
  font-size: 0.8rem;
  color: var(--text-dim);
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin-bottom: 4px;
}

/* ── Footer ─────────────────────────────────────────────────────────────── */

.wiki-footer {
  text-align: center;
  padding: 24px;
  color: var(--text-dim);
  font-size: 0.8rem;
  border-top: 1px solid var(--border);
}

/* ── Mobile ─────────────────────────────────────────────────────────────── */

@media (max-width: 768px) {
  .wiki-nav {
    padding: 10px 16px;
    gap: 16px;
  }

  .wiki-nav-logo { font-size: 0.9rem; }

  .wiki-main {
    padding: 20px 16px 48px;
  }

  .wiki-main h1 { font-size: 1.5rem; }

  .card-detail {
    grid-template-columns: 1fr;
    gap: 24px;
  }

  .card-detail-image img {
    max-width: 280px;
    margin: 0 auto;
    display: block;
  }

  /* Scroll table horizontally */
  .card-table { font-size: 0.75rem; }
  .card-section { overflow-x: auto; }
  .col-ability-text { max-width: 200px; }

  .card-grid {
    grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
    gap: 8px;
  }

  .card-nav-link { font-size: 0.75rem; padding: 6px 8px; }
  .card-nav-thumb { width: 24px; height: 33px; }
}
