﻿/*
  RecruitMS Design System
  Bootstrap 5 + Bootswatch Lux â€” faithfully following Lux design tokens
  Lux: "A touch of class" â€” Nunito Sans, near-black primary, no border-radius, uppercase headings
*/

/* Nunito Sans â€” required by Bootswatch Lux */
@import url('https://fonts.googleapis.com/css2?family=Nunito+Sans:wght@200;300;400;500;600;700&display=swap');

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   1. CSS Variables / Brand Tokens
   Aligned to Bootswatch Lux _variables.scss
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
:root {
  /* Lux palette (from _variables.scss) */
  --rms-primary:        #1a1a1a;   /* Lux $primary = $gray-900 */
  --rms-primary-dark:   #000000;
  --rms-primary-light:  #f0f1f2;   /* Lux $gray-200 */

  /* Sidebar â€” intentional dark chrome (Lux has no sidebar definition) */
  --rms-sidebar-bg:     #1e293b;
  --rms-sidebar-hover:  #2d3f55;
  --rms-sidebar-active: #343a40;   /* Lux $dark ($gray-800) */
  --rms-sidebar-text:   #adb5bd;   /* Lux $gray-500 */
  --rms-sidebar-text-active: #ffffff;
  --rms-sidebar-width:  240px;
  --rms-sidebar-mini:   72px;

  /* Header */
  --rms-header-height:  56px;
  --rms-header-bg:      #ffffff;
  --rms-header-border:  #e0e1e2;   /* Lux $gray-300 */

  /* Content */
  --rms-body-bg:        #f8f9fa;   /* Lux $gray-100 */
  --rms-content-bg:     #ffffff;

  /* Cards â€” Lux enable-rounded: false â†’ radius 0 */
  --rms-card-shadow:    0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.05);
  --rms-card-shadow-md: 0 4px 6px -1px rgba(0,0,0,.08), 0 2px 4px -1px rgba(0,0,0,.05);
  --rms-card-radius:    0;

  /* Typography â€” Lux $body-color: $gray-700 */
  --rms-text:           #1a1a1a;   /* Lux $gray-900 / headings-color */
  --rms-text-muted:     #55595c;   /* Lux $gray-700 / $body-color */
  --rms-border:         #e0e1e2;   /* Lux $gray-300 */

  /* Badges â€” Lux enable-rounded: false */
  --rms-badge-radius:   0;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   2. Base / Reset
   Lux: font-family Nunito Sans, letter-spacing 1px, body-color #55595c
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
html, body {
  height: 100%;
}

body {
  background-color: var(--rms-body-bg);
  color: var(--rms-text-muted);     /* Lux $body-color = $gray-700 = #55595c */
  font-family: "Nunito Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  font-weight: 300;                 /* Lux $font-weight-normal = 300 */
  letter-spacing: 1px;              /* Lux bootswatch body rule */
  font-size: .9375rem;
}

/* Lux heading style: uppercase + 3px letter-spacing */
h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  text-transform: uppercase;
  letter-spacing: 3px;
  font-weight: 600;                 /* Lux $headings-font-weight */
  color: var(--rms-text);           /* Lux $headings-color = $gray-900 */
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   3. App Shell
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#rms-wrapper {
  display: flex;
  min-height: 100vh;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   4. Sidebar
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#rms-sidebar {
  position: fixed;
  top: 0;
  left: 0;
  width: var(--rms-sidebar-width);
  height: 100vh;
  background-color: var(--rms-sidebar-bg);
  display: flex;
  flex-direction: column;
  z-index: 1040;
  transition: width .25s ease, transform .25s ease;
  overflow-x: hidden;
  overflow-y: auto;
}

/* Brand */
#rms-sidebar .rms-brand {
  display: flex;
  align-items: center;
  gap: .75rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid rgba(255,255,255,.07);
  min-height: var(--rms-header-height);
  text-decoration: none;
  flex-shrink: 0;
}

/* Full sidebar: show the regular logo, hide the mini icon */
#rms-sidebar .rms-brand .rms-brand-logo {
  height: 32px;
  width: auto;
  object-fit: contain;
  flex-shrink: 0;
  display: block;
}

