/* Custom CSS for Dashboard */
body {
  font-size: .875rem;
}

body.dashboard-dark {
  --bg-main: #101318;
  --bg-panel: #1a2028;
  --bg-panel-soft: #212a34;
  --bg-sidebar: #2c3138;
  --bg-sidebar-soft: #373d45;
  --text-main: #e8eef5;
  --text-soft: #a8b3c2;
  --border-soft: #3f4752;
  --accent: #3aa5ff;
  --accent-2: #35d39a;
  background:
    radial-gradient(1200px 500px at 90% -10%, #1f2731 10%, transparent 55%),
    radial-gradient(900px 400px at 0% 100%, #1b2530 0%, transparent 60%),
    var(--bg-main);
  color: var(--text-main);
  font-family: "Space Grotesk", sans-serif;
  min-height: 100vh;
}

body.dashboard-light {
  --bg-main: #eef2f7;
  --bg-panel: #ffffff;
  --bg-panel-soft: #f7f9fc;
  --bg-sidebar: #d9dfe8;
  --bg-sidebar-soft: #cfd7e2;
  --text-main: #182433;
  --text-soft: #5b6c80;
  --border-soft: #c7d0dd;
  --accent: #1976d2;
  --accent-2: #1f9d7a;
  background:
    radial-gradient(1200px 520px at 95% -20%, #d8e4f4 0%, transparent 55%),
    radial-gradient(900px 420px at 0% 100%, #dce7f4 0%, transparent 60%),
    var(--bg-main);
  color: var(--text-main);
  font-family: "Space Grotesk", sans-serif;
  min-height: 100vh;
}

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

body.dashboard-dark .dashboard-topnav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
  position: sticky;
  top: 0;
  z-index: 1100;
  background: rgba(16, 19, 24, .88);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border-soft);
  padding: .8rem 1rem;
}

/* Keep modals above sticky top navigation */
body.dashboard-dark .modal {
  z-index: 1300;
}

body.dashboard-dark .modal-backdrop {
  z-index: 1290;
}

body.dashboard-dark .topnav-logo {
  height: 34px;
  width: auto;
}

body.dashboard-dark .topnav-title {
  color: #dce6f3;
  font-weight: 600;
}

body.dashboard-dark .topnav-menu {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

body.dashboard-dark .topnav-menu a {
  color: #c3cfdd;
  text-decoration: none;
  padding: .35rem .7rem;
  border-radius: .55rem;
  border: 1px solid transparent;
  font-size: .88rem;
}

body.dashboard-dark .topnav-menu a:hover {
  color: #fff;
  background: rgba(255, 255, 255, .08);
}

body.dashboard-dark .topnav-menu a.active {
  color: #fff;
  background: linear-gradient(90deg, rgba(58, 165, 255, .28), rgba(58, 165, 255, .06));
  border-color: rgba(58, 165, 255, .35);
}

body.dashboard-dark .dashboard-main {
  max-width: 1400px;
  margin: 0 auto;
}

.feather {
  width: 16px;
  height: 16px;
  vertical-align: text-bottom;
}

/*
 * Sidebar
 */
.sidebar {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  z-index: 100; /* Behind the navbar */
  padding: 48px 0 0; /* Height of navbar */
  box-shadow: inset -1px 0 0 rgba(0, 0, 0, .1);
}

.sidebar-sticky {
  position: relative;
  top: 0;
  height: calc(100vh - 48px);
  padding-top: .5rem;
  overflow-x: hidden;
  overflow-y: auto; /* Scrollable contents */
}

@supports ((position: -webkit-sticky) or (position: sticky)) {
  .sidebar-sticky {
    position: -webkit-sticky;
    position: sticky;
  }
}

body.dashboard-dark .dark-sidebar {
  background: linear-gradient(180deg, var(--bg-sidebar) 0%, var(--bg-sidebar-soft) 100%);
  border-right: 1px solid var(--border-soft);
  box-shadow: 8px 0 24px rgba(0, 0, 0, .22);
}

body.dashboard-dark .brand-block {
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: 14px;
  background: rgba(255, 255, 255, .02);
  padding: .9rem .75rem;
}

body.dashboard-dark .sidebar-divider {
  border-color: rgba(255, 255, 255, .15);
}

body.dashboard-dark .sidebar-heading {
  color: #ccd6e3;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: .78rem;
}

.sidebar .nav-link {
  font-weight: 500;
  color: #333;
  border-radius: 10px;
  margin-bottom: .4rem;
  padding: .65rem .8rem;
}

.sidebar .nav-link .feather {
  margin-right: 4px;
  color: #727272;
}

.sidebar .nav-link.active {
  color: #007bff;
}

body.dashboard-dark .sidebar .nav-link {
  color: #c8d2dd;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}

body.dashboard-dark .sidebar .nav-link:hover {
  background: rgba(255, 255, 255, .08);
  color: #ffffff;
  transform: translateX(3px);
}

body.dashboard-dark .sidebar .nav-link.active {
  color: #ffffff;
  background: linear-gradient(90deg, rgba(58, 165, 255, .28), rgba(58, 165, 255, .06));
  border: 1px solid rgba(58, 165, 255, .35);
}

.sidebar .nav-link:hover .feather,
.sidebar .nav-link.active .feather {
  color: inherit;
}

/*
 * Content
 */
[role="main"] {
  padding-top: 48px; /* Space for fixed navbar */
}

body.dashboard-dark .dashboard-content {
  color: var(--text-main);
}

body.dashboard-dark .hero-panel {
  background: linear-gradient(135deg, rgba(30, 37, 47, .95), rgba(23, 30, 39, .94));
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  padding: 1.1rem 1.25rem;
  margin-bottom: 1.25rem;
}

body.dashboard-dark .eyebrow {
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--text-soft);
  font-size: .72rem;
}

body.dashboard-dark .user-chip {
  background: rgba(255, 255, 255, .05);
  color: var(--text-main);
  border: 1px solid var(--border-soft);
}

body.dashboard-dark .user-chip:hover {
  background: rgba(255, 255, 255, .1);
  color: #fff;
}

body.dashboard-dark .server-time-chip {
  background: rgba(255, 255, 255, .04);
  color: #cfe0f1;
  border: 1px solid var(--border-soft);
  border-radius: .55rem;
  padding: .32rem .6rem;
  font-size: .8rem;
  white-space: nowrap;
}

.theme-mode-select {
  min-width: 94px;
}

.topnav-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: .5rem;
  flex-wrap: nowrap !important;
  white-space: nowrap;
  flex-shrink: 0;
}

.topnav-controls > * {
  flex: 0 0 auto;
}

.topnav-controls .user-chip {
  white-space: nowrap;
}

.topnav-controls .dropdown-toggle {
  white-space: nowrap;
}

.theme-toggle-btn {
  width: 36px;
  height: 36px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.theme-toggle-btn .theme-icon {
  font-size: 1rem;
  line-height: 1;
}

body.dashboard-dark .hero-card {
  background: linear-gradient(145deg, var(--bg-panel) 0%, var(--bg-panel-soft) 100%);
  border: 1px solid var(--border-soft);
  box-shadow: 0 12px 32px rgba(0, 0, 0, .24);
}

body.dashboard-dark .hero-card .lead {
  color: #d1d9e3;
}

body.dashboard-dark .text-soft {
  color: var(--text-soft);
}

body.dashboard-dark .dashboard-footer {
  border-top: 1px solid var(--border-soft);
  margin-top: 1rem;
  text-align: left;
  font-size: .82rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  flex-wrap: wrap;
}

body.dashboard-dark .dashboard-footer .footer-version {
  opacity: .9;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  white-space: nowrap;
}

@media (max-width: 767.98px) {
  body.dashboard-dark .dashboard-footer {
    align-items: flex-start;
  }
}

/*
 * Cards
 */
.card {
  margin-bottom: 1rem;
}

body.dashboard-dark .panel-card {
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  background: linear-gradient(160deg, #1a2028 0%, #202a34 100%);
  color: var(--text-main);
  box-shadow: 0 10px 26px rgba(0, 0, 0, .22);
}

body.dashboard-dark .panel-card .card-text {
  color: var(--text-soft);
}

body.dashboard-dark .table {
  color: var(--text-main);
}

body.dashboard-dark .table > :not(caption) > * > * {
  color: var(--text-main);
  border-color: var(--border-soft);
}

body.dashboard-dark .table thead th {
  color: #d7e3f0;
}

body.dashboard-dark .btn-accent {
  background: var(--accent);
  border-color: var(--accent);
  color: #08121f;
  font-weight: 600;
}

body.dashboard-dark .btn-accent:hover {
  background: #63bbff;
  border-color: #63bbff;
}

body.dashboard-dark .btn-accent-alt {
  background: var(--accent-2);
  border-color: var(--accent-2);
  color: #072116;
  font-weight: 600;
}

body.dashboard-dark .btn-accent-alt:hover {
  background: #5de2b2;
  border-color: #5de2b2;
}

body.dashboard-dark .dropdown-menu {
  background: #1f2730;
  border: 1px solid var(--border-soft);
}

body.dashboard-dark .dropdown-item {
  color: var(--text-main);
}

body.dashboard-dark .dropdown-item:hover {
  background: #2b3744;
}

body.login-page .login-shell {
  position: relative;
}

body.login-page .login-card {
  background: linear-gradient(155deg, rgba(26, 32, 40, .96) 0%, rgba(34, 43, 54, .96) 100%);
  border: 1px solid var(--border-soft);
  border-radius: 18px;
  box-shadow: 0 18px 44px rgba(0, 0, 0, .32);
  color: var(--text-main);
}

body.login-page h1 {
  font-weight: 700;
  letter-spacing: .01em;
}

body.login-page .login-subtitle {
  color: var(--text-soft);
  font-size: .95rem;
}

body.login-page .login-label {
  color: #d6deea;
  font-size: .84rem;
  letter-spacing: .03em;
  margin-bottom: .45rem;
}

body.login-page .login-input-group .input-group-text {
  background: #252f3a;
  border-color: #46515e;
  color: #9eb0c5;
  min-width: 2.8rem;
  justify-content: center;
}

body.login-page .login-input-group .form-control {
  background: #1b232d;
  border-color: #46515e;
  color: #ecf2f9;
  padding-top: .68rem;
  padding-bottom: .68rem;
}

body.login-page .login-input-group .form-control::placeholder {
  color: #7f8da0;
}

body.login-page .login-input-group .form-control:focus {
  border-color: #6dbdfc;
  box-shadow: 0 0 0 .2rem rgba(58, 165, 255, .2);
  background: #1c2631;
}

body.login-page .register-link {
  color: #9ccfff;
  text-decoration: none;
}

body.login-page .register-link:hover {
  color: #d2e9ff;
}

body.login-page .alert {
  border: 1px solid rgba(255, 255, 255, .2);
}

body.connectors-page {
  --sidebar-w: 258px;
  --sidebar-collapsed-w: 86px;
}

body.connectors-page .collapsible-sidebar {
  width: var(--sidebar-w);
  transition: width .22s ease, transform .22s ease;
  padding-top: 0;
}

body.connectors-page .connectors-content {
  margin-left: 0;
  width: 100%;
  transition: margin-left .22s ease, width .22s ease;
}

body.connectors-page .connectors-card {
  overflow: hidden;
}

body.connectors-page .connectors-header {
  border-bottom: 1px solid var(--border-soft);
  background: rgba(255, 255, 255, .03);
}

body.connectors-page .connectors-table {
  color: var(--text-main);
  margin-bottom: 0;
  background: transparent;
}

body.connectors-page .connectors-table thead th {
  color: #c7d2df;
  border-bottom-color: var(--border-soft);
  border-top: 0;
}

body.dashboard-dark .connectors-table > :not(caption) > * > * {
  background-color: transparent;
}

body.dashboard-dark .connectors-table thead th {
  background: rgba(255, 255, 255, .03);
}

body.connectors-page .connectors-table td {
  border-color: var(--border-soft);
  vertical-align: middle;
}

body.connectors-page .connectors-table.table-striped > tbody > tr:nth-of-type(odd) > * {
  color: var(--text-main);
  background-color: rgba(255, 255, 255, .02);
}

body.dashboard-dark .connectors-table tbody tr:hover > * {
  background: rgba(255, 255, 255, .05);
}

body.connectors-page .connectors-chart-wrap {
  background: rgba(255, 255, 255, .02);
  border: 1px solid var(--border-soft);
}

body.customdash-page .customdash-list-item {
  background: rgba(255, 255, 255, .02);
  color: var(--text-main);
  border: 1px solid var(--border-soft);
  margin-bottom: .4rem;
  border-radius: .5rem;
  padding: .4rem .75rem;
  margin-right: .45rem;
  margin-top: .2rem;
}

body.customdash-page .customdash-list-item:hover,
body.customdash-page .customdash-list-item:focus {
  background: rgba(255, 255, 255, .08);
  color: #fff;
}

body.customdash-page .customdash-list-item.active {
  background: linear-gradient(90deg, rgba(58, 165, 255, .28), rgba(58, 165, 255, .06));
  border-color: rgba(58, 165, 255, .35);
  color: #fff;
}

body.customdash-page .dashboard-pills {
  display: flex;
  flex-wrap: wrap;
}

body.customdash-page .customdash-toolbar .form-label {
  color: var(--text-soft);
  font-size: .8rem;
}

body.customdash-page .customdash-toolbar-field {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
}

body.customdash-page .customdash-filter-row {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr)) auto;
  gap: .55rem;
  align-items: end;
}

body.customdash-page.dashboard-header-hidden .dashboard-topnav,
body.customdash-page.dashboard-header-hidden .hero-panel {
  display: none !important;
}

body.customdash-page.dashboard-header-hidden .connectors-content.dashboard-content {
  padding-top: .65rem !important;
}

body.customdash-page .customdash-filter-actions {
  display: inline-flex;
  gap: .45rem;
  align-items: center;
}

body.customdash-page .customdash-quick-row {
  grid-template-columns: auto minmax(220px, 1fr);
  align-items: center;
}

body.customdash-page .customdash-quick-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: .4rem;
  padding: .3rem .35rem;
  border: 1px dashed var(--border-soft);
  border-radius: .55rem;
  background: rgba(255, 255, 255, .02);
}

body.customdash-page .customdash-quick-actions .btn {
  width: 34px;
  height: 34px;
  min-width: 34px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

body.customdash-page .customdash-quick-info {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  padding: 0 .2rem;
}

body.customdash-page .customdash-quick-policy {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}

body.customdash-page .customdash-quick-policy .form-select {
  min-width: 120px;
}

body.customdash-page #resumeRetryRemainingBtn {
  width: auto;
  min-width: 34px;
  padding: 0 .5rem;
  gap: .35rem;
}

body.customdash-page #resumeRetryRemainingBtn .resume-retry-count {
  font-size: .74rem;
  font-weight: 600;
  line-height: 1;
}

