/* ==========================================================================
   Blocks Stylesheet
   Block-specific styles for all ACF flexible content layouts.
   Uses native CSS nesting where appropriate.
   ========================================================================== */

/* ==========================================================================
   Block Base Styles
   ========================================================================== */

.block {
    position: relative;
}

/* ==========================================================================
   Background Variations
   Consolidated heading/link colors for dark backgrounds
   ========================================================================== */

/* Light backgrounds */
.block--bg-white {
    background-color: transparent;
    color: var(--color-dark-gray);
}

.block--bg-light {
    background-color: var(--color-light-gray);
    color: var(--color-dark-gray);
}

.block--bg-cream {
    background-color: var(--color-cream);
    color: var(--color-dark-gray);
}

/* Dark backgrounds - base styles */
.block--bg-dark {
    background-color: var(--color-dark-gray);
    color: var(--color-white);
}

.block--bg-primary {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.block--bg-secondary {
    background-color: var(--color-secondary);
    color: var(--color-white);
}

.block--bg-image {
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    color: var(--color-white);
}

/* Consolidated: Heading colors for dark backgrounds */
:is(.block--bg-dark, .block--bg-primary, .block--bg-secondary, .block--bg-image) :is(h1, h2, h3, h4, h5, h6) {
    color: var(--color-white);
}

/* Link styles for dark backgrounds */
.block--bg-dark a:not(.btn) {
    color: var(--color-primary-light);

    &:hover {
        color: var(--color-white);
    }
}

.block--bg-primary a:not(.btn) {
    color: var(--color-white);
    text-decoration: underline;

    &:hover {
        opacity: 0.8;
    }
}

/* ==========================================================================
   Spacing Variations
   ========================================================================== */

/* Combined (top + bottom) */
.block--spacing-none { padding-top: 0; padding-bottom: 0; }
.block--spacing-small { padding-top: var(--spacing-3xl); padding-bottom: var(--spacing-xl); }
.block--spacing-default { padding-top: var(--spacing-4xl); padding-bottom: var(--spacing-4xl); }
.block--spacing-large { padding-top: var(--spacing-5xl); padding-bottom: var(--spacing-5xl); }

/* Top only */
.block--spacing-top-none { padding-top: 0; }
.block--spacing-top-small { padding-top: var(--spacing-2xl); }
.block--spacing-top-default { padding-top: var(--spacing-3xl); }
.block--spacing-top-large { padding-top: var(--spacing-4xl); }

/* Bottom only */
.block--spacing-bottom-none { padding-bottom: 0; }
.block--spacing-bottom-small { padding-bottom: var(--spacing-2xl); }
.block--spacing-bottom-default { padding-bottom: var(--spacing-4xl); }
.block--spacing-bottom-large { padding-bottom: var(--spacing-5xl); }

/* Responsive spacing - consolidated media query */
@media (max-width: 768px) {
    /* Reduce default and large spacing on mobile */
    .block--spacing-default { padding-top: var(--spacing-3xl); padding-bottom: var(--spacing-3xl); }
    .block--spacing-large { padding-top: var(--spacing-4xl); padding-bottom: var(--spacing-4xl); }
    
    .block--spacing-top-default { padding-top: var(--spacing-3xl); }
    .block--spacing-top-large { padding-top: var(--spacing-4xl); }
    
    .block--spacing-bottom-default { padding-bottom: var(--spacing-3xl); }
    .block--spacing-bottom-large { padding-bottom: var(--spacing-4xl); }
}

/* Block overlay for background images */
.block__overlay {
    position: absolute;
    inset: 0;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 1;
}

.block > .container {
    position: relative;
    z-index: 2;
}

/* First block on page needs extra padding for fixed header (only for solid headers, not transparent)
   Note: page-title and hero blocks handle their own header offset, so they're excluded */
body:not(.has-transparent-header) .site-main > .block:first-child:not(.block-page-title):not(.block-hero) {
    padding-top: calc(80px + var(--spacing-4xl));
}

@media (max-width: 768px) {
    body:not(.has-transparent-header) .site-main > .block:first-child:not(.block-page-title):not(.block-hero) {
        padding-top: calc(70px + var(--spacing-3xl));
    }
}

/* ==========================================================================
   YouTube Embed (Shortcode)
   ========================================================================== */

.youtube-embed {
    position: relative;
    width: 100%;
    padding-bottom: 56.25%; /* 16:9 aspect ratio */
    height: 0;
    overflow: hidden;
    border-radius: var(--radius-lg);
}

.youtube-embed iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: 0;
}

/* ==========================================================================
   Page Content (Fallback when no page builder)
   ========================================================================== */

.page-content {
    padding: var(--spacing-4xl) 0;
    
    .page-header {
        margin-bottom: var(--spacing-2xl);
    }
    
    .page-title {
        margin-bottom: var(--spacing-md);
    }
    
    .page-featured-image {
        margin-bottom: var(--spacing-2xl);
        
        img {
            width: 100%;
            height: auto;
            border-radius: var(--radius-lg);
        }
    }
}

/* Note: .entry-content base styles are defined in style.css */

/* ==========================================================================
   Breadcrumbs
   ========================================================================== */

.breadcrumbs {
    padding: var(--spacing-md) 0;
    font-size: var(--text-sm);
    color: var(--color-gray);
}

.breadcrumb-list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-sm);
    list-style: none;
    margin: 0;
    padding: 0;
}

.breadcrumb-item {
    margin: 0;

    a {
        color: var(--color-gray);

        &:hover {
            color: var(--color-primary);
        }
    }
}

.breadcrumb-item--active {
    color: var(--color-dark-gray);
}

.breadcrumb-separator {
    color: var(--color-gray);
}

/* ==========================================================================
   Pagination
   ========================================================================== */

.pagination {
    margin-top: var(--spacing-3xl);
    
    .page-numbers {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: var(--spacing-xs);
        list-style: none;
        margin: 0;
        padding: 0;
    }
    
    a, span {
        display: flex;
        align-items: center;
        justify-content: center;
        min-width: 40px;
        height: 40px;
        padding: 0 var(--spacing-sm);
        border: 1px solid var(--color-gray);
        border-radius: var(--radius-md);
        font-weight: var(--font-medium);
        color: var(--color-mid-gray);
        transition: all var(--transition-fast);
    }
    
    a:hover {
        border-color: var(--color-primary);
        color: var(--color-primary);
    }
    
    .current {
        background-color: var(--color-primary);
        border-color: var(--color-primary);
        color: var(--color-white);
    }
}

/* ==========================================================================
   Hero Block
   ========================================================================== */

/* Hero SVG animation */
@keyframes hero-svg-breathe {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.05);
    }
    100% {
        transform: scale(1);
    }
}

.block-hero {
    position: relative;
    background-color: var(--color-dark-gray);
    color: var(--color-white);
    padding-top: calc(80px + var(--spacing-4xl));
    padding-bottom: 0;
    overflow: hidden;

    @media (max-width: 768px) {
        padding-top: calc(70px + var(--spacing-3xl));
    }
}

.block-hero__lines {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
    animation: hero-svg-breathe 15s ease-in-out infinite;
}

.block-hero__lines-svg {
    position: absolute;
    top: 0;
    right: 50%;
    transform: translate(48%, -6%);
    width: auto;
    height: auto;
    min-width: 1918px;
    color: var(--color-white);
}

.block-hero__content {
    position: relative;
    z-index: 2;
    max-width: 900px;
    margin: 0 auto;
    text-align: center;
    padding-bottom: var(--spacing-3xl);
}

.block-hero__headline {
    font-size: var(--text-7xl);
    font-weight: var(--font-semibold);
    line-height: 1.05;
    margin-bottom: var(--spacing-lg);
    color: var(--color-white);

    @media (max-width: 1024px) {
        font-size: var(--text-6xl);
    }

    @media (max-width: 768px) {
        font-size: var(--text-4xl);
    }

    em {
        font-family: var(--font-decorative);
        font-style: normal;
        font-weight: 500;
    }
}

.block-hero__description {
    font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    color: rgba(255, 255, 255, 0.9);
    margin-bottom: var(--spacing-xl);
    max-width: 650px;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.5;
}

.block-hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    justify-content: center;
}

/* Hero buttons - match header button sizing */
.block-hero__ctas .btn {
    padding: var(--spacing-sm) var(--spacing-xl);
    font-size: var(--text-sm);

    @media (min-width: 1024px) {
        font-size: var(--text-base);
    }
}

/* Secondary button - transparent with primary border */
.block-hero__ctas .btn--secondary {
    background-color: transparent;
    border-color: var(--color-primary);
    color: var(--color-white);

    &:hover {
        background-color: var(--color-primary);
        border-color: var(--color-primary);
        color: var(--color-white);
    }
}

.block-hero__carousel-wrapper {
    position: relative;
    padding-top: var(--spacing-xl);
}

.block-hero__carousel {
    position: relative;
    z-index: 2;
    max-width: var(--container-wide);
    margin: 0 auto;
    padding: 0 var(--container-padding);
}

.block-hero__carousel-tab {
    background-color: var(--color-white);
    color: var(--color-dark-gray);
    border: none;
    padding: var(--spacing-xs) var(--spacing-md);
    border-radius: 10px;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    cursor: pointer;
    transition: all var(--transition-fast);

    @media (min-width: 768px) {
        font-size: var(--text-base);
        padding: var(--spacing-sm) var(--spacing-lg);
    }

    &:hover {
        background-color: var(--color-light-gray);
    }
}

.block-hero__carousel-tab--active {
    background-color: var(--color-dark-gray);
    color: var(--color-white);

    &:hover {
        background-color: var(--color-dark-gray);
    }
}

/* Carousel slides container with gradient background */
.block-hero__carousel-slides {
    position: relative;
    z-index: 1;
    border-radius: 30px;
    overflow: hidden;
    padding: var(--spacing-xl) var(--spacing-2xl) 0;

    @media (max-width: 768px) {
        padding: var(--spacing-lg) var(--spacing-lg) 0;
        border-radius: 20px;
    }

    /* Teal gradient background with animation */
    &::before {
        content: '';
        position: absolute;
        top: 50%;
        left: 50%;
        width: 200%;
        height: 120%;
        transform: translate(-50%, -50%);
        background: linear-gradient(90deg, rgb(248, 248, 244) 0%, rgb(170, 226, 219) 100%);
        z-index: 0;
        animation: gradient-shift 10s ease-in-out infinite;
    }
}

.block-hero__slide {
    display: none;
    position: relative;
    z-index: 1;
}

.block-hero__slide--active {
    display: block;
}

.block-hero__slide-link {
    display: block;
    position: relative;
    text-decoration: none;

    &:hover .block-hero__image {
        opacity: 0.85;
    }

    &:hover .block-hero__slide-overlay {
        opacity: 1;
    }
}

.block-hero__slide-image {
    position: relative;
    border-radius: 16px 16px 0 0;
    overflow: hidden;
}

/* Navigation tabs inside gradient container */
.block-hero__carousel-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xl);
    position: relative;
    z-index: 2;
}

.block-hero__image {
    width: 100%;
    height: auto;
    display: block;
    transition: opacity var(--transition-base);
}

.block-hero__slide-overlay {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    background-color: rgba(0, 0, 0, 0.25);
    opacity: 0;
    transition: opacity var(--transition-base);
    border-radius: 16px 16px 0 0;
}

.block-hero__slide-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) var(--spacing-xl);
    background-color: var(--color-primary);
    color: var(--color-white);
    font-weight: var(--font-semibold);
    border-radius: 9999px;
    box-shadow: var(--shadow-lg);
    transition: background-color var(--transition-fast);

    &:hover {
        background-color: var(--color-primary-dark);
    }
}

.block-hero__fade-bg {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 50%;
    background-color: var(--color-white);
    z-index: 1;
}

/* ==========================================================================
   Client Logos Block
   ========================================================================== */

.block-client-logos {
    overflow: hidden;
}

.block-client-logos__headline {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    text-align: center;
    margin-bottom: 0;
    color: var(--color-dark-gray);

    @media (min-width: 768px) {
        font-size: var(--text-2xl);
    }

    strong {
        font-weight: var(--font-bold);
    }
}

.block-client-logos__scroller {
    position: relative;
    width: 100%;
    overflow: hidden;
    padding: var(--spacing-xl) 0;
}

.block-client-logos__track {
    display: flex;
    gap: var(--spacing-xl);
    width: max-content;
    animation: logo-scroll 120s linear infinite;
}

@keyframes logo-scroll {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(-50%);
    }
}

.block-client-logos__item {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-md) var(--spacing-lg);
}

.block-client-logos__logo {
    max-width: 170px;
    max-height: 50px;
    width: auto;
    height: auto;
    object-fit: contain;
    /* No hover effects - logos just scroll smoothly */
}

/* Dark background variant */
.block--bg-dark .block-client-logos__headline {
    color: var(--color-white);
}

.block--bg-dark .block-client-logos__logo {
    filter: brightness(0) invert(1);
}

/* ==========================================================================
   Content Accordion Block
   ========================================================================== */

.block-content-accordion {
    position: relative;
}

.block-content-accordion__header {
    margin-bottom: var(--spacing-3xl);

    @media (min-width: 768px) {
        margin-bottom: var(--spacing-2xl);
    }
}

/* Reduce headline margin when followed by description */
.block-content-accordion__header .block-subtitle:has(+ .block-content-accordion__description) {
    margin-bottom: var(--spacing-sm);
}

.block-content-accordion__description {
    font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    color: var(--color-mid-gray);
    line-height: var(--leading-relaxed);
}

.block--bg-dark .block-content-accordion__description {
    color: rgba(255, 255, 255, 0.8);
}

.block-content-accordion__wrapper {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-2xl);

    @media (min-width: 768px) {
        flex-direction: row;
        align-items: flex-start;
    }
}

.block-content-accordion__nav {
    flex: 0 0 42%;

    @media (min-width: 768px) {
        padding-right: var(--spacing-xl);
    }
}

.block-content-accordion__item {
    border-top: 1px solid var(--color-gray);
    padding: var(--spacing-lg) 0;

    &:first-child {
        border-top: none;
    }
}

.block-content-accordion__trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0;
    padding-right: var(--spacing-xl);
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
}

.block-content-accordion__title {
    font-size: var(--text-2xl);
    font-weight: var(--font-semibold);
    color: rgba(37, 38, 38, 0.5);
    transition: color var(--transition-fast);

    @media (min-width: 1024px) {
        font-size: var(--text-3xl);
    }
}

.block-content-accordion__item--active .block-content-accordion__title {
    color: var(--color-dark-gray);
}

.block-content-accordion__arrow {
    color: var(--color-primary);
    opacity: 0;
    transform: translateX(-200%) scale(0.8);
    transition: all 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
    width: 46px;
    height: 48px;
    flex-shrink: 0;

    svg {
        width: 100%;
        height: 100%;
    }
}

.block-content-accordion__item--active {
    .block-content-accordion__title {
        color: var(--color-dark-gray);
    }

    .block-content-accordion__arrow {
        opacity: 1;
        transform: translateX(0) scale(0.8);
    }

    .block-content-accordion__body {
        height: auto;
        opacity: 1;
        padding-top: var(--spacing-lg);
    }
}

.block-content-accordion__body {
    height: 0;
    padding-top: 0;
    overflow: hidden;
    opacity: 0;
    transition: height 0.4s ease, opacity 0.4s ease, padding-top 0.4s ease;

    &[hidden] {
        display: block;
        visibility: hidden;
    }
}

.block-content-accordion__content {
    font-size: var(--text-base);
    color: var(--color-mid-gray);
    margin-bottom: var(--spacing-md);

    p:last-child {
        margin-bottom: 0;
    }
}

.block-content-accordion__links {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-sm) var(--spacing-lg);
    margin-top: var(--spacing-md);
}

.block-content-accordion__link {
    position: relative;
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-primary);
    text-decoration: none;

    &::before {
        content: '';
        position: absolute;
        bottom: -2px;
        left: 0;
        display: block;
        width: 100%;
        height: 2px;
        background-color: var(--color-primary);
        opacity: 0.3;
        transition: opacity 0.4s ease;
    }

    &::after {
        content: '';
        position: absolute;
        bottom: -2px;
        left: 0;
        display: block;
        width: 0%;
        height: 2px;
        background-color: var(--color-primary);
        transition: width 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
    }

    &:hover {
        color: var(--color-primary-dark);
    }

    &:hover::after {
        width: 100%;
    }
}

.block-content-accordion__cta {
    margin-top: var(--spacing-lg);
}

.block-content-accordion__media {
    flex: 0 0 58%;
    position: relative;
    display: none;

    @media (min-width: 768px) {
        display: block;
        min-height: 500px;
    }

    @media (min-width: 1024px) {
        min-height: 600px;
    }
}

.block-content-accordion__image-wrapper {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    opacity: 0;
    transition: opacity 0.5s ease;
    pointer-events: none;
}

.block-content-accordion__image-wrapper--active {
    position: relative;
    opacity: 1;
    pointer-events: auto;
}

.block-content-accordion__image-container {
    position: relative;
    border-radius: var(--radius-3xl);
    overflow: hidden;
}

.block-content-accordion__image {
    width: 100%;
    height: auto;
    display: block;
}

.block-content-accordion__overlay {
    position: absolute;
    bottom: var(--spacing-lg);
    left: var(--spacing-lg);
    right: var(--spacing-lg);
    background-color: var(--color-white);
    border-radius: var(--radius-2xl);
    padding: var(--spacing-lg);
    box-shadow: var(--shadow-lg);

    @media (min-width: 1024px) {
        padding: var(--spacing-xl);
    }
}

.block-content-accordion__overlay-title {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--color-primary);
    margin-bottom: var(--spacing-md);

    @media (min-width: 1024px) {
        font-size: var(--text-xl);
    }
}

.block-content-accordion__overlay-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-sm);
}

.block-content-accordion__overlay-item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
    font-size: var(--text-sm);
    color: var(--color-dark-gray);
    margin: 0;

    @media (min-width: 1024px) {
        font-size: var(--text-base);
    }
}

.block-content-accordion__check-icon {
    flex-shrink: 0;
    color: var(--color-primary);
    margin-top: 2px;
}

/* ==========================================================================
   Blog Posts Block
   ========================================================================== */

.block-blog-posts__headline {
    margin: 0 0 var(--spacing-md) 0;
    color: var(--color-dark-gray);
    text-align: center;
}

.block--bg-dark .block-blog-posts__headline {
    color: var(--color-white);
}

/* Content container */
.block-blog-posts__content {
    position: relative;
    overflow: hidden;
}

/* Category Filters - Matches Alto teal pills with checkmarks */
.block-blog-posts__filters {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-md);
    margin-bottom: var(--spacing-2xl);
    padding: 0 var(--spacing-lg) 0;
}

.block-blog-posts__filter-btn {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background-color: transparent;
    border: none;
    border-radius: 20px;
    padding: 10px 15px;
    font-size: 17px;
    font-weight: var(--font-medium);
    color: var(--color-dark-gray);
    cursor: pointer;
    transition: background-color 0.25s cubic-bezier(0.4, 0, 0.2, 1), 
                padding 0.25s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);

    &:hover {
        background-color: var(--color-teal);
    }
}

.block-blog-posts__filter-btn--active {
    background-color: var(--color-teal);
    padding-left: 37px;

    &::before {
        content: '';
        position: absolute;
        left: 15px;
        top: 50%;
        transform: translateY(-50%) rotate(45deg);
        width: 6px;
        height: 12px;
        border: solid var(--color-dark-gray);
        border-width: 0 2px 2px 0;
    }

    &:hover {
        background-color: var(--color-teal);
    }
}

/* Featured Post - 63/37 split layout like old theme */
.block-blog-posts__featured {
    margin-bottom: var(--spacing-3xl);

    @media (min-width: 768px) {
        margin-bottom: 72px;
    }
}

.block-blog-posts__featured-card {
    display: grid;
    gap: var(--spacing-xl);

    @media (min-width: 768px) {
        grid-template-columns: 63% 37%;
        gap: 0;
    }
}

.block-blog-posts__featured-image-link {
    display: block;
    position: relative;
    overflow: hidden;
    border-radius: 0;

    @media (min-width: 768px) {
        aspect-ratio: unset;
    }

    &:hover .block-blog-posts__featured-image {
        transform: scale(1.05);
    }
}

