/* ============================================================
   CFA DESIGN SYSTEM — GLOBAL POLISH
   Phase 4: QA / Compare / Polish — Full scope
   Crowd for Angels Visual Identity

   Covers cross-cutting elements present on every page:
   1. Risk warning sticky banner (.cfa-risk-banner)
   2. Footer (.footer_wrapper.iom, .inner-footer, .footer-text)
   3. Sticky footer note (.sticky-footer-note)
   4. Footer risk paragraph (.footerpara, .text_alt)
   5. Pagination (Bootstrap .pagination overrides)
   6. Minimal layout wrapper (.content_wrapper-iom)
   ============================================================ */


/* ── clearfix utility (used platform-wide) ── */
.mdr-clearfix,
.clearfix {
  clear: both;
  display: block;
}

/* FIX-07: Footer list reset — replaces inline style="padding:0" in footer ULs */
.footer-list-reset {
  padding: 0;
  list-style: none;
}

/* ============================================================
   1. RISK WARNING STICKY BANNER
   Applied via .cfa-risk-banner on the sticky top div in layout.phtml
   Design system: COMPONENT_LIBRARY §16 — navy bg, small text
   ============================================================ */

.cfa-risk-banner {
  background: var(--cfa-navy) !important;
  color: rgba(255, 255, 255, 0.65) !important;
  padding: 10px 20px !important;
  font-size: 14px !important;
  font-family: var(--cfa-font-body);
  font-weight: 400;
  letter-spacing: 0.01em;
  text-align: center;
  position: sticky;
  top: 0;
  z-index: 200;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

@media (max-width: 768px) {
  .cfa-risk-banner {
    font-size: 10px !important;
    padding: 5px 12px !important;
    line-height: 1.35 !important;
  }
}

.cfa-risk-banner b,
.cfa-risk-banner strong {
  color: rgba(255, 255, 255, 0.9) !important;
  font-weight: 600 !important;
  font-size: inherit !important;
}

.cfa-risk-banner a {
  color: #93B4FF !important;
  text-decoration: none;
  font-weight: 500;
}

.cfa-risk-banner a:hover {
  text-decoration: underline;
}

/* remove legacy <font> tag styling in the banner */
.cfa-risk-banner font {
  font-family: var(--cfa-font-body) !important;
  color: inherit !important;
}

/* remove extra whitespace from nested divs/spans and trailing <br> */
.cfa-risk-banner div,
.cfa-risk-banner span {
  display: inline;
}
.cfa-risk-banner br {
  display: none;
}


/* ============================================================
   2. FOOTER
   .footer_wrapper.iom / .inner-footer / .footer-text / .iom-pad
   Design system: COMPONENT_LIBRARY §18 — navy dark footer
   ============================================================ */

.footer_wrapper.iom,
footer .footer_wrapper {
  background: var(--cfa-navy) !important;
  color: var(--cfa-on-dark-mid);
  padding: 3rem 0 2rem;
}

.footer_wrapper.iom .container,
.footer_wrapper .contair-iom {
  max-width: var(--cfa-container-max, 1320px);
  margin: 0 auto;
}

/* footer section heading */
.footer-text {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-base, 16px) !important;
  font-weight: var(--cfa-weight-bold, 700) !important;
  color: var(--cfa-on-dark) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  display: block;
  margin-bottom: 0.875rem;
}

/* footer nav list items */
.iom-pad,
.footer_wrapper.iom ul > li {
  list-style: none !important;
  padding: 0 !important;
  margin-bottom: 0.5rem !important;
}

.iom-pad a,
.footer_wrapper.iom ul > li a {
  font-size: var(--cfa-text-base, 16px) !important;
  color: var(--cfa-on-dark-muted) !important;
  text-decoration: none !important;
  font-weight: var(--cfa-weight-normal, 400);
  transition: color var(--cfa-transition-fast);
  line-height: 1.6;
}

.iom-pad a:hover,
.footer_wrapper.iom ul > li a:hover {
  color: var(--cfa-on-dark) !important;
  text-decoration: none !important;
}

.iom-pad-top {
  margin-top: 1.5rem;
}

/* divider between nav and bottom bar */
.footer_links.mfooter_links-iom {
  border-top: 1px solid var(--cfa-on-dark-border);
  margin-top: 2rem;
  margin-bottom: 40px;
  padding-top: 1.5rem;
}

/* FCA registration text */
.footer-info p {
  font-size: var(--cfa-text-xs, 13px) !important;
  color: var(--cfa-on-dark-muted) !important;
  line-height: 1.6;
  max-width: 800px;
  text-align: center;
  margin: 0 auto;
}


/* ============================================================
   2b. FOOTER PARTNER LOGOS
   .footer-iom / .footer-logo / .imgukcrowdfund / .imggdf
   ============================================================ */

.footer-iom {
  padding-top: 1em;
}

.footer-logo-link {
  display: inline-block;
}

img.footer-logo {
  filter: brightness(0) invert(1) hue-rotate(0deg);
  opacity: 1;
  transition: filter 0.2s ease;
}

img.imgukcrowdfund:hover,
img.imggdf:hover {
  filter: brightness(1) invert(1) hue-rotate(180deg);
}

img.imgukcrowdfund {
  width: 100% !important;
  max-width: 200px !important;
  height: auto !important;
}

img.imggdf {
  width: auto !important;
  max-width: 100px !important;
  height: auto !important;
}

/* ============================================================
   3. FOOTER SOCIAL ICONS
   .icon-bar-outerdiv / .inner-icon-bar
   ============================================================ */

.icon-bar-outerdiv {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin: 1.25rem 0;
}

.inner-icon-bar a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--cfa-on-dark-faint);
  border: 1px solid var(--cfa-on-dark-border);
  color: var(--cfa-on-dark-mid) !important;
  font-size: var(--cfa-text-sm);
  text-decoration: none !important;
  transition: background var(--cfa-transition-fast), color var(--cfa-transition-fast), border-color var(--cfa-transition-fast);
}

.inner-icon-bar a:hover {
  background: var(--cfa-cobalt) !important;
  border-color: var(--cfa-cobalt) !important;
  color: var(--cfa-on-dark) !important;
}


/* ============================================================
   4. STICKY FOOTER NOTE
   .sticky-footer-note — bottom-of-page risk note
   ============================================================ */

.sticky-footer-note {
  background: var(--cfa-navy);
  border-top: 2px solid var(--cfa-cobalt);
  text-align: center;
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  z-index: 9998;
  padding: 0 24px;
}

.sticky-footer-note p {
  font-size: var(--cfa-text-xs, 13px) !important;
  color: var(--cfa-on-dark-mid) !important;
  margin: 0;
  line-height: 1.5;
}

@media (max-width: 768px) {
  .sticky-footer-note p {
    font-size: 10px !important;
    line-height: 1.35 !important;
  }
  .sticky-footer-note {
    padding: 0 12px;
  }
}

.sticky-footer-note a,
.sticky-footer-note a.bite {
  color: var(--cfa-cobalt-link) !important;
  text-decoration: underline;
  text-underline-offset: 2px;
}

.sticky-footer-note a:hover {
  color: var(--cfa-on-dark) !important;
}

/* Pitch “join to read” bar: same z-index as .sticky-footer-note; footer is later in DOM and
   would cover the bottom of this bar — lift it above the risk banner + extra bottom padding. */
.cc-registrationSneakPeek {
  bottom: calc(4.75rem + env(safe-area-inset-bottom, 0px));
  padding-bottom: 1.5rem;
}

@media (max-width: 767px) {
  .cc-registrationSneakPeek {
    bottom: calc(5rem + env(safe-area-inset-bottom, 0px));
    padding-bottom: 1.5rem;
  }
}


/* ============================================================
   5. FOOTER RISK PARAGRAPH SECTION
   .footerpara / .center_text / .text_alt
   ============================================================ */

.footerpara {
  background: var(--cfa-bg-soft);
  border-radius: var(--cfa-radius-lg, 12px);
  border: 1px solid var(--cfa-border);
  padding: 2rem 2.5rem;
  margin: 2rem 0;
}

.footerpara .center_text,
.footerpara h3.center_text {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-xl, 22px) !important;
  font-weight: var(--cfa-weight-extrabold, 800) !important;
  color: var(--cfa-text) !important;
  text-align: center;
  margin-bottom: 1rem;
}

.footerpara .text_alt,
.footerpara p.text_alt {
  font-size: 16px !important;
  color: var(--cfa-text-muted) !important;
  line-height: 1.7;
  margin-bottom: 1rem;
}

.footerpara .text_alt a {
  color: var(--cfa-cobalt) !important;
  text-decoration: underline;
  text-underline-offset: 2px;
}


/* ============================================================
   6. PAGINATION
   Bootstrap .pagination overrides → CFA cobalt style
   Targets: paginator.phtml .pagination Bootstrap pattern
   Design system: COMPONENT_STATES §9
   ============================================================ */

.pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  list-style: none;
  padding: 0;
  margin: 1.5rem 0;
  justify-content: center;
}

.pagination > li {
  display: block;
}

.pagination > li > a,
.pagination > li > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 0.625rem;
  background: var(--cfa-bg);
  border: 1.5px solid var(--cfa-border);
  border-radius: var(--cfa-radius-sm, 8px);
  color: var(--cfa-text-mid) !important;
  font-size: var(--cfa-text-sm, 14px);
  font-weight: var(--cfa-weight-semibold, 600);
  font-family: var(--cfa-font-body);
  text-decoration: none !important;
  transition: background var(--cfa-transition-fast), border-color var(--cfa-transition-fast), color var(--cfa-transition-fast);
  line-height: 1;
}

.pagination > li > a:hover {
  background: var(--cfa-cobalt-pale) !important;
  border-color: var(--cfa-cobalt) !important;
  color: var(--cfa-cobalt) !important;
  text-decoration: none !important;
}

/* active / current page */
.pagination > li.active > a,
.pagination > li.active > span,
.pagination > li.active > a:hover,
.pagination > li.active > a:focus {
  background: var(--cfa-cobalt) !important;
  border-color: var(--cfa-cobalt) !important;
  color: var(--cfa-on-dark) !important;
  box-shadow: 0 2px 8px rgba(36, 81, 209, 0.25);
}

/* disabled prev/next */
.pagination > li.disabled > a,
.pagination > li.disabled > span {
  background: var(--cfa-bg-soft) !important;
  border-color: var(--cfa-border) !important;
  color: var(--cfa-text-muted) !important;
  opacity: 0.50;
  cursor: not-allowed;
  pointer-events: none;
}

/* focus ring on pagination */
.pagination > li > a:focus-visible {
  outline: 2px solid var(--cfa-cobalt);
  outline-offset: 2px;
}


/* ============================================================
   7. MINIMAL LAYOUT WRAPPER
   .content_wrapper-iom — used in noheaderfooterlayout.phtml
   ============================================================ */

/* Sticky footer — container grows to fill viewport, footer sticks to bottom */
body.cfa-app {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}

/* Container takes all available space between header and footer */
body.cfa-app > .container {
  flex: 1;
}

/* Footer sits immediately below the container — no gap */
body.cfa-app > footer {
  margin-top: 0;
}

.content_wrapper-iom {
  padding: 2rem 0 0;
}


/* ============================================================
   8. SECTION HORIZONTAL PADDING
   — Adds consistent left/right breathing room inside every
     .sixteen.columns row without touching the fixed container width.
   ============================================================ */

.container > .sixteen.columns,
.content_wrapper-iom .sixteen.columns {
  box-sizing: border-box !important;
  padding-left: 24px !important;
  padding-right: 24px !important;
}

/* On very narrow viewports keep a minimum gutter */
@media (max-width: 767px) {
  .container > .sixteen.columns,
  .content_wrapper-iom .sixteen.columns {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }
}

/* ============================================================
   8. RESPONSIVE
   ============================================================ */

@media (max-width: 767px) {
  .footer_wrapper.iom {
    padding: 2rem 0 4rem;
  }

  .footerpara {
    padding: 1.5rem 1rem;
  }

  .icon-bar-outerdiv {
    justify-content: center;
  }

  .pagination > li > a,
  .pagination > li > span {
    min-width: 32px;
    height: 32px;
    font-size: var(--cfa-text-xs);
  }
}


/* ============================================================
   LEGACY TEAL (#00b9b2 / #01b1af) BUTTON & ACTION SWEEP
   Replaces all designer.css teal buttons with CFA tokens.

   Amber  = primary CTA (join, register, hero actions)
   Cobalt = form submits, transactional actions
   ============================================================ */

/* ── Amber CTAs (join / register / hero actions) ── */
.banner_btn a,
.slider_left a,
.call_to_action a.register_btn,
.isa-register-btn a,
.isa-register-btn a:hover,
span.about-us-iom,
a.touch-button,
a.touch-button_new {
  background: var(--cfa-amber) !important;
  color: var(--cfa-on-dark) !important;
  border: none !important;
  border-radius: var(--cfa-radius-md) !important;
  font-family: var(--cfa-font-body) !important;
  font-weight: var(--cfa-weight-semibold) !important;
  text-decoration: none !important;
}

