html {
  font-size: 14px;
}

@media (min-width: 768px) {
  html {
    font-size: 16px;
  }
}

.btn:focus, .btn:active:focus, .btn-link.nav-link:focus, .form-control:focus, .form-check-input:focus {
  box-shadow: 0 0 0 0.1rem white, 0 0 0 0.25rem #258cfb;
}

html {
  position: relative;
  min-height: 100%;
}

body {
  margin-bottom: 0;
}

:root {
  --portal-ink: #172033;
  --portal-muted: #64748b;
  --portal-line: #dbe3ee;
  --portal-surface: #ffffff;
  --portal-soft: #f5f8fb;
  --portal-accent: #23999b;
  --portal-primary: #2f4a83;
}

.content {
  background: #edf3f8;
}

#content .content__wrap > .d-flex.flex-wrap.justify-content-between.align-items-start.mb-3.gap-2 {
  margin-bottom: 1rem !important;
  padding: 1.1rem 1.25rem;
  border: 1px solid var(--portal-line);
  border-left: 4px solid var(--portal-accent);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(35, 153, 155, .12), rgba(47, 74, 131, .06)),
    var(--portal-surface);
}

#content .content__wrap > .d-flex.flex-wrap.justify-content-between.align-items-start.mb-3.gap-2 h1 {
  margin-bottom: .25rem !important;
  color: var(--portal-ink);
  font-size: clamp(1.45rem, 2vw, 2rem);
  font-weight: 700;
  letter-spacing: 0;
}

#content .content__wrap > .d-flex.flex-wrap.justify-content-between.align-items-start.mb-3.gap-2 .text-muted {
  color: #49627f !important;
}

#content .content__wrap > .d-flex.flex-wrap.justify-content-between.align-items-start.mb-3.gap-2 .btn-primary {
  background: var(--portal-primary);
  border-color: var(--portal-primary);
}

#content .content__wrap > h1:first-child {
  margin-bottom: 1rem !important;
  padding: 1rem 1.1rem;
  border: 1px solid var(--portal-line);
  border-left: 4px solid var(--portal-accent);
  border-radius: 8px;
  color: var(--portal-ink);
  background:
    linear-gradient(135deg, rgba(35, 153, 155, .1), rgba(47, 74, 131, .05)),
    var(--portal-surface);
  font-size: clamp(1.35rem, 1.8vw, 1.85rem);
  font-weight: 700;
  letter-spacing: 0;
}

#content .content__wrap .form-control,
#content .content__wrap .form-select {
  border-color: var(--portal-line);
  color: var(--portal-ink);
  background-color: #fff;
}

#content .content__wrap .form-control:focus,
#content .content__wrap .form-select:focus {
  border-color: var(--portal-accent);
  box-shadow: 0 0 0 .18rem rgba(35, 153, 155, .14);
}

#content .content__wrap .form-label {
  color: var(--portal-ink);
  font-size: .78rem;
  font-weight: 600;
}

#content .content__wrap table.table:not(.dashboard-table) {
  overflow: hidden;
  border: 1px solid var(--portal-line);
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 8px;
  background: var(--portal-surface);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .035);
  --bs-table-bg: #ffffff;
  --bs-table-striped-bg: #f8fbff;
  --bs-table-hover-bg: #eef7f7;
  --bs-table-border-color: #e3eaf4;
}

#content .content__wrap table.table:not(.dashboard-table) > :not(caption) > * > * {
  padding: .85rem .75rem;
  color: var(--portal-ink);
  border-bottom-color: #e3eaf4;
}

#content .content__wrap table.table:not(.dashboard-table) thead th {
  color: #324967;
  background: #f7fafc;
  border-bottom: 1px solid var(--portal-line);
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;
  white-space: nowrap;
}

#content .content__wrap table.table:not(.dashboard-table) tbody tr:last-child > * {
  border-bottom-width: 0;
}

#content .content__wrap table.table .op-row-number-head,
#content .content__wrap table.table .op-row-number-cell {
  width: 54px;
  min-width: 54px;
  max-width: 64px;
  color: var(--portal-muted);
  font-size: .78rem;
  font-weight: 700;
  text-align: right;
  white-space: nowrap;
}

#content .content__wrap table.table .op-row-number-cell {
  color: #5d718a;
}

#content .content__wrap table.table .op-sort-link {
  display: inline-flex;
  align-items: center;
  gap: .35rem;
  color: inherit;
  text-decoration: none;
}

#content .content__wrap table.table .op-sort-link:hover,
#content .content__wrap table.table .op-sort-link:focus {
  color: var(--portal-primary);
}

#content .content__wrap table.table .op-sort-link.is-active {
  color: var(--portal-primary);
}

