:root {
  --app-primary: #1e3a8a;
  --app-primary-strong: #1d4ed8;
  --app-primary-soft: #dbeafe;
  --app-bg: #f4f8ff;
  --app-bg-alt: #eef4ff;
  --app-card: #ffffff;
  --app-ink: #0f172a;
  --app-muted: #52627c;
  --app-border: #d8e2f2;
  --app-success-bg: #ecfdf5;
  --app-success-border: #86efac;
  --app-danger-bg: #fff1f2;
  --app-danger-border: #fda4af;
  --app-info-bg: #eff6ff;
  --app-info-border: #93c5fd;
  --btn-height: 2.4rem;
  --control-height: var(--btn-height);
  --btn-radius: 0.72rem;
  --btn-font-size: 0.84rem;
  --btn-gap: 0.44rem;
  --btn-padding-inline: 0.9rem;
  --btn-icon-size: 0.95rem;
  --btn-shadow-soft: 0 4px 10px rgba(15, 23, 42, 0.08);
  --btn-focus-ring: 0 0 0 3px rgba(37, 99, 235, 0.22);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body.app-body {
  margin: 0;
  min-height: 100vh;
  font-family: Roboto, "Segoe UI", Helvetica, sans-serif;
  color: var(--app-ink);
  background: var(--app-bg);
  position: relative;
}

body.app-body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: url('/template-dist/images/noise.png') repeat;
  opacity: 0.08;
  pointer-events: none;
}

body.app-body::after {
  content: "";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(circle at 90% 10%, rgba(37, 99, 235, 0.16), transparent 35%),
    radial-gradient(circle at 5% 95%, rgba(30, 58, 138, 0.14), transparent 28%),
    url('/template-dist/images/accent.svg') no-repeat center center;
  background-size: auto, auto, cover;
  opacity: 0.35;
  pointer-events: none;
}

.app-shell {
  min-height: 100vh;
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 278px 1fr;
}

.app-sidebar {
  padding: 1.55rem 1rem;
  color: #dbeafe;
  background: linear-gradient(170deg, #0f2d72 0%, #173a8d 58%, #1f4fb6 100%);
  border-right: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.06);
}

.app-logo {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  text-decoration: none;
  color: #eff6ff;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-bottom: 1.35rem;
}

.app-logo img {
  width: 20px;
  height: 20px;
}

.app-nav-title {
  margin: 1.2rem 0 0.45rem;
  font-size: 0.71rem;
  text-transform: uppercase;
  letter-spacing: 0.09em;
  opacity: 0.66;
}

.app-nav {
  display: flex;
  flex-direction: column;
  gap: 0.28rem;
}

.app-nav-link {
  display: flex;
  align-items: center;
  gap: 0.56rem;
  text-decoration: none;
  color: #dbeafe;
  border-radius: 0.82rem;
  padding: 0.62rem 0.76rem;
  font-size: 0.91rem;
  transition: background 0.15s ease;
}

.app-nav-link:hover,
.app-nav-link.is-active {
  color: #ffffff;
  background: rgba(255, 255, 255, 0.14);
}

.app-nav-link i {
  width: 16px;
  height: 16px;
}

.app-content {
  min-width: 0;
  padding: 1.2rem 1.25rem 1.35rem;
}

.topbar-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 0.98rem 1.08rem;
  margin-bottom: 0.95rem;
  background: #ffffff;
  border-color: #dce6f6;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.topbar-meta {
  min-width: 0;
}

.page-title {
  margin: 0;
  font-size: 1.32rem;
  font-weight: 700;
  line-height: 1.25;
}

.page-subtitle {
  margin: 0.3rem 0 0;
  color: var(--app-muted);
  font-size: 0.88rem;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 0.56rem;
}

.topbar-profile {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0;
  min-height: 0;
}

.topbar-avatar {
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #234491;
  background: linear-gradient(150deg, #dbeafe 0%, #bfdbfe 100%);
  border: 1px solid #bdd1f6;
}

.topbar-avatar i {
  width: 0.98rem;
  height: 0.98rem;
}

.app-user-meta {
  display: flex;
  flex-direction: column;
  gap: 0.09rem;
  text-align: right;
}

.app-user-meta .name {
  font-size: 0.88rem;
  font-weight: 600;
  line-height: 1.1;
}

.app-user-meta .role {
  font-size: 0.75rem;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: #5d6e8d;
  background: transparent;
  border: 0;
  padding: 0;
  white-space: nowrap;
}

.topbar-logout-form {
  border-left: 1px solid #d8e3f4;
  padding-left: 0.62rem;
}

.topbar-logout {
  min-height: 38px;
  padding-inline: 0.78rem;
  border: 1px solid #d0dbec;
  border-radius: 10px;
  background: #ffffff;
  color: #334155;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03);
}

.topbar-logout:hover {
  background: #eff4ff;
  border-color: #bfd0ef;
  color: #1f3f87;
}

.app-main {
  min-width: 0;
  max-width: 1240px;
  margin: 0 auto;
}

.content-stack {
  display: flex;
  flex-direction: column;
  gap: 0.95rem;
}

.app-card {
  background: var(--app-card);
  border: 1px solid var(--app-border);
  border-radius: 16px;
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.06);
}

.card-pad {
  padding: 1rem 1.05rem;
}

.app-section {
  margin: 0;
}

.section-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 0.8rem;
  margin-bottom: 0.75rem;
}

