/* Weapons page styles — minimal, leveraging base.css */
.hero { padding-block: var(--space-48); }
.hero__inner { display: grid; grid-template-columns: 1.1fr 1fr; gap: var(--space-32); align-items: center; }
.hero__content p { max-width: 56ch; }
.hero__media { border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-lg); border: 1px solid var(--divider-color); }
#weapon-grid {grid-template-columns: repeat(2, minmax(0, 1fr));}
@media (max-width: 900px) { .hero__inner { grid-template-columns: 1fr; } #weapon-grid {grid-template-columns: repeat(1, minmax(0, 1fr));} }

/* Badges */
.badge { display: inline-flex; align-items: center; padding: 4px 8px; border-radius: var(--radius-round); font-size: var(--fs-sm); background: var(--color-elevated); border: 1px solid var(--border-color); color: var(--color-text-muted); }
.badge--accent { color: #111; background: var(--color-accent); border-color: color-mix(in oklab, var(--color-accent) 70%, black); }
.badge--danger { color: #fff; background: var(--color-danger); border-color: color-mix(in oklab, var(--color-danger) 70%, black); }

/* Weapon card */
.weapon-card { display: grid; gap: var(--space-16); }
.weapon-card__header { display: flex; justify-content: space-between; align-items: center; gap: var(--space-16); }
.weapon-card__media { border-radius: var(--radius-md); overflow: hidden; border: 1px solid var(--divider-color); box-shadow: var(--shadow-sm); }
.weapon-card__body .upgrades ul { margin-top: var(--space-8); padding-left: 1.2rem; }

/* Stats grid */
.stat-list { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--space-8); margin-block: var(--space-12); padding: 0; }
.stat-list li { display: flex; justify-content: space-between; gap: var(--space-8); background: var(--color-elevated); border: 1px solid var(--divider-color); border-radius: var(--radius-sm); padding: 8px 10px; }
.stat-list li span { color: var(--gray-400); }

/* Filters */
.filters { flex-wrap: wrap; }
.filters input[type="search"] { max-width: 420px; }

/* Timeline */
.timeline { display: grid; gap: var(--space-8); padding-left: 0; }
.timeline li { list-style: none; position: relative; padding-left: 16px; }
.timeline li::before { content: ""; position: absolute; left: 0; top: 0.6em; width: 8px; height: 8px; border-radius: 50%; background: var(--color-primary); box-shadow: 0 0 0 2px rgba(217, 4, 41, 0.25); }

/* Updates list */
.updates { display: grid; gap: var(--space-8); }

/* FAQ */
.faq-item { background: var(--color-surface); border: 1px solid var(--divider-color); border-radius: var(--radius-md); padding: 8px 12px; box-shadow: var(--shadow-sm); }
.faq-item + .faq-item { margin-top: var(--space-8); }
.faq-item summary { cursor: pointer; font-weight: 700; font-family: var(--font-display); letter-spacing: 0.04em; }
.faq-body { margin-top: var(--space-8); color: var(--color-text); }

