@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 400;
    font-display: swap;
    src: url("fonts/Inter-Regular.woff2") format("woff2");
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 500;
    font-display: swap;
    src: url("fonts/Inter-Medium.woff2") format("woff2");
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 600;
    font-display: swap;
    src: url("fonts/Inter-SemiBold.woff2") format("woff2");
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 700;
    font-display: swap;
    src: url("fonts/Inter-Bold.woff2") format("woff2");
}

@font-face {
    font-family: Inter;
    font-style: normal;
    font-weight: 800;
    font-display: swap;
    src: url("fonts/Inter-ExtraBold.woff2") format("woff2");
}

:root {
    --bg: #e8f0f8;
    --blue: #1785aa;
    --blue-dark: #1a2546;
    --line: #d3e1f1;
    --official-line: #d8e1ec;
    --official-soft: #f5f8fb;
    --official-head: #eef2f6;
    --official-gray: #8c929d;
    --muted: #8695af;
    --text: #32394d;
    --tab-bg: #efeff0;
    --row: #efeff0;
    --yellow: #f8d043;
    --yellow-border: #f0bc20;
}

html {
    width: 100%;
    min-height: 100%;
    box-sizing: border-box;
}

*,
*::before,
*::after {
    box-sizing: inherit;
}

body {
    width: 100%;
    min-height: 100%;
    margin: 0;
    background: var(--bg);
    color: var(--text);
    font-family: Inter, Arial, Helvetica, sans-serif;
    font-size: 14px;
    line-height: 1;
}

a {
    color: var(--blue);
    text-decoration: none;
}

a:hover {
    color: #f47621;
    text-decoration: none;
}

.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

button,
input,
select {
    font: inherit;
}

.portal-shell {
    min-height: 100vh;
}

.portal-top {
    height: 43px;
    display: flex;
    justify-content: space-between;
    border-bottom: 1px solid var(--line);
    background: var(--bg);
    color: #54617a;
}

.portal-top-links,
.portal-top-meta {
    display: flex;
    align-items: stretch;
    min-height: 43px;
}

.portal-top-links a,
.portal-top-links span,
.portal-top-meta a,
.portal-top-meta span {
    min-height: 43px;
    display: inline-flex;
    align-items: center;
    padding: 0 20px;
    border-left: 1px solid var(--line);
    color: #54617a;
    font-size: 13px;
    font-weight: 400;
    white-space: nowrap;
}

.portal-top-links a:first-child {
    border-left: 0;
}

.portal-top-meta a {
    padding: 0 14px;
}

.portal-top-meta .portal-favorites-link {
    color: #334155;
    font-weight: 600;
}

.portal-top-meta .portal-favorites-link.active {
    color: #e11d48;
}

.portal-top-meta a:last-child {
    border-right: 1px solid var(--line);
}

.portal-top-meta span {
    padding: 0 2px;
    border-left: 0;
}

.portal-contact {
    color: var(--muted) !important;
    font-size: 12px !important;
}

.fa-like {
    padding: 0;
    margin-right: 7px;
    border: 0;
    font-weight: 700;
}

.portal-nav {
    height: 105px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 0 15px;
    border-bottom: 1px solid var(--line);
    background: var(--bg);
}

.portal-brand {
    height: 105px;
    display: inline-flex;
    align-items: center;
    color: var(--text);
}

.brand-logo {
    width: 221px;
    height: 70px;
    display: block;
    background: url("official/logo-inner.jpg") no-repeat center center;
    background-size: contain;
}

.brand-msad {
    display: none;
    flex-direction: column;
    justify-content: center;
    min-height: 70px;
    margin-left: 20px;
}

.brand-msad b {
    color: #18c22f;
    font-size: 30px;
    font-weight: 500;
    line-height: 1.05;
}

.brand-msad small {
    max-width: 150px;
    color: #18c22f;
    font-size: 9px;
    font-weight: 500;
    line-height: 1.2;
}

.portal-menu {
    height: 105px;
    display: inline-flex;
    align-items: center;
    gap: 22px;
}

.portal-menu a,
.portal-menu .menu-toggle {
    display: inline-flex;
    align-items: center;
    min-height: 42px;
    padding: 0;
    border: 0;
    background: transparent;
    color: #1a2546;
    font-family: inherit;
    font-size: 16px;
    font-weight: 500;
    white-space: nowrap;
    cursor: pointer;
}

.portal-menu a.active,
.portal-menu a:hover,
.portal-menu .menu-toggle.active,
.portal-menu .menu-toggle:hover {
    color: #1a2546;
}

.portal-main {
    width: 1270px;
    max-width: calc(100% - 30px);
    margin: 29px auto 60px;
    display: block;
    background: #fff;
    border-radius: 4px;
}

.search-panel,
.tenders-card {
    background: transparent;
}

.search-panel {
    padding: 22px 20px 16px;
}

.search-heading,
.quick-filters,
.stats-grid,
.card-head {
    display: none !important;
}

.search-form {
    display: block;
}

.tender-category-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 14px;
}

.tender-category-chips a {
    min-height: 32px;
    display: inline-flex;
    align-items: center;
    border: 1px solid #cfe0f2;
    border-radius: 4px;
    background: #f7fbff;
    padding: 0 12px;
    color: #075985;
    font-size: 13px;
    font-weight: 700;
}

.tender-category-chips a.active {
    border-color: var(--blue);
    background: var(--blue);
    color: #fff;
}

.search-row {
    position: relative;
    display: block;
}

.search-input {
    height: 50px;
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    align-items: center;
    border: 1px solid var(--line);
    border-radius: 5px;
    background: #fff;
}

.search-input-icon {
    display: none;
    place-items: center;
    color: #1a2546;
    font-size: 28px;
    transform: rotate(-20deg);
}

.search-input input {
    width: 100%;
    height: 48px;
    border: 0;
    padding: 0 135px 0 20px;
    color: #32394d;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 13px;
    outline: none;
}

.search-input input::placeholder {
    color: #7b76b5;
}

.search-button {
    position: absolute;
    top: 4px;
    right: 4px;
    width: 112px;
    height: 42px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin: 0;
    border: 1px solid var(--yellow-border);
    border-radius: 4px;
    background: var(--yellow);
    color: #000;
    font-family: Arial, Helvetica, sans-serif;
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

.search-icon {
    font-size: 30px;
    font-weight: 400;
    line-height: 1;
    transform: rotate(-20deg);
}

.portal-tabs {
    display: flex;
    align-items: stretch;
    margin-top: 31px;
    border-bottom: 1px solid var(--blue);
    background: var(--tab-bg);
}

.portal-tabs a {
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    padding: 0 16px;
    border-top: 1px solid #cecece;
    border-right: 1px solid #cecece;
    background: var(--tab-bg);
    color: var(--blue);
    font-size: 16px;
    font-weight: 600;
}

.portal-tabs a:first-child {
    border-left: 1px solid var(--blue);
}

.portal-tabs a:nth-child(2) {
    margin-left: auto;
}

.portal-tabs a.active {
    border-color: var(--blue);
    border-bottom: 1px solid #fff;
    background: #fff;
    color: var(--blue);
    position: relative;
    top: 1px;
}

.portal-tabs a.disabled {
    color: var(--blue);
    opacity: 1;
    pointer-events: none;
}

.advanced-filters {
    margin-top: 12px;
}

.advanced-filters summary {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--blue);
    font-size: 14px;
    font-weight: 700;
    cursor: pointer;
}

.advanced-filters:not([open]) .filter-grid {
    display: none;
}

.advanced-icon {
    color: var(--blue);
    font-size: 19px;
}

.filter-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 16px;
    padding: 16px;
    background: #f5f8fb;
    border: 1px solid #d9e5f1;
}

.filter-grid label {
    display: grid;
    gap: 6px;
    color: #54617a;
    font-size: 12px;
    font-weight: 600;
}

.filter-grid input,
.filter-grid select {
    width: 100%;
    height: 35px;
    border: 1px solid #cecece;
    border-radius: 3px;
    background: #fff;
    color: var(--text);
    padding: 0 8px;
}

.filter-actions {
    align-self: end;
    display: flex;
    gap: 8px;
}

.filter-actions button,
.filter-actions a {
    min-height: 35px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 13px;
    border: 1px solid var(--blue);
    border-radius: 3px;
    background: var(--blue);
    color: #fff;
    font-weight: 600;
}

.filter-actions a {
    border-color: #cecece;
    background: #fff;
    color: #54617a;
}

.portal-alert {
    margin: 0 20px 15px;
    padding: 12px 14px;
    border: 1px solid #f5b5b5;
    border-radius: 3px;
    background: #fff4f4;
    color: #991b1b;
}

.tenders-card {
    padding: 0 20px 0;
    overflow: visible;
}

.official-paginator {
    min-height: 39px;
    display: grid;
    grid-template-columns: minmax(230px, 1fr) auto minmax(230px, 1fr);
    align-items: center;
    column-gap: 8px;
    padding: 3px 9px;
    border: 1px solid #d8d8d8;
    background: #fff;
    color: #32394d;
}

.official-paginator-top {
    border-bottom: 0;
    border-radius: 4px 4px 0 0;
}

.official-paginator-bottom {
    border-top: 0;
    border-radius: 0 0 4px 4px;
    margin-bottom: 18px;
}

.official-paginator a {
    color: #1a2546;
}

.paginator-main {
    grid-column: 2;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-width: 0;
}

.page-control {
    position: relative;
    width: 22px;
    min-width: 22px;
    height: 31px;
    flex: 0 0 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #1a2546;
    font-size: 0;
    line-height: 0;
}

.page-control.disabled,
.pagination a.disabled {
    pointer-events: none;
    color: #b7bdc5;
    opacity: 1;
}

.page-control::before,
.page-control::after {
    content: "";
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
}

.page-first::before,
.page-last::after {
    width: 2px;
    height: 16px;
    background: currentColor;
}

.page-first::before {
    left: 3px;
}

.page-last::after {
    right: 3px;
}

.page-first::after,
.page-prev::before,
.page-prev::after {
    width: 0;
    height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-right: 8px solid currentColor;
}

.page-first::after {
    left: 8px;
}

.page-prev::before {
    left: 3px;
}

.page-prev::after {
    left: 10px;
}

.page-next::before,
.page-next::after,
.page-last::before {
    width: 0;
    height: 0;
    border-top: 6px solid transparent;
    border-bottom: 6px solid transparent;
    border-left: 8px solid currentColor;
}

.page-next::before {
    left: 4px;
}

.page-next::after {
    left: 11px;
}

.page-last::before {
    left: 5px;
}

.page-numbers {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    gap: 9px;
}

.page-numbers a {
    width: 31px;
    height: 31px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #d8d8d8;
    border-radius: 50%;
    color: #8695af;
    font-size: 14px;
    font-weight: 400;
}

.page-numbers a.active {
    border: 2px solid #0085bd;
    color: #0085bd;
    font-weight: 600;
}

.rows-label {
    flex: 0 0 auto;
    margin-left: 14px;
    color: #32394d;
    font-size: 14px;
    white-space: nowrap;
}

.official-paginator select {
    flex: 0 0 auto;
    height: 24px;
    width: 47px;
    padding: 0 2px;
    border: 1px solid #aab4bf;
    background: #fff;
    color: #32394d;
}

.goto-page {
    grid-column: 3;
    justify-self: end;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-width: 0;
    margin: 0;
}

.goto-page label {
    color: #54617a;
    font-size: 12px;
    line-height: 1.1;
    white-space: nowrap;
}

.goto-page input {
    width: 58px;
    height: 24px;
    padding: 0 4px;
    border: 1px solid #aab4bf;
    border-radius: 2px;
    background: #fff;
    color: #32394d;
    text-align: center;
}

.goto-page button {
    height: 24px;
    min-width: 34px;
    padding: 0 8px;
    border: 1px solid #aab4bf;
    border-radius: 2px;
    background: #efeff0;
    color: #32394d;
    font-size: 12px;
    cursor: pointer;
}

.goto-page button:hover {
    background: #e5e5e7;
}

.tender-list {
    display: block;
    border-left: 1px solid #d8d8d8;
    border-right: 1px solid #d8d8d8;
    overflow: visible;
}

.ui-datatable-tablewrapper {
    overflow: visible;
}

.tender-list table {
    width: 100%;
    min-width: 0;
    max-width: 100%;
    border-collapse: collapse;
    table-layout: auto;
    font-size: 14px;
}

.tender-table-head {
    display: table-header-group;
    height: 0;
    visibility: collapse;
}

.tender-table-head th {
    height: 0;
    padding: 0;
    border: 0;
    line-height: 0;
}

.tender-row {
    display: table-row;
    color: #1a2546;
    font-size: 14px;
}

.tender-row.ui-datatable-even,
.tender-row:nth-of-type(odd) {
    background: #efeff0;
}

.tender-row.ui-datatable-odd,
.tender-row:nth-of-type(even) {
    background: #fff;
}

.tender-row > * {
    min-width: 0;
    display: table-cell;
    padding: 15px;
    vertical-align: top;
}

.tender-number {
    width: 159px;
}

.tender-buyer-cell {
    width: 156px;
}

.tender-type-cell {
    width: 81px;
}

.tender-main {
    width: 166px;
}

.open-link-cell,
.tender-row > td:nth-child(5) {
    width: 44px;
}

.tender-method-cell {
    width: 278px;
}

.tender-money {
    width: 108px;
}

.tender-date {
    width: 122px;
}

.tender-deadline {
    width: 110px;
}

.tender-status-protocol-cell,
.tender-status-evaluation-cell {
    width: 30px;
}

.tender-row span {
    display: block;
    margin-bottom: 5px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 600;
    line-height: 1.25;
    text-transform: uppercase;
}

.tender-number b,
.tender-buyer-cell b,
.tender-type-cell b,
.tender-method-cell b,
.tender-money b,
.tender-date b,
.tender-deadline b {
    display: block;
    color: #1a2546;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.tender-number b {
    overflow-wrap: normal;
    word-break: normal;
}

.buyer-link {
    color: #0877a8;
    font-weight: 700;
    text-decoration: none;
}

.buyer-link:hover,
.section-entity-link:hover {
    color: #075985;
    text-decoration: underline;
}

.tender-buyer-cell .buyer-link b {
    color: #0877a8;
    font-weight: 600;
}

.tender-number small,
.tender-deadline small {
    display: none;
}

.tender-title {
    display: block;
    color: #0085bd;
    font-size: 14px;
    font-weight: 500;
    line-height: 1.22;
    text-transform: uppercase;
    overflow-wrap: anywhere;
}

.tender-title:hover {
    color: #f47621;
}

.tender-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 6px;
}

.tender-tags span {
    border: 1px solid #dde8f3;
    border-radius: 3px;
    background: #f8fafc;
    padding: 2px 6px;
    color: #53647c;
    font-size: 11px;
    font-weight: 700;
    line-height: 1.25;
}

