/* ============================================================
   ARK ONE — Light Theme Override  (loaded globally via index.html)
   Primary accent : #0a1a28  (navy)
   ============================================================ */

/* ---- CSS Variables ---- */
:root {
  --ark-primary:        #0a1a28;
  --ark-primary-dark:   #060f16;
  --ark-primary-light:  #e8ecf0;
  --ark-nav-bg:         #0a1a28;
  --ark-nav-bg-hover:   #122333;
  --ark-nav-bg-active:  #163044;
  --ark-page-bg:        #f0f4f8;
  --ark-card-bg:        #ffffff;
  #e3eaf2:         #e3eaf2;
  --ark-text-main:      #2c3e50;
  --ark-text-muted:     #7f8c9a;
  --ark-text-light:     #a2acba;
  --ark-shadow-sm:      0 2px 8px rgba(10,26,40,0.08);
  --ark-shadow-md:      0 4px 20px rgba(10,26,40,0.13);
  --ark-radius:         0.5rem;
  --ark-radius-lg:      0.75rem;
}

/* ============================================================
   PAGE
   ============================================================ */
body {
  background-color: var(--ark-page-bg) !important;
  color: var(--ark-text-main) !important;
}

/* ============================================================
   TOP NAVBAR  — dark #0a1a28
   ============================================================ */
.topnav.navbar {
  background-color: #ffffff !important;
  border-bottom: 1px solid #e3eaf2 !important;
  box-shadow: 0 2px 8px rgba(10,26,40,0.06) !important;
}

/* Brand logo */
.topnav.navbar .navbar-brand {
  display: inline-flex !important;
  align-items: center;
  border-right: 1px solid #e3eaf2 !important;
  padding-right: 1rem;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.topnav.navbar .navbar-brand::before {
  display: none !important;
}
.topnav.navbar .navbar-brand .nav-logo {
  height: 36px;
  width: auto;
  display: block;
  object-fit: contain;
}

/* Hamburger toggle */
.topnav.navbar #sidebarToggle {
  color: var(--ark-text-muted) !important;
}
.topnav.navbar #sidebarToggle:hover {
  background: var(--ark-primary-light) !important;
  color: var(--ark-primary) !important;
}

/* Icon buttons in topnav */
.topnav.navbar .btn-transparent-dark {
  color: var(--ark-text-muted) !important;
}
.topnav.navbar .btn-transparent-dark:hover {
  background: var(--ark-primary-light) !important;
  color: var(--ark-primary) !important;
}
.topnav.navbar .btn-transparent-dark svg path {
  fill: var(--ark-text-muted) !important;
}
.topnav.navbar .btn-transparent-dark:hover svg path {
  fill: var(--ark-primary) !important;
}

/* Notification badge */
.notif-num {
  background: var(--ark-primary) !important;
  color: #fff !important;
  border-radius: 50%;
  font-size: 0.6rem;
  font-weight: 700;
  padding: 2px 5px;
  position: absolute;
  top: 2px; right: 2px;
  line-height: 1.2;
}

/* User avatar ring */
.topnav.navbar .user-image {
  border: 2px solid var(--ark-primary) !important;
  border-radius: 50% !important;
}

/* User name in topnav dropdown */
.topnav.navbar .dropdown-user-details-name {
  color: var(--ark-text-main) !important;
}

/* ============================================================
   DROPDOWN MENUS
   ============================================================ */
.navbar .dropdown-menu,
.dropdown-menu {
  border: 1px solid #e3eaf2 !important;
  box-shadow: var(--ark-shadow-md) !important;
  border-radius: var(--ark-radius-lg) !important;
}
.dropdown-item {
  border-radius: calc(var(--ark-radius) - 2px);
  margin: 2px 6px;
  width: calc(100% - 12px);
  padding: 0.55rem 0.85rem !important;
  color: var(--ark-text-main) !important;
  transition: background 0.12s;
}
.dropdown-item:hover, .dropdown-item:focus {
  background-color: #e8ecf0 !important;
  color: var(--ark-primary) !important;
  text-decoration: none !important;
}
.dropdown-header {
  background: var(--ark-page-bg) !important;
  color: var(--ark-text-muted) !important;
  border-bottom: 1px solid #e3eaf2 !important;
}

/* ============================================================
   SIDEBAR  — white background, navy accents
   ============================================================ */
.sidenav.sidenav-light {
  background-color: #ffffff !important;
  border-right: 1px solid #e3eaf2 !important;
  box-shadow: 2px 0 14px rgba(10,26,40,0.06) !important;
}

/* Brand / logo area inside sidenav */
.sidenav-light .sidenav-brand {
  background-color: #ffffff !important;
  border-bottom: 1px solid #e3eaf2 !important;
}
.sidenav-light .sidenav-brand .sidenav-brand-icon,
.sidenav-light .sidenav-brand .sidenav-brand-text {
  color: var(--ark-primary) !important;
}

