.elementor-1632 .elementor-element.elementor-element-5c31101c{--display:flex;}.elementor-1632 .elementor-element.elementor-element-5c31101c:not(.elementor-motion-effects-element-type-background), .elementor-1632 .elementor-element.elementor-element-5c31101c > .elementor-motion-effects-container > .elementor-motion-effects-layer{background-color:transparent;background-image:linear-gradient(180deg, #ECDCF2 0%, #DDC9E4 100%);}/* Start custom CSS */.ccfy-home {
  font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  color: #1f2933;
  /* Soft lilac/purple magical background */
  background:
    radial-gradient(circle at top left, #e7c4ff 0, #f6e4ff 40%, #ffffff 80%),
    linear-gradient(135deg, #b057a1 0%, #8b5fbf 50%, #5b3f9b 100%);
  background-blend-mode: screen;
  padding: 6rem 1.5rem 4rem;
  box-sizing: border-box;
}

/* Center + max width */
.ccfy-container {
  max-width: 1120px;
  margin: 0 auto;
}

/* Utilities */
.ccfy-tagline {
  letter-spacing: .15em;
  text-transform: uppercase;
  font-size: .8rem;
  color: #b057a1; /* deep mauve accent */
  font-weight: 600;
  margin-bottom: .5rem;
}

.ccfy-eyebrow {
  font-size: .95rem;
  color: #4b5563;
}

/* ===== HERO ===== */
.ccfy-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 1fr);
  gap: 3rem;
  align-items: center;
}

.ccfy-hero-title {
  font-size: 3rem;
  line-height: 1.05;
  margin: 0 0 1rem;
}

/* Magic underline using purple gradient */
.ccfy-hero-title span.ccfy-mark {
  position: relative;
  display: inline-block;
}

.ccfy-hero-title span.ccfy-mark::after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0.1em;
  width: 100%;
  height: .45em;
  background: linear-gradient(90deg, #b057a1, #c471ed, #5b3f9b);
  opacity: .35;
  z-index: -1;
}

.ccfy-hero-sub {
  font-size: 1.15rem;
  max-width: 30rem;
  color: #4b5563;
  margin-bottom: 1.5rem;
}

.ccfy-hero-quote {
  font-size: 1rem;
  font-style: italic;
  color: #6b7280;
  margin-bottom: 2rem;
}

/* Hero image */
.ccfy-hero-media img {
  width: 100%;
  height: auto;
  border-radius: 1.5rem;
  box-shadow: 0 20px 45px rgba(15, 23, 42, .22);
  object-fit: cover;
}

/* Magical 1‑column feature image above intro */
.ccfy-feature {
  margin: 2.5rem auto 1.5rem;
  max-width: 520px;
}

.ccfy-feature-inner {
  position: relative;
  padding: 1.4rem;
  border-radius: 1.75rem;
  background: radial-gradient(circle at top left, rgba(164,71,166,.25), transparent 55%),
              radial-gradient(circle at bottom right, rgba(31,183,179,.25), transparent 55%);
  box-shadow: 0 18px 40px rgba(15,23,42,.22);
}

.ccfy-feature-inner::before {
  content: "";
  position: absolute;
  inset: 12%;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,.6);
  opacity: .6;
  pointer-events: none;
}

.ccfy-feature-img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: 1.4rem;
}

/* Mobile tweaks inherit main breakpoints; just center on small screens */
@media (max-width: 640px) {
  .ccfy-feature {
    margin: 2rem auto 1rem;
    padding: 0 .2rem;
  }
}

/* ===== PRIMARY BUTTON – PURPLE GRADIENT ===== */
.ccfy-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  padding: .9rem 1.6rem;
  border-radius: 999px;
  border: none;
  background: linear-gradient(135deg, #b057a1 0%, #c471ed 45%, #5b3f9b 100%);
  color: #ffffff;
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 12px 25px rgba(80, 41, 136, .55);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

.ccfy-btn-primary span.ccfy-pill {
  font-size: .75rem;
  padding: .15rem .6rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.6);
  background: rgba(22, 10, 48, .3);
}

.ccfy-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 35px rgba(80, 41, 136, .65);
}

/* ===== INTRO SECTION ===== */
.ccfy-section {
  margin-top: 4rem;
}

.ccfy-section h2 {
  font-size: 1.8rem;
  margin-bottom: 1rem;
}

.ccfy-lead {
  font-size: 1.05rem;
  color: #4b5563;
  max-width: 48rem;
}

/* Center CCFY intro heading + text */
#ccfy-about h2,
#ccfy-about .ccfy-lead {
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