.tender-tags span.good {
    border-color: #bbf7d0;
    background: #f0fdf4;
    color: #047857;
}

.tender-tags span.category {
    border-color: #bfdbfe;
    background: #eff6ff;
    color: #1d4ed8;
}

.tender-favorite-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 30px;
    height: 30px;
    min-height: 30px;
    border: 1px solid transparent;
    border-radius: 50%;
    background: transparent;
    padding: 0;
    color: #9aa8bc;
    font: inherit;
    font-size: 22px;
    font-weight: 700;
    line-height: 1;
    cursor: pointer;
    transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease, box-shadow .16s ease;
}

.tender-favorite-button .favorite-icon {
    display: inline-block;
    margin: 0;
    color: currentColor;
    font-size: 22px;
    line-height: 1;
    text-transform: none;
}

.tender-favorite-button:hover {
    border-color: #fecdd3;
    background: #fff1f2;
    color: #e11d48;
    box-shadow: 0 8px 18px rgba(225, 29, 72, .12);
}

.tender-favorite-button.is-active {
    border-color: #fecdd3;
    background: #fff1f2;
    color: #e11d48;
}

.tender-favorite-button.is-loading {
    opacity: .62;
    pointer-events: none;
}

.tender-favorite-button.has-error {
    border-color: #fecaca;
    background: #fef2f2;
    color: #b91c1c;
}

.tender-favorite-button:focus-visible {
    outline: 3px solid rgba(37, 99, 235, .22);
    outline-offset: 2px;
}

.tender-favorite-button-compact {
    margin-top: 6px;
}

.open-link {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    color: #0085bd;
    font-size: 20px;
    line-height: 1;
}

.open-link:hover {
    color: #f47621;
}

.tender-status-icons {
    text-align: center;
    padding: 16px 10px;
}

.tender-status-icon {
    position: relative;
    width: 16px;
    height: 16px;
    display: inline-block;
    color: #6fc795;
}

.tender-status-protocol {
    border: 2px solid currentColor;
    border-radius: 50%;
}

.tender-status-protocol::after {
    content: "";
    position: absolute;
    left: 3px;
    top: 4px;
    width: 7px;
    height: 4px;
    border-left: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(-45deg);
}

.tender-status-evaluation::before,
.tender-status-evaluation::after {
    content: "";
    position: absolute;
    width: 9px;
    height: 11px;
    border: 2px solid currentColor;
    border-radius: 1px;
    background: transparent;
}

.tender-status-evaluation::before {
    left: 5px;
    top: 1px;
}

.tender-status-evaluation::after {
    left: 1px;
    top: 5px;
}

.tender-deadline.danger b,
.tender-deadline.warning b,
.tender-deadline.ok b,
.tender-deadline.expired b {
    color: #1a2546;
}

.empty-state {
    display: grid;
    place-items: center;
    gap: 8px;
    padding: 48px 20px;
    background: #fff;
    color: var(--muted);
    text-align: center;
}

.empty-state b {
    color: var(--text);
    font-size: 18px;
}

.detail-main {
    padding-bottom: 24px;
}

.detail-main .detail-section {
    content-visibility: auto;
    contain-intrinsic-size: 1px 420px;
}

.official-view-card {
    margin: 0 20px;
    padding: 28px 0 10px;
    border: 1px solid var(--official-line);
    border-radius: 3px;
    background: #fff;
    box-shadow: 0 1px 0 rgba(26, 37, 70, 0.04);
}

.official-view-heading {
    display: grid;
    grid-template-columns: 82px minmax(0, 1fr);
    align-items: center;
    column-gap: 28px;
    min-height: 40px;
    padding: 0 20px;
}

.official-back {
    width: 70px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #8c929d;
    border-radius: 3px;
    background: #fff;
    color: #54617a;
    font-size: 14px;
    font-weight: 500;
}

.official-back:hover,
.official-back:focus-visible {
    border-color: #1785aa;
    background: #f6fbfe;
    color: #1785aa;
    outline: 0;
}

.official-view-heading h1 {
    margin: 0;
    color: #1a2546;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.2;
}

.official-source-link {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    color: #0085bd;
    font-size: 13px;
    font-weight: 600;
}

.official-view-tabs {
    display: flex;
    align-items: stretch;
    margin-top: 28px;
    overflow-x: auto;
    border-top: 1px solid var(--official-line);
    border-bottom: 1px solid var(--blue);
    background: var(--official-head);
    scrollbar-width: thin;
}

.official-view-tabs a {
    min-height: 52px;
    display: inline-flex;
    align-items: center;
    flex: 0 0 auto;
    padding: 0 16px;
    border-right: 1px solid #cfd8e3;
    background: var(--official-head);
    color: #0085bd;
    font-size: 16px;
    font-weight: 600;
    white-space: nowrap;
}

.official-view-tabs a:first-child {
    border-left: 0;
}

.official-view-tabs a.active {
    position: relative;
    top: 1px;
    border-color: var(--blue);
    border-bottom: 1px solid #fff;
    background: #fff;
}

.official-view-tabs a:hover,
.official-view-tabs a:focus-visible {
    background: #fff;
    color: #006b99;
    outline: 0;
}

.official-common-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: 30px;
    row-gap: 0;
    padding: 28px 16px 4px;
}

.official-common-column {
    min-width: 0;
}

.official-common-row {
    min-height: 34px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    align-items: start;
}

.official-common-row:nth-child(odd) {
    background: var(--official-head);
}

.official-common-row span,
.official-common-row b {
    min-width: 0;
    padding: 11px 10px;
    color: #1a2546;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.12;
}

.official-common-row span {
    color: #71809a;
    font-weight: 600;
}

.official-common-row b {
    overflow-wrap: anywhere;
}

.official-common-row a {
    color: #0085bd;
}

.official-common-tall {
    min-height: 76px;
}

.official-org-heading {
    margin: 24px 16px 0;
    color: #1a2546;
    font-size: 22px;
    font-weight: 500;
    line-height: 1.2;
}

.official-org-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
    column-gap: 30px;
    margin: 16px 16px 8px;
}

.official-org-grid .official-common-row {
    grid-template-columns: 292px minmax(0, 1fr);
}

.detail-tabs-panel {
    padding-bottom: 0;
}

.detail-tabs-panel .portal-tabs {
    margin-top: 0;
}

.detail-header {
    padding: 16px 20px 4px;
}

.detail-toolbar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 16px;
}

.back-link,
.external-button {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    color: var(--blue);
    font-size: 14px;
    font-weight: 600;
}

.external-button {
    padding: 0 12px;
    border: 1px solid var(--yellow-border);
    border-radius: 4px;
    background: var(--yellow);
    color: #000;
}

.detail-title-block {
    border: 1px solid #d8d8d8;
    border-bottom: 0;
    background: #efeff0;
    padding: 18px 20px;
}

.source-badge {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0 8px;
    border: 1px solid #d8d8d8;
    border-radius: 3px;
    background: #fff;
    color: #54617a;
    font-size: 12px;
    font-weight: 600;
}

.detail-title-block h1 {
    margin: 12px 0 10px;
    color: #0085bd;
    font-size: 20px;
    font-weight: 600;
    line-height: 1.28;
    text-transform: uppercase;
}

.detail-number {
    color: #1a2546;
    font-size: 15px;
    font-weight: 600;
}

.detail-meta-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr 1.2fr 1fr 1fr 1fr;
    border: 1px solid #d8d8d8;
    background: #fff;
}

.detail-meta-grid div {
    min-width: 0;
    padding: 15px;
    border-right: 1px solid #e7e7e7;
}

.detail-meta-grid div:last-child {
    border-right: 0;
}