#rms-sidebar .rms-brand .rms-brand-icon {
  height: 36px;
  width: auto;
  object-fit: contain;
  flex-shrink: 0;
  display: none;  /* hidden in full mode */
}

/* Mini sidebar: hide regular logo, show the icon */
body.rms-mini-nav #rms-sidebar .rms-brand .rms-brand-logo {
  display: none;
}

body.rms-mini-nav #rms-sidebar .rms-brand .rms-brand-icon {
  display: block;
}

#rms-sidebar .rms-brand-text {
  color: #fff;
  font-weight: 700;
  font-size: 1.1rem;
  letter-spacing: -.01em;
  white-space: nowrap;
  overflow: hidden;
}

/* Nav section labels */
#rms-sidebar .rms-nav-label {
  color: #94a3b8;
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 1.25rem 1.25rem .35rem;
  white-space: nowrap;
  overflow: hidden;
}

/* Nav links */
#rms-sidebar .nav-item {
  padding: .1rem .75rem;
}

#rms-sidebar .nav-link {
  display: flex;
  align-items: center;
  gap: .75rem;
  color: var(--rms-sidebar-text) !important;
  padding: .6rem .75rem !important;
  border-radius: 0 !important;      /* Lux: no border-radius */
  font-size: .9rem;
  font-weight: 400;
  letter-spacing: 1px;              /* Lux body letter-spacing */
  text-decoration: none;
  transition: background-color .15s ease, color .15s ease;
  white-space: nowrap;
  overflow: hidden;
}

#rms-sidebar .nav-link:hover,
#rms-sidebar .nav-link:focus {
  background-color: var(--rms-sidebar-hover) !important;
  color: #fff !important;
}

#rms-sidebar .nav-link.active,
#rms-sidebar .nav-link[aria-current="page"] {
  background-color: var(--rms-sidebar-active) !important;
  color: var(--rms-sidebar-text-active) !important;
}

#rms-sidebar .nav-link .rms-nav-icon {
  font-size: 1rem;
  min-width: 1.25rem;
  text-align: center;
  flex-shrink: 0;
}

#rms-sidebar .nav-link .rms-nav-text {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Collapse / mini mode */
#rms-sidebar .rms-sidebar-footer {
  margin-top: auto;
  padding: .75rem;
  border-top: 1px solid rgba(255,255,255,.07);
  flex-shrink: 0;
}

#rms-sidebar .rms-toggle-btn {
  width: 100%;
  background: rgba(255,255,255,.08);
  border: none;
  color: var(--rms-sidebar-text);
  padding: .5rem;
  border-radius: 0;                 /* Lux: no border-radius */
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: .5rem;
  font-size: .85rem;
  transition: background-color .15s ease;
}

#rms-sidebar .rms-toggle-btn:hover {
  background: rgba(255,255,255,.15);
  color: #fff;
}

/* Mini sidebar */
body.rms-mini-nav #rms-sidebar {
  width: var(--rms-sidebar-mini);
}

body.rms-mini-nav #rms-sidebar .rms-brand-text,
body.rms-mini-nav #rms-sidebar .rms-nav-text,
body.rms-mini-nav #rms-sidebar .rms-nav-label,
body.rms-mini-nav #rms-sidebar .rms-toggle-label {
  display: none;
}

body.rms-mini-nav #rms-sidebar .rms-brand {
  justify-content: center;
}

body.rms-mini-nav #rms-sidebar .nav-link {
  justify-content: center;
  padding: .7rem .5rem !important;
}

body.rms-mini-nav #rms-sidebar .nav-link .rms-nav-icon {
  font-size: 1.15rem;
  min-width: unset;
}

body.rms-mini-nav #rms-sidebar .rms-toggle-btn {
  justify-content: center;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   5. Header
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#rms-header {
  position: fixed;
  top: 0;
  left: var(--rms-sidebar-width);
  right: 0;
  height: var(--rms-header-height);
  background: var(--rms-header-bg);
  border-bottom: 1px solid var(--rms-header-border);
  z-index: 1030;
  display: flex;
  align-items: center;
  padding: 0 1.5rem;
  gap: 1rem;
  transition: left .25s ease;
}

