
.axc-directory,
.axc-events {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 24px;
    margin: 28px 0;
}

.axc-card {
    border: 1px solid #e5e7eb;
    border-radius: 18px;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.axc-card-image img {
    width: 100%;
    height: 190px;
    object-fit: cover;
    display: block;
}

.axc-card-body {
    padding: 22px;
}

.axc-card h3 {
    margin-top: 0;
    margin-bottom: 8px;
    font-size: 1.2rem;
    line-height: 1.3;
}

.axc-card h3 a {
    text-decoration: none;
}

.axc-meta {
    color: #64748b;
    font-size: 0.95rem;
    margin: 0 0 10px;
}

.axc-badge {
    display: inline-block;
    background: #0A1C2F;
    color: #fff;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 0.8rem;
    margin: 0 0 12px;
}

.axc-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #0A1C2F;
    color: #fff !important;
    border-radius: 999px;
    padding: 10px 16px;
    text-decoration: none;
    font-weight: 700;
}

.axc-button:focus {
    outline: 3px solid #94a3b8;
    outline-offset: 3px;
}

.axc-sponsors {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 18px;
    margin: 28px 0;
    align-items: center;
}

.axc-sponsor {
    border: 1px solid #e5e7eb;
    border-radius: 16px;
    padding: 22px;
    background: #fff;
    text-align: center;
}

.axc-sponsor img {
    max-width: 100%;
    max-height: 90px;
    object-fit: contain;
}

.axc-dashboard {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 18px;
    margin: 28px 0;
}

.axc-dashboard-card {
    border: 1px solid #e5e7eb;
    border-radius: 18px;
    padding: 22px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.axc-dashboard-card strong {
    display: block;
    font-size: 2rem;
    line-height: 1;
    color: #0A1C2F;
}

.axc-dashboard-card span {
    color: #475569;
    font-weight: 600;
}


.axc-single-details {
    margin: 32px 0;
    padding: 24px;
    border: 1px solid #e5e7eb;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.axc-single-details h2 {
    margin-top: 0;
}

.axc-detail-list {
    display: grid;
    gap: 12px;
    margin: 0;
}

.axc-detail-list div {
    display: grid;
    grid-template-columns: minmax(140px, 220px) 1fr;
    gap: 16px;
    padding: 12px 0;
    border-bottom: 1px solid #eef2f7;
}

.axc-detail-list dt {
    font-weight: 700;
    color: #0A1C2F;
}

.axc-detail-list dd {
    margin: 0;
    color: #334155;
}

@media (max-width: 640px) {
    .axc-detail-list div {
        grid-template-columns: 1fr;
        gap: 4px;
    }
}


.axc-directory-filters {
    display: grid;
    grid-template-columns: 1.5fr 1fr 1fr auto;
    gap: 16px;
    align-items: end;
    margin: 28px 0;
    padding: 20px;
    border: 1px solid #e5e7eb;
    border-radius: 18px;
    background: #f8fafc;
}

.axc-filter-field label {
    display: block;
    font-weight: 700;
    margin-bottom: 6px;
    color: #0A1C2F;
}

.axc-filter-field input,
.axc-filter-field select {
    width: 100%;
    min-height: 44px;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    padding: 8px 12px;
    background: #fff;
    font-size: 16px;
}

.axc-filter-field input:focus,
.axc-filter-field select:focus {
    outline: 3px solid #94a3b8;
    outline-offset: 2px;
}

.axc-filter-actions {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
}

.axc-button-secondary {
    background: #fff;
    color: #0A1C2F !important;
    border: 1px solid #0A1C2F;
}

.axc-directory-count {
    margin: 0 0 18px;
    color: #475569;
    font-weight: 700;
}

.axc-featured-badge {
    display: inline-block;
    margin: 0 0 10px;
    padding: 5px 10px;
    border-radius: 999px;
    background: rgba(199, 172, 111, 0.18);
    color: #5f4b16;
    font-size: 0.8rem;
    font-weight: 800;
}

@media (max-width: 900px) {
    .axc-directory-filters {
        grid-template-columns: 1fr;
    }

    .axc-filter-actions {
        align-items: stretch;
    }

    .axc-filter-actions .axc-button {
        width: 100%;
    }
}


.axc-archive-page {
    background: #fff;
}

.axc-archive-container {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
}

.axc-archive-hero {
    padding: 56px 0 24px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    border-bottom: 1px solid #e5e7eb;
}

.axc-archive-hero h1 {
    margin: 0 0 10px;
    font-size: clamp(2rem, 4vw, 3.25rem);
    line-height: 1.05;
    color: #0A1C2F;
}

.axc-archive-hero p {
    max-width: 760px;
    color: #475569;
    font-size: 1.1rem;
}

.axc-eyebrow {
    margin: 0 0 10px;
    color: #64748b;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.78rem;
}

.axc-archive-content {
    padding: 28px 0 64px;
}


/* Axiom Chamber listing-style member cards */
.axc-directory {
    gap: 28px;
}

.axc-member-card {
    border: 1px solid #eef2f7;
    border-radius: 22px;
    background: #fff;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
    transition: transform 180ms ease, box-shadow 180ms ease;
}

.axc-member-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 55px rgba(15, 23, 42, 0.12);
}

.axc-member-card .axc-card-image {
    display: block;
    position: relative;
    height: 245px;
    overflow: hidden;
    background: #f1f5f9;
}

.axc-member-card .axc-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform 220ms ease;
}

.axc-member-card:hover .axc-card-image img {
    transform: scale(1.035);
}

.axc-card-image-placeholder {
    height: 100%;
    min-height: 245px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #0A1C2F 0%, #1e3a5f 100%);
    color: #fff;
}

.axc-card-image-placeholder span {
    width: 88px;
    height: 88px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255,255,255,0.12);
    font-size: 3rem;
    font-weight: 800;
}

.axc-member-card .axc-card-body {
    padding: 24px 26px 26px;
}

.axc-card-topline {
    display: flex;
    align-items: center;
    gap: 8px;
    min-height: 30px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}

.axc-featured-badge,
.axc-level-pill {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 5px 10px;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    line-height: 1;
}

.axc-featured-badge {
    background: rgba(199, 172, 111, 0.20);
    color: #5f4b16;
}

.axc-level-pill {
    background: #eef2ff;
    color: #243b6b;
}

.axc-member-card h3 {
    margin: 0 0 8px;
    font-size: clamp(1.25rem, 2vw, 1.55rem);
    line-height: 1.18;
    letter-spacing: -0.02em;
}

.axc-member-card h3 a {
    color: #0f172a;
    text-decoration: none;
}

.axc-member-card h3 a:hover {
    color: #0A1C2F;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.axc-card-category {
    margin: 0 0 10px;
    color: #0A75A8;
    font-weight: 800;
    font-size: 0.98rem;
}

.axc-card-description {
    margin: 0 0 12px;
    color: #475569;
    line-height: 1.55;
}

.axc-card-location {
    margin: 0 0 18px;
    color: #64748b;
    font-weight: 600;
}

.axc-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid #eef2f7;
}

.axc-card-phone {
    color: #334155;
    text-decoration: none;
    font-weight: 700;
}

.axc-card-phone:hover {
    text-decoration: underline;
    text-underline-offset: 3px;
}

.axc-more-info-button {
    white-space: nowrap;
}

@media (max-width: 680px) {
    .axc-member-card .axc-card-image {
        height: 210px;
    }

    .axc-card-footer {
        align-items: stretch;
        flex-direction: column;
    }

    .axc-more-info-button {
        width: 100%;
    }
}


/* Twenty Twenty-Five compatibility for Axiom Chamber archive content */
.axc-archive-page {
    background: #ffffff;
    min-height: 60vh;
}

.axc-archive-container {
    width: min(1180px, calc(100% - 40px));
    margin-left: auto;
    margin-right: auto;
}

.axc-archive-hero {
    padding: 56px 0 32px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    border-bottom: 1px solid #e5e7eb;
}

.axc-archive-hero h1 {
    margin: 0 0 10px;
    font-size: clamp(2rem, 4vw, 3.25rem);
    line-height: 1.05;
    color: #0A1C2F;
}

.axc-archive-hero p {
    max-width: 760px;
    color: #475569;
    font-size: 1.1rem;
}

.axc-eyebrow {
    margin: 0 0 10px;
    color: #64748b;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    font-size: 0.78rem;
}

.axc-archive-content {
    padding: 34px 0 70px;
}


/* v0.1.14: Full directory layout inside a normal WordPress page */
.axc-directory-page-shell {
    width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
    background: #fff;
}

.axc-directory-page-shell .axc-archive-hero {
    padding: 56px 0 32px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%);
    border-bottom: 1px solid #e5e7eb;
}

.axc-directory-page-shell .axc-archive-container,
.axc-archive-container {
    width: min(1180px, calc(100% - 40px));
    margin-left: auto;
    margin-right: auto;
}

.axc-directory-page-shell .axc-archive-hero h1 {
    margin: 0 0 10px;
    font-size: clamp(2rem, 4vw, 3.25rem);
    line-height: 1.05;
    color: #0A1C2F;
}

.axc-directory-page-shell .axc-archive-hero p {
    max-width: 760px;
    color: #475569;
    font-size: 1.1rem;
}

.axc-directory-page-shell .axc-archive-content {
    padding: 34px 0 70px;
}

.axc-directory-inline {
    width: 100%;
}

.axc-directory-page-shell + * {
    margin-top: 0;
}

/* Remove excess default block spacing when the shortcode is the primary Members page content. */
.page .entry-content > .axc-directory-page-shell:first-child {
    margin-top: calc(var(--wp--style--block-gap, 1.2rem) * -1);
}

@media (max-width: 760px) {
    .axc-directory-page-shell .axc-archive-hero {
        padding: 38px 0 24px;
    }
}


/* v0.1.15: Make the normal Members page visually match the stronger v12 directory layout. */
.axc-members-directory-page .wp-block-post-title,
.axc-members-directory-page main > h1,
.axc-members-directory-page .entry-title {
    display: none !important;
}

.axc-members-directory-page .entry-content,
.axc-members-directory-page .wp-block-post-content {
    max-width: none !important;
    width: 100% !important;
}

.axc-members-directory-page .entry-content > *,
.axc-members-directory-page .wp-block-post-content > * {
    max-width: none;
}

.axc-directory-page-shell.alignfull,
.axc-members-directory-page .axc-directory-page-shell {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    margin-top: 0 !important;
    padding: 0;
}

.axc-directory-page-shell .axc-archive-container {
    width: min(1180px, calc(100% - 40px)) !important;
    max-width: 1180px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.axc-directory-page-shell .axc-directory-filters {
    grid-template-columns: 1.5fr 1fr 1fr auto;
}

.axc-directory-page-shell .axc-directory {
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
}

.axc-directory-page-shell .axc-member-card .axc-card-image {
    height: 245px;
}

.axc-directory-page-shell .axc-card-description {
    min-height: 0;
}

@media (max-width: 900px) {
    .axc-directory-page-shell .axc-directory-filters {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 760px) {
    .axc-directory-page-shell .axc-directory {
        grid-template-columns: 1fr;
    }
}


/* v0.1.17 Events page */
.axc-events-page .wp-block-post-title,
.axc-events-page main > h1,
.axc-events-page .entry-title {
    display: none !important;
}

.axc-events-page .entry-content,
.axc-events-page .wp-block-post-content {
    max-width: none !important;
    width: 100% !important;
}

.axc-events-page-shell.alignfull,
.axc-events-page .axc-events-page-shell {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    margin-top: 0 !important;
    padding: 0;
    background: #fff;
}

.axc-events-page-shell .axc-archive-container {
    width: min(1180px, calc(100% - 40px)) !important;
    max-width: 1180px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.axc-event-filters {
    display: grid;
    grid-template-columns: minmax(260px, 1fr) auto;
    gap: 16px;
    align-items: end;
    margin: 28px 0;
    padding: 20px;
    border: 1px solid #e5e7eb;
    border-radius: 18px;
    background: #f8fafc;
}

.axc-events-list {
    display: grid;
    grid-template-columns: 1fr;
    gap: 22px;
}

.axc-event-card {
    display: grid;
    grid-template-columns: 150px 1fr;
    align-items: stretch;
    overflow: hidden;
}

.axc-event-date-block {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: #0A1C2F;
    color: #fff;
    text-decoration: none;
    min-height: 190px;
    padding: 24px;
}

.axc-event-month {
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    font-weight: 900;
    color: rgba(255,255,255,0.72);
}

.axc-event-day {
    display: block;
    margin-top: 6px;
    font-size: 3.4rem;
    line-height: 1;
    font-weight: 900;
}

.axc-event-body {
    padding: 26px 30px;
}

.axc-event-meta-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}

.axc-event-meta-row span {
    display: inline-flex;
    align-items: center;
    padding: 6px 11px;
    border-radius: 999px;
    background: #eef2ff;
    color: #243b6b;
    font-size: 0.82rem;
    font-weight: 800;
}

/* v0.1.17 Member and Event detail profile layouts */
.axc-profile,
.axc-event-profile {
    display: grid;
    grid-template-columns: minmax(280px, 420px) 1fr;
    gap: 28px;
    margin: 34px 0;
    align-items: stretch;
}

.axc-profile-media,
.axc-profile-placeholder {
    min-height: 390px;
    border-radius: 24px;
    overflow: hidden;
    background: linear-gradient(135deg, #0A1C2F 0%, #1e3a5f 100%);
}

.axc-profile-media img {
    width: 100%;
    height: 100%;
    min-height: 390px;
    object-fit: cover;
    display: block;
}

.axc-profile-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    color: #fff;
}

.axc-profile-placeholder span {
    width: 112px;
    height: 112px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    background: rgba(255,255,255,0.12);
    font-size: 4rem;
    font-weight: 900;
}

.axc-profile-panel,
.axc-event-profile-panel {
    border: 1px solid #e5e7eb;
    border-radius: 24px;
    background: #fff;
    padding: 30px;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

.axc-profile-panel h2,
.axc-event-profile-panel h2 {
    margin: 0 0 8px;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 1.05;
    color: #0A1C2F;
}

.axc-profile-category {
    margin: 0 0 22px;
    color: #0A75A8;
    font-weight: 900;
    font-size: 1.05rem;
}

.axc-profile-details {
    display: grid;
    gap: 0;
    margin: 22px 0 0;
}

.axc-profile-details div {
    display: grid;
    grid-template-columns: minmax(130px, 190px) 1fr;
    gap: 16px;
    padding: 14px 0;
    border-bottom: 1px solid #eef2f7;
}

.axc-profile-details dt {
    color: #0A1C2F;
    font-weight: 900;
}

.axc-profile-details dd {
    margin: 0;
    color: #334155;
}

.axc-profile-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 24px;
}

.axc-event-profile {
    grid-template-columns: 190px 1fr;
}

.axc-event-profile-date {
    min-height: 260px;
    border-radius: 24px;
    background: #0A1C2F;
    color: #fff;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.axc-event-profile-date span {
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 900;
    color: rgba(255,255,255,.72);
}

.axc-event-profile-date strong {
    font-size: 4.6rem;
    line-height: 1;
    margin: 8px 0;
}

.axc-event-profile-date small {
    color: rgba(255,255,255,.72);
    font-weight: 800;
}

@media (max-width: 800px) {
    .axc-event-filters,
    .axc-event-card,
    .axc-profile,
    .axc-event-profile {
        grid-template-columns: 1fr;
    }

    .axc-event-date-block {
        min-height: 140px;
    }

    .axc-profile-details div {
        grid-template-columns: 1fr;
        gap: 4px;
    }
}


/* v0.1.18 Simpler member detail profile layout */
.axc-member-profile-v2 {
    margin: 34px 0;
}

.axc-member-profile-hero {
    display: grid;
    grid-template-columns: minmax(280px, 460px) 1fr;
    gap: 28px;
    align-items: stretch;
    margin-bottom: 28px;
}

.axc-member-profile-image {
    min-height: 360px;
    border-radius: 26px;
    overflow: hidden;
    background: linear-gradient(135deg, #0A1C2F 0%, #1e3a5f 100%);
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.10);
}

.axc-member-profile-image img {
    width: 100%;
    height: 100%;
    min-height: 360px;
    object-fit: cover;
    display: block;
}

.axc-member-profile-summary {
    border: 1px solid #e5e7eb;
    border-radius: 26px;
    background: #fff;
    padding: clamp(26px, 4vw, 44px);
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.axc-member-profile-summary h2 {
    margin: 0 0 10px;
    font-size: clamp(2.2rem, 5vw, 4.2rem);
    line-height: 1.02;
    letter-spacing: -0.045em;
    color: #0A1C2F;
}

.axc-member-profile-location {
    margin: 14px 0 0;
    color: #475569;
    font-weight: 700;
    font-size: 1.05rem;
}

.axc-member-profile-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 28px;
}

.axc-member-profile-grid {
    display: grid;
    grid-template-columns: minmax(280px, 380px) 1fr;
    gap: 28px;
    align-items: start;
}

.axc-member-contact-card,
.axc-member-about-card {
    border: 1px solid #e5e7eb;
    border-radius: 24px;
    background: #fff;
    padding: 28px;
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06);
}

.axc-member-contact-card {
    position: sticky;
    top: 24px;
}

.admin-bar .axc-member-contact-card {
    top: 56px;
}

.axc-member-contact-card h3,
.axc-member-about-card h3 {
    margin: 0 0 18px;
    font-size: 1.45rem;
    line-height: 1.2;
    color: #0A1C2F;
}

.axc-member-about-content {
    color: #334155;
    line-height: 1.7;
}

.axc-member-about-content > *:first-child {
    margin-top: 0;
}

.axc-member-about-content > *:last-child {
    margin-bottom: 0;
}

.axc-member-contact-card .axc-profile-details {
    margin-top: 0;
}

.axc-member-contact-card .axc-profile-details div {
    grid-template-columns: 1fr;
    gap: 5px;
    padding: 13px 0;
}

.axc-member-contact-card .axc-profile-details div:first-child {
    padding-top: 0;
}

.axc-member-contact-card .axc-profile-details dt {
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #64748b;
}

.axc-member-contact-card .axc-profile-details dd {
    font-size: 1rem;
    color: #0f172a;
}

@media (max-width: 900px) {
    .axc-member-profile-hero,
    .axc-member-profile-grid {
        grid-template-columns: 1fr;
    }

    .axc-member-contact-card {
        position: static;
    }

    .axc-member-profile-image,
    .axc-member-profile-image img {
        min-height: 280px;
    }
}


/* v0.1.20 repaired member detail page */
.axc-member-single-page .wp-block-post-title,
.axc-member-single-page .wp-block-post-date,
.axc-member-single-page .wp-block-post-author,
.axc-member-single-page .entry-title {
    display: none !important;
}

.axc-member-single-page .wp-block-post-content,
.axc-member-single-page .entry-content {
    max-width: none !important;
    width: 100% !important;
}

.axc-member-profile-v3.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    margin-top: 0 !important;
    padding: 56px 0 78px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 45%);
}

.axc-member-profile-container {
    width: min(1180px, calc(100% - 40px));
    margin-left: auto;
    margin-right: auto;
}

.axc-member-profile-v3 .axc-member-profile-hero {
    display: grid;
    grid-template-columns: minmax(320px, 520px) minmax(360px, 1fr);
    gap: 32px;
    align-items: stretch;
    margin-bottom: 30px;
}

.axc-member-profile-v3 .axc-member-profile-image {
    min-height: 430px;
    border-radius: 26px;
    overflow: hidden;
    background: linear-gradient(135deg, #0A1C2F 0%, #1e3a5f 100%);
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.10);
}

.axc-member-profile-v3 .axc-member-profile-image img {
    width: 100%;
    height: 100%;
    min-height: 430px;
    object-fit: cover;
    display: block;
}

.axc-member-profile-v3 .axc-member-profile-summary {
    min-height: 430px;
    border: 1px solid #e5e7eb;
    border-radius: 26px;
    background: #fff;
    padding: clamp(28px, 4vw, 48px);
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.axc-member-profile-v3 .axc-member-profile-summary h1 {
    margin: 0 0 10px;
    font-size: clamp(2.6rem, 5.6vw, 5rem);
    line-height: 1.02;
    letter-spacing: -0.045em;
    color: #0A1C2F;
}

.axc-member-profile-v3 .axc-member-profile-location {
    margin: 14px 0 0;
    color: #475569;
    font-weight: 800;
    font-size: 1.05rem;
}

.axc-member-profile-v3 .axc-member-profile-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 28px;
}

.axc-member-profile-v3 .axc-member-profile-actions .axc-button {
    font-size: 0.98rem;
    padding: 12px 18px;
}

.axc-member-profile-v3 .axc-member-profile-grid {
    display: grid;
    grid-template-columns: minmax(300px, 390px) 1fr;
    gap: 28px;
    align-items: start;
}

.axc-member-profile-v3 .axc-member-contact-card,
.axc-member-profile-v3 .axc-member-about-card {
    border: 1px solid #e5e7eb;
    border-radius: 24px;
    background: #fff;
    padding: 28px;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.07);
}

.axc-member-profile-v3 .axc-member-contact-card {
    position: sticky;
    top: 24px;
}

.admin-bar .axc-member-profile-v3 .axc-member-contact-card {
    top: 56px;
}

.axc-member-profile-v3 .axc-member-contact-card h2,
.axc-member-profile-v3 .axc-member-about-card h2 {
    margin: 0 0 18px;
    font-size: 1.45rem;
    line-height: 1.2;
    color: #0A1C2F;
}

.axc-member-profile-v3 .axc-profile-details {
    margin-top: 0;
}

.axc-member-profile-v3 .axc-profile-details div {
    display: grid;
    grid-template-columns: 1fr;
    gap: 5px;
    padding: 13px 0;
    border-bottom: 1px solid #eef2f7;
}

.axc-member-profile-v3 .axc-profile-details div:first-child {
    padding-top: 0;
}

.axc-member-profile-v3 .axc-profile-details dt {
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    color: #64748b;
    font-weight: 900;
}

.axc-member-profile-v3 .axc-profile-details dd {
    margin: 0;
    color: #0f172a;
    overflow-wrap: anywhere;
}

.axc-member-profile-v3 .axc-member-about-content {
    color: #334155;
    line-height: 1.7;
}

.axc-member-profile-v3 .axc-member-about-content > *:first-child {
    margin-top: 0;
}

.axc-member-profile-v3 .axc-member-about-content > *:last-child {
    margin-bottom: 0;
}

@media (max-width: 960px) {
    .axc-member-profile-v3 .axc-member-profile-hero,
    .axc-member-profile-v3 .axc-member-profile-grid {
        grid-template-columns: 1fr;
    }

    .axc-member-profile-v3.alignfull {
        padding: 40px 0 60px;
    }

    .axc-member-profile-v3 .axc-member-profile-image,
    .axc-member-profile-v3 .axc-member-profile-image img,
    .axc-member-profile-v3 .axc-member-profile-summary {
        min-height: 300px;
    }

    .axc-member-profile-v3 .axc-member-contact-card {
        position: static;
    }
}


/* v0.1.21 smaller member detail hero + services/products */
.axc-admin-full {
    grid-column: 1 / -1;
}

.axc-member-profile-v3.alignfull {
    padding-top: 42px !important;
    padding-bottom: 66px !important;
}

.axc-member-profile-v3 .axc-member-profile-hero {
    grid-template-columns: minmax(260px, 390px) minmax(360px, 1fr) !important;
    gap: 24px !important;
    margin-bottom: 24px !important;
}

.axc-member-profile-v3 .axc-member-profile-image {
    min-height: 300px !important;
    max-height: 340px;
}

.axc-member-profile-v3 .axc-member-profile-image img {
    min-height: 300px !important;
    max-height: 340px;
}

.axc-member-profile-v3 .axc-member-profile-summary {
    min-height: 300px !important;
    padding: clamp(24px, 3vw, 36px) !important;
}

.axc-member-profile-v3 .axc-member-profile-summary h1 {
    font-size: clamp(2.1rem, 4.2vw, 3.8rem) !important;
}

.axc-member-profile-v3 .axc-profile-placeholder {
    min-height: 300px !important;
}

.axc-member-profile-v3 .axc-profile-placeholder span {
    width: 92px;
    height: 92px;
    font-size: 3.25rem;
}

.axc-member-profile-v3 .axc-member-profile-grid {
    grid-template-columns: minmax(280px, 350px) 1fr !important;
    gap: 24px !important;
}

.axc-member-main-content {
    display: grid;
    gap: 24px;
}

.axc-member-services-card {
    border: 1px solid #e5e7eb;
    border-radius: 24px;
    background: #fff;
    padding: 28px;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.07);
}

.axc-member-services-card h2 {
    margin: 0 0 18px;
    font-size: 1.45rem;
    line-height: 1.2;
    color: #0A1C2F;
}

.axc-services-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.axc-services-list li {
    display: inline-flex;
    align-items: center;
    padding: 9px 13px;
    border-radius: 999px;
    background: #f1f5f9;
    color: #0f172a;
    font-weight: 800;
    font-size: 0.95rem;
}

@media (max-width: 960px) {
    .axc-member-profile-v3 .axc-member-profile-hero,
    .axc-member-profile-v3 .axc-member-profile-grid {
        grid-template-columns: 1fr !important;
    }

    .axc-member-profile-v3 .axc-member-profile-image,
    .axc-member-profile-v3 .axc-member-profile-image img,
    .axc-member-profile-v3 .axc-member-profile-summary {
        min-height: 260px !important;
    }
}


