/* Shared styles for industry / vertical pages (industry, commercial, housing, hospitality). */

/* ===== Hero ===== */
.page-hero { padding: 80px 0 72px; background: linear-gradient(180deg, #FDFDFE, var(--off-white-60)); border-bottom: 1px solid var(--color-border); }
.ph-grid { display: grid; grid-template-columns: 1.1fr 1fr; gap: 64px; align-items: center; }
.ph-grid h1 { font-family: var(--font-display); font-weight: 600; font-size: 60px; line-height: 1.04; letter-spacing: -0.025em; margin: 20px 0; }
.ph-grid p.lead { font-size: 19px; color: var(--color-text-muted); line-height: 1.5; margin-bottom: 12px; max-width: 540px; }
.ph-grid p.supp { font-size: 16px; color: var(--color-text-subtle); line-height: 1.55; margin-bottom: 28px; max-width: 520px; }
.ph-hero-visual { aspect-ratio: 4/3; border-radius: 20px; background: var(--vertical-hero-bg, linear-gradient(135deg, #D8C9B0 0%, #A89076 100%)); position: relative; box-shadow: var(--shadow-lg); overflow: hidden; }
.ph-hero-visual::after { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, rgba(255,255,255,0.05) 0 30px, transparent 30px 60px); }

/* Canvas hero — drop the gradient/stripe backdrop and let the .hv-frame
 * render edge-to-edge. The frame supplies its own 1:1 aspect + theme tint. */
.ph-hero-visual--canvas { aspect-ratio: auto; background: transparent; box-shadow: none; overflow: visible; }
.ph-hero-visual--canvas::after { display: none; }
.ph-hero-visual--canvas .hv-frame { width: 100%; max-width: 560px; margin-left: auto; }
.ph-hero-card { position: absolute; bottom: 24px; left: 24px; right: 24px; background: #fff; border-radius: 14px; padding: 16px 20px; box-shadow: var(--shadow-md); display: flex; justify-content: space-between; align-items: center; z-index: 2; }
.ph-hero-card strong { font-family: var(--font-display); font-weight: 600; font-size: 15px; }
.ph-hero-card span { font-size: 12px; color: var(--color-text-subtle); }

/* ===== Client logos strip ===== */
.logo-strip { padding: 40px 0 56px; border-bottom: 1px solid var(--color-border); background: #fff; }
.logo-strip-label { text-align: center; font-size: 13px; color: var(--color-text-subtle); text-transform: uppercase; letter-spacing: 0.12em; margin-bottom: 24px; font-weight: 600; }
.logo-strip-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 32px; align-items: center; }
.logo-strip-grid .logo-item { height: 44px; display: flex; align-items: center; justify-content: center; color: var(--color-text-subtle); font-family: var(--font-display); font-weight: 600; font-size: 18px; letter-spacing: -0.01em; opacity: 0.72; transition: opacity var(--motion-base) var(--ease-standard), color var(--motion-base) var(--ease-standard); white-space: nowrap; }
.logo-strip-grid .logo-item:hover { opacity: 1; color: var(--color-text); }
.logo-strip-grid .logo-item .customer-logo { max-height: 40px; max-width: 100%; }

/* ===== Problems ===== */
.problems { padding: 96px 0; }
.problems h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 12px; }
.problems .lead { font-size: 17px; color: var(--color-text-muted); max-width: 640px; line-height: 1.55; }
.pr-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-top: 48px; }
.pr-card { padding: 28px; border: 1px solid var(--color-border); border-radius: 16px; background: #fff; }
.pr-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 18px; margin-bottom: 10px; line-height: 1.25; }
.pr-card p { font-size: 16px; color: var(--color-text-muted); line-height: 1.55; }
.pr-card .ic { width: 40px; height: 40px; border-radius: 10px; background: var(--color-danger-soft); display: flex; align-items: center; justify-content: center; color: var(--color-danger); margin-bottom: 16px; }
.pr-card .ic svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; }

/* ===== Solution ===== */
.solution { padding: 96px 0; background: var(--off-white-60); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.sol-head { max-width: 760px; margin-bottom: 56px; }
.sol-head h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 16px; }
.sol-head p.lead { font-size: 18px; color: var(--color-text); line-height: 1.55; margin-bottom: 12px; font-weight: 500; }
.sol-head p.supp { font-size: 16px; color: var(--color-text-muted); line-height: 1.6; }
.sol-split { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: start; }
.sol-caps { list-style: none; display: flex; flex-direction: column; gap: 6px; }
.sol-caps li { padding: 22px 24px; background: #fff; border: 1px solid var(--color-border-subtle); border-radius: 14px; display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start; transition: border-color var(--motion-base) var(--ease-standard); }
.sol-caps li:hover { border-color: var(--green-100); }
.sol-caps .ic { width: 36px; height: 36px; border-radius: 10px; background: var(--green-20); color: #1E7A2B; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.sol-caps .ic svg { width: 18px; height: 18px; stroke: currentColor; fill: none; stroke-width: 2.25; }
.sol-caps strong { display: block; font-family: var(--font-display); font-weight: 600; font-size: 16px; margin-bottom: 4px; }
.sol-caps span { font-size: 16px; color: var(--color-text-muted); line-height: 1.5; }

.sol-visual { background: #fff; border-radius: 16px; border: 1px solid var(--color-border); box-shadow: var(--shadow-md); overflow: hidden; }
.sol-visual-head { padding: 14px 20px; border-bottom: 1px solid var(--color-border); display: flex; justify-content: space-between; align-items: center; font-size: 14px; background: var(--off-white-40); }
.sol-row { display: grid; grid-template-columns: 1fr auto auto; gap: 12px; padding: 14px 20px; border-bottom: 1px solid var(--color-border); align-items: center; font-size: 14px; }
.sol-row:last-child { border: none; }
.sol-row strong { display: block; font-family: var(--font-display); font-weight: 600; font-size: 16px; }
.sol-row .sub { color: var(--color-text-subtle); font-size: 12px; }

/* ===== Workflow ===== */
.workflow { padding: 96px 0; }
.workflow .head { max-width: 720px; margin-bottom: 56px; }
.workflow h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 14px; }
.workflow p.lead { font-size: 17px; color: var(--color-text-muted); line-height: 1.55; }
.wf-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 4px; position: relative; }
.wf-step { padding: 28px 24px 32px; background: #fff; border: 1px solid var(--color-border-subtle); border-radius: 16px; position: relative; display: flex; flex-direction: column; gap: 14px; }
.wf-step .n { font-family: var(--font-display); font-weight: 700; font-size: 14px; color: var(--green-100); letter-spacing: 0.1em; text-transform: uppercase; }
.wf-step h4 { font-family: var(--font-display); font-weight: 600; font-size: 18px; line-height: 1.25; }
.wf-step p { font-size: 16px; color: var(--color-text-muted); line-height: 1.5; }
.wf-step .ic { width: 44px; height: 44px; border-radius: 12px; background: var(--green-20); color: #1E7A2B; display: flex; align-items: center; justify-content: center; margin-bottom: 4px; }
.wf-step .ic svg { width: 22px; height: 22px; stroke: currentColor; fill: none; stroke-width: 2; }
.wf-step:not(:last-child)::after { content: ''; position: absolute; right: -12px; top: 50%; transform: translateY(-50%); width: 20px; height: 2px; background: var(--green-100); opacity: 0.3; z-index: 1; }

/* ===== Use case bridge ===== */
.use-bridge { padding: 96px 0; background: var(--off-white-60); border-top: 1px solid var(--color-border); border-bottom: 1px solid var(--color-border); }
.use-bridge .head { max-width: 720px; margin-bottom: 48px; }
.use-bridge h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 14px; }
.use-bridge p.lead { font-size: 17px; color: var(--color-text-muted); line-height: 1.55; }
.uc-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.uc-card { padding: 32px; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; display: flex; flex-direction: column; gap: 14px; transition: transform var(--motion-base) var(--ease-standard), box-shadow var(--motion-base) var(--ease-standard); }
.uc-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.uc-card .visual { aspect-ratio: 16/10; border-radius: 12px; position: relative; overflow: hidden; display: flex; align-items: center; justify-content: center; }
.uc-card.a .visual { background: linear-gradient(135deg, #D8C9B0, #A89076); }
.uc-card.b .visual { background: linear-gradient(135deg, #BDC9D6, #6B7889); }
.uc-card.c .visual { background: linear-gradient(135deg, #C9D4C1, #7A8A77); }
/* d = student accommodation (lavender), e = HMO / shared housing (warm coral),
   f = body corporate (cool teal — ZA-only sectional-title card),
   g = block management (slate blue — UK/EU-only managed-estates card). */
.uc-card.d .visual { background: linear-gradient(135deg, #D8CCE0, #8E7CA8); }
.uc-card.e .visual { background: linear-gradient(135deg, #E8CFB8, #BB907A); }
.uc-card.f .visual { background: linear-gradient(135deg, #B8D4D4, #4F8089); }
.uc-card.g .visual { background: linear-gradient(135deg, #C2C7D6, #6E7591); }
.uc-card .visual::after { content: ''; position: absolute; inset: 0; background: repeating-linear-gradient(45deg, rgba(255,255,255,0.05) 0 20px, transparent 20px 40px); pointer-events: none; }
.uc-card .visual .v-icon { position: relative; z-index: 2; width: 72px; height: 72px; border-radius: 18px; background: rgba(255,255,255,0.92); display: flex; align-items: center; justify-content: center; box-shadow: 0 6px 20px rgba(0,0,0,0.12); }
.uc-card .visual .v-icon svg { width: 36px; height: 36px; fill: none; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.uc-card.a .visual .v-icon svg { stroke: #7A6446; }
.uc-card.b .visual .v-icon svg { stroke: #3F4B5C; }
.uc-card.c .visual .v-icon svg { stroke: #3F5440; }
.uc-card.d .visual .v-icon svg { stroke: #574A6B; }
.uc-card.e .visual .v-icon svg { stroke: #8B5E45; }
.uc-card.f .visual .v-icon svg { stroke: #2F5F66; }
.uc-card.g .visual .v-icon svg { stroke: #3E465A; }
.uc-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 20px; line-height: 1.25; }
.uc-card p { font-size: 16px; color: var(--color-text-muted); line-height: 1.55; }
.uc-card a.more { font-size: 14px; color: var(--color-text); font-weight: 600; display: inline-flex; align-items: center; gap: 6px; margin-top: 4px; }
.uc-card a.more:hover { color: var(--green-100); }

/* Supporting section under the bridge grid — specialist workflows that
   don't earn a primary card (e.g. senior living, supported housing). */
.uc-supporting { margin-top: 56px; padding: 28px 32px; background: #fff; border: 1px solid var(--color-border); border-radius: 16px; }
.uc-supporting h3 { font-family: var(--font-display); font-weight: 600; font-size: 22px; line-height: 1.3; margin-bottom: 8px; }
.uc-supporting p { font-size: 16px; color: var(--color-text-muted); line-height: 1.55; max-width: 800px; }
.uc-supporting-links { list-style: none; display: flex; flex-wrap: wrap; gap: 10px 28px; margin: 18px 0 0; padding: 0; }
.uc-supporting-links li { display: inline-flex; }
.uc-supporting-links a { font-size: 14px; font-weight: 600; color: var(--color-text); display: inline-flex; align-items: center; gap: 6px; }
.uc-supporting-links a:hover { color: var(--green-100); }

/* ===== Specialist hub ("Popular workflows" strip) =====
   Cloned from styles/use-case.css so industry templates (which load
   vertical.css, not use-case.css) can render the same hub directly
   below the bridge section. */
.spec-hub { padding: 96px 0; background: #fff; border-top: 1px solid var(--color-border); }
.spec-hub h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; margin: 16px 0; max-width: 720px; }
.spec-hub .lead { font-size: 19px; color: var(--color-text-muted); line-height: 1.55; max-width: 720px; margin-bottom: 40px; }
.spec-hub-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.spec-hub-grid-3 { grid-template-columns: repeat(3, 1fr); }
.spec-hub-grid-4 { grid-template-columns: repeat(4, 1fr); }
@media (max-width: 1100px) { .spec-hub-grid-4 { grid-template-columns: repeat(2, 1fr); } }
.spec-hub-card {
  position: relative;
  display: flex; flex-direction: column;
  padding: 32px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 16px;
  text-decoration: none;
  color: inherit;
  box-shadow: 0 1px 2px rgba(15,23,42,0.04);
  transition: border-color var(--motion-base) var(--ease-standard),
              box-shadow var(--motion-base) var(--ease-standard),
              transform var(--motion-base) var(--ease-standard);
}
.spec-hub-card:hover {
  border-color: var(--green-100);
  box-shadow: 0 8px 24px rgba(15,23,42,0.08);
  transform: translateY(-2px);
}
.spec-hub-badge {
  position: absolute; top: 18px; right: 18px;
  background: var(--green-100); color: #fff;
  font-size: 11px; font-weight: 700;
  letter-spacing: 0.06em; text-transform: uppercase;
  padding: 5px 10px; border-radius: 999px;
}
.spec-hub-card .ic { width: 44px; height: 44px; border-radius: 10px; background: var(--off-white-100); display: flex; align-items: center; justify-content: center; margin-bottom: 18px; }
.spec-hub-card .ic svg { width: 22px; height: 22px; stroke: var(--anthracite-100); fill: none; stroke-width: 1.75; }
.spec-hub-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 22px; letter-spacing: -0.01em; margin: 0 0 10px; color: var(--anthracite-100); }
.spec-hub-card p { font-size: 16px; color: var(--color-text-muted); line-height: 1.55; margin: 0 0 20px; }
.spec-hub-cta {
  margin-top: auto;
  display: inline-flex; gap: 8px; align-items: center;
  font-weight: 600; font-size: 15px;
  color: var(--green-100);
}
.spec-hub-cta svg { width: 16px; height: 16px; transition: transform var(--motion-base) var(--ease-standard); }
.spec-hub-card:hover .spec-hub-cta svg { transform: translateX(4px); }
@media (max-width: 900px) { .spec-hub-grid, .spec-hub-grid-3, .spec-hub-grid-4 { grid-template-columns: 1fr; } }
@media (max-width: 640px) {
  .spec-hub { padding: 64px 0; }
  .spec-hub h2 { font-size: 28px; }
  .spec-hub .lead { font-size: 16px; }
  .spec-hub-card { padding: 24px; }
  .spec-hub-card h4 { font-size: 20px; }
}

/* ===== Proof / metrics ===== */
.proof { padding: 96px 0; background: var(--gradient-deep); color: #fff; }
.proof .head { max-width: 720px; margin-bottom: 56px; }
.proof h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; color: #fff; line-height: 1.1; margin-top: 16px; margin-bottom: 14px; }
.proof p.lead { font-size: 17px; color: rgba(255,255,255,0.75); line-height: 1.55; }
.proof-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.proof-card { padding: 32px; background: rgba(255,255,255,0.04); border: 1px solid rgba(255,255,255,0.1); border-radius: 16px; }
.proof-card .n { font-family: var(--font-display); font-weight: 700; font-size: 44px; color: var(--green-100); letter-spacing: -0.025em; line-height: 1; }
.proof-card .l { font-family: var(--font-display); font-weight: 600; font-size: 16px; color: #fff; margin-top: 16px; line-height: 1.3; }
.proof-card .d { font-size: 16px; color: rgba(255,255,255,0.7); margin-top: 10px; line-height: 1.5; }

/* ===== Sample reports band ===== */
/* overflow-x: clip stops the rotated rb-report cards' bounding boxes from
 * extending past the section's right edge on narrow viewports (which
 * otherwise pushed the page wider than the viewport and forced horizontal
 * scroll). overflow-x: clip is preferred over overflow-x: hidden because it
 * doesn't establish a new scroll container, so sticky positioning and other
 * layout behaviours upstream stay intact. */
.reports-band { padding: 96px 0; overflow-x: clip; }
.rb-grid { display: grid; grid-template-columns: 1fr 1.1fr; gap: 64px; align-items: center; min-width: 0; }
.rb-grid > * { min-width: 0; }
.rb-grid h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 14px; }
.rb-grid p.lead { font-size: 18px; color: var(--color-text); line-height: 1.55; margin-bottom: 14px; font-weight: 500; }
.rb-grid p.supp { font-size: 16px; color: var(--color-text-muted); line-height: 1.6; margin-bottom: 28px; }
.rb-visual { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; min-width: 0; }
.rb-report { aspect-ratio: 3/4; min-width: 0; overflow: hidden; border-radius: 12px; background: #fff; box-shadow: var(--shadow-md); border: 1px solid var(--color-border); padding: 16px; display: flex; flex-direction: column; gap: 8px; position: relative; transform: rotate(-2deg); transition: transform var(--motion-base) var(--ease-standard); }
.rb-report .ttl { word-break: break-word; }
.rb-report:nth-child(2) { transform: rotate(1deg) translateY(-12px); }
.rb-report:nth-child(3) { transform: rotate(3deg) translateY(6px); }
.rb-report:hover { transform: rotate(0) translateY(-4px); z-index: 2; }
.rb-report .lbl { font-size: 9px; font-weight: 700; color: var(--green-100); letter-spacing: 0.1em; text-transform: uppercase; }
.rb-report .ttl { font-family: var(--font-display); font-size: 11px; font-weight: 600; line-height: 1.3; }
.rb-report .thumbs { display: grid; grid-template-columns: repeat(2, 1fr); gap: 4px; margin-top: 4px; }
.rb-report .thumbs div {
  aspect-ratio: 1; border-radius: 4px;
  background-color: #d6cfc1;
  background-size: cover;
  background-position: center;
}
.rb-report .thumbs div:nth-child(1) { background-image: url('../assets/inspection-photos/kitchen-side-angle.webp'); }
.rb-report .thumbs div:nth-child(2) { background-image: url('../assets/inspection-photos/bathroom-side-angle.webp'); }
.rb-report .thumbs div:nth-child(3) { background-image: url('../assets/inspection-photos/exterior-house-front.webp'); }
.rb-report .thumbs div:nth-child(4) { background-image: url('../assets/inspection-photos/living-room-side-angle.webp'); }
.rb-report .lines { display: flex; flex-direction: column; gap: 4px; margin-top: auto; }
.rb-report .lines div { height: 4px; border-radius: 2px; background: var(--off-white-100); }
.rb-report .lines div:nth-child(2) { width: 80%; }
.rb-report .lines div:nth-child(3) { width: 60%; }

/* ===== Enterprise / scale ===== */
.scale { padding: 96px 0; background: var(--off-white-60); border-top: 1px solid var(--color-border); }
.scale-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 64px; align-items: center; }
.scale h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 14px; }
.scale p.lead { font-size: 17px; color: var(--color-text-muted); line-height: 1.55; margin-bottom: 28px; }
.scale-points { list-style: none; display: flex; flex-direction: column; gap: 14px; }
.scale-points li { display: grid; grid-template-columns: auto 1fr; gap: 12px; align-items: start; font-size: 15px; color: var(--color-text); line-height: 1.5; }
.scale-points svg { width: 18px; height: 18px; stroke: var(--green-100); fill: none; stroke-width: 2.25; margin-top: 2px; flex-shrink: 0; }
.scale-viz { aspect-ratio: 1; background: #fff; border-radius: 20px; border: 1px solid var(--color-border); box-shadow: var(--shadow-md); padding: 24px; display: grid; grid-template-columns: repeat(8, 1fr); gap: 6px; align-content: start; position: relative; }
.scale-cell { aspect-ratio: 1; border-radius: 4px; background: var(--off-white-60); border: 1px solid var(--color-border-subtle); }
.scale-cell.on { background: var(--green-100); border-color: var(--green-100); }
.scale-cell.half { background: var(--green-20); border-color: var(--green-100); }

/* ===== Final CTA ===== */
.final-cta { background: var(--gradient-primary); color: #fff; padding: 96px 0; text-align: center; }
.final-cta h2 { font-family: var(--font-display); font-weight: 600; font-size: 48px; letter-spacing: -0.02em; color: #fff; max-width: 820px; margin: 0 auto 20px; line-height: 1.1; }
.final-cta p { color: rgba(255,255,255,0.8); font-size: 17px; margin: 0 auto 32px; max-width: 600px; line-height: 1.5; }
.final-cta .btns { display: flex; gap: 12px; justify-content: center; }

/* Housing-only: compliance callout grid */
.compliance { padding: 96px 0; background: #fff; border-top: 1px solid var(--color-border); }
.cmp-head { max-width: 760px; margin-bottom: 48px; }
.cmp-head h2 { font-family: var(--font-display); font-weight: 600; font-size: 40px; letter-spacing: -0.02em; line-height: 1.1; margin-top: 16px; margin-bottom: 16px; }
.cmp-head p.lead { font-size: 18px; color: var(--color-text); line-height: 1.55; margin-bottom: 12px; font-weight: 500; }
.cmp-head p.supp { font-size: 16px; color: var(--color-text-muted); line-height: 1.6; }
.cmp-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
/* 4-card variant lays out as 2×2 on desktop (same as the 2-col default) and
   collapses cleanly to 1-col below 860px via the rule further down. */
.cmp-grid-4 { grid-template-columns: repeat(2, 1fr); }
.cmp-card { padding: 28px; border: 1px solid var(--color-border); border-radius: 16px; background: var(--off-white-60); display: grid; grid-template-columns: auto 1fr; gap: 20px; align-items: start; transition: border-color var(--motion-base) var(--ease-standard), background var(--motion-base) var(--ease-standard); }
.cmp-card:hover { border-color: var(--color-text); background: #fff; }
.cmp-card .ic { width: 42px; height: 42px; border-radius: 12px; background: #fff; border: 1px solid var(--color-border); color: var(--color-text); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.cmp-card .ic svg { width: 20px; height: 20px; stroke: currentColor; fill: none; stroke-width: 2; }
/* Supporting paragraph beneath the grid — replaces the legacy "Flexible
   templates" card, kept inline so it doesn't compete visually with the cards. */
.cmp-supporting { margin-top: 28px; padding-top: 24px; border-top: 1px solid var(--color-border); font-size: 15px; line-height: 1.55; color: var(--color-text-muted); max-width: 860px; }
.cmp-card h4 { font-family: var(--font-display); font-weight: 600; font-size: 17px; line-height: 1.3; margin-bottom: 8px; }
.cmp-card p { font-size: 16px; color: var(--color-text-muted); line-height: 1.55; }
@media (max-width: 860px) { .cmp-grid { grid-template-columns: 1fr; } }

/* Vertical gradient variants (set via CSS var on template) */
body.v-residential  { --vertical-hero-bg: linear-gradient(135deg, #D8C9B0 0%, #A89076 100%); }
body.v-commercial   { --vertical-hero-bg: linear-gradient(135deg, #6E7E95 0%, #3A4557 100%); }
body.v-housing      { --vertical-hero-bg: linear-gradient(135deg, #9BB59F 0%, #4E6D54 100%); }
body.v-hospitality  { --vertical-hero-bg: linear-gradient(135deg, #BDC9D6 0%, #6B7889 100%); }

@media (max-width: 900px) { .logo-strip-grid { grid-template-columns: repeat(3, 1fr); row-gap: 20px; } }
/* Tablet: 5- and 6-card bridge grids drop to 2 columns (3-card variants
   collapse to 1-column at this breakpoint via the next rule). */
@media (min-width: 601px) and (max-width: 980px) {
  .uc-grid-5, .uc-grid-6 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 980px) {
  .ph-grid, .sol-split, .rb-grid, .scale-grid { grid-template-columns: 1fr; }
  .pr-grid, .wf-steps, .proof-grid { grid-template-columns: 1fr; }
  .uc-grid:not(.uc-grid-5):not(.uc-grid-6) { grid-template-columns: 1fr; }
  .wf-step:not(:last-child)::after { display: none; }
  .ph-grid h1 { font-size: 42px; }
  .uc-supporting { padding: 24px; }
}
@media (max-width: 600px) {
  .uc-grid-5, .uc-grid-6 { grid-template-columns: 1fr; }
}
