/* Shared NRTHDC theme (modern, colorful, higher contrast)
   Keep this file framework-free; pages already include Bootstrap.
*/

:root {
  --nr-navbar-offset: 96px;
  --nr-bg: #0b1220;
  --nr-surface: rgba(255,255,255,.94);
  --nr-surface-2: rgba(255,255,255,.88);
  --nr-border: rgba(0,0,0,.10);
  --nr-text: #0b1324;
  --nr-muted: #5c6776;

  --nr-shadow: 0 22px 50px rgba(2, 8, 23, .18);
  --nr-shadow-soft: 0 16px 30px rgba(2, 8, 23, .12);

  /* More saturated accents (clearer colors) */
  --nr-accent-1: #1d4ed8; /* blue */
  --nr-accent-2: #0f766e; /* teal */
  --nr-accent-3: #d97706; /* amber */
  --nr-accent-4: #7c3aed; /* purple */

  --nr-warn: #f59e0b;
  --nr-warn-2: #fbbf24;
  --nr-success: #16a34a;
  --nr-danger: #dc2626;
}

body.nrthdc-body {
  font-family: 'Sarabun', system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--nr-text);
  background:
    radial-gradient(1200px 520px at 12% 0%, rgba(29,78,216,.26) 0%, rgba(29,78,216,0) 55%),
    radial-gradient(900px 520px at 90% 10%, rgba(15,118,110,.20) 0%, rgba(15,118,110,0) 55%),
    radial-gradient(900px 520px at 50% 100%, rgba(217,119,6,.18) 0%, rgba(217,119,6,0) 55%),
    linear-gradient(180deg, #eef3ff 0%, #f3f5fb 40%, #eef2f7 100%);
}

/* Layout: reduce “empty bottom area” feeling on short pages */
html,
body.nrthdc-body {
  height: 100%;
}
body.nrthdc-body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  padding-top: var(--nr-navbar-offset);
}
/* Main content containers (most pages use py-3/py-4). Make them fill the viewport
   and render a subtle surface so the bottom doesn't look like an empty background. */
body.nrthdc-body .nr-container.py-4,
body.nrthdc-body .nr-container.py-3,
body.nrthdc-body .nr-container.portal {
  flex: 1 0 auto;
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

/* Consistent page width across NRTHDC */
.nr-container {
  width: 100%;
  max-width: none;
  margin: 0;
  padding-left: 24px;
  padding-right: 24px;
}

/* Force Bootstrap containers to be full-width (no big side gutters) */
.container,
.container-lg,
.container-xl,
.container-xxl {
  max-width: none !important;
}

/* White glass navbar (override per-page styles) */
body.nrthdc-body .navbar-glass {
  background: rgba(255,255,255,.97) !important;
  backdrop-filter: blur(14px) saturate(1.2) !important;
  -webkit-backdrop-filter: blur(14px) saturate(1.2) !important;
  border-bottom: 1px solid rgba(15,23,42,.10) !important;
  box-shadow: 0 8px 26px rgba(2, 8, 23, .10) !important;
  padding: 8px 0;
  z-index: 1080;
  isolation: isolate;
}

@media (max-width: 1199.98px) {
  :root {
    --nr-navbar-offset: 84px;
  }
}

@media (max-width: 575.98px) {
  :root {
    --nr-navbar-offset: 76px;
  }
}

/* Make outlines a bit stronger across the system (clearer than pastel) */
body.nrthdc-body .btn.btn-outline-secondary {
  border-color: rgba(15,23,42,.22);
  color: #0f172a;
}
body.nrthdc-body .btn.btn-outline-secondary:hover {
  border-color: rgba(15,23,42,.30) !important;
}

body.nrthdc-body .navbar-glass .nr-chip {
  background: rgba(255,255,255,.95) !important;
  border: 1.5px solid rgba(15,23,42,.20) !important;
  color: var(--nr-text) !important;
}

body.nrthdc-body .navbar-glass .dropdown-menu {
  z-index: 1085;
  box-sizing: border-box;
  min-width: min(320px, calc(100vw - 24px));
  width: min(360px, calc(100vw - 24px));
  max-width: calc(100vw - 24px);
  max-height: min(70dvh, calc(100dvh - 84px));
  overflow-x: hidden;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding: 6px 0;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.10);
  box-shadow: 0 18px 34px rgba(2, 8, 23, .12);
  scrollbar-width: thin;
  scrollbar-color: rgba(29, 78, 216, .28) rgba(219, 231, 245, .72);
  transform-origin: top right;
}

body.nrthdc-body .navbar-glass .dropdown-menu[data-bs-popper] {
  margin-top: 8px;
}

body.nrthdc-body .navbar-expand-xl .nr-nav-primary .dropdown-menu[data-bs-popper] {
  left: 0;
  right: auto;
}

