.constr-filter {
    list-style: none; 
    margin-bottom: 40px;
}

.constr-filter_child {
    list-style: none;
    margin-bottom: 20px;
    padding-left: 17px;
    display: none;
}

.constr-filter_head {
    font-weight: 600;
    position: relative; 
    display: flex;
    align-items: center;
    cursor: pointer;
    margin-bottom: 5px;
    padding-left: 30px;
}
 

.constr-filter_head div {
    position: relative;
}

.constr-filter_head i::after {
    position: absolute;
    content: "";
    width: 10px;
    height: 10px;
    border: 2px solid gray;
    transform: rotate(45deg);
    top: 4px;
    border-top: none;
    border-left: none;
    margin-left: 30px;
    left: 0;
    left: 200px;
}

.constr-filter_head i {
    position: relative;
    display: block;
    height: 10px;
    flex-grow: 1;
    min-width: 10px;
    position: absolute;
    width: 100%; 
    height: 100%;
    max-width: 400px;
}

.constr-filter_head i.active::after {
    transform: rotate(-135deg);
    top: 8px;
}

.constr-filter_head input {
    position: absolute;
    left: 0;
    top: 0;
    width: 30px;
    height: 30px;
    z-index: 2;
    opacity: 0;
    cursor: pointer;
}
  
.constr-filter_head span {
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    border: 2px solid #c3c3c3;
    border-radius: 5px;
}

.constr-filter_head span::before {
    position: absolute;
    top: 43%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(45deg) skewY(10deg);
    width: 5px;
    height: 10px;
    border: 2px solid #ffffff;
    content: "";
    border-top: none;
    border-left: none;
}

.constr-filter_head input:checked ~ span {
    background: #d9c07f;
    border-color: #d9c07f;
}
 
.constr-filter_child div span {
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    border: 2px solid #c3c3c3;
    border-radius: 5px;
}

.constr-filter_child div {
    position: relative;
    padding-left: 30px;
}

.constr-filter_child input {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    cursor: pointer;
    z-index: 2;
    opacity: 0;
    width: 100%;
}

.constr-filter_child div span::before {
    position: absolute;
    top: 43%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(45deg) skewY(10deg);
    width: 5px;
    height: 10px;
    border: 2px solid #ffffff;
    content: "";
    border-top: none;
    border-left: none;
}

.constr-filter_child input:checked ~ span {
    background: #d9c07f;
    border-color: #d9c07f;
} 


.master-all_btn {
    font-weight: 600;
    position: relative;
    display: flex;
    align-items: center;
    cursor: pointer;
    margin-bottom: 30px;
    padding-left: 30px;
}


.master-all_btn input {
    position: absolute;
    left: 0;
    top: 0;
    width: 225px;
    height: 100%;
    z-index: 2;
    opacity: 0;
    cursor: pointer;
}
  
.master-all_btn span {
    width: 20px;
    height: 20px;
    display: block;
    position: absolute;
    left: 0;
    top: 0;
    border: 2px solid #c3c3c3;
    border-radius: 5px;
}

.master-all_btn span::before {
    position: absolute;
    top: 43%;
    left: 50%;
    transform: translate(-50%, -50%) rotate(45deg) skewY(10deg);
    width: 5px;
    height: 10px;
    border: 2px solid #ffffff;
    content: "";
    border-top: none;
    border-left: none;
}

.master-all_btn input:checked ~ span {
    background: #d9c07f;
    border-color: #d9c07f;
}


.fileimg-add.js_get_list_materials {
    width: auto;
}

.fileimg-add.js_add-material {
    width: auto;
}

.works-cost {
    margin-top: 20px;
    margin-bottom: 12px;
    font-weight: 500;
    font-size: 20px;
}

.materials-cost {
    font-weight: 500;
    font-size: 20px;
    margin-top: 5px;
    margin-bottom: 10px;
}
 

.modal-white .modal-content {
    background: #fff;
}

.modal-white  button.close {
    border-color: #151515;
    color: #151515;
}

.modal-white .modal-body {
    padding: 30px;
    padding-right: 65px;
}

.modal-white .modal-title {
    font-size: 20px;
    font-weight: 500;
    line-height: 1.6;
    color: #151515;
}

.modal-body.modal-body_danger {
    color: red;
}

.modal-white .modal-dialog {
    width: 95%;
    max-width: 600px;
}


div#modalSuccessMessage .btn-gold {
    margin-top: 10px;
    font-size: 14px;
}

.prodlist-table {
    width: 100%;
    font-size: 14px;
}

.messages-right {
    width: 100%;
}

.messages-body {
    height: 350px;
}

.messages-top {
    padding: 10px;
}

.messages-bottom {
    padding: 10px;
}

.messages-emoticons {
    height: 30px;
    width: 30px;
}

.messages-file {
    width: 30px;
}

input.messages-input {
    max-width: 200px;
}