.detail-meta-grid span,
.detail-table th {
    display: block;
    margin-bottom: 6px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.detail-meta-grid b {
    color: #1a2546;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.25;
}

.detail-section {
    padding: 14px 20px 0;
}

.detail-section-title {
    min-height: 42px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    border: 1px solid #d8d8d8;
    border-bottom: 0;
    background: #fff;
    padding: 0 15px;
}

.detail-section-title h2 {
    margin: 0;
    color: #0085bd;
    font-size: 17px;
    font-weight: 600;
}

.detail-section-title span {
    color: #8695af;
    font-size: 13px;
}

.official-view-card + .detail-section .detail-section-title,
.detail-section .detail-section-title {
    min-height: auto;
}

.detail-section-title {
    border: 0;
    background: transparent;
    padding: 0 16px;
    margin: 28px 0 16px;
}

.detail-section-title h2 {
    color: #1a2546;
    font-size: 21px;
    font-weight: 500;
}

.detail-section-title span {
    display: none;
}

.forecast-section {
    color: #1a2546;
}

.forecast-title span {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 9px;
    border: 1px solid #c9d8ea;
    border-radius: 3px;
    background: #f4f8fd;
    color: #38638e;
    font-size: 12px;
    font-weight: 700;
}

.forecast-overview,
.forecast-context,
.forecast-notes,
.forecast-outcome,
.forecast-similar,
.forecast-suppliers {
    margin: 0 0 12px;
    border: 1px solid #d8d8d8;
    background: #fff;
}

.forecast-overview {
    display: grid;
    grid-template-columns: minmax(260px, 0.72fr) minmax(0, 1fr);
}

.forecast-price {
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 7px;
    padding: 18px 20px;
    border-right: 1px solid #e2e7ef;
    background: #f6f9fd;
}

.forecast-price span,
.forecast-kpi-grid span,
.forecast-context span,
.forecast-outcome span,
.forecast-similar-card span,
.forecast-similar-money span,
.forecast-table th {
    display: block;
    color: #6f7f98;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.forecast-price strong {
    color: #0d3264;
    font-size: 28px;
    font-weight: 800;
    line-height: 1.05;
}

.forecast-price small,
.forecast-price em,
.forecast-context small,
.forecast-outcome small,
.forecast-similar-card small,
.forecast-table small {
    display: block;
    color: #60718c;
    font-size: 12px;
    font-style: normal;
    line-height: 1.3;
}

.forecast-price em {
    color: #a35f00;
    font-weight: 700;
}

.forecast-kpi-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.forecast-kpi-grid div {
    min-width: 0;
    padding: 14px 16px;
    border-right: 1px solid #edf1f6;
    border-bottom: 1px solid #edf1f6;
}

.forecast-kpi-grid div:nth-child(3n) {
    border-right: 0;
}

.forecast-kpi-grid div:nth-last-child(-n + 3) {
    border-bottom: 0;
}

.forecast-kpi-grid b,
.forecast-context b,
.forecast-outcome b {
    display: block;
    margin-top: 5px;
    color: #061735;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.18;
}

.forecast-context {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr;
}

.forecast-context div {
    min-width: 0;
    padding: 13px 16px;
    border-right: 1px solid #edf1f6;
}

.forecast-context div:last-child {
    border-right: 0;
}

.forecast-notes {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0;
}

.forecast-notes div {
    min-width: 0;
    padding: 12px 16px;
    border-right: 1px solid #edf1f6;
    border-bottom: 1px solid #edf1f6;
    color: #20304a;
    font-size: 13px;
    line-height: 1.35;
}

.forecast-notes div:nth-child(2n) {
    border-right: 0;
}

.forecast-notes div:nth-last-child(-n + 2) {
    border-bottom: 0;
}

.forecast-outcome {
    padding: 13px 16px;
    border-left: 4px solid #1ab56c;
}

.forecast-subtitle {
    min-height: 42px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0 16px;
    border-bottom: 1px solid #e4e8ef;
}

.forecast-subtitle h3 {
    margin: 0;
    color: #1a2546;
    font-size: 16px;
    font-weight: 700;
}

.forecast-subtitle span {
    color: #71809a;
    font-size: 13px;
}

.forecast-table-wrap {
    overflow-x: auto;
}

.forecast-table {
    width: 100%;
    min-width: 1040px;
    border-collapse: collapse;
}

.forecast-table th,
.forecast-table td {
    padding: 12px 14px;
    border-bottom: 1px solid #edf1f6;
    text-align: left;
    vertical-align: top;
}

.forecast-table thead {
    background: #f3f6fa;
}

.forecast-table td {
    color: #061735;
    font-size: 13px;
    line-height: 1.3;
}

.forecast-table td > b,
.forecast-supplier-name b,
.forecast-similar-card b {
    display: block;
    color: #061735;
    font-size: 13px;
    font-weight: 800;
}

.forecast-similar-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.forecast-similar-card {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 14px 16px;
    border-right: 1px solid #edf1f6;
    border-bottom: 1px solid #edf1f6;
    color: #061735;
    text-decoration: none;
}

.forecast-similar-card:nth-child(3n) {
    border-right: 0;
}

.forecast-similar-card:nth-last-child(-n + 3) {
    border-bottom: 0;
}

.forecast-similar-card:hover strong {
    color: #0969c3;
}

.forecast-similar-card strong {
    display: block;
    color: #0d3264;
    font-size: 14px;
    font-weight: 800;
    line-height: 1.25;
}

.forecast-similar-card em {
    display: block;
    color: #4a5d7a;
    font-size: 12px;
    font-style: normal;
    line-height: 1.35;
}

.forecast-similar-money {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
    margin-top: 4px;
}

.forecast-similar-money div {
    min-width: 0;
    padding: 8px 9px;
    border: 1px solid #e5ebf3;
    background: #f8fafc;
}

.forecast-similar-money b {
    margin-top: 3px;
    font-size: 12px;
    line-height: 1.2;
}

.forecast-supplier-name {
    max-width: 270px;
}

.forecast-status {
    display: inline-flex;
    align-items: center;
    min-height: 22px;
    padding: 0 8px;
    border-radius: 3px;
    background: #eef3f8;
    color: #53637d;
    font-size: 12px;
    font-weight: 800;
}

.forecast-status.won {
    background: #e5f8ee;
    color: #04753b;
}

.forecast-status.seen {
    background: #eef6ff;
    color: #17619d;
}

.forecast-status.pending {
    background: #fff6e5;
    color: #9b5a00;
}

.forecast-status.muted {
    color: #77849a;
}

@media (max-width: 980px) {
    .forecast-overview,
    .forecast-context,
    .forecast-notes,
    .forecast-similar-grid {
        grid-template-columns: 1fr;
    }

    .forecast-price,
    .forecast-context div,
    .forecast-notes div,
    .forecast-similar-card {
        border-right: 0;
    }

    .forecast-context div {
        border-bottom: 1px solid #edf1f6;
    }

    .forecast-context div:last-child {
        border-bottom: 0;
    }

    .forecast-notes div:nth-last-child(-n + 2) {
        border-bottom: 1px solid #edf1f6;
    }

    .forecast-notes div:last-child {
        border-bottom: 0;
    }

    .forecast-similar-card:nth-last-child(-n + 3) {
        border-bottom: 1px solid #edf1f6;
    }

    .forecast-similar-card:last-child {
        border-bottom: 0;
    }
}

@media (max-width: 760px) {
    .forecast-kpi-grid {
        grid-template-columns: 1fr 1fr;
    }

    .forecast-kpi-grid div:nth-child(3n) {
        border-right: 1px solid #edf1f6;
    }

    .forecast-kpi-grid div:nth-child(2n) {
        border-right: 0;
    }

    .forecast-kpi-grid div:nth-last-child(-n + 3) {
        border-bottom: 1px solid #edf1f6;
    }

    .forecast-kpi-grid div:nth-last-child(-n + 2) {
        border-bottom: 0;
    }

    .forecast-price strong {
        font-size: 23px;
    }

    .forecast-similar-money {
        grid-template-columns: 1fr;
    }
}

.lot-cards {
    border: 1px solid #d8d8d8;
    background: #fff;
}

.lot-empty {
    padding: 28px 15px;
    color: #8695af;
    text-align: center;
}

.lot-card {
    background: #fff;
    border-bottom: 1px solid #d8d8d8;
}

.lot-card:last-child {
    border-bottom: 0;
}

.lot-card-head {
    min-height: 54px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 12px 15px;
    background: #efeff0;
}

.lot-card:nth-of-type(even) .lot-card-head {
    background: #fff;
}

.lot-card-head span,
.lot-card-meta dt,
.lot-data-title span,
.lot-mini-table th {
    display: block;
    color: #8695af;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.lot-card-head h3,
.lot-card-head strong,
.lot-data-title h4 {
    margin: 0;
    color: #1a2546;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.2;
}

.lot-card-head strong {
    white-space: nowrap;
}

.lot-card-title {
    padding: 15px;
    color: #0085bd;
    font-size: 16px;
    font-weight: 600;
    line-height: 1.25;
    text-transform: uppercase;
}

.lot-card-meta {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1.3fr;
    margin: 0;
    border-top: 1px solid #e7e7e7;
    border-bottom: 1px solid #e7e7e7;
}

.lot-card-meta div {
    min-width: 0;
    padding: 13px 15px;
    border-right: 1px solid #e7e7e7;
}

.lot-card-meta div:last-child {
    border-right: 0;
}

.lot-card-meta dd {
    margin: 6px 0 0;
    color: #1a2546;
    font-size: 14px;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.lot-data-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
}

.lot-data-panel {
    min-width: 0;
    padding: 13px 15px 15px;
}

.lot-data-panel + .lot-data-panel {
    border-left: 1px solid #e7e7e7;
}

.lot-data-title {
    min-height: 28px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 8px;
}

.lot-muted {
    margin: 0;
    color: #8695af;
    font-size: 13px;
    line-height: 1.25;
}

.lot-mini-table {
    width: 100%;
    border-collapse: collapse;
}

.lot-mini-table th,
.lot-mini-table td {
    padding: 9px 8px;
    border-top: 1px solid #e9e9e9;
    text-align: left;
    vertical-align: top;
}

.lot-mini-table td {
    color: #1a2546;
    font-size: 13px;
    line-height: 1.25;
    overflow-wrap: anywhere;
}

.lot-cards {
    margin: 0 16px;
    border: 0;
    background: transparent;
    box-shadow: 0 1px 0 rgba(26, 37, 70, 0.04);
}

.lot-card {
    margin: 0;
    border: 0;
    border-radius: 0;
    background: #fff;
    box-shadow: none;
    overflow: visible;
}

.lot-residency-strip {
    display: grid;
    grid-template-columns: 122px 174px minmax(0, 1fr);
    align-items: end;
    min-height: 34px;
    background: #fff;
    color: #000;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.05;
}

.lot-residency-strip span {
    padding: 0 0 1px;
}

.lot-card:last-child {
    border-bottom: 0;
}

.lot-card-head {
    min-height: 96px;
    display: grid;
    grid-template-columns: 64px minmax(215px, 1.35fr) 92px minmax(260px, 1.6fr) minmax(215px, 1.22fr) minmax(175px, 0.98fr) 28px;
    align-items: stretch;
    gap: 0;
    padding: 0;
    background: var(--official-head);
    border: 1px solid #d8d8d8;
    border-bottom: 0;
    transition: background .16s ease, box-shadow .16s ease;
}

.lot-card-goods .lot-card-head {
    min-height: 82px;
    grid-template-columns: 122px 174px 104px 164px 228px 160px 218px 28px;
}

.lot-cards .lot-card .lot-card-head {
    background-color: var(--official-head);
}

.lot-card:hover .lot-card-head,
.lot-card.is-open .lot-card-head {
    background: #f7f9fb;
    background-color: #f7f9fb;
}

.lot-card.is-open .lot-card-head {
    box-shadow: inset 4px 0 0 #1785aa;
}

.lot-head-cell {
    min-width: 0;
    padding: 14px 10px 10px;
    border-right: 1px solid #fff;
}

.lot-head-number {
    padding-left: 10px;
}

.lot-card-head span,
.lot-card-head .lot-head-cell span {
    display: block;
    margin: 0 0 6px;
    color: #68758c;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.15;
    text-transform: uppercase;
}

.lot-card-head h3,
.lot-card-head b,
.lot-card-head strong {
    display: block;
    margin: 0;
    color: #1a2546;
    font-size: 13px;
    font-weight: 500;
    line-height: 1.18;
    overflow-wrap: anywhere;
}

.lot-card-head b {
    text-transform: uppercase;
}

.lot-card-goods .lot-head-deadline b:not(.lot-empty-value),
.lot-card-goods .lot-head-schedule b:not(.lot-empty-value) {
    color: #ff5a00;
}

.lot-card-goods .lot-head-sum strong {
    white-space: nowrap;
}

.lot-card-head strong {
    white-space: normal;
}

.lot-chevron {
    position: relative;
    align-self: start;
    justify-self: center;
    width: 18px;
    height: 18px;
    margin-top: 18px;
    padding: 0;
    border: 0;
    border-radius: 50%;
    background: #1a2546;
    cursor: pointer;
    transition: background .16s ease, transform .16s ease;
}

.lot-chevron::before {
    content: "";
    position: absolute;
    left: 6px;
    top: 5px;
    width: 5px;
    height: 5px;
    border-right: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(45deg);
}

.lot-card.is-collapsed .lot-chevron::before {
    top: 6px;
    left: 5px;
    transform: rotate(-45deg);
}

.lot-chevron:hover,
.lot-chevron:focus-visible {
    background: #1785aa;
    outline: 2px solid rgba(23, 133, 170, 0.22);
    outline-offset: 2px;
}

.lot-card.is-open .lot-chevron {
    background: #1785aa;
}

.lot-card-title,
.lot-card-meta {
    display: none;
}

.lot-spoiler-panel[hidden] {
    display: none;
}

.lot-card-body {
    border: 1px solid #d8d8d8;
    border-top: 1px solid #bfc4cc;
    background: #fff;
    box-shadow: 0 12px 28px rgba(26, 37, 70, 0.14);
}

.lot-plan-lines {
    padding: 11px 9px 1px;
    color: #7f8aa0;
    font-size: 12px;
    font-weight: 400;
    line-height: 1.35;
}

.lot-plan-lines p {
    margin: 0 0 13px;
}

.lot-plan-lines span {
    text-transform: uppercase;
}

.lot-doc-heading {
    margin: 0;
    padding: 0 9px 10px;
    color: #000;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.22;
}

.lot-formation-row {
    min-height: 40px;
    display: flex;
    align-items: center;
    padding: 0 10px;
    border-top: 1px solid #d8d8d8;
    border-bottom: 1px solid #e0e0e0;
    color: #7f8aa0;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.lot-product-row {
    padding: 0 10px 8px;
    color: #7f8aa0;
    font-size: 10px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.lot-requirements-grid {
    display: grid;
    grid-template-columns: minmax(260px, 1.55fr) minmax(140px, 0.7fr) minmax(100px, 0.45fr) minmax(210px, 1fr) minmax(170px, 0.8fr);
    align-items: start;
    background: #fff;
}

.lot-requirements-grid > div {
    min-width: 0;
    min-height: 68px;
    padding: 13px 10px 7px;
}

.lot-requirements-grid span {
    display: block;
    margin-bottom: 5px;
    color: #000;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.15;
}

.lot-requirements-grid b {
    display: block;
    color: #1a2546;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.2;
    overflow-wrap: anywhere;
}

.lot-requirements-grid a {
    color: #0085bd;
}

.lot-items-wrap {
    overflow-x: auto;
    border-top: 1px solid #d8d8d8;
}

.lot-items-table {
    width: 100%;
    min-width: 760px;
    border-collapse: collapse;
    color: #1a2546;
}

.lot-items-table th,
.lot-items-table td {
    padding: 10px 9px;
    border-bottom: 1px solid #eceef2;
    text-align: left;
    vertical-align: top;
    font-size: 13px;
    line-height: 1.25;
}

.lot-items-table thead {
    background: #f2f3f5;
}

.lot-items-table th {
    color: #54617a;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    white-space: nowrap;
}

.lot-items-table b,
.lot-items-table span {
    display: block;
}

.lot-items-table b {
    margin-bottom: 3px;
    font-weight: 600;
}

.lot-items-table span {
    color: #54617a;
}

.lot-items-table a {
    color: #0085bd;
    font-weight: 600;
}

.lot-data-grid {
    border-top: 1px solid #d8d8d8;
}

.qualification-section {
    padding-top: 25px;
}

.qualification-section .detail-section-title {
    min-height: 34px;
    border: 0;
    background: transparent;
    padding: 0;
    margin-bottom: 14px;
}

.qualification-section .detail-section-title h2 {
    color: #1a2546;
    font-size: 20px;
    font-weight: 500;
}

.qualification-table-wrap {
    border: 0;
}

.qualification-table {
    border-collapse: collapse;
    border-spacing: 0;
}

.qualification-table thead {
    background: var(--official-gray);
}

.detail-table.qualification-table th {
    border-bottom: 0;
    border-right: 8px solid #fff;
    background: var(--official-gray);
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    text-align: center;
    text-transform: uppercase;
}

.detail-table.qualification-table th:first-child {
    width: 52px;
    text-align: left;
}

.detail-table.qualification-table td {
    border-bottom: 0;
    color: #32394d;
    font-size: 15px;
    line-height: 1.35;
    text-align: left;
}

.detail-table.qualification-table tbody tr:nth-child(odd),
.detail-table.qualification-table tbody tr:nth-child(even) {
    background: #fff;
}

.detail-table.qualification-table .detail-empty {
    color: #8695af;
    text-align: left !important;
}

.detail-table-wrap {
    overflow-x: auto;
    border: 1px solid #d8d8d8;
}

.detail-table-wrap.qualification-table-wrap {
    border: 0;
}

.detail-table {
    width: 100%;
    border-collapse: collapse;
    color: #1a2546;
}

.detail-table thead {
    background: #f2f3f5;
}

.detail-table th,
.detail-table td {
    padding: 13px 15px;
    border-bottom: 1px solid #e9e9e9;
    vertical-align: top;
    text-align: left;
}

.detail-table th {
    display: table-cell;
    margin-bottom: 0;
    white-space: nowrap;
}

.detail-table td {
    font-size: 14px;
    line-height: 1.25;
}

.detail-table tbody tr:nth-child(odd) {
    background: #efeff0;
}

.detail-table tbody tr:nth-child(even) {
    background: #fff;
}

.detail-table a {
    color: #0085bd;
    font-weight: 600;
}

.detail-table.official-gray-table thead {
    background: var(--official-gray);
}

.detail-table.official-gray-table th {
    border-bottom: 0;
    border-right: 8px solid #fff;
    background: var(--official-gray);
    color: #fff;
    font-size: 14px;
    font-weight: 500;
    text-align: center;
    text-transform: uppercase;
}

.detail-table.official-gray-table th:last-child {
    border-right: 0;
}

.special-requirements-wrap {
    border: 0;
}

.compact-detail-table td {
    padding: 10px 12px;
    line-height: 1.35;
}

.compact-detail-table td:first-child {
    width: 34%;
    color: #8695af;
    font-weight: 600;
}

.compact-detail-table tbody tr:nth-child(odd) {
    background: #efeff0;
}

.compact-detail-table tbody tr:nth-child(even) {
    background: #fff;
}

.evaluation-criteria-table td {
    text-align: center;
}

.contract-conditions-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.95fr);
    gap: 24px;
    align-items: start;
}

.contract-side-tables {
    display: grid;
    gap: 24px;
}

.condition-subhead {
    background: #fff !important;
    color: #1a2546 !important;
    font-weight: 600 !important;
    text-align: center !important;
}

.detail-empty {
    color: #8695af;
    text-align: center !important;
}

.winner-badge {
    display: inline-flex;
    margin: 0 6px 4px 0;
    padding: 3px 6px;
    border-radius: 3px;
    background: #dff4e8;
    color: #16834c;
    font-size: 12px;
}

.status-main {
    padding: 22px 20px 28px;
}

.status-header {
    border: 1px solid #d8d8d8;
    background: #efeff0;
    padding: 18px 20px;
}

.status-header span {
    color: #54617a;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.status-header h1 {
    margin: 8px 0 8px;
    color: #0085bd;
    font-size: 22px;
    font-weight: 600;
}

.status-header p {
    margin: 0;
    color: #54617a;
    font-size: 14px;
    line-height: 1.35;
}

.section-main {
    padding: 22px 20px 28px;
}

.section-header {
    margin-bottom: 14px;
}

.section-card {
    border: 1px solid var(--official-line);
    background: #fff;
    padding: 16px;
    border-radius: 3px;
    box-shadow: 0 1px 0 rgba(26, 37, 70, 0.04);
}

.section-card + .section-card {
    margin-top: 14px;
}

.section-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 12px;
    padding-bottom: 12px;
    border-bottom: 1px solid #edf1f6;
}

.section-card-head span {
    color: #54617a;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
}

.section-card-head h2 {
    margin: 0;
    color: #0085bd;
    font-size: 18px;
    font-weight: 600;
}

.section-search-form {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: end;
    gap: 10px;
}

.section-search-form label {
    display: grid;
    gap: 6px;
    color: #54617a;
    font-size: 12px;
    font-weight: 700;
}

.section-search-form input {
    width: 100%;
    height: 38px;
    border: 1px solid #cfd8e3;
    border-radius: 3px;
    padding: 0 10px;
    outline: 0;
}

.section-search-form input:focus {
    border-color: #1785aa;
    box-shadow: 0 0 0 3px rgba(23, 133, 170, 0.12);
}

