/* в данном файле размещаются все основные настройки форм */

input, select, textarea, div.dropfield {
    width: 100%;
    border: 1px solid var(--inputs-borders);
    color: var(--inputs-text);
    padding: .8em;
    font-size: 1.3em;
    /*margin-bottom: 1px;*/ /*Chrome fix*/
    border-radius: 0;
    font-family: Arial, sans-serif;
    box-shadow: none;
}

input:focus,
select:focus,
textarea:focus,
button:focus,
.fieldname:focus {
    outline: none;
}

textarea {
    resize: vertical;
    line-height: normal;
    display: block;
}

select {
    text-overflow: clip;
    white-space: nowrap;
}

select::-ms-expand {
    display: none;
}

input[type=text]:disabled, select:disabled {
    color: var(--gray);
}

select:disabled {
    white-space: pre; /* лечит баг Хрома с расстоянием между двумя выключенными селектами */
}

input[type="checkbox"], input[type="radio"] {
    width: auto;
    margin-bottom: 0;
    vertical-align: middle;
}

.inputcheckbox {
    vertical-align: top;
    width: 1.3em;
    height: 1.3em;
    margin: 0;
}

.inputcheckbox + label {
    cursor: pointer;
    display: inline-block;
}

div.multi_objects_table .inputcheckbox + label {
    display: inline;
    height: 1.4em;
    padding: 0 0 0 3em;
}

.inputcheckbox {
    position: absolute;
    z-index: -1;
    opacity: 0;
    margin: 1em 0 0 2em;
    height: 1px;
}

.inputcheckbox + label {
    position: relative;
    padding: 0 0 0 5em;
}

div.fieldvalue > .inputcheckbox + label {
    margin-bottom: 1.5em;
    display: inline-block;
}

.inputcheckbox + label:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 4em;
    height: 2em;
    border-radius: 1em;
    background: var(--underlay-gray);
    transition: .2s;
}

.inputcheckbox + label:after {
    content: '';
    position: absolute;
    top: 0;
    left: .1em;
    width: 2em;
    height: 2em;
    border-radius: 1em;
    background: var(--underlay-gray-contrast);
    transition: .2s;
    opacity: .4;
}

.inputcheckbox:checked + label:before {
    background: var(--underlay-gray);
}

.inputcheckbox:checked + label:after {
    left: 1.9em;
    opacity: .8;
}

.inputradio {
    vertical-align: top;
    width: 1.3em;
    height: 1.3em;
    margin: 0;
}

.inputradio + label {
    cursor: pointer;
}

.inputradio {
    position: absolute;
    z-index: -1;
    opacity: 0;
    margin: 1em 0 0 1em;
}

.inputradio + label {
    position: relative;
    padding: 0 0 0 3em;
}

div.fieldvalue > .inputradio + label {
    margin-bottom: 1em;
    display: inline-block;
}

.inputradio + label:before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 1.8em;
    height: 1.8em;
    border: 1px solid var(--underlay-gray);
    border-radius: 50%;
    background: var(--underlay-gray);
}

.inputradio + label:after {
    content: '';
    position: absolute;
    top: .5em;
    left: .5em;
    width: 1em;
    height: 1em;
    border-radius: 50%;
    background: var(--underlay-gray-contrast);
    opacity: 0;
    transition: .2s;
}

.inputradio:checked + label:after {
    opacity: 1;
}

span.checkbox_read_green {
    color: var(--green);
}

span.checkbox_read_red {
    color: var(--red);
}

option[disabled] {
    color: var(--color-background-main) !important;
    background-color: var(--color-background-gray);
}

option.option_bold {
    font-weight: bold;
}

input[type=text]:focus, input[type=password]:focus, select:focus, textarea:focus, div.dropfield.hovered {
    border-color: var(--inputs-borders-selected);
}

div.field {
    clear: both;
    margin-bottom: 1em;
}

div.field:after {
    content: "";
    display: table;
    clear: both;
}

div.fieldname {
    float: none;
    width: auto;
    line-height: 1em;
    font-size: 1em;
    color: var(--inputs-fieldname);
    margin-bottom: .3em;
    font-weight: normal;
    text-align: left;
}

div.fieldname.selected {
    font-weight: bold;
}

div.field_group_separator {
    border-top: 1px dashed var(--inputs-borders);
    width: 100%;
    height: 1px;
    clear: both;
    margin-bottom: 1em;
}

