/* Hub landing page styling */
.hub { max-width: 1040px; margin: 0 auto; padding: 28px 20px 60px; }
.hub-hero h1 { font-size: 30px; margin: 8px 0 6px; letter-spacing: .3px; }
.hub-hero p { color: var(--muted); max-width: 720px; font-size: 15px; }

.cards {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 16px; margin-top: 26px;
}
.card {
  display: block; text-decoration: none; color: inherit;
  background: var(--panel); border: 1px solid var(--line); border-radius: 14px;
  padding: 18px; position: relative; transition: border-color .15s, transform .15s;
}
.card.live:hover { border-color: var(--accent); transform: translateY(-2px); }
.card h2 { font-size: 17px; margin: 10px 0 6px; }
.card p { color: var(--muted); font-size: 13.5px; margin: 0 0 30px; }
.card .badge {
  display: inline-block; font-size: 11px; letter-spacing: .8px; text-transform: uppercase;
  color: var(--accent); background: var(--panel2); border: 1px solid var(--line);
  padding: 3px 9px; border-radius: 999px;
}
.card .go { position: absolute; bottom: 16px; left: 18px; color: var(--accent); font-size: 13px; font-weight: 600; }
.card.soon { opacity: .62; }
.card.soon .badge { color: var(--muted); }
.card.soon .go { color: var(--muted); font-weight: 500; }

.flow { margin-top: 34px; }
.flow h3 { font-size: 13px; text-transform: uppercase; letter-spacing: .6px; color: var(--muted); }
.flow .chain { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; color: var(--ink); font-size: 13.5px; }
.flow .chain span { background: var(--panel); border: 1px solid var(--line); border-radius: 8px; padding: 7px 11px; }
.flow .chain b { color: var(--accent); }

.hub-foot { border-top: 1px solid var(--line); color: var(--muted); font-size: 12px; padding: 12px 20px; text-align: center; }
