:root {
    --primary: #431076;
    --secondary: #755b00;
    --accent-yellow: #fed977;
    --bg: #fdf9f3;
    --surface: #f1ede7;
    --text: #1c1c18;
    --accent: #5c2e8f;

    --on-surface-variant: #4b4451;

    --surface-low: #f1ede7;

    /*  */
    --cx-primary: #431076;
    --cx-primary-container: #5b2d8e;
    --cx-primary-fixed: #efdbff;
    --cx-primary-fixed-dim: #dbb8ff;
    --cx-on-primary: #ffffff;
    --cx-on-primary-container: #cda0ff;

    --cx-secondary: #755b00;
    --cx-secondary-container: #fed977;
    --cx-on-secondary-container: #785d00;

    --cx-surface: #fdf9f3;
    --cx-surface-low: #f7f3ed;
    --cx-surface-container: #f1ede7;
    --cx-surface-high: #ebe8e2;
    --cx-surface-white: #ffffff;

    --cx-on-surface: #1c1c18;
    --cx-on-surface-variant: #4b4451;
    --cx-outline: #7c7482;
    --cx-outline-variant: #cdc3d2;

    --cx-error: #ba1a1a;
    --cx-error-container: #ffdad6;

    --cx-shadow-editorial: 0 20px 40px rgba(28, 28, 24, 0.06);
    --cx-shadow-card: 0 4px 16px rgba(28, 28, 24, 0.08);
    --cx-shadow-btn: 0 4px 12px rgba(67, 16, 118, 0.25);

    --cx-radius-sm: 0.375rem;
    /* 6px  */
    --cx-radius-md: 0.5rem;
    /* 8px  */
    --cx-radius-lg: 0.75rem;
    /* 12px */
    --cx-radius-xl: 1rem;
    /* 16px */
    --cx-radius-2xl: 1.25rem;
    /* 20px */

    --cx-font-headline: 'Plus Jakarta Sans', system-ui, sans-serif;
    --cx-font-body: 'Manrope', system-ui, sans-serif;

    --cx-transition: 0.2s ease;
}

.elementskit-post-body p {
    margin-bottom: 24px !important;
    margin-top: 16px !important;
}

body{
	background-color: var(--bg) !important;
	background: var(--bg) !important;
}

body .widget-area:not(.widget-area-secondary){
	min-width:900px;
	margin:0 auto;
}

.hfe-nav-menu {
    flex-wrap: nowrap !important;
}

.cx-white {
    color: white !important;
}

.cx-white-8 {
    color: rgba(255, 255, 255, 0.8) !important;
}

.cx-primary {
    color: var(--cx-primary) !important;
}

.cx-secondary {
    color: var(--cx-secondary) !important;
}

.cx-secondary-gradient {
    background: linear-gradient(90deg, #755b00, #e6c364) !important;
}

.full-height {
    height: 100% !important;
}

/* Base */
body {
    font-family: 'Manrope', sans-serif !important;
    font-size: 16px;
    line-height: 1.7;
    color: var(--text);
    background-color: var(--cx-surface);

}

.elementor-element.elementor-element-8bfcaa3.elementor-widget-mobile__width-initial.elementor-hidden-desktop.elementor-widget.elementor-widget-image {
    flex: 1 !important;
}

body.pmpro-login.pmpro-variation_1.bp-nouveau.wp-singular.page-template-default.page.page-id-2667.wp-custom-logo.wp-theme-buddyboss-theme-disable.wp-child-theme-buddyboss-theme-disable-child.theme-buddyboss-theme-disable.pmpro-body-has-access.woocommerce-js.tribe-js.ehf-template-buddyboss-theme-disable.ehf-stylesheet-buddyboss-theme-disable-child.qodef-qi--no-touch.qi-addons-for-elementor-1\.9\.5.jkit-color-scheme.buddyboss-theme.bb-template-v2.buddypanel-logo-off.header-style-4.menu-style-standard.sticky-header.bb-tribe-events-views-v2.buddy-boss-child.bp-search.elementor-default.elementor-kit-2614.js.bb-page-loaded.e--ua-blink.e--ua-chrome.e--ua-mac.e--ua-webkit {
    background: var(--cx-surface) !important;
}

.bb-grid-cell:not(.no-gutter),
.bb-grid>:not(.no-gutter) {
    padding-left: 0 !important;
    padding-right: 0 !important;

    background-color: var(--cx-surface);
}

.entry-content {
    background-color: var(--cx-surface);
}

.content-area {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    background-color: var(--cx-surface);
}

/* top navigation */
/* MAIN NAV WRAPPER */
.my-navigation {
    position: fixed !important;
    top: 0;
    width: 100% !important;
    padding: 4px 0px !important;
    min-height: 80px !important;
    z-index: 999;
    backdrop-filter: blur(14px);
    background: rgba(255, 255, 255, 0.75);
    border-bottom: 1px solid rgba(0, 0, 0, 0.05);

    transition: all 0.3s ease;
}

/* INNER CONTAINER */


/* wrapper */
.cx-header-actions {
    display: flex;
    /* align-items: center; */
    gap: 8px;
}

/* icons */
.cx-icon {
    position: relative;
    font-size: 18px;
    color: rgba(0, 0, 0, 0.7);
    transition: all 0.2s ease;
}

.cx-icon:hover {
    color: #000;
    transform: translateY(-1px);
}

/* count badge */
.cx-count {
    position: absolute;
    top: -6px;
    right: -8px;
    background: #ff3b30;
    color: #fff;
    font-size: 10px;
    padding: 2px 6px;
    border-radius: 20px;
}

/* user */
.cx-user {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    text-decoration: none;
    color: #000;
}

.cx-user img {
    border-radius: 50%;
    width: 28px;
    height: 28px;
}

a.cx-user span {
    font-size: 14px !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
}








.my-navigation .site-header-container {
    max-width: 1200px;
    margin: 0 auto;

    display: flex;
    align-items: center;
    justify-content: space-between;
}


.my-navigation .default-header .main-navigation {
    /* max-width: fit-content !important; */
    margin-left: 32px !important;
}

.my-navigation .site-header .site-header-container.flex {
    padding-left: 0 !important;
    padding-right: 0 !important;

    margin: 0 auto !important;
}

.my-navigation .bb-logo {
    height: 40px;
    width: auto;
    object-fit: contain;
}

/* .my-navigation .primary-menu {
    display: flex;
    gap: 32px;
    align-items: center;
} */

.my-navigation .primary-menu li a {
    font-weight: 600;
    font-size: 15px;
    color: rgba(0, 0, 0, 0.65);
    text-decoration: none;
    position: relative;
    transition: all 0.25s ease;
}





/* Active menu */


.my-navigation .current-menu-item a::after {
    width: 100%;
}

.current-menu-item .hfe-menu-item {
    color: var(--primary) !important;
    font-weight: 600 !important;
}

.hfe-menu-item:hover {
    color: var(--primary) !important;
    opacity: 0.8;
}

.my-navigation .header-aside {
    display: flex;
    align-items: center;
    gap: 18px;
}

/* Icons */
.my-navigation .notification-link i {
    font-size: 18px;
    opacity: 0.7;
    transition: all 0.2s ease;
}

.my-navigation .notification-link:hover i {
    opacity: 1;
    transform: translateY(-1px);
}

.my-navigation .user-link {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
    position: relative;
}

.sub-menu {
    position: absolute !important;
    background: white !important;
    left: 0 !important;
}

.bb-template-v2 .user-wrap-container .sub-menu-inner>li>a,
.user-wrap.menu-item-has-children .sub-menu a {
    font-size: 14px !important;
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    color: var(--cx-on-surface-variant);
}

.user-wrap .wp-admin-bar-arrow {
    content: "";
    display: inline-block !important;
    margin-left: 6px;
    border: 5px solid transparent;
    border-left: 5px solid transparent;
    transform: translateY(0px) rotate(-90deg);
    position: absolute;
    right: 0;
    top: 12px;
    border-top: 5px solid var(--on-surface-variant);
    border-right: 5px solid transparent;
}

.my-navigation .user-link img {
    width: 32px;
    height: 32px;
    border-radius: 50%;
}

/* Dropdown */
.my-navigation .user-wrap .sub-menu {
    border-radius: 12px;
    box-shadow: 0 20px 40px rgba(0, 0, 0, 0.08);
    border: 1px solid rgba(0, 0, 0, 0.05);
    padding: 10px;
}

.my-navigation.elementor-sticky--effects {
    backdrop-filter: blur(18px);
    background: rgba(255, 255, 255, 0.9);
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.06);
}

/*  */

.text-accent {
    color: var(--accent) !important;
}

.text-accent-yellow {
    color: var(--accent-yellow) !important;
}

p {
    margin: 0 !important;
    padding: 0 !important;
}

/* Headings */
h1,
h2,
h3,
h4,
h5 {
    font-family: 'Plus Jakarta Sans', sans-serif !important;
    color: var(--primary);
    margin: 0 !important;
    padding: 0 !important;
}

h1 {
    font-size: 60px;
    line-height: 1.1;
    letter-spacing: -1px;
}

h2 {
    font-size: 40px;
}

h3 {
    font-size: 24px;
}

h4 {
    font-size: 20px;
}

h5 {
    font-size: 16px;
}

h6 {
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-weight: 700;
}

#hero-word::after {
    content: "|";
    margin-left: 4px;
    animation: blink 1s infinite;
}

@keyframes blink {

    0%,
    50%,
    100% {
        opacity: 1;
    }

    25%,
    75% {
        opacity: 0;
    }
}

.bb-header-buttons a.button.outline {
    color: var(--primary) !important;
    padding: 4px 24px !important;
    border: 1px solid var(--primary) !important;

}

.bb-header-buttons a.button.outline:hover {
    background-color: var(--primary) !important;
    color: white !important;
}

/* Buttons */
button,
.cx-btn,
.elementor-button,
.header-aside .button.signup,
.bb-header-buttons a.button.outline {
    border-radius: 8px;
    font-weight: 700;
    font-size: 16px !important;
    /* transition: all 0.2s ease; */
    /* background: linear-gradient(135deg, #431076 0%, #5b2d8e 100%); */
}