body.nrthdc-body .navbar-expand-xl .nr-nav-util .dropdown-menu[data-bs-popper] {
  left: auto;
  right: 0;
}

body.nrthdc-body .navbar-glass .dropdown-menu::-webkit-scrollbar {
  width: 10px;
}

body.nrthdc-body .navbar-glass .dropdown-menu::-webkit-scrollbar-track {
  background: rgba(219, 231, 245, .72);
  border-radius: 999px;
}

body.nrthdc-body .navbar-glass .dropdown-menu::-webkit-scrollbar-thumb {
  background: rgba(29, 78, 216, .28);
  border-radius: 999px;
  border: 2px solid rgba(219, 231, 245, .72);
}

/* Thin separators between dropdown items */
body.nrthdc-body .navbar-glass .dropdown-menu .dropdown-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 14px;
  white-space: normal;
  line-height: 1.4;
}
body.nrthdc-body .navbar-glass .dropdown-menu .dropdown-item.active,
body.nrthdc-body .navbar-glass .dropdown-menu .dropdown-item[aria-current="page"] {
  background: rgba(29, 78, 216, .10);
  color: #1d4ed8;
  font-weight: 800;
}
body.nrthdc-body .navbar-glass .dropdown-menu li:not(:last-child) > .dropdown-item::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 0;
  height: 1px;
  background: rgba(15,23,42,.12);
  pointer-events: none;
}
body.nrthdc-body .navbar-glass .dropdown-menu .dropdown-divider {
  margin: .35rem 0;
}

body.nrthdc-body .navbar-glass .navbar-toggler:focus {
  box-shadow: 0 0 0 .2rem rgba(37,99,235,.20) !important;
}

/* Larger, clearer help hints (tooltips/popovers) */
.tooltip.nrthdc-tooltip {
  --bs-tooltip-max-width: 440px;
  --bs-tooltip-font-size: 1rem;
  --bs-tooltip-padding-x: .9rem;
  --bs-tooltip-padding-y: .7rem;
  --bs-tooltip-bg: #111827;
  --bs-tooltip-color: #fff;
}
.tooltip.nrthdc-tooltip .tooltip-inner {
  border-radius: 14px;
  font-weight: 800;
  letter-spacing: .1px;
  box-shadow: 0 22px 44px rgba(2, 8, 23, .28);
}

.popover.nrthdc-popover {
  --bs-popover-max-width: 460px;
  --bs-popover-font-size: 1rem;
  --bs-popover-border-radius: 18px;
  --bs-popover-border-color: rgba(0,0,0,.14);
  --bs-popover-header-bg: rgba(29,78,216,.12);
  --bs-popover-header-color: #0b1324;
  --bs-popover-header-padding-y: .75rem;
  --bs-popover-header-padding-x: 1rem;
  --bs-popover-body-padding-y: .95rem;
  --bs-popover-body-padding-x: 1rem;
  background: rgba(255,255,255,.96);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  box-shadow: 0 26px 54px rgba(2, 8, 23, .22);
}
.popover.nrthdc-popover .popover-header {
  font-weight: 1000;
  font-size: 1.05rem;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.popover.nrthdc-popover .popover-body {
  color: #0f172a;
  font-weight: 700;
  line-height: 1.55;
}
.popover.nrthdc-popover ol {
  margin-bottom: 0;
}

.popover.nrthdc-popover li {
  margin: .35rem 0;
}

.popover.nrthdc-popover .nr-step-icon {
  display: inline-block;
  width: 1.25em;
  margin-right: .55rem;
  color: #2563eb;
}

.popover.nrthdc-popover .nr-hl {
  display: inline-block;
  padding: .05rem .45rem;
  margin: 0 .1rem;
  border-radius: .55rem;
  background: rgba(37, 99, 235, .14);
  border: 1px solid rgba(37, 99, 235, .18);
  color: #0b4dd8;
  font-weight: 1000;
  letter-spacing: .1px;
}

/* Navbar helpers: modern nav-link layout with proper wrapping */
.nr-nav-primary {
  gap: 4px;
  align-items: center;
  flex-wrap: nowrap;
  min-width: 0;
}
.nr-nav-util {
  gap: 4px;
  align-items: center;
  flex-wrap: nowrap;
  flex: 0 0 auto;
}

body.nrthdc-body .navbar-expand-xl .navbar-collapse {
  flex-wrap: nowrap;
  align-items: center;
  gap: 10px;
  min-width: 0;
  overflow: visible;
}

body.nrthdc-body .navbar-expand-xl .navbar-nav.ms-auto.nr-nav-primary {
  flex: 1 1 auto;
  min-width: 0;
  flex-wrap: wrap;
  overflow: visible;
}

body.nrthdc-body .navbar-expand-xl .navbar-nav.ms-auto.nr-nav-primary::-webkit-scrollbar {
  height: 6px;
}

body.nrthdc-body .navbar-expand-xl .navbar-nav.ms-auto.nr-nav-primary::-webkit-scrollbar-thumb {
  background: rgba(29, 78, 216, .28);
  border-radius: 999px;
}

/* Vertical separator between primary and utility nav */
.nr-nav-sep {
  width: 1px;
  height: 24px;
  margin: 0 14px;
  background: rgba(15, 23, 42, .15);
  border-radius: 1px;
  flex-shrink: 0;
}

body.nrthdc-body .navbar-glass .nav-item {
  position: relative;
  z-index: 1;
}

/* Nav-link styling: minimal text-based nav, clean and professional */
body.nrthdc-body .navbar-glass .nav-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 9px;
  border-radius: 6px;
  font-weight: 800;
  font-size: .8rem;
  color: #1e293b;
  white-space: nowrap;
  transition: background .16s, color .16s, box-shadow .16s, border-color .16s;
  text-decoration: none;
  border: 1px solid transparent;
  background: transparent;
  box-shadow: none;
  position: relative;
  z-index: 1;
  pointer-events: auto;
  touch-action: manipulation;
}
body.nrthdc-body .navbar-glass button.nav-link {
  appearance: none;
  -webkit-appearance: none;
  width: auto;
}
body.nrthdc-body .navbar-glass .nav-link:hover,
body.nrthdc-body .navbar-glass .nav-link:focus {
  background: rgba(29, 78, 216, .10);
  color: #1d4ed8;
  border-color: transparent;
  box-shadow: none;
}
body.nrthdc-body .navbar-glass .nav-link.active,
body.nrthdc-body .navbar-glass .nav-link[aria-expanded="true"] {
  background: rgba(29, 78, 216, .08);
  color: #1d4ed8;
  border-color: transparent;
  box-shadow: inset 0 -2px 0 rgba(29, 78, 216, .60);
}
body.nrthdc-body .navbar-glass .nav-link .nr-nav-icon {
  font-size: .95em;
  width: 1em;
  text-align: center;
  opacity: .85;
  transition: opacity .16s;
}

