:root {
    --rcm-primary-purple: #7153b0;
    /* Figma r:0.44 g:0.32 b:0.69 */
    --rcm-secondary-blue: #183354;
    /* Figma r:0.09 g:0.20 b:0.32 */
    --rcm-text-grey: #545e69;
    /* Figma r:0.32 g:0.36 b:0.41 */
    --rcm-light-bg: #fbf9f9;
    /* Figma r:0.98 g:0.97 b:0.97 */
    --rcm-dark-purple: #33205c;
    /* Figma r:0.20 g:0.12 b:0.36 */
    --rcm-white: #ffffff;
    --rcm-black: #000000;
    --rcm-border-grey: #dfdfdf;

    --rcm-font-manrope: 'Manrope', sans-serif;
    --rcm-font-inter: 'Inter', sans-serif;
    --rcm-font-montserrat: 'Montserrat', sans-serif;
    --rcm-font-roboto: 'Roboto', sans-serif;
}

.wwu-page {
    font-family: var(--rcm-font-inter);
    color: var(--rcm-text-grey);
    line-height: 1.5;
    overflow-x: clip;
    /* clip prevents double vertical scrollbars while hiding horizontal overflow */
    background-color: var(--rcm-white);
}

.wwu-container {
    max-width: 1440px;
    margin: 0 auto;
    padding-left: 20px;
    padding-right: 20px;
    box-sizing: border-box;
}

@media (min-width: 1281px) {
    .wwu-container {
        padding-left: 89px;
        padding-right: 120px;
    }
}

/* Hero Section */
.wwu-hero {
    position: relative;
    height: 283px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: url('../images/work-with-us/hero-figma.png') center/cover no-repeat;
    margin: 40px auto 0;
    margin-top: 0px!important;
    max-width: 1280px;
    border-radius: 6px;
    overflow: hidden;
}

.wwu-hero::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background: linear-gradient(-84.32deg, rgba(152, 129, 202, 0) 0.82%, rgb(62, 40, 109) 99.63%);
    z-index: 1;
}

.wwu-hero h1 {
    position: relative;
    color: #FFF;
    font-family: var(--rcm-font-manrope);
    font-size: 28.42px;
    font-style: normal;
    font-weight: 700;
    line-height: 41.208px;
    text-transform: capitalize;
    z-index: 2;
    margin: 0;
    text-align: center;
}

/* Section Common Styles */
.wwu-section {
    padding-top: 75px;
    padding-bottom: 23px;
}

.wwu-section-title {
    font-family: var(--rcm-font-manrope);
    font-size: 25px;
    font-weight: 700;
    color: var(--rcm-secondary-blue);
    margin-top: 0;
    margin-bottom: 24px;
    text-transform: capitalize;
}

#about .wwu-section-title {
    margin-top: 0;
}

.wwu-border {
    display: block;
    width: 100%;
    max-width: 503px;
    height: 6px;
    margin-bottom: 47px;
}

.wwu-section-rule {
    position: relative;
    width: 100%;
    max-width: 503px;
    height: 5px;
    border-top: 1px solid var(--rcm-border-grey);
    border-bottom: 1px solid var(--rcm-border-grey);
    margin-bottom: 38px;
    box-sizing: border-box;
}

.wwu-section-rule-accent {
    position: absolute;
    top: -1px;
    left: 0;
    width: 40px;
    height: 5px;
    background: var(--rcm-primary-purple);
}

.wwu-section-rule-notch {
    position: absolute;
    top: -1.5px;
    left: 36px;
    width: 10px;
    height: 6px;
    background: var(--rcm-white);
    -webkit-mask-image: url('../images/notch-mask.svg');
    mask-image: url('../images/notch-mask.svg');
    -webkit-mask-size: 10px 6px;
    mask-size: 10px 6px;
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: 0 0;
    mask-position: 0 0;
}

/* About Us & Bios */
.wwu-row {
    display: flex;
    gap: 75px;
    align-items: center;
}

.wwu-row.reverse {
    flex-direction: row-reverse;
}

.wwu-col-image {
    position: relative;
    overflow: hidden;
    flex: 0 0 619px;
    width: 619px;
    height: 515px;
    box-sizing: border-box;
}

.wwu-col-text {
    flex: 1;
}