#content .content__wrap table.table .op-sort-icon {
  font-size: .78rem;
  opacity: .72;
}

#content .content__wrap table.table:not(.dashboard-table) .btn-sm {
  min-height: 32px;
  font-size: .78rem;
}

#content .content__wrap .pagination {
  gap: .25rem;
}

#content .content__wrap .page-link {
  min-width: 34px;
  border-color: var(--portal-line);
  border-radius: 7px;
  color: var(--portal-primary);
  text-align: center;
}

#content .content__wrap .page-item.active .page-link {
  background: var(--portal-primary);
  border-color: var(--portal-primary);
}

.app-brand-logo {
  display: block;
  width: 168px !important;
  height: auto !important;
  max-height: 36px;
  background: transparent;
  object-fit: contain;
}

.brand-wrap {
  min-width: 168px;
}

.header__brand .brand-title {
  display: none !important;
}

.mainnav .nav-link {
  display: flex;
  align-items: center;
  min-width: 0;
}

.mainnav .nav-link > i {
  flex: 0 0 auto;
}

.mainnav .nav-label {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.login-brand {
  display: grid;
  justify-items: center;
  gap: .75rem;
}

.login-brand-logo {
  width: min(280px, 84%);
  height: auto;
  object-fit: contain;
}

.menu-drag-cell {
  width: 42px;
}

.menu-drag-handle {
  cursor: grab;
  color: var(--bs-secondary-color);
}

.menu-row.menu-dragging {
  opacity: 0.5;
}

.menu-drop-placeholder td {
  padding: 0;
  border: 2px dashed rgba(13, 110, 253, 0.35);
  background-color: rgba(13, 110, 253, 0.06);
}

.menu-drop-placeholder .menu-drop-placeholder-inner {
  height: 34px;
}

.menu-drop-parent .menu-name-wrap {
  background-color: rgba(25, 135, 84, 0.08);
}

.form-floating > .form-control-plaintext::placeholder, .form-floating > .form-control::placeholder {
  color: var(--bs-secondary-color);
  text-align: end;
}

.form-floating > .form-control-plaintext:focus::placeholder, .form-floating > .form-control:focus::placeholder {
  text-align: start;
}

.erp-filter-panel {
  border: 1px solid var(--portal-line);
  border-radius: 8px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .98), rgba(248, 251, 255, .98)),
    var(--portal-surface);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .035);
  padding: 1rem;
}

.erp-filter-panel .row {
  row-gap: .85rem;
}

.erp-filter-panel--compact {
  padding: .85rem 1rem;
}

.erp-filter-commandbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .6rem;
}

.erp-filter-search {
  flex: 1 1 260px;
}

.erp-filter-status,
.erp-filter-page-size {
  flex: 0 1 180px;
}

.erp-filter-actions {
  display: flex;
  flex: 0 0 auto;
  flex-wrap: wrap;
  gap: .5rem;
}

.erp-filter-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin-top: .75rem;
}

.erp-data-table th {
  white-space: nowrap;
  font-size: .82rem;
  text-transform: uppercase;
  color: var(--bs-secondary-color);
}

.erp-data-table th a {
  color: inherit;
  text-decoration: none;
}

.op-lookup-admin {
  display: grid;
  gap: 1rem;
  color: var(--portal-ink);
}

.op-lookup-hero,
.op-lookup-kpi,
.op-lookup-list-panel,
.op-lookup-values-panel {
  border: 1px solid var(--portal-line);
  border-radius: 8px;
  background: var(--portal-surface);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .035);
}

.op-lookup-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 1.25rem;
  border-left: 4px solid var(--portal-accent);
  background:
    linear-gradient(135deg, rgba(35, 153, 155, .12), rgba(47, 74, 131, .06)),
    var(--portal-surface);
}

.op-lookup-hero h1 {
  margin: .12rem 0 .25rem;
  font-size: clamp(1.45rem, 2vw, 2rem);
  font-weight: 800;
}

.op-lookup-hero p,
.op-lookup-panel-head p,
.op-lookup-list-card em,
.op-lookup-kpi small {
  margin: 0;
  color: var(--portal-muted);
}

.op-lookup-kicker {
  color: #137d80;
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.op-lookup-kpis {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: .75rem;
}

.op-lookup-kpi {
  position: relative;
  min-height: 96px;
  padding: .85rem 1rem;
  overflow: hidden;
}

.op-lookup-kpi::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  content: "";
  background: var(--portal-primary);
}

.op-lookup-kpi span {
  display: block;
  color: var(--portal-muted);
  font-size: .76rem;
  font-weight: 800;
  text-transform: uppercase;
}

.op-lookup-kpi strong {
  display: block;
  margin: .35rem 0 .2rem;
  color: var(--portal-ink);
  font-size: 1.75rem;
  line-height: 1;
}

