@charset "UTF-8";
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  color: #111827;
}

html {
  scroll-behavior: smooth;
}

body {
  background-color: #ffffff;
  color: #111827;
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", "Liberation Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  padding-top: 4.25rem;
}

@media (max-width: 767.98px) {
  body {
    padding-top: 3.75rem;
  }
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 600;
  letter-spacing: -0.02em;
  color: #111827;
}

a {
  color: #1fae45;
  text-decoration: none;
  -webkit-transition: color 0.2s ease, opacity 0.2s ease;
  transition: color 0.2s ease, opacity 0.2s ease;
}

a:hover, a:focus {
  color: #1a9039;
  text-decoration: none;
}

img {
  max-width: 100%;
  height: auto;
  display: block;
}

.btn {
  border-radius: 999px;
  font-weight: 500;
  padding: 0.65rem 1.5rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.4rem;
  -webkit-box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
          box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
  border-width: 1px;
  border-style: solid;
  border-color: transparent;
  background-image: none;
}

.btn:hover {
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  -webkit-box-shadow: 0 12px 24px rgba(15, 23, 42, 0.16);
          box-shadow: 0 12px 24px rgba(15, 23, 42, 0.16);
}

.btn:active {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12);
          box-shadow: 0 4px 12px rgba(15, 23, 42, 0.12);
}

.form-control,
.form-select {
  border-radius: 0.75rem;
  border-color: #e5e7eb;
  padding: 0.75rem 0.9rem;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, -webkit-box-shadow 0.2s ease;
}

.form-control:focus,
.form-select:focus {
  border-color: #1fae45;
  -webkit-box-shadow: 0 0 0 0.15rem rgba(31, 174, 69, 0.18);
          box-shadow: 0 0 0 0.15rem rgba(31, 174, 69, 0.18);
}

.page-wrapper {
  padding-top: 4.5rem;
}

.section {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

.section--muted {
  padding-top: 4rem;
  padding-bottom: 4rem;
  background: #f5f7fb;
}

.section-heading {
  margin-bottom: 2.5rem;
  text-align: left;
}

.section-heading__eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.5rem;
}

.section-heading__title {
  font-size: clamp(1.9rem, 3vw, 2.4rem);
  margin-bottom: 0.75rem;
}

.section-heading__lead {
  max-width: 640px;
  color: #555555;
}

.section-content-narrow {
  max-width: 720px;
  margin-left: auto;
  margin-right: auto;
}

.u-gap-xs {
  gap: 0.25rem !important;
}

.u-gap-sm {
  gap: 0.5rem !important;
}

.u-gap-md {
  gap: 1rem !important;
}

.u-gap-lg {
  gap: 1.5rem !important;
}

.u-flex-center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.75rem;
}

.u-text-soft {
  color: #555555 !important;
}

.u-text-muted {
  color: #444444 !important;
}

.u-card {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  padding: 1.5rem;
}

.u-shadow-soft {
  -webkit-box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04) !important;
          box-shadow: 0 3px 10px rgba(0, 0, 0, 0.04) !important;
}

.u-rounded-lg {
  border-radius: 0.75rem !important;
}

.u-rounded-xl {
  border-radius: 1rem !important;
}

/* ===========================
   Header / Top Navigation
   =========================== */
.header {
  background-color: #ffffff;
  -webkit-transition: all 0.25s ease;
  transition: all 0.25s ease;
  z-index: 997;
  padding: 0.55rem 0;
  -webkit-box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
          box-shadow: 0 4px 14px rgba(15, 23, 42, 0.08);
}

.header .logo img {
  height: 64px;
  width: auto;
  display: block;
}

/* Base navbar layout */
.header .navbar {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.5rem;
}

.header .navbar ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 1.5rem;
}

.header .navbar li {
  position: relative;
}

/* Text links */
.header .navbar a {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.95rem;
  font-weight: 500;
  color: #1f2933;
  padding: 0.3rem 0;
  position: relative;
  -webkit-transition: color 0.2s ease, opacity 0.2s ease;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.header .navbar a:hover, .header .navbar a:focus {
  color: #1fae45;
  text-decoration: none;
}

/* Simple underline accent on hover for non-CTA nav links */
.header
.navbar
li:not(:has(.get-a-quote-btn)):not(:has(.survey-btn))
> a::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0;
  height: 2px;
  background-color: #1fae45;
  border-radius: 999px;
  -webkit-transition: width 0.2s ease;
  transition: width 0.2s ease;
}

.header
.navbar
li:not(:has(.get-a-quote-btn)):not(:has(.survey-btn))
> a:hover::after,
.header
.navbar
li:not(:has(.get-a-quote-btn)):not(:has(.survey-btn))
> a:focus::after {
  width: 100%;
}

/* CTA buttons in the header */
.header .navbar .get-a-quote-btn,
.header .navbar .survey-btn {
  padding: 0.45rem 1.25rem;
  border-radius: 999px;
  font-size: 0.92rem;
  font-weight: 600;
  line-height: 1.2;
  -webkit-box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
          box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
  border-width: 1px;
  border-style: solid;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.4rem;
  background-image: none;
}

/* Primary CTA: Get a quote */
.header .navbar .get-a-quote-btn {
  background-color: #1fae45;
  border-color: #1fae45;
  color: #ffffff;
}

.header .navbar .get-a-quote-btn:hover, .header .navbar .get-a-quote-btn:focus {
  background-color: #1a9039;
  border-color: #1a9039;
  color: #ffffff;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  -webkit-box-shadow: 0 12px 24px rgba(15, 23, 42, 0.18);
          box-shadow: 0 12px 24px rgba(15, 23, 42, 0.18);
}

.header .navbar .get-a-quote-btn:active {
  background-color: #178334;
  border-color: #178334;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-box-shadow: 0 4px 12px rgba(15, 23, 42, 0.14);
          box-shadow: 0 4px 12px rgba(15, 23, 42, 0.14);
}

