/* ===================================================
   Lean Counsel — Connect Page Styles
   Two-sides layout, category cards
   =================================================== */

/* --- Two Sides Section --- */
.connect-sides {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

.connect-side {
  background: var(--white);
  border-top: 3px solid var(--accent);
  padding: 36px 28px;
}

.connect-side__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: 12px;
}

.connect-side__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 22px;
  color: var(--ink);
  margin-bottom: 12px;
}

.connect-side__body {
  font-family: var(--font-body);
  font-size: 15px;
  line-height: 1.7;
  color: var(--dim);
  margin-bottom: 24px;
}

.connect-side__cta {
  font-family: var(--font-body);
  font-size: 15px;
  font-weight: 500;
  color: var(--accent);
  transition: opacity 0.2s ease;
}

.connect-side__cta:hover {
  opacity: 0.7;
}

/* --- Category Cards --- */
.connect-categories {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

.category-card {
  border: 1px solid var(--rule);
  padding: 24px;
  transition: all 0.2s ease;
  margin-top: -1px;
}

.category-card:first-child {
  margin-top: 0;
}

.category-card:hover {
  border-color: var(--accent);
  background: var(--accent-light);
}

.category-card__code {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--accent);
  margin-bottom: 8px;
  display: block;
}

.category-card__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  color: var(--ink);
  margin-bottom: 6px;
}

.category-card__description {
  font-family: var(--font-body);
  font-size: 14px;
  color: var(--dim);
  line-height: 1.6;
}

/* --- Section headlines (page-specific) --- */
.connect-section {
  padding: 100px 0;
}

.connect-section--paper {
  background: var(--paper);
}

.connect-section--accent-light {
  background: var(--accent-light);
}

.connect-section__headline {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 28px;
  line-height: 1.25;
  color: var(--ink);
  margin-bottom: 48px;
  max-width: 560px;
}

/* --- Process steps grid --- */
.connect-process__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

/* --- Categories grid --- */
.connect-categories__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 0;
}

/* ===================================================
   RESPONSIVE — Tablet (768px)
   =================================================== */
@media (min-width: 768px) {
  .connect-sides {
    grid-template-columns: repeat(2, 1fr);
  }

  .connect-categories {
    grid-template-columns: repeat(2, 1fr);
    gap: 0;
  }

  .category-card {
    margin-top: 0;
    margin-left: -1px;
    margin-top: -1px;
  }

  .category-card:first-child,
  .category-card:nth-child(2) {
    margin-top: 0;
  }

  .category-card:nth-child(odd) {
    margin-left: 0;
  }

  .connect-process__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .connect-section__headline {
    font-size: 36px;
  }

  .connect-side__title {
    font-size: 24px;
  }
}

/* ===================================================
   RESPONSIVE — Desktop (1200px)
   =================================================== */
@media (min-width: 1200px) {
  .connect-section__headline {
    font-size: 44px;
  }

  .connect-categories {
    grid-template-columns: repeat(3, 1fr);
  }

  .category-card:nth-child(2) {
    margin-left: -1px;
  }

  .category-card:nth-child(-n+3) {
    margin-top: 0;
  }
}
