@charset "utf-8";
/**
 * Created by sunJia on 2025/12/23.
 * @Description: Index Style
 */

.banner{position: relative;}
.banner::before{ content: '';display: block;width: 100%;height: 0;padding-bottom: 10.41%;
    background: linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
    background: -webkit-linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
    background: -moz-linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
    background: -ms-linear-gradient(to bottom, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.6) 100%);
    position: absolute;left: 0;bottom: 0;z-index: 2;
}
.banner a{display:block;position:relative;}
.banner .gp-img{padding-bottom: 29.17%;position: relative;background-repeat: no-repeat;background-size: cover;background-position: center;}
.banner .gp-img::before{content: '';display: none;opacity: 1;height: 100%;position: absolute;left: 0;right: 0;bottom: 0;z-index: 2;
	background: rgba(32, 36, 45, 0.25);pointer-events: none;
}
.banner .gp-img video,.banner .gp-img img{width:100%;height: 100%;position: absolute;left: 0;top: 0;object-fit: cover;}
.banner .gp-img video{width:100%;height: auto;position: absolute;left: 0;top: 50%;transform: translateY(-50%);}

.wrapbanner{overflow: hidden;position: relative;box-sizing: border-box;z-index: 2;flex: 1; min-width: 0;
    flex-direction: row-reverse;align-items: flex-start;}

.banner-func-area{ position: relative;}
.banner .swiper-pagination{font-size: 0;text-align: right;left: 0;bottom: .95rem;width: auto;}
.banner .swiper-pagination .swiper-pagination-bullet{width: .3rem;height: .1rem;opacity: 1;color: #fff;
    border: 1px solid rgba(255,255,255,0.6); background: rgba(255,255,255,0.3); margin-right: .2rem;
	border-radius: .05rem; position: relative;transition: all 0.3s ease-in-out;vertical-align: bottom;}