.banner_btn a:hover,
.slider_left a:hover,
.call_to_action a.register_btn:hover,
span.about-us-iom:hover,
a.touch-button:hover,
a.touch-button_new:hover {
  background: var(--cfa-amber-hover) !important;
  color: var(--cfa-on-dark) !important;
  text-decoration: none !important;
}


/* ── Cobalt submits (form submits, transactional) ── */
a.form_signup_btn,
button.form_signup_btn,
.form_submit_old,
.form_submit_floatright,
.form_submit_floatrightcompany,
.isa_your_transfer_btn,
.bluebtn,
.investbluebtn,
.button.primary,
.btn_normal-new,
.invst-submit,
.fund-btn,
.green_btn,
.green_btn2,
.Pay-now,
.continue,
input.submit-ico,
.pixfort_hotel_5 .Res_btn a,
.pixfort_hotel_5 span.gethouse_btn a,
.login-main,
.social-padding a.btn_read_more {
  background: var(--cfa-cobalt) !important;
  color: var(--cfa-on-dark) !important;
  border: none !important;
  border-radius: var(--cfa-radius-md) !important;
  font-family: var(--cfa-font-body) !important;
  font-weight: var(--cfa-weight-semibold) !important;
  text-decoration: none !important;
  cursor: pointer !important;
}

a.form_signup_btn:hover,
button.form_signup_btn:hover,
.bluebtn:hover,
.button.primary:hover,
.green_btn:hover,
.green_btn2:hover,
.Pay-now:hover,
.continue:hover,
.login-main:hover,
.social-padding a.btn_read_more:hover {
  background: var(--cfa-cobalt-mid) !important;
  color: var(--cfa-on-dark) !important;
  text-decoration: none !important;
}


/* ── ISA / open account element ── */
#open_is_a {
  background: var(--cfa-cobalt) !important;
  border-radius: var(--cfa-radius-md) !important;
}


/* ── Outline button variant ── */
button.btn-outline {
  background: transparent !important;
  border: 2px solid var(--cfa-cobalt) !important;
  color: var(--cfa-cobalt) !important;
  border-radius: var(--cfa-radius-md) !important;
  font-family: var(--cfa-font-body) !important;
  font-weight: var(--cfa-weight-semibold) !important;
  cursor: pointer !important;
}

button.btn-outline.btn-populous {
  background: var(--cfa-cobalt) !important;
  color: var(--cfa-on-dark) !important;
}

button.btn-outline a {
  color: var(--cfa-cobalt) !important;
  text-decoration: none !important;
}

button.btn-outline.btn-populous a {
  color: var(--cfa-on-dark) !important;
}


/* ── Decorative / utility teal remnants ── */
.horizontal_br:before {
  background-color: var(--cfa-cobalt) !important;
}

.background_green {
  background-color: var(--cfa-cobalt-pale) !important;
}

.inner_funds h2,
.inner_funds h3 {
  color: var(--cfa-cobalt) !important;
}

li.dropdown.logout_menu:hover label {
  color: var(--cfa-cobalt) !important;
}


/* ============================================================
   PAGINATION  (.cfa-pagination  — used by market/paginator.phtml)
   ============================================================ */

.cfa-pagination-wrap {
  display: flex;
  justify-content: center;
  padding: var(--cfa-space-6) 0 var(--cfa-space-4);
}

ul.cfa-pagination {
  display: inline-flex !important;
  align-items: center !important;
  gap: var(--cfa-space-1) !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}

.cfa-page-item {
  list-style: none !important;
}

.cfa-page-link {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 36px !important;
  height: 36px !important;
  padding: 0 var(--cfa-space-2) !important;
  border: 1.5px solid var(--cfa-border) !important;
  border-radius: var(--cfa-radius-md) !important;
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  font-weight: var(--cfa-weight-medium) !important;
  color: var(--cfa-text-mid) !important;
  background: var(--cfa-bg) !important;
  text-decoration: none !important;
  transition: background var(--cfa-transition-fast), border-color var(--cfa-transition-fast), color var(--cfa-transition-fast) !important;
  cursor: pointer;
  line-height: 1;
}

a.cfa-page-link:hover {
  background: var(--cfa-cobalt-pale) !important;
  border-color: var(--cfa-cobalt-border) !important;
  color: var(--cfa-cobalt) !important;
  text-decoration: none !important;
}

.cfa-page-item.active .cfa-page-link {
  background: var(--cfa-cobalt) !important;
  border-color: var(--cfa-cobalt) !important;
  color: var(--cfa-on-dark) !important;
  cursor: default;
  font-weight: var(--cfa-weight-bold) !important;
}

a.cfa-page-link:focus-visible {
  outline: 2px solid var(--cfa-cobalt) !important;
  outline-offset: 2px !important;
  border-color: var(--cfa-cobalt) !important;
}

.cfa-page-item.disabled .cfa-page-link {
  opacity: 0.40 !important;
  cursor: not-allowed !important;
  pointer-events: none !important;
}

.cfa-page-link .fa {
  font-size: 11px !important;
  line-height: 1 !important;
}


/* ============================================================
   LEGACY BRIDGE ALIASES
   Maps pre-migration classes to CFA design tokens.
   Do not use in new markup — migrate gradually.
   ============================================================ */

.blue_btn,
.blue_btn a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  font-size: var(--cfa-text-sm);
  font-weight: var(--cfa-weight-bold);
  font-family: var(--cfa-font-body);
  line-height: 1;
  border-radius: var(--cfa-radius-md);
  border: 2px solid transparent;
  background: var(--cfa-cobalt);
  color: #ffffff;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--cfa-transition-fast),
              box-shadow var(--cfa-transition-fast),
              transform var(--cfa-transition-fast);
}

.blue_btn:hover,
.blue_btn a:hover {
  background: var(--cfa-cobalt-mid);
  transform: translateY(-1px);
  box-shadow: var(--cfa-shadow-sm);
  color: #ffffff;
  text-decoration: none;
}

.blue_btn:focus-visible,
.blue_btn a:focus-visible {
  outline: 3px solid var(--cfa-cobalt);
  outline-offset: 2px;
}

.investbluebtn,
.investbluebtn a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 20px;
  font-size: var(--cfa-text-sm);
  font-weight: var(--cfa-weight-bold);
  font-family: var(--cfa-font-body);
  line-height: 1;
  border-radius: var(--cfa-radius-md);
  border: 2px solid transparent;
  background: var(--cfa-amber);
  color: #ffffff;
  cursor: pointer;
  text-decoration: none;
  transition: background var(--cfa-transition-fast),
              box-shadow var(--cfa-transition-fast),
              transform var(--cfa-transition-fast);
}

.investbluebtn:hover,
.investbluebtn a:hover {
  background: var(--cfa-amber-hover);
  transform: translateY(-1px);
  box-shadow: var(--cfa-shadow-amber);
  color: #ffffff;
  text-decoration: none;
}

.investbluebtn:focus-visible,
.investbluebtn a:focus-visible {
  outline: 3px solid var(--cfa-amber);
  outline-offset: 2px;
}


/* ================================================================
   LEGACY POPUP DIALOG — CFA DESIGN SYSTEM OVERRIDE
   Targets: #doc_shade, .popup_dialog_box, .popup_dialog_content
   and all child elements rendered by popup_window.js
   ================================================================ */

/* Fix shade to cover viewport (not document) */
#doc_shade,
#my_doc_shade {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(27, 43, 107, 0.55) !important;
  backdrop-filter: blur(3px) !important;
  -webkit-backdrop-filter: blur(3px) !important;
  opacity: 1 !important;
  z-index: 1050 !important;
}

/* Center the dialog on screen */
.popup_dialog_box,
.my_popup_dialog_box {
  position: fixed !important;
  top: 50% !important;
  left: 50% !important;
  transform: translate(-50%, -50%) !important;
  width: calc(100% - 48px) !important;
  max-width: 520px !important;
  max-height: 88vh !important;
  height: auto !important;
  z-index: 1100 !important;
  background: var(--cfa-bg) !important;
  border-radius: var(--cfa-radius-xl) !important;
  box-shadow: var(--cfa-shadow-xl) !important;
  overflow: hidden !important;
  margin: 0 !important;
}

/* Strip legacy decorative chrome, keep title structure */
.popup_dialog_b,
.popup_dialog_t_r,
.popup_dialog_t_l,
.popup_dialog_b_r,
.popup_dialog_b_l,
.popup_dialog_b_c,
.popup_dialog_c_r,
.popup_dialog_c_l {
  display: none !important;
}

/* Title wrapper — hidden, close button floats above content */
.popup_dialog_t {
  display: none !important;
}

.popup_dialog_t_c {
  display: none !important;
}

.popup_dialog_nav {
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: var(--cfa-space-4) !important;
}

.popup_dialog_nav li,
.popup_dialog_nav li div {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-lg) !important;
  font-weight: var(--cfa-weight-extrabold) !important;
  color: var(--cfa-text) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Content area — scrollable, not full height; top padding clears the close button */
.popup_dialog_c {
  height: auto !important;
  min-height: 0 !important;
  max-height: 88vh !important;
  overflow-y: auto !important;
  padding: 0 !important;
  -webkit-overflow-scrolling: touch;
}

.popup_dialog_content {
  height: auto !important;
  min-height: 0 !important;
}

.popup_dialog_c_c {
  height: auto !important;
  min-height: 0 !important;
  display: block !important;
}

#popup_dialog_content_placement {
  padding: 60px var(--cfa-space-7) var(--cfa-space-7) !important;
  background: var(--cfa-bg) !important;
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  color: var(--cfa-text-muted) !important;
  line-height: var(--cfa-leading-normal) !important;
}

#popup_dialog_content_placement p {
  margin: 0 !important;
  font-size: var(--cfa-text-sm) !important;
  color: var(--cfa-text-muted) !important;
  line-height: var(--cfa-leading-normal) !important;
}

#popup_dialog_content_placement a {
  color: var(--cfa-cobalt) !important;
  font-weight: var(--cfa-weight-semibold) !important;
  text-decoration: underline !important;
}

#popup_dialog_content_placement .space-clearfix,
#popup_dialog_content_placement .clearfix {
  display: none !important;
}

/* Close button */
.popup_dialog_close,
.my_popup_dialog_close {
  position: absolute !important;
  top: 14px !important;
  right: var(--cfa-space-5) !important;
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--cfa-cobalt) !important;
  border-radius: var(--cfa-radius-full) !important;
  border: none !important;
  cursor: pointer !important;
  z-index: 10 !important;
  font-size: 18px !important;
  color: #ffffff !important;
  line-height: 1 !important;
  transition: background var(--cfa-transition-fast) !important;
}

.popup_dialog_close img,
.my_popup_dialog_close img {
  display: none !important;
}

/* Solid SVG "X" icon */
.popup_dialog_close::after,
.my_popup_dialog_close::after {
  content: "";
  width: 16px;
  height: 16px;
  background: #ffffff;
  -webkit-mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%2024%2024%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M18.3%205.71a1%201%200%200%200-1.41%200L12%2010.59%207.11%205.7A1%201%200%200%200%205.7%207.11L10.59%2012l-4.9%204.89a1%201%200%201%200%201.42%201.42L12%2013.41l4.89%204.9a1%201%200%200%200%201.42-1.42L13.41%2012l4.9-4.89a1%201%200%200%200-.01-1.4z%27/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg%20xmlns%3D%27http%3A//www.w3.org/2000/svg%27%20viewBox%3D%270%200%2024%2024%27%3E%3Cpath%20fill%3D%27%23000%27%20d%3D%27M18.3%205.71a1%201%200%200%200-1.41%200L12%2010.59%207.11%205.7A1%201%200%200%200%205.7%207.11L10.59%2012l-4.9%204.89a1%201%200%201%200%201.42%201.42L12%2013.41l4.89%204.9a1%201%200%200%200%201.42-1.42L13.41%2012l4.9-4.89a1%201%200%200%200-.01-1.4z%27/%3E%3C/svg%3E") center / contain no-repeat;
}

.popup_dialog_close:hover,
.my_popup_dialog_close:hover {
  background: var(--cfa-cobalt-mid) !important;
  color: #ffffff !important;
}

/* ================================================================
   SS_POPUP_CONTAINER FAMILY — CFA DESIGN SYSTEM OVERRIDE
   Used in marketplace / secondary-market pages.
   JS animates `top` from -1000% → 0 to show; keep position:absolute.
   ================================================================ */

.ss_popup_container,
.ss_popup_container-new,
.ss_popup_container-new-reykers,
.ss_popup_container-latest,
.ss_popup_container-terms {
  background: var(--cfa-bg) !important;
  border-radius: var(--cfa-radius-xl) !important;
  box-shadow: var(--cfa-shadow-xl) !important;
  border: 1px solid var(--cfa-border) !important;
  overflow: hidden !important;
  position: absolute !important;
  left: 0 !important;
  right: 0 !important;
  margin: auto !important;
}

/* Width overrides — keep existing responsive widths, just ensure max */
.ss_popup_container,
.ss_popup_container-latest {
  width: 50% !important;
  max-width: 540px !important;
}