/* All regular nav links */
.sidenav-light .sidenav-menu .nav-link {
  color: var(--ark-text-muted) !important;
  border-radius: var(--ark-radius) !important;
  margin: 2px 10px !important;
  padding: 0.65rem 0.9rem !important;
  font-weight: 500;
  font-size: 0.875rem;
  transition: background 0.15s, color 0.15s !important;
}
.sidenav-light .sidenav-menu .nav-link:hover {
  background-color: var(--ark-primary-light) !important;
  color: var(--ark-primary) !important;
  text-decoration: none !important;
}

/* ACTIVE nav link — solid navy pill */
.sidenav-light .sidenav-menu .nav-link.active {
  background-color: var(--ark-primary) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 14px rgba(10,26,40,0.2) !important;
}
.sidenav-light .sidenav-menu .nav-link.active .nav-link-icon {
  color: #ffffff !important;
}
.sidenav-light .sidenav-menu .nav-link.active svg {
  stroke: #ffffff !important;
}

/* Icon color for inactive links */
.sidenav-light .sidenav-menu .nav-link .nav-link-icon {
  color: var(--ark-text-light) !important;
}
.sidenav-light .sidenav-menu .nav-link:hover .nav-link-icon {
  color: var(--ark-primary) !important;
}

/* Section headings */
.sidenav-light .sidenav-menu .sidenav-menu-heading {
  color: var(--ark-text-light) !important;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: 700;
}

/* Nested nav links */
.sidenav-light .sidenav-menu-nested {
  border-left-color: #e3eaf2 !important;
}
.sidenav-light .sidenav-menu-nested .nav-link {
  font-size: 0.84rem !important;
  padding-left: 1.25rem !important;
  color: var(--ark-text-muted) !important;
}
.sidenav-light .sidenav-menu-nested .nav-link:hover {
  color: var(--ark-primary) !important;
  background-color: var(--ark-primary-light) !important;
}
.sidenav-light .sidenav-menu-nested .nav-link.active {
  background-color: var(--ark-primary-light) !important;
  color: var(--ark-primary) !important;
  border-left: 3px solid var(--ark-primary) !important;
  box-shadow: none !important;
  font-weight: 600;
}

/* Collapse arrow */
.sidenav-light .sidenav-menu .nav-link .sidenav-collapse-arrow {
  color: var(--ark-text-light) !important;
}