/* Secondary CTA: Book a survey */
.header .navbar .survey-btn {
  background-color: transparent;
  border-color: #1fae45;
  color: #1fae45;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.header .navbar .survey-btn:hover, .header .navbar .survey-btn:focus {
  background-color: #35b658;
  color: #ffffff;
  -webkit-box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
          box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.header .navbar .survey-btn:active {
  -webkit-box-shadow: 0 3px 10px rgba(15, 23, 42, 0.1);
          box-shadow: 0 3px 10px rgba(15, 23, 42, 0.1);
}

/* Mobile nav toggle */
.header .mobile-nav-toggle {
  font-size: 1.6rem;
  line-height: 1;
  cursor: pointer;
  color: #1f2933;
  display: none;
  -webkit-transition: color 0.2s ease, -webkit-transform 0.2s ease;
  transition: color 0.2s ease, -webkit-transform 0.2s ease;
  transition: color 0.2s ease, transform 0.2s ease;
  transition: color 0.2s ease, transform 0.2s ease, -webkit-transform 0.2s ease;
}

.header .mobile-nav-toggle:hover, .header .mobile-nav-toggle:focus {
  color: #1fae45;
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

/* ===========================
     Responsive Behaviour
     =========================== */
/* Desktop / large screens */
@media (min-width: 992px) {
  .header .navbar {
    -webkit-box-pack: end;
        -ms-flex-pack: end;
            justify-content: flex-end;
  }
  .header .navbar ul {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
        -ms-flex-direction: row;
            flex-direction: row;
  }
}

/* Mobile / tablet */
@media (max-width: 991.98px) {
  .header {
    padding: 0.5rem 0;
  }
  .header .container-xl {
    padding-left: 1rem;
    padding-right: 1rem;
  }
  .header .mobile-nav-toggle {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
  }
  .header .navbar ul {
    display: none;
  }
  /* When JS adds .navbar-mobile to #navbar */
  .header .navbar.navbar-mobile {
    position: absolute;
    inset-inline: 0;
    top: 100%;
    background-color: #ffffff;
    -webkit-box-shadow: 0 18px 40px rgba(15, 23, 42, 0.16);
            box-shadow: 0 18px 40px rgba(15, 23, 42, 0.16);
    padding: 0.75rem 1.25rem 1.25rem;
    border-bottom-left-radius: 1rem;
    border-bottom-right-radius: 1rem;
  }
  .header .navbar.navbar-mobile ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    gap: 0.35rem;
  }
  .header .navbar.navbar-mobile li {
    width: 100%;
  }
  .header .navbar.navbar-mobile a {
    width: 100%;
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .header .navbar.navbar-mobile .get-a-quote-btn,
  .header .navbar.navbar-mobile .survey-btn {
    width: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

/* ===========================
   Active nav state
   =========================== */
/* Base active link: colour match with hover */
.header .navbar a.active {
  color: #1fae45;
}

/* Keep underline visible on the active standard links (non-CTA) */
.header
.navbar
li:not(:has(.get-a-quote-btn)):not(:has(.survey-btn))
> a.active::after {
  width: 100%;
}

/* ===========================
   Hero Section
   =========================== */
.hero {
  background: radial-gradient(circle at top left, #f5f7fb 0, #ffffff 55%);
  padding-top: 4.5rem;
  padding-bottom: 4.5rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.hero .container {
  position: relative;
}

/* Left column: text + CTAs */
.hero-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.75rem;
}

.hero-headline {
  font-size: clamp(2.1rem, 3vw, 2.7rem);
  line-height: 1.1;
  margin-bottom: 1rem;
  color: #111827;
}

.hero-headline span {
  display: block;
  font-size: 0.85em;
  font-weight: 500;
  color: #555555;
  margin-top: 0.35rem;
}

.hero-copy {
  max-width: 34rem;
  font-size: 1rem;
  color: #555555;
  margin-bottom: 1.5rem;
}

/* CTAs */
.hero-ctas {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

.hero-ctas .btn {
  white-space: nowrap;
}

/* Primary / secondary hero buttons */
.btn-hero-primary {
  background-color: #1fae45;
  border-color: #1fae45;
  color: #ffffff;
  -webkit-box-shadow: 0 14px 28px rgba(31, 174, 69, 0.35);
          box-shadow: 0 14px 28px rgba(31, 174, 69, 0.35);
}

.btn-hero-primary:hover, .btn-hero-primary:focus {
  background-color: #1a9039;
  border-color: #1a9039;
  color: #ffffff;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  -webkit-box-shadow: 0 18px 36px rgba(31, 174, 69, 0.42);
          box-shadow: 0 18px 36px rgba(31, 174, 69, 0.42);
}

.btn-hero-primary:active {
  background-color: #178334;
  border-color: #178334;
  -webkit-transform: translateY(0);
          transform: translateY(0);
  -webkit-box-shadow: 0 8px 18px rgba(31, 174, 69, 0.3);
          box-shadow: 0 8px 18px rgba(31, 174, 69, 0.3);
}

.btn-hero-outline {
  border-color: #1fae45;
  color: #1fae45;
  background-color: transparent;
}

.btn-hero-outline:hover, .btn-hero-outline:focus {
  background-color: #35b658;
  color: #ffffff;
  -webkit-box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
          box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.btn-hero-outline:active {
  -webkit-box-shadow: 0 4px 10px rgba(15, 23, 42, 0.1);
          box-shadow: 0 4px 10px rgba(15, 23, 42, 0.1);
}

/* Text link under CTAs */
.hero-text-link {
  font-size: 0.95rem;
  font-weight: 500;
  color: #444444;
  text-decoration: none;
  position: relative;
  padding-bottom: 0.1rem;
}

.hero-text-link:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background-color: #cbd2d9;
  -webkit-transition: background-color 0.2s ease;
  transition: background-color 0.2s ease;
}

.hero-text-link:hover, .hero-text-link:focus {
  color: #1fae45;
}

.hero-text-link:hover:after, .hero-text-link:focus:after {
  background-color: #1fae45;
}

/* Trust row – now text only (no pill effect) */
.hero-trust {
  margin-top: 1.75rem;
  font-size: 0.95rem;
  color: #555555;
}

.hero-trust .hero-trust-item {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.4rem;
  padding: 0;
  border-radius: 0;
  background-color: transparent;
  -webkit-box-shadow: none;
          box-shadow: none;
}

.hero-trust .hero-trust-item i {
  font-size: 1rem;
  color: #1fae45;
}

/* Right column: card */
.hero-visual {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
  padding-left: 0;
  padding-right: 0;
}

.hero-card {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  max-width: 500px;
  padding: 1.75rem 1.5rem 1.5rem;
  border-radius: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  -webkit-box-shadow: 0 20px 45px rgba(15, 23, 42, 0.16);
          box-shadow: 0 20px 45px rgba(15, 23, 42, 0.16);
}

.hero-card .section-eyebrow {
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.5rem;
}

.hero-card h2 {
  font-size: 1.25rem;
  margin-bottom: 0.6rem;
}

.hero-card p {
  font-size: 0.95rem;
  color: #555555;
  margin-bottom: 1rem;
}

/* Hero list */
.hero-list {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem 0;
}

.hero-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.5rem;
  font-size: 0.92rem;
  color: #444444;
  margin-bottom: 0.4rem;
}

.hero-list li i {
  font-size: 1rem;
  margin-top: 0.1rem;
  color: #1fae45;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

.hero-card .btn-hero-primary {
  width: 100%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

/* ===========================
       Responsive tweaks
       =========================== */
@media (max-width: 991.98px) {
  .hero {
    padding-top: 3.5rem;
    padding-bottom: 3.5rem;
    min-height: auto;
  }
  .hero-headline {
    font-size: 2rem;
  }
  .hero-copy {
    max-width: 100%;
  }
  /* Force text first, card second */
  .hero .row > .col-lg-6:nth-child(1) {
    -webkit-box-ordinal-group: 2 !important;
        -ms-flex-order: 1 !important;
            order: 1 !important;
  }
  .hero .row > .col-lg-6:nth-child(2) {
    -webkit-box-ordinal-group: 3 !important;
        -ms-flex-order: 2 !important;
            order: 2 !important;
  }
  .hero-card {
    max-width: 100%;
  }
}

@media (max-width: 767.98px) {
  .hero {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
  .hero-ctas {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
        -ms-flex-direction: column;
            flex-direction: column;
    -webkit-box-align: stretch;
        -ms-flex-align: stretch;
            align-items: stretch;
    gap: 0.75rem !important;
  }
  .hero-ctas .btn {
    width: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .hero-ctas .hero-text-link {
    text-align: center;
  }
  .hero-trust {
    margin-top: 1.5rem;
    gap: 0.5rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
  .hero-trust .hero-trust-item {
    -webkit-box-pack: start;
        -ms-flex-pack: start;
            justify-content: flex-start;
  }
  .hero-visual {
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
  .hero-card {
    max-width: 95%;
    margin-inline: auto;
    padding: 1.6rem 1.25rem 1.4rem;
  }
}

/* ===========================
   Mobile Sticky CTA Bar
   =========================== */
.mobile-cta-bar {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 0.75rem 1rem;
  background-color: #ffffff;
  border-top: 1px solid #e5e7eb;
  -webkit-box-shadow: 0 -6px 20px rgba(0, 0, 0, 0.12);
          box-shadow: 0 -6px 20px rgba(0, 0, 0, 0.12);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 0.6rem;
  z-index: 9999;
  /* Animation + hide/show */
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
  opacity: 0;
  -webkit-transition: opacity 0.25s ease, -webkit-transform 0.25s ease;
  transition: opacity 0.25s ease, -webkit-transform 0.25s ease;
  transition: transform 0.25s ease, opacity 0.25s ease;
  transition: transform 0.25s ease, opacity 0.25s ease, -webkit-transform 0.25s ease;
}

.mobile-cta-bar.is-visible {
  -webkit-transform: translateY(0);
          transform: translateY(0);
  opacity: 1;
}

.mobile-cta-bar.is-hidden {
  -webkit-transform: translateY(100%);
          transform: translateY(100%);
  opacity: 0;
  pointer-events: none;
}

.mobile-cta-bar .btn {
  -webkit-box-flex: 1;
      -ms-flex: 1;
          flex: 1;
  font-size: 0.95rem;
  padding: 0.65rem 0.5rem;
  border-radius: 999px;
  text-align: center;
}

.mobile-cta-bar .mobile-cta-link {
  border: none;
  background: none;
  padding: 0;
  font-size: 0.86rem;
  font-weight: 500;
  color: #444444;
  text-decoration: underline;
  white-space: nowrap;
}

/* Only show on mobile */
@media (min-width: 768px) {
  .mobile-cta-bar {
    display: none !important;
  }
}

/* ===========================
     Mobile “Ask a question” modal
     =========================== */
.mobile-question-modal {
  position: fixed;
  inset: 0;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 1rem;
  z-index: 10000;
  opacity: 0;
  pointer-events: none;
  -webkit-transition: opacity 0.25s ease;
  transition: opacity 0.25s ease;
}

.mobile-question-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

.mobile-question-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(15, 23, 42, 0.45);
}

.mobile-question-dialog {
  position: relative;
  width: 100%;
  max-width: 420px;
  border-radius: 1rem 1rem 0.75rem 0.75rem;
  background-color: #ffffff;
  padding: 1.4rem 1.25rem 1.25rem;
  -webkit-box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.25);
          box-shadow: 0 -10px 30px rgba(0, 0, 0, 0.25);
  z-index: 1;
}

.mobile-question-dialog h2 {
  font-size: 1.15rem;
  margin-bottom: 0.5rem;
}

.mobile-question-dialog p {
  font-size: 0.93rem;
  color: #555555;
}

.mobile-question-actions .btn {
  font-size: 0.95rem;
}

/* Only show modal on mobile for now */
@media (min-width: 768px) {
  .mobile-question-modal {
    display: none;
  }
}

/* ===========================
   Footer
   =========================== */
.footer {
  background-color: #111111;
  color: #ffffff;
  padding-top: 2.5rem;
  padding-bottom: 2rem;
  margin-top: 3rem;
  font-size: 0.94rem;
}

/* Top area */
.footer-top {
  padding-bottom: 1.5rem;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

/* Brand block */
.footer .footer-info p {
  color: #cccccc;
  max-width: 24rem;
  margin-bottom: 0;
}

.footer .logo img {
  height: 66px;
  width: auto;
  display: block;
}

/* Column headings */
.footer h4 {
  font-size: 0.98rem;
  font-weight: 600;
  margin-bottom: 0.8rem;
  color: #ffffff;
}

/* Links */
.footer .footer-links ul {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer .footer-links ul li {
  margin-bottom: 0.45rem;
}

.footer .footer-links a {
  color: #cccccc;
  text-decoration: none;
  font-size: 0.93rem;
  -webkit-transition: color 0.2s ease, opacity 0.2s ease;
  transition: color 0.2s ease, opacity 0.2s ease;
}

.footer .footer-links a:hover,
.footer .footer-links a:focus {
  color: #ffffff;
}

/* CTA column */
.footer .footer-contact p {
  color: #cccccc;
  margin-bottom: 0.75rem;
}

.footer .footer-cta {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  padding: 0.55rem 1.3rem;
  border-radius: 999px;
  font-size: 0.93rem;
  font-weight: 600;
  background-color: #1fae45;
  color: #ffffff;
  text-decoration: none;
  -webkit-box-shadow: 0 10px 26px rgba(0, 0, 0, 0.45);
          box-shadow: 0 10px 26px rgba(0, 0, 0, 0.45);
  -webkit-transition: background-color 0.2s ease, -webkit-box-shadow 0.2s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.2s ease, -webkit-box-shadow 0.2s ease, -webkit-transform 0.2s ease;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
  transition: background-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease, -webkit-box-shadow 0.2s ease, -webkit-transform 0.2s ease;
}

.footer .footer-cta:hover,
.footer .footer-cta:focus {
  background-color: #1a9039;
  color: #ffffff;
  -webkit-transform: translateY(-1px);
          transform: translateY(-1px);
  -webkit-box-shadow: 0 14px 32px rgba(0, 0, 0, 0.6);
          box-shadow: 0 14px 32px rgba(0, 0, 0, 0.6);
}

/* Bottom line */
.footer .copyright {
  margin-top: 1.2rem;
  margin-bottom: 0;
  font-size: 0.85rem;
  color: #cccccc;
}

/* ===========================
     Responsive tweaks
     =========================== */
@media (max-width: 991.98px) {
  .footer {
    text-align: left;
  }
  .footer-top .row > [class*="col-"] {
    margin-bottom: 1.25rem;
  }
}

@media (max-width: 767.98px) {
  .footer {
    margin-top: 2.5rem;
  }
  .footer .footer-cta {
    width: 100%;
  }
  .footer .copyright {
    margin-top: 1.5rem;
  }
}

/* ===========================
   Sections / How It Works
   =========================== */
/* "How it works" wrapper */
.how-it-works {
  background-color: #f5f7fb;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
}

/* Section eyebrow + intro (inside this section only) */
.how-it-works .section-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.6rem;
}

.how-it-works h2 {
  font-size: clamp(1.8rem, 2.6vw, 2.2rem);
  margin-bottom: 0.75rem;
}

.how-it-works .section-intro {
  max-width: 36rem;
  margin: 0 auto;
  font-size: 0.98rem;
  color: #555555;
}

/* Step cards */
.how-it-works .step-card {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  position: relative;
  padding: 1.75rem 1.5rem 1.5rem;
  border-radius: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  -webkit-box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
          box-shadow: 0 16px 40px rgba(15, 23, 42, 0.12);
  background-color: #ffffff;
  overflow: hidden;
  -webkit-transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
}

.how-it-works .step-card:hover {
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
  -webkit-box-shadow: 0 22px 50px rgba(15, 23, 42, 0.16);
          box-shadow: 0 22px 50px rgba(15, 23, 42, 0.16);
  border-color: rgba(31, 174, 69, 0.35);
}

/* Step number badge */
.how-it-works .step-number {
  position: absolute;
  top: 1.1rem;
  right: 1.2rem;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 999px;
  background: #35b658;
  color: #ffffff;
  font-weight: 700;
  font-size: 0.95rem;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

/* Card heading + copy */
.how-it-works .step-card h3 {
  font-size: 1.15rem;
  margin-bottom: 0.5rem;
  padding-right: 2.4rem;
}

.how-it-works .step-card p {
  font-size: 0.95rem;
  color: #555555;
  margin-bottom: 0.75rem;
}

/* Bullet list inside steps */
.how-it-works .step-card ul {
  list-style: none;
  padding: 0;
  margin: 0 0 0.9rem 0;
}

.how-it-works .step-card ul li {
  position: relative;
  padding-left: 1.1rem;
  font-size: 0.9rem;
  color: #444444;
  margin-bottom: 0.3rem;
}

.how-it-works .step-card ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background-color: #1fae45;
}

/* Step link at the bottom of each card */
.how-it-works .step-link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.92rem;
  font-weight: 600;
  color: #1fae45;
  text-decoration: none;
  margin-top: 0.2rem;
  position: relative;
  padding-bottom: 0.05rem;
}

.how-it-works .step-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background-color: rgba(31, 174, 69, 0.4);
  -webkit-transition: background-color 0.2s ease, width 0.2s ease;
  transition: background-color 0.2s ease, width 0.2s ease;
}

.how-it-works .step-link:hover,
.how-it-works .step-link:focus {
  color: #1a9039;
}

.how-it-works .step-link:hover::after,
.how-it-works .step-link:focus::after {
  background-color: #1a9039;
}

/* ===========================
     Responsive tweaks
     =========================== */
@media (max-width: 991.98px) {
  .how-it-works .step-card {
    margin-bottom: 0.75rem;
  }
}

@media (max-width: 767.98px) {
  .how-it-works {
    text-align: left;
  }
  .how-it-works .section-intro {
    max-width: 100%;
  }
  .how-it-works .row.gy-4 > [class*="col-"] {
    margin-bottom: 0.25rem;
  }
}

/* ===========================
   Who We Help
   =========================== */
.who-we-help {
  background-color: #ffffff;
}

/* Section eyebrow + intro specific to this section */
.who-we-help .section-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.6rem;
}

.who-we-help h2 {
  font-size: clamp(1.8rem, 2.6vw, 2.2rem);
  margin-bottom: 0.75rem;
}

.who-we-help .section-intro {
  max-width: 36rem;
  margin: 0 auto;
  font-size: 0.98rem;
  color: #555555;
}

/* Help cards */
.who-we-help .help-card {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  text-align: left;
  padding: 1.75rem 1.5rem 1.6rem;
  border-radius: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  background-color: #ffffff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  gap: 0.6rem;
  -webkit-transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
}

.who-we-help .help-card:hover {
  -webkit-transform: translateY(-3px);
          transform: translateY(-3px);
  -webkit-box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
          box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
  border-color: rgba(31, 174, 69, 0.3);
}

/* Icon at the top of each card */
.who-we-help .help-icon {
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 0.9rem;
  background-color: #35b658;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  margin-bottom: 0.4rem;
}

.who-we-help .help-icon i {
  font-size: 1.3rem;
  color: #ffffff;
}

/* Card headings and text */
.who-we-help .help-card h3 {
  font-size: 1.1rem;
  margin-bottom: 0.35rem;
}

.who-we-help .help-card p {
  font-size: 0.95rem;
  color: #555555;
  margin-bottom: 0.4rem;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

/* CTA link at bottom of each card */
.who-we-help .help-link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.92rem;
  font-weight: 600;
  color: #1fae45;
  text-decoration: none;
  padding-bottom: 0.05rem;
  position: relative;
}

.who-we-help .help-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background-color: rgba(31, 174, 69, 0.4);
  -webkit-transition: background-color 0.2s ease, width 0.2s ease;
  transition: background-color 0.2s ease, width 0.2s ease;
}

.who-we-help .help-link:hover,
.who-we-help .help-link:focus {
  color: #1a9039;
}

.who-we-help .help-link:hover::after,
.who-we-help .help-link:focus::after {
  background-color: #1a9039;
}

/* ===========================
     Responsive tweaks
     =========================== */
@media (max-width: 991.98px) {
  .who-we-help .help-card {
    margin-bottom: 0.5rem;
  }
}

@media (max-width: 767.98px) {
  .who-we-help .section-intro {
    max-width: 100%;
  }
}

/* ===========================
   Types of Stairlifts
   =========================== */
.stairlift-types {
  background-color: #ffffff;
}

/* Section eyebrow / intro */
.stairlift-types .section-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.6rem;
}

.stairlift-types h2 {
  font-size: clamp(1.8rem, 2.6vw, 2.2rem);
  margin-bottom: 0.75rem;
}

.stairlift-types .section-intro {
  max-width: 36rem;
  margin: 0 auto;
  font-size: 0.98rem;
  color: #555555;
}

/* Type cards */
.stairlift-types .type-card {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  padding: 1.75rem 1.5rem 1.6rem;
  border-radius: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  background-color: #ffffff;
  -webkit-transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 100%;
}

.stairlift-types .type-card:hover {
  -webkit-transform: translateY(-3px);
          transform: translateY(-3px);
  -webkit-box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
          box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
  border-color: rgba(31, 174, 69, 0.3);
}

/* Headings + text */
.stairlift-types .type-card h3 {
  font-size: 1.15rem;
  margin-bottom: 0.6rem;
}

.stairlift-types .type-card p {
  font-size: 0.95rem;
  color: #555555;
  margin-bottom: 0.75rem;
}

/* Bullets */
.stairlift-types .type-card ul {
  list-style: none;
  padding: 0;
  margin: 0 0 1rem 0;
}

.stairlift-types .type-card ul li {
  position: relative;
  padding-left: 1.1rem;
  font-size: 0.9rem;
  color: #444444;
  margin-bottom: 0.35rem;
}

.stairlift-types .type-card ul li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.55em;
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background-color: #1fae45;
}

/* CTA */
.stairlift-types .type-link {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  font-size: 0.92rem;
  font-weight: 600;
  color: #1fae45;
  text-decoration: none;
  padding-bottom: 0.05rem;
  position: relative;
  margin-top: auto;
}

.stairlift-types .type-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background-color: rgba(31, 174, 69, 0.4);
  -webkit-transition: background-color 0.2s ease, width 0.2s ease;
  transition: background-color 0.2s ease, width 0.2s ease;
}

.stairlift-types .type-link:hover,
.stairlift-types .type-link:focus {
  color: #1a9039;
}

.stairlift-types .type-link:hover::after,
.stairlift-types .type-link:focus::after {
  background-color: #1a9039;
}

/* ===========================
     Responsive Tweaks
     =========================== */
@media (max-width: 991.98px) {
  .stairlift-types .type-card {
    margin-bottom: 0.5rem;
  }
}

@media (max-width: 767.98px) {
  .stairlift-types .section-intro {
    max-width: 100%;
  }
}

/* ===========================
   Why Acorn
   =========================== */
.why-acorn {
  background-color: #f7f7f9;
  border-top: 1px solid #e5e7eb;
  border: 1px solid rgba(0, 0, 0, 0.06);
  padding-top: 4rem;
  padding-bottom: 4rem;
}

/* Section eyebrow & intro */
.why-acorn .section-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.6rem;
}

.why-acorn h2 {
  font-size: clamp(1.8rem, 2.6vw, 2.2rem);
  margin-bottom: 0.75rem;
}

.why-acorn .section-intro {
  max-width: 36rem;
  margin: 0 auto;
  font-size: 0.98rem;
  color: #555555;
}

/* Items (4 icons in a grid) */
.why-acorn .why-item {
  background-color: #ffffff;
  border: 1px solid rgba(0, 0, 0, 0.06);
  border-radius: 1rem;
  padding: 1.75rem 1.25rem 1.4rem;
  text-align: center;
  height: 100%;
  -webkit-box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
  -webkit-transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease, -webkit-transform 0.2s ease, -webkit-box-shadow 0.2s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: start;
      -ms-flex-pack: start;
          justify-content: flex-start;
}

.why-acorn .why-item:hover {
  -webkit-transform: translateY(-4px);
          transform: translateY(-4px);
  -webkit-box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
          box-shadow: 0 18px 40px rgba(15, 23, 42, 0.12);
  border-color: rgba(31, 174, 69, 0.3);
}

/* Icon */
.why-acorn .why-item i {
  font-size: 2rem;
  color: #1fae45;
  margin-bottom: 0.9rem;
}

/* Title */
.why-acorn .why-item h3 {
  font-size: 1.05rem;
  font-weight: 600;
  margin-bottom: 0.55rem;
  color: #111827;
}

/* Copy */
.why-acorn .why-item p {
  font-size: 0.95rem;
  color: #555555;
  margin: 0;
  -webkit-box-flex: 1;
      -ms-flex-positive: 1;
          flex-grow: 1;
}

/* ===========================
     Responsive tweaks
     =========================== */
@media (max-width: 991.98px) {
  .why-acorn .why-item {
    margin-bottom: 0.75rem;
  }
}

@media (max-width: 767.98px) {
  .why-acorn .section-intro {
    max-width: 100%;
  }
}

/* ===========================
   Reassurance Strip
   =========================== */
.reassurance-strip {
  background-color: #f4f5f8;
  border-top: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
  padding: 1.75rem 0;
  margin-top: 2.5rem;
}

.reassurance-strip .reassurance-text {
  font-size: 1.05rem;
  color: #444444;
  line-height: 1.45;
  max-width: 48rem;
}

.reassurance-strip .btn-hero-primary {
  padding: 0.65rem 1.4rem;
  border-radius: 999px;
  white-space: nowrap;
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
  .reassurance-strip {
    text-align: center;
    padding: 1.5rem 0;
    margin-top: 1.5rem;
  }
  .reassurance-strip .reassurance-text {
    margin-bottom: 1rem;
  }
  .reassurance-strip .btn-hero-primary {
    width: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
  }
}

/* ===========================
   FAQ Teaser
   =========================== */
.faq-teaser {
  background-color: #ffffff;
}

/* Section eyebrow / intro */
.faq-teaser .section-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.6rem;
}

.faq-teaser h2 {
  font-size: clamp(1.8rem, 2.6vw, 2.2rem);
  margin-bottom: 0.75rem;
}

.faq-teaser .section-intro {
  max-width: 36rem;
  margin: 0 auto;
  font-size: 0.98rem;
  color: #555555;
}

/* ===========================
     Accordion Styling
     =========================== */
/* Accordion wrapper */
.faq-teaser .accordion {
  --bs-accordion-bg: #ffffff;
  --bs-accordion-border-color: $border-light;
  --bs-accordion-border-width: 1px;
  --bs-accordion-border-radius: 1rem;
  --bs-accordion-btn-padding-x: 1rem;
  --bs-accordion-btn-padding-y: 1.1rem;
  --bs-accordion-btn-focus-box-shadow: none;
}

/* Accordion item */
.faq-teaser .accordion-item {
  border-radius: 1rem;
  overflow: hidden;
  margin-bottom: 1rem;
  border: 1px solid rgba(0, 0, 0, 0.08);
  -webkit-transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  transition: border-color 0.2s ease, box-shadow 0.2s ease, -webkit-box-shadow 0.2s ease;
}

.faq-teaser .accordion-item:hover {
  border-color: rgba(31, 174, 69, 0.35);
  -webkit-box-shadow: 0 14px 36px rgba(15, 23, 42, 0.1);
          box-shadow: 0 14px 36px rgba(15, 23, 42, 0.1);
}

/* Accordion buttons */
.faq-teaser .accordion-button {
  background-color: #ffffff;
  font-size: 1.05rem;
  font-weight: 600;
  color: #111827;
  border: none;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transition: background-color 0.2s ease, color 0.2s ease, padding 0.2s ease;
  transition: background-color 0.2s ease, color 0.2s ease, padding 0.2s ease;
}

/* Remove Bootstrap's default bold arrow icon glow */
.faq-teaser .accordion-button:not(.collapsed) {
  background-color: #ffffff;
  color: #1fae45;
}

.faq-teaser .accordion-button:focus {
  -webkit-box-shadow: none;
          box-shadow: none;
}

/* Accordion chevron colour */
.faq-teaser .accordion-button::after {
  -webkit-filter: brightness(0.4);
          filter: brightness(0.4);
}

.faq-teaser .accordion-button:not(.collapsed)::after {
  -webkit-filter: brightness(1) saturate(1.3);
          filter: brightness(1) saturate(1.3);
}

/* Accordion body */
.faq-teaser .accordion-body {
  font-size: 0.95rem;
  color: #555555;
  padding: 1rem 1.2rem 1.2rem;
  line-height: 1.55;
}

/* ===========================
     Responsive
     =========================== */
@media (max-width: 767.98px) {
  .faq-teaser .accordion-button {
    font-size: 1rem;
  }
  .faq-teaser .accordion-body {
    font-size: 0.93rem;
  }
}

/* ===========================
   Inner Pages – Shared Styles
   =========================== */
/* Inner hero (page header) */
.inner-hero {
  background: radial-gradient(circle at top left, #f5f7fb 0, #ffffff 55%);
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
  border-bottom: 1px solid #e5e7eb;
  text-align: center;
}

.inner-hero h1 {
  font-size: clamp(2rem, 3vw, 2.5rem);
  margin-bottom: 0.9rem;
  color: #111827;
}

.inner-hero .section-eyebrow {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  font-weight: 600;
  color: #1fae45;
  margin-bottom: 0.6rem;
}

.inner-hero .section-intro {
  max-width: 40rem;
  margin: 0 auto;
  font-size: 1rem;
  color: #555555;
}

/* Main inner content section */
.inner-section {
  padding-top: 3.5rem;
  padding-bottom: 3.5rem;
  background-color: #ffffff;
}

.inner-section h2 {
  font-size: 1.35rem;
  margin-bottom: 0.6rem;
  color: #111827;
}

.inner-section p {
  font-size: 0.98rem;
  color: #555555;
  line-height: 1.6;
}

.inner-section ul {
  margin: 0 0 1rem 0;
  padding-left: 1.1rem;
  font-size: 0.96rem;
  color: #444444;
}

.inner-section ul li {
  margin-bottom: 0.35rem;
}

.inner-section .lead-copy {
  font-size: 1.02rem;
  color: #444444;
  margin-bottom: 1.5rem;
}

/* Right-hand CTA panel */
.inner-section .cta-panel {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: 1.75rem 1.5rem 1.6rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  background-color: #ffffff;
  -webkit-box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
          box-shadow: 0 18px 42px rgba(15, 23, 42, 0.14);
}

.inner-section .cta-panel h2 {
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}

.inner-section .cta-panel p {
  font-size: 0.95rem;
  margin-bottom: 0.4rem;
}

.inner-section .cta-panel .btn {
  font-size: 0.95rem;
}

.inner-section .cta-panel .btn-hero-primary {
  width: 100%;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

.inner-section .cta-panel .btn-outline-secondary {
  border-radius: 999px;
  border-width: 1px;
  border-color: #cbd2d9;
  color: #444444;
  background-color: #ffffff;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, -webkit-box-shadow 0.2s ease;
}

.inner-section .cta-panel .btn-outline-secondary:hover, .inner-section .cta-panel .btn-outline-secondary:focus {
  background-color: #35b658;
  border-color: #1fae45;
  color: #1fae45;
  -webkit-box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
          box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
}

.inner-section .cta-panel .btn-outline-secondary:active {
  -webkit-box-shadow: 0 4px 10px rgba(15, 23, 42, 0.1);
          box-shadow: 0 4px 10px rgba(15, 23, 42, 0.1);
}

.inner-section .cta-panel .small.text-muted {
  font-size: 0.85rem;
  color: #555555;
}

/* ===========================
     Responsive tweaks
     =========================== */
@media (max-width: 991.98px) {
  .inner-section {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
  .inner-section .cta-panel {
    margin-top: 1.5rem;
  }
}

@media (max-width: 767.98px) {
  .inner-hero {
    padding-top: 2.8rem;
    padding-bottom: 2.8rem;
  }
  .inner-section {
    padding-top: 2.5rem;
    padding-bottom: 2.5rem;
  }
  .inner-hero h1 {
    font-size: 2.1rem;
  }
  .inner-section .cta-panel {
    padding: 1.5rem 1.25rem 1.4rem;
  }
}

/* ===========================
   404 / Error Page
   =========================== */
.error-hero {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.error-body {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.error-actions .btn {
  font-size: 0.96rem;
}

.error-card {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: 1.6rem 1.4rem 1.5rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  background-color: #ffffff;
  -webkit-box-shadow: 0 18px 42px rgba(15, 23, 42, 0.12);
          box-shadow: 0 18px 42px rgba(15, 23, 42, 0.12);
}

.error-card h2 {
  font-size: 1.15rem;
  margin-bottom: 0.5rem;
}

.error-card p {
  font-size: 0.95rem;
  color: #555555;
}

.error-card ul {
  margin: 0 0 0.75rem 0;
  padding-left: 1.1rem;
  font-size: 0.94rem;
  color: #444444;
}

.error-icon-wrap {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 3rem;
  height: 3rem;
  border-radius: 999px;
  background-color: #35b658;
  margin-bottom: 0.75rem;
}

.error-icon {
  font-size: 1.6rem;
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
  .error-hero {
    padding-top: 2.4rem;
    padding-bottom: 2.4rem;
  }
  .error-body {
    padding-top: 2.4rem;
    padding-bottom: 2.4rem;
  }
  .error-card {
    margin-top: 0.5rem;
  }
}

/* ===========================
   Stairlift types cards
   Used on:
   - Home page "Stairlift options"
   - /stairlift-types.php hub page
   =========================== */
/*.stairlift-types {
  /* No padding here – handled by .section / .inner-section 
}*/
/* Card shell */
.stairlift-types .type-card {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  border-radius: 0.9rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  -webkit-box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
  padding: 1.5rem 1.4rem 1.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.5rem;
  height: 100%;
}

/* Card headings */
.stairlift-types .type-card h2,
.stairlift-types .type-card .h4 {
  font-size: 1.15rem;
  margin-bottom: 0.25rem;
  color: #111827;
}

/* Card copy */
.stairlift-types .type-card p {
  font-size: 0.95rem;
  color: #555555;
  margin-bottom: 0.75rem;
}

/* Link */
.stairlift-types .type-link {
  margin-top: auto;
  font-size: 0.95rem;
  font-weight: 500;
  color: #1fae45;
  text-decoration: none;
  position: relative;
  padding-bottom: 0.05rem;
}

.stairlift-types .type-link::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  height: 1px;
  width: 100%;
  background-color: #35b658;
  -webkit-transition: background-color 0.2s ease, width 0.2s ease;
  transition: background-color 0.2s ease, width 0.2s ease;
}

.stairlift-types .type-link:hover, .stairlift-types .type-link:focus {
  color: #1a9039;
}

.stairlift-types .type-link:hover::after, .stairlift-types .type-link:focus::after {
  background-color: #1fae45;
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
  .stairlift-types .type-card {
    padding: 1.4rem 1.25rem 1.25rem;
  }
}

.stairlift-types .type-card ul.type-list {
  margin: 0 0 1rem 0;
  padding-left: 1.1rem;
}

.stairlift-types .type-card ul.type-list li {
  font-size: 0.9rem;
  color: #444444;
  margin-bottom: 0.4rem;
  line-height: 1.45;
}

/* ===========================
   Legal / Content Pages
   =========================== */
.privacy-policy,
.cookies-policy {
  padding-top: 3rem;
  padding-bottom: 3rem;
  background-color: #ffffff;
  max-width: 760px;
  margin: 0 auto;
  color: #555555;
}

/* Headings */
.privacy-policy h2,
.cookies-policy h2 {
  font-size: 1.4rem;
  margin-top: 2rem;
  margin-bottom: 0.75rem;
  color: #111827;
}

.privacy-policy h3,
.cookies-policy h3 {
  font-size: 1.2rem;
  margin-top: 1.6rem;
  margin-bottom: 0.5rem;
  color: #111827;
}

/* Paragraphs */
.privacy-policy p,
.cookies-policy p {
  font-size: 0.98rem;
  line-height: 1.6;
  margin-bottom: 1rem;
  color: #555555;
}

/* Lists */
.privacy-policy ul,
.cookies-policy ul {
  padding-left: 1.1rem;
  margin-bottom: 1.5rem;
}

.privacy-policy ul li,
.cookies-policy ul li {
  margin-bottom: 0.4rem;
  font-size: 0.96rem;
  color: #444444;
}

/* Strong emphasis */
.privacy-policy strong,
.cookies-policy strong {
  color: #111827;
  font-weight: 600;
}

/* Spacing for the section container */
.privacy-policy,
.cookies-policy {
  padding-bottom: 4rem;
}

/* Responsive */
@media (max-width: 767.98px) {
  .privacy-policy,
  .cookies-policy {
    padding-top: 2.2rem;
    padding-bottom: 2.2rem;
  }
  .privacy-policy h2,
  .cookies-policy h2 {
    font-size: 1.3rem;
  }
  .privacy-policy h3,
  .cookies-policy h3 {
    font-size: 1.1rem;
  }
}

/* ===========================
   Thank You Page
   =========================== */
.thankyou-hero {
  padding-top: 3rem;
  padding-bottom: 3rem;
  border-bottom: 1px solid #e5e7eb;
}

.thankyou-hero h1 {
  font-size: clamp(2rem, 3vw, 2.4rem);
}

.thankyou-hero .section-intro {
  max-width: 38rem;
}

.thankyou-body {
  padding-top: 3rem;
  padding-bottom: 3rem;
}

.thankyou-body h2 {
  font-size: 1.35rem;
  margin-bottom: 0.6rem;
}

.thankyou-body p {
  font-size: 0.98rem;
  color: #555555;
}

.thankyou-body ul {
  margin: 0 0 1.25rem 0;
  padding-left: 1.1rem;
  font-size: 0.95rem;
  color: #444444;
}

.thankyou-body .thankyou-actions .btn {
  font-size: 0.95rem;
}

.thankyou-body .btn-outline-secondary {
  border-radius: 999px;
  border-width: 1px;
  border-color: #cbd2d9;
  color: #444444;
  background-color: #ffffff;
  -webkit-box-shadow: none;
          box-shadow: none;
  -webkit-transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, -webkit-box-shadow 0.2s ease;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease;
  transition: background-color 0.2s ease, color 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, -webkit-box-shadow 0.2s ease;
}

.thankyou-body .btn-outline-secondary:hover, .thankyou-body .btn-outline-secondary:focus {
  background-color: #35b658;
  border-color: #1fae45;
  color: #1fae45;
  -webkit-box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
          box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
}

.thankyou-body .btn-outline-secondary:active {
  -webkit-box-shadow: 0 4px 10px rgba(15, 23, 42, 0.1);
          box-shadow: 0 4px 10px rgba(15, 23, 42, 0.1);
}

/* Responsive tweaks */
@media (max-width: 767.98px) {
  .thankyou-hero {
    padding-top: 2.6rem;
    padding-bottom: 2.6rem;
  }
  .thankyou-body {
    padding-top: 2.4rem;
    padding-bottom: 2.4rem;
    text-align: left;
  }
  .thankyou-actions .btn {
    width: 100%;
    -webkit-box-pack: center;
        -ms-flex-pack: center;
            justify-content: center;
    margin-right: 0 !important;
  }
}

/* ===========================
   Quote + Survey Form Sections
   =========================== */
.quote-form-section,
.survey-form-section {
  background-color: #f5f7fb;
}

/* Main form panel */
.quote-form-section .form-panel,
.survey-form-section .form-panel {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: 1.75rem 1.5rem 1.6rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  background-color: #ffffff;
}

.quote-form-section .form-panel h2,
.survey-form-section .form-panel h2 {
  color: #111827;
}

.quote-form-section .form-panel p.small.text-muted,
.survey-form-section .form-panel p.small.text-muted {
  font-size: 0.9rem;
}

/* Side panel */
.quote-form-section .side-panel,
.survey-form-section .side-panel {
  background: #ffffff;
  border-radius: 0.75rem;
  -webkit-box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
          box-shadow: 0 10px 30px rgba(15, 23, 42, 0.08);
  border-radius: 1rem;
  padding: 1.5rem 1.4rem 1.4rem;
  border: 1px solid rgba(0, 0, 0, 0.06);
  background-color: #ffffff;
}

.quote-form-section .side-panel h3,
.survey-form-section .side-panel h3 {
  font-size: 1.05rem;
  margin-bottom: 0.35rem;
}

/* Numbered list inside side panel */
.quote-form-section .numbered-list,
.survey-form-section .numbered-list {
  counter-reset: quote-steps;
}

.quote-form-section .numbered-list li,
.survey-form-section .numbered-list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.55rem;
  margin-bottom: 0.5rem;
  color: #444444;
}

.quote-form-section .numbered-list li span,
.survey-form-section .numbered-list li span {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 999px;
  background-color: #35b658;
  color: #ffffff;
  font-weight: 600;
  font-size: 0.85rem;
  -ms-flex-negative: 0;
      flex-shrink: 0;
}

/* Form fields / labels / validation */
.quote-form-section .form-label,
.survey-form-section .form-label {
  font-size: 0.95rem;
  font-weight: 500;
  color: #444444;
  margin-bottom: 0.25rem;
}

.quote-form-section .form-control,
.quote-form-section .form-select,
.quote-form-section textarea.form-control,
.survey-form-section .form-control,
.survey-form-section .form-select,
.survey-form-section textarea.form-control {
  font-size: 0.95rem;
}

.quote-form-section .invalid-feedback,
.survey-form-section .invalid-feedback {
  font-size: 0.85rem;
}

/* Checkbox styling */
.quote-form-section .form-check-input,
.survey-form-section .form-check-input {
  cursor: pointer;
}

.quote-form-section .form-check-label,
.survey-form-section .form-check-label {
  cursor: pointer;
  font-size: 0.93rem;
}

/* Recaptcha block */
.quote-form-section .g-recaptcha,
.survey-form-section .g-recaptcha {
  -webkit-transform: scale(1);
          transform: scale(1);
  -webkit-transform-origin: left top;
          transform-origin: left top;
}

.quote-form-section #recaptcha-error,
.survey-form-section #recaptcha-error {
  display: none;
  /* shown by JS if needed */
  margin-top: 0.35rem;
}

/* Submit button + footer text */
.quote-form-section button[type="submit"],
.survey-form-section button[type="submit"] {
  font-size: 0.98rem;
}

.quote-form-section p.small.text-muted,
.survey-form-section p.small.text-muted {
  font-size: 0.86rem;
}

/* ===========================
      Responsive tweaks
      =========================== */
@media (max-width: 991.98px) {
  .quote-form-section .side-panel,
  .survey-form-section .side-panel {
    margin-top: 0.75rem;
  }
}

@media (max-width: 767.98px) {
  .quote-form-section .form-panel,
  .survey-form-section .form-panel {
    padding: 1.5rem 1.25rem 1.4rem;
  }
  .quote-form-section .side-panel,
  .survey-form-section .side-panel {
    padding: 1.4rem 1.2rem 1.3rem;
  }
}
/*# sourceMappingURL=main.css.map */