.section-search-form button,
.section-search-form a,
.section-actions a,
.section-pager a {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 14px;
    border: 1px solid #cfd8e3;
    border-radius: 3px;
    background: #fff;
    color: #54617a;
    font-weight: 600;
    transition: background .16s ease, border-color .16s ease, color .16s ease;
}

.section-search-form button,
.section-actions a.primary {
    border-color: var(--blue);
    background: var(--blue);
    color: #fff;
}

.section-search-form button:hover,
.section-search-form a:hover,
.section-actions a:hover,
.section-pager a:hover {
    border-color: #1785aa;
    background: #f6fbfe;
    color: #1785aa;
}

.section-search-form button:hover,
.section-actions a.primary:hover {
    background: #0f759b;
    color: #fff;
}

.section-table-wrap {
    overflow-x: auto;
    border: 1px solid var(--official-line);
}

.section-table {
    width: 100%;
    min-width: 920px;
    border-collapse: collapse;
    background: #fff;
}

.section-table th,
.section-table td {
    padding: 12px 10px;
    border-bottom: 1px solid #e7ebf1;
    color: #1a2546;
    font-size: 14px;
    line-height: 1.25;
    text-align: left;
    vertical-align: top;
}

.section-table th {
    background: var(--official-head);
    color: #68758c;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    white-space: nowrap;
}

.section-table tbody tr:nth-child(even) {
    background: #fbfcfe;
}

.section-table tbody tr:hover {
    background: #f4f8fc;
}

.section-table b {
    font-weight: 600;
}

.section-entity-link {
    color: #087ca5;
    font-weight: 700;
}

.supplier-metric-kpis {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 10px;
    margin-bottom: 14px;
}

.supplier-metric-kpis article {
    display: grid;
    align-content: start;
    gap: 6px;
    min-height: 88px;
    border: 1px solid var(--official-line);
    border-radius: 3px;
    background: #fff;
    padding: 14px 15px;
    box-shadow: 0 1px 0 rgba(26, 37, 70, 0.04);
}

.supplier-metric-kpis span,
.supplier-metric-table small,
.supplier-metric-head p {
    color: #68758c;
    font-size: 12px;
    line-height: 1.25;
}

.supplier-metric-kpis b {
    color: #1a2546;
    font-size: 19px;
    line-height: 1.15;
}

.supplier-metric-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin: 0 0 14px;
}

.supplier-metric-tabs a {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #cfd8e3;
    border-radius: 3px;
    background: #fff;
    padding: 0 13px;
    color: #54617a;
    font-size: 13px;
    font-weight: 700;
    text-decoration: none;
}

.supplier-metric-tabs a.active {
    border-color: var(--blue);
    background: var(--blue);
    color: #fff;
}

.supplier-metric-filter {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) 180px 150px 120px auto auto;
    align-items: end;
    gap: 10px;
}

.supplier-metric-filter label {
    display: grid;
    gap: 6px;
    color: #54617a;
    font-size: 12px;
    font-weight: 700;
}

.supplier-metric-filter input,
.supplier-metric-filter select {
    width: 100%;
    height: 38px;
    border: 1px solid #cfd8e3;
    border-radius: 3px;
    background: #fff;
    padding: 0 10px;
    outline: 0;
}

.supplier-metric-filter input:focus,
.supplier-metric-filter select:focus {
    border-color: #1785aa;
    box-shadow: 0 0 0 3px rgba(23, 133, 170, 0.12);
}

.supplier-metric-filter button,
.supplier-metric-filter a {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #cfd8e3;
    border-radius: 3px;
    padding: 0 14px;
    font-weight: 700;
    text-decoration: none;
}

.supplier-metric-filter button {
    border-color: var(--blue);
    background: var(--blue);
    color: #fff;
}

.supplier-metric-filter a {
    background: #fff;
    color: #54617a;
}

.supplier-metric-head {
    align-items: flex-start;
}

.supplier-metric-head p {
    margin: 0;
    text-align: right;
}

.supplier-metric-wrap .section-table {
    min-width: 1208px;
    table-layout: fixed;
}

.supplier-metric-table td {
    font-size: 13px;
}

.supplier-metric-table th:nth-child(1),
.supplier-metric-table td:nth-child(1) {
    width: 290px;
}

.supplier-metric-table th:nth-child(2),
.supplier-metric-table td:nth-child(2) {
    width: 150px;
}

.supplier-metric-table th:nth-child(3),
.supplier-metric-table td:nth-child(3),
.supplier-metric-table th:nth-child(4),
.supplier-metric-table td:nth-child(4) {
    width: 74px;
}

.supplier-metric-table th:nth-child(5),
.supplier-metric-table td:nth-child(5) {
    width: 118px;
}

.supplier-metric-table th:nth-child(6),
.supplier-metric-table td:nth-child(6),
.supplier-metric-table th:nth-child(7),
.supplier-metric-table td:nth-child(7) {
    width: 132px;
}

.supplier-metric-table th:nth-child(8),
.supplier-metric-table td:nth-child(8) {
    width: 94px;
}

.supplier-metric-table th:nth-child(9),
.supplier-metric-table td:nth-child(9) {
    width: 126px;
}

.supplier-metric-table small {
    display: block;
    margin-top: 5px;
}

.supplier-metric-name {
    display: -webkit-box;
    max-height: 38px;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    color: #087ca5;
    font-weight: 700;
    line-height: 1.22;
    text-decoration: none;
}

.supplier-metric-inn {
    white-space: nowrap;
}

.supplier-metric-category {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    border: 1px solid #d7e4f0;
    border-radius: 3px;
    background: #f7fbff;
    padding: 3px 7px;
    color: #1a5b84;
    font-size: 12px;
    font-weight: 700;
    line-height: 1.2;
}

.supplier-metric-progress {
    width: 105px;
    height: 7px;
    margin-top: 7px;
    border-radius: 999px;
    background: #dfe8f2;
    overflow: hidden;
}

.supplier-metric-progress span {
    display: block;
    height: 100%;
    border-radius: inherit;
    background: #23b35b;
}

.supplier-metric-card .section-pager {
    flex-wrap: wrap;
}

.supplier-metric-card .section-pager span,
.supplier-metric-card .section-pager a {
    min-width: 38px;
}

.supplier-metric-card .section-pager span.active {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--blue);
    border-radius: 3px;
    background: var(--blue);
    padding: 0 13px;
    color: #fff;
    font-weight: 700;
}

.supplier-main {
    display: grid;
    gap: 16px;
}

.supplier-summary {
    display: grid;
    gap: 16px;
}

.supplier-backline {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    color: #68758c;
    font-size: 13px;
    font-weight: 700;
}

.supplier-backline a {
    color: #087ca5;
}

.supplier-profile-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin: 0;
}

.supplier-profile-grid div,
.supplier-kpis article {
    border: 1px solid var(--official-line);
    background: #fff;
}

.supplier-profile-grid div {
    padding: 14px;
}

.buyer-registry-line {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 16px;
}

.buyer-registry-line a,
.buyer-registry-line span {
    display: inline-flex;
    min-height: 34px;
    align-items: center;
    border-radius: 8px;
    background: #eef4ff;
    color: #315178;
    font-size: 13px;
    font-weight: 800;
    padding: 0 12px;
    text-decoration: none;
}

.buyer-registry-line a {
    color: #075ca8;
}

.buyer-methods .supplier-table-head {
    margin-bottom: 12px;
}

.supplier-profile-grid dt,
.supplier-kpis span,
.supplier-table-head span {
    color: #68758c;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 0;
    text-transform: uppercase;
}

.supplier-profile-grid dd {
    margin: 7px 0 0;
    color: #1a2546;
    font-weight: 600;
    line-height: 1.35;
}

.supplier-kpis {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
}

.supplier-kpis article {
    display: grid;
    align-content: center;
    gap: 7px;
    min-height: 114px;
    padding: 18px;
}

.supplier-kpis b {
    color: #1a2546;
    font-size: 25px;
    line-height: 1.05;
}

.supplier-kpis small,
.supplier-table-head p,
.supplier-result-table small {
    color: #68758c;
    font-size: 12px;
    line-height: 1.35;
}

.supplier-results {
    display: grid;
    gap: 16px;
}

.supplier-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.supplier-tabs a,
.supplier-pages a,
.supplier-pages span {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #cfd8e3;
    border-radius: 3px;
    background: #fff;
    color: #54617a;
    font-weight: 700;
}

.supplier-tabs a {
    padding: 0 14px;
}

.supplier-tabs a.active,
.supplier-pages span.active {
    border-color: var(--blue);
    background: var(--blue);
    color: #fff;
}

.supplier-table-head {
    display: flex;
    justify-content: space-between;
    align-items: end;
    gap: 16px;
}

.supplier-table-head h2 {
    margin: 7px 0 5px;
    color: #1a2546;
    font-size: 24px;
    line-height: 1.15;
}

.supplier-table-head p {
    margin: 0;
}

.supplier-limit label {
    display: grid;
    gap: 6px;
    color: #54617a;
    font-size: 12px;
    font-weight: 700;
}

.supplier-limit select {
    min-width: 86px;
    height: 38px;
    border: 1px solid #cfd8e3;
    border-radius: 3px;
    background: #fff;
    padding: 0 8px;
}

.supplier-result-table small {
    display: block;
    max-width: 360px;
    margin-top: 5px;
}

.supplier-tender-table {
    min-width: 1180px;
}

.supplier-status {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 9px;
    border-radius: 3px;
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.supplier-status.won {
    background: #e8f8ee;
    color: #167242;
}

.supplier-status.lost {
    background: #fff1f2;
    color: #a91d2d;
}

.supplier-status.taken {
    background: #fff7ed;
    color: #b45309;
}

.supplier-status.pending {
    background: #eef4fb;
    color: #54617a;
}

.supplier-activity {
    display: grid;
    gap: 18px;
}

.supplier-chart-legend {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    color: #54617a;
    font-size: 12px;
    font-weight: 800;
}

.supplier-chart-legend span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}

.supplier-chart-legend i {
    width: 10px;
    height: 10px;
    display: inline-block;
    border-radius: 2px;
}

.supplier-chart-legend .wins,
.supplier-chart-bars .wins {
    background: #1785aa;
}

.supplier-chart-legend .taken,
.supplier-chart-bars .taken {
    background: #f59e0b;
}

.supplier-chart-legend .participated,
.supplier-chart-bars .participated {
    background: #cbd5e1;
}

.supplier-chart-block {
    display: grid;
    gap: 10px;
}

.supplier-chart-block h3 {
    margin: 0;
    color: #1a2546;
    font-size: 16px;
}

.supplier-activity-chart {
    min-height: 286px;
    display: grid;
    grid-template-columns: repeat(12, minmax(96px, 1fr));
    gap: 10px;
    align-items: end;
    overflow-x: auto;
    padding: 12px 4px 0;
}

.supplier-activity-chart.yearly {
    grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
}

.supplier-activity-chart.yearly .supplier-chart-col {
    min-width: 110px;
}

.supplier-chart-col {
    min-width: 96px;
    display: grid;
    gap: 6px;
    justify-items: center;
}

.supplier-chart-bars {
    position: relative;
    width: 100%;
    height: 150px;
    display: flex;
    align-items: end;
    justify-content: center;
    gap: 3px;
    border-bottom: 1px solid var(--official-line);
}

.supplier-chart-bars i {
    width: 11px;
    min-height: 2px;
    display: block;
    border-radius: 3px 3px 0 0;
}

.supplier-chart-col b {
    color: #1a2546;
    font-size: 12px;
}

.supplier-chart-label {
    color: #68758c;
    font-size: 11px;
    white-space: nowrap;
}

.supplier-chart-metrics {
    width: 100%;
    display: grid;
    gap: 2px;
}

.supplier-chart-metrics span {
    min-height: 16px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 4px;
    color: #1a2546;
    font-size: 10px;
    font-weight: 800;
    line-height: 1;
    white-space: nowrap;
}

.supplier-chart-metrics i {
    width: 7px;
    height: 7px;
    display: inline-block;
    flex: 0 0 auto;
    border-radius: 2px;
}

.supplier-chart-metrics .wins i {
    background: #1785aa;
}

.supplier-chart-metrics .taken i {
    background: #f59e0b;
}

.supplier-chart-metrics .participated i {
    background: #cbd5e1;
}

.supplier-chart-money {
    width: 100%;
    padding: 4px 6px;
    border: 1px solid #e3eaf3;
    border-radius: 3px;
    background: #f8fafc;
    color: #1a2546;
    font-size: 10px;
    font-weight: 800;
    line-height: 1.15;
    text-align: center;
    white-space: nowrap;
}

.supplier-activity-grid {
    display: grid;
    grid-template-columns: minmax(0, .9fr) minmax(0, 1.1fr);
    gap: 14px;
}

.supplier-activity-table h3 {
    margin: 0 0 10px;
    color: #1a2546;
    font-size: 18px;
}

.supplier-small-table {
    min-width: 620px;
}

.supplier-activity-money-table {
    min-width: 1080px;
}

.supplier-small-table th,
.supplier-small-table td {
    font-size: 12px;
}

.supplier-lot-details summary {
    cursor: pointer;
    color: #087ca5;
    font-weight: 800;
    white-space: nowrap;
}

.supplier-lots-wrap {
    width: min(720px, 72vw);
    margin-top: 10px;
    overflow-x: auto;
    border: 1px solid var(--official-line);
    background: #fff;
}

.supplier-lots-table {
    width: 100%;
    min-width: 620px;
    border-collapse: collapse;
}

.supplier-lots-table th,
.supplier-lots-table td {
    padding: 9px 10px;
    border-bottom: 1px solid #e7ebf1;
    color: #1a2546;
    font-size: 12px;
    line-height: 1.25;
    text-align: left;
    vertical-align: top;
}

.supplier-lots-table th {
    background: var(--official-head);
    color: #68758c;
    font-size: 10px;
    font-weight: 800;
    text-transform: uppercase;
}

.supplier-lots-table small {
    display: block;
    max-width: 280px;
    margin-top: 4px;
    color: #68758c;
    line-height: 1.35;
}

.supplier-pages {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 8px;
}

.supplier-pages a,
.supplier-pages span {
    min-width: 38px;
    padding: 0 12px;
}

