/* loading start */
body{
    background:#f5f7f9
}
.loading-box{
    display: none;
    margin: 40px auto 0;
    font-size: 14px;
    color: #ddd;
    text-align: center;
}
.filter-loading-box{
    position: absolute;
    margin: 0 auto !important;
    padding-top: 3%;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: #fff;
    z-index: 10;
}
.top-loading{
    margin-top: 0 !important;
    padding-top: 30px
}
.loading {
    margin: 0 auto;
    width: 50px;
    height: 20px;
    text-align: center;
    font-size: 10px;
  }
   
  .loading > div {
    background-color: #eee;
    height: 100%;
    width: 3px;
    display: inline-block;  
    -webkit-animation: stretchdelay 1.2s infinite ease-in-out;
    animation: stretchdelay 1.2s infinite ease-in-out;
  }
   
  .loading .rect2 {
    -webkit-animation-delay: -1.1s;
    animation-delay: -1.1s;
  }
   
  .loading .rect3 {
    -webkit-animation-delay: -1.0s;
    animation-delay: -1.0s;
  }
   
  .loading .rect4 {
    -webkit-animation-delay: -0.9s;
    animation-delay: -0.9s;
  }
   
  .loading .rect5 {
    -webkit-animation-delay: -0.8s;
    animation-delay: -0.8s;
  }
   
  @-webkit-keyframes stretchdelay {
    0%, 40%, 100% { -webkit-transform: scaleY(0.4) } 
    20% { -webkit-transform: scaleY(1.0) }
  }
   
  @keyframes stretchdelay {
    0%, 40%, 100% {
      transform: scaleY(0.4);
      -webkit-transform: scaleY(0.4);
    }  20% {
      transform: scaleY(1.0);
      -webkit-transform: scaleY(1.0);
    }
  }
/* loading end */
/* add more start */
.add-more, .add-more:focus,.no-more,.no-more:focus{
    width: 95%;
    margin: 0 30px;
    padding: 16px 0;
    font-size: 16px;
    line-height: 1;
    color: #3a4d82;
    text-align: center;
    border: 1px solid #3a4d82;
    background: #fff;
    border-radius: 3px;
    overflow: hidden;
}
.add-more .btn-icon{
    display: inline-block;
    padding: 6px;
    margin-left: 5px;
    background: url(../images/public/btn-icon.png) no-repeat center center;
    background-size: contain 
}
.no-more,.no-more:focus{
    color: #ddd !important;
    border:none !important;
    padding: 0 !important;
    cursor: default !important
}
/* add more end */


.banner{
    text-align: center;
    background: url(../images/kfr-banner-bg.jpg) no-repeat center center
}
.disabled{
    color: #bbb !important;
    /* background: #d4d4d4 !important; */
    /* border-color:  #d4d4d4 !important; */
    cursor: default !important
}

.kfr-list-box{
    position: relative;
    min-height: 130px
}
.kfr-month,.kfr-list-box{
    padding: 30px 0;
    background: #fff;
}
.kfr-month{
    padding: 40px 0;
    margin-bottom: 20px
}
.kfr-list label{
    display: inline-block;
    font-weight: normal;
    margin-bottom: 0 !important
}
.kfr-list-brief{
    display: inline-block;
    height: 48px;
    line-height: 24px;
    overflow: hidden;
}
.kfr-list-brief label{
    color: #333
}
.address-icon i,.kfr-list-cnt i{
    padding: 2px 10px;
    background: url(../images/address-icon.png) no-repeat center center;
    margin-right: 5px;
}
.kfr-list-cnt i.time-icon{
    background: url(../images/kfr-time.png) no-repeat center center
}
.kfr-list-cnt i.area-icon{
    background: url(../images/kfr-area.png) no-repeat center center
}
.kfr-list-title i.book-icon{
    padding: 2px 12px;
    margin-right: 5px;
    background: url(../images/kfr-list-title.png) no-repeat center center
}

.kfr-month li{
    float: left;
    width: 90px;
    width: 88px \9;
    height: 36px;
    margin: 0 5px;
    font-size: 18px;
    line-height: 36px;
    color: #334d72;
    text-align: center;
    border-radius: 3px;
    cursor: pointer;
    border: 1px solid #334d72;
}
.kfr-month li.disabled{
    background: #d4d4d4 !important;
    border-color:  #d4d4d4 !important;
}
.kfr-month li.active{
    color: #fff;
    background-color: #b58e4b;
    border-color: #b58e4b;
    cursor: default !important
}


