/* ============================================================
   Cards
   ============================================================ */
.card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  transition: border-color var(--transition), box-shadow var(--transition);
}

.card:hover {
  border-color: var(--color-accent);
  box-shadow: 0 0 20px rgba(198, 40, 40, 0.1);
}

.card--link {
  display: block;
  text-decoration: none;
  color: inherit;
}

.card--link:hover {
  text-decoration: none;
  color: inherit;
}

.card__title {
  font-family: var(--font-title);
  font-size: 1.1rem;
  margin-bottom: var(--space-sm);
  letter-spacing: 0.02em;
}

.card__meta {
  color: var(--color-text-muted);
  font-size: 0.875rem;
}

/* Card grid */
.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-md);
}

/* ============================================================
   Type badges
   ============================================================ */
.badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

.badge--type-projectile { background: rgba(249, 115, 22, 0.15); color: var(--color-type-projectile); border: 1px solid rgba(249,115,22,0.3); }
.badge--type-aoe        { background: rgba(168, 85, 247, 0.15); color: var(--color-type-aoe);        border: 1px solid rgba(168,85,247,0.3); }
.badge--type-selfeffect { background: rgba(34, 211, 238, 0.15); color: var(--color-type-selfeffect); border: 1px solid rgba(34,211,238,0.3); }
.badge--type-beam       { background: rgba(234, 179,   8, 0.15); color: var(--color-type-beam);      border: 1px solid rgba(234,179,8,0.3); }
.badge--type-pillar     { background: rgba(132, 204,  22, 0.15); color: var(--color-type-pillar);    border: 1px solid rgba(132,204,22,0.3); }

.badge--severity-minor    { background: rgba(251,191,36,0.15);  color: var(--color-severity-minor);    border: 1px solid rgba(251,191,36,0.3); }
.badge--severity-major    { background: rgba(249,115,22,0.15);  color: var(--color-severity-major);    border: 1px solid rgba(249,115,22,0.3); }
.badge--severity-critical { background: rgba(248,113,113,0.15); color: var(--color-severity-critical); border: 1px solid rgba(248,113,113,0.3); }

.badge--cc      { background: rgba(198,40,40,0.15);  color: var(--color-accent-2);  border: 1px solid rgba(198,40,40,0.3); }
.badge--danger  { background: rgba(244,67,54,0.12);  color: var(--color-danger);    border: 1px solid rgba(244,67,54,0.3); }
.badge--success { background: rgba(76,175,80,0.12);  color: var(--color-success);   border: 1px solid rgba(76,175,80,0.3); }
.badge--status  { background: var(--color-surface-2); color: var(--color-text-muted); border: 1px solid var(--color-border); }

/* ============================================================
   Tag chips
   ============================================================ */
.tags {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-xs);
  margin-top: var(--space-sm);
}

.tag {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  padding: 2px 8px;
  border-radius: 100px;
  background: var(--color-surface-2);
  color: var(--color-text-muted);
  border: 1px solid var(--color-border);
  transition: all var(--transition);
}

.tag--spell {
  color: var(--color-accent-2);
  border-color: rgba(198, 40, 40, 0.3);
}

.tag--spell:hover {
  color: var(--color-gold);
  border-color: var(--color-gold);
  background: var(--color-gold-glow);
  text-decoration: none;
}

/* ============================================================
   Stats table
   ============================================================ */
.stats-table-wrapper {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-top: 3px solid var(--color-accent);
  border-radius: var(--radius-lg);
  overflow-x: auto;
}

.stat-name-cell {
  min-width: 160px;
}

.stat-desc {
  color: var(--color-text-muted);
  font-size: 0.8rem;
  margin-top: 2px;
}

.stat-level-cell {
  text-align: center;
  vertical-align: middle;
  min-width: 80px;
}

.stat-increment {
  font-family: var(--font-mono);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-gold);
}

.stat-cost {
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--color-text-dim);
  margin-top: 2px;
}

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

/* Level column headers */
.stats-table th.level-col {
  text-align: center;
  color: var(--color-gold);
}

/* ============================================================
   Spell stat levels table
   ============================================================ */
.levels-table-wrapper {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-top: 3px solid var(--color-accent);
  border-radius: var(--radius-lg);
  overflow-x: auto;
  margin-bottom: var(--space-lg);
}

.levels-table td.level-val {
  font-family: var(--font-mono);
  font-size: 0.875rem;
}

.levels-table th.level-header {
  text-align: center;
  color: var(--color-gold);
}

/* ============================================================
   Cost chips
   ============================================================ */
.cost-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 2px 8px;
  font-size: 0.8rem;
  font-family: var(--font-mono);
  color: var(--color-gold);
}

.cost-chip__label {
  color: var(--color-text-muted);
  font-family: var(--font-body);
  font-size: 0.75rem;
}

/* ============================================================
   Stub / coming-soon placeholder
   ============================================================ */
.stub {
  border: 1px dashed var(--color-border-2);
  border-radius: var(--radius-md);
  padding: var(--space-lg);
  color: var(--color-text-dim);
  font-style: italic;
  text-align: center;
}

