/* Editor overflow fix for curriculum block */
.block-editor-block-list__layout .curriculum-block,
.editor-styles-wrapper .curriculum-block,
.wp-block-acf-curriculum .curriculum-block {
    max-width: 100%;
    overflow-x: hidden;
}

.curriculum-block {
    --curriculum-desktop-background: linear-gradient(238deg, var(--color-curriculum-gradient-start) 15.98%, var(--color-curriculum-gradient-end) 69.01%);
    background-color: var(--color-white);
    padding: 0;
    font-family: 'Outfit', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
    margin-bottom: 0;
}

.curriculum-block--image-left {
    --curriculum-desktop-background: linear-gradient(122deg, var(--color-curriculum-gradient-start) 15.98%, var(--color-curriculum-gradient-end) 69.01%);
}

.curriculum-content {
    max-width: 100%;
    margin: 0;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-areas: 'content image';
    gap: 0;
    align-items: stretch;
    width: 100%;
    box-sizing: border-box;
    overflow-x: hidden;
    min-width: 0;
    min-height: 41.125rem;
}

.curriculum-content--image-left {
    grid-template-areas: 'image content';
}

/* Left Column - Content Area */
.curriculum-left {
    grid-area: content;
    background: transparent;
    padding: 7.5rem 2rem 5rem 9.375rem;
    box-sizing: border-box;
    min-width: 0;
    max-width: 100%;
    overflow-x: hidden;
    width: 100%;
    color: var(--color-primary-dark);
}

/* Align content with 1728px container on large screens */
@media (min-width: 1729px) {
    .curriculum-left {
        padding-left: calc((100vw - 108rem) / 2 + clamp(6rem, 15.046vw, 16.25rem));
        padding-right: 2rem;
    }
}

/* Match hero-text-column desktop left/right padding logic */
@media (min-width: 1541px) and (max-width: 1728px) {
    .curriculum-left {
        padding-left: clamp(6rem, 15.046vw, 16.25rem);
        padding-right: 2rem;
    }
}

@media (min-width: 1281px) and (max-width: 1540px) {
    .curriculum-left {
        padding-left: 9.375rem;
        padding-right: 2rem;
    }
}

@media (min-width: 1025px) and (max-width: 1280px) {
    .curriculum-left {
        padding-left: 5rem;
        padding-right: 2rem;
    }
}