.wwu-col-image img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0;
    box-shadow: none;
    display: block;
    max-width: none;
    max-height: none;
}

.wwu-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--rcm-primary-purple);
    color: var(--rcm-white) !important;
    height: 50px;
    padding: 0 40px;
    border-radius: 13px;
    text-decoration: none;
    font-family: var(--rcm-font-manrope);
    font-weight: 700;
    font-size: 20px;
    margin-top: 43px;
    transition: all 0.3s ease;
}

.wwu-btn:hover {
    background: var(--rcm-dark-purple);
    color: var(--rcm-white) !important;
    text-decoration: none;
    opacity: 0.9;
}

.wwu-col-text p {
    margin-bottom: 24px;
    font-size: 16px;
}

.wwu-col-text p:last-of-type {
    margin-bottom: 0;
}

/* Partnering Section */
.wwu-partnering {
    background: #FBF9F9;
    margin-top: 40px;
    height: auto;
    min-height: 536px;
    padding-top: 44px;
    padding-bottom: 44px;
    box-sizing: border-box;
}

.wwu-partnering .wwu-container {
    padding-left: 0;
    padding-right: 0;
    max-width: 1440px;
    text-align: center;
}

.wwu-partnering-header {
    max-width: 902px;
    margin: 0 auto 55px; /* 44px top padding + 36px title height + 15px gap = 95px from top to paragraph. 95px - 44px = 51px. Let's stick to visually similar spacing */
}

.wwu-partnering-header h2 {
    font-family: var(--rcm-font-manrope);
    font-size: 25px;
    font-weight: 600;
    color: var(--rcm-secondary-blue);
    margin: 0 0 15px 0;
    line-height: 1.44em; /* 36px */
}

.wwu-partnering-header p {
    font-family: var(--rcm-font-inter);
    font-size: 16px;
    line-height: 1.75em; /* 28px */
    color: var(--rcm-text-grey);
    margin: 0;
    text-transform: capitalize;
}

.wwu-features {
    display: flex;
    gap: 59px;
    text-align: left;
    max-width: 1108px; /* 330 * 3 + 59 * 2 = 990 + 118 = 1108 */
    margin: 0 auto;
    justify-content: center;
}

.wwu-feature-item {
    width: 330px;
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.wwu-feature-item .icon-circle {
    width: 32px;
    height: 32px;
    margin-bottom: 0;
    display: block;
}

.wwu-feature-item h3 {
    font-family: var(--rcm-font-manrope);
    font-size: 18px;
    font-weight: 500;
    color: var(--rcm-secondary-blue);
    margin: 0;
    line-height: 2em; /* 36px */
}

.wwu-feature-item p {
    font-family: var(--rcm-font-inter);
    font-size: 16px;
    line-height: 1.5em; /* 24px */
    color: var(--rcm-text-grey);
    margin: 0;
    text-transform: capitalize;
}

/* Trusted Partners Strip */
.wwu-trusted-partners {
    background: var(--rcm-white);
    padding: 80px 0 0 0;
}

.wwu-partners-container {
    background: var(--rcm-light-bg);
    border-radius: 20px;
    padding: 20px 40px;
    display: grid;
    grid-template-columns: minmax(120px, 158px) minmax(0, 1fr);
    grid-template-areas:
        "title logos"
        "title dots";
    column-gap: 50px;
    row-gap: 14px;
    align-items: center;
    min-height: 156px;
    height: auto;
    box-sizing: border-box;
}

.wwu-partners-container h3 {
    grid-area: title;
    align-self: center;
    width: auto;
    max-width: 158px;
    font-family: var(--rcm-font-manrope);
    font-size: 25px;
    font-weight: 700;
    color: var(--rcm-secondary-blue);
    line-height: 36px;
    margin: 0;
}

.wwu-logo-grid {
    grid-area: logos;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: center;
    gap: clamp(20px, 3vw, 30px);
    width: 100%;
    min-width: 0;
    opacity: 0.66;
    box-sizing: border-box;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    cursor: grab;
}

.wwu-logo-grid::-webkit-scrollbar {
    display: none;
}

.wwu-logo-grid.dragging {
    cursor: grabbing;
    scroll-behavior: auto;
    user-select: none;
}

#partners-dots {
    grid-area: dots;
    display: flex;
    justify-self: center;
    width: 100%;
}