.section-head > .table-actions,
.section-head > .bulk-actions {
  align-items: center;
  justify-content: flex-end;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.section-title {
  margin: 0;
  font-size: 1.08rem;
  font-weight: 700;
}

.section-note {
  margin: 0.28rem 0 0;
  color: var(--app-muted);
  font-size: 0.84rem;
}

.stack-md {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.inline-form {
  display: flex;
  align-items: flex-end;
  gap: 0.55rem;
  flex-wrap: wrap;
}

.inline-form > .btn,
.inline-form > a.btn {
  min-height: var(--btn-height);
}

.inline-form .form-group {
  min-width: min(290px, 100%);
  flex: 1;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--btn-gap);
  min-height: var(--btn-height);
  border: 1px solid #c7d4e8;
  border-radius: var(--btn-radius);
  padding: 0 var(--btn-padding-inline);
  font-size: var(--btn-font-size);
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1.05;
  text-decoration: none;
  cursor: pointer;
  white-space: nowrap;
  background: #ffffff;
  color: #334155;
  box-shadow: var(--btn-shadow-soft);
  vertical-align: middle;
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease, transform 0.08s ease;
}

.btn i {
  width: var(--btn-icon-size);
  height: var(--btn-icon-size);
  stroke-width: 1.8;
  flex-shrink: 0;
}

.btn > span {
  display: inline-flex;
  align-items: center;
}

.btn-primary {
  background: linear-gradient(180deg, #1f4fc9 0%, var(--app-primary) 100%);
  border-color: var(--app-primary);
  color: #ffffff;
  box-shadow: 0 8px 16px rgba(30, 58, 138, 0.25);
}

.btn-primary:hover {
  background: linear-gradient(180deg, #2458dc 0%, var(--app-primary-strong) 100%);
  border-color: var(--app-primary-strong);
}

.btn-muted {
  background: #f7faff;
  color: #334155;
  border-color: #c7d4e8;
}

.btn-muted:hover {
  background: #f1f5fb;
  border-color: #bccbdf;
}

.btn-danger {
  background: linear-gradient(180deg, #e63636 0%, #dc2626 100%);
  color: #ffffff;
  border-color: #dc2626;
  box-shadow: 0 8px 16px rgba(220, 38, 38, 0.22);
}

.btn-danger:hover {
  background: #b91c1c;
  border-color: #b91c1c;
}

.btn-block {
  width: 100%;
}

.btn:hover {
  border-color: #b7c8df;
}

.btn:active {
  transform: translateY(1px);
}

.btn:focus-visible,
.icon-btn:focus-visible,
.rubick .topbar-search-pill:focus-visible,
.rubick .topbar-icon-button:focus-visible,
.rubick .side-menu-user-action-btn:focus-visible,
.rubick .mobile-menu-toggle:focus-visible {
  outline: none;
  box-shadow: var(--btn-focus-ring);
}

.btn:disabled,
.btn[disabled],
.btn[aria-disabled="true"] {
  opacity: 0.55;
  cursor: not-allowed;
  box-shadow: none;
}

.flash {
  display: flex;
  align-items: flex-start;
  gap: 0.56rem;
  border-radius: 12px;
  border: 1px solid;
  padding: 0.86rem 1rem;
  font-size: 0.87rem;
  line-height: 1.45;
  opacity: 1;
  transform: translateY(0);
  transition: opacity 0.28s ease, transform 0.28s ease, margin 0.28s ease, padding 0.28s ease;
}

.flash.is-dismissing {
  opacity: 0;
  transform: translateY(-4px);
  margin-top: 0;
  margin-bottom: 0;
  padding-top: 0;
  padding-bottom: 0;
  pointer-events: none;
}

.flash-stack {
  display: flex;
  flex-direction: column;
  gap: 0.62rem;
  margin-bottom: 0.92rem;
}

.flash-stack:empty {
  display: none;
}

.flash-icon {
  width: 1.1rem;
  height: 1.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.08rem;
}

.flash-icon i {
  width: 1rem;
  height: 1rem;
}

.flash.success {
  background: var(--app-success-bg);
  border-color: var(--app-success-border);
  color: #14532d;
}

.flash.error {
  background: var(--app-danger-bg);
  border-color: var(--app-danger-border);
  color: #881337;
}

.flash.info {
  background: var(--app-info-bg);
  border-color: var(--app-info-border);
  color: #1e3a8a;
}

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

.table-controls {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.65rem;
  flex-wrap: wrap;
  margin-bottom: 0.62rem;
}

.table-controls-left,
.table-controls-right {
  display: flex;
  align-items: flex-end;
  gap: 0.6rem;
  flex-wrap: wrap;
}

.table-control-label {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
  font-size: 0.75rem;
  color: #334155;
  font-weight: 600;
}

.table-control-label .control {
  min-width: 190px;
}

.table-control-inline .control {
  min-width: 90px;
}

.app-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 760px;
}

.app-table th,
.app-table td {
  padding: 0.76rem 0.84rem;
  border-bottom: 1px solid #e7eefb;
  text-align: left;
  vertical-align: middle;
  font-size: 0.85rem;
}

.app-table th {
  background: #f8fbff;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 0.76rem;
  color: #4a5c79;
}

.app-table th.is-sortable {
  user-select: none;
  position: relative;
  padding-right: 1.4rem;
}

.app-table th.is-sortable::after {
  content: "↕";
  position: absolute;
  right: 0.45rem;
  top: 50%;
  transform: translateY(-50%);
  color: #8fa3c5;
  font-size: 0.72rem;
}

.app-table th.is-sort-asc::after {
  content: "↑";
  color: #3158b8;
}

.app-table th.is-sort-desc::after {
  content: "↓";
  color: #3158b8;
}

.app-table tr:hover td {
  background: #f8fbff;
}

.table-wrap-data-list {
  overflow: auto;
}

.table-data-list {
  border-collapse: separate;
  border-spacing: 0 0.82rem;
  width: 100%;
  table-layout: fixed;
  margin-top: -0.15rem;
}

.table-data-list thead th {
  border: 0;
  background: transparent;
  color: #64748b;
  font-size: 0.69rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 0.28rem 0.92rem 0.52rem;
}

.table-data-list tbody tr {
  box-shadow: none;
}

.table-data-list tbody td.data-list-cell {
  border-top: 1px solid #d8e2f0;
  border-bottom: 1px solid #d8e2f0;
  border-left: 0;
  border-right: 0;
  background: #ffffff;
  padding: 0.9rem 1.02rem;
  box-shadow: none;
  vertical-align: middle;
}

.table-data-list tbody td.data-list-cell:first-child {
  border-left: 1px solid #d8e2f0;
  border-top-left-radius: 0.95rem;
  border-bottom-left-radius: 0.95rem;
}

.table-data-list tbody td.data-list-cell:last-child {
  border-right: 1px solid #d8e2f0;
  border-top-right-radius: 0.95rem;
  border-bottom-right-radius: 0.95rem;
}

.table-data-list tbody td.row-check-cell.data-list-cell {
  width: 3rem;
  min-width: 3rem;
  padding-left: 0.75rem;
  padding-right: 0.35rem;
}

.table-data-list thead th.actions-cell {
  padding-right: 1.3rem;
}

.table-data-list tbody td.actions-cell.data-list-cell {
  padding-left: 0.6rem;
  padding-right: 1.3rem;
}

.table-data-list tbody tr:hover td.data-list-cell {
  background: #f9fbff;
}

.table-data-list .data-list-title {
  font-weight: 600;
  color: #1f2a44;
  white-space: normal;
  overflow-wrap: anywhere;
}

.table-data-list .table-subline {
  margin-top: 0.3rem;
  font-size: 0.82rem;
}

.table-data-list .text-center {
  text-align: center;
}

.table-data-list .text-right,
.app-table .text-right {
  text-align: right;
}

.app-table[data-table-id="counterpartiesTable"] .counterparties-col-name {
  width: 30%;
}

.app-table[data-table-id="counterpartiesTable"] .counterparties-col-engagements {
  width: 8.6rem;
  text-align: center;
  white-space: nowrap;
}

.app-table[data-table-id="counterpartiesTable"] thead th.actions-cell,
.app-table[data-table-id="counterpartiesTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="counterpartiesTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="adminsTable"] thead th.actions-cell,
.app-table[data-table-id="adminsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="adminsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="rbacTable"] thead th.actions-cell,
.app-table[data-table-id="rbacTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="rbacTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="zevsTable"] thead th.actions-cell,
.app-table[data-table-id="zevsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="zevsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="ownersTable"] thead th.actions-cell,
.app-table[data-table-id="ownersTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="ownersTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="unitsTable"] thead th.actions-cell,
.app-table[data-table-id="unitsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="unitsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="invoicesTable"] thead th.actions-cell,
.app-table[data-table-id="invoicesTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="invoicesTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="paymentsTable"] thead th.actions-cell,
.app-table[data-table-id="paymentsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="paymentsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="supplierPayoutsTable"] thead th.actions-cell,
.app-table[data-table-id="supplierPayoutsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="supplierPayoutsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="bankAccountsTable"] thead th.actions-cell,
.app-table[data-table-id="bankAccountsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="bankAccountsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="bankLedgerTable"] thead th.actions-cell,
.app-table[data-table-id="bankLedgerTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="bankLedgerTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="zevCounterpartiesTable"] thead th.actions-cell,
.app-table[data-table-id="zevCounterpartiesTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="zevCounterpartiesTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="heatingCostsTable"] thead th.actions-cell,
.app-table[data-table-id="heatingCostsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="heatingCostsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="issuesTable"] thead th.actions-cell,
.app-table[data-table-id="issuesTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="issuesTable"] .actions-cell .table-actions {
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.34rem;
}

.app-table[data-table-id="heatingRequestsTable"] thead th.actions-cell,
.app-table[data-table-id="heatingRequestsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="heatingRequestsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="investmentsTable"] thead th.actions-cell,
.app-table[data-table-id="investmentsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="investmentsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="tariffsTable"] thead th.actions-cell,
.app-table[data-table-id="tariffsTable"] tbody td.actions-cell {
  text-align: center;
}

.app-table[data-table-id="tariffsTable"] .actions-cell .table-actions {
  justify-content: center;
}

.app-table[data-table-id="issuesTable"] .actions-cell .table-actions form {
  display: inline-flex;
  margin: 0;
}

.app-table[data-table-id="issuesTable"] .actions-cell .icon-btn,
.app-table[data-table-id="issuesTable"] .actions-cell .btn {
  flex: 0 0 auto;
}

.app-table[data-table-id="issuesTable"] {
  table-layout: fixed;
}

.app-table[data-table-id="issuesTable"] .issues-col-ticket {
  width: 11.5rem;
}

.app-table[data-table-id="issuesTable"] .issues-col-issue {
  width: 24%;
}

.app-table[data-table-id="issuesTable"] .issues-col-context {
  width: 16%;
}

.app-table[data-table-id="issuesTable"] .issues-col-work {
  width: 24%;
}

.app-table[data-table-id="issuesTable"] .issues-col-actions {
  width: 16.5rem;
}

.app-table[data-table-id="issuesTable"] td {
  vertical-align: top;
}

.issue-text-wrap {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word;
  max-width: 100%;
}

.app-table[data-table-id="unitsTable"] th.units-col-number,
.app-table[data-table-id="unitsTable"] td.units-col-number {
  width: 6.2rem;
  white-space: nowrap;
}

.owner-status-list {
  display: inline-flex;
  flex-direction: column;
  gap: 0.32rem;
}

.owner-property-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.28rem 0.58rem;
}

.owner-cell-name {
  font-weight: 600;
}

.owner-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
}

.owner-tag {
  display: inline-block;
  padding: 0.12rem 0.42rem;
  border-radius: 0.35rem;
  font-size: 0.7rem;
  font-weight: 600;
  line-height: 1.4;
  background: color-mix(in oklch, var(--color-foreground), transparent 90%);
  color: color-mix(in oklch, var(--color-foreground), transparent 20%);
}

.owner-tag--alt {
  background: color-mix(in oklch, #8b5cf6, transparent 85%);
  color: #6d28d9;
}

.owner-tag--info {
  background: color-mix(in oklch, #3b82f6, transparent 85%);
  color: #1d4ed8;
}

.owner-tag--warn {
  background: color-mix(in oklch, #f59e0b, transparent 82%);
  color: #92400e;
}

.dark .owner-tag {
  background: color-mix(in oklch, var(--color-foreground), transparent 82%);
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.dark .owner-tag--alt {
  background: color-mix(in oklch, #8b5cf6, transparent 75%);
  color: color-mix(in oklch, #c4b5fd, white 10%);
}

.dark .owner-tag--info {
  background: color-mix(in oklch, #3b82f6, transparent 75%);
  color: color-mix(in oklch, #93c5fd, white 10%);
}

.dark .owner-tag--warn {
  background: color-mix(in oklch, #f59e0b, transparent 75%);
  color: color-mix(in oklch, #fde68a, white 10%);
}

.owner-profile-hero {
  position: relative;
  overflow: hidden;
}

.owner-profile-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 12% 18%, color-mix(in oklch, var(--color-primary), transparent 88%) 0%, transparent 44%);
}

.owner-profile-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.owner-profile-ident {
  display: flex;
  align-items: center;
  gap: 0.86rem;
  min-width: 0;
}

.owner-profile-mark {
  width: 3.1rem;
  height: 3.1rem;
  border-radius: 0.92rem;
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 66%);
  background: linear-gradient(160deg, color-mix(in oklch, var(--color-primary), transparent 84%) 0%, color-mix(in oklch, var(--color-background), var(--color-primary) 16%) 100%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.08rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: color-mix(in oklch, var(--color-primary), black 8%);
  flex: 0 0 auto;
}

.owner-profile-kicker {
  margin: 0;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #5f7394;
}

.owner-profile-title {
  margin-top: 0.18rem;
}

.owner-profile-chips {
  margin-top: 0.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.44rem;
}

.owner-profile-actions {
  display: inline-flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 0.48rem;
}

.owner-profile-properties {
  position: relative;
  z-index: 1;
  margin-top: 0.84rem;
}

.owner-profile-properties-title {
  margin: 0 0 0.44rem;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #5b6d8b;
}

.owner-profile-property-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.34rem 0.65rem;
}

.owner-profile-property-item {
  align-items: flex-start;
  flex-wrap: wrap;
}

.owner-profile-property-meta {
  color: #607392;
  font-size: 0.74rem;
  margin-left: 0.15rem;
  overflow-wrap: anywhere;
}

.owner-profile-property-units {
  width: 100%;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.36rem;
  margin-left: 1.5rem;
  margin-top: 0.2rem;
}

.owner-profile-property-chip {
  display: inline-flex;
  align-items: center;
  min-height: 1.6rem;
  border-radius: var(--btn-radius);
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  padding: 0 0.58rem;
  font-size: 0.74rem;
  font-weight: 600;
  color: #435776;
}

.owner-metrics-grid {
  align-items: stretch;
  gap: 0.85rem;
}

.owner-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 9.1rem;
  padding-top: 0.92rem;
  padding-bottom: 0.92rem;
}

.owner-metric-card .metric-label {
  margin: 0;
}

.owner-metric-card .metric-value {
  margin: 0;
  line-height: 1.1;
  font-size: clamp(1.2rem, 1.05rem + 0.42vw, 1.46rem);
}

.owner-metric-card .metric-note {
  margin: 0;
  font-size: 0.75rem;
  line-height: 1.25;
  max-width: 34ch;
  color: #5f7290;
}

.owner-metric-card .metric-label-with-icon {
  justify-content: center;
}

.metric-label-with-icon {
  display: inline-flex;
  align-items: center;
  gap: 0.42rem;
}

.metric-label-with-icon span {
  line-height: 1;
}

.metric-label-with-icon i {
  width: 1rem;
  height: 1rem;
  stroke-width: 1.8;
  color: #5e7395;
  flex-shrink: 0;
}

.owner-status-item {
  display: inline-flex;
  align-items: center;
  gap: 0.46rem;
  font-size: 0.8rem;
  color: #4f627f;
}

.owner-status-item input[type="checkbox"]:disabled {
  opacity: 1;
  cursor: default;
}

.owner-status-true {
  color: #15803d;
  font-weight: 600;
}

.owner-status-false {
  color: #b91c1c;
  font-weight: 600;
}

.dark .rubick .owner-status-true {
  color: color-mix(in oklch, #22c55e, white 18%);
}

.dark .rubick .owner-status-false {
  color: color-mix(in oklch, #ef4444, white 12%);
}

.dark .rubick .owner-profile-kicker,
.dark .rubick .owner-profile-properties-title,
.dark .rubick .owner-profile-property-meta,
.dark .rubick .owner-metric-card .metric-note {
  color: color-mix(in oklch, var(--color-foreground), transparent 34%);
}

.dark .rubick .metric-label-with-icon i {
  color: color-mix(in oklch, var(--color-foreground), transparent 32%);
}

.dark .rubick .owner-profile-property-chip {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 78%);
  background: color-mix(in oklch, var(--color-primary), transparent 92%);
  color: color-mix(in oklch, var(--color-foreground), transparent 14%);
}

.dark .rubick .owner-profile-mark {
  border-color: color-mix(in oklch, var(--color-primary), transparent 56%);
  background: linear-gradient(160deg, color-mix(in oklch, var(--color-primary), transparent 80%) 0%, color-mix(in oklch, var(--color-background), var(--color-primary) 26%) 100%);
  color: color-mix(in oklch, var(--color-foreground), transparent 2%);
}

.table-banks-list {
  min-width: 1120px;
}

.table-banks-list .actions-cell {
  min-width: 220px;
}

.table-banks-list .table-actions {
  flex-wrap: nowrap;
  justify-content: center;
}

.table-banks-list thead th.actions-cell,
.table-banks-list tbody td.actions-cell.data-list-cell {
  text-align: center;
  padding-left: 1rem;
  padding-right: 1rem;
}

.table-rbac-list {
  min-width: 980px;
}

.table-rbac-list .actions-cell {
  min-width: 220px;
}

.table-rbac-list .table-actions {
  flex-wrap: nowrap;
  justify-content: flex-end;
}

.rbac-scope-badge {
  min-width: 5.85rem;
  text-align: center;
  letter-spacing: 0.03em;
}

.rbac-scope-badge.scope-global {
  border-color: #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
}

.rbac-scope-badge.scope-agency {
  border-color: #c4b5fd;
  background: #f5f3ff;
  color: #6d28d9;
}

.rbac-scope-badge.scope-zev {
  border-color: #93c5fd;
  background: #eef8ff;
  color: #1e40af;
}

.rbac-scope-badge.scope-portal {
  border-color: #99f6e4;
  background: #ecfeff;
  color: #0f766e;
}

.actions-cell {
  text-align: right;
}

.table-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 0.45rem;
}

.table-actions .btn,
.table-actions .icon-btn {
  min-height: var(--btn-height);
}

.table-actions-center {
  justify-content: center;
}

.table-actions form {
  margin: 0;
}

.table-actions-uniform .btn,
.table-actions-uniform .icon-btn {
  min-width: 6.4rem;
  justify-content: center;
}

.table-subline {
  margin-top: 0.2rem;
  color: #64748b;
  font-size: 0.75rem;
}

.icon-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--btn-gap);
  min-height: var(--btn-height);
  border: 1px solid #c7d4e8;
  background: #f7faff;
  border-radius: var(--btn-radius);
  padding: 0 calc(var(--btn-padding-inline) - 0.08rem);
  font-size: var(--btn-font-size);
  font-weight: 600;
  line-height: 1.05;
  text-decoration: none;
  color: #334155;
  cursor: pointer;
  box-shadow: var(--btn-shadow-soft);
  vertical-align: middle;
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.icon-btn:hover {
  background: #f1f5fb;
  border-color: #bccbdf;
}

.icon-btn-primary {
  background: linear-gradient(180deg, #1f4fc9 0%, var(--app-primary) 100%);
  border-color: var(--app-primary);
  color: #ffffff;
  box-shadow: 0 8px 16px rgba(30, 58, 138, 0.25);
}

.icon-btn-primary:hover {
  background: linear-gradient(180deg, #2458dc 0%, var(--app-primary-strong) 100%);
  border-color: var(--app-primary-strong);
}

.icon-btn-danger {
  background: linear-gradient(180deg, #e63636 0%, #dc2626 100%);
  color: #ffffff;
  border-color: #dc2626;
  box-shadow: 0 8px 16px rgba(220, 38, 38, 0.22);
}

.icon-btn-danger:hover {
  background: #b91c1c;
  border-color: #b91c1c;
}

.icon-btn i {
  width: var(--btn-icon-size);
  height: var(--btn-icon-size);
  stroke-width: 1.8;
  flex-shrink: 0;
}

.icon-btn > span {
  display: inline-flex;
  align-items: center;
}

.row-check-cell {
  width: 44px;
  text-align: center;
}

.rubick input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 1.02rem;
  height: 1.02rem;
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 72%);
  border-radius: 0.28rem;
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  box-shadow: inset 0 1px 0 color-mix(in oklch, var(--color-foreground), transparent 94%);
  display: inline-grid;
  place-content: center;
  flex-shrink: 0;
  margin: 0;
  cursor: pointer;
  transition: background-color 0.14s ease, border-color 0.14s ease, box-shadow 0.14s ease, transform 0.08s ease;
}

.rubick input[type="checkbox"]::before {
  content: "";
  width: 0.58rem;
  height: 0.58rem;
  transform: scale(0);
  transition: transform 0.12s ease;
  clip-path: polygon(14% 52%, 0 66%, 40% 100%, 100% 24%, 86% 10%, 40% 70%);
  background: #ffffff;
}

.rubick input[type="checkbox"]:checked {
  background: var(--color-primary);
  border-color: var(--color-primary);
  box-shadow: 0 6px 12px color-mix(in oklch, var(--color-primary), transparent 82%);
}

.rubick input[type="checkbox"]:checked::before {
  transform: scale(1);
}

.rubick input[type="checkbox"]:focus-visible {
  outline: none;
  box-shadow: var(--btn-focus-ring);
}

.rubick input[type="checkbox"]:disabled {
  opacity: 0.58;
  cursor: not-allowed;
}

.row-check-cell input[type="checkbox"] {
  margin-inline: auto;
}

.bulk-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.bulk-count {
  font-size: 0.75rem;
  color: #51617d;
}

.table-footer {
  margin-top: 0.62rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.7rem;
  flex-wrap: wrap;
}

.table-footer-info {
  font-size: 0.8rem;
  color: #51617d;
}

.table-pagination {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.table-page-label {
  min-width: 96px;
  text-align: center;
  font-size: 0.8rem;
  color: #334155;
}

.badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: var(--btn-height);
  border-radius: var(--btn-radius);
  padding: 0 var(--btn-padding-inline);
  font-size: var(--btn-font-size);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  border: 1px solid;
  white-space: nowrap;
}

.badge.active {
  color: #166534;
  background: #ecfdf5;
  border-color: #86efac;
}

.badge.inactive {
  color: #991b1b;
  background: #fff1f2;
  border-color: #fecdd3;
}

.badge.neutral {
  color: #1e3a8a;
  background: #eff6ff;
  border-color: #bfdbfe;
}

.badge.status-issued {
  color: #1e3a8a;
  background: #eff6ff;
  border-color: #bfdbfe;
}

.badge.status-paid {
  color: #166534;
  background: #ecfdf5;
  border-color: #86efac;
}

.badge.status-overdue {
  color: #991b1b;
  background: #fff1f2;
  border-color: #fecdd3;
}

.badge.status-cancelled {
  color: #475569;
  background: #f8fafc;
  border-color: #cbd5e1;
}

.form-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.78rem;
}

.form-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.78rem;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
}

.checkbox-line {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.84rem;
  color: #334155;
}

.checkbox-line input[type="checkbox"] {
  margin: 0;
}

.check-row {
  display: inline-flex;
  align-items: center;
  gap: 0.52rem;
  font-size: 0.9rem;
  color: color-mix(in oklch, var(--color-foreground), transparent 12%);
  cursor: pointer;
  user-select: none;
}

.check-row input[type="checkbox"] {
  margin: 0;
}

.unit-business-block {
  margin-top: -0.22rem;
}

.unit-heating-block {
  margin-top: -0.22rem;
}

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.72rem;
  margin-bottom: 0.8rem;
}

.kpi-card {
  border: 1px solid #dbe6f6;
  border-radius: 12px;
  padding: 0.78rem;
  background: #fbfdff;
}

.kpi-card h3 {
  margin: 0 0 0.35rem;
  font-size: 0.78rem;
  color: #4a5c79;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.kpi-card strong {
  display: block;
  font-size: 1.1rem;
  color: #1e293b;
}

.kpi-card p {
  margin: 0.38rem 0 0;
  font-size: 0.77rem;
  color: #64748b;
  line-height: 1.35;
}

.heating-kpi-grid {
  gap: 0.85rem;
}

.heating-kpi-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 8.6rem;
  background:
    radial-gradient(circle at 14% 10%, color-mix(in oklch, var(--color-primary), transparent 90%) 0%, transparent 42%),
    linear-gradient(180deg, color-mix(in oklch, var(--color-background), white 36%) 0%, color-mix(in oklch, var(--color-background), var(--color-foreground) 2%) 100%);
}

.heating-kpi-card h3 {
  margin: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
}

.heating-kpi-card h3 i {
  width: 0.95rem;
  height: 0.95rem;
  stroke-width: 1.8;
}

.heating-kpi-card strong,
.heating-kpi-card p {
  margin: 0;
}

.label {
  font-size: 0.79rem;
  color: #334155;
  font-weight: 500;
}

.control,
select.control,
textarea.control {
  width: 100%;
  border: 1px solid #cbd5e1;
  background: #ffffff;
  border-radius: 10px;
  padding: 0.56rem 0.7rem;
  font-size: 0.86rem;
  color: #0f172a;
}

.control:focus,
select.control:focus,
textarea.control:focus {
  outline: none;
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16);
}

.control::placeholder {
  color: #94a3b8;
}

.ts-wrapper {
  width: 100%;
}

.ts-wrapper .ts-control {
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  min-height: 38px;
  box-shadow: none;
  padding: 0.32rem 0.7rem;
  font-size: 0.86rem;
  background: #ffffff;
  color: #0f172a;
}

.ts-wrapper .ts-control > input {
  font-size: 0.86rem;
}

.ts-wrapper.single .ts-control::after {
  border-color: #64748b transparent transparent transparent;
  right: 10px;
}

.ts-wrapper.single.dropdown-active .ts-control::after {
  border-color: transparent transparent #64748b transparent;
}

.ts-wrapper.focus .ts-control {
  outline: none;
  border-color: #3b82f6;
  box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.16);
}

.ts-wrapper.disabled .ts-control {
  background: #f8fafc;
  color: #94a3b8;
}

.ts-dropdown {
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  z-index: 70;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.14);
}

