/* =============================================================================
   LegalSling — Pillar Page Styles
   Mobile-first. Tablet: 768px+. Desktop: 1024px+.
   ============================================================================= */

/* ---- Box Sizing ---- */
.pillar_nav .wrap,
.pillar_hero .wrap,
.toc_section .wrap,
.toc,
.pillar_section .wrap,
.challenge_card,
.feature_item,
.important_note,
.stat_item,
.pillar_step,
.step_num,
.step_content,
.doc_accordian ul li div,
.gs_col,
.newsletter_section .wrap,
.newsletter_form,
.newsletter_fields,
.nl_input,
.nl_input input,
.pillar_cta_section .wrap,
.pull_quote_section .wrap,
.stats_section .wrap {
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}


/* =============================================================================
   NAVIGATION
   ============================================================================= */

.pillar_nav {
  background-color: rgb(17, 17, 17);
  padding: 16px 0;
  position: sticky;
  top: 0;
  z-index: 100;
  border-bottom: 1px solid rgb(35, 35, 35);
}
.pillar_nav .wrap {
  margin: 0 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.pillar_nav .brand {
  color: rgb(255, 255, 255);
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 700;
}
.pillar_nav .nav_cta {
  display: inline-block;
  border: 1px solid rgb(255, 255, 255);
  color: rgb(255, 255, 255);
  padding: 8px 16px;
  text-decoration: none;
  font-size: 0.875rem;
}


/* =============================================================================
   HERO
   ============================================================================= */

.pillar_hero {
  background-color: rgb(17, 17, 17);
  padding: 40px 0 50px 0;
  color: rgb(255, 255, 255);
}
.pillar_hero .wrap {
  margin: 0 20px;
}
.pillar_hero h1 {
  font-size: 1.875rem;
  line-height: 1.1;
  margin: 14px 0 18px 0;
}
.pillar_hero .pillar_intro_text {
  color: rgb(140, 140, 140);
  font-size: 1.0625rem;
  line-height: 1.45;
}
.pillar_hero .hero_meta {
  margin: 22px 0 0 0;
  color: rgb(90, 90, 90);
  font-size: 0.8125rem;
  display: flex;
  gap: 8px;
  align-items: center;
}

/* ---- Breadcrumb ---- */
.breadcrumb {
  display: flex;
  gap: 6px;
  align-items: center;
  font-size: 0.8125rem;
  color: rgb(90, 90, 90);
}
.breadcrumb a {
  color: rgb(110, 110, 110);
  text-decoration: none;
}
.breadcrumb a:hover {
  color: rgb(200, 200, 200);
}
.breadcrumb span[aria-hidden] {
  color: rgb(70, 70, 70);
}


/* =============================================================================
   TABLE OF CONTENTS
   ============================================================================= */

.toc_section {
  padding: 24px 0;
  border-bottom: 1px solid rgb(220, 220, 220);
  background-color: rgb(248, 250, 252);
}
.toc_section .wrap {
  margin: 0 20px;
}
.toc h3 {
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: rgb(140, 140, 140);
  margin: 0 0 10px 0;
}
.toc ol {
  list-style: decimal;
  padding-left: 18px;
  margin: 0;
  columns: 1;
}
.toc ol li {
  margin: 0 0 5px 0;
  break-inside: avoid;
}
.toc ol li a {
  color: rgb(60, 60, 60);
  text-decoration: none;
  font-size: 0.9375rem;
  line-height: 1.4;
  border-bottom: 1px solid transparent;
  transition: border-color 0.15s;
}
.toc ol li a:hover {
  border-bottom-color: rgb(17, 17, 17);
  color: rgb(17, 17, 17);
}


/* =============================================================================
   PILLAR CONTENT SECTIONS
   ============================================================================= */

.pillar_section {
  padding: 50px 0;
}
.pillar_section .wrap {
  margin: 0 20px;
}
.pillar_section--alt {
  background-color: rgb(248, 250, 252);
}
.pillar_section h2 {
  font-size: 1.5rem;
  line-height: 1.1;
  margin: 0 0 14px 0;
}
.pillar_section .pillar_lead {
  font-size: 1.0625rem;
  line-height: 1.45;
  color: rgb(107, 107, 107);
  margin: 0 0 25px 0;
}
.pillar_section p {
  line-height: 1.65;
  color: rgb(60, 60, 60);
  font-size: 1rem;
  margin: 0 0 16px 0;
}
.pillar_section p:last-child {
  margin-bottom: 0;
}


/* =============================================================================
   CHALLENGE CARDS
   ============================================================================= */

.challenge_cards {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin: 28px 0 28px 0;
}
.challenge_card {
  background-color: rgb(255, 255, 255);
  border: 1px solid rgb(208, 200, 212);
  border-radius: 8px;
  padding: 22px 20px;
  box-shadow: 0 5px 10px -5px rgba(22, 22, 22, 0.12);
}
.challenge_card .card_icon {
  font-size: 1.375rem;
  display: block;
  margin: 0 0 10px 0;
  line-height: 1;
}
.challenge_card h3 {
  font-size: 1rem;
  margin: 0 0 7px 0;
  line-height: 1.2;
}
.challenge_card p {
  font-size: 0.9375rem;
  line-height: 1.45;
  color: rgb(107, 107, 107);
  margin: 0;
}


/* =============================================================================
   PULL QUOTES
   ============================================================================= */

.pull_quote_section {
  padding: 50px 0;
  background-color: rgb(17, 17, 17);
  color: rgb(255, 255, 255);
}
.pull_quote_section .wrap {
  margin: 0 20px;
}
.pull_quote_section blockquote {
  border-left: 3px solid rgb(255, 255, 255);
  padding-left: 20px;
  margin: 0;
}
.pull_quote_section blockquote p {
  font-size: 1.25rem;
  line-height: 1.4;
  color: rgb(255, 255, 255);
  font-style: italic;
  margin: 0 0 12px 0;
}
.pull_quote_section blockquote p:last-child {
  margin-bottom: 0;
}
.pull_quote_section blockquote cite {
  font-size: 0.875rem;
  color: rgb(140, 140, 140);
  font-style: normal;
}
.pull_quote_section--light {
  background-color: rgb(248, 250, 252);
}
.pull_quote_section--light blockquote {
  border-left-color: rgb(17, 17, 17);
}
.pull_quote_section--light blockquote p {
  color: rgb(17, 17, 17);
}


/* =============================================================================
   AI FEATURES GRID
   ============================================================================= */

.features_grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  margin: 0 0 28px 0;
}
.feature_item {
  background-color: rgb(255, 255, 255);
  border: 1px solid rgb(220, 220, 220);
  border-radius: 8px;
  padding: 22px 20px;
}
.feature_number {
  font-size: 1.75rem;
  font-weight: 700;
  color: rgb(210, 210, 210);
  line-height: 1;
  margin: 0 0 10px 0;
}
.feature_item h3 {
  font-size: 1rem;
  margin: 0 0 7px 0;
  line-height: 1.2;
}
.feature_item p {
  font-size: 0.9375rem;
  line-height: 1.5;
  color: rgb(107, 107, 107);
  margin: 0;
}