input[type=text].obligatory, input[type=password].obligatory, textarea.obligatory {
    padding-right: 1.5em;
    background: url(../design/asterix.svg) right .5em center no-repeat var(--color-background-main);
    background-size: .5em;
}

textarea.obligatory {
}

textarea.wysihtml5-editor.obligatory {
    background-color: transparent;
    padding-right: 0;
}

div.dropfield, section {
    background: var(--color-background-main);
}

div.dropfield.obligatory, section.obligatory {
    background: url(../design/asterix.svg) right .5em center no-repeat var(--color-background-main);
    background-size: .5em;
    padding-right: 1.5em;
}

select {
    -webkit-appearance: none;
    -moz-appearance: none;
    text-indent: .01em;
    text-overflow: '';
    background: url(../design/arrow-orange-down.svg) right .5em center no-repeat var(--color-background-main);
    background-size: 1em;
    padding-right: 2em;
}

select.obligatory {
    background: url(../design/arrow-asterix.svg) right .5em center no-repeat var(--color-background-main);
    background-size: 1.5em;
    padding-right: 2.5em;
}

div.multi_objects_table, table.menutable, div.cardtable_card {
    width: 100%;
}

table.menutable td, table.menutable th {
    padding: 1em;
    vertical-align: middle;
}

form > div.cardtable_card {
    margin-top: 2em;
    padding: 1em;
    border: 1px solid var(--main-underlay);
}

form > div.cardtable_card:first-of-type {
    margin-top: 0;
}

:root {
    --mot_columns_count: 1;
}

div.multi_objects_table {
    display: grid;
    grid-template-columns: 4em 4em repeat(var(--mot_columns_count), minmax(max-content, 1fr));
}

div.multi_objects_delete.without_delete_column {
    grid-template-columns: 4em repeat(var(--mot_columns_count), minmax(max-content, 1fr));
}

div.multi_objects_table thead, div.multi_objects_table tbody {
    display: contents;
}

div.multi_objects_table div.tr {
    display: contents;
}

div.multi_objects_table div.tr div:first-of-type {
    grid-column-start: 1;
}

div.multi_objects_table div.td, div.multi_objects_table div.th {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 1em;
}

div.multi_objects_table div.tr.menu div.td, div.multi_objects_table div.tr.menu div.th {
    background-color: var(--forms-background);
    color: var(--white);
}

div.multi_objects_table div.td button {
    margin-top: 0;
}

div.multi_objects_table div.td span.jq-checkbox {
    float: none;
}

div.multi_objects_table div.tr.menu, table.menutable tr.menu {
    font-weight: bold;
    background-color: var(--main-underlay);
    color: var(--color-background-main);
    text-align: left;
    font-size: 130%;
}

div.multi_objects_table div.tr.menu a, table.menutable tr.menu a {
    color: var(--color-background-main);
    text-decoration: none;
    font-weight: bold;
    padding-right: 1em;
}

div.multi_objects_table div.tr.menu a:hover, table.menutable tr.menu a:hover {
    border-bottom: 0;
    color: var(--inputs-text);
}

div.multi_objects_table div.tr.full_width div.td {
    grid-column-end: none;
}

table.menutable tr.string1, div.multi_objects_table div.tr.string1 div.td, div.cardtable_card {
    background-color: var(--color-background-main);
}

table.menutable tr.string2, div.multi_objects_table div.tr.string2 div.td, div.cardtable_card.cardtable_new {
    background-color: var(--main-underlay);
}

div.multi_objects_table div.td.multi_objects_delete {
    vertical-align: middle;
}

div.multi_objects_table div.td.multi_objects_num {
    font-size: 130%;
    vertical-align: middle;
    font-weight: bold;
}

div.cardtable_card div.cardtable_card_num {
    font-size: 130%;
    vertical-align: middle;
    font-weight: bold;
    background-color: var(--main-underlay);
}

div.cardtable_card div.cardtable_card_num span.cardtable_card_num_name {
    margin-left: .5em;
}

div.cardtable_card + div.control_buttons {
    margin-top: 2em;
}

div.cardtable_card.cardtable_new div.control_buttons {
    margin: 1em 0 2em 0;
}

span.sup {
    font-size: 70%;
    align-self: flex-start;
    margin-left: .3em;
}

div.fieldname.red {
    font-weight: bold;
}

