.text-columns-with-image-section {
    --container-padding: 20px;
    --container-max-width: 1200px;
    --desktop-image-gap: 16px;
    --desktop-image-vertical-padding: 0px;
    --desktop-logo-max-height: 56px;

    /* Consistent logo boxes so wide logos (Entrepreneur) scale down */
    --as-seen-logo-box-width-desktop: 180px;
    --as-seen-logo-box-width-mobile: clamp(72px, 15vw, 120px);

    background-color: rgb(var(--color-background));
    width: 100%;
    overflow: hidden;
}

/* Container */
.text-columns-with-image__container {
    width: 100%;
    margin: 0 auto;
    padding: 0 var(--container-padding);
    max-width: var(--container-max-width);
}

/* Mobile image height (kept for non-logo usages) */
.text-columns-with-image-section[data-mobile-image-height="300px"] {
    --mobile-image-height: 300px;
}

.text-columns-with-image-section[data-mobile-image-height="400px"] {
    --mobile-image-height: 400px;
}

.text-columns-with-image-section[data-mobile-image-height="500px"] {
    --mobile-image-height: 500px;
}

/* Heading */
.text-columns-with-image__heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
}

/* Title alignment utilities */
.text-columns-with-image__heading-title.align-left {
    text-align: left;
}

.text-columns-with-image__heading-title.align-center {
    text-align: center;
}

.text-columns-with-image__heading-title.align-right {
    text-align: right;
}

.text-columns-with-image__heading-title {
    display: block;
    width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* Heading font size utilities */
.text-columns-with-image__heading-title.title2 {
    font-size: var(--title2-font-size, 32px);
    line-height: var(--title2-line-height, 1.2);
    font-weight: var(--title2-font-weight, 800);
}

.text-columns-with-image__heading-title.title4 {
    font-size: var(--title4-font-size, 24px);
    line-height: var(--title4-line-height, 1.3);
    font-weight: var(--title4-font-weight, 800);
}

.text-columns-with-image__heading-title.title5 {
    font-size: var(--title5-font-size, 20px);
    line-height: var(--title5-line-height, 1.4);
    font-weight: var(--title5-font-weight, 800);
}

.text-columns-with-image__heading-link {
    display: flex;
    column-gap: 8px;
    align-items: center;
    justify-content: center;
    font-size: var(--body1-font-size);
    color: rgb(var(--color-text));
    text-align: var(--card-group-content-align);
}

.text-columns-with-image__heading-link-text {
    display: inline-flex;
}

@media (max-width: 959px) {
    .text-columns-with-image__heading-link-text {
        display: none;
    }
}

/* Group wrappers (NO mobile carousel / NO mobile scroll snapping) */
.text-columns-with-image__card-group-scroll {
    width: 100%;
    margin: 0;
    padding-block: var(--desktop-image-vertical-padding);
    overflow: visible;
}

/* Default card-group layout (for “normal” card grids) */
.text-columns-with-image__card-group {
    display: grid;
    grid-template-columns: repeat(var(--desktop-columns, 3), minmax(0, 1fr));
    gap: var(--card-group-gap, 20px);
    align-items: start;
}

/* Cards */
.text-columns-with-image__card {
    display: flex;
    flex-direction: column;
    gap: 15px;
    width: 100%;
    text-align: var(--card-group-content-align);
}

.text-columns-with-image__card-image {
    display: flex;
    align-items: center;
    justify-content: center;
    order: 1;
    width: 100%;
}

.text-columns-with-image__card-image img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: var(--card-group-image-border-radius);
}

.text-columns-with-image__card-title {
    order: 2;
    margin-block-start: 5px;
    font-style: normal;
}

.text-columns-with-image__card-text {
    order: 3;
}

.text-columns-with-image__card-link {
    display: flex;
    align-items: center;
    order: 4;
}

.text-columns-with-image__card-link .button--link {
    column-gap: 4px;
    text-decoration: none !important;
}

.text-columns-with-image__card-link-icon {
    display: inline-flex;
}

.text-columns-with-image__card-link-icon>svg {
    width: 10px;
    height: 10px;
}