/* ---- Disclaimer note ---- */
.important_note {
  background-color: rgb(255, 255, 255);
  border: 1px solid rgb(220, 220, 220);
  border-left: 3px solid rgb(17, 17, 17);
  border-radius: 0 8px 8px 0;
  padding: 16px 20px;
}
.important_note p {
  font-size: 0.9rem;
  line-height: 1.5;
  color: rgb(80, 80, 80);
  margin: 0;
}


/* =============================================================================
   STATS SECTION
   ============================================================================= */

.stats_section {
  padding: 55px 0;
  background-color: rgb(17, 17, 17);
  color: rgb(255, 255, 255);
}
.stats_section .wrap {
  margin: 0 20px;
}
.stats_section h2 {
  font-size: 1.375rem;
  line-height: 1.15;
  margin: 0 0 30px 0;
  color: rgb(255, 255, 255);
}
.stats_grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px 16px;
}
.stat_number {
  font-size: 2.5rem;
  font-weight: 700;
  line-height: 1;
  margin: 0 0 8px 0;
  color: rgb(255, 255, 255);
}
.stat_item p {
  font-size: 0.875rem;
  line-height: 1.45;
  color: rgb(140, 140, 140);
  margin: 0;
}


/* =============================================================================
   STEP-BY-STEP
   ============================================================================= */