.messages-submit {
    margin-left: auto;
    width: 30px;
    height: 30px;
}


.response-edit {
    background: linear-gradient(151.21deg, #DFC785 -7.71%, #9C723B 353.41%);
    border-radius: 4px;
    border: 1px solid #DFC785;
    padding: 5px 15px;
    font-size: 14px;
    color: #fff;
    text-align: center;
}

.response-edit:hover {
    background: #fff;
    color:  #DFC785;
}


.response-remove {
    background: #ff0000;
    border-radius: 4px;
    border: 1px solid #ff0000;
    padding: 5px 15px;
    font-size: 14px;
    color: #fff;
}

.response-remove:Hover {
    color: #ff0000;
    background: #fff;
}

.statusname {
    padding: 1px 5px;
    font-size: 12px;
    border-radius: 3px;
    white-space: nowrap;
    text-align: center;
    position: relative;
}

.request-noread {
    position: absolute;
    top: -9px;
    right: -6px;
    background: #00aaffb5;
    width: 16px;
    height: 16px;
    border-radius: 50%;
    color: #fff;
    font-size: 11px;
    text-align: center;
}

.statusname.statusname-1 {
    background: #e4e400;
}

.statusname.statusname-2 {
    background: #007bff;color: #fff;
}

.statusname.statusname-3 {
    background: #28a745;
    color: #fff;
}
 
.statusname.statusname-4 {
    background: #20c997;
    color: #fff;
}

.statusname.statusname-5 {
    background: pink;
}


.statusorder {
    padding: 1px 5px;
    font-size: 12px;
    border-radius: 3px;
    white-space: nowrap;
    text-align: center;
}

 

.statusorder-1 {
    background: #e4e400;  
}

.statusorder-2 {
    background: #007bff;  
    color: #fff;
}

.statusorder-3 {
    background: #17a2b8;  
    color: #fff;
}

.statusorder-4 {
    background: #28a745;  
    color: #fff;
}

.statusorder-5 {
    background: pink;
}






.request-accept_inner {
    background: #28a745;
    border-radius: 10px;
    font-weight: 600;
    font-size: 18px;
    line-height: 1.3;
    color: #FFF;
    max-width: 415px;
    padding: 14px 10px;
    margin-top: 10px;
    width: 90%;
    border: 1px solid #28a745;
}

a.request-accept_inner:hover {
    color: #28a745;
    background: #fff;
}

.request-del_inner {
    border-radius: 10px;
    font-weight: 600;
    font-size: 18px;
    line-height: 1.3;
    max-width: 415px;
    padding: 14px 10px;
    margin-top: 10px;
    width: 90%;
    background: pink;
    border: 1px solid pink;
}

a.request-del_inner:hover {
    color: pink;
    background: #fff;
}


.request-ok_inner {
    background: #007bff;
    color: #fff;
    border-radius: 10px;
    font-weight: 600;
    font-size: 18px;
    line-height: 1.3; 
    max-width: 415px;
    padding: 14px 10px;
    margin-top: 10px;
    width: 90%;
    border: 1px solid  #007bff;
}

a.request-ok_inner:hover {
    color: #007bff;
    background: #fff;
}

.loader {
    position: fixed !important;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100vh;
    background: #b7b7b733;
    z-index: 1100;
    text-align: center; 
    justify-content: center;
    align-items: center;
    display: flex;
    background: #00000045;
}

.loader.d-none {
    display: none;
}


div#modalAgreement .form-head {
    padding: 0;
    font-size: 16px;
    margin-bottom: 10px;
    font-weight: 500;
}

div#modalAgreement .fieldset {
    padding: 0;
    margin-bottom: 20px;
}

div#modalAgreement .login-input[readonly] {
    background: #f8f83b12;
}

div#modalAgreement .modal-dialog.modal-dialog-centered {
    max-width: 800px;
}

.modal-section {
    margin-bottom: 20px;
}

.modal-section_head {
    font-weight: bold;
    font-size: 18px;
    margin-bottom: 10px;
    width: 100%;
}

.modal-section b, .modal-section strong {
    font-weight: 600;
}

table.prodpdf-table {
    width: 100%;
    font-size: 14px;
    margin-bottom: 30px;
}

.pdf-materials-cost {
    font-weight: 500;
    font-size: 20px;
    margin-top: 5px;
    margin-bottom: 25px;
}

.pdf-prodtotal-head {
    font-size: 20px;
    line-height: 1.3;
    color: #8F8F8F;
    margin-bottom: 5px;
}

.pdf-prodtotal-price {
    font-size: 39px;
    line-height: 1.3;
    color: #151515;
    margin-bottom: 30px;
}
 
 
a.document-link {
    display: flex;
    align-items: center;
    text-decoration-line: underline;
    color: #0072BB;
    width: 100%;
    text-align: center;
    justify-content: center;
    margin-top: 30px;
}

a.document-link svg {
    margin-right: 10px;
} 