.wwu-partners-container #partners-dots {
    margin-top: 0;
}

.wwu-logo-grid > .wwu-logo-link,
.wwu-logo-grid > img {
    flex: 0 0 auto;
    scroll-snap-align: start;
}

.wwu-logo-grid > .wwu-logo-link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
}

.wwu-logo-grid img {
    max-height: 100px;
    max-width: min(120px, 22vw);
    width: auto;
    height: auto;
    object-fit: contain;
    mix-blend-mode: multiply;
}

/* Reach Families Section */
.wwu-reach {
    padding: 86px 0 86px 0;
    text-align: center;
}

.wwu-reach .wwu-section-title {
    font-family: var(--rcm-font-manrope);
    font-size: 25px;
    font-weight: 700;
    margin: 0 0 40px 0;
    line-height: 33px;
}

.wwu-reach-grid {
    display: flex;
    justify-content: center;
    margin: 0 auto 77px;
    max-width: 1231px;
}

.wwu-reach-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    flex-shrink: 0;
}

.wwu-reach-item:nth-child(1) {
    width: 274px;
    margin-right: 42px;
}

.wwu-reach-item:nth-child(2) {
    width: 250px;
    margin-right: 51px;
}

.wwu-reach-item:nth-child(3) {
    width: 250px;
    margin-right: 41px;
}

.wwu-reach-item:nth-child(4) {
    width: 270px;
}

.wwu-reach-item .icon-stack {
    position: relative;
    width: 24px;
    height: 24px;
    margin: 0 auto 23px;
}

.wwu-reach-item h3 {
    font-family: var(--rcm-font-manrope);
    font-size: 18px;
    font-weight: 700;
    color: var(--rcm-dark-purple);
    margin: 0 0 19px 0;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 22px;
}

.wwu-reach-item p {
    font-family: var(--rcm-font-inter);
    font-size: 14px;
    color: var(--rcm-black);
    line-height: 20px;
    margin: 0;
}

.wwu-reach-item:nth-child(4) p {
    font-family: var(--rcm-font-montserrat);
}

/* Support Section */
.wwu-support {
    background: #FBF9F9;
    padding: 44px 0 60px 0;
    text-align: center;
}

.wwu-reach .wwu-btn {
    margin-top: 0;
}

.wwu-support-header {
    max-width: 928px;
    margin: 0 auto 80px;
}

.wwu-support-header h2 {
    font-family: var(--rcm-font-manrope);
    font-size: 25px;
    font-weight: 600;
    color: var(--rcm-secondary-blue);
    margin-bottom: 15px;
    line-height: 1.44em;
}

.wwu-support-header p {
    font-family: var(--rcm-font-inter);
    font-size: 16px;
    line-height: 1.75em;
    color: var(--rcm-text-grey);
    margin: 0;
}

.wwu-support-logos {
    background: var(--rcm-white);
    border-radius: 20px;
    padding: 20px 28px;
    display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
    gap: clamp(24px, 4vw, 48px);
    margin: 0 auto;
    min-height: 156px;
    height: auto;
    box-sizing: border-box;
    opacity: 0.62;
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    cursor: grab;
}

.wwu-support-logos::-webkit-scrollbar {
    display: none;
}

.wwu-support-logos.dragging {
    cursor: grabbing;
    scroll-behavior: auto;
    user-select: none;
}

.wwu-support-logos > .wwu-logo-link,
.wwu-support-logos > img {
    flex: 0 0 auto;
    scroll-snap-align: start;
}

.wwu-support-logos > .wwu-logo-link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
}

.wwu-support-logos img {
    max-height: 114px;
    max-width: min(160px, 40vw);
    width: auto;
    height: auto;
    object-fit: contain;
    mix-blend-mode: multiply;
    transition: opacity 0.3s;
}

.wwu-support-logos img:hover {
    opacity: 1;
}

/* Reviews Section */
.wwu-reviews {
    background: #3E286D;
    padding: 34px 0 76px 0;
    text-align: center;
    position: relative;
}

.wwu-reviews .wwu-section-title {
    color: #FFFFFF;
    font-size: 25px;
    font-weight: 600;
    margin-bottom: 45px;
    line-height: 1.4em;
}