.op-lookup-shell {
  display: grid;
  grid-template-columns: minmax(260px, 340px) minmax(0, 1fr);
  gap: 1rem;
  align-items: start;
}

.op-lookup-list-panel,
.op-lookup-values-panel {
  min-width: 0;
}

.op-lookup-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
  padding: 1rem;
  border-bottom: 1px solid var(--portal-line);
}

.op-lookup-panel-head h2 {
  margin: 0 0 .18rem;
  font-size: 1.05rem;
  font-weight: 800;
}

.op-lookup-list-stack {
  display: grid;
  gap: .55rem;
  padding: .75rem;
}

.op-lookup-list-card {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: .7rem;
  align-items: center;
  padding: .8rem;
  border: 1px solid var(--portal-line);
  border-radius: 8px;
  color: var(--portal-ink);
  text-decoration: none;
  background: #fff;
}

.op-lookup-list-card:hover,
.op-lookup-list-card:focus {
  border-color: var(--portal-accent);
  color: var(--portal-ink);
  background: rgba(35, 153, 155, .06);
}

.op-lookup-list-card.is-selected {
  border-color: var(--portal-primary);
  box-shadow: inset 4px 0 0 var(--portal-primary);
}

.op-lookup-list-icon,
.op-lookup-value-icon {
  display: inline-grid;
  place-items: center;
  border-radius: 8px;
  color: #1d3b75;
  background: rgba(47, 74, 131, .1);
  font-weight: 800;
}

.op-lookup-list-icon {
  width: 36px;
  height: 36px;
}

.op-lookup-list-main {
  display: grid;
  gap: .1rem;
  min-width: 0;
}

.op-lookup-list-main strong,
.op-lookup-list-main small,
.op-lookup-list-main em {
  overflow: hidden;
  text-overflow: ellipsis;
}

.op-lookup-list-main small {
  color: var(--portal-primary);
  font-size: .74rem;
  font-weight: 800;
}

.op-lookup-list-main em {
  display: block;
  font-size: .78rem;
  font-style: normal;
  white-space: nowrap;
}

.op-lookup-list-count,
.op-lookup-context-chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: .18rem .5rem;
  border-radius: 999px;
  color: #244a8f;
  background: rgba(47, 74, 131, .1);
  font-size: .75rem;
  font-weight: 800;
  white-space: nowrap;
}

.op-lookup-filter {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) minmax(140px, 180px) minmax(130px, 160px) auto;
  gap: .75rem;
  align-items: end;
  padding: 1rem;
  border-bottom: 1px solid var(--portal-line);
  background: var(--portal-soft);
}

.op-lookup-filter-actions {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
}

.op-lookup-table-wrap {
  padding: 1rem;
}

.op-lookup-table {
  margin-bottom: 0;
}

.op-lookup-value-icon {
  width: 38px;
  height: 38px;
  text-transform: uppercase;
}

.op-lookup-status {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: .15rem .5rem;
  border-radius: 999px;
  font-size: .75rem;
  font-weight: 800;
}

.op-lookup-status.is-active {
  color: #166534;
  background: rgba(36, 161, 72, .12);
}

.op-lookup-status.is-passive {
  color: #475569;
  background: #e2e8f0;
}

.op-lookup-empty {
  display: grid;
  justify-items: center;
  gap: .3rem;
  padding: 2rem 1rem;
  color: var(--portal-muted);
  text-align: center;
}

.op-lookup-empty i {
  color: var(--portal-primary);
  font-size: 1.8rem;
}

.op-lookup-empty strong {
  color: var(--portal-ink);
}

.op-lookup-form-context {
  display: grid;
  gap: .12rem;
  padding: .85rem 1rem;
  border: 1px solid var(--portal-line);
  border-left: 4px solid var(--portal-accent);
  border-radius: 8px;
  background: var(--portal-soft);
}

.op-lookup-form-context span {
  color: var(--portal-muted);
  font-size: .75rem;
  font-weight: 800;
  text-transform: uppercase;
}

.op-lookup-form-context strong {
  color: var(--portal-ink);
}

.op-lookup-form-context small {
  color: var(--portal-muted);
}

@media (max-width: 1100px) {
  .op-lookup-shell {
    grid-template-columns: 1fr;
  }

  .op-lookup-list-stack {
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  }
}

@media (max-width: 768px) {
  .op-lookup-hero,
  .op-lookup-panel-head {
    align-items: stretch;
    flex-direction: column;
  }

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

.loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .75rem;
  background: rgba(255, 255, 255, .65);
  color: var(--bs-body-color);
  font-weight: 600;
}

.corporate-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding-bottom: 1rem;
  border-bottom: 1px solid var(--bs-border-color);
}

