:root {
    --iris-form-font-size: 0.775rem;
    --iris-form-label-font-size: 10.45px;
}

body{
	font-family:"Helvetica Neue",Helvetica,Arial,sans-serif;
	font-size: var(--iris-form-font-size);
	line-height:1.224489796;
	color:var(--bs-body-color, #222);
	background-color:var(--bs-body-bg, #fff);
    /*overflow-y: scroll !important; *//* has to be scroll, not auto */
    /*overflow-x: scroll !important; *//* has to be scroll, not auto */
    /*-webkit-overflow-scrolling: touch !important;*/
}

.iris-login-page {
    min-height: 100vh;
    margin: 0;

    background:
            linear-gradient(
                    rgba(8, 22, 34, 0.12),
                    rgba(8, 22, 34, 0.20)
            ),
            url("../images/iris-login-bg.webp");

    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;

    background-color: #eaf2fb;
}

@media (max-width: 768px) {
    .iris-login-page {
        background-image:
                linear-gradient(
                        rgba(8, 22, 34, 0.10),
                        rgba(8, 22, 34, 0.18)
                ),
                url("../images/iris-login-bg-mobile.webp");
    }
}


.iris-login-logo {
    display: block;
    width: 100%;
    max-width: 280px;
    height: auto;
    margin: 0 auto;
}

.iris-blank-logo {
    display: block;
    width: 110%;
    max-width: 600px;
    height: auto;
    margin: 0 auto;
}

.iris-login-shell {
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 1.25rem;
}

.iris-login-panel {
    width: min(100%, 360px);
}

.iris-login-form {
    width: 100%;
    padding: 1.25rem 1.25rem 1rem;
    border: 1px solid rgba(255, 255, 255, .34);
    border-radius: .5rem;
    background: rgba(var(--bs-body-bg-rgb, 255, 255, 255), .9);
    box-shadow: 0 .75rem 2.5rem rgba(0, 0, 0, .22);
    backdrop-filter: blur(8px);
}

.iris-login-brand {
    margin-bottom: 1rem;
    text-align: center;
}

.iris-login-fields {
    display: flex;
    flex-direction: column;
    gap: .65rem;
    width: 100%;
}

.iris-login-input-group,
.iris-login-submit {
    width: 100%;
}

.iris-login-icon {
    background-color: var(--bs-primary);
    border-color: var(--bs-primary);
    color: #fff;
    justify-content: center;
    min-width: 2.75rem;
}

.iris-login-form .form-control {
    min-height: 2.35rem;
}

.iris-login-submit {
    min-height: 2.35rem;
}

.iris-blank-page {
    height: 100vh;
    height: 100dvh;
    inset: 0;
    min-height: 0;
    overflow: hidden;
    position: fixed;
    width: 100vw;
}

.iris-blank-shell {
    height: 100%;
    min-height: 0;
}

.iris-blank-logo-wrap {
    width: min(100%, 360px);
}

.tech-planning-page,
.tech-planning-form {
    height: 100vh;
    height: 100dvh;
    min-height: 0;
    overflow: hidden;
    width: 100%;
}

.tech-planning-panels {
    height: 100%;
    min-height: 0;
    overflow: hidden;
    width: 100%;
}

.tech-planning-frame {
    background: var(--bs-body-bg);
    border: 0;
    display: block;
    height: 100%;
    min-height: 0;
    width: 100%;
}

.tech-planning-panels.splitter_container {
    background: var(--bs-border-color);
}

.tech-planning-panels.splitter_container > .splitter_panel {
    background: var(--bs-body-bg);
    min-height: 0;
    overflow: hidden;
}

.tech-planning-panels.splitter-horizontal > .splitter_bar {
    background: color-mix(in srgb, var(--bs-body-bg) 82%, var(--bs-primary));
    border-bottom: 1px solid var(--bs-border-color);
    border-top: 1px solid var(--bs-border-color);
}

.tech-planning-panels.splitter-horizontal > .splitter_bar > .splitter_handle {
    background-color: var(--bs-secondary-color);
    border-radius: 999px;
    height: 3px;
    margin: 4px auto 0;
    width: 46px;
}

body.tech-planning-body {
    margin: 0;
    overflow: hidden;
}

.tech-planning-requests-page,
.tech-planning-schedule-page {
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    height: 100vh;
    height: 100dvh;
    max-height: 100vh;
    max-height: 100dvh;
    min-height: 0;
    overflow: hidden;
    width: 100%;
}

.tech-planning-toolbar {
    align-items: center;
    background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-primary));
    border-bottom: 1px solid var(--bs-border-color);
    box-shadow: 0 .125rem .35rem rgba(0, 0, 0, .04);
    display: flex;
    flex: 0 0 auto;
    flex-wrap: nowrap;
    gap: .35rem;
    min-height: 2.75rem;
    overflow: hidden;
    padding: .45rem .65rem;
}

.tech-planning-title {
    color: var(--bs-body-color);
    font-size: .9rem;
    font-weight: 700;
    margin: 0 .25rem 0 0;
    white-space: nowrap;
}

.tech-planning-filter {
    flex: 0 1 8.5rem;
    min-width: 6.75rem;
    width: 8.5rem;
}

.tech-planning-filter-object,
.tech-planning-filter-firm,
.tech-planning-filter-office,
.tech-planning-filter-office-wide {
    flex: 0 1 11rem;
    min-width: 8rem;
    width: 11rem;
}

.tech-planning-filter-office-wide {
    flex-basis: 14rem;
    min-width: 11rem;
    width: 14rem;
}

.tech-planning-toolbar .input-group-text {
    justify-content: center;
    min-width: 2.25rem;
}

.tech-planning-toolbar .form-control,
.tech-planning-toolbar .form-select,
.tech-planning-toolbar .btn {
    min-width: 0;
}

.tech-planning-toolbar .btn {
    padding-left: .45rem;
    padding-right: .45rem;
}

.tech-planning-actions {
    align-items: center;
    display: flex;
    flex: 0 0 auto;
    flex-wrap: nowrap;
    gap: .35rem;
    margin-left: 0;
    white-space: nowrap;
}

.tech-planning-toolbar > .tech-planning-actions:last-child {
    margin-left: auto;
}

.tech-planning-check {
    align-items: center;
    display: inline-flex;
    gap: .35rem;
}

.tech-planning-result,
.tech-planning-schedule-result {
    display: flex;
    flex: 1 1 auto;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
}

.tech-planning-result .result_paging,
.tech-planning-schedule-result .result_paging {
    flex: 0 0 auto;
}

.tech-planning-result .result_data,
.tech-planning-schedule-result .result_data {
    flex: 1 1 auto;
    max-height: none !important;
    min-height: 0;
    overflow: auto;
}

.tech-planning-empty {
    height: 0;
    width: 0;
}

.tech-planning-office-select {
    display: none;
    font-size: .85rem;
    max-height: min(18rem, calc(100vh - 5rem));
    overflow: auto;
    position: absolute;
    width: min(25rem, calc(100vw - 1rem));
    z-index: 100;
}

.tech-planning-office-display {
    background-color: #eeffee;
    border-color: #cacaca;
    line-height: 1.5;
    overflow: hidden;
    text-align: left;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tech-planning-date {
    flex: 0 0 10.25rem;
    width: 10.25rem;
}

.tech-planning-period {
    flex: 0 0 auto;
    width: auto;
}

.tech-planning-period .form-control {
    max-width: 3.25rem;
    min-width: 3.25rem;
}

.tech-planning-schedule-page #pMonth {
    display: none;
}

.tech-planning-schedule-page table.result td.person_on_duty a:link,
.tech-planning-schedule-page table.result td.person_on_duty a:visited {
    color: green;
    font-weight: 700;
    text-decoration: none;
}

.tech-planning-schedule-page table.result td.person_on_leave a:link,
.tech-planning-schedule-page table.result td.person_on_leave a:visited {
    color: red;
    font-weight: 700;
    text-decoration: none;
}

.tech-planning-graph-data {
    background: color-mix(in srgb, var(--bs-body-bg) 96%, var(--bs-primary));
    height: 100%;
    overflow: auto;
    width: 100%;
}

.tech-planning-graph-table {
    border-collapse: separate;
    border-spacing: 0;
    color: var(--bs-body-color);
    font-family: var(--bs-body-font-family) !important;
    font-size: .78rem;
    min-width: 920px;
    table-layout: auto;
}

.tech-planning-graph-table thead th {
    background: color-mix(in srgb, var(--bs-body-bg) 88%, var(--bs-primary));
    border-bottom: 1px solid var(--bs-border-color);
    color: var(--bs-emphasis-color);
    font-weight: 700;
    height: 2rem;
    padding: .35rem .5rem;
    position: sticky;
    top: 0;
    z-index: 20;
}

.tech-planning-person-head,
.tech-planning-person-cell {
    min-width: 14rem;
    width: 14rem;
}

.tech-planning-location-head,
.tech-planning-location-cell {
    min-width: 2.35rem;
    text-align: center;
    width: 2.35rem;
}

.tech-planning-earning-head,
.tech-planning-earning-cell {
    min-width: 6rem;
    text-align: right;
    width: 6rem;
}

.tech-planning-timeline-head,
.tech-planning-timeline-cell {
    min-width: 34rem;
}

.tech-planning-person-row {
    white-space: nowrap;
}

.tech-planning-person-row:hover {
    background: color-mix(in srgb, var(--bs-body-bg) 88%, var(--bs-info)) !important;
}

.tech-planning-person-cell {
    border-bottom: 1px solid color-mix(in srgb, var(--bs-border-color) 65%, transparent);
}

.tech-planning-person-cell > div {
    align-items: center;
    display: flex;
    gap: .35rem;
    min-height: 1.85rem;
    padding-left: .6rem;
    width: 100%;
}

.tech-planning-person-cell a {
    color: var(--bs-emphasis-color);
    font-weight: 600;
    max-width: 11rem;
    overflow: hidden;
    text-decoration: none;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tech-planning-person-cell a:hover {
    color: var(--bs-primary);
    text-decoration: underline;
}

.tech-planning-location-cell {
    border-bottom: 1px solid color-mix(in srgb, var(--bs-border-color) 65%, transparent);
    color: var(--bs-primary);
    cursor: pointer;
}

.tech-planning-location-cell:hover {
    background: color-mix(in srgb, var(--bs-body-bg) 86%, var(--bs-primary));
}

.tech-planning-earning-cell {
    border-bottom: 1px solid color-mix(in srgb, var(--bs-border-color) 65%, transparent);
    color: var(--bs-secondary-color);
    font-variant-numeric: tabular-nums;
    padding: 0 .5rem;
}

.tech-planning-time-scale {
    height: 1.35rem;
    padding: 0;
}

.tech-planning-time-scale > div,
.tech-planning-timeline-cell > div {
    height: 100%;
    position: relative;
}

.tech-planning-hour-mark {
    color: var(--bs-secondary-color);
    font-size: .72rem;
    font-weight: 600;
    height: 100%;
    line-height: 1.35rem;
    position: absolute;
    text-align: left;
    top: 0;
}

.tech-planning-time-overlay {
    border-radius: .25rem;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .22), 0 .08rem .25rem rgba(0, 0, 0, .16);
    color: #fff;
    display: none;
    font-size: .68rem;
    font-weight: 700;
    height: 1.35rem;
    line-height: 1.35rem;
    opacity: .78;
    overflow: hidden;
    position: absolute;
    text-overflow: ellipsis;
    top: .15rem;
    white-space: nowrap;
    z-index: 12;
}

.tech-planning-time-overlay > div {
    overflow: hidden;
    padding: 0 .35rem;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.tech-planning-work-overlay {
    opacity: .9;
    z-index: 13;
}

.tech-planning-timeline-cell {
    border-bottom: 1px solid color-mix(in srgb, var(--bs-border-color) 65%, transparent);
    height: 1.5rem;
    margin: 0;
    padding: 0 .25rem;
    width: 100%;
}

.tech-planning-card {
    border: 1px solid transparent;
    border-radius: .3rem;
    box-shadow: 0 .06rem .18rem rgba(15, 23, 42, .18);
    color: #fff;
    cursor: pointer;
    display: inline-block;
    font-size: .68rem;
    font-weight: 700;
    height: calc(100% - .16rem);
    min-width: .35rem;
    overflow: hidden;
    position: absolute;
    top: .08rem;
    transition: box-shadow .12s ease, filter .12s ease, transform .12s ease;
}

.tech-planning-card:hover {
    box-shadow: 0 .14rem .38rem rgba(15, 23, 42, .26);
    filter: brightness(1.05);
    transform: translateY(-1px);
    z-index: 10005;
}

.tech-planning-card > div {
    left: .22rem;
    overflow: hidden;
    position: relative;
    text-overflow: ellipsis;
    top: .06rem;
    white-space: nowrap;
}

.tech-planning-free-slot {
    cursor: pointer;
    display: inline-block;
    height: 100%;
    min-width: .35rem;
    opacity: 0;
    overflow: hidden;
    position: absolute;
    top: 0;
}

.tech-planning-free-slot > div {
    display: none;
}

.tech-planning-move-card {
    opacity: .82;
}

.tech-planning-closed-card {
    background-color: #fff !important;
    border-style: solid;
    border-width: 1px;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, .55), 0 .06rem .18rem rgba(15, 23, 42, .12);
}