body.customdash-page .retry-progress-wrap {
  width: 180px;
  height: 8px;
  border-radius: 999px;
  border: 1px solid var(--border-soft);
  background: rgba(255, 255, 255, .05);
  overflow: hidden;
  display: none;
}

body.customdash-page .retry-progress-wrap.is-active {
  display: inline-block;
}

body.customdash-page .retry-progress-bar {
  height: 100%;
  width: 0%;
  background: linear-gradient(
    135deg,
    rgba(56, 189, 248, .95) 25%,
    rgba(34, 197, 94, .95) 25%,
    rgba(34, 197, 94, .95) 50%,
    rgba(56, 189, 248, .95) 50%,
    rgba(56, 189, 248, .95) 75%,
    rgba(34, 197, 94, .95) 75%,
    rgba(34, 197, 94, .95) 100%
  );
  background-size: 22px 22px;
  transition: width .25s ease;
}

body.customdash-page .retry-progress-bar.is-running {
  animation: retryProgressStripe 0.9s linear infinite;
}

body.customdash-page .retry-progress-bar.is-success {
  background: linear-gradient(90deg, rgba(34, 197, 94, .95), rgba(22, 163, 74, .95));
  animation: none;
}

body.customdash-page .retry-progress-bar.is-error {
  background: linear-gradient(90deg, rgba(239, 68, 68, .95), rgba(220, 38, 38, .95));
  animation: none;
}

@keyframes retryProgressStripe {
  0% {
    background-position: 0 0;
  }
  100% {
    background-position: 22px 0;
  }
}

body.customdash-page #dashboardFilterSummary {
  grid-column: 1 / -1;
}

body.customdash-page .dashboard-insights-panel {
  border: 1px solid var(--border-soft);
  border-radius: .6rem;
  padding: .7rem .8rem;
  background: rgba(255, 255, 255, .03);
}

body.customdash-page .dashboard-insights-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: .6rem;
  margin-bottom: .55rem;
}

body.customdash-page .dashboard-insights-title {
  font-weight: 700;
  font-size: .92rem;
}

body.customdash-page .dashboard-insights-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .5rem;
}

body.customdash-page .dashboard-freshness-badge {
  margin-top: .28rem;
  display: inline-flex;
  align-items: center;
  padding: .12rem .5rem;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 700;
  border: 1px solid var(--border-soft);
}

body.customdash-page .dashboard-freshness-badge.freshness-unknown {
  color: #94a3b8;
  background: rgba(148, 163, 184, .12);
}

body.customdash-page .dashboard-freshness-badge.freshness-live {
  color: #38bdf8;
  background: rgba(56, 189, 248, .14);
  border-color: rgba(56, 189, 248, .45);
}

body.customdash-page .dashboard-freshness-badge.freshness-fresh {
  color: #22c55e;
  background: rgba(34, 197, 94, .14);
  border-color: rgba(34, 197, 94, .45);
}

body.customdash-page .dashboard-freshness-badge.freshness-warn {
  color: #f59e0b;
  background: rgba(245, 158, 11, .14);
  border-color: rgba(245, 158, 11, .45);
}

body.customdash-page .dashboard-freshness-badge.freshness-stale {
  color: #ef4444;
  background: rgba(239, 68, 68, .14);
  border-color: rgba(239, 68, 68, .45);
}

body.customdash-page .dashboard-freshness-badge.sync-health-unknown {
  color: #94a3b8;
  background: rgba(148, 163, 184, .12);
  border-color: rgba(148, 163, 184, .35);
}

body.customdash-page .dashboard-freshness-badge.sync-health-live {
  color: #38bdf8;
  background: rgba(56, 189, 248, .16);
  border-color: rgba(56, 189, 248, .5);
}

body.customdash-page .dashboard-freshness-badge.sync-health-success {
  color: #16a34a;
  background: rgba(34, 197, 94, .2);
  border-color: rgba(34, 197, 94, .55);
}