.wwu-reviews-slider,
.wwu-testimonial-grid {
    display: flex;
    gap: 16px;
    overflow-x: auto;
    overflow-y: visible;
    padding: 20px 20px;
    /* Slight padding to show peek */
    scrollbar-width: none;
    width: 100%;
    margin: 0 auto;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    cursor: grab;
    /* Show it can be dragged */
    align-items: flex-start;
}

/* While dragging with JS */
.wwu-reviews-slider.dragging,
.wwu-testimonial-grid.dragging {
    cursor: grabbing;
    scroll-behavior: auto;
    /* Prevent smooth scroll fighting drag */
    user-select: none;
}

.wwu-reviews-slider::-webkit-scrollbar,
.wwu-testimonial-grid::-webkit-scrollbar {
    display: none;
}

.wwu-review-card {
    flex: 0 0 409px;
    height: 175px;
    padding: 15px 22px;
    background: #FFFFFF !important;
    border-radius: 10px;
    text-align: left;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 14px;
    scroll-snap-align: start;
}

.wwu-review-card p {
    font-family: var(--rcm-font-montserrat);
    font-size: 14px;
    color: #000000;
    line-height: 1.214em;
    margin: 0;
}

.wwu-review-content {
    display: flex;
    flex-direction: column;
    gap: 12px;
}

.wwu-review-author {
    display: flex;
    align-items: center;
    gap: 19px;
    margin-top: 0;
}

.wwu-review-author .avatar {
    width: 52px;
    height: 52px;
    background: rgba(168, 139, 232, 0.27);
    border-radius: 50%;
    flex-shrink: 0;
}

.wwu-review-author span {
    font-family: var(--rcm-font-inter);
    font-weight: 600;
    font-size: 18px;
    color: #000000;
}

/* Testimonials Section */
.wwu-testimonials {
    background: #33205C;
    padding: 44px 0 76px 0;
    text-align: center;
    position: relative;
}

.wwu-testimonials .wwu-section-title {
    color: #FFFFFF;
    font-size: 25px;
    font-weight: 600;
    margin-bottom: 16px;
    line-height: 1.4em;
}

.wwu-testimonial-card {
    flex: 0 0 591px;
    min-height: 318px;
    height: auto;
    background: #F7F6FB;
    border-radius: 17.8px;
    text-align: left;
    padding: 30px 32px;
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    scroll-snap-align: start;
    overflow: visible;
}

.wwu-testimonial-content {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    gap: 0;
}

.wwu-testimonial-card .quote {
    font-family: var(--rcm-font-inter);
    font-size: 18px;
    color: #1A1B1D;
    line-height: 1.6;
    letter-spacing: 0.32px;
    margin: 0 0 15px 0;
    display: -webkit-box;
    -webkit-line-clamp: 4;
    -webkit-box-orient: vertical;
    overflow: hidden;
    word-break: break-word;
}

.wwu-testimonial-author {
    display: flex;
    align-items: center;
    gap: 20px;
    margin-top: 0;
}

.wwu-testimonial-author .avatar-bg {
    width: 62.3px;
    height: 62.3px;
    border-radius: 50%;
    background: #F1F1F1;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    flex-shrink: 0;
}

.wwu-testimonial-author .avatar-bg:not(:has(img)) {
    background-color: var(--rcm-dark-purple);
}

.wwu-testimonial-author .avatar-bg img {
    max-width: 80%;
    max-height: 80%;
    object-fit: contain;
}

.wwu-testimonial-author span {
    font-family: var(--rcm-font-inter);
    font-size: 20px;
    font-weight: 600;
    color: #33205C;
}

.wwu-testimonial-card .wwu-read-more-btn {
    color: var(--rcm-dark-purple);
}

.wwu-testimonial-card .wwu-read-more-btn:hover,
.wwu-testimonial-card .wwu-read-more-btn:active,
.wwu-testimonial-card .wwu-read-more-btn:focus {
    color: var(--rcm-dark-purple);
    text-decoration: underline;
}

/* Dots Navigation */
.wwu-slider-dots {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 10px;
    margin-top: 30px;
    height: 15px;
    /* Fixed height container to prevent jumping when dots scale */
}

.wwu-dot {
    width: 10px;
    height: 10px;
    border-radius: 5px;
    background: rgba(255, 255, 255, 0.4);
    cursor: pointer;
    transition: all 0.3s cubic-bezier(0.25, 0.8, 0.25, 1);
}