.curriculum-heading {
    font-family: 'Outfit', sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 2.5rem;
    line-height: 3rem;
    letter-spacing: 0;
    color: var(--color-primary-dark);
    margin: 0 0 2rem 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.curriculum-description {
    font-family: 'Outfit', sans-serif;
    font-weight: 300;
    font-style: normal;
    font-size: 1rem;
    line-height: 1.5rem;
    letter-spacing: 0;
    color: var(--color-primary-dark);
    margin: 0 0 2rem 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.curriculum-highlighted {
    font-family: 'Outfit', sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 1.5rem;
    line-height: 2rem;
    letter-spacing: 0;
    color: var(--color-accent-blue);
    margin: 0 0 1.5rem 0;
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.curriculum-topics {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    min-width: 0;
}

.curriculum-topics-column {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    min-width: 0;
}

.curriculum-topic {
    font-family: 'Outfit', sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 1rem;
    line-height: 1.25rem;
    letter-spacing: 0;
    color: var(--color-primary-dark);
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.curriculum-content-wysiwyg {
    margin-top: 2rem;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    font-family: 'Outfit', sans-serif;
    font-weight: 300;
    font-size: 1rem;
    line-height: 1.5rem;
    color: var(--color-primary-dark);
    word-wrap: break-word;
    overflow-wrap: break-word;
}

.curriculum-content-wysiwyg > *:first-child {
    margin-top: 0;
}

.curriculum-content-wysiwyg > *:last-child {
    margin-bottom: 0;
}

.curriculum-content-wysiwyg p {
    margin: 0 0 1em 0;
}

.curriculum-content-wysiwyg a {
    color: var(--color-accent-blue);
}

.curriculum-content-wysiwyg ul,
.curriculum-content-wysiwyg ol {
    margin: 0 0 1em 1.25em;
    padding: 0;
}

.curriculum-content-wysiwyg img {
    max-width: 100%;
    height: auto;
}

/* Mirror horizontal padding when text column is on the right */
/* .curriculum-content--image-left .curriculum-left {
    padding: 7.5rem 9.375rem 5rem 2rem;
} */

@media (min-width: 1729px) {
    .curriculum-content--image-left .curriculum-left {
        padding-left: 2rem;
        padding-right: calc((100vw - 108rem) / 2 + clamp(6rem, 15.046vw, 16.25rem));
    }
}

@media (min-width: 1541px) and (max-width: 1728px) {
    .curriculum-content--image-left .curriculum-left {
        padding-right: clamp(6rem, 15.046vw, 16.25rem);
        padding-left: 2rem;
    }
}

@media (min-width: 1281px) and (max-width: 1540px) {
    .curriculum-content--image-left .curriculum-left {
        padding-right: 9.375rem;
        padding-left: 2rem;
    }
}

@media (min-width: 1025px) and (max-width: 1280px) {
    .curriculum-content--image-left .curriculum-left {
        padding-right: 5rem;
        padding-left: 2rem;
    }
}

/* Right Column - Image Area */
.curriculum-right {
    grid-area: image;
    background: transparent;
    display: block;
    width: 100%;
    height: 100%;
    max-width: 100%;
    box-sizing: border-box;
    overflow: hidden;
    min-width: 0;
    min-height: 100%;
    position: relative;
    align-self: stretch;
}

.curriculum-image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    display: block;
    min-width: 0;
    min-height: 100%;
}

.curriculum-image-placeholder {
    color: var(--color-text-caption);
    font-size: 1.2rem;
    font-weight: 500;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    min-height: 25rem;
}

/* Block Alignment Support */
.curriculum-block.alignwide {
    max-width: 75rem;
    margin-left: auto;
    margin-right: auto;
}

.curriculum-block.alignfull {
    max-width: 100vw;
    margin-left: calc(50% - 50vw);
    margin-right: calc(50% - 50vw);
}

/* Fix for editor - prevent overflow */
.block-editor-block-list__layout .curriculum-block.alignfull,
.editor-styles-wrapper .curriculum-block.alignfull,
.wp-block-acf-curriculum .curriculum-block.alignfull {
    max-width: 100%;
    margin-left: 0;
    margin-right: 0;
}

/* Responsive Design */
@media (min-width: 1025px) and (max-width: 1280px) {
    .curriculum-left {
        padding-top: 7.5rem;
        padding-bottom: 5rem;
        max-width: 100%;
        box-sizing: border-box;
    }

    .curriculum-content--image-left .curriculum-left {
        padding-top: 7.5rem;
        padding-bottom: 5rem;
    }
}

@media (min-width: 768px) and (max-width: 1024px) {
    .curriculum-content {
        grid-template-columns: 1fr 1fr;
        min-height: 34rem;
    }


    .curriculum-left {
        padding: 5rem min(3.125rem, 6vw) 5rem min(3.125rem, 6vw) !important;
        max-width: 100%;
        box-sizing: border-box;
    }

    .curriculum-topics {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
}

@media (max-width: 767.98px) {
    .curriculum-content {
        grid-template-columns: 1fr;
        grid-template-areas: 'content';
        max-width: 100%;
        overflow-x: hidden;
        min-height: auto;
    }

    .curriculum-block {
        background-color: var(--color-white);
        margin-bottom: 0 !important;
    }

    .curriculum-left {
        padding: 3.75rem 2rem 5rem 2rem;
        display: flex;
        flex-direction: column;
        max-width: 100%;
        width: 100%;
        box-sizing: border-box;
    }

    .curriculum-right {
        display: none;
    }

    .curriculum-heading {
        font-size: 2rem;
        font-weight: 400;
        line-height: 1.25;
        margin-bottom: 2rem;
        word-wrap: break-word;
        overflow-wrap: break-word;
    }

    .curriculum-description {
        font-family: 'Outfit', sans-serif;
        font-weight: 300;
        font-style: normal;
        font-size: 1rem;
        line-height: 1.5rem;
        letter-spacing: 0;
        margin-bottom: 1.5625rem;
        word-wrap: break-word;
        overflow-wrap: break-word;
    }

    .curriculum-highlighted {
        font-size: 1.5rem;
        font-weight: 400;
        margin-bottom: 2rem;
        word-wrap: break-word;
        overflow-wrap: break-word;
        font-family: Outfit;
        line-height: 2rem;

    }

    .curriculum-topics {
        grid-template-columns: 1fr;
        gap: 1rem;
    }
}

@media (max-width: 480px) {
    .curriculum-left {
        padding: 3.75rem 2rem 5rem 2rem;
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
    }

    .curriculum-heading {
        font-family: 'Outfit', sans-serif;
        font-weight: 400;
        font-style: normal;
        font-size: 2rem;
        line-height: 2.5rem;
        letter-spacing: 0;
    }
}

/* Extra small devices - prevent any overflow */
@media (max-width: 320px) {
    .curriculum-left {
        padding: 3.75rem 2rem 5rem 2rem;
    }

    .curriculum-topics {
        gap: 0.75rem;
    }
}

/* Editor Preview Styles */
.wp-block-acf-curriculum .curriculum-block {
    border: 0.125rem dashed var(--color-border-medium);
    position: relative;
}

.wp-block-acf-curriculum .curriculum-block::after {
    content: "📚 Curriculum Block - Course topics with image";
    position: absolute;
    top: 0.625rem;
    right: 0.625rem;
    background: var(--color-overlay-dark-80);
    color: var(--color-white);
    padding: 0.5rem 0.75rem;
    font-size: 0.6875rem;
    border-radius: 0.25rem;
    z-index: 10;
    font-weight: 500;
    max-width: 17.5rem;
    text-align: center;
    line-height: 1.3;
}
@media only screen and (min-width: 768px) and (max-width: 1024px) and (-webkit-min-device-pixel-ratio: 2) {
    .curriculum-heading {
        font-size: clamp(2rem, 4vw, 2.5rem);
    }
}

/* Desktop: restore classic left/right composition */
@media (min-width: 1025px) {
    .curriculum-block {
        background: var(--curriculum-desktop-background);
    }

    .curriculum-content {
        /* 1728px Figma ratios: left 584, gap 104, right 538 */
        --curriculum-gap: clamp(2.5rem, 6.0185vw, 6.5rem);
        grid-template-columns:
            minmax(0, calc((100% - var(--curriculum-gap)) * 584 / 1122))
            minmax(0, calc((100% - var(--curriculum-gap)) * 538 / 1122));
        align-items: end;
        justify-content: stretch;
        column-gap: var(--curriculum-gap);
        min-height: auto;
        max-width: 1728px;
        margin-left: auto;
        margin-right: auto;
        padding: 0 9.375rem;
        padding-top: 4.125rem;
        box-sizing: border-box;
    }

    .curriculum-left {
        width: 100%;
        max-width: none;
        min-height: clamp(22rem, 26.5046vw, 28.625rem);
        height: auto;
        padding: 0 !important;
        padding-top: 3.375rem !important;
        padding-bottom: 5rem !important;
        align-self: start;
    }

    .curriculum-content--image-left .curriculum-left {
        padding: 0 !important;
        padding-top: 3.375rem !important;
        padding-bottom: 5rem !important;
    }

    .curriculum-right {
        width: 100%;
        max-width: 33.625rem;
        aspect-ratio: 538 / 639;
        height: auto;
        min-height: 0;
        justify-self: end;
        align-self: end;
    }

    .curriculum-image,
    .curriculum-image-placeholder {
        width: 100%;
        height: 100%;
        object-fit: cover;
        object-position: center bottom;
    }

    .curriculum-content--image-left {
        grid-template-columns:
            minmax(0, calc((100% - var(--curriculum-gap)) * 538 / 1122))
            minmax(0, calc((100% - var(--curriculum-gap)) * 584 / 1122));
        grid-template-areas: 'image content';
    }

    .curriculum-content--image-left .curriculum-right {
        justify-self: start;
    }

    .curriculum-content--image-left .curriculum-left {
        margin-left: 0;
    }

    /* Seam fix: pull testimonial separator upward over curriculum bottom edge */
    .curriculum-block + .testimonial-saparator,
    .wp-block-acf-curriculum + .wp-block-acf-testimonial .testimonial-saparator {
        margin-top: -3.5rem !important;
        position: relative;
        z-index: 3;
    }
}

@media (min-width: 1025px) and (max-width: 1280px) {
    .curriculum-content {
        --curriculum-gap: clamp(1.25rem, 3vw, 2.5rem);
        grid-template-columns:
            minmax(0, calc((100% - var(--curriculum-gap)) * 520 / 1122))
            minmax(0, calc((100% - var(--curriculum-gap)) * 602 / 1122));
        padding-left: 5rem;
        padding-right: 5rem;
    }

    .curriculum-heading {
        font-size: 2.25rem;
        line-height: 2.75rem;
    }

    .curriculum-highlighted {
        font-size: 1.375rem;
        line-height: 1.875rem;
    }

    .curriculum-right {
        max-width: 37.625rem;
    }

    .curriculum-content--image-left {
        grid-template-columns:
            minmax(0, calc((100% - var(--curriculum-gap)) * 602 / 1122))
            minmax(0, calc((100% - var(--curriculum-gap)) * 520 / 1122));
    }
}

@media (min-width: 1541px) {
    .curriculum-content {
        padding-left: clamp(6rem, 15.046vw, 16.25rem);
        padding-right: clamp(6rem, 15.046vw, 16.25rem);
    }
}

/* Tablet: stacked layout with visible image */
@media (min-width: 768px) and (max-width: 1024px) {
    .curriculum-block {
        background: var(--curriculum-desktop-background);
        margin-bottom: 0 !important;
    }

    .curriculum-content {
        grid-template-columns: 1fr;
        grid-template-areas:
            'content'
            'image';
        max-width: 100%;
        overflow-x: hidden;
        min-height: auto;
        padding: 0;
        box-sizing: border-box;
        row-gap: 0;
    }

    .curriculum-left {
        display: flex;
        flex-direction: column;
        width: 100%;
        max-width: 100%;
        padding: 3.75rem 3.125rem 1.5rem 3.125rem !important;
        box-sizing: border-box;
    }

    .curriculum-content--image-left .curriculum-left {
        padding: 3.75rem 3.125rem 1.5rem 3.125rem !important;
    }

    .curriculum-right {
        display: block;
        width: 100%;
        max-width: 35rem;
        margin: 0 auto;
        height: auto;
        aspect-ratio: 352 / 280;
        min-height: 0;
        align-self: end;
        overflow: visible;
    }

    .curriculum-image,
    .curriculum-image-placeholder {
        width: 100%;
        height: 100%;
        object-fit: contain;
        object-position: center bottom;
    }

    .curriculum-content--image-left {
        grid-template-areas:
            'content'
            'image';
    }

    .curriculum-topics {
        grid-template-columns: 1fr 1fr;
        gap: 1rem;
    }

    .curriculum-block + .testimonial-saparator,
    .wp-block-acf-curriculum + .wp-block-acf-testimonial .testimonial-saparator {
        margin-top: -2rem !important;
        position: relative;
        z-index: 3;
    }
}