@media (max-width: 767.98px) {
  /* Let the section run wider on mobile */
  #call-to-action.call-to-action.section {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Remove container side gutters for this section only */
  #call-to-action > .container {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Make the CTA card nearly full-bleed on mobile only */
  #call-to-action .cta-wrapper {
    width: calc(100vw - 16px) !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
    border-radius: 0 !important;
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  /* Tighten internal grid spacing slightly */
  #call-to-action .row.align-items-center.g-4 {
    --bs-gutter-x: 1rem !important;
    --bs-gutter-y: 1rem !important;
  }

  /* Give content full usable width */
  #call-to-action .cta-content {
    padding-left: 0 !important;
    padding-right: 0 !important;
  }

  /* Let heading and body copy breathe */
  #call-to-action .cta-content h2 {
    line-height: 1.08 !important;
    margin-bottom: 0.9rem !important;
  }

  #call-to-action .cta-content p {
    line-height: 1.6 !important;
  }

  /* Stack signup fields vertically */
  #call-to-action .cta-signup-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.85rem !important;
  }

  #call-to-action .cta-signup-row .form-group,
  #call-to-action .cta-signup-row .form-group.form-group-submit {
    width: 100% !important;
  }

  /* Roomier form controls */
  #call-to-action .cta-signup-form .form-control {
    width: 100% !important;
    min-height: 56px !important;
    padding: 0.95rem 1rem !important;
    font-size: 1rem !important;
    line-height: 1.35 !important;
    border-radius: 0.95rem !important;
  }

  #call-to-action .cta-signup-form .form-control::placeholder {
    font-size: 1rem !important;
  }

  /* Full-width submit */
  #call-to-action .cta-signup-form button[type="submit"] {
    width: 100% !important;
    min-height: 56px !important;
    justify-content: center !important;
  }

  /* Consent readability */
  #call-to-action .cta-signup-consent {
    margin-top: 0.85rem !important;
  }

  #call-to-action .cta-signup-consent .consent-check {
    align-items: flex-start !important;
    gap: 0.65rem !important;
    line-height: 1.45 !important;
  }

  /* Stack secondary CTAs */
  #call-to-action .cta-buttons {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 0.75rem !important;
  }

  #call-to-action .cta-buttons .hero-cta-btn {
    width: 100% !important;
    justify-content: center !important;
  }
}

@media (max-width: 575.98px) {
  /* Push the card even closer to the screen edges */
  #call-to-action .cta-wrapper {
    width: calc(100vw - 8px) !important;
    border-radius: 0 !important;
    padding-left: 0.9rem !important;
    padding-right: 0.9rem !important;
  }

  #call-to-action .cta-content h2 {
    font-size: clamp(1.9rem, 8vw, 2.4rem) !important;
  }

  /* Keep countdown on one row */
  #call-to-action .countdown {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 0.4rem !important;
    align-items: start !important;
  }

  #call-to-action .countdown > div {
    min-width: 0 !important;
    padding: 0.45rem 0.25rem !important;
  }

  #call-to-action .countdown h3 {
    margin: 0 0 0.2rem !important;
    font-size: clamp(1.1rem, 4.8vw, 1.45rem) !important;
    line-height: 1 !important;
  }

  #call-to-action .countdown h4 {
    margin: 0 !important;
    font-size: 0.68rem !important;
    line-height: 1.1 !important;
    letter-spacing: 0.04em !important;
  }
}


/* =========================================================
   CTA SECTION — FIRE VIDEO BEHIND CARD
========================================================= */

#call-to-action.call-to-action{
  position: relative;
  overflow: hidden;
  isolation: isolate;
  background: #0c1216; /* fallback while video loads */
}

/* background video sits on the section itself */
#call-to-action .cta-bg-video{
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  z-index: 0;
  pointer-events: none;
  opacity: 0.55;
  filter: brightness(0.72) saturate(1.05) contrast(1.03);
}

/* overlay to keep the fire atmospheric, not overpowering */
#call-to-action .cta-bg-overlay{
  position: absolute;
  inset: 0;
  z-index: 1;
  pointer-events: none;
  background:
    linear-gradient(
      180deg,
      rgba(7, 10, 12, 0.18) 0%,
      rgba(7, 10, 12, 0.08) 35%,
      rgba(7, 10, 12, 0.08) 65%,
      rgba(7, 10, 12, 0.22) 100%
    );
}

/* content stays above the video */
#call-to-action .container{
  position: relative;
  z-index: 2;
}

/* keep your existing blue card look, just ensure it sits above cleanly */
#call-to-action .cta-wrapper{
  position: relative;
  z-index: 2;
}

/* mobile: slightly softer fire */
@media (max-width: 767.98px){
  #call-to-action .cta-bg-video{
    opacity: 0.38;
    filter: brightness(0.62) saturate(0.95) contrast(1.02);
  }

  #call-to-action .cta-bg-overlay{
    background:
      linear-gradient(
        180deg,
        rgba(7, 10, 12, 0.78) 0%,
        rgba(7, 10, 12, 0.60) 50%,
        rgba(7, 10, 12, 0.82) 100%
      );
  }
}