.ts-dropdown .option {
  font-size: 0.84rem;
  padding: 0.42rem 0.7rem;
}

.ts-dropdown .active {
  background: #eff6ff;
  color: #1e3a8a;
}

.modal-backdrop {
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  z-index: 80;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
  background: rgba(15, 23, 42, 0.62);
}

[data-modal].is-open {
  display: flex;
}

.modal-panel {
  width: min(840px, 95vw);
  max-height: 88vh;
  overflow: auto;
  border-radius: 16px;
  border: 1px solid var(--app-border);
  background: #ffffff;
  box-shadow: 0 24px 54px rgba(15, 23, 42, 0.26);
  padding: 1rem;
}

.modal-panel-md {
  width: min(640px, 95vw);
}

.modal-panel-lg {
  width: min(930px, 95vw);
}

@media (min-width: 1024px) {
  .rubick .modal-backdrop {
    left: var(--rubick-sidebar-width);
    width: calc(100vw - var(--rubick-sidebar-width));
  }
}

@media (max-width: 1023px) {
  .rubick .modal-backdrop {
    left: 0;
    width: 100vw;
  }
}

.json-preview {
  margin: 0.36rem 0 0;
  border: 1px solid #d7e3f4;
  border-radius: 10px;
  background: #f8fbff;
  padding: 0.62rem;
  max-height: 240px;
  overflow: auto;
  font-size: 0.75rem;
  line-height: 1.45;
  color: #1f2937;
}

.modal-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.75rem;
  margin-bottom: 0.78rem;
}

.modal-title {
  margin: 0;
  font-size: 1.02rem;
  font-weight: 700;
}

.modal-actions {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 0.48rem;
  margin-top: 0.82rem;
}

.checkbox-grid {
  max-height: 55vh;
  overflow-y: auto;
  border: 1px solid #dbe6f7;
  border-radius: 12px;
  background: #fbfdff;
  padding: 0.62rem;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.5rem;
}

.checkbox-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  border-radius: 10px;
  padding: 0.48rem 0.54rem;
}

.checkbox-item:hover {
  background: #eef5ff;
}

.checkbox-item input {
  margin: 0;
}

.check-title {
  font-size: 0.82rem;
  font-weight: 600;
}

.check-subtitle {
  margin-top: 0.14rem;
  font-size: 0.74rem;
  color: #5b6a82;
}

.modal-rbac-editor {
  width: min(1080px, 96vw);
}

.rbac-editor-toolbar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.rbac-editor-summary {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}

.rbac-editor-count {
  font-size: 0.8rem;
  color: #5a6c8a;
}

.rbac-editor-search {
  margin: 0;
  min-width: min(100%, 22rem);
}

.rbac-editor-search .control {
  min-width: 0;
}

.rbac-permission-groups {
  max-height: 56vh;
  overflow-y: auto;
  border: 1px solid #dbe6f7;
  border-radius: 12px;
  background: #fbfdff;
  padding: 0.66rem;
  display: flex;
  flex-direction: column;
  gap: 0.62rem;
}

.rbac-permission-group {
  border: 1px solid #dce7f8;
  border-radius: 11px;
  background: #ffffff;
  padding: 0.58rem;
}

.rbac-permission-group-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  margin-bottom: 0.48rem;
}

.rbac-permission-group-head h4 {
  margin: 0;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #4a5c79;
}

.rbac-permission-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.42rem 0.5rem;
}

.rbac-permission-item {
  display: flex;
  align-items: flex-start;
  gap: 0.5rem;
  border-radius: 10px;
  border: 1px solid transparent;
  background: #f8fbff;
  padding: 0.48rem 0.54rem;
  transition: border-color 0.16s ease, background-color 0.16s ease;
}

.rbac-permission-item:hover {
  border-color: #cfdcf2;
  background: #eff5ff;
}

.rbac-permission-item input {
  margin-top: 0.12rem;
}

.rbac-permission-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
}

.rbac-permission-copy .check-title {
  overflow-wrap: anywhere;
}

.rbac-permission-item[hidden],
.rbac-permission-group[hidden] {
  display: none !important;
}

.modal-rbac-editor .modal-actions {
  position: sticky;
  bottom: -1rem;
  padding-top: 0.72rem;
  padding-bottom: 0.72rem;
  margin-top: 0.62rem;
  border-top: 1px solid #dbe6f7;
  background: #ffffff;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

.metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.75rem;
}

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

.metric-card {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.metric-label {
  margin: 0;
  font-size: 0.77rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: #5a6c8a;
}

.metric-value {
  margin: 0.32rem 0 0;
  font-size: 1.25rem;
  font-weight: 700;
}

.metric-note {
  margin: 0.38rem 0 0;
  color: #64748b;
  font-size: 0.78rem;
}

.billing-metrics-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

.billing-hero-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  margin-bottom: 0.7rem;
}

.billing-hero-title {
  font-size: 1.02rem;
  letter-spacing: 0.01em;
}

.billing-filter-shell {
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 84%);
  border-radius: 1rem;
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  padding: 0.72rem 0.8rem;
}

.billing-filter-form {
  align-items: flex-end;
  gap: 0.7rem;
  flex-wrap: nowrap;
}

.billing-period-group {
  min-width: 0;
  flex: 1 1 auto;
}

.billing-filter-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  flex: 0 0 auto;
}

.billing-filter-actions .btn,
.billing-filter-actions a.btn {
  min-width: 8.4rem;
}

.billing-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.62rem;
  min-height: 8.9rem;
  padding-top: 0.96rem;
  padding-bottom: 0.96rem;
  text-align: center;
  background:
    radial-gradient(circle at 14% 10%, color-mix(in oklch, var(--color-primary), transparent 90%) 0%, transparent 40%),
    linear-gradient(180deg, color-mix(in oklch, var(--color-background), white 36%) 0%, color-mix(in oklch, var(--color-background), var(--color-foreground) 2%) 100%);
}

.billing-metric-head {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.46rem;
}

.billing-metric-icon {
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 0.6rem;
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 72%);
  background: color-mix(in oklch, var(--color-primary), white 90%);
  color: color-mix(in oklch, var(--color-primary), black 9%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.billing-metric-icon i {
  width: 0.96rem;
  height: 0.96rem;
  stroke-width: 1.8;
}

.billing-metric-head .metric-label {
  margin: 0;
}

.billing-metric-value {
  margin: 0;
  line-height: 1.08;
  font-size: clamp(1.6rem, 1.35rem + 0.45vw, 1.95rem);
}

.billing-metric-card .metric-note {
  margin: 0;
  max-width: 34ch;
}

.payments-hero-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  margin-bottom: 0.7rem;
}

.payments-hero-title {
  font-size: 1.02rem;
  letter-spacing: 0.01em;
}

.payments-filter-form {
  align-items: flex-end;
  gap: 0.7rem;
}

.payments-owner-filter-group {
  min-width: min(420px, 100%);
  flex: 1 1 auto;
}

.payments-filter-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.payments-filter-actions .btn,
.payments-filter-actions a.btn {
  min-width: 8.2rem;
}

.payments-metrics-grid {
  gap: 0.85rem;
}

.payments-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 8.4rem;
  background:
    radial-gradient(circle at 14% 10%, color-mix(in oklch, var(--color-primary), transparent 90%) 0%, transparent 42%),
    linear-gradient(180deg, color-mix(in oklch, var(--color-background), white 36%) 0%, color-mix(in oklch, var(--color-background), var(--color-foreground) 2%) 100%);
}

.payments-metric-head {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.44rem;
}

.payments-metric-icon {
  width: 1.66rem;
  height: 1.66rem;
  border-radius: 0.58rem;
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 72%);
  background: color-mix(in oklch, var(--color-primary), white 90%);
  color: color-mix(in oklch, var(--color-primary), black 9%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.payments-metric-icon i {
  width: 0.92rem;
  height: 0.92rem;
  stroke-width: 1.8;
}

.payments-metric-card .metric-value {
  margin: 0;
}

.payouts-hero-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  margin-bottom: 0.7rem;
}

.payouts-hero-title {
  font-size: 1.02rem;
  letter-spacing: 0.01em;
}

.payouts-filter-form {
  align-items: flex-end;
  gap: 0.7rem;
}

.payouts-status-filter-group {
  min-width: min(360px, 100%);
  flex: 1 1 auto;
}

.payouts-filter-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

.payouts-filter-actions .btn,
.payouts-filter-actions a.btn {
  min-width: 8.2rem;
}

.payouts-metrics-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.85rem;
}

.payouts-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 8.5rem;
  background:
    radial-gradient(circle at 14% 10%, color-mix(in oklch, var(--color-primary), transparent 90%) 0%, transparent 42%),
    linear-gradient(180deg, color-mix(in oklch, var(--color-background), white 36%) 0%, color-mix(in oklch, var(--color-background), var(--color-foreground) 2%) 100%);
}

.payouts-metric-head {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.44rem;
}

.payouts-metric-icon {
  width: 1.66rem;
  height: 1.66rem;
  border-radius: 0.58rem;
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 72%);
  background: color-mix(in oklch, var(--color-primary), white 90%);
  color: color-mix(in oklch, var(--color-primary), black 9%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.payouts-metric-icon i {
  width: 0.92rem;
  height: 0.92rem;
  stroke-width: 1.8;
}

.payouts-metric-card .metric-value {
  margin: 0;
}

.bank-ledger-section .section-head {
  margin-bottom: 0.8rem;
}

.bank-ledger-toolbar {
  display: inline-flex;
  align-items: flex-end;
  gap: 0.65rem;
  flex-wrap: wrap;
}

.bank-ledger-filter-form {
  align-items: flex-end;
  gap: 0.58rem;
  margin: 0;
}

.bank-ledger-date-group {
  min-width: 12.4rem;
}

.bank-ledger-filter-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.bank-ledger-opening-note {
  margin-top: -0.15rem;
  margin-bottom: 0.75rem;
}

.bank-ledger-metrics {
  margin-bottom: 0.9rem;
  gap: 0.85rem;
}

.bank-ledger-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 8.4rem;
  background:
    radial-gradient(circle at 14% 10%, color-mix(in oklch, var(--color-primary), transparent 90%) 0%, transparent 42%),
    linear-gradient(180deg, color-mix(in oklch, var(--color-background), white 36%) 0%, color-mix(in oklch, var(--color-background), var(--color-foreground) 2%) 100%);
}

.bank-ledger-metric-head {
  justify-content: center;
}

.dashboard-metrics-grid {
  gap: 0.85rem;
}

.dashboard-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 8.6rem;
}

.dashboard-metric-card .metric-label-with-icon {
  justify-content: center;
}

.dashboard-metric-card .metric-value {
  margin: 0;
}

.dashboard-metric-card .metric-note {
  margin: 0;
  max-width: 34ch;
}

.counterparty-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 8.5rem;
}

.counterparty-metric-card .metric-label-with-icon {
  justify-content: center;
}

.counterparty-metric-card .metric-value {
  margin: 0;
}

.finance-hero-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.9rem;
  margin-bottom: 0.7rem;
}

.finance-hero-title {
  font-size: 1.02rem;
  letter-spacing: 0.01em;
}

.finance-metrics-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.85rem;
}

.finance-metric-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: 0.56rem;
  min-height: 8.5rem;
  background:
    radial-gradient(circle at 14% 10%, color-mix(in oklch, var(--color-primary), transparent 90%) 0%, transparent 42%),
    linear-gradient(180deg, color-mix(in oklch, var(--color-background), white 36%) 0%, color-mix(in oklch, var(--color-background), var(--color-foreground) 2%) 100%);
}

