:root {
    --container-max-width: calc(1088px + 10%);
    --container-padding: 0 5%;
    --images-radius: 16px;
    --color--gpa-black: #3A3939;
    --color--gpa-white: #F8F9F8;
    --color--gpa-brown: #C45E1B;
    --color--gpa-alt-bg: #ECEFEE;
    --font--inria-sans: "Inria Sans";
    --card-shadow: 0px 24px 32px 0px #00000040;
}

.program__section {
    width: 100%;
    padding: var(--container-padding);
}

.program__container {
    max-width: var(--container-max-width);
    margin: 0 auto;
    width: 100%;
}

.h2 {
    font-family: var(--font--inria-sans), Sans-serif;
    font-size: 40px;
    font-weight: 700;
    line-height: 1.2;
    color: var(--color--gpa-black);
    margin-block: 0;
}

.h3 {
    font-family: var(--font--inria-sans), Sans-serif;
    font-size: 24px;
    font-weight: 700;
    line-height: 1.3;
    color: var(--color--gpa-black);
    margin-block: 0;
}

.text--20 {
    font-size: 20px;
    line-height: 1.3;
}

.tagline {
    font-family: var(--font--inria-sans), Sans-serif;
    font-size: 14px;
    letter-spacing: 0.22em;
    font-weight: 700;
    text-transform: uppercase;
}

.program p {
    
    margin-block-end: 0;
}

.program ul {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
    padding-left: 0;
    list-style: none;
}

.program ul li {
    display: flex;
    column-gap: 16px;
}

.program ul li::before {
    content: '';
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: var(--program-color);
    margin-top: -2px;
    flex: none;
}

/*Hero*/
.program-hero {
    padding-block: 48px;
    background-image: url('/wp-content/uploads/2025/08/program-hero-bg.webp');
    background-position: right bottom;
    background-repeat: no-repeat;
    background-size: auto;
}

.program-hero__wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 48px;
    align-items: center;
}

.program-hero__media {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: var(--images-radius);
    overflow: clip;
    min-height: 616px;
}

.program-hero__media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.program-hero__content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    row-gap: 32px;
}

.program-hero__top-label {
    padding: 4px 8px;
    border-radius: 8px;
    background-color: #7676801F;
    font-size: 14px;
    font-weight: 700;
    align-self: end;
}

.program-hero__top-label-number {
    color: var(--color--gpa-black);
}

.program-hero__title-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 14px;
    align-items: center;
}

.program-hero__title {
    font-family: var(--font--inria-sans), Sans-serif;
    font-size: 27px;
    letter-spacing: 0.22em;
    font-weight: 400;
    text-transform: uppercase;
    line-height: 1.5;
    margin-block: 0;
    color: var(--color--gpa-black);
    padding-inline: 16px;
    background-color: var(--program-color);
}

.program-hero__dots {
    display: flex;
    gap: 8px;
}

.program-hero__dot {
    width: 19px;
    height: 19px;
    border-radius: 50%;
    background-color: var(--program-color);
}

.program-hero__text-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
    margin-bottom: 16px;
}

.program-hero__description,
.key-features {
    color: var(--color--gpa-black);
}

ul.key-features {
    row-gap: 24px;
}

/*Specs*/
.program-specs {
    padding-block: 24px;
    background-color: var(--color--gpa-black);
    color: var(--program-color);
}

.program-specs__wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    gap: 48px;
}

.program-specs__item {
    display: flex;
    flex-direction: column;
    text-align: center;
    column-gap: 8px;
}

.program-specs__item-title.h2 {
    color: inherit;
}

/*Offer Banner*/
.program-offer {
    color: var(--color--gpa-black);
    padding-block: 32px;
    background-color: var(--program-color);
    box-shadow: var(--card-shadow);
    position: sticky;
    top: 73px;
    z-index: 9;
}

.program-offer__wrap {
    display: flex;
    gap: 48px;
    align-items: center;
    justify-content: space-between;
}

.program-offer__title-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 8px;
    align-items: center;
}

.program-offer__title {
    font-family: var(--font--inria-sans), Sans-serif;
    font-size: 17px;
    text-transform: uppercase;
    letter-spacing: 0.22em;
    padding-inline: 10px;
    background-color: var(--color--gpa-white);
}

.program-offer__dots {
    display: flex;
    justify-content: center;
    column-gap: 5px;
}