.header-aside .button.signup {
    background: linear-gradient(135deg, #431076 0%, #5b2d8e 100%);
    color: white !important;
    padding: 4px 24px !important;
}

.header-aside .button.signup:hover {
    opacity: 0.9;
}

.cx-btn-sm {
    transform: scale(0.9);
}

.elementor-button:hover {
    opacity: 0.9;
    color: white !important;
}

.btn-secondary .elementor-button {
    /* background-color: var(--surface-low) !important; */
    background-color: var(--accent-yellow) !important;
    color: var(--text) !important;
    border: none !important;
}

.outline-button a {
    background-color: transparent !important;
    color: var(--primary) !important;
    border: 2px solid var(--primary) !important;
}

.outline-button a:hover {
    background-color: var(--primary) !important;
    color: white !important;
}

.outline-button-white a {
    background-color: white !important;
    color: var(--primary) !important;
    border: none !important;
}

.outline-button-white a:hover {
    background-color: transparent !important;
    color: white !important;
    border: 2px solid white !important;
}

.outline-button-white a:hover svg {
    fill: white !important;
}

.outline-button-secondary a {
    background-color: transparent !important;
    color: var(--accent-yellow) !important;
    border: 2px solid var(--accent-yellow) !important;
}

.outline-button-secondary a:hover {
    background-color: var(--accent-yellow) !important;
    color: var(--primary) !important;
}

/* Cards */
.card,
.elementor-widget-container {
    border-radius: 12px;
}

/* BuddyPress fix */
.buddypress {
    font-family: 'Manrope', sans-serif;
}

/* trust + verified badge hero */

/* Wrapper */
.cx-trust-badge {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 0 16px;
}

/* Text */
.cx-trust-text {
    font-size: 14px;
    font-weight: 600;
    color: var(--on-surface-variant);
    /* on-surface-variant */
}

/* Circle badges */
.cx-badge-circle {
    width: 40px;
    height: 40px;
    border-radius: 9999px;
    border: 2px solid #fdf9f3;
    /* surface */
    display: flex;
    align-items: center;
    justify-content: center;
    position: relative;
    overflow: hidden;
}

/* Backgrounds (match your tokens) */
.bg-primary-container {
    background: var(--primary);
}

.bg-secondary-container {
    background: var(--accent-yellow);
}

.bg-tertiary-container {
    background: #44445a;
}

/* SVG icon */
.cx-icon {
    width: 18px;
    height: 18px;
    fill: #ffffff;
}

/* Adjust icon color for light bg */
.bg-secondary-container .cx-icon {
    fill: #241a00;
}

/* Subtle glow (premium feel) */
.cx-badge-circle::after {
    content: "";
    position: absolute;
    inset: 6px;
    border-radius: 9999px;
    background: rgba(255, 255, 255, 0.15);
}

/* Optional animation */
.cx-badge-circle {
    animation: cx-pulse 2.5s infinite ease-in-out;
}

.cx-badge-circle:nth-child(2) {
    animation-delay: 0.3s;
}

.cx-badge-circle:nth-child(3) {
    animation-delay: 0.6s;
}

@keyframes cx-pulse {

    0%,
    100% {
        transform: scale(1);
        opacity: 0.9;
    }

    50% {
        transform: scale(1.08);
        opacity: 1;
    }
}

.user-box .elementor-icon-box-content {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.elementor-icon-box-content a {
    color: var(--primary) !important;
    font-size: 14px !important;
    font-weight: bold !important;
}

.elementor-icon-box-description span {
    color: white !important;
    font-weight: bold;
}

.gap-12 .elementor-icon-box-content {
    display: flex;
    flex-direction: column;
    gap: 12px !important;
}

.gap-8 .elementor-icon-box-content {
    display: flex;
    flex-direction: column;
    gap: 8px !important;
}

.gap-8 .elementor-icon-box-wrapper {
    gap: 16px !important;
}

.gap-4 .elementor-icon-box-content {
    display: flex;
    flex-direction: column;
    gap: 0px !important;
}

.gap-4 .elementor-icon-box-wrapper {
    gap: 12px !important;
}

/* other vs connecxion */
/* Wrapper */
.cx-table-wrap {
    overflow-x: auto;
}

/* Table */
.cx-table {
    width: 100%;
    border-collapse: collapse;
    background: #ffffff;
    /* surface-container-lowest */
    border-radius: 12px;
    overflow: hidden;
    box-shadow: 0 8px 20px rgba(28, 28, 24, 0.05);
    margin: 0 !important;
}

/* Header */
.cx-th {
    padding: 20px;
    font-weight: 700;
    font-family: "Plus Jakarta Sans", sans-serif;
}

.cx-th-left {
    text-align: left;
    background: var(--primary);
    /* primary */
    color: #ffffff;
}

.cx-th-center {
    text-align: center;
    background: var(--primary);
    color: #ffffff;
}

.cx-th-highlight {
    background: var(--primary);
    /* primary-container */
    color: #cda0ff;
}

/* Border */
.cx-border-left {
    border-left: 1px solid rgba(255, 255, 255, 0.1);
}

/* Body */
.cx-td {
    padding: 20px !important;
    font-size: 14px;
    border-bottom: 1px solid #e6e2dc;
    /* outline-variant */
    text-align: left !important;
}

/* Feature column */
.cx-feature {
    font-weight: 700;
    color: #1c1c18;
}

/* Muted text */
.cx-muted {
    text-align: center;
    color: var(--on-surface-variant);
    font-size: 12px !important;
    line-height: normal !important;
}

/* Highlight column */
.cx-highlight {
    text-align: center;
    font-weight: 700;
    color: var(--primary);
    background: rgba(91, 45, 142, 0.05) !important;
}

/* Last row border fix */
.cx-table tr:last-child .cx-td {
    border-bottom: none;
}

/* pmpro subscription plans home page */

.cx-pricing-grid {
    display: grid;
    /* grid-template-columns: repeat(4, 1fr); */
    grid-template-columns: repeat(3, 1fr);
    /* 3 columns */
    grid-template-rows: repeat(2, 1fr);
    /* 2 rows */
    gap: 24px;
    margin: 0 auto;
}



.cx-card {
    background: #ffffff;
    padding: 32px;
    border-radius: 16px;
    border: 1px solid rgba(124, 116, 130, 0.3);
    position: relative;

    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.cx-featured {
    background: var(--primary);
    color: #ffffff;
    border: 2px solid var(--accent-yellow) !important;
    /* transform: scale(1.05);
    transform-origin: top center; */
}

.cx-badge {
    position: absolute;
    top: -12px;
    right: 20px;
    background: var(--accent-yellow);
    color: #241a00;
    padding: 0px 12px;
    font-size: 12px;
    font-weight: bold;
    border-radius: 999px;
}

.cx-badge-relative {
    position: relative !important;
    width: fit-content;
    background: var(--accent-yellow);
    color: #241a00;
    padding: 0px 12px;
    font-size: 12px;
    font-weight: bold;
    border-radius: 999px;
}

.cx-badge-relative h5 {
    letter-spacing: normal !important;
    padding: 8px !important;
}

.cx-badge-purple {
    background: rgba(67, 16, 118, 0.1);
    color: var(--primary) !important;
}

.cx-title {
    font-size: 24px !important;
    font-weight: 700;
    line-height: 30px !important;
    margin-bottom: 8px;
    color: var(--primary) !important;
}

.cx-featured .cx-title {
    color: var(--accent-yellow) !important;
}

p.cx-desc.cx-featured {
    border: none !important;
    color: #CDA0FF;
    opacity: 1;

}

.cx-pricing-grid .cx-desc {
    margin-top: 8px !important;
}

.cx-desc {
    font-size: 14px;
    margin-bottom: 20px;
    opacity: 0.7;
    line-height: normal !important;
}

.cx-price {
    margin-top: 24px;
}

.cx-price-amount {
    font-size: 32px;
    font-weight: 700;
}

.cx-price-duration {
    opacity: 0.7;
}

.cx-features {
    margin-block: 24px;
    padding: 0;
    margin-left: 0;
    list-style: none;
}

.cx-features li {
    display: flex;
    gap: 18px;
    margin-bottom: 10px;
    font-size: 14px;
    line-height: 22px !important;
}

.cx-check {
    color: #755b00;
    font-weight: bold;
}

.cx-featured .cx-check {
    color: var(--accent-yellow);
}

.cx-btn {
    display: block;
    text-align: center;
    padding: 12px;
    border: 2px solid var(--primary) !important;
    border-radius: 8px;
    font-weight: bold !important;
    color: var(--primary) !important;
    text-decoration: none;
}

.cx-btn:hover {
    background-color: var(--primary) !important;
    color: white !important;
}

.cx-featured .cx-btn {
    border-color: var(--accent-yellow) !important;
    color: var(--accent-yellow) !important;
}

.cx-featured .cx-btn:hover {
    background-color: var(--accent-yellow) !important;
    color: var(--primary) !important;
}

.cx-faq .elementor-widget-qi_addons_for_elementor_faq {
    min-width: 100% !important;
}

.cx-faq h6 {
    letter-spacing: normal !important;
    background-color: var(--surface);
    border-top-left-radius: 12px;
    border-top-right-radius: 12px;
    padding: 26px !important;
    margin-top: 16px !important;
}

h6.ui-accordion-header-collapsed {
    border-radius: 12px !important;
}

.cf-faq .qodef-qi-faq .qodef-e-content p,
.qodef-e-content-inner {
    font-size: 16px !important;
}

.ui-widget-content {
    border: none !important;
    border-bottom-left-radius: 12px;
    border-bottom-right-radius: 12px;
}



/* Wrapper */
.cx-steps-nav {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px;
    background: var(--surface);
    border-radius: 999px;
    max-width: fit-content !important;
}

/* Remove default button styles */
.cx-step-item .elementor-button {
    background: transparent;
    border: none;
    box-shadow: none;
    padding: 6px 20px;
    border-radius: 999px;
    font-size: 14px !important;
    font-weight: 600;
    color: var(--on-surface-variant);
    /* on-surface-variant */
    transition: all 0.25s ease;
}

/* Hover */
.cx-step-item .elementor-button:hover {
    color: var(--primary) !important;
    /* primary */
}

.cx-step-item.active .elementor-button:hover {
    color: var(--accent-yellow) !important;
    /* primary */
}

.cx-step-item.not-active {
    background-color: var(--surface) !important;
    border-radius: 999px;
}

.cx-step-item.not-active:hover {
    color: var(--primary) !important;
}

/* Active state */
.cx-step-item.active .elementor-button {
    background: var(--primary);
    /* primary */
    color: white;
    font-weight: 700;
}


/* how it works step 1 artwork */



/* Top bar */
.cx-topbar {
    background: #f1ede7;
    padding: 12px 20px;
    display: flex;
    align-items: center;
    gap: 8px;
    border-bottom: 1px solid rgba(124, 116, 130, 0.2);
    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
}


.cx-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
}

.cx-dot-red {
    background: rgba(186, 26, 26, 0.4);
}

.cx-dot-yellow {
    background: #fed977;
}

.cx-dot-purple {
    background: rgba(67, 16, 118, 0.3);
}

.cx-url {
    margin-left: 12px;
    font-size: 12px;
    color: #4b4451;
    font-family: monospace;
}

/* Content */
.cx-content {
    padding: 44px 24px;
    display: flex;
    flex-direction: column;
    gap: 18px;
}

/* Profile */
.cx-profile {
    display: flex;
    align-items: start;
    gap: 12px;
    line-height: normal;
    justify-content: space-between;
}

.cx-flex-col {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: start;
    gap: 12px;
}

.cx-avatar {
    width: 56px;
    height: 56px;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), #7548a9);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
}

.cx-avatar-md {
    width: 32px;
    height: 32px;
    font-size: 12px;
}

.cx-avatar-ld {
    width: 48px;
    height: 48px;
    font-size: 16px;
}

.cx-name {
    font-weight: 700;
    line-height: normal !important;
}

.cx-name-sm {
    font-size: 16px;
    font-weight: 700;
    line-height: normal !important;
}

.cx-details-sm {
    font-size: 12px;
    color: #4b4451;
    line-height: normal !important;
}

.cx-role {
    font-size: 11px;
    color: #755b00;
    font-weight: 700;
    text-transform: uppercase;
    line-height: normal !important;
}


/* Fields */
.cx-label {
    font-size: 11px;
    font-weight: bold;
    color: #4b4451;
    margin-bottom: 6px;
    text-transform: uppercase;
}

.cx-input {
    background: #f1ede7;
    padding: 10px 12px;
    border-radius: 8px;
    border: 1px solid rgba(124, 116, 130, 0.3);
    font-size: 14px;
}

/* Grid */
.cx-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 12px;
}

