.elementor-5296 .elementor-element.elementor-element-0dc3524{--display:flex;--min-height:46px;}.elementor-5296 .elementor-element.elementor-element-c2084c2{--display:flex;--flex-direction:column;--container-widget-width:100%;--container-widget-height:initial;--container-widget-flex-grow:0;--container-widget-align-self:initial;--flex-wrap-mobile:wrap;}/* Start custom CSS *//* ===== Infrastructure Dynamics — Pillar Page Styling (Theme-aligned) ===== */
.id-pillar { color: #0f172a; }
.id-pillar a { text-decoration: none; }
.id-pillar a:hover { text-decoration: underline; }

.id-wrap {
  max-width: 1120px;
  margin: 0 auto;
  padding: 28px 18px 60px;
}

/* HERO */
.id-hero {
  padding: 56px 18px;
  border-bottom: 1px solid #e2e8f0;
  background: linear-gradient(180deg, #f8fafc 0%, #ffffff 70%);
}
.id-hero__inner {
  max-width: 1120px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1.2fr 0.8fr;
  gap: 26px;
  align-items: center;
}
.id-eyebrow {
  display: inline-block;
  font-size: 13px;
  padding: 6px 10px;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #fff;
  color: #475569;
  margin: 0 0 14px 0;
}
.id-subhead {
  margin: 0 0 10px 0;
  font-weight: 600;
  font-size: 18px;
  color: #0f172a;
}
.id-lead { font-size: 16px; color: #475569; max-width: 62ch; }

.id-hero__media img {
  width: 100%;
  height: auto;
  border-radius: 16px;
  border: 1px solid #e2e8f0;
  box-shadow: 0 12px 30px rgba(2,8,23,0.08);
}

/* Buttons — set to your site’s primary color */
.id-btn {
  display: inline-block;
  padding: 12px 16px;
  border-radius: 999px;
  font-weight: 700;
  font-size: 14px;
  border: 1px solid #0b3a7a;
  white-space: nowrap;
}
.id-btn--primary { background: #0b3a7a; color: #fff; }
.id-btn--secondary { background: #fff; color: #0b3a7a; }
.id-btn:hover { text-decoration: none; filter: brightness(0.97); }

.id-ctaRow { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 16px; }

/* TOC */
.id-toc {
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
  padding: 16px 18px;
  margin: 22px 0;
  box-shadow: 0 10px 25px rgba(2,8,23,0.06);
}
.id-toc h3 { margin: 0 0 10px 0; font-size: 16px; }
.id-toc ul { margin: 0; padding-left: 18px; }
.id-toc a { color: #0b3a7a; }

/* SECTION MODULES */
.id-section {
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  background: #fff;
  padding: 26px 22px;
  margin: 0 0 18px 0;
  box-shadow: 0 10px 25px rgba(2,8,23,0.06);
}
.id-section h2 { margin: 0 0 10px 0; line-height: 1.25; }
.id-section p, .id-section li { color: #475569; }

/* Layout helpers */
.id-twoCol {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 18px;
  margin-top: 14px;
}

/* Cards like product modules */
.id-cards3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 14px;
}
.id-grid2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-top: 14px;
}
.id-card {
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #fff;
  padding: 16px 16px;
}
.id-card h3 { margin: 0 0 8px 0; font-size: 15px; }

/* Callouts */
.id-callout {
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #f8fafc;
  padding: 14px 14px;
}
.id-callout h3 { margin: 0 0 8px 0; font-size: 15px; }

/* Notes */
.id-note {
  margin-top: 14px;
  border-left: 4px solid #0b3a7a;
  background: #eef6ff;
  border-radius: 14px;
  padding: 12px 14px;
  color: #0f172a;
}

/* Checklist + steps */
.id-checklist { margin: 10px 0 0 0; padding-left: 18px; }
.id-steps { margin: 12px 0 0 0; padding-left: 18px; }
.id-steps li { margin: 10px 0; }

/* CTA band (matches product-page CTA feel) */
.id-ctaBand {
  margin-top: 14px;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: center;
  border: 1px solid #e2e8f0;
  background: #f8fafc;
  border-radius: 14px;
  padding: 14px;
}
.id-ctaBand h3 { margin: 0 0 6px 0; }

/* FAQs */
.id-faq {
  border: 1px solid #e2e8f0;
  border-radius: 14px;
  background: #fff;
  padding: 12px 14px;
  margin-top: 10px;
}
.id-faq summary { cursor: pointer; font-weight: 700; color: #0f172a; }
.id-faq p { margin-top: 10px; }

/* Responsive */
@media (max-width: 980px) {
  .id-hero__inner { grid-template-columns: 1fr; }
  .id-twoCol { grid-template-columns: 1fr; }
  .id-cards3 { grid-template-columns: 1fr; }
  .id-grid2 { grid-template-columns: 1fr; }
  .id-ctaBand { grid-template-columns: 1fr; }
}
/* Make H3s more visually distinct on pillar pages */
.id-section h3 {
  font-size: 1.05rem;      /* slightly larger than body text */
  font-weight: 700;        /* stronger emphasis */
  color: #0f172a;          /* same dark heading color */
  margin-top: 0;
  margin-bottom: 8px;
  line-height: 1.35;
}

/* Ensure paragraphs don't visually compete with H3s */
.id-section p {
  font-size: 0.95rem;
  line-height: 1.6;
}/* End custom CSS */