.ss_popup_container-new,
.ss_popup_container-new-reykers {
  width: 60% !important;
  max-width: 600px !important;
}

.ss_popup_container-terms {
  width: 80% !important;
  max-width: 760px !important;
}

/* Header bar */
.ss_header {
  padding: var(--cfa-space-5) var(--cfa-space-6) var(--cfa-space-4) !important;
  border-bottom: 1px solid var(--cfa-border) !important;
  background: var(--cfa-bg) !important;
}

.ss_header h3 {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-lg) !important;
  font-weight: var(--cfa-weight-extrabold) !important;
  color: var(--cfa-text) !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* Content area */
.ss_content {
  padding: var(--cfa-space-5) var(--cfa-space-6) var(--cfa-space-6) !important;
  background: var(--cfa-bg) !important;
}

.ss_content p,
.ss_content .selsh_info {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  color: var(--cfa-text-muted) !important;
  line-height: var(--cfa-leading-normal) !important;
  margin-bottom: var(--cfa-space-4) !important;
}

/* Close button — image replaced visually */
.pp_btn_close {
  position: absolute !important;
  top: var(--cfa-space-4) !important;
  right: var(--cfa-space-4) !important;
  width: 32px !important;
  height: 32px !important;
  opacity: 0 !important;
  cursor: pointer !important;
  z-index: 10 !important;
}

/* CSS close button rendered via pseudo-element on parent */
.ss_popup_container::before,
.ss_popup_container-new::before,
.ss_popup_container-new-reykers::before,
.ss_popup_container-latest::before,
.ss_popup_container-terms::before {
  content: '×' !important;
  position: absolute !important;
  top: var(--cfa-space-4) !important;
  right: var(--cfa-space-4) !important;
  width: 32px !important;
  height: 32px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  background: var(--cfa-bg-soft) !important;
  border: 1px solid var(--cfa-border) !important;
  border-radius: var(--cfa-radius-full) !important;
  font-size: 15px !important;
  color: var(--cfa-text-muted) !important;
  line-height: 1 !important;
  cursor: pointer !important;
  pointer-events: none !important;
  z-index: 1 !important;
}

/* #freeze overlay — global fix (position:fixed so it covers viewport) */
#freeze,
#freeze1 {
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  height: 100% !important;
  background: rgba(27, 43, 107, 0.50) !important;
  backdrop-filter: blur(3px) !important;
  -webkit-backdrop-filter: blur(3px) !important;
  opacity: 1 !important;
  z-index: 1050 !important;
}

/* Responsive — mobile */
@media (max-width: 600px) {
  .ss_popup_container,
  .ss_popup_container-new,
  .ss_popup_container-new-reykers,
  .ss_popup_container-latest,
  .ss_popup_container-terms {
    width: calc(100% - 32px) !important;
    max-width: none !important;
  }
}


/* ================================================================
   CAROUSEL — CONSISTENT HEIGHT + FIRST SLIDE COBALT BACKGROUND
   ================================================================ */

/* Constrain the slider container on desktop */
.slider-outer {
  max-height: 500px !important;
  overflow: hidden !important;
}

/* Enforce consistent height on all slides — do NOT override display:none on inactive items */
.slider-inner .carousel-item {
  min-height: 315px !important;
  max-height: 500px !important;
}

/* Center content vertically only when slide is visible */
.slider-inner .carousel-item.active,
.slider-inner .carousel-item-next,
.slider-inner .carousel-item-prev {
  display: flex !important;
  align-items: center !important;
}

/* First slide: primary cobalt background (overrides inline background:url) */
.slider-inner .carousel-item.slide-cobalt {
  background: var(--cfa-cobalt) !important;
  background-image: none !important;
}

/* Third slide: amber full background */
.slider-inner .carousel-item.slide-amber {
  background: var(--cfa-amber) !important;
  background-image: none !important;
}

/* Slide 1 right panel: amber box */
.slider-right-inner.slide-right-amber {
  background: var(--cfa-amber) !important;
  border-radius: var(--cfa-radius-lg) !important;
  padding: var(--cfa-space-6) var(--cfa-space-5) !important;
}

/* On mobile: let slides grow to fit stacked content — no clipping */
@media (max-width: 767px) {
  .slider-outer {
    max-height: none !important;
    overflow: visible !important;
  }

  .slider-inner .carousel-item {
    min-height: 0 !important;
    max-height: none !important;
  }

  /* carousel-caption is position:absolute by Bootstrap — switch to relative on mobile */
  .slider-inner .carousel-item .carousel-caption {
    position: relative !important;
    bottom: auto !important;
    left: auto !important;
    right: auto !important;
    padding-top: var(--cfa-space-3) !important;
    padding-bottom: var(--cfa-space-3) !important;
    text-align: left !important;
  }

  /* designer.css adds padding-top:40px + margin-top:20px to .slide-caption-outer — reduce on mobile */
  .slide-caption-outer {
    padding-top: var(--cfa-space-3) !important;
    margin-top: 0 !important;
  }
}

/* ================================================================
   HOMEPAGE — CTA BAND (blue-section-iom-new)
   Replace legacy #337ab7 with CFA cobalt
   ================================================================ */
.blue-section-iom,
.blue-section-iom-new {
  background-color: var(--cfa-cobalt) !important;
}


/* ================================================================
   HOMEPAGE — INVESTORS SECTION (.cfa-investors-section)
   ================================================================ */

.cfa-investors-section {
  padding: var(--cfa-space-10) var(--cfa-space-8);
  background: var(--cfa-bg-soft);
}

.cfa-investors-section .cfa-investors-cards {
  max-width: 900px;
  margin-left: auto;
  margin-right: auto;
}

.cfa-investors-intro {
  text-align: center;
  max-width: 640px;
  margin: 0 auto var(--cfa-space-8);
}

.cfa-investors-heading {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-3xl);
  font-weight: 700;
  color: var(--cfa-navy);
  margin-bottom: var(--cfa-space-3);
}

.cfa-investors-desc {
  font-size: var(--cfa-text-base);
  color: var(--cfa-text-mid);
  line-height: 1.7;
  margin: 0;
}

/* Card grid — 2 columns, 1 on mobile */
.cfa-investors-cards {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--cfa-space-6);
  margin-bottom: var(--cfa-space-8);
}

@media (max-width: 768px) {
  .cfa-investors-cards {
    grid-template-columns: 1fr;
  }
}

/* Individual investor card */
.cfa-investor-card {
  background: var(--cfa-bg);
  border: 1px solid var(--cfa-border);
  border-radius: var(--cfa-radius-xl);
  padding: var(--cfa-space-7) var(--cfa-space-6);
  box-shadow: var(--cfa-shadow-sm);
  transition: box-shadow 0.2s ease, transform 0.2s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: var(--cfa-space-4);
}

.cfa-investor-card ul {
  padding: 0;
  margin: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: var(--cfa-space-2);
}

.cfa-investor-card ul li {
  font-size: var(--cfa-text-sm);
  color: var(--cfa-text-mid);
  line-height: 1.6;
}

.cfa-investor-card:hover {
  box-shadow: var(--cfa-shadow-md);
  transform: translateY(-2px);
}

/* Card icon badge */
.cfa-investor-card-icon {
  width: 48px;
  height: 48px;
  border-radius: var(--cfa-radius-md);
  background: var(--cfa-cobalt-pale);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.cfa-investor-card-icon img {
  width: 26px;
  height: 26px;
  object-fit: contain;
}

.cfa-investor-card-icon.amber {
  background: var(--cfa-amber-pale);
}

/* Card title */
.cfa-investor-card-title {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-xl);
  font-weight: 700;
  color: var(--cfa-navy);
  margin: 0;
}

/* Card tag / badge */
.cfa-investor-card-tag {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--cfa-radius-full);
  font-size: var(--cfa-text-xs);
  font-weight: 600;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  background: var(--cfa-cobalt-pale);
  color: var(--cfa-cobalt);
}

.cfa-investor-card-tag.amber {
  background: var(--cfa-amber-pale);
  color: var(--cfa-amber);
}

/* Card body text */
.cfa-investor-card-body {
  font-size: var(--cfa-text-sm);
  color: var(--cfa-text-mid);
  line-height: 1.65;
  margin: 0;
}

/* Feature list inside card */
.cfa-investor-card-features {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: var(--cfa-space-2);
}

.cfa-investor-card-features li {
  font-size: var(--cfa-text-sm);
  color: var(--cfa-text-mid);
  display: flex;
  align-items: flex-start;
  gap: var(--cfa-space-2);
}

.cfa-investor-card-features li::before {
  content: "✓";
  color: var(--cfa-cobalt);
  font-weight: 700;
  flex-shrink: 0;
  margin-top: 1px;
}

/* CTA row */
.cfa-investors-cta {
  text-align: center;
  padding-top: var(--cfa-space-4);
}

/* ============================================================
   PAGE-WIDE CONSISTENCY — shared across all CMS sections
   ============================================================ */

/* ── Section vertical rhythm (replace <br> hacks) ── */
.pix_builder_bg,
.pix_builder {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* ============================================================
   HERO / BANNER (pitches listing banner, etc.)
   Template: module/Application/view/layout/banner_pitches.phtml
   Goal: background cover + readable text on any image.
   Scoped to main platform via body.cfa-app.
   ============================================================ */

/* Let the banner wrapper grow to fit its content */
body.cfa-app .slideshow_wrapper_shrtheight {
  height: auto !important;
}

body.cfa-app .mrpixbanerimg .page_style.pix_builder_bg {
  position: relative;
  background-color: var(--cfa-navy) !important;
  background-image: linear-gradient(135deg, #0d1a47 0%, var(--cfa-navy) 38%, var(--cfa-cobalt) 78%, #3566f0 100%) !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  padding: clamp(56px, 7vw, 96px) 0 !important;
  height: auto !important;
  min-height: 0 !important;
}

/* Radial light bloom + depth vignette */
body.cfa-app .mrpixbanerimg .page_style.pix_builder_bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 70% 90% at 88% 38%, rgba(255, 255, 255, 0.08) 0%, transparent 58%),
    radial-gradient(ellipse 55% 65% at 8% 72%,  rgba(0,   8,  80, 0.22)   0%, transparent 52%);
  pointer-events: none;
  z-index: 0;
}

/* Dot-grid texture */
body.cfa-app .mrpixbanerimg .page_style.pix_builder_bg::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(circle, rgba(255, 255, 255, 0.07) 1px, transparent 1px);
  background-size: 28px 28px;
  pointer-events: none;
  z-index: 0;
}

body.cfa-app .mrpixbanerimg .text_page {
  position: relative;
  z-index: 1;
  padding-top: 0 !important;
  text-align: center;
  max-width: 920px;
  margin: 0 auto;
}

body.cfa-app .mrpixbanerimg h1.head_line {
  font-family: var(--cfa-font-body) !important;
  font-size: clamp(30px, 4vw, 48px) !important;
  font-weight: var(--cfa-weight-extrabold) !important;
  letter-spacing: -0.025em;
  line-height: 1.08;
  color: #ffffff !important;
  margin: 0 0 var(--cfa-space-4) !important;
  text-shadow: 0 2px 16px rgba(0, 0, 0, 0.28);
}

body.cfa-app .mrpixbanerimg p.txt_start {
  font-family: var(--cfa-font-body) !important;
  font-size: clamp(14px, 1.6vw, 17px) !important;
  font-weight: var(--cfa-weight-regular) !important;
  color: rgba(255, 255, 255, 0.82) !important;
  line-height: 1.65 !important;
  margin: 0 auto !important;
  max-width: 64ch;
}

/* ── Auto-contrast system ──────────────────────────────────────
   --cfa-auto-heading / --cfa-auto-text / --cfa-auto-link are set
   to light values by dark-background sections below.
   Default fallbacks = dark (for light backgrounds).
   ─────────────────────────────────────────────────────────── */

/* ── Section title ── */
.intro_div h2,
.container.center_text h2,
.sixteen.columns > h2,
h2.blue-title {
  font-family: var(--cfa-font-body) !important;
  font-size: clamp(22px, 3vw, 30px) !important;
  font-weight: var(--cfa-weight-bold) !important;
  color: var(--cfa-auto-heading, var(--cfa-navy)) !important;
  letter-spacing: -.01em !important;
  line-height: 1.25 !important;
  margin-bottom: var(--cfa-space-4) !important;
  text-align: center !important;
}

/* ── Intro body text inside sections ── */
.intro_div p.normal_text,
.intro_div table p.normal_text {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-base) !important;
  color: var(--cfa-auto-text, var(--cfa-text-mid)) !important;
  line-height: 1.7 !important;
  max-width: 680px !important;
  margin: 0 auto !important;
}

/* ── Intro table wrapper — strip table layout ── */
.intro_div table,
.intro_div tbody,
.intro_div tr,
.intro_div td {
  display: block !important;
  width: 100% !important;
  border: none !important;
  padding: 0 !important;
}

/* ── Section background variants ── */
.light_gray_bg.big_padding.pix_builder_bg,
.light_gray_bg.normal_padding.pix_builder_bg,
.light_gray_bg.pix_builder_bg {
  background-color: #fff !important;
}