/* Sidebar footer */
.sidenav-light .sidenav-footer {
  background-color: #f8fafc !important;
  border-top: 1px solid #e3eaf2 !important;
}
.sidenav-light .sidenav-footer .sidenav-footer-subtitle {
  color: var(--ark-text-light) !important;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.sidenav-footer-title {
  color: var(--ark-text-main) !important;
  font-weight: 600;
}

/* Social / bottom links */
.social-links img {
  width: 26px !important;
  opacity: 0.5;
  transition: opacity 0.15s;
}
.social-links img:hover { opacity: 1; }
.bottom-sidebar-div a { color: var(--ark-text-light) !important; font-size: 0.7rem !important; }
.bottom-sidebar-div a:hover { color: var(--ark-primary) !important; }

/* ============================================================
   CARDS
   ============================================================ */
.card {
  background-color: #ffffff !important;
  border: 1px solid #e3eaf2 !important;
  border-radius: var(--ark-radius-lg) !important;
  box-shadow: var(--ark-shadow-sm) !important;
  transition: box-shadow 0.2s;
}
.card:hover {
  box-shadow: var(--ark-shadow-md) !important;
}
.card .card-header,
.card:not([class*=bg-]) .card-header {
  background-color: #fafcfe !important;
  border-bottom: 1px solid #e3eaf2 !important;
  color: var(--ark-text-main) !important;
  font-weight: 600 !important;
  font-size: 0.875rem !important;
  padding: 1rem 1.25rem !important;
  border-radius: var(--ark-radius-lg) var(--ark-radius-lg) 0 0 !important;
}
.card .card-body {
  padding: 1.25rem !important;
  color: var(--ark-text-main);
}
.card .card-footer {
  background-color: #fafcfe !important;
  border-top: 1px solid #e3eaf2 !important;
  padding: 0.85rem 1.25rem !important;
  border-radius: 0 0 var(--ark-radius-lg) var(--ark-radius-lg) !important;
}
.card-footer a { text-decoration: none !important; }

/* ---- Hero / Welcome card ---- */
.card.card-waves {
  background: linear-gradient(135deg, #c8d8e8 0%, #b4c8dc 50%, #a0b8d0 100%) !important;
  border: 1px solid rgba(10,26,40,0.2) !important;
  overflow: hidden;
  position: relative;
}
.card.card-waves::before {
  content: '';
  position: absolute;
  top: -50px; right: -30px;
  width: 260px; height: 260px;
  background: radial-gradient(circle, rgba(10,26,40,0.12) 0%, transparent 70%);
  border-radius: 50%;
  pointer-events: none;
}
.card.card-waves .card-body { background: transparent !important; }
.card.card-waves h2.text-primary,
.card.card-waves .text-primary {
  color: #0a1a28 !important;
}
.card.card-waves .text-gray-700 {
  color: #1e3a52 !important;
}
/* Hero button — white with navy text for contrast on gradient */
.card.card-waves .btn-primary {
  background-color: #ffffff !important;
  border-color: #ffffff !important;
  color: var(--ark-primary) !important;
  font-weight: 600 !important;
  box-shadow: 0 2px 10px rgba(0,0,0,0.12) !important;
}
.card.card-waves .btn-primary:hover {
  background-color: var(--ark-primary) !important;
  border-color: var(--ark-primary) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 14px rgba(10,26,40,0.3) !important;
  transform: translateY(-1px);
}
.card.card-waves .btn-primary svg {
  stroke: var(--ark-primary);
  transition: stroke 0.15s;
}
.card.card-waves .btn-primary:hover svg {
  stroke: #ffffff;
}

/* ============================================================
   BUTTONS (global)
   ============================================================ */
.btn-primary {
  background-color: var(--ark-primary) !important;
  border-color: var(--ark-primary) !important;
  color: #ffffff !important;
  border-radius: var(--ark-radius) !important;
  font-weight: 500 !important;
  box-shadow: 0 2px 8px rgba(10,26,40,0.22) !important;
  transition: background 0.15s, box-shadow 0.15s, transform 0.1s !important;
}
.btn-primary:hover {
  background-color: var(--ark-primary-dark) !important;
  border-color: var(--ark-primary-dark) !important;
  color: #ffffff !important;
  box-shadow: 0 4px 14px rgba(10,26,40,0.35) !important;
  transform: translateY(-1px);
  text-decoration: none !important;
}
.btn-primary:focus,
.btn-primary:active,
.btn-primary:not(:disabled):not(.disabled):active {
  background-color: var(--ark-primary-dark) !important;
  border-color: var(--ark-primary-dark) !important;
  color: #ffffff !important;
  box-shadow: 0 0 0 3px rgba(10,26,40,0.25) !important;
}
.btn-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 2.2rem !important;
  height: 2.2rem !important;
  padding: 0 !important;
  border-radius: var(--ark-radius) !important;
}

/* ============================================================
   SERVICES TABLE
   ============================================================ */
.custom-row-header {
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--ark-text-light) !important;
}
.custom-row-header [class*="col-"],
.custom-row [class*="col-"] {
  display: inline-block;
}
.custom-row {
  border-bottom: 1px solid #e3eaf2 !important;
  transition: background 0.12s !important;
  border-radius: var(--ark-radius) !important;
}
.custom-row:hover {
  background-color: #edf0f4 !important;
}
.custom-row:last-child { border-bottom: none !important; }
.custom-row p { margin: 0 0 0.1rem !important; color: var(--ark-text-main) !important; font-weight: 600; }
.custom-row small { color: var(--ark-text-muted) !important; font-size: 0.78rem; }

/* ============================================================
   BADGES
   ============================================================ */