.corporate-card-header h1 {
  font-size: clamp(1.55rem, 2.4vw, 2.2rem);
  line-height: 1.15;
}

.corporate-metric-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: .75rem;
}

.corporate-metric {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .15rem .65rem;
  align-items: center;
  min-height: 74px;
  padding: .85rem 1rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-body-bg);
}

.corporate-metric i {
  grid-row: span 2;
  font-size: 1.35rem;
  color: var(--bs-primary);
}

.corporate-metric span {
  color: var(--bs-secondary-color);
  font-size: .82rem;
}

.corporate-metric strong {
  font-size: 1.05rem;
  overflow-wrap: anywhere;
}

.corporate-card-content {
  padding: 1rem 0 2rem;
}

.corporate-field-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: .75rem;
}

.corporate-field,
.corporate-section {
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-body-bg);
}

.corporate-field {
  padding: .85rem 1rem;
}

.corporate-field span {
  display: block;
  color: var(--bs-secondary-color);
  font-size: .82rem;
  margin-bottom: .25rem;
}

.corporate-field strong {
  display: block;
  overflow-wrap: anywhere;
}

.corporate-relation-grid {
  display: grid;
  gap: 1rem;
}

.corporate-section {
  padding: 1rem;
}

.corporate-section h2,
.corporate-pane-title {
  font-size: 1.05rem;
  margin: 0 0 .25rem;
}

.corporate-section p {
  margin: 0;
  color: var(--bs-secondary-color);
}

.corporate-relation-list {
  display: grid;
  gap: .5rem;
}

.technical-detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: .85rem;
}

.technical-detail-card {
  display: grid;
  gap: .65rem;
  padding: 1rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-body-bg);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .04);
}

.technical-detail-card.is-passive {
  opacity: .7;
}

.technical-detail-card__head,
.technical-detail-card__meta,
.technical-detail-card__actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: .5rem;
}

.technical-detail-card h3 {
  margin: 0;
  font-size: 1rem;
  font-weight: 800;
}

.technical-detail-card p {
  min-height: 3.5rem;
  margin: 0;
  color: var(--bs-body-color);
  white-space: pre-wrap;
  overflow-wrap: anywhere;
}

.technical-detail-card__meta {
  color: var(--bs-secondary-color);
  font-size: .82rem;
}

.technical-category {
  display: inline-flex;
  align-items: center;
  padding: .22rem .5rem;
  border-radius: 999px;
  background: rgba(36, 74, 143, .1);
  color: #244a8f;
  font-size: .72rem;
  font-weight: 800;
}

.technical-template-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

.technical-editor {
  min-height: 190px;
  resize: vertical;
  line-height: 1.45;
}

.corporate-relation-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .75rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-tertiary-bg);
}

.corporate-empty {
  padding: 1rem;
  border: 1px dashed var(--bs-border-color);
  border-radius: 8px;
  color: var(--bs-secondary-color);
  background: var(--bs-tertiary-bg);
}

.corporate-upload-zone {
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  padding: 1rem;
  background: var(--bs-tertiary-bg);
}

.corporate-upload-zone.is-drag-over {
  border-color: var(--bs-primary);
  box-shadow: 0 0 0 .2rem rgba(13, 110, 253, .12);
}

.corporate-drop-surface {
  min-height: 86px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: .85rem 1rem;
  border: 2px dashed var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-body-bg);
}

.corporate-gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1rem;
}

.corporate-gallery-item {
  margin: 0;
  padding: .75rem;
  border: 1px solid var(--bs-border-color);
  border-radius: 8px;
  background: var(--bs-body-bg);
}

.corporate-gallery-item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 6px;
  background: var(--bs-tertiary-bg);
}

.corporate-gallery-item figcaption {
  display: grid;
  gap: .15rem;
  margin-top: .5rem;
}

.corporate-gallery-item figcaption span {
  font-weight: 600;
  overflow-wrap: anywhere;
}

.corporate-gallery-item figcaption small {
  color: var(--bs-secondary-color);
}

@media (max-width: 768px) {
  .corporate-card-header,
  .corporate-relation-row,
  .corporate-drop-surface {
    align-items: stretch;
    flex-direction: column;
  }
}

.portal-dashboard {
  --dashboard-ink: #172033;
  --dashboard-muted: #64748b;
  --dashboard-line: #dbe3ee;
  --dashboard-surface: #ffffff;
  --dashboard-soft: #f5f8fb;
  display: grid;
  gap: 1rem;
  padding: 1rem;
  color: var(--dashboard-ink);
}

.dashboard-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 1.25rem;
  border: 1px solid var(--dashboard-line);
  border-left: 4px solid #23999b;
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(35, 153, 155, .12), rgba(47, 74, 131, .06)),
    var(--dashboard-surface);
}