.normal_padding.padding_top_60.pix_builder_bg,
.light_gray_bg.normal_padding.padding_top_60.pix_builder {
  background-color: #fff !important;
  padding-top: 48px !important;
  padding-bottom: 48px !important;
}

.big_padding.pix_builder_bg {
  padding-top: 40px !important;
  padding-bottom: 48px !important;
}

/* ── "Your Investor's Journey" text + video ── */
.New_Latest_Off.pix_builder_bg {
  background-color: #fff !important;
  padding-top: 48px !important;
  padding-bottom: 48px !important;
}

.New_Latest_Off.pix_builder_bg h2 {
  font-family: var(--cfa-font-body) !important;
  font-size: clamp(20px, 2.5vw, 26px) !important;
  font-weight: var(--cfa-weight-bold) !important;
  color: var(--cfa-auto-heading, var(--cfa-navy)) !important;
  margin-bottom: var(--cfa-space-4) !important;
  text-align: left !important;
}

.New_Latest_Off.pix_builder_bg p.normal_text {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  color: var(--cfa-auto-text, var(--cfa-text-mid)) !important;
  line-height: 1.7 !important;
}

.New_Latest_Off.pix_builder_bg p.normal_text a {
  color: var(--cfa-auto-link, var(--cfa-cobalt)) !important;
  text-decoration: underline !important;
}

.video_style {
  border-radius: var(--cfa-radius-lg) !important;
  overflow: hidden !important;
  box-shadow: 0 4px 20px rgba(0,0,0,.1) !important;
  padding-right: 0 !important;
}

.video_style iframe {
  display: block !important;
  border-radius: var(--cfa-radius-lg) !important;
}

/* ── Trust cards (.f1_box.center_align) ── */
.f1_box.center_align {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  background: #fff !important;
  border: 1px solid var(--cfa-border) !important;
  border-radius: var(--cfa-radius-lg) !important;
  padding: var(--cfa-space-5) var(--cfa-space-4) !important;
  margin: 0 var(--cfa-space-2) !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.06) !important;
  transition: box-shadow 0.2s ease, transform 0.2s ease !important;
  height: 100% !important;
}

.f1_box.center_align:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.10) !important;
  transform: translateY(-2px) !important;
}

/* Trust card icon circle — strip all legacy padding/margin first */
.f1_box.center_align .margin_bottom:first-child {
  width: 72px !important;
  height: 72px !important;
  padding: 0 !important;           /* kills designer.css padding-right:20px */
  margin: 0 auto var(--cfa-space-4) !important;
  background: #f2f4f7 !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
}

img.faq-image {
  width: 34px !important;
  height: 34px !important;
  border-radius: 0 !important;
  border: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: block !important;
  object-fit: contain !important;
}

/* Trust card heading */
.f1_box.center_align h3 {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-base) !important;
  font-weight: var(--cfa-weight-bold) !important;
  color: var(--cfa-navy) !important;
  margin-bottom: var(--cfa-space-2) !important;
}

/* Trust card body */
.f1_box.center_align p.normal_text {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  color: var(--cfa-text-mid) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
}

/* ── Blue CTA section ── */
.blue-section {
  background-color: var(--cfa-navy) !important;
  padding: 56px 24px !important;
  text-align: center !important;
}

h2.blue-title {
  font-size: clamp(22px, 3vw, 30px) !important;
  margin-bottom: var(--cfa-space-3) !important;
  /* color comes from --cfa-auto-heading set by the section */
}

.blue-section p.normal_text,
.blue-section p.light_gray.normal_text,
.blue-section p.light_gray.normal_text span {
  color: var(--cfa-auto-text, rgba(255,255,255,.8)) !important;
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-base) !important;
  margin-bottom: var(--cfa-space-5) !important;
}

/* ================================================================
   AUTO-CONTRAST: DARK SECTION DECLARATIONS
   Any section with a dark background sets --cfa-auto-heading,
   --cfa-auto-text, --cfa-auto-link so all descendant text rules
   (which use these variables as values) automatically become light.

   Covers:
     1. Class-based dark sections (.blue-section, page_style, etc.)
     2. Inline style dark backgrounds via attribute selectors
   ================================================================ */

/* --- Class-based dark sections --- */
body.cfa-app .blue-section,
body.cfa-app .mrpixbanerimg .page_style,
body.cfa-app .pixfort_university_6 .page_style,
body.cfa-app .pixfort_university_6 .center_text.pix_builder_bg,
body.cfa-app .light_gray_bg.normal_padding.padding_top_60.pix_builder_bg,
body.cfa-app .dark_bg.pix_builder_bg,
body.cfa-app .dark_bg {
  --cfa-auto-heading: #ffffff;
  --cfa-auto-text:    rgba(255, 255, 255, 0.85);
  --cfa-auto-link:    #93B4FF;
}

/* --- Inline style: navy #1B2B6B variants --- */
body.cfa-app [style*="background-color:#1B2B6B"],
body.cfa-app [style*="background-color: #1B2B6B"],
body.cfa-app [style*="background-color:#1b2b6b"],
body.cfa-app [style*="background-color: #1b2b6b"],
body.cfa-app [style*="background-color:rgb(27,43,107)"],
body.cfa-app [style*="background-color: rgb(27, 43, 107)"],
/* --- Inline style: cobalt #2451D1 variants --- */
body.cfa-app [style*="background-color:#2451D1"],
body.cfa-app [style*="background-color: #2451D1"],
body.cfa-app [style*="background-color:#2451d1"],
body.cfa-app [style*="background-color: #2451d1"],
body.cfa-app [style*="background-color:rgb(36,81,209)"],
body.cfa-app [style*="background-color: rgb(36, 81, 209)"],
/* --- Inline style: dark #1f334a / rgb(31,51,74) variants --- */
body.cfa-app [style*="background-color:#1f334a"],
body.cfa-app [style*="background-color: #1f334a"],
body.cfa-app [style*="background-color:rgb(31,51,74)"],
body.cfa-app [style*="background-color: rgb(31, 51, 74)"],
/* --- Inline style: dark blue rgb(11,83,148) --- */
body.cfa-app [style*="background-color:rgb(11,83,148)"],
body.cfa-app [style*="background-color: rgb(11, 83, 148)"] {
  --cfa-auto-heading: #ffffff;
  --cfa-auto-text:    rgba(255, 255, 255, 0.85);
  --cfa-auto-link:    #93B4FF;
}

/* ── Bottom CTA strip (.Room_Res) ── */
.Room_Res.pix_builder_bg,
.pixfort_hotel_5 .Room_Res {
  background: var(--cfa-bg-soft) !important;
  padding: 48px 24px !important;
  text-align: center !important;
}

.Room_Res h2 {
  font-family: var(--cfa-font-body) !important;
  font-size: clamp(20px, 2.5vw, 26px) !important;
  font-weight: var(--cfa-weight-bold) !important;
  color: var(--cfa-auto-heading, var(--cfa-navy)) !important;
  margin-bottom: var(--cfa-space-5) !important;
}

/* ── CTA Buttons ── */
a.pix_button.orange_bg,
a.pix_button.orange_bg:visited,
a.pix_button.orange_bg:focus {
  background-color: var(--cfa-amber) !important;
  color: #fff !important;
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-base) !important;
  font-weight: var(--cfa-weight-semibold) !important;
  padding: 14px 36px !important;
  border-radius: var(--cfa-radius-md) !important;
  border: none !important;
  display: inline-block !important;
  text-decoration: none !important;
  transition: background-color 0.2s ease, box-shadow 0.2s ease !important;
  box-shadow: 0 2px 8px rgba(var(--cfa-amber-rgb),.25) !important;
  letter-spacing: .01em !important;
}

a.pix_button.orange_bg:hover {
  background-color: var(--cfa-amber-hover) !important;
  box-shadow: 0 4px 16px rgba(var(--cfa-amber-rgb),.35) !important;
}

/* Ensure inner CTA link text never blends into the hover background */
.pix_button .pix_text,
.pix_button:hover .pix_text,
.orange_bg:hover .pix_text {
  color: #fff !important;
  text-decoration: none !important;
}

/* ── Force lazy-hidden images visible ── */
.big_icon.green_1 img.lazy,
.f1_box.pix_container img.lazy,
.f1_box.center_align img.lazy,
img.faq-image.lazy,
img.feature_image.lazy {
  display: block !important;
}

/* ============================================================
   PRODUCT CARDS — Shares & Crowd Bonds (.f1_box.pix_container)
   ============================================================ */

/* Card shell — flush top so image bleeds to edges */
.f1_box.pix_container {
  padding: 0 !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
  border: 1px solid var(--cfa-border) !important;
  border-radius: var(--cfa-radius-lg) !important;
  background: #fff !important;
  box-shadow: 0 1px 6px rgba(0,0,0,.07) !important;
  transition: box-shadow 0.2s ease, transform 0.2s ease !important;
}

.f1_box.pix_container:hover {
  box-shadow: 0 6px 20px rgba(0,0,0,.11) !important;
  transform: translateY(-2px) !important;
}

/* Image — full-bleed stretched background at top */
.f1_box.pix_container img.feature_image.pix_radius,
.f1_box.pix_container img.feature_image {
  width: 100% !important;
  max-width: 100% !important;
  height: 220px !important;
  max-height: none !important;
  object-fit: fill !important;
  display: block !important;
  padding: 0 !important;
  margin: 0 !important;
  border-radius: 0 !important;
}

/* Wrapper div around image — remove margin/inline-block weirdness */
.f1_box.pix_container .margin_bottom:first-child {
  margin-bottom: 0 !important;
  display: block !important;
  line-height: 0 !important;
}

/* Text content area */
.f1_box.pix_container .margin_bottom:not(:first-child) {
  padding: var(--cfa-space-5) var(--cfa-space-5) var(--cfa-space-6) !important;
  margin-bottom: 0 !important;
  display: block !important;
  text-align: left !important;
  flex: 1 !important;
}

/* Suppress the clearfix spacer between image and text */
.f1_box.pix_container .clearfix {
  display: none !important;
}

/* Heading */
.f1_box.pix_container h3 {
  font-family: var(--cfa-font-body) !important;
  font-size: 13px !important;
  font-weight: var(--cfa-weight-bold) !important;
  color: var(--cfa-navy) !important;
  letter-spacing: .08em !important;
  text-transform: uppercase !important;
  margin: 0 0 var(--cfa-space-3) !important;
}

/* Body text */
.f1_box.pix_container p.normal_text {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  color: var(--cfa-text-mid) !important;
  line-height: 1.7 !important;
  margin: 0 !important;
}

/* Bold labels (Ownership:, Tax Relief: etc.) */
.f1_box.pix_container p.normal_text strong {
  font-weight: var(--cfa-weight-semibold) !important;
  color: var(--cfa-navy) !important;
}

/* Inline links */
.f1_box.pix_container p.normal_text a {
  color: var(--cfa-cobalt) !important;
  text-decoration: underline !important;
}

@media (max-width: 767px) {
  .f1_box.pix_container img.feature_image.pix_radius,
  .f1_box.pix_container img.feature_image {
    height: 180px !important;
  }
  .f1_box.pix_container .margin_bottom:not(:first-child) {
    padding: var(--cfa-space-4) !important;
  }
}

/* ============================================================
   HOME — FEATURE BOXES (.f1_box / .big_icon)
   ============================================================ */

/* Row — override legacy float-based grid to flex so cards match height */
.sixteen.columns:has(.f1_box) {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch !important;
  justify-content: center !important;
  padding: 0 !important;
  width: 100% !important;
}

/* Section wrapper padding */
.container:has(.f1_box) {
  padding-top: 48px !important;
  padding-bottom: 48px !important;
}

/* Column — strip float, stretch to row height */
.onethird_style {
  padding-bottom: var(--cfa-space-3) !important;
  float: none !important;
  display: flex !important;
  align-items: stretch !important;
}

/* Card */
.f1_box {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: center !important;
  background: #fff !important;
  border: 1px solid var(--cfa-border) !important;
  border-radius: var(--cfa-radius-lg) !important;
  padding: var(--cfa-space-5) var(--cfa-space-4) !important;
  margin: 0 var(--cfa-space-2) !important;
  width: 100% !important;
  box-shadow: 0 1px 4px rgba(0,0,0,.06) !important;
  transition: box-shadow 0.2s ease, transform 0.2s ease !important;
}

.f1_box:hover {
  box-shadow: 0 4px 16px rgba(0,0,0,.10) !important;
  transform: translateY(-2px) !important;
}

/* Icon circle wrapper */
.big_icon.green_1 {
  width: 68px !important;
  height: 68px !important;
  min-width: 68px !important;
  background: #f2f4f7 !important;
  border-radius: 50% !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 auto var(--cfa-space-4) !important;
  font-size: 0 !important;
  float: none !important;
}

.big_icon.green_1 img,
.big_icon.green_1 img.lazy {
  width: 34px !important;
  height: 34px !important;
  margin: 0 !important;
  display: block !important;
  object-fit: contain !important;
}

/* Text area */
.f1_box .center_text {
  padding: 0 !important;
  float: none !important;
  width: 100% !important;
  flex: 1 !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
}