body.customdash-page .dashboard-freshness-badge.sync-health-failed {
  color: #dc2626;
  background: rgba(239, 68, 68, .2);
  border-color: rgba(239, 68, 68, .55);
}

body.customdash-page .dashboard-finding-item {
  border: 1px solid var(--border-soft);
  border-radius: .5rem;
  padding: .45rem .55rem;
  background: rgba(255, 255, 255, .02);
}

body.customdash-page .dashboard-finding-title {
  display: flex;
  align-items: center;
  gap: .45rem;
  font-weight: 600;
}

body.customdash-page .dashboard-finding-reason {
  margin-top: .35rem;
  font-size: .82rem;
}

body.customdash-page .widget-insight-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: .1rem .5rem;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .2px;
  border: 1px solid transparent;
}

body.customdash-page .widget-insight-good {
  background: rgba(34, 197, 94, .18);
  color: #bbf7d0;
  border-color: rgba(34, 197, 94, .42);
}

body.customdash-page .widget-insight-watch {
  background: rgba(250, 204, 21, .16);
  color: #fde68a;
  border-color: rgba(250, 204, 21, .4);
}

body.customdash-page .widget-insight-risk {
  background: rgba(239, 68, 68, .16);
  color: #fecaca;
  border-color: rgba(239, 68, 68, .42);
}

body.customdash-page .widget-data-quality-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  padding: .1rem .5rem;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .2px;
  border: 1px solid transparent;
}

body.customdash-page .widget-data-quality-ok {
  color: #16a34a;
  background: rgba(34, 197, 94, .14);
  border-color: rgba(34, 197, 94, .42);
}

body.customdash-page .widget-data-quality-partial {
  color: #d97706;
  background: rgba(245, 158, 11, .14);
  border-color: rgba(245, 158, 11, .4);
}

body.customdash-page .widget-data-quality-no_mapping {
  color: #b45309;
  background: rgba(251, 191, 36, .18);
  border-color: rgba(251, 191, 36, .45);
}

body.customdash-page .widget-data-quality-source_error {
  color: #dc2626;
  background: rgba(239, 68, 68, .16);
  border-color: rgba(239, 68, 68, .42);
  cursor: pointer;
  text-decoration: underline;
  text-decoration-style: dotted;
}

body.customdash-page .widget-data-quality-no_data {
  color: #64748b;
  background: rgba(148, 163, 184, .14);
  border-color: rgba(148, 163, 184, .4);
}

#widgetQualityModalRecoveryHint {
  border: 1px dashed var(--border-soft);
  border-radius: .55rem;
  padding: .55rem .65rem;
  background: rgba(255, 255, 255, .03);
}

body.customdash-page .customdash-refresh-inline {
  display: flex;
  flex-direction: column;
  gap: .35rem;
}

body.customdash-page .customdash-refresh-controls {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: .45rem;
}

body.customdash-page .customdash-refresh-status {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
}

body.customdash-page .customdash-refresh-controls .btn {
  width: auto;
}

body.customdash-page .customdash-meta-refresh-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .55rem 1rem;
  flex-wrap: wrap;
}

@media (max-width: 1399px) {
  body.customdash-page .customdash-filter-row {
    grid-template-columns: repeat(3, minmax(140px, 1fr));
  }
}

@media (max-width: 991px) {
  body.customdash-page .customdash-filter-row {
    grid-template-columns: repeat(2, minmax(140px, 1fr));
  }
  body.customdash-page .customdash-quick-row {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    gap: .45rem;
  }
  body.customdash-page .connectors-header {
    flex-wrap: wrap;
  }
  body.customdash-page .connectors-header .print-hide {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}

@media (max-width: 575px) {
  body.customdash-page .customdash-filter-row {
    grid-template-columns: minmax(0, 1fr);
  }
  body.customdash-page .customdash-filter-actions {
    justify-content: flex-start;
  }
  body.customdash-page .dashboard-insights-list {
    grid-template-columns: minmax(0, 1fr);
  }
  body.customdash-page .customdash-quick-actions {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 34px));
    justify-content: start;
  }
  body.customdash-page .customdash-quick-info {
    line-height: 1.3;
  }
  body.customdash-page .customdash-quick-policy {
    width: 100%;
    justify-content: flex-start;
  }
  body.customdash-page .customdash-quick-policy .form-select {
    max-width: 180px;
  }
  body.customdash-page .retry-progress-wrap {
    width: 100%;
    max-width: 240px;
  }
}

body.customdash-page .customdash-meta-refresh-row .dashboard-meta-grid {
  margin-top: 0;
  flex: 1 1 620px;
}

body.customdash-page .customdash-refresh-compact {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  margin-left: auto;
  flex: 0 0 auto;
}

body.customdash-page .customdash-refresh-compact .form-label {
  margin-bottom: 0;
  white-space: nowrap;
}

body.customdash-page .customdash-refresh-compact .customdash-refresh-controls {
  grid-template-columns: 112px auto;
}

body.customdash-page .widget-color-swatch {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: .35rem;
  border: 1px solid rgba(255, 255, 255, .35);
  vertical-align: middle;
}

body.customdash-page .widget-color-preset-btn.active {
  border-color: rgba(79, 179, 255, .72);
  box-shadow: inset 0 0 0 1px rgba(79, 179, 255, .45);
}

body.customdash-page .widget-palette-mix-preset-btn.active {
  border-color: rgba(79, 179, 255, .72);
  box-shadow: inset 0 0 0 1px rgba(79, 179, 255, .45);
}

body.customdash-page .widget-setting-tabs {
  border-bottom-color: rgba(255, 255, 255, .12);
}

body.customdash-page .widget-setting-tabs .nav-link {
  color: #c8d2dd;
  padding: .4rem .75rem;
  border: 1px solid transparent;
  border-bottom: 0;
}

body.customdash-page .widget-setting-tabs .nav-link:hover {
  color: #fff;
  border-color: rgba(255, 255, 255, .12);
}

body.customdash-page .widget-setting-tabs .nav-link.active {
  color: #fff;
  background: linear-gradient(180deg, rgba(58, 165, 255, .24), rgba(58, 165, 255, .08));
  border-color: rgba(58, 165, 255, .35);
}

body.customdash-page #widgetVisualModal .tab-pane {
  background: rgba(255, 255, 255, .02);
  border: 1px solid rgba(255, 255, 255, .08);
  border-radius: .55rem;
  padding: .75rem;
}

body.customdash-page .widget-style-layout .form-control-color {
  min-height: 2.3rem;
}

body.customdash-page .widget-style-preset-panel {
  border: 1px solid rgba(255, 255, 255, .1);
  border-radius: .5rem;
  padding: .65rem;
  background: rgba(255, 255, 255, .02);
}

body.customdash-page .widget-description {
  margin-top: .55rem;
  padding: .5rem .65rem;
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: .5rem;
  background: rgba(255, 255, 255, .04);
  white-space: pre-line;
  word-break: break-word;
}

body.dashboard-light.customdash-page .widget-description {
  border-color: #d6deea;
  background: #f8fbff;
}

body.dashboard-light.customdash-page .widget-setting-tabs {
  border-bottom-color: rgba(24, 36, 51, .18);
}

body.dashboard-light.customdash-page .widget-setting-tabs .nav-link {
  color: #344357;
}

body.dashboard-light.customdash-page .widget-setting-tabs .nav-link:hover {
  color: #182433;
  border-color: rgba(24, 36, 51, .2);
}

body.dashboard-light.customdash-page .widget-setting-tabs .nav-link.active {
  color: #182433;
  background: linear-gradient(180deg, rgba(25, 118, 210, .2), rgba(25, 118, 210, .08));
  border-color: rgba(25, 118, 210, .35);
}

body.dashboard-light.customdash-page #widgetVisualModal .tab-pane {
  background: #ffffff;
  border-color: #d6deea;
}

body.dashboard-light.customdash-page .widget-style-preset-panel {
  border-color: #d6deea;
  background: #f8fbff;
}

body.customdash-page .widget-visual-modal-dialog {
  max-width: min(1400px, 94vw);
}

body.customdash-page #widgetVisualModal .modal-body {
  overflow-y: auto;
}

@media (max-width: 767px) {
  body.customdash-page .customdash-toolbar .h2 {
    margin-bottom: .2rem !important;
  }
  body.customdash-page .customdash-toolbar .btn {
    width: 100%;
  }
  body.customdash-page .customdash-refresh-controls .btn {
    width: auto;
  }
  body.customdash-page .widget-style-preset-panel {
    margin-top: .25rem;
  }
}

@media (min-width: 1400px) {
  body.customdash-page .widget-visual-modal-dialog {
    max-width: min(1560px, 95vw);
  }
}

body.connectors-page .join-rule-row {
  border: 1px dashed rgba(255, 255, 255, .18);
  border-radius: 10px;
  padding: .65rem;
}

body.connectors-page .analysis-tip {
  border: 1px solid rgba(79, 179, 255, .35);
  background: rgba(79, 179, 255, .08);
  color: #d7ecff;
  padding: .65rem .8rem;
  border-radius: .5rem;
  font-size: .85rem;
}

body.connectors-page .advanced-box {
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: .6rem;
  padding: .85rem;
  background: rgba(255, 255, 255, .02);
}

body.connectors-page #joinAnalysisTabs {
  border-bottom-color: rgba(255, 255, 255, .15);
}

/* integrated-shell.css may override Bootstrap .nav to be vertical.
   Force Join Analysis tabs to stay horizontal on connectors page. */
