/* ------------------------------------------------------------ *\
    Datatable
\* ------------------------------------------------------------ */
.datatable{
    border-collapse: collapse;
    width: 100%;
    display: table !important;
    position: relative;
}

.table-body{ display: table-row-group; }
.table-head{ display: table-header-group;}

.table-row,
.table-row.small-row,
.table-row-medium {
    display: table-row;
}

.table-cell,
.table-cell-medium {
    position: relative;
    display: table-cell;
    vertical-align: top;
}

.table-row.small-row .table-cell {
    min-width: 34px;
}

.table-cell, .table-cell-medium {
    min-width: 44px;
}


.table-cell-40 {
    width: 40px;
}
.table-cell-60 {
    width: 60px;
}
.table-cell-s {
    width: 100px;
}
.table-cell-xs {
    width: 5px;
    min-width:5px;
}
.table-cell.form-label {
    min-width: 100% !important;
    padding-right: 10px !important;
}
.table-cell.form-label label {
    padding-right: 0;
    text-align: right;
}


.table-colspan{
    position: absolute;
    width: 95%;
}

.table-head .table-cell {
    padding: 0 15px 0 0;
}

.table-head .table-cell:first-child {
    padding: 0 15px 0 15px;
}

.table-head .table-cell.stretch-center > a {
    display: block;
    width: 100%;
    text-align: center;
}

.table-head.margin .table-row {
    border-bottom:solid 10px #fff;
}

.table-body .table-cell {
    padding: 20px 15px 15px 0;
}

.table-body .table-cell:first-child {
    padding: 20px 5px 15px 15px;
}

.table-body .table-row.small-row .table-cell {
    padding: 15px 15px 12px 0;
}
.table-body .table-row.small-row .table-cell.label-form {

}

.table-body .table-row.tight-row .table-cell {
    padding: 12px 15px 0 0;
}

.table-body .table-row.small-row.checkbox-row .table-cell {
    padding: 18px 15px 3px 0;
}

.table-body .table-row.small-row.checkbox-row .checkbox-wrapper {
    margin-top: 0;
}

.table-body .table-row.small-row.checkbox-row .table-canton-icon {
    margin-top: -2px;
}

.table-body .table-row.small-row .table-cell:first-child {
    padding: 15px 15px 12px 10px;
}
.table-body .table-row.tight-row .table-cell:first-child {
    padding: 12px 15px 0px 10px;
}

.table-body .table-cell-medium {
    padding: 5px 15px 5px 0;
}

.table-body .table-cell-medium:first-child {
    padding: 5px 15px 5px 5px;
}

.table-head .table-row {
    background-color: #f2f2f2;
}

.table-body .table-row,
.table-body .table-row.small-row,
.table-body .table-row-medium {
    border-bottom: 1px solid #e5e5e5;
    height: 79px;
}

.table-body .table-row:hover,
.table-body .table-row.small-row:hover,
.table-body .table-row-medium:hover {
    background: #fafafa;
}

.table-body .table-row.tight-row {
    height: 44px;
}

.table-body .table-row.small-row {
    height: 55px;
}

.table-body .table-row-medium {
    height: 55px;
}

.datatable-tools-holder {
    display: none;
    position: absolute;
    right: 0;
    min-width: 260px;
    z-index: 5;
    margin: 19px 10px 0 0;
    -webkit-border-top: 1px solid #e5e5e5;
    text-align: right;
}
.datatable-tools-holder > div {
    text-align: right;
}
.datatable-tools-holder button,
.datatable-tools-holder .button {
    margin-left: 10px;
    text-align: center;
}
.table-row.small-row .datatable-tools-holder {
    margin-top: 8px;
}

.table-head .table-row:hover {
    background-color: #fafafa;
}
.table-head .table-row .table-cell-40 {
    text-align: center;
}
.table-head .table-row .table-cell-40.style-right {
    text-align: right;
}
.table-head a, .table-head p {
    display: inline-block;
    font-size: 13px;
    color: #222222;
    padding: 8px 0;
}
/*.table-body a {
    color: #3570db;
}
.table-body a:hover {
    text-decoration: underline;
}*/

#main-section .table-body p,
#main-section .table-body p,
#main-section .table-body p {
    font-size: 15px;
    line-height: 18px;
    color: #222222;
    margin-bottom: 0 !important;
}


#main-section .table-body p + p,
#main-section .table-body p + p,
#main-section .table-body p + p {
    font-size: 13px;
    line-height: 20px;
    color: #999999;
}

#main-section .table-body .table-colspan > p {
    color: #999999;
}

/*.table-body .table-row.single-row p {
    line-height: 30px;
}*/

/* icons */
#main-section .table-body p.icon-medium {
    font-size: 15px;
    line-height: 18px;
    text-align: center;
    color: #a3b1bf;
    cursor: help;
}
#main-section .table-body p.icon-large {
    font-size: 24px;
    line-height: 20px;
    text-align: center;
    color: #a3b1bf;
    cursor: help;
}
#main-section .table-body p[class^="icon-badge"] {
    font-size: 24px !important;
    line-height: 35px !important;
    text-align: center;
    color: inherit;
}

#main-section .table-body [class^="icon-bullet"]:before {
    font-size: 18px;
}
#main-section .table-body p.icon-ok {
    color: #77cc66;
}

.table-body.simple {

}
.table-head.simple .table-row {
    background-color: #a3b1bf;
}
.table-head.simple a, .table-head.simple p {
    color: #ffffff;
}
.table-body.simple .table-row {
    height: auto;
    border-bottom: 0;
}
.table-body.simple .table-row:nth-child(2n){
    background-color: #f0f0f0;
}
.table-body.simple .table-row.small-row .table-cell {
    padding: 10px 15px 10px 0px;
}
.table-body.simple .table-row.small-row .table-cell:first-child {
    padding: 10px 15px 10px 15px;
}

@media screen and (-webkit-min-device-pixel-ratio:0) {

    .placeholder-cell{
        display: table-cell;
        vertical-align: top;
        width: 1px;
    }

}

.table-body .table-row:hover .datatable-tools-holder,
.table-body .table-row.small-row:hover .datatable-tools-holder {
    display: block;
}

.partner-icon-cell{ max-width: 32px; }
.progress-bar-cell{ max-width: 125px; }


.progress-bar{
    height: 5px;
    width: 100%;
    position: relative;
    margin: 10px 0 5px 0;
}

.progress-bar-inner{
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
}

#show-more-button-holder {
    text-align: center;
    padding: 20px 0;
}

@media (max-width: 768px) {
    .has-mobile-list .datatable .table-cell {
        display: none;
    }

    .datatable .table-cell.mobile-list {
        display: table-cell;
    }
}