.wwu-dot:hover {
    background: rgba(255, 255, 255, 0.7);
}

.wwu-dot.active {
    background: #FFFFFF;
    width: 30px;
    /* Expand to pill shape */
    border-radius: 5px;
    box-shadow: 0 0 8px rgba(255, 255, 255, 0.3);
}

/* Darker dots for light backgrounds (Trusted Partners) */
.wwu-partners-container .wwu-dot {
    background: rgba(24, 51, 84, 0.2);
    /* var(--rcm-secondary-blue) */
}

.wwu-partners-container .wwu-dot:hover {
    background: rgba(24, 51, 84, 0.5);
}

.wwu-partners-container .wwu-dot.active {
    background: var(--rcm-secondary-blue);
    box-shadow: 0 0 8px rgba(24, 51, 84, 0.3);
}

.wwu-support .wwu-dot,
.wwu-as-seen-on .wwu-dot {
    background: rgba(24, 51, 84, 0.2);
}

.wwu-support .wwu-dot:hover,
.wwu-as-seen-on .wwu-dot:hover {
    background: rgba(24, 51, 84, 0.5);
}

.wwu-support .wwu-dot.active,
.wwu-as-seen-on .wwu-dot.active {
    background: var(--rcm-secondary-blue);
    box-shadow: 0 0 8px rgba(24, 51, 84, 0.3);
}

#support-dots,
#media-dots {
    display: flex;
}

/* As Seen On Section */
.wwu-as-seen-on {
    padding: 80px 0;
    text-align: center;
}

.wwu-as-seen-on h3 {
    font-family: var(--rcm-font-manrope);
    font-size: 25px;
    font-weight: 600;
    color: var(--rcm-secondary-blue);
    margin-bottom: 40px;
}

.wwu-media-strip {
    background: #FBF9F9;
    border-radius: 20px;
    min-height: 156px;
    height: auto;
    padding: 24px 28px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: nowrap;
    gap: clamp(24px, 4vw, 40px);
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
    box-sizing: border-box;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    scroll-behavior: smooth;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    cursor: grab;
}

.wwu-media-strip::-webkit-scrollbar {
    display: none;
}

.wwu-media-strip.dragging {
    cursor: grabbing;
    scroll-behavior: auto;
    user-select: none;
}

.wwu-media-strip > .wwu-logo-link,
.wwu-media-strip > img {
    flex: 0 0 auto;
    scroll-snap-align: start;
}

.wwu-media-strip > .wwu-logo-link {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    color: inherit;
}

.wwu-media-strip img {
    max-height: 100px;
    max-width: min(130px, 28vw);
    width: auto;
    height: auto;
    object-fit: contain;
    mix-blend-mode: multiply;
    opacity: 0.5;
    transition: opacity 0.3s;
}

.wwu-media-strip img:hover,
.wwu-media-strip .wwu-logo-link:hover img {
    opacity: 1;
}

/* More Topics */
.wwu-more-topics {
    padding: 60px 0;
    text-align: center;
    background: var(--rcm-white);
}

.wwu-more-topics h3 {
    font-family: var(--rcm-font-manrope);
    font-size: 21.33px;
    font-weight: 700;
    color: var(--rcm-secondary-blue);
    margin-bottom: 40px;
}

.wwu-topics-grid {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 40px 60px;
    max-width: 900px;
    margin: 0 auto;
}

.wwu-topic-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 110px;
    text-align: center;
}

.wwu-topic-item img {
    width: 48px;
    height: 48px;
    margin-bottom: 12px;
}

.wwu-topic-item span {
    font-family: var(--rcm-font-manrope);
    font-weight: 700;
    font-size: 15px;
    color: var(--rcm-black);
    line-height: 1.2;
}

/* Newsletter Section */
.wwu-newsletter {
    background: #F5F5F5;
    padding: 60px 0;
}

.newsletter-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 30px;
}

.newsletter-left h3 {
    font-family: var(--rcm-font-manrope);
    font-size: 24px;
    font-weight: 700;
    color: var(--rcm-primary-purple);
    line-height: 1.2;
    margin: 0;
}

.newsletter-form {
    display: flex;
    gap: 15px;
    align-items: center;
}