.banner .swiper-pagination .swiper-pagination-bullet:last-child{ margin-right: 0;}
.banner .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active{ width: .4rem; background: #fff; border-color: #fff;}
.banner-arrow{ position: absolute; right: 0; bottom: .7rem;z-index: 1;}
.banner-arrow .swiper-arrow{ width: .6rem; height: .6rem; }
.banner-arrow .swiper-arrow:hover{ animation: beat 0.7s 1;}
.banner-arrow .swiper-prev{ background: url(../images/banner-prev.png) no-repeat center/cover; margin-right: .1rem;}
.banner-arrow .swiper-next{ background: url(../images/banner-next.png) no-repeat center/cover;}
.banner .gp-position{ position: relative; z-index: 3;}
@-webkit-keyframes beat {
    from, to {
        -webkit-transform: scale(1, 1);
        transform: scale(1, 1);
    }
    25% {
        -webkit-transform: scale(0.9, 1.1);
        transform: scale(0.9, 1.1);
    }
    50% {
        -webkit-transform: scale(1.1, 0.9);
        transform: scale(1.1, 0.9);
    }
    75% {
        -webkit-transform: scale(0.95, 1.05);
        transform: scale(0.95, 1.05);
    }

    from, to {
        -webkit-transform: scale(1, 1);
        transform: scale(1, 1);
    }
    25% {
        -webkit-transform: scale(0.9, 1.1);
        transform: scale(0.9, 1.1);
    }
    50% {
        -webkit-transform: scale(1.1, 0.9);
        transform: scale(1.1, 0.9);
    }
    75% {
        -webkit-transform: scale(0.95, 1.05);
        transform: scale(0.95, 1.05);
    }
}

.modeTil{ position: relative; padding-bottom: .3rem;border-bottom: .01rem solid rgba(0, 0, 0, 0.1); box-sizing: border-box;}
.modeTil.gp-flex{ align-items: flex-end;}
.modeTil .modeTitle{ display: inline-block; color: #333; line-height: 1; padding: .24rem .22rem 0; padding-right: 0;
    background: url(../images/building-red.png) no-repeat center top; background-size: auto .4rem; position: relative;z-index: 1;}
.modeTil .modeTitle::before{
    content: '';display: block;width: .06rem;height: .24rem; border-radius: .03rem;background: #94070A;
    position: absolute; left: 0;bottom: 0;
}
.modeMore{ color: #94070A; width: 1.12rem; line-height: 0.4rem; text-align: center;border-radius: .2rem;
    border: 1px solid rgba(148, 7, 10, 0.3);}
.modeMore i{ font-size: 0; margin-left: 0.1rem;}
.modeMore:hover{ transition: all 0.3s ease-in-out; border-color: rgba(148, 7, 10, 0.6);}
.modeMore:hover i{ transition: all 0.3s ease-in-out; transform: rotateZ(90deg);}

.indexContent{
    position: relative;
    z-index: 2;
}
.row01{
    padding-bottom: .8rem;
}
.row01 .modeCon{
    margin-top: -.5rem;
    background: #fff;
    border-radius: .5rem;
    box-shadow: 0px 0px 50px rgba(0, 0, 0, 0.1);
}
.row01 ul{
    margin: 0 -.2rem;
    padding: .5rem;
    justify-content: flex-start;
}
.row01 li{}
.row01 dl{
    margin: 0 .2rem;
    background: #FFECD6;
    border-radius: .3rem;
    border: .02rem solid #FFE2C0;
    padding: .4rem .4rem 1.17rem;
    position: relative;
    height: 100%;
}
.row01 dl:hover .icon{
    animation: beat 0.7s 1;
}
@-webkit-keyframes beat {
    from, to {
        -webkit-transform: scale(1, 1);
        transform: scale(1, 1);
    }
    25% {
        -webkit-transform: scale(0.9, 1.1);
        transform: scale(0.9, 1.1);
    }
    50% {
        -webkit-transform: scale(1.1, 0.9);
        transform: scale(1.1, 0.9);
    }
    75% {
        -webkit-transform: scale(0.95, 1.05);
        transform: scale(0.95, 1.05);
    }

    from, to {
        -webkit-transform: scale(1, 1);
        transform: scale(1, 1);
    }
    25% {
        -webkit-transform: scale(0.9, 1.1);
        transform: scale(0.9, 1.1);
    }
    50% {
        -webkit-transform: scale(1.1, 0.9);
        transform: scale(1.1, 0.9);
    }
    75% {
        -webkit-transform: scale(0.95, 1.05);
        transform: scale(0.95, 1.05);
    }
}
.row01 dl::before{
    content: '';
    display: block;
    width: calc(100% + .04rem);
    height: calc(100% + .04rem);
    background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.8) 100%);
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 0;
}
.row01 li:nth-of-type(2) dl{
    background: #CEFBF6;
    border-color: #9AF4EA;
}
.row01 li:nth-of-type(3) dl{
    background: #CFEFFF;
    border-color: #A0DFFF;
}
.row01 li:nth-of-type(4) dl{
    background: #F1EFFF;
    border-color: #E0DBFF;
}
.row01 dt{
    position: relative;
    z-index: 2;
    line-height: .3rem;
    margin-bottom: .4rem;
}
.row01 dd{
    position: relative;
    z-index: 2;
    margin-bottom: .2rem;
    transition: all .25s ease-in-out;
}
.row01 dd:last-child{
    margin-bottom: 0;
}
.row01 dd:hover{
    transform: translateX(.05rem);
}
.row01 dd a{
    justify-content: flex-start;
    align-items: center;
}
.row01 dd a:hover{
    color: #333;
}
.row01 dd i{
    font-size: 0;
    flex-shrink: 0;
    margin-right: .1rem;
}
.row01 dl .icon{
    position: absolute;
    right: 0.2rem;
    bottom: 0.2rem;
    width: 1rem;
}
.row01 li:nth-of-type(3) .icon{
    width: 1.22rem;
}
.modeCon{
    margin-top: .2rem;
}