.program-offer__dot {
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background-color: var(--color--gpa-white);
}

.program-offer__text-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 8px;
    text-align: center;
}

.program-offer__description strong {
    font-size: 20px;
    font-weight: 800;
}

/*Testimonials*/
.program-testimonials {
    padding-block: 48px;
    overflow: hidden;
    background-image: url('/wp-content/uploads/2025/08/footer-bg.webp');
     background-position: center bottom;
    background-repeat: no-repeat;
    background-size: contain;
}

.program-testimonials__wrap {
    display: flex;
    flex-direction: column;
    row-gap: 64px;
}

.program-testimonials__list-wrap {
    overflow: visible;
    width: auto;
    max-width: 100%;
    position: relative;
}

.program-testimonials__title-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
    text-align: center;
}

.testimonial__item {
    max-width: 320px;
    width: 100%;
}

.testimonial__card {
    padding: 24px 16px;
    background-color: var(--color--gpa-white);
    border-radius: 16px;
    box-shadow: var(--card-shadow);
    display: flex;
    flex-direction: column;
    row-gap: 17px;
}

.testimonial__author-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 5px;
}

.testimonial__author {
    font-family: var(--font--inria-sans), Sans-serif;
    font-size: 20px;
    font-weight: 700;
    margin-block: 0;
    color: var(--color--gpa-black);
}

.testimonial__company {
    font-size: 12px;
    font-weight: 500;
    line-height: 1.1;
}

.testimonial__content {
    font-size: 14px;
    color: var(--color--gpa-black);
}

.testimonial__rating {
    display: flex;
    column-gap: 5px;
}

.testimonial__star {
    color: var(--color--gpa-brown);
}

.program-testimonials__navigation {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 2;
    cursor: pointer;
}

.program-testimonials__navigation.swiper-button-disabled {
    opacity: .7;
    cursor: unset;
}

.program-testimonials__navigation.next {
    right: 3%;
}

.program-testimonials__navigation.prev {
    left: 3%;
}

.program-testimonials__navigation > svg {
    width: 34px;
    display: flex;
}

/*Ideal For*/
.ideal-for {
    padding-block: 64px;
    background-color: var(--program-color);
    background-image: url('/wp-content/uploads/2025/08/ideal-for-bg.webp');
    background-repeat: no-repeat;
    background-size: auto 100%;
    background-position: right bottom; 
}

.ideal-for__wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    align-items: center;
    gap: 48px;
}

.ideal-for__content {
    display: flex;
    flex-direction: column;
    row-gap: 64px;
    color: var(--color--gpa-black);
}

.ideal-for__content-top {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
}

ul.ideal-for__key-features > li.ideal-for__key-features__item::before {
    background-color: var(--color--gpa-white);
}

.ideal-for__media {
    position: relative;
    width: 100%;
    height: 100%;
    border-radius: var(--images-radius);
    overflow: clip;
    min-height: 421px;
}

.ideal-for__media img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

/*Curriculum*/
.curriculum {
    padding-block: 64px;
    background-image: url('/wp-content/uploads/2025/08/curriculum-bg.webp');
    background-repeat: no-repeat;
    background-position: center bottom;
    background-size: 100% 40%;
}

.curriculum__wrap {
    display: flex;
    flex-direction: column;
    row-gap: 64px;
}

.curriculum__title-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 16px;
    text-align: center;
}

.curriculum__ground-wrap {
    display: flex;
    flex-direction: column;
    row-gap: 24px;
}

.ground__item {
    padding: 24px;
    border-radius: 16px;
    border: 1px solid var(--program-color);
    display: flex;
    flex-direction: column;
    row-gap: 64px;
    background-color: var(--color--gpa-white);
}

.ground__title-wrap {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    row-gap: 16px;
}

.ground__title {
    padding: 8px 16px;
    background-color: var(--color--gpa-alt-bg);
    border-radius: 8px;
}

.ground__description {
    font-weight: 500;
}

.module {
    padding: 24px;
    border-radius: 16px;
    background-color: var(--color--gpa-alt-bg);
}

.module[aria-expanded="false"] .module__key-feature-wrap {
    max-height: 0px
}

.module[aria-expanded="true"] .module__key-feature-wrap {
    max-height: 1000px
}

.module__title-wrap {
    display: flex;
    column-gap: 24px;
    justify-content: space-between;
    align-items: center;
    color: var(--color-gpa-black);
    cursor: pointer;
}