/* Highlight link (CID check) - minimal accent line */
body.nrthdc-body .navbar-glass .nav-link.nr-nav-highlight {
  background: transparent;
  border-color: transparent;
  color: #6d28d9;
}
body.nrthdc-body .navbar-glass .nav-link.nr-nav-highlight:hover {
  background: rgba(124, 58, 237, .08);
  border-color: transparent;
  color: #5b21b6;
  box-shadow: inset 0 -2px 0 rgba(124, 58, 237, .60);
}

/* Logout link - minimal accent line */
body.nrthdc-body .navbar-glass .nav-link.nr-nav-logout {
  color: #7f1d1d;
  border-color: transparent;
}
body.nrthdc-body .navbar-glass .nav-link.nr-nav-logout:hover {
  background: rgba(220, 38, 38, .08);
  border-color: transparent;
  color: #dc2626;
  box-shadow: inset 0 -2px 0 rgba(220, 38, 38, .60);
}

/* Service chip adjustments */
.nr-nav-service {
  max-width: min(360px, 24vw);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: .78rem;
}

body.nrthdc-body .navbar-glass .navbar-brand {
  margin-right: 10px;
  flex: 0 0 auto;
}

body.nrthdc-body .navbar-glass .nr-brand {
  padding: 8px 12px;
  font-size: .9rem;
}

body.nrthdc-body .navbar-glass .nr-chip.nr-nav-service {
  flex: 0 1 auto;
  min-width: 0;
  padding: 6px 8px;
}

body.nrthdc-body .navbar-glass .dropdown-toggle::after {
  margin-left: 4px;
}

/* Dropdown toggle caret - larger & visible */
body.nrthdc-body .navbar-glass .dropdown-toggle::after {
  border-top-width: .45em;
  border-right-width: .45em;
  border-left-width: .45em;
  vertical-align: .2em;
  margin-left: 6px;
  color: #00e5ff;
  opacity: 1;
}