.f1_box .center_text h3 {
  font-family: var(--cfa-font-body) !important;
  font-size: 11px !important;
  font-weight: var(--cfa-weight-bold) !important;
  color: var(--cfa-navy) !important;
  letter-spacing: .08em !important;
  margin-bottom: var(--cfa-space-2) !important;
  text-transform: uppercase !important;
}

.f1_box .center_text p.normal_text {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  color: var(--cfa-text-mid) !important;
  line-height: 1.6 !important;
  margin: 0 !important;
  max-width: 220px !important;
}

.f1_box .center_text p.normal_text a {
  color: var(--cfa-cobalt) !important;
  text-decoration: underline !important;
}

@media (max-width: 767px) {
  .container:has(.f1_box) {
    padding-top: 32px !important;
    padding-bottom: 32px !important;
  }
  .f1_box {
    margin: 0 0 var(--cfa-space-3) !important;
  }
}

/* ============================================================
   RISK WARNING POPUP — consistent with platform design system
   ============================================================ */

#my_popup_dialog_content_placement {
  padding: var(--cfa-space-6) var(--cfa-space-7) var(--cfa-space-7) !important;
  background: var(--cfa-bg) !important;
  font-family: var(--cfa-font-body) !important;
}

.cfa-risk-popup-warning {
  background: var(--cfa-amber-pale);
  border: 1px solid var(--cfa-amber-border);
  border-radius: var(--cfa-radius-md);
  padding: var(--cfa-space-4) var(--cfa-space-5);
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-base);
  color: var(--cfa-amber-text);
  line-height: var(--cfa-leading-relaxed);
  margin-bottom: var(--cfa-space-6);
}

.cfa-risk-popup-warning strong {
  font-weight: var(--cfa-weight-bold);
  display: block;
  margin-bottom: var(--cfa-space-1);
}

.cfa-risk-popup-warning a {
  color: var(--cfa-amber-text) !important;
  text-decoration: underline !important;
  font-weight: var(--cfa-weight-semibold) !important;
}

.cfa-risk-popup-actions {
  display: flex;
  gap: var(--cfa-space-3);
  justify-content: center;
  flex-wrap: wrap;
}

.cfa-popup-btn {
  font-family: var(--cfa-font-body);
  font-size: var(--cfa-text-sm);
  font-weight: var(--cfa-weight-semibold);
  padding: var(--cfa-space-3) var(--cfa-space-6);
  border-radius: var(--cfa-radius-md);
  cursor: pointer;
  border: none;
  transition: background var(--cfa-transition-fast), border-color var(--cfa-transition-fast);
  min-width: 200px;
  line-height: 1;
}

.cfa-popup-btn--primary {
  background: var(--cfa-cobalt);
  color: var(--cfa-on-dark);
}

.cfa-popup-btn--primary:hover {
  background: var(--cfa-cobalt-mid);
}

.cfa-popup-btn--secondary {
  background: transparent;
  color: var(--cfa-text-mid);
  border: 1px solid var(--cfa-border-strong) !important;
}

.cfa-popup-btn--secondary:hover {
  background: var(--cfa-bg-soft);
}


/* ── Error / validation message unification ── */
.error-msg,
.error_msg {
  color: var(--cfa-red) !important;
  font-size: var(--cfa-text-sm) !important;
  font-weight: var(--cfa-weight-medium) !important;
  font-family: var(--cfa-font-body) !important;
  display: block;
  margin-top: var(--cfa-space-1) !important;
}

/* Input error state border */
.error-inp,
.error-class {
  border-color: var(--cfa-red) !important;
  background-color: var(--cfa-red-pale) !important;
  outline: none !important;
}

/* Form-level error banner (shown at top of form) */
.form-error-banner {
  background: var(--cfa-red-pale) !important;
  border: 1px solid var(--cfa-red-border) !important;
  border-radius: var(--cfa-radius-md) !important;
  color: var(--cfa-red) !important;
  font-size: var(--cfa-text-sm) !important;
  font-family: var(--cfa-font-body) !important;
  padding: var(--cfa-space-3) var(--cfa-space-4) !important;
  margin-bottom: var(--cfa-space-4) !important;
}


/* ── Status Badge Modifiers ──
   Base .cfa-badge is defined in cfa-badges-alerts.css.
   These are platform-specific status variants only. */
.cfa-badge--active  { background: var(--cfa-green-pale);  color: var(--cfa-green);       }
.cfa-badge--funded  { background: var(--cfa-cobalt-pale); color: var(--cfa-cobalt);      }
.cfa-badge--pending { background: var(--cfa-amber-pale);  color: var(--cfa-amber);       }
.cfa-badge--closed  { background: var(--cfa-bg-soft);     color: var(--cfa-text-muted);  }
.cfa-badge--suspended { background: var(--cfa-red-pale);  color: var(--cfa-red);         }
.cfa-badge--kyc-verified { background: var(--cfa-green-pale); color: var(--cfa-green);   }
.cfa-badge--kyc-pending  { background: var(--cfa-amber-pale); color: var(--cfa-amber);   }
.cfa-badge--kyc-failed   { background: var(--cfa-red-pale);   color: var(--cfa-red);     }
.cfa-badge--draft        { background: var(--cfa-bg-soft);    color: var(--cfa-text-muted); }


/* ── Tab navigation — shared active state ── */
/* Covers both .nav-tabs-dropdown (CMS/pitch pages) and .invest-tab (portfolio/account) */
.nav-tabs-dropdown li.active > a,
.nav-tabs-dropdown li > a.active,
.nav-tabs-dropdown li > a[aria-current="page"],
li.invest-tab.active-tab > a,
li.active-tab > a {
  color: var(--cfa-cobalt) !important;
  border-bottom: 2px solid var(--cfa-cobalt) !important;
  font-weight: var(--cfa-weight-semibold) !important;
  background: transparent !important;
}

.nav-tabs-dropdown li > a,
li.invest-tab > a {
  color: var(--cfa-text-muted) !important;
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm) !important;
  font-weight: var(--cfa-weight-medium) !important;
  text-decoration: none !important;
  transition: color var(--cfa-transition-fast), border-color var(--cfa-transition-fast) !important;
  border-bottom: 2px solid transparent !important;
  padding-bottom: var(--cfa-space-2) !important;
}

.nav-tabs-dropdown li > a:hover,
li.invest-tab > a:hover {
  color: var(--cfa-cobalt) !important;
  border-bottom-color: var(--cfa-cobalt-border) !important;
}

/* ============================================================
   CFA HERO SECTION — replaces homepage slider
   All classes prefixed .cfa-hero* to avoid conflicts
   ============================================================ */

.cfa-hero {
  padding: 120px 0;
  overflow: hidden;
  background: #FFFFFF;
}
.cfa-hero-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
  display: grid;
  grid-template-columns: 55fr 45fr;
  gap: 80px;
  align-items: center;
  box-sizing: border-box;
}
.cfa-hero *, .cfa-hero *::before, .cfa-hero *::after {
  box-sizing: border-box;
}

/* Badge */
.cfa-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #EEF3FF;
  color: #2451D1;
  font-size: 14px;
  font-weight: 700;
  padding: 9px 18px;
  border-radius: 100px;
  margin-bottom: 32px;
  letter-spacing: 0.02em;
  font-family: 'DM Sans', sans-serif;
}
.cfa-hero-badge::before {
  content: '';
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #2451D1;
  flex-shrink: 0;
}

/* Heading */
.cfa-hero-h1 {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: clamp(48px, 5vw, 76px);
  line-height: 1.0;
  color: #111827;
  letter-spacing: -0.04em;
  margin: 0 0 24px;
}
.cfa-hero-accent { color: #2451D1; }
.cfa-hero-amber  { color: var(--cfa-amber); }

/* Subtext */
.cfa-hero-sub {
  font-size: 18px;
  font-weight: 400;
  color: #6B7280;
  max-width: 480px;
  line-height: 1.75;
  margin: 0 0 40px;
}
.cfa-hero-sub a,
.cfa-hero-trust a {
  color: inherit !important;
  text-decoration: underline !important;
}

/* CTAs */
.cfa-hero-ctas {
  display: flex;
  gap: 14px;
  align-items: center;
  margin-bottom: 48px;
  flex-wrap: wrap;
}
.cfa-hero-btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: #2451D1;
  color: #fff;
  text-decoration: none;
  padding: 16px 32px;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 700;
  font-family: 'DM Sans', sans-serif;
  transition: background 0.15s, transform 0.15s;
}
.cfa-hero-btn-primary:hover {
  background: #3563E9;
  color: #fff;
  transform: translateY(-1px);
  text-decoration: none;
}
.cfa-hero-btn-outline {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #374151;
  text-decoration: none;
  padding: 16px 28px;
  border-radius: 10px;
  border: 1.5px solid #D1D5DB;
  font-size: 16px;
  font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  transition: border-color 0.15s, color 0.15s;
}
.cfa-hero-btn-outline:hover {
  border-color: #2451D1;
  color: #2451D1;
  text-decoration: none;
}