@media (max-width: 980px) {
    .supplier-profile-grid,
    .supplier-kpis,
    .supplier-metric-kpis,
    .supplier-activity-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .supplier-metric-filter {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 640px) {
    .supplier-profile-grid,
    .supplier-kpis,
    .supplier-metric-kpis,
    .supplier-metric-filter,
    .supplier-activity-grid {
        grid-template-columns: 1fr;
    }

    .supplier-backline,
    .supplier-table-head,
    .supplier-metric-head {
        flex-direction: column;
        align-items: flex-start;
    }

    .supplier-metric-tabs {
        display: grid;
        grid-template-columns: 1fr;
    }

    .supplier-metric-filter button,
    .supplier-metric-filter a,
    .supplier-metric-tabs a {
        width: 100%;
    }

    .supplier-metric-head p {
        text-align: left;
    }
}

.section-list {
    display: grid;
    gap: 10px;
}

.section-list p,
.section-faq p {
    margin: 0;
    color: #1a2546;
    font-size: 15px;
    line-height: 1.45;
}

.section-faq {
    display: grid;
    gap: 8px;
}

.section-faq details {
    border: 1px solid var(--official-line);
    background: #fbfcfe;
}

.section-faq summary {
    min-height: 40px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    color: #0085bd;
    font-weight: 700;
    cursor: pointer;
}

.section-faq p {
    padding: 0 12px 12px;
}

.section-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 18px;
}

.analytics-section {
    display: grid;
    gap: 22px;
}

.analytics-metrics {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.analytics-metric {
    min-height: 98px;
    display: grid;
    align-content: center;
    gap: 10px;
    padding: 18px;
    border: 1px solid var(--official-line);
    background: #fff;
    box-shadow: 0 1px 0 rgba(26, 37, 70, 0.04);
}

.analytics-metric span,
.analytics-panel dt {
    color: #61708b;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.analytics-metric b {
    color: #1a2546;
    font-size: 28px;
    line-height: 1;
}

.analytics-split {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 16px;
}

.analytics-panel {
    border: 1px solid var(--official-line);
    background: #fff;
}

.analytics-panel h2 {
    margin: 0;
    padding: 16px 18px;
    border-bottom: 1px solid #edf1f6;
    color: #1a2546;
    font-size: 18px;
}

.analytics-panel dl {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
}

.analytics-panel dl div {
    min-height: 78px;
    display: grid;
    align-content: center;
    gap: 8px;
    padding: 16px 18px;
    border-right: 1px solid #edf1f6;
    border-bottom: 1px solid #edf1f6;
}

.analytics-panel dd {
    margin: 0;
    color: #1785aa;
    font-size: 22px;
    font-weight: 800;
}

.analytics-latest-head {
    margin-top: 4px;
}

.analytics-actions {
    margin-top: 0;
}

.section-pager {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 10px;
    margin-top: 12px;
    color: #54617a;
}

.section-pager a.disabled {
    opacity: .45;
    pointer-events: none;
}

.login-main {
    width: 850px;
    max-width: calc(100% - 30px);
    min-height: 470px;
    padding: 40px 20px 34px;
}

.login-back {
    margin-bottom: 22px;
}

.login-card {
    max-width: 430px;
    margin: 0 auto;
    text-align: center;
}

.login-title span {
    display: block;
    margin-bottom: 30px;
    color: #1a2546;
    font-size: 24px;
    font-weight: 400;
}

.login-title h1 {
    margin: 0 0 20px;
    color: #1a2546;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
    text-transform: uppercase;
}

.login-alert {
    margin: 0 0 16px;
    text-align: left;
}

.uac-login-form {
    display: grid;
    gap: 14px;
}

.uac-login-form input {
    width: 100%;
    height: 46px;
    border: 1px solid #d8d8d8;
    border-radius: 3px;
    background: #fff;
    color: #1a2546;
    padding: 0 14px;
    font-size: 14px;
}

.uac-login-form input::placeholder {
    color: #8695af;
}

.login-links-row {
    display: flex;
    justify-content: center;
    gap: 0;
    color: #0085bd;
    font-size: 14px;
}

.login-links-row a + a::before {
    content: "";
    display: inline-block;
    width: 1px;
    height: 14px;
    margin: 0 8px;
    background: #d8d8d8;
    vertical-align: middle;
}

.uac-login-form button {
    width: 100%;
    height: 46px;
    border: 1px solid #f0bc20;
    border-radius: 3px;
    background: #f8d043;
    color: #1a2546;
    font-weight: 700;
    cursor: pointer;
}

.login-external-list {
    display: grid;
    gap: 8px;
    margin-top: 26px;
}

.login-external-list a {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #d8d8d8;
    border-radius: 3px;
    background: #fff;
    color: #0085bd;
    font-size: 14px;
    font-weight: 600;
}

.login-footer {
    width: 850px;
    max-width: calc(100% - 30px);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 14px 24px;
    margin: -40px auto 40px;
    color: #54617a;
    font-size: 13px;
}

.cabinet-shell {
    min-height: 100vh;
    background: #e8f0f8;
}

.cabinet-top {
    min-height: 68px;
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
    gap: 18px;
    padding: 0 18px;
    border-bottom: 1px solid #d3e1f1;
    background: #fff;
}

.cabinet-brand {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: #1a2546;
}

.cabinet-brand .brand-logo {
    width: 126px;
    height: 42px;
}

.cabinet-brand b {
    font-size: 18px;
    line-height: 1.2;
}

.cabinet-language {
    display: inline-flex;
    justify-content: center;
    gap: 4px;
}

.cabinet-language a {
    min-width: 34px;
    min-height: 30px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #d8d8d8;
    background: #fff;
    color: #54617a;
    font-weight: 700;
}

.cabinet-language a.active {
    border-color: #0085bd;
    color: #0085bd;
}

.cabinet-profile {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    color: #54617a;
    font-size: 13px;
}

.cabinet-profile span {
    max-width: 220px;
    overflow: hidden;
    color: #1a2546;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cabinet-layout {
    width: 1360px;
    max-width: calc(100% - 24px);
    display: grid;
    grid-template-columns: 286px minmax(0, 1fr);
    gap: 18px;
    margin: 18px auto 48px;
}

.cabinet-sidebar,
.cabinet-content,
.cabinet-card {
    border: 1px solid #d3e1f1;
    background: #fff;
    border-radius: 4px;
}

.cabinet-sidebar {
    align-self: start;
    overflow: hidden;
}

.cabinet-user {
    display: grid;
    gap: 6px;
    padding: 18px;
    border-bottom: 1px solid #d3e1f1;
    background: #f8fbff;
}

.cabinet-user span {
    color: #8695af;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.cabinet-user b {
    color: #1a2546;
    font-size: 18px;
}

.cabinet-menu {
    display: grid;
}

.cabinet-menu a {
    min-height: 43px;
    display: flex;
    align-items: center;
    padding: 0 18px;
    border-bottom: 1px solid #e7edf5;
    color: #1a2546;
    font-weight: 600;
    line-height: 1.2;
}

.cabinet-menu a:hover,
.cabinet-menu a.active {
    background: #0085bd;
    color: #fff;
}

.cabinet-content {
    min-width: 0;
    padding: 18px;
}

.cabinet-heading,
.cabinet-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.cabinet-heading {
    margin-bottom: 18px;
}

.cabinet-heading span {
    display: block;
    margin-bottom: 6px;
    color: #8695af;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.cabinet-heading h1 {
    margin: 0;
    color: #1a2546;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.2;
}

.cabinet-card {
    padding: 18px;
}

.cabinet-alert {
    margin: 0 0 14px;
    padding: 12px 14px;
    border: 1px solid #cfdceb;
    border-radius: 3px;
    background: #f8fbff;
    color: #1a2546;
    font-weight: 700;
}

.cabinet-alert.success {
    border-color: #9ad6b2;
    background: #eefbf3;
    color: #136b38;
}

.cabinet-alert.danger {
    border-color: #e5a7a7;
    background: #fff4f4;
    color: #9b2323;
}

.cabinet-card + .cabinet-card {
    margin-top: 18px;
}

.cabinet-card h2,
.cabinet-welcome h2 {
    margin: 0;
    color: #1a2546;
    font-size: 18px;
    line-height: 1.25;
}

.cabinet-card p {
    color: #54617a;
    line-height: 1.5;
}

.cabinet-button,
.cabinet-search-form button,
.cabinet-inline-form button {
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 16px;
    border: 1px solid #f0bc20;
    border-radius: 3px;
    background: #f8d043;
    color: #1a2546;
    font-weight: 800;
    cursor: pointer;
}

.cabinet-button.secondary {
    border-color: #d8d8d8;
    background: #fff;
    color: #0085bd;
}

.cabinet-notice-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.cabinet-notice-grid article,
.cabinet-notification-list article {
    min-width: 0;
    padding: 16px;
    border: 1px solid #d8d8d8;
    background: #f8fbff;
}

.cabinet-notice-grid span {
    width: 28px;
    height: 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
    border-radius: 50%;
    background: #0085bd;
    color: #fff;
    font-weight: 800;
}

.cabinet-notice-grid b,
.cabinet-notification-list b {
    display: block;
    color: #1a2546;
    line-height: 1.25;
}

.cabinet-card-head {
    margin-bottom: 14px;
}

.cabinet-search-form {
    display: grid;
    gap: 14px;
}

.cabinet-search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
}

.cabinet-search-row input,
.cabinet-filters input,
.cabinet-filters select,
.cabinet-settings-form input {
    width: 100%;
    height: 38px;
    border: 1px solid #cfdceb;
    border-radius: 3px;
    background: #fff;
    color: #1a2546;
    padding: 0 10px;
    outline: 0;
}

.cabinet-advanced summary {
    display: inline-flex;
    color: #0085bd;
    font-weight: 800;
    cursor: pointer;
}

.cabinet-filters {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 12px;
    margin-top: 12px;
}

.cabinet-filters label,
.cabinet-settings-form label {
    display: grid;
    gap: 6px;
    color: #54617a;
    font-size: 12px;
    font-weight: 800;
}

.cabinet-inline-form {
    align-items: end;
    margin-bottom: 14px;
}

.cabinet-tabs {
    display: flex;
    align-items: stretch;
    flex-wrap: wrap;
    margin: -18px -18px 18px;
    border-bottom: 1px solid #0085bd;
    background: #efeff0;
}

.cabinet-tabs a {
    min-height: 48px;
    display: inline-flex;
    align-items: center;
    padding: 0 15px;
    border-top: 1px solid #cecece;
    border-right: 1px solid #cecece;
    color: #0085bd;
    font-weight: 700;
}

.cabinet-tabs a.active {
    position: relative;
    top: 1px;
    border-color: #0085bd;
    border-bottom: 1px solid #fff;
    background: #fff;
}

.cabinet-table-wrap {
    width: 100%;
    overflow-x: auto;
    border: 1px solid #d8d8d8;
}

.cabinet-table {
    width: 100%;
    min-width: 960px;
    border-collapse: collapse;
    background: #fff;
}

.cabinet-table th,
.cabinet-table td {
    padding: 12px 10px;
    border-right: 1px solid #e7e7e7;
    border-bottom: 1px solid #e7e7e7;
    color: #1a2546;
    font-size: 13px;
    line-height: 1.3;
    text-align: left;
    vertical-align: top;
}

.cabinet-table th {
    background: #efeff0;
    color: #8695af;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
}

.cabinet-table td b {
    color: #0085bd;
    font-weight: 700;
}

.cabinet-row-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 8px;
    white-space: nowrap;
}

.cabinet-row-actions a {
    display: inline-flex;
    color: #0085bd;
    font-weight: 700;
}

.cabinet-pill {
    display: inline-flex;
    align-items: center;
    min-height: 24px;
    padding: 0 9px;
    border: 1px solid #cfdceb;
    border-radius: 999px;
    background: #f8fbff;
    color: #1a2546;
    font-size: 12px;
    font-weight: 800;
    white-space: nowrap;
}