.newsletter-form .input-group input {
    height: 50px;
    border-radius: 6px;
    border: none;
    padding: 0 20px;
    font-family: var(--rcm-font-inter);
    font-size: 14px;
    color: #6F6F6F;
    width: 200px;
    outline: none;
    box-sizing: border-box;
}

.newsletter-form .wwu-btn {
    height: 50px;
    margin-top: 0;
    border-radius: 4px;
    font-size: 14px;
    padding: 0 30px;
    border: none;
    cursor: pointer;
}

.newsletter-right {
    display: flex;
    align-items: center;
    gap: 22px;
}

.follow-text {
    font-family: var(--rcm-font-manrope);
    font-weight: 700;
    font-size: 18px;
    color: var(--rcm-primary-purple);
}

.social-icons {
    display: flex;
    gap: 10px;
}

.social-icons a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 37px;
    height: 37px;
    background: var(--rcm-primary-purple);
    border-radius: 50%;
    color: var(--rcm-white);
    text-decoration: none;
    font-size: 16px;
    transition: transform 0.2s;
}

.social-icons a:hover {
    transform: translateY(-2px);
}

.social-icons .tiktok-icon {
    width: 14px;
    height: 14px;
    filter: brightness(0) invert(1);
}

/* Responsive */
@media (max-width: 1024px) {
    .wwu-container {
        padding-left: 40px;
        padding-right: 40px;
    }

    /* Reach (#reach): wrap instead of fixed 4-column row that overflows */
    .wwu-reach {
        padding: clamp(48px, 7vw, 86px) 0;
    }

    .wwu-reach .wwu-section-title {
        font-size: clamp(22px, 2.2vw, 25px);
        line-height: 1.3;
        margin-bottom: clamp(28px, 4vw, 40px);
        max-width: min(900px, 100%);
        margin-left: auto;
        margin-right: auto;
    }

    .wwu-reach-grid {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: flex-start;
        gap: clamp(28px, 3.5vw, 40px);
        max-width: 100%;
        width: 100%;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: clamp(48px, 8vw, 77px);
        box-sizing: border-box;
    }

    .wwu-reach-item,
    .wwu-reach-item:nth-child(1),
    .wwu-reach-item:nth-child(2),
    .wwu-reach-item:nth-child(3),
    .wwu-reach-item:nth-child(4) {
        width: auto !important;
        flex: 1 1 min(240px, 100%);
        max-width: min(320px, 100%);
        margin-right: 0 !important;
        box-sizing: border-box;
    }

    .wwu-reach-item h3 {
        font-size: clamp(16px, 1.6vw, 18px);
        min-height: 0;
        line-height: 1.25;
    }

    .wwu-reach-item p {
        font-size: clamp(13px, 1.2vw, 14px);
        line-height: 1.5;
    }

    /* Partnering: align with page gutters; flexible feature columns under 1280px */
    .wwu-partnering .wwu-container {
        padding-left: 40px;
        padding-right: 40px;
        box-sizing: border-box;
    }

    .wwu-partnering-header {
        max-width: min(902px, 100%);
        margin-bottom: clamp(36px, 4vw, 55px);
    }

    .wwu-partnering-header h2 {
        font-size: clamp(22px, 2.2vw, 25px);
        line-height: 1.35;
    }

    .wwu-partnering-header p {
        font-size: clamp(15px, 1.4vw, 16px);
        line-height: 1.65;
        text-transform: none;
    }

    .wwu-features {
        flex-wrap: wrap;
        gap: clamp(28px, 4vw, 48px);
        max-width: 100%;
        justify-content: center;
        align-items: stretch;
    }

    .wwu-feature-item {
        flex: 1 1 min(300px, 100%);
        max-width: min(330px, 100%);
        width: auto;
        min-width: 0;
        box-sizing: border-box;
    }

    .wwu-feature-item p {
        text-transform: none;
    }

    .newsletter-row {
        flex-direction: column;
        text-align: center;
    }

    .newsletter-form {
        flex-direction: column;
        width: 100%;
    }

    .newsletter-form .input-group input {
        width: 100%;
    }
}