body.connectors-page #joinAnalysisTabs.nav,
body.connectors-page #joinAnalysisTabs.nav-tabs {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
}

body.connectors-page #joinAnalysisTabs .nav-item {
  margin-bottom: 0 !important;
}

body.connectors-page #joinAnalysisTabs .nav-link {
  width: auto !important;
  display: block !important;
}

body.connectors-page #joinAnalysisTabs .nav-link {
  color: #c8d2dd;
}

body.connectors-page #joinAnalysisTabs .nav-link.active {
  color: #fff;
  background: rgba(79, 179, 255, .16);
  border-color: rgba(79, 179, 255, .4) rgba(79, 179, 255, .4) transparent;
}

body.connectors-page .relation-map-canvas {
  width: 100%;
  min-height: 320px;
  border: 1px solid rgba(255, 255, 255, .16);
  border-radius: .55rem;
  background: rgba(255, 255, 255, .02);
}

body.connectors-page .sidebar-toggle {
  border-color: var(--border-soft);
  color: var(--text-main);
}

body.connectors-page .sidebar-toggle:hover {
  background: rgba(255, 255, 255, .1);
}

body.connectors-page .collapsible-sidebar .nav-link .feather {
  width: 16px;
  height: 16px;
  margin-right: .5rem;
}

body.connectors-page.sidebar-collapsed .collapsible-sidebar {
  width: var(--sidebar-collapsed-w);
}

body.connectors-page.sidebar-collapsed .connectors-content {
  margin-left: var(--sidebar-collapsed-w);
  width: calc(100% - var(--sidebar-collapsed-w));
}

body.connectors-page.sidebar-collapsed .collapsible-sidebar .sidebar-heading,
body.connectors-page.sidebar-collapsed .collapsible-sidebar .brand-block h6 {
  display: none;
}

body.connectors-page.sidebar-collapsed .collapsible-sidebar .nav-link {
  display: flex;
  justify-content: center;
  padding: .78rem .45rem;
}

body.connectors-page.sidebar-collapsed .collapsible-sidebar .nav-link .nav-label {
  display: none;
}

body.connectors-page.sidebar-collapsed .collapsible-sidebar .nav-link .feather {
  margin-right: 0;
}