.block-blog-posts__featured-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);

    @media (min-width: 768px) {
        position: absolute;
        top: 0;
        left: 0;
    }
}

.block-blog-posts__featured-content {
    padding: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;

    @media (min-width: 768px) {
        padding: 0 39px 0 39px;
        min-height: 500px;
    }
}

/* Featured badge */
.block-blog-posts__featured-badge {
    display: inline-block;
    color: var(--color-dark-gray);
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    margin-bottom: var(--spacing-md);
}

.block-blog-posts__tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    margin-bottom: var(--spacing-md);
    position: absolute;
    top: 10px;
    left: 10px;
    z-index: 1;
}



.block-blog-posts__tag {
    background-color: var(--color-teal);
    color: var(--color-dark-gray);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    padding: 10px 15px;
    border-radius: 20px;
}

.block-blog-posts__featured-title {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    margin: 0 0 var(--spacing-sm) 0;
    line-height: 1.4;

    @media (min-width: 768px) {
        font-size: var(--text-3xl);
    }

    a {
        color: var(--color-dark-gray);
        text-decoration: none;
        transition: color 0.2s ease;

        &:hover {
            color: var(--color-primary);
        }
    }
}

.block-blog-posts__featured-date {
    display: block;
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
    margin-top: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
    line-height: 1;
}

.block-blog-posts__featured-excerpt {
    font-size: var(--text-base);
    color: var(--color-mid-gray);
    line-height: 1.6;
    margin: 0 0 var(--spacing-lg) 0;
}

.block-blog-posts__featured-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    color: var(--color-dark-gray);
    font-weight: var(--font-medium);
    font-size: var(--text-base);
    text-decoration: underline;
    text-underline-offset: 4px;
    transition: color 0.2s ease;

    &:hover {
        color: var(--color-primary);
    }

    svg {
        display: none;
    }
}

/* Posts Grid - 3 columns with percentage-based widths */
.block-blog-posts__grid {
    display: grid;
    gap: var(--spacing-2xl);
    margin-bottom: var(--spacing-2xl);
    transition: opacity 0.25s ease-out;

    @media (min-width: 640px) {
        grid-template-columns: repeat(2, 1fr);
    }

    @media (min-width: 1024px) {
        grid-template-columns: repeat(3, 1fr);
        column-gap: 3%;
        row-gap: var(--spacing-2xl);
    }
}

/* Post Card - Clean style with zoom hover on image */
.block-blog-posts__card {
    display: flex;
    flex-direction: column;
    transition: opacity 0.3s ease-out, transform 0.3s ease-out;

    &:hover .block-blog-posts__card-image {
        transform: scale(1.05);
    }
}

.block-blog-posts__card-image-link {
    display: block;
    position: relative;
    aspect-ratio: 381 / 214;
    overflow: hidden;
    border-radius: 0;
    margin-bottom: 0;
}

.block-blog-posts__card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.block-blog-posts__card-image--placeholder {
    background-color: var(--color-gray);
    width: 100%;
    height: 100%;
}

.block-blog-posts__card-content {
    padding: var(--spacing-lg) 0;
}

.block-blog-posts__card-title {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    margin: 0 0 0.6rem 0;
    line-height: 1.5;

    @media (min-width: 768px) {
        font-size: var(--text-lg);
    }

    @media (min-width: 1024px) {
        font-size: 22px;
    }

    a {
        color: var(--color-dark-gray);
        text-decoration: none;
        transition: color 0.2s ease;

        &:hover {
            color: var(--color-primary);
        }
    }
}

.block-blog-posts__card-date {
    display: block;
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
    margin: 0 0 0.85rem;
    line-height: 1;
}

.block-blog-posts__card-excerpt {
    font-size: var(--text-base);
    color: var(--color-mid-gray);
    line-height: 1.6;
    margin: 0 0 var(--spacing-md) 0;
}

.block-blog-posts__card-link {
    display: inline-block;
    color: var(--color-dark-gray);
    font-weight: var(--font-medium);
    font-size: var(--text-base);
    text-decoration: underline;
    text-underline-offset: 4px;
    transition: color 0.2s ease;

    &:hover {
        color: var(--color-primary);
    }
}

/* Load More */
.block-blog-posts__load-more-wrap {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-2xl) 0;
    clear: both;
}

.block-blog-posts__loading {
    display: none;
    justify-content: center;
    align-items: center;
    padding: var(--spacing-xl);
    min-height: 120px;
}

.block-blog-posts__loading::after {
    content: '';
    width: 40px;
    height: 40px;
    border: 3px solid var(--color-gray);
    border-top-color: var(--color-primary);
    border-radius: 50%;
    animation: spin 0.8s linear infinite;
}

@keyframes spin {
    to {
        transform: rotate(360deg);
    }
}

/* Grid fade transition for filtering */
.block-blog-posts__grid--fading {
    opacity: 0;
}

/* Card entrance animation for load more */
.block-blog-posts__card--entering {
    opacity: 0;
    transform: translateY(20px);
}

.block-blog-posts__load-more {
    text-align: center;
    margin-top: var(--spacing-2xl);
}

.block-blog-posts__load-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    background-color: var(--color-primary);
    color: var(--color-white);
    border: none;
    border-radius: var(--radius-full);
    padding: var(--spacing-md) var(--spacing-2xl);
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    cursor: pointer;
    transition: background-color 0.2s ease, transform 0.2s ease;

    &:hover {
        background-color: var(--color-primary-dark);
        transform: translateY(-2px);
    }

    &:disabled {
        opacity: 0.6;
        cursor: not-allowed;
        transform: none;
    }
}

/* No Posts Message */
.block-blog-posts__no-posts {
    text-align: center;
    padding: var(--spacing-3xl);
    color: var(--color-gray);
    font-size: var(--text-lg);
    grid-column: 1 / -1;
}



/* ==========================================================================
   Page Title Block
   ========================================================================== */

/* -----------------------------------------------------
   Page Title - Hero Content Style
   ----------------------------------------------------- */

.block-page-title--hero-content {
    position: relative;
    background-color: var(--color-white);
    padding-top: calc(80px + var(--spacing-2xl));
    padding-bottom: var(--spacing-3xl);
    overflow: hidden;
    overflow-x: clip;

    @media (max-width: 768px) {
        padding-top: calc(70px + var(--spacing-xl));
        padding-bottom: var(--spacing-2xl);
    }
}

/* Allow overflow when class is applied */
.block-page-title--hero-content.block--svg-overflow {
    overflow: visible !important;
    overflow-x: clip !important;
}

/* Override all child overflow hidden when parent has overflow class */
.block-page-title--hero-content.block--svg-overflow .block-page-title__lines,
.block-page-title--hero-content.block--svg-overflow .svg-lines {
    overflow: visible !important;
    height: auto !important;
    bottom: auto !important;
}

.block-page-title__lines {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    pointer-events: none;
    z-index: 1;
    overflow: hidden;
    /* Note: left positioning is determined by the svg-lines--* pattern class */
}

.block-page-title__lines-svg {
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-50%);
    width: auto;
    height: auto;
    min-width: 1580px;
}

.block-page-title--hero-content .block-page-title__content {
    position: relative;
    z-index: 2;
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
    padding: var(--spacing-xl) 0;
    text-align: center;
}

.block-page-title__eyebrow {
    margin-bottom: var(--spacing-md);

    span {
        display: inline-block;
        font-family: var(--font-decorative);
        font-size: 26px;
        font-weight: var(--font-semibold);
        color: var(--color-primary);
        text-align: center;
    }
}

.block-page-title--hero-content .block-page-title__header {
    margin-bottom: var(--spacing-lg);

    h1 {
        font-size: var(--text-6xl);
        font-weight: var(--font-semibold);
        line-height: 1.1;
        margin: 0;
        color: var(--color-dark-gray);

        @media (max-width: 768px) {
            font-size: var(--text-4xl);
        }

        em {
            font-family: var(--font-decorative);
            font-style: normal;
            font-weight: 500;
        }
    }
}

/* Larger headline variant */
.block-page-title--larger-headline .block-page-title__header h1 {
    font-size: var(--text-7xl);

    @media (max-width: 768px) {
        font-size: var(--text-5xl);
    }
}

.block-page-title__description {
    font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    line-height: 1.6;
    color: var(--color-mid-gray);
    margin-bottom: var(--spacing-lg);

    p {
        margin-bottom: var(--spacing-md);

        &:last-child {
            margin-bottom: 0;
        }
    }

    @media (max-width: 768px) {
        font-size: 18px;
    }
}

.block-page-title__cta {
    margin-top: var(--spacing-xs);
}

/* -----------------------------------------------------
   Page Title - Hero Content with Image (Two Column)
   ----------------------------------------------------- */

.block-page-title__columns {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column-reverse;
    gap: var(--spacing-md);
    align-items: center;

    @media (min-width: 768px) {
        flex-direction: row;
        gap: var(--spacing-4xl);
    }
}

.block-page-title__column--content {
    flex: 1;
}

.block-page-title__column--image {
    flex: 0 0 auto;
    width: 100%;

    @media (min-width: 768px) {
        flex: 0 0 40%;
        width: 40%;
    }
}

.block-page-title__content--left {
    text-align: left;
    margin-left: 0;
    margin-right: 0;
}

.block-page-title__content--left .block-page-title__eyebrow {
    text-align: left;
}

.block-page-title__content--left .block-page-title__eyebrow span {
    text-align: left;
}

.block-page-title__content--left .block-page-title__header {
    text-align: left;
}

.block-page-title__content--left .block-page-title__header h1 {
    text-align: left;
}

.block-page-title__content--left .block-page-title__description {
    text-align: left;
}

.block-page-title__content--left .block-page-title__cta {
    text-align: left;
    display: flex;
    justify-content: flex-start;
}

.block-page-title__hero-image {
    width: 100%;
    overflow: hidden;

    img {
        width: 100%;
        height: auto;
        display: block;
    }
}

/* Hero image border radius options */
.block-page-title__hero-image--radius-none {
    border-radius: 0;
}

.block-page-title__hero-image--radius-small {
    border-radius: var(--radius-md);
}

.block-page-title__hero-image--radius-medium {
    border-radius: var(--radius-xl);
}

.block-page-title__hero-image--radius-large {
    border-radius: var(--radius-3xl);
}

/* Video trigger and play button for hero image */
.block-page-title__hero-image--has-video {
    position: relative;
}

.block-page-title__video-trigger {
    display: block;
    position: relative;
    width: 100%;
    border: none;
    padding: 0;
    margin: 0;
    background: none;
    cursor: pointer;
}

.block-page-title__video-trigger img {
    display: block;
    width: 100%;
    height: auto;
}

.block-page-title__play-button {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.9);
    width: 100px;
    height: 100px;
    background-color: var(--color-white);
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: transform 0.3s cubic-bezier(0.165, 0.84, 0.44, 1), box-shadow 0.3s ease;
    box-shadow: 0 8px 30px rgba(0, 0, 0, 0.15);
    z-index: 2;
}

.block-page-title__play-button svg {
    width: 28px;
    height: 28px;
    color: var(--color-primary);
    margin-left: 4px;
}

.block-page-title__video-trigger:hover .block-page-title__play-button,
.block-page-title__video-trigger:focus .block-page-title__play-button {
    transform: translate(-50%, -50%) scale(1);
    box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
}

.block-page-title__video-trigger:focus {
    outline: none;
}

.block-page-title__video-trigger:focus-visible .block-page-title__play-button {
    outline: 2px solid var(--color-primary);
    outline-offset: 4px;
}

@media (max-width: 768px) {
    .block-page-title__play-button {
        width: 70px;
        height: 70px;
    }

    .block-page-title__play-button svg {
        width: 22px;
        height: 22px;
        margin-left: 3px;
    }
}

/* -----------------------------------------------------
   Page Title - Hero Content Dark Style
   ----------------------------------------------------- */

.block-page-title--hero-dark {
    background-color: var(--color-dark-gray);
}

.block-page-title--hero-dark .block-page-title__lines-svg path {
    stroke: #454545;
}

.block-page-title--hero-dark .block-page-title__eyebrow span {
    color: var(--color-primary);
}

.block-page-title--hero-dark .block-page-title__header h1 {
    color: var(--color-white);
}

.block-page-title--hero-dark .block-page-title__description {
    color: rgba(255, 255, 255, 0.8);
}

/* -----------------------------------------------------
   Page Title - Standard Style (with featured image)
   ----------------------------------------------------- */

.block-page-title--standard {
    position: relative;
}