div.fieldname.red + div.fieldvalue input,
div.fieldname.red + div.fieldvalue textarea,
div.fieldname.red + div.fieldvalue select,
div.fieldname.red + div.fieldvalue div.dropfield,
div.fieldname.red + div.help + div.fieldvalue input,
div.fieldname.red + div.help + div.fieldvalue textarea,
div.fieldname.red + div.help + div.fieldvalue select,
div.fieldname.red + div.help + div.fieldvalue div.dropfield,
div.fieldname.red + div.fieldvalue iframe {
    border-color: var(--careful) !important;
}

div.multi_objects_table div.tr.red, .cardtable_card.red {
    background-color: var(--careful);
}

div.multi_objects_table div.tr.red div.td * {
    background-color: var(--color-background-main);
}

div.multi_objects_table div.tr.red img {
    background: none;
}

div.help {
    font-size: 100%;
    font-weight: normal;
    text-align: justify;
    display: none;
    position: absolute;
    background-color: var(--color-background-gray);
    color: var(--color-background-main);
    padding: .2em .3em;
    z-index: 1;
}

div.help a {
    text-decoration: underline;
    color: var(--color-background-main);
}

div.help.shown + div.fieldvalue > input, div.help.shown + div.fieldvalue > select, div.help.shown + div.fieldvalue > textarea, div.help.shown + div.fieldvalue > div.dropfield, div.help.shown + div.fieldvalue.read {
    border-top-left-radius: 0;
    border-top-right-radius: 0;
}

div.fixed_help {
    position: absolute;
    display: inline-block;
    text-align: right;
    font-size: .8em;
    right: 0;
    margin-top: -1.3em;
    z-index: 1;
}

div.fieldvalue {
}

div.fieldvalue.read {
    font-size: 1.3em;
    line-height: normal;
    -ms-word-break: break-all;
    overflow-wrap: break-word;
}

div.fieldvalue font {
    display: inline-block;
}

div.fieldvalue ol, div.fieldvalue ul {
    margin-left: 1em;
}

div.fieldvalue .wysihtml5-toolbar a.toolbar_button[data-wysihtml5-command]:after, div.fieldvalue .wysihtml5-toolbar a.toolbar_button[data-wysihtml5-action]:after {
    content: "";
    background-size: contain;
    width: 1.5em;
    height: 1.5em;
    position: absolute;
    left: .75em;
    top: .15em;
    margin: 0;
}

div.fieldvalue .wysihtml5-toolbar div[data-wysihtml5-dialog] a {
    vertical-align: initial;
}

div.fieldvalue .wysihtml5-toolbar button, div.fieldvalue .wysihtml5-toolbar button:hover {
    padding: .5em !important;
    border-radius: unset !important;
    border: none !important;
}

div.placeholder {
    color: var(--placeholder);
    position: absolute;
    display: block;
    margin-left: 5px;
    font-size: 130%;
}

div.dropfield {
    cursor: pointer;
    border: 1px solid var(--inputs-borders);
    text-align: left;
    padding: 0 .8em;
}

div.dropfield div:not(.options):not(.clear) {
    padding: .8em 0;
}

div.dropfield.focus {
    border-color: var(--inputs-borders-selected);
}

div.dropfield div.options {
    padding: calc(.6em - 1px) 1em;
    margin: .2em .3em .2em 0;
    font-size: 1em;
    cursor: default;
    display: inline-block;
    background-color: var(--inputs-borders);
}

div.dropfield div.options a[rel] {
    display: inline-block;
    font: normal normal normal 1em FontAwesome;
    font-size: inherit;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    opacity: .4;
    margin-left: .3em;
}

div.dropfield div.options a[rel]:before {
    content: "\f00d";
}

div.dropfield div.options:hover a[rel] {
    opacity: 1;
    border-bottom: 0;
}

div.dropfield2 {
    display: none;
    border: 1px solid var(--inputs-borders);
    border-top: 0;
    vertical-align: bottom;
    text-align: left;
    padding: 0;
    overflow: hidden;
    height: 0;
    font-size: 130%;
    margin-top: -0.1em; /*Chrome fix*/
    width: 100% !important;
    position: absolute;
    background-color: var(--color-background-main);
    z-index: 2; /* чтобы перекрывать какие-то пункты с z-index 1, но дальше по тексту */
    top: auto !important;
}

div.dropfield2 div.dropfield2_container {
    overflow: auto;
    width: 100%;
    height: 100%;
    padding: .5em;
}