body.connectors-page .modal-content {
  background: linear-gradient(160deg, #1d242e 0%, #222d39 100%);
  border: 1px solid var(--border-soft);
  color: var(--text-main);
}

body.connectors-page .connector-modal-dialog {
  max-width: min(1380px, 96vw);
}

body.connectors-page .db-col-panel {
  background: rgba(16, 24, 34, .45);
  border: 1px solid var(--border-soft);
  border-radius: 12px;
  padding: .9rem;
  height: 100%;
}

body.connectors-page .db-col-title {
  font-weight: 700;
  font-size: .95rem;
  margin-bottom: .7rem;
  color: var(--text-main);
}

body.connectors-page .connector-wizard-head .connector-step-btn.active {
  background: rgba(77, 176, 255, .25);
  border-color: #6dbdfc;
  color: #dff0ff;
}

body.connectors-page .connector-wizard-progress {
  height: 10px;
  background: rgba(255, 255, 255, .12);
}

body.connectors-page .connector-wizard-progress .progress-bar {
  background: linear-gradient(90deg, #4fb3ff 0%, #7dd3fc 100%);
  font-size: 10px;
  line-height: 10px;
  color: #0b1620;
  font-weight: 700;
}

@media (max-width: 991.98px) {
  body.connectors-page .db-col-panel {
    padding: .75rem;
  }
}

/* Template Starter Alignment Layer
   - Harmonizes Dashboard shell with IAM starter visual tokens
   - Keeps existing page-specific widgets/features untouched
*/
:root {
  --tp-bg-1: #f3f5f9;
  --tp-bg-2: #dfe8f6;
  --tp-text: #1a2536;
  --tp-panel: #ffffff;
  --tp-accent: #0c5ecf;
  --tp-muted: #5e6d84;
  --tp-line: #d5ddeb;
  --tp-danger: #b42318;
}

body.dashboard-light {
  --tp-bg-1: #f3f5f9;
  --tp-bg-2: #dfe8f6;
  --tp-text: #1a2536;
  --tp-panel: #ffffff;
  --tp-accent: #0c5ecf;
  --tp-muted: #5e6d84;
  --tp-line: #d5ddeb;
  --tp-danger: #b42318;
}

body.dashboard-dark {
  --tp-bg-1: #0b1020;
  --tp-bg-2: #04060f;
  --tp-text: #e8edf7;
  --tp-panel: #11172a;
  --tp-accent: #4e9bff;
  --tp-muted: #98a6c2;
  --tp-line: #2a3552;
  --tp-danger: #ff8080;
}

body.dashboard-light,
body.dashboard-dark {
  background:
    radial-gradient(circle at top left, rgba(87, 141, 236, .16), transparent 42%),
    radial-gradient(circle at bottom right, rgba(69, 190, 146, .14), transparent 40%),
    linear-gradient(165deg, var(--tp-bg-1), var(--tp-bg-2));
  color: var(--tp-text);
  font-family: "Manrope", "Space Grotesk", "Segoe UI", sans-serif;
}

body.dashboard-light .dashboard-topnav,
body.dashboard-dark .dashboard-topnav {
  background: color-mix(in srgb, var(--tp-panel) 86%, transparent);
  border-bottom: 1px solid var(--tp-line);
  backdrop-filter: blur(8px);
}

body.dashboard-light .topnav-title,
body.dashboard-dark .topnav-title {
  color: var(--tp-accent);
  font-weight: 800;
}

body.dashboard-light .topnav-menu a,
body.dashboard-dark .topnav-menu a {
  color: var(--tp-muted);
  border: 1px solid transparent;
  border-radius: 10px;
  transition: background-color .16s ease, color .16s ease, border-color .16s ease;
}

body.dashboard-light .topnav-menu a:hover,
body.dashboard-dark .topnav-menu a:hover {
  background: color-mix(in srgb, var(--tp-accent) 12%, transparent);
  color: var(--tp-text);
}

body.dashboard-light .topnav-menu a.active,
body.dashboard-dark .topnav-menu a.active {
  color: var(--tp-accent);
  background: color-mix(in srgb, var(--tp-accent) 16%, transparent);
  border-color: color-mix(in srgb, var(--tp-accent) 35%, transparent);
}

body.dashboard-light .hero-panel,
body.dashboard-dark .hero-panel,
body.dashboard-light .hero-card,
body.dashboard-dark .hero-card,
body.dashboard-light .panel-card,
body.dashboard-dark .panel-card {
  background: var(--tp-panel);
  border: 1px solid var(--tp-line);
  border-radius: 14px;
  box-shadow: 0 8px 24px rgba(17, 35, 74, .10);
  color: var(--tp-text);
}

body.dashboard-light .text-soft,
body.dashboard-dark .text-soft,
body.dashboard-light .eyebrow,
body.dashboard-dark .eyebrow {
  color: var(--tp-muted);
}

body.dashboard-light .btn-accent,
body.dashboard-dark .btn-accent {
  background: var(--tp-accent);
  border-color: var(--tp-accent);
  color: #ffffff;
  font-weight: 700;
}

body.dashboard-light .btn-accent:hover,
body.dashboard-dark .btn-accent:hover {
  filter: brightness(1.06);
}

body.dashboard-light .btn-outline-soft,
body.dashboard-dark .btn-outline-soft,
body.dashboard-light .btn-outline-light,
body.dashboard-dark .btn-outline-light,
body.dashboard-light .user-chip,
body.dashboard-dark .user-chip,
body.dashboard-light .server-time-chip,
body.dashboard-dark .server-time-chip {
  border: 1px solid var(--tp-line);
  color: var(--tp-text);
  background: color-mix(in srgb, var(--tp-panel) 90%, transparent);
}

body.dashboard-light .btn-outline-soft:hover,
body.dashboard-dark .btn-outline-soft:hover,
body.dashboard-light .btn-outline-light:hover,
body.dashboard-dark .btn-outline-light:hover,
body.dashboard-light .user-chip:hover,
body.dashboard-dark .user-chip:hover,
body.dashboard-light .server-time-chip:hover,
body.dashboard-dark .server-time-chip:hover {
  background: color-mix(in srgb, var(--tp-accent) 12%, transparent);
  color: var(--tp-text);
}

body.dashboard-light .table,
body.dashboard-dark .table {
  color: var(--tp-text);
}

body.dashboard-light .table > :not(caption) > * > *,
body.dashboard-dark .table > :not(caption) > * > * {
  border-color: var(--tp-line);
}

body.dashboard-light .table thead th,
body.dashboard-dark .table thead th {
  color: color-mix(in srgb, var(--tp-text) 84%, var(--tp-muted));
  background: color-mix(in srgb, var(--tp-accent) 7%, var(--tp-panel));
}

body.dashboard-light .form-control,
body.dashboard-dark .form-control,
body.dashboard-light .form-select,
body.dashboard-dark .form-select,
body.dashboard-light .input-group-text,
body.dashboard-dark .input-group-text {
  background: var(--tp-panel);
  color: var(--tp-text);
  border-color: var(--tp-line);
}

body.dashboard-light .form-control:focus,
body.dashboard-dark .form-control:focus,
body.dashboard-light .form-select:focus,
body.dashboard-dark .form-select:focus {
  border-color: color-mix(in srgb, var(--tp-accent) 58%, var(--tp-line));
  box-shadow: 0 0 0 .18rem color-mix(in srgb, var(--tp-accent) 20%, transparent);
}

body.dashboard-light .dropdown-menu,
body.dashboard-dark .dropdown-menu {
  background: var(--tp-panel);
  border: 1px solid var(--tp-line);
  border-radius: 10px;
}

body.dashboard-light .dropdown-item,
body.dashboard-dark .dropdown-item {
  color: var(--tp-text);
}

body.dashboard-light .dropdown-item:hover,
body.dashboard-dark .dropdown-item:hover {
  background: color-mix(in srgb, var(--tp-accent) 12%, transparent);
}

body.dashboard-light .dashboard-footer,
body.dashboard-dark .dashboard-footer {
  border-top: 1px solid var(--tp-line);
  color: var(--tp-muted);
  background: color-mix(in srgb, var(--tp-panel) 86%, transparent);
}

body.connectors-page .modal-header,
body.connectors-page .modal-footer {
  border-color: var(--border-soft);
}

body.connectors-page .form-control,
body.connectors-page .form-select,
body.connectors-page textarea {
  background: #1a222c;
  border-color: #4a5564;
  color: var(--text-main);
}

body.connectors-page .form-control::placeholder,
body.connectors-page textarea::placeholder {
  color: #8b98aa;
}

body.connectors-page .form-control:focus,
body.connectors-page .form-select:focus,
body.connectors-page textarea:focus {
  border-color: #6dbdfc;
  box-shadow: 0 0 0 .2rem rgba(58, 165, 255, .2);
  background: #1c2631;
  color: var(--text-main);
}

@keyframes revealUp {
  from {
    opacity: 0;
    transform: translateY(12px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.reveal-up {
  animation: revealUp .5s ease both;
}

.delay-1 {
  animation-delay: .08s;
}

.delay-2 {
  animation-delay: .16s;
}

/* Dashboard shell mapped to starter app shell (left-nav + header + footer). */
.starter-app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
}

.starter-app-shell-nav-hidden {
  grid-template-columns: minmax(0, 1fr) !important;
}

.starter-app-shell-nav-hidden .starter-left-nav {
  display: none;
}

.starter-left-nav {
  border-right: 1px solid var(--tp-line);
  background: color-mix(in srgb, var(--tp-panel) 95%, transparent);
  padding: 18px 14px;
  position: sticky;
  top: 0;
  height: 100vh;
  overflow-y: auto;
}

.starter-left-nav-brand-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.starter-brand-logo {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  object-fit: contain;
  background: transparent;
  border: 0;
  padding: 0;
}

.starter-left-nav-brand {
  font-size: 20px;
  font-weight: 800;
  color: var(--tp-accent);
}

.starter-left-nav-caption {
  margin: 2px 0 0;
  color: var(--tp-muted);
  font-size: 12px;
}

.starter-left-nav-menu {
  display: grid;
  gap: 12px;
}

.starter-left-nav-group {
  display: grid;
  gap: 6px;
}

.starter-left-nav-group-title {
  margin: 2px 4px 0;
  padding: 4px 2px;
  border: 0;
  background: transparent;
  width: calc(100% - 8px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  text-align: left;
  cursor: pointer;
  color: var(--tp-muted);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.starter-left-nav-group-title:hover {
  color: var(--tp-text);
}

.starter-left-nav-group-items {
  display: grid;
  gap: 4px;
}

.starter-left-nav-group-collapsed {
  display: none;
}

.starter-nav-item {
  display: block;
  padding: 10px 12px;
  border-radius: 10px;
  color: var(--tp-muted);
  font-weight: 600;
  border: 1px solid transparent;
}

.starter-nav-item:hover {
  background: color-mix(in srgb, var(--tp-accent) 10%, transparent);
  color: var(--tp-accent);
}

.starter-nav-item-active {
  background: color-mix(in srgb, var(--tp-accent) 15%, transparent);
  color: var(--tp-accent);
  border-color: color-mix(in srgb, var(--tp-accent) 28%, transparent);
}

.starter-main-stack {
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 100vh;
  min-width: 0;
  width: 100%;
}

/* When left navigation is hidden, allow main dashboard content to use full width. */
body.dashboard-dark .starter-app-shell.starter-app-shell-nav-hidden .dashboard-main,
body.dashboard-light .starter-app-shell.starter-app-shell-nav-hidden .dashboard-main {
  max-width: none !important;
  width: 100% !important;
  margin: 0 !important;
}

/* Connectors-style pages also need explicit full-width behavior when nav is hidden. */
body.dashboard-dark .starter-app-shell.starter-app-shell-nav-hidden .connectors-content,
body.dashboard-light .starter-app-shell.starter-app-shell-nav-hidden .connectors-content {
  width: 100% !important;
  max-width: none !important;
  margin: 0 !important;
}

.starter-app-header {
  border-bottom: 1px solid var(--tp-line);
  background: color-mix(in srgb, var(--tp-panel) 90%, transparent);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  gap: 12px;
  /* Keep user dropdown overlays above page content/charts. */
  position: relative;
  z-index: 1200;
  overflow: visible;
}

.starter-header-left {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
  flex: 1 1 auto;
}

.starter-nav-toggle {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid var(--tp-line);
  background: var(--tp-panel);
  display: grid;
  align-content: center;
  gap: 4px;
  padding: 0 9px;
  cursor: pointer;
}

.starter-nav-toggle span {
  display: block;
  height: 2px;
  width: 100%;
  border-radius: 2px;
  background: var(--tp-text);
}

.starter-nav-toggle:hover {
  background: color-mix(in srgb, var(--tp-accent) 8%, var(--tp-panel));
}

.starter-header-brand {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--tp-line);
  background: var(--tp-panel);
  border-radius: 12px;
  height: 38px;
  width: 44px;
  padding: 0;
  flex: 0 0 auto;
  text-decoration: none;
}

.starter-header-brand:hover {
  background: color-mix(in srgb, var(--tp-accent) 8%, var(--tp-panel));
}

.integrated-app-nav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px;
  border: 1px solid var(--tp-line);
  border-radius: 999px;
  background: color-mix(in srgb, var(--tp-panel) 88%, var(--tp-bg));
  box-shadow: 0 10px 24px rgba(17, 35, 74, .06);
  flex: 0 0 auto;
}

.integrated-app-link {
  border-radius: 999px;
  color: var(--tp-muted);
  font-size: 13px;
  font-weight: 800;
  line-height: 1;
  padding: 10px 14px;
  text-decoration: none;
  white-space: nowrap;
}

.integrated-app-link:hover {
  background: color-mix(in srgb, var(--tp-accent) 9%, var(--tp-panel));
  color: var(--tp-accent);
  text-decoration: none;
}

.integrated-app-link-active,
.integrated-app-link-active:hover {
  background: var(--tp-accent);
  color: #fff;
  box-shadow: 0 8px 20px color-mix(in srgb, var(--tp-accent) 28%, transparent);
}

.starter-header-branding {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.starter-header-logo {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  object-fit: contain;
  background: transparent;
}

.starter-header-eyebrow {
  margin: 0;
  color: var(--tp-muted);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 700;
}

.starter-header-title {
  margin: 0;
  color: var(--tp-text);
  font-size: 17px;
  font-weight: 800;
}

.starter-header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-left: auto;
  flex-wrap: wrap;
  position: relative;
  overflow: visible;
}

.starter-header-actions .dropdown {
  position: relative;
}

.starter-header-actions .dropdown-menu {
  z-index: 1305;
}

.theme-menu {
  position: relative;
  z-index: 1300;
}

.theme-menu-trigger {
  border: 1px solid var(--tp-line);
  border-radius: 999px;
  background: var(--tp-panel);
  color: var(--tp-text);
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 7px 12px;
  cursor: pointer;
  font: inherit;
  font-size: 12px;
  font-weight: 800;
}

.theme-menu-trigger:hover {
  background: color-mix(in srgb, var(--tp-accent) 8%, var(--tp-panel));
}

.theme-menu-dot,
.theme-color-dot {
  width: 13px;
  height: 13px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .72);
  flex: 0 0 auto;
}

.theme-menu-value {
  color: var(--tp-muted);
  font-size: 12px;
}

.theme-menu-dropdown {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  width: 260px;
  border: 1px solid var(--tp-line);
  border-radius: 16px;
  background: var(--tp-panel);
  box-shadow: 0 20px 46px rgba(17, 35, 74, .18);
  padding: 12px;
  display: none;
  z-index: 1400;
}

.theme-menu.is-open .theme-menu-dropdown {
  display: block;
}

.theme-menu-section + .theme-menu-section {
  border-top: 1px solid var(--tp-line);
  margin-top: 12px;
  padding-top: 12px;
}

.theme-menu-section p {
  margin: 0 0 8px;
  color: var(--tp-muted);
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.theme-menu-options {
  display: grid;
  gap: 8px;
}

.theme-menu-options-two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.theme-option,
.theme-color-option {
  border: 1px solid var(--tp-line);
  border-radius: 12px;
  background: color-mix(in srgb, var(--tp-panel) 92%, var(--tp-bg));
  color: var(--tp-text);
  padding: 8px 10px;
  cursor: pointer;
  text-align: left;
  font-weight: 800;
}

.theme-option.is-active,
.theme-color-option.is-active {
  border-color: color-mix(in srgb, var(--tp-accent) 45%, var(--tp-line));
  background: color-mix(in srgb, var(--tp-accent) 12%, var(--tp-panel));
  color: var(--tp-accent);
}

.theme-color-option {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.starter-app-footer {
  margin-top: 0;
}

.dashboard-content {
  padding-top: 1.25rem !important;
}

/* Desktop guard: prevent sidebar toggle from accidentally using mobile-like sizing. */
@media (min-width: 992px) {
  .starter-app-shell {
    grid-template-columns: 260px minmax(0, 1fr) !important;
  }

  .starter-app-shell.starter-app-shell-nav-hidden {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .starter-app-shell .starter-left-nav {
    position: sticky !important;
    transform: none !important;
    display: block;
  }

  .starter-app-shell.starter-app-shell-nav-hidden .starter-left-nav {
    display: none !important;
  }
}

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

  .starter-left-nav {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    width: min(290px, 86vw);
    z-index: 1042;
    transform: translateX(0);
    box-shadow: 0 12px 42px rgba(0, 0, 0, .24);
  }

  .starter-app-shell-nav-hidden .starter-left-nav {
    display: block;
    transform: translateX(-110%);
  }

  .starter-app-header {
    padding: 12px 14px;
  }

  .starter-header-title {
    font-size: 15px;
  }

  .integrated-app-nav {
    order: 3;
    width: 100%;
    justify-content: center;
    overflow-x: auto;
  }

  .integrated-app-link {
    padding: 9px 12px;
  }

  .starter-header-actions {
    gap: 6px;
  }
}

@media (max-width: 767.98px) {
  body.dashboard-dark .dashboard-topnav {
    padding: .6rem .75rem;
  }

  body.dashboard-dark .topnav-title {
    display: none;
  }

  body.dashboard-dark .topnav-menu {
    width: 100%;
  }

  body.dashboard-dark .dashboard-content {
    padding-top: 1rem !important;
  }

  body.dashboard-dark .hero-card,
  body.dashboard-dark .hero-panel {
    padding: 1rem !important;
  }

  body.connectors-page .collapsible-sidebar {
    transform: translateX(-100%);
    width: var(--sidebar-w);
  }

  body.connectors-page .connectors-content {
    margin-left: 0;
    width: 100%;
  }

  body.connectors-page.sidebar-collapsed .collapsible-sidebar {
    transform: translateX(0);
  }

  body.connectors-page.sidebar-collapsed .collapsible-sidebar .sidebar-heading,
  body.connectors-page.sidebar-collapsed .collapsible-sidebar .brand-block h6 {
    display: block;
  }

  body.connectors-page.sidebar-collapsed .collapsible-sidebar .nav-link .nav-label {
    display: inline;
  }

  body.connectors-page.sidebar-collapsed .collapsible-sidebar .nav-link .feather {
    margin-right: .5rem;
  }
}

.border-left-primary {
  border-left: .25rem solid #007bff !important;
}

.border-left-success {
  border-left: .25rem solid #28a745 !important;
}

.border-left-info {
  border-left: .25rem solid #17a2b8 !important;
}

.border-left-warning {
  border-left: .25rem solid #ffc107 !important;
}

.shadow {
  box-shadow: 0 .125rem .25rem rgba(0, 0, 0, .075) !important;
}

.h-100 {
  height: 100% !important;
}

.text-xs {
  font-size: .75rem;
}

.text-uppercase {
  text-transform: uppercase;
}

.font-weight-bold {
  font-weight: 700;
}

.m-0 {
  margin: 0 !important;
}

.mb-0 {
  margin-bottom: 0 !important;
}

.mb-1 {
  margin-bottom: .25rem !important;
}

.mb-2 {
  margin-bottom: .5rem !important;
}

.mb-3 {
  margin-bottom: 1rem !important;
}

.mb-4 {
  margin-bottom: 1.5rem !important;
}

.p-0 {
  padding: 0 !important;
}

.pt-3 {
  padding-top: 1rem !important;
}

.pb-2 {
  padding-bottom: .5rem !important;
}

.pl-3 {
  padding-left: 1rem !important;
}

.pr-3 {
  padding-right: 1rem !important;
}

.d-flex {
  display: flex !important;
}

.justify-content-between {
  justify-content: space-between !important;
}

.flex-wrap {
  flex-wrap: wrap !important;
}

.align-items-center {
  align-items: center !important;
}

.no-gutters {
  margin-right: 0;
  margin-left: 0;
}

.no-gutters > .col,
.no-gutters > [class*="col-"] {
  padding-right: 0;
  padding-left: 0;
}

.h5 {
  font-size: 1.25rem;
}

.text-gray-800 {
  color: #5a5c69 !important;
}

.text-primary {
  color: #007bff !important;
}

.text-success {
  color: #28a745 !important;
}

.text-info {
  color: #17a2b8 !important;
}

.text-warning {
  color: #ffc107 !important;
}

.border-bottom {
  border-bottom: 1px solid #e3e6f0 !important;
}

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

body.dashboard-dark .widget-icon-btn {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  flex: 0 0 auto;
}

body.dashboard-dark a.btn .feather,
body.dashboard-dark .widget-icon-btn .feather {
  width: 15px;
  height: 15px;
}

body.dashboard-dark .chart-type-icon-group {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  flex-wrap: wrap;
}

body.dashboard-dark .dashboard-meta-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem 1rem;
  margin-top: .2rem;
}

body.dashboard-dark .dashboard-meta-grid > span {
  display: inline-flex;
  align-items: center;
  padding: .18rem .48rem;
  border-radius: .45rem;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .03);
}

body.dashboard-dark .widget-toolbar {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: .75rem;
  width: 100%;
  overflow-x: auto;
  scrollbar-width: thin;
}

body.dashboard-dark .widget-toolbar-left {
  justify-self: start;
}

body.dashboard-dark .widget-toolbar-right {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  flex-wrap: nowrap;
}

body.dashboard-dark .widget-toolbar-group {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  flex-wrap: nowrap;
}

@keyframes widgetQuickSelectReveal {
  from {
    opacity: 0;
    transform: translateX(6px);
  }
  to {
    opacity: 1;
    transform: translateX(0);
  }
}

body.dashboard-dark .widget-profile-quick-wrap {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
}

body.dashboard-dark .widget-unit-quick-wrap {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
}

body.dashboard-dark .widget-profile-quick-select {
  display: none;
  min-width: 170px;
}

body.dashboard-dark .widget-unit-quick-select {
  display: none;
  min-width: 120px;
}

body.dashboard-dark .widget-profile-quick-wrap.is-open .widget-profile-quick-select {
  display: block;
  animation: widgetQuickSelectReveal .16s ease-out;
}

body.dashboard-dark .widget-unit-quick-wrap.is-open .widget-unit-quick-select {
  display: block;
  animation: widgetQuickSelectReveal .16s ease-out;
}

body.dashboard-dark .widget-profile-toggle-btn[aria-expanded="true"] {
  background: rgba(53, 211, 154, .2);
  border-color: rgba(53, 211, 154, .72);
  color: #ddfff1;
}

body.dashboard-dark .widget-unit-toggle-btn[aria-expanded="true"] {
  background: rgba(53, 211, 154, .2);
  border-color: rgba(53, 211, 154, .72);
  color: #ddfff1;
}

body.dashboard-dark .widget-card-shell {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

body.dashboard-dark .widget-footer-controls {
  margin-top: auto;
  padding-top: .55rem;
  justify-content: flex-end;
}

body.dashboard-dark .chart-type-icon-btn.active {
  background: rgba(58, 165, 255, .2);
  border-color: rgba(58, 165, 255, .7);
  color: #dff1ff;
}

body.dashboard-dark .widget-size-icon-btn.active {
  background: rgba(53, 211, 154, .2);
  border-color: rgba(53, 211, 154, .72);
  color: #ddfff1;
}

body.dashboard-light .dashboard-topnav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: .75rem;
  position: sticky;
  top: 0;
  z-index: 1100;
  background: rgba(238, 242, 247, .92);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border-soft);
  padding: .8rem 1rem;
}

/* Keep modals above sticky top navigation */
body.dashboard-light .modal {
  z-index: 1300;
}

body.dashboard-light .modal-backdrop {
  z-index: 1290;
}

body.dashboard-light .topnav-logo {
  height: 34px;
  width: auto;
}

body.dashboard-light .topnav-title {
  color: #1a2b40;
  font-weight: 600;
}

body.dashboard-light .topnav-menu {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
}

body.dashboard-light .topnav-menu a {
  color: #415166;
  text-decoration: none;
  padding: .35rem .7rem;
  border-radius: .55rem;
  border: 1px solid transparent;
  font-size: .88rem;
}

body.dashboard-light .topnav-menu a:hover {
  color: #132438;
  background: rgba(20, 38, 60, .08);
}

body.dashboard-light .topnav-menu a.active {
  color: #0f2033;
  background: linear-gradient(90deg, rgba(25, 118, 210, .2), rgba(25, 118, 210, .05));
  border-color: rgba(25, 118, 210, .35);
}

body.dashboard-light .dashboard-main {
  max-width: 1400px;
  margin: 0 auto;
}

body.dashboard-light .dark-sidebar {
  background: linear-gradient(180deg, var(--bg-sidebar) 0%, var(--bg-sidebar-soft) 100%);
  border-right: 1px solid var(--border-soft);
  box-shadow: 8px 0 24px rgba(80, 95, 118, .2);
}

body.dashboard-light .brand-block {
  border: 1px solid rgba(16, 35, 57, .12);
  border-radius: 14px;
  background: rgba(255, 255, 255, .6);
  padding: .9rem .75rem;
}

body.dashboard-light .sidebar-divider {
  border-color: rgba(31, 50, 75, .2);
}

body.dashboard-light .sidebar-heading {
  color: #4a5e76;
  letter-spacing: .06em;
  text-transform: uppercase;
  font-size: .78rem;
}

body.dashboard-light .sidebar .nav-link {
  color: #33465e;
  transition: background-color .2s ease, color .2s ease, transform .2s ease;
}

body.dashboard-light .sidebar .nav-link:hover {
  background: rgba(20, 38, 60, .08);
  color: #12263c;
  transform: translateX(3px);
}

body.dashboard-light .sidebar .nav-link.active {
  color: #0f2033;
  background: linear-gradient(90deg, rgba(25, 118, 210, .2), rgba(25, 118, 210, .06));
  border: 1px solid rgba(25, 118, 210, .35);
}

body.dashboard-light .dashboard-content {
  color: var(--text-main);
}

body.dashboard-light .hero-panel {
  background: linear-gradient(135deg, rgba(255, 255, 255, .95), rgba(245, 248, 252, .95));
  border: 1px solid var(--border-soft);
  border-radius: 16px;
  padding: 1.1rem 1.25rem;
  margin-bottom: 1.25rem;
}

body.dashboard-light .eyebrow {
  text-transform: uppercase;
  letter-spacing: .09em;
  color: var(--text-soft);
  font-size: .72rem;
}

body.dashboard-light .user-chip {
  background: rgba(255, 255, 255, .72);
  color: var(--text-main);
  border: 1px solid var(--border-soft);
}

body.dashboard-light .user-chip:hover {
  background: rgba(255, 255, 255, .96);
  color: #0f1e32;
}

body.dashboard-light .server-time-chip {
  background: rgba(255, 255, 255, .68);
  color: #2f435a;
  border: 1px solid var(--border-soft);
  border-radius: .55rem;
  padding: .32rem .6rem;
  font-size: .8rem;
  white-space: nowrap;
}

body.dashboard-light .hero-card {
  background: linear-gradient(145deg, var(--bg-panel) 0%, var(--bg-panel-soft) 100%);
  border: 1px solid var(--border-soft);
  box-shadow: 0 12px 30px rgba(79, 100, 129, .18);
}

body.dashboard-light .hero-card .lead {
  color: #3d5168;
}

body.dashboard-light .text-soft {
  color: var(--text-soft);
}

body.dashboard-light .dashboard-footer {
  border-top: 1px solid var(--border-soft);
  margin-top: 1rem;
  text-align: left;
  font-size: .82rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  flex-wrap: wrap;
}

body.dashboard-light .dashboard-footer .footer-version {
  opacity: .9;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  white-space: nowrap;
}

body.dashboard-light .panel-card {
  border: 1px solid var(--border-soft);
  border-radius: 14px;
  background: linear-gradient(160deg, #ffffff 0%, #f2f6fb 100%);
  color: var(--text-main);
  box-shadow: 0 10px 24px rgba(93, 114, 141, .16);
}

body.dashboard-light .panel-card .card-text {
  color: var(--text-soft);
}

body.dashboard-light .table {
  color: #1b2a3b;
}

body.dashboard-light .table > :not(caption) > * > * {
  color: #1b2a3b;
  border-color: var(--border-soft);
}

body.dashboard-light .table thead th {
  color: #324760;
}

body.dashboard-light .btn-accent {
  background: var(--accent);
  border-color: var(--accent);
  color: #f2f8ff;
  font-weight: 600;
}

body.dashboard-light .btn-accent:hover {
  background: #2b87df;
  border-color: #2b87df;
}

body.dashboard-light .btn-accent-alt {
  background: var(--accent-2);
  border-color: var(--accent-2);
  color: #f1fffb;
  font-weight: 600;
}

body.dashboard-light .btn-accent-alt:hover {
  background: #24af87;
  border-color: #24af87;
}

body.dashboard-light .dropdown-menu {
  background: #ffffff;
  border: 1px solid var(--border-soft);
}

body.dashboard-light .dropdown-item {
  color: var(--text-main);
}

body.dashboard-light .dropdown-item:hover {
  background: #ecf3fb;
}

body.dashboard-light .connectors-header {
  border-bottom: 1px solid var(--border-soft);
  background: rgba(255, 255, 255, .72);
}

body.dashboard-light .connectors-table {
  color: var(--text-main);
  margin-bottom: 0;
  background: transparent;
}

body.dashboard-light .connectors-table thead th {
  color: #4a5d73;
  border-bottom-color: var(--border-soft);
  border-top: 0;
}

body.dashboard-light .connectors-table > :not(caption) > * > * {
  background-color: transparent;
}

body.dashboard-light .connectors-table thead th {
  background: rgba(255, 255, 255, .82);
}

body.dashboard-light .connectors-table td {
  border-color: var(--border-soft);
  vertical-align: middle;
}

body.dashboard-light .connectors-table.table-striped > tbody > tr:nth-of-type(odd) > * {
  color: var(--text-main);
  background-color: rgba(16, 34, 56, .02);
}

body.dashboard-light .connectors-table tbody tr:hover > * {
  background: rgba(16, 35, 57, .05);
}

body.dashboard-light .connectors-chart-wrap {
  background: rgba(255, 255, 255, .72);
  border: 1px solid var(--border-soft);
}

body.dashboard-light .join-rule-row {
  border: 1px dashed rgba(16, 35, 57, .2);
  border-radius: 10px;
  padding: .65rem;
}

body.dashboard-light .analysis-tip {
  border: 1px solid rgba(25, 118, 210, .35);
  background: rgba(25, 118, 210, .08);
  color: #1a3f66;
  padding: .65rem .8rem;
  border-radius: .5rem;
  font-size: .85rem;
}

body.dashboard-light .advanced-box {
  border: 1px solid rgba(16, 35, 57, .14);
  border-radius: .6rem;
  padding: .85rem;
  background: rgba(255, 255, 255, .7);
}

body.dashboard-light #joinAnalysisTabs {
  border-bottom-color: rgba(16, 35, 57, .18);
}

body.dashboard-light #joinAnalysisTabs .nav-link {
  color: #45617f;
}

body.dashboard-light #joinAnalysisTabs .nav-link.active {
  color: #153453;
  background: rgba(25, 118, 210, .12);
  border-color: rgba(25, 118, 210, .32) rgba(25, 118, 210, .32) transparent;
}