.tech-planning-closed-card:hover {
    background-color: #fff !important;
}

.tech-planning-work-row {
    height: 1.35rem;
}

.tech-planning-work-spacer {
    border-bottom-color: color-mix(in srgb, var(--bs-border-color) 70%, var(--bs-success)) !important;
}

.tech-planning-work-cell {
    background: color-mix(in srgb, var(--bs-body-bg) 92%, var(--bs-success));
    height: 1.35rem;
    padding-bottom: 0;
    padding-top: 0;
}

.tech-planning-work-card {
    font-size: .68rem;
    height: calc(100% - .14rem);
    opacity: 1;
    top: .07rem;
}

.person_select {
    background-color: #c1c1c1;
}

.separator_person {
    border-bottom: 1px solid #99bb99 !important;
}

.separator_rows {
    border-bottom: 1px solid #cecece !important;
}

[data-bs-theme="dark"] .tech-planning-toolbar {
    background: color-mix(in srgb, var(--bs-body-bg) 86%, var(--bs-primary));
}

@media (max-width: 768px) {
    .tech-planning-toolbar {
        flex-wrap: wrap;
        overflow: visible;
    }

    .tech-planning-filter,
    .tech-planning-filter-object,
    .tech-planning-filter-firm,
    .tech-planning-filter-office,
    .tech-planning-filter-office-wide,
    .tech-planning-date,
    .tech-planning-actions,
    .tech-planning-period {
        width: 100%;
    }

    .tech-planning-actions {
        justify-content: stretch;
        margin-left: 0;
    }

    .tech-planning-actions .btn {
        flex: 1 1 auto;
    }
}

.iris-login-title {
    font-size: 1.35rem;
    font-weight: 700;
    color: var(--bs-emphasis-color);
}

.iris-login-subtitle {
    color: var(--bs-secondary-color);
    font-size: .82rem;
    margin-top: 1rem;
    text-align: center;
}

@media (max-width: 575.98px) {
    .iris-login-page {
        background-attachment: scroll;
    }

    .iris-login-shell {
        padding: .85rem;
    }

    .iris-login-form {
        padding: 1rem .95rem .8rem;
    }
}

.no-scroll {
    overflow-y: hidden !important;
}

.input-transparent {
    border: 0px;
    color: inherit;
    font-weight: inherit;
    background-color: transparent;
}

input.input-transparent-no-borders {
    border: 0px;
    color: inherit;
    font-weight: normal;
    background-color: transparent;
}