.pillar_steps {
  margin: 0;
}
.pillar_step {
  display: flex;
  gap: 16px;
  padding: 22px 0;
  border-bottom: 1px solid rgb(220, 220, 220);
  align-items: flex-start;
}
.pillar_step:first-child {
  border-top: 1px solid rgb(220, 220, 220);
}
.step_num {
  width: 38px;
  height: 38px;
  min-width: 38px;
  border-radius: 50%;
  background-color: rgb(17, 17, 17);
  color: rgb(255, 255, 255);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9375rem;
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 2px;
}
.step_content h3 {
  font-size: 1rem;
  margin: 0 0 7px 0;
  line-height: 1.2;
}
.step_content p {
  font-size: 0.9375rem;
  line-height: 1.55;
  color: rgb(107, 107, 107);
  margin: 0;
}


/* =============================================================================
   DOCUMENT TYPES ACCORDION
   ============================================================================= */

.doc_accordian ul {
  list-style: none;
  border-bottom: 1px solid rgb(17, 17, 17);
  margin: 0;
  padding: 0;
}
.doc_accordian ul li {
  padding: 15px 0;
}
.doc_accordian ul li + li {
  border-top: 1px solid rgb(17, 17, 17);
}
.doc_accordian ul li button {
  font-size: 1.0625rem;
  font-weight: 500;
  text-align: left;
  width: 100%;
  cursor: pointer;
  background: none;
  border: none;
  padding: 0;
  font-family: "basic-sans", sans-serif;
  color: rgb(17, 17, 17);
  line-height: 1.3;
}
.doc_accordian ul li button.open + div {
  display: block;
}
.doc_accordian ul li div {
  display: none;
  margin: 14px 0 4px 0;
  line-height: 1.5;
  color: rgb(94, 94, 94);
}
.doc_accordian ul li div p {
  font-size: 0.9375rem;
  line-height: 1.55;
  margin: 0 0 10px 0;
}
.doc_accordian ul li div p:last-child {
  margin-bottom: 0;
}
.doc_accordian ul li div p strong {
  color: rgb(40, 40, 40);
  font-weight: 600;
}


/* =============================================================================
   GETTING STARTED / PILLAR PRICING
   ============================================================================= */

.pillar_pricing {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin: 28px 0 0 0;
}
.pillar_price_card {
  background-color: rgb(248, 250, 252);
  border: 1px solid rgb(220, 220, 220);
  border-radius: 8px;
  padding: 32px 24px 36px 24px;
  text-align: center;
}
.pillar_price_card--dark {
  background-color: rgb(17, 17, 17);
  color: rgb(255, 255, 255);
  border-color: rgb(17, 17, 17);
}
.pillar_price_card h3 {
  font-size: 1.5rem;
  margin: 0 0 12px 0;
}
.pillar_price_card p {
  font-size: 0.9375rem;
  line-height: 1.4;
  color: rgb(107, 107, 107);
  margin: 0;
}
.pillar_price_card--dark p {
  color: rgb(140, 140, 140);
}
.pillar_price_figure {
  font-size: 1.625rem;
  font-weight: 700;
  color: rgb(17, 17, 17);
  margin: 20px 0;
  line-height: 1.1;
  display: block;
}
.pillar_price_card--dark .pillar_price_figure {
  color: rgb(255, 255, 255);
}
.pillar_price_card a {
  display: inline-block;
  border: 1px solid rgb(17, 17, 17);
  color: rgb(17, 17, 17);
  padding: 10px 26px;
  text-decoration: none;
  font-size: 0.9375rem;
}
.pillar_price_card--dark a {
  border-color: rgb(255, 255, 255);
  color: rgb(255, 255, 255);
}


/* =============================================================================
   NEWSLETTER / MAILING LIST SIGNUP
   ============================================================================= */