.cabinet-notification-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.cabinet-settings-form {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.cabinet-settings-panel {
    min-height: 180px;
}

.cabinet-check {
    display: flex !important;
    align-items: center;
    gap: 8px;
}

.cabinet-check input {
    width: 16px;
    height: 16px;
}

.cabinet-shell {
    background: #eef8ff;
}

.cabinet-top {
    min-height: 72px;
    grid-template-columns: 66px 72px minmax(0, 1fr) auto auto;
    gap: 0;
    padding: 0;
    border-bottom: 1px solid rgba(8, 48, 95, .22);
    background: #2f64b3;
    color: #fff;
}

.cabinet-menu-button,
.cabinet-back {
    width: 66px;
    height: 72px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 0;
    border-right: 1px solid rgba(255, 255, 255, .16);
    background: transparent;
    color: #fff;
    font-size: 30px;
    font-weight: 700;
}

.cabinet-back {
    width: 44px;
    height: 44px;
    margin-left: 22px;
    border: 1px solid rgba(255, 255, 255, .78);
    border-radius: 50%;
    font-size: 32px;
    line-height: 1;
}

.cabinet-brand {
    min-width: 0;
    color: #fff;
}

.cabinet-brand .brand-logo {
    display: none;
}

.cabinet-brand b {
    overflow: hidden;
    color: #fff;
    font-size: 21px;
    font-weight: 700;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.cabinet-language {
    padding: 0 18px;
    gap: 9px;
}

.cabinet-language a {
    min-width: auto;
    min-height: auto;
    border: 0;
    background: transparent;
    color: rgba(255, 255, 255, .75);
    font-size: 12px;
    font-weight: 800;
}

.cabinet-language a.active {
    border: 0;
    color: #ffe072;
}

.cabinet-profile {
    min-height: 72px;
    padding: 0 24px;
    border-left: 1px solid rgba(255, 255, 255, .16);
    color: #fff;
}

.cabinet-profile span,
.cabinet-profile a {
    color: #fff;
}

.cabinet-layout {
    width: 100%;
    max-width: none;
    min-height: calc(100vh - 72px);
    grid-template-columns: 66px minmax(0, 1fr);
    gap: 0;
    margin: 0;
}

.cabinet-sidebar {
    position: sticky;
    top: 0;
    height: calc(100vh - 72px);
    border: 0;
    border-radius: 0;
    background: #3f75bf;
}

.cabinet-user {
    display: none;
}

.cabinet-menu a {
    height: 61px;
    min-height: 61px;
    justify-content: center;
    padding: 0;
    border-bottom: 1px solid rgba(255, 255, 255, .12);
    color: #fff;
    position: relative;
}

.cabinet-menu-icon {
    width: 24px;
    height: 24px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 24px;
    color: #fff;
}

.cabinet-menu-icon svg {
    width: 22px;
    height: 22px;
    display: block;
    fill: none;
    stroke: currentColor;
    stroke-width: 1.9;
    stroke-linecap: round;
    stroke-linejoin: round;
}

.cabinet-menu-text {
    position: absolute;
    left: 66px;
    top: 0;
    z-index: 20;
    min-width: 260px;
    height: 61px;
    display: none;
    align-items: center;
    padding: 0 16px;
    background: #2f64b3;
    box-shadow: 0 12px 24px rgba(15, 42, 76, .18);
    white-space: nowrap;
}

.cabinet-menu a:hover,
.cabinet-menu a.active {
    background: #316cb8;
}

.cabinet-menu a:hover .cabinet-menu-text,
.cabinet-menu a:focus .cabinet-menu-text {
    display: flex;
}

.cabinet-shell.is-menu-open .cabinet-layout {
    grid-template-columns: 286px minmax(0, 1fr);
}

.cabinet-shell.is-menu-open .cabinet-sidebar {
    background: #3f75bf;
}

.cabinet-shell.is-menu-open .cabinet-menu a {
    justify-content: flex-start;
    gap: 14px;
    padding: 0 18px;
}

.cabinet-shell.is-menu-open .cabinet-menu-text {
    position: static;
    min-width: 0;
    width: auto;
    height: auto;
    display: inline-flex;
    padding: 0;
    background: transparent;
    box-shadow: none;
}

.cabinet-content {
    border: 0;
    border-radius: 0;
    background: #eef8ff;
    padding: 32px 40px 58px;
}

.cabinet-heading {
    display: none;
}

.cabinet-card {
    border: 0;
    border-radius: 0;
    background: transparent;
    padding: 0;
}

.cabinet-card + .cabinet-card {
    margin-top: 32px;
}

.cabinet-card h2,
.cabinet-welcome h2 {
    color: #142238;
    font-size: 20px;
}

.cabinet-tabs {
    gap: 10px;
    margin: 0 0 24px;
    border: 0;
    background: transparent;
}

.cabinet-tabs a {
    min-height: 40px;
    padding: 0 17px;
    border: 0;
    border-radius: 4px;
    background: #51b7cf;
    color: #fff;
    font-size: 14px;
    font-weight: 700;
}

.cabinet-tabs a.active {
    top: 0;
    border: 0;
    background: #0789c4;
    color: #fff;
}

.cabinet-search-form,
.cabinet-inline-form,
.cabinet-settings-form,
.cabinet-settings-panel {
    margin-bottom: 22px;
    padding: 18px;
    border: 1px solid #cfe1f2;
    background: rgba(255, 255, 255, .72);
}

.cabinet-inline-form {
    margin-top: 0;
}

.cabinet-table-wrap {
    border: 0;
    overflow-x: auto;
}

.cabinet-table {
    min-width: 1080px;
    border-collapse: separate;
    border-spacing: 0 8px;
    background: transparent;
}

.cabinet-table th,
.cabinet-table td {
    border: 0;
    border-right: 1px solid rgba(230, 238, 247, .9);
    color: #273142;
    font-size: 14px;
    line-height: 1.25;
    text-transform: none;
}

.cabinet-table th {
    padding: 0 14px 12px;
    background: transparent;
    color: #101828;
    font-size: 15px;
    font-weight: 500;
}

.cabinet-table td {
    min-height: 62px;
    padding: 18px 14px;
    background: #fff;
    font-size: 14px;
}

.cabinet-table tbody tr td:first-child {
    border-radius: 3px 0 0 3px;
}

.cabinet-table tbody tr td:last-child {
    border-right: 0;
    border-radius: 0 3px 3px 0;
}

.cabinet-table td b,
.cabinet-table td a {
    color: #7aa272;
}

.cabinet-row-number {
    width: 44px;
    color: #334155;
    text-align: center;
}

.cabinet-stacked-actions {
    min-width: 128px;
    padding: 8px 0 !important;
}

.cabinet-stacked-actions a,
.cabinet-small-action {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0 0 7px;
    padding: 0 13px;
    border-radius: 3px;
    color: #fff !important;
    font-size: 13px;
    font-weight: 700;
}

.cabinet-stacked-actions .edit {
    background: #0a89bc;
}

.cabinet-stacked-actions .view,
.cabinet-small-action {
    background: #ff7600;
}

.cabinet-pill {
    border-radius: 4px;
    background: #f6fbff;
    color: #26354e;
}

.cabinet-home-document {
    max-width: 1500px;
    color: #2d3748;
    font-size: 15px;
    line-height: 1.35;
}

.cabinet-home-document p {
    max-width: 1420px;
    margin: 0 0 8px;
}

.cabinet-contact-block {
    display: grid;
    gap: 3px;
    margin: 8px 0;
}

.cabinet-contact-block b,
.cabinet-home-document p b {
    color: #2b3344;
}

.cabinet-home-document h2 {
    margin: 18px 0 8px;
    color: #2b3344;
    font-size: 16px;
    font-weight: 800;
}

.cabinet-requirement-table {
    width: min(880px, 100%);
    border-collapse: collapse;
    margin: 0 0 12px;
    background: #fff;
}

.cabinet-requirement-table td {
    padding: 8px 10px;
    border: 1px solid #cfe1f2;
    color: #2d3748;
}

.cabinet-requirement-table td:first-child {
    width: 48px;
    text-align: center;
}

.cabinet-notification-panel {
    width: 100%;
    background: #fff;
    color: #2d3748;
}

.cabinet-panel-title {
    min-height: 34px;
    display: flex;
    align-items: center;
    padding: 0 12px;
    background: #268ca6;
    color: #fff;
    font-size: 17px;
    font-weight: 800;
}

.cabinet-panel-lead {
    margin: 0;
    padding: 14px 16px;
    border-bottom: 1px solid #edf1f6;
    color: #4b5d75;
    font-size: 14px;
    line-height: 1.45;
}

.cabinet-notification-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    padding: 14px;
    border-bottom: 1px solid #edf1f6;
    background: #f7fbff;
}

.cabinet-notification-grid a {
    min-height: 112px;
    display: grid;
    grid-template-rows: auto 1fr auto;
    gap: 8px;
    border: 1px solid #cfe1f2;
    border-radius: 4px;
    background: #fff;
    padding: 12px;
    color: #2d3748;
    text-decoration: none;
    box-shadow: 0 8px 18px rgba(19, 55, 96, .06);
}

.cabinet-notification-grid a:hover,
.cabinet-notification-grid a.active {
    border-color: #0789c4;
    background: #eef9ff;
}

.cabinet-notification-grid b {
    color: #087ca5;
    font-size: 14px;
    line-height: 1.25;
}

.cabinet-notification-grid span {
    color: #607086;
    font-size: 12px;
    line-height: 1.35;
}

.cabinet-notification-grid em {
    justify-self: start;
    border-radius: 999px;
    background: #e8f1fb;
    color: #315178;
    font-size: 11px;
    font-style: normal;
    font-weight: 800;
    padding: 4px 8px;
}

.cabinet-notification-panel ul {
    margin: 0;
    padding: 0;
    list-style: none;
}

.cabinet-notification-panel li {
    padding: 5px 10px;
    font-size: 15px;
}

.status-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
    margin-top: 14px;
}

.status-grid article {
    border: 1px solid #d8d8d8;
    background: #fff;
}

.status-grid h2 {
    margin: 0;
    padding: 14px 15px;
    border-bottom: 1px solid #d8d8d8;
    color: #0085bd;
    font-size: 17px;
    font-weight: 600;
}

.status-grid dl {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin: 0;
}

.status-grid dl div {
    padding: 16px 15px;
    border-right: 1px solid #e7e7e7;
    border-bottom: 1px solid #e7e7e7;
}

.status-grid dt {
    margin-bottom: 7px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
}

.status-grid dd {
    margin: 0;
    color: #1a2546;
    font-size: 24px;
    font-weight: 600;
}

.status-workers {
    padding-left: 0;
    padding-right: 0;
}

.pagination {
    display: none;
}

.cabinet-card-head {
    min-height: 58px;
    margin: 0 0 14px;
    padding: 14px 18px;
    border: 1px solid #cfe1f2;
    border-radius: 4px;
    background: #fff;
}

.cabinet-list-head {
    margin-bottom: 12px;
}

.cabinet-card-head h2 {
    color: #142238;
    font-size: 19px;
    font-weight: 700;
}

.cabinet-tabs {
    gap: 4px;
    margin: 0 0 14px;
    padding: 6px;
    border: 1px solid #cfe1f2;
    border-radius: 4px;
    background: #fff;
    overflow-x: auto;
    scrollbar-width: thin;
}

.cabinet-tabs a {
    flex: 0 0 auto;
    min-height: 38px;
    padding: 0 14px;
    border-radius: 3px;
    background: #edf6fb;
    color: #1d617f;
    font-size: 13px;
    transition: background .16s ease, color .16s ease;
}

.cabinet-tabs a:hover,
.cabinet-tabs a:focus-visible {
    background: #dff0f8;
    color: #0f5577;
    outline: 0;
}

.cabinet-tabs a.active {
    background: #0789c4;
    color: #fff;
}

.cabinet-search-form,
.cabinet-inline-form,
.cabinet-settings-form,
.cabinet-settings-panel {
    border: 1px solid #cfe1f2;
    border-radius: 4px;
    background: #fff;
    box-shadow: 0 1px 0 rgba(26, 37, 70, 0.04);
}

.cabinet-search-row input,
.cabinet-filters input,
.cabinet-filters select,
.cabinet-settings-form input {
    border-color: #cfd8e3;
    background: #fff;
}

.cabinet-search-row input:focus,
.cabinet-filters input:focus,
.cabinet-filters select:focus,
.cabinet-settings-form input:focus {
    border-color: #1785aa;
    box-shadow: 0 0 0 3px rgba(23, 133, 170, 0.12);
}

.cabinet-button,
.cabinet-search-form button,
.cabinet-inline-form button {
    min-height: 38px;
    transition: background .16s ease, border-color .16s ease, color .16s ease;
}

.cabinet-button:hover,
.cabinet-search-form button:hover,
.cabinet-inline-form button:hover {
    background: #f3c62f;
}

.cabinet-button.secondary:hover {
    border-color: #1785aa;
    background: #f6fbfe;
    color: #1785aa;
}

.cabinet-table-wrap {
    border: 1px solid #cfe1f2;
    border-radius: 4px;
    background: #fff;
}

.cabinet-table {
    border-collapse: collapse;
    border-spacing: 0;
    background: #fff;
}

.cabinet-table th,
.cabinet-table td {
    border-right: 0;
    border-bottom: 1px solid #e6eef7;
}

.cabinet-table th {
    padding: 12px 14px;
    background: #eef2f6;
    color: #68758c;
    font-size: 11px;
    font-weight: 800;
    text-transform: uppercase;
    white-space: nowrap;
}

.cabinet-table td {
    min-height: 0;
    padding: 13px 14px;
    background: #fff;
}

.cabinet-table tbody tr:nth-child(even) td {
    background: #fbfcfe;
}

.cabinet-table tbody tr:hover td {
    background: #f4f8fc;
}

.cabinet-table tbody tr td:first-child,
.cabinet-table tbody tr td:last-child {
    border-radius: 0;
}

.cabinet-table td b,
.cabinet-table td a {
    color: #0085bd;
}

.cabinet-sobs-table td:nth-child(4),
.cabinet-tender-table td:nth-child(3) {
    min-width: 260px;
}

.cabinet-sobs-table {
    min-width: 1040px;
    table-layout: fixed;
}

.cabinet-sobs-table th,
.cabinet-sobs-table td {
    overflow-wrap: anywhere;
}

.cabinet-sobs-table th {
    white-space: normal;
}

.cabinet-sobs-table th:nth-child(1),
.cabinet-sobs-table td:nth-child(1) {
    width: 44px;
}

.cabinet-sobs-table th:nth-child(2),
.cabinet-sobs-table td:nth-child(2) {
    width: 140px;
}

.cabinet-sobs-table th:nth-child(3),
.cabinet-sobs-table td:nth-child(3) {
    width: 210px;
}

.cabinet-sobs-table th:nth-child(5),
.cabinet-sobs-table td:nth-child(5) {
    width: 150px;
}

.cabinet-sobs-table th:nth-child(6),
.cabinet-sobs-table td:nth-child(6) {
    width: 135px;
}

.cabinet-sobs-table th:nth-child(7),
.cabinet-sobs-table td:nth-child(7) {
    width: 170px;
}

.cabinet-sobs-table th:nth-child(8),
.cabinet-sobs-table td:nth-child(8) {
    width: 126px;
}

.cabinet-my-tenders-table {
    min-width: 1380px;
}

.cabinet-my-tenders-table th:nth-child(4),
.cabinet-my-tenders-table td:nth-child(4) {
    width: 290px;
}

.cabinet-my-tenders-table th:nth-child(7),
.cabinet-my-tenders-table td:nth-child(7),
.cabinet-my-tenders-table th:nth-child(8),
.cabinet-my-tenders-table td:nth-child(8),
.cabinet-my-tenders-table th:nth-child(9),
.cabinet-my-tenders-table td:nth-child(9),
.cabinet-my-tenders-table th:nth-child(10),
.cabinet-my-tenders-table td:nth-child(10) {
    width: 120px;
}

.cabinet-pill.ok {
    background: #e7f8ef;
    color: #047342;
}

.cabinet-pill.warn {
    background: #fff3df;
    color: #9a4d00;
}

.cabinet-tabs a span {
    margin-left: 6px;
    color: inherit;
    opacity: 0.78;
}

.cabinet-stacked-actions a,
.cabinet-small-action {
    width: 100%;
    min-height: 34px;
    display: flex;
    margin: 0 0 6px;
    padding: 0 12px;
}

.cabinet-stacked-actions .edit {
    background: #0789c4;
}

.cabinet-stacked-actions .view,
.cabinet-small-action {
    background: #f47621;
}

.cabinet-pill {
    border: 1px solid #d8e1ec;
    border-radius: 4px;
    background: #f7f9fc;
    color: #26354e;
}

.cabinet-pager {
    min-height: 46px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-top: 12px;
    padding: 8px 10px 8px 14px;
    border: 1px solid #cfe1f2;
    border-radius: 4px;
    background: #fff;
    color: #61708b;
    font-size: 13px;
    font-weight: 700;
}

.cabinet-pager div {
    display: flex;
    align-items: center;
    gap: 6px;
}

.cabinet-pager a,
.cabinet-pager em {
    min-width: 32px;
    height: 32px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #d8e1ec;
    border-radius: 3px;
    background: #fff;
    color: #1d617f;
    font-style: normal;
}

.cabinet-pager a:hover {
    border-color: #1785aa;
    background: #f6fbfe;
    color: #1785aa;
}

.cabinet-pager a.active {
    border-color: #0789c4;
    background: #0789c4;
    color: #fff;
}

.cabinet-pager a.disabled {
    opacity: .45;
    pointer-events: none;
}

.cabinet-notification-panel {
    border: 1px solid #cfe1f2;
    border-radius: 4px;
    overflow: hidden;
}

.cabinet-panel-title {
    background: #0789c4;
}

.cabinet-notification-panel li {
    min-height: 34px;
    display: flex;
    align-items: center;
    border-bottom: 1px solid #edf1f6;
}

@media (max-width: 1450px) {
    .brand-msad {
        display: none !important;
    }
}

@media (max-width: 1360px) {
    .portal-contact {
        display: none !important;
    }
}