/* Tags */
.cx-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;

}

.cx-tag {
    padding: 0px 14px;
    border-radius: 999px;
    font-size: 12px;
    border: 1px solid rgba(124, 116, 130, 0.3);
    color: #4b4451;
    max-width: fit-content;
}

.cx-tag.active {
    background: rgba(67, 16, 118, 0.1);
    color: var(--primary);
    font-weight: 700;
    border: none;
}

/* Progress */
.cx-progress-wrap {
    margin-top: 6px;
}

.cx-progress-head {
    display: flex;
    justify-content: space-between;
    font-size: 12px;
    color: #4b4451;
    margin-bottom: 6px;
}

.cx-progress-value {
    color: var(--primary);
    font-weight: bold;
}

.cx-progress-bar {
    height: 8px;
    background: #f1ede7;
    border-radius: 999px;
    overflow: hidden;
}

.cx-progress-fill {
    width: 80%;
    height: 100%;
    background: var(--primary);
    border-radius: 999px;
}

/* Tip */
.cx-tip {
    margin-top: 12px !important;
    background: rgba(254, 217, 119, 0.4);
    padding: 14px 16px;
    border-radius: 12px;
    display: flex;
    gap: 10px;
    font-size: 14px;
    color: #4b4451;
    align-items: center;
}

.cx-tip-icon {
    font-size: 18px;
}

.cx-tip p,
.cx-notification p {
    line-height: normal !important;
}

.cx-tip-icon img {
    width: 32px;
    height: 32px;
    display: block;
}

.cx-np {
    padding: 0 !important;
}

.cx-p6-12 {
    padding: 6px 12px !important
}


/* /// how it works step 2 artwork */

/* Topbar variations */
.cx-topbar-between {
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.cx-dots {
    display: flex;
    gap: 6px;
}

.cx-top-title {
    font-size: 12px;
    font-weight: 600;
    color: #4b4451;
}

.cx-top-badge {
    font-size: 11px;
    background: rgba(67, 16, 118, 0.1);
    color: var(--primary);
    font-weight: 700;
    padding: 4px 8px;
    border-radius: 999px;
}

/* Match list */
.cx-p20 {
    padding: 20px;
}

.cx-p16 {
    padding: 16px;
}

.cx-p32 {
    padding: 32px !important;
}

.cx-match {
    position: relative;
    display: flex;
    align-items: start;
    flex-direction: column;
    gap: 14px;
    padding: 16px;
    border-radius: 12px;
    border: 1px solid rgba(124, 116, 130, 0.2);
    background: #faf8f5;
}

.cx-match-highlight {
    border: 2px solid rgba(67, 16, 118, 0.2);
    background: #ffffff;
}

.cx-match-highlight-primary {
    background-color: var(--cx-surface-low);
    border-left: 4px solid var(--primary);
}

.cx-match-highlight-secondary {
    background-color: var(--cx-surface-low);
    border-left: 4px solid var(--secondary);
}

/* Match % badge */
.cx-match-percent {
    position: absolute;
    top: 8px;
    right: 8px;
    background: var(--primary);
    color: #fff;
    font-size: 11px;
    font-weight: 700;
    padding: 10px 16px;
    border-radius: 999px;
}

.cx-match-percent.cx-muted {
    background: #f1ede7;
    color: #4b4451;
}

/* Avatar variations */
.cx-avatar-secondary {
    background: rgba(254, 217, 119, 0.2);
    color: #755b00;
}

.cx-avatar-tertiary {
    background: #44445a;
    color: #fff;
}

/* Info */
.cx-match-info {
    width: 100%;
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    align-items: baseline;

}

.cx-column {
    display: flex;
    flex-direction: column;
    /* gap: 6px; */
}

/* Buttons */
.cx-btn-primary {
    height: 34px;
    background: var(--primary) !important;
    color: #fff !important;
    border: none !important;
    padding: 0 16px !important;
    line-height: normal !important;
    border-radius: 8px !important;
    font-size: 12px !important;
    font-weight: 700;
}

.cx-outline {
    border: 1px solid var(--primary) !important;
    color: var(--primary) !important;
    background: transparent !important;

}

.cx-btn-outline {
    border: 1px solid var(--primary);
    color: var(--primary);
    background: transparent;
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
}

.cx-btn-outline-filled {
    border: 1px solid var(--primary);
    color: white !important;
    background: var(--primary) !important;
    padding: 8px 14px;
    border-radius: 8px;
    font-size: 12px;
    font-weight: 700;
}

.cx-btn-outline:hover {
    background: var(--primary);
    color: #fff;
}

.cx-btn-outline-filled:hover {
    opacity: 0.9;
}

/* Notification */
.cx-notification {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    border-radius: 10px;
    background: rgba(67, 16, 118, 0.05);
    border: 1px solid rgba(67, 16, 118, 0.15);
    font-size: 13px;
    color: #4b4451;
}

.cx-notification img {
    width: 20px;
}

.cx-mt4 {
    margin-top: 12px !important;
}


.key-num {
    max-width: fit-content !important;
}

/* // artwork 3 */

/* Header */
.cx-chat-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 12px 20px;
    background: #f1ede7;
    border-bottom: 1px solid rgba(124, 116, 130, 0.2);

    border-top-left-radius: 16px;
    border-top-right-radius: 16px;
}

.cx-chat-actions {
    display: flex;
    gap: 12px;
}

.cx-chat-actions img {
    width: 20px;
    opacity: 0.6;
    cursor: pointer;
}

.cx-chat-actions img:hover {
    opacity: 1;
}

/* Chat body */
.cx-chat-body {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 14px;
    background: rgba(241, 237, 231, 0.4);
}

/* Messages */
.cx-msg-row {
    display: flex;
    gap: 10px;
}

.cx-msg-right {
    justify-content: flex-end;
}

.cx-msg {
    max-width: 260px;
    padding: 12px 14px;
    border-radius: 16px;
    font-size: 14px;
    line-height: 1.4;
}

.cx-msg-in {
    background: #fff;
    border-top-left-radius: 4px;
}

.cx-msg-out {
    background: var(--primary);
    color: #fff;
    border-top-right-radius: 4px;
}

.cx-time {
    display: block;
    font-size: 11px;
    margin-top: 6px;
    color: #4b4451;
}

.cx-time.light {
    color: rgba(255, 255, 255, 0.6);
}

/* Small avatar */
.cx-avatar-sm {
    width: 28px;
    height: 28px;
    font-size: 11px;
}

/* Meeting card */
.cx-meeting-card {
    background: #fff;
    border: 1px solid rgba(124, 116, 130, 0.3);
    padding: 12px;
    border-radius: 10px;
    max-width: 240px;
}

.cx-meeting-head {
    display: flex;
    align-items: center;
    gap: 6px;
    margin-bottom: 6px;
    font-size: 12px;
    font-weight: bold;
    color: var(--primary);
}

.cx-meeting-head img {
    width: 16px;
}

.cx-meeting-title {
    font-size: 12px;
    font-weight: 600;
}

.cx-meeting-sub {
    font-size: 11px;
    color: #4b4451;
}

/* Input */
.cx-chat-input {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 12px 16px;
    border-top: 1px solid rgba(124, 116, 130, 0.2);
}

.cx-input-placeholder {
    flex: 1;
    background: #f1ede7;
    border-radius: 999px;
    padding: 10px 14px;
    font-size: 13px;
    color: #4b4451;
}

