/* =========================================================
CURRICULUM HERO
========================================================= */

.curriculum-hero{
    position: relative;
    overflow: hidden;
    min-height: calc(100vh - 88px);
    display: flex;
    align-items: flex-end;
    padding: 58px 0 0;
    background:
        radial-gradient(circle at top left, rgba(255,255,255,.95), transparent 30%),
        radial-gradient(circle at bottom right, rgba(11,44,102,.12), transparent 34%),
        linear-gradient(135deg, #ffffff 0%, #f1f7ff 48%, #e4f1ff 100%);
}

.curriculum-hero::before{
    content: '';
    position: absolute;
    inset: auto 0 0 0;
    height: 42%;
    background: linear-gradient(180deg, transparent 0%, rgba(255,255,255,.92) 92%);
    z-index: 2;
    pointer-events: none;
}

.curriculum-hero .container{
    position: relative;
    z-index: 3;
    max-width: 1320px;
}

.curriculum-hero-content{
    position: relative;
    z-index: 4;
    padding-bottom: 92px;
}

.curriculum-hero-content h1{
    font-size: 56px;
    font-weight: 800;
    color: var(--color1);
    line-height: 1.08;
    margin-bottom: 24px;
    letter-spacing: -1px;
}

.curriculum-hero-content p{
    font-size: 17px;
    line-height: 1.9;
    color: var(--color1);
    max-width: 560px;
    margin-bottom: 54px;
}

/* VALUES */

.curriculum-hero-values{
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 24px 22px;
    width: 100%;
    max-width: 560px;
}

.curriculum-hero-value-item{
    position: relative;
    text-align: center;
}

.curriculum-hero-value-icon{
    width: 72px;
    height: 72px;
    margin: 0 auto 18px;
    border-radius: 50%;
    background: rgba(240, 248, 255, .95);
    color: #0f9e9e;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 34px;
    box-shadow: 0 12px 28px rgba(11,44,102,.08);
}

.curriculum-hero-value-item h4{
    font-size: 13px;
    font-weight: 800;
    color: var(--color1);
    margin-bottom: 9px;
}

.curriculum-hero-value-item span{
    display: block;
    font-size: 11.5px;
    line-height: 1.65;
    color: var(--color5);
}

/* VISUAL */

.curriculum-hero-visual{
    position: relative;
    min-height: 560px;
    display: flex;
    align-items: flex-end;
    justify-content: flex-end;
}

.curriculum-hero-img{
    position: absolute;
    left: 0;
    right: 60px;
    bottom: 0;
    height: 78%;
    max-height: 78%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    z-index: 2;
    pointer-events: none;
}

.curriculum-hero-img img{
    width: auto;
    height: 100%;
    max-height: 100%;
    object-fit: contain;
    object-position: bottom center;
}

/* ANIMATION */

.fade-up{
    opacity: 0;
    animation: curriculumFadeUp .85s ease forwards;
}

.fade-left{
    opacity: 0;
    animation: curriculumFadeLeft .9s ease forwards;
}

@keyframes curriculumFadeUp{
    from{
        opacity: 0;
        transform: translateY(42px);
    }
    to{
        opacity: 1;
        transform: translateY(0);
    }
}

@keyframes curriculumFadeLeft{
    from{
        opacity: 0;
        transform: translateX(44px);
    }
    to{
        opacity: 1;
        transform: translateX(0);
    }
}

/* RESPONSIVE */

@media(max-width:1199px){

    .curriculum-hero{
        min-height: auto;
        padding: 54px 0 0;
    }

    .curriculum-hero-content{
        padding-bottom: 58px;
    }

    .curriculum-hero-content h1{
        font-size: 46px;
    }

    .curriculum-hero-content p{
        margin-bottom: 42px;
    }

    .curriculum-hero-values{
        width: 100%;
        max-width: 560px;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .curriculum-hero-visual{
        min-height: 520px;
    }
}

@media(max-width:991px){

    .curriculum-hero{
        text-align: center;
        padding: 48px 0 0;
    }

    .curriculum-hero-content{
        padding-bottom: 36px;
    }

    .curriculum-hero-content h1{
        font-size: 40px;
    }

    .curriculum-hero-content p{
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 34px;
    }

    .curriculum-hero-values{
        max-width: 720px;
        margin: 0 auto;
    }

    .curriculum-hero-visual{
        min-height: auto;
        flex-direction: column;
        align-items: center;
    }

    .curriculum-hero-img{
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
        width: 100%;
        height: auto;
        max-height: none;
        justify-content: center;
        pointer-events: auto;
        z-index: 2;
    }

    .curriculum-hero-img img{
        width: auto;
        height: auto;
        max-height: 430px;
        object-position: bottom center;
    }
}

@media(max-width:768px){

    .curriculum-hero{
        padding-top: 42px;
    }

    .curriculum-hero-content h1{
        font-size: 34px;
    }

    .curriculum-hero-content p{
        font-size: 15px;
        line-height: 1.8;
    }

    .curriculum-hero-values{
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .curriculum-hero-value-item{
        padding: 20px;
        background: rgba(255,255,255,.74);
        border-radius: 20px;
        box-shadow: 0 12px 28px rgba(11,44,102,.06);
    }

    .curriculum-hero-value-icon{
        width: 64px;
        height: 64px;
        font-size: 28px;
        margin-bottom: 14px;
    }

    .curriculum-hero-img img{
        max-height: 340px;
    }
}

@media(max-width:480px){

    .curriculum-hero-content h1{
        font-size: 31px;
    }

    .curriculum-hero-img img{
        max-height: 300px;
    }
}

/* =========================================================
CURRICULUM PROGRAM SECTION
========================================================= */

.curriculum-program-section{
    position: relative;
    overflow: hidden;
    padding: 72px 0 82px;
    background:
        radial-gradient(circle at top left, rgba(32,160,160,.09), transparent 28%),
        radial-gradient(circle at bottom right, rgba(11,44,102,.08), transparent 32%),
        linear-gradient(180deg, #ffffff 0%, #f8fbff 50%, #eef7ff 100%);
}

.curriculum-section-heading{
    margin-bottom: 30px;
}

.curriculum-section-heading h2{
    font-size: 30px;
    font-weight: 800;
    color: var(--color1);
    margin-bottom: 10px;
}

.curriculum-section-heading p{
    font-size: 14px;
    line-height: 1.7;
    color: var(--color5);
    margin: 0;
}

.curriculum-program-card{
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(11,44,102,.08);
    border-radius: 24px;
    padding: 28px;
    margin-bottom: 32px;
    box-shadow: 0 18px 46px rgba(11,44,102,.08);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
    transition: var(--transition);
}

.curriculum-program-card:hover{
    transform: translateY(-6px);
    box-shadow: 0 26px 60px rgba(11,44,102,.12);
}

/* LEFT PROFILE */

.curriculum-program-profile{
    display: grid;
    grid-template-columns: 210px 1fr;
    gap: 28px;
    height: auto;
}

.curriculum-program-image{
    overflow: hidden;
    border-radius: 16px;
    height: 250px;
    box-shadow: 0 12px 30px rgba(11,44,102,.09);
}

.curriculum-program-image img{
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .55s ease;
}

.curriculum-program-card:hover .curriculum-program-image img{
    transform: scale(1.06);
}

.curriculum-program-info{
    padding-top: 8px;
}

.curriculum-program-title{
    display: flex;
    align-items: center;
    gap: 18px;
    margin-bottom: 20px;
}

.curriculum-program-icon{
    width: 66px;
    height: 66px;
    flex: 0 0 66px;
    border-radius: 50%;
    background: linear-gradient(135deg, #0f9e9e 0%, #087d80 100%);
    color: var(--color4);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 30px;
    box-shadow: 0 14px 28px rgba(8,125,128,.22);
}

.curriculum-program-icon.purple{
    background: linear-gradient(135deg, #7552c8 0%, #5635a7 100%);
    box-shadow: 0 14px 28px rgba(86,53,167,.18);
}

.curriculum-program-title h3{
    font-size: 24px;
    line-height: 1.25;
    font-weight: 800;
    color: var(--color1);
    margin: 0;
}

.curriculum-program-info p{
    font-size: 13px;
    line-height: 1.8;
    color: var(--color5);
    margin-bottom: 22px;
}

.curriculum-program-info span{
    display: block;
    font-size: 13px;
    font-weight: 700;
    color: var(--color1);
    margin-bottom: 8px;
}

.curriculum-akre-img img{
    width: 165px;
    height: auto;
}

/* META */

.curriculum-program-meta{
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 22px;
    margin-top: 24px;
}

.curriculum-program-meta-item{
    display: flex;
    align-items: center;
    gap: 14px;
}

.curriculum-program-meta-item i{
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: rgba(15,158,158,.10);
    color: #0f9e9e;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 20px;
}

.purple-meta .curriculum-program-meta-item i{
    background: rgba(117,82,200,.10);
    color: #7552c8;
}

.curriculum-program-meta-item strong{
    display: block;
    font-size: 14px;
    font-weight: 800;
    color: var(--color1);
    margin-bottom: 4px;
}

.curriculum-program-meta-item span{
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--color5);
}

/* RIGHT STRUCTURE */

.curriculum-structure{
    height: 100%;
    padding-left: 34px;
    border-left: 1px solid rgba(11,44,102,.12);
}

.curriculum-structure h4{
    font-size: 21px;
    font-weight: 800;
    color: var(--color1);
    margin-bottom: 32px;
}

.curriculum-semester-grid{
    display: grid;
    gap: 34px 26px;
}

.s1-grid{
    grid-template-columns: repeat(4, 1fr);
}

.curriculum-semester-item{
    position: relative;
    min-height: 136px;
    padding: 28px 16px 18px;
    border-radius: 16px;
    text-align: center;
    background:
        radial-gradient(circle at top, rgba(255,255,255,.9), transparent 48%),
        linear-gradient(180deg, #ffffff 0%, #f5fbff 100%);
    box-shadow: 0 12px 28px rgba(11,44,102,.05);
}

.curriculum-semester-item:not(:nth-child(4n))::after{
    content: '\f061';
    font-family: "Font Awesome 7 Free";
    font-weight: 900;
    position: absolute;
    right: -19px;
    top: 48%;
    transform: translateY(-50%);
    color: #0f9e9e;
    font-size: 14px;
}

.curriculum-semester-number{
    position: absolute;
    top: -16px;
    left: 50%;
    transform: translateX(-50%);
    width: 34px;
    height: 34px;
    border-radius: 50%;
    background: #0f9e9e;
    color: var(--color4);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
    font-weight: 800;
    box-shadow: 0 8px 18px rgba(8,125,128,.20);
}

.curriculum-semester-item h5{
    font-size: 13px;
    font-weight: 800;
    color: var(--color1);
    margin-bottom: 8px;
}

.curriculum-semester-item p{
    font-size: 11.5px;
    line-height: 1.55;
    color: var(--color5);
    margin: 0;
}

/* NOTE */

.curriculum-program-note{
    position: relative;
    overflow: hidden;
    margin-top: 28px;
    min-height: 66px;
    border-radius: 16px;
    padding: 16px 92px 16px 24px;
    background: rgba(15,158,158,.06);
    border: 1px solid rgba(15,158,158,.12);
    display: flex;
    align-items: center;
    gap: 18px;
}

.curriculum-program-note > i{
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    border-radius: 50%;
    background: rgba(15,158,158,.10);
    color: #0f9e9e;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
}

.curriculum-program-note p{
    position: relative;
    z-index: 2;
    flex: 1;
    min-width: 0;
    margin: 0;
    font-size: 13px;
    line-height: 1.65;
    color: var(--color5);
}

.curriculum-program-note strong{
    color: #0f9e9e;
}

.curriculum-note-arrow{
    position: absolute;
    top: 50%;
    right: 24px;
    transform: translateY(-50%);
    z-index: 1;
    margin-left: 0;
    color: rgba(15,158,158,.35);
    font-size: 44px;
    line-height: 1;
    pointer-events: none;
}

/* NERS */

.ners-card{
    margin-bottom: 0;
}

.curriculum-ners-grid{
    display: grid;
    grid-template-columns: 1fr 34px 1fr;
    gap: 18px;
    align-items: center;
}

.curriculum-ners-semester{
    min-height: 280px;
    border-radius: 24px;
    padding: 30px 32px;
    background:
        radial-gradient(circle at top left, rgba(255,255,255,.88), transparent 42%),
        linear-gradient(135deg, rgba(117,82,200,.10) 0%, rgba(255,255,255,.96) 100%);
    border: 1px solid rgba(117,82,200,.10);
}

.curriculum-ners-title{
    display: flex;
    align-items: center;
    gap: 16px;
    margin-bottom: 22px;
}

.curriculum-ners-title span{
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background: #7552c8;
    color: var(--color4);
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 800;
}

.curriculum-ners-title h5{
    font-size: 18px;
    font-weight: 800;
    color: #5635a7;
    margin: 0;
}

.curriculum-ners-table{
    overflow: hidden;
    border-radius: 16px;
    border: 1px solid rgba(117,82,200,.12);
    background: rgba(255,255,255,.78);
}

.curriculum-ners-row{
    display: grid;
    grid-template-columns: 38px minmax(0, 1fr) 42px;
    align-items: center;
    gap: 10px;
    padding: 10px 12px;
    border-bottom: 1px solid rgba(117,82,200,.10);
}

.curriculum-ners-row:last-child{
    border-bottom: none;
}

.curriculum-ners-row span,
.curriculum-ners-row strong{
    font-size: 12px;
    line-height: 1.45;
}

.curriculum-ners-row span:first-child,
.curriculum-ners-row strong:last-child{
    text-align: center;
}

.curriculum-ners-row span{
    color: var(--color1);
}

.curriculum-ners-row strong{
    font-weight: 800;
    color: #5635a7;
}

.curriculum-ners-head{
    background: rgba(117,82,200,.10);
}

.curriculum-ners-head span{
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    color: #5635a7;
}

.curriculum-ners-total,
.curriculum-ners-grand-total{
    background: rgba(117,82,200,.06);
}

.curriculum-ners-total span,
.curriculum-ners-grand-total span{
    font-weight: 800;
}

.curriculum-ners-grand-total{
    background: rgba(245,197,24,.18);
}

.curriculum-ners-arrow{
    text-align: center;
    color: #7552c8;
    font-size: 20px;
}

.purple-note{
    background: rgba(117,82,200,.06);
    border-color: rgba(117,82,200,.12);
}

.purple-note > i{
    background: rgba(117,82,200,.10);
    color: #7552c8;
}

/* RESPONSIVE */

@media(max-width:1199px){

    .curriculum-program-profile{
        grid-template-columns: 180px 1fr;
    }

    .curriculum-program-image{
        height: 230px;
    }

    .s1-grid{
        grid-template-columns: repeat(2, 1fr);
    }

    .curriculum-semester-item:not(:nth-child(4n))::after{
        display: none;
    }
}

@media(max-width:991px){

    .curriculum-program-section{
        padding: 62px 0 70px;
    }

    .curriculum-structure{
        padding-left: 0;
        border-left: none;
        border-top: 1px solid rgba(11,44,102,.12);
        padding-top: 28px;
    }

    .curriculum-structure h4{
        text-align: center;
    }
}

@media(max-width:768px){

    .curriculum-program-section{
        padding: 52px 0 60px;
    }

    .curriculum-section-heading h2{
        font-size: 25px;
    }

    .curriculum-program-card{
        padding: 22px;
        border-radius: 22px;
    }

    .curriculum-program-profile{
        grid-template-columns: 1fr;
        text-align: center;
    }

    .curriculum-program-image{
        height: 240px;
    }

    .curriculum-program-title{
        justify-content: center;
        flex-direction: column;
        gap: 14px;
    }

    .curriculum-akre-img img{
        width: 150px;
    }

    .curriculum-program-meta{
        grid-template-columns: 1fr;
    }

    .curriculum-program-meta-item{
        justify-content: center;
        text-align: left;
    }

    .s1-grid{
        grid-template-columns: 1fr;
        gap: 26px;
    }

    .curriculum-program-note{
        flex-direction: column;
        text-align: center;
        padding: 20px;
    }

    .curriculum-note-arrow{
        position: static;
        transform: none;
        margin: 0;
        font-size: 32px;
    }

    .curriculum-ners-grid{
        grid-template-columns: 1fr;
    }

    .curriculum-ners-arrow{
        transform: rotate(90deg);
    }

    .curriculum-ners-semester{
        min-height: auto;
        padding: 26px 24px;
    }
}

@media(max-width:480px){

    .curriculum-program-card{
        padding: 18px;
    }

    .curriculum-program-image{
        height: 210px;
    }

    .curriculum-program-title h3{
        font-size: 21px;
    }

    .curriculum-structure h4{
        font-size: 18px;
    }
}

/* =========================================================
CURRICULUM PATH & EXCELLENCE SECTION
========================================================= */

.curriculum-path-section{
    position: relative;
    overflow: hidden;
    padding: 72px 0 82px;
    background:
        radial-gradient(circle at top right, rgba(32,160,160,.08), transparent 28%),
        radial-gradient(circle at bottom left, rgba(11,44,102,.07), transparent 30%),
        linear-gradient(180deg, #ffffff 0%, #f8fbff 52%, #eef7ff 100%);
}

.curriculum-path-box{
    background:
        radial-gradient(circle at top left, rgba(255,255,255,.92), transparent 38%),
        linear-gradient(135deg, #eefaff 0%, #f8fcff 58%, #edf7ff 100%);
    border: 1px solid rgba(11,44,102,.07);
    border-radius: 22px;
    padding: 28px 38px 24px;
    box-shadow: 0 16px 42px rgba(11,44,102,.07);
    margin-bottom: 42px;
}

.curriculum-path-box h2{
    text-align: center;
    font-size: 22px;
    font-weight: 800;
    color: #0f9e9e;
    margin-bottom: 28px;
}

.curriculum-path-flow{
    display: grid;
    grid-template-columns: 1fr 30px 1.25fr 30px 1.2fr 30px 1.2fr 30px 1.45fr;
    align-items: center;
    gap: 14px;
}

.curriculum-path-item{
    display: grid;
    grid-template-columns: 42px 1fr;
    align-items: center;
    gap: 14px;
}

.curriculum-path-item i{
    width: 42px;
    height: 42px;
    border-radius: 50%;
    background: rgba(15,158,158,.10);
    color: #0f9e9e;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 22px;
}

.curriculum-path-item h4{
    font-size: 12.5px;
    font-weight: 800;
    line-height: 1.45;
    color: var(--color1);
    margin: 0;
}

.curriculum-path-arrow{
    text-align: center;
    color: var(--color1);
    font-size: 18px;
}

.curriculum-path-box p{
    text-align: center;
    font-size: 13px;
    font-weight: 800;
    color: var(--color1);
    margin: 26px 0 0;
}

/* EXCELLENCE */

.curriculum-excellence{
    position: relative;
}

.curriculum-excellence .curriculum-section-heading{
    margin-bottom: 26px;
}

.curriculum-excellence-grid{
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
}

.curriculum-excellence-item{
    text-align: center;
    padding: 0 34px;
    position: relative;
    transition: var(--transition);
}

.curriculum-excellence-item:not(:last-child)::after{
    content: '';
    position: absolute;
    right: 0;
    top: 42px;
    width: 1px;
    height: 96px;
    background: rgba(11,44,102,.14);
}

.curriculum-excellence-item:hover{
    transform: translateY(-8px);
}

.curriculum-excellence-icon{
    width: 74px;
    height: 74px;
    margin: 0 auto 18px;
    border-radius: 50%;
    background: rgba(15,158,158,.09);
    color: #0f9e9e;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 34px;
    box-shadow: 0 12px 28px rgba(11,44,102,.06);
}

.curriculum-excellence-item h4{
    font-size: 14px;
    font-weight: 800;
    color: var(--color1);
    margin-bottom: 9px;
}

.curriculum-excellence-item p{
    font-size: 12px;
    line-height: 1.7;
    color: var(--color5);
    margin: 0;
}

/* RESPONSIVE */

@media(max-width:1199px){

    .curriculum-path-flow{
        grid-template-columns: repeat(5, 1fr);
        gap: 18px;
    }

    .curriculum-path-arrow{
        display: none;
    }

    .curriculum-path-item{
        grid-template-columns: 1fr;
        text-align: center;
        justify-items: center;
    }

    .curriculum-excellence-grid{
        grid-template-columns: repeat(3, 1fr);
        gap: 28px 0;
    }

    .curriculum-excellence-item:nth-child(3)::after{
        display: none;
    }
}

@media(max-width:768px){

    .curriculum-path-section{
        padding: 52px 0 60px;
    }

    .curriculum-path-box{
        padding: 26px 20px;
        border-radius: 20px;
    }

    .curriculum-path-flow{
        grid-template-columns: 1fr;
    }

    .curriculum-path-item{
        padding: 18px;
        border-radius: 18px;
        background: rgba(255,255,255,.72);
        box-shadow: 0 10px 24px rgba(11,44,102,.05);
    }

    .curriculum-path-box p{
        font-size: 12px;
        line-height: 1.7;
    }

    .curriculum-excellence-grid{
        grid-template-columns: 1fr;
        gap: 18px;
    }

    .curriculum-excellence-item{
        padding: 24px 20px;
        background: rgba(255,255,255,.78);
        border-radius: 20px;
        box-shadow: 0 12px 28px rgba(11,44,102,.06);
    }

    .curriculum-excellence-item::after{
        display: none !important;
    }
}