/* Responsive mobile */
@media (max-width: 1199.98px) {
  body.nrthdc-body .navbar-glass .dropdown-menu {
    min-width: 0;
    width: calc(100vw - 24px);
    max-width: calc(100vw - 24px);
    max-height: min(60dvh, calc(100dvh - 96px));
  }

  body.nrthdc-body .navbar-glass .dropdown-menu[data-bs-popper] {
    left: 0;
    right: auto;
  }

  body.nrthdc-body .navbar-expand-xl .navbar-collapse {
    overflow: visible;
  }

  .nr-nav-primary,
  .nr-nav-util {
    flex-direction: column;
    align-items: stretch;
    gap: 8px;
    padding: 8px 0;
  }
  body.nrthdc-body .navbar-glass .nav-link {
    padding: 11px 14px;
    border-radius: 12px;
    font-size: 1rem;
  }
  .nr-nav-sep {
    display: none;
  }
  .nr-nav-util {
    border-top: 1px solid rgba(15, 23, 42, .08);
    margin-top: 4px;
    padding-top: 8px;
  }
  .nr-nav-service {
    max-width: 100%;
    margin-bottom: 6px;
  }
}

/* Keep old .nr-nav-actions compat (for any pages that still reference it) */
.nr-nav-actions {
  gap: 10px;
}
.nr-nav-actions.flex-nowrap {
  flex-wrap: nowrap;
}
@media (max-width: 1200px) {
  .nr-nav-actions.flex-nowrap { flex-wrap: wrap; }
  .nr-nav-actions { padding-top: 10px; padding-bottom: 6px; }
}

.card.nr-card,
.nr-card {
  border-radius: 22px;
  border: 1px solid rgba(0,0,0,.08);
  background: var(--nr-surface);
  box-shadow: var(--nr-shadow);
}

.nr-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,.10);
  background: rgba(255,255,255,.90);
  color: var(--nr-text);
}

.nr-brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 18px;
  font-weight: 1000;
  letter-spacing: .7px;
  text-transform: uppercase;
  background: linear-gradient(135deg, rgba(29,78,216,.22) 0%, rgba(15,118,110,.18) 45%, rgba(217,119,6,.18) 100%);
  border: 1px solid rgba(29,78,216,.22);
  box-shadow: 0 14px 28px rgba(2,8,23,.10);
  color: #0b2a55;
}

.nr-brand .dot {
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  background:
    radial-gradient(circle at 30% 30%, rgba(255,255,255,.92) 0%, rgba(255,255,255,0) 55%),
    linear-gradient(135deg, var(--nr-accent-1) 0%, var(--nr-accent-2) 55%, var(--nr-accent-3) 100%);
  box-shadow: 0 12px 22px rgba(37,99,235,.22);
}

/* Site switcher dropdown */
.nkhdc-site-menu {
  border-radius: 16px !important;
  border: 1px solid rgba(0,0,0,.06) !important;
  box-shadow: 0 20px 40px rgba(0,0,0,.12), 0 0 0 1px rgba(0,0,0,.03) !important;
  padding: 8px 0 !important;
  min-width: 260px;
  backdrop-filter: blur(16px);
  background: rgba(255,255,255,.96) !important;
  overflow: hidden;
}
.nkhdc-site-menu .dropdown-item {
  border-radius: 10px;
  margin: 2px 8px;
  padding: 10px 12px !important;
  transition: background .15s ease, transform .15s ease;
}
.nkhdc-site-menu .dropdown-item:hover {
  background: linear-gradient(135deg, rgba(99,102,241,.06) 0%, rgba(16,185,129,.06) 100%) !important;
  transform: translateX(2px);
}
.nkhdc-site-menu .dropdown-item:active {
  background: linear-gradient(135deg, rgba(99,102,241,.12) 0%, rgba(16,185,129,.12) 100%) !important;
}
.nkhdc-site-menu .site-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 14px;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
}
.nr-brand.dropdown-toggle::after {
  font-size: .6em;
  vertical-align: middle;
  margin-left: 4px;
  opacity: .5;
}

.btn {
  border-radius: 12px;
  font-weight: 800;
}

/* Stronger yellow for “latest” */
.badge-latest {
  background: #f59e0b;
  color: #111;
  border: 1px solid rgba(0,0,0,.12);
  font-weight: 900;
}

.latest-run td,
.latest-table td {
  background: rgba(245,158,11,.22) !important;
}
.latest-run:hover td,
.latest-table:hover td {
  background: rgba(245,158,11,.30) !important;
}
.latest-run td:first-child::before,
.latest-table td:first-child::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 10px;
  border-radius: 0;
  background: linear-gradient(180deg, #f59e0b 0%, #fbbf24 100%);
}

/* Make alert “latest import” more vivid */
.alert.nr-alert {
  border: 1px solid rgba(0,0,0,.08);
  box-shadow: var(--nr-shadow-soft);
  border-radius: 18px;
}

/* Better table look */
.table thead th { user-select: none; }
.tbl thead th {
  background: #f7f8fa;
  position: sticky;
  top: 0;
  z-index: 1;
}
.tbl th, .tbl td { padding: .65rem .85rem; }
.tbl th + th, .tbl td + td { border-left: 1px solid rgba(0,0,0,.08); }