/* row02 */
.row02{
    padding: .6rem 0;
    background: url(../images/row02-bg.jpg) no-repeat center/cover;
    overflow-x: clip;
}
.row02 .lf{
    width: 55.33%;
}
.row02 .lf ul{}
.row02 .lf li{
    margin-top: .28rem;
}
.row02 .lf li:first-child{
    margin-top: 0rem;
}
.row02 .lf li a{
    display: block;
    padding: .3rem;
    border-radius: .2rem;
    background: #fff;
}
.row02 .lf .date{
    justify-content: flex-start;
    align-items: center;
    line-height: 1.25;
    margin-top: .18rem;
}
.row02 .lf .day{
    position: relative;
    z-index: 1;
    padding-right: .1rem;
    margin-right: .1rem;
}
.row02 .lf .day::before{
    content: '';
    display: block;
    width: .01rem;
    height: .14rem;
    background: rgba(0, 0, 0, 0.1);
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    z-index: -1;
}
.row02 .lf .title{
    position: relative;
    line-height: 1.28;
    padding-left: .22rem;
}
.row02 .lf .title::before{
    content: '';
    display: block;
    width: .12rem;
    height: .04rem;
    border-radius: .02rem;
    background: #94070A;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.row02 .lf li a:hover{
    background: #94070A;
}
.row02 .lf a:hover .title{
    color: #fff;
}
.row02 .lf a:hover .title::before{
    background: #FFAC41;
}
.row02 a:hover .date{
    color: rgba(255,255,255,0.6);
}
.row02 a:hover .day::before{
    background: rgba(255,255,255,0.2);
}
.row02 .rt{
    width: 41.33%;
}
.row02 .rt .modeCon{
    position: relative;
    z-index: 1;
    border-radius: .3rem;
    background: #fff;
    padding: .28rem .3rem .48rem;
    box-shadow: 1px 4px 4px rgba(0, 0, 0, 0.1);
}
.row02 .rt .modeCon::after,
.row02 .rt .modeCon::before{
    content: '';
    display: block;
    width: calc(100% - .04rem);
    height: calc(100% - .04rem);
    background: #fff;
    box-shadow: 1px 4px 4px rgba(0, 0, 0, 0.1);
    border-radius: .3rem;
    position: absolute;
    top: 0rem;
    left: 0rem;
    z-index: -2;
}
.row02 .rt .modeCon::before{
    width: calc(100% - .08rem);
    height: calc(100% - .08rem);
    z-index: -1;
}
.calendarTil{
    position: relative;
    z-index: 1;
    justify-content: center;
}
.calendarTil::before,
.calendarTil::after{
    content: '';
    display: block;
    width: .26rem;
    height: .25rem;
    background: url(../images/calendar-dot.png) no-repeat center/cover;
    position: absolute;
    left: 0.2rem;
    top: 50%;
    transform: translateY(-50%);
}
.calendarTil::after{
    left: auto;
    right: .2rem;
}
.prevMonth{
    margin-right: .3rem;
    font-size: 0;
    cursor: pointer;
}
.nextMonth{
    margin-left: .3rem;
    font-size: 0;
    cursor: pointer;
}
.curMonth{
    font-size: 0;
    color: #94070A;
    align-items: center;
}
.curMonth i{
    margin-right: .1rem;
    font-size: 0;
}
.calendarSwiperOut{
    display: none;
}
.on + .calendarSwiperOut{
    display: block;
    border-top: .22rem solid transparent;
    position: absolute;
    width: 3rem;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    z-index: 10;
    text-align: left;
}
.calendarSwiper{
    overflow: hidden;
    background: #94070A;
    padding: .2rem .3rem;
    border-radius: .1rem;
}
.calendarSwiper .swiper-slide{
    
}
.calendarSwiper .swiper-slide a{
    color: #fff;
    line-height: 1.25;
}
.calendarSwiper .swiper-slide .title{
    color: #fff;
    line-height: 1.28;
    padding-left: .14rem;
    position: relative;

}
.calendarSwiper .swiper-slide .title::before{
    content: '';
    display: block;
    width: .04rem;
    height: .16rem;
    border-radius: .02rem;
    background: #FFAC41;
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
}
.calendarSwiper .swiper-slide .info{
    color: rgba(255,255,255,0.8);
}
.calendarSwiper .swiper-slide .time{
    margin-top: .1rem;
}
.calendarSwiper .swiper-slide .addr{
    margin-top: .1rem;
}
.calendar-pagination{
    margin-top: .2rem;
    font-size: 0;
    text-align: center;
}
.calendar-pagination .swiper-pagination-bullet{
    width: .1rem;
    height: .06rem;
    border: 1px solid rgba(255,255,255,0.6);
    background: rgba(255,255,255,0.3);
    border-radius: .03rem;
    margin: 0 .05rem !important;
    opacity: 1;
}
.calendar-pagination .swiper-pagination-bullet-active{
    width: .2rem;
    background: #fff;
    border-color: #fff;
}