/* ===== HOW IT WORKS ===== */
.ccfy-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1.75rem;
  margin-top: 2rem;
}

.ccfy-step-card {
  background: #ffffff;
  border-radius: 1.25rem;
  border: 1px solid rgba(148,163,184,.28);
  padding: 1.5rem 1.4rem;
  box-shadow: 0 12px 28px rgba(15,23,42,.08);
}

.ccfy-step-label {
  font-size: .8rem;
  text-transform: uppercase;
  letter-spacing: .14em;
  color: #b057a1;
  font-weight: 600;
  margin-bottom: .5rem;
}

.ccfy-step-title {
  font-size: 1.1rem;
  font-weight: 600;
  margin-bottom: .4rem;
}

.ccfy-step-text {
  font-size: .95rem;
  color: #4b5563;
}

/* ===== GRID EXPLAINER ===== */
.ccfy-note {
  margin-top: 1rem;
  font-size: .95rem;
  color: #6b7280;
}

/* ===== NEWSLETTER ===== */
.ccfy-newsletter {
  margin-top: 4rem;
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(0, .9fr);
  gap: 2.5rem;
  align-items: center;
}

.ccfy-newsletter-card {
  background: radial-gradient(circle at top left, #f3e1ff 0, #fdf2ff 35%, #ffffff 80%);
  border-radius: 1.75rem;
  padding: 2rem 1.8rem;
  box-shadow: 0 18px 40px rgba(76, 29, 149, .25);
  position: relative;
  overflow: hidden;
}

.ccfy-newsletter-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at top left, rgba(192,113,237,.26), transparent 55%),
    radial-gradient(circle at bottom right, rgba(91,63,155,.3), transparent 55%);
  mix-blend-mode: screen;
  pointer-events: none;
}

.ccfy-newsletter-title {
  font-size: 1.4rem;
  margin-bottom: .6rem;
}

.ccfy-newsletter-text {
  font-size: .98rem;
  color: #4b5563;
  margin-bottom: 1.4rem;
}

/* Newsletter form */
.ccfy-newsletter-form {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
}

.ccfy-newsletter-form input[type="email"] {
  min-width: 0;
  flex: 1 1 180px;
  padding: .85rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,.9);
  font-size: .9rem;
}

.ccfy-newsletter-form button {
  border: none;
}

/* Newsletter images row */
.ccfy-brand-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  justify-content: center;
}

.ccfy-brand-strip img {
  border-radius: 1rem;
  width: 100%;
  max-width: 180px;
  height: auto;
  object-fit: cover;
  box-shadow: 0 10px 22px rgba(15,23,42,.15);
}

/* Make sure both hero + newsletter buttons share the same look */
.ccfy-btn-primary,
.ccfy-newsletter-form .ccfy-btn-primary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  padding: .9rem 1.6rem;
  border-radius: 999px;
  border: none;
  background: linear-gradient(135deg, #b057a1 0%, #c471ed 45%, #5b3f9b 100%);
  color: #ffffff;
  font-weight: 600;
  font-size: .95rem;
  text-decoration: none;
  cursor: pointer;
  box-shadow: 0 12px 25px rgba(80, 41, 136, .55);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease;
}

/* Keep inner pill styling for hero CTA */
.ccfy-btn-primary .ccfy-pill {
  font-size: .75rem;
  padding: .15rem .6rem;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.6);
  background: rgba(22, 10, 48, .3);
}

.ccfy-btn-primary:hover {
  transform: translateY(-1px);
  box-shadow: 0 18px 35px rgba(80, 41, 136, .65);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 960px) {
  .ccfy-home {
    padding: 4.5rem 1.25rem 3.25rem;
  }
  .ccfy-hero {
    grid-template-columns: minmax(0,1fr);
  }
  .ccfy-hero-media {
    order: -1;
  }
  .ccfy-hero-title {
    font-size: 2.4rem;
  }
  .ccfy-steps {
    grid-template-columns: repeat(2,minmax(0,1fr));
  }
  .ccfy-newsletter {
    grid-template-columns: minmax(0,1fr);
  }
}

@media (max-width: 640px) {
  .ccfy-home {
    padding: 3.5rem 1.1rem 2.8rem;
  }
  .ccfy-hero-title {
    font-size: 2rem;
  }
  .ccfy-hero-sub {
    font-size: 1.02rem;
  }
  .ccfy-steps {
    grid-template-columns: minmax(0,1fr);
  }
  .ccfy-step-card {
    padding: 1.25rem 1.1rem;
  }
  .ccfy-newsletter-card {
    padding: 1.6rem 1.4rem;
  }
  .ccfy-brand-strip {
    justify-content: center;
  }
}/* End custom CSS */