/* About / bios: stack at 1280px — avoids crushed two-column + scroll */
@media (max-width: 1024px) {

    .wwu-section .wwu-row,
    .wwu-section .wwu-row.reverse {
        flex-direction: column;
        gap: 40px;
        align-items: center;
    }

    /* Image first, then text (natural DOM order) */
    .wwu-section .wwu-row.reverse .wwu-col-text {
        order: 0;
    }

    .wwu-section .wwu-col-image {
        flex: 0 0 auto;
        width: 100%;
        max-width: min(619px, 100%);
        min-width: 0;
        height: auto;
        aspect-ratio: 619 / 515;
    }

    .wwu-section .wwu-col-text {
        display: flex;
        flex-direction: column;
        align-items: center;
        text-align: center;
        flex: 1 1 auto;
        max-width: 100%;
        width: 100%;
        min-width: 0;
        overflow: visible;
        max-height: none;
    }

    .wwu-section .wwu-section-title {
        margin-bottom: 20px;
        line-height: 1.25;
    }

    .wwu-section .wwu-section-rule {
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 28px;
        max-width: min(503px, 100%);
    }

    .wwu-section .wwu-col-text p {
        max-width: 38rem;
        margin-left: auto;
        margin-right: auto;
    }

    .wwu-section .wwu-btn {
        margin-top: 28px;
    }
}

@media (max-width: 1024px) {

    .wwu-reach-grid {
        flex-direction: column;
        gap: 40px;
        align-items: center;
    }

    .wwu-features {
        flex-direction: column;
        gap: 36px;
        align-items: center;
        text-align: center;
        max-width: 40rem;
        width: 100%;
    }

    .wwu-feature-item {
        flex: none;
        width: 100%;
        max-width: 40rem;
    }

    .wwu-feature-item p {
        text-transform: none;
    }

    .wwu-feature-item .icon-circle {
        margin: 0 auto 15px auto;
    }

    .wwu-partnering-header {
        margin-bottom: 40px;
    }

    .wwu-partnering-header h2 {
        line-height: 1.3;
    }

    .wwu-partnering-header p {
        text-transform: none;
    }

    .wwu-partners-container {
        grid-template-columns: 1fr;
        grid-template-areas:
            "title"
            "logos"
            "dots";
        justify-items: center;
        row-gap: 24px;
        column-gap: 0;
    }

    .wwu-reach-item {
        width: 100% !important;
        margin-right: 0 !important;
        flex: none !important;
        max-width: min(40rem, 100%);
    }

    .wwu-reach .wwu-btn {
        width: 100%;
        max-width: min(320px, 100%);
    }

    .wwu-media-strip {
        justify-content: center;
    }

    .wwu-partners-container {
        height: auto;
        padding: 40px 20px;
    }

    .wwu-partners-container h3 {
        max-width: 80%;
        font-size: 22px;
        line-height: 30px;
        text-align: center;
        margin: 0 auto;
    }

    .wwu-logo-grid {
        justify-content: center;
        width: 100%;
        padding-bottom: 0;
        gap: 20px;
    }

    .wwu-logo-grid img {
        max-width: min(120px, 28vw);
    }

    .wwu-review-card,
    .wwu-testimonial-card {
        flex: 0 0 90%;
    }
}