/* row03 */
.row03{
    padding: .8rem 0 1.75rem;
}
.row03 .modeCon{
    margin-top: .8rem;
}
.row03 ul{
    margin: 0 -.2rem;
}
.row03 li{}
.row03 li a{
    display: block;
    background: rgba(148, 7, 10, .04);
    line-height: .6rem;
    margin: 0 .2rem;
    border-radius: .3rem;
}
.row03 li .gp-flex{
    justify-content: center;
    align-items: center;
    padding: 0 .1rem;
}
.row03 li i{
    width: .3rem;
    height: .3rem;
    flex-shrink: 0;
    background: url(../images/link-icon.png) no-repeat center/cover;
    margin-right: .1rem;
}
.row03 li .title{
    min-width: 0;
}
.row03 li a:hover{
    background: #94070A;
}
.row03 li a:hover .title{
    color: #fff;
    
}
.row03 a:hover i{
    background: url(../images/link-icon-hover.png) no-repeat center/cover;
}






/* Responsive style */
@media screen and (max-width:1600px){
    
}

@media screen and (max-width:1280px){
    .row01 dl{
        padding: 0.3rem 0.3rem 1.17rem;
    }
}

@media screen and (max-width:996px){
    .banner-arrow{
        bottom: .45rem;
    }
    .banner-arrow .swiper-arrow{
        width: .45rem;
        height: .45rem;
    }
    .banner .swiper-pagination{
        bottom: .65rem;
    }
    .banner .swiper-pagination .swiper-pagination-bullet{
        margin-right: .15rem;
    }
    .row01{
        padding-bottom: .5rem;
    }
    .row01 .modeCon{
        margin-top: -.3rem;
        border-radius: .3rem;
    }
    .row01 ul{
        padding: .3rem;
        margin: 0 -.1rem;
        flex-wrap: wrap;
    }
    .row01 li{
        width: 50%;
        margin-top: .3rem;
    }
    .row01 li:nth-of-type(1),
    .row01 li:nth-of-type(2){
        margin-top: 0;
    }
    .row01 dl{
        margin: 0 .1rem;
        padding: 0.2rem 0.2rem 1rem;
    }
    .row01 dl .icon{
        width: .8rem;
    }
    .row01 li:nth-of-type(3) .icon{
        width: 1rem;
    }
    .row01 dt{
        margin-bottom: .2rem;
    }
    .row01 dd{
        margin-bottom: .15rem;
    }
    .row01 dd i{
        width: .25rem;
    }
    .modeTil{
        padding-bottom: .2rem;
    }
    .row02{
        padding: .4rem 0;
    }
    .row02 > .gp-flex{
        flex-direction: column;
    }
    .row02 .lf,
    .row02 .rt{
        width: 100%;
    }
    .row02 .rt{
        margin-top: .4rem;
    }
    .pc_academic_calendar_wrap ul{
        margin-top: .15rem;
    }
    .pc_academic_calendar_wrap dl dd{
        margin-top: .2rem;
    }
    .row02 .lf li a{
        padding: .25rem .2rem;
    }
    .row02 .rt .modeCon{
        padding: .2rem .3rem .45rem;
    }
    .row03{
        padding: .4rem 0 1.2rem;
    }
    .row03 .modeCon{
        margin-top: .2rem;
    }
    .row03 li{
        margin-top: .3rem;
    }
}

@media screen and (max-width:768px){
    .row03 .modeCon{
        margin-top: 0;
    }
    .row03 ul{
        margin: 0 -.1rem;
    }
    .row03 li a{
        margin: 0 .1rem;
    }
    .row03 li i{
        width: .25rem;
        height: .25rem;
    }
}