.block-page-title--bg-cream {
    background-color: var(--color-cream, #F8F7EF);
}

.block-page-title--bg-cream .block-page-title__content-standard {
    background-color: var(--color-cream, #F8F7EF);
}

.block-page-title--bg-white {
    background-color: var(--color-white);
}

.block-page-title--bg-white .block-page-title__content-standard {
    background-color: var(--color-white);
}

.block-page-title--bg-light {
    background-color: var(--color-light-gray);
}

.block-page-title--bg-light .block-page-title__content-standard {
    background-color: var(--color-light-gray);
}

/* Custom background color - uses CSS variable set via inline style */
.block-page-title--bg-custom {
    background-color: var(--block-custom-bg, #f5f5f5);
}

.block-page-title--bg-custom .block-page-title__content-standard {
    background-color: var(--block-custom-bg, #f5f5f5);
}

/* Outer wrapper - position relative for absolute children */
.block-page-title__outer {
    position: relative;
    width: 100%;
}

/* Background wrapper - absolute positioned, behind content */
.block-page-title__bg-wrapper {
    position: absolute;
    height: 100%;
    width: 100%;
    z-index: 1;
    top: 0;
    left: 0;
}

/* Background container - flex, right-aligned, hidden on mobile */
.block-page-title__bg-container {
    display: none;
    position: relative;
    height: 100%;
    margin: 0 auto;
    flex-direction: row;
    justify-content: flex-end;

    @media (min-width: 1024px) {
        display: flex;
    }
}

/* Background image - positioned on right side, extends under content curve */
.block-page-title__bg-image {
    --image-position: center center;
    position: absolute;
    right: 0;
    top: 0;
    height: 100%;
    width: 55%;
}

.block-page-title__bg-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: var(--image-position);
}

/* Logo variant - contained logo with gradient background */
.block-page-title__bg-image--logo {
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(90deg, #fdda8f 35%, #ccf0eb);
    padding: var(--spacing-3xl);
    /* Offset for header overlap - push content down to visually center */
    padding-top: calc(80px + var(--spacing-3xl));
    /* Offset for content area overlap - push logo right to visually center in visible area */
    padding-left: calc(120px + var(--spacing-3xl));

    img {
        width: auto;
        height: auto;
        max-width: 50%;
        max-height: 40%;
        object-fit: contain;
        object-position: center;
    }
}

/* Inner wrapper - above background, z-index 50 */
.block-page-title__inner {
    position: relative;
    z-index: 50;

    @media (min-width: 1024px) {
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
}

/* Content block - has background with border-radius to create curved edge */
.block-page-title__content-standard {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    max-width: 100%;
    height: auto;
    padding-top: calc(80px + var(--spacing-2xl));
    padding-right: var(--spacing-lg);
    padding-bottom: var(--spacing-2xl);

    @media (min-width: 1024px) {
        max-width: 620px;
        padding-top: calc(80px + var(--spacing-4xl));
        padding-right: var(--spacing-2xl);
        padding-bottom: var(--spacing-4xl);
        border-radius: 0 0 100px 0;
    }
}

/* Back Link */
.block-page-title__back {
    position: relative;
    text-decoration: none;
    margin: 0 0 30px 0;
    padding-right: var(--spacing-lg);
    display: block;

    a {
        display: inline-flex;
        align-items: center;
        text-decoration: none;
        color: var(--color-black, #000);
        transition: color 0.2s ease;

        &:hover {
            color: var(--color-primary);
        }
    }

    svg {
        position: relative;
        flex-shrink: 0;
    }

    span {
        padding: 0 0 0 10px;
        font-size: 18px;
    }
}

/* Header / Title - Standard Style */
.block-page-title__header-standard {
    position: relative;
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-bottom: 20px;
    padding-right: var(--spacing-lg);

    h1 {
        font-size: clamp(2.25rem, 5vw, 3.25rem);
        font-weight: var(--font-semibold);
        line-height: 1.05;
        margin: 0;
        color: var(--color-dark-gray);

        em {
            font-family: var(--font-decorative);
            font-style: normal;
            font-weight: 500;
        }
    }
}

/* ==========================================================================
   Features Grid Block
   ========================================================================== */

/* Header */
.block-features-grid__header {
    margin-bottom: var(--spacing-2xl);
}

.block-features-grid__header.text-center {
    margin-left: auto;
    margin-right: auto;
}

/* Reduce subtitle margin when followed by description */
.block-features-grid__header .block-subtitle:has(+ .block-features-grid__description) {
    margin-bottom: var(--spacing-lg);
}

.block-features-grid__description {
        font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    color: var(--color-mid-gray);
    line-height: var(--leading-relaxed);
}

.block--bg-dark .block-features-grid__description {
    color: rgba(255, 255, 255, 0.8);
}

/* Grid Layout */
.block-features-grid__grid {
    display: grid;
    gap: var(--spacing-lg);
}

/* Column variations */
.block-features-grid--cols-2 .block-features-grid__grid {
    grid-template-columns: repeat(2, 1fr);
}

.block-features-grid--cols-3 .block-features-grid__grid {
    grid-template-columns: repeat(3, 1fr);
}

.block-features-grid--cols-4 .block-features-grid__grid {
    grid-template-columns: repeat(4, 1fr);
}

.block-features-grid--cols-5 .block-features-grid__grid {
    grid-template-columns: repeat(5, 1fr);
}

/* 5-Item Offset Layout (3 columns with bottom row centered) */
.block-features-grid--five-item-offset .block-features-grid__grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: var(--spacing-lg);
}

.block-features-grid--five-item-offset .block-features-grid__item:nth-child(1),
.block-features-grid--five-item-offset .block-features-grid__item:nth-child(2),
.block-features-grid--five-item-offset .block-features-grid__item:nth-child(3) {
    grid-column: span 2;
}

.block-features-grid--five-item-offset .block-features-grid__item:nth-child(4) {
    grid-column: 2 / span 2;
}

.block-features-grid--five-item-offset .block-features-grid__item:nth-child(5) {
    grid-column: 4 / span 2;
}

@media (max-width: 768px) {
    .block-features-grid--five-item-offset .block-features-grid__grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .block-features-grid--five-item-offset .block-features-grid__item:nth-child(1),
    .block-features-grid--five-item-offset .block-features-grid__item:nth-child(2),
    .block-features-grid--five-item-offset .block-features-grid__item:nth-child(3),
    .block-features-grid--five-item-offset .block-features-grid__item:nth-child(4),
    .block-features-grid--five-item-offset .block-features-grid__item:nth-child(5) {
        grid-column: span 1;
    }
}

@media (max-width: 550px) {
    .block-features-grid--five-item-offset .block-features-grid__grid {
        grid-template-columns: 1fr;
    }
}

/* Responsive grid columns */
@media (max-width: 1024px) {
    .block-features-grid--cols-4 .block-features-grid__grid,
    .block-features-grid--cols-5 .block-features-grid__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .block-features-grid--cols-3 .block-features-grid__grid,
    .block-features-grid--cols-4 .block-features-grid__grid,
    .block-features-grid--cols-5 .block-features-grid__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (max-width: 550px) {
    .block-features-grid__grid {
        grid-template-columns: 1fr !important;
    }
}

/* ==========================================================================
   Icon Grid Style
   ========================================================================== */

.block-features-grid--style-icon_grid .block-features-grid__item {
    display: flex;
    flex-direction: column;
    text-decoration: none;
    color: inherit;
}

/* Rounded box style */
.block-features-grid--box-rounded .block-features-grid__item {
    background-color: var(--color-white);
    border-radius: var(--radius-2xl);
    padding: var(--spacing-xl);
}

/* White background - boxes should be light gray so they're visible */
.block--bg-white.block-features-grid--box-rounded .block-features-grid__item {
    background-color: #f8f8f8;
}

/* Dark background - boxes should be slightly lighter dark */
.block--bg-dark.block-features-grid--box-rounded .block-features-grid__item {
    background-color: var(--color-dark-gray-light);
}

/* No box style */
.block-features-grid--box-none .block-features-grid__item {
    background: transparent;
    padding: var(--spacing-md) 0;
}

/* Content alignment */
.block-features-grid--content-center .block-features-grid__item {
    text-align: center;
    align-items: center;
}

.block-features-grid--content-left .block-features-grid__item {
    text-align: left;
    align-items: flex-start;
}

/* Icon sizing */
.block-features-grid__icon {
    margin-bottom: var(--spacing-md);
    line-height: 0;

    img {
        width: auto;
        height: auto;
    }
}

.block-features-grid--icon-small .block-features-grid__icon img {
    max-width: 24px;
    max-height: 24px;
}

.block-features-grid--icon-medium .block-features-grid__icon img {
    max-width: 48px;
    max-height: 48px;
}

.block-features-grid--icon-large .block-features-grid__icon img {
    max-width: 64px;
    max-height: 64px;
}

/* Illustration style - icon right-aligned with header */
.block-features-grid--icon-illustration .block-features-grid__item {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    gap: 0 var(--spacing-lg);
    align-items: start;
}

.block-features-grid--icon-illustration .block-features-grid__icon {
    grid-column: 2;
    grid-row: 1;
    margin-bottom: 0;
}

.block-features-grid--icon-illustration .block-features-grid__icon img {
    width: 100px;
    height: auto;
    max-width: 100%;
}

.block-features-grid--icon-illustration .block-features-grid__item-title {
    grid-column: 1;
    grid-row: 1;
    font-size: var(--text-4xl);
    font-weight: var(--font-semibold);
    line-height: var(--leading-tight);
    align-self: center;
}

.block-features-grid--icon-illustration .block-features-grid__item-description {
    grid-column: 1 / -1;
    grid-row: 2;
    margin-top: var(--spacing-md);
    font-family: var(--font-decorative);
}

/* Item content */
.block-features-grid__item-title {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    margin-bottom: var(--spacing-sm);
    line-height: var(--leading-snug);
}

/* Icon grid item heading size variations */
.block-features-grid__item--heading-large .block-features-grid__item-title {
    font-size: var(--text-xl);
}

.block-features-grid__item--heading-xlarge .block-features-grid__item-title {
    font-size: var(--text-2xl);
}

.block-features-grid__item-description {
    font-size: var(--text-base);
    color: var(--color-mid-gray);
    line-height: var(--leading-relaxed);
    margin: 0;
}

.block--bg-dark .block-features-grid__item-description {
    color: rgba(255, 255, 255, 0.7);
}

/* Text link for no-box style items */
a.underline.block-features-grid__item-link {
    margin-top: var(--spacing-md);
    font-size: var(--text-base);
}

.block--bg-dark .block-features-grid__item-link.underline {
    color: #fff;
}

.block--bg-dark .block-features-grid__item-link.underline::before {
    background-color: rgba(255, 255, 255, 0.3);
}

.block--bg-dark .block-features-grid__item-link.underline::after {
    background-color: var(--color-secondary);
}

/* Linked item hover effect */
.block-features-grid__item--linked {
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
    cursor: pointer;
}

.block-features-grid--box-rounded .block-features-grid__item--linked:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.block-features-grid--box-none .block-features-grid__item--linked:hover {
    opacity: 0.8;
}

/* ==========================================================================
   Illustrations Grid Style
   ========================================================================== */

.block-features-grid--style-illustrations_grid .block-features-grid__item {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-2xl);
    padding: var(--spacing-xl);
    text-decoration: none;
    color: inherit;
    /* Gradient based on index - starts at hsl(40, 98%, 80%) and decreases lightness */
    background-color: hsl(40, 98%, calc(80% - (var(--gradient-index, 1) - 1) * 10%));
}

.block-features-grid--style-illustrations_grid .block-features-grid__illustration {
    margin-bottom: var(--spacing-lg);
    border-radius: var(--radius-lg);
    overflow: hidden;
}

.block-features-grid--style-illustrations_grid .block-features-grid__illustration img {
    width: 100%;
    height: auto;
    display: block;
}

.block-features-grid--style-illustrations_grid .block-features-grid__item-title {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    margin-bottom: var(--spacing-sm);
    color: var(--color-dark-gray);
}

.block-features-grid--style-illustrations_grid .block-features-grid__item-content {
    font-size: var(--text-base);
    color: var(--color-dark-gray);
    line-height: var(--leading-relaxed);

    a {
        color: var(--color-dark-gray);
        text-decoration: underline;

        &:hover {
            color: var(--color-primary);
        }
    }
}

.block-features-grid--style-illustrations_grid .block-features-grid__item--linked:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

/* Illustrations Grid - No boxes style */
.block-features-grid--illus-box-none .block-features-grid__item {
    background-color: transparent !important;
    border-radius: 0;
    padding: 0;
}

.block-features-grid--illus-box-none .block-features-grid__grid {
    gap: var(--spacing-2xl);
}

.block-features-grid--illus-box-none .block-features-grid__item--linked:hover {
    transform: none;
    box-shadow: none;
    opacity: 0.85;
}

/* Illustrations Grid - Image max height variations */
.block-features-grid--illus-height-200 .block-features-grid__illustration img {
    max-height: 200px;
    width: auto;
    object-fit: contain;
}

.block-features-grid--illus-height-150 .block-features-grid__illustration img {
    max-height: 150px;
    width: auto;
    object-fit: contain;
}

.block-features-grid--illus-height-100 .block-features-grid__illustration img {
    max-height: 100px;
    width: auto;
    object-fit: contain;
}

/* Illustrations Grid - Content alignment */
.block-features-grid--illus-align-center .block-features-grid__item {
    text-align: center;
    align-items: center;
}

.block-features-grid--illus-align-center .block-features-grid__illustration {
    display: flex;
    justify-content: center;
}

.block-features-grid--illus-align-left .block-features-grid__item {
    text-align: left;
    align-items: flex-start;
}

/* Illustrations Grid - Description size */
.block-features-grid--illus-desc-large .block-features-grid__item-content {
    font-size: var(--text-lg);
}

/* ==========================================================================
   Stats Grid Style
   ========================================================================== */

.block-features-grid--style-stats_grid .block-features-grid__stat-item {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-2xl);
    padding: var(--spacing-xl);
    text-decoration: none;
    color: inherit;
}

/* Light gray background - white boxes */
.block--bg-light.block-features-grid--style-stats_grid .block-features-grid__stat-item {
    background-color: var(--color-white);
}

/* Cream background - white boxes */
.block--bg-cream.block-features-grid--style-stats_grid .block-features-grid__stat-item {
    background-color: var(--color-white);
}

/* White background - light gray boxes */
.block--bg-white.block-features-grid--style-stats_grid .block-features-grid__stat-item {
    background-color: var(--color-light-gray);
}

/* Dark background - slightly lighter dark boxes */
.block--bg-dark.block-features-grid--style-stats_grid .block-features-grid__stat-item {
    background-color: var(--color-dark-gray-light);
}

/* Stat number wrapper */
.block-features-grid__stat-number-wrapper {
    display: flex;
    align-items: baseline;
    gap: 0.1em;
}

:is(.block-features-grid__stat-number, .block-features-grid__stat-suffix) {
    font-size: var(--text-4xl);
    font-weight: var(--font-semibold);
    color: var(--color-primary);
    line-height: 1;

    @media (max-width: 768px) {
        font-size: var(--text-3xl);
    }
}

.block-features-grid__stat-label {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
    line-height: var(--leading-snug);
    margin-top: var(--spacing-xs);

    @media (max-width: 768px) {
        font-size: var(--text-lg);
    }
}

.block--bg-dark .block-features-grid__stat-label {
    color: var(--color-white);
}

/* Divider */
.block-features-grid__stat-divider {
    width: 100%;
    height: 1px;
    background-color: var(--color-light-gray);
    margin: var(--spacing-lg) 0;
}

.block--bg-dark .block-features-grid__stat-divider {
    background-color: rgba(255, 255, 255, 0.2);
}

/* Bottom content */
.block-features-grid__stat-subtitle {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
    margin-bottom: var(--spacing-sm);
}

.block--bg-dark .block-features-grid__stat-subtitle {
    color: var(--color-white);
}

.block-features-grid__stat-description {
    font-size: var(--text-base);
    color: var(--color-mid-gray);
    line-height: var(--leading-relaxed);
    margin: 0;
}

.block--bg-dark .block-features-grid__stat-description {
    color: rgba(255, 255, 255, 0.7);
}

/* Stats linked hover */
.block-features-grid--style-stats_grid .block-features-grid__item--linked {
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.block-features-grid--style-stats_grid .block-features-grid__item--linked:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

/* ==========================================================================
   HubSpot Form Block
   ========================================================================== */

.block-hubspot-form {
    position: relative;
}

/* Header Row - Content + Icon side by side */
.block-hubspot-form__header {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-2xl);

    @media (min-width: 768px) {
        flex-direction: row;
        align-items: flex-start;
        justify-content: space-between;
        gap: var(--spacing-3xl);
    }
}

/* Content Column */
.block-hubspot-form__content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
    flex: 1;
}

.block-hubspot-form__title {
    margin: 0;
}

.block-hubspot-form__description {
        font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    line-height: 1.6;
    color: var(--color-mid-gray);

    p {
        margin: 0 0 var(--spacing-md);

        &:last-child {
            margin-bottom: 0;
        }
    }
}

/* Video Link */
.block-hubspot-form__video-link {
    margin-top: var(--spacing-sm);
}

.block-hubspot-form__video-trigger {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-sm);
    background: transparent;
    border: none;
    padding: 0;
    cursor: pointer;
    font-family: inherit;
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--color-primary);
    transition: color var(--transition-fast);

    &:hover {
        color: var(--color-primary-dark);
    }

    &:focus {
        outline: 2px solid var(--color-primary);
        outline-offset: 2px;
    }
}

.block-hubspot-form__play-icon {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    width: 24px;
    height: 24px;
    color: currentColor;
}

/* Icon Image */
.block-hubspot-form__icon {
    flex-shrink: 0;
    display: none;

    @media (min-width: 768px) {
        display: block;
    }
}

.block-hubspot-form__icon-image {
    max-width: 200px;
    width: 100%;
    height: auto;

    @media (min-width: 1024px) {
        max-width: 240px;
    }
}

/* Form Wrapper - Full Width with white container */
.block-hubspot-form__form-wrapper {
    width: 100%;
    background: var(--color-white);
    border-radius: var(--radius-xl, 24px);
    padding: var(--spacing-2xl);

    @media (min-width: 768px) {
        padding: var(--spacing-3xl);
    }
}

/* Remove white box when block background is white */
.block-hubspot-form.block--bg-white .block-hubspot-form__form-wrapper {
    background: transparent;
    border-radius: 0;
    padding: 0;
}

.block-hubspot-form__form {
    width: 100%;
}

/* HubSpot Form Styling Overrides */
.block-hubspot-form__form .hs-form {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);

    @media (min-width: 768px) {
        grid-template-columns: repeat(2, 1fr);
    }
}

.block-hubspot-form__form .hs-form-field {
    margin-bottom: 0;
}

.block-hubspot-form__form .hs-form-field.hs-fieldtype-textarea,
.block-hubspot-form__form .hs-form-field.hs-fieldtype-booleancheckbox,
.block-hubspot-form__form .hs_submit {
    grid-column: 1 / -1;
}

.block-hubspot-form__form label {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-mid-gray);
    margin-bottom: var(--spacing-xs);
}

.block-hubspot-form__form .hs-input {
    width: 100%;
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--text-base);
    font-family: inherit;
    border: 1px solid var(--color-gray);
    border-radius: var(--radius-md);
    background: var(--color-white);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);

    &:focus {
        outline: none;
        border-color: var(--color-primary);
        box-shadow: 0 0 0 3px rgba(255, 87, 34, 0.1);
    }
}

.block-hubspot-form__form textarea.hs-input {
    min-height: 120px;
    resize: vertical;
}

.block-hubspot-form__form select.hs-input {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23666' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right var(--spacing-md) center;
    padding-right: calc(var(--spacing-md) * 2 + 12px);
}

/* Checkbox styling */
.block-hubspot-form__form .hs-form-booleancheckbox-display {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-sm);
}

.block-hubspot-form__form .hs-form-booleancheckbox-display input[type="checkbox"] {
    width: 18px;
    height: 18px;
    margin: 2px 0 0;
    flex-shrink: 0;
}

.block-hubspot-form__form .hs-form-booleancheckbox-display span {
    font-size: var(--text-sm);
    line-height: 1.5;
    color: var(--color-mid-gray);
}

/* Submit button */
.block-hubspot-form__form .hs-submit {
    margin-top: var(--spacing-md);
}

.block-hubspot-form__form .hs-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-sm) var(--spacing-xl);
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    font-family: inherit;
    color: var(--color-white);
    background: var(--color-primary);
    border: 2px solid var(--color-primary);
    border-radius: 100px;
    cursor: pointer;
    transition: background-color var(--transition-fast), border-color var(--transition-fast), transform var(--transition-fast);

    &:hover {
        background: var(--color-primary-dark);
        border-color: var(--color-primary-dark);
        transform: translateY(-1px);
    }

    &:focus {
        outline: 2px solid var(--color-primary);
        outline-offset: 2px;
    }
}

/* Error messages */
.block-hubspot-form__form .hs-error-msgs {
    list-style: none;
    padding: 0;
    margin: var(--spacing-xs) 0 0;
}

.block-hubspot-form__form .hs-error-msg {
    font-size: var(--text-sm);
    color: var(--color-error, #dc2626);
}

/* Form placeholder styling (when no embed code) */
.block-hubspot-form__placeholder {
    background: var(--color-light-gray);
    border: 2px dashed var(--color-gray);
    border-radius: var(--radius-lg);
    padding: var(--spacing-3xl);
    text-align: center;
}

.block-hubspot-form__placeholder-title {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--color-mid-gray);
    margin: 0 0 var(--spacing-sm);
}

.block-hubspot-form__placeholder-text {
    font-size: var(--text-base);
    color: var(--color-gray);
    margin: 0;
}

/* ==========================================================================
   Video Lightbox Modal
   ========================================================================== */

.video-lightbox {
    position: fixed;
    inset: 0;
    z-index: 10000;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-lg);
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.3s ease, visibility 0.3s ease;

    &[aria-hidden="false"] {
        opacity: 1;
        visibility: visible;
    }
}

.video-lightbox__backdrop {
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.9);
    cursor: pointer;
}

.video-lightbox__container {
    position: relative;
    width: 100%;
    max-width: 1000px;
    z-index: 1;
}

.video-lightbox__close {
    position: absolute;
    top: -50px;
    right: 0;
    background: transparent;
    border: none;
    color: var(--color-white);
    cursor: pointer;
    padding: var(--spacing-sm);
    line-height: 1;
    transition: opacity 0.2s ease;

    &:hover {
        opacity: 0.7;
    }
}

.video-lightbox__video {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    background: var(--color-black);
    border-radius: var(--radius-lg);

    iframe {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border: none;
    }
}

/* ==========================================================================
   Content Area Block
   ========================================================================== */

.block-content-area__title {
    margin-bottom: var(--spacing-xl);
}

.block-content-area h1.block-content-area__title {
    margin-bottom: var(--spacing-2xl);
}

.block-content-area__columns {
    display: grid;
    gap: var(--spacing-2xl);
}

/* Single column layout */
.block-content-area--cols-1 .block-content-area__columns {
    grid-template-columns: 1fr;
}

/* Two column layout */
.block-content-area--cols-2 .block-content-area__columns {
    grid-template-columns: repeat(2, 1fr);

    @media (max-width: 768px) {
        grid-template-columns: 1fr;
    }
}

/* Column content styles */
.block-content-area__column {
    p {
        margin-bottom: var(--spacing-md);

        &:last-child {
            margin-bottom: 0;
        }
    }

    :is(ul, ol) {
        margin-bottom: var(--spacing-md);
    }

    img {
        border-radius: var(--radius-md);
    }
}

/* Text size variations */
.block-content-area--text-small .block-content-area__column {
    font-size: var(--text-base);
}

.block-content-area--text-default .block-content-area__column {
    font-size: var(--text-lg);
}

.block-content-area--text-large .block-content-area__column {
    font-size: var(--text-xl);
}

/* Heading alignment */
.block-content-area--heading-center .block-content-area__header {
    text-align: center;
}

/* Boxed style - content in white rounded boxes */
.block-content-area--boxed .block-content-area__columns {
    margin-top: var(--spacing-md);
}

.block-content-area--boxed .block-content-area__column {
    background: var(--color-white);
    border-radius: 32px;
    padding: var(--spacing-lg);
}

@media (min-width: 768px) {
    .block-content-area--boxed .block-content-area__column {
        padding: var(--spacing-xl);
    }
}

/* Remove boxed styling when background is white */
.block-content-area--boxed.block--bg-white .block-content-area__columns {
    margin-top: 0;
}

.block-content-area--boxed.block--bg-white .block-content-area__column {
    background: transparent;
    border-radius: 0;
    padding: 0;
}

/* Dark background text colors */
.block--bg-dark .block-content-area__title,
.block--bg-dark .block-content-area__column {
    color: var(--color-white);
}

.block--bg-dark .block-content-area__column a:not(.btn) {
    color: var(--color-secondary);
}

/* ==========================================================================
   Underline Link Style
   ========================================================================== */

a.underline {
    position: relative;
    display: inline-block;
    color: var(--color-dark-gray);
    text-decoration: none;
    font-weight: var(--font-semibold);
    font-size: var(--text-lg);

    &::before {
        content: "";
        position: absolute;
        bottom: -4px;
        left: 0;
        display: block;
        width: 100%;
        height: 2px;
        background-color: var(--color-dark-gray);
        opacity: 0.2;
        transition: opacity 0.4s ease;
    }

    &::after {
        content: "";
        position: absolute;
        bottom: -4px;
        left: 0;
        display: block;
        width: 0%;
        height: 2px;
        background-color: var(--color-primary);
        transition: width 0.4s cubic-bezier(0.22, 0.61, 0.36, 1);
    }

    &:hover::after {
        width: 100%;
    }
}

/* ==========================================================================
   Block: Video Grid
   ========================================================================== */

.block-video-grid {
    position: relative;
    overflow: hidden;
}

/* SVG Background Decoration */
.block-video-grid__bg-decoration {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 0;

    svg {
        width: 100%;
        height: 100%;
        color: var(--color-white);
    }
}

:is(.block--bg-white, .block--bg-light) .block-video-grid__bg-decoration svg {
    color: var(--color-dark-gray);
}

/* Container positioning above SVG */
.block-video-grid .container,
.block-video-grid .container--lg,
.block-video-grid .container--xl {
    position: relative;
    z-index: 1;
}

/* Header */
.block-video-grid__header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.block-video-grid__headline {
    margin: 0;
}

/* Grid */
.block-video-grid__grid {
    display: grid;
    gap: var(--spacing-lg);
}

/* Column variations */
.block-video-grid--cols-2 .block-video-grid__grid {
    grid-template-columns: 1fr;

    @media (min-width: 768px) {
        grid-template-columns: repeat(2, 1fr);
    }
}

.block-video-grid--cols-3 .block-video-grid__grid {
    grid-template-columns: 1fr;

    @media (min-width: 600px) {
        grid-template-columns: repeat(2, 1fr);
    }

    @media (min-width: 992px) {
        grid-template-columns: repeat(3, 1fr);
    }
}