.newsletter_section {
  background-color: rgb(17, 17, 17);
  color: rgb(255, 255, 255);
  padding: 50px 0;
}
.newsletter_section .wrap {
  margin: 0 20px;
}
.newsletter_header {
  margin: 0 0 30px 0;
}
.newsletter_header h2 {
  font-size: 1.5rem;
  line-height: 1.1;
  margin: 0 0 12px 0;
  color: rgb(255, 255, 255);
}
.newsletter_header p {
  color: rgb(140, 140, 140);
  font-size: 1rem;
  line-height: 1.45;
}
.newsletter_form {
  background-color: rgb(27, 27, 27);
  border-radius: 8px;
  padding: 25px 20px 28px 20px;
  border: 1px solid rgb(40, 40, 40);
}
.newsletter_fields {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.nl_input label {
  display: none;
}
.nl_input input {
  display: block;
  width: 100%;
  background-color: transparent;
  border-radius: 6px;
  border: 1px solid rgb(61, 61, 61);
  font-size: 1rem;
  padding: 13px 15px;
  color: rgb(255, 255, 255);
  font-family: "basic-sans", sans-serif;
}
.nl_input input::placeholder {
  color: rgb(90, 90, 90);
}
.nl_input input:focus {
  outline: none;
  border-color: rgb(100, 100, 100);
}
.newsletter_form .nl_submit {
  display: inline-block;
  border: 1px solid rgb(255, 255, 255);
  background: none;
  padding: 12px 24px;
  color: rgb(255, 255, 255);
  font-size: 1rem;
  font-family: "basic-sans", sans-serif;
  cursor: pointer;
  margin: 8px 0 0 0;
}
.newsletter_form .nl_submit:hover {
  background-color: rgb(255, 255, 255);
  color: rgb(17, 17, 17);
}
.nl_disclaimer {
  font-size: 0.8125rem;
  color: rgb(90, 90, 90);
  margin: 14px 0 0 0;
  line-height: 1.4;
}
.newsletter_success {
  padding: 20px 0;
}
.newsletter_success p {
  font-size: 1.125rem;
  color: rgb(200, 200, 200);
  line-height: 1.4;
}


/* =============================================================================
   FINAL CTA
   ============================================================================= */

.pillar_cta_section {
  padding: 70px 0;
  text-align: center;
  background-color: rgb(17, 17, 17);
  color: rgb(255, 255, 255);
  background-image: url("../images/hero.png");
  background-size: cover;
  background-position: center;
  position: relative;
}
.pillar_cta_section:before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  background-color: rgba(17, 17, 17, 0.82);
}
.pillar_cta_section .wrap {
  margin: 0 20px;
  position: relative;
  z-index: 2;
}
.pillar_cta_section h2 {
  font-size: 1.875rem;
  line-height: 1.1;
  margin: 0 0 16px 0;
  color: rgb(255, 255, 255);
}
.pillar_cta_section p {
  color: rgb(140, 140, 140);
  font-size: 1.0625rem;
  line-height: 1.4;
  margin: 0 0 28px 0;
}
.pillar_cta_section a {
  display: inline-block;
  border: 1px solid rgb(255, 255, 255);
  color: rgb(255, 255, 255);
  padding: 13px 28px;
  text-decoration: none;
  font-size: 1rem;
}


/* =============================================================================
   TABLET (768px+)
   ============================================================================= */

@media screen and (min-width: 768px) {

  .pillar_nav .wrap {
    margin: 0 50px;
  }

  .pillar_hero {
    padding: 50px 0 65px 0;
  }
  .pillar_hero .wrap {
    margin: 0 50px;
  }
  .pillar_hero h1 {
    font-size: 2.25rem;
    max-width: 700px;
  }
  .pillar_hero .pillar_intro_text {
    font-size: 1.125rem;
  }

  .toc_section .wrap {
    margin: 0 50px;
  }
  .toc ol {
    columns: 2;
    column-gap: 30px;
  }

  .pillar_section .wrap {
    margin: 0 50px;
  }

  .challenge_cards {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }

  .pull_quote_section .wrap {
    margin: 0 50px;
  }

  .features_grid {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }

  .stats_section .wrap {
    margin: 0 50px;
  }

  .pillar_pricing {
    grid-template-columns: 1fr 1fr;
    gap: 14px;
  }

  .newsletter_section .wrap {
    margin: 0 50px;
  }

  .pillar_cta_section .wrap {
    margin: 0 50px;
  }

}