.finance-metric-head {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.44rem;
}

.finance-metric-icon {
  width: 1.66rem;
  height: 1.66rem;
  border-radius: 0.58rem;
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 72%);
  background: color-mix(in oklch, var(--color-primary), white 90%);
  color: color-mix(in oklch, var(--color-primary), black 9%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.finance-metric-icon i {
  width: 0.92rem;
  height: 0.92rem;
  stroke-width: 1.8;
}

.finance-metric-card .metric-value {
  margin: 0;
}

.changelog-stack {
  display: grid;
  gap: 0.95rem;
}

.changelog-entry {
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 88%);
  border-radius: 1rem;
  padding: 0.95rem 1rem;
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
}

.changelog-entry-current {
  border-color: color-mix(in oklch, var(--color-primary), transparent 58%);
  box-shadow: 0 0 0 1px color-mix(in oklch, var(--color-primary), transparent 72%) inset;
}

.changelog-title {
  margin: 0 0 0.5rem;
  font-size: 1rem;
}

.changelog-subtitle {
  margin: 0.68rem 0 0.4rem;
  font-size: 0.9rem;
}

.changelog-text,
.changelog-bullet {
  margin: 0;
  font-size: 0.88rem;
  line-height: 1.5;
}

.changelog-bullet + .changelog-bullet,
.changelog-text + .changelog-text,
.changelog-text + .changelog-bullet,
.changelog-bullet + .changelog-text {
  margin-top: 0.24rem;
}

.changelog-spacer {
  height: 0.45rem;
}

.counterparty-details-summary .inline-form {
  align-items: flex-end;
  margin-bottom: 0.9rem;
}

.counterparty-profile-hero {
  position: relative;
  overflow: hidden;
}

.counterparty-profile-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 12% 18%, color-mix(in oklch, var(--color-primary), transparent 88%) 0%, transparent 42%);
}

.counterparty-profile-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

.counterparty-profile-ident {
  display: flex;
  align-items: center;
  gap: 0.86rem;
  min-width: 0;
}

.counterparty-profile-mark {
  width: 3.2rem;
  height: 3.2rem;
  border-radius: 0.95rem;
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 66%);
  background: linear-gradient(160deg, color-mix(in oklch, var(--color-primary), transparent 84%) 0%, color-mix(in oklch, var(--color-background), var(--color-primary) 16%) 100%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 1.12rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: color-mix(in oklch, var(--color-primary), black 8%);
  flex: 0 0 auto;
}

.counterparty-profile-copy {
  min-width: 0;
}

.counterparty-profile-kicker {
  margin: 0;
  font-size: 0.76rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #5f7394;
}

.counterparty-profile-title {
  margin-top: 0.18rem;
}

.counterparty-profile-chips {
  margin-top: 0.5rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.44rem;
}

.counterparty-profile-grid {
  position: relative;
  z-index: 1;
  margin-top: 0.82rem;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.58rem;
}

.counterparty-hero-meta-item {
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 84%);
  border-radius: 0.72rem;
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  padding: 0.5rem 0.65rem;
  min-width: 0;
}

.counterparty-hero-meta-item-wide {
  grid-column: span 2;
}

.counterparty-hero-meta-label {
  display: block;
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #5b6d8b;
}

.counterparty-hero-meta-value {
  display: block;
  margin-top: 0.16rem;
  font-size: 0.88rem;
  font-weight: 600;
  color: #23324b;
  overflow-wrap: anywhere;
}

.counterparty-details-summary .inline-form .form-group {
  margin-bottom: 0;
}

.counterparty-details-summary .metrics-grid {
  margin-top: 0.28rem;
  margin-bottom: 0.62rem;
}

.counterparty-details-summary .metrics-grid.metrics-grid-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.module-breakdown-card {
  display: flex;
  flex-direction: column;
  gap: 0.52rem;
}

.module-breakdown-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
  font-size: 0.86rem;
  color: #475569;
}

.module-breakdown-row strong {
  font-size: 0.93rem;
  font-weight: 700;
  color: #0f172a;
}

.dashboard-split-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.75rem;
}

.dashboard-mini-table {
  min-width: 0;
}

.dashboard-mini-table th,
.dashboard-mini-table td {
  font-size: 0.82rem;
  padding: 0.62rem 0.7rem;
}

.dashboard-mini-table td .badge {
  white-space: nowrap;
}

.amount-overdue {
  color: #b91c1c !important;
}

.amount-paid {
  color: #047857 !important;
}

.amount-balanced {
  color: #ca8a04 !important;
}

.dashboard-card {
  border: 1px solid #dce7f8;
  border-radius: 14px;
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  text-decoration: none;
  color: inherit;
  padding: 0.95rem;
  display: flex;
  flex-direction: column;
  gap: 0.34rem;
}

.dashboard-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(30, 58, 138, 0.1);
}

.dashboard-card .icon-wrap {
  width: 2.06rem;
  height: 2.06rem;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--app-primary-soft);
  color: var(--app-primary-strong);
}

.dashboard-card .icon-wrap i {
  width: 16px;
  height: 16px;
}

.dashboard-card h3 {
  margin: 0.08rem 0 0;
  font-size: 0.98rem;
}

.dashboard-card p {
  margin: 0;
  font-size: 0.8rem;
  color: #5a6880;
}

.login-shell {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: 1rem;
  position: relative;
  z-index: 2;
}

.login-card {
  width: min(480px, 100%);
  padding: 1.9rem 1.8rem 1.5rem;
}

.login-form {
  margin-top: 0.25rem;
}

.login-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.42rem;
  color: color-mix(in oklch, var(--color-background), transparent 20%);
  margin-bottom: 0.9rem;
  width: 100%;
  text-align: center;
}

.login-brand__logo {
  width: 100px;
  height: 80px;
  flex: 0 0 auto;
  display: block;
  object-fit: contain;
  object-position: left center;
}

.login-brand__text {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  line-height: 40px;
  font-size: 50px;
  font-weight: 100;
  color: #a3a9b4;
  letter-spacing: -0.02em;
  transform: translateX(-20px) translateY(2px);
  white-space: nowrap;
}

.login-title {
  margin: 0;
  font-size: 2.25rem;
  letter-spacing: -0.02em;
  font-weight: 700;
  line-height: 1.05;
}

.login-subtitle {
  margin: 0.5rem 0 1.08rem;
  color: var(--app-muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

.login-footer {
  margin-top: 1.15rem;
  font-size: 0.76rem;
  color: #64748b;
  text-align: center;
}

.login-card .control {
  padding: 0.76rem 0.84rem;
  font-size: 0.9rem;
  border-radius: 14px;
}

.login-card .btn {
  margin-top: 0.16rem;
  padding: 0.78rem 1rem;
  font-size: 0.97rem;
  border-radius: 16px;
}

.dashboard-hero {
  background: linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}

.dashboard-hero-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.9rem;
}

.dashboard-hero-title {
  margin: 0;
  font-size: 1.84rem;
  line-height: 1.05;
  letter-spacing: -0.02em;
}

.dashboard-hero-subtitle {
  margin: 0.4rem 0 0;
  color: var(--app-muted);
  font-size: 0.88rem;
}

.dashboard-role-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.32rem;
}

.dashboard-hero-context-form {
  margin-left: auto;
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
  min-width: min(100%, 44rem);
}

.dashboard-hero-tenant-select {
  min-width: min(100%, 30rem);
}

.dashboard-hero-tenant-submit {
  flex-shrink: 0;
}

.tenant-panel {
  border: 1px solid #e0e9f7;
  border-radius: 12px;
  background: #ffffff;
  padding: 0.7rem;
}

.tenant-panel .label {
  margin-bottom: 0.22rem;
}

.dashboard-section-title {
  display: inline-flex;
  align-items: center;
  gap: 0.46rem;
}

.dashboard-section-title i {
  width: 0.98rem;
  height: 0.98rem;
  color: #3158b8;
}

.empty-state {
  display: flex;
  align-items: flex-start;
  gap: 0.66rem;
  border: 1px dashed #c9d7ef;
  border-radius: 12px;
  background: #f8fbff;
  padding: 1rem;
}

.empty-state h3 {
  margin: 0;
  font-size: 0.94rem;
}

.empty-state p {
  margin: 0.34rem 0 0;
  color: #5b6981;
  font-size: 0.83rem;
}

.empty-state-icon {
  width: 1.7rem;
  height: 1.7rem;
  border-radius: 10px;
  background: #e7f0ff;
  color: #3158b8;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

.empty-state-icon i {
  width: 0.95rem;
  height: 0.95rem;
}

@media (max-width: 1080px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .app-sidebar {
    padding: 0.95rem 0.9rem;
  }

  .app-nav {
    flex-direction: row;
    flex-wrap: wrap;
  }

  .app-nav-title {
    width: 100%;
  }

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

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

  .counterparty-profile-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .owner-profile-property-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-split-grid {
    grid-template-columns: 1fr;
  }

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

  .form-grid-2,
  .form-grid-3,
  .checkbox-grid {
    grid-template-columns: 1fr;
  }

  .rbac-permission-list {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 700px) {
  .app-content {
    padding: 0.9rem 0.72rem 1rem;
  }

  .topbar-card {
    flex-direction: column;
    align-items: flex-start;
  }

  .topbar-actions {
    width: 100%;
    justify-content: space-between;
    gap: 0.55rem;
    flex-wrap: wrap;
  }

  .topbar-profile {
    flex: 1;
    min-width: 220px;
  }

  .app-user-meta {
    text-align: left;
  }

  .topbar-logout-form {
    border-left: 0;
    padding-left: 0;
  }

  .topbar-logout {
    margin-left: auto;
  }

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

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

  .counterparty-profile-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .owner-profile-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .counterparty-profile-grid {
    grid-template-columns: 1fr;
  }

  .owner-profile-property-grid {
    grid-template-columns: 1fr;
  }

  .counterparty-hero-meta-item-wide {
    grid-column: span 1;
  }

  .dashboard-split-grid {
    grid-template-columns: 1fr;
  }

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

  .section-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .section-head > .table-actions,
  .section-head > .bulk-actions {
    width: 100%;
    justify-content: stretch;
  }

  .section-head > .table-actions .btn,
  .section-head > .table-actions a.btn,
  .section-head > .bulk-actions .btn,
  .section-head > .bulk-actions a.btn,
  .section-head > .btn,
  .section-head > a.btn {
    flex: 1 1 100%;
    justify-content: center;
  }

  .bulk-actions {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
  }

  .bulk-actions .btn {
    flex: 1 1 100%;
    justify-content: center;
  }

  .issues-head-actions {
    width: 100%;
    justify-content: stretch;
    flex-wrap: wrap;
    gap: 0.45rem;
  }

  .issues-head-actions .btn {
    flex: 1 1 100%;
    justify-content: center;
  }

  .issues-settings-auto-form {
    width: 100%;
    align-items: stretch;
  }

  .issues-settings-auto-form .check-row {
    width: 100%;
  }

  .issues-settings-auto-form .btn {
    width: 100%;
  }

  .issues-settings-head-actions {
    width: 100%;
    justify-content: stretch;
  }

  .issues-settings-head-actions .btn {
    flex: 1 1 100%;
    justify-content: center;
  }

  .billing-head-actions {
    width: 100%;
    justify-content: stretch;
    flex-wrap: wrap;
    gap: 0.45rem;
  }

  .billing-head-actions .btn {
    flex: 1 1 calc(50% - 0.3rem);
    justify-content: center;
  }

  .billing-hero-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
  }

  .payments-hero-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
  }

  .payouts-hero-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
  }

  .finance-hero-toolbar {
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
  }

  .payments-filter-form {
    width: 100%;
  }

  .payments-filter-actions {
    width: 100%;
  }

  .payments-filter-actions .btn,
  .payments-filter-actions a.btn {
    flex: 1 1 calc(50% - 0.3rem);
    min-width: 0;
  }

  .payouts-filter-form {
    width: 100%;
  }

  .payouts-filter-actions {
    width: 100%;
  }

  .payouts-filter-actions .btn,
  .payouts-filter-actions a.btn {
    flex: 1 1 calc(50% - 0.3rem);
    min-width: 0;
  }

  .bank-ledger-toolbar {
    width: 100%;
    align-items: stretch;
  }

  .bank-ledger-filter-form {
    width: 100%;
    flex-wrap: wrap;
  }

  .bank-ledger-date-group {
    width: 100%;
    min-width: 0;
  }

  .bank-ledger-filter-actions {
    width: 100%;
  }

  .bank-ledger-filter-actions .btn,
  .bank-ledger-filter-actions a.btn {
    flex: 1 1 calc(33.333% - 0.4rem);
    min-width: 0;
  }

  .billing-filter-form {
    width: 100%;
    flex-wrap: wrap;
  }

  .billing-filter-actions {
    width: 100%;
  }

  .billing-filter-actions .btn,
  .billing-filter-actions a.btn {
    flex: 1 1 calc(50% - 0.3rem);
    min-width: 0;
  }

  .app-table .actions-cell {
    text-align: left;
  }

  .app-table .actions-cell .table-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table .actions-cell .icon-btn,
  .app-table .actions-cell .btn {
    flex: 1 1 calc(50% - 0.3rem);
    min-width: 6.4rem;
  }

  .app-table[data-table-id="invoicesTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="invoicesTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="paymentsTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="paymentsTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="supplierPayoutsTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="supplierPayoutsTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="bankAccountsTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="bankAccountsTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="bankLedgerTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="bankLedgerTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="zevCounterpartiesTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="zevCounterpartiesTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="heatingCostsTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="heatingCostsTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="invoicesTable"] .actions-cell .icon-btn,
  .app-table[data-table-id="invoicesTable"] .actions-cell .btn {
    flex: 1 1 calc(50% - 0.3rem);
    min-width: 6.4rem;
  }

  .app-table[data-table-id="issuesTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="issuesTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="issuesTable"] .actions-cell .icon-btn,
  .app-table[data-table-id="issuesTable"] .actions-cell .btn {
    flex: 0 0 auto;
    min-width: 0;
  }

  .app-table[data-table-id="heatingRequestsTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="heatingRequestsTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="investmentsTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="investmentsTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="tariffsTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="tariffsTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="issueTypesTable"] .actions-cell {
    text-align: center;
  }

  .app-table[data-table-id="issueTypesTable"] .actions-cell .table-actions {
    justify-content: center;
    flex-wrap: wrap;
    gap: 0.3rem;
  }

  .app-table[data-table-id="issueTypesTable"] .actions-cell .icon-btn,
  .app-table[data-table-id="issueTypesTable"] .actions-cell .btn {
    flex: 1 1 calc(50% - 0.3rem);
    min-width: 6.6rem;
  }

  .table-controls {
    flex-direction: column;
    align-items: stretch;
  }

  .table-controls-left,
  .table-controls-right {
    width: 100%;
  }

  .table-control-label .control {
    min-width: 100%;
  }

  .login-card {
    padding: 1.35rem 1.1rem 1.15rem;
  }

  .login-title {
    font-size: 1.72rem;
  }

  .dashboard-hero-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .dashboard-role-badges {
    justify-content: flex-start;
  }
}