.cx-send-btn {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--primary), #7548a9);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.cx-send-btn img {
    width: 16px;
}


/* timeline */

/* Wrapper */
.cx-timeline {
    display: flex;
    flex-direction: column;
    gap: 28px;
}

/* Item */
.cx-timeline-item {
    display: flex;
    gap: 20px;
    align-items: flex-start;
    position: relative;
    z-index: 100;
}


.cx-timeline-item::after {
    content: '';
    position: absolute;
    left: 20px;
    height: 130%;
    width: 2px;
    z-index: -100;
    background: linear-gradient(to bottom,
            rgba(67, 16, 118, 0.6),
            rgba(67, 16, 118, 0));
}


/* Badge */
.cx-timeline-badge {
    width: 44px;
    height: 44px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    font-size: 12px;
    flex-shrink: 0;
}

/* Badge variants */
.cx-badge-primary {
    background: linear-gradient(135deg, var(--primary), #7548a9);
    color: #fff;
}

.cx-badge-soft {
    background: #dfcfef;
    color: var(--primary);
}

.cx-badge-secondary {
    background: #fed977;
    color: #241a00;
}

/* Card */
.cx-timeline-card {
    background: #ffffff;
    padding: 18px 20px 20px 20px;
    border-radius: 12px;
    border: 1px solid rgba(124, 116, 130, 0.2);
    box-shadow: 0 10px 25px rgba(28, 28, 24, 0.05);
    flex: 1;
}

/* Header */
.cx-timeline-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 0px;
}

.cx-timeline-head h4 {
    font-weight: 700;
    font-size: 15px;
    color: #1c1c18;
    line-height: normal !important;
}

/* Chips */
/* .cx-chip {
    font-size: 11px;
    font-weight: 700;
    padding: 0px 10px;
    border-radius: 999px;
} */

/* .cx-chip {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 999px;
    border: 1px solid rgba(124, 116, 130, 0.3);
    font-size: 12px;
    font-weight: 600;
    background: transparent;
    cursor: pointer;
} */
/* ── Chip Base ── */
.cx-chip {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 8px 16px;
    border-radius: 9999px;
    border: 1px solid #cdc3d2;
    background: transparent !important;
    color: #4b4451 !important;
    font-size: 12px !important;
    line-height: normal !important;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.15s ease;
    user-select: none;
    line-height: 1;
}

.cx-chip-primary {
    background: rgba(67, 16, 118, 0.1) !important;
    color: var(--primary) !important;
}

.cx-chip-secondary {
    background: rgba(254, 217, 119, 0.5) !important;
    color: #755b00 !important;
}

.cx-chip-brown {
    color: #4b4451 !important;
    background-color: #f1ede7 !important;
}

/* Text */
.cx-timeline-card p {
    font-size: 14px;
    color: #4b4451;
    line-height: 1.5;
}


/* Pricing feature comparision table


.cx-compare-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 16px;
    border: 1px solid rgba(124, 116, 130, 0.2);
}

.cx-compare {
    width: 100%;
    min-width: 560px;

    border-collapse: collapse;
    border-radius: 16px;
    overflow: hidden;
    table-layout: fixed;
}

/* Header 
.cx-compare thead tr.cx-compare-head {
    border-bottom: 1px solid rgba(124, 116, 130, 0.2);
    background-color: white;
}

.cx-compare {
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid rgba(124, 116, 130, 0.2);
}

/* Header 
.cx-compare-head {
    display: grid;
    grid-template-columns: 1.5fr repeat(4, 1fr);
    border-bottom: 1px solid rgba(124, 116, 130, 0.2);
    background-color: white;
}

.cx-col-feature {
    padding: 16px;
    font-weight: 600;
    font-size: 14px;
    display: flex;
    align-items: center;
    line-height: normal !important;
    padding-inline: 12px !important;
}

.cx-col-plan {
    padding: 16px;
    text-align: center;
    border-left: 1px solid rgba(124, 116, 130, 0.1);
    font-size: 14px;
    line-height: normal !important;
}

.cx-col-plan.cx-featured {
    background: rgba(67, 16, 118, 0.068) !important;
    border: none !important;
}



.cx-plan-name {
    display: block;
    font-size: 12px;
    text-transform: uppercase;
    color: #4b4451;
    line-height: normal !important;
}

.cx-featured .cx-plan-name {
    color: var(--primary) !important;
    font-weight: 700;
}

.cx-plan-price {
    font-weight: bold;
    font-size: 16px;
    line-height: normal !important;
}



/* Category 
.cx-category {
    background: #f1ede7;
    padding: 10px 16px;
    font-size: 12px;
    font-weight: bold;
    color: var(--primary);
}

/* Rows 
.cx-row {
    display: grid;
    grid-template-columns: 1.5fr repeat(4, 1fr);
    border-top: 1px solid rgba(124, 116, 130, 0.1);
    background-color: white;
}

.cx-row:hover {
    background: rgba(67, 16, 118, 0.05);
}

.cx-check {
    color: var(--primary);
    font-weight: bold;
}

.cx-cross {
    color: #aaa;
}

.cx-featured .cx-plan-price,
.cx-featured.cx-col-plan,
.cx-featured .cx-check {
    color: var(--primary) !important;
    font-weight: 700;
} */

/* ============================================
   PRICING COMPARISON TABLE — Full Rewrite
   Works: Desktop / Tablet (1024px) / Mobile (640px)
   ============================================ */

/* Scroll wrapper — handles overflow on all screens */
.cx-compare-wrapper {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    border-radius: 16px;
    border: 1px solid rgba(124, 116, 130, 0.2);
}

/* Table base */
.cx-compare {
    width: 100%;
    min-width: 600px;
    border-collapse: collapse;
    border: none;
    table-layout: fixed;
    background-color: white;
    margin: 0 !important;
}

/* ── Column widths ── */
.cx-compare .cx-col-feature {
    width: 20%;
}

.cx-compare .cx-col-plan {
    width: 18%;
}

/* ── Header row ── */
.cx-compare thead tr {
    /* border-bottom: 2px solid rgba(124, 116, 130, 0.2); */
    background-color: white;
}

.cx-compare thead .cx-col-feature,
.cx-compare thead .cx-col-plan {
    padding: 18px 12px;
    vertical-align: middle;
}

.cx-compare thead .cx-col-feature {
    font-weight: 600;
    font-size: 14px;
    text-align: left;
    color: #4b4451;
}

.cx-compare thead .cx-col-plan {
    text-align: center;
    border-left: 1px solid rgba(124, 116, 130, 0.1);
}

/* Plan name + price in header */
.cx-plan-name {
    display: block;
    font-size: 11px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: #4b4451;
    line-height: 1.2;
}

.cx-plan-price {
    display: block;
    font-size: 17px;
    font-weight: 700;
    color: #1a1a1a;
    margin-top: 4px;
    line-height: 1.2;
}

/* ── Featured column ── */
.cx-col-plan.cx-featured {
    background-color: rgba(67, 16, 118, 0.06);
    border-left: none !important;
    border-right: none !important;
    border-bottom: 1px solid #7c74821a !important;
    border-top: 1px solid #7c74821a !important;
}

.cx-featured .cx-plan-name {
    color: var(--primary, var(--primary));
    font-weight: 700;
}

.cx-featured .cx-plan-price {
    color: var(--primary, var(--primary));
}

/* ── Category heading rows ── */
.cx-category-row td {
    background-color: #f1ede7;
    padding: 9px 16px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    color: var(--primary);
    border-top: 1px solid rgba(124, 116, 130, 0.15);
}

/* ── Feature rows ── */
.cx-row td {
    padding: 13px 12px;
    border-top: 1px solid rgba(124, 116, 130, 0.1);
    vertical-align: middle;
    background-color: white;
    font-size: 14px;
    line-height: 1.4;
}

.cx-row:hover td {
    background-color: rgba(67, 16, 118, 0.04);
}

.cx-row td.cx-col-feature {
    font-size: 13px;
    font-weight: 500;
    color: #333;
    text-align: left;
    padding-left: 14px;
}

.cx-row td.cx-col-plan {
    text-align: center;
    border-left: 1px solid rgba(124, 116, 130, 0.08);
    color: #4b4451;
    font-size: 13px;
}

.cx-row td.cx-col-plan.cx-featured {
    background-color: rgba(67, 16, 118, 0.05);
    border-left: none;
    border-right: none;
    border-bottom: 1px solid #7c74821a !important;
    border-top: 1px solid #7c74821a !important;
    font-weight: 700;
    color: var(--primary) !important;
}

/* ── Check / cross icons ── */
.cx-check {
    color: var(--primary, var(--primary));
    font-weight: 700;
    font-size: 15px;
}

.cx-cross {
    color: #bbb;
    font-size: 15px;
}

/* Featured column — check mark + text color */
.cx-row td.cx-featured .cx-check {
    color: var(--primary, var(--primary));
}


/* //////////////////////////////////// */
/* PM PRO Login / Register */
/* //////////////////////////////////// */

.entry-header {
    display: none !important;
}
body.single-post .entry-header {
    display : block !important;
}
body.single-post h1:not(.ekit-template-content-footer h1){
	font-size:40px !important;
	line-height: normal;
    margin-top: 40px !important;
    margin-bottom: 24px !important;
}

body.single-post h2:not(.ekit-template-content-footer h2){
	font-size:36px !important;
	line-height: normal;
    margin-top: 40px !important;
    margin-bottom: 24px !important;
}

body.single-post h3:not(.ekit-template-content-footer h3){
	font-size:30px !important;
	line-height: normal;
    margin-top: 40px !important;
    margin-bottom: 24px !important;
}

body.single-post h4:not(.ekit-template-content-footer h4){
	font-size:24px !important;
	line-height: normal;
    margin-top: 40px !important;
    margin-bottom: 24px !important;
}

body.single-post h5:not(.ekit-template-content-footer h5){
	font-size:16px !important;
	line-height: normal;
    margin-top: 40px !important;
    margin-bottom: 24px !important;
}

body.single-post h6:not(.ekit-template-content-footer h6){
	font-size:12px !important;
	line-height: normal;
    margin-top: 40px !important;
    margin-bottom: 24px !important;
}

