/* ============================================================
   CARROSSÉIS — HUB
   Página índice listando famílias de templates disponíveis
   ============================================================ */

.hub {
  max-width: 1100px;
  margin: 0 auto;
  padding: 120px 32px 80px;
}

.hub__header {
  margin-bottom: 72px;
}

.hub__label {
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-3);
  margin-bottom: 16px;
}

.hub__title {
  font-family: var(--f-display);
  font-size: clamp(48px, 5.5vw, 78px);
  font-weight: 800;
  letter-spacing: -0.028em;
  line-height: 1;
  margin-bottom: 20px;
  background: linear-gradient(145deg, var(--text) 0%, color-mix(in oklab, var(--text) 70%, var(--c-purple) 30%) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hub__subtitle {
  font-family: var(--f-body);
  font-size: 18px;
  line-height: 1.5;
  color: var(--text-2);
  max-width: 560px;
}

.hub__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}

@media (max-width: 768px) {
  .hub { padding: 80px 20px 60px; }
  .hub__grid { grid-template-columns: 1fr; }
}

/* ============================================================
   FAMILY CARD
   ============================================================ */

.family-card {
  display: flex;
  flex-direction: column;
  padding: 0;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: background var(--t-fast), box-shadow var(--t-fast),
              transform var(--t-fast), border-color var(--t-slow);
}

.family-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--g-shadow-hover);
}

.family-card__preview {
  aspect-ratio: 3 / 4;
  background: var(--bg);
  position: relative;
  overflow: hidden;
  border-bottom: 1px solid var(--g-border-dim);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Wrapper that holds a full-size slide and scales it to fit.
   Override --mini-w, --mini-h, --mini-scale per card for non-standard dimensions. */
.hub-mini-slide {
  --mini-w: 1080px;
  --mini-h: 1440px;
  --mini-scale: 0.40;
  width: var(--mini-w);
  height: var(--mini-h);
  flex-shrink: 0;
  transform: scale(var(--mini-scale));
  transform-origin: center center;
  position: absolute;
  top: 50%;
  left: 50%;
  margin-top: calc(var(--mini-h) / -2);
  margin-left: calc(var(--mini-w) / -2);
}

.family-card__body {
  padding: 28px 32px 32px;
}

.family-card__name {
  font-family: var(--f-display);
  font-size: 24px;
  font-weight: 700;
  letter-spacing: -0.015em;
  margin-bottom: 10px;
}

.family-card__desc {
  font-family: var(--f-body);
  font-size: 15px;
  line-height: 1.5;
  color: var(--text-2);
  margin-bottom: 20px;
}

.family-card__cta {
  font-family: var(--f-mono);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-3);
  transition: color var(--t-fast);
}

.family-card:hover .family-card__cta {
  color: var(--c-purple);
}