div.fieldvalue div.dropfield2 {
    top: auto !important;
    box-shadow: 0 0 1.5em var(--shadow-black-1);
}

div.multi_objects_table div.dropfield2 {
    position: relative;
}

div.dropfield2 div {
    vertical-align: middle;
}

div.dropfield2 .inputcheckbox + label {
    padding: 0 0 0 2em;
    display: inline;
}

div.dropfield2 .inputcheckbox + label:before, div.dropfield2 .inputcheckbox + label:after {
    font-size: .5em;
    margin-top: .5em;
}

div.dropfield2 .inputradio + label {
    padding: 0 0 0 1.5em;
}

div.dropfield2 .inputradio + label:before {
    font-size: .5em;
}

div.dropfield2 .inputradio + label:after {
    font-size: .5em;
}

div.dropfield2 img {
    vertical-align: middle;
    margin-right: .5em;
}

div.dropfield2_search {
    margin-bottom: .3em;
}

div.dropfield2_search input, div.maincontent_data.autocreated .ui-widget div.dropfield2_search input {
    font-size: .8em !important;
}

div.dropfield2_search a.create {
    font-size: .9em;
    position: absolute;
    right: 1em;
    top: .3em;
    display: none;
    z-index: 2000;
}

div.dropfield2 div.dropfield2_field input[type="checkbox"][name$="empty_value]"], div.dropfield2 div.dropfield2_field input[type="checkbox"][name$="empty_value]"] + span, div.dropfield2 div.dropfield2_field input[type="checkbox"][name$="empty_value]"] + span + label {
    display: none !important;
}

div.dropfield2 div.dropfield2_select_all, div.dropfield2 div.dropfield2_deselect_all {
    float: right;
    z-index: 1;
    margin-left: 1em;
}

div.dropfield2 div.dropfield2_select_all a, div.dropfield2 div.dropfield2_deselect_all a {
    cursor: pointer;
    background-color: var(--main-underlay);
    padding: .4em;
    border-radius: .3em;
    display: inline-block;
    font-size: .8em;
}

div.dropfield2 div.dropfield2_select_all a:hover, div.dropfield2 div.dropfield2_deselect_all a:hover {
    color: inherit;
    background-color: var(--main-underlay-light);
}

div.dropfield2 .ui-resizable-s {
    height: .5em;
    line-height: .5em;
    bottom: 0;
    border-top: 1px solid var(--ui-resizable-border);
    border-bottom: 1px solid var(--ui-resizable-border);
    background-color: var(--ui-resizable-bg);
    font-size: inherit;
    background-size: 1em 1em;
    background-repeat: no-repeat;
    background-image: linear-gradient(to bottom, var(--ui-resizable-gradient) .1em, transparent .1em, transparent);
    background-position: center .1em;
    z-index: 1 !important;
    margin-bottom: 0 !important;
}

a.ctrlink, a.ctrlink:link, a.ctrlink:visited {
    font-size: 1.3em;
    font-weight: bold;
    float: left;
    margin-right: .3em;
    background-color: var(--color-background-main);
    padding: .5em;
    border-radius: .5em .5em 0 0;
}

a.ctrlink:hover {
    text-decoration: none;
}

a.ctrlink span.fa {
    vertical-align: middle;
    margin-right: .3em;
}

ol, ul {
    padding-left: 2em;
    text-align: left;
}

ol li > span.fa:first-of-type, ul li > span.fa:first-of-type {
    margin-right: .5em;
}

ul.mainCatalog, ul.mainCatalog ul {
    margin-left: 0;
    list-style: none;
    clear: both;
    font-size: 1.2rem;
}

ul.mainCatalog > li {
    padding-left: .5em;
}

ul.subCatalogs li {
    padding: .5em 0 0 1.5em;
}

ul.catalogItems li {
    padding: .5em 0 0 3em;
}

button {
    margin-top: 1%;
}

button.main, input.main {
    background: var(--main-button) !important;
    color: var(--color-background-main) !important;
    border: .15rem var(--main-button) solid !important;
    border-radius: 0 !important;
    text-transform: uppercase;
    -moz-transition: 0.5s linear;
    -webkit-transition: 0.5s linear;
    transition: 0.5s linear;
    -moz-transition-property: border, background;
    -webkit-transition-property: border, background;
    transition-property: border, background;
    will-change: border, background;
    margin: 0;
}