.block-video-grid--cols-4 .block-video-grid__grid {
    grid-template-columns: 1fr;

    @media (min-width: 600px) {
        grid-template-columns: repeat(2, 1fr);
    }

    @media (min-width: 992px) {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Grid item */
.block-video-grid__item {
    background-color: var(--color-white);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.08);
    transition: transform 0.3s ease, box-shadow 0.3s ease;

    &:hover {
        transform: translateY(-4px);
        box-shadow: 0 8px 30px rgba(0, 0, 0, 0.12);
    }
}

/* Video wrapper - maintains aspect ratio */
.block-video-grid__video-wrap {
    position: relative;
    background-color: var(--color-dark-gray);
}

/* Ensure Wistia embed is responsive */
.block-video-grid__video-wrap .wistia_responsive_padding {
    padding-top: 56.25% !important;
}

/* Description */
.block-video-grid__description {
    padding: var(--spacing-md) var(--spacing-lg);
    background-color: var(--color-white);

    p {
        margin: 0;
            font-size: var(--text-base);
    font-weight: var(--font-normal);
        line-height: 1.6;
        color: var(--color-dark-gray);
    }
}

/* Dark background adjustments */
.block--bg-dark .block-video-grid__headline {
    color: var(--color-white);
}


/* ==========================================================================
   CTA Block
   ========================================================================== */

/* ==========================================================================
   Full Width Style
   ========================================================================== */

.block-cta--full-width {
    position: relative;
    overflow: hidden;
    min-height: 320px;
    display: flex;
    align-items: center;

    @media (max-width: 768px) {
        min-height: auto;
    }
}

/* ==========================================================================
   CTA Background Variations (extends standard block--bg-* system)
   ========================================================================== */

/* Orange Gradient - animated gradient pseudo-element */
.block-cta--bg-orange-gradient {
    position: relative;
    color: var(--color-dark-gray);

    &::before {
        content: "";
        position: absolute;
        display: block;
        width: 200%;
        height: 120%;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        z-index: 0;
        background: linear-gradient(90deg, var(--color-yellow) 0%, var(--color-primary) 100%);
        transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);

        @media (min-width: 640px) {
            animation: gradient-shift 10s infinite;
        }
    }
}

.block-cta--bg-orange-gradient .block-cta__svg-lines {
    color: rgba(255, 255, 255, 0.6);
}

/* Yellow Background */
.block-cta--bg-yellow {
    background-color: var(--color-yellow);
    color: var(--color-dark-gray);
}

.block-cta--bg-yellow .block-cta__svg-lines {
    color: rgba(255, 255, 255, 0.5);
}

/* Grey Gradient - animated gradient pseudo-element */
.block-cta--bg-grey-gradient {
    position: relative;
    color: var(--color-dark-gray);
}

.block-cta--bg-grey-gradient::before {
    content: "";
    position: absolute;
    display: block;
    width: 200%;
    height: 120%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
    background: linear-gradient(90deg, rgb(216, 216, 216) 25%, rgb(125, 126, 126) 100%);
    transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

@media (min-width: 640px) {
    .block-cta--bg-grey-gradient::before {
        animation: gradient-shift 10s infinite;
    }
}

.block-cta--bg-grey-gradient .block-cta__svg-lines {
    color: rgba(255, 255, 255, 0.5);
}

/* Teal Gradient Dark - animated gradient pseudo-element */
.block-cta--bg-teal-gradient-dark {
    position: relative;
    color: var(--color-dark-gray);
}

.block-cta--bg-teal-gradient-dark::before {
    content: "";
    position: absolute;
    display: block;
    width: 200%;
    height: 120%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
    background: rgb(204, 240, 235);
    background: linear-gradient(90deg, rgb(204, 240, 235) 0%, rgb(148, 219, 211) 100%);
    transition: opacity 0.5s ease, transform 0.5s cubic-bezier(0.165, 0.84, 0.44, 1);
}

@media (min-width: 640px) {
    .block-cta--bg-teal-gradient-dark::before {
        animation: gradient-shift 10s infinite;
    }
}

.block-cta--bg-teal-gradient-dark .block-cta__svg-lines {
    color: rgba(255, 255, 255, 0.6);
}

/* Standard backgrounds - SVG line color adjustments (subtle gray for decorative lines) */
.block-cta.block--bg-cream .block-cta__svg-lines,
.block-cta.block--bg-white .block-cta__svg-lines,
.block-cta.block--bg-light .block-cta__svg-lines {
    color: #E3E3E3;
}

.block-cta.block--bg-dark .block-cta__svg-lines {
    color: rgba(255, 255, 255, 0.15);
}

/* Note: CTA block uses the centralized .svg-lines system (see end of file) */

/* ==========================================================================
   CTA Inner Container
   ========================================================================== */

.block-cta__inner {
    position: relative;
    z-index: 2;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);
}

.block-cta__inner--has-illustration {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-2xl);
    align-items: center;

    @media (min-width: 992px) {
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-3xl);
    }
}

/* ==========================================================================
   CTA Content
   ========================================================================== */

.block-cta__content {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.block-cta__title {
    font-size: var(--text-4xl);
    font-weight: var(--font-semibold);
    line-height: var(--leading-snug);
    margin: 0;

    @media (max-width: 768px) {
        font-size: var(--text-3xl);
    }
}

.block-cta__subtitle {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
    opacity: 0.9;

    p {
        margin: 0;
    }
}

.block-cta__action {
    margin-top: var(--spacing-sm);
}

/* ==========================================================================
   CTA Illustration
   ========================================================================== */

.block-cta__illustration {
    display: flex;
    justify-content: center;
    align-items: center;

    @media (min-width: 768px) {
        justify-content: flex-end;
    }

    /* Hide illustration on tablets and stacked view */
    @media (max-width: 991px) {
        display: none;
    }

    img {
        max-width: 100%;
        height: auto;
        object-fit: contain;
    }
}

/* Illustration Max Height Variants */
.block-cta__illustration--max-300 img {
    max-height: 300px;
}

.block-cta__illustration--max-250 img {
    max-height: 250px;
}

.block-cta__illustration--max-200 img {
    max-height: 200px;
}

/* ==========================================================================
   Contained CTA Component (shared between block and shortcode)
   ========================================================================== */

.cta-contained {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);
    padding: var(--spacing-2xl) var(--spacing-xl);
    border-radius: var(--radius-2xl);
    align-items: flex-start;
}

/* Single CTA: horizontal layout on desktop */
.block-cta--contained-wrapper:not(.block-cta--two-column) .cta-contained {
    @media (min-width: 1201px) {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
        padding: var(--spacing-2xl) var(--spacing-3xl);
        gap: var(--spacing-2xl);
    }
}

/* Two-column CTA: keep vertical layout, button below */
.cta-contained-grid .cta-contained {
    padding: var(--spacing-2xl);
    height: 100%;
}

/* Dark Background (default) */
.cta-contained--bg-dark {
    background-color: var(--color-dark-gray);
    color: var(--color-white);
}

.cta-contained--bg-dark .cta-contained__title {
    color: var(--color-white);
}

.cta-contained--bg-dark .cta-contained__subtitle {
    color: rgba(255, 255, 255, 0.8);
}

/* Primary Background */
.cta-contained--bg-primary {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.cta-contained--bg-primary .cta-contained__title {
    color: var(--color-white);
}

.cta-contained--bg-primary .cta-contained__subtitle {
    color: rgba(255, 255, 255, 0.9);
}

/* White Background */
.cta-contained--bg-white {
    background-color: var(--color-white);
    color: var(--color-dark-gray);
    box-shadow: var(--shadow-md);
}

.cta-contained--bg-white .cta-contained__title {
    color: var(--color-dark-gray);
}

.cta-contained--bg-white .cta-contained__subtitle {
    color: var(--color-mid-gray);
}

/* Content */
.cta-contained__content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.cta-contained__title {
    font-size: var(--text-4xl);
    font-weight: var(--font-semibold);
    line-height: var(--leading-tight);
    margin: 0;

    @media (max-width: 768px) {
        font-size: var(--text-3xl);
    }
}

.cta-contained__title + .cta-contained__subtitle {
    margin-top: var(--spacing-sm);
}

/* Heading size modifiers */
.cta-contained__title--bigger {
    font-size: var(--text-5xl);

    @media (max-width: 768px) {
        font-size: var(--text-4xl);
    }
}

.cta-contained__title--smaller {
    font-size: var(--text-3xl);

    @media (max-width: 768px) {
        font-size: var(--text-2xl);
    }
}

.cta-contained__subtitle {
    font-size: var(--text-2xl);
    line-height: var(--leading-relaxed);
    margin: 0;
}

/* Action */
.cta-contained__action {
    flex-shrink: 0;
}

/* Button adjustments for white button on primary bg */
.cta-contained--bg-primary .btn--white {
    background-color: var(--color-white);
    color: var(--color-primary);
    border-color: var(--color-white);
}

.cta-contained--bg-primary .btn--white:hover {
    background-color: var(--color-cream);
    border-color: var(--color-cream);
}

/* Outline Style (secondary CTA) - Always transparent background */
.cta-contained--outline {
    background-color: transparent;
    border: 2px solid var(--color-primary);
    color: var(--color-dark-gray);
}

.cta-contained--outline .cta-contained__title {
    color: var(--color-dark-gray);
}

.cta-contained--outline .cta-contained__subtitle {
    color: var(--color-mid-gray);
}

/* Outline CTA on dark/primary backgrounds - light text */
.block--bg-dark .cta-contained--outline,
.block--bg-primary .cta-contained--outline {
    color: var(--color-white);
}

.block--bg-dark .cta-contained--outline .cta-contained__title,
.block--bg-primary .cta-contained--outline .cta-contained__title {
    color: var(--color-white);
}

.block--bg-dark .cta-contained--outline .cta-contained__subtitle,
.block--bg-primary .cta-contained--outline .cta-contained__subtitle {
    color: rgba(255, 255, 255, 0.8);
}

/* Two Column Grid Layout */
.cta-contained-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--spacing-lg);
}

@media (min-width: 768px) {
    .cta-contained-grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--spacing-xl);
    }
}

/* ==========================================================================
   Image Cards Block
   ========================================================================== */

.block-image-cards__header {
    text-align: center;
    margin-bottom: var(--spacing-2xl);
}

.block-image-cards__subtitle {
    margin: 0;
}

/* Grid Layout */
.block-image-cards__grid {
    display: grid;
    gap: var(--spacing-xl);
}

.block-image-cards--cols-2 .block-image-cards__grid {
    grid-template-columns: 1fr;
}

.block-image-cards--cols-3 .block-image-cards__grid {
    grid-template-columns: 1fr;
}

.block-image-cards--cols-4 .block-image-cards__grid {
    grid-template-columns: 1fr;
}

