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

/* Единый стиль полей и выпадающих списков (native + Tom Select) */
:root {
  --cm-select-bg: #0f130c;
  --cm-select-border: #2a3020;
  --cm-select-text: #9ca88a;
  --cm-select-accent: #c9a227;
  --cm-dropdown-bg: #141a10;
  --cm-dropdown-hover: #1e231c;
  --cm-dropdown-active: #252b18;
  --cm-chip-bg: #2a3020;
  --cm-chip-border: #3d4a2d;
}

* { box-sizing: border-box; }
html { overflow-x: hidden; }
body {
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  margin: 16px;
  background: #0a0c08;
  color: #9ca88a;
  font-size: 14px;
  line-height: 1.4;
  max-width: 100%;
  overflow-x: hidden;
}
body::before {
  content: "";
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0, 0, 0, 0.03) 2px, rgba(0, 0, 0, 0.03) 4px);
  pointer-events: none;
  z-index: 9999;
}
h1, h2, h3 { color: #c9a227; font-weight: bold; text-shadow: 0 0 8px rgba(201,162,39,0.3); border-bottom: 1px solid #3d4a2d; padding-bottom: 6px; margin-top: 0; }
h1.site-header { display: flex; justify-content: space-between; align-items: center; border-bottom: none; padding-bottom: 0; margin-bottom: 12px; text-align: left; flex-wrap: wrap; gap: 8px; }
h1.site-header .site-logo-img { width: 250px; height: auto; display: block; }
h1.site-header .site-credit {
  font-family: "Caveat", "Segoe Script", "Brush Script MT", cursive;
  font-size: 1.35rem;
  font-weight: 400;
  color: #7a8a6a;
  white-space: nowrap;
}
.lang-switch { margin-left: auto; display: flex; align-items: center; gap: 6px; }
.lang-switch select { width: auto; min-width: 120px; }
h2 { text-align: center; }
h2.page-title {
  text-align: left;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  width: 100%;
}
.page-title .h2-title { margin: 0; border: none; padding: 0; }
.page-title .h2-user-nav {
  margin-left: auto;
  color: #9ca88a;
  font-size: 0.95rem;
  font-weight: normal;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.page-title .h2-user-nav select.lang-select { min-width: 100px; max-width: 160px; }
.nav-bar { position: sticky; top: 0; z-index: 1000; display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; padding: 0; border-bottom: 1px solid #2a3020; background: #0a0c08; }
.nav-left { display: flex; align-items: flex-end; gap: 0; min-width: 0; flex: 1 1 auto; flex-wrap: wrap; }
.nav-right { color: #9ca88a; display: flex; align-items: flex-end; gap: 0; min-width: 0; flex-shrink: 0; justify-content: flex-end; flex-wrap: wrap; }
.nav-tab { display: inline-block; padding: 10px 18px; margin-right: 2px; background: rgba(20, 26, 16, 0.7); color: #9ca88a; text-decoration: none; font-size: 14px; border: 1px solid #2a3020; border-bottom: none; border-radius: 8px 8px 0 0; -webkit-backdrop-filter: blur(6px); backdrop-filter: blur(6px); transition: background 0.2s, color 0.2s; cursor: pointer; font-family: inherit; }
button.nav-tab { color: #9ca88a; }
.nav-tab:hover { background: rgba(42, 48, 32, 0.9); color: #c9a227; }
.nav-tab.active { position: relative; bottom: -1px; z-index: 1; padding-bottom: 11px; background: #0a0c08; color: #c9a227; border-color: #2a3020; border-bottom: 1px solid #0a0c08; }
.nav-right .nav-tab { margin-right: 0; margin-left: 2px; }
a { color: #c9a227; text-decoration: none; }
a:hover { color: #e0b830; text-shadow: 0 0 6px rgba(201,162,39,0.5); }
button:not(.nav-tab):not(.settings-subtab), .btn-open { display: inline-block; padding: 8px 14px; background: rgba(20,26,16,0.85); color: #c9a227; border: 1px solid #3d4a2d; border-radius: 6px; cursor: pointer; font-size: 13px; font-family: inherit; }
button:not(.nav-tab):not(.settings-subtab):hover, .btn-open:hover { background: rgba(26,34,18,0.9); border-color: rgba(201,162,39,0.5); }
.devices-filters-intro {
  font-size: 13px;
  color: #8a9a7a;
  margin: 0 0 12px 0;
  padding: 10px 12px;
  border: 1px solid #2a3020;
  background: #0f130c;
  max-width: 920px;
  line-height: 1.45;
}
.devices-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 12px;
  align-items: flex-start;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid #2a3020;
}
.devices-filter-dropdown {
  min-width: 200px;
  max-width: 280px;
  border: 1px solid #3d4a2d;
  border-radius: 6px;
  background: #0f130c;
  overflow: hidden;
}
.devices-filter-dropdown[open] {
  border-color: #c9a227;
  box-shadow: 0 0 0 1px rgba(201, 162, 39, 0.2);
}
.devices-filter-summary {
  list-style: none;
  cursor: pointer;
  padding: 10px 12px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px 8px;
  color: #c9a227;
  font-weight: 600;
  font-size: 13px;
  user-select: none;
}
.devices-filter-summary::-webkit-details-marker { display: none; }
.devices-filter-summary::marker { content: ""; }
.devices-filter-caret {
  font-size: 10px;
  color: #9ca88a;
  margin-left: auto;
}
.devices-filter-dropdown[open] .devices-filter-caret {
  transform: rotate(-180deg);
  display: inline-block;
}
.devices-filter-multi-tag {
  font-size: 11px;
  font-weight: normal;
  color: #7a8a6a;
  border: 1px solid #2a3020;
  padding: 2px 6px;
  border-radius: 4px;
}
.devices-filter-body {
  padding: 0 10px 10px;
  border-top: 1px solid #2a3020;
}
.devices-filter-hint {
  font-size: 11px;
  color: #6a7a5a;
  margin: 8px 0 6px;
}
select.devices-filter-multiselect {
  width: 100%;
  min-height: 160px;
  max-height: 220px;
  padding: 6px;
  font-size: 13px;
  line-height: 1.35;
  background: var(--cm-select-bg);
  border: 1px solid var(--cm-select-border);
  color: var(--cm-select-text);
  border-radius: 4px;
  cursor: pointer;
}
select.devices-filter-multiselect:focus {
  outline: none;
  border-color: var(--cm-select-accent);
}
select.devices-filter-multiselect option {
  padding: 6px 8px;
  margin: 1px 0;
}
select.devices-filter-multiselect option:checked {
  background: linear-gradient(0deg, #2a3020 0%, #2a3020 100%);
  color: #c9a227;
}
tr.devices-row-link { cursor: pointer; }
tr.devices-row-link:hover { background: rgba(201, 162, 39, 0.1); }
tr.devices-row-link td { cursor: pointer; }
.table-wrap { overflow-x: auto; margin: 0 0 16px 0; }
table { border-collapse: collapse; width: 100%; font-size: 13px; }
th, td { border: 1px solid #2a3020; padding: 10px 12px; text-align: left; }
th { background: #141a10; color: #c9a227; }
tr:nth-child(even) { background: #0f130c; }
tr:hover { background: #1a2212; }
.devices-intro { max-width: 560px; margin: 1rem 0; padding: 1rem; border: 1px solid #2a3020; background: #0f130c; color: #9ca88a; line-height: 1.5; }
input[type="text"],
input[type="password"] {
  background: var(--cm-select-bg);
  border: 1px solid var(--cm-select-border);
  color: var(--cm-select-text);
  padding: 8px 10px;
  border-radius: 4px;
  width: 200px;
  font-size: 14px;
}
input[type="text"]:focus,
input[type="password"]:focus {
  outline: none;
  border-color: var(--cm-select-accent);
  box-shadow: 0 0 0 1px rgba(201, 162, 39, 0.15);
}
.login-form label { display: inline-block; width: 80px; }
.login-form .row { margin-bottom: 10px; }
.login-form button[type="submit"] { margin-top: 8px; }
.login-error { color: #b54; margin-top: 8px; }
select,
select.lang-select {
  background-color: var(--cm-select-bg);
  border: 1px solid var(--cm-select-border);
  color: var(--cm-select-text);
  padding: 8px 10px;
  border-radius: 4px;
  min-width: 140px;
  max-width: 220px;
  font-family: inherit;
  font-size: 14px;
  line-height: 1.35;
  cursor: pointer;
  appearance: auto;
}
select:focus,
select.lang-select:focus {
  outline: none;
  border-color: var(--cm-select-accent);
  box-shadow: 0 0 0 1px rgba(201, 162, 39, 0.2);
}
select:disabled { opacity: 0.72; cursor: not-allowed; }
select option {
  background: var(--cm-dropdown-bg);
  color: var(--cm-select-text);
  padding: 6px;
}

/* Tom Select — тот же визуальный язык, что у select */
.ts-wrapper {
  position: relative;
  font-family: inherit;
}
.ts-wrapper .ts-control,
.ts-wrapper .ts-control input,
.ts-dropdown {
  color: var(--cm-select-text);
  font-family: inherit;
  font-size: 14px;
  line-height: 1.4;
}
.ts-wrapper .ts-control,
.ts-wrapper.single .ts-control {
  background: var(--cm-select-bg) !important;
  border: 1px solid var(--cm-select-border) !important;
  border-radius: 4px;
  min-height: 38px;
  padding: 6px 10px;
  box-shadow: none !important;
}
.ts-wrapper.multi.has-items .ts-control {
  padding: 5px 8px 4px;
}
.ts-wrapper.focus .ts-control,
.ts-wrapper.dropdown-active .ts-control,
.ts-wrapper.plugin-dropdown_input.focus.dropdown-active .ts-control {
  border-color: var(--cm-select-accent) !important;
  box-shadow: 0 0 0 1px rgba(201, 162, 39, 0.2) !important;
}
.ts-control > input {
  color: var(--cm-select-text) !important;
}
.ts-control > input::placeholder {
  color: #6a7a5a;
}
.ts-wrapper.multi .ts-control > div,
.ts-wrapper.multi .ts-control > div.item,
.ts-wrapper.multi .ts-control > div.active {
  background: var(--cm-chip-bg) !important;
  color: var(--cm-select-accent) !important;
  border: 1px solid var(--cm-chip-border) !important;
  border-radius: 4px;
  margin: 0 4px 4px 0;
  padding: 3px 6px;
}
.ts-wrapper.plugin-remove_button:not(.rtl) .item .remove {
  border-left: 1px solid var(--cm-chip-border) !important;
  color: var(--cm-select-text);
}
.ts-wrapper.plugin-remove_button .item .remove:hover {
  background: rgba(201, 162, 39, 0.12) !important;
  color: var(--cm-select-accent);
}
.disabled .ts-control,
.ts-wrapper.disabled .ts-control {
  background: var(--cm-select-bg) !important;
  opacity: 0.65;
  cursor: not-allowed !important;
}
.ts-dropdown {
  background: var(--cm-dropdown-bg) !important;
  border: 1px solid var(--cm-select-border) !important;
  border-radius: 6px;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.55);
  margin-top: 4px;
  z-index: 10050 !important;
}
.ts-dropdown .option,
.ts-dropdown .create,
.ts-dropdown .no-results,
.ts-dropdown .optgroup-header {
  padding: 8px 12px;
}
.ts-dropdown .option,
.ts-dropdown [data-selectable].option {
  color: var(--cm-select-text);
}
.ts-dropdown [data-selectable].option:hover,
.ts-dropdown .option:hover {
  background: var(--cm-dropdown-hover) !important;
  color: var(--cm-select-accent) !important;
}
.ts-dropdown .active,
.ts-dropdown [data-selectable].option.active {
  background: var(--cm-dropdown-active) !important;
  color: var(--cm-select-accent) !important;
}
.ts-dropdown .create {
  color: var(--cm-select-accent);
  border-top: 1px solid var(--cm-select-border);
  opacity: 0.95;
}
.ts-dropdown .highlight {
  background: rgba(201, 162, 39, 0.25) !important;
  color: var(--cm-select-text);
}
.ts-dropdown-content {
  max-height: 240px;
}
.ts-wrapper.single .ts-control::after {
  border-color: var(--cm-select-text) transparent transparent transparent !important;
}
.ts-dropdown .spinner:after {
  border-color: var(--cm-select-accent) transparent !important;
}
.full .ts-control {
  background: var(--cm-select-bg) !important;
}
.settings-add { font-size: 11px; color: #6a7a5a; margin-top: 4px; }
.settings-add a { color: #c9a227; cursor: pointer; }
.cell-select-wrap { display: flex; flex-direction: column; align-items: flex-start; }
.cell-select-wrap.cell-locked select { opacity: 0.85; cursor: not-allowed; }
.settings-target-wrap { margin: 12px 0 16px; padding: 10px 12px; border: 1px solid #2a3020; background: #0f130c; max-width: 640px; }
.settings-target-wrap label { margin-right: 8px; }
.settings-target-wrap select { min-width: 220px; margin-right: 12px; }
.settings-target-hint { display: block; margin-top: 8px; font-size: 12px; }
.tr-editing select:disabled { opacity: 1; cursor: pointer; }
.view-hidden { display: none !important; }
#add-modal { display: none; position: fixed; top:0;left:0;right:0;bottom:0; background: rgba(0,0,0,0.6); z-index: 10000; align-items: center; justify-content: center; }
#add-modal.open { display: flex; }
#add-modal .modal-inner { background: #1e231c; border: 1px solid #3a4035; border-radius: 8px; padding: 20px; }
#add-modal .modal-inner input { width: 220px; margin-bottom: 10px; }
.hint-muted { margin-top: 1rem; color: #6a7a5a; font-size: 12px; }
.users-section { margin-top: 2rem; padding-top: 1.25rem; border-top: 1px solid #2a3020; }
.settings-subtitle { font-size: 1.1rem; margin: 0 0 0.5rem 0; border-bottom: none; padding-bottom: 0; }
.form-add-user { margin-top: 14px; display: flex; flex-wrap: wrap; align-items: center; gap: 10px 14px; }
.form-add-user .row-inline label { margin-right: 6px; }
.form-add-user input[type="text"], .form-add-user input[type="password"] { width: 160px; }
.users-msg { margin: 10px 0; font-size: 13px; }
.users-msg.users-msg-ok { color: #7a9a6a; }
.users-msg.users-msg-err { color: #c75; }
.users-table { max-width: 720px; }
button.btn-del-user { padding: 4px 10px; font-size: 12px; }
.accounts-toolbar { margin: 12px 0; display: flex; flex-wrap: wrap; align-items: center; gap: 10px; }
.accounts-toolbar .accounts-msg { margin: 0; }
.accounts-msg-ok { color: #7a9a6a; font-size: 13px; }
.accounts-table-wrap { margin-top: 8px; }
.table-scroll { overflow-x: auto; max-width: 100%; border: 1px solid #2a3020; }
.accounts-table { min-width: 1400px; font-size: 12px; }
.accounts-table-compact { min-width: 480px; max-width: 900px; }
tr.acc-row-clickable { cursor: pointer; }
tr.acc-row-clickable:hover { background: #1a2212; }
tr.acc-row-clickable td { cursor: pointer; }
tr.acc-row-clickable input { cursor: text; }
tr.acc-row-clickable button { cursor: pointer; }
.acc-profile-back-wrap { margin-bottom: 12px; }
.acc-profile-grid { display: flex; flex-direction: column; gap: 14px; max-width: 720px; margin-top: 16px; }
.acc-prof-label { display: flex; flex-direction: column; gap: 6px; color: #9ca88a; }
.acc-prof-inp { max-width: 400px; }
.acc-prof-multi { display: flex; flex-direction: column; gap: 6px; }
.acc-prof-multi-label { color: #c9a227; font-size: 13px; }
.acc-prof-multi .ts-wrapper { max-width: 100%; }
.acc-profile-actions { margin-top: 20px; }
.accounts-table th, .accounts-table td { padding: 8px 6px; vertical-align: top; }
.acc-inp { width: 100%; max-width: 120px; font-size: 12px; padding: 6px 8px; }
.acc-login { max-width: 100px; }
.acc-td-multi { min-width: 140px; max-width: 180px; }
.acc-td-multi .ts-wrapper,
.acc-prof-multi .ts-wrapper { font-size: 13px; }
.acc-td-multi .ts-control,
.acc-prof-multi .ts-control { min-height: 36px; }
.acc-role { max-width: 110px; font-size: 12px; padding: 4px; }
.btn-edit-acc { padding: 4px 10px; font-size: 11px; margin-right: 6px; }
.btn-del-acc { padding: 4px 8px; font-size: 11px; }
.acc-inp:disabled,
.acc-role:disabled { opacity: 0.72; cursor: not-allowed; }
.account-row-new { background: rgba(201, 162, 39, 0.06); }
.settings-subnav { display: flex; flex-wrap: wrap; gap: 6px; margin: 16px 0 20px; padding-bottom: 12px; border-bottom: 1px solid #2a3020; }
.settings-subtab { padding: 8px 14px; font-size: 13px; background: rgba(20,26,16,0.85); color: #9ca88a; border: 1px solid #2a3020; border-radius: 6px; cursor: pointer; font-family: inherit; }
.settings-subtab:hover { color: #c9a227; border-color: #3d4a2d; }
.settings-subtab.active { color: #c9a227; border-color: #c9a227; background: #141a10; }
.settings-panel-title { font-size: 1.05rem; margin: 0 0 8px 0; border: none; padding: 0; }
.settings-panel-subtitle { font-size: 0.95rem; color: #c9a227; margin: 20px 0 8px; }
.catalog-add-row { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; margin: 12px 0; }
.catalog-inp {
  min-width: 220px;
  padding: 8px 10px;
  font-size: 14px;
  background: var(--cm-select-bg);
  border: 1px solid var(--cm-select-border);
  color: var(--cm-select-text);
  border-radius: 4px;
}
.catalog-inp:focus {
  outline: none;
  border-color: var(--cm-select-accent);
}
.btn-catalog-add { padding: 8px 16px; }
.catalog-msg { font-size: 13px; margin: 8px 0; }
.catalog-msg-ok { color: #7a9a6a; }
.catalog-table { max-width: 720px; }
.ho-head-name-row,
.ho-under-head-row,
.ho-my-org-row { cursor: pointer; }
.ho-head-name-row:hover,
.ho-under-head-row:hover,
.ho-my-org-row:hover { background: rgba(201, 162, 39, 0.08); }
/* Целая строка — ссылка: курсор «рука» по всей строке */
tr.ho-tr-link { cursor: pointer; }
tr.ho-tr-link:hover { background: rgba(201, 162, 39, 0.1); }
tr.ho-tr-link td { cursor: pointer; }
tr.ho-tr-link button,
tr.ho-tr-link a { cursor: pointer; }
.link-danger { color: #a65c5c; font-size: 13px; }
.link-danger:hover { color: #c97a7a; }
.org-delete-wrap { margin-top: 16px; }
.btn-tiny { padding: 4px 10px; font-size: 11px; margin: 0 2px; }
.form-new-device { margin: 12px 0; }
.device-form-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); gap: 12px; margin-bottom: 14px; }
.device-form-grid label { display: flex; flex-direction: column; gap: 4px; font-size: 12px; color: #9ca88a; }
.device-form-grid input {
  padding: 8px 10px;
  font-size: 14px;
  background: var(--cm-select-bg);
  border: 1px solid var(--cm-select-border);
  color: var(--cm-select-text);
  border-radius: 4px;
}
.btn-catalog-del { padding: 4px 10px; font-size: 11px; }
.head-org-toolbar { margin: 12px 0; display: flex; flex-wrap: wrap; gap: 10px; align-items: center; }
.head-org-matrix { min-width: 900px; }
.ho-flat-row { cursor: pointer; }
.ho-flat-row:hover { background: #1a2212; }
.ho-tt-click { cursor: pointer; color: #c9a227; text-decoration: underline; }
.ho-org-tt-row { cursor: pointer; }
.ho-org-tt-row:hover { background: #1a2212; }
.link-back { color: #c9a227; font-size: 14px; }
.btn-danger-soft { background: rgba(80,30,30,0.4); color: #c88; border-color: #633; }
.modal-overlay { position: fixed; inset: 0; background: rgba(0,0,0,0.65); z-index: 10001; display: flex; align-items: center; justify-content: center; padding: 16px; }
.modal-overlay.view-hidden { display: none !important; }
.modal-box { background: #1e231c; border: 1px solid #3a4035; border-radius: 10px; padding: 20px; max-width: 420px; width: 100%; }
.modal-box-wide { max-width: 520px; }
.modal-form-grid { display: flex; flex-direction: column; gap: 12px; margin: 16px 0; }
.modal-form-grid label { display: flex; flex-direction: column; gap: 4px; font-size: 13px; }
.modal-form-grid input,
.modal-form-grid select {
  padding: 8px 10px;
  font-size: 14px;
  background: var(--cm-select-bg);
  border: 1px solid var(--cm-select-border);
  color: var(--cm-select-text);
  border-radius: 4px;
}
.modal-form-grid input:focus,
.modal-form-grid select:focus {
  outline: none;
  border-color: var(--cm-select-accent);
}
.modal-actions { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 12px; }
.btn-del-tt-dev { padding: 4px 8px; font-size: 11px; }
@media (max-width: 768px) {
  body { margin: 10px; font-size: 13px; }
  h2 { font-size: 1.25rem; }
  h1.site-header .site-logo-img { max-width: 180px; }
  h1.site-header .site-credit { font-size: 0.75rem; }
  .nav-bar {
    gap: 6px;
    padding: 8px 0;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
  }
  .nav-left,
  .nav-right { font-size: 0.9rem; flex-wrap: nowrap; flex-shrink: 0; }
  .nav-tab { padding: 8px 12px; font-size: 12px; white-space: nowrap; }
}
@media (max-width: 480px) {
  body { margin: 8px; }
  h2 { font-size: 1.1rem; }
  h1.site-header .site-logo-img { max-width: 140px; }
  h1.site-header .site-credit { font-size: 0.65rem; }
  .nav-tab { padding: 6px 10px; font-size: 16px; }
  table { min-width: 360px; }
}