button.main:hover:not(.ui-button-disabled), input.main:hover {
    background: var(--main-button-light) !important;
    border: .15rem var(--main-button-light) solid !important;
}

button.careful, input.careful, button.close, button.careful2, input.careful2 {
    background: var(--careful) !important;
    color: var(--color-background-main) !important;
    border: .15rem var(--careful) solid !important;
    border-radius: 0 !important;
    text-transform: uppercase;
    -moz-transition: 0.5s linear;
    -webkit-transition: 0.5s linear;
    transition: 0.5s linear;
    -moz-transition-property: color, border, background;
    -webkit-transition-property: color, border, background;
    transition-property: color, border, background;
    will-change: color, border, background;
    margin: 0;
}

button.careful:hover:not(.ui-button-disabled), input.careful:hover, button.careful2:hover, input.careful2:hover, button.close:hover {
    background: var(--careful-hover) !important;
    border: .15rem var(--careful-hover) solid !important;
    color: var(--color-background-main) !important;
}

button.nonimportant, input.nonimportant {
    background: var(--color-background-main) !important;
    color: var(--main-button) !important;
    border: .15rem var(--main-button) solid !important;
    border-radius: 0 !important;
    text-transform: uppercase;
    -moz-transition: 0.5s linear;
    -webkit-transition: 0.5s linear;
    transition: 0.5s linear;
    -moz-transition-property: border, background;
    -webkit-transition-property: border, background;
    transition-property: border, background;
    will-change: border, background;
    margin: 0;
}

button.nonimportant:hover:not(.ui-button-disabled), input.nonimportant:hover {
    color: var(--main-button-light) !important;
    border: .15rem var(--main-button-light) solid !important;
}

.trash {
    border: none;
    cursor: pointer;
    display: inline-block;
    outline: none;
    padding: 0;
    position: relative;
    min-width: 1.1em;
    height: 1.3em;
    vertical-align: top;
    background: url(../design/icon-trash.svg) 0 0 no-repeat;
    background-size: contain;
}

.trash > span {
    margin-left: 1.5em;
    font-weight: normal;
    vertical-align: middle;
}

a.trash:hover {
    border: 0;
}

div.clear {
    clear: both;
}

div.maincontent_wrapper {
    display: flex;
    flex-wrap: wrap;
}

div.maincontent_data {
}

div.maincontent_data.autocreated {
}

div.maincontent_data.with_indexer {
    flex: 1;
    min-width: 63%;
    max-width: 100%;
    width: 100%;
}

div.maincontent_data.autocreated form, div.maincontent_data.autocreated form div.cardtable_card {
    display: flex;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    flex-wrap: wrap;
    justify-content: space-between;
}

div.maincontent_data.autocreated form div.field, div.maincontent_data.autocreated form div.cardtable_card_num, div.maincontent_data.autocreated form div.cardtable_card_delete {
    flex: 1;
    width: 48%;
    max-width: 48%;
    min-width: 48%;
    margin-bottom: 1.5em;
}

div.maincontent_data.autocreated form h1.data_h1 {
    flex: 1;
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    margin-bottom: 1em;
}

div.maincontent_data.autocreated form div.cardtable_card div.field {
    width: 23%;
    max-width: 23%;
    min-width: 23%;
}

div.maincontent_data form button.main {
}

div.maincontent_data form button.nonimportant.add_group {
    margin-bottom: 1em;
}

div.maincontent_data table td.alert, div.maincontent_data div.multi_objects_table div.td.alert {
    width: 2%;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center center;
}

div.colorSelector {
    float: left;
    width: 4%;
    height: 100%;
    border: 1px solid var(--color-font-main);
    cursor: pointer;
}

input.cpkr {
    width: 95% !important;
    margin-left: 1%;
}

/* фильтры indexer */
div.indexer {
    font-size: .9em;
    height: 100%;
    background-color: var(--color-background-main);
    padding: .5em;
    vertical-align: top;
    border: 1px solid var(--inputs-borders);
    border-left: 0;
    display: none;
    flex: 1;
    width: 21em;
    max-width: 21em;
    min-width: 21em;
}

div.indexer.shown {
    display: block;
}

div.indexer_toggle {
    float: right;
    cursor: pointer;
    font-size: 130%;
    z-index: 1;
}

div.multi_objects_entity div.indexer_toggle {
    margin-top: -3em;
}