@media (max-width: 768px) {
    .wwu-container {
        padding-left: 20px;
        padding-right: 20px;
    }

    .wwu-section {
        padding-top: 36px;
        padding-bottom: 36px;
    }

    #about {
        scroll-margin-top: 96px;
    }

    .wwu-section .wwu-section-title {
        font-size: 22px;
        margin-bottom: 18px;
    }

    .wwu-section .wwu-col-text p {
        font-size: 15px;
        line-height: 1.65;
        margin-bottom: 20px;
    }

    .wwu-section .wwu-btn {
        margin-top: 24px;
        width: 100%;
        max-width: 280px;
        height: 48px;
        font-size: 18px;
        padding: 0 28px;
    }

    .wwu-hero {
        height: 180px;
        margin-top: 20px;
        border-radius: 0;
    }

    .wwu-hero h1 {
        font-size: 28px;
    }

    .wwu-row,
    .wwu-row.reverse {
        flex-direction: column !important;
        gap: 28px;
    }

    /* Mobile: image first, then text (already set at 1280px, kept for clarity) */
    .wwu-section .wwu-row.reverse .wwu-col-text {
        order: 0;
    }

    .wwu-reach-grid {
        gap: 28px;
    }

    .wwu-col-image,
    .wwu-col-text {
        flex: 1 1 auto;
        width: 100%;
        max-width: 100%;
    }

    .wwu-col-image {
        max-width: 619px;
        margin-left: auto;
        margin-right: auto;
        aspect-ratio: 619 / 515;
        height: auto;
    }

    .wwu-border {
        width: 100%;
        max-width: 503px;
        /* Allow shrinking but not growing past original */
        margin-bottom: 30px;
    }

    .wwu-section-rule {
        width: 100%;
        max-width: 503px;
        margin-bottom: 30px;
    }

    .wwu-partnering {
        height: auto;
        min-height: 0;
        margin-top: 24px;
        padding-top: 32px;
        padding-bottom: 32px;
    }

    .wwu-partnering .wwu-container {
        padding-left: 20px;
        padding-right: 20px;
    }

    .wwu-partnering-header {
        margin-bottom: 28px;
    }

    .wwu-partnering-header h2 {
        font-size: 21px;
        margin-bottom: 12px;
    }

    .wwu-partnering-header p {
        font-size: 15px;
        line-height: 1.65;
        text-transform: none;
    }

    .wwu-features {
        gap: 28px;
        max-width: 100%;
    }

    .wwu-feature-item {
        max-width: 100%;
        gap: 12px;
    }

    .wwu-feature-item h3 {
        font-size: 17px;
        line-height: 1.35;
    }

    .wwu-feature-item p {
        font-size: 15px;
        line-height: 1.6;
        text-transform: none;
    }

    .wwu-support {
        padding: 40px 0;
    }

    .wwu-support-header {
        margin-bottom: 40px;
    }

    .wwu-support-logos {
        padding: 20px 16px;
        gap: 20px;
        min-height: 140px;
    }

    .wwu-media-strip {
        padding: 20px 16px;
        gap: 20px;
        min-height: 140px;
        justify-content: center;
    }

    .wwu-about-box {
        position: static;
        width: 100%;
        transform: none;
        margin-top: -20px;
    }

    .wwu-review-card {
        flex: 0 0 calc(100% - 40px);
        /* 100% width minus the 20px padding on each side of the slider container */
        height: auto;
        min-height: 175px;
        justify-content: space-between;
    }

    .wwu-review-card .quote {
        display: -webkit-box;
        -webkit-line-clamp: 4;
        -webkit-box-orient: vertical;
        overflow: hidden;
    }

    .wwu-review-card .quote.expanded {
        display: block;
        -webkit-line-clamp: unset;
        overflow: visible;
    }
    
    .wwu-testimonial-card {
        flex: 0 0 90%; /* Show part of next card */
        margin-right: 16px; /* Gap between cards */
        scroll-snap-align: center;
        min-height: auto; /* Allow height to adjust */
        height: auto;
    }
    
    .wwu-testimonials .wwu-section-title {
        font-size: 20px;
        margin-bottom: 20px;
    }

    .wwu-testimonial-author {
        gap: 12px;
    }

    .wwu-testimonial-author .avatar-bg {
        width: 40px;
        height: 40px;
    }

    .wwu-testimonial-author span {
        font-size: 16px;
    }
}

.wwu-testimonial-card .quote.expanded {
    display: block;
    max-height: none;
    -webkit-line-clamp: unset;
    -webkit-box-orient: unset;
    overflow: visible;
}

.wwu-read-more-btn {
    background: none;
    border: none;
    color: var(--rcm-primary-purple);
    font-family: var(--rcm-font-inter);
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    padding: 0;
    margin-bottom: 20px;
    display: none; /* Hidden by default, shown via JS if needed */
    text-align: center;
    width: 100%;
}

.wwu-read-more-btn:hover,
.wwu-read-more-btn:active,
.wwu-read-more-btn:focus {
    background: none;
    outline: none;
    text-decoration: underline;
    color:var(--rcm-dark-purple);
}

.wwu-read-more-btn--review {
    display: none;
}

/* Logo carousels: one row only; horizontal scroll when viewport is narrow */
.wwu-logo-grid,
.wwu-support-logos,
.wwu-media-strip {
    flex-wrap: nowrap;
    scroll-padding-inline: 0;
}

.wwu-logo-grid.is-scrollable,
.wwu-support-logos.is-scrollable,
.wwu-media-strip.is-scrollable {
    justify-content: flex-start;
}