.text-columns-with-image__card-link-icon>svg path {
    stroke: rgb(var(--color-text));
}

/* =========================================================
   AS SEEN IN / FEATURED ON
   - Apply the SAME layout on mobile + desktop (scaled down)
   ========================================================= */

/* Inline: heading next to logos */
.as-seen-in-desktop-inline .text-columns-with-image__container {
    display: grid !important;
    grid-template-columns: max-content 1fr;
    align-items: center;
    column-gap: clamp(16px, 4vw, 48px);
}

.as-seen-in-desktop-inline .text-columns-with-image__heading {
    width: auto;
    padding: 0;
    justify-content: flex-start;
    white-space: nowrap;
}

.as-seen-in-desktop-inline .text-columns-with-image__heading-title {
    width: auto;
    white-space: nowrap;
    text-overflow: unset;
    overflow: visible;
}

.as-seen-in-desktop-inline .text-columns-with-image__heading-link {
    display: none;
}

/* Stacked: heading above logos */
.as-seen-in-desktop-stacked .text-columns-with-image__heading-link {
    display: none;
}

/* Logos row (applies to both inline + stacked) */
.as-seen-in-desktop-inline .text-columns-with-image__card-group-scroll,
.as-seen-in-desktop-stacked .text-columns-with-image__card-group-scroll {
    width: 100%;
    max-width: none;
    margin: 0;
    padding: 0;
    overflow: visible;
    padding-block: var(--desktop-image-vertical-padding);
}

.as-seen-in-desktop-inline .text-columns-with-image__card-group,
.as-seen-in-desktop-stacked .text-columns-with-image__card-group {
    display: flex !important;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    width: 100%;

    grid: none;
    grid-template-columns: none;
    grid-auto-flow: initial;
    grid-auto-columns: initial;

    gap: var(--desktop-image-gap);
}

.as-seen-in-desktop-inline .text-columns-with-image__card,
.as-seen-in-desktop-stacked .text-columns-with-image__card {
    width: auto;
    min-width: 0;
    flex: 0 1 auto;
}

.as-seen-in-desktop-inline .text-columns-with-image__card-image,
.as-seen-in-desktop-stacked .text-columns-with-image__card-image {
    width: var(--as-seen-logo-box-width-desktop);
    justify-content: center;
}

.as-seen-in-desktop-inline .text-columns-with-image__card-image img,
.as-seen-in-desktop-stacked .text-columns-with-image__card-image img {
    width: 100%;
    height: auto;
    max-height: var(--desktop-logo-max-height);
    max-width: 100%;
    object-fit: contain;
    aspect-ratio: auto;
}

/* Mobile: keep the SAME row layout, just scale logos down + equalize width */
@media (max-width: 959px) {

    .as-seen-in-desktop-inline .text-columns-with-image__card-image,
    .as-seen-in-desktop-stacked .text-columns-with-image__card-image {
        width: var(--as-seen-logo-box-width-mobile);
    }

    /* Prevent the “full-width images” option from blowing logos up on mobile */
    .as-seen-in-desktop-inline.full-width-images .text-columns-with-image__card-image img,
    .as-seen-in-desktop-stacked.full-width-images .text-columns-with-image__card-image img {
        width: 100%;
        margin: 0;
        max-width: 100%;
    }
}

/* =========================================================
   Typography (hard-set font families)
   ========================================================= */
.text-columns-with-image-section .text-columns-with-image__heading-title,
.text-columns-with-image-section .text-columns-with-image__card-title {
    font-family: "Brother Bold", sans-serif;
}

.text-columns-with-image-section .text-columns-with-image__heading-link,
.text-columns-with-image-section .text-columns-with-image__card-text,
.text-columns-with-image-section .text-columns-with-image__card-link,
.text-columns-with-image-section .text-columns-with-image__card-link .button,
.text-columns-with-image-section .text-columns-with-image__card-link .button--link,
.text-columns-with-image-section .shopline-element-buy-now {
    font-family: "FraktionMono", "FraktionMono Bold", monospace;
}

/* Keep button components inheriting */
.text-columns-with-image-section .button,
.text-columns-with-image-section .shopline-element-buy-now {
    font-family: inherit;
}