.d4-dual-list-checkbox {
    .selected-hidden {
        display: none;
    }

    .checkbox-group .checkbox-normal {
        display: none;
    }

    .checkbox-group {
        position: relative;
        display: flex;
        justify-content: space-between;
        width: calc(100% - 2px);
    }

    .checkbox-group label {
        display: inline-block;
        position: relative;
        padding-left: 25px;
        cursor: pointer;
    }

    .checkbox-group + .checkbox-group label {
        margin-left: 15px;
    }

    .clearfix:before, .clearfix:after {
        content: "";
        display: table;
    }

    .radio-group label:before {
        content: "";
        display: inline-block;
        width: 16px;
        height: 16px;
        position: absolute;
        top: 3px;
        left: 0px;
        background: #fcfcfc;
        border: 1px solid #bbb;
    }

    .radio-group .radio-normal + label:before {
        -webkit-border-radius: 10px;
        -moz-border-radius: 10px;
        border-radius: 10px;
    }

    .radio-group .radio-normal:hover + label:before {
        border-color: #197DD5;
    }

    .radio-group .radio-normal:checked + label:before {
        content: "\e6bf";
        font-family: "Font Awesome 6 Pro";
        color: #fff;
        font-size: 14px;
        line-height: 15px;
        border-color: #197DD5;
        text-align: center;
        background: #197DD5;
    }

    .radio-group .radio-normal:disabled + label:before {
        color: #fff;
        border: 1px solid #ccc;
        background: #ddd;
        cursor: not-allowed;
    }

    .checkbox-group label:before {
        content: "";
        display: inline-block;
        width: 16px;
        height: 16px;
        position: absolute;
        top: 3px;
        left: 0;
        background: #fcfcfc;
        border: 1px solid #bbb;
    }

    .checkbox-group .checkbox-normal + label:before {
        -webkit-border-radius: 3px;
        -moz-border-radius: 3px;
        border-radius: 3px;
    }

    .checkbox-group .checkbox-normal:hover + label:before {
        border-color: #197DD5;
    }

    .checkbox-group .checkbox-normal:checked + label:before {
        content: "\f00c";
        font-family: "Font Awesome 6 Pro";
        color: #fff;
        font-size: 12px;
        text-align: center;
        line-height: 13px;
        border-color: #197DD5;
        font-weight: bold;
        background: #197DD5;
    }

    .checkbox-group .checkbox-normal:disabled + label:before {
        color: #fff;
        border: 1px solid #ccc;
        background-color: #ddd;
        cursor: not-allowed;
    }

    .checkbox-group .checkbox-indeterminate + label:before {
        content: "\e95f";
        font-family: "Font Awesome 6 Pro";
        font-size: 14px;
        text-align: center;
        line-height: 15px;
        color: #fff;
        border-color: #197DD5;
        font-weight: bold;
        background: #197DD5;
        -webkit-border-radius: 3px;
        -moz-border-radius: 3px;
        border-radius: 3px;
    }

    .multi-select-active:after {
        content: "\e93e";
        font-family: "Font Awesome 6 Pro";
        margin-left: 64%;
        font-weight: bold;
    }

    .icon-single-add {
        font-size: 22px;
        position: absolute;
        margin-left: -30px;
        margin-top: 7px;
    }

    .icon-double-add {
        font-size: 22px;
        position: absolute;
        margin-left: -30px;
        margin-top: 7px;
    }

    .transfer-double {
        width: 100%;
        background-color: #fff;
        z-index: 1000;
    }

    .transfer-double-header {
        padding: 10px
    }

    .transfer-double-content-left {
        display: inline-block;
        width: calc(50% - 35px);
        min-height: 320px;
        border: 1px solid #eee;
        border-radius: 2px;
        float: left;
    }

    .transfer-double-content-middle {
        display: inline-block;
        width: 70px;
        float: left;
        padding: 20% 15px 20% 15px;
        text-align: center;
    }

    .transfer-double-content-right {
        display: inline-block;
        width: calc(50% - 35px);
        height: 320px;
        border: 1px solid #eee;
        border-radius: 2px;
    }

    .transfer-double-content-param {
        display: inline-block;
        width: 100%;
        height: 36px;
        line-height: 36px;
        border-bottom: 1px solid #eee;
        text-align: center;
    }

    .transfer-double-content-param .param-item {
        display: inline-block;
        height: 36px;
        line-height: 36px;
    }

    .vertical-separation-line {
        color: #eee;
        margin: 0 10px;
    }

    .transfer-double-list-header {
        padding: 8px 8px 6px 8px;
        text-align: center;
    }

    .transfer-double-list-search-input {
        width: 100%;
        height: 24px;
        line-height: 24px;
        border: 1px solid #ddd;
        padding: 5px 0 4px 8px;
        border-radius: 2px;
    }

    .transfer-double-list-content {
        padding: 3px 3px;
    }

    .transfer-double-list-main {
        height: 210px;
        overflow-y: auto;
    }

    .transfer-double-list-main .transfer-double-list-ul {
        list-style: none;
        padding-left: 25px;
        margin: 0;
    }

    .transfer-double-list-main .transfer-double-list-ul .transfer-double-list-li {
        margin-top: 5px;
    }

    .transfer-double-list-main .transfer-double-list-ul .transfer-double-list-li input {
        margin-right: 10px;
    }

    .transfer-double-list-main .transfer-double-group-list-ul {
        list-style: none;
        padding-left: 7px;
        margin: 0;
    }

    .transfer-double-list-main .transfer-double-group-list-ul .transfer-double-group-list-li .transfer-double-group-list-li-ul {
        list-style: none;
        margin-left: 0;
        padding-left: 19px;
    }

    .transfer-double-list-main .transfer-double-group-list-ul .transfer-double-group-list-li .transfer-double-group-list-li-ul .transfer-double-group-list-li-ul-li {
        margin-top: 5px;
    }

    .transfer-double-selected-list-header {
        padding: 8px 8px 6px 8px;
        text-align: center;
    }

    .transfer-double-selected-list-search-input {
        width: 100%;
        height: 24px;
        line-height: 24px;
        border: 1px solid #ddd;
        padding: 5px 0 4px 8px;
        border-radius: 2px;
    }

    .transfer-double-selected-list-content {
        padding: 3px 3px;
    }

    .transfer-double-selected-list-main {
        height: 210px;
        overflow-y: auto;
    }

    .transfer-double-selected-list-main .transfer-double-selected-list-ul {
        list-style: none;
        padding-left: 25px;
        margin: 0;
    }

    .transfer-double-selected-list-main .transfer-double-selected-list-ul .transfer-double-selected-list-li {
        margin-top: 5px;
    }

    .transfer-double-selected-list-main .transfer-double-selected-list-ul .transfer-double-selected-list-li .checkbox-group {
        width: 99%;
    }

    .transfer-double-selected-list-main .transfer-double-selected-list-ul .transfer-double-selected-list-li input[type="checkbox"] {
        margin-right: 10px;
    }

    .transfer-double-selected-list-main .transfer-double-selected-list-ul .transfer-double-selected-list-li input[type="text"] {
        min-width: 40px;
        width: 40px;
        min-height: 24px;
        height: 24px;
    }

    .transfer-double-list-footer {
        height: 24px;
        line-height: 24px;
        border-top: 1px solid #ddd;
        padding-left: 18px;
        color: #999;
        padding-top: 1px;
    }

    .transfer-double-list-footer span {
        margin-left: 20px;
    }

    .transfer-double-list-footer input {
        min-width: 40px;
        width: 40px;
        min-height: 24px;
        height: 24px;
        margin-left: 75px;
    }

    .transfer-double-list-footer .btn-setting {
        display: inline-block;
        margin-left: 5px;
    }

    .transfer-double-list-footer label {
        margin-left: 10px;
    }

    .transfer-double-footer {
        padding: 10px;
        text-align: right;
    }

    .btn-select-arrow {
        display: inline-block;
        width: 34px;
        height: 28px;
        line-height: 28px;
        color: #bbb;
        background: #e0e0e0;
    }

    .btn-select-arrow + .btn-select-arrow {
        margin-top: 10px;
    }

    .btn-arrow-active {
        color: #fff;
        background: #387EE8;
    }

    /*
     * clear float
     */

    .clearfix:before, .clearfix:after {
        display: table;
        content: " ";
    }

    .clearfix:after {
        clear: both;
    }

    .clearfix {
        *zoom: 1;
    }

    /*
     * input placeholder style
     */

    input::-webkit-input-placeholder { /* WebKit browsers */
        font-size: 12px;
        color: #bbb;
    }

    input:-moz-placeholder { /* Mozilla Firefox 4 to 18 */
        font-size: 12px;
        color: #bbb;
    }

    input::-moz-placeholder { /* Mozilla Firefox 19+ */
        font-size: 12px;
        color: #bbb;
    }

    input:-ms-input-placeholder { /* Internet Explorer 10+ */
        font-size: 12px;
        color: #bbb;
    }

    /*
     * webkit scrollbar
     */

    .transfer-double-list-main::-webkit-scrollbar {
        width: 4px;
        height: 4px;
    }

    .transfer-double-list-main::-webkit-scrollbar-track {
        background: #f6f6f6;
        border-radius: 2px;
    }

    .transfer-double-list-main::-webkit-scrollbar-thumb {
        background: #ddd;
        border-radius: 2px;
    }

    .transfer-double-list-main::-webkit-scrollbar-thumb:hover {
        background: #999;
    }

    .transfer-double-list-main::-webkit-scrollbar-corner {
        background: #f6f6f6;
    }

    .transfer-double-selected-list-main::-webkit-scrollbar {
        width: 4px;
        height: 4px;
    }

    .transfer-double-selected-list-main::-webkit-scrollbar-track {
        background: #f6f6f6;
        border-radius: 2px;
    }

    .transfer-double-selected-list-main::-webkit-scrollbar-thumb {
        background: #ddd;
        border-radius: 2px;
    }

    .transfer-double-selected-list-main::-webkit-scrollbar-thumb:hover {
        background: #999;
    }

    .transfer-double-selected-list-main::-webkit-scrollbar-corner {
        background: #f6f6f6;
    }

    label {
        margin-bottom: 0;
    }

    .transfer-double-footer {
        padding: 0;
    }

    .checkbox-group.toggle-group-items {
        padding: 5px;
    }

    .toggle-btn {
        width: 20px;
        height: 20px;
        text-align: center;
        padding-top: 2px;
        background: #f2f4f8;
        border: 1px solid #eaeaea;
        border-radius: 3px;
    }

    .transfer-double-group-list-li-ul.collapsed {
        display: none;
    }

}

.d4-dual-list-checkbox[disabled] {
    .checkbox-group .checkbox-normal + label::before,
    .transfer-double-content-left,
    .transfer-double-content-middle,
    .transfer-double-list-footer{
        display: none;
    }

    .transfer-double-content-right {
        width: 100%;
    }

    .transfer-double-selected-list-main .transfer-double-selected-list-ul {
        list-style: none;
        padding-left: 0;
    }

    .checkbox-group label {
        padding-left: 7px;
        pointer-events: none;
    }
}