/* ==========================================================================
   CONNECT — closing contact slide. QR to Daniel's LinkedIn.
   ---------------------------------------------------------------------------
   Offline-safe: the QR is a locally-generated SVG (assets/img/qr-linkedin.svg),
   NOT an external image — the deck must run without WLAN on stage. Master-detail:
   the invite left, the QR in an off-white "scan card" right. Dark QR on paper =
   high contrast = scannable from across the room; red corner-brackets give brand
   without touching scan contrast. Same chrome/tokens as the rest of the deck.
   ========================================================================== */

.nc-connect__slide { justify-content: center; }

.nc-connect__stage {
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: var(--space-4xl);
  align-items: center;
}

/* left — the invite */
.nc-connect__text { max-width: 34ch; }
.nc-connect__text .nc-eyebrow { margin-bottom: var(--space-lg); }
.reveal .nc-connect__title {
  font-family: var(--font-display);
  font-size: var(--fs-display);
  font-weight: 700;
  line-height: 1.04;
  letter-spacing: -0.025em;
  margin: 0 0 var(--space-lg);
}
.nc-connect__lead {
  font-family: var(--font-body);
  font-size: var(--fs-body-lg);
  line-height: 1.5;
  color: var(--text-muted);
  margin: 0 0 var(--space-2xl);
  max-width: 32ch;
}

/* the person block — a signature line under a hairline */
.nc-connect__person {
  display: flex;
  flex-direction: column;
  gap: var(--space-2xs);
  padding-top: var(--space-lg);
  border-top: 1px solid var(--border-subtle);
}
.nc-connect__name {
  font-family: var(--font-display);
  font-size: var(--fs-h3);
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--text-primary);
}
.nc-connect__handle {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  letter-spacing: 0.04em;
  color: var(--accent-2);
}

/* right — the scan card (off-white paper keeps the dark QR scannable) */
.nc-connect__qr {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-lg);
}
.nc-connect__qr-card {
  position: relative;
  background: var(--c-paper-200);
  padding: var(--space-xl);
  border-radius: var(--radius-md);
  box-shadow: var(--elev-3);
}
/* quiet red corner-brackets — brand cue that never sits over the QR itself */
.nc-connect__qr-card::before,
.nc-connect__qr-card::after {
  content: "";
  position: absolute;
  width: 24px;
  height: 24px;
  border: 2px solid var(--accent);
}
.nc-connect__qr-card::before { top: -7px; left: -7px; border-right: none; border-bottom: none; }
.nc-connect__qr-card::after  { bottom: -7px; right: -7px; border-left: none; border-top: none; }
.nc-connect__qr-card img {
  display: block;
  width: 320px;
  height: 320px;
}
.nc-connect__qr-label {
  font-family: var(--font-mono);
  font-size: var(--fs-label);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin: 0;
}
.nc-connect__qr-label .nc-accent { color: var(--accent); }