body.rms-mini-nav #rms-header {
  left: var(--rms-sidebar-mini);
}

#rms-header .rms-header-title {
  flex: 1;
  font-size: 1rem;
  font-weight: 600;
  color: var(--rms-text);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

#rms-header .rms-header-title small {
  font-size: .8rem;
  font-weight: 400;
  color: var(--rms-text-muted);
  margin-left: .5rem;
}

/* Mobile toggle for sidebar */
#rms-header .rms-mobile-toggle {
  display: none;
  background: none;
  border: none;
  color: var(--rms-text);
  font-size: 1.25rem;
  cursor: pointer;
  padding: .25rem;
  border-radius: .25rem;
}

#rms-header .rms-mobile-toggle:hover {
  background: var(--rms-body-bg);
}

/* Search bar */
#rms-header .rms-search-wrap {
  position: relative;
  width: 220px;
}

#rms-header .rms-search-wrap input {
  padding-left: 2rem;
  font-size: .875rem;
  background: var(--rms-body-bg);
  border-color: var(--rms-border);
  border-radius: 2rem;
}

#rms-header .rms-search-wrap .rms-search-icon {
  position: absolute;
  left: .65rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--rms-text-muted);
  font-size: .85rem;
  pointer-events: none;
}

/* Account dropdown */
#rms-header .rms-user-dropdown .dropdown-toggle {
  display: flex;
  align-items: center;
  gap: .5rem;
  background: none;
  border: 1px solid var(--rms-border);
  border-radius: 2rem;
  padding: .35rem .85rem .35rem .5rem;
  font-size: .875rem;
  color: var(--rms-text);
  cursor: pointer;
  transition: background .15s ease;
}

#rms-header .rms-user-dropdown .dropdown-toggle:hover {
  background: var(--rms-body-bg);
}

#rms-header .rms-user-dropdown .rms-avatar {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--rms-primary);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .8rem;
  font-weight: 600;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   6. Main Content Area
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#rms-content {
  margin-left: var(--rms-sidebar-width);
  margin-top: var(--rms-header-height);
  flex: 1;
  padding: 1.5rem;
  min-height: calc(100vh - var(--rms-header-height));
  transition: margin-left .25s ease;
}

body.rms-mini-nav #rms-content {
  margin-left: var(--rms-sidebar-mini);
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   7. Cards
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.card {
  border: 1px solid var(--rms-border);
  border-radius: 0 !important;      /* Lux: enable-rounded: false */
  box-shadow: var(--rms-card-shadow);
}

.card-header {
  background: #fff;
  border-bottom: 1px solid var(--rms-border);
  font-weight: 600;                 /* Lux $headings-font-weight */
  font-size: .95rem;
  letter-spacing: 2px;              /* Lux heading tracking */
  text-transform: uppercase;        /* Lux heading style */
  padding: .875rem 1.25rem;
}

.card-header.rms-card-header-primary {
  background: var(--rms-primary);
  color: #fff;
  border-bottom: none;
  border-radius: 0 !important;      /* Lux: no radius */
}

.rms-stat-card {
  border: 1px solid var(--rms-border);
  border-radius: 0;                 /* Lux: no radius */
  box-shadow: var(--rms-card-shadow);
  background: #fff;
  padding: 1.25rem;
  display: flex;
  align-items: flex-start;
  gap: 1rem;
}

.rms-stat-card .rms-stat-icon {
  width: 48px;
  height: 48px;
  border-radius: .5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.35rem;
  flex-shrink: 0;
}

.rms-stat-card .rms-stat-value {
  font-size: 1.75rem;
  font-weight: 700;
  color: var(--rms-text);
  line-height: 1;
}

.rms-stat-card .rms-stat-label {
  font-size: .8rem;
  color: var(--rms-text-muted);
  margin-top: .25rem;
}

/* Legacy panel mapped to card look */
.panel {
  background: #fff;
  border: 1px solid var(--rms-border);
  border-radius: 0;                 /* Lux: no radius */
  box-shadow: var(--rms-card-shadow);
  overflow: hidden;
  margin-bottom: 1.5rem;
}