div.indexer_toggle.indexer_shown {
    margin-right: 1em;
}

div.indexer_toggle span.indexer_toggle_text {
    margin-right: .3em;
    font-size: 90%;
}

div.indexer_toggle.indexer_shown span.indexer_toggle_text {
    display: none;
}

div.open_part div.indexer {
    width: 22em;
}

div.indexer.white {
    background-color: var(--color-background-main);
    padding: 0;
}

div.indexer input, div.indexer select, div.indexer textarea, div.indexer div.dropfield, div.indexer div.dropfield2 {
    font-size: .9rem !important;
}

div.indexer select[name="searchAllTextFieldsValues"] {
    margin-bottom: .3em;
}

div.indexer select[name="searchAllTextFieldsValues"] ~ br {
    display: table;
    height: .5em;
    content: '';
}

div.indexer form div.filtersBlock {
    margin-bottom: 1.3em;
}

div.indexer form div.filtersBlock div.filtersName {
    font-weight: bold;
    margin-bottom: .5em;
}

div.indexer form .inputcheckbox + label {
    padding: 0 0 0 2em;
    display: inline;
}

div.indexer form div.filtersBlock > .inputcheckbox + label:before, div.indexer form div.filtersBlock > .inputcheckbox + label:after, div.indexer form div.filtersBlock > div.dropfield2 .inputcheckbox + label:before, div.indexer form div.filtersBlock > div.dropfield2 .inputcheckbox + label:after {
    font-size: .5em;
    margin-top: .5em;
}

div.indexer form div.filtersBlock > .inputradio + label {
    padding: 0 0 0 1.5em;
}

div.indexer form div.filtersBlock > .inputradio + label:before, div.indexer form div.filtersBlock > .inputradio + label:after {
    font-size: .5em;
    margin-top: .5em;
}

div.indexer button {
    padding: .8em !important;
    border-radius: 0 !important;
}

div.indexer button.main {
    float: left;
    margin-left: 0 !important;
}

div.indexer button.main.full_width {
    width: 100%;
}

div.indexer button.nonimportant {
    float: right;
}

div.indexer button.floaty {
    position: fixed;
    bottom: 0;
    z-index: 10000;
}

div.indexer button.floaty.nonimportant {
    margin-left: 7.5em;
}

div.indexer div.ui-resizable-w {
    border-left: 1px solid var(--ui-resizable-border);
    border-right: 1px solid var(--ui-resizable-border);
    background-color: var(--ui-resizable-bg);
    width: .5em;
    left: -0.5em;
    font-size: inherit;
    background-size: 1em 1em;
    background-repeat: no-repeat;
    background-image: linear-gradient(to right, var(--ui-resizable-gradient) .1em, transparent .1em, transparent), linear-gradient(to right, var(--ui-resizable-gradient) .1em, transparent .1em, transparent);
    background-position: 0 center, .3em center;
    z-index: 1 !important;
}

div.indexer input.inputnum {
    width: 60%;
}

div.copy_filters_link {
    text-align: center;
    margin: 3em 0 -1em 0;
}

/* пагинатор */
div.pagecounter {
    display: flex;
    margin: 4em auto 2em auto;
    width: max-content;
    min-width: max-content;
    max-width: max-content;
    flex-wrap: wrap;
    align-items: center;
}

div.pagecounter div {
    display: flex;
    width: max-content;
    min-width: max-content;
    max-width: max-content;
    align-items: center;
    flex: 1;
}

div.pagecounter div.pagecounter_buttons, div.pagecounter div.pagecounter_text {
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    justify-content: center;
}

div.pagecounter a {
    display: inline-flex;
    border-radius: .7em;
    border: 1px solid var(--color-font-main);
    color: var(--color-font-main);
    width: 3em;
    height: 3em;
    align-items: center;
    justify-content: center;
    margin-right: .5em;
}

div.pagecounter div a:last-of-type, div.pagecounter div.pagecounter_nums a:last-of-type {
    margin-right: 0;
}

div.pagecounter a.disabled {
    cursor: initial;
    opacity: .5;
}

div.pagecounter div.pagecounter_nums a {
    margin-right: 1.2em;
    border: 1px solid var(--color-font-main);
    background-color: var(--color-font-main);
    color: var(--color-background-main);
}