/* v0.1.22 Accent color variables */
.axc-button,
.axc-badge,
.axc-event-date-block,
.axc-event-profile-date,
.axc-card-image-placeholder,
.axc-profile-placeholder,
.axc-member-profile-image,
.axc-member-profile-v3 .axc-member-profile-image {
    background-color: var(--axc-primary, #0A1C2F);
}

.axc-button {
    background: var(--axc-primary, #0A1C2F) !important;
}

.axc-button-secondary {
    background: #fff !important;
    color: var(--axc-primary, #0A1C2F) !important;
    border-color: var(--axc-primary, #0A1C2F) !important;
}

.axc-card-category,
.axc-profile-category,
.axc-member-card h3 a:hover {
    color: var(--axc-accent, #0A75A8) !important;
}

.axc-level-pill,
.axc-event-meta-row span {
    background: var(--axc-soft-accent, #EEF2FF) !important;
    color: var(--axc-primary, #0A1C2F) !important;
}

.axc-archive-hero h1,
.axc-member-profile-v3 .axc-member-profile-summary h1,
.axc-member-profile-v3 .axc-member-contact-card h2,
.axc-member-profile-v3 .axc-member-about-card h2,
.axc-member-services-card h2 {
    color: var(--axc-primary, #0A1C2F) !important;
}

/* v0.1.22 Hide default Twenty Twenty-Five post meta on member detail pages */
.axc-member-single-page .wp-block-post-title,
.axc-member-single-page .wp-block-post-date,
.axc-member-single-page .wp-block-post-author,
.axc-member-single-page .wp-block-post-terms,
.axc-member-single-page .wp-block-group:has(.wp-block-post-author),
.axc-member-single-page .entry-title,
.axc-member-single-page .posted-on,
.axc-member-single-page .byline,
.axc-member-single-page .cat-links,
.axc-member-single-page .entry-meta {
    display: none !important;
}

/* v0.1.22 tighter member detail spacing and equal hero heights */
.axc-member-single-page .wp-site-blocks > main,
.axc-member-single-page main {
    margin-top: 0 !important;
}

.axc-member-profile-v3.alignfull {
    padding-top: 30px !important;
    padding-bottom: 58px !important;
}

.axc-member-profile-v3 .axc-member-profile-hero {
    display: grid !important;
    grid-template-columns: minmax(250px, 360px) minmax(360px, 1fr) !important;
    align-items: stretch !important;
    gap: 22px !important;
    margin-bottom: 24px !important;
}

.axc-member-profile-v3 .axc-member-profile-image,
.axc-member-profile-v3 .axc-member-profile-summary {
    height: 280px !important;
    min-height: 280px !important;
    max-height: 280px !important;
}

.axc-member-profile-v3 .axc-member-profile-image img,
.axc-member-profile-v3 .axc-profile-placeholder {
    height: 280px !important;
    min-height: 280px !important;
    max-height: 280px !important;
}

.axc-member-profile-v3 .axc-profile-placeholder span {
    width: 78px !important;
    height: 78px !important;
    font-size: 2.75rem !important;
}

.axc-member-profile-v3 .axc-member-profile-summary {
    padding: 26px 34px !important;
}

.axc-member-profile-v3 .axc-member-profile-summary h1 {
    font-size: clamp(2rem, 3.8vw, 3.25rem) !important;
    line-height: 1.02 !important;
    margin-bottom: 6px !important;
}

.axc-member-profile-v3 .axc-profile-category {
    margin-bottom: 10px !important;
}

.axc-member-profile-v3 .axc-member-profile-location {
    margin-top: 8px !important;
    font-size: 1rem !important;
}

.axc-member-profile-v3 .axc-member-profile-actions {
    margin-top: 18px !important;
}

.axc-member-profile-v3 .axc-member-profile-actions .axc-button {
    padding: 10px 16px !important;
    font-size: .92rem !important;
}

@media (max-width: 960px) {
    .axc-member-profile-v3 .axc-member-profile-hero {
        grid-template-columns: 1fr !important;
    }

    .axc-member-profile-v3 .axc-member-profile-image,
    .axc-member-profile-v3 .axc-member-profile-summary,
    .axc-member-profile-v3 .axc-member-profile-image img,
    .axc-member-profile-v3 .axc-profile-placeholder {
        height: auto !important;
        min-height: 240px !important;
        max-height: none !important;
    }
}


/* v0.1.23 final single-member meta suppression and equal hero cards */
body.single-axc_member .wp-block-post-author,
body.single-axc_member .wp-block-post-author-name,
body.single-axc_member .wp-block-post-date,
body.single-axc_member .wp-block-post-terms,
body.single-axc_member .wp-block-post-title,
body.single-axc_member .entry-title,
body.single-axc_member .entry-meta,
body.single-axc_member .byline,
body.single-axc_member .posted-on,
body.axc-member-single-page .wp-block-post-author,
body.axc-member-single-page .wp-block-post-author-name,
body.axc-member-single-page .wp-block-post-date,
body.axc-member-single-page .wp-block-post-terms,
body.axc-member-single-page .wp-block-post-title,
body.axc-member-single-page .entry-title,
body.axc-member-single-page .entry-meta,
body.axc-member-single-page .byline,
body.axc-member-single-page .posted-on {
    display: none !important;
}

/* Hide common Twenty Twenty-Five single-template meta wrappers for this CPT only */
body.single-axc_member main .wp-block-group:has(.wp-block-post-author),
body.single-axc_member main .wp-block-group:has(.wp-block-post-author-name),
body.single-axc_member main .wp-block-group:has(.wp-block-post-terms),
body.single-axc_member main .wp-block-group:has(.wp-block-post-date),
body.axc-member-single-page main .wp-block-group:has(.wp-block-post-author),
body.axc-member-single-page main .wp-block-group:has(.wp-block-post-author-name),
body.axc-member-single-page main .wp-block-group:has(.wp-block-post-terms),
body.axc-member-single-page main .wp-block-group:has(.wp-block-post-date) {
    display: none !important;
}

/* Equalize member image and summary card heights. */
.axc-member-profile-v3 .axc-member-profile-hero {
    align-items: stretch !important;
}

.axc-member-profile-v3 .axc-member-profile-image,
.axc-member-profile-v3 .axc-member-profile-summary {
    height: 285px !important;
    min-height: 285px !important;
    max-height: 285px !important;
    box-sizing: border-box !important;
}

.axc-member-profile-v3 .axc-member-profile-image img,
.axc-member-profile-v3 .axc-profile-placeholder,
.axc-member-profile-v3 .axc-default-member-image {
    height: 285px !important;
    min-height: 285px !important;
    max-height: 285px !important;
    width: 100% !important;
    object-fit: cover !important;
    box-sizing: border-box !important;
}

.axc-member-profile-v3 .axc-member-profile-summary {
    overflow: hidden;
}

.axc-member-profile-v3 .axc-member-profile-summary h1 {
    font-size: clamp(2rem, 3.4vw, 3.1rem) !important;
}

@media (max-width: 960px) {
    .axc-member-profile-v3 .axc-member-profile-image,
    .axc-member-profile-v3 .axc-member-profile-summary,
    .axc-member-profile-v3 .axc-member-profile-image img,
    .axc-member-profile-v3 .axc-profile-placeholder,
    .axc-member-profile-v3 .axc-default-member-image {
        height: auto !important;
        min-height: 240px !important;
        max-height: none !important;
    }
}


/* v0.1.24 event month dropdown */
.axc-event-filters {
    grid-template-columns: minmax(240px, 1.3fr) minmax(180px, .75fr) auto !important;
}

.axc-event-filters select,
.axc-event-filters input[type="search"] {
    width: 100%;
    min-height: 44px;
    border: 1px solid #cbd5e1;
    border-radius: 12px;
    padding: 8px 12px;
    background: #fff;
}

@media (max-width: 900px) {
    .axc-event-filters {
        grid-template-columns: 1fr !important;
    }
}


/* v0.1.26 Improved event card display and typography */
.axc-events-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 24px !important;
}

.axc-event-card-v2 {
    display: grid !important;
    grid-template-columns: 150px minmax(0, 1fr) !important;
    align-items: stretch !important;
    overflow: hidden !important;
    min-height: 220px;
    font-family: inherit !important;
}

.axc-event-card-v2 .axc-event-date-block {
    min-height: 100% !important;
    padding: 24px 18px !important;
    text-align: center;
    background: var(--axc-primary, #0A1C2F) !important;
    color: #fff !important;
    text-decoration: none !important;
}

.axc-event-card-v2 .axc-event-month {
    font-size: 0.86rem !important;
    letter-spacing: 0.14em !important;
    text-transform: uppercase !important;
    font-weight: 900 !important;
    color: rgba(255,255,255,.70) !important;
}

.axc-event-card-v2 .axc-event-day {
    margin-top: 8px !important;
    font-size: 3.75rem !important;
    line-height: .95 !important;
    font-weight: 900 !important;
    letter-spacing: -0.04em !important;
    color: #fff !important;
}

.axc-event-card-v2 .axc-event-year {
    display: block;
    margin-top: 8px;
    font-size: 0.9rem;
    font-weight: 800;
    color: rgba(255,255,255,.68);
}

.axc-event-card-v2 .axc-event-body {
    padding: 28px 32px !important;
    min-width: 0;
}

.axc-event-card-v2 .axc-event-meta-row {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
    margin-bottom: 14px !important;
}

.axc-event-card-v2 .axc-event-meta-row span {
    max-width: 100%;
    width: auto !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    line-height: 1.35 !important;
    border-radius: 999px !important;
    padding: 7px 12px !important;
    font-size: 0.86rem !important;
    font-weight: 800 !important;
    font-family: inherit !important;
}

.axc-event-card-v2 .axc-event-time-pill {
    background: var(--axc-soft-accent, #EEF2FF) !important;
    color: var(--axc-primary, #0A1C2F) !important;
}

.axc-event-card-v2 .axc-event-price-pill {
    background: rgba(199, 172, 111, 0.18) !important;
    color: #5f4b16 !important;
}

.axc-event-card-v2 h3 {
    margin: 0 0 10px !important;
    font-size: clamp(1.45rem, 2.4vw, 2.1rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -0.025em !important;
    font-family: inherit !important;
}

.axc-event-card-v2 h3 a {
    color: var(--axc-primary, #0A1C2F) !important;
    text-decoration: none !important;
}

.axc-event-card-v2 h3 a:hover {
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

.axc-event-card-v2 .axc-card-description {
    margin: 0 0 12px !important;
    font-size: 1rem !important;
    line-height: 1.55 !important;
    color: #475569 !important;
    font-family: inherit !important;
}

.axc-event-card-v2 .axc-card-location {
    margin: 0 0 18px !important;
    font-size: 1rem !important;
    line-height: 1.45 !important;
    color: #64748b !important;
    font-weight: 800 !important;
    font-family: inherit !important;
}

.axc-event-card-v2 .axc-event-card-footer {
    justify-content: flex-start !important;
    gap: 12px !important;
    margin-top: 18px !important;
    padding-top: 18px !important;
}

.axc-event-card-v2 .axc-button {
    font-size: .95rem !important;
    padding: 11px 17px !important;
    font-family: inherit !important;
}

@media (max-width: 760px) {
    .axc-event-card-v2 {
        grid-template-columns: 1fr !important;
    }

    .axc-event-card-v2 .axc-event-date-block {
        min-height: 135px !important;
    }

    .axc-event-card-v2 .axc-event-day {
        font-size: 3rem !important;
    }

    .axc-event-card-v2 .axc-event-body {
        padding: 24px !important;
    }
}


/* v0.1.27 EventON-inspired but chamber-professional event row */
.axc-events-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
}

.axc-event-row-card {
    display: grid;
    grid-template-columns: 98px 170px minmax(0, 1fr) auto;
    gap: 0;
    align-items: stretch;
    border: 1px solid #e5e7eb;
    border-radius: 20px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06);
    font-family: inherit;
}

.axc-event-row-date {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-decoration: none !important;
    background: var(--axc-primary, #0A1C2F);
    color: #fff !important;
    padding: 18px 12px;
    min-height: 165px;
}

.axc-event-row-month {
    text-transform: uppercase;
    letter-spacing: .14em;
    font-size: .78rem;
    font-weight: 900;
    color: rgba(255,255,255,.72);
}

.axc-event-row-day {
    font-size: 3.1rem;
    line-height: .95;
    font-weight: 900;
    letter-spacing: -.05em;
    color: #fff;
    margin-top: 6px;
}

.axc-event-row-year {
    margin-top: 7px;
    font-size: .82rem;
    font-weight: 800;
    color: rgba(255,255,255,.68);
}

.axc-event-row-image {
    display: block;
    min-height: 165px;
    background: #f1f5f9;
    text-decoration: none !important;
    overflow: hidden;
}

.axc-event-row-image img {
    width: 100%;
    height: 100%;
    min-height: 165px;
    object-fit: cover;
    display: block;
    transition: transform 180ms ease;
}

.axc-event-row-card:hover .axc-event-row-image img {
    transform: scale(1.025);
}

.axc-event-image-placeholder {
    min-height: 165px;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
    color: var(--axc-primary, #0A1C2F);
}

.axc-event-image-placeholder span {
    width: 64px;
    height: 64px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    font-size: 2rem;
    font-weight: 900;
    box-shadow: 0 8px 22px rgba(15, 23, 42, .08);
}

.axc-event-row-content {
    padding: 22px 26px;
    min-width: 0;
}

.axc-event-row-kicker {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 11px;
}

.axc-event-row-kicker span {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 6px 10px;
    background: var(--axc-soft-accent, #EEF2FF);
    color: var(--axc-primary, #0A1C2F);
    font-size: .82rem;
    line-height: 1.25;
    font-weight: 800;
    max-width: 100%;
}

.axc-event-row-content h3 {
    margin: 0 0 8px !important;
    font-size: clamp(1.35rem, 2vw, 1.85rem) !important;
    line-height: 1.15 !important;
    letter-spacing: -.025em;
    font-family: inherit !important;
}

.axc-event-row-content h3 a {
    color: var(--axc-primary, #0A1C2F) !important;
    text-decoration: none !important;
}

.axc-event-row-content h3 a:hover {
    text-decoration: underline !important;
    text-underline-offset: 4px;
}

.axc-event-row-description {
    margin: 0 0 10px;
    color: #475569;
    line-height: 1.55;
    font-size: .98rem;
}

.axc-event-row-location {
    margin: 0;
    color: #64748b;
    font-weight: 800;
    font-size: .98rem;
}

.axc-event-row-actions {
    padding: 22px 24px 22px 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: stretch;
    gap: 10px;
    min-width: 150px;
}

.axc-event-row-actions .axc-button {
    padding: 10px 15px !important;
    font-size: .92rem !important;
    white-space: nowrap;
    text-align: center;
}

@media (max-width: 980px) {
    .axc-event-row-card {
        grid-template-columns: 96px 1fr;
    }

    .axc-event-row-image {
        display: none;
    }

    .axc-event-row-actions {
        grid-column: 2;
        padding: 0 22px 22px;
        flex-direction: row;
        justify-content: flex-start;
        min-width: 0;
    }
}

@media (max-width: 640px) {
    .axc-event-row-card {
        grid-template-columns: 1fr;
    }

    .axc-event-row-date {
        min-height: 110px;
    }

    .axc-event-row-day {
        font-size: 2.75rem;
    }

    .axc-event-row-content {
        padding: 22px;
    }

    .axc-event-row-actions {
        grid-column: auto;
        padding: 0 22px 22px;
        flex-direction: column;
    }
}


/* v0.1.28 Stable simple event cards. This intentionally overrides prior event card layouts. */
.axc-events-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
}

.axc-event-simple-card {
    display: grid !important;
    grid-template-columns: 118px minmax(0, 1fr) auto !important;
    align-items: stretch !important;
    width: 100% !important;
    min-height: 168px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 20px !important;
    background: #fff !important;
    overflow: hidden !important;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06) !important;
    font-family: inherit !important;
}

.axc-event-simple-card * {
    box-sizing: border-box;
}

.axc-event-simple-date {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 168px !important;
    padding: 18px 12px !important;
    background: var(--axc-primary, #0A1C2F) !important;
    color: #fff !important;
    text-align: center !important;
    text-decoration: none !important;
}

.axc-event-simple-month {
    display: block !important;
    text-transform: uppercase !important;
    letter-spacing: .14em !important;
    font-size: .78rem !important;
    font-weight: 900 !important;
    color: rgba(255,255,255,.72) !important;
}

.axc-event-simple-day {
    display: block !important;
    margin-top: 7px !important;
    font-size: 3.15rem !important;
    line-height: .95 !important;
    font-weight: 900 !important;
    letter-spacing: -.05em !important;
    color: #fff !important;
}

.axc-event-simple-year {
    display: block !important;
    margin-top: 7px !important;
    font-size: .84rem !important;
    font-weight: 800 !important;
    color: rgba(255,255,255,.68) !important;
}

.axc-event-simple-content {
    min-width: 0 !important;
    padding: 24px 28px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.axc-event-simple-pills {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-bottom: 11px !important;
}

.axc-event-simple-pills span {
    display: inline-flex !important;
    width: auto !important;
    max-width: 100% !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    background: var(--axc-soft-accent, #EEF2FF) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: .83rem !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
}

.axc-event-simple-content h3 {
    margin: 0 0 8px !important;
    font-size: clamp(1.4rem, 2vw, 1.95rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -.025em !important;
    font-family: inherit !important;
    color: var(--axc-primary, #0A1C2F) !important;
}

.axc-event-simple-content h3 a {
    color: var(--axc-primary, #0A1C2F) !important;
    text-decoration: none !important;
}

.axc-event-simple-content h3 a:hover {
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

.axc-event-simple-description {
    margin: 0 0 10px !important;
    color: #475569 !important;
    font-size: 1rem !important;
    line-height: 1.55 !important;
    font-family: inherit !important;
}

.axc-event-simple-location {
    margin: 0 !important;
    color: #64748b !important;
    font-weight: 800 !important;
    font-size: .98rem !important;
    line-height: 1.4 !important;
    font-family: inherit !important;
}

.axc-event-simple-actions {
    min-width: 162px !important;
    padding: 24px 24px 24px 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: stretch !important;
    gap: 10px !important;
}

.axc-event-simple-actions .axc-button {
    width: 100% !important;
    padding: 10px 15px !important;
    font-size: .92rem !important;
    text-align: center !important;
    white-space: nowrap !important;
    font-family: inherit !important;
}

/* Hide any old event card child styles if theme/browser keeps prior class combinations. */
.axc-event-simple-card .axc-event-row-image,
.axc-event-simple-card .axc-event-date-block,
.axc-event-simple-card .axc-event-body,
.axc-event-simple-card .axc-card-body {
    display: none !important;
}

@media (max-width: 860px) {
    .axc-event-simple-card {
        grid-template-columns: 96px minmax(0, 1fr) !important;
    }

    .axc-event-simple-actions {
        grid-column: 2 !important;
        min-width: 0 !important;
        padding: 0 24px 24px !important;
        flex-direction: row !important;
        justify-content: flex-start !important;
    }

    .axc-event-simple-actions .axc-button {
        width: auto !important;
    }
}

@media (max-width: 620px) {
    .axc-event-simple-card {
        grid-template-columns: 1fr !important;
    }

    .axc-event-simple-date {
        min-height: 108px !important;
    }

    .axc-event-simple-day {
        font-size: 2.7rem !important;
    }

    .axc-event-simple-content {
        padding: 22px !important;
    }

    .axc-event-simple-actions {
        grid-column: auto !important;
        padding: 0 22px 22px !important;
        flex-direction: column !important;
    }

    .axc-event-simple-actions .axc-button {
        width: 100% !important;
    }
}


/* v0.1.29 month heading + stronger neutral event layout overrides */
.axc-events-current-month {
    margin: 0 0 14px;
    color: #111827;
    font-size: clamp(2.1rem, 5vw, 4rem);
    line-height: 1;
    font-weight: 900;
    letter-spacing: -.05em;
    text-transform: uppercase;
}

@media (max-width: 980px) {
    .axc-event-neutral-card {
        flex-wrap: wrap !important;
    }
    .axc-event-neutral-image-wrap {
        display: none !important;
    }
    .axc-event-neutral-content {
        flex: 1 1 calc(100% - 116px) !important;
    }
    .axc-event-neutral-actions {
        width: auto !important;
        min-width: 0 !important;
        border-left: 0 !important;
        padding-top: 0 !important;
        margin-left: 116px !important;
        flex-direction: row !important;
    }
}

@media (max-width: 640px) {
    .axc-events-current-month {
        margin-bottom: 10px;
    }
    .axc-event-neutral-card {
        display: block !important;
    }
    .axc-event-neutral-date,
    .axc-event-neutral-content,
    .axc-event-neutral-actions {
        width: 100% !important;
        min-width: 0 !important;
        margin-left: 0 !important;
    }
    .axc-event-neutral-date {
        min-height: 108px !important;
    }
    .axc-event-neutral-actions {
        border-left: 0 !important;
        border-top: 1px solid #eef2f7 !important;
        flex-direction: column !important;
    }
}


/* v0.1.30 EventON-inspired neutral event rows. Final override for old event-card CSS. */
.axc-events-page-shell,
.axc-events-page-shell * {
    font-family: var(--wp--preset--font-family--body, inherit) !important;
}

.axc-events-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 18px !important;
}

.axc-events-list > .axc-evon-card {
    display: grid !important;
    grid-template-columns: 112px 176px minmax(0, 1fr) 168px !important;
    align-items: stretch !important;
    width: 100% !important;
    min-height: 176px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 22px !important;
    background: #fff !important;
    overflow: hidden !important;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06) !important;
}

.axc-evon-card > * {
    min-width: 0;
    box-sizing: border-box;
}

.axc-evon-date {
    grid-column: 1 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    background: var(--axc-primary, #0A1C2F) !important;
    color: #fff !important;
    text-decoration: none !important;
    padding: 18px 10px !important;
    text-align: center !important;
}

.axc-evon-month {
    display: block !important;
    text-transform: uppercase !important;
    letter-spacing: .14em !important;
    font-size: .76rem !important;
    font-weight: 900 !important;
    color: rgba(255,255,255,.72) !important;
}

.axc-evon-day {
    display: block !important;
    margin-top: 7px !important;
    font-size: 3rem !important;
    line-height: .95 !important;
    font-weight: 900 !important;
    letter-spacing: -.05em !important;
    color: #fff !important;
}

.axc-evon-year {
    display: block !important;
    margin-top: 7px !important;
    font-size: .82rem !important;
    font-weight: 800 !important;
    color: rgba(255,255,255,.68) !important;
}

.axc-evon-image {
    grid-column: 2 !important;
    display: block !important;
    background: #f8fafc !important;
    border-right: 1px solid #eef2f7 !important;
    text-decoration: none !important;
    overflow: hidden !important;
}

.axc-evon-image img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 176px !important;
    object-fit: cover !important;
}

.axc-evon-placeholder {
    height: 100% !important;
    min-height: 176px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%) !important;
}

.axc-evon-placeholder span {
    width: 68px !important;
    height: 68px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: 2rem !important;
    font-weight: 900 !important;
    box-shadow: 0 8px 22px rgba(15,23,42,.08) !important;
}

.axc-evon-main {
    grid-column: 3 !important;
    padding: 24px 28px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.axc-evon-pills {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-bottom: 10px !important;
}

.axc-evon-pills span {
    display: inline-flex !important;
    width: auto !important;
    max-width: 100% !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    background: var(--axc-soft-accent, #EEF2FF) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: .83rem !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
    overflow-wrap: anywhere !important;
}

.axc-evon-main h3 {
    margin: 0 0 8px !important;
    font-size: clamp(1.45rem, 2vw, 1.95rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -.025em !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-family: inherit !important;
}

.axc-evon-main h3 a {
    color: inherit !important;
    text-decoration: none !important;
}

.axc-evon-main h3 a:hover {
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

.axc-evon-desc {
    margin: 0 0 9px !important;
    color: #475569 !important;
    font-size: 1rem !important;
    line-height: 1.55 !important;
}

.axc-evon-location {
    margin: 0 !important;
    color: #64748b !important;
    font-weight: 800 !important;
    font-size: .98rem !important;
    line-height: 1.45 !important;
}

.axc-evon-flyer {
    margin: 10px 0 0 !important;
    font-weight: 800 !important;
}

.axc-evon-flyer a {
    color: var(--axc-accent, #0A75A8) !important;
}

.axc-evon-actions {
    grid-column: 4 !important;
    padding: 24px 24px 24px 0 !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: stretch !important;
    gap: 10px !important;
    border-left: 1px solid #eef2f7 !important;
}

.axc-evon-actions .axc-button {
    width: 100% !important;
    text-align: center !important;
    white-space: nowrap !important;
    padding: 10px 14px !important;
    font-size: .92rem !important;
}

@media (max-width: 1050px) {
    .axc-events-list > .axc-evon-card {
        grid-template-columns: 104px minmax(0, 1fr) 160px !important;
    }

    .axc-evon-image {
        display: none !important;
    }

    .axc-evon-main {
        grid-column: 2 !important;
    }

    .axc-evon-actions {
        grid-column: 3 !important;
    }
}

@media (max-width: 760px) {
    .axc-events-list > .axc-evon-card {
        grid-template-columns: 1fr !important;
    }

    .axc-evon-date,
    .axc-evon-main,
    .axc-evon-actions {
        grid-column: 1 !important;
    }

    .axc-evon-date {
        min-height: 110px !important;
    }

    .axc-evon-actions {
        border-left: 0 !important;
        border-top: 1px solid #eef2f7 !important;
        padding: 0 24px 24px !important;
    }
}


/* v0.1.32 event detail page */
.axc-event-single-page .wp-block-post-title,
.axc-event-single-page .wp-block-post-date,
.axc-event-single-page .wp-block-post-author,
.axc-event-single-page .entry-title,
.axc-event-single-page .entry-meta {
    display: none !important;
}

.axc-event-detail-v2.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    margin-top: 0 !important;
    padding: 54px 0 78px;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 46%);
}

.axc-event-detail-container {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
}

.axc-event-detail-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, .85fr);
    gap: 42px;
    align-items: start;
}

.axc-event-detail-main h1 {
    margin: 0 0 24px;
    color: var(--axc-primary, #0A1C2F);
    font-size: clamp(2.6rem, 5vw, 4.8rem);
    line-height: 1.02;
    letter-spacing: -.055em;
}

.axc-event-detail-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
    margin: 0 0 44px;
}

.axc-event-detail-section {
    margin-top: 10px;
}

.axc-event-detail-section h2,
.axc-event-info-card h2,
.axc-event-flyer-card h2 {
    margin: 0 0 18px;
    color: var(--axc-primary, #0A1C2F);
    font-size: 1.45rem;
    line-height: 1.2;
}

.axc-event-detail-section h2::after {
    content: "";
    display: block;
    width: 68px;
    height: 3px;
    margin-top: 10px;
    border-radius: 99px;
    background: var(--axc-accent, #0A75A8);
}

.axc-event-detail-description {
    color: #0f172a;
    line-height: 1.75;
    font-size: 1.05rem;
}

.axc-event-detail-side {
    display: grid;
    gap: 22px;
}

.axc-event-detail-image {
    border-radius: 24px;
    overflow: hidden;
    background: #f8fafc;
    box-shadow: 0 18px 45px rgba(15,23,42,.10);
    border: 1px solid #e5e7eb;
}

.axc-event-detail-image img {
    display: block;
    width: 100%;
    height: 300px;
    object-fit: cover;
}

.axc-event-detail-placeholder {
    min-height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
}

.axc-event-detail-placeholder span {
    width: 86px;
    height: 86px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #fff;
    color: var(--axc-primary, #0A1C2F);
    font-size: 2.5rem;
    font-weight: 900;
}

.axc-event-info-card,
.axc-event-flyer-card {
    border: 1px solid #e5e7eb;
    border-radius: 24px;
    background: #fff;
    padding: 26px;
    box-shadow: 0 16px 38px rgba(15,23,42,.06);
}

.axc-event-info-card dl {
    margin: 0;
    display: grid;
    gap: 0;
}

.axc-event-info-card div {
    display: grid;
    gap: 6px;
    padding: 16px 0;
    border-bottom: 1px solid #eef2f7;
}

.axc-event-info-card div:first-child {
    padding-top: 0;
}

.axc-event-info-card div:last-child {
    border-bottom: 0;
    padding-bottom: 0;
}

.axc-event-info-card dt {
    color: #64748b;
    font-size: .82rem;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-weight: 900;
}

.axc-event-info-card dd {
    margin: 0;
    color: #0f172a;
    font-weight: 700;
    line-height: 1.45;
}

.axc-event-flyer-card img {
    width: 100%;
    height: auto;
    border-radius: 16px;
    margin-bottom: 16px;
}

@media (max-width: 900px) {
    .axc-event-detail-layout {
        grid-template-columns: 1fr;
    }
}


/* v0.1.33 Event cards: true four-column layout */
.axc-events-list {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 20px !important;
}

.axc-events-list > .axc-v33-event-card {
    display: grid !important;
    grid-template-columns: 116px 190px minmax(0, 1fr) minmax(230px, 280px) !important;
    align-items: stretch !important;
    width: 100% !important;
    min-height: 190px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 24px !important;
    background: #fff !important;
    overflow: hidden !important;
    box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06) !important;
    font-family: inherit !important;
}

.axc-v33-event-card * {
    box-sizing: border-box !important;
}

.axc-v33-event-date {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    background: var(--axc-primary, #0A1C2F) !important;
    color: #fff !important;
    text-decoration: none !important;
    padding: 18px 10px !important;
    text-align: center !important;
}

.axc-v33-event-month {
    display: block !important;
    text-transform: uppercase !important;
    letter-spacing: .14em !important;
    font-size: .76rem !important;
    font-weight: 900 !important;
    color: rgba(255,255,255,.72) !important;
}

.axc-v33-event-day {
    display: block !important;
    margin-top: 8px !important;
    font-size: 3.1rem !important;
    line-height: .95 !important;
    font-weight: 900 !important;
    letter-spacing: -.05em !important;
    color: #fff !important;
}

.axc-v33-event-year {
    display: block !important;
    margin-top: 8px !important;
    font-size: .84rem !important;
    font-weight: 800 !important;
    color: rgba(255,255,255,.68) !important;
}

.axc-v33-event-image {
    display: block !important;
    background: #f8fafc !important;
    border-right: 1px solid #eef2f7 !important;
    text-decoration: none !important;
    overflow: hidden !important;
}

.axc-v33-event-image img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 190px !important;
    object-fit: cover !important;
}

.axc-v33-event-placeholder {
    min-height: 190px !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%) !important;
}

.axc-v33-event-placeholder span {
    width: 72px !important;
    height: 72px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: 2.1rem !important;
    font-weight: 900 !important;
    box-shadow: 0 8px 22px rgba(15,23,42,.08) !important;
}

.axc-v33-event-main {
    min-width: 0 !important;
    padding: 26px 30px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
}

.axc-v33-event-main h3 {
    margin: 0 0 10px !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: clamp(1.5rem, 2.2vw, 2.1rem) !important;
    line-height: 1.1 !important;
    letter-spacing: -.03em !important;
    font-weight: 800 !important;
    font-family: inherit !important;
}

.axc-v33-event-main h3 a {
    color: inherit !important;
    text-decoration: none !important;
}

.axc-v33-event-main h3 a:hover {
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

.axc-v33-event-description {
    margin: 0 !important;
    color: #475569 !important;
    font-size: 1rem !important;
    line-height: 1.6 !important;
    font-family: inherit !important;
}

.axc-v33-event-description-muted {
    color: #94a3b8 !important;
}

.axc-v33-flyer-link {
    display: inline-flex !important;
    width: fit-content !important;
    margin-top: 12px !important;
    color: var(--axc-accent, #0A75A8) !important;
    font-weight: 800 !important;
    text-decoration: none !important;
}

.axc-v33-flyer-link:hover {
    text-decoration: underline !important;
}

.axc-v33-event-info {
    min-width: 0 !important;
    padding: 24px !important;
    border-left: 1px solid #eef2f7 !important;
    background: #fbfdff !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    gap: 18px !important;
}

.axc-v33-info-list {
    display: grid !important;
    gap: 12px !important;
}

.axc-v33-info-item {
    display: grid !important;
    gap: 4px !important;
}

.axc-v33-info-label {
    color: #64748b !important;
    font-size: .72rem !important;
    text-transform: uppercase !important;
    letter-spacing: .08em !important;
    font-weight: 900 !important;
}

.axc-v33-info-value {
    color: #0f172a !important;
    font-size: .95rem !important;
    line-height: 1.35 !important;
    font-weight: 800 !important;
    overflow-wrap: anywhere !important;
}

.axc-v33-event-actions {
    display: flex !important;
    gap: 10px !important;
    flex-direction: column !important;
    align-items: stretch !important;
}

.axc-v33-event-actions .axc-button {
    width: 100% !important;
    text-align: center !important;
    padding: 10px 14px !important;
    font-size: .92rem !important;
    white-space: nowrap !important;
}

@media (max-width: 1100px) {
    .axc-events-list > .axc-v33-event-card {
        grid-template-columns: 108px 160px minmax(0, 1fr) !important;
    }

    .axc-v33-event-info {
        grid-column: 3 !important;
        border-left: 0 !important;
        border-top: 1px solid #eef2f7 !important;
        padding-top: 0 !important;
    }

    .axc-v33-event-actions {
        flex-direction: row !important;
    }

    .axc-v33-event-actions .axc-button {
        width: auto !important;
    }
}

@media (max-width: 760px) {
    .axc-events-list > .axc-v33-event-card {
        grid-template-columns: 1fr !important;
    }

    .axc-v33-event-date,
    .axc-v33-event-image,
    .axc-v33-event-main,
    .axc-v33-event-info {
        grid-column: 1 !important;
    }

    .axc-v33-event-date {
        min-height: 110px !important;
    }

    .axc-v33-event-image {
        display: none !important;
    }

    .axc-v33-event-info {
        border-left: 0 !important;
        border-top: 1px solid #eef2f7 !important;
    }

    .axc-v33-event-actions {
        flex-direction: column !important;
    }

    .axc-v33-event-actions .axc-button {
        width: 100% !important;
    }
}


/* v0.1.34 Final event card reset. Description removed from Events listing. */
.axc-events-list {
    display: block !important;
}

.axc-event-final-card * {
    box-sizing: border-box !important;
}

@media (max-width: 980px) {
    .axc-event-final-card {
        flex-wrap: wrap !important;
    }

    .axc-event-final-card > a:first-child {
        flex-basis: 104px !important;
    }

    .axc-event-final-card > a:nth-child(2) {
        flex: 1 1 calc(100% - 104px) !important;
        min-width: 220px !important;
    }

    .axc-event-final-card > div {
        flex: 1 1 100% !important;
        border-right: 0 !important;
        border-top: 1px solid #eef2f7 !important;
    }

    .axc-event-final-card > aside {
        flex: 1 1 100% !important;
        border-top: 1px solid #eef2f7 !important;
    }
}

@media (max-width: 640px) {
    .axc-event-final-card {
        display: block !important;
    }

    .axc-event-final-card > a:first-child,
    .axc-event-final-card > a:nth-child(2),
    .axc-event-final-card > div,
    .axc-event-final-card > aside {
        width: 100% !important;
        flex: none !important;
    }

    .axc-event-final-card > a:first-child {
        min-height: 110px !important;
    }

    .axc-event-final-card > a:nth-child(2) {
        min-height: 190px !important;
    }
}


/* v0.1.35 force event listing into one horizontal row except on mobile */
@media (min-width: 761px) {
    .axc-event-final-card {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: stretch !important;
        width: 100% !important;
    }

    .axc-event-final-card > a:first-child {
        flex: 0 0 116px !important;
        width: 116px !important;
        min-width: 116px !important;
        min-height: 190px !important;
    }

    .axc-event-final-card > a:nth-child(2) {
        flex: 0 0 250px !important;
        width: 250px !important;
        min-width: 250px !important;
        min-height: 190px !important;
    }

    .axc-event-final-card > div {
        flex: 1 1 auto !important;
        width: auto !important;
        min-width: 0 !important;
        border-top: 0 !important;
        border-right: 1px solid #eef2f7 !important;
    }

    .axc-event-final-card > aside {
        flex: 0 0 240px !important;
        width: 240px !important;
        min-width: 240px !important;
        border-top: 0 !important;
    }
}

/* Override the earlier 980px stacking rule from v0.1.34 */
@media (min-width: 761px) and (max-width: 980px) {
    .axc-event-final-card {
        flex-wrap: nowrap !important;
    }

    .axc-event-final-card > a:first-child {
        flex-basis: 104px !important;
        width: 104px !important;
        min-width: 104px !important;
    }

    .axc-event-final-card > a:nth-child(2) {
        flex: 0 0 200px !important;
        width: 200px !important;
        min-width: 200px !important;
    }

    .axc-event-final-card > div {
        flex: 1 1 auto !important;
        width: auto !important;
        min-width: 0 !important;
    }

    .axc-event-final-card > aside {
        flex: 0 0 210px !important;
        width: 210px !important;
        min-width: 210px !important;
    }
}


/* v0.1.36 Reference-style Events listing. One professional event row per event. */
.axc-events-list {
    display: block !important;
}

.axc-events-list > .axc-ref-event-card {
    display: grid !important;
    grid-template-columns: 300px minmax(0, 1fr) 300px !important;
    align-items: stretch !important;
    width: 100% !important;
    min-height: 230px !important;
    margin: 0 0 22px !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: #fff !important;
    overflow: hidden !important;
    box-shadow: none !important;
    font-family: inherit !important;
}

.axc-ref-event-card * {
    box-sizing: border-box !important;
}

.axc-ref-event-media {
    position: relative !important;
    min-height: 230px !important;
    background: #f1f5f9 !important;
    overflow: hidden !important;
}

.axc-ref-event-image-link {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 230px !important;
    text-decoration: none !important;
}

.axc-ref-event-image-link img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    min-height: 230px !important;
    object-fit: cover !important;
}

.axc-ref-event-placeholder {
    min-height: 230px !important;
    height: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%) !important;
}

.axc-ref-event-placeholder span {
    width: 78px !important;
    height: 78px !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: 2.35rem !important;
    font-weight: 900 !important;
    box-shadow: 0 8px 22px rgba(15,23,42,.08) !important;
}

.axc-ref-event-date-badge {
    position: absolute !important;
    top: 16px !important;
    left: 16px !important;
    width: 78px !important;
    height: 78px !important;
    border-radius: 18px !important;
    background: var(--axc-primary, #0A1C2F) !important;
    color: #fff !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    text-align: center !important;
    text-decoration: none !important;
    box-shadow: 0 10px 26px rgba(15,23,42,.22) !important;
}

.axc-ref-event-month {
    display: block !important;
    text-transform: uppercase !important;
    letter-spacing: .12em !important;
    font-size: .68rem !important;
    font-weight: 900 !important;
    color: rgba(255,255,255,.72) !important;
}

.axc-ref-event-day {
    display: block !important;
    margin-top: 3px !important;
    font-size: 2rem !important;
    line-height: .9 !important;
    font-weight: 900 !important;
    color: #fff !important;
}

.axc-ref-event-main {
    min-width: 0 !important;
    padding: 34px 32px !important;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    background: #fff !important;
}

.axc-ref-event-time {
    margin: 0 0 22px !important;
    color: #5b6472 !important;
    font-size: 1.14rem !important;
    line-height: 1.35 !important;
    font-weight: 700 !important;
}

.axc-ref-event-main h3 {
    margin: 0 0 22px !important;
    color: #24262b !important;
    font-size: clamp(1.75rem, 2.4vw, 2.55rem) !important;
    line-height: 1.12 !important;
    letter-spacing: -.035em !important;
    font-family: inherit !important;
    font-weight: 850 !important;
}

.axc-ref-event-main h3 a {
    color: inherit !important;
    text-decoration: none !important;
}

.axc-ref-event-main h3 a:hover {
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

.axc-ref-event-location,
.axc-ref-event-price {
    margin: -10px 0 16px !important;
    color: #64748b !important;
    font-size: 1rem !important;
    line-height: 1.45 !important;
    font-weight: 700 !important;
}

.axc-ref-event-links {
    display: flex !important;
    gap: 18px !important;
    flex-wrap: wrap !important;
    align-items: center !important;
    margin-top: auto !important;
}

.axc-ref-event-links a {
    color: var(--axc-accent, #0A75A8) !important;
    font-weight: 800 !important;
    font-size: 1.05rem !important;
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

.axc-ref-event-action {
    padding: 34px 32px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
}

.axc-ref-register-button {
    display: flex !important;
    width: 100% !important;
    min-height: 74px !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 10px !important;
    background: var(--axc-accent, #0A75A8) !important;
    color: #fff !important;
    text-decoration: none !important;
    text-align: center !important;
    font-size: 1.16rem !important;
    line-height: 1.2 !important;
    font-weight: 900 !important;
    letter-spacing: .08em !important;
    text-transform: uppercase !important;
    padding: 18px 22px !important;
}

.axc-ref-register-button:hover {
    filter: brightness(.94) !important;
}

@media (max-width: 980px) {
    .axc-events-list > .axc-ref-event-card {
        grid-template-columns: 240px minmax(0, 1fr) !important;
    }

    .axc-ref-event-action {
        grid-column: 2 !important;
        padding-top: 0 !important;
        justify-content: flex-start !important;
    }

    .axc-ref-register-button {
        width: auto !important;
        min-width: 220px !important;
    }
}

@media (max-width: 700px) {
    .axc-events-list > .axc-ref-event-card {
        grid-template-columns: 1fr !important;
        border-radius: 18px !important;
        border: 1px solid #e5e7eb !important;
        overflow: hidden !important;
    }

    .axc-ref-event-media,
    .axc-ref-event-image-link,
    .axc-ref-event-image-link img {
        min-height: 220px !important;
    }

    .axc-ref-event-action {
        grid-column: 1 !important;
        padding-top: 0 !important;
    }

    .axc-ref-register-button {
        width: 100% !important;
        min-width: 0 !important;
    }
}


/* v0.1.37 final event listing card cleanup */
.axc-events-list > .axc-ref-event-card-v37 {
    margin: 0 0 28px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 24px !important;
    background: #fff !important;
    overflow: hidden !important;
    box-shadow: 0 16px 42px rgba(15,23,42,.07) !important;
}

.axc-ref-event-card-v37 .axc-ref-event-action {
    border-left: 1px solid #eef2f7 !important;
}

.axc-ref-event-card-v37 .axc-ref-register-button {
    background: var(--axc-accent, #0A75A8) !important;
    color: #fff !important;
}

/* Remove default Twenty Twenty-Five single event content/meta before custom event detail. */
.axc-event-single-page .wp-block-post-title,
.axc-event-single-page .wp-block-post-featured-image,
.axc-event-single-page .wp-block-post-content,
.axc-event-single-page .wp-block-post-excerpt,
.axc-event-single-page .wp-block-post-date,
.axc-event-single-page .wp-block-post-author,
.axc-event-single-page .wp-block-post-author-name,
.axc-event-single-page .wp-block-post-terms,
.axc-event-single-page .entry-title,
.axc-event-single-page .entry-content > figure,
.axc-event-single-page .entry-meta,
.axc-event-single-page .byline,
.axc-event-single-page .posted-on {
    display: none !important;
}

.axc-event-single-page main {
    margin-top: 0 !important;
}

@media (max-width: 980px) {
    .axc-ref-event-card-v37 .axc-ref-event-action {
        border-left: 0 !important;
        border-top: 1px solid #eef2f7 !important;
    }
}


/* v0.1.38 repair event detail page output */
.axc-event-single-page .wp-block-post-content,
.axc-event-single-page .entry-content {
    display: block !important;
}

.axc-event-single-page .wp-block-post-content .axc-event-detail-v2,
.axc-event-single-page .entry-content .axc-event-detail-v2 {
    display: block !important;
}

.axc-event-single-page .wp-block-post-title,
.axc-event-single-page .wp-block-post-featured-image,
.axc-event-single-page .wp-block-post-date,
.axc-event-single-page .wp-block-post-author,
.axc-event-single-page .wp-block-post-author-name,
.axc-event-single-page .wp-block-post-terms,
.axc-event-single-page .entry-title,
.axc-event-single-page .entry-content > figure,
.axc-event-single-page .entry-meta,
.axc-event-single-page .byline,
.axc-event-single-page .posted-on {
    display: none !important;
}


/* v0.1.39 event detail refinement */
.axc-event-detail-main h1 {
    font-size: clamp(2.2rem, 4.25vw, 4.1rem) !important;
}

.axc-event-detail-actions {
    gap: 10px !important;
    margin-bottom: 38px !important;
}

.axc-event-detail-actions .axc-button {
    padding: 10px 18px !important;
    font-size: 0.95rem !important;
    line-height: 1.2 !important;
    min-height: 0 !important;
}

.axc-event-detail-v2 .axc-button {
    border-radius: 999px !important;
}

.axc-event-flyer-card {
    display: none !important;
}


/* v0.1.40 hard event detail refinements */
.axc-event-detail-main h1 {
    font-size: clamp(2.2rem, 4.25vw, 4.1rem) !important;
}

.axc-event-detail-actions .axc-button,
.axc-event-detail-v2 .axc-button {
    padding: 10px 18px !important;
    font-size: 0.95rem !important;
    line-height: 1.2 !important;
    min-height: 0 !important;
    border-radius: 999px !important;
}

.axc-event-flyer-card {
    display: none !important;
}


/* v0.1.43 safe reusable front-end carousels */
.axc-carousel-section {
    width: min(1180px, calc(100% - 40px));
    margin: 56px auto;
}

.axc-carousel-header {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 24px;
    margin-bottom: 22px;
}

.axc-carousel-header h2 {
    margin: 0;
    color: var(--axc-primary, #0A1C2F);
    font-size: clamp(2rem, 4vw, 3.4rem);
    line-height: 1.02;
    letter-spacing: -.045em;
}

.axc-carousel-header p {
    margin: 10px 0 0;
    color: #475569;
    max-width: 680px;
}

.axc-carousel-view-all {
    color: var(--axc-accent, #0A75A8);
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 4px;
    white-space: nowrap;
}

.axc-carousel-track {
    display: grid;
    grid-auto-flow: column;
    grid-auto-columns: minmax(260px, 320px);
    gap: 18px;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    scroll-snap-type: inline mandatory;
    padding: 2px 2px 18px;
}

.axc-carousel-card {
    scroll-snap-align: start;
    border: 1px solid #e5e7eb;
    border-radius: 22px;
    background: #fff;
    overflow: hidden;
    box-shadow: 0 14px 34px rgba(15,23,42,.06);
}

.axc-mini-image,
.axc-sponsor-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 180px;
    background: #f8fafc;
    text-decoration: none;
}

.axc-mini-image img {
    width: 100%;
    height: 180px;
    object-fit: cover;
    display: block;
}

.axc-sponsor-logo img {
    max-width: 78%;
    max-height: 118px;
    width: auto;
    height: auto;
    object-fit: contain;
    display: block;
}

.axc-mini-placeholder {
    min-height: 180px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%);
}

.axc-mini-placeholder span {
    width: 74px;
    height: 74px;
    border-radius: 999px;
    background: #fff;
    color: var(--axc-primary, #0A1C2F);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 2.2rem;
    font-weight: 900;
    box-shadow: 0 8px 22px rgba(15,23,42,.08);
}

.axc-mini-body {
    padding: 22px;
}

.axc-mini-body h3 {
    margin: 12px 0 8px;
    color: var(--axc-primary, #0A1C2F);
    font-size: 1.35rem;
    line-height: 1.15;
    letter-spacing: -.025em;
}

.axc-mini-body h3 a {
    color: inherit;
    text-decoration: none;
}

.axc-mini-meta {
    margin: 7px 0;
    color: #64748b;
    line-height: 1.45;
    font-weight: 700;
}

.axc-mini-link {
    display: inline-flex;
    margin-top: 12px;
    color: var(--axc-accent, #0A75A8);
    font-weight: 900;
    text-decoration: underline;
    text-underline-offset: 4px;
}

.axc-event-mini-card {
    display: grid;
    grid-template-columns: 94px 1fr;
}

.axc-event-mini-date {
    min-height: 100%;
    background: var(--axc-primary, #0A1C2F);
    color: #fff;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
}

.axc-event-mini-date span {
    text-transform: uppercase;
    letter-spacing: .12em;
    font-size: .75rem;
    font-weight: 900;
    color: rgba(255,255,255,.72);
}

.axc-event-mini-date strong {
    margin-top: 6px;
    font-size: 2.5rem;
    line-height: 1;
    color: #fff;
}

@media (max-width: 760px) {
    .axc-carousel-header {
        display: block;
    }

    .axc-carousel-view-all {
        display: inline-flex;
        margin-top: 16px;
    }

    .axc-carousel-track {
        grid-auto-columns: minmax(245px, 82vw);
    }
}


/* v0.1.44 Apple-style front-end carousel refresh */
.axc-carousel-section {
    width: min(1180px, calc(100% - 40px)) !important;
    margin: 76px auto !important;
    padding: 0 !important;
}

.axc-carousel-header {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-end !important;
    gap: 32px !important;
    margin-bottom: 28px !important;
}

.axc-carousel-header h2 {
    margin: 0 !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: clamp(2.25rem, 5vw, 4.35rem) !important;
    line-height: .96 !important;
    letter-spacing: -0.065em !important;
    font-weight: 850 !important;
    max-width: 820px !important;
}

.axc-carousel-header p {
    margin: 14px 0 0 !important;
    color: #5f6b7a !important;
    max-width: 680px !important;
    font-size: clamp(1rem, 1.4vw, 1.15rem) !important;
    line-height: 1.55 !important;
    font-weight: 500 !important;
}

.axc-carousel-view-all {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 42px !important;
    padding: 10px 18px !important;
    border-radius: 999px !important;
    background: rgba(15, 23, 42, 0.04) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-weight: 800 !important;
    text-decoration: none !important;
    white-space: nowrap !important;
    border: 1px solid rgba(15, 23, 42, 0.08) !important;
    transition: transform 180ms ease, background 180ms ease, box-shadow 180ms ease !important;
}

.axc-carousel-view-all:hover {
    transform: translateY(-1px) !important;
    background: rgba(15, 23, 42, 0.07) !important;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.08) !important;
}

.axc-apple-carousel-track,
.axc-carousel-track {
    display: grid !important;
    grid-auto-flow: column !important;
    grid-auto-columns: minmax(280px, 342px) !important;
    gap: 22px !important;
    overflow-x: auto !important;
    overscroll-behavior-inline: contain !important;
    scroll-snap-type: inline mandatory !important;
    padding: 4px 4px 26px !important;
    scrollbar-width: thin !important;
    scrollbar-color: #cbd5e1 transparent !important;
}

.axc-apple-carousel-track::-webkit-scrollbar,
.axc-carousel-track::-webkit-scrollbar {
    height: 10px !important;
}

.axc-apple-carousel-track::-webkit-scrollbar-track,
.axc-carousel-track::-webkit-scrollbar-track {
    background: transparent !important;
}

.axc-apple-carousel-track::-webkit-scrollbar-thumb,
.axc-carousel-track::-webkit-scrollbar-thumb {
    background: #cbd5e1 !important;
    border-radius: 999px !important;
}

.axc-carousel-card {
    scroll-snap-align: start !important;
    border: 1px solid rgba(15, 23, 42, 0.08) !important;
    border-radius: 28px !important;
    background: linear-gradient(180deg, #ffffff 0%, #fbfdff 100%) !important;
    overflow: hidden !important;
    box-shadow: 0 18px 45px rgba(15, 23, 42, 0.075) !important;
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease !important;
}

.axc-carousel-card:hover {
    transform: translateY(-4px) !important;
    box-shadow: 0 26px 60px rgba(15, 23, 42, 0.12) !important;
    border-color: rgba(15, 23, 42, 0.12) !important;
}

.axc-mini-image,
.axc-sponsor-logo {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 210px !important;
    background: radial-gradient(circle at top left, rgba(10, 117, 168, 0.10), transparent 38%),
                linear-gradient(135deg, #f8fafc 0%, #eef2f7 100%) !important;
    text-decoration: none !important;
    overflow: hidden !important;
}

.axc-mini-image img {
    width: 100% !important;
    height: 210px !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 220ms ease !important;
}

.axc-carousel-card:hover .axc-mini-image img {
    transform: scale(1.035) !important;
}

.axc-sponsor-logo {
    min-height: 190px !important;
    padding: 34px !important;
}

.axc-sponsor-logo img {
    max-width: 82% !important;
    max-height: 120px !important;
    width: auto !important;
    height: auto !important;
    object-fit: contain !important;
    display: block !important;
    filter: saturate(.9) contrast(1.02) !important;
    transition: transform 180ms ease, filter 180ms ease !important;
}

.axc-carousel-card:hover .axc-sponsor-logo img {
    transform: scale(1.025) !important;
    filter: saturate(1) contrast(1.05) !important;
}

.axc-mini-placeholder {
    min-height: 210px !important;
    width: 100% !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: radial-gradient(circle at top left, rgba(10, 117, 168, 0.12), transparent 38%),
                linear-gradient(135deg, #f8fafc 0%, #e2e8f0 100%) !important;
}

.axc-mini-placeholder span {
    width: 82px !important;
    height: 82px !important;
    border-radius: 999px !important;
    background: rgba(255,255,255,.88) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    font-size: 2.35rem !important;
    font-weight: 900 !important;
    box-shadow: 0 12px 30px rgba(15,23,42,.10) !important;
    backdrop-filter: blur(10px) !important;
}

.axc-mini-body {
    padding: 24px 24px 26px !important;
}

.axc-mini-body .axc-level-pill,
.axc-carousel-card .axc-level-pill {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    background: var(--axc-soft-accent, #EEF2FF) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: .76rem !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    letter-spacing: .02em !important;
}

.axc-mini-body h3 {
    margin: 12px 0 8px !important;
    color: var(--axc-primary, #0A1C2F) !important;
    font-size: 1.48rem !important;
    line-height: 1.08 !important;
    letter-spacing: -.035em !important;
    font-weight: 850 !important;
}

.axc-mini-body h3 a {
    color: inherit !important;
    text-decoration: none !important;
}

.axc-mini-body h3 a:hover {
    text-decoration: underline !important;
    text-underline-offset: 4px !important;
}

.axc-mini-meta,
.axc-card-category {
    margin: 8px 0 0 !important;
    color: #657184 !important;
    line-height: 1.45 !important;
    font-weight: 650 !important;
    font-size: .98rem !important;
}

.axc-mini-link {
    display: inline-flex !important;
    align-items: center !important;
    margin-top: 16px !important;
    color: var(--axc-accent, #0A75A8) !important;
    font-weight: 900 !important;
    text-decoration: none !important;
    position: relative !important;
}

.axc-mini-link::after {
    content: "→" !important;
    margin-left: 7px !important;
    transition: transform 160ms ease !important;
}

.axc-mini-link:hover::after {
    transform: translateX(3px) !important;
}

/* Upcoming events carousel refinement */
.axc-event-mini-card {
    display: grid !important;
    grid-template-columns: 98px 1fr !important;
    min-height: 210px !important;
}

.axc-event-mini-date {
    min-height: 100% !important;
    background: linear-gradient(180deg, var(--axc-primary, #0A1C2F) 0%, #12375c 100%) !important;
    color: #fff !important;
    text-decoration: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
}

.axc-event-mini-date span {
    text-transform: uppercase !important;
    letter-spacing: .14em !important;
    font-size: .75rem !important;
    font-weight: 900 !important;
    color: rgba(255,255,255,.72) !important;
}

.axc-event-mini-date strong {
    margin-top: 7px !important;
    font-size: 2.8rem !important;
    line-height: .95 !important;
    color: #fff !important;
    letter-spacing: -.04em !important;
}

/* Sponsor carousel refinement */
.axc-sponsor-mini-card .axc-mini-body {
    text-align: center !important;
}

.axc-sponsor-mini-card .axc-mini-body h3 {
    font-size: 1.3rem !important;
}

.axc-sponsor-mini-card .axc-mini-link {
    justify-content: center !important;
}

/* Page/editor compatibility */
.wp-block-shortcode .axc-carousel-section,
.entry-content .axc-carousel-section {
    max-width: min(1180px, calc(100% - 40px)) !important;
}

@media (max-width: 760px) {
    .axc-carousel-section {
        margin: 54px auto !important;
    }

    .axc-carousel-header {
        display: block !important;
        margin-bottom: 22px !important;
    }

    .axc-carousel-header h2 {
        font-size: clamp(2.1rem, 11vw, 3.2rem) !important;
    }

    .axc-carousel-view-all {
        display: inline-flex !important;
        margin-top: 18px !important;
    }

    .axc-apple-carousel-track,
    .axc-carousel-track {
        grid-auto-columns: minmax(252px, 84vw) !important;
        gap: 16px !important;
    }
}


/* v0.1.45 Apple-style demo homepage shortcode */
.axc-home-shell.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    margin-top: 0 !important;
    padding: 0 0 60px;
    background:
        radial-gradient(circle at 18% 8%, rgba(10,117,168,.12), transparent 30%),
        radial-gradient(circle at 82% 6%, rgba(15,23,42,.09), transparent 28%),
        linear-gradient(180deg, #f8fafc 0%, #ffffff 34%);
}

.axc-home-hero {
    min-height: 520px;
    display: flex;
    align-items: center;
    padding: 84px 0 48px;
}

.axc-home-hero-inner {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    text-align: center;
}

.axc-home-hero h1 {
    margin: 0 auto;
    max-width: 980px;
    color: var(--axc-primary, #0A1C2F);
    font-size: clamp(3.2rem, 8vw, 7.4rem);
    line-height: .92;
    letter-spacing: -.075em;
    font-weight: 850;
}

.axc-home-hero p:not(.axc-eyebrow) {
    margin: 26px auto 0;
    max-width: 780px;
    color: #536173;
    font-size: clamp(1.1rem, 2vw, 1.42rem);
    line-height: 1.5;
    font-weight: 500;
}

.axc-home-actions,
.axc-home-cta-actions {
    display: flex;
    justify-content: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-top: 34px;
}

.axc-home-primary,
.axc-home-secondary {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 12px 22px;
    border-radius: 999px;
    font-weight: 900;
    text-decoration: none;
    transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease;
}

.axc-home-primary {
    background: var(--axc-primary, #0A1C2F);
    color: #fff;
    box-shadow: 0 14px 34px rgba(15,23,42,.16);
}

.axc-home-secondary {
    background: rgba(255,255,255,.72);
    color: var(--axc-primary, #0A1C2F);
    border: 1px solid rgba(15,23,42,.10);
    backdrop-filter: blur(12px);
}

.axc-home-primary:hover,
.axc-home-secondary:hover {
    transform: translateY(-2px);
    box-shadow: 0 18px 44px rgba(15,23,42,.18);
}

.axc-home-stats {
    width: min(980px, calc(100% - 40px));
    margin: -20px auto 74px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}

.axc-home-stat-card {
    border: 1px solid rgba(15,23,42,.08);
    border-radius: 26px;
    background: rgba(255,255,255,.82);
    backdrop-filter: blur(14px);
    box-shadow: 0 18px 45px rgba(15,23,42,.075);
    padding: 26px;
    text-align: center;
}

.axc-home-stat-card strong {
    display: block;
    color: var(--axc-primary, #0A1C2F);
    font-size: clamp(2.3rem, 5vw, 4.2rem);
    line-height: .95;
    letter-spacing: -.055em;
    font-weight: 900;
}

.axc-home-stat-card span {
    display: block;
    margin-top: 8px;
    color: #64748b;
    font-size: .95rem;
    font-weight: 800;
}

.axc-home-cta {
    width: min(1180px, calc(100% - 40px));
    margin: 82px auto 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 32px;
    align-items: center;
    border-radius: 34px;
    background:
        radial-gradient(circle at top left, rgba(10,117,168,.18), transparent 34%),
        linear-gradient(135deg, var(--axc-primary, #0A1C2F) 0%, #12375c 100%);
    color: #fff;
    padding: clamp(32px, 5vw, 58px);
    box-shadow: 0 28px 70px rgba(15,23,42,.18);
}

.axc-home-cta .axc-eyebrow {
    color: rgba(255,255,255,.7);
}

.axc-home-cta h2 {
    margin: 0;
    max-width: 850px;
    color: #fff;
    font-size: clamp(2.1rem, 5vw, 4.4rem);
    line-height: .98;
    letter-spacing: -.06em;
    font-weight: 850;
}

.axc-home-cta p:not(.axc-eyebrow) {
    margin: 18px 0 0;
    max-width: 760px;
    color: rgba(255,255,255,.76);
    font-size: 1.08rem;
    line-height: 1.55;
}

.axc-home-cta .axc-home-primary {
    background: #fff;
    color: var(--axc-primary, #0A1C2F);
}

.axc-home-cta .axc-home-secondary {
    color: #fff;
    background: rgba(255,255,255,.10);
    border-color: rgba(255,255,255,.20);
}

@media (max-width: 860px) {
    .axc-home-hero {
        min-height: auto;
        padding: 64px 0 34px;
    }

    .axc-home-stats {
        grid-template-columns: 1fr;
        margin-top: 0;
        margin-bottom: 54px;
    }

    .axc-home-cta {
        grid-template-columns: 1fr;
    }

    .axc-home-cta-actions {
        justify-content: flex-start;
        margin-top: 0;
    }
}


/* v0.1.48 safe modular homepage without Hero Slides CPT */
.axc-home-stats {
    display: none !important;
}

.axc-safe-hero {
    width: min(1180px, calc(100% - 40px)) !important;
    min-height: 560px !important;
    margin: 74px auto 36px !important;
    border-radius: 38px !important;
    overflow: hidden !important;
    display: flex !important;
    align-items: center !important;
    padding: 0 !important;
    background:
        radial-gradient(circle at 18% 10%, rgba(10,117,168,.22), transparent 34%),
        linear-gradient(135deg, var(--axc-primary, #0A1C2F) 0%, #12375c 100%) !important;
    background-size: cover !important;
    background-position: center !important;
    box-shadow: 0 34px 90px rgba(15,23,42,.20) !important;
}

.axc-safe-hero .axc-home-hero-inner {
    text-align: left !important;
    margin: 0 !important;
    padding: clamp(34px, 7vw, 74px) !important;
    width: 100% !important;
}

.axc-safe-hero .axc-eyebrow {
    color: rgba(255,255,255,.74) !important;
}

.axc-safe-hero h1 {
    margin: 0 !important;
    max-width: 860px !important;
    color: #fff !important;
    font-size: clamp(3rem, 7vw, 6.6rem) !important;
    line-height: .91 !important;
    letter-spacing: -.075em !important;
    font-weight: 850 !important;
}

.axc-safe-hero p:not(.axc-eyebrow) {
    margin: 24px 0 0 !important;
    max-width: 680px !important;
    color: rgba(255,255,255,.78) !important;
    font-size: clamp(1.08rem, 1.8vw, 1.35rem) !important;
    line-height: 1.5 !important;
}

.axc-safe-hero .axc-home-actions {
    justify-content: flex-start !important;
    margin-top: 32px !important;
}

.axc-safe-hero .axc-home-primary {
    background: #fff !important;
    color: var(--axc-primary, #0A1C2F) !important;
}

.axc-safe-hero .axc-home-secondary {
    background: rgba(255,255,255,.12) !important;
    color: #fff !important;
    border-color: rgba(255,255,255,.24) !important;
}

.axc-settings-panel {
    padding: 16px;
    border: 1px solid #dcdcde;
    border-radius: 10px;
    background: #fff;
    max-width: 980px;
}

@media (max-width: 860px) {
    .axc-safe-hero {
        min-height: 520px !important;
        margin-top: 42px !important;
        border-radius: 28px !important;
    }

    .axc-safe-hero .axc-home-hero-inner {
        padding: 34px !important;
    }
}


/* v0.1.51 full-width modular hero slider */
.axc-full-hero-slider.alignfull {
    width: 100vw !important;
    max-width: 100vw !important;
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw !important;
    margin-right: -50vw !important;
    margin-top: 0 !important;
    margin-bottom: 76px !important;
    min-height: 660px;
    overflow: hidden;
    background: var(--axc-primary, #0A1C2F);
}

.axc-full-hero-track {
    position: relative;
    min-height: 660px;
}

.axc-full-hero-slide {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    opacity: 0;
    visibility: hidden;
    background:
        radial-gradient(circle at 18% 10%, rgba(10,117,168,.22), transparent 34%),
        linear-gradient(135deg, var(--axc-primary, #0A1C2F) 0%, #12375c 100%);
    background-size: cover;
    background-position: center;
    transition: opacity 500ms ease, visibility 500ms ease;
}

.axc-full-hero-slide.is-active {
    opacity: 1;
    visibility: visible;
    z-index: 1;
}

.axc-full-hero-inner {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    padding: 86px 0;
    position: relative;
    z-index: 2;
}

.axc-full-hero-inner .axc-eyebrow {
    color: rgba(255,255,255,.74) !important;
}

.axc-full-hero-inner h1 {
    margin: 0;
    max-width: 900px;
    color: #fff;
    font-size: clamp(3.35rem, 8vw, 7.5rem);
    line-height: .9;
    letter-spacing: -.078em;
    font-weight: 850;
}

.axc-full-hero-inner p:not(.axc-eyebrow) {
    margin: 26px 0 0;
    max-width: 720px;
    color: rgba(255,255,255,.80);
    font-size: clamp(1.1rem, 2vw, 1.42rem);
    line-height: 1.5;
    font-weight: 500;
}

.axc-full-hero-inner .axc-home-actions {
    justify-content: flex-start !important;
    margin-top: 34px !important;
}

.axc-full-hero-inner .axc-home-primary {
    background: #fff !important;
    color: var(--axc-primary, #0A1C2F) !important;
}

.axc-full-hero-inner .axc-home-secondary {
    background: rgba(255,255,255,.12) !important;
    color: #fff !important;
    border-color: rgba(255,255,255,.24) !important;
}

.axc-hero-dots {
    position: absolute;
    z-index: 4;
    left: 50%;
    bottom: 28px;
    transform: translateX(-50%);
    display: flex;
    gap: 10px;
}

.axc-hero-dots button {
    width: 9px;
    height: 9px;
    padding: 0;
    border-radius: 999px;
    border: 0;
    background: rgba(255,255,255,.45);
    cursor: pointer;
}

.axc-hero-dots button.is-active {
    width: 28px;
    background: #fff;
}

@media (max-width: 860px) {
    .axc-full-hero-slider.alignfull,
    .axc-full-hero-track {
        min-height: 600px;
    }

    .axc-full-hero-inner {
        padding: 70px 0;
    }

    .axc-full-hero-inner h1 {
        font-size: clamp(3rem, 14vw, 5.4rem);
    }
}


/* v0.1.52 hero slider interaction repair */
.axc-full-hero-slider {
    isolation: isolate;
}

.axc-full-hero-slide {
    pointer-events: none !important;
}

.axc-full-hero-slide.is-active {
    pointer-events: auto !important;
}

.axc-hero-dots {
    pointer-events: auto !important;
}

.axc-hero-dots button {
    appearance: none !important;
    -webkit-appearance: none !important;
    pointer-events: auto !important;
    position: relative !important;
    z-index: 10 !important;
    transition: width 180ms ease, background 180ms ease;
}


/* v0.1.53 remove default page title/gap on Axiom Chamber homepage shortcode pages */
body.axc-has-home-shortcode .wp-block-post-title,
body.axc-has-home-shortcode .entry-title,
body.axc-has-home-shortcode h1.wp-block-post-title {
    display: none !important;
}

body.axc-has-home-shortcode main,
body.axc-has-home-shortcode .wp-site-blocks main,
body.axc-has-home-shortcode .wp-block-group:has(.axc-home-shell) {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.axc-has-home-shortcode .entry-content,
body.axc-has-home-shortcode .wp-block-post-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.axc-has-home-shortcode .wp-block-post-content > .axc-home-shell:first-child,
body.axc-has-home-shortcode .entry-content > .axc-home-shell:first-child {
    margin-top: 0 !important;
}

body.axc-has-home-shortcode .axc-full-hero-slider.alignfull {
    margin-top: 0 !important;
}


/* v0.1.55 global top-spacing repair for Axiom Chamber pages */
body.axc-has-plugin-content .wp-site-blocks > main,
body.axc-has-plugin-content main.wp-block-group,
body.axc-has-plugin-content main {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.axc-has-plugin-content .wp-block-post-content,
body.axc-has-plugin-content .entry-content,
body.axc-has-plugin-content .wp-site-blocks .wp-block-post-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.axc-has-plugin-content .wp-block-post-content > *:first-child,
body.axc-has-plugin-content .entry-content > *:first-child {
    margin-top: 0 !important;
}

/* Tighten the theme-generated title area when a page is used only as an Axiom Chamber app page */
body.axc-has-plugin-content .wp-block-post-title,
body.axc-has-plugin-content .entry-title,
body.axc-has-plugin-content h1.wp-block-post-title {
    margin-top: 0 !important;
}

/* Hide page title only for hero/home pages. Directory/events pages keep their plugin-level titles. */
body.axc-has-hero-shortcode .wp-block-post-title,
body.axc-has-hero-shortcode .entry-title,
body.axc-has-hero-shortcode h1.wp-block-post-title {
    display: none !important;
}

/* Remove top margin from all primary Axiom Chamber front-end sections */
body.axc-has-plugin-content .axc-full-hero-slider.alignfull,
body.axc-has-plugin-content .axc-home-shell.alignfull,
body.axc-has-plugin-content .axc-directory-page,
body.axc-has-plugin-content .axc-events-page,
body.axc-has-plugin-content .axc-sponsors-page,
body.axc-has-plugin-content .axc-member-detail,
body.axc-has-plugin-content .axc-event-detail,
body.axc-has-plugin-content .axc-sponsor-detail {
    margin-top: 0 !important;
}

/* Twenty Twenty-Five block spacing compatibility */
body.axc-has-plugin-content .wp-site-blocks > * + * {
    margin-block-start: 0 !important;
}

body.axc-has-plugin-content .wp-block-template-part + main {
    margin-block-start: 0 !important;
}


/* v0.1.61 unified front-end width system
   Rebuilt from stable v0.1.55.
   Goal: Home modular sections, Events, Members, Sponsors, and detail pages use the same visual width. */

:root {
    --axc-layout-width: 1380px;
    --axc-layout-edge-gap: 40px;
}

/* Full-bleed archive shells stay full width, but their internal content shares one max width. */
.axc-directory-page-shell .axc-archive-container,
.axc-events-page-shell .axc-archive-container,
.axc-sponsors-page-shell .axc-archive-container,
.axc-archive-container {
    width: min(var(--axc-layout-width), calc(100% - var(--axc-layout-edge-gap))) !important;
    max-width: var(--axc-layout-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Modular homepage sections use the same width as Members and Events. */
.axc-carousel-section,
.axc-home-cta {
    width: min(var(--axc-layout-width), calc(100% - var(--axc-layout-edge-gap))) !important;
    max-width: var(--axc-layout-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Hero remains full width, but hero text aligns to the same layout width. */
.axc-full-hero-inner {
    width: min(var(--axc-layout-width), calc(100% - var(--axc-layout-edge-gap))) !important;
    max-width: var(--axc-layout-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Detail pages align to the same system without changing their internal grid structure. */
.axc-member-detail,
.axc-event-detail,
.axc-sponsor-detail {
    width: min(var(--axc-layout-width), calc(100% - var(--axc-layout-edge-gap))) !important;
    max-width: var(--axc-layout-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Keep filters, grids, and tracks filling their parent layout width. */
.axc-directory-filters,
.axc-events-filters,
.axc-sponsors-filters,
.axc-members-grid,
.axc-events-list,
.axc-sponsors-grid,
.axc-carousel-header,
.axc-carousel-track,
.axc-carousel-grid,
.axc-carousel-viewport {
    width: 100% !important;
    max-width: 100% !important;
}

/* WordPress content wrapper compatibility for modular shortcodes. */
.wp-block-post-content > .axc-carousel-section,
.entry-content > .axc-carousel-section,
.wp-block-post-content > .axc-home-cta,
.entry-content > .axc-home-cta {
    max-width: var(--axc-layout-width) !important;
}

/* Mobile safety. */
@media (max-width: 782px) {
    :root {
        --axc-layout-edge-gap: 24px;
    }
}


/* v0.1.62 small width correction
   The v0.1.61 unified layout was slightly wider than the header/logo line.
   This keeps the same unified system but tightens the left/right gutter. */

:root {
    --axc-layout-width: 1600px;
    --axc-layout-edge-gap: clamp(80px, 10vw, 176px);
}

/* Keep mobile comfortable */
@media (max-width: 782px) {
    :root {
        --axc-layout-edge-gap: 24px;
    }
}


/* v0.1.63 targeted alignment polish
   Keep v0.1.62 structure, but correct the two visible alignment issues:
   1. Directory filter bar should match the member grid width.
   2. Homepage modular sections should align closer to the hero/header content line. */

/* Member directory filter bar should visually match the card grid width, not extend wider. */
.axc-directory-page .axc-directory-filters,
.axc-directory-page-shell .axc-directory-filters {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
}

/* The grid and filters now share the same container behavior. */
.axc-directory-page .axc-members-grid,
.axc-directory-page-shell .axc-members-grid {
    width: 100% !important;
    max-width: 100% !important;
}

/* If the filter bar still appears wider because of inner padding, reduce only its outer horizontal padding slightly. */
.axc-directory-filters {
    padding-left: clamp(18px, 1.8vw, 28px) !important;
    padding-right: clamp(18px, 1.8vw, 28px) !important;
}

/* Homepage modular sections were inheriting extra centered spacing.
   Align them with the same outer line as the hero text and header. */
.axc-carousel-section,
.wp-block-post-content > .axc-carousel-section,
.entry-content > .axc-carousel-section,
.axc-home-cta,
.wp-block-post-content > .axc-home-cta,
.entry-content > .axc-home-cta {
    width: min(var(--axc-layout-width), calc(100% - var(--axc-layout-edge-gap))) !important;
    max-width: var(--axc-layout-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Keep carousel header, track, and cards aligned inside the same section width. */
.axc-carousel-section .axc-carousel-header,
.axc-carousel-section .axc-carousel-track,
.axc-carousel-section .axc-carousel-grid,
.axc-carousel-section .axc-carousel-viewport {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Reduce excessive top whitespace after hero before the first modular section. */
.axc-full-hero-slider + .axc-carousel-section,
.axc-home-shell .axc-full-hero-slider + .axc-carousel-section {
    margin-top: clamp(54px, 6vw, 86px) !important;
}

/* Preserve mobile spacing. */
@media (max-width: 782px) {
    .axc-directory-filters {
        padding-left: 18px !important;
        padding-right: 18px !important;
    }

    .axc-carousel-section,
    .wp-block-post-content > .axc-carousel-section,
    .entry-content > .axc-carousel-section,
    .axc-home-cta,
    .wp-block-post-content > .axc-home-cta,
    .entry-content > .axc-home-cta {
        width: calc(100% - 24px) !important;
        max-width: calc(100% - 24px) !important;
    }
}


/* v0.1.64 homepage modular shortcode width polish
   Members page is now correct, so this only adjusts homepage modular shortcodes.
   Goal: Upcoming Events, Featured Members, Sponsors carousel, and CTA align closer to the header/hero width. */

:root {
    --axc-home-section-width: 1600px;
    --axc-home-section-edge-gap: 176px;
}

/* Widen homepage modular shortcode sections without affecting Members/Events archive pages. */
.axc-carousel-section,
.wp-block-post-content > .axc-carousel-section,
.entry-content > .axc-carousel-section,
.axc-home-cta,
.wp-block-post-content > .axc-home-cta,
.entry-content > .axc-home-cta {
    width: min(var(--axc-home-section-width), calc(100% - var(--axc-home-section-edge-gap))) !important;
    max-width: var(--axc-home-section-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Remove any extra inner left/right offset inside homepage carousel sections. */
.axc-carousel-section .axc-carousel-header,
.axc-carousel-section .axc-carousel-track,
.axc-carousel-section .axc-carousel-grid,
.axc-carousel-section .axc-carousel-viewport,
.axc-carousel-section .axc-section-header,
.axc-carousel-section .axc-section-inner {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* If a theme content wrapper is adding left/right padding around direct shortcode output, neutralize only around these sections. */
.wp-block-post-content > .axc-carousel-section:first-child,
.entry-content > .axc-carousel-section:first-child,
.wp-block-post-content > .axc-home-cta:first-child,
.entry-content > .axc-home-cta:first-child {
    margin-left: auto !important;
    margin-right: auto !important;
}

@media (max-width: 782px) {
    :root {
        --axc-home-section-edge-gap: 24px;
    }

    .axc-carousel-section,
    .wp-block-post-content > .axc-carousel-section,
    .entry-content > .axc-carousel-section,
    .axc-home-cta,
    .wp-block-post-content > .axc-home-cta,
    .entry-content > .axc-home-cta {
        width: calc(100% - var(--axc-home-section-edge-gap)) !important;
        max-width: calc(100% - var(--axc-home-section-edge-gap)) !important;
    }
}


/* v0.1.65 homepage shortcode + CTA width/padding repair
   Keep Members and Events page fixes intact.
   Only adjust homepage modular sections and the homepage CTA card. */

:root {
    --axc-home-width: 1500px;
    --axc-home-edge-gap: clamp(72px, 9vw, 160px);
    --axc-home-card-padding: clamp(28px, 4vw, 64px);
}

/* Homepage modular shortcode sections should be wider and closer to the header/footer width. */
.axc-carousel-section,
.wp-block-post-content > .axc-carousel-section,
.entry-content > .axc-carousel-section {
    box-sizing: border-box !important;
    width: min(var(--axc-home-width), calc(100% - var(--axc-home-edge-gap))) !important;
    max-width: var(--axc-home-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* CTA outer card should match the homepage section width, not overflow or crop content. */
.axc-home-cta,
.wp-block-post-content > .axc-home-cta,
.entry-content > .axc-home-cta {
    box-sizing: border-box !important;
    width: min(var(--axc-home-width), calc(100% - var(--axc-home-edge-gap))) !important;
    max-width: var(--axc-home-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding: var(--axc-home-card-padding) !important;
    overflow: hidden !important;
}

/* CTA internal layout must stay inside the card. */
.axc-home-cta *,
.axc-home-cta *::before,
.axc-home-cta *::after {
    box-sizing: border-box !important;
}

.axc-home-cta .axc-home-cta-inner,
.axc-home-cta .axc-cta-inner,
.axc-home-cta .axc-home-cta-content,
.axc-home-cta .axc-cta-content {
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Prevent CTA text from being clipped on the left side. */
.axc-home-cta h1,
.axc-home-cta h2,
.axc-home-cta h3,
.axc-home-cta p,
.axc-home-cta .axc-eyebrow {
    max-width: 760px !important;
    overflow-wrap: anywhere !important;
}

/* Keep CTA buttons inside the card and aligned cleanly. */
.axc-home-cta .axc-home-actions,
.axc-home-cta .axc-cta-actions,
.axc-home-cta .axc-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 14px !important;
    justify-content: flex-end !important;
    align-items: center !important;
    max-width: 100% !important;
}

.axc-home-cta a,
.axc-home-cta .axc-home-primary,
.axc-home-cta .axc-home-secondary,
.axc-home-cta .axc-btn {
    white-space: normal !important;
    max-width: 100% !important;
}

/* Carousel internals should fill the wider homepage section. */
.axc-carousel-section .axc-carousel-header,
.axc-carousel-section .axc-carousel-track,
.axc-carousel-section .axc-carousel-grid,
.axc-carousel-section .axc-carousel-viewport,
.axc-carousel-section .axc-section-header,
.axc-carousel-section .axc-section-inner {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Mobile safety */
@media (max-width: 782px) {
    :root {
        --axc-home-edge-gap: 24px;
        --axc-home-card-padding: 24px;
    }

    .axc-carousel-section,
    .wp-block-post-content > .axc-carousel-section,
    .entry-content > .axc-carousel-section,
    .axc-home-cta,
    .wp-block-post-content > .axc-home-cta,
    .entry-content > .axc-home-cta {
        width: calc(100% - var(--axc-home-edge-gap)) !important;
        max-width: calc(100% - var(--axc-home-edge-gap)) !important;
    }

    .axc-home-cta .axc-home-actions,
    .axc-home-cta .axc-cta-actions,
    .axc-home-cta .axc-actions {
        justify-content: flex-start !important;
    }
}


/* v0.1.66 homepage shortcode outer-width correction
   v0.1.65 fixed CTA internal padding.
   This widens the homepage shortcode outer container to match the header/footer width more closely. */

:root {
    --axc-home-width: 1700px;
    --axc-home-edge-gap: clamp(80px, 8.6vw, 160px);
}

/* Homepage modular shortcode sections only */
.axc-carousel-section,
.wp-block-post-content > .axc-carousel-section,
.entry-content > .axc-carousel-section,
.axc-home-cta,
.wp-block-post-content > .axc-home-cta,
.entry-content > .axc-home-cta {
    width: min(var(--axc-home-width), calc(100% - var(--axc-home-edge-gap))) !important;
    max-width: var(--axc-home-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Keep CTA padding from v0.1.65 intact while using wider outer width. */
.axc-home-cta,
.wp-block-post-content > .axc-home-cta,
.entry-content > .axc-home-cta {
    padding: var(--axc-home-card-padding) !important;
}

/* Mobile safety */
@media (max-width: 782px) {
    :root {
        --axc-home-edge-gap: 24px;
    }

    .axc-carousel-section,
    .wp-block-post-content > .axc-carousel-section,
    .entry-content > .axc-carousel-section,
    .axc-home-cta,
    .wp-block-post-content > .axc-home-cta,
    .entry-content > .axc-home-cta {
        width: calc(100% - var(--axc-home-edge-gap)) !important;
        max-width: calc(100% - var(--axc-home-edge-gap)) !important;
    }
}


/* v0.1.67 homepage shortcode DOM + width repair
   Fixes the exact issue shown in inspector:
   - Empty shortcode-generated paragraphs and <br> tags between sections.
   - WordPress constrained-layout max-width affecting modular shortcode sections.
   - Homepage shortcodes should align with the header/footer gutter. */

:root {
    --axc-page-gutter: clamp(64px, 4.8vw, 96px);
}

/* Remove empty WordPress auto-paragraphs and line breaks between modular shortcodes. */
body.axc-has-plugin-content .entry-content > p:empty,
body.axc-has-plugin-content .wp-block-post-content > p:empty,
body.axc-has-plugin-content .entry-content > br,
body.axc-has-plugin-content .wp-block-post-content > br {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
    line-height: 0 !important;
}

/* Homepage modular shortcodes should escape the constrained content width
   but keep the same visual gutter as the header/footer. */
body.axc-has-plugin-content .entry-content > .axc-carousel-section,
body.axc-has-plugin-content .wp-block-post-content > .axc-carousel-section,
body.axc-has-plugin-content .entry-content > .axc-home-cta,
body.axc-has-plugin-content .wp-block-post-content > .axc-home-cta {
    box-sizing: border-box !important;
    width: calc(100vw - (var(--axc-page-gutter) * 2)) !important;
    max-width: none !important;
    margin-left: calc(50% - 50vw + var(--axc-page-gutter)) !important;
    margin-right: calc(50% - 50vw + var(--axc-page-gutter)) !important;
}

/* Keep CTA internal padding from v0.1.65/v0.1.66, but use the widened outer container. */
body.axc-has-plugin-content .entry-content > .axc-home-cta,
body.axc-has-plugin-content .wp-block-post-content > .axc-home-cta {
    padding: var(--axc-home-card-padding, clamp(28px, 4vw, 64px)) !important;
    overflow: hidden !important;
}

/* Make the inner shortcode content fill the corrected outer width. */
body.axc-has-plugin-content .axc-carousel-section .axc-carousel-header,
body.axc-has-plugin-content .axc-carousel-section .axc-carousel-track,
body.axc-has-plugin-content .axc-carousel-section .axc-carousel-grid,
body.axc-has-plugin-content .axc-carousel-section .axc-carousel-viewport,
body.axc-has-plugin-content .axc-carousel-section .axc-section-header,
body.axc-has-plugin-content .axc-carousel-section .axc-section-inner {
    box-sizing: border-box !important;
    width: 100% !important;
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* CTA inner content safety */
body.axc-has-plugin-content .axc-home-cta *,
body.axc-has-plugin-content .axc-home-cta *::before,
body.axc-has-plugin-content .axc-home-cta *::after {
    box-sizing: border-box !important;
}

/* Mobile safety */
@media (max-width: 782px) {
    :root {
        --axc-page-gutter: 20px;
    }

    body.axc-has-plugin-content .entry-content > .axc-carousel-section,
    body.axc-has-plugin-content .wp-block-post-content > .axc-carousel-section,
    body.axc-has-plugin-content .entry-content > .axc-home-cta,
    body.axc-has-plugin-content .wp-block-post-content > .axc-home-cta {
        width: calc(100vw - (var(--axc-page-gutter) * 2)) !important;
        margin-left: calc(50% - 50vw + var(--axc-page-gutter)) !important;
        margin-right: calc(50% - 50vw + var(--axc-page-gutter)) !important;
    }
}


/* v0.1.68 typography scale refinement
   Reduce oversized headings while keeping the Apple-style premium hierarchy. */

/* Hero headline: slightly smaller, still dominant */
.axc-full-hero-inner h1 {
    font-size: clamp(3rem, 6.8vw, 6.65rem) !important;
    line-height: .92 !important;
    letter-spacing: -.07em !important;
}

/* Archive/page hero titles: about 15-20% smaller */
.axc-page-hero h1,
.axc-directory-hero h1,
.axc-events-hero h1,
.axc-sponsors-hero h1,
.axc-page-title,
.axc-archive-title {
    font-size: clamp(2.85rem, 5vw, 4.95rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -.055em !important;
}

/* Homepage section titles like Upcoming Events, Featured Members, Sponsors */
.axc-carousel-section h2,
.axc-section-title,
.axc-home-section-title {
    font-size: clamp(2.45rem, 4.6vw, 4.55rem) !important;
    line-height: 1 !important;
    letter-spacing: -.055em !important;
}

/* Detail page titles: reduce without weakening presence */
.axc-member-detail h1,
.axc-event-detail h1,
.axc-sponsor-detail h1,
.axc-detail-title {
    font-size: clamp(2.85rem, 5vw, 5.15rem) !important;
    line-height: 1 !important;
    letter-spacing: -.055em !important;
}

/* CTA headline: moderate reduction so it fits comfortably inside the card */
.axc-home-cta h1,
.axc-home-cta h2,
.axc-home-cta h3 {
    font-size: clamp(2.35rem, 4.2vw, 4.25rem) !important;
    line-height: 1.03 !important;
    letter-spacing: -.052em !important;
}

/* Card titles: only slightly reduced for readability */
.axc-member-card h3,
.axc-event-card h3,
.axc-sponsor-card h3,
.axc-card-title {
    font-size: clamp(1.45rem, 2vw, 2.05rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -.025em !important;
}

/* Filter labels should remain bold but not oversized */
.axc-directory-filters label,
.axc-events-filters label,
.axc-sponsors-filters label,
.axc-filter-label {
    font-size: clamp(1.15rem, 1.45vw, 1.55rem) !important;
    line-height: 1.1 !important;
}

/* Mobile safety */
@media (max-width: 782px) {
    .axc-full-hero-inner h1 {
        font-size: clamp(2.75rem, 12vw, 4.75rem) !important;
    }

    .axc-page-hero h1,
    .axc-directory-hero h1,
    .axc-events-hero h1,
    .axc-sponsors-hero h1,
    .axc-page-title,
    .axc-archive-title,
    .axc-carousel-section h2,
    .axc-section-title,
    .axc-home-section-title,
    .axc-member-detail h1,
    .axc-event-detail h1,
    .axc-sponsor-detail h1,
    .axc-detail-title {
        font-size: clamp(2.25rem, 10vw, 3.35rem) !important;
        letter-spacing: -.045em !important;
    }
}


/* v0.1.69 smaller homepage section + event month headings */

/* Homepage section titles such as Upcoming Events, Featured Members, and Sponsors */
.axc-carousel-section h2,
.axc-section-title,
.axc-home-section-title {
    font-size: clamp(2.15rem, 3.6vw, 3.5rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.04em !important;
}

/* Event archive current month heading, such as MAY, 2026 */
.axc-events-page .axc-current-month,
.axc-events-page .axc-events-month-title,
.axc-events-page .axc-month-heading,
.axc-events-page-shell .axc-current-month,
.axc-events-page-shell .axc-events-month-title,
.axc-events-page-shell .axc-month-heading {
    font-size: clamp(2.6rem, 5vw, 4.25rem) !important;
    line-height: 1 !important;
    letter-spacing: -0.05em !important;
}

/* Broader fallback if the month heading is rendered as the first large h2/h3 inside the events page */
.axc-events-page h2.axc-section-title,
.axc-events-page-shell h2.axc-section-title {
    font-size: clamp(2.6rem, 5vw, 4.25rem) !important;
    line-height: 1 !important;
    letter-spacing: -0.05em !important;
}

/* Mobile safety */
@media (max-width: 782px) {
    .axc-carousel-section h2,
    .axc-section-title,
    .axc-home-section-title {
        font-size: clamp(2rem, 9vw, 3rem) !important;
        letter-spacing: -0.035em !important;
    }

    .axc-events-page .axc-current-month,
    .axc-events-page .axc-events-month-title,
    .axc-events-page .axc-month-heading,
    .axc-events-page-shell .axc-current-month,
    .axc-events-page-shell .axc-events-month-title,
    .axc-events-page-shell .axc-month-heading,
    .axc-events-page h2.axc-section-title,
    .axc-events-page-shell h2.axc-section-title {
        font-size: clamp(2.1rem, 10vw, 3.25rem) !important;
    }
}


/* v0.1.70 header standardization + single detail template spacing repair */

/* Standardize archive/header sections using Member Directory as the visual source of truth */
.axc-directory-hero,
.axc-events-hero,
.axc-sponsors-hero,
.axc-page-hero {
    padding-top: clamp(64px, 7vw, 110px) !important;
    padding-bottom: clamp(50px, 5vw, 84px) !important;
}

.axc-directory-hero h1,
.axc-events-hero h1,
.axc-sponsors-hero h1,
.axc-page-hero h1,
.axc-directory-page .axc-page-title,
.axc-events-page .axc-page-title,
.axc-sponsors-page .axc-page-title,
.axc-directory-page-shell .axc-page-title,
.axc-events-page-shell .axc-page-title,
.axc-sponsors-page-shell .axc-page-title {
    font-size: clamp(3.05rem, 4.9vw, 4.95rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.055em !important;
    font-weight: 400 !important;
}

.axc-directory-hero p,
.axc-events-hero p,
.axc-sponsors-hero p,
.axc-page-hero p,
.axc-directory-page .axc-page-intro,
.axc-events-page .axc-page-intro,
.axc-sponsors-page .axc-page-intro,
.axc-directory-page-shell .axc-page-intro,
.axc-events-page-shell .axc-page-intro,
.axc-sponsors-page-shell .axc-page-intro {
    max-width: 760px !important;
    font-size: clamp(1.05rem, 1.25vw, 1.25rem) !important;
    line-height: 1.42 !important;
}

/* Detail pages use single CPT templates, not the normal Page template.
   Remove the separate Twenty Twenty-Five single-template top gap. */
body.single-axc_member main#wp--skip-link--target,
body.single-axc_event main#wp--skip-link--target,
body.single-axc_sponsor main#wp--skip-link--target,
body.single-axc_member .wp-site-blocks > main,
body.single-axc_event .wp-site-blocks > main,
body.single-axc_sponsor .wp-site-blocks > main {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Remove padding from the first theme wrapper around single CPT content */
body.single-axc_member main#wp--skip-link--target > .wp-block-group:first-child,
body.single-axc_event main#wp--skip-link--target > .wp-block-group:first-child,
body.single-axc_sponsor main#wp--skip-link--target > .wp-block-group:first-child,
body.single-axc_member .wp-site-blocks > main > .wp-block-group:first-child,
body.single-axc_event .wp-site-blocks > main > .wp-block-group:first-child,
body.single-axc_sponsor .wp-site-blocks > main > .wp-block-group:first-child {
    padding-top: 0 !important;
    margin-top: 0 !important;
}

/* Hide default theme-generated single CPT title/meta if the plugin detail layout is rendering its own hero/title */
body.single-axc_member .wp-block-post-title,
body.single-axc_event .wp-block-post-title,
body.single-axc_sponsor .wp-block-post-title,
body.single-axc_member .wp-block-post-author,
body.single-axc_event .wp-block-post-author,
body.single-axc_sponsor .wp-block-post-author,
body.single-axc_member .wp-block-post-date,
body.single-axc_event .wp-block-post-date,
body.single-axc_sponsor .wp-block-post-date,
body.single-axc_member .wp-block-post-featured-image,
body.single-axc_event .wp-block-post-featured-image,
body.single-axc_sponsor .wp-block-post-featured-image {
    display: none !important;
}

/* Detail page container should start closer to the header */
body.single-axc_member .axc-member-detail,
body.single-axc_event .axc-event-detail,
body.single-axc_sponsor .axc-sponsor-detail {
    margin-top: clamp(36px, 4vw, 68px) !important;
}

/* Event and member detail title scale refinement */
.axc-event-detail h1,
.axc-member-detail h1,
.axc-sponsor-detail h1,
.axc-detail-title {
    font-size: clamp(2.85rem, 4.6vw, 4.7rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.055em !important;
}

/* Detail page buttons slightly slimmer */
.axc-event-detail .axc-btn,
.axc-member-detail .axc-btn,
.axc-sponsor-detail .axc-btn,
.axc-event-detail a[class*="button"],
.axc-member-detail a[class*="button"],
.axc-sponsor-detail a[class*="button"] {
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    min-height: 0 !important;
}

/* Mobile safety */
@media (max-width: 782px) {
    .axc-directory-hero,
    .axc-events-hero,
    .axc-sponsors-hero,
    .axc-page-hero {
        padding-top: 48px !important;
        padding-bottom: 42px !important;
    }

    .axc-directory-hero h1,
    .axc-events-hero h1,
    .axc-sponsors-hero h1,
    .axc-page-hero h1,
    .axc-directory-page .axc-page-title,
    .axc-events-page .axc-page-title,
    .axc-sponsors-page .axc-page-title,
    .axc-directory-page-shell .axc-page-title,
    .axc-events-page-shell .axc-page-title,
    .axc-sponsors-page-shell .axc-page-title,
    .axc-event-detail h1,
    .axc-member-detail h1,
    .axc-sponsor-detail h1,
    .axc-detail-title {
        font-size: clamp(2.35rem, 10vw, 3.35rem) !important;
        letter-spacing: -0.045em !important;
    }
}


/* v0.1.71 single CPT template cleanup + archive header match */

/* Remove the remaining Twenty Twenty-Five post-meta group on plugin single detail pages.
   This is the highlighted empty/flex group shown above the event detail layout. */
body.single-axc_event main#wp--skip-link--target .wp-block-group.has-small-font-size.has-accent-4-color,
body.single-axc_member main#wp--skip-link--target .wp-block-group.has-small-font-size.has-accent-4-color,
body.single-axc_sponsor main#wp--skip-link--target .wp-block-group.has-small-font-size.has-accent-4-color,
body.single-axc_event main#wp--skip-link--target .wp-block-group.has-small-font-size.has-text-color.has-link-color,
body.single-axc_member main#wp--skip-link--target .wp-block-group.has-small-font-size.has-text-color.has-link-color,
body.single-axc_sponsor main#wp--skip-link--target .wp-block-group.has-small-font-size.has-text-color.has-link-color {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

/* Remove default single template first-wrapper spacing more aggressively for Axiom Chamber CPTs */
body.single-axc_event main#wp--skip-link--target > .wp-block-group,
body.single-axc_member main#wp--skip-link--target > .wp-block-group,
body.single-axc_sponsor main#wp--skip-link--target > .wp-block-group {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Remove spacing after hidden default title/meta area */
body.single-axc_event .wp-block-post-title + *,
body.single-axc_member .wp-block-post-title + *,
body.single-axc_sponsor .wp-block-post-title + * {
    margin-top: 0 !important;
}

/* Make the plugin detail layout start in the correct visual area */
body.single-axc_event .entry-content,
body.single-axc_member .entry-content,
body.single-axc_sponsor .entry-content,
body.single-axc_event .wp-block-post-content,
body.single-axc_member .wp-block-post-content,
body.single-axc_sponsor .wp-block-post-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Detail content should not carry extra top offset from the single CPT template */
body.single-axc_event .axc-event-detail,
body.single-axc_member .axc-member-detail,
body.single-axc_sponsor .axc-sponsor-detail {
    margin-top: 0 !important;
    padding-top: clamp(34px, 4vw, 62px) !important;
}

/* Force Events and Sponsors archive headers to visually match the Member Directory header */
.axc-events-page-shell .axc-page-hero,
.axc-sponsors-page-shell .axc-page-hero,
.axc-directory-page-shell .axc-page-hero,
.axc-events-page .axc-page-hero,
.axc-sponsors-page .axc-page-hero,
.axc-directory-page .axc-page-hero,
.axc-events-hero,
.axc-sponsors-hero,
.axc-directory-hero {
    padding-top: clamp(64px, 7vw, 108px) !important;
    padding-bottom: clamp(48px, 5vw, 76px) !important;
    border-bottom: 1px solid rgba(10, 28, 47, 0.08) !important;
}

.axc-events-page-shell .axc-page-hero h1,
.axc-sponsors-page-shell .axc-page-hero h1,
.axc-directory-page-shell .axc-page-hero h1,
.axc-events-page .axc-page-hero h1,
.axc-sponsors-page .axc-page-hero h1,
.axc-directory-page .axc-page-hero h1,
.axc-events-hero h1,
.axc-sponsors-hero h1,
.axc-directory-hero h1,
.axc-events-page .axc-page-title,
.axc-sponsors-page .axc-page-title,
.axc-directory-page .axc-page-title,
.axc-events-page-shell .axc-page-title,
.axc-sponsors-page-shell .axc-page-title,
.axc-directory-page-shell .axc-page-title {
    font-size: clamp(3.05rem, 4.65vw, 4.55rem) !important;
    line-height: 1.04 !important;
    letter-spacing: -0.055em !important;
    font-weight: 400 !important;
    margin: 0 0 18px !important;
}

.axc-events-page-shell .axc-page-hero p,
.axc-sponsors-page-shell .axc-page-hero p,
.axc-directory-page-shell .axc-page-hero p,
.axc-events-page .axc-page-hero p,
.axc-sponsors-page .axc-page-hero p,
.axc-directory-page .axc-page-hero p,
.axc-events-hero p,
.axc-sponsors-hero p,
.axc-directory-hero p,
.axc-events-page .axc-page-intro,
.axc-sponsors-page .axc-page-intro,
.axc-directory-page .axc-page-intro,
.axc-events-page-shell .axc-page-intro,
.axc-sponsors-page-shell .axc-page-intro,
.axc-directory-page-shell .axc-page-intro {
    max-width: 760px !important;
    font-size: clamp(1.05rem, 1.2vw, 1.22rem) !important;
    line-height: 1.42 !important;
    margin-top: 0 !important;
}

/* Mobile safety */
@media (max-width: 782px) {
    body.single-axc_event .axc-event-detail,
    body.single-axc_member .axc-member-detail,
    body.single-axc_sponsor .axc-sponsor-detail {
        padding-top: 28px !important;
    }

    .axc-events-page-shell .axc-page-hero,
    .axc-sponsors-page-shell .axc-page-hero,
    .axc-directory-page-shell .axc-page-hero,
    .axc-events-page .axc-page-hero,
    .axc-sponsors-page .axc-page-hero,
    .axc-directory-page .axc-page-hero,
    .axc-events-hero,
    .axc-sponsors-hero,
    .axc-directory-hero {
        padding-top: 48px !important;
        padding-bottom: 42px !important;
    }

    .axc-events-page-shell .axc-page-hero h1,
    .axc-sponsors-page-shell .axc-page-hero h1,
    .axc-directory-page-shell .axc-page-hero h1,
    .axc-events-page .axc-page-hero h1,
    .axc-sponsors-page .axc-page-hero h1,
    .axc-directory-page .axc-page-hero h1,
    .axc-events-hero h1,
    .axc-sponsors-hero h1,
    .axc-directory-hero h1,
    .axc-events-page .axc-page-title,
    .axc-sponsors-page .axc-page-title,
    .axc-directory-page .axc-page-title,
    .axc-events-page-shell .axc-page-title,
    .axc-sponsors-page-shell .axc-page-title,
    .axc-directory-page-shell .axc-page-title {
        font-size: clamp(2.35rem, 10vw, 3.35rem) !important;
        letter-spacing: -0.045em !important;
    }
}


/* v0.1.72 final header/detail width normalization
   Member Directory header is the visual source of truth. */

/* One shared archive/detail width */
:root {
    --axc-shared-page-width: 1380px;
    --axc-shared-page-gap: clamp(72px, 9vw, 160px);
}

/* Archive pages and single detail pages use the same visual width */
.axc-directory-page-shell .axc-archive-container,
.axc-events-page-shell .axc-archive-container,
.axc-sponsors-page-shell .axc-archive-container,
.axc-directory-page,
.axc-events-page,
.axc-sponsors-page,
body.single-axc_member .axc-member-detail,
body.single-axc_event .axc-event-detail,
body.single-axc_sponsor .axc-sponsor-detail {
    box-sizing: border-box !important;
    width: min(var(--axc-shared-page-width), calc(100% - var(--axc-shared-page-gap))) !important;
    max-width: var(--axc-shared-page-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Make Events and Sponsors page headers match the Member Directory header exactly */
.axc-directory-hero,
.axc-events-hero,
.axc-sponsors-hero,
.axc-page-hero,
.axc-directory-page-shell .axc-page-hero,
.axc-events-page-shell .axc-page-hero,
.axc-sponsors-page-shell .axc-page-hero,
.axc-directory-page .axc-page-hero,
.axc-events-page .axc-page-hero,
.axc-sponsors-page .axc-page-hero {
    padding-top: clamp(68px, 7.2vw, 116px) !important;
    padding-bottom: clamp(52px, 5.2vw, 82px) !important;
    border-bottom: 1px solid rgba(10, 28, 47, 0.08) !important;
}

/* Header inner width should match the page archive/detail width */
.axc-directory-hero-inner,
.axc-events-hero-inner,
.axc-sponsors-hero-inner,
.axc-page-hero-inner,
.axc-directory-page-shell .axc-page-hero-inner,
.axc-events-page-shell .axc-page-hero-inner,
.axc-sponsors-page-shell .axc-page-hero-inner,
.axc-directory-page .axc-page-hero-inner,
.axc-events-page .axc-page-hero-inner,
.axc-sponsors-page .axc-page-hero-inner {
    box-sizing: border-box !important;
    width: min(var(--axc-shared-page-width), calc(100% - var(--axc-shared-page-gap))) !important;
    max-width: var(--axc-shared-page-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Exact title treatment based on the Members header */
.axc-directory-hero h1,
.axc-events-hero h1,
.axc-sponsors-hero h1,
.axc-page-hero h1,
.axc-directory-page .axc-page-title,
.axc-events-page .axc-page-title,
.axc-sponsors-page .axc-page-title,
.axc-directory-page-shell .axc-page-title,
.axc-events-page-shell .axc-page-title,
.axc-sponsors-page-shell .axc-page-title {
    font-size: clamp(3.15rem, 4.9vw, 5.05rem) !important;
    line-height: 1.03 !important;
    letter-spacing: -0.06em !important;
    font-weight: 400 !important;
    margin-top: 0 !important;
    margin-bottom: 18px !important;
}

/* Exact intro treatment based on the Members header */
.axc-directory-hero p,
.axc-events-hero p,
.axc-sponsors-hero p,
.axc-page-hero p,
.axc-directory-page .axc-page-intro,
.axc-events-page .axc-page-intro,
.axc-sponsors-page .axc-page-intro,
.axc-directory-page-shell .axc-page-intro,
.axc-events-page-shell .axc-page-intro,
.axc-sponsors-page-shell .axc-page-intro {
    max-width: 820px !important;
    font-size: clamp(1.08rem, 1.22vw, 1.25rem) !important;
    line-height: 1.42 !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    color: rgba(10, 28, 47, 0.70) !important;
}

/* Single detail pages: remove theme spacing and align with archive-page width */
body.single-axc_member main#wp--skip-link--target,
body.single-axc_event main#wp--skip-link--target,
body.single-axc_sponsor main#wp--skip-link--target {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

body.single-axc_member .wp-block-post-content,
body.single-axc_event .wp-block-post-content,
body.single-axc_sponsor .wp-block-post-content,
body.single-axc_member .entry-content,
body.single-axc_event .entry-content,
body.single-axc_sponsor .entry-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Single detail section should begin closer to the header but still breathe */
body.single-axc_member .axc-member-detail,
body.single-axc_event .axc-event-detail,
body.single-axc_sponsor .axc-sponsor-detail {
    padding-top: clamp(44px, 4.6vw, 74px) !important;
}

/* Single event/member/sponsor title smaller and closer to page header scale */
body.single-axc_member .axc-member-detail h1,
body.single-axc_event .axc-event-detail h1,
body.single-axc_sponsor .axc-sponsor-detail h1,
body.single-axc_member .axc-detail-title,
body.single-axc_event .axc-detail-title,
body.single-axc_sponsor .axc-detail-title {
    font-size: clamp(2.65rem, 4.15vw, 4.25rem) !important;
    line-height: 1.03 !important;
    letter-spacing: -0.055em !important;
    font-weight: 400 !important;
}

/* Single detail cards/image should not exceed their parent width */
body.single-axc_member .axc-member-detail *,
body.single-axc_event .axc-event-detail *,
body.single-axc_sponsor .axc-sponsor-detail * {
    box-sizing: border-box;
}

/* Mobile */
@media (max-width: 782px) {
    :root {
        --axc-shared-page-gap: 24px;
    }

    .axc-directory-hero,
    .axc-events-hero,
    .axc-sponsors-hero,
    .axc-page-hero,
    .axc-directory-page-shell .axc-page-hero,
    .axc-events-page-shell .axc-page-hero,
    .axc-sponsors-page-shell .axc-page-hero,
    .axc-directory-page .axc-page-hero,
    .axc-events-page .axc-page-hero,
    .axc-sponsors-page .axc-page-hero {
        padding-top: 48px !important;
        padding-bottom: 42px !important;
    }

    .axc-directory-hero h1,
    .axc-events-hero h1,
    .axc-sponsors-hero h1,
    .axc-page-hero h1,
    .axc-directory-page .axc-page-title,
    .axc-events-page .axc-page-title,
    .axc-sponsors-page .axc-page-title,
    .axc-directory-page-shell .axc-page-title,
    .axc-events-page-shell .axc-page-title,
    .axc-sponsors-page-shell .axc-page-title,
    body.single-axc_member .axc-member-detail h1,
    body.single-axc_event .axc-event-detail h1,
    body.single-axc_sponsor .axc-sponsor-detail h1,
    body.single-axc_member .axc-detail-title,
    body.single-axc_event .axc-detail-title,
    body.single-axc_sponsor .axc-detail-title {
        font-size: clamp(2.25rem, 10vw, 3.2rem) !important;
        letter-spacing: -0.045em !important;
    }

    body.single-axc_member .axc-member-detail,
    body.single-axc_event .axc-event-detail,
    body.single-axc_sponsor .axc-sponsor-detail {
        padding-top: 30px !important;
    }
}


/* v0.1.73 real selector fix
   Uses the actual plugin classes for archive headers and single detail layouts. */

/* 1. Archive headers: make Events/Sponsors match the Member Directory header style */
.axc-events-page-shell .axc-archive-hero,
.axc-sponsors-page-shell .axc-archive-hero,
.axc-directory-page-shell .axc-archive-hero {
    padding-top: 56px !important;
    padding-bottom: 32px !important;
    background: linear-gradient(180deg, #f8fafc 0%, #ffffff 100%) !important;
    border-bottom: 1px solid #e5e7eb !important;
}

.axc-events-page-shell .axc-archive-hero h1,
.axc-sponsors-page-shell .axc-archive-hero h1,
.axc-directory-page-shell .axc-archive-hero h1,
.axc-archive-hero h1 {
    margin: 0 0 10px !important;
    font-size: clamp(2.9rem, 4.1vw, 4.25rem) !important;
    line-height: 1.04 !important;
    letter-spacing: -0.055em !important;
    font-weight: 400 !important;
    color: #0A1C2F !important;
}

.axc-events-page-shell .axc-archive-hero p:not(.axc-eyebrow),
.axc-sponsors-page-shell .axc-archive-hero p:not(.axc-eyebrow),
.axc-directory-page-shell .axc-archive-hero p:not(.axc-eyebrow),
.axc-archive-hero p:not(.axc-eyebrow) {
    max-width: 820px !important;
    color: #475569 !important;
    font-size: 1.1rem !important;
    line-height: 1.42 !important;
    margin-top: 0 !important;
}

/* Keep archive inner containers consistent */
.axc-archive-container,
.axc-directory-page-shell .axc-archive-container,
.axc-events-page-shell .axc-archive-container,
.axc-sponsors-page-shell .axc-archive-container {
    width: min(1380px, calc(100% - 160px)) !important;
    max-width: 1380px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* 2. Single detail pages: remove extra top gap from the CPT single template */
body.axc-member-single-page main#wp--skip-link--target,
body.axc-event-single-page main#wp--skip-link--target,
body.single-axc_sponsor main#wp--skip-link--target,
body.axc-member-single-page .wp-site-blocks > main,
body.axc-event-single-page .wp-site-blocks > main,
body.single-axc_sponsor .wp-site-blocks > main {
    margin-top: 0 !important;
    padding-top: 0 !important;
}

/* Hide remaining default theme post title/meta/featured image groups */
body.axc-member-single-page .wp-block-post-title,
body.axc-event-single-page .wp-block-post-title,
body.single-axc_sponsor .wp-block-post-title,
body.axc-member-single-page .wp-block-post-featured-image,
body.axc-event-single-page .wp-block-post-featured-image,
body.single-axc_sponsor .wp-block-post-featured-image,
body.axc-member-single-page .wp-block-post-date,
body.axc-event-single-page .wp-block-post-date,
body.single-axc_sponsor .wp-block-post-date,
body.axc-member-single-page .wp-block-post-author,
body.axc-event-single-page .wp-block-post-author,
body.single-axc_sponsor .wp-block-post-author,
body.axc-member-single-page .wp-block-post-author-name,
body.axc-event-single-page .wp-block-post-author-name,
body.single-axc_sponsor .wp-block-post-author-name,
body.axc-member-single-page .wp-block-post-terms,
body.axc-event-single-page .wp-block-post-terms,
body.single-axc_sponsor .wp-block-post-terms,
body.axc-member-single-page main#wp--skip-link--target .wp-block-group.has-small-font-size,
body.axc-event-single-page main#wp--skip-link--target .wp-block-group.has-small-font-size,
body.single-axc_sponsor main#wp--skip-link--target .wp-block-group.has-small-font-size {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    overflow: hidden !important;
}

/* Remove wrapper spacing around single content */
body.axc-member-single-page .entry-content,
body.axc-event-single-page .entry-content,
body.single-axc_sponsor .entry-content,
body.axc-member-single-page .wp-block-post-content,
body.axc-event-single-page .wp-block-post-content,
body.single-axc_sponsor .wp-block-post-content {
    margin-top: 0 !important;
    padding-top: 0 !important;
    max-width: none !important;
    width: 100% !important;
}

/* 3. Single detail layouts use the same page width as archive pages */
.axc-member-profile-container,
.axc-event-detail-container,
.axc-single-details {
    width: min(1380px, calc(100% - 160px)) !important;
    max-width: 1380px !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Detail section top spacing */
.axc-member-profile-v3.alignfull,
.axc-event-detail-v2.alignfull {
    padding-top: 34px !important;
    padding-bottom: 72px !important;
}

/* 4. Single event/member titles smaller */
.axc-member-profile-v3 .axc-member-profile-summary h1,
.axc-event-detail-v2 .axc-event-detail-main h1,
.axc-event-detail-v2 h1,
.axc-single-details h1 {
    font-size: clamp(2.35rem, 3.6vw, 3.75rem) !important;
    line-height: 1.04 !important;
    letter-spacing: -0.05em !important;
    font-weight: 400 !important;
}

/* Make member summary title less dominant relative to the card */
.axc-member-profile-v3 .axc-member-profile-summary h1 {
    margin-bottom: 8px !important;
}

/* Keep detail buttons slim */
.axc-event-detail-v2 .axc-button,
.axc-member-profile-v3 .axc-button,
.axc-single-details .axc-button {
    padding-top: 10px !important;
    padding-bottom: 10px !important;
    font-size: 0.95rem !important;
}

/* Responsive */
@media (max-width: 980px) {
    .axc-archive-container,
    .axc-directory-page-shell .axc-archive-container,
    .axc-events-page-shell .axc-archive-container,
    .axc-sponsors-page-shell .axc-archive-container,
    .axc-member-profile-container,
    .axc-event-detail-container,
    .axc-single-details {
        width: min(100% - 40px, 1380px) !important;
    }
}

@media (max-width: 782px) {
    .axc-events-page-shell .axc-archive-hero,
    .axc-sponsors-page-shell .axc-archive-hero,
    .axc-directory-page-shell .axc-archive-hero {
        padding-top: 44px !important;
        padding-bottom: 32px !important;
    }

    .axc-events-page-shell .axc-archive-hero h1,
    .axc-sponsors-page-shell .axc-archive-hero h1,
    .axc-directory-page-shell .axc-archive-hero h1,
    .axc-archive-hero h1,
    .axc-member-profile-v3 .axc-member-profile-summary h1,
    .axc-event-detail-v2 .axc-event-detail-main h1,
    .axc-event-detail-v2 h1,
    .axc-single-details h1 {
        font-size: clamp(2.15rem, 9vw, 3.1rem) !important;
        letter-spacing: -0.04em !important;
    }

    .axc-member-profile-v3.alignfull,
    .axc-event-detail-v2.alignfull {
        padding-top: 26px !important;
    }
}


/* v0.1.76 Events archive refinement
   Controlled update from v0.1.75.
   Goal: cleaner event list, less wasted space, smaller type, rounded accent buttons. */

/* Month heading was too dominant */
.axc-events-current-month {
    font-size: clamp(2.15rem, 3.5vw, 3.65rem) !important;
    line-height: 1.02 !important;
    letter-spacing: -0.045em !important;
    margin-top: clamp(28px, 3vw, 44px) !important;
    margin-bottom: 8px !important;
}

.axc-events-page-shell .axc-directory-count,
.axc-events-page .axc-directory-count {
    font-size: clamp(1.08rem, 1.3vw, 1.35rem) !important;
    margin-bottom: clamp(22px, 2.5vw, 32px) !important;
    color: #475569 !important;
}

/* Event cards: reduce overall height and wasted space */
.axc-events-list > .axc-ref-event-card-v37,
.axc-events-list > .axc-ref-event-card {
    grid-template-columns: 260px minmax(0, 1fr) 230px !important;
    min-height: 170px !important;
    margin-bottom: 22px !important;
    border-radius: 22px !important;
    box-shadow: 0 14px 36px rgba(15, 23, 42, 0.06) !important;
}

/* Left image/visual column */
.axc-ref-event-media,
.axc-ref-event-image-link,
.axc-ref-event-image-link img,
.axc-ref-event-placeholder {
    min-height: 170px !important;
    height: 100% !important;
}

/* Date badge stays over the image, but smaller and cleaner */
.axc-ref-event-date-badge {
    top: 16px !important;
    left: 16px !important;
    width: 66px !important;
    height: 66px !important;
    border-radius: 16px !important;
}

.axc-ref-event-month {
    font-size: 0.62rem !important;
    letter-spacing: 0.12em !important;
}

.axc-ref-event-day {
    font-size: 1.72rem !important;
    margin-top: 2px !important;
}

/* Placeholder initial should be less oversized */
.axc-ref-event-placeholder span {
    width: 66px !important;
    height: 66px !important;
    font-size: 2rem !important;
}

/* Middle content: tighter, more editorial */
.axc-ref-event-main {
    padding: 26px 30px !important;
    justify-content: center !important;
}

.axc-ref-event-time {
    margin-bottom: 14px !important;
    font-size: clamp(0.95rem, 1.05vw, 1.08rem) !important;
    line-height: 1.25 !important;
    color: #5f6b7d !important;
    font-weight: 700 !important;
}

.axc-ref-event-main h3 {
    margin-bottom: 12px !important;
    font-size: clamp(1.45rem, 2vw, 2.05rem) !important;
    line-height: 1.1 !important;
    letter-spacing: -0.035em !important;
    font-weight: 800 !important;
    color: #111827 !important;
}

.axc-ref-event-location,
.axc-ref-event-price {
    margin: 0 0 12px !important;
    font-size: 0.98rem !important;
    line-height: 1.35 !important;
    color: #64748b !important;
}

.axc-ref-event-links {
    margin-top: 0 !important;
}

.axc-ref-event-links a {
    font-size: 0.98rem !important;
    font-weight: 800 !important;
    color: var(--axc-accent, #0A75A8) !important;
}

/* Right action column: reduce width and make button match site pill style */
.axc-ref-event-card-v37 .axc-ref-event-action,
.axc-ref-event-action {
    padding: 24px 26px !important;
    border-left: 1px solid #eef2f7 !important;
    justify-content: center !important;
}

.axc-ref-event-card-v37 .axc-ref-register-button,
.axc-ref-register-button {
    width: auto !important;
    min-width: 165px !important;
    min-height: 52px !important;
    border-radius: 999px !important;
    padding: 13px 24px !important;
    background: var(--axc-accent, #0A75A8) !important;
    color: #ffffff !important;
    font-size: 0.96rem !important;
    line-height: 1.1 !important;
    font-weight: 850 !important;
    letter-spacing: 0.055em !important;
    text-transform: uppercase !important;
    box-shadow: 0 10px 22px rgba(10, 117, 168, 0.18) !important;
}

/* Filter bar should not crowd the month section */
.axc-event-filters {
    margin-bottom: clamp(30px, 3vw, 46px) !important;
}

/* Responsive: keep compact and readable */
@media (max-width: 980px) {
    .axc-events-list > .axc-ref-event-card-v37,
    .axc-events-list > .axc-ref-event-card {
        grid-template-columns: 220px minmax(0, 1fr) !important;
        min-height: 170px !important;
    }

    .axc-ref-event-card-v37 .axc-ref-event-action,
    .axc-ref-event-action {
        grid-column: 2 !important;
        border-left: 0 !important;
        border-top: 0 !important;
        padding: 0 30px 26px !important;
        justify-content: flex-start !important;
    }

    .axc-ref-register-button {
        min-width: 160px !important;
    }
}

@media (max-width: 700px) {
    .axc-events-current-month {
        font-size: clamp(2rem, 9vw, 2.85rem) !important;
    }

    .axc-events-list > .axc-ref-event-card-v37,
    .axc-events-list > .axc-ref-event-card {
        display: block !important;
        min-height: 0 !important;
        border-radius: 20px !important;
    }

    .axc-ref-event-media,
    .axc-ref-event-image-link,
    .axc-ref-event-image-link img,
    .axc-ref-event-placeholder {
        min-height: 210px !important;
        height: 210px !important;
    }

    .axc-ref-event-main {
        padding: 24px !important;
    }

    .axc-ref-event-action {
        padding: 0 24px 24px !important;
    }

    .axc-ref-register-button {
        width: 100% !important;
        min-width: 0 !important;
    }
}


/* v0.1.77 event archive accent-color cleanup
   Use plugin settings/accent variables instead of hard-coded colors.
   Remove pricing from event archive cards. */

/* Shared accent variables fallback to the existing plugin setting variables */
:root {
    --axc-event-accent: var(--axc-accent, var(--axc-primary, var(--axc-color-primary, #0A75A8)));
    --axc-event-accent-text: var(--axc-accent-contrast, var(--axc-primary-contrast, #ffffff));
}

/* Date badge uses the plugin accent color, not hard-coded navy */
.axc-ref-event-date-badge,
.axc-events-page-shell .axc-event-date-badge,
.axc-events-page .axc-event-date-badge,
.axc-events-page-shell .axc-event-date,
.axc-events-page .axc-event-date {
    background: var(--axc-event-accent) !important;
    color: var(--axc-event-accent-text) !important;
}

/* Placeholder/initial accent treatment */
.axc-ref-event-placeholder span {
    color: var(--axc-event-accent) !important;
}

/* Register button uses the plugin accent color */
.axc-ref-event-card-v37 .axc-ref-register-button,
.axc-ref-register-button,
.axc-events-page-shell .axc-event-card-actions a,
.axc-events-page .axc-event-card-actions a,
.axc-events-page-shell .axc-event-actions a,
.axc-events-page .axc-event-actions a,
.axc-events-page-shell .axc-event-card .axc-btn,
.axc-events-page .axc-event-card .axc-btn {
    background: var(--axc-event-accent) !important;
    border-color: var(--axc-event-accent) !important;
    color: var(--axc-event-accent-text) !important;
}

/* Learn More/details links also use the selected accent color */
.axc-ref-event-links a,
.axc-events-page-shell .axc-event-card a[href*="/events/"]:not(.axc-btn),
.axc-events-page .axc-event-card a[href*="/events/"]:not(.axc-btn) {
    color: var(--axc-event-accent) !important;
}

/* Remove pricing from event archive/list cards */
.axc-ref-event-price,
.axc-events-page-shell .axc-event-price,
.axc-events-page .axc-event-price,
.axc-events-page-shell .axc-card-price,
.axc-events-page .axc-card-price {
    display: none !important;
}

/* If price badges or price rows exist inside event cards, hide them only on the archive page */
.axc-events-page-shell .axc-ref-event-card-v37 [class*="price"],
.axc-events-page .axc-ref-event-card-v37 [class*="price"],
.axc-events-page-shell .axc-ref-event-card [class*="price"],
.axc-events-page .axc-ref-event-card [class*="price"] {
    display: none !important;
}


/* v0.1.78 event archive button/date color correction
   Event Register buttons and event date badges should use the first Accent Color setting.
   The first accent color is the primary/dark chamber color, not the secondary blue. */

:root {
    --axc-event-primary-accent: var(--axc-primary, var(--axc-accent-1, var(--axc-color-primary, #0A1C2F)));
    --axc-event-primary-accent-text: var(--axc-primary-contrast, var(--axc-accent-1-contrast, #ffffff));
}

/* Date badge uses first accent color */
.axc-ref-event-date-badge,
.axc-events-page-shell .axc-event-date-badge,
.axc-events-page .axc-event-date-badge,
.axc-events-page-shell .axc-event-date,
.axc-events-page .axc-event-date {
    background: var(--axc-event-primary-accent) !important;
    border-color: var(--axc-event-primary-accent) !important;
    color: var(--axc-event-primary-accent-text) !important;
}

/* Register button uses first accent color */
.axc-ref-event-card-v37 .axc-ref-register-button,
.axc-ref-register-button,
.axc-events-page-shell .axc-event-card-actions a,
.axc-events-page .axc-event-card-actions a,
.axc-events-page-shell .axc-event-actions a,
.axc-events-page .axc-event-actions a,
.axc-events-page-shell .axc-event-card .axc-btn,
.axc-events-page .axc-event-card .axc-btn {
    background: var(--axc-event-primary-accent) !important;
    border-color: var(--axc-event-primary-accent) !important;
    color: var(--axc-event-primary-accent-text) !important;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--axc-event-primary-accent) 22%, transparent) !important;
}

/* Learn More links can still use the second accent color when available */
.axc-ref-event-links a {
    color: var(--axc-accent, var(--axc-secondary, #0878bf)) !important;
}


/* v0.1.79 event card action layout
   Register Now = solid primary action.
   Event Details / Learn More = transparent outline secondary action.
   Both use the first Accent Color setting. */

/* Action column: stack buttons neatly and reduce wasted space */
.axc-ref-event-card-v37 .axc-ref-event-action,
.axc-ref-event-action {
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 12px !important;
    padding: 24px 24px !important;
}

/* Shared action button style */
.axc-ref-event-action a,
.axc-ref-event-card-v37 .axc-ref-event-action a,
.axc-ref-register-button,
.axc-ref-details-button,
.axc-ref-event-links a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 168px !important;
    min-height: 50px !important;
    border-radius: 999px !important;
    padding: 12px 22px !important;
    font-size: 0.94rem !important;
    line-height: 1.1 !important;
    font-weight: 850 !important;
    letter-spacing: 0.035em !important;
    text-decoration: none !important;
    text-align: center !important;
    white-space: nowrap !important;
    transition: background-color .18s ease, color .18s ease, border-color .18s ease, transform .18s ease, box-shadow .18s ease !important;
}

/* Primary: Register Now */
.axc-ref-register-button,
.axc-ref-event-card-v37 .axc-ref-register-button {
    background: var(--axc-event-primary-accent) !important;
    border: 1px solid var(--axc-event-primary-accent) !important;
    color: var(--axc-event-primary-accent-text) !important;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--axc-event-primary-accent) 20%, transparent) !important;
    text-transform: uppercase !important;
}

.axc-ref-register-button:hover,
.axc-ref-event-card-v37 .axc-ref-register-button:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 14px 28px color-mix(in srgb, var(--axc-event-primary-accent) 26%, transparent) !important;
}

/* Secondary: Event Details / Learn More as outline button */
.axc-ref-event-links {
    margin-top: 0 !important;
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px !important;
}

.axc-ref-event-links a,
.axc-ref-details-button,
.axc-ref-event-card-v37 .axc-ref-event-links a {
    background: transparent !important;
    border: 1.5px solid var(--axc-event-primary-accent) !important;
    color: var(--axc-event-primary-accent) !important;
    box-shadow: none !important;
    text-transform: none !important;
}

.axc-ref-event-links a:hover,
.axc-ref-details-button:hover,
.axc-ref-event-card-v37 .axc-ref-event-links a:hover {
    background: color-mix(in srgb, var(--axc-event-primary-accent) 8%, transparent) !important;
    color: var(--axc-event-primary-accent) !important;
    transform: translateY(-1px) !important;
}

/* If Learn More currently appears inside the content column, make it button-like but do not overcrowd text */
.axc-ref-event-main .axc-ref-event-links {
    margin-top: 14px !important;
}

/* If the details link and register button are both in the action column, center them */
.axc-ref-event-action .axc-ref-event-links {
    justify-content: center !important;
}

/* Make the right action column slightly narrower now that buttons are compact */
.axc-events-list > .axc-ref-event-card-v37,
.axc-events-list > .axc-ref-event-card {
    grid-template-columns: 260px minmax(0, 1fr) 215px !important;
}

/* Responsive: put buttons below content cleanly */
@media (max-width: 980px) {
    .axc-ref-event-card-v37 .axc-ref-event-action,
    .axc-ref-event-action {
        align-items: flex-start !important;
        padding: 0 30px 26px !important;
        gap: 10px !important;
    }

    .axc-ref-event-action a,
    .axc-ref-event-card-v37 .axc-ref-event-action a,
    .axc-ref-register-button,
    .axc-ref-details-button,
    .axc-ref-event-links a {
        min-width: 160px !important;
    }
}

@media (max-width: 700px) {
    .axc-ref-event-action a,
    .axc-ref-event-card-v37 .axc-ref-event-action a,
    .axc-ref-register-button,
    .axc-ref-details-button,
    .axc-ref-event-links a {
        width: 100% !important;
        min-width: 0 !important;
    }

    .axc-ref-event-links {
        width: 100% !important;
    }
}


/* v0.1.81 event button/date color system
   Base: v0.1.79 rollback.
   - Register Now uses Accent Color 2.
   - Event Details outline uses Accent Color 2.
   - Event Details hover stays transparent and switches to Accent Color 1.
   - Event date badge uses new Pop Accent Color setting. */

:root {
    --axc-event-primary-accent: var(--axc-primary, #0A1C2F);
    --axc-event-secondary-accent: var(--axc-accent, #0A75A8);
    --axc-event-pop-accent: var(--axc-pop-accent, #F7C948);
}

/* Event date badge now uses the new Pop Accent Color setting */
.axc-ref-event-date-badge,
.axc-events-page-shell .axc-event-date-badge,
.axc-events-page .axc-event-date-badge,
.axc-events-page-shell .axc-event-date,
.axc-events-page .axc-event-date {
    background: var(--axc-event-pop-accent) !important;
    border-color: var(--axc-event-pop-accent) !important;
    color: var(--axc-event-primary-accent) !important;
}

/* Date badge inner typography should inherit the readable first-accent text color */
.axc-ref-event-date-badge *,
.axc-events-page-shell .axc-event-date-badge *,
.axc-events-page .axc-event-date-badge *,
.axc-events-page-shell .axc-event-date *,
.axc-events-page .axc-event-date * {
    color: var(--axc-event-primary-accent) !important;
}

/* Register Now button uses Accent Color 2 */
.axc-ref-register-button,
.axc-ref-event-card-v37 .axc-ref-register-button,
.axc-events-page-shell .axc-event-card-actions a,
.axc-events-page .axc-event-card-actions a,
.axc-events-page-shell .axc-event-actions a,
.axc-events-page .axc-event-actions a,
.axc-events-page-shell .axc-event-card .axc-btn,
.axc-events-page .axc-event-card .axc-btn {
    background: var(--axc-event-secondary-accent) !important;
    border-color: var(--axc-event-secondary-accent) !important;
    color: #ffffff !important;
    box-shadow: 0 10px 22px color-mix(in srgb, var(--axc-event-secondary-accent) 22%, transparent) !important;
}

/* Event Details / Learn More outline button uses Accent Color 2 */
.axc-ref-event-links a,
.axc-ref-details-button,
.axc-ref-event-card-v37 .axc-ref-event-links a {
    background: transparent !important;
    border: 1.5px solid var(--axc-event-secondary-accent) !important;
    color: var(--axc-event-secondary-accent) !important;
    box-shadow: none !important;
}

/* Hover: keep transparent background, switch border/text to Accent Color 1 */
.axc-ref-event-links a:hover,
.axc-ref-details-button:hover,
.axc-ref-event-card-v37 .axc-ref-event-links a:hover {
    background: transparent !important;
    border-color: var(--axc-event-primary-accent) !important;
    color: var(--axc-event-primary-accent) !important;
    box-shadow: none !important;
}

/* Placeholder initial can use Accent Color 2 while date badge uses Pop Accent */
.axc-ref-event-placeholder span {
    color: var(--axc-event-secondary-accent) !important;
}


/* v0.1.82 Homepage Upcoming Events grid
   Replaces the cramped homepage horizontal event carousel presentation with a cleaner 3-column card grid.
   Events archive page remains unchanged. */

.axc-home-events-grid-section,
.axc-carousel-section.axc-events-carousel {
    overflow: visible !important;
}

.axc-home-events-grid-section .axc-carousel-header,
.axc-carousel-section.axc-events-carousel .axc-carousel-header {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between !important;
    gap: 24px !important;
    margin-bottom: clamp(24px, 3vw, 36px) !important;
}

/* Convert only homepage events preview into a 3-card grid */
.axc-home-events-grid-section .axc-carousel-track,
.axc-home-events-grid-section .axc-carousel-grid,
.axc-home-events-grid-section .axc-carousel-viewport,
.axc-carousel-section.axc-events-carousel .axc-carousel-track,
.axc-carousel-section.axc-events-carousel .axc-carousel-grid,
.axc-carousel-section.axc-events-carousel .axc-carousel-viewport {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: clamp(20px, 2vw, 28px) !important;
    overflow: visible !important;
    transform: none !important;
    scroll-snap-type: none !important;
    width: 100% !important;
}

/* Show only first 3 events on homepage preview */
.axc-home-events-grid-section .axc-carousel-track > *:nth-child(n+4),
.axc-home-events-grid-section .axc-carousel-grid > *:nth-child(n+4),
.axc-carousel-section.axc-events-carousel .axc-carousel-track > *:nth-child(n+4),
.axc-carousel-section.axc-events-carousel .axc-carousel-grid > *:nth-child(n+4) {
    display: none !important;
}

/* Hide carousel UI on homepage events preview */
.axc-home-events-grid-section .axc-carousel-controls,
.axc-home-events-grid-section .axc-carousel-dots,
.axc-home-events-grid-section .axc-carousel-arrow,
.axc-carousel-section.axc-events-carousel .axc-carousel-controls,
.axc-carousel-section.axc-events-carousel .axc-carousel-dots,
.axc-carousel-section.axc-events-carousel .axc-carousel-arrow {
    display: none !important;
}

/* Card frame */
.axc-home-events-grid-section .axc-carousel-card,
.axc-home-events-grid-section .axc-event-carousel-card,
.axc-home-events-grid-section .axc-home-event-card,
.axc-carousel-section.axc-events-carousel .axc-carousel-card,
.axc-carousel-section.axc-events-carousel .axc-event-carousel-card,
.axc-carousel-section.axc-events-carousel .axc-home-event-card {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    width: 100% !important;
    min-height: 0 !important;
    border-radius: 28px !important;
    overflow: hidden !important;
    background: #ffffff !important;
    border: 1px solid rgba(10, 28, 47, 0.10) !important;
    box-shadow: 0 18px 45px rgba(10, 28, 47, 0.07) !important;
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease !important;
}

.axc-home-events-grid-section .axc-carousel-card:hover,
.axc-home-events-grid-section .axc-event-carousel-card:hover,
.axc-carousel-section.axc-events-carousel .axc-carousel-card:hover,
.axc-carousel-section.axc-events-carousel .axc-event-carousel-card:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 24px 60px rgba(10, 28, 47, 0.11) !important;
    border-color: color-mix(in srgb, var(--axc-accent, #0A75A8) 28%, #e5e7eb) !important;
}

/* Visual image area */
.axc-home-events-grid-section .axc-carousel-card-media,
.axc-home-events-grid-section .axc-event-card-media,
.axc-home-events-grid-section .axc-event-image,
.axc-home-events-grid-section .axc-event-carousel-image,
.axc-carousel-section.axc-events-carousel .axc-carousel-card-media,
.axc-carousel-section.axc-events-carousel .axc-event-card-media,
.axc-carousel-section.axc-events-carousel .axc-event-image,
.axc-carousel-section.axc-events-carousel .axc-event-carousel-image {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: 230px !important;
    min-height: 230px !important;
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--axc-primary, #0A1C2F) 10%, #f8fafc),
            #eef3f8) !important;
    overflow: hidden !important;
}

.axc-home-events-grid-section .axc-carousel-card img,
.axc-home-events-grid-section .axc-event-carousel-card img,
.axc-carousel-section.axc-events-carousel .axc-carousel-card img,
.axc-carousel-section.axc-events-carousel .axc-event-carousel-card img {
    width: 100% !important;
    height: 230px !important;
    object-fit: cover !important;
    display: block !important;
}

/* If the existing card only has the old vertical date strip, make it act as a visual panel */
.axc-home-events-grid-section .axc-carousel-card > .axc-event-date,
.axc-home-events-grid-section .axc-carousel-card > .axc-event-date-card,
.axc-home-events-grid-section .axc-carousel-card > .axc-carousel-date,
.axc-carousel-section.axc-events-carousel .axc-carousel-card > .axc-event-date,
.axc-carousel-section.axc-events-carousel .axc-carousel-card > .axc-event-date-card,
.axc-carousel-section.axc-events-carousel .axc-carousel-card > .axc-carousel-date {
    min-height: 230px !important;
    height: 230px !important;
    width: 100% !important;
    border-radius: 0 !important;
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--axc-primary, #0A1C2F) 92%, #ffffff),
            color-mix(in srgb, var(--axc-primary, #0A1C2F) 72%, #ffffff)) !important;
    color: #ffffff !important;
}

/* Compact overlay date badge */
.axc-home-events-grid-section .axc-event-date-badge,
.axc-home-events-grid-section .axc-ref-event-date-badge,
.axc-home-events-grid-section .axc-carousel-date-badge,
.axc-carousel-section.axc-events-carousel .axc-event-date-badge,
.axc-carousel-section.axc-events-carousel .axc-ref-event-date-badge,
.axc-carousel-section.axc-events-carousel .axc-carousel-date-badge {
    position: absolute !important;
    top: 18px !important;
    left: 18px !important;
    z-index: 5 !important;
    width: 70px !important;
    height: 70px !important;
    min-height: 70px !important;
    border-radius: 18px !important;
    background: var(--axc-pop-accent, #F7C948) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    box-shadow: 0 14px 30px rgba(10, 28, 47, 0.20) !important;
}

/* Body content */
.axc-home-events-grid-section .axc-carousel-card-body,
.axc-home-events-grid-section .axc-event-card-body,
.axc-home-events-grid-section .axc-event-carousel-content,
.axc-carousel-section.axc-events-carousel .axc-carousel-card-body,
.axc-carousel-section.axc-events-carousel .axc-event-card-body,
.axc-carousel-section.axc-events-carousel .axc-event-carousel-content {
    padding: 26px 28px 28px !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
}

.axc-home-events-grid-section .axc-carousel-card h3,
.axc-home-events-grid-section .axc-event-carousel-card h3,
.axc-home-events-grid-section .axc-event-title,
.axc-carousel-section.axc-events-carousel .axc-carousel-card h3,
.axc-carousel-section.axc-events-carousel .axc-event-carousel-card h3,
.axc-carousel-section.axc-events-carousel .axc-event-title {
    font-size: clamp(1.55rem, 2vw, 2.05rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.035em !important;
    font-weight: 820 !important;
    color: var(--axc-primary, #0A1C2F) !important;
    margin: 0 0 14px !important;
}

.axc-home-events-grid-section .axc-event-meta,
.axc-home-events-grid-section .axc-event-time,
.axc-home-events-grid-section .axc-carousel-meta,
.axc-carousel-section.axc-events-carousel .axc-event-meta,
.axc-carousel-section.axc-events-carousel .axc-event-time,
.axc-carousel-section.axc-events-carousel .axc-carousel-meta {
    font-size: 1rem !important;
    line-height: 1.4 !important;
    font-weight: 700 !important;
    color: #64748b !important;
    margin: 0 0 18px !important;
}

.axc-home-events-grid-section .axc-event-location,
.axc-carousel-section.axc-events-carousel .axc-event-location {
    font-size: 0.96rem !important;
    color: #64748b !important;
    margin-bottom: 18px !important;
}

.axc-home-events-grid-section .axc-carousel-card a,
.axc-home-events-grid-section .axc-event-carousel-card a,
.axc-carousel-section.axc-events-carousel .axc-carousel-card a,
.axc-carousel-section.axc-events-carousel .axc-event-carousel-card a {
    color: var(--axc-accent, #0A75A8) !important;
    font-weight: 850 !important;
    text-decoration: none !important;
}

.axc-home-events-grid-section .axc-event-details-link,
.axc-home-events-grid-section .axc-carousel-card .axc-link,
.axc-carousel-section.axc-events-carousel .axc-event-details-link,
.axc-carousel-section.axc-events-carousel .axc-carousel-card .axc-link {
    margin-top: auto !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 8px !important;
}

@media (max-width: 1100px) {
    .axc-home-events-grid-section .axc-carousel-track,
    .axc-home-events-grid-section .axc-carousel-grid,
    .axc-home-events-grid-section .axc-carousel-viewport,
    .axc-carousel-section.axc-events-carousel .axc-carousel-track,
    .axc-carousel-section.axc-events-carousel .axc-carousel-grid,
    .axc-carousel-section.axc-events-carousel .axc-carousel-viewport {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 700px) {
    .axc-home-events-grid-section .axc-carousel-header,
    .axc-carousel-section.axc-events-carousel .axc-carousel-header {
        display: block !important;
    }

    .axc-home-events-grid-section .axc-carousel-track,
    .axc-home-events-grid-section .axc-carousel-grid,
    .axc-home-events-grid-section .axc-carousel-viewport,
    .axc-carousel-section.axc-events-carousel .axc-carousel-track,
    .axc-carousel-section.axc-events-carousel .axc-carousel-grid,
    .axc-carousel-section.axc-events-carousel .axc-carousel-viewport {
        grid-template-columns: 1fr !important;
    }

    .axc-home-events-grid-section .axc-carousel-card-media,
    .axc-home-events-grid-section .axc-event-card-media,
    .axc-home-events-grid-section .axc-event-image,
    .axc-home-events-grid-section .axc-event-carousel-image,
    .axc-home-events-grid-section .axc-carousel-card img,
    .axc-home-events-grid-section .axc-event-carousel-card img,
    .axc-carousel-section.axc-events-carousel .axc-carousel-card-media,
    .axc-carousel-section.axc-events-carousel .axc-event-card-media,
    .axc-carousel-section.axc-events-carousel .axc-event-image,
    .axc-carousel-section.axc-events-carousel .axc-event-carousel-image,
    .axc-carousel-section.axc-events-carousel .axc-carousel-card img,
    .axc-carousel-section.axc-events-carousel .axc-event-carousel-card img {
        height: 215px !important;
        min-height: 215px !important;
    }
}


/* v0.1.83 Dedicated homepage Upcoming Events grid
   This replaces the old carousel/date-strip output for [axiom_chamber_upcoming_events]. */

.axc-home-events-preview {
    box-sizing: border-box;
    width: min(1380px, calc(100% - clamp(72px, 9vw, 160px)));
    max-width: 1380px;
    margin: clamp(56px, 7vw, 104px) auto;
}

.axc-home-events-preview-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 28px;
    margin-bottom: clamp(24px, 3vw, 38px);
}

.axc-home-events-preview-header h2 {
    margin: 0 0 10px;
    color: var(--axc-primary, #0A1C2F);
    font-size: clamp(2.15rem, 3.6vw, 3.5rem);
    line-height: 1.05;
    letter-spacing: -0.04em;
    font-weight: 850;
}

.axc-home-events-preview-header p {
    margin: 0;
    max-width: 720px;
    color: #64748b;
    font-size: clamp(1.05rem, 1.2vw, 1.22rem);
    line-height: 1.45;
}

.axc-home-section-link {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    white-space: nowrap;
    color: var(--axc-primary, #0A1C2F) !important;
    text-decoration: none !important;
    font-weight: 850;
    letter-spacing: 0.10em;
    text-transform: uppercase;
    font-size: clamp(0.95rem, 1.05vw, 1.12rem);
    padding-bottom: 8px;
    border-bottom: 2px solid transparent;
    transition: color .18s ease, border-color .18s ease, transform .18s ease;
}

.axc-home-section-link:hover {
    color: var(--axc-accent, #0A75A8) !important;
    border-bottom-color: var(--axc-accent, #0A75A8);
    transform: translateX(2px);
}

.axc-home-section-link span:last-child {
    font-size: 1.6em;
    line-height: 0.8;
}

.axc-home-events-preview-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: clamp(20px, 2vw, 30px);
}

.axc-home-event-preview-card {
    overflow: hidden;
    border-radius: 28px;
    background: #fff;
    border: 1px solid rgba(10, 28, 47, 0.10);
    box-shadow: 0 18px 45px rgba(10, 28, 47, 0.07);
    transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.axc-home-event-preview-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 24px 60px rgba(10, 28, 47, 0.11);
    border-color: color-mix(in srgb, var(--axc-accent, #0A75A8) 26%, #e5e7eb);
}

.axc-home-event-preview-media {
    position: relative;
    display: block;
    height: 235px;
    overflow: hidden;
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--axc-primary, #0A1C2F) 12%, #f8fafc),
            #eef3f8);
    text-decoration: none !important;
}

.axc-home-event-image,
.axc-home-event-preview-media img {
    width: 100%;
    height: 235px;
    object-fit: cover;
    display: block;
    transition: transform .24s ease;
}

.axc-home-event-preview-card:hover .axc-home-event-image,
.axc-home-event-preview-card:hover .axc-home-event-preview-media img {
    transform: scale(1.035);
}

.axc-home-event-image-placeholder {
    width: 100%;
    height: 235px;
    display: grid;
    place-items: center;
    background:
        linear-gradient(135deg,
            color-mix(in srgb, var(--axc-primary, #0A1C2F) 96%, #ffffff),
            color-mix(in srgb, var(--axc-primary, #0A1C2F) 72%, #ffffff));
}

.axc-home-event-image-placeholder span {
    width: 86px;
    height: 86px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
    font-size: 2.4rem;
    font-weight: 850;
}

.axc-home-event-date-badge {
    position: absolute;
    top: 18px;
    left: 18px;
    width: 74px;
    height: 74px;
    border-radius: 18px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    background: var(--axc-pop-accent, #F7C948);
    color: var(--axc-primary, #0A1C2F);
    box-shadow: 0 14px 30px rgba(10, 28, 47, 0.22);
    z-index: 2;
}

.axc-home-event-date-month {
    font-size: 0.72rem;
    line-height: 1;
    font-weight: 850;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    opacity: .82;
}

.axc-home-event-date-day {
    margin-top: 4px;
    font-size: 2rem;
    line-height: 1;
    font-weight: 900;
    letter-spacing: -0.04em;
}

.axc-home-event-preview-body {
    padding: 26px 28px 30px;
}

.axc-home-event-preview-time {
    margin-bottom: 12px;
    color: #64748b;
    font-size: 0.98rem;
    line-height: 1.35;
    font-weight: 750;
}

.axc-home-event-preview-body h3 {
    margin: 0 0 14px;
    color: var(--axc-primary, #0A1C2F);
    font-size: clamp(1.45rem, 1.75vw, 1.9rem);
    line-height: 1.1;
    letter-spacing: -0.035em;
    font-weight: 850;
}

.axc-home-event-preview-body h3 a {
    color: inherit !important;
    text-decoration: none !important;
}

.axc-home-event-preview-location {
    margin-bottom: 20px;
    color: #64748b;
    font-size: 0.96rem;
    line-height: 1.4;
    font-weight: 650;
}

.axc-home-event-preview-actions {
    margin-top: 18px;
}

.axc-home-event-details-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    color: var(--axc-accent, #0A75A8) !important;
    text-decoration: none !important;
    font-weight: 850;
    letter-spacing: 0.02em;
    transition: color .18s ease, transform .18s ease;
}

.axc-home-event-details-link:hover {
    color: var(--axc-primary, #0A1C2F) !important;
    transform: translateX(2px);
}

.axc-home-event-details-link span:last-child {
    font-size: 1.3em;
    line-height: .8;
}

/* Hide old carousel version if both render because of theme/plugin cache edge cases */
.axc-home-events-preview + .axc-carousel-section.axc-events-carousel {
    display: none !important;
}

@media (max-width: 1100px) {
    .axc-home-events-preview-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 782px) {
    .axc-home-events-preview {
        width: calc(100% - 24px);
        margin-top: 48px;
        margin-bottom: 64px;
    }

    .axc-home-events-preview-header {
        display: block;
    }

    .axc-home-section-link {
        margin-top: 22px;
    }

    .axc-home-events-preview-grid {
        grid-template-columns: 1fr;
    }

    .axc-home-event-preview-media,
    .axc-home-event-image,
    .axc-home-event-preview-media img,
    .axc-home-event-image-placeholder {
        height: 220px;
    }
}


/* v0.1.84 Homepage event CTA refinement
   - Use a curved/flowing arrow style closer to the reference.
   - Make card-level Event Details smaller and more refined. */

/* Section CTA: View All Events with curved arrow treatment */
.axc-home-section-link {
    gap: 16px !important;
    font-size: clamp(0.86rem, 0.92vw, 1rem) !important;
    letter-spacing: 0.13em !important;
    font-weight: 900 !important;
}

.axc-home-section-link span:last-child,
.axc-home-event-details-link span:last-child {
    position: relative !important;
    display: inline-block !important;
    width: 31px !important;
    height: 16px !important;
    overflow: hidden !important;
    text-indent: -999px !important;
    color: currentColor !important;
}

/* Curved arrow built in CSS so it inherits the link color */
.axc-home-section-link span:last-child::before,
.axc-home-event-details-link span:last-child::before {
    content: "" !important;
    position: absolute !important;
    left: 1px !important;
    top: 7px !important;
    width: 22px !important;
    height: 2.5px !important;
    background: currentColor !important;
    border-radius: 999px !important;
    transform-origin: right center !important;
}

.axc-home-section-link span:last-child::after,
.axc-home-event-details-link span:last-child::after {
    content: "" !important;
    position: absolute !important;
    right: 2px !important;
    top: 4px !important;
    width: 9px !important;
    height: 9px !important;
    border-top: 2.5px solid currentColor !important;
    border-right: 2.5px solid currentColor !important;
    border-radius: 1px !important;
    transform: rotate(45deg) !important;
}

/* Add subtle upward curve mark for a more designed arrow */
.axc-home-section-link span:last-child {
    transform: translateY(1px) !important;
}

.axc-home-section-link:hover span:last-child,
.axc-home-event-details-link:hover span:last-child {
    transform: translateX(3px) translateY(1px) !important;
}

/* Card Event Details: smaller, cleaner, less dominant */
.axc-home-event-details-link {
    gap: 10px !important;
    font-size: 0.98rem !important;
    line-height: 1.1 !important;
    font-weight: 850 !important;
    letter-spacing: 0.03em !important;
}

.axc-home-event-details-link span:last-child {
    width: 26px !important;
    height: 14px !important;
}

.axc-home-event-details-link span:last-child::before {
    top: 6px !important;
    width: 18px !important;
    height: 2.25px !important;
}

.axc-home-event-details-link span:last-child::after {
    top: 3px !important;
    width: 8px !important;
    height: 8px !important;
    border-top-width: 2.25px !important;
    border-right-width: 2.25px !important;
}

/* Slightly tighten card body now that CTA is smaller */
.axc-home-event-preview-actions {
    margin-top: 14px !important;
}

@media (max-width: 782px) {
    .axc-home-section-link {
        font-size: 0.9rem !important;
    }

    .axc-home-event-details-link {
        font-size: 0.95rem !important;
    }
}


/* v0.1.85 homepage width + section title scale refinement
   - Restore wider homepage section rhythm.
   - Reduce homepage section titles by roughly 10-15%. */

/* Widen the new homepage events preview to match the broader homepage sections */
.axc-home-events-preview {
    width: min(1540px, calc(100% - clamp(48px, 7vw, 128px))) !important;
    max-width: 1540px !important;
}

/* Keep the event cards balanced within the wider section */
.axc-home-events-preview-grid {
    gap: clamp(22px, 2.2vw, 34px) !important;
}

/* Section titles across homepage modules: 10-15% smaller */
.axc-home-events-preview-header h2,
.axc-carousel-section h2,
.axc-section-title,
.axc-home-section-title {
    font-size: clamp(2rem, 3.15vw, 3.08rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.04em !important;
}

/* Homepage event title specifically should stay strong but not oversized */
.axc-home-event-preview-body h3 {
    font-size: clamp(1.35rem, 1.55vw, 1.72rem) !important;
    line-height: 1.12 !important;
}

/* Match the top header text width after the section grows */
.axc-home-events-preview-header p {
    max-width: 760px !important;
}

/* Keep View All Events aligned and refined */
.axc-home-section-link {
    font-size: clamp(0.82rem, 0.88vw, 0.96rem) !important;
}

/* Tablet/mobile safety */
@media (max-width: 1100px) {
    .axc-home-events-preview {
        width: min(100% - 40px, 1540px) !important;
    }
}

@media (max-width: 782px) {
    .axc-home-events-preview {
        width: calc(100% - 24px) !important;
        max-width: calc(100% - 24px) !important;
    }

    .axc-home-events-preview-header h2,
    .axc-carousel-section h2,
    .axc-section-title,
    .axc-home-section-title {
        font-size: clamp(2rem, 9vw, 2.8rem) !important;
    }
}


/* v0.1.86 Homepage Upcoming Events cleanup
   Hide location on homepage event cards only. Event archive/detail pages are unchanged. */
.axc-home-events-preview .axc-home-event-preview-location {
    display: none !important;
}


/* v0.1.87 Homepage Upcoming Events width alignment
   Match the same overall section width rhythm used by the rest of the homepage modules. */
.axc-home-events-preview {
    width: min(var(--axc-home-section-width, 1600px), calc(100% - var(--axc-home-section-edge-gap, 176px))) !important;
    max-width: var(--axc-home-section-width, 1600px) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Keep the internal header/grid stretching the full available section width */
.axc-home-events-preview-header,
.axc-home-events-preview-grid {
    width: 100% !important;
}

@media (max-width: 1100px) {
    .axc-home-events-preview {
        width: min(100% - 40px, var(--axc-home-section-width, 1600px)) !important;
        max-width: var(--axc-home-section-width, 1600px) !important;
    }
}

@media (max-width: 782px) {
    .axc-home-events-preview {
        width: calc(100% - 24px) !important;
        max-width: calc(100% - 24px) !important;
    }
}


/* v0.1.88 Homepage Upcoming Events edge alignment
   The section was still capped and centered narrower than Featured Members.
   This removes the cap and uses the same left/right edge rhythm as the rest of the homepage content. */

.axc-home-events-preview {
    width: calc(100% - var(--axc-home-section-edge-gap, 176px)) !important;
    max-width: none !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.axc-home-events-preview-header,
.axc-home-events-preview-grid {
    width: 100% !important;
    max-width: none !important;
}

/* Keep the cards from becoming too wide on very large displays while the section still aligns correctly */
.axc-home-events-preview-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

@media (max-width: 1100px) {
    .axc-home-events-preview {
        width: calc(100% - 40px) !important;
        max-width: none !important;
    }
}

@media (max-width: 782px) {
    .axc-home-events-preview {
        width: calc(100% - 24px) !important;
        max-width: none !important;
    }
}


/* v0.1.90 Homepage modular section edge alignment
   Match header/footer rhythm by breaking out of constrained page wrappers.
   This affects homepage modular sections only, not archive/detail pages. */
body.home .entry-content > .axc-home-events-preview,
body.home .entry-content > .axc-carousel-section,
body.home .entry-content > .axc-home-cta,
body.home .wp-block-post-content > .axc-home-events-preview,
body.home .wp-block-post-content > .axc-carousel-section,
body.home .wp-block-post-content > .axc-home-cta,
body.home .axc-home-events-preview,
body.home .axc-carousel-section.axc-events-carousel,
body.home .axc-carousel-section.axc-members-carousel,
body.home .axc-carousel-section.axc-sponsors-carousel,
body.home .axc-home-cta {
    box-sizing: border-box !important;
    width: calc(100vw - 144px) !important;
    max-width: none !important;
    margin-left: calc(50% - 50vw + 72px) !important;
    margin-right: calc(50% - 50vw + 72px) !important;
}

body.home .axc-home-events-preview-header,
body.home .axc-home-events-preview-grid,
body.home .axc-carousel-section .axc-carousel-header,
body.home .axc-carousel-section .axc-carousel-grid,
body.home .axc-carousel-section .axc-carousel-track,
body.home .axc-home-cta > * {
    max-width: none !important;
}

body.home .axc-home-cta {
    padding-left: clamp(42px, 5vw, 82px) !important;
    padding-right: clamp(42px, 5vw, 82px) !important;
}

@media (max-width: 1100px) {
    body.home .entry-content > .axc-home-events-preview,
    body.home .entry-content > .axc-carousel-section,
    body.home .entry-content > .axc-home-cta,
    body.home .wp-block-post-content > .axc-home-events-preview,
    body.home .wp-block-post-content > .axc-carousel-section,
    body.home .wp-block-post-content > .axc-home-cta,
    body.home .axc-home-events-preview,
    body.home .axc-carousel-section.axc-events-carousel,
    body.home .axc-carousel-section.axc-members-carousel,
    body.home .axc-carousel-section.axc-sponsors-carousel,
    body.home .axc-home-cta {
        width: calc(100vw - 40px) !important;
        margin-left: calc(50% - 50vw + 20px) !important;
        margin-right: calc(50% - 50vw + 20px) !important;
    }
}

@media (max-width: 782px) {
    body.home .entry-content > .axc-home-events-preview,
    body.home .entry-content > .axc-carousel-section,
    body.home .entry-content > .axc-home-cta,
    body.home .wp-block-post-content > .axc-home-events-preview,
    body.home .wp-block-post-content > .axc-carousel-section,
    body.home .wp-block-post-content > .axc-home-cta,
    body.home .axc-home-events-preview,
    body.home .axc-carousel-section.axc-events-carousel,
    body.home .axc-carousel-section.axc-members-carousel,
    body.home .axc-carousel-section.axc-sponsors-carousel,
    body.home .axc-home-cta {
        width: calc(100vw - 24px) !important;
        margin-left: calc(50% - 50vw + 12px) !important;
        margin-right: calc(50% - 50vw + 12px) !important;
    }

    body.home .axc-home-cta {
        padding-left: 24px !important;
        padding-right: 24px !important;
    }
}


/* v0.1.93 Events archive search control refinement
   Match Search Events and Reset button height and add cleaner spacing. */

.axc-events-page-shell .axc-filter-actions,
.axc-events-page-shell .axc-search-actions,
.axc-events-page-shell .axc-events-filter-actions,
.axc-events-page-shell .axc-archive-filter-actions,
.axc-events-page-shell .axc-filter-buttons {
    display: flex !important;
    align-items: center !important;
    gap: 14px !important;
}

/* Normalize both submit and reset links/buttons inside the events filter bar. */
.axc-events-page-shell .axc-filter-bar button,
.axc-events-page-shell .axc-filter-bar input[type="submit"],
.axc-events-page-shell .axc-filter-bar .button,
.axc-events-page-shell .axc-filter-bar a.button,
.axc-events-page-shell .axc-filter-bar a.axc-btn,
.axc-events-page-shell .axc-filter-bar .axc-btn,
.axc-events-page-shell .axc-events-filter button,
.axc-events-page-shell .axc-events-filter input[type="submit"],
.axc-events-page-shell .axc-events-filter .button,
.axc-events-page-shell .axc-events-filter a.button,
.axc-events-page-shell .axc-events-filter a.axc-btn,
.axc-events-page-shell .axc-events-filter .axc-btn,
.axc-events-page-shell form[role="search"] button,
.axc-events-page-shell form[role="search"] input[type="submit"],
.axc-events-page-shell form[role="search"] a.button,
.axc-events-page-shell form[role="search"] a.axc-btn {
    min-height: 58px !important;
    height: 58px !important;
    padding-top: 0 !important;
    padding-bottom: 0 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
    box-sizing: border-box !important;
    white-space: nowrap !important;
}

/* Add spacing even if the buttons are not wrapped in a dedicated action container. */
.axc-events-page-shell .axc-filter-bar input[type="submit"] + a,
.axc-events-page-shell .axc-filter-bar button + a,
.axc-events-page-shell .axc-events-filter input[type="submit"] + a,
.axc-events-page-shell .axc-events-filter button + a,
.axc-events-page-shell form[role="search"] input[type="submit"] + a,
.axc-events-page-shell form[role="search"] button + a {
    margin-left: 14px !important;
}

/* Make Reset visually consistent but still secondary. */
.axc-events-page-shell .axc-filter-bar a,
.axc-events-page-shell .axc-events-filter a,
.axc-events-page-shell form[role="search"] a {
    text-decoration: none !important;
}

/* Mobile: stack controls cleanly and keep matching heights. */
@media (max-width: 782px) {
    .axc-events-page-shell .axc-filter-actions,
    .axc-events-page-shell .axc-search-actions,
    .axc-events-page-shell .axc-events-filter-actions,
    .axc-events-page-shell .axc-archive-filter-actions,
    .axc-events-page-shell .axc-filter-buttons {
        gap: 10px !important;
        flex-wrap: wrap !important;
    }

    .axc-events-page-shell .axc-filter-bar button,
    .axc-events-page-shell .axc-filter-bar input[type="submit"],
    .axc-events-page-shell .axc-filter-bar .button,
    .axc-events-page-shell .axc-filter-bar a.button,
    .axc-events-page-shell .axc-filter-bar a.axc-btn,
    .axc-events-page-shell .axc-filter-bar .axc-btn,
    .axc-events-page-shell .axc-events-filter button,
    .axc-events-page-shell .axc-events-filter input[type="submit"],
    .axc-events-page-shell .axc-events-filter .button,
    .axc-events-page-shell .axc-events-filter a.button,
    .axc-events-page-shell .axc-events-filter a.axc-btn,
    .axc-events-page-shell .axc-events-filter .axc-btn {
        min-height: 54px !important;
        height: 54px !important;
    }
}


/* v0.1.94 Events filter control sizing refinement
   Make Search Events and Reset slimmer with matching font size and visual height. */

.axc-events-page-shell .axc-filter-bar button,
.axc-events-page-shell .axc-filter-bar input[type="submit"],
.axc-events-page-shell .axc-filter-bar .button,
.axc-events-page-shell .axc-filter-bar a.button,
.axc-events-page-shell .axc-filter-bar a.axc-btn,
.axc-events-page-shell .axc-filter-bar .axc-btn,
.axc-events-page-shell .axc-events-filter button,
.axc-events-page-shell .axc-events-filter input[type="submit"],
.axc-events-page-shell .axc-events-filter .button,
.axc-events-page-shell .axc-events-filter a.button,
.axc-events-page-shell .axc-events-filter a.axc-btn,
.axc-events-page-shell .axc-events-filter .axc-btn,
.axc-events-page-shell form[role="search"] button,
.axc-events-page-shell form[role="search"] input[type="submit"],
.axc-events-page-shell form[role="search"] a.button,
.axc-events-page-shell form[role="search"] a.axc-btn {
    min-height: 50px !important;
    height: 50px !important;
    padding: 0 24px !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    letter-spacing: -0.01em !important;
    border-radius: 999px !important;
    box-sizing: border-box !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* Make Reset match Search Events instead of appearing oversized. */
.axc-events-page-shell .axc-filter-bar a,
.axc-events-page-shell .axc-events-filter a,
.axc-events-page-shell form[role="search"] a {
    font-size: 1rem !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    text-decoration: none !important;
}

/* Maintain clean gap between the two buttons. */
.axc-events-page-shell .axc-filter-actions,
.axc-events-page-shell .axc-search-actions,
.axc-events-page-shell .axc-events-filter-actions,
.axc-events-page-shell .axc-archive-filter-actions,
.axc-events-page-shell .axc-filter-buttons {
    gap: 16px !important;
}

/* If the buttons are direct siblings, keep spacing there too. */
.axc-events-page-shell .axc-filter-bar input[type="submit"] + a,
.axc-events-page-shell .axc-filter-bar button + a,
.axc-events-page-shell .axc-events-filter input[type="submit"] + a,
.axc-events-page-shell .axc-events-filter button + a,
.axc-events-page-shell form[role="search"] input[type="submit"] + a,
.axc-events-page-shell form[role="search"] button + a {
    margin-left: 16px !important;
}

/* Slightly slimmer inputs/selects to match the button height better. */
.axc-events-page-shell .axc-filter-bar input[type="text"],
.axc-events-page-shell .axc-filter-bar input[type="search"],
.axc-events-page-shell .axc-filter-bar select,
.axc-events-page-shell .axc-events-filter input[type="text"],
.axc-events-page-shell .axc-events-filter input[type="search"],
.axc-events-page-shell .axc-events-filter select {
    min-height: 50px !important;
    height: 50px !important;
}

/* Mobile safety. */
@media (max-width: 782px) {
    .axc-events-page-shell .axc-filter-bar button,
    .axc-events-page-shell .axc-filter-bar input[type="submit"],
    .axc-events-page-shell .axc-filter-bar .button,
    .axc-events-page-shell .axc-filter-bar a.button,
    .axc-events-page-shell .axc-filter-bar a.axc-btn,
    .axc-events-page-shell .axc-filter-bar .axc-btn,
    .axc-events-page-shell .axc-events-filter button,
    .axc-events-page-shell .axc-events-filter input[type="submit"],
    .axc-events-page-shell .axc-events-filter .button,
    .axc-events-page-shell .axc-events-filter a.button,
    .axc-events-page-shell .axc-events-filter a.axc-btn,
    .axc-events-page-shell .axc-events-filter .axc-btn {
        min-height: 48px !important;
        height: 48px !important;
        width: auto !important;
    }
}


/* v0.1.95 Events archive width/header alignment
   The Events archive header was visually narrower than the site header/nav.
   Use one consistent archive width rhythm for the page intro, filter bar, and results. */

.axc-events-page-shell {
    --axc-archive-wide-width: min(1720px, calc(100vw - clamp(96px, 10vw, 190px)));
}

/* Events archive title/header area */
.axc-events-page-shell .axc-archive-header,
.axc-events-page-shell .axc-page-header,
.axc-events-page-shell .axc-events-header,
.axc-events-page-shell .axc-directory-header {
    width: var(--axc-archive-wide-width) !important;
    max-width: var(--axc-archive-wide-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Events archive content containers */
.axc-events-page-shell .axc-archive-container,
.axc-events-page-shell .axc-events-container,
.axc-events-page-shell .axc-events-list-wrap,
.axc-events-page-shell .axc-events-results,
.axc-events-page-shell .axc-filter-bar,
.axc-events-page-shell .axc-events-filter {
    width: var(--axc-archive-wide-width) !important;
    max-width: var(--axc-archive-wide-width) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

/* Override older hard-coded archive widths from prior builds. */
.axc-events-page-shell .axc-archive-container {
    max-width: var(--axc-archive-wide-width) !important;
}

/* Keep the intro text readable while the container matches header width. */
.axc-events-page-shell .axc-archive-header p,
.axc-events-page-shell .axc-page-header p,
.axc-events-page-shell .axc-events-header p,
.axc-events-page-shell .axc-directory-header p {
    max-width: 900px !important;
}

/* Match the Members page visual rhythm more closely. */
.axc-events-page-shell .axc-archive-header,
.axc-events-page-shell .axc-page-header,
.axc-events-page-shell .axc-events-header,
.axc-events-page-shell .axc-directory-header {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Tablet/mobile safety. */
@media (max-width: 1100px) {
    .axc-events-page-shell {
        --axc-archive-wide-width: calc(100vw - 40px);
    }
}

@media (max-width: 782px) {
    .axc-events-page-shell {
        --axc-archive-wide-width: calc(100vw - 24px);
    }
}


/* v0.1.96 Events filter mobile and sizing cleanup
   Target the actual form class: .axc-event-filters.
   Keep filters inline, not modal, because there are only two controls right now. */

/* Desktop/tablet: normalize actual Events filter controls */
.axc-events-page-shell .axc-event-filters {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    align-items: end !important;
}

.axc-events-page-shell .axc-event-filters .axc-filter-field input,
.axc-events-page-shell .axc-event-filters .axc-filter-field select {
    min-height: 50px !important;
    height: 50px !important;
    font-size: 16px !important;
    line-height: 1.2 !important;
    box-sizing: border-box !important;
}

.axc-events-page-shell .axc-event-filters .axc-filter-actions {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 14px !important;
    flex-wrap: nowrap !important;
    margin: 0 !important;
}

.axc-events-page-shell .axc-event-filters .axc-filter-actions .axc-button,
.axc-events-page-shell .axc-event-filters .axc-filter-actions button.axc-button,
.axc-events-page-shell .axc-event-filters .axc-filter-actions a.axc-button {
    min-height: 50px !important;
    height: 50px !important;
    padding: 0 24px !important;
    font-size: 16px !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    letter-spacing: -0.01em !important;
    border-radius: 999px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    box-sizing: border-box !important;
    width: auto !important;
    min-width: 0 !important;
    margin: 0 !important;
    white-space: nowrap !important;
}

.axc-events-page-shell .axc-event-filters .axc-filter-actions a.axc-button + a,
.axc-events-page-shell .axc-event-filters .axc-filter-actions button + a,
.axc-events-page-shell .axc-event-filters .axc-filter-actions input[type="submit"] + a {
    margin-left: 0 !important;
}

/* Mobile: clean stacked fields, equal buttons, no overlap */
@media (max-width: 782px) {
    .axc-events-page-shell .axc-archive-container {
        width: calc(100% - 32px) !important;
        max-width: calc(100% - 32px) !important;
    }

    .axc-events-page-shell .axc-event-filters {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 18px !important;
        padding: 22px !important;
        border-radius: 24px !important;
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        margin-left: auto !important;
        margin-right: auto !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-field {
        width: 100% !important;
        max-width: 100% !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-field label {
        font-size: 1.25rem !important;
        line-height: 1.1 !important;
        margin-bottom: 10px !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-field input,
    .axc-events-page-shell .axc-event-filters .axc-filter-field select {
        width: 100% !important;
        min-height: 52px !important;
        height: 52px !important;
        font-size: 16px !important;
        line-height: 1.2 !important;
        padding: 0 18px !important;
        border-radius: 16px !important;
        -webkit-text-size-adjust: 100% !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-actions {
        display: grid !important;
        grid-template-columns: 1fr 1fr !important;
        gap: 12px !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 2px 0 0 !important;
        align-items: stretch !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-actions .axc-button,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions button.axc-button,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions a.axc-button {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 52px !important;
        height: 52px !important;
        padding: 0 12px !important;
        font-size: 16px !important;
        line-height: 1 !important;
        font-weight: 800 !important;
        border-radius: 999px !important;
        margin: 0 !important;
        box-sizing: border-box !important;
        white-space: nowrap !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-actions button + a,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions input[type="submit"] + a,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions .axc-button + .axc-button {
        margin-left: 0 !important;
    }

    .axc-events-page-shell .axc-events-current-month {
        font-size: clamp(2.4rem, 11vw, 3.4rem) !important;
        line-height: 1 !important;
        letter-spacing: -0.055em !important;
        margin-top: 42px !important;
    }

    .axc-events-page-shell .axc-directory-count {
        font-size: 1.2rem !important;
        line-height: 1.25 !important;
    }
}

/* Very narrow phones: stack buttons to avoid cramped text */
@media (max-width: 374px) {
    .axc-events-page-shell .axc-event-filters .axc-filter-actions {
        grid-template-columns: 1fr !important;
    }
}


/* v0.1.97 Mobile Events archive CTA refinement
   - Search Events label is now Search in PHP.
   - Make mobile event-card Register Now full width to match Event Details. */

@media (max-width: 782px) {
    /* Keep filter Search and Reset on one row with the shorter Search label. */
    .axc-events-page-shell .axc-event-filters .axc-filter-actions {
        grid-template-columns: 1fr 1fr !important;
        gap: 12px !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-actions .axc-button,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions button.axc-button,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions a.axc-button {
        min-width: 0 !important;
        width: 100% !important;
        font-size: 16px !important;
    }

    /* Mobile event cards: make Register Now full width and aligned with Event Details. */
    .axc-events-page-shell .axc-event-card .axc-event-register,
    .axc-events-page-shell .axc-event-card a.axc-event-register,
    .axc-events-page-shell .axc-event-card .axc-register-button,
    .axc-events-page-shell .axc-event-card a.axc-register-button,
    .axc-events-page-shell .axc-event-card .axc-event-cta,
    .axc-events-page-shell .axc-event-card a.axc-event-cta,
    .axc-events-page-shell .axc-event-card .axc-button-primary,
    .axc-events-page-shell .axc-event-card a.axc-button-primary {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 56px !important;
        height: 56px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        box-sizing: border-box !important;
        border-radius: 999px !important;
        padding-left: 18px !important;
        padding-right: 18px !important;
        white-space: nowrap !important;
    }

    /* If the action wrapper is narrow, let it span the card content width. */
    .axc-events-page-shell .axc-event-card .axc-event-actions,
    .axc-events-page-shell .axc-event-card .axc-card-actions,
    .axc-events-page-shell .axc-event-card .axc-event-card-actions {
        width: 100% !important;
        max-width: 100% !important;
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 14px !important;
    }
}


/* v0.1.98 Events archive header + mobile action fixes
   Fixes the real selectors visible in the browser:
   - .axc-events-page-shell
   - .axc-archive-container
   - .axc-event-filters
   - .axc-ref-event-card
   - .axc-ref-register-button
*/

/* Desktop: match the site header/footer content rhythm instead of the overly-wide v0.1.95 width. */
@media (min-width: 783px) {
    .axc-events-page-shell {
        --axc-archive-wide-width: min(1362px, calc(100vw - 156px)) !important;
    }

    .axc-events-page-shell .axc-archive-container,
    .axc-events-page-shell .axc-archive-hero .axc-archive-container,
    .axc-events-page-shell .axc-archive-content {
        width: var(--axc-archive-wide-width) !important;
        max-width: var(--axc-archive-wide-width) !important;
        margin-left: auto !important;
        margin-right: auto !important;
        padding-left: 0 !important;
        padding-right: 0 !important;
        box-sizing: border-box !important;
    }

    .axc-events-page-shell .axc-archive-hero {
        width: 100vw !important;
        max-width: 100vw !important;
    }
}

/* Desktop/tablet filter actions: real spacing between Search and Reset. */
.axc-events-page-shell .axc-event-filters .axc-filter-actions {
    display: flex !important;
    flex-direction: row !important;
    align-items: end !important;
    justify-content: flex-start !important;
    gap: 18px !important;
    column-gap: 18px !important;
    flex-wrap: nowrap !important;
}

.axc-events-page-shell .axc-event-filters .axc-filter-actions .axc-button + .axc-button,
.axc-events-page-shell .axc-event-filters .axc-filter-actions button + a,
.axc-events-page-shell .axc-event-filters .axc-filter-actions input[type="submit"] + a {
    margin-left: 0 !important;
}

/* Mobile: force Search and Reset inline on one row. */
@media (max-width: 782px) {
    .axc-events-page-shell .axc-event-filters .axc-filter-actions {
        display: flex !important;
        flex-direction: row !important;
        align-items: stretch !important;
        justify-content: stretch !important;
        gap: 12px !important;
        width: 100% !important;
        max-width: 100% !important;
        margin: 4px 0 0 !important;
        padding: 0 !important;
        flex-wrap: nowrap !important;
    }

    .axc-events-page-shell .axc-event-filters .axc-filter-actions .axc-button,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions button.axc-button,
    .axc-events-page-shell .axc-event-filters .axc-filter-actions a.axc-button {
        flex: 1 1 0 !important;
        width: auto !important;
        max-width: none !important;
        min-width: 0 !important;
        min-height: 52px !important;
        height: 52px !important;
        padding: 0 12px !important;
        font-size: 16px !important;
        line-height: 1 !important;
        border-radius: 999px !important;
        margin: 0 !important;
        box-sizing: border-box !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        white-space: nowrap !important;
    }

    /* Override the previous very-small-phone stacking rule. */
    .axc-events-page-shell .axc-event-filters .axc-filter-actions {
        grid-template-columns: none !important;
    }

    /* Mobile event cards: make the real Register Now button full width. */
    .axc-events-page-shell .axc-events-list > .axc-ref-event-card,
    .axc-events-page-shell .axc-events-list > .axc-ref-event-card-v37 {
        display: block !important;
    }

    .axc-events-page-shell .axc-ref-event-action,
    .axc-events-page-shell .axc-ref-event-card-v37 .axc-ref-event-action {
        width: 100% !important;
        max-width: 100% !important;
        padding-left: clamp(24px, 6vw, 34px) !important;
        padding-right: clamp(24px, 6vw, 34px) !important;
        padding-top: 0 !important;
        box-sizing: border-box !important;
        display: block !important;
        border-left: 0 !important;
        border-top: 0 !important;
    }

    .axc-events-page-shell .axc-ref-event-action .axc-ref-register-button,
    .axc-events-page-shell .axc-ref-event-card-v37 .axc-ref-register-button,
    .axc-events-page-shell .axc-ref-register-button {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 58px !important;
        height: 58px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        text-align: center !important;
        border-radius: 999px !important;
        box-sizing: border-box !important;
        padding: 0 18px !important;
        margin: 0 !important;
        white-space: nowrap !important;
    }

    /* Event Details button should remain full width and visually paired with Register Now. */
    .axc-events-page-shell .axc-ref-event-links,
    .axc-events-page-shell .axc-ref-event-card-v37 .axc-ref-event-links {
        width: 100% !important;
    }

    .axc-events-page-shell .axc-ref-event-links a,
    .axc-events-page-shell .axc-ref-event-card-v37 .axc-ref-event-links a {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 58px !important;
        height: 58px !important;
        display: inline-flex !important;
        align-items: center !important;
        justify-content: center !important;
        box-sizing: border-box !important;
    }
}


/* v0.1.103
   Only change: keep Events Register Now button text in title case. */
.axc-events-page-shell .axc-ref-register-button,
.axc-events-page-shell a.axc-ref-register-button,
.axc-ref-register-button,
a.axc-ref-register-button {
    text-transform: none !important;
}


/* v0.1.104
   Single Event mobile order refinement only.
   Desktop layout is unchanged.
   Mobile order:
   title/actions, featured image, info card, details. */

@media (max-width: 782px) {
    body.single-axc_event .axc-event-single-layout,
    body.single-axc_event .axc-single-event-layout,
    body.single-axc_event .axc-event-detail-layout,
    body.axc-event-single-page .axc-event-single-layout,
    body.axc-event-single-page .axc-single-event-layout,
    body.axc-event-single-page .axc-event-detail-layout {
        display: flex !important;
        flex-direction: column !important;
    }

    /* Left/content column should remain first because it contains title and action buttons. */
    body.single-axc_event .axc-event-single-main,
    body.single-axc_event .axc-single-event-main,
    body.single-axc_event .axc-event-detail-main,
    body.axc-event-single-page .axc-event-single-main,
    body.axc-event-single-page .axc-single-event-main,
    body.axc-event-single-page .axc-event-detail-main {
        display: contents !important;
    }

    /* Right/sidebar column becomes contents so image and info card can be ordered independently. */
    body.single-axc_event .axc-event-single-sidebar,
    body.single-axc_event .axc-single-event-sidebar,
    body.single-axc_event .axc-event-detail-sidebar,
    body.axc-event-single-page .axc-event-single-sidebar,
    body.axc-event-single-page .axc-single-event-sidebar,
    body.axc-event-single-page .axc-event-detail-sidebar {
        display: contents !important;
    }

    /* Hero/title/actions remain first. */
    body.single-axc_event .axc-event-single-hero,
    body.single-axc_event .axc-single-event-hero,
    body.single-axc_event .axc-event-detail-hero,
    body.axc-event-single-page .axc-event-single-hero,
    body.axc-event-single-page .axc-single-event-hero,
    body.axc-event-single-page .axc-event-detail-hero {
        order: 1 !important;
    }

    /* Featured image immediately after the action buttons. */
    body.single-axc_event .axc-event-featured-image,
    body.single-axc_event .axc-single-featured-image,
    body.single-axc_event .axc-event-detail-image,
    body.single-axc_event .axc-event-image,
    body.axc-event-single-page .axc-event-featured-image,
    body.axc-event-single-page .axc-single-featured-image,
    body.axc-event-single-page .axc-event-detail-image,
    body.axc-event-single-page .axc-event-image {
        order: 2 !important;
        margin-top: 34px !important;
    }

    /* Info/meta card after image. */
    body.single-axc_event .axc-event-info-card,
    body.single-axc_event .axc-single-event-info,
    body.single-axc_event .axc-event-meta-card,
    body.single-axc_event .axc-event-detail-card,
    body.single-axc_event .axc-event-sidebar-card,
    body.axc-event-single-page .axc-event-info-card,
    body.axc-event-single-page .axc-single-event-info,
    body.axc-event-single-page .axc-event-meta-card,
    body.axc-event-single-page .axc-event-detail-card,
    body.axc-event-single-page .axc-event-sidebar-card {
        order: 3 !important;
        margin-top: 24px !important;
    }

    /* Details move below the image/info card. */
    body.single-axc_event .axc-event-details,
    body.single-axc_event .axc-single-event-details,
    body.single-axc_event .axc-event-detail-content,
    body.single-axc_event .axc-event-content,
    body.axc-event-single-page .axc-event-details,
    body.axc-event-single-page .axc-single-event-details,
    body.axc-event-single-page .axc-event-detail-content,
    body.axc-event-single-page .axc-event-content {
        order: 4 !important;
        margin-top: 34px !important;
    }
}


/* v0.1.105
   Single event mobile order fix using the actual rendered classes:
   .axc-event-detail-layout
   .axc-event-detail-main
   .axc-event-detail-side
   .axc-event-detail-section
   .axc-event-detail-image
   .axc-event-info-card

   Mobile order:
   1. eyebrow/title/buttons
   2. image
   3. info card
   4. details
*/

@media (max-width: 782px) {
    body.axc-event-single-page .axc-event-detail-layout,
    body.single-axc_event .axc-event-detail-layout {
        display: flex !important;
        flex-direction: column !important;
    }

    body.axc-event-single-page .axc-event-detail-main,
    body.single-axc_event .axc-event-detail-main,
    body.axc-event-single-page .axc-event-detail-side,
    body.single-axc_event .axc-event-detail-side {
        display: contents !important;
    }

    body.axc-event-single-page .axc-event-detail-main > .axc-eyebrow,
    body.single-axc_event .axc-event-detail-main > .axc-eyebrow {
        order: 1 !important;
    }

    body.axc-event-single-page .axc-event-detail-main > h1,
    body.single-axc_event .axc-event-detail-main > h1 {
        order: 2 !important;
    }

    body.axc-event-single-page .axc-event-detail-main > .axc-event-detail-actions,
    body.single-axc_event .axc-event-detail-main > .axc-event-detail-actions {
        order: 3 !important;
    }

    body.axc-event-single-page .axc-event-detail-side > .axc-event-detail-image,
    body.single-axc_event .axc-event-detail-side > .axc-event-detail-image {
        order: 4 !important;
        margin-top: 28px !important;
    }

    body.axc-event-single-page .axc-event-detail-side > .axc-event-info-card,
    body.single-axc_event .axc-event-detail-side > .axc-event-info-card {
        order: 5 !important;
        margin-top: 22px !important;
    }

    body.axc-event-single-page .axc-event-detail-main > .axc-event-detail-section,
    body.single-axc_event .axc-event-detail-main > .axc-event-detail-section {
        order: 6 !important;
        margin-top: 34px !important;
    }
}


/* v0.1.106
   Single event mobile spacing and info card width refinement only.
   Keeps v0.1.105 mobile order.
   Desktop unchanged. */

@media (max-width: 782px) {
    /* Reduce excessive vertical whitespace after the title/buttons area. */
    body.axc-event-single-page .axc-event-detail-layout,
    body.single-axc_event .axc-event-detail-layout {
        row-gap: 0 !important;
        gap: 0 !important;
    }

    body.axc-event-single-page .axc-event-detail-main,
    body.single-axc_event .axc-event-detail-main,
    body.axc-event-single-page .axc-event-detail-side,
    body.single-axc_event .axc-event-detail-side {
        gap: 0 !important;
        row-gap: 0 !important;
    }

    /* Image should come closer to the buttons. */
    body.axc-event-single-page .axc-event-detail-side > .axc-event-detail-image,
    body.single-axc_event .axc-event-detail-side > .axc-event-detail-image {
        width: 100% !important;
        max-width: 100% !important;
        margin-top: 28px !important;
        margin-bottom: 0 !important;
        box-sizing: border-box !important;
    }

    body.axc-event-single-page .axc-event-detail-side > .axc-event-detail-image img,
    body.single-axc_event .axc-event-detail-side > .axc-event-detail-image img {
        width: 100% !important;
        max-width: 100% !important;
        display: block !important;
        object-fit: cover !important;
    }

    /* Info card should match the image/content width and sit closer to the image. */
    body.axc-event-single-page .axc-event-detail-side > .axc-event-info-card,
    body.single-axc_event .axc-event-detail-side > .axc-event-info-card {
        width: 100% !important;
        max-width: 100% !important;
        margin-top: 22px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        box-sizing: border-box !important;
        padding: 28px 24px !important;
    }

    /* Details should not feel disconnected from the info card. */
    body.axc-event-single-page .axc-event-detail-main > .axc-event-detail-section,
    body.single-axc_event .axc-event-detail-main > .axc-event-detail-section {
        width: 100% !important;
        max-width: 100% !important;
        margin-top: 36px !important;
        margin-left: 0 !important;
        margin-right: 0 !important;
        box-sizing: border-box !important;
    }

    /* Remove inherited top spacing from the first Details heading if the theme adds block margins. */
    body.axc-event-single-page .axc-event-detail-section > :first-child,
    body.single-axc_event .axc-event-detail-section > :first-child {
        margin-top: 0 !important;
    }
}


/* v0.1.107
   Home page Upcoming Events mobile layout fix only.
   Desktop remains unchanged.
   Mobile cards should stack vertically instead of staying in narrow columns. */

@media (max-width: 782px) {
    /* Header row should stack cleanly on mobile. */
    .axc-events-carousel .axc-section-head,
    .axc-upcoming-events .axc-section-head,
    .axc-home-events .axc-section-head,
    .axc-carousel-section.axc-events-carousel .axc-section-head {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 18px !important;
    }

    /* Upcoming Events list/grid should become one column. */
    .axc-events-carousel .axc-carousel-track,
    .axc-events-carousel .axc-events-grid,
    .axc-events-carousel .axc-home-events-grid,
    .axc-events-carousel .axc-cards-grid,
    .axc-upcoming-events .axc-carousel-track,
    .axc-upcoming-events .axc-events-grid,
    .axc-upcoming-events .axc-home-events-grid,
    .axc-home-events .axc-carousel-track,
    .axc-home-events .axc-events-grid,
    .axc-home-events .axc-home-events-grid,
    .axc-carousel-section.axc-events-carousel .axc-carousel-track,
    .axc-carousel-section.axc-events-carousel .axc-events-grid,
    .axc-carousel-section.axc-events-carousel .axc-home-events-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 24px !important;
        overflow: visible !important;
        width: 100% !important;
        max-width: 100% !important;
        transform: none !important;
    }

    /* If the carousel uses flex, force wrapping into a vertical stack. */
    .axc-events-carousel .axc-carousel-items,
    .axc-upcoming-events .axc-carousel-items,
    .axc-home-events .axc-carousel-items,
    .axc-carousel-section.axc-events-carousel .axc-carousel-items {
        display: flex !important;
        flex-direction: column !important;
        gap: 24px !important;
        overflow: visible !important;
        transform: none !important;
        width: 100% !important;
        max-width: 100% !important;
    }

    /* Cards should be full width, not calculated carousel widths. */
    .axc-events-carousel .axc-event-card,
    .axc-events-carousel .axc-home-event-card,
    .axc-events-carousel .axc-ref-event-card,
    .axc-events-carousel .axc-ref-event-card-v37,
    .axc-upcoming-events .axc-event-card,
    .axc-upcoming-events .axc-home-event-card,
    .axc-upcoming-events .axc-ref-event-card,
    .axc-upcoming-events .axc-ref-event-card-v37,
    .axc-home-events .axc-event-card,
    .axc-home-events .axc-home-event-card,
    .axc-home-events .axc-ref-event-card,
    .axc-home-events .axc-ref-event-card-v37,
    .axc-carousel-section.axc-events-carousel .axc-event-card,
    .axc-carousel-section.axc-events-carousel .axc-home-event-card,
    .axc-carousel-section.axc-events-carousel .axc-ref-event-card,
    .axc-carousel-section.axc-events-carousel .axc-ref-event-card-v37 {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        flex: 0 0 auto !important;
        display: block !important;
        box-sizing: border-box !important;
    }

    /* Restore normal card image proportions on mobile. */
    .axc-events-carousel .axc-event-card img,
    .axc-events-carousel .axc-home-event-card img,
    .axc-events-carousel .axc-ref-event-card img,
    .axc-events-carousel .axc-ref-event-card-v37 img,
    .axc-upcoming-events .axc-event-card img,
    .axc-upcoming-events .axc-home-event-card img,
    .axc-home-events .axc-event-card img,
    .axc-home-events .axc-home-event-card img,
    .axc-carousel-section.axc-events-carousel .axc-event-card img,
    .axc-carousel-section.axc-events-carousel .axc-home-event-card img {
        width: 100% !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
        aspect-ratio: 16 / 9 !important;
        object-fit: cover !important;
        display: block !important;
    }

    /* Keep card body readable and prevent text from squeezing. */
    .axc-events-carousel .axc-card-body,
    .axc-events-carousel .axc-event-card-body,
    .axc-events-carousel .axc-home-event-body,
    .axc-upcoming-events .axc-card-body,
    .axc-upcoming-events .axc-event-card-body,
    .axc-home-events .axc-card-body,
    .axc-home-events .axc-event-card-body,
    .axc-carousel-section.axc-events-carousel .axc-card-body,
    .axc-carousel-section.axc-events-carousel .axc-event-card-body,
    .axc-carousel-section.axc-events-carousel .axc-home-event-body {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
    }

    /* Hide carousel overflow behavior on mobile so stacked cards are not clipped. */
    .axc-events-carousel,
    .axc-upcoming-events,
    .axc-home-events,
    .axc-carousel-section.axc-events-carousel {
        overflow: visible !important;
    }
}


/* v0.1.108
   Actual homepage Upcoming Events mobile stack fix.
   Targets the real current classes:
   .axc-home-events-preview
   .axc-home-events-preview-grid
   .axc-home-event-preview-card
   .axc-home-event-preview-media
   Desktop unchanged. */

@media (max-width: 782px) {
    body.home .axc-home-events-preview,
    .axc-home-events-preview {
        width: calc(100% - 48px) !important;
        max-width: calc(100% - 48px) !important;
        margin-left: auto !important;
        margin-right: auto !important;
        overflow: visible !important;
    }

    body.home .axc-home-events-preview-header,
    .axc-home-events-preview-header {
        display: flex !important;
        flex-direction: column !important;
        align-items: flex-start !important;
        gap: 18px !important;
        width: 100% !important;
    }

    body.home .axc-home-events-preview-grid,
    .axc-home-events-preview-grid {
        display: grid !important;
        grid-template-columns: 1fr !important;
        gap: 24px !important;
        width: 100% !important;
        max-width: 100% !important;
        overflow: visible !important;
    }

    body.home .axc-home-event-preview-card,
    .axc-home-event-preview-card {
        width: 100% !important;
        max-width: 100% !important;
        min-width: 0 !important;
        display: block !important;
        box-sizing: border-box !important;
        border-radius: 28px !important;
        overflow: hidden !important;
    }

    body.home .axc-home-event-preview-media,
    .axc-home-event-preview-media {
        width: 100% !important;
        height: auto !important;
        min-height: 0 !important;
        max-height: none !important;
        aspect-ratio: 16 / 9 !important;
        display: block !important;
        overflow: hidden !important;
    }

    body.home .axc-home-event-image,
    body.home .axc-home-event-preview-media img,
    .axc-home-event-image,
    .axc-home-event-preview-media img {
        width: 100% !important;
        height: 100% !important;
        min-height: 0 !important;
        max-height: none !important;
        aspect-ratio: 16 / 9 !important;
        object-fit: cover !important;
        display: block !important;
    }

    body.home .axc-home-event-preview-body,
    .axc-home-event-preview-body {
        width: 100% !important;
        max-width: 100% !important;
        box-sizing: border-box !important;
        padding: 24px 24px 28px !important;
    }

    body.home .axc-home-event-preview-body h3,
    .axc-home-event-preview-body h3 {
        font-size: clamp(1.55rem, 7vw, 2rem) !important;
        line-height: 1.08 !important;
        max-width: 100% !important;
        overflow-wrap: break-word !important;
    }

    body.home .axc-home-event-preview-time,
    .axc-home-event-preview-time {
        font-size: 1rem !important;
        line-height: 1.35 !important;
    }
}

@media (max-width: 420px) {
    body.home .axc-home-events-preview,
    .axc-home-events-preview {
        width: calc(100% - 32px) !important;
        max-width: calc(100% - 32px) !important;
    }
}


/* v0.1.109
   Member directory card refresh.
   Goals:
   - More condensed member cards
   - Category pill instead of membership level
   - No description on cards
   - Full address line
   - Cleaner logo/image presentation inspired by the provided sample
*/

.axc-directory-page-shell .axc-member-card-v109,
.axc-member-card-v109 {
    border: 1px solid #e6edf5 !important;
    border-radius: 22px !important;
    background: #fff !important;
    box-shadow: 0 16px 42px rgba(15, 23, 42, 0.06) !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
    min-height: 0 !important;
}

.axc-directory-page-shell .axc-member-card-v109:hover,
.axc-member-card-v109:hover {
    transform: translateY(-3px) !important;
    box-shadow: 0 24px 55px rgba(15, 23, 42, 0.10) !important;
}

.axc-directory-page-shell .axc-member-card-v109 .axc-card-image,
.axc-member-card-v109 .axc-card-image {
    height: 176px !important;
    min-height: 176px !important;
    padding: 0 !important;
    display: flex !important;
    align-items: stretch !important;
    justify-content: stretch !important;
    background: #f8fafc !important;
    border-bottom: 1px solid #eef2f7 !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
}

.axc-directory-page-shell .axc-member-card-v109 .axc-card-image img,
.axc-member-card-v109 .axc-card-image img {
    width: 100% !important;
    height: 100% !important;
    max-width: none !important;
    max-height: none !important;
    object-fit: cover !important;
    display: block !important;
    transition: transform 220ms ease !important;
}

.axc-directory-page-shell .axc-member-card-v109:hover .axc-card-image img,
.axc-member-card-v109:hover .axc-card-image img {
    transform: scale(1.025) !important;
}

.axc-member-card-v109 .axc-card-image-placeholder {
    width: 100% !important;
    height: 100% !important;
    min-height: 0 !important;
    border-radius: 18px !important;
}

.axc-directory-page-shell .axc-member-card-v109 .axc-card-body,
.axc-member-card-v109 .axc-card-body {
    padding: 22px 24px 24px !important;
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
}

.axc-member-card-v109 .axc-card-topline {
    min-height: 0 !important;
    margin-bottom: 12px !important;
    gap: 8px !important;
}

.axc-member-card-v109 .axc-category-pill,
.axc-member-card-v109 .axc-featured-badge {
    display: inline-flex !important;
    align-items: center !important;
    width: fit-content !important;
    min-height: 28px !important;
    padding: 6px 12px !important;
    border-radius: 999px !important;
    font-size: 0.78rem !important;
    font-weight: 800 !important;
    line-height: 1 !important;
}

.axc-member-card-v109 .axc-category-pill {
    background: color-mix(in srgb, var(--axc-accent-3, #e8eef7) 70%, #ffffff 30%) !important;
    color: var(--axc-accent-1, #0A1C2F) !important;
}

.axc-member-card-v109 .axc-featured-badge {
    background: color-mix(in srgb, var(--axc-accent-4, #f4e7bd) 55%, #ffffff 45%) !important;
    color: var(--axc-accent-1, #0A1C2F) !important;
}

.axc-member-card-v109 h3 {
    margin: 0 0 12px !important;
    font-size: clamp(1.45rem, 2.15vw, 1.85rem) !important;
    line-height: 1.08 !important;
    letter-spacing: -0.045em !important;
}

.axc-member-card-v109 h3 a {
    color: var(--axc-accent-1, #0A1C2F) !important;
    text-decoration: none !important;
}

.axc-member-card-v109 .axc-card-description,
.axc-member-card-v109 .axc-card-category {
    display: none !important;
}

.axc-member-card-v109 .axc-card-location {
    margin: 0 0 16px !important;
    color: #56657a !important;
    font-weight: 650 !important;
    font-size: 1rem !important;
    line-height: 1.38 !important;
    display: flex !important;
    align-items: flex-start !important;
    gap: 10px !important;
}

.axc-member-card-v109 .axc-card-icon {
    color: var(--axc-primary, #0A1C2F) !important;
    font-weight: 900 !important;
    line-height: 1.25 !important;
    flex: 0 0 auto !important;
}

.axc-member-card-v109 .axc-card-footer {
    margin-top: auto !important;
    padding-top: 18px !important;
    border-top: 1px solid #eef2f7 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 16px !important;
}

.axc-member-card-v109 .axc-card-phone {
    color: var(--axc-accent-1, #0A1C2F) !important;
    font-weight: 850 !important;
    font-size: 1.05rem !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: 9px !important;
}

.axc-member-card-v109 .axc-more-info-button {
    min-height: 46px !important;
    padding: 0 20px !important;
    border-radius: 999px !important;
    font-size: 0.98rem !important;
    font-weight: 850 !important;
    line-height: 1 !important;
    white-space: nowrap !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* More compact directory grid feel on desktop. */
.axc-directory-page-shell .axc-directory {
    gap: 24px !important;
}

@media (max-width: 782px) {
    .axc-directory-page-shell .axc-member-card-v109 .axc-card-image,
    .axc-member-card-v109 .axc-card-image {
        height: 160px !important;
        min-height: 160px !important;
        padding: 0 !important;
    }

    .axc-member-card-v109 .axc-card-footer {
        flex-direction: row !important;
        align-items: center !important;
    }

    .axc-member-card-v109 .axc-more-info-button {
        width: auto !important;
    }
}

@media (max-width: 480px) {
    .axc-member-card-v109 .axc-card-footer {
        flex-direction: column !important;
        align-items: stretch !important;
    }

    .axc-member-card-v109 .axc-card-phone,
    .axc-member-card-v109 .axc-more-info-button {
        width: 100% !important;
        justify-content: center !important;
    }
}


/* v0.1.110 member card icon + image refinements */
.axc-member-card-v109 .axc-card-icon {
    width: 18px !important;
    min-width: 18px !important;
    height: 18px !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    line-height: 1 !important;
}

.axc-member-card-v109 .axc-card-icon svg {
    width: 18px !important;
    height: 18px !important;
    display: block !important;
}

.axc-member-card-v109 .axc-card-icon--phone {
    color: var(--axc-primary, #0A1C2F) !important;
}

.axc-member-card-v109 .axc-card-icon--location {
    color: var(--axc-primary, #0A1C2F) !important;
    margin-top: 2px !important;
}


/* v0.1.111 member directory refinements */
.axc-directory-filters .axc-button,
.axc-directory-filters .axc-button-secondary {
    font-size: 0.95rem !important;
}

.axc-directory-filters .axc-button {
    white-space: nowrap !important;
}

.axc-directory-filters .axc-button-secondary {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-height: 44px !important;
    padding: 0 20px !important;
    line-height: 1 !important;
    white-space: nowrap !important;
}

.axc-member-card-v109 .axc-category-pill,
.axc-member-card-v109 .axc-featured-badge {
    min-height: 0 !important;
    padding: 4px 16px !important;
    font-size: 0.76rem !important;
    line-height: 1.15 !important;
}

.axc-member-card-v109 .axc-card-location {
    color: #56657a !important;
}

.axc-member-card-v109 .axc-card-location-lines {
    display: flex !important;
    flex-direction: column !important;
    gap: 2px !important;
    min-width: 0 !important;
}

.axc-member-card-v109 .axc-card-location-line {
    display: block !important;
}

.axc-member-card-v109 .axc-card-location-line--street,
.axc-member-card-v109 .axc-card-location-line--locality {
    overflow-wrap: anywhere !important;
}

.axc-member-card-v109 .axc-card-icon,
.axc-member-card-v109 .axc-card-icon--phone,
.axc-member-card-v109 .axc-card-icon--location {
    color: var(--axc-primary, #0A1C2F) !important;
}

@media (max-width: 782px) {
    .axc-filter-field input,
    .axc-filter-field select {
        font-size: 16px !important;
    }

    .axc-directory-filters .axc-button,
    .axc-directory-filters .axc-button-secondary {
        font-size: 0.95rem !important;
    }
}


/* v0.1.112
   Member card CTA refinement:
   - fixes mobile overflow
   - changes CTA from heavy filled pill to a cleaner View Profile arrow style
   - keeps colors tied to plugin variables
*/

.axc-member-card-v109 .axc-card-footer {
    overflow: hidden !important;
}

.axc-member-card-v109 .axc-view-profile-link,
.axc-member-card-v109 .axc-more-info-button {
    width: auto !important;
    max-width: 100% !important;
    min-height: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    color: var(--axc-primary, #0A1C2F) !important;
    box-shadow: none !important;
    font-size: 0.96rem !important;
    font-weight: 850 !important;
    line-height: 1.1 !important;
    text-decoration: none !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 10px !important;
    white-space: nowrap !important;
    box-sizing: border-box !important;
}

.axc-member-card-v109 .axc-view-profile-link:hover,
.axc-member-card-v109 .axc-more-info-button:hover {
    color: var(--axc-primary, #0A1C2F) !important;
    background: transparent !important;
    box-shadow: none !important;
    transform: none !important;
}

@media (max-width: 782px) {
    .axc-member-card-v109 .axc-card-footer {
        align-items: stretch !important;
        overflow: hidden !important;
    }

    .axc-member-card-v109 .axc-view-profile-link,
    .axc-member-card-v109 .axc-more-info-button {
        width: 100% !important;
        max-width: 100% !important;
        min-height: 50px !important;
        padding: 0 18px !important;
        border: 2px solid var(--axc-primary, #0A1C2F) !important;
        border-radius: 999px !important;
        justify-content: center !important;
        box-sizing: border-box !important;
        overflow: hidden !important;
    }
}


/* v0.1.113
   Member card link color refinement:
   Use plugin primary accent color instead of hard-coded blue/fallback blue. */
.axc-member-card-v109 .axc-view-profile-link,
.axc-member-card-v109 .axc-view-profile-link:hover,
.axc-member-card-v109 .axc-more-info-button,
.axc-member-card-v109 .axc-more-info-button:hover,
.axc-member-card-v109 .axc-card-icon,
.axc-member-card-v109 .axc-card-icon--phone,
.axc-member-card-v109 .axc-card-icon--location {
    color: var(--axc-primary, #0A1C2F) !important;
}


/* v0.1.114 desktop member card typography refinement */
@media (min-width: 783px) {
    .axc-member-card-v109 .axc-category-pill,
    .axc-member-card-v109 .axc-featured-badge {
        font-size: 0.72rem !important;
        padding: 4px 14px !important;
    }

    .axc-member-card-v109 h3 {
        margin: 0 0 10px !important;
        font-size: clamp(1.15rem, 1.35vw, 1.45rem) !important;
        line-height: 1.08 !important;
        letter-spacing: -0.035em !important;
    }

    .axc-member-card-v109 .axc-card-location {
        margin: 0 0 14px !important;
        font-size: 0.90rem !important;
        line-height: 1.35 !important;
    }

    .axc-member-card-v109 .axc-card-phone {
        font-size: 0.92rem !important;
    }

    .axc-member-card-v109 .axc-view-profile-link,
    .axc-member-card-v109 .axc-more-info-button {
        font-size: 0.90rem !important;
        gap: 8px !important;
    }
}


/* v0.1.115
   Homepage hero button refinement only.
   - Slimmer hero buttons
   - Secondary hero button uses plugin Accent 2 variable
*/

.axc-full-hero-slider .axc-hero-actions .axc-home-primary,
.axc-full-hero-slider .axc-hero-actions .axc-home-secondary,
.axc-full-hero-slider .axc-hero-actions a,
.axc-hero-slide .axc-hero-actions .axc-home-primary,
.axc-hero-slide .axc-hero-actions .axc-home-secondary,
.axc-hero-slide .axc-hero-actions a {
    min-height: 58px !important;
    padding: 0 30px !important;
    border-radius: 999px !important;
    font-size: clamp(1rem, 1.1vw, 1.12rem) !important;
    font-weight: 850 !important;
    line-height: 1 !important;
}

.axc-full-hero-slider .axc-hero-actions .axc-home-secondary,
.axc-hero-slide .axc-hero-actions .axc-home-secondary {
    background: var(--axc-accent-2, #C7AC6F) !important;
    border-color: var(--axc-accent-2, #C7AC6F) !important;
    color: #ffffff !important;
}

.axc-full-hero-slider .axc-hero-actions .axc-home-secondary:hover,
.axc-hero-slide .axc-hero-actions .axc-home-secondary:hover {
    background: var(--axc-accent-2, #C7AC6F) !important;
    border-color: var(--axc-accent-2, #C7AC6F) !important;
    color: #ffffff !important;
    filter: brightness(0.96);
}

@media (max-width: 782px) {
    .axc-full-hero-slider .axc-hero-actions .axc-home-primary,
    .axc-full-hero-slider .axc-hero-actions .axc-home-secondary,
    .axc-full-hero-slider .axc-hero-actions a,
    .axc-hero-slide .axc-hero-actions .axc-home-primary,
    .axc-hero-slide .axc-hero-actions .axc-home-secondary,
    .axc-hero-slide .axc-hero-actions a {
        min-height: 52px !important;
        padding: 0 24px !important;
        font-size: 1rem !important;
    }
}


/* v0.1.116
   Actual homepage full hero button selectors.
   Fixes v0.1.115 selector miss.
*/

.axc-full-hero-inner .axc-home-actions .axc-home-primary,
.axc-full-hero-inner .axc-home-actions .axc-home-secondary {
    min-height: 56px !important;
    padding: 0 28px !important;
    border-radius: 999px !important;
    font-size: clamp(1rem, 1vw, 1.1rem) !important;
    font-weight: 850 !important;
    line-height: 1 !important;
}

/* Secondary hero button uses Accent 2 from plugin settings */
.axc-full-hero-inner .axc-home-actions .axc-home-secondary {
    background: var(--axc-accent-2, #C7AC6F) !important;
    border-color: var(--axc-accent-2, #C7AC6F) !important;
    color: #ffffff !important;
    backdrop-filter: none !important;
}

.axc-full-hero-inner .axc-home-actions .axc-home-secondary:hover {
    background: var(--axc-accent-2, #C7AC6F) !important;
    border-color: var(--axc-accent-2, #C7AC6F) !important;
    color: #ffffff !important;
    filter: brightness(0.96);
}

@media (max-width: 782px) {
    .axc-full-hero-inner .axc-home-actions .axc-home-primary,
    .axc-full-hero-inner .axc-home-actions .axc-home-secondary {
        min-height: 50px !important;
        padding: 0 22px !important;
        font-size: 0.98rem !important;
    }
}


/* v0.1.118
   Safe More Posts removal support.
   No broad .wp-block-query hiding.
*/
body.single-axc_event [aria-hidden="true"],
body.single-axc_member [aria-hidden="true"],
body.single-axc_sponsor [aria-hidden="true"] {
    display: none !important;
}


/* v0.1.120
   Chamber detail pages: tighten space before footer.
   This replaces the v0.1.119 padding-bottom approach.
   Scoped only to plugin single detail pages.
*/
body.single-axc_event main,
body.single-axc_member main,
body.single-axc_sponsor main,
body.single-axc_event main.wp-block-group,
body.single-axc_member main.wp-block-group,
body.single-axc_sponsor main.wp-block-group {
    padding-bottom: 0 !important;
    margin-bottom: 0 !important;
}

body.single-axc_event main > *:last-child,
body.single-axc_member main > *:last-child,
body.single-axc_sponsor main > *:last-child,
body.single-axc_event .entry-content > *:last-child,
body.single-axc_member .entry-content > *:last-child,
body.single-axc_sponsor .entry-content > *:last-child {
    margin-bottom: 0 !important;
}

/* Reduce Twenty Twenty-Five block gap between main and footer on Chamber detail pages. */
body.single-axc_event .wp-site-blocks,
body.single-axc_member .wp-site-blocks,
body.single-axc_sponsor .wp-site-blocks {
    gap: 0 !important;
}

/* Footer itself should start closer on Chamber detail pages. */
body.single-axc_event footer,
body.single-axc_member footer,
body.single-axc_sponsor footer {
    margin-top: 48px !important;
}

/* If the footer starts with a separator, keep it tight. */
body.single-axc_event footer .wp-block-separator:first-child,
body.single-axc_member footer .wp-block-separator:first-child,
body.single-axc_sponsor footer .wp-block-separator:first-child,
body.single-axc_event footer hr:first-child,
body.single-axc_member footer hr:first-child,
body.single-axc_sponsor footer hr:first-child {
    margin-top: 0 !important;
    margin-bottom: 48px !important;
}

/* If the hidden More Posts container leaves nearby blank block spacing, collapse it. */
body.single-axc_event [aria-hidden="true"],
body.single-axc_member [aria-hidden="true"],
body.single-axc_sponsor [aria-hidden="true"] {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

@media (max-width: 782px) {
    body.single-axc_event footer,
    body.single-axc_member footer,
    body.single-axc_sponsor footer {
        margin-top: 32px !important;
    }

    body.single-axc_event footer .wp-block-separator:first-child,
    body.single-axc_member footer .wp-block-separator:first-child,
    body.single-axc_sponsor footer .wp-block-separator:first-child,
    body.single-axc_event footer hr:first-child,
    body.single-axc_member footer hr:first-child,
    body.single-axc_sponsor footer hr:first-child {
        margin-bottom: 32px !important;
    }
}


/* v0.1.121
   Detail page layout collapse fix.
   The excess blank area is coming from the plugin detail layout section/grid,
   not the footer. Keep the fix scoped to Chamber detail pages.
*/
body.single-axc_event .axc-event-detail-v2,
body.single-axc_member .axc-member-detail-v2,
body.single-axc_sponsor .axc-sponsor-detail-v2 {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

body.single-axc_event .axc-event-detail-container,
body.single-axc_member .axc-member-detail-container,
body.single-axc_sponsor .axc-sponsor-detail-container {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

body.single-axc_event .axc-event-detail-layout,
body.single-axc_member .axc-member-detail-layout,
body.single-axc_sponsor .axc-sponsor-detail-layout {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
    min-height: 0 !important;
    align-items: start !important;
}

/* Collapse large empty space inside the left and right columns. */
body.single-axc_event .axc-event-detail-layout > *,
body.single-axc_member .axc-member-detail-layout > *,
body.single-axc_sponsor .axc-sponsor-detail-layout > * {
    margin-bottom: 0 !important;
}

/* If the details column has a large minimum height, remove it. */
body.single-axc_event .axc-event-detail-main,
body.single-axc_event .axc-event-detail-sidebar,
body.single-axc_member .axc-member-detail-main,
body.single-axc_member .axc-member-detail-sidebar,
body.single-axc_sponsor .axc-sponsor-detail-main,
body.single-axc_sponsor .axc-sponsor-detail-sidebar {
    min-height: 0 !important;
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

/* Keep the footer reasonably close after the plugin detail section. */
body.single-axc_event .entry-content,
body.single-axc_member .entry-content,
body.single-axc_sponsor .entry-content {
    margin-bottom: 0 !important;
    padding-bottom: 0 !important;
}

body.single-axc_event footer,
body.single-axc_member footer,
body.single-axc_sponsor footer {
    margin-top: 36px !important;
}

@media (max-width: 782px) {
    body.single-axc_event footer,
    body.single-axc_member footer,
    body.single-axc_sponsor footer {
        margin-top: 28px !important;
    }
}


/* v0.1.122
   Collapse empty Twenty Twenty-Five template groups after Chamber detail content.
   This is intentionally scoped to Chamber single detail pages.
*/
body.single-axc_event .entry-content + .wp-block-group[aria-hidden="true"],
body.single-axc_member .entry-content + .wp-block-group[aria-hidden="true"],
body.single-axc_sponsor .entry-content + .wp-block-group[aria-hidden="true"],
body.single-axc_event .wp-block-group[aria-hidden="true"],
body.single-axc_member .wp-block-group[aria-hidden="true"],
body.single-axc_sponsor .wp-block-group[aria-hidden="true"] {
    display: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* Reduce visible footer separator spacing on Chamber detail pages. */
body.single-axc_event main + footer,
body.single-axc_member main + footer,
body.single-axc_sponsor main + footer,
body.single-axc_event footer,
body.single-axc_member footer,
body.single-axc_sponsor footer {
    margin-top: 24px !important;
}


/* v0.1.123
   Member detail membership-level badge refinement.
   Use plugin Accent 4 dynamically and add more horizontal padding.
*/
.axc-member-profile-v3 .axc-member-level-badge,
.axc-member-profile-v3 .axc-level-badge,
.axc-member-profile-v3 .axc-membership-level,
.axc-member-profile-v3 .axc-profile-badge,
body.single-axc_member .axc-member-level-badge,
body.single-axc_member .axc-level-badge,
body.single-axc_member .axc-membership-level,
body.single-axc_member .axc-profile-badge {
    background: var(--axc-accent-4, #F4F6FA) !important;
    border-color: var(--axc-accent-4, #F4F6FA) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    padding: 7px 18px !important;
    border-radius: 999px !important;
    line-height: 1 !important;
}


/* v0.1.124
   Actual member detail membership-level badge selector.
   The visible badge in the member profile header is rendered as .axc-member-tier.
*/
body.single-axc_member .axc-member-profile-v3 .axc-member-tier,
body.single-axc_member .axc-member-tier,
.axc-member-profile-v3 .axc-member-tier {
    background: var(--axc-accent-4, #F4F6FA) !important;
    border-color: var(--axc-accent-4, #F4F6FA) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    padding: 7px 20px !important;
    border-radius: 999px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}


/* v0.1.125
   Actual member detail membership badge is .axc-level-pill.
   Use plugin Accent 4 dynamically and improve horizontal padding.
*/
body.single-axc_member .axc-member-profile-v3 .axc-card-topline .axc-level-pill,
body.single-axc_member .axc-member-profile-v3 .axc-level-pill,
.axc-member-profile-v3 .axc-card-topline .axc-level-pill,
.axc-member-profile-v3 .axc-level-pill {
    background: var(--axc-accent-4, #F4F6FA) !important;
    border: 1px solid var(--axc-accent-4, #F4F6FA) !important;
    color: var(--axc-primary, #0A1C2F) !important;
    padding: 7px 22px !important;
    border-radius: 999px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}


/* v0.1.126
   Membership badge uses Accent 4 variable once it is output by PHP.
   Fallback remains subtle only if Accent 4 is not configured.
*/
body.single-axc_member .axc-member-profile-v3 .axc-card-topline .axc-level-pill,
body.single-axc_member .axc-member-profile-v3 .axc-level-pill,
.axc-member-profile-v3 .axc-card-topline .axc-level-pill,
.axc-member-profile-v3 .axc-level-pill {
    background: var(--axc-accent-4, #F4F6FA) !important;
    border-color: var(--axc-accent-4, #F4F6FA) !important;
}


/* v0.1.127
   Member detail membership-level badge now uses the existing plugin pop accent variable.
   This matches the variable already used by the event date badge:
   --axc-event-pop-accent
*/
body.single-axc_member .axc-member-profile-v3 .axc-card-topline .axc-level-pill,
body.single-axc_member .axc-member-profile-v3 .axc-level-pill,
.axc-member-profile-v3 .axc-card-topline .axc-level-pill,
.axc-member-profile-v3 .axc-level-pill {
    background: var(--axc-event-pop-accent, var(--axc-accent-4, #F4F6FA)) !important;
    border-color: var(--axc-event-pop-accent, var(--axc-accent-4, #F4F6FA)) !important;
    color: var(--axc-event-primary-accent, var(--axc-primary, #0A1C2F)) !important;
    padding: 7px 22px !important;
    border-radius: 999px !important;
    line-height: 1 !important;
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
}


/* v0.1.128
   Detail page typography refinement.
   - Single event title and single member business name use the same smaller scale.
   - Member About body text matches the calmer event Details body text scale.
*/

/* Event title + member business name */
body.single-axc_event .axc-event-detail-v2 h1,
body.single-axc_event .axc-event-detail-v2 .axc-event-title,
body.single-axc_event h1.wp-block-post-title,
body.single-axc_member .axc-member-profile-v3 h1,
body.single-axc_member .axc-member-profile-v3 .axc-member-profile-title,
body.single-axc_member h1.wp-block-post-title {
    font-size: clamp(2.65rem, 4.2vw, 4.75rem) !important;
    line-height: 0.98 !important;
    letter-spacing: -0.065em !important;
}

/* Member detail About section body text */
body.single-axc_member .axc-member-profile-v3 .axc-member-about,
body.single-axc_member .axc-member-profile-v3 .axc-member-about p,
body.single-axc_member .axc-member-profile-v3 .axc-profile-about,
body.single-axc_member .axc-member-profile-v3 .axc-profile-about p,
body.single-axc_member .axc-member-profile-v3 .axc-member-description,
body.single-axc_member .axc-member-profile-v3 .axc-member-description p,
body.single-axc_member .axc-member-profile-v3 .axc-card-content p {
    font-size: clamp(1.05rem, 1.05vw, 1.18rem) !important;
    line-height: 1.55 !important;
    letter-spacing: -0.015em !important;
}

/* Keep member section headings polished but not oversized */
body.single-axc_member .axc-member-profile-v3 h2,
body.single-axc_member .axc-member-profile-v3 .axc-card-title {
    font-size: clamp(1.35rem, 1.65vw, 1.9rem) !important;
    line-height: 1.15 !important;
    letter-spacing: -0.04em !important;
}

@media (max-width: 782px) {
    body.single-axc_event .axc-event-detail-v2 h1,
    body.single-axc_event .axc-event-detail-v2 .axc-event-title,
    body.single-axc_event h1.wp-block-post-title,
    body.single-axc_member .axc-member-profile-v3 h1,
    body.single-axc_member .axc-member-profile-v3 .axc-member-profile-title,
    body.single-axc_member h1.wp-block-post-title {
        font-size: clamp(2.35rem, 11vw, 3.65rem) !important;
        line-height: 1.02 !important;
        letter-spacing: -0.055em !important;
    }

    body.single-axc_member .axc-member-profile-v3 .axc-member-about,
    body.single-axc_member .axc-member-profile-v3 .axc-member-about p,
    body.single-axc_member .axc-member-profile-v3 .axc-profile-about,
    body.single-axc_member .axc-member-profile-v3 .axc-profile-about p,
    body.single-axc_member .axc-member-profile-v3 .axc-member-description,
    body.single-axc_member .axc-member-profile-v3 .axc-member-description p,
    body.single-axc_member .axc-member-profile-v3 .axc-card-content p {
        font-size: 1.05rem !important;
        line-height: 1.55 !important;
    }
}


/* v0.1.129
   Corrected detail page typography.
   v0.1.128 made the titles too large on some pages, so this locks them smaller.
*/

/* Single event title + single member business name */
body.single-axc_event h1.wp-block-post-title,
body.single-axc_event .axc-event-detail-v2 h1,
body.single-axc_event .axc-event-detail-v2 .axc-event-title,
body.single-axc_member h1.wp-block-post-title,
body.single-axc_member .axc-member-profile-v3 h1,
body.single-axc_member .axc-member-profile-v3 .axc-member-profile-title {
    font-size: clamp(2.35rem, 3.2vw, 3.65rem) !important;
    line-height: 1.04 !important;
    letter-spacing: -0.055em !important;
}

/* Member About section body text: close to event Details text size */
body.single-axc_member .axc-member-profile-v3 .axc-member-about,
body.single-axc_member .axc-member-profile-v3 .axc-member-about p,
body.single-axc_member .axc-member-profile-v3 .axc-profile-about,
body.single-axc_member .axc-member-profile-v3 .axc-profile-about p,
body.single-axc_member .axc-member-profile-v3 .axc-member-description,
body.single-axc_member .axc-member-profile-v3 .axc-member-description p,
body.single-axc_member .axc-member-profile-v3 .axc-card-content p {
    font-size: 1.05rem !important;
    line-height: 1.58 !important;
    letter-spacing: -0.01em !important;
}

/* Keep member detail card headings controlled */
body.single-axc_member .axc-member-profile-v3 h2,
body.single-axc_member .axc-member-profile-v3 .axc-card-title {
    font-size: clamp(1.25rem, 1.35vw, 1.6rem) !important;
    line-height: 1.18 !important;
    letter-spacing: -0.035em !important;
}

@media (max-width: 782px) {
    body.single-axc_event h1.wp-block-post-title,
    body.single-axc_event .axc-event-detail-v2 h1,
    body.single-axc_event .axc-event-detail-v2 .axc-event-title,
    body.single-axc_member h1.wp-block-post-title,
    body.single-axc_member .axc-member-profile-v3 h1,
    body.single-axc_member .axc-member-profile-v3 .axc-member-profile-title {
        font-size: clamp(2.1rem, 9.2vw, 3.05rem) !important;
        line-height: 1.05 !important;
        letter-spacing: -0.05em !important;
    }

    body.single-axc_member .axc-member-profile-v3 .axc-member-about,
    body.single-axc_member .axc-member-profile-v3 .axc-member-about p,
    body.single-axc_member .axc-member-profile-v3 .axc-profile-about,
    body.single-axc_member .axc-member-profile-v3 .axc-profile-about p,
    body.single-axc_member .axc-member-profile-v3 .axc-member-description,
    body.single-axc_member .axc-member-profile-v3 .axc-member-description p,
    body.single-axc_member .axc-member-profile-v3 .axc-card-content p {
        font-size: 1.05rem !important;
        line-height: 1.58 !important;
    }
}


/* v0.1.130
   Corrected member About selector and made detail titles 10% smaller.
*/

/* Single event title + single member business name: 10% smaller than v0.1.129 */
body.single-axc_event h1.wp-block-post-title,
body.single-axc_event .axc-event-detail-v2 h1,
body.single-axc_event .axc-event-detail-v2 .axc-event-title,
body.single-axc_member h1.wp-block-post-title,
body.single-axc_member .axc-member-profile-v3 h1,
body.single-axc_member .axc-member-profile-v3 .axc-member-profile-title {
    font-size: clamp(2.12rem, 2.88vw, 3.28rem) !important;
    line-height: 1.05 !important;
    letter-spacing: -0.052em !important;
}

/* Actual member About section selector shown in inspector */
body.single-axc_member .axc-member-profile-v3 .axc-member-about-content,
body.single-axc_member .axc-member-profile-v3 .axc-member-about-content p,
body.single-axc_member .axc-member-about-card .axc-member-about-content,
body.single-axc_member .axc-member-about-card .axc-member-about-content p,
body.single-axc_member .axc-member-about-content,
body.single-axc_member .axc-member-about-content p {
    font-size: 1.05rem !important;
    line-height: 1.58 !important;
    letter-spacing: -0.01em !important;
}

/* Keep paragraph spacing clean in the About card */
body.single-axc_member .axc-member-about-content p {
    margin-top: 0 !important;
    margin-bottom: 0.85em !important;
}

body.single-axc_member .axc-member-about-content p:last-child {
    margin-bottom: 0 !important;
}

/* Member card/section headings stay controlled */
body.single-axc_member .axc-member-profile-v3 h2,
body.single-axc_member .axc-member-profile-v3 .axc-card-title,
body.single-axc_member .axc-member-about-card h2 {
    font-size: clamp(1.2rem, 1.25vw, 1.5rem) !important;
    line-height: 1.18 !important;
    letter-spacing: -0.035em !important;
}

@media (max-width: 782px) {
    body.single-axc_event h1.wp-block-post-title,
    body.single-axc_event .axc-event-detail-v2 h1,
    body.single-axc_event .axc-event-detail-v2 .axc-event-title,
    body.single-axc_member h1.wp-block-post-title,
    body.single-axc_member .axc-member-profile-v3 h1,
    body.single-axc_member .axc-member-profile-v3 .axc-member-profile-title {
        font-size: clamp(1.95rem, 8.3vw, 2.75rem) !important;
        line-height: 1.06 !important;
        letter-spacing: -0.048em !important;
    }

    body.single-axc_member .axc-member-profile-v3 .axc-member-about-content,
    body.single-axc_member .axc-member-profile-v3 .axc-member-about-content p,
    body.single-axc_member .axc-member-about-card .axc-member-about-content,
    body.single-axc_member .axc-member-about-card .axc-member-about-content p,
    body.single-axc_member .axc-member-about-content,
    body.single-axc_member .axc-member-about-content p {
        font-size: 1.05rem !important;
        line-height: 1.58 !important;
    }
}