@media (max-width: 1199px) {
    .portal-menu {
        gap: 14px;
    }

    .portal-menu a {
        font-size: 14px;
    }

    .tender-table-head {
        display: none;
    }

    .tender-row {
        grid-template-columns: 150px minmax(0, 1fr) 140px;
        min-height: auto;
        border-bottom: 1px solid #e2e6ea;
    }

    .tender-main,
    .tender-method-cell {
        grid-column: 2;
    }

    .tender-money,
    .tender-date,
    .tender-deadline {
        grid-column: 3;
    }

    .open-link {
        grid-column: 3;
        grid-row: 1;
    }

    .tender-status-icons {
        grid-column: 3;
        grid-row: 2;
        align-items: flex-start;
        flex-direction: row;
    }
}

@media (max-width: 980px) {
    body {
        min-width: 0;
    }

    .portal-top {
        height: auto;
        display: grid;
        grid-template-columns: 1fr;
    }

    .portal-top-links,
    .portal-top-meta {
        min-height: 0;
        flex-wrap: wrap;
    }

    .portal-top-links a,
    .portal-top-links span,
    .portal-top-meta a,
    .portal-top-meta span {
        min-height: 34px;
        padding: 0 10px;
        font-size: 12px;
    }

    .portal-nav {
        height: auto;
        display: grid;
        gap: 12px;
        padding: 14px;
    }

    .portal-brand {
        height: auto;
    }

    .brand-logo {
        width: 190px;
        height: 60px;
    }

    .portal-menu {
        width: 100%;
        height: auto;
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 0;
        border-top: 1px solid var(--line);
    }

    .portal-menu a {
        min-height: 38px;
        border-bottom: 1px solid var(--line);
        white-space: normal;
    }

    .portal-main {
        max-width: calc(100% - 20px);
        margin-top: 18px;
    }

    .search-panel,
    .tenders-card {
        padding-left: 10px;
        padding-right: 10px;
    }

    .search-row {
        position: static;
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .search-input {
        border: 1px solid var(--line);
        border-radius: 5px;
    }

    .search-input input {
        padding-right: 10px;
    }

    .search-button {
        position: static;
        width: 100%;
        height: 44px;
        margin: 0;
    }

    .portal-tabs {
        display: grid;
        grid-template-columns: 1fr;
    }

    .portal-tabs a:nth-child(2) {
        margin-left: 0;
    }

    .portal-tabs a {
        justify-content: center;
        min-height: 44px;
    }

    .official-paginator {
        grid-template-columns: 1fr;
        justify-items: center;
        gap: 6px;
        padding: 8px;
    }

    .paginator-main,
    .goto-page {
        grid-column: 1;
        justify-self: center;
    }

    .paginator-main,
    .page-numbers {
        flex-wrap: wrap;
    }

    .rows-label {
        margin-left: 0;
    }

    .official-view-card {
        margin: 0 10px;
        padding: 20px 0 6px;
    }

    .official-view-heading {
        padding: 0 10px;
    }

    .official-view-heading,
    .official-common-grid,
    .detail-meta-grid,
    .status-grid,
    .status-grid dl {
        grid-template-columns: 1fr;
    }

    .official-view-tabs {
        display: flex;
        overflow-x: auto;
    }

    .official-view-tabs a {
        min-height: 46px;
        padding: 0 12px;
        font-size: 13px;
    }

    .official-common-grid {
        gap: 0;
        padding: 18px 0 0;
    }

    .official-common-row {
        grid-template-columns: 1fr;
    }

    .official-org-grid .official-common-row {
        grid-template-columns: 1fr;
    }

    .lot-card-head,
    .lot-data-title {
        align-items: flex-start;
        flex-direction: column;
    }

    .lot-card-meta,
    .lot-data-grid {
        grid-template-columns: 1fr;
    }

    .lot-card-meta div {
        border-right: 0;
        border-bottom: 1px solid #e7e7e7;
    }

    .lot-card-meta div:last-child {
        border-bottom: 0;
    }

    .lot-data-panel + .lot-data-panel {
        border-left: 0;
        border-top: 1px solid #e7e7e7;
    }
}

@media (max-width: 760px) {
    body {
        min-width: 0;
    }

    .portal-top {
        height: auto;
        display: grid;
        grid-template-columns: 1fr;
    }

    .portal-top-links,
    .portal-top-meta {
        min-height: 0;
        flex-wrap: wrap;
    }

    .portal-top-links a,
    .portal-top-links span,
    .portal-top-meta a,
    .portal-top-meta span {
        min-height: 34px;
        padding: 0 10px;
        font-size: 12px;
    }

    .portal-nav {
        height: auto;
        display: grid;
        gap: 12px;
        padding: 14px;
    }

    .portal-brand {
        height: auto;
    }

    .brand-logo {
        width: 190px;
        height: 60px;
    }

    .portal-menu {
        height: auto;
        display: grid;
        grid-template-columns: 1fr;
        gap: 0;
        border-top: 1px solid var(--line);
    }

    .portal-menu a {
        min-height: 38px;
        border-bottom: 1px solid var(--line);
    }

    .portal-main {
        max-width: calc(100% - 20px);
        margin-top: 18px;
    }

    .search-panel,
    .tenders-card {
        padding-left: 10px;
        padding-right: 10px;
    }

    .search-row {
        position: static;
        display: grid;
        grid-template-columns: 1fr;
        gap: 8px;
    }

    .search-input {
        border: 1px solid var(--line);
        border-radius: 5px;
    }

    .search-input input {
        padding-right: 10px;
    }

    .search-button {
        position: static;
        width: 100%;
        height: 44px;
        margin: 0;
    }

    .portal-tabs {
        display: grid;
        grid-template-columns: 1fr;
    }

    .portal-tabs a:nth-child(2) {
        margin-left: 0;
    }

    .portal-tabs a {
        justify-content: center;
        min-height: 44px;
    }

    .filter-grid {
        grid-template-columns: 1fr;
    }

    .official-paginator {
        grid-template-columns: 1fr;
        justify-items: center;
        gap: 6px;
        padding: 8px;
    }

    .paginator-main,
    .goto-page {
        grid-column: 1;
        justify-self: center;
    }

    .paginator-main {
        flex-wrap: wrap;
    }

    .page-numbers {
        gap: 5px;
        flex-wrap: wrap;
    }

    .page-numbers a {
        width: 28px;
        height: 28px;
    }

    .rows-label {
        margin-left: 0;
    }

    .tender-list {
        border-left: 0;
        border-right: 0;
    }

    .tender-list table,
    .tender-list tbody {
        display: block;
        width: 100%;
        min-width: 0;
    }

    .tender-row {
        display: grid;
        grid-template-columns: minmax(0, 1fr);
        padding: 0;
    }

    .detail-toolbar {
        align-items: stretch;
        flex-direction: column;
    }

    .official-view-card {
        margin: 0;
        padding: 20px 0 6px;
    }

    .official-view-heading {
        grid-template-columns: 1fr;
        row-gap: 12px;
        padding: 0 10px;
    }

    .official-view-tabs {
        display: flex;
        overflow-x: auto;
    }

    .official-view-tabs a {
        min-height: 44px;
        padding: 0 12px;
        font-size: 13px;
    }

    .official-common-grid {
        grid-template-columns: 1fr;
        gap: 0;
        padding: 18px 0 0;
    }

    .official-common-row {
        grid-template-columns: 1fr;
    }

    .official-org-grid .official-common-row {
        grid-template-columns: 1fr;
    }

    .external-button {
        justify-content: center;
    }

    .detail-meta-grid {
        grid-template-columns: 1fr;
    }

    .detail-meta-grid div {
        border-right: 0;
        border-bottom: 1px solid #e7e7e7;
    }

    .detail-title-block h1 {
        font-size: 17px;
    }

    .status-main {
        padding-left: 10px;
        padding-right: 10px;
    }

    .section-main {
        padding-left: 10px;
        padding-right: 10px;
    }

    .section-search-form,
    .section-card-head {
        grid-template-columns: 1fr;
        align-items: stretch;
    }

    .section-card-head {
        display: grid;
    }

    .analytics-metrics,
    .analytics-split,
    .analytics-panel dl,
    .contract-conditions-grid {
        grid-template-columns: 1fr;
    }

    .section-search-form button,
    .section-search-form a {
        width: 100%;
    }

    .section-pager {
        align-items: stretch;
        flex-direction: column;
    }

    .login-main {
        padding: 24px 12px;
    }

    .login-title span {
        margin-bottom: 22px;
        font-size: 20px;
    }

    .status-grid {
        grid-template-columns: 1fr;
    }

    .status-grid dl {
        grid-template-columns: 1fr;
    }

    .tender-row > *,
    .tender-main,
    .tender-method-cell,
    .tender-money,
    .tender-date,
    .tender-deadline,
    .tender-status-icons,
    .open-link {
        width: auto;
        display: block;
        grid-column: auto;
        grid-row: auto;
    }

    .open-link {
        justify-content: flex-start;
        padding-top: 0;
    }

    .tender-status-icons {
        align-items: flex-start;
        flex-direction: row;
        padding-top: 0;
    }
}

@media (max-width: 1100px) {
    .tender-row {
        width: 100%;
        margin-right: 0;
    }

    .lot-card-head {
        grid-template-columns: 1fr;
        min-height: auto;
    }

    .lot-card-goods .lot-card-head,
    .lot-residency-strip {
        grid-template-columns: 1fr;
    }

    .lot-head-cell {
        border-right: 0;
        border-bottom: 1px solid rgba(255, 255, 255, 0.7);
    }

    .lot-chevron {
        display: none;
    }

    .lot-requirements-grid {
        grid-template-columns: 1fr;
    }
}

.home-shell {
    background: #2f65b5;
    color: #d7e5fb;
}

.home-shell a {
    color: #d7e5fb;
}

.home-shell a:hover {
    color: #ffd527;
}

.home-shell .portal-top,
.home-shell .portal-nav {
    background: #e8f0f8;
    border-color: #d3e1f1;
    color: #54617a;
}

.home-shell .portal-top-links a,
.home-shell .portal-top-links span,
.home-shell .portal-top-meta a,
.home-shell .portal-top-meta span {
    border-color: #d3e1f1;
    color: #54617a;
}

.home-shell .portal-contact {
    color: #71809a !important;
}

.home-shell .portal-menu a,
.home-shell .portal-menu .menu-toggle {
    color: #1a2546;
}

.home-shell .portal-menu a:hover,
.home-shell .portal-menu .menu-toggle:hover,
.home-shell .portal-menu a.active,
.home-shell .portal-menu .menu-toggle.active {
    color: #0085bd;
}

.official-home-nav {
    gap: 20px;
    height: auto;
    min-height: 105px;
    flex-wrap: wrap;
    padding-top: 14px;
    padding-bottom: 14px;
    box-shadow: 0 1px 0 rgba(26, 37, 70, 0.04);
}

.home-shell .portal-top {
    height: auto;
    min-height: 43px;
    flex-wrap: wrap;
}

.home-shell .portal-top-links,
.home-shell .portal-top-meta {
    height: auto;
    flex-wrap: wrap;
}

.new-portal-link {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 14px;
    border: 1px solid #d4e3f4;
    background: transparent;
    color: #ff001e !important;
    font-size: 13px;
    font-weight: 700;
    white-space: nowrap;
}

.official-dropdown-menu {
    gap: 10px;
    height: auto;
    flex-wrap: wrap;
}

.menu-group {
    position: relative;
    min-height: 42px;
    display: inline-flex;
    align-items: center;
}

.menu-dropdown {
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 20;
    min-width: 260px;
    display: none;
    padding: 8px 0;
    border: 1px solid #d4e3f4;
    background: #fff;
    box-shadow: 0 14px 35px rgba(31, 45, 74, 0.16);
}

.menu-group:hover .menu-dropdown,
.menu-group:focus-within .menu-dropdown,
.menu-group.is-open .menu-dropdown {
    display: block;
}

.menu-dropdown a {
    width: 100%;
    min-height: 36px;
    padding: 0 14px;
    color: #25304f;
    font-size: 13px;
    white-space: normal;
}

.menu-dropdown a:hover {
    background: #f3f7fb;
    color: #0085bd;
}

.home-banner {
    min-height: 275px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 34px 20px;
    border-bottom: 0;
    background: #2f65b5;
    color: #fff;
    text-align: center;
}

.home-banner h1 {
    margin: 0;
    color: #fff;
    font-size: 34px;
    font-weight: 700;
    line-height: 1.2;
}

.home-main {
    width: 1270px;
    max-width: calc(100% - 30px);
    margin: -64px auto 42px;
}

.home-search {
    position: relative;
    z-index: 3;
    background: #fff;
    border-radius: 4px;
    border: 1px solid #d8e1ec;
    box-shadow: 0 14px 34px rgba(26, 37, 70, 0.12);
}

.home-search-form {
    padding: 7px;
}

.home-search-row {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 8px;
}

.home-search-tabs {
    display: flex;
    border-bottom: 1px solid #e4edf7;
}

.home-search-tabs button {
    min-height: 52px;
    padding: 0 26px;
    border: 0;
    border-right: 1px solid #e4edf7;
    background: #f7f9fc;
    color: #53627c;
    font-weight: 700;
    cursor: pointer;
}

.home-search-tabs button.active {
    background: #fff;
    color: #1785aa;
}

.home-search-pane {
    display: none;
    padding: 22px;
}

.home-search-pane.active {
    display: block;
}

.home-search-pane.advanced {
    margin-top: 12px;
    padding: 18px;
    border-top: 1px solid #e4edf7;
    background: #f7f9fc;
}

.home-search-field {
    display: block;
}

.home-search-field input,
.advanced-grid input,
.advanced-grid select {
    width: 100%;
    height: 46px;
    border: 1px solid #cfdceb;
    background: #fff;
    color: #26304b;
    padding: 0 14px;
    outline: 0;
}

.home-search-field input:focus,
.advanced-grid input:focus,
.advanced-grid select:focus {
    border-color: #1785aa;
    box-shadow: 0 0 0 3px rgba(23, 133, 170, 0.14);
}

.home-search-button {
    height: 38px;
    min-width: 120px;
    border: 0;
    background: #f8d043;
    color: #1a2546;
    font-weight: 800;
    cursor: pointer;
    transition: background .16s ease;
}

.home-search-button:hover {
    background: #f3c62f;
}

.home-search-button span {
    margin-right: 8px;
    font-size: 18px;
}

.home-advanced-toggle {
    height: 38px;
    border: 0;
    background: transparent;
    color: #7b7197;
    font-weight: 800;
    cursor: pointer;
}

.home-advanced-toggle:hover {
    color: #1785aa;
}

.home-advanced-toggle.active {
    color: #1785aa;
}

.home-search-switch {
    margin-top: 14px;
    border: 0;
    background: transparent;
    color: #1785aa;
    font-weight: 700;
    cursor: pointer;
}

.home-search-switch.simple {
    margin: 0 0 16px;
}

.advanced-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr);
    gap: 14px;
}