body.dashboard-light .relation-map-canvas {
  border: 1px solid rgba(16, 35, 57, .16);
  background: rgba(255, 255, 255, .8);
}

body.dashboard-light .sidebar-toggle {
  border-color: var(--border-soft);
  color: var(--text-main);
}

body.dashboard-light .sidebar-toggle:hover {
  background: rgba(16, 35, 57, .08);
}

body.dashboard-light .modal-content {
  background: linear-gradient(160deg, #ffffff 0%, #f3f7fc 100%);
  border: 1px solid var(--border-soft);
  color: var(--text-main);
}

body.dashboard-light .modal-header,
body.dashboard-light .modal-footer {
  border-color: var(--border-soft);
}

body.dashboard-light .form-control,
body.dashboard-light .form-select,
body.dashboard-light textarea {
  background: #ffffff;
  border-color: #b9c6d8;
  color: var(--text-main);
}

body.dashboard-light .form-control::placeholder,
body.dashboard-light textarea::placeholder {
  color: #73859c;
}

body.dashboard-light .form-control:focus,
body.dashboard-light .form-select:focus,
body.dashboard-light textarea:focus {
  border-color: #4f9ce6;
  box-shadow: 0 0 0 .2rem rgba(25, 118, 210, .2);
  background: #ffffff;
  color: var(--text-main);
}

body.dashboard-light .customdash-list-item {
  background: rgba(255, 255, 255, .72);
  color: var(--text-main);
  border: 1px solid var(--border-soft);
}

body.dashboard-light .customdash-list-item:hover,
body.dashboard-light .customdash-list-item:focus {
  background: rgba(25, 118, 210, .1);
  color: #0f2135;
}

body.dashboard-light .customdash-list-item.active {
  background: linear-gradient(90deg, rgba(25, 118, 210, .2), rgba(25, 118, 210, .06));
  border-color: rgba(25, 118, 210, .35);
  color: #0f2135;
}

body.dashboard-light .customdash-toolbar .form-label {
  color: #536982;
  font-size: .8rem;
}

body.dashboard-light .widget-icon-btn {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  flex: 0 0 auto;
  border-color: #bcc8d8;
  color: #2f4660;
  background: #fff;
}

body.dashboard-light a.btn .feather,
body.dashboard-light .widget-icon-btn .feather {
  width: 15px;
  height: 15px;
}

body.dashboard-light .chart-type-icon-group {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  flex-wrap: wrap;
}

body.dashboard-light .dashboard-meta-grid {
  display: flex;
  flex-wrap: wrap;
  gap: .45rem 1rem;
  margin-top: .2rem;
}

body.dashboard-light .dashboard-meta-grid > span {
  display: inline-flex;
  align-items: center;
  padding: .18rem .48rem;
  border-radius: .45rem;
  border: 1px solid rgba(16, 35, 57, .12);
  background: rgba(255, 255, 255, .7);
}

body.dashboard-light .widget-toolbar {
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: .75rem;
  width: 100%;
  overflow-x: auto;
  scrollbar-width: thin;
}

body.dashboard-light .widget-toolbar-left {
  justify-self: start;
}

body.dashboard-light .widget-toolbar-right {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  flex-wrap: nowrap;
}

body.dashboard-light .widget-toolbar-group {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
  flex-wrap: nowrap;
}

body.dashboard-light .widget-profile-quick-wrap {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
}

body.dashboard-light .widget-unit-quick-wrap {
  display: inline-flex;
  align-items: center;
  gap: .32rem;
}

body.dashboard-light .widget-profile-quick-select {
  display: none;
  min-width: 170px;
}

body.dashboard-light .widget-unit-quick-select {
  display: none;
  min-width: 120px;
}

body.dashboard-light .widget-profile-quick-wrap.is-open .widget-profile-quick-select {
  display: block;
  animation: widgetQuickSelectReveal .16s ease-out;
}

body.dashboard-light .widget-unit-quick-wrap.is-open .widget-unit-quick-select {
  display: block;
  animation: widgetQuickSelectReveal .16s ease-out;
}

body.dashboard-light .widget-profile-toggle-btn[aria-expanded="true"] {
  background: rgba(25, 118, 210, .2);
  border-color: rgba(25, 118, 210, .7);
  color: #143457;
}

body.dashboard-light .widget-unit-toggle-btn[aria-expanded="true"] {
  background: rgba(25, 118, 210, .2);
  border-color: rgba(25, 118, 210, .7);
  color: #143457;
}

body.dashboard-light .widget-card-shell {
  display: flex;
  flex-direction: column;
  min-height: 100%;
}

body.dashboard-light .widget-footer-controls {
  margin-top: auto;
  padding-top: .55rem;
  justify-content: flex-end;
}

body.dashboard-light .chart-type-icon-btn.active {
  background: rgba(25, 118, 210, .2);
  border-color: rgba(25, 118, 210, .7);
  color: #143457;
}

body.dashboard-light .widget-size-icon-btn.active {
  background: rgba(31, 157, 122, .2);
  border-color: rgba(31, 157, 122, .72);
  color: #14513f;
}

.widget-drag-handle {
  cursor: grab;
}

.widget-drag-handle:active {
  cursor: grabbing;
}

.widget-grid-item.widget-drag-chosen {
  opacity: .85;
}

.widget-grid-item.widget-drag-ghost {
  opacity: .45;
}

body.widget-tools-hidden .widget-toolbar,
body.widget-tools-hidden .widget-footer-controls {
  display: none !important;
}

.widget-header-tools-btn {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
}

body.customdash-page .connectors-header .print-hide {
  display: inline-flex;
  align-items: center;
  gap: .4rem;
}

body.customdash-page .connectors-header .print-hide .btn {
  flex: 0 0 auto;
}

@media print {
  body.customdash-page .dashboard-topnav,
  body.customdash-page .hero-panel,
  body.customdash-page .dashboard-footer,
  body.customdash-page .print-hide,
  body.customdash-page .card-header .btn,
  body.customdash-page .advanced-menu-item {
    display: none !important;
  }

  body.customdash-page .connectors-content.dashboard-content {
    padding: 0 !important;
  }

  body.customdash-page .panel-card,
  body.customdash-page .connectors-chart-wrap {
    border: 1px solid #d6d9de !important;
    box-shadow: none !important;
    background: #fff !important;
  }

  body.customdash-page .connectors-card .card-header {
    border-bottom: 1px solid #d6d9de !important;
  }

  body.customdash-page {
    background: #fff !important;
    color: #111 !important;
  }

  .widget-toolbar,
  .widget-footer-controls {
    display: none !important;
  }
}

#widgetsContainer.widgets-layout-vertical-2-1 {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-auto-rows: 150px;
  grid-auto-flow: dense;
  gap: 1rem;
}

