/* ── Roadmap page ───────────────────────────────── */

/* Header */
.rm-header {
  padding: 4rem 0 2.5rem;
  text-align: center;
}

.rm-header__title {
  font-family: 'Grtsk Tera', sans-serif;
  font-size: clamp(2.5rem, 6vw, 4rem);
  font-weight: 400;
  letter-spacing: -0.05em;
  color: var(--text);
  margin-bottom: 0.75rem;
}

.rm-header__sub {
  font-size: 1rem;
  color: var(--text-mid);
  max-width: 400px;
  margin-inline: auto;
  line-height: 1.6;
}

/* ── Shipped changelog ─────────────────────────── */
.rm-shipped {
  padding: 0 0 2rem;
}

.rm-shipped .container {
  background: var(--bg-white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  padding: 2rem 2.5rem;
}

.rm-shipped__header {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.rm-shipped__title {
  font-family: 'Grtsk Tera', sans-serif;
  font-size: 1.25rem;
  font-weight: 400;
  letter-spacing: -0.03em;
  color: var(--text);
}

.rm-shipped__date {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--text-muted);
}

.rm-shipped__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 0;
}

.rm-shipped__item {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  padding: 0.625rem 0;
  font-size: 0.8125rem;
  color: var(--text-mid);
}

.rm-shipped__check {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #E8F5E9;
  color: #2E7D32;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.5625rem;
  font-weight: 700;
  flex-shrink: 0;
}

.rm-shipped__text {
  color: var(--text);
  font-weight: 400;
}

/* ── Board ──────────────────────────────────────── */
.rm-board {
  padding: 1rem 0 5rem;
}

/* Category */
.rm-category {
  margin-bottom: 3rem;
}

.rm-category__header {
  display: flex;
  align-items: baseline;
  gap: 0.75rem;
  margin-bottom: 1.25rem;
}

.rm-category__title {
  font-family: 'Grtsk Tera', sans-serif;
  font-size: 1.375rem;
  font-weight: 400;
  letter-spacing: -0.03em;
  color: var(--text);
}

.rm-category__count {
  font-size: 0.75rem;
  font-weight: 500;
  color: var(--text-muted);
}

/* Grid */
.rm-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0.75rem;
}

/* Card */
.rm-card {
  background: var(--bg-white);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  transition: transform 0.15s, box-shadow 0.15s;
}

.rm-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.06);
}

/* Badges */
.rm-badge {
  font-size: 0.5625rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.25rem 0.625rem;
  border-radius: var(--radius-pill);
  align-self: flex-start;
}

.rm-badge--progress {
  background: #E3F2FD;
  color: var(--blue);
}

.rm-badge--planned {
  background: rgba(25, 25, 25, 0.06);
  color: var(--text-mid);
}

.rm-badge--future {
  background: #FFF8E1;
  color: #F57F17;
}

.rm-card__title {
  font-family: 'Inter', sans-serif;
  font-size: 0.9375rem;
  font-weight: 600;
  color: var(--text);
  letter-spacing: -0.01em;
}

.rm-card__desc {
  font-size: 0.8125rem;
  color: var(--text-mid);
  line-height: 1.55;
  flex: 1;
}

/* Card footer */
.rm-card__footer {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 0.25rem;
}

.rm-card__meta {
  font-size: 0.6875rem;
  font-weight: 500;
  color: var(--text-muted);
}

/* Tags */
.rm-tag {
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  padding: 0.1875rem 0.5rem;
  border-radius: var(--radius-pill);
  background: rgba(25, 25, 25, 0.05);
  color: var(--text-mid);
}

.rm-tag--premium {
  background: #FFF8E1;
  color: #F57F17;
}

/* Active nav link */
.nav__link--active {
  color: var(--text) !important;
}

/* ── Responsive ────────────────────────────────── */
@media (max-width: 900px) {
  .rm-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 540px) {
  .rm-grid { grid-template-columns: 1fr; }
  .rm-shipped__grid { grid-template-columns: 1fr; }
  .rm-shipped .container { padding: 1.5rem 1.25rem; }
  .rm-card { padding: 1.25rem; }
}