/* KPI grid */
.cfa-hero-kpis {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border: 1.5px solid rgba(36,81,209,0.4);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 28px;
  box-shadow: 0 8px 32px rgba(36,81,209,0.1), inset 0 1px 0 rgba(255,255,255,0.9);
}
.cfa-kpi-item {
  padding: 24px 22px;
  border-right: 1px solid rgba(36,81,209,0.15);
  background: linear-gradient(135deg, rgba(36,81,209,0.10) 0%, rgba(36,81,209,0.03) 100%);
}
.cfa-kpi-item:last-child { border-right: none; }
.cfa-kpi-val {
  font-family: 'DM Sans', sans-serif;
  font-weight: 800;
  font-size: 40px;
  letter-spacing: -0.04em;
  line-height: 1;
  color: #2451D1;
  margin-bottom: 5px;
}
.cfa-kpi-lbl {
  font-size: 16px;
  font-weight: 500;
  color: #6B7280;
  line-height: 1.3;
}
.cfa-kpi-badge {
  display: inline-block;
  margin-top: 7px;
  font-size: 13px;
  font-weight: 700;
  padding: 4px 10px;
  border-radius: 100px;
  font-family: 'DM Sans', sans-serif;
  letter-spacing: 0.04em;
}
.cfa-badge-cobalt         { background: #EEF3FF; color: #2451D1; }
.cfa-badge-green          { background: #ECFDF5; color: #059669; }
.cfa-kpi-badge--green     { background: #ECFDF5; color: #059669; border: 1px solid #A7F3D0; }
.cfa-kpi-badge--amber     { background: #FFF7ED; color: #C2410C; border: 1px solid #FED7AA; }
.cfa-kpi-badge--muted     { background: #F3F4F6; color: #6B7280; border: 1px solid #E5E7EB; }

/* Trust line */
.cfa-hero-trust {
  font-size: 15px;
  color: #6B7280;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-family: 'DM Sans', sans-serif;
}
.cfa-trust-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: #059669;
  flex-shrink: 0;
}
.cfa-trust-em { font-weight: 600; color: #111827; }
.cfa-trust-sep { color: #D1D5DB; margin: 0 4px; }

/* Right — image */
.cfa-hero-visual {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.cfa-hero-photo {
  width: 100%;
  height: 680px;
  object-fit: cover;
  border-radius: 24px 300px 300px 24px;
  box-shadow: 0 8px 24px rgba(27,43,107,0.10);
  display: block;
}

/* Floating overlay card */
.cfa-hero-overlay-card {
  position: absolute;
  bottom: 32px;
  left: -24px;
  background: rgba(255,255,255,0.88);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255,255,255,0.95);
  border-radius: 16px;
  padding: 20px 24px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12);
  z-index: 2;
  text-align: center;
}
.cfa-overlay-val {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: 36px;
  color: #2451D1;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-bottom: 4px;
}
.cfa-overlay-lbl {
  font-size: 16px;
  font-weight: 500;
  color: #6B7280;
}

/* Floating pills */
.cfa-hero-pill {
  position: absolute;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-radius: 100px;
  padding: 12px 20px;
  box-shadow: 0 4px 30px rgba(0,0,0,0.1);
  font-size: 16px;
  font-weight: 700;
  z-index: 3;
  white-space: nowrap;
  font-family: 'DM Sans', sans-serif;
  display: flex;
  align-items: center;
  gap: 7px;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(255,255,255,0.95);
}
.cfa-pill-1 { top: 32px; right: -12px; color: #2451D1; }
.cfa-pill-2 { bottom: 120px; right: -16px; color: var(--cfa-amber); }
.cfa-pill-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
  display: inline-block;
}

/* Responsive */
@media (max-width: 920px) {
  .cfa-hero { padding: 48px 0; }
  .cfa-hero-inner {
    grid-template-columns: 1fr;
    gap: 48px;
    padding: 0 24px;
  }
  .cfa-hero-visual {
    display: flex;
    justify-content: center;
  }
  .cfa-hero-photo {
    width: 100%;
    max-width: 360px;
    height: auto;
    aspect-ratio: 4 / 5;
    border-radius: 24px 300px 300px 24px;
  }
  .cfa-hero-overlay-card { left: 16px; bottom: 16px; }
  .cfa-pill-1 { right: 8px; top: 16px; }
  .cfa-pill-2 { right: 8px; }
}
@media (max-width: 600px) {
  .cfa-hero { padding: 32px 0; }
  .cfa-hero-kpis { grid-template-columns: 1fr; }
  .cfa-kpi-item { border-right: none; border-bottom: 1px solid rgba(36,81,209,0.15); }
  .cfa-kpi-item:last-child { border-bottom: none; }
  .cfa-hero-h1 { font-size: 40px; }
  .cfa-hero-pill { display: none; }
  .cfa-hero-overlay-card { display: none; }
}
@media (max-width: 480px) {
  .cfa-hero-inner { padding: 0 16px; }
  .cfa-hero-trust { font-size: 13px; gap: 4px; }
  .cfa-trust-sep { display: none; }
}


/* ============================================================
   HOME PAGE SECTIONS — FULL RESPONSIVE
   Press · How it Works · Social Proof Strip · About · CTA Strip
   Breakpoints: 1280 / 1024 / 768 / 480 / 360
   ============================================================ */

/* ── PRESS ── */
.cfa-press {
  background: #F4F6FB;
  border-top: 1px solid #E5E7EB;
  border-bottom: 1px solid #E5E7EB;
  padding: 40px 0;
}
.cfa-press-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
  display: flex;
  align-items: center;
  gap: 52px;
  flex-wrap: wrap;
}
.cfa-press-lbl {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #6B7280;
  white-space: nowrap;
  font-family: 'DM Sans', sans-serif;
}
.cfa-press-names { display: flex; gap: 44px; flex-wrap: wrap; align-items: center; }
.cfa-press-name {
  font-family: 'DM Sans', sans-serif;
  font-weight: 800;
  font-size: 18px;
  letter-spacing: -0.02em;
  color: #111827;
  opacity: 0.22;
  cursor: default;
}

/* ── HOW IT WORKS ── */
.cfa-how {
  background: #F4F6FB;
  border-top: 1px solid #E5E7EB;
  padding: 120px 0;
}
.cfa-how-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
}
.cfa-how-eyebrow {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: #2451D1;
  margin-bottom: 12px;
  font-family: 'DM Sans', sans-serif;
}
.cfa-how-h2 {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: clamp(36px, 4vw, 56px);
  color: #111827;
  letter-spacing: -0.04em;
  margin-bottom: 14px;
  line-height: 1.05;
}
.cfa-how-sub {
  font-size: 18px;
  color: #6B7280;
  max-width: 600px;
  line-height: 1.7;
  margin-bottom: 56px;
}
.cfa-how-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 28px;
}
.cfa-how-card {
  border-radius: 20px;
  overflow: hidden;
  position: relative;
}
.cfa-how-card-img {
  width: 100%;
  height: 260px;
  object-fit: cover;
  display: block;
}
.cfa-how-card-content {
  padding: 44px 48px;
  position: relative;
}
.cfa-how-card.bonds {
  background: linear-gradient(135deg, rgba(36,81,209,0.10) 0%, rgba(36,81,209,0.03) 100%);
  border: 1.5px solid rgba(36,81,209,0.4);
  box-shadow: 0 8px 32px rgba(36,81,209,0.08), inset 0 1px 0 rgba(255,255,255,0.9);
}
.cfa-how-card.shares {
  background: linear-gradient(135deg, rgba(var(--cfa-amber-rgb),0.06) 0%, rgba(var(--cfa-amber-rgb),0.02) 100%);
  border: 1.5px solid rgba(var(--cfa-amber-rgb),0.3);
  box-shadow: 0 8px 32px rgba(var(--cfa-amber-rgb),0.06), inset 0 1px 0 rgba(255,255,255,0.9);
}
.cfa-how-step {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: 90px;
  line-height: 1;
  letter-spacing: -0.04em;
  position: absolute;
  top: 16px; right: 28px;
  opacity: 0.08;
}
.cfa-how-card.bonds .cfa-how-step { color: #2451D1; }
.cfa-how-card.shares .cfa-how-step { color: var(--cfa-amber); }
.cfa-how-tag {
  display: inline-block;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 7px 16px;
  border-radius: 100px;
  margin-bottom: 22px;
  font-family: 'DM Sans', sans-serif;
}
.cfa-how-card.bonds .cfa-how-tag { background: #2451D1; color: white; }
.cfa-how-card.shares .cfa-how-tag { background: var(--cfa-amber); color: white; }
.cfa-how-card-h3 {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: 34px;
  color: #111827;
  margin-bottom: 22px;
  letter-spacing: -0.03em;
}
.cfa-how-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 13px; }
.cfa-how-list li {
  font-size: 16px;
  color: #374151;
  padding-left: 24px;
  position: relative;
  line-height: 1.55;
}
.cfa-how-list li::before {
  content: '\2713';
  position: absolute;
  left: 0;
  font-weight: 700;
}
.cfa-how-card.bonds .cfa-how-list li::before { color: #2451D1; }
.cfa-how-card.shares .cfa-how-list li::before { color: var(--cfa-amber); }
.cfa-how-card-cta {
  display: inline-block;
  margin-top: 32px;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;
  font-family: 'DM Sans', sans-serif;
  padding: 14px 28px;
  border-radius: 10px;
  transition: box-shadow 0.15s, transform 0.15s;
}
.cfa-how-card-cta:hover { transform: translateY(-1px); text-decoration: none; }
.cfa-how-card.bonds .cfa-how-card-cta { background: #2451D1; color: white; }
.cfa-how-card.bonds .cfa-how-card-cta:hover { box-shadow: 0 6px 20px rgba(36,81,209,0.3); color: white; }
.cfa-how-card.shares .cfa-how-card-cta { background: var(--cfa-amber); color: white; }
.cfa-how-card.shares .cfa-how-card-cta:hover { box-shadow: 0 6px 20px rgba(var(--cfa-amber-rgb),0.3); color: white; }

.cfa-how-card-risk {
  margin-top: 24px;
  padding-top: 18px;
  border-top: 1px solid rgba(0,0,0,0.07);
  font-size: 12px;
  line-height: 1.6;
  color: #9CA3AF;
}
.cfa-how-card-risk a,
.cfa-how-card-risk a:visited,
.cfa-how-card-risk a:hover,
.cfa-how-card-risk a:active {
  color: inherit !important;
  text-decoration: underline !important;
  text-underline-offset: 2px;
}

/* ── SOCIAL PROOF STRIP ── */
.cfa-proof-strip {
  background: #EEF2FF;
  border-top: 1px solid #C7D7FB;
  border-bottom: 1px solid #C7D7FB;
  padding: 36px 0;
}
.cfa-proof-inner {
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 48px;
  display: flex;
  align-items: center;
  gap: 52px;
  flex-wrap: wrap;
}
.cfa-proof-stars { display: flex; gap: 4px; font-size: 20px; color: var(--cfa-amber); }
.cfa-proof-text { font-size: 16px; color: #374151; font-weight: 500; }
.cfa-proof-text strong { color: #2451D1; font-weight: 700; }
.cfa-proof-divider { width: 1px; height: 36px; background: #C7D7FB; flex-shrink: 0; }
.cfa-proof-stat { display: flex; flex-direction: column; gap: 2px; }
.cfa-proof-stat .v {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: 28px;
  color: #2451D1;
  letter-spacing: -0.03em;
}
.cfa-proof-stat .l { font-size: 16px; color: #6B7280; font-weight: 500; }

/* ── ABOUT ── */
.cfa-about {
  background: #F4F6FB;
  padding: 120px 0;
  position: relative;
}
.cfa-about-photo-wrap {
  max-width: 1320px;
  width: 100%;
  margin: 0 auto;
}
.cfa-about-photo {
  width: 100%;
  height: 580px;
  object-fit: cover;
  border-radius: 24px;
  display: block;
}
@media (max-width: 1320px) {
  .cfa-about-photo { border-radius: 0; }
}
.cfa-about-card-outer {
  max-width: 1200px;
  margin: -220px auto 0;
  padding: 0 48px;
  position: relative;
  z-index: 2;
  box-sizing: border-box;
}
.cfa-about-card {
  background: #1B2B6B;
  border-radius: 24px;
  box-shadow: 0 8px 48px rgba(0,0,0,0.25);
  padding: 56px 64px;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: start;
}
.cfa-about-tagline {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: clamp(36px, 4vw, 56px);
  color: #ffffff;
  letter-spacing: -0.04em;
  line-height: 1.05;
  margin-bottom: 24px;
}
.cfa-about-tagline .cfa-hl-amber { color: var(--cfa-amber); }
.cfa-about-p {
  font-size: 17px;
  color: rgba(255,255,255,0.82);
  line-height: 1.8;
  margin-bottom: 20px;
}
.cfa-about-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  padding: 14px 22px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  color: rgba(255,255,255,0.75);
  font-family: 'DM Sans', sans-serif;
  letter-spacing: 0.02em;
  text-decoration: none;
  transition: background 0.15s, border-color 0.15s;
}
a.cfa-about-badge:hover {
  background: rgba(255,255,255,0.14);
  border-color: rgba(255,255,255,0.28);
  color: rgba(255,255,255,0.9);
  text-decoration: none;
}
.cfa-about-numbers { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; align-content: start; }
.cfa-about-num {
  background: linear-gradient(135deg, rgba(255,255,255,0.12) 0%, rgba(255,255,255,0.04) 100%);
  border: 1.5px solid rgba(255,255,255,0.25);
  border-radius: 14px;
  padding: 32px 24px;
  box-shadow: 0 8px 32px rgba(0,0,0,0.12), inset 0 1px 0 rgba(255,255,255,0.2);
}
.cfa-about-num .n {
  font-family: 'DM Sans', sans-serif;
  font-weight: 900;
  font-size: 48px;
  letter-spacing: -0.04em;
  line-height: 1;
  margin-bottom: 6px;
  margin-top: 0;
}
.cfa-about-num .l { font-size: 16px; color: rgba(255,255,255,0.60); font-weight: 500; margin: 0; }
.cfa-n-dark   { color: #ffffff; }
.cfa-n-cobalt { color: #93B4FF; }
.cfa-n-green  { color: #6EE7B7; }
.cfa-n-amber  { color: var(--cfa-amber); }

/* ── CTA STRIP ── */
.cfa-cta-strip {
  padding: 0 64px 88px;
  background: #F4F6FB;
  box-sizing: border-box;
}
.cfa-cta-strip-inner {
  max-width: 1320px;
  margin: 0 auto;
  background: #E8EAFF;
  border-radius: 24px;
  overflow: hidden;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 40px;
  padding: 0 0 0 72px;
  box-sizing: border-box;
}
.cfa-cta-strip-text {
  max-width: 520px;
  min-width: 300px;
  position: relative;
  z-index: 1;
}
.cfa-cta-strip-photo {
  max-width: 600px;
  aspect-ratio: 1;
  border-radius: 50% 0 0 50%;
  overflow: hidden;
  flex-shrink: 0;
}
.cfa-cta-strip-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  display: block;
}
.cfa-cta-strip-h2 {
  font-family: 'DM Sans', sans-serif;
  font-weight: 800;
  font-size: clamp(26px, 2.8vw, 38px);
  color: #1B2B6B;
  letter-spacing: -0.03em;
  line-height: 1.15;
  margin: 0 0 16px;
}
.cfa-cta-strip-h2 .hl { color: #2451D1; font-weight: 900; }
.cfa-cta-strip-sub {
  font-size: 18px;
  color: #374151;
  line-height: 1.7;
  margin: 0 0 28px;
  font-family: 'DM Sans', sans-serif;
}
.cfa-cta-strip-btns { display: flex; gap: 14px; flex-shrink: 0; flex-wrap: wrap; }
.cfa-btn-cta-primary {
  background: var(--cfa-amber);
  color: #fff;
  text-decoration: none;
  padding: 15px 30px;
  border-radius: 100px;
  font-size: 16px;
  font-weight: 700;
  font-family: 'DM Sans', sans-serif;
  transition: background 0.15s, transform 0.15s;
  display: inline-block;
}
.cfa-btn-cta-primary:hover { background: var(--cfa-amber-hover); transform: translateY(-1px); color: #fff; text-decoration: none; }
.cfa-btn-cta-secondary {
  background: transparent;
  color: #1B2B6B;
  text-decoration: none;
  padding: 15px 30px;
  border-radius: 100px;
  border: 2px solid rgba(27,43,107,0.40);
  font-size: 16px;
  font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  transition: border-color 0.15s;
  display: inline-block;
}
.cfa-btn-cta-secondary:hover { border-color: #1B2B6B; color: #1B2B6B; text-decoration: none; }

/* Keep old button classes for other pages */
.cfa-btn-white-solid {
  background: #2451D1;
  color: #fff;
  text-decoration: none;
  padding: 16px 32px;
  border-radius: 10px;
  font-size: 16px;
  font-weight: 700;
  font-family: 'DM Sans', sans-serif;
  transition: background 0.15s, transform 0.15s;
  display: inline-block;
}
.cfa-btn-white-solid:hover { background: #3563E9; transform: translateY(-1px); color: #fff; text-decoration: none; }
.cfa-btn-white-outline {
  background: transparent;
  color: rgba(255,255,255,0.85);
  text-decoration: none;
  padding: 16px 32px;
  border-radius: 10px;
  border: 2px solid rgba(255,255,255,0.35);
  font-size: 16px;
  font-weight: 600;
  font-family: 'DM Sans', sans-serif;
  transition: border-color 0.15s, color 0.15s;
  display: inline-block;
}
.cfa-btn-white-outline:hover { border-color: rgba(255,255,255,0.7); color: white; text-decoration: none; }

/* ── RESPONSIVE: 1280px — slightly tighten padding ── */
@media (max-width: 1280px) {
  .cfa-press-inner,
  .cfa-how-inner,
  .cfa-proof-inner,
  .cfa-about-inner { padding-left: 32px; padding-right: 32px; }
}

/* ── RESPONSIVE: 1024px — tablet landscape ── */
@media (max-width: 1024px) {
  .cfa-how { padding: 96px 0; }
  .cfa-how-inner { padding: 0 28px; }
  .cfa-how-card-content { padding: 36px 36px; }
  .cfa-how-card-h3 { font-size: 28px; }
  .cfa-how-step { font-size: 72px; }

  .cfa-about { padding: 96px 0; }
  .cfa-about-card-outer { padding: 0 28px; }
  .cfa-about-card { grid-template-columns: 1fr; padding: 48px; gap: 40px; }
  .cfa-about-tagline { font-size: clamp(36px, 4vw, 52px); }

  .cfa-press-inner { padding: 0 28px; gap: 36px; }
  .cfa-press-names { gap: 28px; }

  .cfa-proof-inner { padding: 0 28px; gap: 32px; }
  .cfa-cta-strip { padding: 0 28px 64px; }
  .cfa-cta-strip-inner {padding: 0 0 0 48px; }
  .cfa-cta-strip-photo { width: 440px; }
  .cfa-cta-strip-h2 { font-size: 30px; }
}

/* ── RESPONSIVE: 768px — tablet portrait, stack grids ── */
@media (max-width: 768px) {
  /* Press */
  .cfa-press { padding: 28px 0; }
  .cfa-press-inner { padding: 0 20px; gap: 20px; flex-direction: column; align-items: flex-start; }
  .cfa-press-names { gap: 18px; }
  .cfa-press-name { font-size: 15px; }

  /* How it works */
  .cfa-how { padding: 72px 0; }
  .cfa-how-inner { padding: 0 20px; }
  .cfa-how-h2 { font-size: 36px; }
  .cfa-how-sub { font-size: 16px; margin-bottom: 36px; }
  .cfa-how-grid { grid-template-columns: 1fr; gap: 20px; }
  .cfa-how-card-img { height: 200px; }
  .cfa-how-card-content { padding: 32px 28px; }
  .cfa-how-card-h3 { font-size: 26px; margin-bottom: 16px; }
  .cfa-how-step { font-size: 64px; top: 12px; right: 20px; }
  .cfa-how-list li { font-size: 15px; }
  .cfa-how-card-cta { margin-top: 24px; padding: 13px 24px; font-size: 15px; }

  /* Proof strip */
  .cfa-proof-strip { padding: 28px 0; }
  .cfa-proof-inner {
    padding: 0 20px;
    gap: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    row-gap: 20px;
    column-gap: 16px;
  }
  .cfa-proof-stars { grid-column: 1 / -1; }
  .cfa-proof-text { grid-column: 1 / -1; }
  .cfa-proof-divider { display: none; }
  .cfa-proof-stat .v { font-size: 22px; }
  .cfa-proof-stat .l { font-size: 14px; }

  /* About */
  .cfa-about { padding: 72px 0; }
  .cfa-about-photo { height: 280px; }
  .cfa-about-card-outer { padding: 0 20px; margin-top: -60px; }
  .cfa-about-card { grid-template-columns: 1fr; padding: 36px 28px; gap: 32px; }
  .cfa-about-tagline { font-size: 40px; margin-bottom: 20px; }
  .cfa-about-p { font-size: 16px; margin-bottom: 18px; }
  .cfa-about-numbers { gap: 12px; }
  .cfa-about-num { padding: 24px 18px; }
  .cfa-about-num .n { font-size: 40px; }
  .cfa-about-num .l { font-size: 14px; }

  /* CTA Strip */
  .cfa-cta-strip { padding: 0 20px 40px; }
  .cfa-cta-strip-inner {
    height: auto;
    flex-direction: column;
    align-items: flex-start;
    padding: 40px 0 0 0;
    overflow: hidden;
  }
  .cfa-cta-strip-text { max-width: 100%; padding-right: 0; }
  .cfa-cta-strip-h2 { font-size: 26px; }
  .cfa-cta-strip-text {
    padding: 0 32px;
  }
  .cfa-cta-strip-sub {
    font-size: 16px;
  }
  .cfa-cta-strip-btns { gap: 12px; }
  .cfa-cta-strip-photo {
    align-self: end;
    width: 90%;
  }
}

/* ── RESPONSIVE: 480px — mobile ── */
@media (max-width: 480px) {
  /* Press */
  .cfa-press-inner { gap: 14px; }
  .cfa-press-names { gap: 14px; }
  .cfa-press-name { font-size: 14px; }

  /* How it works */
  .cfa-how { padding: 56px 0; }
  .cfa-how-inner { padding: 0 16px; }
  .cfa-how-h2 { font-size: 30px; }
  .cfa-how-card-img { height: 160px; }
  .cfa-how-card-content { padding: 24px 20px; }
  .cfa-how-card-h3 { font-size: 22px; }
  .cfa-how-tag { font-size: 11px; padding: 5px 12px; }
  .cfa-how-step { display: none; }
  .cfa-how-list { gap: 10px; }
  .cfa-how-list li { font-size: 14px; }
  .cfa-how-card-cta { display: block; text-align: center; margin-top: 20px; }

  /* Proof strip */
  .cfa-proof-inner { grid-template-columns: 1fr 1fr; padding: 0 16px; row-gap: 16px; }
  .cfa-proof-stat .v { font-size: 20px; }

  /* About */
  .cfa-about { padding: 56px 0; }
  .cfa-about-photo { height: 200px; }
  .cfa-about-card-outer { padding: 0 16px; margin-top: -48px; }
  .cfa-about-card { padding: 28px 20px; gap: 24px; }
  .cfa-about-tagline { font-size: 34px; }
  .cfa-about-badge { font-size: 12px; padding: 10px 14px; }
  .cfa-about-numbers { grid-template-columns: 1fr 1fr; gap: 10px; }
  .cfa-about-num { padding: 20px 14px; }
  .cfa-about-num .n { font-size: 34px; }

  /* CTA Strip */
  .cfa-cta-strip { padding: 0 16px 56px; }
  .cfa-cta-strip-inner {
    padding: 32px 0 0 0;
  }
  .cfa-cta-strip-text { max-width: 100%; min-width: auto; padding: 0 15px; }
  .cfa-cta-strip-h2 { font-size: 24px; }
  .cfa-cta-strip-btns { flex-direction: column; gap: 10px; }
  .cfa-btn-cta-primary, .cfa-btn-cta-secondary { width: 100%; text-align: center; box-sizing: border-box; }
}

/* ── RESPONSIVE: 360px — small mobile ── */
@media (max-width: 360px) {
  .cfa-how-inner,
  .cfa-press-inner, .cfa-proof-inner { padding-left: 12px; padding-right: 12px; }
  .cfa-about-numbers { grid-template-columns: 1fr; }
  .cfa-about-num .n { font-size: 32px; }
}

/* ════════════════════════════════════════════════════════
   RISK SECTION — unified card style (all pages)
   .footerpara wraps the risk content in layout.phtml
   ════════════════════════════════════════════════════════ */

.footerpara {
  background: #FFFFFF !important;
  border: 1px solid #E5E7EB !important;
  border-radius: 16px !important;
  padding: 40px 48px !important;
  margin: 32px auto !important;
  max-width: 100% !important;
  width: 100% !important;
  box-sizing: border-box !important;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.04) !important;
}

/* Headings inside footerpara */
.footerpara .cfa-risk-h2,
.footerpara h2,
.footerpara h3,
.footerpara h3.center_text {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 800 !important;
  font-size: 20px !important;
  color: #111827 !important;
  margin: 0 0 22px 0 !important;
  padding: 0 !important;
  letter-spacing: -0.02em !important;
  text-align: left !important;
  line-height: 1.3 !important;
}

/* Paragraphs inside footerpara */
.footerpara .text_alt,
.footerpara p {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 16px !important;
  color: #6B7280 !important;
  line-height: 1.8 !important;
  margin: 0 0 14px 0 !important;
  padding: 0 !important;
  max-width: none !important;
}
.footerpara .text_alt:last-child,
.footerpara p:last-child { margin-bottom: 0 !important; }

.footerpara .text_alt strong,
.footerpara p strong { color: #374151 !important; font-weight: 600 !important; }

.footerpara .text_alt a,
.footerpara p a { color: #2451D1 !important; text-decoration: none !important; }
.footerpara .text_alt a:hover,
.footerpara p a:hover { text-decoration: underline !important; }

/* Responsive */
@media (max-width: 768px) {
  .footerpara {
    padding: 28px 24px !important;
    border-radius: 12px !important;
    width: calc(100% - 32px) !important;
    margin: 24px auto !important;
  }
  .footerpara .cfa-risk-h2,
  .footerpara h2,
  .footerpara h3 { font-size: 15px !important; margin-bottom: 16px !important; }
  .footerpara .text_alt,
  .footerpara p { font-size: 17px !important; line-height: 1.7 !important; }
}
@media (max-width: 480px) {
  .footerpara {
    padding: 24px 20px !important;
    border-radius: 10px !important;
    width: calc(100% - 24px) !important;
    margin: 16px auto !important;
  }
}

/* ════════════════════════════════════════════════════════
   BOOTSTRAP RESETS for home landing sections
   Prevents Bootstrap h2/h3/p/ul from bleeding in
   ════════════════════════════════════════════════════════ */
.cfa-how h2, .cfa-how h3, .cfa-how p, .cfa-how ul,
.cfa-proof-strip p, .cfa-proof-strip span,
.cfa-about h2, .cfa-about p,
.cfa-press span,
.cfa-cta-strip h2,
.cfa-launching-soon h2, .cfa-launching-soon p {
  margin-top: 0 !important;
}

.cfa-launching-eyebrow,
.cfa-launching-h2,
.cfa-launching-sub {
  font-size: revert;
}
.cfa-launching-eyebrow { font-size: 14px !important; }
.cfa-launching-h2      { font-size: clamp(36px, 4vw, 56px) !important; }
.cfa-launching-sub     { font-size: 18px !important; }

/* Prevent Bootstrap list reset interfering with how-list */
.cfa-how-list {
  padding-left: 0 !important;
  list-style: none !important;
  margin-bottom: 0 !important;
}

/* Ensure font-sizes override Bootstrap h2 { font-size: 2rem } etc */
.cfa-how-h2   { font-size: clamp(36px, 4vw, 56px) !important; }
.cfa-how-sub  { font-size: 18px !important; }
.cfa-how-card-h3 { font-size: 34px !important; }
.cfa-how-list li { font-size: 16px !important; }
.cfa-about-tagline { font-size: clamp(40px, 4.5vw, 64px) !important; }
.cfa-about-p { font-size: 18px !important; }
.cfa-about-num .n { font-size: 48px !important; }
.cfa-about-num .l { font-size: 16px !important; }
.cfa-proof-stat .v { font-size: 28px !important; }
.cfa-proof-stat .l { font-size: 16px !important; }
.cfa-cta-strip-h2 { font-size: clamp(32px, 3.5vw, 50px) !important; }

/* Responsive overrides must beat Bootstrap too */
@media (max-width: 1024px) {
  .cfa-how-card-h3 { font-size: 28px !important; }
  .cfa-about-tagline { font-size: clamp(36px, 4vw, 52px) !important; }
}
@media (max-width: 768px) {
  .cfa-how-h2   { font-size: 36px !important; }
  .cfa-how-sub  { font-size: 16px !important; }
  .cfa-how-card-h3 { font-size: 26px !important; }
  .cfa-how-list li { font-size: 15px !important; }
  .cfa-about-tagline { font-size: 40px !important; }
  .cfa-about-p { font-size: 16px !important; }
  .cfa-about-num .n { font-size: 40px !important; }
  .cfa-about-num .l { font-size: 14px !important; }
  .cfa-proof-stat .v { font-size: 22px !important; }
  .cfa-proof-stat .l { font-size: 14px !important; }
  .cfa-cta-strip-h2 { font-size: 26px !important; }
}
@media (max-width: 480px) {
  .cfa-how-h2   { font-size: 30px !important; }
  .cfa-how-card-h3 { font-size: 22px !important; }
  .cfa-how-list li { font-size: 14px !important; }
  .cfa-about-tagline { font-size: 34px !important; }
  .cfa-about-num .n { font-size: 34px !important; }
  .cfa-cta-strip-h2 { font-size: 22px !important; }
}

/* ============================================================
   LANDING — investor categorisation prompt (logged-in, home only)
   Fixed floating bar at bottom of viewport
   ============================================================ */

/* Reserve space so main content isn't covered by the fixed bar */
body.cfa-app:has(.cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal)) {
  padding-bottom: clamp(160px, 26vw, 220px);
}

body.cfa-app .cfa-landing-cat-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: calc(80px + env(safe-area-inset-bottom, 0px));
  z-index: 1040;
  margin: 0;
  padding: 0 16px;
  pointer-events: none;
}

body.cfa-app .cfa-landing-cat-cta__inner {
  pointer-events: auto;
  max-width: min(860px, 100%);
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--cfa-space-4);
  padding: var(--cfa-space-4) var(--cfa-space-5);
  background: linear-gradient(135deg, var(--cfa-cobalt-pale) 0%, var(--cfa-bg) 55%, var(--cfa-bg-soft) 100%);
  border: 1.5px solid rgba(36, 81, 209, 0.28);
  border-radius: var(--cfa-radius-xl) !important;
  box-shadow: 0 8px 40px rgba(1, 29, 50, 0.16);
}

body.cfa-app .cfa-landing-cat-cta__text {
  flex: 1 1 260px;
  min-width: 0;
}

body.cfa-app .cfa-landing-cat-cta__title {
  font-family: var(--cfa-font-body) !important;
  font-size: clamp(1.1rem, 2vw, 1.5rem) !important;
  font-weight: var(--cfa-weight-extrabold) !important;
  color: var(--cfa-navy) !important;
  margin: 0 0 var(--cfa-space-1) !important;
  line-height: 1.25 !important;
  letter-spacing: -0.02em !important;
}

body.cfa-app .cfa-landing-cat-cta__desc {
  font-family: var(--cfa-font-body) !important;
  font-size: var(--cfa-text-sm, 14px) !important;
  color: var(--cfa-text-mid) !important;
  line-height: 1.55 !important;
  margin: 0 !important;
  max-width: 52ch;
}

body.cfa-app .cfa-landing-cat-cta__action {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  align-self: center;
}

body.cfa-app .cfa-landing-cat-cta__btn.blue_btn {
  padding: 11px 24px !important;
  font-size: var(--cfa-text-base) !important;
  white-space: nowrap !important;
  display: inline-flex !important;
  align-items: center !important;
}

/* tablet — compact horizontal */
@media (max-width: 860px) {
  body.cfa-app .cfa-landing-cat-cta {
    padding: 0 12px;
    bottom: calc(72px + env(safe-area-inset-bottom, 0px));
  }
  body.cfa-app .cfa-landing-cat-cta__inner {
    gap: var(--cfa-space-3);
    padding: var(--cfa-space-3) var(--cfa-space-4);
  }
}

/* mobile — stacked (homepage bar only, not modal) */
@media (max-width: 640px) {
  body.cfa-app .cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal) {
    padding: 0 10px;
    bottom: calc(60px + env(safe-area-inset-bottom, 0px));
  }
  body.cfa-app .cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal) .cfa-landing-cat-cta__inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--cfa-space-3);
    gap: var(--cfa-space-3);
  }
  body.cfa-app .cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal) .cfa-landing-cat-cta__text {
    flex: 0 0 auto;
    width: 100%;
  }
  body.cfa-app .cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal) .cfa-landing-cat-cta__title {
    font-size: 1.05rem !important;
  }
  body.cfa-app .cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal) .cfa-landing-cat-cta__desc {
    font-size: 13px !important;
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: 38ch;
  }
  body.cfa-app .cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal) .cfa-landing-cat-cta__action {
    width: 100%;
    display: flex;
    justify-content: center;
  }
  body.cfa-app .cfa-landing-cat-cta:not(.cfa-landing-cat-cta--modal) .cfa-landing-cat-cta__btn.blue_btn {
    width: 100% !important;
    justify-content: center !important;
    min-height: 48px !important;
  }
}

/* MODAL-LIKE STYLE for investment page categorisation callout */
body.cfa-app:has(.cfa-landing-cat-cta.cfa-landing-cat-cta--modal) {
  padding-bottom: 0 !important;
}

body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal {
  position: fixed;
  inset: 0;
  z-index: 1090;
  display: flex;
  align-items: center;
  justify-content: center;
  pointer-events: auto;
}

body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal::before {
  content: '';
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.64);
  z-index: 1089;
  pointer-events: auto;
}

body.cfa-app:has(.cfa-landing-cat-cta.cfa-landing-cat-cta--modal) {
  overflow: hidden !important;
}

body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__inner {
  position: relative;
  z-index: 1090;
  max-width: min(860px, calc(100% - 32px));
  margin: 0 auto;
  width: 100%;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: var(--cfa-space-4);
  border-radius: var(--cfa-radius-xl) !important;
}

body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__text {
  flex: 1 1 260px;
  min-width: 0;
  text-align: left;
}

body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__action {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
}

body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__btn.blue_btn {
  width: auto !important;
}

@media (max-width: 640px) {
  body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__inner {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }
  body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__text {
    flex: 0 0 auto;
    width: 100%;
    text-align: center;
  }
  body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__action {
    width: 100%;
  }
  body.cfa-app .cfa-landing-cat-cta.cfa-landing-cat-cta--modal .cfa-landing-cat-cta__btn.blue_btn {
    width: 100% !important;
    justify-content: center !important;
  }
}


/* ================================================================
   LAUNCHING SOON SECTION  (.cfa-launching-soon)
   Homepage section — placed after "How It Works", before stats strip.
   ================================================================ */

.cfa-launching-soon {
  background: var(--cfa-bg);
  padding: var(--cfa-space-15) 0 var(--cfa-space-13);
  border-top: 1px solid var(--cfa-glass-cobalt-border, rgba(36,81,209,0.15));
  border-bottom: 1px solid var(--cfa-glass-cobalt-border, rgba(36,81,209,0.15));
  position: relative;
  overflow: hidden;
}

/* Subtle radial accent — cobalt glow top-right */
.cfa-launching-soon::before {
  content: '';
  position: absolute;
  top: -120px;
  right: -80px;
  width: 560px;
  height: 560px;
  background: radial-gradient(ellipse at center, rgba(36, 81, 209, 0.06) 0%, transparent 65%);
  pointer-events: none;
}

.cfa-launching-inner {
  max-width: var(--cfa-container-max);
  margin: 0 auto;
  padding: 0 var(--cfa-container-pad);
  position: relative;
}

/* ── Header row: eyebrow+title left, link right ── */
.cfa-launching-header {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--cfa-space-8);
  margin-bottom: var(--cfa-space-10);
}

.cfa-launching-header-left {
  display: flex;
  flex-direction: column;
}

.cfa-launching-eyebrow {
  font-family: var(--cfa-font-body);
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--cfa-cobalt);
  margin: 0 0 12px;
}

.cfa-launching-h2 {
  font-family: var(--cfa-font-body);
  font-weight: 900;
  font-size: clamp(36px, 4vw, 56px);
  color: var(--cfa-text);
  letter-spacing: -0.03em;
  line-height: 1.05;
  margin: 0 0 14px;
}

/* Accent word in title */
.cfa-launching-h2-accent {
  color: var(--cfa-cobalt);
  position: relative;
}

/* Red button variant for launching section */
.cfa-btn-red {
  background: var(--cfa-amber) !important;
  border-color: var(--cfa-amber) !important;
  box-shadow: none !important;
}
.cfa-btn-red:hover {
  background: var(--cfa-amber-hover) !important;
  border-color: var(--cfa-amber-hover) !important;
  box-shadow: none !important;
  color: #fff !important;
}

.cfa-launching-sub {
  font-family: var(--cfa-font-body);
  font-size: 18px;
  color: #6B7280;
  max-width: 600px;
  line-height: 1.7;
  margin: 0;
}

/* Underline accent below the word */
.cfa-launching-h2-accent::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 3px;
  background: var(--cfa-amber);
  border-radius: 2px;
}