.badge {
  font-size: 0.7rem !important;
  font-weight: 600 !important;
  padding: 0.35em 0.8em !important;
  border-radius: 2rem !important;
  letter-spacing: 0.03em;
}
.badge-info    { background-color: #dde4ec !important; color: #0a1a28 !important; border: 1px solid #b4c4d4 !important; }
.badge-warning { background-color: #fff4de !important; color: #9a6800 !important; border: 1px solid #f5e0a0 !important; }
.badge-success { background-color: #dcf5ea !important; color: #0b7a42 !important; border: 1px solid #a5dfc0 !important; }
.badge-dark    { background-color: #eaeff4 !important; color: #4a5568 !important; border: 1px solid #d0dae3 !important; }
.badge-light   { background-color: #f0f4f8 !important; color: #687281 !important; border: 1px solid #e3eaf2 !important; }

/* ============================================================
   AVATAR RING
   ============================================================ */
.avatar-img {
  border: 2px solid var(--ark-primary) !important;
  border-radius: 50% !important;
  object-fit: cover !important;
}

/* ============================================================
   MODALS
   ============================================================ */
.modal-content {
  border: 1px solid #e3eaf2 !important;
  border-radius: var(--ark-radius-lg) !important;
  box-shadow: 0 8px 40px rgba(31,45,65,0.14) !important;
}
.modal-header {
  border-bottom: 1px solid #e3eaf2 !important;
  background: #fafcfe !important;
  border-radius: var(--ark-radius-lg) var(--ark-radius-lg) 0 0 !important;
}
.modal-title { color: var(--ark-text-main) !important; font-weight: 600 !important; }
.modal-footer { border-top: 1px solid #e3eaf2 !important; background: #fafcfe !important; }

/* ============================================================
   MISC
   ============================================================ */
.text-primary { color: var(--ark-primary) !important; }
a.text-primary:hover { color: var(--ark-primary-dark) !important; }
.text-muted { color: var(--ark-text-muted) !important; }
hr { border-color: #e3eaf2 !important; }
.post-content a { color: var(--ark-primary) !important; }
.header-link { color: var(--ark-primary) !important; }
.stretched-link { color: var(--ark-primary) !important; }
.text-purple { color: var(--ark-primary) !important; }

/* Notification item icon */
.dropdown-notifications-item-icon.bg-warning {
  background: var(--ark-primary-light) !important;
  border-radius: var(--ark-radius) !important;
}
.dropdown-notifications-item-icon svg { stroke: var(--ark-primary) !important; }

/* Scrollbar */
::-webkit-scrollbar { width: 5px; height: 5px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #b0bed0; border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--ark-primary); }

/* ============================================================
   WELCOME BANNER  (no background card)
   ============================================================ */
.ark-welcome-banner {
  padding: 1.25rem 0 0.5rem;
}
.ark-welcome-inner {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 1rem;
  padding-bottom: 1.25rem;
  border-bottom: 1px solid #e3eaf2;
}
.ark-welcome-greeting {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--ark-primary);
  margin-bottom: 0.4rem;
}
.ark-welcome-title {
  font-size: 1.6rem;
  font-weight: 700;
  color: var(--ark-text-main);
  margin: 0 0 0.4rem;
  line-height: 1.2;
}
.ark-welcome-name {
  color: var(--ark-primary);
}
.ark-welcome-sub {
  font-size: 0.9rem;
  color: var(--ark-text-muted);
  margin: 0;
}
.ark-welcome-actions {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-shrink: 0;
}
.ark-welcome-link {
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--ark-primary) !important;
  text-decoration: none !important;
  display: inline-flex;
  align-items: center;
  transition: color 0.15s;
}
.ark-welcome-link:hover {
  color: var(--ark-primary-dark) !important;
}

/* ============================================================
   SIDEBAR MENU GROUP HEADINGS  (override empty default)
   ============================================================ */
.sidenav .sidenav-menu .nav .sidenav-menu-heading,
.sidenav-light .sidenav-menu .sidenav-menu-heading {
  color: var(--ark-text-light) !important;
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.1em !important;
  padding: 1.25rem 1rem 0.4rem !important;
  margin: 0 !important;
}

/* Feed badge in sidebar */
.sidenav .badge-secondary {
  background-color: var(--ark-primary-light) !important;
  color: var(--ark-primary) !important;
  font-size: 0.65rem !important;
  padding: 0.2em 0.55em !important;
  border-radius: 1rem !important;
  font-weight: 700;
}

/* ============================================================
   PAGE HEADER  — replace dark gradient with clean light banner
   Applies to all inner dashboard pages using .page-header-dark
   ============================================================ */

/* Override the dark gradient header entirely */
.page-header,
.page-header.page-header-dark {
  background: #ffffff !important;
  border-bottom: 1px solid #e3eaf2 !important;
  padding-top: 1.5rem !important;
  padding-bottom: 1.5rem !important;
  margin-bottom: 0 !important;
}

/* Page title row */
.page-header .page-header-content {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.page-header .page-header-title {
  display: flex !important;
  align-items: center !important;
  gap: 0.65rem !important;
  font-size: 1.35rem !important;
  font-weight: 700 !important;
  color: var(--ark-text-main) !important;
  margin: 0 !important;
}
.page-header .page-header-icon {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 2.2rem !important;
  height: 2.2rem !important;
  background: var(--ark-primary-light) !important;
  border-radius: var(--ark-radius) !important;
  flex-shrink: 0 !important;
}
.page-header .page-header-icon i,
.page-header .page-header-icon svg {
  color: var(--ark-primary) !important;
  stroke: var(--ark-primary) !important;
  width: 18px !important;
  height: 18px !important;
}
.page-header .page-header-subtitle {
  color: var(--ark-text-muted) !important;
  font-size: 0.85rem !important;
  margin-top: 0.25rem !important;
}

/* Breadcrumb inside page header */
.page-header .breadcrumb {
  background: transparent !important;
  padding: 0 !important;
  margin: 0 !important;
  font-size: 0.78rem !important;
}
.page-header .breadcrumb .breadcrumb-item { color: var(--ark-text-muted) !important; }
.page-header .breadcrumb .breadcrumb-item.active { color: var(--ark-primary) !important; font-weight: 600; }
.page-header .breadcrumb-item + .breadcrumb-item::before { color: var(--ark-text-light) !important; }

/* Fix the negative top margin that overlapped the old dark header */
.container-fluid.mt-n10,
.container-xl.mt-n10,
.container.mt-n10 {
  margin-top: 0 !important;
  padding-top: 1.5rem !important;
}

/* Page body wrapper — consistent top spacing when no page-header is used */
main > .container-fluid:first-child,
main > .container-xl:first-child,
main > .container:first-child {
  padding-top: 1.5rem;
}

/* ============================================================
   TABLES  — consistent light-theme data tables
   ============================================================ */
.table {
  color: var(--ark-text-main) !important;
  border-color: #e3eaf2 !important;
}
.table thead th {
  background-color: #f5f7fa !important;
  color: var(--ark-text-muted) !important;
  font-size: 0.72rem !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.06em !important;
  border-bottom: 2px solid #e3eaf2 !important;
  border-top: none !important;
  padding: 0.85rem 1rem !important;
  white-space: nowrap;
}
.table tbody td {
  border-color: #e3eaf2 !important;
  padding: 0.85rem 1rem !important;
  vertical-align: middle !important;
  font-size: 0.875rem !important;
  color: var(--ark-text-main) !important;
}
.table tbody tr:hover td {
  background-color: #f5f7fa !important;
}
.table-striped tbody tr:nth-of-type(odd) {
  background-color: #fafcfe !important;
}
.table-striped tbody tr:nth-of-type(odd):hover td {
  background-color: #f0f4f8 !important;
}
.table-bordered,
.table-bordered td,
.table-bordered th {
  border-color: #e3eaf2 !important;
}

/* ============================================================
   FORMS  — consistent input fields across all pages
   ============================================================ */
.form-control {
  border: 1px solid #e3eaf2 !important;
  border-radius: var(--ark-radius) !important;
  color: var(--ark-text-main) !important;
  background-color: #ffffff !important;
  font-size: 0.875rem !important;
  padding: 0.5rem 0.85rem !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
}
.form-control:focus {
  border-color: var(--ark-primary) !important;
  box-shadow: 0 0 0 3px rgba(10,26,40,0.1) !important;
  outline: none !important;
}
.form-control::placeholder { color: var(--ark-text-light) !important; }
.form-control.is-invalid {
  border-color: #dc3545 !important;
}
.form-label,
label {
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  color: var(--ark-text-muted) !important;
  margin-bottom: 0.35rem !important;
}
select.form-control,
.custom-select {
  background-color: #ffffff !important;
  border: 1px solid #e3eaf2 !important;
  border-radius: var(--ark-radius) !important;
  color: var(--ark-text-main) !important;
}
textarea.form-control { resize: vertical; min-height: 100px; }

/* Input group */
.input-group .input-group-text {
  background: #f5f7fa !important;
  border-color: #e3eaf2 !important;
  color: var(--ark-text-muted) !important;
  font-size: 0.875rem !important;
}

/* ============================================================
   TABS  — consistent nav-tabs across all pages
   ============================================================ */
.nav-tabs {
  border-bottom: 2px solid #e3eaf2 !important;
  gap: 0.25rem;
}
.nav-tabs .nav-link {
  border: none !important;
  border-bottom: 2px solid transparent !important;
  margin-bottom: -2px !important;
  color: var(--ark-text-muted) !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  padding: 0.65rem 1rem !important;
  border-radius: 0 !important;
  transition: color 0.15s, border-color 0.15s !important;
  background: transparent !important;
}
.nav-tabs .nav-link:hover {
  color: var(--ark-primary) !important;
  border-bottom-color: var(--ark-primary-light) !important;
}
.nav-tabs .nav-link.active {
  color: var(--ark-primary) !important;
  border-bottom-color: var(--ark-primary) !important;
  font-weight: 600 !important;
  background: transparent !important;
}
.tab-content { padding-top: 1.25rem; }

/* ============================================================
   CARD HEADER  — action buttons alignment
   ============================================================ */
.card-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  flex-wrap: wrap !important;
  gap: 0.5rem !important;
}
.card-header .col-md-6,
.card-header .col-md-4,
.card-header .col-md-8 {
  padding: 0 !important;
  flex: unset !important;
  width: auto !important;
  max-width: unset !important;
}
.card-header .text-right { text-align: right !important; }

/* ============================================================
   OUTLINE BUTTONS  — secondary actions
   ============================================================ */
.btn-outline-primary {
  color: var(--ark-primary) !important;
  border-color: var(--ark-primary) !important;
  border-radius: var(--ark-radius) !important;
  font-weight: 500 !important;
  transition: background 0.15s, color 0.15s !important;
}
.btn-outline-primary:hover {
  background-color: var(--ark-primary) !important;
  color: #ffffff !important;
  border-color: var(--ark-primary) !important;
}
.btn-outline-danger {
  border-radius: var(--ark-radius) !important;
  font-weight: 500 !important;
}
.btn-secondary {
  background-color: var(--ark-primary-light) !important;
  border-color: #e3eaf2 !important;
  color: var(--ark-primary) !important;
  border-radius: var(--ark-radius) !important;
  font-weight: 500 !important;
}
.btn-secondary:hover {
  background-color: #d8e0e8 !important;
  color: var(--ark-primary) !important;
}

/* ============================================================
   ALERTS
   ============================================================ */
.alert {
  border-radius: var(--ark-radius) !important;
  border: 1px solid transparent !important;
  font-size: 0.875rem !important;
}
.alert-info    { background: #e8ecf0 !important; color: var(--ark-primary) !important; border-color: #c8d4e0 !important; }
.alert-success { background: #dcf5ea !important; color: #0b7a42 !important; border-color: #a5dfc0 !important; }
.alert-warning { background: #fff4de !important; color: #9a6800 !important; border-color: #f5e0a0 !important; }
.alert-danger  { background: #fff0f5 !important; color: #c00055 !important; border-color: #f5b8d4 !important; }

/* ============================================================
   PAGINATION
   ============================================================ */
.pagination .page-link {
  color: var(--ark-primary) !important;
  border-color: #e3eaf2 !important;
  border-radius: var(--ark-radius) !important;
  margin: 0 2px !important;
  font-size: 0.85rem !important;
  padding: 0.4rem 0.75rem !important;
  transition: background 0.12s !important;
}
.pagination .page-link:hover {
  background-color: var(--ark-primary-light) !important;
  color: var(--ark-primary) !important;
}
.pagination .page-item.active .page-link {
  background-color: var(--ark-primary) !important;
  border-color: var(--ark-primary) !important;
  color: #ffffff !important;
}

/* ============================================================
   LIGHTCOLOR LABEL  (used in form rows)
   ============================================================ */
.lightcolor {
  color: var(--ark-text-muted) !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
}

/* ============================================================
   LOADING STATE
   ============================================================ */
.no-record-found,
td[colspan] {
  color: var(--ark-text-muted) !important;
  font-size: 0.875rem !important;
}

/* ============================================================
   RESPONSIVE UTILITIES
   ============================================================ */
@media (max-width: 767px) {
  .page-header .page-header-title { font-size: 1.1rem !important; }
  .card-header { flex-direction: column !important; align-items: flex-start !important; }
  .card-header .text-right { width: 100% !important; text-align: left !important; }
  .table thead th { font-size: 0.68rem !important; padding: 0.65rem 0.65rem !important; }
  .table tbody td { padding: 0.65rem !important; font-size: 0.82rem !important; }
}

/* ============================================================
   GLOBAL MODAL REDESIGN
   Applies to all .modal across the entire dashboard.
   Slide-in modals (modal-slide) retain their own positioning.
   ============================================================ */

/* ── Backdrop ─────────────────────────────────────────────── */
.modal-backdrop {
  background-color: #0a1a28 !important;
}
.modal-backdrop.show {
  opacity: 0.45 !important;
}

/* ── Entrance animation — scale + fade ───────────────────── */
.modal.fade:not(.modal-slide) .modal-dialog {
  transform: scale(0.95) translateY(-12px) !important;
  transition: transform 0.22s cubic-bezier(0.34, 1.28, 0.64, 1),
              opacity 0.18s ease !important;
}
.modal.show:not(.modal-slide) .modal-dialog {
  transform: scale(1) translateY(0) !important;
}

/* ── Dialog sizing ────────────────────────────────────────── */
.modal-dialog:not(.modal-slide .modal-dialog) {
  margin: 2rem auto !important;
}
.modal-dialog-centered {
  margin: auto !important;
  min-height: calc(100% - 3.5rem) !important;
  display: flex !important;
  align-items: center !important;
}

/* ── Modal content shell ──────────────────────────────────── */
.modal-content {
  border: none !important;
  border-radius: 1rem !important;
  box-shadow: 0 20px 60px rgba(10, 26, 40, 0.18),
              0 4px 16px rgba(10, 26, 40, 0.1) !important;
  overflow: hidden !important;
  background: #ffffff !important;
}

/* ── Modal header ─────────────────────────────────────────── */
.modal-header {
  padding: 1.25rem 1.5rem 1.1rem !important;
  background: #ffffff !important;
  border-bottom: 1px solid #e9eef4 !important;
  align-items: center !important;
  gap: 0.75rem !important;
}
.modal-title {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #0a1a28 !important;
  letter-spacing: -0.01em !important;
  line-height: 1.3 !important;
  margin: 0 !important;
}

/* ── Close button — both BS4 (.close) and BS5 (.btn-close) ── */
.modal-header .close,
.modal-header .btn-close {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 2rem !important;
  height: 2rem !important;
  min-width: 2rem !important;
  padding: 0 !important;
  margin: 0 0 0 auto !important;
  background: #f0f4f8 !important;
  border: none !important;
  border-radius: 50% !important;
  opacity: 1 !important;
  font-size: 1.1rem !important;
  line-height: 1 !important;
  color: #5a6a7a !important;
  cursor: pointer !important;
  transition: background 0.15s, color 0.15s !important;
  flex-shrink: 0 !important;
}
.modal-header .close:hover,
.modal-header .btn-close:hover {
  background: #e3eaf2 !important;
  color: #0a1a28 !important;
  opacity: 1 !important;
}
.modal-header .close span[aria-hidden="true"] {
  line-height: 1 !important;
  margin-top: -1px !important;
  display: block !important;
}

/* ── Modal body ───────────────────────────────────────────── */
.modal-body {
  padding: 1.5rem !important;
  font-size: 0.875rem !important;
  color: #4a5568 !important;
  line-height: 1.65 !important;
  background: #ffffff !important;
}

/* ── Modal footer ─────────────────────────────────────────── */
.modal-footer {
  padding: 1rem 1.5rem !important;
  background: #fafcfe !important;
  border-top: 1px solid #e9eef4 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  gap: 0.6rem !important;
  flex-wrap: wrap !important;
}

/* ── card-footer used as modal footer (careerselection) ───── */
.modal-content .card-footer {
  padding: 1rem 1.5rem !important;
  background: #fafcfe !important;
  border-top: 1px solid #e9eef4 !important;
  border-radius: 0 0 1rem 1rem !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  flex-wrap: wrap !important;
}

/* ── Headings inside modal body ───────────────────────────── */
.modal-body h3,
.modal-body h4 {
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: #0a1a28 !important;
  margin-bottom: 1rem !important;
  line-height: 1.4 !important;
}
.modal-body h2 {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #0a1a28 !important;
}
/* payment question heading */
.modal-body .paypalcustomer,
.modal-body h4.paypalcustomer {
  font-size: 0.95rem !important;
  font-weight: 600 !important;
  color: #2c3e50 !important;
  margin-bottom: 0 !important;
  line-height: 1.5 !important;
}

/* ── Buttons inside modals ────────────────────────────────── */
.modal .btn-primary,
.modal-footer .btn-primary,
.modal-content .card-footer .btn-primary {
  background: #0a1a28 !important;
  border-color: #0a1a28 !important;
  color: #ffffff !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  padding: 0.5rem 1.2rem !important;
  border-radius: 0.5rem !important;
  transition: background 0.15s, box-shadow 0.15s !important;
  box-shadow: 0 2px 6px rgba(10, 26, 40, 0.14) !important;
}
.modal .btn-primary:hover,
.modal-footer .btn-primary:hover,
.modal-content .card-footer .btn-primary:hover {
  background: #172d40 !important;
  border-color: #172d40 !important;
  box-shadow: 0 4px 12px rgba(10, 26, 40, 0.22) !important;
}
.modal .btn-outline-primary {
  color: #0a1a28 !important;
  border-color: #0a1a28 !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  padding: 0.5rem 1.2rem !important;
  border-radius: 0.5rem !important;
  transition: background 0.15s !important;
}
.modal .btn-outline-primary:hover {
  background: #0a1a28 !important;
  color: #ffffff !important;
}
.modal .btn-secondary,
.modal .btn-outline-secondary,
.modal [data-bs-dismiss="modal"]:not(.close):not(.btn-close),
.modal [data-dismiss="modal"]:not(.close) {
  background: #f0f4f8 !important;
  border-color: #d4dde8 !important;
  color: #4a5568 !important;
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  padding: 0.5rem 1.2rem !important;
  border-radius: 0.5rem !important;
  transition: background 0.15s !important;
}
.modal .btn-secondary:hover,
.modal [data-bs-dismiss="modal"]:not(.close):not(.btn-close):hover {
  background: #e3eaf2 !important;
  color: #0a1a28 !important;
}

.truncate {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Form inputs inside modals ────────────────────────────── */
.modal-body .form-control {
  border: 1px solid #d4dde8 !important;
  border-radius: 0.5rem !important;
  font-size: 0.875rem !important;
  padding: 0.55rem 0.875rem !important;
  background: #f8fafc !important;
  color: #2c3e50 !important;
  transition: border-color 0.15s, box-shadow 0.15s !important;
}
.modal-body .form-control:focus {
  border-color: #0a1a28 !important;
  box-shadow: 0 0 0 3px rgba(10, 26, 40, 0.08) !important;
  background: #ffffff !important;
  outline: none !important;
}
.modal-body label,
.modal-body .form-group label {
  font-size: 0.78rem !important;
  font-weight: 600 !important;
  color: #5a6a7a !important;
  margin-bottom: 0.35rem !important;
  display: block !important;
}
.modal-body .form-group {
  margin-bottom: 1rem !important;
}

/* ── ng-select inside modals ──────────────────────────────── */
.modal-body .ng-select .ng-select-container {
  border: 1px solid #d4dde8 !important;
  border-radius: 0.5rem !important;
  font-size: 0.875rem !important;
  min-height: 40px !important;
  background: #f8fafc !important;
}
.modal-body .ng-select.ng-select-focused .ng-select-container {
  border-color: #0a1a28 !important;
  box-shadow: 0 0 0 3px rgba(10, 26, 40, 0.08) !important;
}

/* ── Info / service cards inside modal body ───────────────── */
.modal-body .projects {
  background: #f8fafc !important;
  border: 1px solid #e9eef4 !important;
  border-radius: 0.75rem !important;
  padding: 1rem !important;
  margin-bottom: 0.75rem !important;
  box-shadow: none !important;
}
.modal-body .projects .info p {
  font-size: 0.8rem !important;
  color: #5a6a7a !important;
  margin-bottom: 0.4rem !important;
}
.modal-body .projects .info p span {
  display: inline-block !important;
  min-width: 110px !important;
  color: #8a96a3 !important;
  font-weight: 600 !important;
  font-size: 0.75rem !important;
}
.modal-body .projects .info strong {
  color: #0a1a28 !important;
  font-weight: 600 !important;
}
.modal-body .projects .Caction {
  margin-top: 0.75rem !important;
}
.modal-body .projects .btn-line,
.modal-body .projects .btn-outline-primary {
  font-size: 0.78rem !important;
  padding: 0.4rem 0.9rem !important;
  border-radius: 0.45rem !important;
  border: 1.5px solid #0a1a28 !important;
  color: #0a1a28 !important;
  background: transparent !important;
  font-weight: 600 !important;
  transition: background 0.15s !important;
}
.modal-body .projects .btn-line:hover {
  background: #0a1a28 !important;
  color: #ffffff !important;
}

/* ── Profile modal (sViewProfileModal) ───────────────────── */
.sViewProfileModal .sProf-info {
  display: flex !important;
  align-items: flex-start !important;
  gap: 1rem !important;
  padding-bottom: 1.25rem !important;
  margin-bottom: 1.25rem !important;
  border-bottom: 1px solid #e9eef4 !important;
}
.sViewProfileModal .sProf-img {
  width: 72px !important;
  height: 72px !important;
  border-radius: 50% !important;
  overflow: hidden !important;
  flex-shrink: 0 !important;
  border: 2px solid #e3eaf2 !important;
}
.sViewProfileModal .sProf-img img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
}
.sViewProfileModal .sProf-name {
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: #0a1a28 !important;
  margin-bottom: 0.3rem !important;
}
.sViewProfileModal .sProf-email,
.sViewProfileModal .sProf-phone {
  font-size: 0.8rem !important;
  color: #7f8c9a !important;
  margin-bottom: 0.2rem !important;
}
.sViewProfileModal .sProf-phone span {
  color: #0a1a28 !important;
  font-weight: 600 !important;
}

/* ── Badge / tag pills inside modals ──────────────────────── */
.modal-body .badge {
  font-size: 0.65rem !important;
  font-weight: 700 !important;
  padding: 0.25em 0.65em !important;
  border-radius: 2rem !important;
  letter-spacing: 0.04em !important;
}

/* ── Large / xl modals (service packages) ─────────────────── */
.modal-xl .modal-content,
.subscrPack .modal-content {
  border-radius: 1rem !important;
}
.modal-xl .modal-body,
.subscrPack .modal-body {
  padding: 1.25rem !important;
}

/* ── Scrollable modal body ────────────────────────────────── */
.modal-body[style*="overflow-y:scroll"],
.modal-body[style*="overflow-y: scroll"] {
  max-height: 75vh !important;
  overflow-y: auto !important;
  scrollbar-width: thin !important;
  scrollbar-color: #c8d4e0 transparent !important;
}
.modal-body::-webkit-scrollbar { width: 5px !important; }
.modal-body::-webkit-scrollbar-track { background: transparent !important; }
.modal-body::-webkit-scrollbar-thumb {
  background: #c8d4e0 !important;
  border-radius: 3px !important;
}

/* ── Confirm / simple modals (payment, cancel, etc.) ─────── */
.modal-dialog:not(.modal-lg):not(.modal-xl):not(.modal-slide .modal-dialog) .modal-content {
  border-radius: 1rem !important;
}

/* ── Responsive modal tweaks ──────────────────────────────── */
@media (max-width: 600px) {
  .modal-dialog:not(.modal-slide .modal-dialog) {
    margin: 0.75rem !important;
  }
  .modal-content {
    border-radius: 0.875rem !important;
  }
  .modal-header { padding: 1rem 1.1rem 0.875rem !important; }
  .modal-body   { padding: 1.1rem !important; }
  .modal-footer { padding: 0.875rem 1.1rem !important; }
}


.tab-content > .tab-pane {
  min-height: 105px;
}
