/* ftm/learn-hub — frontend + editor */

.ftm-learn-hub {
  --radius-pill: 999px;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--ftm-navy);
  max-width: 1120px;
  margin: 0 auto;
  padding: 48px 24px 96px;
}
.ftm-learn-hub *, .ftm-learn-hub *::before, .ftm-learn-hub *::after { box-sizing: border-box; }

.ftm-learn-hub__hero { text-align: center; padding: 24px 0 48px; }
.ftm-learn-hub__kicker {
  font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ftm-navy-soft); font-weight: 600; margin-bottom: 12px;
}
.ftm-learn-hub__title {
  font-family: 'Prequel', 'Playfair Display', Georgia, serif;
  font-size: clamp(44px, 7vw, 72px); line-height: 1.05; margin: 0 0 16px;
  color: var(--ftm-navy); font-weight: 400;
}
.ftm-learn-hub__sub {
  max-width: 640px; margin: 0 auto;
  font-size: 18px; line-height: 1.55; color: var(--ftm-navy-soft);
}
.ftm-learn-hub__divider {
  height: 4px; width: 72px;
  background: var(--ftm-rainbow);
  border-radius: 2px;
  margin: 32px auto 0;
}

.ftm-learn-hub__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 24px;
  margin-top: 32px;
}

.ftm-learn-hub__card {
  background: var(--ftm-card);
  border-radius: var(--radius);
  padding: 36px 28px 32px;
  box-shadow: var(--shadow-md);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 320px;
  transition: transform .25s ease, box-shadow .25s ease;
  text-decoration: none;
  color: inherit;
  border: 1px solid var(--ftm-line);
}
a.ftm-learn-hub__card:hover { transform: translateY(-4px); box-shadow: var(--shadow-lg); }
.ftm-learn-hub__card::before {
  content: ""; position: absolute;
  inset: 0 0 auto 0; height: 4px;
  background: var(--ftm-rainbow);
}
.ftm-learn-hub__card.is-soon::before { opacity: 0.25; }
.ftm-learn-hub__card.is-soon { background: #FBFAF6; pointer-events: none; }

.ftm-learn-hub__icon { font-size: 40px; line-height: 1; margin-bottom: 16px; color: var(--ftm-navy); }

.ftm-learn-hub__tag {
  position: absolute; top: 20px; right: 20px;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 10px; border-radius: var(--radius-pill); font-weight: 600;
}
.ftm-learn-hub__tag--live { background: rgba(80,185,24,.14); color: #3f6e15; }
.ftm-learn-hub__tag--soon { background: rgba(107,114,128,.14); color: var(--ftm-muted); }

.ftm-learn-hub__card-title {
  font-family: 'Prequel', 'Playfair Display', Georgia, serif;
  font-size: 28px; font-weight: 400;
  margin: 0 0 10px; line-height: 1.15;
}
.ftm-learn-hub__card-desc {
  color: var(--ftm-navy-soft);
  font-size: 15px; line-height: 1.55;
  margin: 0 0 20px; flex: 1;
}
.ftm-learn-hub__cta {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 14px; font-weight: 600;
  color: var(--ftm-navy); margin-top: auto;
}
.ftm-learn-hub__cta .arrow { transition: transform .2s ease; }
a.ftm-learn-hub__card:hover .ftm-learn-hub__cta .arrow { transform: translateX(4px); }
.ftm-learn-hub__card.is-soon .ftm-learn-hub__cta { color: var(--ftm-muted); }

.ftm-learn-hub__footnote {
  text-align: center; margin-top: 56px;
  font-size: 14px; color: var(--ftm-muted);
}
.ftm-learn-hub__footnote a { color: var(--ftm-navy); text-decoration: underline; }

@media (max-width: 600px) {
  .ftm-learn-hub { padding: 32px 16px 64px; }
  .ftm-learn-hub__title { font-size: 44px; }
  .ftm-learn-hub__card { min-height: 260px; padding: 28px 22px; }
}