.hentry blockquote.wp-block-quote>p{
	line-height:1;
}

body.single-post a:not(.ekit-template-content-footer a){
color: var(--primary) !important;
/* 	font-weight : bold !important; */
	font-size:inherit !important;
	line-height:normal !important;
}
.post-meta-wrapper .cat-links, .post-meta-wrapper .tag-links{
	align-items:center !important;
}

body.single-post .entry-content{
	margin-bottom:32px !important;
}

body.single-post .single-attachment .post-related-posts>.post-grid.slick-initialized, .single-post .post-related-posts>.post-grid.slick-initialized{
	margin-top: 32px !important;
    padding-inline: 16px !important;
}

body.single-post .single-attachment .post-related-posts>.post-grid.slick-initialized, .single-post .post-related-posts>.post-grid.slick-initialized .entry-title{
	font-size:24px !important;
}
body.single-post .single-attachment .post-related-posts>.post-grid.slick-initialized, .single-post .post-related-posts>.post-grid.slick-initialized .entry-content{
	font-size:18px !important;
}


/* ── PAGE BODY (only when PMPro login page) ──────────────────────── */
body.page-template-default .pmpro,
body.pmpro_login_page .pmpro,
.pmpro {
    font-family: var(--cx-font-body);
    color: var(--cx-on-surface);
    background: var(--cx-surface);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* ── OUTER SECTION ───────────────────────────────────────────────── */
#pmpro_login {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    min-height: 60vh;
    padding: 130px 1.5rem 0;
    background: var(--cx-surface);
}

/* ── CARD WRAPPER ────────────────────────────────────────────────── */
.pmpro_login_wrap.pmpro_card {
    width: 100%;
    max-width: 440px;
    background: var(--cx-surface-white);
    border: 1px solid var(--cx-outline-variant);
    border-radius: var(--cx-radius-2xl);
    box-shadow: var(--cx-shadow-editorial);
    overflow: hidden;
    padding: 0;
}

/* ── CARD HEADER ACCENT (top purple bar) ────────────────────────── */
.pmpro_login_wrap.pmpro_card::before {
    content: '';
    display: block;
    height: 4px;
    background: linear-gradient(90deg, #431076 0%, #5b2d8e 100%);
    border-radius: var(--cx-radius-2xl) var(--cx-radius-2xl) 0 0;
}

/* ── CARD CONTENT ────────────────────────────────────────────────── */
.pmpro_card_content {
    padding: 2.25rem 2.25rem 1.5rem;
}

/* Inject a heading above the form */
.pmpro_card_content::before {
    content: 'Welcome Back';
    display: block;
    font-family: var(--cx-font-headline);
    font-size: 1.625rem;
    font-weight: 800;
    color: var(--cx-primary);
    letter-spacing: -0.02em;
    margin-bottom: 0.375rem;
}

.pmpro_card_content::after {
    content: 'Sign in to your ConnecXion.io account';
    display: block;
    font-family: var(--cx-font-body);
    font-size: 0.875rem;
    color: var(--cx-on-surface-variant);
    margin-top: 12px;
    margin-bottom: 1.75rem;
    line-height: 1.5;
}

/* ── FORM ────────────────────────────────────────────────────────── */
#loginform {
    display: flex;
    flex-direction: column;
    gap: 8px;
    margin-top: 24px;
}

/* ── PARAGRAPH WRAPPERS ──────────────────────────────────────────── */
#loginform p {
    margin: 0 0 1.125rem 0;
    padding: 0;
    gap: 0 !important;
}

#loginform p.login-submit {
    margin-bottom: 0;
    margin-top: 0.5rem;
}

/* ── LABELS ──────────────────────────────────────────────────────── */
#loginform label {
    display: block;
    font-family: var(--cx-font-body);
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--cx-on-surface);
    margin-bottom: 0.5rem;
    letter-spacing: 0.01em;
}

/* ── INPUT FIELDS ────────────────────────────────────────────────── */
#loginform input[type="text"],
#loginform input[type="email"],
#loginform input[type="password"] {
    display: block;
    width: 100%;
    box-sizing: border-box;
    background: var(--cx-surface-low);
    border: 1.5px solid var(--cx-outline-variant);
    border-radius: var(--cx-radius-md);
    padding: 0.8125rem 1rem;
    font-family: var(--cx-font-body);
    font-size: 0.9375rem;
    font-weight: 400;
    color: var(--cx-on-surface);
    line-height: 1.5;
    outline: none;
    transition: border-color var(--cx-transition), box-shadow var(--cx-transition), background var(--cx-transition);
    -webkit-appearance: none;
    appearance: none;
}

#loginform input[type="text"]::placeholder,
#loginform input[type="email"]::placeholder,
#loginform input[type="password"]::placeholder {
    color: var(--cx-outline);
    opacity: 1;
}

#loginform input[type="text"]:focus,
#loginform input[type="email"]:focus,
#loginform input[type="password"]:focus {
    border-color: var(--cx-primary-container);
    background: var(--cx-surface-white);
    box-shadow: 0 0 0 3px rgba(91, 45, 142, 0.12);
}

#loginform input[type="text"]:hover:not(:focus),
#loginform input[type="email"]:hover:not(:focus),
#loginform input[type="password"]:hover:not(:focus) {
    border-color: var(--cx-outline);
}

/* ── PASSWORD WRAPPER — make relative for the toggle button ─────── */
#loginform .login-password {
    position: relative;
}

/* ── PASSWORD TOGGLE WRAPPER ─────────────────────────────────────── */
.pmpro_form_field-password-toggle {
    position: absolute;
    right: 0;
    bottom: 0;
    height: 100%;
    display: flex;
    align-items: flex-end;
    padding-bottom: 0.2rem;
}

/* Move toggle inside the input visually */
.login-password .pmpro_form_field-password-toggle {
    bottom: 0;
    right: 0.125rem;
    padding-bottom: 0;
    height: auto;
    top: 5px;
    /* transform: translateY(50%); */
}

/* ── PASSWORD TOGGLE BUTTON ──────────────────────────────────────── */
.pmpro_btn-plain {
    background: transparent;
    border: none;
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    padding: 0.5rem 0.875rem;
    font-family: var(--cx-font-body);
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--cx-on-surface-variant);
    border-radius: var(--cx-radius-sm);
    transition: color var(--cx-transition), background var(--cx-transition);
    white-space: nowrap;
}

.pmpro_btn-plain:hover {
    color: var(--cx-primary);
    background: var(--cx-primary-fixed);
}

.pmpro_btn-plain .pmpro_form_field-password-toggle-state {
    font-size: 0.75rem;
}

/* pmpro accent colour used in the SVG stroke */
.pmpro_icon svg {
    display: block;
    flex-shrink: 0;
}

/* ── REMEMBER ME ─────────────────────────────────────────────────── */
#loginform .login-remember {
    margin-bottom: 1.25rem;
}

#loginform .login-remember label {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--cx-on-surface-variant);
    cursor: pointer;
    margin-bottom: 0;
}

#loginform #rememberme {
    width: 1rem;
    height: 1rem;
    border: 1.5px solid var(--cx-outline-variant);
    border-radius: 0.25rem;
    accent-color: var(--cx-primary);
    cursor: pointer;
    flex-shrink: 0;
    transition: border-color var(--cx-transition);
}

#loginform #rememberme:focus {
    outline: 2px solid rgba(91, 45, 142, 0.3);
    outline-offset: 1px;
}

/* ── SUBMIT BUTTON ───────────────────────────────────────────────── */
#loginform #wp-submit,
#loginform input[type="submit"],
#lostpasswordform input[type="submit"] {
    display: block;
    width: 100%;
    box-sizing: border-box;
    background: linear-gradient(135deg, #431076 0%, #5b2d8e 100%);
    color: var(--cx-on-primary);
    border: none;
    border-radius: var(--cx-radius-md);
    padding: 24px 1.5rem;
    font-family: var(--cx-font-body);
    font-size: 0.9375rem;
    font-weight: 700;
    letter-spacing: 0.01em;
    cursor: pointer;
    box-shadow: var(--cx-shadow-btn);
    transition: opacity var(--cx-transition), transform var(--cx-transition), box-shadow var(--cx-transition);
    -webkit-appearance: none;
    appearance: none;
    line-height: 0;
}

#loginform #wp-submit:hover,
#loginform input[type="submit"]:hover {
    opacity: 0.92;
    box-shadow: 0 6px 20px rgba(67, 16, 118, 0.35);
}

#loginform #wp-submit:active,
#loginform input[type="submit"]:active {
    transform: scale(0.985);
    opacity: 1;
}

#loginform #wp-submit:focus-visible,
#loginform input[type="submit"]:focus-visible {
    outline: 2px solid var(--cx-primary-fixed-dim);
    outline-offset: 2px;
}

/* ── CARD ACTIONS (bottom bar: Join Now | Lost Password?) ────────── */
.pmpro_card_actions {
    background: var(--cx-surface-low);
    border-top: 1px solid var(--cx-outline-variant);
    padding: 1rem 2.25rem;
}

.pmpro_actions_nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0.25rem;
    font-family: var(--cx-font-body);
    font-size: 0.875rem;
    color: var(--cx-on-surface-variant);
    flex-wrap: wrap;
}

/* The | separator */
.pmpro_actions_nav {
    /* the text node " | " between the links is kept as-is */
}

.pmpro_actions_nav a {
    font-weight: 700;
    font-size: 16px;
    font-family: var(--cx-font-body) !important;
    color: var(--cx-primary-container);
    text-decoration: none;
    padding: 0.125rem 0.25rem;
    border-radius: var(--cx-radius-sm);
    transition: color var(--cx-transition), background var(--cx-transition);
}

.pmpro_actions_nav a:hover {
    color: var(--cx-primary);
    background: var(--cx-primary-fixed);
    text-decoration: none;
}

/* ── ERROR / NOTICE MESSAGES (PMPro adds these on failed login) ──── */
.pmpro .pmpro_message,
.pmpro .pmpro_error,
#login_error,
.login .message {
    font-family: var(--cx-font-body);
    font-size: 0.875rem;
    line-height: 1.5;
    border-radius: var(--cx-radius-md);
    padding: 0.875rem 1rem;
    margin-bottom: 1.25rem;
    border: none;
}