/* Rubick integration */
body.app-body.rubick {
  --rubick-sidebar-width: 240px;
  --background-image-accent: url('/template-dist/images/accent.svg');
  --background-image-noise: url('/template-dist/images/noise.png');
  background: var(--color-primary);
  color: var(--color-foreground);
  position: relative;
  min-height: 100vh;
  overflow-x: hidden;
}

body.app-body.rubick::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: var(--background-image-noise) repeat;
  opacity: 0.18;
}

body.app-body.rubick::after {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: var(--background-image-accent) no-repeat center center / cover;
  opacity: 0.42;
}

.rubick .app-shell {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: block;
  overflow-x: clip;
}

.rubick .app-sidebar.side-menu {
  position: fixed;
  inset: 0 auto 0 0;
  width: var(--rubick-sidebar-width);
  margin: 0;
  padding: 0;
  z-index: 60;
  overflow: hidden;
  color: var(--color-background);
  background: transparent;
  border: 0;
  box-shadow: none;
}

.rubick .app-sidebar.side-menu::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 16% 100%, rgba(56, 189, 248, 0.32) 0%, rgba(56, 189, 248, 0) 42%),
    radial-gradient(circle at 90% 6%, rgba(99, 102, 241, 0.38) 0%, rgba(99, 102, 241, 0) 34%),
    linear-gradient(170deg, #0f1f58 0%, #112b70 46%, #102864 100%),
    var(--background-image-noise);
  background-blend-mode: screen, screen, normal, overlay;
}

.rubick .close-mobile-menu {
  display: none;
  position: absolute;
  top: 1rem;
  right: 1rem;
  z-index: 35;
  width: 2.2rem;
  height: 2.2rem;
  border-radius: 9999px;
  border: 1px solid color-mix(in oklch, var(--color-background), transparent 70%);
  background: color-mix(in oklch, var(--color-background), transparent 88%);
  color: var(--color-background);
  align-items: center;
  justify-content: center;
  cursor: pointer;
}

.rubick .close-mobile-menu i {
  width: 1rem;
  height: 1rem;
}

.rubick .side-menu__content {
  position: relative;
  z-index: 20;
  width: var(--rubick-sidebar-width);
  height: 100dvh;
  max-height: 100dvh;
  box-sizing: border-box;
  padding: 1.25rem 0 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0;
}

.rubick .side-menu-brand-row {
  flex: 0 0 auto;
  height: 56px;
  display: flex;
  align-items: center;
  padding-inline: 1.5rem;
}

.rubick .side-menu-brand {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding-inline: 0.35rem;
  text-decoration: none;
  color: color-mix(in oklch, var(--color-background), transparent 20%);
  overflow: hidden;
}

.rubick .side-menu-brand__logo {
  max-width: 80px;
  margin-left: -20px;
  flex: 0 0 auto;
  display: block;
  object-fit: contain;
  object-position: left center;
}

.rubick .side-menu-brand__text {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  height: 40px;
  line-height: 40px;
  font-size: 40px;
  font-family: inherit;
  font-weight: 100;
  max-width: 100%;
  letter-spacing: -0.02em;
  white-space: nowrap;
  transform: translateY(5px);
  color: rgb(181, 186, 192);
  margin-left: -15px;
}

.rubick .side-menu-brand__name {
  display: inline-flex;
  gap: 0.35rem;
  font-size: 1rem;
  letter-spacing: -0.01em;
}

.rubick .side-menu-brand__name .brand-main {
  font-weight: 500;
}

.rubick .side-menu-brand__name .brand-sub {
  font-weight: 300;
}

.rubick .side-menu-scroll {
  min-height: 0;
  flex: 1;
  padding-inline: 1rem;
  padding-bottom: 0.25rem;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
}

.rubick ul.scrollable {
  padding: 0;
  margin: 0;
  list-style: none;
}

.rubick .app-nav-link.side-menu__link {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin-bottom: 0.25rem;
  padding: 0.7rem 1rem;
  border-radius: 9999px;
  color: color-mix(in oklch, var(--color-background), transparent 20%);
  text-decoration: none;
  transition: all 0.1s ease;
}

.rubick .app-nav-link.side-menu__link:hover:not(.side-menu__link--active) {
  background: color-mix(in oklch, var(--color-background), transparent 92%);
  color: var(--color-background);
}

.rubick .app-nav-link.side-menu__link.is-active,
.rubick .app-nav-link.side-menu__link.side-menu__link--active {
  background: transparent;
  color: var(--color-foreground);
}

.rubick .app-nav-link .side-menu__link__title {
  font-size: 0.88rem;
  font-weight: 500;
}

.rubick .app-nav-link .side-menu__link__icon {
  width: 1rem;
  height: 1rem;
  stroke-width: 1.5;
}

.rubick .side-menu__group-label--meta {
  margin: 0 0 0.35rem;
}

.rubick .side-menu-meta {
  margin: 0.25rem 1rem 0.5rem;
}

.rubick .app-nav-link.app-version-link {
  border: 1px solid color-mix(in oklch, var(--color-background), transparent 78%);
  background: color-mix(in oklch, var(--color-background), transparent 90%);
  color: color-mix(in oklch, var(--color-background), transparent 8%);
  padding: 0.5rem 1rem;
}

.rubick .app-nav-link.app-version-link .side-menu__link__title {
  font-size: 0.8rem;
  font-weight: 600;
}

.rubick .app-nav-link.app-version-link:hover:not(.side-menu__link--active) {
  background: color-mix(in oklch, var(--color-background), transparent 84%);
}

.rubick .side-menu-user-menu {
  position: relative;
  z-index: 25;
  margin-inline: 1rem;
  margin-bottom: 0.5rem;
}

.rubick .side-menu-user-menu > summary {
  list-style: none;
  cursor: pointer;
}

.rubick .side-menu-user-menu > summary::-webkit-details-marker {
  display: none;
}

.rubick .side-menu-user-menu > summary::marker {
  content: "";
}

.rubick .side-menu-user-card {
  margin-inline: 0;
  border-radius: 9999px;
  border: 1px solid color-mix(in oklch, var(--color-background), transparent 78%);
  background:
    radial-gradient(circle at 14% 50%, color-mix(in oklch, #22d3ee, transparent 78%) 0%, transparent 44%),
    linear-gradient(102deg, color-mix(in oklch, var(--color-background), transparent 90%) 0%, color-mix(in oklch, var(--color-background), transparent 84%) 100%);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  padding: 0.42rem 0.7rem;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  box-shadow: inset 0 0 0 1px color-mix(in oklch, var(--color-background), transparent 90%);
}

.rubick .side-menu-user-menu[open] .side-menu-user-card {
  border-color: color-mix(in oklch, var(--color-background), transparent 66%);
}

.rubick .side-menu-user-avatar {
  width: 1.8rem;
  height: 1.8rem;
  border-radius: 9999px;
  border: 2px solid color-mix(in oklch, var(--color-background), transparent 80%);
  background: color-mix(in oklch, var(--color-background), transparent 90%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  flex: 0 0 auto;
}

.rubick .side-menu-user-avatar i {
  width: 0.9rem;
  height: 0.9rem;
  opacity: 0.82;
}

.rubick .side-menu-user-meta {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 0.08rem;
  flex: 1;
}

.rubick .side-menu-user-name {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: color-mix(in oklch, var(--color-background), transparent 6%);
}

.rubick .side-menu-user-role {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-size: 0.7rem;
  opacity: 0.66;
}

.rubick .side-menu-user-arrow {
  margin-left: auto;
  margin-right: 0.32rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: color-mix(in oklch, var(--color-background), transparent 38%);
  opacity: 0.75;
}

.rubick .side-menu-user-arrow i {
  width: 0.8rem;
  height: 0.8rem;
  stroke-width: 1.8;
  transition: transform 0.14s ease;
}

.rubick .side-menu-user-menu[open] .side-menu-user-arrow i {
  transform: rotate(-90deg);
}

.rubick .side-menu-user-dropdown {
  position: absolute;
  left: 0;
  right: 0;
  bottom: calc(100% + 0.4rem);
  border-radius: 0.75rem;
  border: 1px solid color-mix(in oklch, var(--color-background), transparent 76%);
  background: color-mix(in oklch, var(--color-background), transparent 88%);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  box-shadow: 0 12px 24px color-mix(in oklch, #000, transparent 80%);
  padding: 0.55rem;
}

.rubick .side-menu-user-dropdown-name {
  font-size: 0.82rem;
  font-weight: 700;
  color: color-mix(in oklch, var(--color-background), transparent 6%);
}

.rubick .side-menu-user-dropdown-role {
  margin-top: 0.1rem;
  font-size: 0.7rem;
  color: color-mix(in oklch, var(--color-background), transparent 36%);
}

.rubick .side-menu-user-dropdown-divider {
  height: 1px;
  background: color-mix(in oklch, var(--color-background), transparent 84%);
  margin: 0.4rem 0;
}

.rubick .side-menu-user-logout-form {
  margin: 0;
}

.rubick .side-menu-user-action-btn {
  width: 100%;
  min-height: 2rem;
  padding: 0 0.65rem;
  border-radius: var(--btn-radius);
  border: 1px solid color-mix(in oklch, var(--color-background), transparent 76%);
  background: color-mix(in oklch, var(--color-background), transparent 92%);
  color: color-mix(in oklch, var(--color-background), transparent 6%);
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1.05;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--btn-gap);
  cursor: pointer;
  text-decoration: none;
  box-shadow: var(--btn-shadow-soft);
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.rubick .side-menu-user-action-btn i {
  width: var(--btn-icon-size);
  height: var(--btn-icon-size);
  flex-shrink: 0;
}

.rubick .side-menu-user-action-btn:hover {
  background: color-mix(in oklch, var(--color-background), transparent 88%);
}

.rubick .side-menu-backdrop {
  position: fixed;
  inset: 0;
  z-index: 45;
  background: rgba(5, 15, 38, 0.58);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s ease;
}

.rubick .app-content.content {
  margin: 0 0 0 var(--rubick-sidebar-width);
  min-height: 100vh;
  transition: margin 0.2s ease;
  padding: 2rem 1.75rem 3rem;
  position: relative;
  z-index: 10;
  background: transparent;
  border: 0;
  border-radius: 0;
  overflow: hidden;
}

.rubick .app-content.content::before {
  content: "";
  position: absolute;
  inset-block: 1rem;
  left: 1rem;
  right: 1rem;
  margin-left: -1px;
  opacity: 0.07;
  background: var(--color-foreground);
  border-radius: 2rem;
  pointer-events: none;
}

.rubick .app-content.content::after {
  content: "";
  position: absolute;
  inset-block: 1rem;
  left: 1rem;
  right: 1rem;
  margin-left: -1px;
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 85%);
  border-radius: 2rem;
  pointer-events: none;
}

@media (min-width: 1280px) {
  .rubick .app-content.content::before,
  .rubick .app-content.content::after {
    left: 0;
  }
}

.rubick .content__scroll-area {
  position: relative;
  z-index: 20;
  height: 100%;
  overflow-y: auto;
  overflow-x: hidden;
  margin-right: -1.75rem;
  padding-left: 1rem;
  padding-right: 2.75rem;
  padding-bottom: 0;
}

@media (min-width: 1280px) {
  .rubick .content__scroll-area {
    padding-left: 0;
  }
}

.rubick .top-bar {
  position: sticky;
  top: 0;
  z-index: 30;
  margin-bottom: 0.8rem;
  padding-top: 0.1rem;
}

.rubick .top-bar-inner {
  display: flex;
  align-items: center;
  gap: 0.8rem;
  min-height: 56px;
  padding: 0.35rem 0.15rem 0.55rem;
  border-bottom: 1px solid #dbe3f1;
  background: transparent;
  box-shadow: none;
}

.rubick .top-bar.scrolled .top-bar-inner {
  border-bottom-color: #cfd9e8;
  background: #f8fafc;
  border-radius: 0.9rem;
  padding-inline: 0.8rem;
}

.rubick .mobile-menu-toggle {
  width: var(--btn-height);
  height: var(--btn-height);
  border-radius: var(--btn-radius);
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 84%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
  display: none;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--btn-shadow-soft);
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.rubick .mobile-menu-toggle i {
  width: var(--btn-icon-size);
  height: var(--btn-icon-size);
  flex-shrink: 0;
}

.rubick .top-breadcrumb {
  display: inline-flex;
  align-items: center;
  gap: 1.35rem;
  min-width: 0;
  margin-right: auto;
}

.rubick .top-breadcrumb li {
  position: relative;
  white-space: nowrap;
  color: color-mix(in oklch, var(--color-foreground), transparent 18%);
  font-size: 0.92rem;
  letter-spacing: 0.01em;
}

.rubick .top-breadcrumb li + li::before {
  content: "";
  position: absolute;
  left: -0.78rem;
  top: 50%;
  width: 0.35rem;
  height: 0.35rem;
  margin-top: -0.17rem;
  border-top: 1.5px solid color-mix(in oklch, var(--color-foreground), transparent 40%);
  border-right: 1.5px solid color-mix(in oklch, var(--color-foreground), transparent 40%);
  transform: rotate(45deg);
}

.rubick .top-breadcrumb a {
  color: var(--color-primary);
  text-decoration: none;
}

.rubick .top-breadcrumb span {
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.rubick .topbar-context-form {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  margin-left: 0.85rem;
  min-width: 0;
  flex: 0 1 22rem;
  justify-content: flex-end;
  flex-wrap: nowrap;
}

.rubick .topbar-tenant-label {
  display: flex;
  align-items: center;
  color: var(--color-foreground);
  opacity: 0.5;
  flex-shrink: 0;
}

.rubick .topbar-tenant-label svg {
  width: 1rem;
  height: 1rem;
}

.rubick .topbar-tenant-select,
.rubick .topbar-context-form .ts-wrapper {
  min-width: 10rem;
  max-width: 18rem;
  flex: 1 1 auto;
}

.rubick .topbar-context-form .ts-wrapper .ts-control {
  min-height: 2rem;
  height: 2rem;
  border-radius: var(--btn-radius);
  padding-block: 0;
  font-size: 0.8rem;
  border-color: color-mix(in oklch, var(--color-foreground), transparent 80%);
  background: color-mix(in oklch, var(--color-background), transparent 50%);
}

.rubick .topbar-tenant-submit {
  min-height: 2rem;
  height: 2rem;
  padding: 0 0.65rem;
  border-radius: var(--btn-radius);
  flex-shrink: 0;
  font-size: 0.75rem;
}

.rubick .topbar-actions {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
}

.rubick .topbar-role-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 2rem;
  height: 2rem;
  padding: 0 0.55rem;
  border-radius: var(--btn-radius);
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 68%);
  background: color-mix(in oklch, var(--color-primary), white 88%);
  color: color-mix(in oklch, var(--color-primary), black 8%);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  line-height: 1;
}

.rubick .topbar-inline-logout-form {
  margin: 0;
}

.rubick .topbar-search-pill {
  min-height: 2rem;
  height: 2rem;
  padding: 0 0.6rem;
  border-radius: var(--btn-radius);
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 80%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 3%);
  color: color-mix(in oklch, var(--color-foreground), transparent 30%);
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  font-weight: 600;
  line-height: 1.05;
  cursor: pointer;
  box-shadow: var(--btn-shadow-soft);
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.rubick .topbar-search-pill i {
  width: 0.85rem;
  height: 0.85rem;
  stroke-width: 1.7;
  flex-shrink: 0;
}

.rubick .topbar-search-pill:hover {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 68%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 5%);
  color: color-mix(in oklch, var(--color-foreground), transparent 16%);
}

.rubick .topbar-icon-button {
  width: 2rem;
  height: 2rem;
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 80%);
  border-radius: var(--btn-radius);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 3%);
  color: color-mix(in oklch, var(--color-foreground), transparent 26%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  box-shadow: var(--btn-shadow-soft);
  transition: background-color 0.16s ease, border-color 0.16s ease, color 0.16s ease, box-shadow 0.16s ease;
}