.empty-list{
    font-size: 16px;
    color: #666;
    text-align: center;
}
.empty-list p {
    padding: 2% 0
}
.kfr-list{
    display: flex;
    align-items: center;
    border-bottom: 1px solid #eee;
    padding-bottom: 30px;
    margin-bottom: 30px
}

.kfr-list-img,.kfr-list-cnt,.kfr-list-btn{
    float: left;
}
.kfr-list-img{
    width: 210px;
    text-align: center;
    margin-right: 20px;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
    overflow: hidden;
}
.kfr-list .kfr-list-title,.kfr-list .kfr-list-cnt > ul{
    margin-bottom: 15px
}
.kfr-list .kfr-list-title a{
    float: left;
    font-size: 22px;
    line-height: 30px;
    font-weight: bold;
    color: #333;
    margin-right: 10px;
}
.kfr-list .kfr-list-title .address-icon {
    height: 30px;
    line-height: 30px;
    font-size: 14px;
    color: #666;
}
.kfr-list-cnt{
    width: 64%;
    flex-basis: 845px;
    padding-right: 30px;
    border-right: 1px dashed #e2e2e2
}

.kfr-list-cnt > ul{
    padding-left: 10px;
    height: 36px;
    border-radius: 2px;
}
.kfr-list-cnt > ul > li select,.kfr-list-cnt > ul{
    height: 36px;
    line-height: 36px;
    font-size: 16px;
    color: #334d72;
    font-weight: bold;
    background-color: #f1f1f1;
    border: none !important
}
.kfr-list-cnt > ul > li label{
    float: left;
    font-weight: bold;
}
.kfr-list-cnt > ul > li .select-div{
    display: inline-block;
    width: 75%; 
}
.kfr-list-cnt > ul > li select{
    width: 100%;
    height: auto \9;
    padding-bottom:  5px \9;
    vertical-align: baseline;
    vertical-align: middle \9;
}
.kfr-list-cnt > ul > li {
    float: left;
    width: 50%;
    height: 36px;
    line-height: 36px;
}
.kfr-list-cnt > ul > li.kfr-area-li{
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
}

.kfr-list-btn{
    margin-top: 50px \9;
    margin-left: 30px;
    text-align: center;
}
.kfr-list-btn a{
    width: 170px;
    height: 40px;
    font-size: 16px;
    line-height: 40px;
    color: #fff;
    background-color: #334d72;
    display: inline-block;
    border-radius: 3px;
    -webkit-border-radius: 3px;
    -moz-border-radius: 3px;
    -ms-border-radius: 3px;
    -o-border-radius: 3px;
}
.kfr-list-btn a.overdue{
    background-color: #f1f1f1 !important;
    color: #666 !important
}
.kfr-list-btn a:hover{
    background-color: #b58e4b;
}

/* fake select start */
.select-ul{
    display: none;
    position: relative;
    padding: 0 !important;
    width: 100%;
    height: 36px;
    overflow: hidden;
    background: #fff;
    border: 1px solid #f1f1f1;
    z-index: 99;
}
.select-ul.open{
    display: block;
    height: auto;
    max-height: 182px;
    border: 1px solid #ddd;
    overflow-y: auto;
}
.select-ul > li{

    font-weight: normal;
    padding: 0 10px;
    color: #333
}
.select-ul > li.active{
    color: #b58e4b;
}
.select-ul > li.select-result{
    position: absolute;
    color: #334d72 !important;
    font-weight: bold !important;
    background-color: #f1f1f1 !important;
    z-index: 1;
    width: 100%;
    top: 0;
    left: 0;
}
.select-ul > li.selet-icon {
    position: absolute;
    display: block;
    width: 30px;
    height: 36px;
    background: url(../images/select-icon.png) no-repeat center center;
    top: 0;
    right: 0;
    z-index: 9;
}
.select-result-box{
    height: 36px;
    position: relative;
    cursor: pointer;
}
.select-result-box .select-result{
    position: absolute;
    color: #334d72 !important;
    font-weight: bold !important;
    background-color: #f1f1f1 !important;
    z-index: 1;
    width: 100%;
    top: 0;
    left: 0;
}
.select-result-box > .selet-icon{
    position: absolute;
    display: block;
    width: 30px;
    height: 36px;
    background: url(../images/select-icon.png) no-repeat center center;
    top: 0;
    right: 0;
    z-index: 9;
}
/* fake select end */