@media screen and (max-width:680px){
    
}

@media screen and (max-width:491px){
    .banner .swiper-pagination{
        bottom: .15rem;
        width: 100%;
        text-align: center;
    }
    .banner .swiper-pagination .swiper-pagination-bullet{
        width: .25rem;
        margin: 0 .05rem;
    }
    .banner .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet-active{
        width: .3rem;
    }
    .banner .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet::before{
        height: calc(100% - 0.25rem);
    }
    .banner-arrow{
        display: none;
    }
    .banner .gp-img{
        padding-bottom: 1.8rem;
    }
    .row01{
        padding: .3rem 0;
    }
    .row01 .modeCon{
        margin-top: 0;
    }
    .row01 ul{
        padding: .2rem;
    }
    .row01 li{
        width: 100%;
        margin-top: .2rem;
    }
    .row01 li:nth-of-type(2){
        margin-top: .2rem;
    }
    .row01 dl{
        padding: .15rem .2rem .8rem;
    }
    .row01 dt{
        margin-bottom: .1rem;
    }
    .row01 dd i{
        margin-right: .05rem;
    }
    .row02{
        padding: .3rem 0;
    }
    .row02 .lf li{
        margin-top: .2rem;
    }
    .row02 .rt{
        margin-top: .3rem;
    }
    dd:nth-of-type(7n + 1) .on + .calendarSwiperOut{
        transform: translateX(-0.2rem);
    }
    dd:nth-of-type(7n + 2) .on + .calendarSwiperOut{
        transform: translateX(-0.2rem);
    }
    dd:nth-of-type(7n + 6) .on + .calendarSwiperOut{
        transform: translateX(-90%);
    }
    dd:nth-of-type(7n + 7) .on + .calendarSwiperOut{
        transform: translateX(-90%);
    }
    .row03 li{
        width: 50%;
    }
    .calendarTil::before, .calendarTil::after{
        width: .2rem;
        height: .2rem;
        left: 0;
    }
    .calendarTil::after{
        left: auto;
        right: 0;
    }
    .pc_academic_calendar_wrap ul li span{
        line-height: .45rem;
    }
    .pc_academic_calendar_wrap dl dd{
        margin-top: .15rem;
    }
    .row02 .rt .modeCon{
        padding: .2rem .25rem .4rem;
    }
    .row03 li{
        margin-top: .2rem;
    }
    
    
}

@media screen and (max-width:414px){
    .banner .swiper-pagination{
        bottom: 0.1rem;
    }
    .banner .swiper-pagination .swiper-pagination-bullet.swiper-pagination-bullet::before{
        display: none;
    }
    .banner .gp-img{
        padding-bottom: 1.4rem;
    }
    .row01 ul{
        padding: .15rem;
    }
    .row01 dl{
        padding: .15rem .15rem .7rem;
    }
    .row02 .lf li a{
        padding: .2rem;
    }
    .row02 .lf .date{
        margin-top: .1rem;
    }
    .row03 li{
        width: 100%;
    }
    .on + .calendarSwiperOut{
        width: 2.4rem;
        border-top-width: .15rem;
    }
    .calendarSwiper{
        padding: .15rem;
    }
    .calendar-pagination{
        margin-top: .1rem;
    }
    .row03 li a{
        line-height: .45rem;
    }
    .prevMonth{
        margin-right: .15rem;
    }
    .nextMonth{
        margin-left: .15rem;
    }
    .curMonth i{
        width: .2rem;
    }
    .row01 dl .icon{
        width: .6rem;
    }
    .row01 li:nth-of-type(3) .icon{
        width: .8rem;
    }
    
}

@media screen and (max-width:370px){
    .row02 .rt .modeCon{
        padding: .15rem 0.15rem .3rem;
    }
    .pc_academic_calendar_wrap dl{
        margin-left: -0.1rem;
        margin-right: -0.1rem;
    }
    .on + .calendarSwiperOut{
        width: 2.2rem;
    }
    .pc_academic_calendar_wrap dl dd{
        margin-top: .1rem;
    }
    
}