/* =============================================================================
   DESKTOP (1024px+)
   ============================================================================= */

@media screen and (min-width: 1024px) {

  /* Navigation */
  .pillar_nav .wrap {
    width: calc(100% - 100px);
    max-width: 1100px;
    margin: 0 auto;
  }
  .pillar_nav .brand {
    font-size: 1.375rem;
  }
  .pillar_nav .nav_cta {
    font-size: 1rem;
    padding: 10px 24px;
  }

  /* Hero */
  .pillar_hero {
    padding: 80px 0 90px 0;
  }
  .pillar_hero .wrap {
    width: calc(100% - 100px);
    max-width: 1100px;
    margin: 0 auto;
  }
  .pillar_hero h1 {
    font-size: 3rem;
    line-height: 1.05;
    max-width: 820px;
    margin: 18px 0 22px 0;
  }
  .pillar_hero .pillar_intro_text {
    font-size: 1.3125rem;
    line-height: 1.4;
    max-width: 680px;
  }
  .pillar_hero .hero_meta {
    margin: 28px 0 0 0;
    font-size: 0.9375rem;
  }

  /* TOC */
  .toc_section {
    padding: 28px 0;
  }
  .toc_section .wrap {
    width: calc(100% - 100px);
    max-width: 1100px;
    margin: 0 auto;
  }
  .toc ol {
    columns: 2;
    column-gap: 50px;
  }
  .toc ol li {
    margin: 0 0 6px 0;
  }
  .toc ol li a {
    font-size: 1rem;
  }

  /* Content Sections */
  .pillar_section {
    padding: 85px 0 95px 0;
  }
  .pillar_section .wrap {
    width: calc(100% - 100px);
    max-width: 1100px;
    margin: 0 auto;
  }
  .pillar_section h2 {
    font-size: 2.75rem;
    line-height: 1.05;
    margin: 0 0 20px 0;
  }
  .pillar_section .pillar_lead {
    font-size: 1.25rem;
    line-height: 1.4;
    max-width: 720px;
    margin: 0 0 40px 0;
  }
  .pillar_section p {
    font-size: 1.0625rem;
    line-height: 1.7;
  }

  /* Challenge Cards */
  .challenge_cards {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 40px 0 40px 0;
  }
  .challenge_card {
    padding: 28px 24px;
  }
  .challenge_card h3 {
    font-size: 1.125rem;
    margin: 0 0 10px 0;
  }
  .challenge_card p {
    font-size: 1rem;
    line-height: 1.5;
  }

  /* Pull Quotes */
  .pull_quote_section {
    padding: 85px 0;
  }
  .pull_quote_section .wrap {
    width: calc(100% - 100px);
    max-width: 900px;
    margin: 0 auto;
  }
  .pull_quote_section blockquote {
    border-left-width: 4px;
    padding-left: 36px;
  }
  .pull_quote_section blockquote p {
    font-size: 1.875rem;
    line-height: 1.35;
  }
  .pull_quote_section blockquote cite {
    font-size: 1rem;
  }

  /* Features Grid */
  .features_grid {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 18px;
    margin: 0 0 40px 0;
  }
  .feature_item {
    padding: 28px 24px;
  }
  .feature_number {
    font-size: 2.25rem;
    margin: 0 0 12px 0;
  }
  .feature_item h3 {
    font-size: 1.125rem;
    margin: 0 0 10px 0;
  }
  .feature_item p {
    font-size: 1rem;
    line-height: 1.5;
  }

  /* Stats */
  .stats_section {
    padding: 90px 0 100px 0;
  }
  .stats_section .wrap {
    width: calc(100% - 100px);
    max-width: 1100px;
    margin: 0 auto;
  }
  .stats_section h2 {
    font-size: 2.5rem;
    line-height: 1.1;
    margin: 0 0 55px 0;
    max-width: 660px;
  }
  .stats_grid {
    grid-template-columns: repeat(4, 1fr);
    gap: 50px;
  }
  .stat_number {
    font-size: 3.5rem;
    margin: 0 0 12px 0;
  }
  .stat_item p {
    font-size: 1rem;
    line-height: 1.45;
  }

  /* Steps */
  .pillar_step {
    gap: 28px;
    padding: 30px 0;
  }
  .step_num {
    width: 48px;
    height: 48px;
    min-width: 48px;
    font-size: 1.0625rem;
    margin-top: 3px;
  }
  .step_content h3 {
    font-size: 1.25rem;
    margin: 0 0 10px 0;
  }
  .step_content p {
    font-size: 1.0625rem;
    line-height: 1.6;
    max-width: 650px;
  }

  /* Doc Types */
  .doc_accordian ul li {
    padding: 18px 0;
  }
  .doc_accordian ul li button {
    font-size: 1.375rem;
  }
  .doc_accordian ul li div {
    margin: 16px 0 6px 0;
  }
  .doc_accordian ul li div p {
    font-size: 1.0625rem;
    line-height: 1.6;
  }

  /* Pillar Pricing */
  .pillar_pricing {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin: 40px 0 0 0;
  }
  .pillar_price_card {
    padding: 55px 40px 60px 40px;
  }
  .pillar_price_card h3 {
    font-size: 2rem;
    margin: 0 0 14px 0;
  }
  .pillar_price_card p {
    font-size: 1.0625rem;
    line-height: 1.4;
  }
  .pillar_price_figure {
    font-size: 2.1875rem;
    margin: 28px 0;
  }
  .pillar_price_card a {
    font-size: 1.125rem;
    padding: 12px 30px;
  }

  /* Newsletter */
  .newsletter_section {
    padding: 90px 0 100px 0;
  }
  .newsletter_section .wrap {
    width: calc(100% - 100px);
    max-width: 1100px;
    margin: 0 auto;
    display: flex;
    gap: 70px;
    align-items: flex-start;
  }
  .newsletter_header {
    flex: 1;
    margin: 0;
    padding: 15px 0 0 0;
  }
  .newsletter_header h2 {
    font-size: 2.75rem;
    line-height: 1.05;
    margin: 0 0 18px 0;
  }
  .newsletter_header p {
    font-size: 1.125rem;
    line-height: 1.45;
  }
  .newsletter_form {
    flex: 1;
    padding: 36px 40px 42px 40px;
  }
  .newsletter_fields {
    gap: 12px;
  }
  .nl_input input {
    font-size: 1.125rem;
    padding: 14px 16px;
  }
  .newsletter_form .nl_submit {
    font-size: 1.125rem;
    padding: 13px 32px;
    margin: 10px 0 0 0;
  }
  .nl_disclaimer {
    font-size: 0.875rem;
    margin: 16px 0 0 0;
  }

  /* Final CTA */
  .pillar_cta_section {
    padding: 120px 0 130px 0;
  }
  .pillar_cta_section .wrap {
    width: calc(100% - 100px);
    max-width: 1100px;
    margin: 0 auto;
  }
  .pillar_cta_section h2 {
    font-size: 3.125rem;
    line-height: 1;
    margin: 0 0 22px 0;
  }
  .pillar_cta_section p {
    font-size: 1.25rem;
    margin: 0 0 38px 0;
  }
  .pillar_cta_section a {
    font-size: 1.25rem;
    padding: 15px 40px;
  }

}


/* =============================================================================
   WIDE DESKTOP (1400px+)
   ============================================================================= */

@media screen and (min-width: 1400px) {

  .pillar_hero h1 {
    font-size: 3.5rem;
  }

  .pillar_section h2 {
    font-size: 3.125rem;
  }

  .stats_section h2 {
    font-size: 2.75rem;
  }

  .pull_quote_section blockquote p {
    font-size: 2.1875rem;
  }

  .newsletter_header h2 {
    font-size: 3.125rem;
  }

  .pillar_cta_section h2 {
    font-size: 3.75rem;
  }

}