#widgetsContainer.widgets-layout-vertical-2-1 > .widget-grid-item {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  min-height: 0;
}

#widgetsContainer.widgets-layout-vertical-2-1 > .widget-grid-item .widget-card-shell {
  height: 100%;
}

body.customdash-page .widget-visual-stage {
  position: relative;
  height: var(--widget-chart-height, 180px);
  min-height: 140px;
}

body.customdash-page .widget-visual-stage.is-table {
  height: auto;
  min-height: var(--widget-chart-height, 180px);
}

body.customdash-page .widget-visual-stage > canvas {
  width: 100% !important;
  height: 100% !important;
  display: block;
}

body.customdash-page .widget-chart-loading {
  position: absolute;
  inset: 0;
  border-radius: .45rem;
  border: 1px dashed var(--border-soft);
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, .03) 0%,
    rgba(255, 255, 255, .12) 50%,
    rgba(255, 255, 255, .03) 100%
  );
  background-size: 220% 100%;
  animation: widgetChartShimmer 1.2s ease-in-out infinite;
  pointer-events: none;
}

@keyframes widgetChartShimmer {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

#widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-small {
  grid-column: span 1;
  grid-row: span 1;
}

#widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-medium {
  grid-column: span 1;
  grid-row: span 2;
}

#widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-medium_1_2 {
  grid-column: span 1;
  grid-row: span 2;
}

#widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-large {
  grid-column: 1 / -1;
  grid-row: span 2;
}

body.dashboard-dark .btn-outline-soft {
  color: #dce7f4;
  border-color: rgba(220, 231, 244, .45);
  background: rgba(255, 255, 255, .03);
}

body.dashboard-dark .btn-outline-soft:hover {
  color: #ffffff;
  border-color: rgba(58, 165, 255, .65);
  background: rgba(58, 165, 255, .16);
}

body.dashboard-light .btn-outline-soft {
  color: #2f4861;
  border-color: #b6c6da;
  background: rgba(255, 255, 255, .7);
}

body.dashboard-light .btn-outline-soft:hover {
  color: #10263e;
  border-color: #4f8fd0;
  background: rgba(79, 143, 208, .14);
}

.dashboard-action-btn {
  font-weight: 600;
  border-width: 1px;
}

body.dashboard-dark .dashboard-action-rename {
  color: #d8ebff;
  border-color: rgba(58, 165, 255, .55);
  background: rgba(58, 165, 255, .12);
}

body.dashboard-dark .dashboard-action-rename:hover {
  color: #ffffff;
  border-color: rgba(58, 165, 255, .8);
  background: rgba(58, 165, 255, .24);
}

body.dashboard-light .dashboard-action-rename {
  color: #114a83;
  border-color: rgba(25, 118, 210, .5);
  background: rgba(25, 118, 210, .12);
}

body.dashboard-light .dashboard-action-rename:hover {
  color: #0b3b6b;
  border-color: rgba(25, 118, 210, .75);
  background: rgba(25, 118, 210, .22);
}

body.dashboard-dark .dashboard-action-permission {
  color: #d9f8ed;
  border-color: rgba(53, 211, 154, .45);
  background: rgba(53, 211, 154, .12);
}

body.dashboard-dark .dashboard-action-permission:hover {
  color: #ffffff;
  border-color: rgba(53, 211, 154, .72);
  background: rgba(53, 211, 154, .24);
}

body.dashboard-light .dashboard-action-permission {
  color: #1f7c63;
  border-color: rgba(31, 157, 122, .45);
  background: rgba(31, 157, 122, .12);
}

body.dashboard-light .dashboard-action-permission:hover {
  color: #135848;
  border-color: rgba(31, 157, 122, .72);
  background: rgba(31, 157, 122, .22);
}

body.dashboard-dark .dashboard-action-delete {
  color: #ffdfe2;
  border-color: rgba(242, 88, 101, .5);
  background: rgba(242, 88, 101, .14);
}

body.dashboard-dark .dashboard-action-delete:hover {
  color: #ffffff;
  border-color: rgba(242, 88, 101, .78);
  background: rgba(242, 88, 101, .27);
}

body.dashboard-light .dashboard-action-delete {
  color: #8d2430;
  border-color: rgba(205, 71, 86, .5);
  background: rgba(205, 71, 86, .12);
}

body.dashboard-light .dashboard-action-delete:hover {
  color: #691520;
  border-color: rgba(205, 71, 86, .76);
  background: rgba(205, 71, 86, .22);
}

@media (max-width: 767.98px) {
  body.customdash-page .customdash-meta-refresh-row {
    align-items: flex-start;
  }

  body.customdash-page .customdash-meta-refresh-row .dashboard-meta-grid {
    flex: 1 1 100%;
  }

  body.customdash-page .customdash-refresh-compact {
    width: 100%;
    margin-left: 0;
    justify-content: flex-start;
  }

  body.customdash-page .customdash-refresh-compact .customdash-refresh-controls {
    grid-template-columns: minmax(0, 108px) auto;
    width: 100%;
  }

  body.dashboard-dark .widget-toolbar {
    grid-template-columns: 1fr auto;
    gap: .5rem;
  }

  body.dashboard-dark .widget-toolbar-right {
    justify-self: end;
  }

  body.dashboard-dark .dashboard-meta-grid {
    gap: .35rem;
  }

  body.dashboard-light .widget-toolbar {
    grid-template-columns: 1fr auto;
    gap: .5rem;
  }

  body.dashboard-light .widget-toolbar-right {
    justify-self: end;
  }

  body.dashboard-light .dashboard-meta-grid {
    gap: .35rem;
  }

  #widgetsContainer.widgets-layout-vertical-2-1 {
    grid-template-columns: 1fr;
  }

  #widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-small,
  #widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-medium,
  #widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-medium_1_2,
  #widgetsContainer.widgets-layout-vertical-2-1 > .widget-size-large {
    grid-column: 1;
    grid-row: span 1;
  }
}