.stub__icon {
  font-size: 1.5rem;
  margin-bottom: var(--space-sm);
}

/* ============================================================
   Scales-with badges
   ============================================================ */
.scales-with {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-sm);
}

.scale-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: var(--color-gold-glow);
  border: 1px solid rgba(201, 162, 60, 0.3);
  border-radius: var(--radius-sm);
  padding: 4px 10px;
  font-size: 0.8rem;
  color: var(--color-gold);
  text-decoration: none;
  transition: background var(--transition), border-color var(--transition);
}

.scale-badge:hover {
  background: rgba(201, 162, 60, 0.25);
  border-color: var(--color-gold);
  text-decoration: none;
  color: var(--color-gold-2);
}

.scale-badge__unit {
  color: var(--color-text-muted);
  font-family: var(--font-mono);
  font-size: 0.7rem;
}

/* ============================================================
   Bug cards
   ============================================================ */
.bug-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-lg);
  margin-bottom: var(--space-md);
}

.bug-card__header {
  display: flex;
  align-items: center;
  gap: var(--space-sm);
  margin-bottom: var(--space-sm);
  flex-wrap: wrap;
}

.bug-card__title {
  font-size: 1rem;
  font-weight: 600;
}

.bug-card__meta {
  color: var(--color-text-dim);
  font-size: 0.8rem;
  margin-top: var(--space-sm);
}

/* ============================================================
   Changelog entries
   ============================================================ */
.changelog-entry {
  margin-bottom: var(--space-xl);
}

.changelog-entry__header {
  display: flex;
  align-items: baseline;
  gap: var(--space-md);
  margin-bottom: var(--space-md);
  padding-bottom: var(--space-sm);
  border-bottom: 1px solid var(--color-border);
}

.changelog-entry__version {
  font-family: var(--font-title);
  font-size: 1.5rem;
  font-weight: 700;
  color: var(--color-gold);
  letter-spacing: 0.04em;
}

.changelog-entry__date {
  color: var(--color-text-muted);
  font-size: 0.875rem;
}

.changelog-section {
  margin-bottom: var(--space-md);
}

.changelog-section__label {
  font-family: var(--font-title);
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  margin-bottom: var(--space-xs);
}

.changelog-section--added .changelog-section__label   { color: var(--color-success); }
.changelog-section--changed .changelog-section__label { color: var(--color-info); }
.changelog-section--fixed .changelog-section__label   { color: var(--color-warning); }

/* ============================================================
   Forms
   ============================================================ */
.form {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-xl);
  max-width: 600px;
}

.form-group {
  margin-bottom: var(--space-lg);
}

.form-label {
  display: block;
  font-family: var(--font-title);
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--color-text-muted);
  margin-bottom: var(--space-xs);
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.form-input,
.form-select,
.form-textarea {
  width: 100%;
  background: var(--color-surface-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  font-family: var(--font-body);
  font-size: 0.9rem;
  padding: var(--space-sm) var(--space-md);
  transition: border-color var(--transition);
  appearance: none;
}

.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  box-shadow: 0 0 0 3px var(--color-accent-glow);
}

.form-textarea {
  resize: vertical;
  min-height: 120px;
}

.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238a8494' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-md) center;
  padding-right: 36px;
}

.form-turnstile {
  margin: var(--space-md) 0;
}

.btn {
  display: inline-flex;
  align-items: center;
  gap: var(--space-sm);
  background: var(--color-accent);
  color: #fff;
  border: none;
  border-radius: var(--radius-md);
  font-family: var(--font-title);
  font-size: 0.85rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: var(--space-sm) var(--space-lg);
  cursor: pointer;
  transition: background var(--transition), transform var(--transition), box-shadow var(--transition);
}

.btn:hover {
  background: var(--color-accent-2);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(198, 40, 40, 0.3);
}

/* ============================================================
   Hero section
   ============================================================ */
.hero {
  text-align: center;
  padding: var(--space-xl) 0;
  margin-bottom: var(--space-xl);
}

.hero__title {
  font-family: var(--font-title);
  font-size: 3.5rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  background: linear-gradient(135deg, var(--color-gold), var(--color-gold-2), var(--color-accent-2));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  margin-bottom: var(--space-md);
}

.hero__subtitle {
  color: var(--color-text-muted);
  font-size: 1.2rem;
  margin-bottom: var(--space-lg);
}

.hero__links {
  display: flex;
  gap: var(--space-md);
  justify-content: center;
  flex-wrap: wrap;
}

.hero__link {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  color: var(--color-text);
  padding: var(--space-sm) var(--space-lg);
  font-family: var(--font-title);
  font-weight: 600;
  font-size: 0.85rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  transition: all var(--transition);
}

.hero__link:hover {
  border-color: var(--color-accent);
  background: var(--color-accent-glow);
  box-shadow: 0 0 15px rgba(198, 40, 40, 0.15);
  text-decoration: none;
  color: var(--color-text);
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width: 768px) {
  .hero__title {
    font-size: 2.2rem;
  }
}