@media (min-width: 640px) {
    .block-image-cards--cols-2 .block-image-cards__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .block-image-cards--cols-3 .block-image-cards__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .block-image-cards--cols-4 .block-image-cards__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .block-image-cards--cols-3 .block-image-cards__grid {
        grid-template-columns: repeat(3, 1fr);
    }

    .block-image-cards--cols-4 .block-image-cards__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Card Base */
.block-image-cards__card {
    display: flex;
    flex-direction: column;
}

/* Card Style Variations */
.block-image-cards--card-none .block-image-cards__card {
    background: transparent;
}

.block-image-cards--card-white .block-image-cards__image-wrapper {
    background-color: var(--color-white);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.block-image-cards--card-light .block-image-cards__image-wrapper {
    background-color: var(--color-light-gray);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.block-image-cards--card-medium .block-image-cards__image-wrapper {
    background-color: var(--color-mid-gray);
    border-radius: var(--radius-xl);
    overflow: hidden;
}

/* Image Wrapper */
.block-image-cards__image-wrapper {
    aspect-ratio: 4 / 3;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

/* Image Fit Variations (per card) */
.block-image-cards__card--fit-cover .block-image-cards__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.block-image-cards__card--fit-contain .block-image-cards__image {
    max-width: 80%;
    max-height: 80%;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Content Area */
.block-image-cards__content {
    padding: var(--spacing-lg) 0 0;
}

.block-image-cards__title {
    font-size: var(--text-2xl);
    font-weight: var(--font-semibold);
    line-height: var(--leading-tight);
    margin: 0 0 var(--spacing-xs);
}

.block-image-cards__title--no-role {
    margin-bottom: var(--spacing-md);
}

.block-image-cards__role {
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--color-mid-gray);
    margin: 0 0 var(--spacing-md);
}

/* Role color on dark backgrounds */
.block--bg-dark .block-image-cards__role {
    color: rgba(255, 255, 255, 0.7);
}

.block-image-cards__description {
    font-size: var(--text-base);
    line-height: var(--leading-relaxed);
    margin: 0;
    color: var(--color-mid-gray);
}

/* Description color on dark backgrounds */
.block--bg-dark .block-image-cards__description {
    color: rgba(255, 255, 255, 0.8);
}

/* Link styling */
a.underline.block-image-cards__link {
    margin-top: var(--spacing-md);
    font-size: var(--text-base);
}

.block--bg-dark a.underline.block-image-cards__link {
    color: #fff;
}

.block--bg-dark a.underline.block-image-cards__link::before {
    background-color: rgba(255, 255, 255, 0.3);
}

.block--bg-dark a.underline.block-image-cards__link::after {
    background-color: var(--color-secondary);
}

/* ==========================================================================
   Testimonial Block
   ========================================================================== */

.block-testimonial {
    position: relative;
    overflow: hidden;
}

/* Teal Gradient Background */
.block-testimonial--teal-gradient {
    position: relative;
}

.block-testimonial--teal-gradient::before {
    content: '';
    position: absolute;
    display: block;
    width: 200%;
    height: 120%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: linear-gradient(90deg, rgb(248, 248, 244) 0%, rgb(170, 226, 219) 100%);
    z-index: 0;
    animation: gradient-shift 10s ease-in-out infinite;
}

.block-testimonial--teal-gradient > .container,
.block-testimonial--teal-gradient > .container-narrow,
.block-testimonial--teal-gradient > .container-wide {
    position: relative;
    z-index: 2;
}

.block-testimonial--teal-gradient .block-testimonial__svg-accent {
    color: rgba(255, 255, 255, 0.6);
}

/* Orange Gradient Background */
.block-testimonial--orange-gradient {
    position: relative;
}

.block-testimonial--orange-gradient::before {
    content: '';
    position: absolute;
    display: block;
    width: 200%;
    height: 120%;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    background: linear-gradient(90deg, var(--color-yellow) 0%, var(--color-primary) 100%);
    z-index: 0;
    animation: gradient-shift 10s ease-in-out infinite;
}

.block-testimonial--orange-gradient > .container,
.block-testimonial--orange-gradient > .container-narrow,
.block-testimonial--orange-gradient > .container-wide {
    position: relative;
    z-index: 2;
}

.block-testimonial--orange-gradient .block-testimonial__svg-accent {
    color: rgba(255, 255, 255, 0.6);
}

/* SVG Accent for Simple Quote - centered at bottom */
.block-testimonial__svg-accent {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: auto;
    pointer-events: none;
    z-index: 1;
    color: rgba(255, 255, 255, 0.6);
    display: flex;
    justify-content: center;
}

.block-testimonial__svg-accent svg {
    width: 100%;
    max-width: 1318px;
    height: auto;
    display: block;
}

/* ==========================================================================
   Simple Quote Style
   ========================================================================== */

.block-testimonial__simple {
    position: relative;
    z-index: 2;
    text-align: center;
    max-width: 900px;
    margin: 0 auto;
}

/* Simple Quote style uses decorative font */
.block-testimonial--simple_quote .block-testimonial__quote {
    font-family: var(--font-decorative);
}

.block-testimonial__quote {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    font-weight: var(--font-medium);
    font-style: normal;
    line-height: 1.25;
    color: var(--color-dark-gray);
    margin: 0 0 var(--spacing-lg) 0;
    padding: 0;
    border: none;
    background: none;

    @media (min-width: 768px) {
        font-size: var(--text-4xl);
    }

    @media (min-width: 1024px) {
        font-size: 2.2rem;
    }

    /* Quote marks only for simple quote (not --with-marks or --mobile which use PHP spans) */
    &:not(.block-testimonial__quote--with-marks):not(.block-testimonial__quote--mobile) {
        &::before {
            content: '\201C';
        }

        &::after {
            content: '\201D';
        }
    }

    & p {
        margin: 0;
        display: inline;
    }
}

.block-testimonial__cite {
    display: block;
    font-style: italic;
    font-size: var(--text-lg);
    color: var(--color-dark-gray);
}

.block-testimonial__author {
    font-weight: var(--font-semibold);
}

.block-testimonial__role {
    font-weight: var(--font-normal);
}

/* ==========================================================================
   Image Quote Style
   ========================================================================== */

.block-testimonial__headline sub {
    display: block;
    font-size: 0.5em;
    font-weight: var(--font-normal);
    text-transform: none;
    margin-bottom: var(--spacing-xs);
}

.block-testimonial__headline--left {
    text-align: left;

    @media (max-width: 767px) {
        text-align: center;
    }
}

.block-testimonial__headline--center {
    text-align: center;
}

.block-testimonial__image-quote {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xl);

    @media (min-width: 768px) {
        flex-direction: row;
        align-items: center;
        gap: var(--spacing-2xl);
    }
}

.block-testimonial__image-wrapper {
    flex: 0 0 auto;
    width: 100%;
    max-width: 400px;

    @media (min-width: 768px) {
        flex: 0 0 45%;
        max-width: none;
    }
}

.block-testimonial__image {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    object-fit: cover;
}

.block-testimonial__content {
    flex: 1;
}

.block-testimonial__quote--with-marks {
    font-family: var(--font-heading);
    font-size: var(--text-2xl);
    font-weight: var(--font-semibold);
    font-style: normal;
    line-height: 1.2;
    color: var(--color-dark-gray);
    margin: 0 0 var(--spacing-lg) 0;
    padding: 0;
    border: none;
    background: none;

    @media (min-width: 768px) {
        font-size: 1.625rem;
    }

    @media (min-width: 1024px) {
        font-size: 1.875rem;
    }

    @media (min-width: 1200px) {
        font-size: 2rem;
        text-wrap: pretty;
    }

    & p {
        margin: 0;
        display: inline;
    }
}

.block-testimonial__quote-mark {
    color: var(--color-primary);
}

.block-testimonial__meta {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);

    @media (min-width: 768px) {
        flex-direction: row;
        align-items: flex-end;
        justify-content: space-between;
    }
}

.block-testimonial__author-info {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.block-testimonial--image_quote .block-testimonial__author {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
    font-style: normal;
}

.block-testimonial--image_quote .block-testimonial__role {
    font-size: var(--text-lg);
    color: var(--color-mid-gray);
}

.block-testimonial__logo {
    flex-shrink: 0;
}

.block-testimonial__logo-img {
    max-width: 150px;
    max-height: 50px;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* ==========================================================================
   Carousel Style
   ========================================================================== */

/* Desktop Carousel */
.block-testimonial__carousel-desktop {
    display: none;

    @media (min-width: 768px) {
        display: block;
    }
}

.block-testimonial__carousel {
    position: relative;
}

.block-testimonial__carousel.flickity-enabled {
    outline: none;
}

.block-testimonial__slide {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: var(--spacing-2xl);
    width: 100%;
    padding-right: var(--spacing-md);
}

.block-testimonial__slide-image {
    flex: 0 0 45%;
    max-width: 500px;
}

.block-testimonial__slide-image .block-testimonial__image {
    border-radius: var(--radius-lg);
}

.block-testimonial__slide-content {
    flex: 1;
}

.block-testimonial__slide-meta {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.block-testimonial--carousel .block-testimonial__author {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
    display: block;
}

.block-testimonial--carousel .block-testimonial__role {
    font-size: var(--text-lg);
    color: var(--color-mid-gray);
    display: block;
}

/* Logo Navigation */
.block-testimonial__nav {
    display: flex;
    align-items: center;
    gap: 0;
    margin-top: var(--spacing-2xl);
    position: relative;
}

.block-testimonial__nav-item {
    position: relative;
    flex: 1;
    padding: var(--spacing-md) var(--spacing-sm);
    padding-top: calc(var(--spacing-md) + 8px);
    background: transparent;
    border: none;
    cursor: pointer;
    transition: opacity var(--transition-base);
    display: flex;
    align-items: center;
    justify-content: center;

    &::before {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        right: 0;
        height: 1px;
        background-color: var(--color-gray);
    }

    &::after {
        content: '';
        position: absolute;
        top: 0;
        left: 0;
        width: 0;
        height: 3px;
        background-color: var(--color-primary);
        transition: width 0s linear;
    }

    & img {
        opacity: 0.5;
        transition: opacity var(--transition-base);
    }

    &:hover img {
        opacity: 0.7;
    }
}

/* Active state - must be separate due to BEM modifier with native CSS nesting */
.block-testimonial__nav-item--active::after {
    width: 100%;
    transition: width 10s linear;
}

.block-testimonial__nav-item--active img {
    opacity: 1;
}

.block-testimonial__nav-logo {
    max-width: 150px;
    max-height: 50px;
    width: auto;
    height: auto;
    object-fit: contain;
}

/* Mobile Carousel */
.block-testimonial__carousel-mobile {
    display: block;

    @media (min-width: 768px) {
        display: none;
    }
}

.block-testimonial__carousel-mobile-inner {
    position: relative;
}

.block-testimonial__carousel-mobile-inner.flickity-enabled {
    outline: none;
}

.block-testimonial__mobile-slide {
    width: 100%;
    text-align: center;
    padding: 0 var(--spacing-md);
}

.block-testimonial__mobile-logo {
    margin-bottom: var(--spacing-lg);
}

.block-testimonial__mobile-logo img {
    max-width: 150px;
    max-height: 50px;
    width: auto;
    height: auto;
    margin: 0 auto;
}

.block-testimonial__quote--mobile {
    font-family: var(--font-heading);
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    font-style: normal;
    line-height: 1.4;
    color: var(--color-dark-gray);
    margin: 0 0 var(--spacing-lg) 0;
    padding: 0 var(--spacing-2xl);
    border: none;
    background: none;
    text-align: center;
}

.block-testimonial__mobile-meta {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
    text-align: center;
}

.block-testimonial__mobile-meta .block-testimonial__author {
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
}

.block-testimonial__mobile-meta .block-testimonial__role {
    font-size: var(--text-base);
    color: var(--color-mid-gray);
}

/* Flickity Overrides for Testimonial */
.block-testimonial .flickity-viewport {
    overflow: hidden;
}

.block-testimonial .flickity-slider {
    position: relative;
}

/* Desktop carousel - no prev/next buttons */
.block-testimonial__carousel-desktop .flickity-button {
    display: none;
}

/* Mobile carousel arrows - positioned at sides */
.block-testimonial__carousel-mobile .flickity-button {
    display: block;
    position: absolute;
    cursor: pointer;
    width: 40px;
    height: 40px;
    border: none;
    background-color: transparent;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 6 L15 12 L9 18' stroke='%23999999' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 24px 24px;
    opacity: 0.5;
    transition: opacity 0.3s ease;
    z-index: 2;
    top: 50%;
    transform: translateY(-50%);
}

.block-testimonial__carousel-mobile .flickity-button:hover {
    opacity: 0.8;
    background-color: transparent;
}

.block-testimonial__carousel-mobile .flickity-button-icon {
    display: none;
}

.block-testimonial__carousel-mobile .flickity-prev-next-button.previous {
    left: 0;
    right: auto;
    transform: translateY(-50%) rotate(180deg);
}

.block-testimonial__carousel-mobile .flickity-prev-next-button.next {
    right: 0;
    left: auto;
    transform: translateY(-50%);
}

/* Flickity Page Dots for mobile - simple dots like old theme */
.block-testimonial__carousel-mobile .flickity-page-dots {
    display: flex;
    flex-direction: row;
    justify-content: center;
    position: relative;
    bottom: -37px;
    width: 100%;
    padding: 0;
    margin: 0;
    list-style: none;
}

.block-testimonial__carousel-mobile .flickity-page-dots .dot {
    width: 10px;
    height: 10px;
    margin: 0 5px;
    padding: 0;
    background-color: var(--color-gray);
    border-radius: 50%;
    opacity: 0.6;
    cursor: pointer;
    transition: background-color var(--transition-base), opacity var(--transition-base);
}

.block-testimonial__carousel-mobile .flickity-page-dots .dot.is-selected {
    background-color: var(--color-primary);
    opacity: 1;
}

/* -----------------------------------------------------
   Testimonial Carousel - Dark Background
   ----------------------------------------------------- */

.block--bg-dark.block-testimonial--carousel .block-testimonial__quote {
    color: var(--color-white);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__author {
    color: var(--color-white);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__role {
    color: rgba(255, 255, 255, 0.7);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__nav-item::before {
    background-color: rgba(255, 255, 255, 0.3);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__nav-item img {
    filter: brightness(0) invert(1);
    opacity: 0.5;
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__nav-item:hover img {
    opacity: 0.7;
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__nav-item--active img {
    opacity: 1;
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__headline {
    color: var(--color-white);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__quote--mobile {
    color: var(--color-white);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__mobile-meta .block-testimonial__author {
    color: var(--color-white);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__mobile-meta .block-testimonial__role {
    color: rgba(255, 255, 255, 0.7);
}

.block--bg-dark.block-testimonial--carousel .block-testimonial__mobile-logo img {
    filter: brightness(0) invert(1);
}

.block--bg-dark.block-testimonial--carousel .flickity-page-dots .dot {
    background-color: rgba(255, 255, 255, 0.4);
}

.block--bg-dark.block-testimonial--carousel .flickity-page-dots .dot.is-selected {
    background-color: var(--color-white);
}

.block--bg-dark.block-testimonial--carousel .flickity-button {
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 6 L15 12 L9 18' stroke='%23ffffff' stroke-width='2' fill='none' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
}

/* ==========================================================================
   Testimonial Card Style (contained carousel with rating)
   ========================================================================== */

.block-testimonial__card {
    padding: var(--spacing-3xl) var(--spacing-2xl);
    border-radius: var(--radius-2xl);
    text-align: center;

    @media (min-width: 768px) {
        padding: var(--spacing-4xl) var(--spacing-3xl);
    }
}

/* Card Background Variants */
.block-testimonial__card--bg-dark {
    background-color: var(--color-dark-gray);
    color: var(--color-white);
}

.block-testimonial__card--bg-white {
    background-color: var(--color-gray-100);
    color: var(--color-dark-gray);
}

.block-testimonial__card--bg-primary {
    background-color: var(--color-primary);
    color: var(--color-white);
}

/* Adjust card backgrounds for contrast on matching section backgrounds */
.block--bg-dark .block-testimonial__card--bg-dark {
    background-color: #3a3a3a;
}

.block--bg-white .block-testimonial__card--bg-white,
.block--bg-cream .block-testimonial__card--bg-white {
    background-color: var(--color-white);
    box-shadow: var(--shadow-md);
}

/* Rating */
.block-testimonial__card-rating {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-xl);
}

.block-testimonial__card-stars {
    display: flex;
    gap: 2px;
    color: var(--color-primary);
}

.block-testimonial__card-stars svg {
    width: 20px;
    height: 20px;
}

.block-testimonial__card-rating-value {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
}

.block-testimonial__card--bg-dark .block-testimonial__card-rating-value {
    color: var(--color-white);
}

.block-testimonial__card--bg-white .block-testimonial__card-rating-value {
    color: var(--color-dark-gray);
}

/* Card Carousel */
.block-testimonial__card-carousel {
    position: relative;
    margin-bottom: var(--spacing-xl);
}

.block-testimonial__card-slide {
    display: none;
}

.block-testimonial__card-slide--active {
    display: block;
}

.block-testimonial__card-quote {
    font-size: var(--text-2xl);
    font-weight: var(--font-semibold);
    font-style: normal;
    line-height: 1.4;
    margin: 0;
    padding: 0;
    border: 0;
    quotes: none;

    @media (min-width: 768px) {
        font-size: var(--text-3xl);
    }

    @media (min-width: 1024px) {
        font-size: var(--text-4xl);
    }
}

.block-testimonial__card--bg-dark .block-testimonial__card-quote {
    color: var(--color-white);
}

.block-testimonial__card--bg-white .block-testimonial__card-quote {
    color: var(--color-dark-gray);
}

.block-testimonial__card-quote .block-testimonial__quote-mark {
    color: var(--color-primary);
}

/* Card Navigation with Arrows and Image */
.block-testimonial__card-nav {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-md);
}

.block-testimonial__card-arrow {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: none;
    background: transparent;
    cursor: pointer;
    transition: opacity 0.2s ease;
    opacity: 0.5;
}

.block-testimonial__card-arrow:hover {
    opacity: 1;
}

.block-testimonial__card--bg-dark .block-testimonial__card-arrow {
    color: var(--color-white);
}

.block-testimonial__card--bg-white .block-testimonial__card-arrow {
    color: var(--color-dark-gray);
}

.block-testimonial__card--bg-primary .block-testimonial__card-arrow {
    color: var(--color-white);
}

/* Person Image Carousel */
.block-testimonial__card-person {
    position: relative;
}

.block-testimonial__card-person-slide {
    display: none;
}

.block-testimonial__card-person-slide--active {
    display: block;
}

.block-testimonial__card-image {
    width: 100px;
    height: 100px;
    border-radius: 50%;
    overflow: hidden;
}

.block-testimonial__card-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Meta (Name & Title) */
.block-testimonial__card-meta {
    position: relative;
}

.block-testimonial__card-meta-slide {
    display: none;
}

.block-testimonial__card-meta-slide--active {
    display: block;
}

.block-testimonial__card-author {
    display: block;
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    margin-bottom: 2px;
}

.block-testimonial__card--bg-dark .block-testimonial__card-author {
    color: var(--color-white);
}

.block-testimonial__card--bg-white .block-testimonial__card-author {
    color: var(--color-dark-gray);
}

.block-testimonial__card-role {
    display: block;
    font-size: var(--text-sm);
    opacity: 0.7;
}

.block-testimonial__card--bg-dark .block-testimonial__card-role {
    color: var(--color-white);
}

.block-testimonial__card--bg-white .block-testimonial__card-role {
    color: var(--color-mid-gray);
    opacity: 1;
}

/* ==========================================================================
   Text & Image Block
   A versatile text and image block with three style variants:
   - Contained: 50/50 split within container
   - Stretched: Image takes 50% viewport width
   - Image Background: Full-width image with floating content box
   ========================================================================== */

/* ==========================================================================
   Base Styles
   ========================================================================== */

.block-text-image {
    position: relative;
    overflow: hidden;
}

/* Subtitle styling */
.block-text-image__subtitle {
    font-size: var(--text-4xl);
    font-weight: var(--font-semibold);
    line-height: var(--leading-tight);
    margin-bottom: var(--spacing-lg);
    color: var(--color-dark-gray);

    @media (max-width: 768px) {
        font-size: var(--text-3xl);
    }

    em {
        font-family: var(--font-decorative);
        font-style: normal;
        font-weight: 500;
    }
}

/* Dark background subtitle */
.block--bg-dark .block-text-image__subtitle {
    color: var(--color-white);
}

/* Content styling */
.block-text-image__content {
    font-size: var(--text-lg);
    line-height: var(--leading-relaxed);
    color: var(--color-mid-gray);

    p {
        margin-bottom: var(--spacing-md);

        &:last-child {
            margin-bottom: 0;
        }
    }

    strong {
        color: var(--color-dark-gray);
        font-weight: var(--font-semibold);
    }

    ul, ol {
        margin-bottom: var(--spacing-md);
        padding-left: var(--spacing-xl);
    }
}

/* Dark background content */
.block--bg-dark .block-text-image__content {
    color: rgba(255, 255, 255, 0.85);

    strong {
        color: var(--color-white);
    }
}

/* CTA buttons */
.block-text-image__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-md);
    margin-top: var(--spacing-xl);
}

/* ==========================================================================
   Contained Style (Default)
   50/50 split within container
   ========================================================================== */

.block-text-image--style-contained .block-text-image__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-3xl);
    align-items: center;

    @media (max-width: 992px) {
        grid-template-columns: 1fr;
        gap: var(--spacing-2xl);
    }
}

/* Image Left - Reverse grid order */
.block-text-image--style-contained.block-text-image--image-left .block-text-image__grid {
    @media (min-width: 993px) {
        direction: rtl;

        & > * {
            direction: ltr;
        }
    }
}

/* Vertical alignment */
.block-text-image--style-contained.block-text-image--valign-top .block-text-image__grid {
    align-items: flex-start;
}

.block-text-image--style-contained.block-text-image--valign-bottom .block-text-image__grid {
    align-items: flex-end;
}

/* Content column */
.block-text-image--style-contained .block-text-image__content-column {
    @media (max-width: 992px) {
        order: 2;
    }
}

/* Image column */
.block-text-image--style-contained .block-text-image__image-column {
    @media (max-width: 992px) {
        order: 1;
    }
}

/* Image wrapper */
.block-text-image--style-contained .block-text-image__image-wrapper {
    position: relative;
    overflow: hidden;
}

.block-text-image--style-contained .block-text-image__image {
    width: 100%;
    height: auto;
    display: block;
}

/* ==========================================================================
   Image Alignment / Edge Bleed (Contained Style)
   Removes padding on one side so image can "bleed" to edge
   ========================================================================== */

/* Bottom alignment - image touches bottom of container */
.block-text-image--img-align-bottom .block-text-image__image-wrapper {
    margin-bottom: calc(-1 * var(--spacing-section-default, 80px));
}

.block-text-image--img-align-bottom .block-text-image__grid {
    align-items: flex-end;
}

.block-text-image--img-align-bottom .block-text-image__image {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
}

/* Top alignment - image touches top of container */
.block-text-image--img-align-top .block-text-image__image-wrapper {
    margin-top: calc(-1 * var(--spacing-section-default, 80px));
}

.block-text-image--img-align-top .block-text-image__grid {
    align-items: flex-start;
}

.block-text-image--img-align-top .block-text-image__image {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

/* Left alignment - image bleeds to left */
.block-text-image--img-align-left.block-text-image--image-left .block-text-image__image-wrapper {
    margin-left: calc(-50vw + 50%);
    width: calc(100% + 50vw - 50%);
}

.block-text-image--img-align-left.block-text-image--image-left .block-text-image__image {
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

/* Right alignment - image bleeds to right */
.block-text-image--img-align-right.block-text-image--image-right .block-text-image__image-wrapper {
    margin-right: calc(-50vw + 50%);
    width: calc(100% + 50vw - 50%);
}

.block-text-image--img-align-right.block-text-image--image-right .block-text-image__image {
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}

/* Responsive adjustments - disable edge bleed on mobile */
@media (max-width: 992px) {
    .block-text-image--img-align-bottom .block-text-image__image-wrapper,
    .block-text-image--img-align-top .block-text-image__image-wrapper {
        margin-top: 0;
        margin-bottom: 0;
    }
    
    .block-text-image--img-align-left .block-text-image__image-wrapper,
    .block-text-image--img-align-right .block-text-image__image-wrapper {
        margin-left: 0;
        margin-right: 0;
        width: 100%;
    }
    
    .block-text-image--img-align-bottom .block-text-image__image,
    .block-text-image--img-align-top .block-text-image__image,
    .block-text-image--img-align-left .block-text-image__image,
    .block-text-image--img-align-right .block-text-image__image {
        border-radius: var(--radius-xl);
    }
}

/* ==========================================================================
   Aspect Ratio Variations
   ========================================================================== */

.block-text-image--ratio-1-1 .block-text-image__image-wrapper {
    aspect-ratio: 1 / 1;
}

.block-text-image--ratio-4-3 .block-text-image__image-wrapper {
    aspect-ratio: 4 / 3;
}

.block-text-image--ratio-3-2 .block-text-image__image-wrapper {
    aspect-ratio: 3 / 2;
}

.block-text-image--ratio-16-9 .block-text-image__image-wrapper {
    aspect-ratio: 16 / 9;
}

/* When aspect ratio is set, image should fill container */
:is(.block-text-image--ratio-1-1, .block-text-image--ratio-4-3, .block-text-image--ratio-3-2, .block-text-image--ratio-16-9) .block-text-image__image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

:is(.block-text-image--ratio-1-1, .block-text-image--ratio-4-3, .block-text-image--ratio-3-2, .block-text-image--ratio-16-9) .block-text-image__image-wrapper {
    position: relative;
}

/* ==========================================================================
   Image Fit Variations
   ========================================================================== */

.block-text-image--fit-cover .block-text-image__image {
    object-fit: cover;
}

.block-text-image--fit-contain .block-text-image__image {
    object-fit: contain;
}

/* ==========================================================================
   Border Radius Variations
   ========================================================================== */

.block-text-image--radius-none .block-text-image__image-wrapper {
    border-radius: 0;
}

.block-text-image--radius-small .block-text-image__image-wrapper {
    border-radius: var(--radius-md);
}

.block-text-image--radius-medium .block-text-image__image-wrapper {
    border-radius: var(--radius-xl);
}

.block-text-image--radius-large .block-text-image__image-wrapper {
    border-radius: var(--radius-3xl);
}

/* ==========================================================================
   Mobile Options
   ========================================================================== */

/* Hide image on mobile */
.block-text-image--hide-image-mobile .block-text-image__image-column {
    @media (max-width: 992px) {
        display: none;
    }
}

/* Mobile image position - above content (default) */
.block-text-image--mobile-top .block-text-image__image-column {
    @media (max-width: 992px) {
        order: 1;
    }
}

.block-text-image--mobile-top .block-text-image__content-column {
    @media (max-width: 992px) {
        order: 2;
    }
}

/* Mobile image position - below content */
.block-text-image--mobile-bottom .block-text-image__image-column {
    @media (max-width: 992px) {
        order: 2;
    }
}

.block-text-image--mobile-bottom .block-text-image__content-column {
    @media (max-width: 992px) {
        order: 1;
    }
}

/* ==========================================================================
   Stretched Style
   Image bleeds to edge (50vw), content stays in container flow
   ========================================================================== */

.block-text-image--style-stretched {
    position: relative;
    overflow: hidden;
    min-height: 500px;
    display: flex;
    flex-direction: column;

    /* Container stretches to fill available height */
    & > .container,
    & > .container-wide,
    & > .container-narrow {
        flex: 1 1 auto;
        display: flex;
        flex-direction: column;
    }

    @media (max-width: 992px) {
        min-height: auto;
        display: block;

        & > .container,
        & > .container-wide,
        & > .container-narrow {
            display: block;
        }
    }
}

/* --------------------------------------------------------------------------
   Stretched Height Variations
   -------------------------------------------------------------------------- */

.block-text-image--height-400 { min-height: 400px; }
.block-text-image--height-500 { min-height: 500px; }
.block-text-image--height-600 { min-height: 600px; }
.block-text-image--height-700 { min-height: 700px; }
.block-text-image--height-800 { min-height: 800px; }

/* On mobile, height variations reset to auto */
@media (max-width: 992px) {
    :is(.block-text-image--height-400, .block-text-image--height-500, .block-text-image--height-600, .block-text-image--height-700, .block-text-image--height-800) {
        min-height: auto;
    }
}

/* Image - absolute positioned to bleed to screen edge */
.block-text-image--style-stretched .block-text-image__image-bleed {
    position: absolute;
    top: 0;
    right: 0;
    width: 50%;
    height: 100%;

    @media (max-width: 992px) {
        position: relative;
        width: 100%;
        height: auto;
        min-height: 300px;
    }
}

/* Image left - position to left edge */
.block-text-image--style-stretched.block-text-image--image-left .block-text-image__image-bleed {
    right: auto;
    left: 0;
}

.block-text-image--style-stretched .block-text-image__image-bleed .block-text-image__image {
    width: 100%;
    height: 100%;
    object-fit: cover;

    @media (max-width: 992px) {
        height: auto;
        min-height: 300px;
    }
}

/* Grid inside container - 50/50 split */
.block-text-image--style-stretched .block-text-image__stretched-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    flex: 1 1 auto;

    @media (max-width: 992px) {
        display: block;
    }
}

/* Content takes left column (image-right default) */
.block-text-image--style-stretched .block-text-image__stretched-grid .block-text-image__content-inner {
    grid-column: 1;
    display: flex;
    flex-direction: column;
    justify-content: center;
    padding-right: var(--spacing-3xl);
    padding-top: var(--spacing-3xl);
    padding-bottom: var(--spacing-3xl);

    @media (max-width: 992px) {
        padding: var(--spacing-2xl) 0;
        grid-column: auto;
    }
}

/* Image left - content goes in right column */
.block-text-image--style-stretched.block-text-image--image-left .block-text-image__stretched-grid .block-text-image__content-inner {
    grid-column: 2;
    padding-right: 0;
    padding-left: var(--spacing-3xl);

    @media (max-width: 992px) {
        padding: var(--spacing-2xl) 0;
        grid-column: auto;
    }
}

/* Vertical alignment for stretched */
.block-text-image--style-stretched.block-text-image--valign-top .block-text-image__content-inner {
    justify-content: flex-start;
}

.block-text-image--style-stretched.block-text-image--valign-bottom .block-text-image__content-inner {
    justify-content: flex-end;
}

/* Full bleed image style - image already fills the bleed container */
.block-text-image--stretched-full_bleed .block-text-image__image-bleed .block-text-image__image {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* ==========================================================================
   Contained with Background Image Style
   Image floats within a colored/gradient background with configurable padding
   ========================================================================== */

.block-text-image--stretched-contained_padded {
    /* Background wrapper - fills the bleed area */
    & .block-text-image__image-bg-wrapper {
        position: absolute;
        inset: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        overflow: hidden;
        padding: var(--spacing-3xl);

        @media (max-width: 992px) {
            padding: var(--spacing-2xl);
        }
    }

    /* Image container - holds the image within padding bounds */
    & .block-text-image__image-container {
        position: relative;
        z-index: 2;
        width: 100%;
        height: 100%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    /* Image - fills container maintaining aspect ratio */
    & .block-text-image__image-container .block-text-image__image {
        width: 100%;
        height: 100%;
        object-fit: contain;
        display: block;
    }

    /* Mobile: Ensure proper sizing */
    @media (max-width: 992px) {
        & .block-text-image__image-bleed {
            min-height: 350px;
            aspect-ratio: 4 / 3;
        }
    }
}

/* --------------------------------------------------------------------------
   Padding Variations
   -------------------------------------------------------------------------- */

.block-text-image--img-padding-small .block-text-image__image-bg-wrapper {
    padding: var(--spacing-2xl);

    @media (max-width: 992px) { padding: var(--spacing-xl); }
    @media (max-width: 768px) { padding: var(--spacing-lg); }
}

.block-text-image--img-padding-medium .block-text-image__image-bg-wrapper {
    padding: var(--spacing-3xl);

    @media (max-width: 992px) { padding: var(--spacing-2xl); }
    @media (max-width: 768px) { padding: var(--spacing-xl); }
}

.block-text-image--img-padding-large .block-text-image__image-bg-wrapper {
    padding: var(--spacing-4xl);

    @media (max-width: 992px) { padding: var(--spacing-3xl); }
    @media (max-width: 768px) { padding: var(--spacing-2xl); }
}

/* ==========================================================================
   Image Position / Alignment
   Pins image to a side or corner by removing padding and adjusting alignment
   ========================================================================== */

/* Shared styles for all positioned images */
[class*="block-text-image--img-pos-"] {
    & .block-text-image__image-container {
        width: auto;
        height: 100%;
        max-width: 100%;
    }

    & .block-text-image__image-container .block-text-image__image {
        width: auto;
        height: 100%;
        max-width: 100%;
        object-fit: contain;
    }
}

/* Top alignment */
:is(.block-text-image--img-pos-top, .block-text-image--img-pos-top-left, .block-text-image--img-pos-top-right) {
    & .block-text-image__image-bg-wrapper {
        padding-top: 0 !important;
        align-items: flex-start;
    }

    & .block-text-image__image-container {
        align-items: flex-start;
    }
}

/* Bottom alignment */
:is(.block-text-image--img-pos-bottom, .block-text-image--img-pos-bottom-left, .block-text-image--img-pos-bottom-right) {
    & .block-text-image__image-bg-wrapper {
        padding-bottom: 0 !important;
        align-items: flex-end;
    }

    & .block-text-image__image-container {
        align-items: flex-end;
    }
}

/* Left alignment */
:is(.block-text-image--img-pos-left, .block-text-image--img-pos-top-left, .block-text-image--img-pos-bottom-left) {
    & .block-text-image__image-bg-wrapper {
        padding-left: 0 !important;
        justify-content: flex-start;
    }

    & .block-text-image__image-container {
        justify-content: flex-start;
    }
}

/* Right alignment */
:is(.block-text-image--img-pos-right, .block-text-image--img-pos-top-right, .block-text-image--img-pos-bottom-right) {
    & .block-text-image__image-bg-wrapper {
        padding-right: 0 !important;
        justify-content: flex-end;
    }

    & .block-text-image__image-container {
        justify-content: flex-end;
    }
}

/* SVG Pattern overlay */
.block-text-image__svg-pattern {
    position: absolute;
    inset: 0;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
    color: rgba(250, 249, 246, 0.6);

    svg {
        position: absolute;
        top: 0;
        left: 50%;
        transform: translateX(-50%);
        min-width: 100%;
        min-height: 100%;
    }
}

/* ==========================================================================
   Image Background Gradient Variations (for stretched style)
   ========================================================================== */

/* Orange Gradient */
.block-text-image--img-bg-orange-gradient .block-text-image__image-bg-wrapper {
    background: linear-gradient(135deg, var(--color-yellow) 0%, var(--color-primary) 100%);
}

.block-text-image--img-bg-orange-gradient .block-text-image__svg-pattern {
    color: rgba(250, 249, 246, 0.5);
}

/* Teal Gradient */
.block-text-image--img-bg-teal-gradient .block-text-image__image-bg-wrapper {
    background: linear-gradient(135deg, var(--color-cream) 0%, var(--color-teal) 100%);
}

.block-text-image--img-bg-teal-gradient .block-text-image__svg-pattern {
    color: rgba(250, 249, 246, 0.4);
}

/* Yellow Gradient */
.block-text-image--img-bg-yellow-gradient .block-text-image__image-bg-wrapper {
    background: linear-gradient(135deg, var(--color-yellow) 0%, var(--color-yellow-dark) 100%);
}

.block-text-image--img-bg-yellow-gradient .block-text-image__svg-pattern {
    color: rgba(250, 249, 246, 0.5);
}

/* Dark background */
.block-text-image--img-bg-dark .block-text-image__image-bg-wrapper {
    background-color: var(--color-dark-gray);
}

.block-text-image--img-bg-dark .block-text-image__svg-pattern {
    color: rgba(255, 255, 255, 0.15);
}

/* Cream background */
.block-text-image--img-bg-cream .block-text-image__image-bg-wrapper {
    background-color: var(--color-cream);
}

.block-text-image--img-bg-cream .block-text-image__svg-pattern {
    color: rgba(0, 0, 0, 0.05);
}

/* ==========================================================================
   Image Background Style
   Full-width image with floating content box
   ========================================================================== */

.block-text-image--style-image_background {
    position: relative;
    min-height: 500px;
    display: flex;
    align-items: center;
    padding-top: var(--spacing-4xl);
    padding-bottom: var(--spacing-4xl);

    @media (max-width: 768px) {
        min-height: 400px;
        padding-top: var(--spacing-3xl);
        padding-bottom: var(--spacing-3xl);
    }
}

/* Background image */
.block-text-image__background-image {
    position: absolute;
    inset: 0;
    z-index: 1;
}

.block-text-image__bg-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/* Container positioning */
.block-text-image--style-image_background .container {
    position: relative;
    z-index: 2;
}

/* Content box */
.block-text-image__content-box {
    max-width: 50%;
    padding: var(--spacing-2xl);
    border-radius: var(--radius-xl);

    @media (max-width: 992px) {
        max-width: 100%;
        padding: var(--spacing-xl);
    }
}

/* Content box position - Left */
.block-text-image--content-pos-left .block-text-image__content-box {
    margin-right: auto;
}

/* Content box position - Right */
.block-text-image--content-pos-right .block-text-image__content-box {
    margin-left: auto;
}

/* Content box background - Dark */
.block-text-image--content-bg-dark .block-text-image__content-box {
    background-color: var(--color-dark-gray);
}

.block-text-image--content-bg-dark .block-text-image__subtitle {
    color: var(--color-white);
}

.block-text-image--content-bg-dark .block-text-image__content {
    color: rgba(255, 255, 255, 0.85);

    strong {
        color: var(--color-white);
    }
}

.block-text-image--content-bg-dark .btn--outline {
    border-color: var(--color-white);
    color: var(--color-white);

    &:hover {
        background-color: var(--color-white);
        color: var(--color-dark-gray);
    }
}

/* Content box background - White */
.block-text-image--content-bg-white .block-text-image__content-box {
    background-color: var(--color-white);
    box-shadow: var(--shadow-lg);
}

/* Content box background - Cream */
.block-text-image--content-bg-cream .block-text-image__content-box {
    background-color: var(--color-cream);
    box-shadow: var(--shadow-lg);
}

/* ==========================================================================
   Mobile Layout for Stretched Style
   ========================================================================== */

/* Mobile image on top */
.block-text-image--style-stretched.block-text-image--mobile-top .block-text-image__stretched-wrapper {
    @media (max-width: 992px) {
        flex-direction: column;
    }
}

.block-text-image--style-stretched.block-text-image--mobile-top .block-text-image__image-column {
    @media (max-width: 992px) {
        order: 1;
    }
}

.block-text-image--style-stretched.block-text-image--mobile-top .block-text-image__content-column {
    @media (max-width: 992px) {
        order: 2;
    }
}

/* Mobile image on bottom */
.block-text-image--style-stretched.block-text-image--mobile-bottom .block-text-image__stretched-wrapper {
    @media (max-width: 992px) {
        flex-direction: column;
    }
}

.block-text-image--style-stretched.block-text-image--mobile-bottom .block-text-image__image-column {
    @media (max-width: 992px) {
        order: 2;
    }
}

.block-text-image--style-stretched.block-text-image--mobile-bottom .block-text-image__content-column {
    @media (max-width: 992px) {
        order: 1;
    }
}

/* Hide image on mobile for stretched style */
.block-text-image--style-stretched.block-text-image--hide-image-mobile .block-text-image__image-column {
    @media (max-width: 992px) {
        display: none;
    }
}

/* ==========================================================================
   Mobile Layout for Image Background Style
   ========================================================================== */

.block-text-image--style-image_background.block-text-image--hide-image-mobile {
    @media (max-width: 992px) {
        background-color: var(--color-dark-gray);
    }
}

.block-text-image--style-image_background.block-text-image--hide-image-mobile .block-text-image__background-image {
    @media (max-width: 992px) {
        display: none;
    }
}

.block-text-image--style-image_background.block-text-image--hide-image-mobile .block-text-image__content-box {
    @media (max-width: 992px) {
        background-color: transparent;
        box-shadow: none;
        max-width: 100%;
    }
}

/* ==========================================================================
   Comparison Table Block
   Two styles: Versus (Alto vs The Rest) and Multi-Competitor
   ========================================================================== */

.block-comparison-table {
    position: relative;
}

.block-comparison-table__header {
    margin-bottom: var(--spacing-2xl);
    max-width: 800px;
}

.block-comparison-table__header.text-left {
    text-align: left;
}

.block-comparison-table__header.text-center {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
}

.block-comparison-table__subtitle {
    margin-bottom: var(--spacing-md);
}

.block-comparison-table__description {
        font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    color: var(--color-mid-gray);
}

.block--bg-dark .block-comparison-table__description {
    color: rgba(255, 255, 255, 0.7);
}

/* Logo styling */
.block-comparison-table__logo {
    max-height: 40px;
    width: auto;
    display: block;
}

.block-comparison-table__logo--alto {
    max-height: 35px;
}

@media (min-width: 768px) {
    .block-comparison-table__logo {
        max-height: 50px;
    }

    .block-comparison-table__logo--alto {
        max-height: 45px;
    }
}

/* ==========================================================================
   Versus Style (Alto vs The Rest)
   ========================================================================== */

.block-comparison-table__versus {
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Light background variant */
.block--bg-white .block-comparison-table__versus,
.block--bg-cream .block-comparison-table__versus,
.block--bg-light .block-comparison-table__versus {
    border-color: var(--color-gray);
}

/* Header row */
.block-comparison-table__versus-header {
    display: grid;
    grid-template-columns: 1fr 1fr;
}

.block-comparison-table__versus-header .block-comparison-table__versus-cell {
    padding: var(--spacing-xl) var(--spacing-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.block-comparison-table__versus-header .block-comparison-table__versus-cell--alto {
    background-color: #343636;
}

.block-comparison-table__versus-header .block-comparison-table__versus-cell--competitor {
    background-color: var(--color-dark-gray);
}

/* Light background variant for header */
.block--bg-white .block-comparison-table__versus-header .block-comparison-table__versus-cell--alto,
.block--bg-cream .block-comparison-table__versus-header .block-comparison-table__versus-cell--alto,
.block--bg-light .block-comparison-table__versus-header .block-comparison-table__versus-cell--alto {
    background-color: var(--color-light-gray);
}

.block--bg-white .block-comparison-table__versus-header .block-comparison-table__versus-cell--competitor,
.block--bg-cream .block-comparison-table__versus-header .block-comparison-table__versus-cell--competitor,
.block--bg-light .block-comparison-table__versus-header .block-comparison-table__versus-cell--competitor {
    background-color: var(--color-white);
}

.block-comparison-table__competitor-label {
    font-family: var(--font-heading);
    font-size: var(--text-3xl);
    font-weight: var(--font-medium);
    color: var(--color-white);
}

@media (min-width: 768px) {
    .block-comparison-table__competitor-label {
        font-size: var(--text-4xl);
    }
}

.block--bg-white .block-comparison-table__competitor-label,
.block--bg-cream .block-comparison-table__competitor-label,
.block--bg-light .block-comparison-table__competitor-label {
    color: var(--color-dark-gray);
}

/* Body rows */
.block-comparison-table__versus-body {
    background-color: transparent;
}

.block-comparison-table__versus-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.block--bg-white .block-comparison-table__versus-row,
.block--bg-cream .block-comparison-table__versus-row,
.block--bg-light .block-comparison-table__versus-row {
    border-top-color: var(--color-gray);
}

.block-comparison-table__versus-cell {
    position: relative;
    padding: var(--spacing-lg);
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    text-align: center;
}

@media (min-width: 768px) {
    .block-comparison-table__versus-cell {
        padding: var(--spacing-xl) var(--spacing-2xl);
    }
}

.block-comparison-table__versus-cell--alto {
    background-color: #343636;
}

.block-comparison-table__versus-cell--competitor {
    background-color: var(--color-dark-gray);
}

/* Light background variant for cells */
.block--bg-white .block-comparison-table__versus-cell--alto,
.block--bg-cream .block-comparison-table__versus-cell--alto,
.block--bg-light .block-comparison-table__versus-cell--alto {
    background-color: var(--color-light-gray);
}

.block--bg-white .block-comparison-table__versus-cell--competitor,
.block--bg-cream .block-comparison-table__versus-cell--competitor,
.block--bg-light .block-comparison-table__versus-cell--competitor {
    background-color: var(--color-white);
}

/* Cell content */
.block-comparison-table__cell-content {
    flex: 1;
    color: var(--color-white);
    font-size: var(--text-sm);
    line-height: 1.6;
}

@media (min-width: 768px) {
    .block-comparison-table__cell-content {
        font-size: var(--text-base);
    }
}

.block-comparison-table__cell-content p {
    margin: 0;
}

.block-comparison-table__cell-content p:first-child {
    margin-bottom: 0;
}

.block-comparison-table__cell-content strong {
    display: block;
    font-weight: var(--font-semibold);
    margin-bottom: var(--spacing-xs);
}

/* Light background variant for cell content */
.block--bg-white .block-comparison-table__cell-content,
.block--bg-cream .block-comparison-table__cell-content,
.block--bg-light .block-comparison-table__cell-content {
    color: var(--color-dark-gray);
}

.block-comparison-table__versus-cell--competitor .block-comparison-table__cell-content {
    color: rgba(255, 255, 255, 0.7);
    text-align: center;
}

.block--bg-white .block-comparison-table__versus-cell--competitor .block-comparison-table__cell-content,
.block--bg-cream .block-comparison-table__versus-cell--competitor .block-comparison-table__cell-content,
.block--bg-light .block-comparison-table__versus-cell--competitor .block-comparison-table__cell-content {
    color: var(--color-mid-gray);
}

/* ==========================================================================
   Tooltip Styles
   ========================================================================== */

.block-comparison-table__tooltip-wrapper {
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 50;
}

.block-comparison-table__tooltip-trigger {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: var(--radius-md) 0 0 0;
    background-color: var(--color-primary);
    border: none;
    cursor: pointer;
    transition: background-color var(--transition-fast);
}

.block-comparison-table__tooltip-trigger:hover {
    background-color: var(--color-primary-dark);
}

.block-comparison-table__tooltip-icon {
    font-size: var(--text-sm);
    font-weight: var(--font-bold);
    color: var(--color-white);
    line-height: 1;
}

.block-comparison-table__tooltip {
    position: absolute;
    bottom: calc(100% + 12px);
    right: 0;
    width: 280px;
    padding: var(--spacing-lg);
    background-color: var(--color-black);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: opacity var(--transition-fast), transform var(--transition-fast), visibility var(--transition-fast);
    z-index: 200;
}

.block-comparison-table__tooltip-wrapper:hover .block-comparison-table__tooltip,
.block-comparison-table__tooltip-trigger:focus + .block-comparison-table__tooltip,
.block-comparison-table__tooltip--visible {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}

.block-comparison-table__tooltip-arrow {
    position: absolute;
    bottom: -8px;
    right: 12px;
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 10px solid var(--color-black);
}

.block-comparison-table__tooltip-content {
    font-size: var(--text-sm);
    color: var(--color-white);
    line-height: 1.6;
    margin-bottom: var(--spacing-md);
}

.block-comparison-table__tooltip-btn {
    width: 100%;
    text-align: center;
    padding: var(--spacing-sm) var(--spacing-lg);
    font-size: var(--text-sm);
}

/* ==========================================================================
   Multi-Competitor Style
   ========================================================================== */

/* Desktop table - hidden on mobile */
.block-comparison-table__multi--desktop {
    display: none;
}

@media (min-width: 768px) {
    .block-comparison-table__multi--desktop {
        display: block;
    }
}

/* Mobile layout - shown only on mobile */
.block-comparison-table__multi--mobile {
    display: block;
}

@media (min-width: 768px) {
    .block-comparison-table__multi--mobile {
        display: none;
    }
}

/* Desktop table styles */
.block-comparison-table__multi--desktop {
    border-radius: var(--radius-xl);
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.1);
}

.block--bg-white .block-comparison-table__multi--desktop,
.block--bg-cream .block-comparison-table__multi--desktop,
.block--bg-light .block-comparison-table__multi--desktop {
    border-color: var(--color-gray);
}

/* Multi header */
.block-comparison-table__multi-header {
    display: grid;
    grid-template-columns: var(--grid-cols, 2fr 1fr 1fr 1fr 1fr);
    background-color: transparent;
}

.block-comparison-table__multi-header .block-comparison-table__multi-cell {
    padding: var(--spacing-xl) var(--spacing-md);
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
}

.block--bg-white .block-comparison-table__multi-header .block-comparison-table__multi-cell,
.block--bg-cream .block-comparison-table__multi-header .block-comparison-table__multi-cell,
.block--bg-light .block-comparison-table__multi-header .block-comparison-table__multi-cell {
    border-right-color: var(--color-gray);
}

.block-comparison-table__multi-header .block-comparison-table__multi-cell:last-child {
    border-right: none;
}

.block-comparison-table__multi-header .block-comparison-table__multi-cell--category {
    justify-content: flex-start;
    padding-left: var(--spacing-xl);
}

.block-comparison-table__category-label {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--color-white);
}

.block--bg-white .block-comparison-table__category-label,
.block--bg-cream .block-comparison-table__category-label,
.block--bg-light .block-comparison-table__category-label {
    color: var(--color-dark-gray);
}

/* Multi body */
.block-comparison-table__multi-row {
    display: grid;
    grid-template-columns: var(--grid-cols, 2fr 1fr 1fr 1fr 1fr);
    border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.block--bg-white .block-comparison-table__multi-row,
.block--bg-cream .block-comparison-table__multi-row,
.block--bg-light .block-comparison-table__multi-row {
    border-top-color: var(--color-gray);
}

.block-comparison-table__multi-row:hover {
    background-color: rgba(255, 255, 255, 0.03);
}

.block--bg-white .block-comparison-table__multi-row:hover,
.block--bg-cream .block-comparison-table__multi-row:hover,
.block--bg-light .block-comparison-table__multi-row:hover {
    background-color: rgba(0, 0, 0, 0.02);
}

.block-comparison-table__multi-cell {
    padding: var(--spacing-lg) var(--spacing-md);
    display: flex;
    align-items: center;
    justify-content: center;
    border-right: 1px solid rgba(255, 255, 255, 0.1);
    text-align: center;
}

.block--bg-white .block-comparison-table__multi-cell,
.block--bg-cream .block-comparison-table__multi-cell,
.block--bg-light .block-comparison-table__multi-cell {
    border-right-color: var(--color-gray);
}

.block-comparison-table__multi-cell:last-child {
    border-right: none;
}

.block-comparison-table__multi-cell--category {
    justify-content: flex-start;
    padding-left: var(--spacing-xl);
    text-align: left;
    font-weight: var(--font-medium);
    color: var(--color-white);
}

.block--bg-white .block-comparison-table__multi-cell--category,
.block--bg-cream .block-comparison-table__multi-cell--category,
.block--bg-light .block-comparison-table__multi-cell--category {
    color: var(--color-dark-gray);
}

.block-comparison-table__multi-cell--alto {
    background-color: rgba(52, 54, 54, 0.5);
}

.block--bg-white .block-comparison-table__multi-cell--alto,
.block--bg-cream .block-comparison-table__multi-cell--alto,
.block--bg-light .block-comparison-table__multi-cell--alto {
    background-color: rgba(0, 0, 0, 0.03);
}

/* Value styling */
.block-comparison-table__value {
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.7);
}

@media (min-width: 1024px) {
    .block-comparison-table__value {
        font-size: var(--text-base);
    }
}

.block--bg-white .block-comparison-table__value,
.block--bg-cream .block-comparison-table__value,
.block--bg-light .block-comparison-table__value {
    color: var(--color-mid-gray);
}

.block-comparison-table__value--alto {
    font-weight: var(--font-semibold);
    color: var(--color-white);
}

.block--bg-white .block-comparison-table__value--alto,
.block--bg-cream .block-comparison-table__value--alto,
.block--bg-light .block-comparison-table__value--alto {
    color: var(--color-dark-gray);
}

.block-comparison-table__competitor-name {
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-white);
}

.block--bg-white .block-comparison-table__competitor-name,
.block--bg-cream .block-comparison-table__competitor-name,
.block--bg-light .block-comparison-table__competitor-name {
    color: var(--color-dark-gray);
}

/* ==========================================================================
   Mobile Stacked Layout for Multi-Competitor
   ========================================================================== */

.block-comparison-table__mobile-category {
    background-color: rgba(255, 255, 255, 0.03);
    border-radius: var(--radius-lg);
    overflow: hidden;
    margin-bottom: var(--spacing-lg);
}

.block--bg-white .block-comparison-table__mobile-category,
.block--bg-cream .block-comparison-table__mobile-category,
.block--bg-light .block-comparison-table__mobile-category {
    background-color: var(--color-white);
    border: 1px solid var(--color-gray);
}

.block-comparison-table__mobile-category:last-child {
    margin-bottom: 0;
}

.block-comparison-table__mobile-category-header {
    padding: var(--spacing-lg);
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--color-white);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.block--bg-white .block-comparison-table__mobile-category-header,
.block--bg-cream .block-comparison-table__mobile-category-header,
.block--bg-light .block-comparison-table__mobile-category-header {
    color: var(--color-dark-gray);
    border-bottom-color: var(--color-gray);
}

.block-comparison-table__mobile-row {
    display: flex;
    align-items: center;
    padding: var(--spacing-md) var(--spacing-lg);
    border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.block--bg-white .block-comparison-table__mobile-row,
.block--bg-cream .block-comparison-table__mobile-row,
.block--bg-light .block-comparison-table__mobile-row {
    border-bottom-color: var(--color-gray);
}

.block-comparison-table__mobile-row:last-child {
    border-bottom: none;
}

.block-comparison-table__mobile-row--alto {
    background-color: rgba(52, 54, 54, 0.5);
}

.block--bg-white .block-comparison-table__mobile-row--alto,
.block--bg-cream .block-comparison-table__mobile-row--alto,
.block--bg-light .block-comparison-table__mobile-row--alto {
    background-color: var(--color-light-gray);
}

.block-comparison-table__mobile-logo {
    width: 100px;
    flex-shrink: 0;
    display: flex;
    align-items: center;
}

.block-comparison-table__mobile-logo .block-comparison-table__logo {
    max-height: 30px;
}

.block-comparison-table__mobile-value {
    flex: 1;
    text-align: right;
}

.block-comparison-table__mobile-value .block-comparison-table__value {
    font-size: var(--text-base);
}

.block-comparison-table__mobile-value .block-comparison-table__value--alto {
    font-weight: var(--font-semibold);
}

/* ==========================================================================
   Block: Integrations
   ========================================================================== */

.block-integrations__header {
    margin-bottom: var(--spacing-2xl);
}

.block-integrations__subtitle {
    margin-bottom: var(--spacing-md);
}

.block-integrations__description {
    max-width: 700px;
    margin-left: auto;
    margin-right: auto;
        font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    color: var(--color-mid-gray);
}

.text-left .block-integrations__description {
    margin-left: 0;
}

/* Dark background text colors */
.block--bg-dark .block-integrations__description {
    color: rgba(255, 255, 255, 0.7);
}

/* ==========================================================================
   Filters
   ========================================================================== */

.block-integrations__filters {
    margin-bottom: var(--spacing-2xl);
    text-align: center;
}

.block-integrations__filter-label {
    display: block;
    font-size: var(--text-base);
    font-weight: var(--font-semibold);
    color: var(--color-mid-gray);
    margin-bottom: var(--spacing-md);
}

.block--bg-dark .block-integrations__filter-label {
    color: rgba(255, 255, 255, 0.7);
}

.block-integrations__filter-buttons {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: var(--spacing-sm);
}

.block-integrations__filter {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    padding: 0.5rem 1rem;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-dark-gray);
    background-color: var(--color-white);
    border: 1px solid var(--color-gray);
    border-radius: var(--radius-full);
    cursor: pointer;
    transition: all var(--transition-fast);
}

.block-integrations__filter:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

.block-integrations__filter--active {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-white);
}

.block-integrations__filter--active:hover {
    background-color: var(--color-primary-dark);
    border-color: var(--color-primary-dark);
    color: var(--color-white);
}

.block-integrations__filter-check {
    width: 1rem;
    height: 1rem;
    opacity: 0;
    transform: scale(0);
    transition: all var(--transition-fast);
}

.block-integrations__filter--active .block-integrations__filter-check {
    opacity: 1;
    transform: scale(1);
}

/* Dark background filter styles */
.block--bg-dark .block-integrations__filter {
    background-color: var(--color-dark-gray-light);
    border-color: var(--color-dark-gray-light);
    color: var(--color-white);
}

.block--bg-dark .block-integrations__filter:hover {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
}

/* ==========================================================================
   Grid Layout
   ========================================================================== */

.block-integrations__grid {
    display: grid;
    gap: var(--spacing-lg);
}

.block-integrations--cols-3 .block-integrations__grid {
    grid-template-columns: repeat(3, 1fr);
}

.block-integrations--cols-4 .block-integrations__grid {
    grid-template-columns: repeat(4, 1fr);
}

.block-integrations--cols-5 .block-integrations__grid {
    grid-template-columns: repeat(5, 1fr);
}

@media (max-width: 1200px) {
    .block-integrations--cols-5 .block-integrations__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

@media (max-width: 992px) {
    .block-integrations--cols-3 .block-integrations__grid,
    .block-integrations--cols-4 .block-integrations__grid,
    .block-integrations--cols-5 .block-integrations__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

@media (max-width: 768px) {
    .block-integrations--cols-3 .block-integrations__grid,
    .block-integrations--cols-4 .block-integrations__grid,
    .block-integrations--cols-5 .block-integrations__grid {
        grid-template-columns: repeat(2, 1fr);
    }
    
    .block-integrations__filter-buttons {
        gap: 0.5rem;
    }
    
    .block-integrations__filter {
        padding: 0.4rem 0.75rem;
        font-size: var(--text-xs);
    }
}

@media (max-width: 580px) {
    .block-integrations--cols-3 .block-integrations__grid,
    .block-integrations--cols-4 .block-integrations__grid,
    .block-integrations--cols-5 .block-integrations__grid {
        grid-template-columns: 1fr;
    }
}

/* ==========================================================================
   SIMPLE MODE: Logo Cards
   Clean white cards displaying just the logo, optionally clickable.
   Completely separate structure from full cards.
   ========================================================================== */

.block-integrations__logo-card {
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 16 / 10;
    padding: var(--spacing-lg);
    background-color: var(--color-white);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-sm);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
    text-decoration: none;
}

a.block-integrations__logo-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-md);
}

.block-integrations__logo-card-img {
    max-width: 85%;
    max-height: 60%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.block-integrations__logo-card-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background-color: var(--color-light-gray);
    border-radius: var(--radius-full);
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--color-gray);
}

/* Animation states for filtering (shared) */
.block-integrations__logo-card[data-hidden="true"],
.block-integrations__card[data-hidden="true"] {
    opacity: 0;
    transform: scale(0.8);
    pointer-events: none;
    position: absolute;
    visibility: hidden;
}

.block-integrations__logo-card[data-animating="true"],
.block-integrations__card[data-animating="true"] {
    transition: opacity 0.3s ease, transform 0.3s ease;
}

/* ==========================================================================
   FULL MODE: Cards with Logo + Content Area
   Two-part cards: white logo area on top, dark content area below.
   ========================================================================== */

.block-integrations__card {
    display: flex;
    flex-direction: column;
    background-color: var(--color-dark-gray);
    border-radius: var(--radius-xl);
    overflow: hidden;
    transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.block-integrations__card--linked {
    text-decoration: none;
    cursor: pointer;
}

.block-integrations__card--linked:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

/* Logo area - white section at top */
.block-integrations__card-logo {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: var(--spacing-xl);
    background-color: var(--color-white);
    aspect-ratio: 16 / 9;
}

.block-integrations__card-logo-img {
    max-width: 70%;
    max-height: 70%;
    width: auto;
    height: auto;
    object-fit: contain;
}

.block-integrations__card-logo-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 60px;
    height: 60px;
    background-color: var(--color-light-gray);
    border-radius: var(--radius-full);
    font-size: var(--text-2xl);
    font-weight: var(--font-bold);
    color: var(--color-gray);
}

/* Content area - dark section below */
.block-integrations__card-content {
    display: flex;
    flex-direction: column;
    flex: 1;
    padding: var(--spacing-lg);
    color: var(--color-white);
}

/* Tags */
.block-integrations__card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: var(--spacing-md);
}

.block-integrations__card-tag {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-size: var(--text-xs);
    font-weight: var(--font-medium);
    color: var(--color-white);
    background-color: var(--color-primary);
    border-radius: var(--radius-full);
}

/* Title */
.block-integrations__card-title {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    color: var(--color-white);
    margin-bottom: var(--spacing-sm);
    line-height: var(--leading-tight);
}

/* Excerpt */
.block-integrations__card-excerpt {
    font-size: var(--text-sm);
    color: rgba(255, 255, 255, 0.8);
    margin-bottom: var(--spacing-md);
    flex: 1;
    line-height: var(--leading-relaxed);
}

/* Link */
.block-integrations__card-link {
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-white);
    text-decoration: underline;
    text-underline-offset: 3px;
    margin-top: auto;
    transition: color var(--transition-fast);
}

.block-integrations__card-link:hover {
    color: var(--color-teal);
}

/* ==========================================================================
   Dark Background Variants
   ========================================================================== */

.block--bg-dark .block-integrations__card {
    background-color: var(--color-dark-gray-light);
}

/* ==========================================================================
   CTA Button
   ========================================================================== */

.block-integrations__cta {
    display: flex;
    justify-content: center;
    margin-top: var(--spacing-2xl);
}

.text-left .block-integrations__cta {
    justify-content: flex-start;
}

/* ==========================================================================
   Single Integration Template (fallback)
   ========================================================================== */

.single-integration__layout {
    max-width: 800px;
    margin: 0 auto;
    text-align: center;
}

.single-integration__logo {
    display: flex;
    justify-content: center;
    margin-bottom: var(--spacing-xl);
}

.single-integration__logo-image {
    max-width: 200px;
    max-height: 100px;
    width: auto;
    height: auto;
    object-fit: contain;
}

.single-integration__types {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.5rem;
    margin-bottom: var(--spacing-lg);
}

.single-integration__type-tag {
    display: inline-block;
    padding: 0.25rem 0.75rem;
    font-size: var(--text-xs);
    font-weight: var(--font-medium);
    color: var(--color-dark-gray);
    background-color: var(--color-teal);
    border-radius: var(--radius-full);
}

.single-integration__header {
    margin-bottom: var(--spacing-xl);
}

.single-integration__title {
    font-size: var(--text-4xl);
    margin-bottom: 0;
}

.single-integration__content {
    text-align: left;
}

/* ==========================================================================
   Discover Content Block
   ========================================================================== */

.block-discover-content__header {
    margin-bottom: var(--spacing-2xl);
}

.block-discover-content__subtitle {
    margin-bottom: var(--spacing-md);
}

.block-discover-content__description {
        font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    color: var(--color-mid-gray);
    max-width: 700px;
    margin: 0;
    line-height: 1.6;
}

/* Dark background support */
.block--bg-dark .block-discover-content__description {
    color: var(--color-light-gray);
}

/* Grid Layout */
.block-discover-content__grid {
    display: grid;
    gap: var(--spacing-xl);
}

.block-discover-content--cols-2 .block-discover-content__grid {
    @media (min-width: 640px) {
        grid-template-columns: repeat(2, 1fr);
    }
}

.block-discover-content--cols-3 .block-discover-content__grid {
    @media (min-width: 640px) {
        grid-template-columns: repeat(2, 1fr);
    }

    @media (min-width: 1024px) {
        grid-template-columns: repeat(3, 1fr);
    }
}

.block-discover-content--cols-4 .block-discover-content__grid {
    @media (min-width: 640px) {
        grid-template-columns: repeat(2, 1fr);
    }

    @media (min-width: 1024px) {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Card Styles */
.block-discover-content__card {
    display: flex;
    flex-direction: column;

    &:hover .block-discover-content__card-image {
        transform: scale(1.05);
    }
}

.block-discover-content__card-image-link {
    display: block;
    position: relative;
    aspect-ratio: 381 / 254;
    overflow: hidden;
    border-radius: var(--radius-lg);
    margin-bottom: 0;
}

.block-discover-content__card-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}

.block-discover-content__card-image--placeholder {
    background: linear-gradient(135deg, var(--color-light-gray) 0%, var(--color-cream) 100%);
    width: 100%;
    height: 100%;
}

.block-discover-content__card-content {
    padding: var(--spacing-lg) 0;
}

.block-discover-content__card-type {
    display: block;
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-mid-gray);
    margin-bottom: var(--spacing-xs);
}

/* Dark background support */
.block--bg-dark .block-discover-content__card-type {
    color: var(--color-gray);
}

.block-discover-content__card-title {
    font-size: var(--text-lg);
    font-weight: var(--font-semibold);
    margin: 0 0 var(--spacing-md) 0;
    line-height: 1.4;

    @media (min-width: 768px) {
        font-size: var(--text-xl);
    }

    a {
        color: var(--color-dark-gray);
        text-decoration: none;
        transition: color 0.2s ease;

        &:hover {
            color: var(--color-primary);
        }
    }
}

/* Dark background support */
.block--bg-dark .block-discover-content__card-title a {
    color: var(--color-white);

    &:hover {
        color: var(--color-primary-light);
    }
}

.block-discover-content__card-link,
a.underline.block-discover-content__card-link {
    display: inline-block;
    font-size: var(--text-sm);
    font-weight: var(--font-semibold);
    color: var(--color-primary);
    text-decoration: none;
}

a.underline.block-discover-content__card-link::before {
    background-color: var(--color-primary);
    opacity: 0.3;
    bottom: -2px;
}

a.underline.block-discover-content__card-link::after {
    background-color: var(--color-primary);
    bottom: -2px;
}

/* Dark background support */
.block--bg-dark .block-discover-content__card-link,
.block--bg-dark a.underline.block-discover-content__card-link {
    color: var(--color-primary-light);
}

.block--bg-dark a.underline.block-discover-content__card-link::before {
    background-color: var(--color-primary-light);
}

.block--bg-dark a.underline.block-discover-content__card-link::after {
    background-color: var(--color-primary-light);
}

/* ==========================================================================
   Details Accordion Block
   ========================================================================== */

.block-details-accordion__header {
    margin-bottom: var(--spacing-2xl);
}

.block-details-accordion--heading-center .block-details-accordion__header {
    text-align: center;
}

.block-details-accordion--heading-center .block-details-accordion__description {
    margin-left: auto;
    margin-right: auto;
}

.block-details-accordion__subtitle {
    margin-bottom: var(--spacing-md);
}

.block-details-accordion__description {
        font-size: var(--text-2xl);
    font-weight: var(--font-normal);
    color: var(--color-mid-gray);
    max-width: 700px;
    margin: 0;
    line-height: 1.6;
}

/* Dark background support for header */
.block--bg-dark .block-details-accordion__description {
    color: var(--color-gray);
}

/* Accordion List */
.block-details-accordion__list {
    border-top: 1px solid var(--color-gray);
}

.block--bg-dark .block-details-accordion__list {
    border-top-color: rgba(255, 255, 255, 0.2);
}

/* Accordion Item */
.block-details-accordion__item {
    border-bottom: 1px solid var(--color-gray);
}

.block--bg-dark .block-details-accordion__item {
    border-bottom-color: rgba(255, 255, 255, 0.2);
}

/* Accordion Trigger - Shared styles */
.block-details-accordion__trigger {
    display: flex;
    align-items: center;
    width: 100%;
    padding: var(--spacing-lg) 0;
    background: transparent;
    border: none;
    cursor: pointer;
    text-align: left;
    gap: var(--spacing-lg);
}

/* FAQ Style Trigger */
.block-details-accordion--faqs .block-details-accordion__trigger {
    justify-content: space-between;
}

.block-details-accordion__question {
    font-size: var(--text-lg);
    font-weight: var(--font-medium);
    color: var(--color-dark-gray);
    flex: 1;
    line-height: 1.4;

    @media (min-width: 768px) {
        font-size: var(--text-xl);
    }
}

.block--bg-dark .block-details-accordion__question {
    color: var(--color-white);
}

/* Team Style Trigger - Table layout */
.block-details-accordion--team .block-details-accordion__trigger {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: var(--spacing-md);
    padding: var(--spacing-xl) 0;

    @media (min-width: 768px) {
        grid-template-columns: minmax(200px, 1fr) 1fr auto;
        gap: var(--spacing-2xl);
    }
}

.block-details-accordion__name {
    font-size: var(--text-xl);
    font-weight: var(--font-semibold);
    color: var(--color-dark-gray);
    line-height: 1.3;

    @media (min-width: 768px) {
        font-size: var(--text-2xl);
    }

    @media (min-width: 1024px) {
        font-size: var(--text-3xl);
    }
}

.block--bg-dark .block-details-accordion__name {
    color: var(--color-white);
}

.block-details-accordion__title {
    font-family: var(--font-decorative);
    font-size: var(--text-base);
    font-weight: var(--font-medium);
    color: var(--color-mid-gray);
    display: none;

    @media (min-width: 768px) {
        display: block;
        font-size: var(--text-lg);
        align-self: center;
    }
}

.block--bg-dark .block-details-accordion__title {
    color: var(--color-gray);
}

/* Icon */
.block-details-accordion__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 24px;
    height: 24px;
    flex-shrink: 0;
    color: var(--color-primary);
    transition: transform var(--transition-fast);
}

.block-details-accordion__item--active .block-details-accordion__icon {
    transform: rotate(45deg);
}

/* Content */
.block-details-accordion__content {
    overflow: hidden;
    padding-bottom: var(--spacing-xl);

    &[hidden] {
        display: none;
    }
}

.block-details-accordion__answer,
.block-details-accordion__bio {
    font-size: var(--text-base);
    color: var(--color-mid-gray);
    max-width: 800px;
    line-height: 1.7;

    p:last-child {
        margin-bottom: 0;
    }
}

.block-details-accordion__bio {
    font-size: var(--text-lg);
}

.block--bg-dark .block-details-accordion__answer,
.block--bg-dark .block-details-accordion__bio {
    color: var(--color-gray);
}

/* Team bio with offset for table layout */
.block-details-accordion--team .block-details-accordion__content {
    @media (min-width: 768px) {
        padding-left: 0;
    }
}

/* Team member expanded details with photo and LinkedIn */
.block-details-accordion__team-details {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-lg);

    @media (min-width: 768px) {
        flex-direction: row;
        gap: var(--spacing-xl);
    }
}

.block-details-accordion__photo {
    flex-shrink: 0;
}

.block-details-accordion__photo img {
    width: 120px;
    height: 120px;
    object-fit: cover;
    border-radius: var(--radius-lg);

    @media (min-width: 768px) {
        width: 150px;
        height: 150px;
    }
}

.block-details-accordion__team-content {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

/* ==========================================================================
   PDF Embed Shortcode
   ========================================================================== */

.alto-pdf-embed {
    width: 100%;
    margin: var(--spacing-lg) 0;
}

.alto-pdf-embed__container {
    width: 100%;
    border: 1px solid var(--color-gray);
    border-radius: var(--radius-lg);
    overflow: hidden;
    background-color: var(--color-light-gray);
}

.alto-pdf-embed__object,
.alto-pdf-embed__iframe {
    display: block;
    width: 100%;
    height: 100%;
    border: none;
}

.alto-pdf-embed__fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    height: 100%;
    padding: var(--spacing-xl);
    text-align: center;
    color: var(--color-mid-gray);
}

.alto-pdf-embed__fallback a {
    color: var(--color-primary);
    font-weight: var(--font-medium);
}

.alto-pdf-embed__download {
    margin-top: var(--spacing-sm);
    text-align: center;
}

.alto-pdf-embed__download-link {
    display: inline-flex;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-sm) var(--spacing-md);
    font-size: var(--text-sm);
    font-weight: var(--font-medium);
    color: var(--color-dark-gray);
    text-decoration: none;
    background-color: var(--color-light-gray);
    border-radius: var(--radius-md);
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.alto-pdf-embed__download-link:hover {
    background-color: var(--color-primary);
    color: var(--color-white);
}

.alto-pdf-error {
    padding: var(--spacing-lg);
    background-color: var(--color-light-gray);
    border-radius: var(--radius-md);
    color: var(--color-mid-gray);
    text-align: center;
}

/* ==========================================================================
   SVG Line Art System
   Centralized styles for decorative line patterns
   ========================================================================== */

/* Breathing Animation - subtle scale pulse */
@keyframes svg-lines-breathe {
    0% {
        transform: scale(1);
    }
    50% {
        transform: scale(1.03);
    }
    100% {
        transform: scale(1);
    }
}

/* Base SVG Lines Container */
.svg-lines {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    pointer-events: none;
    overflow: hidden;
}

/* When overflow is enabled, remove height/bottom constraints */
.svg-lines.svg-lines--overflow {
    height: auto !important;
    bottom: auto !important;
    overflow: visible !important;
}

.svg-lines svg {
    position: absolute;
    z-index: 1;
}

/* Enable breathing animation */
.svg-lines--animate {
    animation: svg-lines-breathe 15s ease-in-out infinite;
}

/* Allow overflow to extend beyond parent block */
.svg-lines--overflow {
    overflow: visible;
}

/* ==========================================================================
   Pattern-Specific Positioning
   ========================================================================== */

/* Large Hero - aligned to right edge for hero blocks */
.svg-lines--large-hero svg {
    top: 0;
    right: 0;
    left: auto;
    transform: translateY(-6%);
    min-width: 1918px;
}

@media (max-width: 1200px) {
    .svg-lines--large-hero svg {
        transform: translateY(-6%);
    }
}

@media (max-width: 768px) {
    .svg-lines--large-hero svg {
        transform: translateY(-10%);
        min-width: 1400px;
    }
}

/* Squiggle Wide - left-biased S-curve */
.svg-lines--squiggle-wide svg {
    top: 0;
    left: 50%;
    transform: translateX(-36%) scale(1.3);
    min-width: 1352px;
}

/* Squiggle Wide 2 - extended wave pattern */
.svg-lines--squiggle-wide2 svg {
    top: 0;
    left: 50%;
    transform: translateX(-46%) scale(0.9);
    min-width: 3008px;
}

@media (max-width: 768px) {
    .svg-lines--squiggle-wide2 svg {
        transform: translateX(-35%) scale(0.7);
    }
}

/* Semi Circle Bottom - arcs from bottom center, horizontally centered */
.svg-lines--semi-circle-bottom svg {
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 100%;
    max-width: 1318px;
}

/* Waves Center - aligned to right edge for page titles without image */
.svg-lines--waves-center svg {
    top: 0;
    left: auto;
    right: 0;
    transform: none;
    min-width: 1580px;
}

@media (max-width: 768px) {
    .svg-lines--waves-center svg {
        right: -10%;
    }
}

/* Waves Left - positioned flush against right edge */
.svg-lines--waves-left {
    left: auto;
    right: 0;
    width: auto;
}

.svg-lines--waves-left svg {
    top: 0;
    left: auto;
    right: 0;
    transform: none;
    min-width: 1918px;
}

/* ==========================================================================
   Position Variants (for ACF selection)
   ========================================================================== */

.svg-lines--pos-left svg {
    left: 0;
    right: auto;
}

.svg-lines--pos-right svg {
    right: 0;
    left: auto;
}

.svg-lines--pos-center svg {
    left: 50%;
    transform: translateX(-50%);
}

/* ==========================================================================
   Color Variants (inherited from block backgrounds)
   ========================================================================== */

/* Dark backgrounds - use solid subtle gray instead of white with opacity to avoid overlap issues */
.block--bg-dark .svg-lines svg path,
.block-hero .svg-lines svg path {
    stroke: #8e8e8e;
}

/* Light backgrounds - use subtle gray */
.block--bg-white .svg-lines svg path,
.block--bg-cream .svg-lines svg path,
.block--bg-light .svg-lines svg path {
    stroke: #E3E3E3;
}

/* Gradient backgrounds - white SVG lines */
.block-cta--bg-orange-gradient .svg-lines svg path,
.block-cta--bg-teal-gradient-dark .svg-lines svg path,
.block-cta--bg-grey-gradient .svg-lines svg path,
.block-testimonial--orange-gradient .svg-lines svg path,
.block-testimonial--teal-gradient .svg-lines svg path {
    stroke: rgba(255, 255, 255, 0.6);
}

/* ==========================================================================
   Block-Specific Overflow Handling
   For allowing SVG lines to appear behind subsequent sections
   ========================================================================== */

/* Parent block needs overflow visible to show lines behind next block */
.block--svg-overflow {
    overflow: visible !important;
    overflow-x: clip !important;
    position: relative;
    z-index: 0;
}

/* SVG container when overflow is enabled - remove height constraint */
.block--svg-overflow .svg-lines {
    overflow: visible;
    height: auto;
    bottom: auto;
}

/* SVG itself needs to extend beyond the container */
.block--svg-overflow .svg-lines svg {
    height: auto;
}

/* Ensure content stays above SVG */
.block--svg-overflow > .container,
.block--svg-overflow > .container-wide,
.block--svg-overflow > .container-narrow {
    position: relative;
    z-index: 3;
}

/* Page Title specific overflow - SVG extends below into next section */
.block-page-title.block--svg-overflow .svg-lines--waves-center svg,
.block-page-title.block--svg-overflow .svg-lines--waves-left svg {
    min-height: 140%;
}



/* Container inside next block stays above */
.block--svg-overflow + section > .container,
.block--svg-overflow + section > .container-wide,
.block--svg-overflow + section > .container-narrow,
.block--svg-overflow + .block > .container,
.block--svg-overflow + .block > .container-wide,
.block--svg-overflow + .block > .container-narrow,
.block--svg-overflow + [class*="block-"] > .container,
.block--svg-overflow + [class*="block-"] > .container-wide,
.block--svg-overflow + [class*="block-"] > .container-narrow {
    position: relative;
    z-index: 2;
}

/* ==========================================================================
   Block: Image
   ========================================================================== */

.block-image__figure,
.block-image__link {
    display: block;
    margin: 0;
    line-height: 0;
}

.block-image__link {
    transition: opacity 0.3s ease;
}

.block-image__link:hover {
    opacity: 0.9;
}

.block-image__img {
    width: 100%;
    height: auto;
    border-radius: var(--radius-lg, 16px);
}

/* Screenshot Style - Card with gradient background */
.block-image--screenshot .block-image__card {
    position: relative;
    border-radius: 30px;
    overflow: hidden;
    padding: var(--spacing-2xl) var(--spacing-2xl) 0;
}

@media (max-width: 768px) {
    .block-image--screenshot .block-image__card {
        padding: var(--spacing-xl) var(--spacing-lg) 0;
        border-radius: 20px;
    }
}

/* Animated gradient background pseudo-element */
.block-image--screenshot .block-image__card::before {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 200%;
    height: 120%;
    transform: translate(-50%, -50%);
    z-index: 0;
    animation: gradient-shift 10s ease-in-out infinite;
}

/* Screenshot image styling */
.block-image--screenshot .block-image__img {
    position: relative;
    z-index: 1;
    border-radius: 16px 16px 0 0;
}

.block-image--screenshot .block-image__link {
    position: relative;
    z-index: 1;
}

/* Gradient Presets */

/* Teal gradient (default) - Cream to Teal */
.block-image--gradient-teal .block-image__card::before {
    background: linear-gradient(90deg, rgb(248, 248, 244) 0%, rgb(170, 226, 219) 100%);
}

/* Orange gradient - Yellow to Orange */
.block-image--gradient-orange .block-image__card::before {
    background: linear-gradient(90deg, var(--color-yellow) 0%, var(--color-primary) 100%);
}

/* Grey gradient - Light to Dark Grey */
.block-image--gradient-grey .block-image__card::before {
    background: linear-gradient(90deg, rgb(216, 216, 216) 0%, rgb(125, 126, 126) 100%);
}

/* Custom gradient - uses CSS custom properties */
.block-image--gradient-custom .block-image__card::before {
    background: linear-gradient(90deg, var(--gradient-color-1, #f8f8f4) 0%, var(--gradient-color-2, #aae2db) 100%);
}

/* ==========================================================================
   OVERFLOW OVERRIDES - MUST BE AT END OF FILE FOR CASCADE
   ========================================================================== */

/* Force overflow visible on all elements when overflow is enabled */
section.block--svg-overflow,
.block-page-title.block--svg-overflow,
.block-page-title--hero-content.block--svg-overflow {
    overflow: visible !important;
    overflow-x: clip !important;
    overflow-y: visible !important;
}

section.block--svg-overflow .svg-lines,
.block--svg-overflow .svg-lines,
.block--svg-overflow .block-page-title__lines {
    overflow: visible !important;
    height: auto !important;
    bottom: auto !important;
}

section.block--svg-overflow .svg-lines svg,
.block--svg-overflow .svg-lines svg {
    height: auto !important;
}

/* ==========================================================================
   Custom HTML Block
   ========================================================================== */

.block-custom-html {
    position: relative;
    overflow: hidden; /* Prevents margin collapse on child elements */
}

.block-custom-html__content {
    width: 100%;
}

/* ==========================================================================
   Block: Vertical Carousel (Screenshots Carousel)
   Desktop: Content left (40%), large screenshot right (50-60%), positioned absolutely
   Mobile: Stacked, image below content in each slide
   Uses Flickity fade: true with synced carousels
   ========================================================================== */

.block-vertical-carousel {
    position: relative;
    overflow: hidden;
    width: 100%;
    padding: 60px 0 0 0;
}

@media (min-width: 768px) {
    .block-vertical-carousel {
        padding: 110px 0 0 0;
    }
}

/* Remove spacing overrides */
.block-vertical-carousel.block--spacing-default,
.block-vertical-carousel.block--spacing-lg,
.block-vertical-carousel.block--spacing-sm,
.block-vertical-carousel.block--spacing-none {
    padding-bottom: 0 !important;
}

/* Outer wrapper */
.block-vertical-carousel__outer {
    width: 100%;
    height: auto;
}

/* Intro section with headline */
.block-vertical-carousel__intro {
    margin-bottom: 28px;
}

@media (min-width: 768px) {
    .block-vertical-carousel__intro {
        margin-bottom: 42px;
    }
}

.block-vertical-carousel__headline {
    margin: 0;
    text-align: center;
    font-size: 1.875rem;
    line-height: 1.2;
}

@media (min-width: 768px) {
    .block-vertical-carousel__headline {
        font-size: 2.5rem;
    }
}

@media (min-width: 1024px) {
    .block-vertical-carousel__headline {
        text-align: left;
        font-size: 2.5rem;
    }
}

@media (min-width: 1240px) {
    .block-vertical-carousel__headline {
        font-size: 3.125rem;
    }
}

.block--bg-dark .block-vertical-carousel__headline {
    color: var(--color-white);
}

/* Main carousel wrapper */
.block-vertical-carousel__main {
    position: relative;
    width: 100%;
    height: auto;
}

/* ==========================================================================
   Desktop Image Carousel (right side, absolutely positioned)
   ========================================================================== */

.block-vertical-carousel__desktop-images {
    display: none;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 0;
    width: 100%;
    height: 100%;
    max-width: 100%;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__desktop-images {
        display: block;
        max-width: 50%;
    }
}

@media (min-width: 1400px) {
    .block-vertical-carousel__desktop-images {
        max-width: 58%;
    }
}

@media (min-width: 1600px) {
    .block-vertical-carousel__desktop-images {
        max-width: 59%;
    }
}

/* Desktop carousel container */
.block-vertical-carousel__desktop-carousel {
    width: 100%;
    height: 100%;
}

/* Desktop slide */
.block-vertical-carousel__desktop-slide {
    overflow: hidden;
    width: 100%;
    max-width: 100%;
    min-height: 622px;
}

@media (min-width: 1400px) {
    .block-vertical-carousel__desktop-slide {
        min-height: 822px;
    }
}

.block-vertical-carousel__desktop-slide picture {
    display: flex;
    flex-direction: row;
    justify-content: flex-start;
    min-height: 622px;
}

@media (min-width: 1400px) {
    .block-vertical-carousel__desktop-slide picture {
        min-height: 822px;
    }
}

.block-vertical-carousel__desktop-slide img {
    width: 100%;
    height: auto;
    min-height: 622px;
    object-fit: cover;
    object-position: top left;
    border-radius: var(--radius-lg) 0 0 0;
}

@media (min-width: 1400px) {
    .block-vertical-carousel__desktop-slide img {
        min-height: 822px;
    }
}

/* ==========================================================================
   Content Carousel (left side, inside container)
   ========================================================================== */

.block-vertical-carousel__content-carousel {
    width: 100%;
    height: auto;
    position: relative;
    z-index: 50;
}

/* Individual slide */
.block-vertical-carousel__slide {
    display: flex;
    flex-direction: column;
    justify-content: center;
    position: relative;
    width: 100%;
    height: auto;
}

/* Columns layout inside slide */
.block-vertical-carousel__columns {
    display: flex;
    flex-direction: column;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__columns {
        flex-direction: row;
    }
}

/* Text column */
.block-vertical-carousel__text-column {
    display: flex;
    flex-direction: column;
    justify-content: center;
    min-height: 350px;
    width: 100%;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__text-column {
        max-width: 46%;
        min-height: 622px;
    }
}

@media (min-width: 1400px) {
    .block-vertical-carousel__text-column {
        max-width: 35%;
        min-height: 822px;
    }
}

/* Text wrapper */
.block-vertical-carousel__text-wrap {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    height: auto;
    padding: 40px 20px;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__text-wrap {
        padding: 40px 60px 40px 0;
        max-width: 520px;
    }
}

/* Title */
.block-vertical-carousel__title {
    text-align: center;
    font-size: 1.9375rem;
    line-height: 1.1;
    margin: 0 0 var(--spacing-md) 0;
}

@media (min-width: 768px) {
    .block-vertical-carousel__title {
        font-size: 2.625rem;
    }
}

@media (min-width: 1024px) {
    .block-vertical-carousel__title {
        text-align: left;
    }
}

.block--bg-dark .block-vertical-carousel__title {
    color: var(--color-white);
}

/* Description */
.block-vertical-carousel__description {
    text-align: center;
    font-size: 1rem;
    line-height: 1.6;
    margin: 0 0 var(--spacing-md) 0;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__description {
        text-align: left;
        font-size: 1.125rem;
    }
}

.block--bg-dark .block-vertical-carousel__description {
    color: rgba(255, 255, 255, 0.9);
}

.block-vertical-carousel__description p {
    margin: 0 0 var(--spacing-sm) 0;
}

.block-vertical-carousel__description p:last-child {
    margin-bottom: 0;
}

.block-vertical-carousel__description ul {
    list-style: disc;
    padding-left: 1.25rem;
    margin: var(--spacing-sm) 0;
}

.block-vertical-carousel__description li {
    margin-bottom: 0.5rem;
}

/* CTA button */
.block-vertical-carousel__cta {
    margin-top: var(--spacing-md);
    text-align: center;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__cta {
        text-align: left;
    }
}

/* ==========================================================================
   Image Column (mobile only)
   ========================================================================== */

.block-vertical-carousel__image-column {
    width: 100%;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__image-column {
        display: none;
    }
}

.block-vertical-carousel__mobile-image {
    margin: 0;
}

.block-vertical-carousel__mobile-image picture {
    width: 100%;
    max-width: 100%;
    height: auto;
    margin: 0 auto;
    padding: 0 0 0 20px;
}

.block-vertical-carousel__mobile-image img {
    width: 100%;
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-lg) 0 0 0;
}

/* ==========================================================================
   Flickity Styles - Let Flickity Fade plugin handle positioning
   ========================================================================== */

/* Content carousel viewport */
.block-vertical-carousel__content-carousel .flickity-viewport {
    min-height: 500px;
}

@media (min-width: 1024px) {
    .block-vertical-carousel__content-carousel .flickity-viewport {
        min-height: 622px;
    }
}

@media (min-width: 1400px) {
    .block-vertical-carousel__content-carousel .flickity-viewport {
        min-height: 822px;
    }
}

/* Page dots styling only - no transform overrides */

/* ==========================================================================
   Pagination Dots - Horizontal, positioned below content
   ========================================================================== */

/* On mobile, dots appear below the carousel naturally */
.block-vertical-carousel__content-carousel .flickity-page-dots {
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    gap: 0;
    padding: 8px 12px;
    margin: var(--spacing-md) auto var(--spacing-lg) auto;
    list-style: none;
    position: relative;
    bottom: auto;
    left: auto;
    width: fit-content;
    background-color: #000;
    border-radius: 60px;
    height: auto;
}

/* On desktop, position dots absolutely below the text content area */
@media (min-width: 1024px) {
    .block-vertical-carousel__content-carousel {
        position: relative;
    }
    
    .block-vertical-carousel__content-carousel .flickity-page-dots {
        position: absolute;
        bottom: 40px;
        left: 0;
        margin: 0;
    }
}

@media (min-width: 1400px) {
    .block-vertical-carousel__content-carousel .flickity-page-dots {
        bottom: 60px;
    }
}

.block-vertical-carousel__content-carousel .flickity-page-dots .dot {
    width: 10px;
    height: 10px;
    margin: 0 6px;
    padding: 0;
    background-color: var(--color-white);
    opacity: 0.4;
    border-radius: 50%;
    border: none;
    transition: all 0.25s ease;
    cursor: pointer;
}

.block-vertical-carousel__content-carousel .flickity-page-dots .dot.is-selected {
    opacity: 1;
    background-color: var(--color-white);
}

/* ==========================================================================
   Carousel Focus Styles
   Hide default focus ring on Flickity drag interactions only.
   Keyboard focus-visible is preserved for accessibility.
   ========================================================================== */

.block-vertical-carousel *:focus:not(:focus-visible) {
    outline: none;
    box-shadow: none;
}