.pmpro .pmpro_error,
#login_error {
    background: var(--cx-error-container);
    color: var(--cx-error);
    border-left: 3px solid var(--cx-error);
}

.pmpro .pmpro_message {
    background: var(--cx-primary-fixed);
    color: var(--cx-primary);
    border-left: 3px solid var(--cx-primary-container);
}

/* ── FORGOT PASSWORD FORM (reset_pass action) ────────────────────── */
#lostpasswordform label {
    display: block;
    font-family: var(--cx-font-body);
    font-size: 0.8125rem;
    font-weight: 700;
    color: var(--cx-on-surface);
    margin-bottom: 0.5rem;
}

#lostpasswordform input[type="text"],
#lostpasswordform input[type="email"] {
    display: block;
    width: 100%;
    box-sizing: border-box;
    background: var(--cx-surface-low);
    border: 1.5px solid var(--cx-outline-variant);
    border-radius: var(--cx-radius-md);
    padding: 0.8125rem 1rem;
    font-family: var(--cx-font-body);
    font-size: 0.9375rem;
    color: var(--cx-on-surface);
    outline: none;
    transition: border-color var(--cx-transition), box-shadow var(--cx-transition);
}

#lostpasswordform input[type="text"]:focus,
#lostpasswordform input[type="email"]:focus {
    border-color: var(--cx-primary-container);
    box-shadow: 0 0 0 3px rgba(91, 45, 142, 0.12);
}



#lostpasswordform input[type="submit"]:hover {
    opacity: 0.92;
}

#lostpasswordform input[type="submit"]:active {
    transform: scale(0.985);
}

/* ── ACCESSIBILITY: focus-visible ring across all interactive ────── */
.pmpro a:focus-visible,
.pmpro button:focus-visible,
.pmpro input:focus-visible {
    outline: 2px solid var(--cx-primary-container);
    outline-offset: 2px;
}


/* ///////////////////// about us mission */

.cx-eco {
    padding: 0 !important;
}

/* Header */
.cx-eco-header {
    background: linear-gradient(135deg, #431076, #7548a9);
    padding: 32px;
    color: #fff;
    border-top-left-radius: 14px;
    border-top-right-radius: 14px;
}

.cx-eco-icon img {
    width: 32px;
    opacity: 0.8;
    margin-bottom: 12px;
}


.cx-eco-title {
    font-size: 24px !important;
    font-weight: 700;
    margin-bottom: 12px !important;
    color: white !important;
    line-height: normal !important;
}

.cx-eco-desc {
    font-size: 14px;
    opacity: 0.85 !important;
    line-height: normal !important;
}

/* Content */
.cx-eco-content {
    padding: 24px;
    display: flex;
    flex-direction: column;
    gap: 22px;

}

/* Items */
.cx-eco-item {
    display: flex;
    gap: 12px;
    padding: 14px;
    background: #f1ede7;
    border-radius: 10px;
    align-items: center;
}

.cx-eco-check {
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: linear-gradient(135deg, #431076, #7548a9);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: bold;
    flex-shrink: 0;
}

.cx-eco-heading {
    font-weight: 700;
    font-size: 14px;
    line-height: normal !important;
}

.cx-eco-sub {
    font-size: 12px;
    color: #4b4451;
    line-height: normal !important;
}

/* Quote */
.cx-eco-quote {
    margin-top: 10px;
    padding-top: 22px;
    border-top: 1px solid rgba(124, 116, 130, 0.2);
}

.cx-eco-quote-text {
    font-size: 12px;
    font-style: italic;
    color: #4b4451;
    line-height: normal !important;
}

.cx-eco-author {
    font-size: 12px;
    font-weight: 700;
    color: #431076;
    margin-top: 6px;
}

/* //////////////////// */
/* //////////////////// */
/* match making step - 1 */
/* //////////////////// */

/* Title */
.cx-diagram-title {
    text-align: center;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: #4b4451;
    margin-bottom: 24px;
}

/* Layout */
.cx-diagram-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-top: 22px;
}

/* Profile box */
.cx-profile-box {
    max-width: 360px;
    width: 100%;
    background: rgba(67, 16, 118, 0.05);
    border: 2px solid rgba(67, 16, 118, 0.2);
    border-radius: 12px;
    padding: 16px;
}

.cx-profile-head {
    display: flex;
    gap: 10px;
    margin-bottom: 12px;
    align-items: center;
}

.cx-profile-title {
    font-weight: 700;
    font-size: 14px;
    line-height: normal !important;
}

.cx-profile-sub {
    font-size: 11px;
    color: #4b4451;
    line-height: normal !important;
}

/* Grid */
.cx-profile-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 6px;
}

.cx-pill {
    background: #fff;
    border: 1px solid rgba(124, 116, 130, 0.3);
    padding: 6px 8px;
    font-size: 12px;
    border-radius: 6px;
    line-height: normal !important;
}

.cx-span-2 {
    grid-column: span 2;
}

/* Engine */
.cx-engine {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin: 10px 0;
}

.cx-line {
    width: 1px;
    height: 32px;
    background: rgba(67, 16, 118, 0.4);
    margin-block: 8px;
}

.cx-engine-pill {
    display: flex;
    align-items: center;
    gap: 6px;
    background: linear-gradient(135deg, #431076, #7548a9);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    padding: 2px 18px;
    border-radius: 999px;
}

.cx-engine-pill img {
    width: 14px;
}

/* Results */
.cx-results {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 16px;
    max-width: 360px;
    width: 100%;
}

.cx-result {
    background: #fff;
    border: 1px solid rgba(124, 116, 130, 0.3);
    border-radius: 10px;
    padding: 20px 10px;
    text-align: center;
    display: flex;
    align-items: center;
    flex-direction: column;
}

.cx-result-icon {
    width: 32px;
    height: 32px;
    background: rgba(67, 16, 118, 0.1);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 6px;
}

.cx-result-icon img {
    width: 16px;
}

.cx-result-title {
    font-size: 12px;
    font-weight: 700;
    line-height: normal !important;
}

.cx-result-sub {
    font-size: 11px;
    color: #4b4451;
    line-height: normal !important;
}


.cx-highlight-bg {
    background: rgba(67, 16, 118, 0.2);
}

.cx-primary {
    color: var(--primary);
}

.mt-24 {
    margin-top: 24px !important;
}

/* //////////////////// */
/* //////////////////// */
/* 4 type of match */

/* Members card */

.elementor-shortcode:has(.cx-match-card),
.cx-match-card {
    height: 100%;
}

.cx-match-card .cx-card {
    display: flex;
    height: 100%;
    justify-content: flex-start;
}

.cx-members,
.cx-vendors {
    border-top: 4px solid var(--primary);
    align-items: start;
}

.cx-members-head {
    display: flex;
    gap: 16px;
    margin-bottom: 20px;
    align-items: flex-start;

}

.cx-members-icon img {
    width: 56px;
}

.cx-members-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    color: #755b00;
    letter-spacing: 0.08em;
    line-height: normal;
}

.cx-members-title {
    font-size: 24px;
    font-weight: 700;
    line-height: normal;
}

.cx-members-info {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}

.cx-members-sub {
    font-size: 13px;
    color: #4b4451;
    line-height: normal;
    margin-top: 8px !important;
}

.cx-members-desc {
    font-size: 14px;
    color: #4b4451;
    opacity: 0.9;
    margin-block: 4px !important;
    line-height: normal;
}

.cx-members-small-title {
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 10px;
    line-height: normal;
    letter-spacing: 1px;
}

.cx-members-tags-wrap {
    margin-bottom: 20px;
    display: flex;
    flex-direction: column;
    gap: 10px;
    margin-top: 12px !important;
}

.cx-members-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cx-member-row {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #f1ede7;
    padding: 10px 12px;
    border-radius: 10px;
}

.cx-member-info {
    flex: 1;
}

.cx-member-name {
    font-size: 14px;
    font-weight: 700;
    line-height: normal;
}

.cx-member-meta {
    font-size: 11px;
    text-transform: uppercase;
    color: #755b00;
    font-weight: 700;
    line-height: normal;
}

.cx-member-badge {
    font-size: 11px;
    font-weight: 700;
    background: rgba(67, 16, 118, 0.1);
    color: #431076;
    padding: 4px 8px;
    border-radius: 999px;
}

/* //////////////////// */
/* //////////////////// */

/* //////////////////// */

/* opportunities */

/* Top bar override */

.cx-opportunities {
    border-top: 4px solid var(--secondary);
    max-height: fit-content;
}