.panel .panel-heading,
.panel-heading {
  background: var(--rms-primary) !important;
  background-image: none !important;
  color: #fff !important;
  font-size: .85rem;
  font-weight: 600;
  letter-spacing: 2px;              /* Lux heading tracking */
  text-transform: uppercase;        /* Lux heading style */
  padding: .875rem 1.25rem;
  border-bottom: none;
  box-shadow: none !important;
}

.panel .panel-body,
.panel-body {
  background: #fff !important;
  padding: 1rem 1.25rem;
  border: none !important;
}

/* Status section titles (pai-RecruitMS-status) */
.pai-RecruitMS-status-item {
  background: #fff;
  border: 1px solid var(--rms-border);
  border-radius: 0;                 /* Lux: no radius */
  box-shadow: var(--rms-card-shadow);
  overflow: hidden;
  margin-bottom: 1.5rem;
}

.pai-RecruitMS-status-item-title {
  background: var(--rms-primary) !important;
  background-image: none !important;
  color: #fff !important;
  font-size: .8rem;
  font-weight: 600;
  letter-spacing: 2px;              /* Lux heading tracking */
  text-transform: uppercase;        /* Lux heading style */
  padding: .875rem 1.25rem;
  margin: 0;
}

.pai-RecruitMS-status-item-title-content {
  border: none !important;
  padding: 1rem 1.25rem;
  background: #fff !important;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   8. Tables
   Lux: th font-size-sm + uppercase; cell padding 1.5rem (sm: .75rem)
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.table {
  font-size: .875rem;
}

.table th {
  font-weight: 600;
  color: var(--rms-text-muted);
  font-size: .8125rem;              /* Lux $font-size-sm */
  text-transform: uppercase;        /* Lux th rule */
  letter-spacing: 1px;              /* Lux body letter-spacing */
  border-bottom: 2px solid var(--rms-border) !important;
  padding: 1.5rem;                  /* Lux .table th/td padding */
  background: #f8f9fa;              /* Lux $gray-100 */
}

.table td {
  padding: 1.5rem;                  /* Lux .table td padding */
  vertical-align: middle;
  border-color: rgba(0,0,0,.05);    /* Lux $table-border-color */
}

.table.table-sm th,
.table.table-sm td {
  padding: .75rem;                  /* Lux .table-sm padding */
}

.table-hover tbody tr:hover {
  background-color: var(--rms-primary-light);
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   9. Buttons
   Lux: font-weight 600, no border-radius, large padding, uppercase text
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.btn {
  font-weight: 600;                 /* Lux $btn-font-weight */
  font-size: .875rem;
  border-radius: 0;                 /* Lux: enable-rounded: false */
  letter-spacing: 1px;              /* Lux body letter-spacing */
  text-transform: uppercase;        /* Lux button convention */
  padding: .75rem 1.5rem;           /* Lux $input-btn-padding-y/x */
  transition: all .15s ease;
}

.btn-sm {
  font-size: .8rem;
  padding: .5rem 1rem;              /* Lux $input-btn-padding-y/x-sm */
}

.btn-lg {
  padding: 2rem;                    /* Lux $input-btn-padding-y/x-lg */
}

.btn-primary {
  background-color: var(--rms-primary);
  border-color: var(--rms-primary);
}

.btn-primary:hover {
  background-color: var(--rms-primary-dark);
  border-color: var(--rms-primary-dark);
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   10. Forms
   Lux: input-bg $gray-200 (#f0f1f2), border-radius 0, line-height 1.5
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.form-control,
.form-select {
  font-size: .875rem;
  border-color: var(--rms-border);
  border-radius: 0;                 /* Lux: enable-rounded: false */
  background-color: #f0f1f2;        /* Lux $input-bg = $gray-200 */
  color: var(--rms-text);
  line-height: 1.5;                 /* Lux $input-line-height */
}

.form-control:focus,
.form-select:focus {
  border-color: var(--rms-primary);
  box-shadow: 0 0 0 .2rem rgba(26, 26, 26, .15); /* Lux primary-based shadow */
  background-color: #fff;
}

label,
.form-label {
  font-weight: 600;                 /* Lux $font-weight-bold = 600 */
  font-size: .8125rem;              /* Lux $font-size-sm */
  text-transform: uppercase;        /* Lux label convention */
  letter-spacing: 1px;
  color: var(--rms-text);
  margin-bottom: .35rem;
}

.text-danger,
.field-validation-error {
  font-size: .8rem;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   11. Badges / Status Labels
   Lux: no border-radius, padding-top .28rem
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.badge {
  font-size: .75rem;
  font-weight: 600;
  border-radius: 0;                 /* Lux: enable-rounded: false */
  padding: .28rem .6em;             /* Lux badge padding-top */
  letter-spacing: 1px;
  text-transform: uppercase;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   12. Tabs
   Lux: uppercase text, letter-spacing, no radius
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.nav-tabs {
  border-bottom: 2px solid var(--rms-border) !important;
  gap: .25rem;
}

.nav-tabs .nav-link {
  color: var(--rms-text-muted) !important;
  background: transparent !important;
  background-image: none !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  border-radius: 0 !important;      /* Lux: no radius */
  padding: .6rem 1rem !important;
  font-size: .8125rem !important;   /* Lux $font-size-sm */
  font-weight: 600 !important;      /* Lux $font-weight-bold */
  text-transform: uppercase !important; /* Lux nav convention */
  letter-spacing: 1px !important;
  transition: color .15s ease, border-color .15s ease !important;
  margin-bottom: -2px;
}

.nav-tabs .nav-link:hover,
.nav-tabs .nav-link:focus {
  color: var(--rms-primary) !important;
  border-bottom-color: var(--rms-primary) !important;
  background: transparent !important;
}

.nav-tabs .nav-link.active,
.nav-tabs .nav-item.show .nav-link {
  color: var(--rms-primary) !important;
  border-bottom-color: var(--rms-primary) !important;
  background: transparent !important;
  font-weight: 600 !important;
}

.tab-content {
  padding: 1.25rem 0 !important;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   13. Alerts
   Lux: no border-radius
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.alert {
  border-radius: 0;                 /* Lux: enable-rounded: false */
  font-size: .875rem;
  border-left: 4px solid;
}

.alert-success  { border-left-color: #198754; }
.alert-danger   { border-left-color: #dc3545; }
.alert-warning  { border-left-color: #ffc107; }
.alert-info     { border-left-color: #0dcaf0; }

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   14. Accordion
   Lux: uppercase, no radius
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.accordion-button {
  background: var(--rms-primary) !important;
  color: #fff !important;
  font-weight: 600;                 /* Lux $font-weight-bold */
  font-size: .8125rem;              /* Lux $font-size-sm */
  text-transform: uppercase;        /* Lux heading style */
  letter-spacing: 2px;
  box-shadow: none !important;
  border-radius: 0 !important;      /* Lux: no radius */
}

.accordion-button::after {
  filter: brightness(0) invert(1);
}

.accordion-button:not(.collapsed) {
  background: var(--rms-primary-dark) !important;
  color: #fff !important;
}

.accordion-body {
  background: #fff;
  border: 1px solid var(--rms-border);
  border-top: none;
  border-radius: 0;                 /* Lux: no radius */
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   15. Page Title / Section Header
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.rms-page-header {
  margin-bottom: 1.5rem;
}

.rms-page-header h1,
.rms-page-header .rms-page-title {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--rms-text);
  margin: 0;
}

.rms-page-header .rms-page-subtitle {
  font-size: .875rem;
  color: var(--rms-text-muted);
  margin-top: .15rem;
}

/* Legacy page title */
.page-title-recruitMS {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 1rem;
  flex-wrap: wrap;
  gap: .5rem;
}

.page-title-recruitMS #pageTitle {
  font-size: 1.2rem;
  font-weight: 700;
  color: var(--rms-text);
}

.page-title-recruitMS #pageTitle small {
  font-size: .8rem;
  font-weight: 400;
  color: var(--rms-text-muted);
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   16. Dashboard Summary Cards
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.summery-wrap {
  margin-bottom: 1.5rem;
}

.summery-wrap-inner {
  background: #fff;
  border: 1px solid var(--rms-border);
  border-radius: 0;                 /* Lux: no radius */
  box-shadow: var(--rms-card-shadow);
  padding: 1.25rem;
  position: relative;
  overflow: hidden;
  margin-bottom: 1rem;
  display: flex;
  flex-direction: column;
  gap: .5rem;
  transition: box-shadow .15s ease;
}

.summery-wrap-inner:hover {
  box-shadow: var(--rms-card-shadow-md);
}

.summery-wrap-inner > i.fa {
  font-size: 2rem;
  opacity: .15;
  position: absolute;
  right: 1rem;
  top: 50%;
  transform: translateY(-50%);
}

.summery-wrap-inner-content h1 {
  font-size: 2rem;
  font-weight: 700;
  margin: 0;
  line-height: 1;
}

.summery-wrap-inner-content h1 small {
  font-size: .85rem;
  font-weight: 400;
  color: var(--rms-text-muted);
  display: block;
  margin-top: .25rem;
}

.summery-wrap-inner-read-more {
  font-size: .78rem;
  font-weight: 600;
  text-decoration: none;
  letter-spacing: .02em;
}

/* Lux-aligned dashboard accent colors â€” using Lux named colors */
.summery-wrap-inner-one   { border-top: 3px solid #1a1a1a; }  /* Lux primary */
.summery-wrap-inner-two   { border-top: 3px solid #4bbf73; }  /* Lux $green */
.summery-wrap-inner-three { border-top: 3px solid #f0ad4e; }  /* Lux $yellow */
.summery-wrap-inner-four  { border-top: 3px solid #d9534f; }  /* Lux $red */

.summery-wrap-inner-one   > i.fa { color: #1a1a1a; }
.summery-wrap-inner-two   > i.fa { color: #4bbf73; }
.summery-wrap-inner-three > i.fa { color: #f0ad4e; }
.summery-wrap-inner-four  > i.fa { color: #d9534f; }

.summery-wrap-inner-one   .summery-wrap-inner-read-more { color: #1a1a1a; }
.summery-wrap-inner-two   .summery-wrap-inner-read-more { color: #4bbf73; }
.summery-wrap-inner-three .summery-wrap-inner-read-more { color: #f0ad4e; }
.summery-wrap-inner-four  .summery-wrap-inner-read-more { color: #d9534f; }

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   17. Footer
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#rms-footer {
  margin-left: var(--rms-sidebar-width);
  padding: .75rem 1.5rem;
  background: #fff;
  border-top: 1px solid var(--rms-border);
  text-align: center;
  font-size: .8rem;
  color: var(--rms-text-muted);
  transition: margin-left .25s ease;
}

body.rms-mini-nav #rms-footer {
  margin-left: var(--rms-sidebar-mini);
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   18. Modal
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#modal-container .modal-header {
  background: #f8f9fa;              /* Lux $gray-100 */
  border-bottom: 1px solid var(--rms-border);
}

#modal-container .modal-title {
  font-size: .875rem;
  font-weight: 600;                 /* Lux $font-weight-bold */
  text-transform: uppercase;        /* Lux heading style */
  letter-spacing: 2px;
}

#modal-container .modal-footer {
  background: #f8f9fa;              /* Lux $gray-100 */
  border-top: 1px solid var(--rms-border);
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   19. Empty State
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.rms-empty-state {
  text-align: center;
  padding: 3rem 1rem;
  color: var(--rms-text-muted);
}

.rms-empty-state .rms-empty-icon {
  font-size: 3rem;
  opacity: .4;
  margin-bottom: 1rem;
}

.rms-empty-state p {
  font-size: .9rem;
  margin-bottom: 1rem;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   20. Login Page
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
.rms-login-wrapper {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, #1e293b 0%, #2d3f55 50%, #1e293b 100%);
  padding: 2rem 1rem;
}

.rms-login-card {
  width: 100%;
  max-width: 420px;
  background: #fff;
  border-radius: 0;                 /* Lux: no radius */
  box-shadow: 0 20px 60px rgba(0,0,0,.25);
  padding: 2.5rem 2rem;
}

.rms-login-card .rms-login-logo {
  text-align: center;
  margin-bottom: 1.75rem;
}

.rms-login-card .rms-login-logo img {
  height: 56px;
  width: auto;
}

.rms-login-card h1 {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--rms-text);
  text-align: center;
  margin-bottom: .25rem;
}

.rms-login-card .rms-login-subtitle {
  text-align: center;
  color: var(--rms-text-muted);
  font-size: .875rem;
  margin-bottom: 1.75rem;
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   21. Responsive / Mobile
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
@media (max-width: 768px) {
  #rms-sidebar {
    transform: translateX(calc(-1 * var(--rms-sidebar-width)));
    width: var(--rms-sidebar-width) !important;
  }

  #rms-sidebar.rms-sidebar-open {
    transform: translateX(0);
  }

  #rms-header {
    left: 0;
  }

  #rms-header .rms-mobile-toggle {
    display: flex;
  }

  #rms-content {
    margin-left: 0;
  }

  #rms-footer {
    margin-left: 0;
  }

  body.rms-mini-nav #rms-sidebar {
    width: var(--rms-sidebar-width) !important;
    transform: translateX(calc(-1 * var(--rms-sidebar-width)));
  }

  body.rms-mini-nav #rms-content {
    margin-left: 0;
  }

  /* Overlay when sidebar open on mobile */
  .rms-sidebar-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.5);
    z-index: 1039;
  }

  .rms-sidebar-overlay.active {
    display: block;
  }
}

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   22. Scrollbar polish
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
#rms-sidebar::-webkit-scrollbar { width: 6px; }
#rms-sidebar::-webkit-scrollbar-track { background: transparent; }
#rms-sidebar::-webkit-scrollbar-thumb { background: rgba(255,255,255,.15); border-radius: 3px; }
#rms-sidebar::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,.25); }

/* â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€
   23. Utility overrides
   â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€â”€ */
/* "View All" link on dashboard */
.rec-view-all-btn {
  display: inline-block;
  margin-top: .5rem;
  font-size: .8rem;
  font-weight: 600;
  color: var(--rms-primary);
  text-decoration: none;
}
.rec-view-all-btn:hover { text-decoration: underline; }

/* Select2 alignment â€” Lux: no border-radius, gray-200 bg */
.select2-container--default .select2-selection--single {
  height: calc(1.5em + 1.5rem + 2px); /* Lux input padding */
  padding: .75rem;
  font-size: .875rem;
  border-color: var(--rms-border);
  border-radius: 0;                 /* Lux: no radius */
  background-color: #f0f1f2;        /* Lux $input-bg */
}

/* DataTables pagination alignment â€” Lux: no border-radius */
.dataTables_wrapper .dataTables_paginate .paginate_button.current,
.dataTables_wrapper .dataTables_paginate .paginate_button.current:hover {
  background: var(--rms-primary);
  border-color: var(--rms-primary);
  color: #fff !important;
  border-radius: 0;                 /* Lux: no radius */
}

/* Highcharts / CanvasJS chart containers */
.RecruitMS-paichart {
  min-height: 280px;
}

/* ──────────────────────────────────────────
   21. Slide-in Panel (cd-panel / cd-mask)
   ────────────────────────────────────────── */
/* Override SlideInPanel.css html/body height rule that breaks the app shell */
html, body { height: auto; min-height: 100%; }

/* Dark overlay — sits above page content but below the slide panel */
.cd-mask {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.55);
    z-index: 1045;
}

/* Slide panel and its children sit above the mask, header (1030) and sidebar (1040) */
.cd-panel          { top: 0 !important; z-index: 1050 !important; }
.cd-panel::after   { top: 0 !important; }
.cd-panel-header   { z-index: 1052 !important; }
.cd-panel-container{ z-index: 1051 !important; }

/* ── Index table: hide row checkboxes ── */
.table .form-check { display: none; }

/* ════════════════════════════════════════════════════════
   AR-4: Extracted from inline <style> blocks in views
   ════════════════════════════════════════════════════════ */

/* ── Dashboard ── */
.HrSubTitle {
    margin-top: 0;
    width: 80px;
    margin-left: 0;
    border-width: 2px !important;
    margin-bottom: 5px;
}
.scrollable {
    height: 440px;
    overflow-y: auto;
    position: relative;
}
.divZoom { zoom: .85; }

/* ── Upgrade banner ── */
.upgrade-banner {
    border-left-width: 5px !important;
    box-shadow: 0 2px 8px rgba(0,0,0,.1);
    margin-bottom: 1.5rem;
}
.upgrade-banner .banner-icon { line-height: 1; }
.upgrade-banner .alert-heading {
    font-size: 1.1rem;
    font-weight: 600;
}
@media (max-width: 768px) {
    .upgrade-banner .d-flex { flex-direction: column; align-items: flex-start !important; }
    .upgrade-banner .flex-shrink-0.ms-3 { margin-left: 0 !important; margin-top: 1rem; width: 100%; }
    .upgrade-banner .btn { width: 100%; }
}

/* ── SEO preview widget ── */
.google-preview {
    font-family: Arial, sans-serif;
    padding: 10px;
    border: 1px solid #ddd;
    border-radius: 4px;
    background: white;
}
.preview-url { font-size: 14px; margin-bottom: 5px; }
.preview-title { font-size: 20px; color: #1a0dab; margin-bottom: 5px; cursor: pointer; }
.preview-title:hover { text-decoration: underline; }
.preview-description { font-size: 14px; line-height: 1.4; color: #545454; }

/* ── Chart containers (shared sizing) ── */
.rms-chart-container {
    height: 300px;
    min-width: 310px;
    max-width: 1200px;
    margin: 0 auto;
}
#CreatedJobOrderChart,
#ActiveCandidateChart,
#CandidateFlowChart {
    height: 300px;
    min-width: 310px;
    max-width: 1200px;
    margin: 0 auto;
}

/* ── Calendar ── */
#calendar { max-width: 900px; margin: 0 auto; }

/* ── Print / PDF layout ── */
@media print {
    #rms-footer, .btn, .no-print { display: none !important; }
}

/* ── Reports layout ── */
.reports-container {
    display: flex !important;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 15px !important;
}
.reports-container > div {
    flex: 0 0 calc(20% - 10px) !important;
    min-width: 150px;
    padding: 0 !important;
}

/* ── Report: sortable list items ── */
#sortable2 .list-group-item { min-height: 70px; }

/* ── Report panel body shading ── */
.report-panel-body .panel-body { background: #eeeeee; }

/* ── Report: DataTables export button spacing ── */
a.buttons-collection { margin-left: 1em; }

/* ── Report field editor ── */
.editCandField.form-control { width: initial; }
#divSelectCandidate .row,
#divSelectJobOrder .row {
    border-bottom: 1px solid #aaa;
    padding-bottom: 5px;
    padding-top: 5px;
}

/* ── Admin: CompanyWorkFlow active step ── */
.workflow-active-step { background-color: #f4ba51; }

/* ── Admin: Tenant wizard ── */
.wizard-step-circle {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #dee2e6;
    color: #6c757d;
    display: flex;
    align-items: center;
    justify-content: center;
    font-weight: 600;
    margin: 0 auto 4px;
    font-size: .85rem;
}
.wizard-step-indicator.active .wizard-step-circle { background: #0d6efd; color: #fff; }
.wizard-step-indicator.done .wizard-step-circle { background: #198754; color: #fff; }
.wizard-step-line {
    height: 2px;
    background: #dee2e6;
    margin-top: 15px;
    flex-grow: 1;
    max-width: 40px;
}

/* ── Billing: plan card select ── */
.plan-card { cursor: pointer; transition: border-color .15s, box-shadow .15s; }
.plan-card.selected {
    border-color: #0d6efd !important;
    box-shadow: 0 0 0 2px rgba(13,110,253,.25);
}

/* ── Candidate Index ── */
.tableHieght td { line-height: 30px !important; }
.firstLetterBig:first-letter { text-transform: uppercase; }
.jobs .joba td a { margin-top: 0 !important; margin-bottom: 0 !important; margin-left: 6px; }

/* ── Jobs public board tiles ── */
.tiles {
    min-height: 120px;
    background: #fff;
    border: 1px solid #cccccc;
    color: #000;
    font-weight: bold;
    box-shadow: 0 1px 0 3px rgba(0,0,0,.6);
    cursor: default;
}

/* Match action buttons — fixed width so Update and Reject are always the same size */
.btn-fixed-width {
    min-width: 80px;
    text-align: center;
}