.dashboard-hero h1 {
  margin: .15rem 0 .25rem;
  font-size: clamp(1.55rem, 2vw, 2.15rem);
  font-weight: 700;
  letter-spacing: 0;
}

.dashboard-hero p,
.dashboard-toolbar p {
  margin: 0;
  color: var(--dashboard-muted);
  font-size: .9rem;
}

.dashboard-kicker {
  color: #137d80;
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.dashboard-actions,
.dashboard-toolbar-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .5rem;
}

.dashboard-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: .75rem;
}

.dashboard-kpi {
  display: block;
  position: relative;
  min-height: 112px;
  padding: .9rem 1rem;
  overflow: hidden;
  border: 1px solid var(--dashboard-line);
  border-radius: 8px;
  background: var(--dashboard-surface);
  color: inherit;
  text-decoration: none;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.dashboard-kpi:hover,
.dashboard-kpi:focus-visible {
  border-color: var(--kpi-accent, #2f4a83);
  box-shadow: 0 12px 26px rgba(15, 23, 42, .1);
  color: inherit;
  text-decoration: none;
  transform: translateY(-1px);
}

.dashboard-kpi:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--kpi-accent, #2f4a83) 38%, transparent);
  outline-offset: 2px;
}

.dashboard-kpi::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  content: "";
  background: var(--kpi-accent, #2f4a83);
}

.dashboard-kpi span,
.dashboard-kpi small {
  display: block;
  color: var(--dashboard-muted);
}

.dashboard-kpi span {
  font-size: .78rem;
  font-weight: 700;
  text-transform: uppercase;
}

.dashboard-kpi strong {
  display: block;
  margin: .45rem 0 .25rem;
  color: var(--dashboard-ink);
  font-size: clamp(1.4rem, 2.4vw, 2rem);
  line-height: 1;
}

.dashboard-kpi small {
  font-size: .8rem;
}

.dashboard-kpi--blue { --kpi-accent: #2f4a83; }
.dashboard-kpi--teal { --kpi-accent: #23999b; }
.dashboard-kpi--indigo { --kpi-accent: #4f46e5; }
.dashboard-kpi--slate { --kpi-accent: #64748b; }
.dashboard-kpi--green { --kpi-accent: #24a148; }
.dashboard-kpi--amber { --kpi-accent: #f59e0b; }
.dashboard-kpi--red { --kpi-accent: #dc2626; }
.dashboard-kpi--purple { --kpi-accent: #7c3aed; }
.dashboard-kpi--orange { --kpi-accent: #ea580c; }

.dashboard-alert-strip {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: .75rem;
}

.dashboard-alert {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: .75rem;
  min-height: 72px;
  padding: .8rem .9rem;
  border: 1px solid var(--dashboard-line);
  border-radius: 8px;
  background: var(--dashboard-surface);
  color: inherit;
  text-decoration: none;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}

.dashboard-alert:hover,
.dashboard-alert:focus-visible {
  border-color: var(--alert-color, #2f4a83);
  box-shadow: 0 10px 22px rgba(15, 23, 42, .09);
  color: inherit;
  text-decoration: none;
  transform: translateY(-1px);
}

.dashboard-alert:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--alert-color, #2f4a83) 34%, transparent);
  outline-offset: 2px;
}

.dashboard-alert i {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 8px;
  color: var(--alert-color, #2f4a83);
  background: var(--alert-bg, rgba(47, 74, 131, .12));
}

.dashboard-alert strong,
.dashboard-alert span {
  display: block;
}

.dashboard-alert strong {
  margin-bottom: .12rem;
  font-size: .9rem;
}

.dashboard-alert span {
  color: var(--dashboard-muted);
  font-size: .82rem;
  line-height: 1.35;
}

.dashboard-alert--danger { --alert-color: #dc2626; --alert-bg: rgba(220, 38, 38, .12); }
.dashboard-alert--warning { --alert-color: #d97706; --alert-bg: rgba(245, 158, 11, .16); }
.dashboard-alert--success { --alert-color: #24a148; --alert-bg: rgba(36, 161, 72, .12); }
.dashboard-alert--primary { --alert-color: #2f4a83; --alert-bg: rgba(47, 74, 131, .12); }
.dashboard-alert--info { --alert-color: #0ea5e9; --alert-bg: rgba(14, 165, 233, .13); }

.dashboard-workbench,
.dashboard-panel {
  border: 1px solid var(--dashboard-line);
  border-radius: 8px;
  background: var(--dashboard-surface);
}

.dashboard-toolbar {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  padding: 1rem 1rem .85rem;
  border-bottom: 1px solid var(--dashboard-line);
}

.dashboard-toolbar h2,
.dashboard-panel h2 {
  margin: 0;
  font-size: 1rem;
  font-weight: 700;
}

.dashboard-widget-menu {
  min-width: 230px;
}

.dashboard-widget-menu label {
  display: flex;
  align-items: center;
  gap: .55rem;
  min-height: 32px;
  padding: .25rem .35rem;
  color: var(--dashboard-ink);
  font-size: .85rem;
  cursor: pointer;
}

.dashboard-widget-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: .85rem;
  padding: .85rem;
  background: var(--dashboard-soft);
}

.dashboard-widget {
  grid-column: span 4;
  min-width: 0;
  border: 1px solid var(--dashboard-line);
  border-radius: 8px;
  background: var(--dashboard-surface);
  box-shadow: 0 8px 18px rgba(15, 23, 42, .04);
}

.dashboard-widget--wide {
  grid-column: span 6;
}

.dashboard-widget--full {
  grid-column: 1 / -1;
}

.dashboard-widget[hidden] {
  display: none;
}

.dashboard-widget--dragging {
  opacity: .45;
}

.dashboard-widget header,
.dashboard-panel header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: .75rem;
}

.dashboard-widget header {
  min-height: 66px;
  padding: .8rem .85rem .35rem;
}

.dashboard-widget header span {
  display: block;
  color: var(--dashboard-muted);
  font-size: .76rem;
  font-weight: 700;
  text-transform: uppercase;
}

.dashboard-widget header strong {
  display: block;
  margin-top: .2rem;
  font-size: .95rem;
  font-weight: 700;
}

.dashboard-widget-controls {
  display: none;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: .25rem;
}

.dashboard-editing .dashboard-widget-controls {
  display: flex;
}

.dashboard-editing .dashboard-widget {
  cursor: move;
}

.dashboard-widget-controls button {
  display: inline-grid;
  place-items: center;
  width: 28px;
  height: 28px;
  padding: 0;
  border: 1px solid var(--dashboard-line);
  border-radius: 6px;
  color: #2f4a83;
  background: #fff;
}

.dashboard-widget-controls button:hover {
  border-color: #2f4a83;
  background: rgba(47, 74, 131, .08);
}

.dashboard-chart {
  width: 100%;
  height: 292px;
  min-height: 292px;
}

.dashboard-widget--full .dashboard-chart {
  height: 360px;
}

.dashboard-bottom-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, .65fr);
  gap: 1rem;
}

.dashboard-panel {
  min-width: 0;
  padding: 1rem;
}

.dashboard-panel header {
  margin-bottom: .75rem;
}

.dashboard-panel header a {
  font-size: .84rem;
  font-weight: 600;
  text-decoration: none;
}

.dashboard-table {
  margin-bottom: 0;
}

.dashboard-table th {
  color: var(--dashboard-muted);
  font-size: .74rem;
  text-transform: uppercase;
  white-space: nowrap;
}

.dashboard-table td {
  color: var(--dashboard-ink);
  font-size: .86rem;
}

.dashboard-status {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: .15rem .5rem;
  border-radius: 999px;
  font-size: .76rem;
  font-weight: 700;
}

.dashboard-status--success {
  color: #166534;
  background: rgba(36, 161, 72, .12);
}

.dashboard-status--danger {
  color: #991b1b;
  background: rgba(220, 38, 38, .12);
}

.dashboard-status--muted {
  color: #475569;
  background: #e2e8f0;
}

.dashboard-gateway-list {
  display: grid;
  gap: .75rem;
}

.dashboard-gateway-row {
  display: grid;
  gap: .45rem;
  padding: .75rem;
  border: 1px solid var(--dashboard-line);
  border-radius: 8px;
  background: var(--dashboard-soft);
}

.dashboard-gateway-row strong,
.dashboard-gateway-row span,
.dashboard-gateway-row small {
  display: block;
}

.dashboard-gateway-row strong {
  font-size: .9rem;
}

.dashboard-gateway-row span,
.dashboard-gateway-row small {
  color: var(--dashboard-muted);
  font-size: .78rem;
}

.dashboard-mini-bar {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: #dbe3ee;
}

.dashboard-mini-bar span {
  display: block;
  height: 100%;
  min-width: 2px;
  border-radius: inherit;
  background: linear-gradient(90deg, #23999b, #24a148);
}

@media (max-width: 1200px) {
  .dashboard-widget,
  .dashboard-widget--wide {
    grid-column: span 6;
  }
}

@media (max-width: 992px) {
  .dashboard-bottom-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-widget,
  .dashboard-widget--wide,
  .dashboard-widget--full {
    grid-column: 1 / -1;
  }
}

@media (max-width: 768px) {
  .portal-dashboard {
    padding: .75rem;
  }

  .dashboard-hero,
  .dashboard-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .dashboard-actions,
  .dashboard-toolbar-actions {
    justify-content: flex-start;
  }

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

  .dashboard-kpi {
    min-height: 104px;
  }

  .dashboard-chart,
  .dashboard-widget--full .dashboard-chart {
    height: 260px;
    min-height: 260px;
  }
}

@media (max-width: 520px) {
  .dashboard-kpi-grid,
  .dashboard-alert-strip {
    grid-template-columns: 1fr;
  }
}

.op-theme-toggle {
  color: rgba(255, 255, 255, .88);
}

.op-theme-toggle:hover,
.op-theme-toggle:focus,
.op-theme-toggle.is-dark {
  color: #fff;
  background: rgba(255, 255, 255, .14);
}

html[data-bs-theme="dark"] {
  color-scheme: dark;
  --portal-ink: #e6edf7;
  --portal-muted: #9fb0c5;
  --portal-line: #2b3a4f;
  --portal-surface: #111a27;
  --portal-soft: #0b1220;
  --portal-accent: #35c9c3;
  --portal-primary: #8aa7ff;
}

html[data-bs-theme="dark"] body {
  background: #0b1220;
  color: var(--portal-ink);
}

html[data-bs-theme="dark"] .content {
  background: #0b1220;
}

html[data-bs-theme="dark"] .mainnav {
  background: #111a27;
  border-right: 1px solid var(--portal-line);
}

html[data-bs-theme="dark"] .mainnav__caption,
html[data-bs-theme="dark"] .mainnav .nav-link,
html[data-bs-theme="dark"] .mainnav .nav-label {
  color: #d7e2ef;
}

html[data-bs-theme="dark"] .mainnav .nav-link:hover {
  background: rgba(53, 201, 195, .1);
  color: #f8fbff;
}

html[data-bs-theme="dark"] #content .content__wrap > .d-flex.flex-wrap.justify-content-between.align-items-start.mb-3.gap-2,
html[data-bs-theme="dark"] #content .content__wrap > h1:first-child {
  border-color: var(--portal-line);
  background:
    linear-gradient(135deg, rgba(53, 201, 195, .14), rgba(138, 167, 255, .08)),
    var(--portal-surface);
}

html[data-bs-theme="dark"] #content .content__wrap > .d-flex.flex-wrap.justify-content-between.align-items-start.mb-3.gap-2 h1,
html[data-bs-theme="dark"] #content .content__wrap > h1:first-child {
  color: var(--portal-ink);
}

html[data-bs-theme="dark"] #content .content__wrap > .d-flex.flex-wrap.justify-content-between.align-items-start.mb-3.gap-2 .text-muted,
html[data-bs-theme="dark"] #content .content__wrap .text-muted {
  color: var(--portal-muted) !important;
}

html[data-bs-theme="dark"] #content .content__wrap .form-control,
html[data-bs-theme="dark"] #content .content__wrap .form-select {
  border-color: var(--portal-line);
  color: var(--portal-ink);
  background-color: #0f1724;
}

html[data-bs-theme="dark"] #content .content__wrap .form-control::placeholder {
  color: #7f91a8;
}

html[data-bs-theme="dark"] #content .content__wrap table.table:not(.dashboard-table) {
  background: var(--portal-surface);
  box-shadow: none;
  --bs-table-bg: #111a27;
  --bs-table-color: var(--portal-ink);
  --bs-table-striped-bg: #142033;
  --bs-table-striped-color: var(--portal-ink);
  --bs-table-hover-bg: #18283a;
  --bs-table-hover-color: #f8fbff;
  --bs-table-border-color: var(--portal-line);
}

html[data-bs-theme="dark"] #content .content__wrap table.table:not(.dashboard-table) > :not(caption) > * > * {
  color: var(--portal-ink);
  border-bottom-color: var(--portal-line);
}

html[data-bs-theme="dark"] #content .content__wrap table.table:not(.dashboard-table) thead th {
  color: #d7e2ef;
  background: #162236;
  border-bottom-color: var(--portal-line);
}

html[data-bs-theme="dark"] #content .content__wrap .page-link {
  border-color: var(--portal-line);
  color: #c3d3ff;
  background: #111a27;
}

html[data-bs-theme="dark"] .erp-filter-panel {
  border-color: var(--portal-line);
  background:
    linear-gradient(180deg, rgba(17, 26, 39, .98), rgba(13, 21, 34, .98)),
    var(--portal-surface);
  box-shadow: none;
}

html[data-bs-theme="dark"] .op-lookup-hero,
html[data-bs-theme="dark"] .op-lookup-kpi,
html[data-bs-theme="dark"] .op-lookup-list-panel,
html[data-bs-theme="dark"] .op-lookup-values-panel,
html[data-bs-theme="dark"] .op-lookup-list-card {
  border-color: var(--portal-line);
  background: var(--portal-surface);
  box-shadow: none;
}

html[data-bs-theme="dark"] .op-lookup-hero {
  background:
    linear-gradient(135deg, rgba(53, 201, 195, .14), rgba(138, 167, 255, .08)),
    var(--portal-surface);
}

html[data-bs-theme="dark"] .op-lookup-kicker {
  color: #65e2dc;
}

html[data-bs-theme="dark"] .op-lookup-filter,
html[data-bs-theme="dark"] .op-lookup-form-context {
  border-color: var(--portal-line);
  background: #0f1724;
}

html[data-bs-theme="dark"] .op-lookup-list-card:hover,
html[data-bs-theme="dark"] .op-lookup-list-card:focus {
  background: rgba(53, 201, 195, .1);
}

html[data-bs-theme="dark"] .op-lookup-list-icon,
html[data-bs-theme="dark"] .op-lookup-value-icon,
html[data-bs-theme="dark"] .op-lookup-list-count,
html[data-bs-theme="dark"] .op-lookup-context-chip {
  color: #c3d3ff;
  background: rgba(138, 167, 255, .14);
}

html[data-bs-theme="dark"] .op-lookup-status.is-active {
  color: #8be6a7;
  background: rgba(36, 161, 72, .18);
}

html[data-bs-theme="dark"] .op-lookup-status.is-passive {
  color: #b7c5d8;
  background: #203047;
}

html[data-bs-theme="dark"] .loading-overlay {
  background: rgba(11, 18, 32, .72);
}

html[data-bs-theme="dark"] .corporate-field,
html[data-bs-theme="dark"] .corporate-section,
html[data-bs-theme="dark"] .corporate-gallery-item,
html[data-bs-theme="dark"] .corporate-metric,
html[data-bs-theme="dark"] .corporate-drop-surface,
html[data-bs-theme="dark"] .technical-detail-card {
  background: var(--portal-surface);
  border-color: var(--portal-line);
}

html[data-bs-theme="dark"] .technical-category {
  background: rgba(53, 201, 195, .12);
  color: #7de4dc;
}

html[data-bs-theme="dark"] .corporate-empty,
html[data-bs-theme="dark"] .corporate-relation-row,
html[data-bs-theme="dark"] .corporate-upload-zone {
  background: #0f1724;
  border-color: var(--portal-line);
}

html[data-bs-theme="dark"] .portal-dashboard {
  --dashboard-ink: #e6edf7;
  --dashboard-muted: #9fb0c5;
  --dashboard-line: #2b3a4f;
  --dashboard-surface: #111a27;
  --dashboard-soft: #0b1220;
}

html[data-bs-theme="dark"] .dashboard-hero {
  background:
    linear-gradient(135deg, rgba(53, 201, 195, .14), rgba(138, 167, 255, .08)),
    var(--dashboard-surface);
}

html[data-bs-theme="dark"] .dashboard-kicker {
  color: #65e2dc;
}

html[data-bs-theme="dark"] .dashboard-widget-grid {
  background: #0b1220;
}

html[data-bs-theme="dark"] .dashboard-widget,
html[data-bs-theme="dark"] .dashboard-kpi,
html[data-bs-theme="dark"] .dashboard-alert,
html[data-bs-theme="dark"] .dashboard-workbench,
html[data-bs-theme="dark"] .dashboard-panel {
  box-shadow: none;
}

html[data-bs-theme="dark"] .dashboard-widget-controls button {
  color: #c3d3ff;
  background: #0f1724;
  border-color: var(--dashboard-line);
}

html[data-bs-theme="dark"] .dashboard-widget-controls button:hover {
  background: rgba(138, 167, 255, .14);
  border-color: #8aa7ff;
}

html[data-bs-theme="dark"] .dashboard-table {
  --bs-table-bg: var(--dashboard-surface);
  --bs-table-color: var(--dashboard-ink);
  --bs-table-border-color: var(--dashboard-line);
}

html[data-bs-theme="dark"] .dashboard-status--success {
  color: #8be6a7;
  background: rgba(36, 161, 72, .18);
}

html[data-bs-theme="dark"] .dashboard-status--danger {
  color: #ffaaa5;
  background: rgba(220, 38, 38, .18);
}

html[data-bs-theme="dark"] .dashboard-status--muted {
  color: #b7c5d8;
  background: #203047;
}

html[data-bs-theme="dark"] .dashboard-gateway-row {
  background: #0f1724;
}

html[data-bs-theme="dark"] .dashboard-mini-bar {
  background: #25364d;
}