/* link start */
.link-box{
    background: #fff;
}
.link {
    padding-top: 2%;
}

.link .link-title {
    width: 100%;
    text-align: left;
    font-size: 24px;
    height: 26px;
    line-height: 24px;
    font-weight: bold;
    color: #222;
    margin: 0 auto 25px;
    position: relative;
    padding-left: 20px;
}

.link .link-title::before {
    position: absolute;
    display: block;
    content: '';
    left: 0;
    top: 0;
    background: #373c77;
    width: 6px;
    height: 26px;
    border-radius: 0 3px 3px 0;
}

.link .module-title {
    margin-bottom: 20px;
}

.link a {
    padding: 0 10px 10px;
    display: block;
    float: left;
    font-size: 14px;
    color: #666;
}

.link a:hover {
    color: #b49277;
}
  
/* link end */

@media only screen and (max-width:1200px){
    .container {
        width: 98%;
        margin: 0 auto;
    }
    .kfr-month, .kfr-list-box{
        padding: 2% 0
    }
    .kfr-month li{
        width: 14.66%;
        margin: 1%;
    }
    .kfr-list-img{
        width: 17%;
        flex-basis: 17%;
        margin-right: 2%
    }
    .kfr-list-cnt{
        width: 66%;
        flex-basis: 67%;
    }
    .kfr-list-btn a{
        width: 120px;
    }

    .add-more, .add-more:focus, .no-more, .no-more:focus{
        margin: 0 2.5%
    }
}

@media only screen and (max-width:1024px){
    
    .kfr-list{
        flex-wrap: wrap;
    }
    .kfr-list-cnt{
        width: 80%;
        flex-basis: 81%;
        border: none
    }
    .kfr-list-cnt > ul > li select, .kfr-list-cnt > ul{
        font-size: 14px
    }
    .kfr-list-btn{
        margin-left: 19%
    }
    .kfr-list-btn a{
        margin-top: 10px;
        height: 30px;
        line-height: 30px
    }
}
@media only screen and (max-width: 767px){

    .kfr-month li,.empty-list,.kfr-list-btn a{
      font-size: 14px
    }
    .kfr-month, .kfr-list-box{
        padding: 3% 0
    }
    .kfr-list .kfr-list-title, .kfr-list .kfr-list-cnt > ul{
        margin-bottom: 10px
    }
    .kfr-list-cnt > ul > li select,.kfr-list-cnt > ul li,.select-ul{
        height: 30px;
        line-height: 30px
    }
    .kfr-list-cnt > ul{
        height: 60px;
    }
    .kfr-list-cnt > ul li,.kfr-list-btn{
        width: 100%;
        margin: 0 auto;
    }
    .kfr-list{
        display: block;
        padding-bottom: 3%;
        margin-bottom: 3%
    }
    .kfr-list-cnt{
        width: 100%;
        /* flex-basis: 100%; */
        padding: 0;
    }
    .kfr-list .kfr-list-title h2{
        width: 100% !important;
    }
    .kfr-list .kfr-list-title a{
        font-size: 17px;
        width: 100%;
        margin: 0 auto;
        white-space: nowrap;
        overflow: hidden;
        text-overflow: ellipsis;
    }
    .kfr-list .kfr-list-title .address-icon{
       display: none !important
    }
    .kfr-list-cnt > ul > li label{
        width: 67px;
    }
    .kfr-list-cnt > ul > li .select-div{
        width: calc(100% - 67px); 
    }
    .kfr-list-brief{
        height: auto;
    }
    
    .kfr-list-img{
        display: none
    }

    .empty-list img{
        max-width: 120px;
    }
    .add-more, .add-more:focus, .no-more, .no-more:focus{
        line-height: 1.4;
        padding: 1.5% 0;
    }
}
@media only screen and (max-width: 425px){
    .kfr-list{
        padding-bottom: 5%;
        margin-bottom: 5%
    }
    .kfr-month li{
        width: 23%;
        height: 28px;
        line-height: 28px;
    }
    .kfr-month, .kfr-list-box{
        padding: 4% 0
    }
    .kfr-list-img{
        margin: 0 auto 5%
    }
    /* .kfr-list-img,.kfr-list-cnt,.kfr-list-btn{
        width: 100%;
        flex-basis: 100%;
    } */
    .kfr-list-cnt{
        padding: 0 2%;
    }
    .kfr-list-btn{
        margin: 0 auto;
    }

    .add-more, .add-more:focus, .no-more, .no-more:focus{
        font-size: 14px;
    } 
}