.rubick .topbar-icon-button i {
  width: 0.9rem;
  height: 0.9rem;
  stroke-width: 1.8;
  flex-shrink: 0;
}

.rubick .topbar-icon-button:hover {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 72%);
  background: color-mix(in oklch, var(--color-foreground), transparent 93%);
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.rubick .topbar-theme-toggle.is-dark {
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 66%);
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  color: color-mix(in oklch, var(--color-primary), white 18%);
}

.rubick .topbar-avatar-menu {
  position: relative;
}

.rubick .topbar-avatar-button {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 9999px;
  border: 0;
  background: transparent;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 0.08s ease;
}

.rubick .topbar-avatar-button:active {
  transform: translateY(1px);
}

.rubick .topbar-avatar-photo {
  width: 2.35rem;
  height: 2.35rem;
  border-radius: 9999px;
  overflow: hidden;
  border: 3px solid color-mix(in oklch, var(--color-foreground), transparent 84%);
  box-shadow: 0 0 0 1px color-mix(in oklch, var(--color-background), transparent 55%);
  display: inline-flex;
}

.rubick .topbar-avatar-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.rubick .topbar-avatar-dropdown {
  position: absolute;
  top: calc(100% + 0.45rem);
  right: 0;
  min-width: 18rem;
  border-radius: 1.4rem;
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 84%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  box-shadow: 0 14px 28px color-mix(in oklch, var(--color-foreground), transparent 88%);
  padding: 1rem 1rem 0.95rem;
  display: none;
  flex-direction: column;
  gap: 0.62rem;
  z-index: 70;
}

.rubick .topbar-avatar-menu:hover .topbar-avatar-dropdown,
.rubick .topbar-avatar-menu:focus-within .topbar-avatar-dropdown {
  display: flex;
}

.rubick .topbar-avatar-user {
  font-size: 0.95rem;
  font-weight: 700;
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.rubick .topbar-avatar-role {
  font-size: 0.74rem;
  opacity: 0.68;
}

.rubick .topbar-avatar-divider {
  height: 1px;
  background: color-mix(in oklch, var(--color-foreground), transparent 90%);
  margin: 0.05rem 0;
}

.rubick .topbar-avatar-menu-list {
  display: flex;
  flex-direction: column;
  gap: 0.18rem;
}

.rubick .topbar-avatar-item {
  width: 100%;
  border: 0;
  background: transparent;
  color: color-mix(in oklch, var(--color-foreground), transparent 14%);
  border-radius: 0.85rem;
  min-height: 2.65rem;
  padding: 0 0.78rem;
  font-size: 0.9rem;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
  gap: 0.58rem;
  cursor: pointer;
  text-align: left;
  transition: background-color 0.12s ease;
}

.rubick .topbar-avatar-item:hover {
  background: color-mix(in oklch, var(--color-foreground), transparent 95%);
}

.rubick .topbar-avatar-item.is-active {
  background: color-mix(in oklch, var(--color-foreground), transparent 93%);
}

.rubick .topbar-avatar-item i {
  width: 0.98rem;
  height: 0.98rem;
  stroke-width: 1.9;
  opacity: 0.82;
}

.rubick .topbar-avatar-logout-form {
  margin: 0;
}

.rubick .topbar-avatar-item--button {
  font: inherit;
  cursor: pointer;
  appearance: none;
}

.rubick .topbar-card {
  margin-bottom: 0.65rem;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0.35rem 0.15rem 0.15rem;
}

.rubick .topbar-card .page-title {
  font-size: 2.55rem;
  line-height: 1.08;
  letter-spacing: -0.02em;
}

.rubick .topbar-card .page-subtitle {
  margin-top: 0.22rem;
  font-size: 1.05rem;
  color: color-mix(in oklch, var(--color-foreground), transparent 20%);
}

.rubick .app-main {
  max-width: none;
}

.rubick .app-card {
  border-radius: 1rem;
  border: 1px solid color-mix(in oklch, var(--color-foreground), transparent 86%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
  box-shadow: 0 10px 25px color-mix(in oklch, var(--color-foreground), transparent 92%);
}

.rubick .dashboard-hero.card-pad {
  padding: 1.35rem 1.45rem 1.2rem;
  border-radius: 1.15rem;
}

.rubick .dashboard-hero-head {
  margin-bottom: 0;
  gap: 1.1rem;
  align-items: center;
}

.rubick .dashboard-hero-title {
  font-size: 2.06rem;
  line-height: 1.08;
  letter-spacing: -0.02em;
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.rubick .dashboard-hero-subtitle {
  margin-top: 0.45rem;
  font-size: 0.96rem;
  color: color-mix(in oklch, var(--color-foreground), transparent 28%);
}

.rubick .dashboard-hero-context-form {
  min-width: min(100%, 46rem);
}

.rubick .dashboard-hero-tenant-select,
.rubick .dashboard-hero-context-form .ts-wrapper {
  flex: 1 1 auto;
}

.rubick .dashboard-hero-tenant-submit {
  min-height: var(--control-height);
  height: var(--control-height);
  padding-inline: 1.05rem;
}

.rubick .dashboard-role-badges .badge.neutral {
  padding: 0.3rem 0.78rem;
  border-radius: var(--btn-radius);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  text-transform: lowercase;
  color: color-mix(in oklch, var(--color-primary), black 12%);
  border-color: color-mix(in oklch, var(--color-primary), transparent 70%);
  background: color-mix(in oklch, var(--color-primary), white 85%);
}

.rubick .dashboard-role-badges {
  align-items: center;
  gap: 0.45rem;
}

.rubick .dashboard-split-grid .section-title {
  font-size: 1rem;
}

.rubick .dashboard-split-grid .section-note {
  margin-top: 0.25rem;
}

.rubick .dashboard-mini-table th,
.rubick .dashboard-mini-table td {
  font-size: 0.8rem;
}

.rubick .dashboard-role-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.48rem;
  gap: 0.35rem;
  border-radius: var(--btn-radius);
  padding: 0.3rem 0.78rem;
  font-size: 0.74rem;
  font-weight: 650;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  white-space: nowrap;
  color: color-mix(in oklch, var(--color-primary), black 12%);
  border: 1px solid color-mix(in oklch, var(--color-primary), transparent 70%);
  background: color-mix(in oklch, var(--color-primary), white 89%);
}

.rubick .dashboard-role-chip i {
  width: 0.86rem;
  height: 0.86rem;
  stroke-width: 1.9;
}

.rubick .dashboard-hero .tenant-panel {
  border-radius: 1.05rem;
  border-color: color-mix(in oklch, var(--color-foreground), transparent 84%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  padding: 0.95rem 1rem 1rem;
}

.rubick .dashboard-hero .tenant-panel .label {
  font-size: 0.84rem;
  letter-spacing: 0.01em;
  color: color-mix(in oklch, var(--color-foreground), transparent 25%);
  margin-bottom: 0.38rem;
}

.rubick .dashboard-hero .inline-form {
  align-items: flex-end;
  gap: 0.75rem;
}

.rubick .dashboard-hero .inline-form .form-group {
  min-width: min(360px, 100%);
}

.rubick .dashboard-hero .inline-form > .btn,
.rubick .dashboard-hero .inline-form > a.btn,
.rubick .dashboard-hero .inline-form > .icon-btn,
.rubick .dashboard-hero .inline-form > a.icon-btn {
  min-height: var(--control-height);
  height: var(--control-height);
}

.rubick .dashboard-hero select.control,
.rubick .dashboard-hero .ts-wrapper .ts-control {
  min-height: var(--control-height);
  height: var(--control-height);
  border-radius: var(--btn-radius);
  font-size: var(--btn-font-size);
}

.rubick .dashboard-hero .section-head > .table-actions .btn,
.rubick .dashboard-hero .section-head > .table-actions .icon-btn,
.rubick .dashboard-hero .section-head > .btn,
.rubick .dashboard-hero .section-head > .icon-btn,
.rubick .dashboard-hero .section-head > a.btn,
.rubick .dashboard-hero .section-head > a.icon-btn {
  min-height: var(--btn-height);
  border-radius: var(--btn-radius);
  box-shadow: var(--btn-shadow-soft);
}

.rubick .control,
.rubick input[type="text"],
.rubick input[type="number"],
.rubick input[type="email"],
.rubick input[type="password"],
.rubick input[type="date"],
.rubick input[type="month"],
.rubick textarea,
.rubick select {
  min-height: var(--control-height);
  border-radius: var(--btn-radius);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  box-shadow: inset 0 1px 0 color-mix(in oklch, var(--color-foreground), transparent 95%);
}

.rubick input[type="text"],
.rubick input[type="number"],
.rubick input[type="email"],
.rubick input[type="password"],
.rubick input[type="date"],
.rubick input[type="month"],
.rubick select,
.rubick .control:not(textarea):not(.ts-wrapper) {
  height: var(--control-height);
  font-size: var(--btn-font-size);
}

.rubick textarea {
  min-height: 5.4rem;
}

.rubick .control:focus,
.rubick input:focus,
.rubick textarea:focus,
.rubick select:focus {
  border-color: color-mix(in oklch, var(--color-primary), transparent 55%);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-primary), transparent 85%);
}

.rubick input.easepick-field {
  padding-right: 2.6rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%2364758b' stroke-width='1.9' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M8 2v4'/%3E%3Cpath d='M16 2v4'/%3E%3Crect width='18' height='18' x='3' y='4' rx='2'/%3E%3Cpath d='M3 10h18'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.8rem center;
  background-size: 1rem 1rem;
}

.rubick input.easepick-field:hover {
  border-color: color-mix(in oklch, var(--color-primary), transparent 70%);
}

.rubick .btn {
  min-height: var(--btn-height);
  border-radius: var(--btn-radius);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
  box-shadow: 0 1px 0 color-mix(in oklch, var(--color-background), transparent 35%);
}

.rubick .btn-primary {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: var(--color-background);
  box-shadow: 0 10px 18px color-mix(in oklch, var(--color-primary), transparent 78%);
}

.rubick .btn-primary:hover {
  background: color-mix(in oklch, var(--color-primary), white 7%);
  border-color: color-mix(in oklch, var(--color-primary), white 7%);
}

.rubick .btn-muted {
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.rubick .btn-muted:hover {
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 4%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 74%);
}

.rubick .btn-danger {
  background: var(--color-danger);
  border-color: var(--color-danger);
  color: var(--color-background);
  box-shadow: 0 10px 18px color-mix(in oklch, var(--color-danger), transparent 80%);
}

.rubick .btn-danger:hover {
  background: color-mix(in oklch, var(--color-danger), white 7%);
  border-color: color-mix(in oklch, var(--color-danger), white 7%);
}

.rubick .icon-btn {
  min-height: var(--btn-height);
  border-radius: var(--btn-radius);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
  color: color-mix(in oklch, var(--color-foreground), transparent 12%);
}

.rubick .icon-btn:hover {
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 5%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 74%);
}

.rubick .icon-btn-danger {
  color: var(--color-background);
  border-color: var(--color-danger);
  background: var(--color-danger);
  box-shadow: 0 10px 18px color-mix(in oklch, var(--color-danger), transparent 80%);
}

.rubick .icon-btn-danger:hover {
  background: color-mix(in oklch, var(--color-danger), white 7%);
  border-color: color-mix(in oklch, var(--color-danger), white 7%);
}

.rubick .icon-btn-primary {
  color: var(--color-background);
  border-color: var(--color-primary);
  background: var(--color-primary);
  box-shadow: 0 10px 18px color-mix(in oklch, var(--color-primary), transparent 78%);
}

.rubick .icon-btn-primary:hover {
  background: color-mix(in oklch, var(--color-primary), white 7%);
  border-color: color-mix(in oklch, var(--color-primary), white 7%);
}

