body.is-mainland-page footer {
    background: #192043 !important;
    margin-top: 100px !important;
}

body.is-mainland-page footer a {
    color: #fff;
}

.region.region-footer-mainland {
    display: flex;
    flex-direction: row;
    align-items: center;
    flex-wrap: wrap;
}

footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;

    height: 100%;
    align-items: center;
    margin: 0 20px 0 0;
}

footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li {
    list-style: none;

    display: flex;
    flex-direction: row;
    justify-items: flex-end;
    align-items: center;
    padding-top: 0;
}

footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li > a,
footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li > span {
    padding: 0px 20px;
    color: #fff;
    white-space: nowrap;
}

footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li > span {
    cursor: default;
}

/* Home icon: first footer nav item — hide text, show icon */
footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li:first-child > a {
    font-size: 0;
    color: transparent;
    display: inline-flex;
    align-items: center;
}

footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li:first-child > a::before {
    content: '';
    display: inline-block;
    width: 22px;
    height: 20px;
    background-image: url('../image/icon/home.svg');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    filter: brightness(0) invert(1);
}

footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li > .menu_link_content {
    display: none;
}

/* Dim non-hovered/non-active siblings to 50% opacity */
footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li {
    transition: opacity 0.2s ease;
}

footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0:has(> li:hover) > li:not(:hover),
footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0:has(> li.is-active) > li:not(.is-active) {
    opacity: 0.5;
}

/* =====================================================
   #block-applynowfooter-mainland — "Apply Now" footer button
   Consolidated from: custom.css
   ===================================================== */

#block-applynowfooter-mainland {
    flex-grow: 1;
}

/* Reset button to a transparent wrapper so the inner <a> is the full click target */
#block-applynowfooter-mainland button.apply-now-btn {
    background: none;
    border: none;
    padding: 0;
    width: 224px;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* All visual styles live on the <a>, which fills the entire button area */
#block-applynowfooter-mainland button.apply-now-btn a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    background: linear-gradient(90deg, #DF7433 0%, #DA562B 31.87%, #CC103C 73.65%, #9F0D43 100%);
    border-radius: 100px;
    color: #fff;
    font-size: 18px;
    line-height: 22px;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
    padding: 14px;
}

#block-applynowfooter-mainland button.apply-now-btn a:hover {
    background: #9F0D43;
    color: #fff;
    text-decoration: none;
}

#block-applynowfooter-mainland button.apply-now-btn a::after {
    background: url(../image/icon/apply-btn-after-arrow.svg) center center no-repeat;
    content: '';
    display: inline-block;
    width: 8px;
    height: 12px;
    margin-left: 10px;
}

@media (max-width: 1399.98px) {
    footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li > a,
    footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li > span {
        padding: 0px 10px;
    }
}

@media (max-width: 1199.98px) {
    .region.region-footer-mainland {
        flex-wrap: wrap;
        margin-bottom: 50px;
    }
    footer nav#block-admission-theme-mainnavigationmainland {
        flex-basis: 100%;
    }
    footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 {
        margin-top: 40px;
        flex-direction: column;
        align-items: flex-start;
    }
    footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 li {
        font-size: 18px;
        line-height: 22px;
        margin-bottom: 20px;
        padding: 0;
    }
    footer nav#block-admission-theme-mainnavigationmainland ul.menu.menu-level-0 > li:first-child > a::before {
        width: 26px;
        height: 24px;
    }
    #block-socialiconsmainland-footer {
        padding: 16px 0 0 4px;
    }
}

@media (max-width: 767.98px) {
    #block-applynowfooter-mainland {
        flex: 1 1 auto;
    }
    #block-applynowfooter-mainland button.apply-now-btn {
        max-width: none;
        width: 100%;
    }
}


/* Social Media Icons */
body.is-mainland-page footer .social-media {
    width: unset;
    gap: 20px;
}

#block-socialiconsmainland-footer .social-media-icons {
    display: flex;
    flex-direction: row;
    align-items: center;
    list-style: none;
    margin: 0;
    padding: 0;
    gap: 16px;
    height: 30px;
}

#block-socialiconsmainland-footer .social-media-icons li {
    list-style: none;
    height: 30px;
}

#block-socialiconsmainland-footer .social-media-icons a {
    display: inline-flex;
    align-items: center;
    transition: opacity 0.15s ease;
}

#block-socialiconsmainland-footer .social-media-icons a:hover {
    opacity: 1;
}

/* Icon spans — white variants declared in CSS, not in block HTML */
#block-socialiconsmainland-footer .social-media-icons .social-icon {
    display: block;
    width: 30px;
    height: 30px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
}

/* rednote has no white SVG variant — invert the standard icon */
#block-socialiconsmainland-footer .social-media-icons .social-icon--rednote {
    background-image: url('../image/icon/rednote-white.svg');
}

#block-socialiconsmainland-footer .social-media-icons .social-icon--weibo {
    background-image: url('../image/icon/weibo-new-white.svg');
}

#block-socialiconsmainland-footer .social-media-icons .social-icon--wechat {
    background-image: url('../image/icon/wechat-white.svg');
}

#block-socialiconsmainland-footer .social-media-icons .social-icon--bilibili {
    background-image: url('../image/icon/bilibili-white.svg');
}

@media (max-width: 767.98px) {
    body.is-mainland-page footer #block-admission-theme-socialmediafootermainland {
        padding: 16px 10px;
    }
}

/* Back to top — mainland page */
body.is-mainland-page #block-backtotop {
    width: 50px;
    height: 50px;
    border-radius: 50%;
    border: solid 1px #EEEEEE;
    background: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    overflow: hidden;
}

body.is-mainland-page #block-backtotop > * {
    display: none;
}

body.is-mainland-page #block-backtotop::before {
    content: '';
    display: block;
    width: 20px;
    height: 12px;
    background-image: url('../image/icon/arrow-up-gradient.svg');
    background-repeat: no-repeat;
    background-size: contain;
    background-position: center;
    flex-shrink: 0;
}

body.is-mainland-page #block-backtotop:hover {
}

/* Footer end */
#block-admission-theme-footer-end-content-mainland {
    order: 200;
    flex-basis: 100%;
    margin-top: 100px;
}

#block-admission-theme-footer-end-content-mainland section {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    min-height: 90px;
}

#block-admission-theme-footer-end-content-mainland p {
    color: #fff;
    margin-bottom: 10px;
}

/* Utility links row inside the footer-end block */
.mainland-footer-utility-links {
    margin-bottom: 20px;
}

.mainland-footer-utility-links .mainland-utility-bar__links {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 4px 0;
}

.mainland-footer-utility-links .mainland-utility-bar__link {
    color: #fff !important;
    -webkit-text-fill-color: #fff !important;
}

.mainland-footer-utility-links .mainland-utility-bar__link:hover {
    background: linear-gradient(90deg, #DF7433 2.14%, #DA562B 58.13%, #CC103C 100%);
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent !important;
}

@media (max-width: 575.98px) {
    /* Social icons — break to their own row */
    #block-socialiconsmainland-footer {
        flex-basis: 100%;
    }

    /* Logo — break to its own row below the copyright/links text */
    #block-admission-theme-footer-end-content-mainland section {
        flex-direction: column;
        align-items: flex-start;
        gap: 20px;
    }
}