.module__title-icon svg {
    width: 11px;
    transform: rotate(-180deg);
    transition: all .3s ease;
}

.module[aria-expanded="false"] .module__title-icon svg {
    transform: rotate(-180deg)
}

.module[aria-expanded="true"] .module__title-icon svg {
    transform: rotate(0deg)
}

.module__key-feature-wrap {
    overflow: hidden;
    transition: max-height .3s ease;
}

.module__key-features-spacer {
    height: 48px;
}

ul.module__key-features-list {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: 24px;
    padding-top: 2px;
}

.ground__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.ground__tag {
    font-size: 14px;
    font-weight: 700;
    color: var(--color--gpa-black);
    padding: 4px 8px;
    border-radius: 8px;
}

.curriculum__bottom-text {
    font-weight: 600;
    color: var(--color--gpa-black);
}

.curriculum__bottom-text  a {
    text-decoration: underline;
}

/*CTA*/
.program-cta {
    padding-block: 64px;
    background-color: var(--color--gpa-alt-bg);
    background-image: url('/wp-content/uploads/2025/08/program-cta-bg.webp');
    background-repeat: no-repeat;
    background-position: left bottom;
}

.program-cta__wrap {
    display: grid;
    grid-template-columns: .8fr 1fr;
    gap: 64px;
    align-items: center;
}

.program-cta__content {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    row-gap: 16px;
    color: var(--color--gpa-black);
}

.program-cta__description {
    margin-bottom: 32px;
}

.program-cta__content .elementor-button {
    background-color: var(--color--gpa-black);
}

.program-cta__content .elementor-button-content-wrapper {
    column-gap: 14px;
}

/*Table Screen*/
@media screen and (max-width: 1024px) {
    .h2 {
        font-size: 32px;
    }
    
    .h3 {
        font-size: 22px;
    }
    
    .text--20 {
        font-size: 18px;
    }
    
    .program ul li::before {
        width: 30px;
        height: 30px;
     }
    
    /*Hero*/
    .program-hero__title {
        font-size: 24px;
    }
    
    /*Offer Banner*/
    .program-offer {
        padding-block: 24px;
    }
    
    .program-offer__wrap {
        gap: 16px;
        flex-direction: column;
    }

    .program-offer__description strong {
        font-size: 18px;
    }
    
    /*Curriculum*/
    .ground__item {
        row-gap: 48px;
    }
    
    /*CTA*/
    .program-cta__wrap {
        gap: 48px; 
    }
}

/*Phone Landscape*/
@media screen and (max-width: 767px) {
    .h2 {
        font-size: 28px;
    }
    
    .h3 {
        font-size: 20px;
    }
    
    .text--20 {
        font-size: 16px;
    }
    
    .program ul li::before {
        width: 28px;
        height: 28px;
     }
    
    /*Hero*/
    .program-hero__wrap {
        display: flex;
        flex-direction: column-reverse;
    }
    
    .program-hero__media {
        min-height: 400px;
    }
    
    .program-hero__title {
        font-size: 20px;
    }
    
    /*Offer Banner*/
    .program-offer__description strong {
        font-size: 16px;
    }
    
    /*Testimonials*/
    .program-testimonials__wrap {
        row-gap: 48px;    
    }
    
    .testimonial__item {
        max-width: 280px;
    }
    
    /*Ideal For*/
    .ideal-for {
        padding-block: 48px;
        background-image: unset;
    }
    
    .ideal-for__wrap {
        display: flex;
        flex-direction: column;
        row-gap:  48px;
    }
    
    .ideal-for__content {
        row-gap: 48px;
    }
    
    .ideal-for__media {
        min-height: 400px;
    }
    
    /*Curriculum*/
    .curriculum {
        padding-block: 48px;
    }
    
    .curriculum__wrap {
        row-gap: 48px;
    }
    
    .ground__item,
    .module {
        padding: 16px;
    }
    
    ul.module__key-features-list {
        grid-template-columns: 1fr;
    }
    
    /*CTA*/
    .program-cta {
        padding-block: 48px;
    }
    .program-cta__wrap {
        display: flex;
        flex-direction: column;
    }
    
    .program-cta__wrap img {
        max-width: 400px;
    }
    
    .program-cta__content {
        text-align: center;
        align-items: center;
    }
    
    .program-cta__description {
        margin-bottom: 0;  
    }
}