.invalidField {
    border-color: var(--bs-danger, #dc3545) !important;
    box-shadow: 0 0 0 0.12rem rgba(var(--bs-danger-rgb, 220, 53, 69), 0.2);
}

.input-group-sm>.input-group-text,
.input-group-sm>.fa,
.input-group-sm>.far,
.input-group-sm>.fas,
.input-group-sm>.input-group-btn>.btn {
	/*height: 28px;*/
    min-width: 28px;
    border-color: var(--bs-border-color, #cccccc);
    border-width: 1px 0px 1px 1px;
    border-style: solid;
    color: var(--bs-body-color, rgb(34, 34, 34));
    background: var(--bs-tertiary-bg, #efefef);
	padding: 7px 6px;
	font-size: 12px;
	line-height: 1;
	border-radius: 3px 0px 0px 3px;
	top: 0px;
    text-align: center;
}

.iris-input-addon-end,
.input-group > .form-control + span.input-group-text,
.input-group > .form-select + span.input-group-text,
.input-group > input + span.input-group-text,
.input-group > select + span.input-group-text,
.input-group > textarea + span.input-group-text {
    border-right-width: 1px;
    border-right-style: solid;
    border-right-color: var(--bs-border-color, #cccccc);
}

.input-group > .form-control + span.input-group-text:last-child,
.input-group > .form-select + span.input-group-text:last-child,
.input-group > input + span.input-group-text:last-child,
.input-group > select + span.input-group-text:last-child,
.input-group > textarea + span.input-group-text:last-child {
    border-radius: 0 3px 3px 0;
}

.input-group-sm.iris-check-group {
    height: 28px;
    align-items: stretch;
}

.input-group-sm.iris-check-group > .input-group-text {
    height: 28px;
    min-height: 28px;
    display: flex;
    align-items: center;
    padding: 1px 6px;
    line-height: 1;
}

.input-group-sm.iris-check-group > .input-group-text.form-control {
    flex: 1 1 auto;
    width: 1%;
    justify-content: flex-start;
    border-right-width: 0;
    border-radius: 3px 0 0 3px;
    text-align: left;
}

.input-group-sm.iris-check-group > .input-group-text:last-child {
    flex: 0 0 28px;
    justify-content: center;
    border-right-width: 1px;
    border-radius: 0 3px 3px 0;
}

.input-group-sm.iris-check-group .form-check-input {
    width: 1rem;
    height: 1rem;
    margin: 0;
}
#login-menu {
    /*margin: -5px !important;*/
    padding: 0.1rem;
}

.input-group-sm>.form-control{
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-select300 {
    width: 300px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-select250 {
    width: 250px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-select200 {
	width: 200px;
	height: 28px;
	padding: 1px 2px;
	font-size: 12px;
	line-height: 1;
	border-radius: 3px;
	top: 0px;
	color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-select150 {
	width: 150px;
	height: 28px;
	padding: 1px 2px;
	font-size: 12px;
	line-height: 1;
	border-radius: 3px;
	top: 0px;
	color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-select120 {
    width: 120px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-select100 {
    width: 100px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-select75 {
    width: 75px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}
.input-group-sm>.form-control-select50 {
    width: 50px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp400 {
    width: 400px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp350 {
    width: 350px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp300 {
    width: 300px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp250 {
    width: 250px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp200 {
	width: 200px;
	height: 28px;
	padding: 1px 2px;
	font-size: 12px;
	line-height: 1;
	border-radius: 3px;
	top: 0px;
	color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp175 {
    width: 175px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp150 {
	width: 150px;
	height: 28px;
	padding: 1px 2px;
	font-size: 12px;
	line-height: 1;
	border-radius: 3px;
	top: 0px;
	color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp100 {
    width: 100px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp75 {
    width: 75px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}
.input-group-sm>.form-control-inp50 {
    width: 50px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-group-sm>.form-control-inp40 {
    width: 25px;
    height: 28px;
    padding: 1px 2px;
    font-size: 12px;
    line-height: 1;
    border-radius: 3px;
    top: 0px;
    color: var(--bs-body-color, #121212);
}

.input-type-file {
    line-height: 18px !important;
}

.input-group-sm>.form-control-calendar {
	width: 100px;
	color: var(--bs-body-color, #121212);
    height: 28px !important;
}

.input-group-sm>.form-control-inpNoBorder {
    color: var(--bs-body-color, #121212);
    height: 28px !important;
    border: 0px;
}

table {
	font-size: 12.5px;
    margin-bottom: 0px !important;
}

table.result th {
    text-align: center;
    background-color: var(--iris-result-header-bg, #265E86);
    padding: 0.43rem 0rem;
    color: #ffffff !important;
}
table.result th a {
    color: #ffffff !important;
}

.table-condensed>thead>tr>th,
.table-condensed>tbody>tr>th,
.table-condensed>tfoot>tr>th,
.table-condensed>thead>tr>td,
.table-condensed>tbody>tr>td,
.table-condensed>tfoot>tr>td {
    padding: 2px;
}

.table-sm th, .table-sm td {
    padding: 0.2rem;
}

a[role="button"]:hover {
    text-decoration:none;
}

legend {
	font-size: 12px;
    font-weight: bold;
    color: var(--bs-link-color, #0088cc);
    text-align: left;
    padding: 5px 0 2px 7px;
    background: var(--bs-tertiary-bg);
	margin:0px;
}

.section {
    font-size: 12px;
    font-weight: bold;
    color: var(--bs-link-color, #0088cc);
    text-align: left;
    margin-top:10px;
    padding: 5px 0 2px 7px;
    background: var(--bs-tertiary-bg);
}

hr {
    margin-top: 0px;
}

#result {
    max-width: 100%;
    overflow-x: visible;
    -webkit-overflow-scrolling: touch !important;
}

#result.has-fixed-exportbar {
    padding-bottom: 3.75rem;
}

#filter {
    max-width: 100%;
}

.page_caption {
    margin-right: 0;
    margin-left: 0;
    align-items: center;
}

.page_caption .col,
.page_caption [class*="col-"] {
    min-width: 0;
}
.btn-sm, .btn-group-sm > .btn {
    padding: 0.21rem 0.5rem;
    font-size: 0.87rem;
    line-height: 1.4;
    border-radius: 0.2rem;
    margin-top: -0.5px;
}

.btn-transparent {
    background: none;
    font-size: inherit;
    color: inherit;
}

.form-check-input, .form-check-label {
    margin-top: 0.4rem;
}

.form-group {
    margin-bottom: 0.4rem;
}

.bg-iris {
    border-bottom: 2px solid var(--iris-result-header-active-bg, #2e8cb8);
    background: var(--iris-nav-bg, #265E86);
    color: var(--iris-nav-text, #fff);
}

.bg-iris-light {
    background-color: var(--bs-tertiary-bg);
    opacity: 1;
}

.iris-navbar {
    padding: 0.1rem 0.5rem;
}

.nav-item>a {
    color: var(--iris-nav-text, #ffffff);
    padding: 8px 10px 8px 10px;
    font-size: 13px !important;
}

.nav-tabs {
    border-bottom: 1px solid transparent;
}
.nav-tabs .nav-item {
    margin-bottom: -2px;
}

.nav-tabs .nav-link {
    color: var(--bs-link-color, #265E86);
    border-bottom: 0px solid transparent !important;
}

.dropdown-menu {
    font-size: 0.84rem;
}

.dropdown-item {
    padding-top: 7px;
    padding-bottom: 7px;
}


.dropdown-toggle::after {
    border-right: 0em solid transparent;
    border-left: 0em solid transparent;
}

.navbar-nav:not(.sm-collapsible) .nav-link .sub-arrow {
    margin-left: .455em;
}

/*.sm-iris a, .sm-iris a:hover, .sm-iris a:focus, .sm-iris a:active {*/
    /*line-height: 24px !important;*/
/*}*/
.pt-05 {
    padding-top: 0.1rem !important;
}

.h-40{
    height: 40% !important;
}

.h-90{
    height: 90% !important;
}

.btn-primary {
    background-color:#007DC0 !important;
    border-color:#007DC0 !important;
}

.bg-primary {
    background-color:#007DC0 !important;
    border-color:#007DC0 !important;
}


element.style {
}
.text-dark {
    color: var(--bs-emphasis-color) !important;
}
label.label-iris {
    display: inline-block;
    margin-bottom: 0rem !important;
    color: var(--bs-secondary-color, #555555);
}

.iris-overline-label {
    position: relative;
    z-index: 3;
    display: inline-block;
    margin: 0 0 -0.25rem 2.3rem !important;
    padding: 0 .35rem;
    background: var(--bs-body-bg);
    color: var(--bs-secondary-color);
    font-size: var(--iris-form-label-font-size);
    line-height: 1;
}

input,
select,
textarea,
button,
.form-control,
.form-select,
.form-label,
.form-check-label,
.input-group-text,
.btn {
    font-size: var(--iris-form-font-size) !important;
}

.form-label,
.form-check-label,
label.label-iris {
    font-size: var(--iris-form-label-font-size) !important;
}


.h25 {
    height: 25px !important;
}

.h50 {
    height: 50px !important;
}

.w25 {
    width: 25px !important;
}

.w50 {
    width: 50px !important;
}

.w75 {
    width: 75px !important;
}

.w100 {
    width: 100px !important;
}

.w125 {
    width: 125px !important;
}

.w150 {
    width: 150px !important;
}

.w175 {
    width: 175px !important;
}

.w200 {
    width: 200px !important;
}

.w300 {
    width: 300px !important;
}

.w400 {
    width: 400px !important;
}

.min-h-0 {
    min-height: 0 !important;
}

/* OPTIMA Icons */
.fa-optima {
    width: 20px;
    height: 20px;
    padding: 8px;
    #background-color: #ffffff; /* defines the background color of the image */
}

.optima-mass-depack {
    mask: url(/images/icons/mass-depack.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/mass-depack.svg) no-repeat center / contain;
}

.optima-box-taped-plus {
    mask: url(/images/icons/box-taped-plus.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/box-taped-plus.svg) no-repeat center / contain;
}

.optima-search-check {
    mask: url(/images/icons/search-check.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/search-check.svg) no-repeat center / contain;
}

.optima-arrow-down-to-square {
    mask: url(/images/icons/arrow-down-to-square.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/arrow-down-to-square.svg) no-repeat center / contain;
}

.optima-arrow-down-to-square-search {
    mask: url(/images/icons/arrow-down-to-square-search.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/arrow-down-to-square-search.svg) no-repeat center / contain;
}

.optima-arrow-down-to-square-plus {
    mask: url(/images/icons/arrow-down-to-square-plus.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/arrow-down-to-square-plus.svg) no-repeat center / contain;
}

.optima-arrow-up-from-square {
    mask: url(/images/icons/arrow-up-from-square.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/arrow-up-from-square.svg) no-repeat center / contain;
}

.optima-arrow-up-from-square-minus {
    mask: url(/images/icons/arrow-up-from-square-minus.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/arrow-up-from-square-minus.svg) no-repeat center / contain;
}

.optima-receive-and-move {
    mask: url(/images/icons/receive-and-move.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/receive-and-move.svg) no-repeat center / contain;
}

.optima-receive-and-unpack {
    mask: url(/images/icons/receive-and-unpack.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/receive-and-unpack.svg) no-repeat center / contain;
}

.optima-share-from-square {
    mask: url(/images/icons/share-from-square.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/share-from-square.svg) no-repeat center / contain;
}

.optima-share-from-square-search {
    mask: url(/images/icons/share-from-square-search.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/share-from-square-search.svg) no-repeat center / contain;
}

.optima-square-ellipsis-vertical-pen {
    mask: url(/images/icons/square-ellipsis-vertical-pen.svg) no-repeat center / contain;
    -webkit-mask: url(/images/icons/square-ellipsis-vertical-pen.svg) no-repeat center / contain;
}
/* End OPTIMA Icons */

/* Bootstrap 5 shell and theme helpers */
:root {
    --iris-nav-height: 44px;
    --iris-nav-bg: #265e86;
    --iris-nav-text: #ffffff;
    --iris-dropdown-bg: #265e86;
    --iris-dropdown-hover: #1d4d70;
}

[data-bs-theme="dark"] {
    color-scheme: dark;
    --iris-nav-bg: #162230;
    --iris-nav-text: #f8f9fa;
    --iris-dropdown-bg: #1d2d3d;
    --iris-dropdown-hover: #2b3f52;
}

:is(
    .admin-menu-page,
    .access-profiles-page,
    .admin-access-level-page,
    .admin-accounts-page,
    .admin-personnels-page,
    .register-scripts-page,
    .setup-positions-page,
    .setup-salary-page,
    .person-shifts-page,
    .view-balance-page,
    .view-firm-balances-page,
    .summary-finances-page,
    .sales-docs-page
) {
    min-height: 100%;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

:is(
    .admin-menu-page .admin-menu-toolbar,
    .access-profiles-page .profiles-toolbar,
    .admin-access-level-page .access-toolbar,
    .admin-accounts-page .accounts-toolbar,
    .register-scripts-page .scripts-toolbar,
    .setup-positions-page .positions-toolbar,
    .setup-salary-page .salary-toolbar,
    .person-shifts-page .person-shifts-toolbar,
    .view-balance-page .view-balance-toolbar,
    .view-firm-balances-page .view-balance-toolbar,
    .summary-finances-page .summary-finances-toolbar,
    .sales-docs-page .sales-docs-toolbar,
    .person-popup .sales-docs-toolbar,
    .person-contract-popup .sales-docs-toolbar,
    .person-schedule-page .sales-docs-toolbar
) {
    border-bottom: 1px solid var(--bs-border-color);
    background: color-mix(in srgb, #98c1d9 42%, var(--bs-body-bg));
    border-bottom-color: color-mix(in srgb, #98c1d9 52%, var(--bs-border-color));
    box-shadow: inset 0 -1px 0 color-mix(in srgb, #98c1d9 18%, transparent);
}

:is(
    .admin-menu-page,
    .access-profiles-page,
    .admin-access-level-page,
    .admin-accounts-page,
    .admin-personnels-page,
    .register-scripts-page,
    .setup-positions-page,
    .setup-salary-page,
    .person-shifts-page,
    .view-balance-page,
    .view-firm-balances-page,
    .sales-docs-page
) #result {
    min-height: 320px;
}

.view-balance-page .view-balance-filter {
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
}

.view-balance-page .date-picker-trigger {
    cursor: pointer;
}

.sales-docs-page .sales-docs-filter {
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
}

.required_filters_invalid {
    border-color: #dc3545;
}

.toggledDiv {
    display: none;
}

.setup-objects-page table label {
    font-weight: normal;
    cursor: pointer;
    margin-bottom: 0;
}

.iris-report-filter > .row {
    padding-left: .75rem !important;
    padding-right: .75rem !important;
    gap: .35rem 0;
}

.iris-report-filter > .row > [class*="col"] {
    flex: 1 1 220px;
    min-width: 190px;
    margin-bottom: .35rem;
}

.iris-report-filter .input-group-text {
    min-width: 2.25rem;
    justify-content: center;
}

.iris-report-filter .form-check-input {
    margin: 0;
}

.iris-report-filter.is-collapsed {
    display: none;
}

.iris-report-filter-toggle {
    --iris-filter-toggle-bg: color-mix(in srgb, var(--bs-primary) 10%, var(--bs-body-bg));
    --iris-filter-toggle-border: color-mix(in srgb, var(--bs-primary) 42%, var(--bs-border-color));
    --iris-filter-toggle-color: var(--bs-primary);
    align-items: center;
    background: var(--iris-filter-toggle-bg);
    border-color: var(--iris-filter-toggle-border);
    color: var(--iris-filter-toggle-color);
    display: inline-flex;
    font-weight: 600;
    gap: .4rem;
    line-height: 1.2;
    padding: .28rem .6rem;
    white-space: nowrap;
}

.iris-report-filter-toggle:hover,
.iris-report-filter-toggle:focus {
    background: color-mix(in srgb, var(--bs-primary) 16%, var(--bs-body-bg));
    border-color: color-mix(in srgb, var(--bs-primary) 58%, var(--bs-border-color));
    color: var(--bs-primary);
}

.iris-report-filter-toggle.is-collapsed {
    --iris-filter-toggle-bg: var(--bs-primary);
    --iris-filter-toggle-border: var(--bs-primary);
    --iris-filter-toggle-color: var(--bs-white);
    box-shadow: 0 .125rem .35rem rgba(var(--bs-primary-rgb), .22);
}

.iris-report-filter-toggle.is-collapsed:hover,
.iris-report-filter-toggle.is-collapsed:focus {
    background: color-mix(in srgb, var(--bs-primary) 88%, var(--bs-black));
    border-color: color-mix(in srgb, var(--bs-primary) 88%, var(--bs-black));
    color: var(--bs-white);
}

.iris-report-filter-toggle .fa,
.iris-report-filter-toggle .far,
.iris-report-filter-toggle .fas {
    flex: 0 0 auto;
}

.admin-personnels-page .personnels-filter {
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
}

.admin-personnels-page .iris-report-filter > .row {
    padding-left: .75rem !important;
    padding-right: .75rem !important;
    gap: .35rem 0;
}

.admin-personnels-page .iris-report-filter .input-group-text {
    min-width: 2.25rem;
    justify-content: center;
}

.iris-report-actions {
    display: flex;
    gap: .35rem;
    justify-content: flex-end;
    flex-wrap: wrap;
}

.iris-road-list-status {
    width: 2rem;
    min-width: 2rem;
    padding-left: 0;
    padding-right: 0;
}

.person-tabs-wrap {
    display: flex;
    justify-content: flex-end;
    overflow-x: auto;
}

.person-data-toolbar .person-data-heading {
    min-width: 0;
}

.person-data-toolbar .sales-docs-title {
    align-items: flex-start;
    line-height: 1.2;
    margin-bottom: .15rem;
}

.person-data-toolbar .sales-docs-subtitle {
    display: block;
    max-width: 100%;
    padding-left: 1.65rem;
    line-height: 1.25;
    white-space: normal;
    word-break: break-word;
}

.person-data-tabs .person-tabs-wrap {
    justify-content: flex-start;
}

.person-data-page .input-group-sm > .form-control-inp200,
.person-data-page .input-group-sm > .form-control-inp175,
.person-data-page .input-group-sm > .form-control-select200 {
    width: auto;
    min-width: 0;
    flex: 1 1 auto;
}

.person-info-page {
    min-height: 100%;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.person-info-body {
    max-height: calc(100vh - 8rem);
    overflow-y: auto;
    overflow-x: hidden;
}

.person-info-section {
    padding: .55rem 0;
    border-bottom: 1px solid var(--bs-border-color);
}

.person-info-section:first-child {
    padding-top: 0;
}

.person-info-section-title {
    display: flex;
    align-items: center;
    gap: .45rem;
    margin-bottom: .45rem;
    color: var(--bs-emphasis-color);
    font-weight: 600;
}

.person-info-photo-panel {
    position: sticky;
    top: .75rem;
    display: flex;
    flex-direction: column;
    gap: .5rem;
    padding: .75rem;
    border: 1px solid var(--bs-border-color);
    border-radius: var(--bs-border-radius-sm);
    background: var(--bs-tertiary-bg);
}

.person-info-photo {
    width: 100%;
    max-width: 150px;
    aspect-ratio: 11 / 13.5;
    object-fit: cover;
    align-self: center;
    border: 1px solid var(--bs-border-color);
    border-radius: var(--bs-border-radius-sm);
    background: var(--bs-body-bg);
}

.person-info-photo-empty {
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--bs-secondary-color);
    font-size: 2.25rem;
}

.person-info-address-num {
    max-width: 3.5rem;
    text-align: right;
}

.person-info-note {
    min-height: 11.6rem;
    resize: vertical;
}

.person-info-actions {
    border-top: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
}

.person-data-backdrop {
    position: fixed;
    inset: 0;
    z-index: 1040;
    display: none;
    background: rgba(0, 0, 0, .45);
}

.person-data-history-result {
    min-height: 110px !important;
    max-height: 12rem;
    overflow: auto;
}

.person-data-salary-dialog {
    position: fixed;
    top: 4rem;
    left: 50%;
    z-index: 1050;
    display: none;
    width: min(92vw, 30rem);
    max-height: calc(100vh - 6rem);
    overflow: auto;
    padding: .75rem;
    border: 1px solid var(--bs-border-color);
    border-radius: var(--bs-border-radius-sm);
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    box-shadow: 0 .75rem 2rem rgba(0, 0, 0, .18);
    transform: translateX(-50%);
}

@media (max-width: 576px) {
    .iris-report-filter > .row {
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }

    .iris-report-filter > .row > [class*="col"] {
        flex-basis: 100%;
        min-width: 0;
    }

    .admin-personnels-page .iris-report-filter > .row {
        padding-left: .5rem !important;
        padding-right: .5rem !important;
    }

}

@media (max-width: 768px) {
    .iris-report-filter {
        max-height: calc(100dvh - 8rem);
        overflow-y: auto;
        overflow-x: hidden;
        border-bottom: 1px solid var(--bs-border-color);
        -webkit-overflow-scrolling: touch;
    }

    .admin-personnels-page .iris-report-filter {
        max-height: calc(100dvh - 8rem);
        overflow-y: auto;
        overflow-x: hidden;
        border-bottom: 1px solid var(--bs-border-color);
        -webkit-overflow-scrolling: touch;
    }

    .iris-report-actions {
        justify-content: stretch;
    }

    .iris-report-actions .btn {
        flex: 1 1 auto;
    }

    .person-info-body {
        max-height: none;
    }

    .person-info-photo-panel {
        position: static;
    }
}

.sales-docs-page .date-picker-trigger {
    cursor: pointer;
}

.sales-docs-page .sales-docs-filter .input-group > .btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.currency-movement-page .iris-currency-total {
    background: color-mix(in srgb, var(--bs-success-bg-subtle) 55%, var(--bs-body-bg));
    color: var(--bs-emphasis-color);
    font-weight: 600;
}

.money-nomenclatures-page .date-picker-trigger {
    cursor: pointer;
}

.money-nomenclatures-page .money-nomenclatures-totals .input-group-text {
    min-width: 9.5rem;
    justify-content: flex-start;
}

.money-nomenclatures-popup-result #result {
    min-height: 360px;
}

.money-nomenclatures-filter-page .popup-body {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.money-nomenclatures-filter-page .money-filter-fields .form-check {
    padding-top: .25rem;
    padding-bottom: .25rem;
}

.order-popup-page {
    min-height: 100vh;
    min-height: 100dvh;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.order-popup-form {
    min-height: 100vh;
    min-height: 100dvh;
    display: flex;
    flex-direction: column;
}

.order-tabs-wrap {
    margin-bottom: 0;
}

.order-popup-filter {
    border-bottom: 1px solid var(--bs-border-color);
}

.order-popup-filter .date-picker-trigger {
    cursor: pointer;
}

.order-popup-body {
    min-height: 0;
    flex: 1 1 auto;
    overflow: hidden;
}

.order-popup-body #result {
    height: 100%;
    min-height: 300px;
}

.order-popup-body .iris-result-shell,
.order-popup-body .iris-result-scroll {
    max-height: none;
}

.order-info-panel {
    height: 100%;
    border: 1px solid var(--bs-border-color);
    border-radius: .35rem;
    background: var(--bs-body-bg);
    padding: 1rem;
}

.order-info-balances #result {
    min-height: 260px;
}

.order-doc-link {
    cursor: pointer;
}

.order-popup-actions {
    flex: 0 0 auto;
    border-top: 1px solid var(--bs-border-color);
    background: var(--bs-tertiary-bg);
}

.buy-docs-filter-page {
    height: 100vh;
    height: 100dvh;
    max-height: 100vh;
    max-height: 100dvh;
    min-height: 0;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    display: flex;
    flex-direction: column;
    overflow: hidden;
}

.buy-docs-filter-page .popup-actions {
    border-color: var(--bs-border-color);
    background: var(--bs-tertiary-bg);
}

.buy-docs-filter-page .popup-actions {
    border-top: 1px solid var(--bs-border-color);
    display: flex;
    justify-content: flex-end;
    gap: .5rem;
    flex: 0 0 auto;
}

.buy-docs-filter-page .buy-docs-filter-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    overscroll-behavior: contain;
    scrollbar-width: thin;
    -webkit-overflow-scrolling: touch;
}

.buy-docs-filter-page .filter-panel {
    border: 1px solid var(--bs-border-color);
    border-radius: .45rem;
    background: color-mix(in srgb, var(--bs-body-bg) 96%, var(--bs-tertiary-bg));
    padding: .9rem;
    margin-bottom: .75rem;
}

.buy-docs-filter-page .section-title {
    display: flex;
    align-items: center;
    gap: .45rem;
    margin-bottom: .75rem;
    color: var(--bs-emphasis-color);
    font-weight: 600;
}

.buy-docs-filter-page .period-select {
    flex: 0 0 4.25rem;
    max-width: 4.25rem;
}

.buy-docs-filter-page .date-picker-trigger {
    cursor: pointer;
}

.buy-docs-filter-page .dual-list {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    gap: .5rem;
    align-items: center;
}

.buy-docs-filter-page .dual-list select {
    min-height: 9rem;
}

.buy-docs-filter-page .dual-list-actions {
    display: flex;
    flex-direction: column;
    gap: .35rem;
}

@media (max-width: 575.98px) {
    .buy-docs-filter-page .dual-list {
        grid-template-columns: 1fr;
    }

    .buy-docs-filter-page .dual-list-actions {
        flex-direction: row;
        justify-content: center;
    }
}

.iris-tabs-wrap {
    display: flex;
    justify-content: flex-start;
    overflow-x: auto;
    padding: .25rem 0 .35rem;
}

.iris-tabs,
.finance-tabs {
    --bs-nav-tabs-border-color: var(--bs-border-color);
    --bs-nav-tabs-link-hover-border-color: var(--bs-border-color) var(--bs-border-color) transparent;
    gap: .12rem;
    margin-bottom: 0;
    border-bottom-color: var(--bs-border-color);
    overflow-x: auto;
    overflow-y: hidden;
    flex-wrap: nowrap;
    scrollbar-width: thin;
    padding-top: .1rem;
}

.iris-tabs:has(.dropdown.show),
.finance-tabs:has(.dropdown.show),
.iris-tabs.iris-tabs-dropdown-open,
.finance-tabs.iris-tabs-dropdown-open {
    overflow: visible;
}

.iris-tabs .nav-item,
.finance-tabs .nav-item,
.iris-tabs > li {
    margin-bottom: 0;
}

.iris-tabs .nav-link,
.finance-tabs .nav-link,
.iris-tabs > li > a {
    color: var(--bs-body-color);
    background: color-mix(in srgb, #98c1d9 24%, var(--bs-tertiary-bg));
    border-color: color-mix(in srgb, #98c1d9 32%, var(--bs-border-color));
    border: 1px solid color-mix(in srgb, #98c1d9 32%, var(--bs-border-color));
    border-radius: var(--bs-nav-tabs-border-radius, .375rem) var(--bs-nav-tabs-border-radius, .375rem) 0 0;
    white-space: nowrap;
    min-height: 2.15rem;
    padding: .48rem .72rem;
    display: inline-flex;
    align-items: center;
    line-height: 1.1;
    text-decoration: none;
}

.iris-tabs .nav-link:hover,
.iris-tabs .nav-link:focus,
.finance-tabs .nav-link:hover,
.finance-tabs .nav-link:focus,
.iris-tabs > li > a:hover,
.iris-tabs > li > a:focus {
    color: var(--bs-emphasis-color);
    background: color-mix(in srgb, #98c1d9 36%, var(--bs-tertiary-bg));
    border-color: color-mix(in srgb, #98c1d9 44%, var(--bs-border-color));
}

.iris-tabs .nav-link.active,
.finance-tabs .nav-link.active,
.iris-tabs > li.active > a,
.iris-tabs > li > a.active {
    color: var(--bs-emphasis-color);
    background: var(--bs-body-bg);
    border-color: color-mix(in srgb, #98c1d9 58%, var(--bs-border-color));
    border-bottom-color: var(--bs-body-bg);
    font-weight: 600;
}

.iris-tabs .nav-link.disabled,
.iris-tabs > li > a.disabled {
    color: var(--bs-secondary-color);
    pointer-events: none;
    background: var(--bs-tertiary-bg);
    border-color: var(--bs-border-color);
    opacity: .72;
}

.iris-tabs .dropdown-menu {
    font-size: .84rem;
    min-width: 12rem;
    margin-top: .1rem;
    z-index: 1080;
}

.iris-tabs .dropdown.show {
    position: relative;
    z-index: 1081;
}

.iris-tabs .dropdown-menu > li > a,
.iris-tabs .dropdown-item {
    display: block;
    width: 100%;
    padding: .42rem .75rem;
    clear: both;
    color: var(--bs-body-color);
    text-decoration: none;
    white-space: nowrap;
    background-color: transparent;
    border: 0;
}

.iris-tabs .dropdown-menu > li > a:hover,
.iris-tabs .dropdown-menu > li > a:focus,
.iris-tabs .dropdown-item:hover,
.iris-tabs .dropdown-item:focus {
    color: var(--bs-emphasis-color);
    background-color: var(--bs-tertiary-bg);
}

.iris-tabs .dropdown-menu > li.active > a,
.iris-tabs .dropdown-item.active {
    color: #fff;
    background-color: var(--bs-primary);
}

.iris-tabs .dropdown-menu > li > a.disabled,
.iris-tabs .dropdown-item.disabled {
    color: var(--bs-secondary-color);
    pointer-events: none;
    background-color: transparent;
    opacity: .72;
}

.view-firm-balances-page table.result tbody tr[id] {
    --row-bg: var(--bs-info-bg-subtle) !important;
}

.view-firm-balances-page table.result tbody tr[id*="@"] {
    --row-bg: var(--bs-warning-bg-subtle) !important;
}

.view-firm-balances-page table.result tbody tr[id^="@@"] {
    --row-bg: var(--bs-success-bg-subtle) !important;
    font-weight: 700;
}

.view-firm-balances-page table.result tbody tr[id*="@"] td:nth-child(2) {
    padding-left: 1.85rem !important;
    padding-right: .25rem !important;
}

.person-shift-popup {
    min-height: 100vh;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.person-shift-popup .person-shift-title {
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-tertiary-bg);
}

.person-shift-popup .person-shift-actions {
    border-top: 1px solid var(--bs-border-color);
    background: var(--bs-tertiary-bg);
}

:is(.salary-popup, .position-popup) {
    min-height: 100vh;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

:is(.salary-popup .salary-title, .position-popup .position-title) {
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-tertiary-bg);
}

.salary-popup .salary-scroll {
    max-height: calc(100vh - 92px);
    overflow: auto;
}

.position-popup .position-scroll {
    max-height: calc(100vh - 92px);
    overflow: auto;
    padding-bottom: 1rem;
}

.position-popup .firm-pick-list {
    min-height: 10rem;
}

.position-popup .firm-transfer-buttons {
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: .35rem;
}

@media (max-width: 767.98px) {
    :is(.salary-popup .salary-scroll, .position-popup .position-scroll) {
        max-height: none;
    }

    .position-popup .firm-transfer-buttons {
        flex-direction: row;
        padding: .25rem 0;
    }
}

.center {
    position: relative;
    margin: 0 auto;
}

.summary-finances-notice {
    white-space: nowrap;
}

.summary-finances-frame-grid {
    display: grid;
    grid-template-rows: minmax(10rem, 30%) minmax(18rem, 70%);
    gap: .5rem;
    height: calc(100vh - 9.25rem);
    min-height: 34rem;
    padding: .5rem;
}

.summary-finances-frame {
    width: 100%;
    height: 100%;
    border: 1px solid var(--bs-border-color);
    border-radius: .35rem;
    background: var(--bs-body-bg);
}

.summary-result-page {
    min-height: 100%;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.summary-result-page #result {
    min-height: 12rem;
}

.summary-popup-page {
    min-height: 100vh;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.summary-popup-filter {
    border-bottom: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
}

.summary-chart-scroll {
    width: min(100%, 720px);
    height: min(500px, calc(100vh - 1rem));
    overflow: auto;
    margin: 0 auto;
}

.summary-region-header,
.myheader,
table.result td.summary-region-header,
table.result td.myheader {
    --row-bg: var(--iris-result-header-bg, #265E86);
    font-size: .75rem;
    font-weight: 700;
    height: 1.5rem;
    text-align: center;
    vertical-align: middle;
    color: #fff;
    border-right: 1px solid var(--iris-result-header-border, #81bedc);
    border-bottom: 1px solid var(--iris-result-header-border, #81bedc);
    background-color: var(--iris-result-header-bg, #265E86) !important;
}

.summary-region-header-light,
.myheaderlight,
table.result td.summary-region-header-light,
table.result td.myheaderlight {
    --row-bg: var(--iris-result-header-bg, #265E86);
    font-size: .75rem;
    font-weight: 700;
    height: 1.5rem;
    text-align: center;
    vertical-align: middle;
    color: #fff;
    border-right: 1px solid var(--iris-result-header-border, #81bedc);
    border-bottom: 1px solid var(--iris-result-header-border, #81bedc);
    background-color: var(--iris-result-header-bg, #265E86) !important;
}

.summary-link {
    font-weight: 700;
    color: var(--bs-primary);
    text-align: right;
    cursor: pointer;
}

.summary-progress {
    display: inline-block;
    width: var(--summary-progress-width, 0px);
    max-width: 100%;
    height: .75rem;
    border-radius: 999px;
    vertical-align: middle;
}

.summary-progress-positive {
    background: var(--bs-primary);
}

.summary-progress-negative {
    background: var(--bs-danger);
}

table.result tr.summary-change-minus > td {
    --row-bg: #ffbaba;
}

table.result tr.summary-change-plus > td {
    --row-bg: #babaff;
}

[data-bs-theme="dark"] table.result tr.summary-change-minus > td {
    --row-bg: #5f2931;
}

[data-bs-theme="dark"] table.result tr.summary-change-plus > td {
    --row-bg: #253b63;
}

table.result td.summary-separator {
    height: 30px;
    background: var(--bs-tertiary-bg) !important;
}

@media (max-width: 767.98px) {
    .summary-finances-frame-grid {
        grid-template-rows: minmax(12rem, 35%) minmax(18rem, 65%);
        height: calc(100vh - 12rem);
        min-height: 32rem;
    }

    .summary-finances-notice {
        white-space: normal;
    }
}

[data-bs-theme="dark"] .bg-light,
[data-bs-theme="dark"] .bg-white,
[data-bs-theme="dark"] form.bg-light,
[data-bs-theme="dark"] .fixed-bottom.bg-white {
    background-color: var(--bs-body-bg) !important;
    color: var(--bs-body-color) !important;
}

[data-bs-theme="dark"] .page_caption,
[data-bs-theme="dark"] .input-group-text,
[data-bs-theme="dark"] .form-control,
[data-bs-theme="dark"] select,
[data-bs-theme="dark"] textarea {
    background-color: var(--bs-tertiary-bg);
    color: var(--bs-body-color);
    border-color: var(--bs-border-color);
}

[data-bs-theme="dark"] #result {
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
}

html,
body {
    min-height: 100%;
}

body.iris-shell {
    height: 100vh;
    overflow: hidden;
    background-color: var(--bs-body-bg);
    color: var(--bs-body-color);
}

.navbar.bg-iris,
.bg-iris {
    background-color: var(--iris-nav-bg) !important;
}

.iris-navbar {
    min-height: var(--iris-nav-height);
    z-index: 1111;
}

.iris-navbar .nav-link,
.iris-navbar .dropdown-item {
    color: var(--iris-nav-text) !important;
}

.iris-navbar .nav-link:hover,
.iris-navbar .nav-link:focus,
.iris-navbar .dropdown-item:hover,
.iris-navbar .dropdown-item:focus {
    color: var(--iris-nav-text) !important;
    background-color: var(--iris-dropdown-hover);
}

.iris-navbar-collapse {
    background-color: var(--iris-nav-bg);
}

.dropdown-menu.bg-iris {
    background-color: var(--iris-dropdown-bg) !important;
    border-color: rgba(255, 255, 255, 0.16);
}

.iris-theme-toggle {
    width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.iris-content-frame,
#content {
    display: block;
    width: 100%;
    height: calc(100vh - var(--iris-nav-height));
    border: 0;
    background-color: var(--bs-body-bg);
}

.input-group-text {
    min-width: 32px;
    justify-content: center;
}

.fixed-bottom.text-end,
.fixed-bottom .text-end {
    background-color: var(--bs-body-bg);
}

@media (min-width: 1200px) {
    .dropdown-submenu {
        position: relative;
    }

    .dropdown-submenu > .dropdown-menu {
        top: 0;
        left: 100%;
        margin-top: -0.125rem;
    }

    .dropdown-submenu:hover > .dropdown-menu,
    .dropdown-submenu:focus-within > .dropdown-menu {
        display: block;
    }
}

@media (max-width: 1199.98px) {
    .iris-navbar .navbar-collapse {
        max-height: calc(100vh - var(--iris-nav-height));
        overflow-y: auto;
        padding: 0.5rem 0;
    }

    .iris-navbar .dropdown-menu {
        border: 0;
        box-shadow: none;
        margin-left: 0.75rem;
    }

    .dropdown-submenu > .dropdown-menu {
        display: block;
        position: static;
    }

    .iris-theme-toggle {
        margin: 0.25rem 0.75rem;
    }
}



/* SCROLL контейнер */
.result_data {
    overflow: auto;
    position: relative;
    max-width: 100%;
    scrollbar-gutter: stable;
}

/* Таблица */
table.result {
    border-collapse: separate;
    border-spacing: 0;
    width: max-content;
    min-width: 100%;
}

table.result tbody tr.iris-result-row-odd {
    --row-bg: var(--iris-result-row-odd);
}

table.result tbody tr.iris-result-row-even {
    --row-bg: var(--iris-result-row-even);
}

table.result tbody tr:hover {
    --row-bg: var(--iris-result-row-hover);
}

table.result tbody tr.iris-result-row-selected,
table.result tbody tr.iris-result-row-selected:hover {
    --row-bg: var(--iris-result-row-selected);
}

table.result tbody tr > td {
    background-color: var(--row-bg, var(--bs-body-bg)) !important;
    transition: background-color .12s ease;
}

table.result th.iris-result-icon-col,
table.result td.iris-result-icon-col {
    width: 1%;
    min-width: 2.15rem;
    max-width: 2.65rem;
    padding-left: .35rem !important;
    padding-right: .35rem !important;
    text-align: center !important;
    white-space: nowrap;
}

table.result th.iris-result-icon-col > i,
table.result td.iris-result-icon-col > i,
table.result td.iris-result-icon-col .iris-result-status-icon > i,
table.result td.iris-result-icon-col .iris-result-icon-button > i {
    display: block;
    margin: 0 auto;
}

table.result th.iris-result-icon-col img,
table.result td.iris-result-icon-col img {
    display: block;
    width: 1em;
    height: 1em;
    object-fit: contain;
    margin: 0 auto;
}

table.result th.iris-result-sort-active {
    background: color-mix(in srgb, var(--iris-result-header-bg, #265E86) 88%, #ffffff) !important;
    color: #ffffff !important;
    box-shadow: inset 0 -2px 0 color-mix(in srgb, var(--bs-warning, #ffc107) 80%, #ffffff);
}

table.result th .iris-result-sort-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: .25rem;
    width: 100%;
    min-width: 0;
}

table.result th .iris-result-sort-caption {
    min-width: 0;
}

table.result th .iris-result-sort-icon {
    flex: 0 0 auto;
    font-size: .72rem;
    line-height: 1;
    opacity: .95;
}

table.result td.summary-region-header,
table.result td.myheader,
table.result td.summary-region-header-light,
table.result td.myheaderlight {
    --row-bg: var(--iris-result-header-bg, #265E86) !important;
    background-color: var(--iris-result-header-bg, #265E86) !important;
    color: #ffffff !important;
}

table.result td.iris-result-icon-col .btn.iris-result-icon-button {
    width: 1.55rem;
    height: 1.45rem;
    padding: 0;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

 /*sticky cells*/
table.result th[data-sticky],
table.result td[data-sticky] {
    position: sticky;
    background-color: var(--row-bg, inherit);
    background-clip: padding-box;
    box-sizing: border-box;

    /* Визуален border вдясно */
    box-shadow: inset -2px 0 0 var(--iris-result-header-border, #81bedc);
    overflow: hidden;
    text-overflow: ellipsis;
}

table.result td[data-sticky] {
    z-index: 10;
}

/* header */
table.result thead th {
    position: sticky;
    top: 0;
    z-index: 40;
    background: var(--iris-result-header-bg, #265E86);
}

table.result thead th[data-sticky] {
    z-index: 80 !important;
}

table.result thead th[data-sticky-col] {
    cursor: pointer;
    transition: background-color 0.15s ease, box-shadow 0.15s ease;
}

table.result thead th[data-sticky-col]:hover {
    background: var(--iris-result-header-active-bg, #2E8BB8);
}

table.result thead th.sticky-selected {
    background: var(--iris-result-header-active-bg, #2E8BB8) !important;
    box-shadow: inset 0 -3px 0 var(--bs-warning, #ffc107);
}

/* Последната sticky колона – по-дебел ръб */
table.result th[data-sticky].sticky-last,
table.result td[data-sticky].sticky-last {
    box-shadow: inset -3px 0 0 var(--iris-result-header-bg, #265E86);
    padding-right: 10px;
}

table.result thead th.sticky-selected.sticky-last {
    box-shadow:
        inset -3px 0 0 var(--iris-result-header-bg, #265E86),
        inset 0 -3px 0 var(--bs-warning, #ffc107);
}


/* при активен ред */
table.result tr.active {
    --row-bg: var(--iris-result-row-selected);
}

/* hover */
table.result tr:hover {
    --row-bg: var(--iris-result-row-hover);
}

.iris-result-paging {
    border: 1px solid var(--bs-border-color);
    border-radius: .35rem .35rem 0 0;
    background: color-mix(in srgb, var(--bs-tertiary-bg) 82%, transparent);
    box-shadow: inset 0 -1px 0 rgba(0, 0, 0, .035);
    grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
    min-height: 2.15rem;
}

.iris-result-paging-summary {
    font-weight: 600;
    white-space: nowrap;
    text-align: center;
    justify-self: center;
}

.iris-result-paging-left {
    min-width: 0;
    justify-self: start;
}

.iris-result-paging-controls {
    display: inline-flex;
    align-items: center;
    gap: .2rem;
    justify-self: end;
}

.iris-result-paging-controls .btn {
    width: 1.9rem;
    height: 1.55rem;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}

.iris-result-status-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.25rem;
    line-height: 1;
}

.iris-result-paging-controls .form-control {
    height: 1.55rem;
    min-width: 4rem;
    padding-top: .05rem;
    padding-bottom: .05rem;
}

.iris-result-exportbar {
    z-index: 1050;
    border-top: 1px solid var(--bs-border-color);
    background: color-mix(in srgb, var(--bs-body-bg) 94%, transparent);
    box-shadow: 0 -.35rem 1rem rgba(0, 0, 0, .08);
}

.iris-result-operations {
    min-width: 0;
}

.iris-result-operation-group {
    width: auto;
    max-width: 245px;
    flex-wrap: nowrap;
}

.iris-result-operation-group .form-select {
    flex: 0 1 175px;
    max-width: 175px;
    min-width: 0;
    height: 1.55rem;
    padding-top: .05rem;
    padding-bottom: .05rem;
    font-size: .72rem;
    line-height: 1.1;
}

.iris-result-operation-group .input-group-text {
    height: 1.55rem;
    padding: .05rem .4rem;
    font-size: .72rem;
}

.iris-result-operation-group .btn {
    height: 1.55rem;
    min-width: 3.65rem;
    padding: .05rem .45rem;
    font-size: .72rem;
    line-height: 1.1;
}

@media (max-width: 767.98px) {
    .iris-result-paging {
        grid-template-columns: 1fr;
    }

    .iris-result-paging-left,
    .iris-result-paging-summary,
    .iris-result-paging-controls {
        justify-self: stretch;
    }

    .iris-result-paging-summary {
        text-align: left;
    }

    .iris-result-operation-group {
        max-width: 100%;
    }

    .iris-result-operation-group .form-select {
        flex: 1 1 auto;
        max-width: none;
    }
}

.result_total td,
table.result_total td {
    --row-bg: var(--bs-success-bg-subtle, #d1e7dd);
    border-bottom: 1px solid color-mix(in srgb, var(--bs-success, #198754) 30%, var(--bs-border-color));
    background: var(--row-bg) !important;
    color: var(--bs-emphasis-color);
    font-weight: 700;
}

[data-bs-theme="dark"] .result_total td,
[data-bs-theme="dark"] table.result_total td {
    --row-bg: color-mix(in srgb, var(--bs-success-bg-subtle, #12281f) 82%, var(--bs-body-bg));
}

.result_data {
    padding-bottom: .75rem;
}

[data-bs-theme="dark"] .iris-result-paging {
    background: color-mix(in srgb, var(--bs-tertiary-bg) 88%, transparent);
    box-shadow: inset 0 -1px 0 rgba(255, 255, 255, .04);
}

[data-bs-theme="dark"] .iris-result-exportbar {
    background: color-mix(in srgb, var(--bs-body-bg) 92%, transparent);
    box-shadow: 0 -.35rem 1rem rgba(0, 0, 0, .35);
}

.iris-popup-page,
.client-calls-popup,
.client-info-popup,
.client-mail-popup,
.client-objects-popup,
.client-payments-popup,
.object-info-page,
.object-messages-popup,
.object-archive-popup,
.object-geo-popup,
.object-parts-popup,
.object-support-popup,
.object-taxes-popup,
.object-zone-popup,
.object-support-tech-popup,
.direction-funds-popup,
.set-object-client-popup,
.set-setup-tech-request-popup,
.limit-card-popup,
.signal-message-popup,
.sot-schedule-popup {
    min-height: 100vh;
    min-height: 100dvh;
    background: var(--bs-body-bg);
    color: var(--bs-body-color);
    font-size: .85rem;
}

.client-calls-popup,
.client-mail-popup,
.client-objects-popup,
.client-payments-popup,
.object-messages-popup,
.object-archive-popup,
.object-geo-popup,
.object-parts-popup,
.object-support-popup,
.object-taxes-popup,
.object-zone-popup,
.object-support-tech-popup,
.direction-funds-popup,
.set-object-client-popup,
.set-setup-tech-request-popup,
.limit-card-popup,
.signal-message-popup,
.sot-schedule-popup {
    height: 100vh;
    height: 100dvh;
    min-height: 0;
    overflow: hidden;
}

.client-payments-popup {
    padding-bottom: 2.75rem;
}

.object-archive-popup {
    padding-bottom: 2.75rem;
}

.object-parts-popup,
.object-geo-popup,
.object-support-popup,
.object-taxes-popup,
.object-zone-popup {
    overflow-x: hidden;
    padding-bottom: 2.75rem;
}

.iris-popup-title {
    align-items: center;
    border: 0 solid #81bedc !important;
    background-color: var(--iris-result-caption-bg);
    color: #ffffff;
    display: flex;
    flex: 0 0 auto;
    font-size: 14px;
    font-weight: normal;
    gap: .5rem;
    height: 32px;
    justify-content: space-between;
    line-height: 30px !important;
    min-height: 32px;
    padding: 1px .5rem 0 6px !important;
}

.client-info-scroll,
.object-info-scroll {
    max-height: calc(100vh - 120px);
    overflow: auto;
}

.client-objects-scroll {
    min-height: 0;
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.iris-popup-page .section-panel,
.client-calls-popup .section-panel,
.client-info-popup .section-panel,
.client-mail-popup .section-panel,
.client-objects-popup .section-panel,
.client-payments-popup .section-panel,
.object-info-page .section-panel,
.object-messages-popup .section-panel,
.object-archive-popup .section-panel,
.object-geo-popup .section-panel,
.object-parts-popup .section-panel,
.object-support-popup .section-panel,
.object-taxes-popup .section-panel,
.object-zone-popup .section-panel,
.set-setup-object-popup .section-panel,
.set-setup-object-tax-popup .section-panel,
.direction-funds-popup .section-panel,
.set-object-client-popup .section-panel,
.set-setup-tech-request-popup .section-panel,
.limit-card-popup .section-panel,
.signal-message-popup .section-panel,
.sot-schedule-popup .section-panel {
    border-bottom: 1px solid var(--bs-border-color);
    padding: .75rem .85rem;
}

.client-calls-popup .section-panel.result-panel,
.client-mail-popup .section-panel.result-panel,
.client-objects-popup .section-panel.result-panel,
.client-payments-popup .section-panel.result-panel,
.object-messages-popup .section-panel.result-panel {
    padding: 0;
    min-height: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.client-calls-popup #result,
.client-mail-popup #result,
.client-payments-popup #result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.client-calls-popup #result {
    display: flex;
    flex-direction: column;
    height: auto !important;
    overflow: hidden;
}

.client-payments-popup #result {
    display: flex;
    flex-direction: column;
    height: auto !important;
    overflow: hidden;
}

.client-calls-popup #result .result_data {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.client-payments-popup #result .result_data {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.client-payments-popup #result .result_foother {
    flex: 0 0 auto;
}

.section-title {
    align-items: center;
    background: #dfdfdf;
    color: var(--bs-emphasis-color);
    display: flex;
    font-size: .85rem;
    font-weight: 600;
    gap: .5rem;
    margin: 0 0 .5rem;
    min-height: 1.75rem;
    padding: .25rem .5rem;
}

.finished {
    text-decoration: line-through;
}

.client-mail-toolbar {
    align-items: center;
    background: #f5f5f5;
    border-bottom: 1px solid #d8d8d8;
    display: flex;
    gap: .5rem;
    justify-content: space-between;
    padding: .5rem;
}

.client-calls-toolbar {
    align-items: center;
    background: #f5f5f5;
    border-bottom: 1px solid #d8d8d8;
    display: flex;
    gap: .5rem;
    justify-content: flex-end;
    padding: .5rem .75rem;
}

.client-calls-type {
    max-width: 14rem;
}

.client-mail-toolbar-group {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .5rem;
}

.client-mail-toolbar .btn {
    align-items: center;
    display: inline-flex;
    gap: .25rem;
    white-space: nowrap;
}

.btn-iris-close {
    --bs-btn-bg: var(--bs-light);
    --bs-btn-border-color: var(--bs-danger);
    --bs-btn-color: var(--bs-danger);
    --bs-btn-hover-bg: var(--bs-danger);
    --bs-btn-hover-border-color: var(--bs-danger);
    --bs-btn-hover-color: #fff;
    --bs-btn-active-bg: var(--bs-danger);
    --bs-btn-active-border-color: var(--bs-danger);
    --bs-btn-active-color: #fff;
    background: var(--bs-light) !important;
    border-color: var(--bs-danger) !important;
    color: var(--bs-danger) !important;
}

.btn-iris-close:hover,
.btn-iris-close:focus {
    background: var(--bs-danger) !important;
    border-color: var(--bs-danger) !important;
    color: #fff !important;
}

.btn-iris-save {
    --bs-btn-bg: var(--bs-success);
    --bs-btn-border-color: var(--bs-success);
    --bs-btn-color: #fff;
    --bs-btn-hover-bg: color-mix(in srgb, var(--bs-success) 88%, #000);
    --bs-btn-hover-border-color: color-mix(in srgb, var(--bs-success) 88%, #000);
    --bs-btn-hover-color: #fff;
    background: var(--bs-success) !important;
    border-color: var(--bs-success) !important;
    color: #fff !important;
}

.iris-popup-page .input-group-text,
.client-info-popup .input-group-text,
.client-objects-popup .input-group-text,
.object-info-page .input-group-text,
.object-messages-popup .input-group-text,
.object-archive-popup .input-group-text,
.object-geo-popup .input-group-text,
.object-parts-popup .input-group-text,
.object-support-popup .input-group-text,
.object-taxes-popup .input-group-text,
.object-zone-popup .input-group-text,
.set-setup-object-popup .input-group-text,
.set-setup-object-tax-popup .input-group-text,
.direction-funds-popup .input-group-text,
.set-object-client-popup .input-group-text,
.signal-message-popup .input-group-text {
    justify-content: center;
    min-width: 2.35rem;
}

.iris-popup-page .form-label,
.client-info-popup .form-label,
.client-objects-popup .form-label,
.object-info-page .form-label,
.object-messages-popup .form-label,
.object-archive-popup .form-label,
.object-geo-popup .form-label,
.object-parts-popup .form-label,
.object-support-popup .form-label,
.object-taxes-popup .form-label,
.object-zone-popup .form-label,
.set-setup-object-popup .form-label,
.set-setup-object-tax-popup .form-label,
.direction-funds-popup .form-label,
.set-object-client-popup .form-label,
.signal-message-popup .form-label {
    margin-bottom: .15rem;
}

.client-info-popup .confirm-check {
    justify-content: center;
    min-width: 2.75rem;
}

.client-info-popup .confirm-ok {
    color: var(--bs-success);
    display: none;
}

.client-info-popup textarea.form-control {
    min-height: 2.3rem;
    resize: vertical;
}

.object-info-page textarea.form-control {
    min-height: 5.4rem;
    resize: vertical;
}

.client-info-popup .client-actions,
.object-actions,
.object-messages-actions,
.sot-schedule-actions {
    position: sticky;
    bottom: 0;
    z-index: 20;
    border-top: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
}

.client-objects-popup #result {
    min-height: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.object-archive-actions-wrap {
    z-index: 1030;
    border-top: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    box-shadow: 0 -.35rem .85rem rgba(0, 0, 0, .08);
    padding: .25rem .45rem;
}

.object-messages-tabs {
    flex: 0 0 auto;
}

.object-messages-toolbar {
    flex: 0 0 auto;
}

.object-messages-check {
    min-height: 1.95rem;
    display: flex;
    align-items: center;
    gap: .45rem;
}

.object-messages-check .form-check-input {
    margin-top: 0;
}

.object-messages-result {
    min-height: 0;
    flex: 1 1 auto;
}

.object-messages-popup #result {
    min-height: 0;
    flex: 1 1 auto;
    display: flex;
    flex-direction: column;
}

.signal-message-scroll {
    min-height: 0;
    overflow: auto;
    padding-bottom: 3.5rem;
}

.signal-message-tabs {
    border-bottom: 1px solid var(--bs-border-color);
}

.signal-message-popup .row {
    margin-left: 0;
    margin-right: 0;
}

.signal-message-popup .col-sm-12 {
    padding-left: .75rem;
    padding-right: .75rem;
}

.signal-message-popup .input-group {
    margin-bottom: .35rem !important;
}

.signal-message-label {
    flex: 0 0 8.5rem;
    min-width: 8.5rem;
}

.signal-message-code-field {
    flex: 1 1 auto;
    min-width: 0;
}

.signal-message-actions.fixed-bottom {
    align-items: center;
    border-top: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    box-shadow: 0 -.35rem .85rem rgba(0, 0, 0, .08);
    box-sizing: border-box;
    left: 0;
    max-width: 100vw;
    overflow-x: hidden;
    right: 0;
    z-index: 1030;
}

.sot-schedule-tabs {
    flex: 0 0 auto;
    border-bottom: 1px solid var(--bs-border-color);
}

.sot-schedule-scroll {
    min-height: 0;
    overflow: auto;
}

.sot-schedule-grid {
    display: grid;
    gap: .25rem;
    max-width: 34rem;
}

.sot-schedule-row {
    display: grid;
    grid-template-columns: minmax(7.5rem, 1fr) minmax(6.5rem, 1fr) minmax(6.5rem, 1fr);
    gap: .35rem;
    align-items: center;
}

.sot-schedule-row > label,
.sot-schedule-head > div {
    margin: 0;
    font-weight: 600;
}

.sot-schedule-head > div {
    text-align: center;
    color: var(--bs-secondary-color);
}

.sot-schedule-active {
    min-height: 1.95rem;
    display: flex;
    align-items: center;
    gap: .45rem;
}

.sot-schedule-active .form-check-input {
    margin-top: 0;
}

.client-objects-popup .object-attach-button {
    white-space: nowrap;
}

.object-archive-layout,
.object-archive-filter {
    width: 100%;
    border-collapse: collapse;
}

.object-archive-layout {
    flex: 1 1 auto;
    min-height: 0;
}

.object-archive-layout > tbody > tr > td {
    padding: 0;
    vertical-align: top;
}

.object-archive-filter {
    margin: .35rem 0;
}

.object-archive-filter td {
    padding: .15rem .2rem;
    vertical-align: middle;
    white-space: nowrap;
}

.object-archive-filter .input-group {
    flex-wrap: nowrap;
}

.object-archive-react-label {
    width: 4.25rem;
    text-align: right;
}

.object-archive-react-check {
    width: 1.75rem;
    text-align: center;
}

.object-archive-mobile-search {
    height: 245px;
    overflow-y: auto;
    padding-top: .625rem;
    width: 800px;
}

.object-archive-mobile-search-short {
    height: 220px;
}

.object-archive-table-wrap {
    height: calc(100vh - 8.8rem);
    height: calc(100dvh - 8.8rem);
    min-height: 0;
    overflow: auto;
}

.object-archive-table-wrap-mobile-short {
    height: 210px;
    width: 790px;
}

.object-archive-table-wrap-mobile-tall {
    height: 235px;
    width: 790px;
}

.object-archive-table {
    table-layout: fixed;
}

.object-archive-table th,
.object-archive-table td {
    vertical-align: middle;
}

.object-archive-table td {
    color: var(--bs-body-color);
}

.object-archive-new-row td {
    color: #2562be;
}

.object-archive-unlinked-row td {
    background: #ffd4aa;
}

.object-archive-time-cell {
    width: 130px;
}

.object-archive-time-col {
    width: 120px;
}

.object-archive-photo-col,
.object-archive-pass-col {
    width: 40px;
}

.object-archive-alarm-col,
.object-archive-arrival-col {
    width: 20px;
}

.object-archive-rr-col,
.object-archive-ssp-col {
    width: 30px;
}

.object-archive-vr-col,
.object-archive-channel-col {
    width: 55px;
}

.object-archive-hidden,
.object-archive-modal-backdrop,
.object-archive-signals-modal {
    display: none;
}

.object-archive-signal-image {
    height: 16px;
    width: 16px;
}

.object-archive-actions {
    align-items: center;
    display: flex;
    gap: .35rem;
    margin: 0;
    min-height: 2.2rem;
    width: 100%;
}

.object-archive-signals-cell {
    flex: 1 1 auto;
    min-width: 0;
}

.object-archive-loss-filter {
    flex: 0 0 auto;
    max-width: 13rem;
}

.object-archive-check-all {
    float: left;
    width: 12.5rem;
}

.object-archive-alarm-images {
    background: #d60000;
    display: inline-block;
    min-height: 1rem;
}

.object-archive-image-strip {
    align-items: center;
    display: flex;
    flex: 0 1 auto;
    gap: .25rem;
    min-width: 0;
    overflow: hidden;
    white-space: nowrap;
}

.object-archive-action-buttons {
    align-items: center;
    display: flex;
    flex: 0 0 auto;
    gap: .25rem;
    justify-content: flex-end;
}

.object-archive-action-btn {
    width: 4.8rem;
    white-space: nowrap;
}

.object-parts-tabs,
.object-zone-tabs {
    flex: 0 0 auto;
}

.object-parts-result-wrap,
.object-zone-result-wrap {
    flex: 1 1 auto;
    max-width: 100%;
    min-height: 0;
    overflow: hidden;
}

.object-parts-result-wrap #result,
.object-zone-result-wrap #result {
    height: calc(100vh - 6.35rem);
    height: calc(100dvh - 6.35rem);
    max-width: 100%;
    min-height: 0;
    overflow-x: hidden;
    overflow-y: auto;
    width: 100%;
}

.object-parts-actions.fixed-bottom,
.object-support-actions.fixed-bottom,
.object-taxes-actions.fixed-bottom,
.object-zone-actions.fixed-bottom,
.set-setup-object-actions.fixed-bottom,
.set-setup-object-tax-actions.fixed-bottom,
.direction-funds-actions.fixed-bottom,
.set-object-client-actions.fixed-bottom,
.set-setup-tech-request-actions.fixed-bottom,
.limit-card-actions.fixed-bottom {
    align-items: center;
    border-top: 1px solid var(--bs-border-color);
    background: var(--bs-body-bg);
    box-sizing: border-box;
    box-shadow: 0 -.35rem .85rem rgba(0, 0, 0, .08);
    display: flex;
    gap: .35rem;
    justify-content: flex-end;
    left: 0;
    max-width: 100vw;
    overflow-x: hidden;
    padding: .3rem .5rem;
    position: fixed;
    right: 0;
    z-index: 1030;
}

.set-setup-object-popup {
    min-height: 100vh;
    min-height: 100dvh;
    padding-bottom: 3.25rem;
}

.set-setup-object-content {
    flex: 1 1 auto;
}

.set-setup-object-tax-popup {
    min-height: 100vh;
    min-height: 100dvh;
    padding-bottom: 3.25rem;
}

.set-setup-object-tax-content {
    flex: 1 1 auto;
    overflow: auto;
}

.set-setup-tech-request-popup {
    padding-bottom: 3.25rem;
}

.limit-card-popup {
    padding-bottom: 3.25rem;
}

.limit-card-tabs-wrap {
    border-bottom: 1px solid var(--bs-border-color);
    flex: 0 0 auto;
    padding: .35rem .5rem 0;
}

.limit-card-result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    width: 100%;
}

.limit-card-result-grid {
    display: grid;
    flex: 1 1 auto;
    gap: .5rem;
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
    min-height: 0;
    padding-bottom: 3.25rem;
}

.limit-card-inline-input {
    flex: 0 0 8rem;
    max-width: 8rem;
}

.limit-card-info-scroll {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    padding-bottom: 3.25rem;
}

.limit-card-date-group {
    flex-wrap: nowrap;
}

.limit-card-readonly-highlight {
    background-color: #eeffee;
}

.limit-card-textarea-sm {
    min-height: 2.15rem;
    resize: none;
}

.limit-card-note {
    min-height: 4.4rem;
    resize: none;
}

.set-setup-tech-request-content {
    flex: 1 1 auto;
    margin: 0;
    overflow: auto;
    width: 100%;
}

.set-setup-tech-request-column {
    display: flex;
    flex-direction: column;
    gap: .5rem;
}

.set-setup-tech-request-content textarea {
    min-height: 4.8rem;
    resize: none;
}

.set-setup-tech-request-content #sDescription {
    min-height: 5.7rem;
}

.set-setup-tech-request-time {
    font-size: .78rem;
    opacity: .9;
}

.set-setup-tech-request-content .admin {
    display: none;
}

.set-setup-tech-request-last-service {
    color: var(--bs-success-text-emphasis);
    cursor: pointer;
    font-weight: 600;
    min-height: 2.15rem !important;
}

.set-setup-tech-request-last-service.is-warranty {
    background-color: var(--bs-danger);
    color: #fff;
}

.set-setup-tech-request-last-service.is-ok {
    background-color: var(--bs-success);
    color: #fff;
}

.set-setup-tech-request-readonly {
    border-color: transparent;
    color: var(--bs-success);
}

.set-setup-tech-request-duration {
    flex-wrap: nowrap;
    max-width: 14rem;
}

.set-setup-tech-request-duration-unit {
    flex: 0 0 3.1rem;
    white-space: nowrap;
}

.set-setup-tech-request-date-group {
    flex-wrap: nowrap;
}

.form-control-inp-time {
    flex: 0 0 4.75rem;
    max-width: 4.75rem;
}

.form-control-inp-date {
    flex: 0 0 7.25rem;
    max-width: 7.25rem;
}

.cursor-pointer {
    cursor: pointer;
}

.object-taxes-tabs {
    border-bottom: 1px solid var(--bs-border-color);
    flex: 0 0 auto;
}

.object-taxes-scroll {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    padding-bottom: 3.5rem;
}

.object-taxes-summary {
    flex: 0 0 auto;
}

.object-taxes-client,
.object-taxes-total {
    color: var(--bs-danger) !important;
    cursor: pointer;
    font-weight: 700;
}

.object-taxes-total {
    cursor: default;
}

.object-taxes-funds-btn {
    min-width: 2.25rem;
}

.object-taxes-panels {
    display: grid;
    gap: .5rem;
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    padding: .5rem;
}

.object-taxes-panel {
    display: flex;
    flex-direction: column;
    min-height: 0;
    padding: .5rem !important;
}

.object-taxes-panel-title {
    justify-content: space-between;
    margin-bottom: .35rem;
}

.object-taxes-single-title {
    align-items: flex-start;
    flex-wrap: wrap;
}

.object-taxes-single-tools {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .25rem;
    justify-content: flex-end;
}

.object-taxes-service-filter {
    width: 10rem;
}

.object-taxes-year-filter {
    width: 6.5rem;
}

.object-taxes-result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    width: 100%;
}

.object-taxes-title-actions {
    align-items: center;
    display: flex;
    flex: 0 0 auto;
    gap: .25rem;
}

.object-taxes-actions.fixed-bottom {
    justify-content: space-between;
}

.object-support-tabs {
    border-bottom: 1px solid var(--bs-border-color);
    flex: 0 0 auto;
}

.object-support-scroll {
    display: flex;
    flex-direction: column;
    min-height: 0;
    overflow: hidden;
    padding-bottom: 3.5rem;
}

.object-support-panels {
    display: grid;
    gap: .5rem;
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr);
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    padding: .5rem;
}

.object-support-panel {
    display: flex;
    flex-direction: column;
    min-height: 0;
    padding: .5rem !important;
}

.object-support-panel-title {
    justify-content: space-between;
    margin-bottom: .35rem;
}

.object-support-result,
.object-support-frame,
.object-support-tech-result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
    width: 100%;
}

.object-support-frame {
    border: 0;
    display: block;
}

.object-support-title-actions {
    align-items: center;
    display: flex;
    flex: 0 0 auto;
    gap: .25rem;
}

.object-support-actions.fixed-bottom {
    justify-content: flex-end;
}

.object-support-tech-popup {
    padding: .35rem;
}

.object-support-tech-toolbar {
    align-items: center;
    display: flex;
    flex: 0 0 auto;
    justify-content: flex-end;
    padding: 0 0 .35rem;
}

.object-support-tech-filter {
    align-items: center;
    display: inline-flex;
    gap: .35rem;
    margin: 0;
}

.object-geo-tabs {
    border-bottom: 1px solid var(--bs-border-color);
    flex: 0 0 auto;
}

.object-geo-map-wrap {
    flex: 1 1 auto;
    min-height: 0;
    overflow: hidden;
    padding: .5rem;
    position: relative;
}

#map_canvas {
    height: 100%;
    min-height: 0;
    width: 100%;
}

.object-geo-address {
    background-color: var(--bs-body-bg);
    box-shadow: 0 .125rem .35rem rgba(0, 0, 0, .16);
    margin: .75rem 0 0 .75rem;
    max-width: 18rem;
    text-overflow: ellipsis;
}

.object-geo-controls {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    justify-content: flex-end;
    position: absolute;
    right: .75rem;
    top: .75rem;
    z-index: 5;
}

.object-geo-pov-actions {
    align-items: center;
    flex-wrap: wrap;
    gap: .25rem;
}

.object-geo-hidden-control {
    visibility: hidden;
}

.object-geo-points,
.object-geo-save-position {
    display: none;
}

.object-geo-save-position {
    align-items: center;
    background: var(--bs-body-bg);
    border: 1px solid var(--bs-border-color);
    border-radius: .25rem;
    gap: .25rem;
    padding: .25rem .5rem;
}

.object-geo-mode-menu .dropdown-menu {
    min-width: 8rem;
}

.object-geo-provider-message {
    align-items: center;
    color: var(--bs-secondary-color);
    display: flex;
    font-size: .85rem;
    height: 100%;
    justify-content: center;
    padding: 1rem;
    text-align: center;
}

.direction-funds-popup {
    padding-bottom: 3.25rem;
}

.direction-funds-scroll {
    min-height: 0;
    overflow: auto;
    padding-bottom: 3.5rem;
}

.direction-funds-list {
    max-height: calc(100vh - 13.5rem);
    max-height: calc(100dvh - 13.5rem);
    overflow: auto;
}

.direction-funds-percent {
    font-variant-numeric: tabular-nums;
}

.set-object-client-popup {
    padding-bottom: 3.25rem;
}

.set-object-client-content {
    flex: 1 1 auto;
}

.object-title {
    display: inline-block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: middle;
    white-space: nowrap;
}

.object-title-service {
    background-color: #cc0000;
    border-radius: .25rem;
    color: #fff;
    padding: .1rem .35rem;
}

.object-geo-fields .form-control {
    max-width: 8.5rem;
}

.object-check-row {
    min-height: 1.95rem;
}

.object-check-row .form-check {
    margin-bottom: 0;
}

.object-faces-result {
    height: 8rem;
    overflow: auto;
    border: 1px solid var(--bs-border-color);
    border-radius: .25rem;
}

.object-key-btn {
    float: left;
    margin-right: 2px;
}

#objectKeysDiv {
    display: none;
}

.personal-card-page,
.personal-card-popup,
.personal-card-schedule-page {
    background: #f3f6fa;
    font-size: 0.85rem;
}

.personal-card-page {
    height: 100vh;
    margin: 0;
    overflow: hidden;
}

.personal-card-frame {
    border-top: 1px solid #cfd8e3;
    min-height: 0;
}

.personal-card-frame iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}

.personal-card-frame-limit {
    height: 10.25rem;
}

.personal-card-frame-operations {
    flex: 1 1 auto;
    min-height: 16rem;
}

.personal-card-frame-schedule {
    height: 6.25rem;
}

.personal-card-tabs-wrap {
    padding: 0.35rem 0.55rem 0;
    background: #f3f6fa;
}

.personal-card-popup {
    min-height: 100vh;
    padding: 0.4rem 0.55rem;
    overflow: hidden;
}

.personal-card-child-popup {
    padding-bottom: 0.55rem;
}

.personal-card-toolbar {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 0.5rem;
    padding-bottom: 0.35rem;
}

.personal-card-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.personal-card-result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.personal-card-filter-panel {
    margin: 0.45rem 0;
}

.personal-card-year-input {
    width: 4.5rem;
    text-align: right;
}

.personal-card-month-input {
    width: 3.75rem;
    text-align: right;
}

.personal-card-earning-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    gap: 0.4rem;
    margin-top: 0.4rem;
}

.personal-card-schedule-page {
    height: 100vh;
    padding: 0.25rem;
    overflow: hidden;
}

.personal-card-schedule-toolbar {
    width: max-content;
    max-width: 100%;
    margin: 0 auto 0.25rem;
}

.personal-card-schedule-result {
    height: calc(100vh - 2.6rem);
    overflow: auto;
}

.personal-card-schedule-cell {
    cursor: pointer;
    color: #fff;
    text-align: right;
    background-position: 20%;
}

.personal-card-schedule-cell-unsigned {
    border: 2px solid #dc3545 !important;
}

.personal-card-limit-popup {
    padding: 0.45rem;
}

.personal-card-limit-grid {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    overflow: auto;
}

.personal-card-limit-name {
    color: #fff;
    font-weight: 600;
    border-color: transparent;
}

.personal-card-type-build {
    background-color: #5957bb !important;
}

.personal-card-type-remove,
.personal-card-type-alert {
    background-color: #bd2937 !important;
}

.personal-card-type-arrange {
    background-color: #569457 !important;
}

.personal-card-type-support {
    background-color: purple !important;
}

.personal-card-action-ready {
    background-color: #569457 !important;
    border-color: #569457 !important;
    color: #fff !important;
}

.personal-card-action-danger {
    background-color: #bd2937 !important;
    border-color: #bd2937 !important;
    color: #fff !important;
}

.personal-card-action-muted {
    background-color: #c0c0c0 !important;
    border-color: #c0c0c0 !important;
    color: #212529 !important;
}

.personal-card-object-number {
    max-width: 5.5rem;
}

.personal-card-note {
    min-height: 4.25rem;
    resize: none;
}

.cursor-pointer {
    cursor: pointer;
}

.salary-holiday-cell {
    background-color: #bedaf8 !important;
}

.salary-holiday-money {
    color: #dc3545 !important;
}

.rpc-loading-panel {
    background: #800000;
    border: 1px solid #808080;
    text-align: center;
    color: #fff;
    position: absolute;
    width: 169px;
    height: 16px;
    bottom: 2px;
    right: 2px;
    z-index: 1000;
}

.person-popup {
    min-height: 100vh;
    padding: 0 0 3.4rem;
    /*background: #f3f6fa;*/
    font-size: 0.85rem;
    overflow: hidden;
}

.person-popup .person-toolbar,
.person-popup .person-result {
    margin-left: 0.55rem;
    margin-right: 0.55rem;
}

.person-tabs-wrap {
    padding: 0.35rem 0 0;
    /*background: #f3f6fa;*/
}

.person-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    margin: 0.45rem 0;
}

.person-toolbar-actions {
    display: flex;
    align-items: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.person-result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.person-actions.fixed-bottom {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 0.45rem;
    padding: 0.45rem 0.65rem;
    background: #fff;
    border-top: 1px solid var(--bs-border-color);
    z-index: 1030;
}

.person-select {
    min-width: 12rem;
}

.person-month-nav {
    width: 9.5rem;
}

.person-month-nav .form-control {
    text-align: center;
}

.person-salary-popup {
    padding-bottom: 4.4rem;
}

.person-salary-actions.fixed-bottom {
    justify-content: space-between;
    flex-wrap: wrap;
}

.person-salary-summary {
    width: auto;
    min-width: 24rem;
}

.person-salary-summary .form-control {
    max-width: 5.5rem;
    text-align: right;
}

.setup-person-leave-popup {
    padding-bottom: 0.65rem;
}

.setup-person-leave-content {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    overflow: auto;
}

#resolution,
#saveResLeave,
#printLeave {
    display: none;
}

.person-leave-graph-page {
    height: 100vh;
    padding: 0.45rem 0.55rem;
    background: #f3f6fa;
    font-size: 0.85rem;
    overflow: hidden;
}

.person-leave-graph-filter {
    margin: 0.45rem 0;
}

.person-leave-graph-result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto;
}

.person-leave-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem;
    padding-top: 0.55rem;
    font-size: 0.8rem;
}

.person-leave-legend span {
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
}

.person-leave-dot {
    display: inline-block;
    width: 0.85rem;
    height: 0.85rem;
    border-radius: 50%;
    border: 1px solid rgba(0, 0, 0, 0.2);
}

.person-leave-dot-paid {
    background-color: #64ff64;
}

.person-leave-dot-unpaid {
    background-color: #ff6464;
}

.person-leave-dot-unconfirmed {
    background-color: #ff9632;
}

.person-leave-dot-denied {
    background-color: #000;
}

.person-leave-dot-hospital {
    background-color: #dc64ff;
}

.person-schedule-page {
    min-height: 100dvh;
    min-width: 100dvw;
    margin-bottom: 0;
    background: #f3f6fa;
    font-size: 0.85rem;
    overflow: hidden;
}

.person-schedule-toolbar {
    margin: 0;
}

.person-schedule-toolbar-field {
    width: 10rem;
}

.person-schedule-result {
    flex: 1 1 auto;
    min-height: 0;
    overflow: auto !important;
    margin: 0;
}

.person-schedule-norm {
    font-weight: 700;
}

@media (max-width: 575.98px) {
    .client-info-scroll,
    .object-info-scroll {
        max-height: none;
    }

    .client-info-popup .client-actions .btn,
    .object-actions .btn,
    .client-objects-popup .object-attach-button {
        width: 100%;
    }

    .client-objects-scroll {
        overflow: hidden;
    }
}

/* person_schedule migrated from template */

	/*.wd {*/
		/*width: 250px;*/
	/*}*/

.person-schedule-page table
	{
		empty-cells: show !important;
	}

.person-schedule-page table td
	{
		empty-cells: show !important;
	}

.person-schedule-page table.shifts
	{
		margin: auto;
		text-align: center;
		width: 95% !important;
	}

.person-schedule-page table.shifts td
	{
		width: 50px !important;
	}

.person-schedule-page table.shifts button
	{
		width: 50px;
	}

.person-schedule-page table.shifts button.selected
	{
		background-image: none;
		background-color: Silver;
	}

.person-schedule-page table.ps_layout
	{

	}

	.ps-bottom-toolbar {
		display: flex;
    	align-content: center;
    	justify-content: flex-start;
    	align-items: center;
    	gap: 8px;
    	padding: 4px;
	}

.person-schedule-page #tableResult > tbody > tr:nth-child(1) {
		position: sticky;
		top: 0;
	}

.person-schedule-page table.result
	{
		empty-cells: show !important;
		border-collapse: collapse !important;
		width: auto !important;
		
	}

.person-schedule-page table.result th
	{
		padding: 2px 7px 2px 7px;
	}

.person-schedule-page table.result tr
	{
		height: 24px;
	}

.person-schedule-page table.result td
	{
		white-space: nowrap !important;
	}

.person-schedule-page table.result th.weekend
	{
		background-image: none;
		background-color: Silver;
	}

.person-schedule-page table.result td.weekend
	{
		background-image: none;
		background-color: #DDDDDD;
	}

.person-schedule-page table.result th.work_weekend
	{
		background-image: none;
		background-color: #C8C8DD;
	}

.person-schedule-page table.result td.work_weekend
	{
		background-image: none;
		background-color: #DDDDF1;
	}

.person-schedule-page table.result th.holiday
	{
		/* background-repeat: no-repeat;
		background-position: center center;
		background-image: url( 'images/icon_free.gif' ); */
		background-image: none !important;
		background-color: #DDDDDD !important;
		color: Red !important;
	}

.person-schedule-page table.result td.invalidated
	{
		border: ridge 2px !important;
	}

.person-schedule-page table.result td.leave_planned
	{
		background-color: #FFD200 !important;
	}

.person-schedule-page table.result td.leave_planned_weekend
	{
		background-color: #FFB400 !important;
	}

.person-schedule-page table.result td.hospital
	{
		background-color: #E6AAFF !important;
	}

.person-schedule-page table.result td.hospital_weekend
	{
		background-color: #E66EFF !important;
	}

.person-schedule-page table.result td.busy
	{
		background-color: Pink !important;
	}

.person-schedule-page table.result td.isValidatedStart
	{
		background-color: #eff465 !important;
	}

.person-schedule-page table.result td.stake
	{
		text-align: right;
	}

.person-schedule-page table.result td.days
	{
		cursor: default;
	}

.person-schedule-page table.result td.personName
	{
	}

.person-schedule-page table.result td.planMoney,
.person-schedule-page table.result td.planDuration,
.person-schedule-page table.result td.realMoney,
.person-schedule-page table.result td.realDuration
	{
		text-align: center;
	}

.person-schedule-page table.result tr.total td
	{
		font-weight: normal;
	}

.person-schedule-page table.foother
	{
		margin-top: 10px;
	}

.person-schedule-page table.foother button
	{
		font-family: Tahoma;
		font-size: 11px;
		padding: 2px 5px 2px 5px;
	}

.person-schedule-page #divTitle
	{
		font-size: 16px;
		text-align: center;
		margin: auto;
		font-weight: bold;
		padding: 7px;
	}

.person-schedule-page td.busy
	{
		background-color: Red;
	}

.person-schedule-page td.isValidatedStart
	{
		background-color: #eff465;
	}

.person-schedule-page .row select,
.person-schedule-page .row input {
		width: 100%;
	}

.person-schedule-page .row label {
		width: 45px;
	}

.person-schedule-page #tableShifts td {
		display: inline-block !important;
	}

/* end person_schedule */

/* person_contract */
.person-contract-popup,
.person-contract-print-popup {
    min-height: 100vh;
    padding-bottom: 4.75rem;
}

.person-contract-form,
.person-contract-print-form {
    padding: 0;
}

.person-contract-grid {
    width: 100%;
}

#filter.person-contract-grid {
    margin: 0.5rem;
    width: calc(100% - 1rem);
}

.person-contract-grid > tbody > tr > td,
.person-contract-grid td {
    padding: 0.18rem 0.25rem;
    vertical-align: top;
}

.person-contract-input-group {
    flex-wrap: nowrap;
    align-items: stretch;
}

.person-contract-input-group .input-group-text {
    min-height: 30px;
}

.person-contract-label {
    width: 10rem;
}

.person-contract-label-sm {
    width: 8.3rem;
}

.person-contract-label-md {
    width: 10.5rem;
}

.person-contract-label-lg {
    width: 13rem;
}

.person-contract-money,
.person-contract-number {
    text-align: right;
}

.person-contract-date {
    text-align: center;
}

.person-contract-narrow {
    width: 3rem !important;
    flex: 0 0 3rem !important;
}

.person-contract-short {
    width: 4rem !important;
    flex: 0 0 4rem !important;
}

.person-contract-mini {
    width: 2rem !important;
    flex: 0 0 2rem !important;
}

.person-contract-wide {
    width: 31.25rem !important;
    max-width: 31.25rem;
}

.person-contract-print-wide {
    width: 37.5rem !important;
    max-width: 37.5rem;
}

.person-contract-info-icon,
.person-contract-copy-icon,
.person-contract-calendar-icon {
    cursor: pointer;
    width: 2rem;
    justify-content: center;
}

.person-contract-spacer {
    height: 0.45rem;
}

.person-contract-section {
    margin-bottom: 0.5rem;
    border: 1px solid #cfd6df;
    border-radius: 0.35rem;
    padding: 0.45rem;
    background: #fff;
}

.person-contract-section legend {
    float: none;
    width: auto;
    margin-bottom: 0.35rem;
    padding: 0 0.35rem;
    font-size: 0.85rem;
    font-weight: 600;
    color: #1f5d82;
}

.person-contract-print-popup .content,
.person-contract-print-scroll {
    width: 40rem;
    max-width: 100%;
    height: calc(100vh - 4.75rem);
    overflow-y: auto;
    padding: 0.5rem;
}

.person-contract-print-tab {
    width: 3.2rem;
}

.person-contract-text-left {
    text-align: left;
}

.person-contract-text-right {
    text-align: right;
}

.person-contract-text-center {
    text-align: center;
}

.person-contract-hidden-row {
    display: none;
}

/* end person_contract */