.cx-op-bar {
    background: linear-gradient(90deg, #755b00, #e6c364);
}

/* Icon background */
.cx-op-icon {
    background: linear-gradient(135deg, #755b00, #e6c364);
    padding: 10px;
    border-radius: 12px;
}

.cx-op-icon img {
    width: 20px;
    filter: brightness(0) invert(1);
}

/* Tag variation (yellow tone) */
.cx-op-tags .cx-tag {
    background: rgba(254, 217, 119, 0.4);
    color: #755b00;
    border: none;
}

/* Opportunity list */
.cx-op-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cx-op-item {
    background: #f1ede7;
    padding: 12px 14px;
    border-radius: 10px;
    border-left: 4px solid #755b00;
}

.cx-op-title {
    font-size: 14px;
    font-weight: 700;
    line-height: normal;
}

.cx-op-meta {
    font-size: 11px;
    color: #4b4451;
    line-height: normal;
}

/* //////////////////// */
/* //////////////////// */

/* vendors */

/* Trust box */
.cx-vendor-trust {
    display: flex;
    align-items: center;
    gap: 10px;
    background: rgba(67, 16, 118, 0.05);
    border: 1px solid rgba(67, 16, 118, 0.15);
    padding: 12px 14px;
    border-radius: 10px;
    font-size: 12px;
    color: #4b4451;
}

.cx-vendor-trust-icon img {
    width: 32px;
}

/* strong emphasis */
.cx-vendor-trust p {
    color: #1c1c18;
    line-height: normal !important;
}

/* //////////////////// */
/* //////////////////// */
/* events */
/* //////////////////// */

.cx-events {
    border-top: 4px solid #2e2e43;
}

/* Top bar */
.cx-ev-bar {
    background: linear-gradient(90deg, #2e2e43, #c6c4df);
}

/* Icon */
.cx-ev-icon {
    background: linear-gradient(135deg, #2e2e43, #44445a);
    padding: 10px;
    border-radius: 12px;
}

.cx-ev-icon img {
    width: 20px;
    filter: brightness(0) invert(1);
}

/* Tags */
.cx-ev-tags .cx-tag {
    background: rgba(68, 68, 90, 0.2);
    color: #2e2e43;
    border: none;
}

/* Event item */
.cx-ev-item {
    display: flex;
    align-items: center;
    gap: 14px;
    background: #f1ede7;
    padding: 12px 14px;
    border-radius: 10px;
}

/* Date block */
.cx-ev-date {
    background: linear-gradient(135deg, #431076, #5b2d8e);
    color: #fff;
    padding: 6px 10px;
    border-radius: 8px;
    text-align: center;
    min-width: 48px;
}

.cx-ev-day {
    font-size: 16px;
    font-weight: 700;
    line-height: normal;
}

.cx-ev-month {
    font-size: 10px;
    opacity: 0.8;
    line-height: normal;
}

/* Info */
.cx-ev-info {
    flex: 1;
}

.cx-ev-title {
    font-size: 14px;
    font-weight: 700;
    line-height: normal;
}

.cx-ev-meta {
    font-size: 11px;
    color: #4b4451;
    line-height: normal;
}

/* Badge */
.cx-ev-badge {
    font-size: 11px;
    font-weight: 700;
    background: rgba(67, 16, 118, 0.1);
    color: #431076;
    padding: 4px 8px;
    border-radius: 999px;
}

/*  */
/* vendors */

/* Filters */
.cx-demo-title {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    margin-bottom: 12px;
}

.cx-demo-filters {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 20px;
}



.cx-chip img {
    width: 14px;
}

.cx-chip.active {
    background: var(--primary);
    color: #fff;
    border-color: var(--primary);
}

/* Results */
.cx-demo-results {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

.cx-result {
    display: flex;
    align-items: center;
    gap: 12px;
    background: #f1ede7;
    padding: 12px 14px;
    border-radius: 10px;
}

.cx-result-info {
    flex: 1;
}

.cx-result-head {
    display: flex;
    align-items: center;
    gap: 6px;
}

.cx-result-title {
    font-size: 14px;
    font-weight: 700;
}

.cx-result-meta {
    font-size: 11px;
    color: #4b4451;
}

.cx-result-score {
    font-weight: 700;
    color: var(--primary);
}

.cx-result-tag {
    font-size: 11px;
    font-weight: 700;
    color: #755b00;
}

.cx-result-icon img {
    width: 18px;
}

.cx-verified {
    width: 18px;
}

/* Note */
.cx-demo-note {
    font-size: 11px;
    text-align: center;
    margin-top: 16px;
    color: #4b4451;
    font-style: italic;
    line-height: normal;
}

/* ///////////////////////// */
/* ///////////////////////// */

/* how search works - match making */

.cx-search-demo {
    background: #ffffff;
    border-radius: 16px;
    box-shadow: 0 20px 40px rgba(28, 28, 24, 0.06);
    border: 1px solid rgba(205, 195, 210, 0.2);
    padding: 24px;
}

/* ── Filter Label ── */
.cx-filter-label {
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: #4b4451;
    margin: 0 0 14px 0;
}

/* ── Chips Row ── */
.cx-chips-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-bottom: 24px;
}



.cx-chip:hover {
    border-color: #431076;
    color: #431076;
}

.cx-chip-active,
.cx-chip.cx-chip-active {
    background: #431076 !important;
    border-color: #431076 !important;
    color: #ffffff !important;
}

/* ── Chip Icon ── */
.cx-chip-icon {
    display: inline-flex;
    align-items: center;
}

.cx-chip-icon svg {
    width: 14px;
    height: 14px;
}

/* ── Results List ── */
.cx-results-list {
    display: flex;
    flex-direction: column;
    gap: 10px;
}

/* ── Single Result Item ── */
.cx-result-item {
    display: flex;
    align-items: center;
    gap: 14px;
    background: #f1ede7;
    border-radius: 12px;
    padding: 12px 16px;
    transition: opacity 0.3s ease, transform 0.3s ease;
}

.cx-result-item.cx-hidden {
    display: none;
}

.cx-result-item.cx-fading {
    opacity: 0;
    transform: scale(0.97);
}

/* ── Avatars ── */
.cx-result-avatar {
    width: 40px;
    height: 40px;
    border-radius: 9999px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 11px;
    font-weight: 700;
    flex-shrink: 0;
}

.cx-result-avatar svg {
    width: 16px;
    height: 16px;
}

.cx-avatar-primary {
    background: linear-gradient(135deg, #431076 0%, #5b2d8e 100%);
    color: #ffffff;
}

.cx-avatar-primary svg {
    stroke: #ffffff;
}

.cx-avatar-secondary {
    background: rgba(117, 91, 0, 0.2);
    color: #755b00;
}

.cx-avatar-secondary-light {
    background: rgba(117, 91, 0, 0.15);
    color: #755b00;
}

.cx-avatar-secondary-light svg {
    stroke: #755b00;
}

.cx-avatar-gold {
    background: linear-gradient(135deg, #755b00 0%, #e6c364 100%);
    color: #ffffff;
}

.cx-avatar-gold svg {
    stroke: #ffffff;
}

/* ── Date Badge (Events) ── */
.cx-result-date {
    background: linear-gradient(135deg, #431076 0%, #5b2d8e 100%);
    border-radius: 8px;
    padding: 8px 12px;
    text-align: center;
    flex-shrink: 0;
}

.cx-date-day {
    color: #ffffff;
    font-weight: 700;
    font-size: 16px;
    line-height: 1;
    margin: 0;
}

.cx-date-month {
    color: rgba(255, 255, 255, 0.75);
    font-size: 11px;
    margin: 0;
    line-height: normal !important;
}

/* ── Result Body ── */
.cx-result-body {
    flex: 1;
    min-width: 0;
}

.cx-result-name-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 3px;
}

.cx-result-name {
    font-size: 14px;
    font-weight: 700;
    color: #1c1c18;
    margin: 0;
    white-space: nowrap;
    line-height: normal !important;
    overflow: hidden;
    text-overflow: ellipsis;
}

.cx-result-meta {
    font-size: 12px;
    color: #4b4451;
    margin: 0;
    line-height: normal !important;
}

/* ── Badges ── */
.cx-result-badge {
    font-size: 11px;
    font-weight: 700;
    padding: 6px 8px;
    line-height: normal !important;
    border-radius: 9999px;
    white-space: nowrap;
    flex-shrink: 0;
}

.cx-badge-member {
    background: rgba(67, 16, 118, 0.1);
    color: #431076;
}

.cx-badge-opportunity {
    background: rgba(254, 217, 119, 0.6);
    color: #755b00;
}

.cx-badge-vendor {
    background: #ebe8e2;
    color: #4b4451;
}

.cx-badge-event {
    background: rgba(68, 68, 90, 0.4);
    color: #2e2e43;
}

/* ── Score / Verified / Seats ── */
.cx-result-score {
    font-size: 14px;
    font-weight: 700;
    color: #431076;
    flex-shrink: 0;
}

.cx-score-new {
    color: #755b00;
}

.cx-result-seats {
    font-size: 12px;
    font-weight: 700;
    color: #4b4451;
    flex-shrink: 0;
}

.cx-result-verified {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
    background: rgba(67, 16, 118, 0.1);
    border-radius: 9999px;
    flex-shrink: 0;
}

.cx-result-verified svg {
    width: 12px;
    height: 12px;
    stroke: #431076;
}

/* ── Demo Note ── */
.cx-demo-note {
    font-size: 12px;
    color: #4b4451;
    text-align: center;
    font-style: italic;
    margin: 20px 0 0 0 !important;
}

/* ///////////////////////// */
/* ///////////////////////// */
/* ///////////////////////// */

/*  */


/* profile setup - match making */

.cx-ps-body {
    display: flex;
    flex-direction: column;
    gap: 18px;
    margin-top: 24px;
}

/* Helpers */
.cx-flex-between {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.cx-icon-sm {
    width: 16px;
    height: 16px;
}

/* Progress text */
.cx-progress-text {
    text-align: center;
    font-size: 12px;
    color: #4b4451;
    margin-top: 12px !important;
    line-height: normal;
}

/* Width helper */
.cx-w-66 {
    width: 66%;
}



/* critearea match making - 2 */

/* Title center helper */
.cx-center {
    text-align: center;
}

/* Margin helper */
.cx-mb-6 {
    margin-bottom: 24px;
}

/* List */
.cx-mc-list {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* Item */
.cx-mc-item {
    display: flex;
    flex-direction: column;
    gap: 6px;
    margin-top: 12px;
}

/* Head */
.cx-mc-head {
    font-size: 12px;
}

/* Title */
.cx-mc-title {
    font-weight: 600;
    color: #1c1c18;
    line-height: normal;
}

/* Value */
.cx-mc-value {
    font-weight: 700;
    line-height: normal;
}

.cx-mt-20 {
    margin-top: 20px !important;
}


/* members page */
/*  */
div#buddypress,
.bb-grid-cell:not(.no-gutter),
.bb-grid>:not(.no-gutter),
body.pmpro-variation_1.bp-nouveau.wp-singular.tribe_events-template-default.single.single-tribe_events.postid-515.logged-in.admin-bar.wp-custom-logo.wp-theme-buddyboss-theme-disable.wp-child-theme-buddyboss-theme-disable-child.theme-buddyboss-theme-disable.pmpro-body-has-access.woocommerce-js.tribe-events-page-template.tribe-js.tribe-filter-live.ehf-template-buddyboss-theme-disable.ehf-stylesheet-buddyboss-theme-disable-child.qodef-qi--no-touch.qi-addons-for-elementor-1\.9\.5.jkit-color-scheme.buddyboss-theme.bb-template-v2.buddypanel-logo-off.default-fi.header-style-4.menu-style-standard.sticky-header.bb-tribe-events-views-v2.buddy-boss-child.bp-search.events-single.tribe-events-style-full.tribe-events-style-theme.elementor-default.elementor-kit-2614.dialog-body.dialog-buttons-body.dialog-container.dialog-buttons-container.js.customize-support.bb-page-loaded.e--ua-blink.e--ua-chrome.e--ua-mac.e--ua-webkit,
.tribe-events-view {
    background-color: var(--cx-surface) !important;
    background: var(--cx-surface) !important;
}

div#buddypress {
    max-width: 1260px !important;
    margin: 0 auto !important;
    padding-top: 100px !important;
}

.members-directory-wrapper,
.site-main,
#tribe-events-pg-template,
.tribe-events-pg-template {
    max-width: 1260px !important;
    margin: 0 auto !important;
    padding-top: 130px !important;
    padding-bottom: 60px !important;
}

.tribe-events-single-event-title {
    font-size: 72px !important;
    line-height: normal !important;
}

.tribe-events-visuallyhidden {
    font-size: 24px !important;
}




/* product tour page -- try it section (profile) */

/* Toggle */

.cx-try-wrap {
    max-width: 720px;
    margin: 0 auto;
    overflow: hidden;
}

.cx-hidden {
    display: none !important;
}

.cx-try-toggle {
    display: flex;
    border-bottom: 1px solid rgba(124, 116, 130, 0.2);
}

.cx-try-btn {
    flex: 1;
    padding: 14px;
    font-size: 13px;
    font-weight: 600;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background: transparent !important;
    border: none;
    cursor: pointer;
    color: #4b4451 !important;
}

.cx-try-btn.active {
    background: linear-gradient(135deg, #431076, #5b2d8e) !important;
    color: #fff !important;
    border-radius: 12px;
}

/* Body spacing */
.cx-try-body {
    display: flex;
    flex-direction: column;
    gap: 18px;
}

/* textarea style */
.cx-textarea {
    min-height: 80px;
    color: #6b6570;
}

/* focus input */
.cx-input-focus {
    border: 1px solid rgba(91, 45, 142, 0.4);
    box-shadow: 0 0 0 3px rgba(91, 45, 142, 0.1);
}

/* 3 grid */
.cx-grid-3 {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
}

/* full button */
.cx-full {
    width: 100%;
}

/* optional secondary notification */
.cx-secondary-bg {
    background: rgba(117, 91, 0, 0.1);
}

.cx-full {
    max-width: fit-content;
}

/* step 1 */

/* Create cards */
.cx-create-card {
    border: 2px solid rgba(124, 116, 130, 0.2);
    border-radius: 12px;
    padding: 16px;
    text-align: center;
    cursor: pointer;
    transition: all 0.2s ease;
}

.cx-create-card:hover {
    border-color: rgba(67, 16, 118, 0.4);
}

.cx-create-active {
    border-color: #431076;
    background: rgba(67, 16, 118, 0.04);
}

/* Icon */
.cx-create-icon {
    width: 40px;
    height: 40px;
    border-radius: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto 10px;
}

.cx-dark-bg {
    background: linear-gradient(135deg, #2e2e43, #44445a);
}

/* Text */
.cx-create-title {
    font-size: 14px;
    font-weight: 700;
    line-height: normal;
}

.cx-preview {
    background: #f1ede7;
    border-radius: 12px;
    padding: 16px;
    border: 1px solid rgba(124, 116, 130, 0.2);
}

.cx-text-right {
    text-align: right;
}

.cx-bold {
    font-weight: 700;
}

.cx-font-16 {
    font-size: 16px;
    line-height: normal !important;
}

.cx-mb16 {
    margin-bottom: 16px;
}

.cx-mb12 {
    margin-bottom: 12px;
}



/* Tablet */
@media (max-width: 1024px) {
    .cx-pricing-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .cx-timeline-item:last-child::after {
        height: 100%;
    }

    .cx-timeline-head {
        flex-direction: column-reverse;
        align-items: start;
        gap: 8px;
    }

    .cx-timeline-card {
        display: flex;
        flex-direction: column;
        gap: 12px;
    }

    /* //////////////////////////////////// */
    /* features comparision */
    /* //////////////////////////////////// */
    .cx-compare {
        min-width: 520px;
    }

    .cx-compare .cx-col-feature {
        width: 26%;
    }

    .cx-compare .cx-col-plan {
        width: 18.5%;
    }

    .cx-compare thead .cx-col-feature,
    .cx-compare thead .cx-col-plan {
        padding: 14px 10px;
    }

    .cx-plan-name {
        font-size: 10px;
    }

    .cx-plan-price {
        font-size: 15px;
    }

    .cx-row td {
        padding: 11px 10px;
        font-size: 13px;
    }

    .cx-row td.cx-col-feature {
        font-size: 12px;
    }

    .cx-row td.cx-col-plan {
        font-size: 12px;
    }

    .cx-category-row td {
        padding: 8px 12px;
        font-size: 10px;
    }

    .my-navigation .elementor-widget-container {
        width: 64px !important;
    }

    .my-navigation .elementor-element.e-con-full.e-flex.e-con.e-child {
        justify-content: end !important;
        max-width: fit-content !important;
    }

    .my-navigation .elementor-element .hfe-nav-menu__toggle {
        margin: 0 !important;
    }

    .my-navigation nav.hfe-nav-menu__layout-horizontal.hfe-nav-menu__submenu-arrow.hfe-dropdown.menu-is-active {
        margin-top: 22px !important;
    }

    /* opportunity */

    .cx-match-card .cx-card {
        padding: 10px !important;
    }

    .cx-members-head,
    .cx-vendor-trust,
    .cx-ev-item {
        flex-direction: column !important;
        align-items: start !important;
    }

    .cx-ev-info-wrapper {
        display: flex;
        gap: 12px !important;
        /* flex-direction: column-reverse !important; */
    }

    .cx-ev-item .cx-tag.active {
        max-width: fit-content !important;
    }

    /* vendors */


    /* members page */
    .members-directory-wrapper,
    .site-main {
        padding-top: 120px;
        padding-inline: 24px;
        max-width: 100%;
    }

    #friend-list.grid,
    #groups-list.grid,
    #members-list.grid {
        display: grid !important;
        grid-template-columns: 1fr 1fr 1fr !important;
    }

    #buddypress .friends-mutual-list>li,
    #buddypress .members-list>li {
        min-width: unset !important;
    }

    .tribe-events-single-event-title {
        font-size: 40px !important;
    }

    .tribe-events-visuallyhidden {
        font-size: 20px !important;
    }

    div#buddypress {
        max-width: 100% !important;
        margin: 0 auto !important;
        padding-top: 70px !important;
        overflow-x: hidden !important;
        padding-inline: 24px !important;
    }

    .hfe-nav-menu {
        flex-direction: column !important;
    }
    ul.sub-menu.sub-menu-open{
        width: 100% !important;
        margin-top: 48px !important;
    }
}

/* Mobile */
@media (max-width: 640px) {


    .my-navigation .primary-menu {
        display: none;
    }

    .my-navigation .site-header-container {
        padding: 10px 16px;
    }

    .my-navigation .bb-logo {
        height: 32px;
    }

    .cx-pricing-grid {
        grid-template-columns: repeat(1, 1fr);
    }

    .cx-trust-badge {
        padding: 0 !important;
    }

    .cx-steps-nav {
        max-width: 100% !important;
        flex-direction: row !important;
    }

    /* //////////////////////////////////// */
    /* features comparision */
    /* //////////////////////////////////// */

    .cx-compare-wrapper {
        border-radius: 12px;
    }

    .cx-compare {
        min-width: 480px;
    }

    .cx-compare .cx-col-feature {
        width: 24%;
    }

    .cx-compare .cx-col-plan {
        width: 19%;
    }

    .cx-compare thead .cx-col-feature,
    .cx-compare thead .cx-col-plan {
        padding: 10px 6px;
    }

    .cx-plan-name {
        font-size: 9px;
        letter-spacing: 0;
    }

    .cx-plan-price {
        font-size: 13px;
        margin-top: 2px;
    }

    .cx-row td {
        padding: 9px 6px;
        font-size: 11px;
    }

    .cx-row td.cx-col-feature {
        font-size: 11px;
        padding-left: 8px;
    }

    .cx-row td.cx-col-plan {
        font-size: 11px;
    }

    .cx-category-row td {
        padding: 7px 8px;
        font-size: 9px;
    }

    .cx-check,
    .cx-cross {
        font-size: 13px;
    }

    .cx-btn-sm {
        transform: scale(0.8);
    }

    .my-navigation .elementor-element .hfe-nav-menu__toggle {
        margin: 10px !important;
    }

    .my-navigation .elementor-element.e-con-full.e-flex.e-con.e-child {
        gap: 0 !important;
    }

    .my-navigation nav.hfe-nav-menu__layout-horizontal.hfe-nav-menu__submenu-arrow.hfe-dropdown.menu-is-active {
        margin-top: 10px !important;
    }


    .cx-tip {
        flex-direction: column !important;
    }

    .cx-tip-icon img {
        width: 24px;
        height: 24px;
    }

    /* members page */
    .members-directory-wrapper,
    .site-main {
        padding-top: 110px;
        padding-inline: 16px;
        overflow-x: hidden !important;
    }

    #friend-list.grid,
    #groups-list.grid,
    #members-list.grid {
        grid-template-columns: 1fr !important;
    }

    .tribe-events-single-event-title {
        font-size: 28px !important;
    }

    div#buddypress {
        padding-top: 70px !important;
        overflow-x: hidden !important;
        padding-inline: 24px !important;
    }

    .cx-grid,
    .cx-grid-3 {
        grid-template-columns: 1fr;
    }

    .cx-profile-detail {
        flex-direction: column;
        gap: 12px;
        align-items: center;
        margin-top: 12px;
    }

    .cx-text-right {
        text-align: center;
    }

}