/* ═══════════════════════════════════════════════════════════════════════════════
   RPG OVERVIEW PAGE
   ═══════════════════════════════════════════════════════════════════════════════ */

/* ── Shared section spacing ─────────────────────────────────────────────────── */
.rpg-section {
  padding-block: var(--space-12);
  border-top:    1px solid var(--color-divider);
}

.rpg-section h2 {
  margin-bottom: var(--space-4);
}

.rpg-section__intro {
  font-size:     var(--font-large);
  max-width:     66ch;
  margin-bottom: var(--space-8);
}

.rpg-subsection-label {
  font-family:    var(--font-family-mono);
  font-size:      var(--font-small);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color:          var(--color-text-secondary);
  margin-bottom:  var(--space-5);
  margin-top:     var(--space-8);
}

/* ── Core resolution rule block ─────────────────────────────────────────────── */
.rule-block {
  max-width:      720px;
  margin-bottom:  var(--space-4);
  border-left:    3px solid var(--color-accent);
  padding-left:   var(--space-6);
  line-height:    1.7;
}

.rule-block p { margin-bottom: var(--space-4); color: var(--color-text-secondary); }

.rule-list {
  list-style: none;
  display:    flex;
  flex-direction: column;
  gap:        var(--space-2);
  font-size:  var(--font-small);
  color:      var(--color-text-secondary);
}

.rule-list li {
  display:     flex;
  gap:         var(--space-3);
  align-items: baseline;
}

.rule-list li .font-mono {
  flex-shrink: 0;
  min-width:   10ch;
}

/* ── Attribute grid ─────────────────────────────────────────────────────────── */
.attr-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap:                   var(--space-3);
}

.attr-card {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-2);
  transition:     border-color var(--transition-fast), transform var(--transition-fast);
  position:       relative;
  overflow:       hidden;
}

/* Accent bar slides in on hover */
.attr-card::after {
  content:    '';
  position:   absolute;
  left: 0; top: 0; bottom: 0;
  width:      2px;
  background: var(--color-accent);
  transform:  scaleY(0);
  transform-origin: bottom;
  transition: transform var(--transition-normal);
}

.attr-card:hover::after  { transform: scaleY(1); }
.attr-card:hover         { border-color: var(--color-accent); transform: translateX(2px); }

.attr-card__header {
  display:     flex;
  align-items: baseline;
  gap:         var(--space-3);
}

.attr-card__abbr {
  font-size:      var(--font-base);
  color:          var(--color-accent);
  letter-spacing: 0.08em;
  min-width:      3.5ch;
}

.attr-card__name {
  font-size:   var(--font-small);
  font-family: var(--font-family-display);
  color:       var(--color-text-primary);
}

.attr-card__desc { line-height: 1.5; }

/* ── Origin cards ───────────────────────────────────────────────────────────── */
.origin-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap:                   var(--space-5);
  margin-bottom:         var(--space-8);
}

.origin-card {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-3);
  transition:     border-color var(--transition-normal), box-shadow var(--transition-normal);
  position:       relative;
  overflow:       hidden;
}

.origin-card:hover {
  border-color: var(--color-accent);
  box-shadow:   0 0 24px color-mix(in srgb, var(--color-accent) 8%, transparent);
}

.origin-card__glyph {
  font-size:   2.5rem;
  line-height: 1;
  /* subtle glow */
  text-shadow: 0 0 16px currentColor;
}

.origin-card__name {
  font-size:   var(--font-h4);
  letter-spacing: 0.06em;
}

.origin-card__summary { line-height: 1.6; flex: 1; }

.origin-card__wealth {
  display:     flex;
  align-items: center;
  gap:         var(--space-3);
  margin-top:  auto;
  padding-top: var(--space-3);
  border-top:  1px solid var(--color-divider);
}

.origin-card__wealth .eyebrow { margin-bottom: 0; }

/* ── Technomancer cards ─────────────────────────────────────────────────────── */
.techno-grid {
  display:               grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap:                   var(--space-5);
  margin-block:          var(--space-6) var(--space-8);
}

.techno-card {
  display:        flex;
  flex-direction: column;
  gap:            var(--space-3);
  position:       relative;
  overflow:       hidden;
  transition:     border-color var(--transition-normal);
}

/* Diagonal accent stripe in the corner */
.techno-card::before {
  content:    '';
  position:   absolute;
  top:        -20px; right: -20px;
  width:      80px; height: 80px;
  background: color-mix(in srgb, var(--color-accent) 6%, transparent);
  transform:  rotate(45deg);
  transition: background var(--transition-normal);
}
.techno-card:hover::before {
  background: color-mix(in srgb, var(--color-accent) 12%, transparent);
}

.techno-card:hover { border-color: var(--color-accent); }

.techno-card__glyph {
  font-size:   2rem;
  color:       var(--color-accent);
  line-height: 1;
}

.techno-card__name {
  font-size:   var(--font-h4);
  letter-spacing: 0.05em;
}

.techno-card__desc { color: var(--color-text-secondary); line-height: 1.6; }

/* ── Character creator CTA ──────────────────────────────────────────────────── */
.creator-cta {
  padding-block:   var(--space-16);
  border-top:      1px solid var(--color-divider);
  position:        relative;
  overflow:        hidden;
}

/* Subtle background pulse */
.creator-cta::before {
  content:    '';
  position:   absolute;
  inset:      0;
  background: radial-gradient(
    ellipse 60% 40% at 50% 50%,
    color-mix(in srgb, var(--color-accent) 4%, transparent),
    transparent
  );
  animation:  cta-pulse 6s ease-in-out infinite;
  pointer-events: none;
}

@keyframes cta-pulse {
  0%, 100% { opacity: 0.5; }
  50%       { opacity: 1; }
}

.creator-cta__inner { position: relative; z-index: 1; }

.creator-cta h2 {
  font-size:     clamp(1.6rem, 3.5vw, 2.4rem);
  margin-bottom: var(--space-4);
}

.creator-cta p {
  color:         var(--color-text-secondary);
  font-size:     var(--font-large);
  max-width:     56ch;
  margin-bottom: var(--space-8);
}

.creator-cta__btn { min-width: 220px; }

.creator-cta__soon {
  display:        flex;
  flex-direction: column;
  align-items:    flex-start;
  gap:            var(--space-2);
}

/* ── Notice spacing on this page ────────────────────────────────────────────── */
.rpg-section .notice { margin-top: var(--space-6); }