/* ── "View all" button ── */
.cfa-btn-launching {
  display: inline-flex;
  align-items: center;
  gap: var(--cfa-space-2);
  font-family: var(--cfa-font-body);
  font-weight: var(--cfa-weight-semibold);
  font-size: var(--cfa-text-sm);
  color: var(--cfa-cobalt);
  text-decoration: none;
  padding: 10px 22px;
  border-radius: var(--cfa-radius-full);
  border: 1.5px solid var(--cfa-cobalt-border);
  background: var(--cfa-cobalt-pale);
  white-space: nowrap;
  flex-shrink: 0;
  transition: background var(--cfa-transition-fast),
              border-color var(--cfa-transition-fast),
              box-shadow var(--cfa-transition-fast);
}

.cfa-btn-launching:hover {
  background: var(--cfa-cobalt);
  border-color: var(--cfa-cobalt);
  color: #fff;
  box-shadow: var(--cfa-shadow-cobalt);
}

/* ── Responsive ── */
@media (max-width: 920px) {
  .cfa-launching-soon {
    padding: var(--cfa-space-13) 0 var(--cfa-space-10);
  }
  .cfa-launching-inner {
    padding: 0 var(--cfa-container-pad-sm);
  }
}

@media (max-width: 600px) {
  .cfa-launching-soon {
    padding: var(--cfa-space-12) 0 var(--cfa-space-9);
  }
  .cfa-launching-header {
    flex-direction: column;
    align-items: flex-start;
    gap: var(--cfa-space-5);
    margin-bottom: var(--cfa-space-8);
  }
  .cfa-btn-launching {
    align-self: flex-start;
  }
}