.rubick .badge {
  border-radius: var(--btn-radius);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  color: color-mix(in oklch, var(--color-foreground), transparent 12%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
}

.rubick .badge.neutral,
.rubick .badge.status-issued {
  color: var(--color-primary);
  border-color: color-mix(in oklch, var(--color-primary), transparent 70%);
  background: color-mix(in oklch, var(--color-primary), transparent 92%);
}

.rubick .badge.active,
.rubick .badge.status-paid {
  color: var(--color-success);
  border-color: color-mix(in oklch, var(--color-success), transparent 72%);
  background: color-mix(in oklch, var(--color-success), transparent 92%);
}

.rubick .badge.inactive,
.rubick .badge.status-overdue {
  color: var(--color-danger);
  border-color: color-mix(in oklch, var(--color-danger), transparent 72%);
  background: color-mix(in oklch, var(--color-danger), transparent 92%);
}

.rubick .badge.status-cancelled {
  color: color-mix(in oklch, var(--color-foreground), transparent 26%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 2%);
}

.rubick .table-card {
  border-radius: 1rem;
}

.rubick .table-card table thead th {
  color: color-mix(in oklch, var(--color-foreground), transparent 18%);
}

.rubick .table-card table tbody tr:hover {
  background: color-mix(in oklch, var(--color-primary), transparent 96%);
}

.rubick .table-data-list thead th {
  color: color-mix(in oklch, var(--color-foreground), transparent 26%);
}

.rubick .table-data-list tbody td.data-list-cell {
  border-top-color: color-mix(in oklch, var(--color-foreground), transparent 86%);
  border-bottom-color: color-mix(in oklch, var(--color-foreground), transparent 86%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  box-shadow: 0 3px 5px color-mix(in oklch, #000, transparent 95%);
}

.rubick .table-data-list tbody td.data-list-cell:first-child {
  border-left-color: color-mix(in oklch, var(--color-foreground), transparent 86%);
}

.rubick .table-data-list tbody td.data-list-cell:last-child {
  border-right-color: color-mix(in oklch, var(--color-foreground), transparent 86%);
}

.rubick .table-data-list thead th.actions-cell {
  padding-right: 1.3rem;
}

.rubick .table-data-list tbody td.actions-cell.data-list-cell {
  padding-left: 0.6rem;
  padding-right: 1.3rem;
}

.rubick .table-data-list tbody tr:hover td.data-list-cell {
  background: color-mix(in oklch, var(--color-primary), transparent 96%);
}

.rubick .flash {
  border-radius: 0.9rem;
}

.rubick .ts-wrapper {
  width: 100%;
}

.rubick .ts-wrapper.control {
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  height: auto;
  min-height: 0;
}

.rubick .ts-wrapper .ts-control,
.rubick .ts-wrapper.single .ts-control,
.rubick .ts-wrapper.multi .ts-control {
  height: var(--control-height);
  min-height: var(--control-height);
  border-radius: var(--btn-radius);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  display: flex;
  align-items: center;
  padding: 0 var(--btn-padding-inline);
  overflow: hidden;
  font-size: var(--btn-font-size);
}

.rubick .ts-wrapper .ts-control > input {
  font-size: var(--btn-font-size);
  line-height: 1.2;
}

.rubick .ts-wrapper.single .ts-control::after {
  right: var(--btn-padding-inline);
}

.rubick .top-bar .topbar-context-form .topbar-tenant-select,
.rubick .top-bar .topbar-context-form .ts-wrapper .ts-control,
.rubick .top-bar .topbar-context-form .ts-wrapper.single .ts-control {
  height: 2rem;
  min-height: 2rem;
  border-radius: var(--btn-radius);
  font-size: 0.8rem;
}

.rubick .top-bar .topbar-context-form .ts-wrapper .ts-control {
  padding-inline: 0.65rem;
}

.rubick .ts-dropdown {
  border-radius: 0.75rem;
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
}

.rubick .ts-dropdown .dropdown-header {
  border-bottom: 1px solid color-mix(in oklch, var(--color-foreground), transparent 88%);
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 1%);
  border-top-left-radius: 0.75rem;
  border-top-right-radius: 0.75rem;
}

.rubick .ts-dropdown .dropdown-header-title {
  padding: 0.48rem 0.72rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
}

.rubick .ts-dropdown .dropdown-header-label {
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--color-foreground), transparent 26%);
  font-weight: 700;
}

.rubick .ts-dropdown .dropdown-header-close {
  text-decoration: none;
  color: color-mix(in oklch, var(--color-foreground), transparent 42%);
  font-size: 0.92rem;
  line-height: 1;
}

/* Rubick dark alignment (based on template/Source behavior) */
.dark body.app-body.rubick {
  background: var(--color-background);
}

.dark .rubick {
  --rubick-dark-shared-surface: #071733;
  --rubick-dark-shared-edge: rgba(147, 197, 253, 0.2);
  --rubick-dark-shared-edge-soft: rgba(5, 12, 29, 0.52);
}

.dark body.app-body.rubick::before {
  opacity: 0;
}

.dark body.app-body.rubick::after {
  background:
    radial-gradient(circle at 16% 100%, rgba(34, 211, 238, 0.2) 0%, rgba(34, 211, 238, 0) 42%),
    radial-gradient(circle at 90% 6%, rgba(99, 102, 241, 0.2) 0%, rgba(99, 102, 241, 0) 34%),
    linear-gradient(170deg, #030611 0%, #061128 46%, #081735 100%),
    var(--background-image-noise);
  opacity: 1;
  filter: none;
}

.dark .rubick .app-sidebar.side-menu::after {
  background: transparent;
}

.dark .rubick .side-menu-brand {
  color: #dbe5f4;
  color: color-mix(in oklch, var(--color-foreground), white 10%);
}

.dark .rubick .app-nav-link.app-version-link {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-foreground), transparent 92%);
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.dark .rubick .app-nav-link.app-version-link:hover:not(.side-menu__link--active) {
  background: color-mix(in oklch, var(--color-foreground), transparent 88%);
}

.dark .rubick .side-menu__group-label {
  color: rgba(203, 213, 225, 0.56);
  opacity: 1;
}

.dark .rubick .app-nav-link .side-menu__link__icon {
  --color: rgba(219, 229, 244, 0.72);
  --color: color-mix(in oklch, var(--color-foreground), transparent 30%);
}

.dark .rubick .app-nav-link.side-menu__link {
  color: rgba(219, 229, 244, 0.84);
  color: color-mix(in oklch, var(--color-foreground), transparent 20%);
}

.dark .rubick .app-nav-link.side-menu__link:hover:not(.side-menu__link--active) {
  background: rgba(219, 229, 244, 0.06);
  background: color-mix(in oklch, var(--color-foreground), transparent 95%);
  color: #e6edf9;
  color: var(--color-foreground);
}

.dark .rubick .app-nav-link.side-menu__link.is-active,
.dark .rubick .app-nav-link.side-menu__link.side-menu__link--active {
  color: #e6edf9;
  color: var(--color-foreground);
  text-shadow: 0 0 0 rgba(0, 0, 0, 0);
}

.dark .rubick .app-nav-link.side-menu__link.is-active .side-menu__link__icon,
.dark .rubick .app-nav-link.side-menu__link.side-menu__link--active .side-menu__link__icon {
  --color: var(--color-foreground);
}

.dark .rubick ul.scrollable > li > .side-menu__link.side-menu__link--active::before,
.dark .rubick ul.scrollable > li > .side-menu__link.side-menu__link--active::after {
  content: "" !important;
  display: block !important;
}

.dark .rubick ul.scrollable > li > .side-menu__link.side-menu__link--active > div::before {
  content: "" !important;
  display: block !important;
}

.dark .rubick ul.scrollable > li > .side-menu__link.side-menu__link--active::before {
  background: var(--rubick-dark-shared-surface) !important;
  opacity: 0.78 !important;
}

.dark .rubick ul.scrollable > li > .side-menu__link.side-menu__link--active::after {
  background: color-mix(in oklch, var(--rubick-dark-shared-surface), transparent 68%) !important;
  opacity: 0.22 !important;
}

.dark .rubick ul.scrollable > li > .side-menu__link.side-menu__link--active > div::before {
  background: color-mix(in oklch, var(--rubick-dark-shared-surface), transparent 82%) !important;
  opacity: 1 !important;
}

.dark .rubick ul.scrollable > li > .side-menu__link.side-menu__link--active {
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  outline: 0 !important;
}

.dark .rubick .side-menu-user-card {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 78%);
  background:
    radial-gradient(circle at 14% 50%, color-mix(in oklch, #22d3ee, transparent 86%) 0%, transparent 44%),
    linear-gradient(102deg, color-mix(in oklch, var(--color-foreground), transparent 92%) 0%, color-mix(in oklch, var(--color-foreground), transparent 88%) 100%);
}

.dark .rubick .side-menu-user-avatar {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 82%);
  background: color-mix(in oklch, var(--color-foreground), transparent 92%);
}

.dark .rubick .side-menu-user-name {
  color: #e6edf9;
  color: color-mix(in oklch, var(--color-foreground), white 8%);
}

.dark .rubick .side-menu-user-role {
  color: rgba(219, 229, 244, 0.72);
  color: color-mix(in oklch, var(--color-foreground), transparent 24%);
}

.dark .rubick .side-menu-user-arrow {
  color: rgba(219, 229, 244, 0.56);
  color: color-mix(in oklch, var(--color-foreground), transparent 40%);
}

.dark .rubick .side-menu-user-dropdown {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 76%);
  background:
    linear-gradient(
      160deg,
      color-mix(in oklch, var(--color-primary), transparent 90%) 0%,
      color-mix(in oklch, var(--color-background), transparent 44%) 100%
    );
  box-shadow: 0 14px 28px rgba(0, 0, 0, 0.22);
}

.dark .rubick .side-menu-user-dropdown-name {
  color: color-mix(in oklch, var(--color-foreground), white 12%);
}

.dark .rubick .side-menu-user-dropdown-role {
  color: color-mix(in oklch, var(--color-foreground), transparent 24%);
}

.dark .rubick .side-menu-user-dropdown-divider {
  background: color-mix(in oklch, var(--color-foreground), transparent 88%);
}

.dark .rubick .side-menu-user-action-btn {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 74%);
  background:
    linear-gradient(
      170deg,
      color-mix(in oklch, var(--color-primary), transparent 90%) 0%,
      color-mix(in oklch, var(--color-background), transparent 46%) 100%
    );
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
  box-shadow: none;
}

.dark .rubick .side-menu-user-action-btn:hover {
  background:
    linear-gradient(
      170deg,
      color-mix(in oklch, var(--color-primary), transparent 86%) 0%,
      color-mix(in oklch, var(--color-background), transparent 38%) 100%
    );
}

.dark .rubick .app-content.content::before {
  left: 0;
  opacity: 0.04;
}

.dark .rubick .app-content.content::after {
  left: 0;
  background: var(--rubick-dark-shared-surface);
  border-color: rgba(148, 163, 184, 0.14);
  border-left-color: transparent;
  opacity: 1;
}

.dark .rubick .app-content.content {
  background: transparent;
}

.dark .rubick .app-card {
  --color-background: color-mix(in oklch, var(--color-white), transparent 99%);
  background: rgba(255, 255, 255, 0.012);
  background: color-mix(in oklch, var(--color-white), transparent 99%);
  border-color: rgba(148, 163, 184, 0.14);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 90%);
  box-shadow: 0 3px 5px #0000000b;
}

.dark .rubick .dashboard-card {
  background: rgba(255, 255, 255, 0.02);
  border-color: rgba(148, 163, 184, 0.16);
  box-shadow: 0 3px 5px #0000000b;
}

.dark .rubick .dashboard-card h3 {
  color: #e6edf9;
}

.dark .rubick .dashboard-card p {
  color: rgba(203, 213, 225, 0.72);
}

.dark .rubick .top-bar.scrolled .top-bar-inner {
  background: color-mix(in oklch, var(--color-background), var(--color-foreground) 3%);
  border-bottom-color: color-mix(in oklch, var(--color-foreground), transparent 80%);
}

.dark .rubick .top-breadcrumb a {
  color: color-mix(in oklch, var(--color-primary), white 32%);
}

.dark .rubick .top-breadcrumb span {
  color: color-mix(in oklch, var(--color-foreground), transparent 4%);
}

.dark .rubick .topbar-search-pill {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 76%);
  background:
    linear-gradient(
      170deg,
      color-mix(in oklch, var(--color-primary), transparent 90%) 0%,
      color-mix(in oklch, var(--color-background), transparent 44%) 100%
    );
  color: color-mix(in oklch, var(--color-foreground), transparent 16%);
  box-shadow: none;
}

.dark .rubick .topbar-icon-button,
.dark .rubick .mobile-menu-toggle {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 76%);
  background:
    linear-gradient(
      170deg,
      color-mix(in oklch, var(--color-primary), transparent 90%) 0%,
      color-mix(in oklch, var(--color-background), transparent 44%) 100%
    );
  color: color-mix(in oklch, var(--color-foreground), transparent 18%);
  box-shadow: none;
}

.dark .rubick .topbar-icon-button:hover,
.dark .rubick .mobile-menu-toggle:hover {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 66%);
  background:
    linear-gradient(
      170deg,
      color-mix(in oklch, var(--color-primary), transparent 86%) 0%,
      color-mix(in oklch, var(--color-background), transparent 36%) 100%
    );
  color: color-mix(in oklch, var(--color-foreground), transparent 8%);
}

.dark .rubick .topbar-search-pill:hover {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 66%);
  background:
    linear-gradient(
      170deg,
      color-mix(in oklch, var(--color-primary), transparent 86%) 0%,
      color-mix(in oklch, var(--color-background), transparent 36%) 100%
    );
  color: color-mix(in oklch, var(--color-foreground), transparent 8%);
}

.dark .rubick .table-control-label,
.dark .rubick .table-footer-info,
.dark .rubick .table-subline,
.dark .rubick .section-note,
.dark .rubick .label,
.dark .rubick .metric-label,
.dark .rubick .metric-note,
.dark .rubick .dashboard-card p {
  color: rgba(203, 213, 225, 0.76);
  color: color-mix(in oklch, var(--color-foreground), transparent 16%);
}

.dark .rubick .page-title,
.dark .rubick .section-title,
.dark .rubick .dashboard-hero-title,
.dark .rubick .modal-title,
.dark .rubick .metric-value,
.dark .rubick .dashboard-card h3,
.dark .rubick .table-data-list .data-list-title {
  color: #e6edf9;
  color: color-mix(in oklch, var(--color-foreground), white 8%);
}

.dark .rubick .module-breakdown-row {
  color: color-mix(in oklch, var(--color-foreground), transparent 6%);
}

.dark .rubick .module-breakdown-row strong {
  color: color-mix(in oklch, var(--color-foreground), white 8%);
}

.dark .rubick .counterparty-profile-kicker {
  color: color-mix(in oklch, var(--color-foreground), transparent 38%);
}