div.pagecounter div.pagecounter_nums a.selected {
    cursor: initial;
    color: var(--color-font-main);
    background-color: var(--inputs-borders);
    border: 1px solid var(--inputs-borders);
}

div.pagecounter div.pagecounter_prevs {
    margin-right: 2em;
}

div.pagecounter div.pagecounter_prevs a, div.pagecounter div.pagecounter_nexts a {
    width: 2.5em;
    height: 2.5em;
    background: center center no-repeat;
    background-size: auto .8em;
    vertical-align: bottom;
}

div.pagecounter div.pagecounter_prevs a.prev {
    background-image: url(../design/arrow-orange-left.svg);
}

div.pagecounter div.pagecounter_prevs a.first {
    background-image: url(../design/arrow-orange-double-left.svg);
}

div.pagecounter div.pagecounter_nexts {
    margin-left: 2em;
}

div.pagecounter div.pagecounter_nexts a.next {
    background-image: url(../design/arrow-orange-right.svg);
}

div.pagecounter div.pagecounter_nexts a.last {
    background-image: url(../design/arrow-orange-double-right.svg);
}

div.pagecounter div.pagecounter_text {
    color: var(--placeholder);
    margin-top: 1.8em;
}

div.pagecounter div.pagecounter_text span {
    color: var(--color-font-main);
    margin: 0 .3em;
}

/* адаптативная верстка */
@media only screen and (min-width: 1300px) {
    div.maincontent {
        padding: 2.5rem 8%;
    }
}

/* мобильная верстка */
@media only screen and (max-device-width: 767px) {
    div.maincontent_data form {
        font-size: .8em;
    }

    div.maincontent_data.autocreated form div.field, div.maincontent_data.autocreated form div.cardtable_card div.field {
        width: 100%;
        max-width: 100%;
        min-width: 100%;
    }

    div.fieldname {
        font-size: 1.5em;
    }

    div.fieldvalue {
        font-size: 1.5em;
    }

    div.fieldvalue.read {
        font-size: 1.95em;
    }

    div.maincontent_data h1.data_h1 {
        font-size: 2em;
    }

    a.edit_file, div.uploaded_file a.trash {
        display: block;
    }

    div.fieldvalue div.uploaded_file a.edit_file, div.fieldvalue div.uploaded_file a.trash {
        display: inline-block;
    }

    /* перестраиваем автоматические таблицы под удобный для работы формат */
    div.multi_objects_table {
        width: 100%;
    }

    div.multi_objects_table div.tr {
        width: 100%;
        display: inline-block;
    }

    div.multi_objects_table div.tr.menu {
        font-size: inherit;
    }

    div.multi_objects_table div.tr.menu div.td {
        font-size: 1.3rem;
    }

    div.multi_objects_table div.td {
        display: inline-block;
        text-align: left;
        padding: 0 !important;
        margin: 1% !important;
    }

    div.multi_objects_table div.tr.menu div.td:nth-of-type(3) {
        font-size: 1.6rem;
    }

    div.multi_objects_table div.tr div.td:nth-of-type(3) {
        width: 90% !important;
        min-width: 90% !important;
    }

    div.multi_objects_table div.tr div.td:nth-of-type(4n) {
        margin-left: 9% !important;
    }

    div.multi_objects_table div.td {
        width: 21% !important;
        min-width: 21% !important;
    }

    div.multi_objects_table div.tr.menu div.td[colspan] {
        width: 100% !important;
        margin: 1% 0 !important;
    }

    div.indexer_toggle {
        position: absolute;
        right: 0;
        float: none;
    }

    div.indexer_toggle.indexer_shown {
        margin-right: 0;
    }

    div.indexer {
        flex: 1;
        width: 100%;
        min-width: 100%;
        max-width: 100%;
        order: 1;
        height: 15em;
        overflow-y: auto;
        margin-bottom: 2em;
        font-size: 1.5rem;
    }

    div.maincontent_data.with_indexer {
        order: 2;
    }

    div.indexer input, div.indexer select, div.indexer textarea, div.indexer div.dropfield, div.indexer div.dropfield2 {
        font-size: inherit !important;
    }

    div.indexer button.floaty {
        position: inherit;
        bottom: auto;
        z-index: inherit;
    }

    a.ctrlink, a.ctrlink:link, a.ctrlink:visited {
        float: none;
        width: 100%;
        border-radius: 0;
        border-bottom: 1px solid var(--gray-very-light);
        margin: 0;
    }
}