/* ── Sitemap page ───────────────────────────────────────────────── */
.sitemap-page {
  width: 100%;
  margin: 48px 0 64px;
  padding: 0;
  font-family: 'DM Sans', sans-serif;
}

.sitemap-page h1 {
  font-size: 32px;
  font-weight: 700;
  color: #1B2B6B;
  margin: 0 0 8px;
}

.sitemap-page > p {
  font-size: 16px;
  color: #6b7280;
  margin: 0 0 40px;
}

.sitemap-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 24px;
}

.sitemap-section {
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 28px 28px 24px;
  transition: box-shadow 0.2s ease;
}

.sitemap-section:hover {
  box-shadow: 0 4px 20px rgba(36, 81, 209, 0.10);
}

.sitemap-section-title {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #2451D1;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 2px solid #e8ecfb;
}

.sitemap-section ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

.sitemap-section ul li {
  margin: 0;
  padding: 0;
}

.sitemap-section ul li + li {
  margin-top: 2px;
}

.sitemap-section ul li a {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  color: #374151;
  text-decoration: none;
  padding: 7px 10px;
  border-radius: 8px;
  transition: background 0.15s ease, color 0.15s ease;
}

.sitemap-section ul li a::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #d1d5db;
  flex-shrink: 0;
  transition: background 0.15s ease;
}

.sitemap-section ul li a:hover {
  background: #eef1fc;
  color: #2451D1;
  text-decoration: none;
}

.sitemap-section ul li a:hover::before {
  background: #2451D1;
}

.sitemap-badge {
  display: inline-block;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  background: #2451D1;
  color: #fff;
  padding: 2px 7px;
  border-radius: 20px;
  vertical-align: middle;
  margin-left: 4px;
}

#admin-main:has(.sitemap-page) {
  width: 100%;
  max-width: none;
  background: transparent;
}

#wrapper-main:has(.sitemap-page) {
  background-image: none;
}

@media (max-width: 600px) {
  .sitemap-grid {
    grid-template-columns: 1fr;
  }
  .sitemap-page h1 {
    font-size: 26px;
  }
}
/* ──────────────────────────────────────────────────────────────── */

/* CMS-generated sitemap content (flat ul/li/a from DB) */
.sitemap-cms-content {
  width: 100%;
  background: #ffffff;
  border: 1px solid #e5e7eb;
  border-radius: 16px;
  padding: 32px 36px;
  box-sizing: border-box;
}

.sitemap-cms-content ul {
  list-style: none;
  margin: 0;
  padding: 0;
  columns: 3;
  column-gap: 32px;
}

.sitemap-cms-content ul li {
  margin: 0;
  padding: 0;
  break-inside: avoid;
}

.sitemap-cms-content ul li + li {
  margin-top: 2px;
}

.sitemap-cms-content ul li a {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 15px;
  color: #374151;
  text-decoration: none;
  padding: 7px 10px;
  border-radius: 8px;
  transition: background 0.15s ease, color 0.15s ease;
}

.sitemap-cms-content ul li a::before {
  content: '';
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #d1d5db;
  flex-shrink: 0;
  transition: background 0.15s ease;
}

.sitemap-cms-content ul li a:hover {
  background: #eef1fc;
  color: #2451D1;
  text-decoration: none;
}

.sitemap-cms-content ul li a:hover::before {
  background: #2451D1;
}

@media (max-width: 900px) {
  .sitemap-cms-content ul { columns: 2; }
}
@media (max-width: 600px) {
  .sitemap-cms-content ul { columns: 1; }
  .sitemap-cms-content { padding: 20px; }
}