.dark .rubick .counterparty-profile-mark {
  border-color: color-mix(in oklch, var(--color-primary), transparent 56%);
  background: linear-gradient(160deg, color-mix(in oklch, var(--color-primary), transparent 80%) 0%, color-mix(in oklch, var(--color-background), var(--color-primary) 26%) 100%);
  color: color-mix(in oklch, var(--color-foreground), transparent 2%);
}

.dark .rubick .counterparty-hero-meta-item {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 84%);
  background: color-mix(in oklch, var(--color-primary), transparent 92%);
}

.dark .rubick .counterparty-hero-meta-label {
  color: color-mix(in oklch, var(--color-foreground), transparent 34%);
}

.dark .rubick .counterparty-hero-meta-value {
  color: color-mix(in oklch, var(--color-foreground), transparent 8%);
}

.dark .rubick .billing-filter-shell {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 84%);
  background: color-mix(in oklch, var(--color-primary), transparent 94%);
}

.dark .rubick .billing-metric-icon {
  border-color: color-mix(in oklch, var(--color-primary), transparent 62%);
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  color: color-mix(in oklch, var(--color-foreground), transparent 8%);
}

.dark .rubick .payments-metric-icon {
  border-color: color-mix(in oklch, var(--color-primary), transparent 62%);
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  color: color-mix(in oklch, var(--color-foreground), transparent 8%);
}

.dark .rubick .payouts-metric-icon {
  border-color: color-mix(in oklch, var(--color-primary), transparent 62%);
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  color: color-mix(in oklch, var(--color-foreground), transparent 8%);
}

.dark .rubick .finance-metric-icon {
  border-color: color-mix(in oklch, var(--color-primary), transparent 62%);
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  color: color-mix(in oklch, var(--color-foreground), transparent 8%);
}

.dark .rubick .app-table th,
.dark .rubick .app-table td {
  border-bottom-color: color-mix(in oklch, var(--color-foreground), transparent 90%);
  color: var(--color-foreground);
}

.dark .rubick .app-table th {
  background: transparent;
  color: color-mix(in oklch, var(--color-foreground), transparent 35%);
}

.dark .rubick .app-table th.is-sortable::after {
  color: color-mix(in oklch, var(--color-foreground), transparent 38%);
}

.dark .rubick .app-table th.is-sort-asc::after,
.dark .rubick .app-table th.is-sort-desc::after {
  color: var(--color-primary);
}

.dark .rubick .app-table tr:hover td {
  background: color-mix(in oklch, var(--color-primary), transparent 96%);
}

.dark .rubick .btn-primary,
.dark .rubick .btn-danger {
  color: #eaf1ff;
}

.dark .rubick .btn-primary i,
.dark .rubick .btn-danger i {
  color: inherit;
}

.dark .rubick .dashboard-mini-table td .badge.active {
  color: color-mix(in oklch, var(--color-success), white 32%);
}

.dark .rubick .dashboard-mini-table td .badge.inactive {
  color: color-mix(in oklch, var(--color-danger), white 22%);
}

.dark .rubick .btn-muted,
.dark .rubick .btn {
  color: rgba(226, 234, 247, 0.92);
}

.dark .rubick .icon-btn-primary {
  color: #eaf1ff;
  border-color: var(--color-primary);
  background: var(--color-primary);
}

.dark .rubick .icon-btn-danger {
  color: #ffeef0;
  border-color: var(--color-danger);
  background: var(--color-danger);
}

.dark .rubick .topbar-role-badge {
  border-color: color-mix(in oklch, var(--color-primary), transparent 78%);
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  color: color-mix(in oklch, var(--color-primary), white 30%);
}

.dark .rubick .badge.neutral,
.dark .rubick .badge.status-issued {
  color: color-mix(in oklch, var(--color-primary), white 34%);
  border-color: color-mix(in oklch, var(--color-primary), transparent 54%);
  background: color-mix(in oklch, var(--color-primary), transparent 84%);
}

.dark .rubick .rbac-scope-badge.scope-global {
  border-color: color-mix(in oklch, #60a5fa, transparent 50%);
  background: color-mix(in oklch, #3b82f6, transparent 82%);
  color: color-mix(in oklch, #93c5fd, white 20%);
}

.dark .rubick .rbac-scope-badge.scope-agency {
  border-color: color-mix(in oklch, #a78bfa, transparent 50%);
  background: color-mix(in oklch, #8b5cf6, transparent 84%);
  color: color-mix(in oklch, #c4b5fd, white 18%);
}

.dark .rubick .rbac-scope-badge.scope-zev {
  border-color: color-mix(in oklch, #60a5fa, transparent 54%);
  background: color-mix(in oklch, #2563eb, transparent 86%);
  color: color-mix(in oklch, #93c5fd, white 18%);
}

.dark .rubick .rbac-scope-badge.scope-portal {
  border-color: color-mix(in oklch, #5eead4, transparent 54%);
  background: color-mix(in oklch, #14b8a6, transparent 86%);
  color: color-mix(in oklch, #99f6e4, white 18%);
}

.dark .rubick .app-table.js-data-table {
  border-collapse: separate;
  border-spacing: 0 0.62rem;
}

.dark .rubick .app-table.js-data-table thead th {
  background: transparent;
  border: 0;
  color: color-mix(in oklch, var(--color-foreground), transparent 22%);
  padding-top: 0.22rem;
  padding-bottom: 0.48rem;
}

.dark .rubick .app-table.js-data-table tbody td {
  --color-background: color-mix(in oklch, var(--color-white), transparent 99%);
  background: rgba(255, 255, 255, 0.012);
  background: var(--color-background);
  border-top: 1px solid rgba(148, 163, 184, 0.12);
  border-bottom: 1px solid rgba(148, 163, 184, 0.12);
  border-top: 1px solid color-mix(in oklch, var(--color-foreground), transparent 90%);
  border-bottom: 1px solid color-mix(in oklch, var(--color-foreground), transparent 90%);
}

.dark .rubick .app-table.js-data-table tbody td:first-child {
  border-left: 1px solid rgba(148, 163, 184, 0.12);
  border-left: 1px solid color-mix(in oklch, var(--color-foreground), transparent 90%);
  border-top-left-radius: 0.95rem;
  border-bottom-left-radius: 0.95rem;
}

.dark .rubick .app-table.js-data-table tbody td:last-child {
  border-right: 1px solid rgba(148, 163, 184, 0.12);
  border-right: 1px solid color-mix(in oklch, var(--color-foreground), transparent 90%);
  border-top-right-radius: 0.95rem;
  border-bottom-right-radius: 0.95rem;
}

.dark .rubick .app-table.js-data-table tbody tr:hover td {
  background: color-mix(in oklch, var(--color-primary), transparent 95%);
}

.dark .rubick .table-data-list tbody td.data-list-cell {
  --color-background: color-mix(in oklch, var(--color-white), transparent 99%);
  background: rgba(255, 255, 255, 0.012);
  background: var(--color-background);
}

.dark .rubick .rbac-editor-count,
.dark .rubick .rbac-permission-copy .check-subtitle {
  color: color-mix(in oklch, var(--color-foreground), transparent 22%);
}

.dark .rubick .modal-panel {
  background:
    linear-gradient(
      155deg,
      color-mix(in oklch, var(--color-primary), transparent 90%) 0%,
      color-mix(in oklch, var(--color-background), transparent 52%) 48%,
      color-mix(in oklch, var(--color-primary), transparent 92%) 100%
    );
  border-color: color-mix(in oklch, var(--color-foreground), transparent 78%);
  box-shadow: 0 18px 40px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(10px) saturate(112%);
}

.dark .rubick .modal-head,
.dark .rubick .modal-actions {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 86%);
}

.dark .rubick .modal-panel,
.dark .rubick .modal-panel p,
.dark .rubick .modal-panel li,
.dark .rubick .modal-panel strong,
.dark .rubick .modal-panel .section-note,
.dark .rubick .modal-panel .label {
  color: color-mix(in oklch, var(--color-foreground), transparent 22%);
}

.dark .rubick .modal-panel .modal-title {
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.dark .rubick .modal-panel .btn.btn-muted {
  background: color-mix(in oklch, var(--color-primary), transparent 90%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 74%);
  color: color-mix(in oklch, var(--color-foreground), transparent 16%);
  box-shadow: none;
}

.dark .rubick .modal-panel .btn.btn-muted:hover {
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 66%);
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.dark .rubick .modal-panel .modal-head [data-modal-close].icon-btn {
  background: color-mix(in oklch, var(--color-primary), transparent 90%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 74%);
  color: color-mix(in oklch, var(--color-foreground), transparent 18%);
  box-shadow: none;
}

.dark .rubick .modal-panel .modal-head [data-modal-close].icon-btn:hover {
  background: color-mix(in oklch, var(--color-primary), transparent 86%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 66%);
  color: color-mix(in oklch, var(--color-foreground), transparent 10%);
}

.dark .rubick .rbac-permission-copy .check-title {
  color: color-mix(in oklch, var(--color-foreground), white 6%);
}

.dark .rubick .rbac-permission-groups {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 88%);
  background: color-mix(in oklch, var(--color-white), transparent 99%);
}

.dark .rubick .rbac-permission-group {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 88%);
  background: color-mix(in oklch, var(--color-white), transparent 98%);
}

.dark .rubick .rbac-permission-group-head h4 {
  color: color-mix(in oklch, var(--color-foreground), transparent 28%);
}

.dark .rubick .rbac-permission-item {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 94%);
  background: color-mix(in oklch, var(--color-white), transparent 98%);
}

.dark .rubick .rbac-permission-item:hover {
  border-color: color-mix(in oklch, var(--color-primary), transparent 64%);
  background: color-mix(in oklch, var(--color-primary), transparent 92%);
}

.dark .rubick .modal-rbac-editor .modal-actions {
  border-top-color: color-mix(in oklch, var(--color-foreground), transparent 88%);
  background: color-mix(in oklch, var(--color-white), transparent 99%);
}

.dark .rubick .control,
.dark .rubick input[type="text"],
.dark .rubick input[type="number"],
.dark .rubick input[type="email"],
.dark .rubick input[type="password"],
.dark .rubick input[type="date"],
.dark .rubick input[type="month"],
.dark .rubick textarea,
.dark .rubick select,
.dark .rubick .ts-wrapper .ts-control,
.dark .rubick .ts-wrapper.single .ts-control,
.dark .rubick .ts-wrapper.multi .ts-control {
  color: color-mix(in oklch, var(--color-foreground), transparent 20%);
  border-color: color-mix(in oklch, var(--color-foreground), transparent 78%);
  background: color-mix(in oklch, var(--color-primary), transparent 92%);
  box-shadow: none;
}

.dark .rubick .control:focus,
.dark .rubick input:focus,
.dark .rubick textarea:focus,
.dark .rubick select:focus,
.dark .rubick .ts-wrapper .ts-control:focus-within {
  border-color: color-mix(in oklch, var(--color-primary), transparent 52%);
  box-shadow: 0 0 0 3px color-mix(in oklch, var(--color-primary), transparent 86%);
}

.dark .rubick .control::placeholder,
.dark .rubick input::placeholder,
.dark .rubick textarea::placeholder,
.dark .rubick .ts-wrapper .ts-control > input::placeholder {
  color: color-mix(in oklch, var(--color-foreground), transparent 44%);
  opacity: 1;
}

.dark .rubick input[type="checkbox"] {
  border-color: color-mix(in oklch, var(--color-foreground), transparent 64%);
  background: color-mix(in oklch, var(--color-primary), transparent 94%);
  box-shadow: none;
}

.dark .rubick input[type="checkbox"]:checked {
  background: color-mix(in oklch, var(--color-primary), white 6%);
  border-color: color-mix(in oklch, var(--color-primary), white 6%);
  box-shadow: 0 8px 14px color-mix(in oklch, var(--color-primary), transparent 86%);
}

.dark .rubick .checkbox-item:hover {
  background: color-mix(in oklch, var(--color-primary), transparent 92%);
}

.dark .rubick .check-row,
.dark .rubick .checkbox-line {
  color: color-mix(in oklch, var(--color-foreground), transparent 18%);
}

@media (max-width: 1279px) {
  .rubick .app-sidebar.side-menu {
    transform: translateX(-100%);
    transition: transform 0.2s ease;
  }

  .rubick .app-sidebar.side-menu.is-open {
    transform: translateX(0);
  }

  .dark .rubick .app-sidebar.side-menu::after {
    background:
      radial-gradient(circle at 16% 100%, rgba(34, 211, 238, 0.2) 0%, rgba(34, 211, 238, 0) 42%),
      radial-gradient(circle at 90% 6%, rgba(99, 102, 241, 0.22) 0%, rgba(99, 102, 241, 0) 34%),
      linear-gradient(170deg, #030611 0%, #061128 46%, #081735 100%),
      var(--background-image-noise);
    background-blend-mode: screen, screen, normal, overlay;
  }

  .rubick .close-mobile-menu {
    display: inline-flex;
  }

  .rubick .side-menu-backdrop.is-open {
    opacity: 1;
    pointer-events: auto;
  }

  .rubick .app-content.content {
    margin: 0.3rem;
    min-height: calc(100vh - 0.6rem);
    padding: 0.7rem 0.5rem 0.8rem;
    border-radius: 0;
  }

  .rubick .app-content.content::before,
  .rubick .app-content.content::after {
    left: 0;
    right: 0;
  }

  .rubick .content__scroll-area {
    height: 100%;
    padding: 0.35rem 0.35rem 0.45rem;
    margin-right: 0;
  }

  .rubick .mobile-menu-toggle {
    display: inline-flex;
  }

  .rubick .top-breadcrumb {
    gap: 0.85rem;
  }

  .rubick .topbar-context-form {
    min-width: 0;
    margin-left: 0.55rem;
    flex-basis: 22rem;
  }

  .rubick .topbar-tenant-select,
  .rubick .topbar-context-form .ts-wrapper {
    min-width: 9.5rem;
    max-width: 14.5rem;
  }
}

@media (max-width: 700px) {
  .rubick .top-bar-inner {
    flex-wrap: wrap;
    align-items: center;
  }

  .rubick .top-breadcrumb {
    display: none;
  }

  .rubick .topbar-actions {
    margin-left: auto;
  }

  .rubick .topbar-context-form {
    width: 100%;
    order: 3;
    margin-top: 0.5rem;
    margin-left: 0;
    flex-direction: row;
    align-items: center;
  }

  .rubick .topbar-tenant-label {
    display: none;
  }

  .rubick .topbar-tenant-select,
  .rubick .topbar-context-form .ts-wrapper {
    min-width: 0;
    max-width: none;
    flex: 1;
  }

  .rubick .topbar-card .page-title {
    font-size: 2.1rem;
  }
}