.search-radio-group {
    display: grid;
    gap: 8px;
    margin: 0;
    padding: 0;
    border: 0;
    color: #4c5b75;
    font-size: 13px;
}

.search-radio-group label {
    display: flex;
    align-items: center;
    gap: 8px;
}

.advanced-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
    margin-top: 14px;
}

.advanced-grid label {
    display: grid;
    gap: 7px;
    color: #52617c;
    font-size: 13px;
    font-weight: 700;
}

.advanced-actions {
    display: flex;
    align-items: end;
    gap: 12px;
}

.advanced-actions button,
.advanced-actions a {
    height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 20px;
    border: 0;
    background: #f8d043;
    color: #1a2546;
    font-weight: 800;
}

.advanced-actions a {
    background: #eef4fb;
    color: #53627c;
}

.latest-section,
.home-forecasts,
.home-news,
.home-statistics,
.home-info-grid,
.home-footer,
.home-copyright {
    margin-top: 26px;
}

.latest-section,
.home-forecasts,
.home-news,
.home-statistics,
.home-info-grid > *,
.home-footer {
    background: transparent;
    border-radius: 4px;
    box-shadow: none;
}

.section-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 22px 24px 0;
}

.section-heading h2,
.home-statistics h2,
.info-panel h2,
.links-panel h2,
.home-footer h2 {
    margin: 0;
    color: #d7e5fb;
    font-size: 22px;
    line-height: 1.2;
}

.section-heading a {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 14px;
    border: 1px solid rgba(215, 229, 251, 0.5);
    border-radius: 3px;
    color: #d7e5fb;
    font-size: 13px;
    font-weight: 800;
}

.home-forecast-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin-top: 18px;
    background: #fff;
}

.home-forecast-card {
    min-width: 0;
    display: grid;
    align-content: start;
    gap: 12px;
    min-height: 230px;
    padding: 20px;
    border: 1px solid #e2ebf5;
    background: #fff;
}

.home-forecast-head,
.home-forecast-meta,
.home-forecast-money {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.home-forecast-head span,
.home-forecast-money span,
.home-forecast-card small {
    color: #60708a;
    font-size: 12px;
    line-height: 1.3;
}

.home-forecast-head b {
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    padding: 0 8px;
    border-radius: 3px;
    background: #eef7f1;
    color: #08723d;
    font-size: 12px;
    font-weight: 800;
}

.home-forecast-title {
    color: #007aaa;
    font-size: 15px;
    font-weight: 800;
    line-height: 1.3;
}

.home-forecast-card p {
    margin: 0;
    color: #26304b;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.35;
}

.home-forecast-money {
    align-items: stretch;
}

.home-forecast-money div {
    min-width: 0;
    flex: 1 1 0;
    padding: 10px;
    background: #f5f8fc;
}

.home-forecast-money b {
    display: block;
    margin-top: 4px;
    color: #061735;
    font-size: 15px;
    font-weight: 900;
    line-height: 1.15;
}

.home-forecast-meta {
    justify-content: flex-start;
    flex-wrap: wrap;
}

.home-forecast-meta span {
    min-height: 24px;
    display: inline-flex;
    align-items: center;
    padding: 0 8px;
    border-radius: 3px;
    background: #fff6df;
    color: #8b5300;
    font-size: 12px;
    font-weight: 800;
}

.home-forecast-intents {
    display: grid;
    gap: 6px;
}

.home-forecast-intents div {
    min-width: 0;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    gap: 10px;
    padding: 7px 8px;
    background: #f7faff;
}

.home-forecast-intents b {
    min-width: 0;
    overflow: hidden;
    color: #25304f;
    font-size: 12px;
    font-weight: 800;
    line-height: 1.25;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.home-forecast-intents span {
    color: #007aaa;
    font-size: 12px;
    font-weight: 900;
    white-space: nowrap;
}

.home-pilot {
    min-height: 160px;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    align-items: center;
    gap: 20px;
    padding: 26px 20px;
    border-radius: 4px;
    background: rgba(255, 255, 255, 0.12);
    color: #fff;
}

.home-pilot h2 {
    margin: 0 0 12px;
    color: #ffd527;
    font-size: 21px;
    line-height: 1.25;
}

.home-pilot p {
    max-width: 1140px;
    margin: 0;
    font-weight: 700;
    line-height: 1.45;
}

.home-pilot-link {
    min-height: 34px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 14px;
    padding: 0 18px;
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: 3px;
    color: #fff;
    font-size: 13px;
    font-weight: 700;
}

.home-pilot-link:hover {
    color: #ffd527;
}

.home-pilot button {
    border: 0;
    background: transparent;
    color: #d7e5fb;
    font-size: 34px;
    cursor: pointer;
}

.pilot-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 26px;
}

.pilot-dots span {
    width: 9px;
    height: 9px;
    border-radius: 999px;
    border: 2px solid #d7e5fb;
}

.pilot-dots span:first-child {
    background: #fff;
}

.news-heading {
    padding: 48px 20px 22px;
}

.news-heading h2 {
    margin: 0;
    color: #d7e5fb;
    font-size: 24px;
}

.news-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    border: 1px solid rgba(255, 255, 255, 0.12);
}

.news-grid article {
    min-height: 160px;
    display: grid;
    align-content: start;
    gap: 10px;
    padding: 18px 16px;
    border-right: 1px solid rgba(255, 255, 255, 0.12);
    cursor: pointer;
}

.news-grid article.active {
    box-shadow: inset 0 3px 0 #ffd527;
}

.news-grid article:last-child {
    border-right: 0;
}

.news-grid time {
    color: #d7e5fb;
    font-size: 13px;
}

.news-grid b {
    color: #fff;
    line-height: 1.35;
}

.home-tender-tabs {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 34px;
    padding: 34px 0 24px;
}

.home-tender-tabs button {
    min-height: 44px;
    border: 0;
    border-bottom: 2px solid rgba(255, 255, 255, 0.22);
    background: transparent;
    color: #b8c9e8;
    font-size: 16px;
    font-weight: 800;
    cursor: pointer;
}

.home-tender-tabs button.active {
    border-color: #ffd527;
    color: #ffd527;
}

.latest-grid {
    display: none;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    padding: 0;
    background: #fff;
}

.latest-grid.active {
    display: grid;
}

.latest-tender {
    min-height: 190px;
    display: grid;
    align-content: start;
    gap: 12px;
    padding: 28px;
    border: 1px solid #e2ebf5;
    background: #fff;
}

.latest-tender p {
    margin: 0;
}

.latest-tender .date {
    color: #60708a;
    font-size: 12px;
}

.latest-tender .date span {
    color: #1d9a5b;
    font-weight: 700;
}

.latest-tender .number {
    color: #26304b;
    font-weight: 700;
    line-height: 1.35;
}

.latest-tender .name {
    color: #4f5e78;
    line-height: 1.35;
}

.latest-tender .name a {
    font-weight: 700;
}

.latest-tender .sum {
    color: #d76021;
    font-size: 18px;
    font-weight: 800;
}

.latest-tender .sum span {
    display: block;
    color: #7a879b;
    font-size: 12px;
    font-weight: 600;
}

.home-empty {
    grid-column: 1 / -1;
}

.home-statistics {
    padding: 24px;
}

.statistics-layout {
    display: grid;
    grid-template-columns: 330px minmax(0, 1fr);
    gap: 24px;
    margin-top: 18px;
}

.stat-column {
    display: grid;
    gap: 16px;
}

.stat-block {
    padding: 18px;
    background: #fff;
    color: #1a2546;
    border-radius: 4px;
}

.stat-block label {
    display: block;
    font-weight: 800;
}

.registry-stat-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-top: 22px;
}

.registry-stat-row span {
    display: block;
    color: #8490a8;
    font-size: 12px;
    font-weight: 800;
    text-transform: uppercase;
}

.registry-stat-row p {
    margin-top: 8px;
    font-size: 30px;
}

.registry-stat-row .good {
    color: #41b853;
}

.registry-stat-row .bad {
    color: #dc694a;
}

.stat-block ul {
    display: grid;
    gap: 10px;
    margin: 14px 0 0;
    padding: 0;
    list-style: none;
}

.stat-block li {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    border-top: 1px solid #e8edf5;
    padding-top: 10px;
}

.stat-block p {
    margin: 0;
    font-size: 22px;
    font-weight: 800;
}

.main-chart {
    min-height: 250px;
    display: flex;
    align-items: end;
    padding: 26px;
    background: rgba(255, 255, 255, 0.12);
}

.chart-bars {
    width: 100%;
    height: 220px;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    align-items: end;
    gap: 18px;
}

.chart-bar {
    min-height: 34px;
    height: var(--bar-height);
    display: flex;
    flex-direction: column;
    justify-content: end;
    gap: 8px;
    padding: 12px;
    background: #f8d043;
    color: #1a2546;
}

.chart-bar b {
    font-size: 16px;
}

.chart-bar span {
    font-size: 12px;
    font-weight: 700;
}

.home-info-grid {
    display: grid;
    grid-template-columns: 5fr 7fr;
    gap: 24px;
}

.info-panel,
.links-panel {
    padding: 24px;
}

.info-panel details {
    background: #fff;
    border-radius: 4px;
    padding-left: 18px;
    padding-right: 18px;
}

.info-panel details {
    border-bottom: 1px solid #e3ecf6;
    padding: 14px 0;
}

.info-panel summary {
    color: #25304f;
    font-weight: 800;
    cursor: pointer;
}

.info-panel details a,
.links-panel a,
.home-footer a {
    display: block;
    margin-top: 10px;
    color: #d7e5fb;
    line-height: 1.35;
}

.home-footer {
    width: 1270px;
    max-width: calc(100% - 30px);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-left: auto;
    margin-right: auto;
    padding: 24px;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

.home-footer a {
    display: inline-block;
    margin-right: 16px;
}

.home-copyright {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    width: 1270px;
    max-width: calc(100% - 30px);
    margin-left: auto;
    margin-right: auto;
    padding: 18px 0 32px;
    color: #b9c9e4;
}

@media (max-width: 1180px) {
    .official-home-nav {
        height: auto;
        min-height: 105px;
        align-items: flex-start;
        flex-direction: column;
        padding-top: 14px;
        padding-bottom: 14px;
    }

    .official-dropdown-menu {
        height: auto;
        flex-wrap: wrap;
    }

    .advanced-grid,
    .home-forecast-grid,
    .latest-grid,
    .news-grid,
    .home-tender-tabs {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .statistics-layout,
    .home-info-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 680px) {
    .home-banner {
        min-height: 160px;
        background-position: center 20px;
        background-size: 120px auto;
        padding-top: 105px;
    }

    .home-banner h1 {
        font-size: 24px;
    }

    .home-main {
        max-width: calc(100% - 16px);
        margin-top: -24px;
    }

    .home-search-row,
    .home-search-tabs,
    .home-copyright,
    .home-footer {
        grid-template-columns: 1fr;
        flex-direction: column;
    }

    .home-search-tabs button {
        width: 100%;
        border-right: 0;
    }

    .home-search-button {
        width: 100%;
        margin-top: 12px;
    }

    .home-advanced-toggle {
        width: 100%;
    }

    .home-pilot {
        grid-template-columns: 1fr;
        text-align: left;
    }

    .home-pilot button {
        display: none;
    }

    .advanced-grid,
    .home-forecast-grid,
    .latest-grid,
    .news-grid,
    .home-tender-tabs,
    .chart-bars {
        grid-template-columns: 1fr;
    }

    .main-chart,
    .chart-bars {
        height: auto;
        min-height: 0;
    }

    .chart-bar {
        height: auto;
    }
}

@media (max-width: 980px) {
    .cabinet-top {
        grid-template-columns: 56px 56px minmax(0, 1fr);
        align-items: center;
        padding: 0;
    }

    .cabinet-menu-button {
        width: 56px;
        height: 64px;
    }

    .cabinet-back {
        width: 36px;
        height: 36px;
        margin-left: 10px;
    }

    .cabinet-language {
        display: none;
    }

    .cabinet-profile {
        grid-column: 1 / -1;
        min-height: 38px;
        padding: 8px 12px;
        border-left: 0;
        background: #295ca6;
        justify-content: flex-start;
        overflow-x: auto;
    }

    .cabinet-notice-grid,
    .cabinet-notification-grid,
    .cabinet-notification-list,
    .cabinet-settings-form {
        grid-template-columns: 1fr;
    }

    .cabinet-layout {
        grid-template-columns: 56px minmax(0, 1fr);
    }

    .cabinet-shell.is-menu-open .cabinet-layout {
        grid-template-columns: 240px minmax(0, 1fr);
    }

    .cabinet-sidebar {
        position: sticky;
        height: auto;
    }

    .cabinet-menu {
        grid-template-columns: 1fr;
    }

    .cabinet-filters {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 620px) {
    .cabinet-layout {
        max-width: none;
        grid-template-columns: 52px minmax(0, 1fr);
        margin-top: 0;
    }

    .cabinet-shell.is-menu-open .cabinet-layout {
        grid-template-columns: 220px minmax(0, 1fr);
    }

    .cabinet-menu-button {
        width: 52px;
    }

    .cabinet-menu a {
        min-height: 52px;
        height: 52px;
    }

    .cabinet-menu-text {
        left: 52px;
        height: 52px;
    }

    .cabinet-filters,
    .cabinet-search-row {
        grid-template-columns: 1fr;
    }

    .cabinet-content {
        padding: 14px;
    }

    .cabinet-card {
        padding: 0;
    }

    .cabinet-heading,
    .cabinet-card-head,
    .cabinet-profile {
        align-items: stretch;
        flex-direction: column;
    }

    .cabinet-heading h1 {
        font-size: 18px;
    }

    .cabinet-tabs {
        margin: -12px -12px 12px;
    }

    .cabinet-tabs a {
        width: 100%;
        min-height: 42px;
    }

    .cabinet-search-form button,
    .cabinet-inline-form button,
    .cabinet-button {
        width: 100%;
    }
}

@media (max-width: 760px) {
    .cabinet-content {
        padding: 14px 10px 28px;
    }

    .cabinet-card-head,
    .cabinet-pager {
        align-items: stretch;
        flex-direction: column;
    }

    .cabinet-tabs {
        margin: 0 0 12px;
        padding: 5px;
    }

    .cabinet-tabs a {
        width: auto;
        min-height: 38px;
        font-size: 12px;
    }

    .cabinet-search-form,
    .cabinet-inline-form,
    .cabinet-settings-form,
    .cabinet-settings-panel {
        padding: 12px;
    }

    .cabinet-pager div {
        flex-wrap: wrap;
    }
}
