/*!*********************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[2]!../../node_modules/next/dist/build/webpack/loaders/postcss-loader/src/index.js??ruleSet[1].rules[14].oneOf[10].use[3]!./app/globals.css ***!
  \*********************************************************************************************************************************************************************************************************************************************************************/
:root {
  --together-green: #0b6b3a;
  --together-green-2: #168a45;
  --together-green-light: #4caf50; /* lighter green */
  --together-mint: #eaf6ef;
  --together-bg: #f5fbf7;
  --together-text: #172033;
  --together-muted: #667085;
  --together-border: rgba(11, 107, 58, 0.16);
  /* Module shell design tokens — aligned to Together brand */
  --text: #0b6b3a;
  --text-soft: #5a7a65;
  --text-muted: #96a2ad;
  --border: #e5e9ed;
  --border-soft: #f0efe9;
  --muted: #f8fafb;
  --orange: #f97316;
  --orange-strong: #ea580c;
  --orange-soft: #fff4eb;
  --teal-soft: #e8f4f8;
  --teal-mid: #1a6a8a;
  --success: #16a34a;
  --success-soft: #edf9f1;
  --warning: #f59e0b;
  --warning-soft: #fff8e7;
  --danger: #ef4444;
  --danger-soft: #fff1f2;
  --shadow-sm: 0 10px 24px rgba(11,107,58,.06);
  --shadow-md: 0 18px 40px rgba(11,107,58,.08);
  --shadow-lg: 0 24px 48px rgba(11,107,58,.11);
  --shadow-orange: 0 16px 30px rgba(249,115,22,.26);
  font-family: var(--font-cairo, "Cairo", system-ui, -apple-system, "Segoe UI", sans-serif);
}

/* Use a system Latin font for ASCII digit codepoints so Cairo's OpenType
   Arabic-Indic glyph substitution (triggered by lang="ar") never fires. */
@font-face {
  font-family: 'Cairo';
  src: local('Segoe UI'), local('Helvetica Neue'), local('Arial');
  unicode-range: U+0030-0039;
  font-weight: 100 900;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: radial-gradient(circle at top right, #e7f6ea, transparent 32rem), var(--together-bg);
  color: var(--together-text);
}

button, input, select, textarea {
  font-family: inherit;
  font-size: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

:root {
  --sidebar-w: 316px;
}

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: var(--sidebar-w) minmax(0, 1fr);
  direction: rtl;
}

/* ===== Sidebar ===== */
.sidebar {
  width: var(--sidebar-w);
  background: linear-gradient(180deg, #0d582c 0%, #15733c 100%);
  color: #fff;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  height: 100vh;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  overflow: hidden;
  transition: width 0.28s ease, padding 0.28s ease;
  z-index: 40;
  box-shadow: -18px 0 42px rgba(13, 88, 44, 0.16);
  padding: 22px 18px;
}

.sidebar.sidebar-collapsed {
  width: 96px;
  padding: 18px 12px;
  overflow: visible;
}

/* ── Logo bar ── */
.sidebar-logo {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 14px;
}

.sidebar-logo-bar {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.sidebar-logo-card {
  flex: 1 1;
  min-height: 78px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 14px 16px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(21, 115, 60, 0.14);
  box-shadow: 0 18px 30px rgba(8, 39, 19, 0.14);
  position: relative;
  overflow: hidden;
}

.sidebar-logo-card::before {
  content: "";
  position: absolute;
  inset: auto -24px -30px auto;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  background: rgba(165, 214, 63, 0.12);
}

.sidebar-logo-full {
  display: block;
  width: 152px;
  max-width: 100%;
  height: auto;
  position: relative;
  z-index: 1;
  filter: drop-shadow(0 10px 18px rgba(0, 0, 0, 0.12));
}

.sidebar-logo-icon {
  display: none;
  width: 34px;
  height: 34px;
  object-fit: contain;
  position: relative;
  z-index: 1;
}

.sidebar-toggle {
  width: 48px;
  height: 48px;
  flex: 0 0 48px;
  display: grid;
  place-items: center;
  border-radius: 18px;
  color: #fff;
  background: rgba(255, 255, 255, 0.10);
  border: 1px solid rgba(255, 255, 255, 0.14);
  box-shadow: 0 14px 24px rgba(0, 0, 0, 0.12);
  cursor: pointer;
  transition: transform 0.25s ease, background 0.25s ease, border-color 0.25s ease;
}

.sidebar-toggle:hover {
  background: rgba(255, 255, 255, 0.16);
  border-color: rgba(255, 255, 255, 0.22);
  transform: translateY(-1px);
}

.sidebar-toggle svg {
  width: 18px;
  height: 18px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2.2;
  transition: transform 0.28s ease;
}

.sidebar.sidebar-collapsed .sidebar-logo {
  align-items: center;
}

.sidebar.sidebar-collapsed .sidebar-logo-bar {
  flex-direction: column;
}

.sidebar.sidebar-collapsed .sidebar-logo-card {
  width: 58px;
  min-height: 58px;
  padding: 10px;
  border-radius: 20px;
  flex: none;
}

.sidebar.sidebar-collapsed .sidebar-logo-full {
  display: none;
}

.sidebar.sidebar-collapsed .sidebar-logo-icon {
  display: block;
}

.sidebar.sidebar-collapsed .sidebar-toggle svg {
  transform: rotate(180deg);
}

/* ── Scrollable nav area ── */
.sidebar-scroll-area {
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 16px;
  -webkit-padding-end: 4px;
          padding-inline-end: 4px;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: rgba(255, 255, 255, 0.22) transparent;
}

.sidebar-scroll-area::-webkit-scrollbar { width: 9px; }
.sidebar-scroll-area::-webkit-scrollbar-track { background: transparent; }
.sidebar-scroll-area::-webkit-scrollbar-thumb {
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(255,255,255,.22) 0%, rgba(255,255,255,.12) 100%);
  border: 2px solid transparent;
  background-clip: padding-box;
} 

/* ---------- Global Scrollbar Styling ---------- */
html { scroll-behavior: smooth; }
*::-webkit-scrollbar { width: 8px; height: 8px; }
*::-webkit-scrollbar-track { background: var(--together-bg); border-radius: 4px; }
*::-webkit-scrollbar-thumb { background: var(--together-green); border-radius: 4px; border: 2px solid transparent; background-clip: padding-box; }
*::-webkit-scrollbar-thumb:hover { background: var(--together-green-2); }
/* Firefox */
* { scrollbar-width: thin; scrollbar-color: var(--together-green) var(--together-bg); }
/* Utility class for scrollable containers */
.scrollable { overflow: auto; }


.sidebar-scroll-area > .sidebar-section-divider,
.sidebar-scroll-area > .sidebar-nav,
.sidebar-scroll-area > .module-switcher,
.sidebar-scroll-area > .promo-card,
.sidebar-scroll-area > .sidebar-no-module {
  flex: 0 0 auto;
}

.sidebar.sidebar-collapsed .sidebar-scroll-area {
  overflow: visible;
  padding-inline: 0;
  scrollbar-width: none;
}

/* ── Section divider ── */
.sidebar-section-divider {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 4px;
}

.sidebar-section-divider::before,
.sidebar-section-divider::after {
  content: '';
  flex: 1 1;
  height: 1px;
  background: rgba(255, 255, 255, 0.16);
}

.sidebar-section-divider span {
  color: rgba(255, 255, 255, 0.50);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.06em;
  white-space: nowrap;
  text-transform: uppercase;
}

.sidebar.sidebar-collapsed .sidebar-section-divider {
  display: none;
}

/* ── Nav ── */
.sidebar-nav {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  align-content: start;
  overflow: visible;
  min-height: 0;
}

/* ── Role nav group (expandable section) ── */
.role-nav-group,
.nav-item-wrap {
  position: relative;
  width: 100%;
}

.role-nav-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 38px;
  align-items: center;
  grid-gap: 8px;
  gap: 8px;
}

.nav-item {
  display: grid !important;
  grid-template-columns: 22px minmax(0, 1fr);
  align-items: center;
  grid-gap: 10px;
  gap: 10px;
  min-height: 48px;
  padding: 0 13px !important;
  border-radius: 16px !important;
  color: rgba(255, 255, 255, 0.72);
  font-size: 13px;
  font-weight: 800;
  border: 1px solid transparent;
  transition: background 0.20s ease, border-color 0.20s ease, color 0.20s ease, box-shadow 0.20s ease;
  min-width: 0;
}

.nav-item:hover {
  background: rgba(255, 255, 255, 0.10);
  color: #fff;
}

.nav-item.active {
  background: linear-gradient(135deg, #15733c 0%, #2c9142 100%) !important;
  color: #fff !important;
  box-shadow: 0 16px 32px rgba(21, 115, 60, 0.24) !important;
}

.nav-icon {
  width: 22px;
  height: 22px;
  display: grid;
  place-items: center;
  flex: 0 0 22px;
}

.nav-label {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  overflow: hidden;
  line-height: 1.35;
}

/* Expand button */
.nav-expand-btn {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid rgba(255, 255, 255, 0.10);
  color: rgba(255, 255, 255, 0.88);
  cursor: pointer;
  transition: background 0.20s ease, border-color 0.20s ease;
}

.nav-expand-btn:hover {
  background: rgba(255, 255, 255, 0.14);
  border-color: rgba(255, 255, 255, 0.16);
}

.nav-expand-btn svg {
  width: 16px;
  height: 16px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2;
  transition: transform 0.22s ease;
}

.role-nav-group.open .nav-expand-btn svg {
  transform: rotate(180deg);
}

/* Submenu */
.nav-submenu {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  padding-inline: 7px 3px;
  margin-top: 0;
  transform: translateY(-4px);
  transition: max-height 0.28s ease, opacity 0.24s ease, transform 0.24s ease, margin 0.24s ease;
}

.role-nav-group.open .nav-submenu {
  max-height: 640px;
  opacity: 1;
  margin-top: 6px;
  transform: translateY(0);
}

/* Sub-items — stacked (role-shell style) */
.nav-subitem {
  min-height: 40px;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-content: center;
  grid-gap: 2px;
  gap: 2px;
  padding: 7px 12px;
  border-radius: 14px;
  color: rgba(255, 255, 255, 0.72) !important;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.35;
  transition: background 0.20s ease, color 0.20s ease, border-color 0.20s ease, transform 0.20s ease;
  text-decoration: none;
}

.nav-subitem > span:first-child {
  display: block;
  white-space: normal;
}

.nav-subitem:hover {
  color: #fff !important;
  background: rgba(255, 255, 255, 0.10);
  border-color: rgba(255, 255, 255, 0.12);
  transform: translateX(-2px);
}

.nav-subitem.active {
  color: #fff !important;
  background: linear-gradient(135deg, rgba(165, 214, 63, 0.16) 0%, rgba(255, 255, 255, 0.12) 100%);
  border-color: rgba(165, 214, 63, 0.28);
  box-shadow: 0 12px 20px rgba(0, 0, 0, 0.10);
}

.nav-submeta {
  display: block;
  color: rgba(255, 255, 255, 0.46);
  font-size: 9px;
  font-weight: 800;
  white-space: normal;
  line-height: 1.35;
}

/* ── Collapsed sidebar state ── */
.sidebar.sidebar-collapsed .nav-expand-btn,
.sidebar.sidebar-collapsed .nav-label,
.sidebar.sidebar-collapsed .logout-label {
  opacity: 0;
  visibility: hidden;
  max-width: 0;
  margin: 0;
  overflow: hidden;
}

.sidebar.sidebar-collapsed .nav-submenu,
.sidebar.sidebar-collapsed .role-nav-group.open .nav-submenu {
  display: none !important;
  max-height: 0 !important;
  opacity: 0 !important;
  visibility: hidden !important;
  padding: 0 !important;
  margin: 0 !important;
}

.sidebar.sidebar-collapsed .nav-expand-btn {
  display: none !important;
}

.sidebar.sidebar-collapsed .role-nav-main {
  width: 100%;
  grid-template-columns: 1fr;
  justify-items: center;
}

.sidebar.sidebar-collapsed .role-nav-group {
  width: 100%;
  display: grid;
  justify-items: center;
}

.sidebar.sidebar-collapsed .nav-item {
  width: 56px;
  height: 56px;
  min-height: 56px;
  grid-template-columns: 1fr;
  place-items: center;
  padding: 0 !important;
  margin-inline: auto;
}

.sidebar.sidebar-collapsed .nav-item > *:not(.nav-icon) {
  display: none !important;
}

.sidebar.sidebar-collapsed .nav-icon {
  margin: 0 !important;
  width: 24px;
  height: 24px;
}

/* ── Flyout (white panel on hover when collapsed) ── */
.nav-flyout {
  position: absolute;
  top: 50%;
  left: auto;
  right: calc(100% + 6px);
  width: 248px;
  padding: 16px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(21, 115, 60, 0.12);
  box-shadow: 0 24px 44px rgba(15, 60, 30, 0.18);
  transform: translateY(-50%) translateX(8px);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.22s ease, transform 0.22s ease, visibility 0.22s ease;
  z-index: 60;
}

.nav-flyout::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -8px;
  width: 16px;
  height: 16px;
  background: #fff;
  border-top: 1px solid rgba(21, 115, 60, 0.10);
  border-right: 1px solid rgba(21, 115, 60, 0.10);
  transform: translateY(-50%) rotate(45deg);
}

.nav-flyout::before {
  content: "";
  position: absolute;
  top: 0;
  right: -18px;
  width: 22px;
  height: 100%;
  background: transparent;
}

.sidebar.sidebar-collapsed .nav-flyout {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.sidebar.sidebar-collapsed .role-nav-group:hover .nav-flyout,
.sidebar.sidebar-collapsed .role-nav-group:focus-within .nav-flyout {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(-50%) translateX(0);
}

.flyout-title {
  color: #0d582c;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.4;
}

.flyout-subtitle {
  margin-top: 4px;
  color: #54715e;
  font-size: 11px;
  font-weight: 800;
}

.flyout-links {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  margin-top: 14px;
}

.flyout-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 42px;
  padding: 0 12px;
  border-radius: 14px;
  background: #f8fcf8;
  color: #0d582c !important;
  border: 1px solid rgba(21, 115, 60, 0.08);
  font-size: 12px;
  font-weight: 900;
  text-decoration: none;
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.flyout-link:hover {
  transform: translateX(-2px);
  box-shadow: 0 10px 18px rgba(21, 115, 60, 0.10);
  border-color: rgba(21, 115, 60, 0.14);
}

.flyout-link span:last-child {
  color: #809687;
  font-size: 10px;
}

/* No module state */
.sidebar-no-module {
  color: rgba(255, 255, 255, 0.52);
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
}

/* ── Module switcher ── */
.module-switcher {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  padding: 10px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.switcher-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px 4px;
}

.switcher-title {
  color: rgba(255, 255, 255, 0.58);
  font-size: 10px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.switcher-tiles {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 6px;
  gap: 6px;
}

.mod-tile {
  min-height: 46px;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  grid-gap: 8px;
  gap: 8px;
  padding: 7px 8px;
  border-radius: 14px;
  color: rgba(255, 255, 255, 0.70);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid transparent;
  font-size: 10px;
  font-weight: 900;
  text-decoration: none;
  transition: background 0.18s ease, color 0.18s ease;
}

.mod-tile:hover {
  background: rgba(255, 255, 255, 0.09);
  color: #fff;
}

.mod-tile.active {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.16), rgba(255, 255, 255, 0.08));
  border-color: rgba(255, 255, 255, 0.14);
  color: #fff;
}

.mod-icon {
  width: 28px;
  height: 28px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: rgba(255, 255, 255, 0.82);
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
}

.mod-icon svg { width: 16px; height: 16px; }

.mod-label {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar.sidebar-collapsed .module-switcher {
  display: none;
}

/* ── Promo card ── */
.promo-card {
  border-radius: 20px;
  padding: 16px;
  background: linear-gradient(145deg, #2c9142 0%, #0d582c 100%);
  box-shadow: 0 20px 36px rgba(21, 115, 60, 0.24);
  transition: opacity 0.22s ease, transform 0.22s ease, margin 0.22s ease, padding 0.22s ease;
}

.promo-card h4 {
  margin: 0 0 7px;
  font-size: 13px;
  font-weight: 900;
  color: #fff;
}

.promo-card p {
  margin: 0;
  font-size: 11px;
  line-height: 1.85;
  color: rgba(255, 255, 255, 0.72);
  font-weight: 700;
}

.promo-actions {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  margin-top: 18px;
}

.promo-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  border-radius: 16px;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
}

.promo-link.primary {
  background: #fff;
  color: #0d582c !important;
}

.promo-link.primary:hover {
  background: #f0f9f2;
}

.promo-link.secondary {
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.16);
  color: #fff !important;
}

.promo-link.secondary:hover {
  background: rgba(255, 255, 255, 0.18);
}

.sidebar.sidebar-collapsed .promo-card {
  opacity: 0;
  transform: scale(0.92);
  pointer-events: none;
  height: 0;
  padding: 0;
  margin: 0;
  overflow: hidden;
  border-width: 0;
}

/* ── Footer / logout ── */
.sidebar-footer {
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}

.logout-btn {
  width: 100%;
  border: none;
  background: transparent;
  border-radius: 14px;
  padding: 11px 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  color: rgba(255, 255, 255, 0.62);
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  transition: background 0.18s ease, color 0.18s ease;
  white-space: nowrap;
  overflow: hidden;
  text-decoration: none;
}

.logout-btn:hover {
  color: #fff;
  background: rgba(255, 255, 255, 0.08);
}

.sidebar.sidebar-collapsed .logout-btn {
  justify-content: center;
  padding: 12px 0;
}

.main {
  min-width: 0;
}

.topbar {
  height: 76px;
  padding: 18px 32px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--together-border);
  background: rgba(255, 255, 255, 0.72);
  -webkit-backdrop-filter: blur(14px);
          backdrop-filter: blur(14px);
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  z-index: 5;
}

.topbar-subtitle {
  color: var(--together-muted);
  font-size: 13px;
  margin-top: 4px;
}

.topbar-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.content {
  padding: 32px;
}

.page-title {
  font-size: 34px;
  color: var(--together-green);
  margin: 0 0 8px;
}

.page-subtitle {
  color: var(--together-muted);
  margin: 0 0 24px;
  line-height: 1.7;
}

.grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.erp-card {
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid var(--together-border);
  border-radius: 18px;
  padding: 20px;
  box-shadow: 0 16px 45px rgba(11, 107, 58, 0.08);
}

.metric {
  font-size: 30px;
  color: var(--together-green);
  font-weight: 900;
  margin-top: 12px;
}

.dashboard-stack {
  display: grid;
  grid-gap: 20px;
  gap: 20px;
}

.dashboard-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.dashboard-panels {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  grid-gap: 16px;
  gap: 16px;
}

.metric-card {
  min-height: 156px;
  display: grid;
  align-content: space-between;
  grid-gap: 10px;
  gap: 10px;
}

.metric-label {
  color: var(--together-muted);
  font-weight: 800;
}

.metric-value {
  color: var(--together-green);
  font-size: 34px;
  line-height: 1;
}

.metric-card p,
.attention-item span {
  color: var(--together-muted);
  margin: 0;
  line-height: 1.6;
}

.section-heading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  margin-bottom: 16px;
}

.section-title {
  color: var(--together-green);
  font-size: 22px;
  margin: 0;
}

.summary-list,
.attention-list {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.summary-row,
.attention-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 14px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.58);
}

.summary-row strong,
.attention-item b {
  color: var(--together-green);
  font-size: 22px;
}

.attention-item div {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.attention-item--high {
  border-color: rgba(180, 35, 24, 0.24);
}

.attention-item--medium {
  border-color: rgba(220, 104, 3, 0.24);
}

.loading-card span,
.loading-card strong,
.loading-card p {
  display: block;
  min-height: 18px;
  border-radius: 999px;
  background: linear-gradient(90deg, #eef6f0, #dcefe3, #eef6f0);
}

.loading-card strong {
  width: 40%;
  min-height: 34px;
}

.loading-card p {
  width: 74%;
}

.settings-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.settings-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.settings-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.settings-summary-count {
  min-width: 132px;
  border-radius: 18px;
  padding: 16px;
  text-align: center;
  background: var(--together-mint);
  color: var(--together-green);
}

.settings-summary-count strong {
  display: block;
  font-size: 34px;
  line-height: 1;
}

.settings-group {
  border: 1px solid var(--together-border);
  border-radius: 18px;
  padding: 18px;
  background: rgba(255, 255, 255, 0.62);
}

.settings-list {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.settings-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 0.34fr);
  grid-gap: 16px;
  gap: 16px;
  align-items: center;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.78);
}

.settings-meta {
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.settings-meta strong {
  color: var(--together-green);
  font-size: 18px;
}

.settings-meta span,
.settings-meta p {
  color: var(--together-muted);
}

.settings-meta p {
  margin: 0;
  line-height: 1.7;
}

.settings-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 4px;
}

.settings-tags span {
  border-radius: 999px;
  padding: 5px 9px;
  background: #f3faf5;
  color: var(--together-green);
  font-size: 12px;
  font-weight: 800;
}

.settings-control {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-gap: 10px;
  gap: 10px;
  align-items: center;
}

.settings-control--readonly {
  grid-template-columns: 1fr;
  justify-items: stretch;
}

.settings-readonly-value {
  display: inline-flex;
  justify-content: center;
  border-radius: 14px;
  padding: 12px 14px;
  color: var(--together-green);
  background: var(--together-mint);
}

.settings-toggle {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 14px;
  padding: 10px 12px;
  background: #fff;
  color: var(--together-green);
  font-weight: 800;
}

.settings-toggle input {
  width: 18px;
  height: 18px;
  accent-color: var(--together-green);
}

.settings-message {
  margin: 0;
  border-radius: 14px;
  padding: 12px 14px;
  font-weight: 800;
}

.settings-message--success {
  color: var(--together-green);
  background: var(--together-mint);
}

.settings-message--error {
  color: #b42318;
  background: #fff4f2;
}

.settings-loading-card {
  min-height: 130px;
  display: grid;
  align-content: space-between;
}

.users-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.users-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.users-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.users-summary-metrics {
  display: flex;
  gap: 10px;
}

.users-summary-metrics span {
  min-width: 118px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.users-summary-metrics strong {
  display: block;
  font-size: 30px;
  line-height: 1;
}

.users-toolbar,
.users-create-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.users-toolbar {
  grid-template-columns: minmax(220px, 1fr) 180px auto auto;
}

.users-create-form {
  grid-template-columns: repeat(3, minmax(0, 1fr)) 170px minmax(190px, 0.7fr) auto;
}

.users-table-wrap {
  overflow-x: auto;
}

.users-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}

.users-table th {
  color: var(--together-muted);
  font-size: 13px;
  text-align: right;
  padding: 0 12px;
}

.users-table td {
  background: rgba(255, 255, 255, 0.78);
  border-block: 1px solid var(--together-border);
  padding: 14px 12px;
  vertical-align: middle;
}

.users-table td:first-child {
  -webkit-border-start: 1px solid var(--together-border);
          border-inline-start: 1px solid var(--together-border);
  border-start-start-radius: 16px;
  border-end-start-radius: 16px;
}

.users-table td:last-child {
  -webkit-border-end: 1px solid var(--together-border);
          border-inline-end: 1px solid var(--together-border);
  border-start-end-radius: 16px;
  border-end-end-radius: 16px;
}

.users-table td strong,
.users-table td span {
  display: block;
}

.users-table td strong {
  color: var(--together-green);
}

.users-table td span {
  color: var(--together-muted);
  margin-top: 4px;
}

.users-status-select,
.users-role-select {
  min-width: 150px;
}

.user-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.user-status--active {
  color: var(--together-green);
  background: var(--together-mint);
}

.user-status--inactive {
  color: #667085;
  background: #f2f4f7;
}

.user-status--suspended {
  color: #b42318;
  background: #fff4f2;
}

.role-assignment {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
}

.role-chip-list {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.role-chip-list--form {
  margin-top: 12px;
}

.role-chip {
  border: 1px solid var(--together-border);
  border-radius: 999px;
  padding: 7px 10px;
  color: var(--together-green);
  background: var(--together-mint);
  font: inherit;
  font-weight: 800;
  cursor: pointer;
}

.role-chip:disabled {
  cursor: default;
  opacity: 0.78;
}

.users-muted,
.users-empty {
  color: var(--together-muted);
}

.user-current-label {
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 5px 9px;
  color: var(--together-green);
  background: var(--together-mint);
  font-size: 12px;
  font-weight: 800;
}

.users-empty {
  margin: 14px 0 0;
  text-align: center;
}

.users-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 16px;
}

.users-loading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.users-loading-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 1fr 0.5fr 0.8fr;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
}

.employees-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.employees-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.employees-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.employees-summary-metrics {
  display: flex;
  gap: 10px;
}

.employees-summary-metrics span {
  min-width: 112px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.employees-summary-metrics strong {
  display: block;
  font-size: 30px;
  line-height: 1;
}

.employees-toolbar,
.employees-create-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.employees-toolbar {
  grid-template-columns: minmax(220px, 1fr) 160px 180px 180px auto auto;
}

.employees-create-form {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.employees-table-wrap {
  overflow-x: auto;
}

.employees-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}

.employees-table th {
  color: var(--together-muted);
  font-size: 13px;
  text-align: right;
  padding: 0 12px;
}

.employees-table td {
  background: rgba(255, 255, 255, 0.78);
  border-block: 1px solid var(--together-border);
  padding: 14px 12px;
  vertical-align: middle;
}

.employees-table td:first-child {
  -webkit-border-start: 1px solid var(--together-border);
          border-inline-start: 1px solid var(--together-border);
  border-start-start-radius: 16px;
  border-end-start-radius: 16px;
}

.employees-table td:last-child {
  -webkit-border-end: 1px solid var(--together-border);
          border-inline-end: 1px solid var(--together-border);
  border-start-end-radius: 16px;
  border-end-end-radius: 16px;
}

.employees-table td strong,
.employees-table td span {
  display: block;
}

.employees-table td strong {
  color: var(--together-green);
}

.employees-table td span {
  color: var(--together-muted);
  margin-top: 4px;
}

.employees-status-select {
  min-width: 150px;
}

.employee-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.employee-status--active {
  color: var(--together-green);
  background: var(--together-mint);
}

.employee-status--inactive {
  color: #667085;
  background: #f2f4f7;
}

.employee-status--on_leave {
  color: #b54708;
  background: #fff7ed;
}

.employee-status--terminated {
  color: #b42318;
  background: #fff4f2;
}

.employees-loading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.employees-loading-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 1fr 0.5fr 0.8fr;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
}

.organization-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.organization-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.organization-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.organization-summary-metrics {
  display: flex;
  gap: 10px;
}

.organization-summary-metrics span {
  min-width: 108px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.organization-summary-metrics strong {
  display: block;
  font-size: 30px;
  line-height: 1;
}

.organization-create-grid,
.organization-lists {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.organization-form,
.organization-row-list {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.organization-two-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 10px;
  gap: 10px;
}

.organization-row {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.78);
}

.organization-row strong {
  display: block;
  color: var(--together-green);
}

.organization-row span,
.organization-row p {
  color: var(--together-muted);
}

.organization-row p {
  margin: 4px 0 0;
  line-height: 1.6;
}

.organization-row-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  grid-gap: 10px;
  gap: 10px;
  align-items: center;
}

.organization-status-select {
  min-width: 130px;
}

.organization-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.organization-status--active {
  color: var(--together-green);
  background: var(--together-mint);
}

.organization-status--inactive {
  color: #667085;
  background: #f2f4f7;
}

.organization-loading {
  min-height: 120px;
  display: grid;
  align-content: space-between;
}

.attendance-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.attendance-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.attendance-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.attendance-summary-metrics {
  display: flex;
  gap: 10px;
}

.attendance-summary-metrics span {
  min-width: 104px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.attendance-summary-metrics strong {
  display: block;
  font-size: 30px;
  line-height: 1;
}

.attendance-toolbar,
.attendance-create-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.attendance-toolbar {
  grid-template-columns: minmax(220px, 1fr) 150px 140px 150px 150px auto auto;
}

.attendance-create-form {
  grid-template-columns: minmax(220px, 1fr) repeat(4, minmax(0, 0.75fr)) minmax(180px, 1fr) auto;
}

.attendance-table-wrap {
  overflow-x: auto;
}

.attendance-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}

.attendance-table th {
  color: var(--together-muted);
  font-size: 13px;
  text-align: right;
  padding: 0 12px;
}

.attendance-table td {
  background: rgba(255, 255, 255, 0.78);
  border-block: 1px solid var(--together-border);
  padding: 14px 12px;
  vertical-align: middle;
}

.attendance-table td:first-child {
  -webkit-border-start: 1px solid var(--together-border);
          border-inline-start: 1px solid var(--together-border);
  border-start-start-radius: 16px;
  border-end-start-radius: 16px;
}

.attendance-table td:last-child {
  -webkit-border-end: 1px solid var(--together-border);
          border-inline-end: 1px solid var(--together-border);
  border-start-end-radius: 16px;
  border-end-end-radius: 16px;
}

.attendance-table td strong,
.attendance-table td span {
  display: block;
}

.attendance-table td strong {
  color: var(--together-green);
}

.attendance-table td span {
  color: var(--together-muted);
  margin-top: 4px;
}

.attendance-status-select {
  min-width: 150px;
}

.attendance-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.attendance-status--pending {
  color: #b54708;
  background: #fff7ed;
}

.attendance-status--present,
.attendance-status--approved {
  color: var(--together-green);
  background: var(--together-mint);
}

.attendance-status--absent,
.attendance-status--rejected {
  color: #b42318;
  background: #fff4f2;
}

.attendance-status--late {
  color: #b54708;
  background: #fff7ed;
}

.attendance-status--excused {
  color: #175cd3;
  background: #eff8ff;
}

.attendance-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.attendance-loading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.attendance-loading-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 1fr 0.5fr 0.8fr;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
}

.leave-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.leave-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.leave-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.leave-summary-metrics {
  display: flex;
  gap: 10px;
}

.leave-summary-metrics span {
  min-width: 112px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.leave-summary-metrics strong {
  display: block;
  font-size: 30px;
  line-height: 1;
}

.leave-toolbar,
.leave-create-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.leave-toolbar {
  grid-template-columns: minmax(220px, 1fr) 160px 160px 150px 150px auto auto;
}

.leave-create-form {
  grid-template-columns: minmax(220px, 1fr) 150px 150px 150px 160px minmax(190px, 1fr) auto;
}

.leave-table-wrap {
  overflow-x: auto;
}

.leave-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}

.leave-table th {
  color: var(--together-muted);
  font-size: 13px;
  text-align: right;
  padding: 0 12px;
}

.leave-table td {
  background: rgba(255, 255, 255, 0.78);
  border-block: 1px solid var(--together-border);
  padding: 14px 12px;
  vertical-align: middle;
}

.leave-table td:first-child {
  -webkit-border-start: 1px solid var(--together-border);
          border-inline-start: 1px solid var(--together-border);
  border-start-start-radius: 16px;
  border-end-start-radius: 16px;
}

.leave-table td:last-child {
  -webkit-border-end: 1px solid var(--together-border);
          border-inline-end: 1px solid var(--together-border);
  border-start-end-radius: 16px;
  border-end-end-radius: 16px;
}

.leave-table td strong,
.leave-table td span {
  display: block;
}

.leave-table td strong {
  color: var(--together-green);
}

.leave-table td span {
  color: var(--together-muted);
  margin-top: 4px;
}

.leave-status-select {
  min-width: 160px;
}

.leave-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.leave-status--draft {
  color: #667085;
  background: #f2f4f7;
}

.leave-status--submitted {
  color: #b54708;
  background: #fff7ed;
}

.leave-status--approved {
  color: var(--together-green);
  background: var(--together-mint);
}

.leave-status--rejected,
.leave-status--cancelled {
  color: #b42318;
  background: #fff4f2;
}

.leave-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.leave-loading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.leave-loading-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 1fr 0.5fr 0.8fr;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
}

.documents-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.documents-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.documents-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.documents-summary-metrics {
  display: flex;
  gap: 10px;
}

.documents-summary-metrics span {
  min-width: 118px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.documents-summary-metrics strong {
  display: block;
  font-size: 26px;
  line-height: 1.05;
}

.documents-toolbar,
.documents-create-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.documents-toolbar {
  grid-template-columns: minmax(220px, 1fr) 160px 140px minmax(160px, 0.8fr) minmax(160px, 0.8fr) auto auto;
}

.documents-create-form {
  grid-template-columns: minmax(220px, 1fr) 150px minmax(220px, 1fr) minmax(180px, 0.85fr) 150px minmax(180px, 1fr) minmax(180px, 1fr) 130px auto;
}

.documents-table-wrap {
  overflow-x: auto;
}

.documents-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}

.documents-table th {
  color: var(--together-muted);
  font-size: 13px;
  text-align: right;
  padding: 0 12px;
}

.documents-table td {
  background: rgba(255, 255, 255, 0.78);
  border-block: 1px solid var(--together-border);
  padding: 14px 12px;
  vertical-align: middle;
}

.documents-table td:first-child {
  -webkit-border-start: 1px solid var(--together-border);
          border-inline-start: 1px solid var(--together-border);
  border-start-start-radius: 16px;
  border-end-start-radius: 16px;
}

.documents-table td:last-child {
  -webkit-border-end: 1px solid var(--together-border);
          border-inline-end: 1px solid var(--together-border);
  border-start-end-radius: 16px;
  border-end-end-radius: 16px;
}

.documents-table td strong,
.documents-table td span {
  display: block;
}

.documents-table td strong {
  color: var(--together-green);
}

.documents-table td span {
  color: var(--together-muted);
  margin-top: 4px;
}

.documents-status-select {
  min-width: 130px;
}

.documents-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.documents-status--active {
  color: var(--together-green);
  background: var(--together-mint);
}

.documents-status--archived {
  color: #667085;
  background: #f2f4f7;
}

.documents-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.documents-loading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.documents-loading-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 1fr 0.5fr 0.8fr;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
}

/* ==========================================================================
   Modern Documents Panel Styles (Refined & Premium Grid Layouts)
   ========================================================================== */

.documents-toolbar-modern {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.documents-toolbar-top {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-gap: 14px;
  gap: 14px;
  align-items: center;
}

.documents-toolbar-filters {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

@media (max-width: 767px) {
  .documents-toolbar-top {
    grid-template-columns: 1fr;
  }
}

.documents-create-form-modern {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  grid-gap: 20px;
  gap: 20px;
  padding: 12px 0;
}

.form-group-modern {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.form-group-modern label {
  font-size: 12.5px;
  font-weight: 800;
  color: var(--together-muted);
  font-family: 'Cairo';
}

.erp-input-modern {
  min-height: 42px;
  border-radius: 10px;
  border: 1px solid var(--together-border);
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 700;
  background: #fff;
  color: var(--together-green);
  font-family: 'Cairo';
  cursor: pointer;
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s;
}

.erp-input-modern:focus {
  border-color: var(--together-green);
  box-shadow: 0 0 0 3px rgba(21, 115, 60, 0.1);
}

.erp-input-modern:disabled {
  background: #f1f5f9;
  color: #94a3b8;
  cursor: not-allowed;
}

/* Beautiful responsive grid card for summary metrics */
.documents-summary-modern {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  grid-gap: 16px;
  gap: 16px;
  margin-top: 20px;
}

.metric-card-modern {
  background: #fff;
  border: 1px solid var(--together-border);
  border-radius: 20px;
  padding: 20px;
  display: flex;
  align-items: center;
  gap: 16px;
  box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.03);
  transition: transform 0.22s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.22s;
}

.metric-card-modern:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 20px -3px rgba(0, 0, 0, 0.06);
}

.metric-icon-modern {
  width: 46px;
  height: 46px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}

.metric-info-modern {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.metric-info-modern span {
  font-size: 12px;
  font-weight: 800;
  color: var(--together-muted);
  font-family: 'Cairo';
}

.metric-info-modern strong {
  font-size: 24px;
  font-weight: 900;
  color: var(--together-green);
  line-height: 1.1;
}

/* Modern documents table aesthetics */
.documents-table-wrap-modern {
  width: 100%;
  overflow-x: auto;
  border-radius: 20px;
  border: 1px solid var(--together-border);
  background: #fff;
  margin-top: 12px;
}

.documents-table-modern {
  width: 100%;
  border-collapse: collapse;
  text-align: right;
  font-size: 13.5px;
}

.documents-table-modern th {
  background: #f8fafc;
  color: var(--together-muted);
  font-weight: 800;
  padding: 16px;
  font-family: 'Cairo';
  border-bottom: 1.5px solid var(--together-border);
}

.documents-table-modern td {
  padding: 16px;
  border-bottom: 1px solid var(--together-border);
  vertical-align: middle;
  font-family: 'Cairo';
}

.documents-table-modern tr:last-child td {
  border-bottom: none;
}

.documents-table-modern tr:hover td {
  background: #f8fafc;
}

.projects-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.projects-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.projects-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.projects-summary-metrics {
  display: flex;
  gap: 10px;
}

.projects-summary-metrics span {
  min-width: 118px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.projects-summary-metrics strong {
  display: block;
  font-size: 30px;
  line-height: 1;
}

.projects-toolbar,
.projects-create-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.projects-toolbar {
  grid-template-columns: minmax(240px, 1fr) 160px 180px 150px 150px auto auto;
}

.projects-create-form {
  grid-template-columns: minmax(220px, 1fr) 150px minmax(180px, 0.9fr) minmax(170px, 0.8fr) 150px 150px 150px auto;
}

.projects-table-wrap {
  overflow-x: auto;
}

.projects-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}

.projects-table th {
  color: var(--together-muted);
  font-size: 13px;
  text-align: right;
  padding: 0 12px;
}

.projects-table td {
  background: rgba(255, 255, 255, 0.78);
  border-block: 1px solid var(--together-border);
  padding: 14px 12px;
  vertical-align: middle;
}

.projects-table td:first-child {
  -webkit-border-start: 1px solid var(--together-border);
          border-inline-start: 1px solid var(--together-border);
  border-start-start-radius: 16px;
  border-end-start-radius: 16px;
}

.projects-table td:last-child {
  -webkit-border-end: 1px solid var(--together-border);
          border-inline-end: 1px solid var(--together-border);
  border-start-end-radius: 16px;
  border-end-end-radius: 16px;
}

.projects-table td strong,
.projects-table td span {
  display: block;
}

.projects-table td strong {
  color: var(--together-green);
}

.projects-table td span {
  color: var(--together-muted);
  margin-top: 4px;
}

.projects-status-select {
  min-width: 150px;
}

.projects-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.projects-status--draft {
  color: #667085;
  background: #f2f4f7;
}

.projects-status--active {
  color: var(--together-green);
  background: var(--together-mint);
}

.projects-status--paused {
  color: #b54708;
  background: #fff7ed;
}

.projects-status--completed {
  color: #175cd3;
  background: #eff8ff;
}

.projects-status--cancelled {
  color: #b42318;
  background: #fff4f2;
}

.projects-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.projects-loading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.projects-loading-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 1fr 0.5fr 0.8fr;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
}

.reports-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.reports-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.reports-hero p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.reports-generated {
  min-width: 220px;
  border-radius: 18px;
  padding: 16px;
  background: var(--together-mint);
  color: var(--together-green);
  display: grid;
  grid-gap: 6px;
  gap: 6px;
}

.reports-generated span {
  color: var(--together-muted);
  font-weight: 800;
}

.reports-generated strong {
  font-size: 18px;
}

.reports-filters {
  display: grid;
  grid-template-columns: 180px 180px auto auto auto;
  grid-gap: 12px;
  gap: 12px;
  align-items: center;
}

.reports-metrics-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.reports-metric-card {
  min-height: 152px;
  display: grid;
  align-content: space-between;
  grid-gap: 10px;
  gap: 10px;
}

.reports-metric-card span {
  color: var(--together-muted);
  font-weight: 800;
}

.reports-metric-card strong {
  color: var(--together-green);
  font-size: 34px;
  line-height: 1;
}

.reports-metric-card p {
  color: var(--together-muted);
  margin: 0;
  line-height: 1.6;
}

.reports-panels {
  display: grid;
  grid-template-columns: minmax(0, 0.85fr) minmax(0, 1.15fr);
  grid-gap: 16px;
  gap: 16px;
}

.reports-structure-grid {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.reports-structure-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 14px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.62);
}

.reports-structure-item span {
  color: var(--together-muted);
  font-weight: 800;
}

.reports-structure-item strong {
  color: var(--together-green);
  font-size: 24px;
}

.reports-attention-list,
.reports-breakdown-list {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.reports-attention-item,
.reports-breakdown-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 14px;
  padding: 12px 14px;
  background: rgba(255, 255, 255, 0.62);
}

.reports-attention-item div {
  display: grid;
  grid-gap: 4px;
  gap: 4px;
}

.reports-attention-item strong,
.reports-breakdown-row span {
  color: var(--together-green);
  font-weight: 900;
}

.reports-attention-item span {
  color: var(--together-muted);
}

.reports-attention-item b,
.reports-breakdown-row strong {
  color: var(--together-green);
  font-size: 22px;
}

.reports-attention-item--high {
  border-color: rgba(180, 35, 24, 0.24);
}

.reports-attention-item--medium {
  border-color: rgba(220, 104, 3, 0.24);
}

.reports-breakdown-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.notifications-stack {
  display: grid;
  grid-gap: 18px;
  gap: 18px;
}

.notifications-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}

.notifications-summary p {
  color: var(--together-muted);
  line-height: 1.7;
  margin: 10px 0 0;
}

.notifications-summary-metrics {
  display: flex;
  gap: 10px;
}

.notifications-summary-metrics span {
  min-width: 124px;
  border-radius: 18px;
  padding: 14px;
  background: var(--together-mint);
  color: var(--together-green);
  text-align: center;
  font-weight: 800;
}

.notifications-summary-metrics strong {
  display: block;
  font-size: 28px;
  line-height: 1;
}

.notifications-toolbar,
.notifications-create-form {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.notifications-toolbar {
  grid-template-columns: minmax(240px, 1fr) 150px 150px minmax(180px, 0.9fr) auto auto auto;
}

.notifications-create-form {
  grid-template-columns: minmax(220px, 1fr) 150px 140px minmax(180px, 0.9fr) minmax(220px, 1fr) auto;
}

.notifications-table-wrap {
  overflow-x: auto;
}

.notifications-table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0 10px;
}

.notifications-table th {
  color: var(--together-muted);
  font-size: 13px;
  text-align: right;
  padding: 0 12px;
}

.notifications-table td {
  background: rgba(255, 255, 255, 0.78);
  border-block: 1px solid var(--together-border);
  padding: 14px 12px;
  vertical-align: middle;
}

.notifications-table td:first-child {
  -webkit-border-start: 1px solid var(--together-border);
          border-inline-start: 1px solid var(--together-border);
  border-start-start-radius: 16px;
  border-end-start-radius: 16px;
}

.notifications-table td:last-child {
  -webkit-border-end: 1px solid var(--together-border);
          border-inline-end: 1px solid var(--together-border);
  border-start-end-radius: 16px;
  border-end-end-radius: 16px;
}

.notifications-table td strong,
.notifications-table td span {
  display: block;
}

.notifications-table td strong {
  color: var(--together-green);
}

.notifications-table td span {
  color: var(--together-muted);
  margin-top: 4px;
}

.notifications-status-select {
  min-width: 135px;
}

.notifications-status {
  display: inline-flex;
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 7px 10px;
  font-weight: 800;
}

.notifications-status--unread {
  color: #b54708;
  background: #fff7ed;
}

.notifications-status--read {
  color: var(--together-green);
  background: var(--together-mint);
}

.notifications-status--archived {
  color: #667085;
  background: #f2f4f7;
}

.notifications-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.notifications-loading {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.notifications-loading-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 1fr 0.5fr 0.8fr;
  align-items: center;
  grid-gap: 12px;
  gap: 12px;
  border: 1px solid var(--together-border);
  border-radius: 16px;
  padding: 14px;
}

.erp-button {
  border: 0;
  border-radius: 14px;
  padding: 12px 18px;
  font-weight: 800;
  cursor: pointer;
}

.erp-button--primary {
  color: #fff;
  background: var(--together-green);
}

.erp-button--secondary {
  color: var(--together-green);
  background: var(--together-mint);
}

.erp-button--danger {
  color: #fff;
  background: #b42318;
}

.erp-button--ghost {
  color: var(--together-green);
  background: transparent;
}

.erp-input {
  width: 100%;
  border: 1px solid var(--together-border);
  border-radius: 14px;
  padding: 12px 14px;
  font: inherit;
  direction: rtl;
}

.erp-badge {
  display: inline-flex;
  border-radius: 999px;
  padding: 6px 10px;
  background: var(--together-mint);
  color: var(--together-green);
  font-weight: 800;
  font-size: 12px;
}

.login-page {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 2fr;
  grid-gap: 28px;
  gap: 28px;
  padding: 28px;
  direction: rtl;
  background:
    radial-gradient(circle at 14% 8%, rgba(44,145,66,.12), transparent 24%),
    radial-gradient(circle at 84% 16%, rgba(165,214,63,.12), transparent 20%),
    linear-gradient(180deg, #fbfdf9 0%, #f4faf2 48%, #edf5eb 100%);
}

.login-brand {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 54px;
  border-radius: 38px;
  background: linear-gradient(180deg, #0d582c 0%, #15733c 100%);
  color: #fff;
  overflow: hidden;
  box-shadow: 0 26px 56px rgba(21,115,60,.14);
}
.login-brand::before {
  content: "";
  position: absolute;
  width: 320px;
  height: 320px;
  left: -110px;
  bottom: -140px;
  border-radius: 50%;
  background: rgba(165,214,63,.15);
}

.login-brand-card {
  width: 250px;
  max-width: 100%;
  padding: 18px 20px;
  border-radius: 28px;
  background: rgba(255,255,255,.98);
  box-shadow: 0 18px 30px rgba(0,0,0,.14);
}
.login-brand-card img { display: block; width: 100%; height: auto; }

.login-eyebrow {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  margin-top: 30px;
  padding: 0 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.12);
  color: #d9f0d3;
  font-size: 12px;
  font-weight: 900;
  width: max-content;
}

.login-brand h1 { margin: 18px 0 10px; font-size: 56px; line-height: 1.02; }
.login-brand p { margin: 0; max-width: 620px; color: rgba(255,255,255,.76); font-size: 18px; line-height: 1.95; font-weight: 700; }

.login-highlights {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
  margin: 28px 0 0;
  padding: 0;
  list-style: none;
}
.login-highlights li {
  min-height: 54px;
  display: flex;
  align-items: center;
  padding: 0 16px;
  border-radius: 18px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.10);
  font-size: 14px;
  font-weight: 800;
}

.login-panel {
  display: flex;
  align-items: center;
  justify-content: center;
}

.login-card {
  width: min(100%, 470px);
  padding: 34px;
  border-radius: 34px;
  background: rgba(255,255,255,.96);
  border: 1px solid rgba(21,115,60,.08);
  box-shadow: 0 26px 56px rgba(21,115,60,.14);
}

.login-role-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 76px;
  height: 34px;
  border-radius: 999px;
  background: #eef8eb;
  color: #6d8f1d;
  font-size: 12px;
  font-weight: 900;
}

.login-card h2 { margin: 18px 0 8px; font-size: 30px; color: #0d582c; }
.login-card > p { margin: 0; color: #61766a; font-size: 15px; line-height: 1.9; font-weight: 700; }

.login-field { margin-top: 18px; }
.login-label { display: block; margin-bottom: 8px; color: #2d513d; font-size: 13px; font-weight: 900; }
.login-input {
  width: 100%;
  height: 56px;
  padding: 0 16px;
  border-radius: 18px;
  border: 1px solid rgba(21,115,60,.12);
  background: #fff;
  font: inherit;
  font-size: 15px;
  color: #173725;
  outline: none;
  direction: ltr;
  text-align: right;
}
.login-input:focus { border-color: rgba(21,115,60,.28); box-shadow: 0 0 0 4px rgba(21,115,60,.08); }

.login-actions { display: grid; grid-gap: 12px; gap: 12px; margin-top: 26px; }

.login-btn {
  height: 58px;
  border: none;
  border-radius: 20px;
  cursor: pointer;
  font: inherit;
  font-size: 16px;
  font-weight: 900;
  transition: opacity .18s;
}
.login-btn:disabled { opacity: .6; cursor: not-allowed; }
.login-btn-primary {
  background: linear-gradient(135deg, #15733c 0%, #2c9142 100%);
  color: #fff;
  box-shadow: 0 18px 32px rgba(21,115,60,.20);
}
.login-btn-secondary {
  background: #f7fbf6;
  color: #0d582c;
  border: 1px solid rgba(21,115,60,.10);
}

@media (max-width: 1080px) {
  .login-page {
    grid-template-columns: 1fr;
    padding: 18px;
  }
  .login-brand { padding: 34px; }
  .login-brand h1 { font-size: 42px; }
}

.form-stack {
  display: grid;
  grid-gap: 14px;
  gap: 14px;
}

.form-error {
  color: #b42318;
  margin: 0;
  font-weight: 700;
}

.session-gate {
  min-height: 100vh;
  display: grid;
  place-content: center;
  justify-items: center;
  grid-gap: 10px;
  gap: 10px;
  padding: 24px;
  text-align: center;
}

.session-gate h1,
.session-gate p {
  margin: 0;
}

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

  .sidebar {
    position: static;
    height: auto;
  }

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

  .dashboard-grid,
  .dashboard-panels {
    grid-template-columns: 1fr;
  }

  .settings-summary,
  .settings-row {
    grid-template-columns: 1fr;
  }

  .settings-summary {
    display: grid;
  }

  .settings-control {
    grid-template-columns: 1fr;
  }

  .users-summary {
    display: grid;
  }

  .users-summary-metrics,
  .users-toolbar,
  .users-create-form {
    grid-template-columns: 1fr;
  }

  .users-summary-metrics {
    display: grid;
  }

  .employees-summary {
    display: grid;
  }

  .employees-summary-metrics,
  .employees-toolbar,
  .employees-create-form {
    grid-template-columns: 1fr;
  }

  .employees-summary-metrics {
    display: grid;
  }

  .organization-summary {
    display: grid;
  }

  .organization-summary-metrics,
  .organization-create-grid,
  .organization-lists,
  .organization-row-actions {
    grid-template-columns: 1fr;
  }

  .organization-summary-metrics {
    display: grid;
  }

  .attendance-summary {
    display: grid;
  }

  .attendance-summary-metrics,
  .attendance-toolbar,
  .attendance-create-form {
    grid-template-columns: 1fr;
  }

  .attendance-summary-metrics {
    display: grid;
  }

  .leave-summary {
    display: grid;
  }

  .leave-summary-metrics,
  .leave-toolbar,
  .leave-create-form {
    grid-template-columns: 1fr;
  }

  .leave-summary-metrics {
    display: grid;
  }

  .documents-summary {
    display: grid;
  }

  .documents-summary-metrics,
  .documents-toolbar,
  .documents-create-form {
    grid-template-columns: 1fr;
  }

  .documents-summary-metrics {
    display: grid;
  }

  .projects-summary {
    display: grid;
  }

  .projects-summary-metrics,
  .projects-toolbar,
  .projects-create-form {
    grid-template-columns: 1fr;
  }

  .projects-summary-metrics {
    display: grid;
  }

  .reports-hero {
    display: grid;
  }

  .reports-generated {
    min-width: 0;
  }

  .reports-filters,
  .reports-metrics-grid,
  .reports-panels,
  .reports-breakdown-grid {
    grid-template-columns: 1fr;
  }

  .notifications-summary {
    display: grid;
  }

  .notifications-summary-metrics,
  .notifications-toolbar,
  .notifications-create-form {
    grid-template-columns: 1fr;
  }

  .notifications-summary-metrics {
    display: grid;
  }
}

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

  .topbar,
  .content {
    padding-inline: 18px;
  }

  .topbar {
    height: auto;
    align-items: flex-start;
    gap: 12px;
    flex-direction: column;
  }
}

.topbar {
  height: 86px;
  background: rgba(249, 252, 250, 0.82);
  -webkit-backdrop-filter: blur(22px);
          backdrop-filter: blur(22px);
  box-shadow: 0 14px 40px rgba(11, 107, 58, 0.06);
}

.topbar-profile,
.topbar-scope {
  display: flex;
  align-items: center;
  gap: 12px;
}

.topbar-avatar {
  width: 50px;
  height: 50px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  color: #fff;
  background: linear-gradient(135deg, #168a45, #0b6b3a);
  font-size: 24px;
  font-weight: 900;
  box-shadow: 0 16px 30px rgba(11, 107, 58, 0.2);
}

.topbar-profile strong {
  color: #172033;
  font-size: 15px;
}

.topbar-scope {
  min-height: 54px;
  border: 1px solid var(--together-border);
  border-radius: 22px;
  padding: 10px 18px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 16px 36px rgba(11, 107, 58, 0.07);
}

.topbar-scope span,
.topbar-scope strong {
  display: block;
}

.topbar-scope span {
  color: #8d9a92;
  font-size: 11px;
  font-weight: 800;
}

.topbar-scope strong {
  color: var(--together-green);
  font-size: 14px;
}

/* ===== Employees command center ===== */
.employees-command {
  display: grid;
  grid-gap: 28px;
  gap: 28px;
}

.employees-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}

.employees-page-header h1 {
  margin: 8px 0 0;
  color: var(--together-green);
  font-size: clamp(32px, 4vw, 52px);
  line-height: 1.05;
  font-weight: 900;
}

.employees-page-header p {
  max-width: 860px;
  margin: 12px 0 0;
  color: #77857d;
  font-weight: 700;
  line-height: 1.9;
}

.employees-kicker {
  display: block;
  color: #9ca9a2;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.employees-header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.employees-primary-link {
  min-height: 46px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 16px;
  padding: 0 18px;
  background: var(--together-green);
  color: #fff;
  font-weight: 900;
  box-shadow: 0 16px 32px rgba(11, 107, 58, 0.18);
}

.employees-hero-card {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.72fr);
  grid-gap: 24px;
  gap: 24px;
  min-height: 330px;
  padding: 30px;
  border-radius: 32px;
  background:
    radial-gradient(circle at 8% 12%, rgba(165, 214, 63, 0.16), transparent 24%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(248, 253, 246, 0.96) 100%);
}

.employees-hero-copy {
  display: grid;
  align-content: center;
}

.employees-hero-copy h2 {
  max-width: 760px;
  margin: 16px 0 0;
  color: var(--together-green);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.16;
}

.employees-hero-copy p {
  max-width: 820px;
  margin: 14px 0 0;
  color: #738179;
  font-weight: 700;
  line-height: 1.9;
}

.employees-chip-row {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.employees-chip-row span,
.employees-section-pill {
  min-height: 34px;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 0 13px;
  background: #edf8f0;
  color: var(--together-green);
  font-size: 12px;
  font-weight: 900;
}

.employees-decision-stack {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.employees-decision-card {
  display: grid;
  grid-gap: 8px;
  gap: 8px;
  border: 1px solid rgba(11, 107, 58, 0.12);
  border-radius: 24px;
  padding: 18px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 14px 30px rgba(11, 107, 58, 0.07);
}

.employees-decision-card strong {
  color: #173422;
  font-size: 15px;
}

.employees-decision-card p {
  margin: 0;
  color: #798780;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.8;
}

.employees-decision-tag {
  width: -moz-fit-content;
  width: fit-content;
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 900;
}

.employees-decision-tag.warning {
  background: #fff7ed;
  color: #a16207;
}

.employees-decision-tag.ok {
  background: #edf8f0;
  color: #15733c;
}

.employees-decision-tag.info {
  background: #eff8ff;
  color: #175cd3;
}

.employees-metrics-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-gap: 16px;
  gap: 16px;
}

.employees-metric-card {
  min-height: 152px;
  display: grid;
  align-content: space-between;
  grid-gap: 12px;
  gap: 12px;
  border-radius: 26px;
  transition:
    transform 0.18s ease,
    box-shadow 0.18s ease;
}

.employees-metric-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 20px 46px rgba(11, 107, 58, 0.12);
}

.employees-metric-card span {
  color: #8b9891;
  font-size: 12px;
  font-weight: 900;
}

.employees-metric-card strong {
  color: var(--together-green);
  font-size: 38px;
  line-height: 1;
  font-weight: 900;
}

.employees-metric-card p {
  margin: 0;
  color: #728078;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
}

.employees-metric-card--warning strong {
  color: #a16207;
}

.employees-metric-card--info strong {
  color: #175cd3;
}

.employees-toolbar-card,
.employees-create-card,
.employees-directory-card,
.employees-insight-card {
  border-radius: 28px;
}

.employees-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}

.employees-section-head h2 {
  margin: 10px 0 0;
  color: var(--together-green);
  font-size: 24px;
}

.employees-section-head p {
  max-width: 780px;
  margin: 8px 0 0;
  color: #798780;
  font-weight: 700;
  line-height: 1.8;
}

.employees-toolbar-modern {
  display: grid;
  grid-template-columns: minmax(240px, 1fr) 160px 180px 180px auto auto;
  grid-gap: 12px;
  gap: 12px;
}

.employees-create-form-modern {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
}

.employees-create-form-modern .erp-button {
  min-height: 48px;
}

.employees-table-wrap-modern {
  border: 1px solid rgba(11, 107, 58, 0.11);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.76);
}

.employees-table-modern {
  border-spacing: 0;
}

.employees-table-modern th {
  background: #f8fbf9;
  color: #8b9891;
  font-size: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(11, 107, 58, 0.1);
}

.employees-table-modern td {
  border: 0;
  border-bottom: 1px solid rgba(11, 107, 58, 0.08);
  background: rgba(255, 255, 255, 0.78);
  padding: 18px;
}

.employees-table-modern tr:last-child td {
  border-bottom: 0;
}

.employees-table-modern td:first-child,
.employees-table-modern td:last-child {
  border-radius: 0;
  border-inline: 0;
}

.employee-profile-cell {
  display: flex;
  align-items: center;
  gap: 14px;
}

.employee-avatar {
  width: 46px;
  height: 46px;
  border-radius: 17px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  color: var(--together-green);
  background: linear-gradient(135deg, #edf8f0, #fbfff7);
  border: 1px solid rgba(11, 107, 58, 0.12);
  font-weight: 900;
  font-size: 18px;
}

.employee-profile-cell em {
  display: block;
  margin-top: 4px;
  color: #8d9a92;
  font-style: normal;
  font-size: 12px;
  font-weight: 800;
}

.employees-status-select {
  min-width: 150px;
  max-width: 170px;
  background: #fff;
}

.employees-pagination {
  margin-top: 18px;
}

.employees-loading-modern {
  display: grid;
  grid-gap: 10px;
  gap: 10px;
}

.employees-insight-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(320px, 0.8fr);
  grid-gap: 16px;
  gap: 16px;
}

.employees-mini-flow {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  grid-gap: 12px;
  gap: 12px;
}

.employees-flow-step {
  min-height: 122px;
  display: grid;
  align-content: space-between;
  grid-gap: 8px;
  gap: 8px;
  border: 1px solid rgba(11, 107, 58, 0.1);
  border-radius: 20px;
  padding: 16px;
  background: #fbfdfb;
}

.employees-flow-step b {
  width: 34px;
  height: 34px;
  border-radius: 13px;
  display: grid;
  place-items: center;
  background: #edf8f0;
  color: var(--together-green);
  font-size: 13px;
}

.employees-flow-step strong {
  color: #173422;
}

.employees-flow-step span {
  color: #7d8a83;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.7;
}

.employees-alert-list {
  display: grid;
  grid-gap: 12px;
  gap: 12px;
}

.employees-alert-list div {
  border: 1px solid rgba(11, 107, 58, 0.1);
  border-radius: 20px;
  padding: 16px;
  background: #fbfdfb;
}

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

.employees-alert-list strong {
  color: #173422;
}

.employees-alert-list span {
  margin-top: 6px;
  color: #7d8a83;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.8;
}

@media (max-width: 1280px) {
  .employees-hero-card,
  .employees-insight-grid {
    grid-template-columns: 1fr;
  }

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

  .employees-mini-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .topbar {
    height: auto;
    flex-wrap: wrap;
  }

  .topbar-scope {
    order: 3;
    width: 100%;
  }

  .employees-page-header {
    display: grid;
  }

  .employees-toolbar-modern,
  .employees-create-form-modern {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 620px) {
  .employees-metrics-grid,
  .employees-mini-flow {
    grid-template-columns: 1fr;
  }

  .employees-hero-card {
    padding: 20px;
  }
}

/* ============================================================
   TogetherERP — Employees Module Shell
   Wizard / Form styles — ported from employees-module-shell.css
   ============================================================ */

/* ===== Buttons ===== */
.ghost-btn, .primary-btn {
  height: 52px; border-radius: 20px;
  display: inline-flex; align-items: center; gap: 10px;
  padding: 0 20px; font-size: 14px; font-weight: 900;
  cursor: pointer; transition: all .24s ease;
  font-family: inherit;
}
.ghost-btn { border: 1px dashed #d8e0e5; background: rgba(255,255,255,.84); color: #7a8793; }
.ghost-btn:hover { background: #fff; color: var(--text); }
.ghost-btn[disabled], .ghost-btn:disabled { opacity: .42; pointer-events: none; }
.primary-btn { border: none; background: var(--orange); color: #fff; box-shadow: var(--shadow-orange); }
  .primary-btn:hover { background: linear-gradient(135deg, var(--together-green), var(--together-green-2)); box-shadow: 0 4px 12px rgba(11,107,58,0.3); }
.primary-btn:disabled { opacity: .55; pointer-events: none; }

/* ===== Chips & tags ===== */
.soft-chip {
  min-height: 34px; padding: 0 14px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 900;
}
.soft-chip.teal { background: var(--teal-soft); color: var(--teal-mid); }
.soft-chip.orange { background: var(--warning-soft); color: #8a5d07; }
.soft-chip.green { background: var(--success-soft); color: #166534; }
.soft-chip.blue { background: var(--teal-soft); color: var(--teal-mid); }
.soft-chip.red { background: var(--danger-soft); color: #be123c; }

.tag {
  min-height: 28px; padding: 0 10px; border-radius: 999px;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 10px; font-weight: 900; white-space: nowrap;
}
.tag.warn { background: var(--warning-soft); color: #a16207; }
.tag.ok { background: var(--success-soft); color: #15803d; }
.tag.info { background: var(--teal-soft); color: var(--teal-mid); }
.tag.danger { background: var(--danger-soft); color: #be123c; }

.hero-chips { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px; }

/* ===== Wizard steps nav ===== */
.wizard-steps {
  display: grid; grid-template-columns: repeat(6, minmax(0,1fr));
  grid-gap: 10px;
  gap: 10px; padding: 14px; border-radius: 24px;
  background: #fff; border: 1px solid var(--border); box-shadow: var(--shadow-sm);
}
.wizard-step {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px;
  border-radius: 16px; border: 1px solid transparent;
  background: transparent; cursor: pointer; transition: all .2s ease; text-align: right;
}
.wizard-step:hover:not(.active) { background: rgba(165,214,63,.07); border-color: rgba(44,145,66,.10); }
.wizard-step:focus-visible { box-shadow: 0 0 0 4px rgba(44,145,66,.18); }
.wizard-step .step-num {
  width: 32px; height: 32px; border-radius: 12px; flex-shrink: 0;
  display: grid; place-items: center;
  background: #eef5f8; color: var(--text); font-weight: 900; font-size: 13px;
}
.wizard-step .step-copy { min-width: 0; line-height: 1.2; }
.wizard-step .step-copy strong {
  display: block; color: #0f172a; font-size: 12px; font-weight: 900;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.wizard-step .step-copy span { display: block; color: #96a2ad; font-size: 10px; font-weight: 700; margin-top: 3px; }
.wizard-step.active {
  background: linear-gradient(135deg, rgba(44,145,66,.06) 0%, rgba(165,214,63,.10) 100%);
  border-color: rgba(44,145,66,.18); box-shadow: 0 12px 24px rgba(44,145,66,.10);
}
.wizard-step.active .step-num {
  background: linear-gradient(135deg,#22c55e,#16a34a); color: #fff;
  box-shadow: 0 8px 14px rgba(22,163,74,.32);
}
.wizard-step.done .step-num {
  background: linear-gradient(135deg,#22c55e,#16a34a) !important;
  color: #fff !important; box-shadow: 0 8px 14px rgba(22,163,74,.30);
  font-size: 0; position: relative;
}
.wizard-step.done .step-num::after {
  content: "";
  position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none'><path d='m5 12 4 4L19 6' stroke='white' stroke-width='3.2' stroke-linecap='round' stroke-linejoin='round'/></svg>");
  background-repeat: no-repeat; background-position: center; background-size: 60%;
}

/* ===== Wizard progress bar ===== */
.wizard-bar {
  display: grid; grid-template-columns: auto minmax(0,1fr) auto;
  align-items: center; grid-gap: 18px; gap: 18px; padding: 14px 18px;
  border-radius: 22px; background: rgba(255,255,255,.92);
  border: 1px solid var(--border); box-shadow: var(--shadow-sm);
}
.wizard-counter {
  display: inline-flex; align-items: center; gap: 10px;
  padding: 9px 14px; border-radius: 14px;
  background: linear-gradient(135deg, rgba(165,214,63,.10), rgba(44,145,66,.08));
  border: 1px solid rgba(44,145,66,.18);
  color: var(--text); font-size: 12px; font-weight: 900;
}
.wizard-counter b { font-size: 15px; }
.wizard-counter small { color: #7f8b95; font-weight: 800; }
.wizard-progress {
  position: relative; height: 10px; background: #eef3f6;
  border-radius: 999px; overflow: hidden;
}
.wizard-progress i {
  display: block; height: 100%; border-radius: 999px;
  background: linear-gradient(90deg,#a5d63f 0%,#22c55e 50%,#16a34a 100%);
  transition: width .6s cubic-bezier(.22,1,.36,1);
}
.wizard-autosave {
  display: inline-flex; align-items: center; gap: 8px;
  color: #7f8b95; font-size: 11px; font-weight: 800; white-space: nowrap;
}
.wizard-autosave .pulse {
  position: relative; width: 9px; height: 9px;
  border-radius: 50%; background: #22c55e; display: inline-block; flex-shrink: 0;
}
.wizard-autosave .pulse::after {
  content: ""; position: absolute; inset: 0; border-radius: 50%;
  background: rgba(34,197,94,.4); animation: wizpulse 1.7s ease-out infinite;
}
@keyframes wizpulse {
  0% { transform: scale(1); opacity: .7; }
  100% { transform: scale(2.8); opacity: 0; }
}

/* ===== Form card & sections ===== */
.form-card {
  padding: 30px; display: grid; grid-gap: 0; gap: 0;
  position: relative; min-height: 420px;
  background: #fff; border: 1px solid var(--border);
  border-radius: 28px; box-shadow: var(--shadow-md);
}
.form-section { display: none; opacity: 0; transform: translateY(8px); }
.form-section.is-active {
  display: grid; grid-gap: 14px; gap: 14px; padding: 22px;
  border-radius: 24px; background: #fbfdfa; border: 1px solid var(--border-soft);
  opacity: 1; transform: translateY(0);
  animation: section-enter .5s cubic-bezier(.22,1,.36,1);
}
@keyframes section-enter {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}
.form-section h4 {
  margin: 0; color: var(--text); font-size: 16px; font-weight: 900;
  display: flex; align-items: center; gap: 10px;
}
.form-section h4 .num {
  width: 28px; height: 28px; border-radius: 10px; flex-shrink: 0;
  background: #fff; border: 1px solid var(--border-soft);
  color: var(--text); font-size: 13px; font-weight: 900;
  display: grid; place-items: center;
}
.form-section.is-active h4 .num {
  background: linear-gradient(135deg,#22c55e,#16a34a) !important;
  color: #fff !important; border: none !important;
}
.form-section .desc {
  margin: 0; color: #7f8b95; font-size: 12px; font-weight: 700; line-height: 1.7;
}

/* ===== Form fields ===== */
.field { position: relative; }
.field label.label-text {
  display: block; font-size: 11px; font-weight: 900;
  color: #7a8793; margin-bottom: 8px; letter-spacing: .04em;
}
.field input, .field select, .field textarea {
  width: 100%; height: 50px;
  border: 1px solid var(--border-soft); background: #fbfcfd;
  color: var(--text); border-radius: 18px; padding: 0 16px;
  outline: none; font-family: inherit; font-size: 14px;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.field textarea { height: auto; min-height: 120px; padding: 14px 16px; resize: vertical; line-height: 1.7; }
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: rgba(44,145,66,.45); box-shadow: 0 0 0 4px rgba(44,145,66,.10);
}
.field-hint { margin-top: 6px; color: #9aa6af; font-size: 11px; font-weight: 700; line-height: 1.7; }
.field-row { display: grid; grid-template-columns: repeat(2, minmax(0,1fr)); grid-gap: 14px; gap: 14px; }
.field-row.three { grid-template-columns: repeat(3, minmax(0,1fr)); }

/* ===== Action bar ===== */
.action-bar {
  display: flex; justify-content: space-between; align-items: center;
  gap: 16px; flex-wrap: wrap; padding: 18px; border-radius: 22px;
  background: rgba(255,255,255,.94) !important; border: 1px solid var(--border);
  box-shadow: var(--shadow-sm); position: -webkit-sticky; position: sticky; bottom: 14px;
  z-index: 20; -webkit-backdrop-filter: blur(10px); backdrop-filter: blur(10px);
}
.header-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }

/* ===== Form hero ===== */
.form-hero {
  position: relative; overflow: hidden; border-radius: 32px; padding: 30px;
  background: radial-gradient(circle at 90% -10%, rgba(37,99,235,.14), transparent 38%),
              linear-gradient(135deg,#ffffff 0%,#f6fbf3 100%);
  border: 1px solid rgba(44,145,66,.18); box-shadow: var(--shadow-md);
  display: grid; grid-template-columns: minmax(0,1.5fr) minmax(280px,.9fr); grid-gap: 28px; gap: 28px;
}
.form-hero small {
  display: block; color: #788c81; font-size: 11px; font-weight: 900;
  letter-spacing: .08em; text-transform: uppercase;
}
.form-hero h1 { margin: 6px 0 12px; color: var(--text); font-size: 30px; line-height: 1.1; font-weight: 900; letter-spacing: -.03em; }
.form-hero > div > p { margin: 0; color: #6b7a73; font-size: 14px; line-height: 1.95; font-weight: 600; }

/* ===== Tip cards ===== */
.tip-card {
  display: grid; grid-template-columns: auto minmax(0,1fr); grid-gap: 14px; gap: 14px;
  padding: 16px 18px; border-radius: 22px; background: #fff;
  border: 1px solid rgba(44,145,66,.10); box-shadow: var(--shadow-sm);
}
.tip-card .tip-icon {
  width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center;
  background: linear-gradient(135deg,#dbeafe,#bfdbfe); color: #1d4ed8;
}
.tip-card strong { color: var(--text); font-size: 13px; font-weight: 900; display: block; }
.tip-card p { margin: 6px 0 0; color: #7f8b95; font-size: 11px; font-weight: 700; line-height: 1.7; }

/* ===== Upload zones ===== */
.upload-zone {
  display: grid; grid-template-columns: auto minmax(0,1fr) auto;
  align-items: center; grid-gap: 18px; gap: 18px; padding: 22px;
  border: 2px dashed rgba(37,99,235,.30); border-radius: 22px;
  background: linear-gradient(135deg, rgba(219,234,254,.30), rgba(255,255,255,.5));
}
.upload-zone .u-icon {
  width: 60px; height: 60px; border-radius: 18px; display: grid; place-items: center;
  background: #fff; color: #1d4ed8; border: 1px solid rgba(37,99,235,.14);
}
.upload-zone strong { color: var(--text); font-size: 15px; font-weight: 900; display: block; }
.upload-zone span { color: #7f8b95; font-size: 12px; font-weight: 700; display: block; margin-top: 4px; }
.upload-zone--ready {
  border-color: rgba(22,163,74,.35);
  background: linear-gradient(135deg, rgba(220,252,231,.40), rgba(255,255,255,.5));
}
.upload-zone--ready .u-icon { background: rgba(220,252,231,.6); border-color: rgba(22,163,74,.2); }

/* ===== Toggle rows & switches ===== */
.toggle-row {
  display: grid; grid-template-columns: 1fr auto; grid-gap: 16px; gap: 16px;
  padding: 16px 18px; border-radius: 18px; background: #fff;
  border: 1px solid var(--border-soft); align-items: center;
}
.toggle-row strong { color: #0f172a; font-size: 13px; font-weight: 900; display: block; }
.toggle-row span { color: #7f8b95; font-size: 11px; font-weight: 700; display: block; margin-top: 4px; line-height: 1.7; }
.switch {
  position: relative; width: 50px; height: 28px; border-radius: 999px;
  background: #e5ebef; cursor: pointer; transition: background .25s ease;
  border: none; flex-shrink: 0; display: inline-block;
}
.switch::after {
  content: ""; position: absolute; top: 3px; right: 3px;
  width: 22px; height: 22px; border-radius: 50%;
  background: #fff; box-shadow: 0 4px 8px rgba(0,0,0,.12); transition: transform .25s ease;
}
.switch.on { background: linear-gradient(135deg,#22c55e,#16a34a); }
.switch.on::after { transform: translateX(-22px); }

/* ===== Alert list (review step) ===== */
.alert-list { display: grid; grid-template-columns: minmax(0,1fr); grid-gap: 12px; gap: 12px; }
.alert-item {
  border: 1px solid var(--border-soft); background: #fbfcfd;
  border-radius: 22px; padding: 16px;
}
.alert-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.alert-item strong { display: block; color: #0f172a; font-size: 13px; font-weight: 900; }
.alert-item p { margin: 8px 0 0; color: #8b97a1; font-size: 11px; line-height: 1.8; font-weight: 700; }

/* ===================================================
   Module Shell — shared classes (employees, projects, etc.)
   =================================================== */

/* Page content grid wrapper — layout already provides padding via .content */
.page-content {
  display: grid;
  grid-template-columns: minmax(0,1fr);
  grid-gap: 28px;
  gap: 28px;
}

.module-tabs {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  padding: 10px; border-radius: 28px;
  background: rgba(255,255,255,.72);
  border: 1px solid var(--border); box-shadow: var(--shadow-sm);
  width: max-content; max-width: 100%;
}
.module-tab {
  min-height: 52px; padding: 12px 18px; border: none; border-radius: 20px;
  background: transparent; color: #82909c;
  font-size: 13px; font-weight: 900;
  display: flex; align-items: center; gap: 12px;
  cursor: pointer; transition: all .24s ease;
}
.module-tab:hover { color: var(--text); background: #fff; }
.module-tab.active {
  background: var(--text); color: #fff;
  box-shadow: 0 18px 30px rgba(11,107,58,.2);
}
.module-tab .tab-count {
  min-width: 24px; height: 24px; padding: 0 8px; border-radius: 999px;
  background: rgba(255,255,255,.18);
  display: flex; align-items: center; justify-content: center;
  font-size: 10px;
}
.module-tab:not(.active) .tab-count { background: var(--muted); color: #64748b; }

.panel { display: none; }
.panel.active { display: grid; grid-template-columns: minmax(0,1fr); grid-gap: 28px; gap: 28px; }

.record-link { color: inherit; text-decoration: none; }
.record-link:hover { color: var(--text); text-decoration: underline; }

.card {
  background: #fff;
  border: 1px solid var(--border);
  border-radius: 28px;
  box-shadow: var(--shadow-md);
}

.split-two { display: grid; grid-template-columns: repeat(2,minmax(0,1fr)); grid-gap: 24px; gap: 24px; }
.split-three { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); grid-gap: 20px; gap: 20px; }
.stats-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); grid-gap: 20px; gap: 20px; }

.section-card { padding: 26px; }
.section-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 16px; margin-bottom: 22px;
}
.section-head h3 { margin: 0; color: var(--text); font-size: 22px; font-weight: 900; letter-spacing: -.02em; }
.section-head p { margin: 8px 0 0; color: #8a98a6; font-size: 12px; line-height: 1.8; font-weight: 700; }
.section-badge {
  min-height: 34px; padding: 0 14px; border-radius: 999px;
  background: var(--teal-soft); color: var(--teal-mid);
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 11px; font-weight: 900; white-space: nowrap;
}

.metric-card { padding: 24px; transition: transform .22s ease, box-shadow .22s ease; }
.metric-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-lg); }
.metric-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.metric-top > div > label { display: block; color: #9da8b2; font-size: 10px; font-weight: 900; letter-spacing: .09em; text-transform: uppercase; }
.metric-top > div > strong { display: block; font-size: 32px; line-height: 1; font-weight: 900; margin-top: 12px; color: var(--text); letter-spacing: -.04em; }
.metric-top > div > p { margin: 8px 0 0; color: #8a98a6; font-size: 11px; font-weight: 700; }
.metric-icon { width: 54px; height: 54px; border-radius: 22px; display: grid; place-items: center; flex-shrink: 0; }
.metric-trend {
  display: inline-flex; align-items: center; gap: 6px;
  margin-top: 14px; padding: 7px 10px; border-radius: 14px;
  font-size: 10px; font-weight: 900;
}
.metric-trend.up { background: var(--success-soft); color: #15803d; }
.metric-trend.warn { background: var(--warning-soft); color: #a16207; }
.metric-trend.down { background: var(--danger-soft); color: #b91c1c; }

.schedule-item { border: 1px solid var(--border-soft); background: #fbfcfd; border-radius: 22px; padding: 16px; }
.schedule-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.schedule-item strong { display: block; color: #0f172a; font-size: 13px; font-weight: 900; }
.schedule-item p { margin: 8px 0 0; color: #8b97a1; font-size: 11px; line-height: 1.8; font-weight: 700; }

.timeline { display: grid; grid-template-columns: minmax(0,1fr); grid-gap: 14px; gap: 14px; }
.timeline-item { position: relative; padding: 0 24px 0 0; }
.timeline-item::before {
  content: ""; position: absolute; top: 6px; right: 0;
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--orange);
  box-shadow: 0 0 0 6px rgba(249,115,22,.12);
}
.timeline-item::after {
  content: ""; position: absolute; top: 24px; right: 4px;
  width: 2px; height: calc(100% + 8px); background: #edf2f5;
}
.timeline-item:last-child::after { display: none; }
.timeline-item strong { display: block; color: #0f172a; font-size: 13px; font-weight: 900; }
.timeline-item span { display: block; color: #8b97a1; font-size: 11px; line-height: 1.8; font-weight: 700; margin-top: 6px; }
.timeline-item.done::before { background: var(--success); box-shadow: 0 0 0 6px rgba(22,163,74,.12); }
.timeline-item.warn::before { background: var(--warning); box-shadow: 0 0 0 6px rgba(245,158,11,.12); }
.timeline-item.info::before { background: var(--teal-mid); box-shadow: 0 0 0 6px rgba(26,106,138,.12); }
.timeline-item.danger::before { background: var(--danger); box-shadow: 0 0 0 6px rgba(239,68,68,.12); }

.tiny-btn {
  min-height: 40px; padding: 0 16px; border-radius: 16px;
  border: 1px solid var(--border-soft); background: #fff;
  color: #657482; font-size: 12px; font-weight: 900;
  display: inline-flex; align-items: center; gap: 10px; cursor: pointer;
  transition: all .2s ease; text-decoration: none;
}
.tiny-btn:hover { border-color: var(--text); color: var(--text); }

.progress { height: 10px; background: #edf2f5; border-radius: 999px; overflow: hidden; margin-top: 12px; }
.progress > span { display: block; height: 100%; border-radius: 999px; }
.progress.green span { background: linear-gradient(90deg,#22c55e,#16a34a); }
.progress.orange span { background: linear-gradient(90deg,#fb923c,#f97316); }
.progress.blue span { background: linear-gradient(90deg, var(--teal-mid), #2b9ac8); }
.progress.red span { background: linear-gradient(90deg,#fb7185,#e11d48); }

.tag.teal { background: var(--teal-soft); color: var(--teal-mid); }

/* ===================================================
   Employee Profile Page
   =================================================== */

.emp-hero {
  position: relative; overflow: hidden;
  border-radius: 32px; padding: 30px;
  background:
    radial-gradient(circle at 88% -10%, rgba(26,106,138,.10), transparent 38%),
    radial-gradient(circle at 6% 110%, rgba(165,214,63,.14), transparent 36%),
    linear-gradient(135deg,#ffffff 0%,#f6fbf3 100%);
  border: 1px solid rgba(44,145,66,.18);
  box-shadow: var(--shadow-md);
  display: grid;
  grid-template-columns: auto minmax(0,1.4fr) minmax(280px,.9fr);
  grid-gap: 28px;
  gap: 28px; align-items: center;
}
.portrait {
  width: 130px; height: 130px; border-radius: 32px;
  background: linear-gradient(135deg, var(--teal-soft), #b8d8e6);
  color: var(--teal-mid);
  display: grid; place-items: center; font-size: 52px; font-weight: 900;
  box-shadow: 0 18px 30px rgba(11,107,58,.12);
  position: relative; -webkit-user-select: none; -moz-user-select: none; user-select: none;
}
.portrait::after {
  content: ""; position: absolute; bottom: 8px; inset-inline-start: 8px;
  width: 18px; height: 18px; border-radius: 50%;
  background: #10b981; border: 3px solid #fff;
}
.crumb { display: inline-flex; align-items: center; gap: 8px; color: #788c81; font-size: 11px; font-weight: 800; letter-spacing: .04em; }
.emp-hero h1 { margin: 14px 0 6px; color: var(--text); font-size: 30px; line-height: 1.1; font-weight: 900; letter-spacing: -.03em; }
.lede { margin: 0 0 16px; color: #6b7a73; font-size: 13px; line-height: 1.9; font-weight: 600; max-width: 560px; }
.meta-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); grid-gap: 12px; gap: 12px; }
.meta-grid .cell label { display: block; color: #9aa6af; font-size: 10px; font-weight: 900; letter-spacing: .06em; text-transform: uppercase; }
.meta-grid .cell strong { display: block; color: var(--text); font-size: 13px; font-weight: 900; margin-top: 4px; }
.side-stats { display: grid; grid-gap: 12px; gap: 12px; }
.side-stat {
  background: #fff; border: 1px solid rgba(44,145,66,.10); border-radius: 22px;
  padding: 16px 18px;
  display: grid; grid-template-columns: auto minmax(0,1fr); grid-gap: 12px; gap: 12px; align-items: center;
  box-shadow: var(--shadow-sm);
}
.side-stat .icon { width: 46px; height: 46px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg, var(--teal-soft), #b8d8e6); color: var(--teal-mid); }
.side-stat label { color: #9aa6af; font-size: 10px; font-weight: 900; letter-spacing: .05em; text-transform: uppercase; display: block; }
.side-stat strong { color: var(--text); font-size: 18px; font-weight: 900; display: block; margin-top: 4px; letter-spacing: -.02em; }
.fam-grid { display: grid; grid-template-columns: repeat(4,minmax(0,1fr)); grid-gap: 12px; gap: 12px; }
.fam-card { background: #fff; border: 1px solid var(--border); border-radius: 22px; padding: 16px; display: grid; grid-gap: 8px; gap: 8px; box-shadow: var(--shadow-sm); }
.fam-top { display: flex; align-items: center; gap: 12px; }
.fam-avatar { width: 42px; height: 42px; border-radius: 14px; background: linear-gradient(135deg,#dde8e3,#eaf4eb); color: var(--text); display: grid; place-items: center; font-size: 14px; font-weight: 900; flex-shrink: 0; }
.fam-card strong { color: #0f172a; font-size: 13px; font-weight: 900; display: block; }
.fam-card span { color: #96a2ad; font-size: 10px; font-weight: 800; display: block; margin-top: 3px; }
.fam-card .meta { color: #475569; font-size: 11px; font-weight: 700; padding-top: 6px; border-top: 1px dashed #e5ecef; line-height: 1.7; }
.contract-row {
  display: grid; grid-template-columns: auto minmax(0,1fr) auto auto auto;
  align-items: center; grid-gap: 14px; gap: 14px;
  padding: 14px 16px; border-radius: 18px;
  background: #fff; border: 1px solid var(--border-soft);
}
.contract-row .ic { width: 42px; height: 42px; border-radius: 14px; display: grid; place-items: center; background: linear-gradient(135deg, var(--teal-soft), #b8d8e6); color: var(--teal-mid); }
.contract-row strong { color: #0f172a; font-size: 13px; font-weight: 900; display: block; }
.contract-row span { color: #7f8b95; font-size: 11px; font-weight: 700; display: block; margin-top: 3px; }
.muted-note { color: #9aa6af; font-size: 11px; font-weight: 800; white-space: nowrap; }
.bar-chart { display: grid; grid-gap: 14px; gap: 14px; }
.bar-row { display: grid; grid-template-columns: minmax(100px,1fr) minmax(0,3fr) auto; align-items: center; grid-gap: 10px; gap: 10px; }
.bar-row strong { font-size: 12px; font-weight: 800; color: #475569; }
.bar-row b { font-size: 12px; font-weight: 900; color: #0f172a; white-space: nowrap; }
.bar-track { height: 8px; background: #f0f4f7; border-radius: 99px; overflow: hidden; }
.bar-fill { display: block; height: 100%; border-radius: 99px; }
.bar-fill.green { background: linear-gradient(90deg,#16a34a,#4ade80); }
.bar-fill.blue { background: linear-gradient(90deg, var(--teal-mid), #2b9ac8); }
.bar-fill.orange { background: linear-gradient(90deg,#ea580c,#fb923c); }
.bar-fill.red { background: linear-gradient(90deg,#dc2626,#f87171); }
.empty-state-soft { display: flex; flex-direction: column; align-items: center; }

/* ===== Responsive ===== */
@media (max-width: 1440px) {
  .wizard-steps { grid-template-columns: repeat(3, minmax(0,1fr)); }
}
@media (max-width: 1240px) {
  .form-hero { grid-template-columns: 1fr; }
}
@media (max-width: 860px) {
  .wizard-steps { grid-template-columns: 1fr; }
  .field-row, .field-row.three { grid-template-columns: 1fr; }
  .wizard-bar { grid-template-columns: auto 1fr; }
  .wizard-autosave { display: none; }
  .ghost-btn, .primary-btn { height: 46px; font-size: 13px; }
}

/* ===================================================
   Employees Dashboard Command Center
   =================================================== */

.page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
  flex-wrap: wrap;
}
.header-copy small {
  display: block;
  color: #9aa6af;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .07em;
  text-transform: uppercase;
}
.header-copy h1 {
  margin: 8px 0 0;
  color: var(--text);
  font-size: clamp(28px, 3.6vw, 46px);
  line-height: 1.06;
  font-weight: 900;
  letter-spacing: -.03em;
}
.header-copy p {
  max-width: 820px;
  margin: 12px 0 0;
  color: #78878f;
  font-weight: 700;
  line-height: 1.85;
  font-size: 13px;
}
.header-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  flex-shrink: 0;
  padding-top: 8px;
}
.search-shell {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.search-shell input[type="search"] {
  height: 48px;
  width: 240px;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 0 42px 0 16px;
  background: rgba(255,255,255,.9);
  font-family: inherit;
  font-size: 13px;
  font-weight: 700;
  color: #3a4a40;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.search-shell input[type="search"]:focus {
  border-color: rgba(44,145,66,.4);
  box-shadow: 0 0 0 4px rgba(44,145,66,.09);
}
.search-shell svg {
  position: absolute;
  inset-inline-end: 14px;
  color: #9aa6af;
  pointer-events: none;
}
.primary-btn.secondary {
  background: var(--text);
  box-shadow: 0 16px 30px rgba(11,107,58,.2);
}
.primary-btn.secondary:hover { background: #15803d; }

.ops-hero {
  display: grid;
  grid-template-columns: minmax(0,1.25fr) minmax(320px,.75fr);
  grid-gap: 24px;
  gap: 24px;
  align-items: stretch;
}
.hero-command {
  min-height: 320px;
  padding: 30px;
  display: grid;
  align-content: center;
  background:
    radial-gradient(circle at 12% 8%, rgba(168,214,73,.18), transparent 28%),
    linear-gradient(135deg,#ffffff 0%,#f7fbf6 100%);
}
.hero-command .tag { margin-bottom: 12px; }
.hero-command h2 {
  margin: 0 0 14px;
  color: var(--text);
  font-size: clamp(20px, 2.4vw, 28px);
  line-height: 1.2;
  font-weight: 900;
  letter-spacing: -.02em;
  max-width: 680px;
}
.hero-command > p {
  margin: 0;
  color: #71807a;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.9;
  max-width: 640px;
}
.hero-command .chips {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.hero-command .chip {
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  background: #edf8f0;
  color: #0d582c;
  font-size: 11px;
  font-weight: 900;
}

.decision-stack { display: grid; grid-gap: 12px; gap: 12px; }
.decision-card {
  border: 1px solid rgba(21,115,60,.10);
  background: #fff;
  border-radius: 22px;
  padding: 16px;
  display: grid;
  grid-gap: 10px;
  gap: 10px;
  box-shadow: var(--shadow-sm);
}
.decision-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.decision-top strong {
  display: block;
  color: #123323;
  font-size: 13px;
  font-weight: 900;
}
.decision-top > div > span {
  display: block;
  color: #8b9892;
  font-size: 10px;
  font-weight: 800;
  margin-top: 4px;
}
.action-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.action-row .tiny-btn {
  min-height: 34px;
  border-radius: 14px;
  padding: 0 12px;
}

.status-pill {
  display: inline-flex;
  align-items: center;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 900;
  white-space: nowrap;
}
.status-pill.info { background: var(--teal-soft); color: var(--teal-mid); }
.status-pill.warn { background: var(--warning-soft); color: #a16207; }
.status-pill.danger { background: var(--danger-soft); color: #be123c; }
.status-pill.ok { background: var(--success-soft); color: #15803d; }

.table-wrap { overflow-x: auto; margin-top: 4px; }
.table-wrap table { width: 100%; border-collapse: separate; border-spacing: 0; }
.table-wrap thead th {
  color: #8a98a6;
  font-size: 11px;
  font-weight: 900;
  text-align: right;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  background: #f9fbfa;
  white-space: nowrap;
}
.table-wrap thead th:first-child { border-start-start-radius: 16px; }
.table-wrap thead th:last-child { border-start-end-radius: 16px; }
.table-wrap tbody tr { transition: background .15s ease; }
.table-wrap tbody tr:hover td { background: #f8fdf9; }
.table-wrap tbody td {
  padding: 14px;
  border-bottom: 1px solid rgba(11,107,58,.07);
  font-size: 12px;
  font-weight: 700;
  color: #3a4a40;
  vertical-align: middle;
}
.table-wrap tbody td strong {
  display: block;
  font-size: 13px;
  color: #123323;
  font-weight: 900;
}
.table-wrap tbody tr:last-child td { border-bottom: 0; }

.ops-grid {
  display: grid;
  grid-template-columns: 1.15fr .85fr;
  grid-gap: 24px;
  gap: 24px;
}

.mini-flow {
  display: grid;
  grid-template-columns: repeat(5,minmax(0,1fr));
  grid-gap: 12px;
  gap: 12px;
}
.mini-step {
  border: 1px solid #edf2ef;
  background: #fbfdfb;
  border-radius: 20px;
  padding: 16px;
  min-height: 118px;
  display: grid;
  align-content: space-between;
  grid-gap: 12px;
  gap: 12px;
}
.mini-step b {
  width: 34px;
  height: 34px;
  border-radius: 14px;
  background: #edf8f0;
  color: #0d582c;
  display: grid;
  place-items: center;
  font-size: 12px;
}
.mini-step strong { font-size: 13px; color: #123323; font-weight: 900; }
.mini-step span { font-size: 10px; color: #839088; font-weight: 800; line-height: 1.7; }

.quality-grid {
  display: grid;
  grid-template-columns: repeat(2,minmax(0,1fr));
  grid-gap: 12px;
  gap: 12px;
}
.quality-card {
  border: 1px solid #edf2ef;
  background: #fff;
  border-radius: 20px;
  padding: 16px;
}
.quality-card label { display: block; color: #97a49c; font-size: 10px; font-weight: 900; }
.quality-card strong { display: block; color: #0d582c; font-size: 26px; font-weight: 900; margin-top: 4px; }
.quality-card p { margin: 6px 0 0; color: #7f8d86; font-size: 11px; line-height: 1.8; font-weight: 700; }

.foot-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--border-soft);
}

@media (max-width: 1180px) {
  .ops-hero, .ops-grid { grid-template-columns: 1fr; }
  .mini-flow { grid-template-columns: repeat(2,minmax(0,1fr)); }
}
@media (max-width: 720px) {
  .mini-flow, .quality-grid { grid-template-columns: 1fr; }
}

/* ===================================================
   Document Viewer Modal
   =================================================== */
.doc-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  background: rgba(10, 18, 14, 0.58);
  -webkit-backdrop-filter: blur(6px);
          backdrop-filter: blur(6px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: overlay-in .18s ease;
}
@keyframes overlay-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.doc-modal {
  background: #fff;
  border-radius: 28px;
  box-shadow: 0 40px 80px rgba(0,0,0,.28), 0 0 0 1px rgba(11,107,58,.08);
  width: min(920px, 100%);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: modal-in .22s cubic-bezier(.22,1,.36,1);
}
@keyframes modal-in {
  from { opacity: 0; transform: scale(.96) translateY(12px); }
  to   { opacity: 1; transform: scale(1)  translateY(0); }
}

.doc-modal-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
  background: #fafcfb;
}
.doc-modal-meta { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.doc-modal-type {
  display: inline-flex;
  align-items: center;
  padding: 3px 8px;
  border-radius: 8px;
  background: var(--teal-soft);
  color: var(--teal-mid);
  font-size: 9px;
  font-weight: 900;
  letter-spacing: .06em;
  width: -moz-fit-content;
  width: fit-content;
  margin-bottom: 4px;
}
.doc-modal-meta h4 {
  margin: 0;
  color: var(--text);
  font-size: 15px;
  font-weight: 900;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.doc-modal-sub { color: #8a98a6; font-size: 11px; font-weight: 700; }
.doc-modal-actions { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }

.doc-modal-close {
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid var(--border);
  background: #fff;
  color: #657482;
  display: grid;
  place-items: center;
  cursor: pointer;
  transition: all .18s ease;
  flex-shrink: 0;
}
.doc-modal-close:hover {
  background: var(--danger-soft);
  color: var(--danger);
  border-color: rgba(239,68,68,.2);
}

.doc-modal-body {
  flex: 1 1;
  overflow: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 280px;
  background: #f6f8f7;
}

.doc-modal-loading {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  color: #8a98a6;
  font-size: 13px;
  font-weight: 700;
}
.doc-modal-spinner {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  border: 3px solid var(--border);
  border-top-color: var(--teal-mid);
  animation: spin .7s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.doc-modal-iframe {
  width: 100%;
  height: 76vh;
  border: 0;
  display: block;
}

.doc-modal-img {
  max-width: 100%;
  max-height: 76vh;
  object-fit: contain;
  display: block;
  border-radius: 4px;
  margin: 16px;
  box-shadow: 0 8px 32px rgba(0,0,0,.12);
}

.doc-modal-err {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 40px;
  color: #8a98a6;
  text-align: center;
}
.doc-modal-err svg { color: var(--warning); }
.doc-modal-err p { margin: 0; font-size: 13px; font-weight: 700; max-width: 320px; line-height: 1.7; }

.doc-modal-download {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 48px 32px;
  color: #8a98a6;
  text-align: center;
}
.doc-modal-download svg { color: var(--teal-mid); opacity: .7; }
.doc-modal-download p { margin: 0; font-size: 13px; font-weight: 700; max-width: 300px; line-height: 1.7; }

/* ══════════════════════════════════════════════
   Tab edit bar
   ══════════════════════════════════════════════ */
.tab-edit-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 0 0 14px;
  min-height: 40px;
}
.tab-edit-bar.editing {
  background: linear-gradient(135deg, #f0fdf4, #e8f4f8);
  border: 1.5px solid rgba(26,106,138,.22);
  border-radius: 14px;
  padding: 12px 18px;
  margin-bottom: 16px;
  animation: edit-bar-in .2s ease;
}
@keyframes edit-bar-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.tab-edit-bar-copy {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--teal-mid);
}
.tab-edit-bar-copy svg { flex-shrink: 0; }
.tab-edit-bar-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.tab-edit-err {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--danger);
  background: var(--danger-soft);
  border-radius: 8px;
  padding: 4px 10px;
}

/* Edit tab button (view mode) */
.edit-tab-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 10px;
  border: 1.5px solid var(--together-border);
  background: #fff;
  color: var(--teal-mid);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, border-color .15s, box-shadow .15s;
  white-space: nowrap;
}
.edit-tab-btn:hover {
  background: var(--teal-soft);
  border-color: var(--teal-mid);
  box-shadow: 0 2px 8px rgba(26,106,138,.12);
}

/* Save / Cancel buttons */
.save-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 20px;
  border-radius: 12px;
  border: none;
  background: linear-gradient(135deg, var(--together-green), var(--together-green-2));
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  box-shadow: 0 4px 14px rgba(11,107,58,.28);
  transition: opacity .15s, box-shadow .15s, transform .1s;
}
.save-btn:hover:not(:disabled) {
  opacity: .92;
  box-shadow: 0 6px 18px rgba(11,107,58,.34);
}
.save-btn:active:not(:disabled) { transform: scale(.97); }
.save-btn:disabled { opacity: .55; cursor: not-allowed; }

.cancel-btn {
  display: inline-flex;
  align-items: center;
  padding: 8px 16px;
  border-radius: 12px;
  border: 1.5px solid var(--border);
  background: #fff;
  color: var(--together-text);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background .15s, border-color .15s;
}
.cancel-btn:hover:not(:disabled) {
  background: #f8fafb;
  border-color: #c8d0d8;
}
.cancel-btn:disabled { opacity: .5; cursor: not-allowed; }

/* Spinner inside save button */
.save-spinner {
  display: inline-block;
  width: 13px;
  height: 13px;
  border: 2px solid rgba(255,255,255,.35);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin .7s linear infinite;
  flex-shrink: 0;
}

/* Inline edit fields */
.edit-field {
  display: block;
  width: 100%;
  padding: 6px 10px;
  border-radius: 8px;
  border: 1.5px solid rgba(26,106,138,.28);
  background: #fff;
  color: var(--together-text);
  font-size: 13px;
  font-weight: 600;
  transition: border-color .15s, box-shadow .15s;
  outline: none;
}
.edit-field:focus {
  border-color: var(--teal-mid);
  box-shadow: 0 0 0 3px rgba(26,106,138,.13);
}
.edit-field-select {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M6 9l6 6 6-6' stroke='%231a6a8a' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: left 10px center;
  background-size: 16px;
  padding-left: 30px;
}

/* Editing indicator on tab button */
.module-tab.tab-editing {
  border-color: var(--teal-mid) !important;
}
.tab-editing-dot {
  display: inline-block;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--teal-mid);
  margin-right: 4px;
  animation: pulse-dot 1.4s ease-in-out infinite;
}
@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .5; transform: scale(.75); }
}

/* ══════════════════════════════════════════════
   Employee actions dropdown
   ══════════════════════════════════════════════ */
.emp-actions-wrap {
  position: relative;
  flex-shrink: 0;
}

.emp-actions-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: 10px;
  border: 1.5px solid var(--together-border);
  background: #fff;
  color: var(--together-text);
  font-size: 12.5px;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
  transition: background .15s, border-color .15s, box-shadow .15s;
  box-shadow: 0 2px 6px rgba(11,107,58,.06);
}
.emp-actions-btn:hover {
  background: var(--together-mint);
  border-color: rgba(11,107,58,.3);
  box-shadow: 0 4px 12px rgba(11,107,58,.1);
}
.emp-actions-btn[aria-expanded="true"] {
  background: var(--together-mint);
  border-color: rgba(11,107,58,.35);
}

.emp-actions-menu {
  position: absolute;
  top: calc(100% + 8px);
  inset-inline-end: 0;
  min-width: 230px;
  background: #fff;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  box-shadow: 0 16px 48px rgba(11,107,58,.13), 0 4px 16px rgba(0,0,0,.07);
  z-index: 200;
  overflow: hidden;
  animation: dropdown-in .18s ease;
}
@keyframes dropdown-in {
  from { opacity: 0; transform: translateY(-8px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.emp-actions-group {
  padding: 6px 0;
  border-bottom: 1px solid var(--border);
}
.emp-actions-group:last-child { border-bottom: none; }

.emp-actions-group-label {
  display: block;
  padding: 4px 14px 2px;
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--text-muted);
}

.emp-action-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 14px;
  border: none;
  background: transparent;
  color: var(--together-text);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  text-decoration: none;
  text-align: start;
  transition: background .12s, color .12s;
}
.emp-action-item:hover {
  background: var(--together-mint);
  color: var(--together-green);
}
.emp-action-item.danger { color: #c0392b; }
.emp-action-item .primary-btn:hover { background: linear-gradient(135deg, var(--together-green-light), var(--together-green)); box-shadow: 0 4px 12px rgba(11,107,58,0.3); }
.emp-action-item.danger:hover { background: var(--danger-soft); color: var(--danger); }

.act-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: var(--muted);
  color: var(--together-green);
  flex-shrink: 0;
}
.emp-action-item.danger .act-icon { background: var(--danger-soft); color: var(--danger); }

/* ── Premium Notification Bell & Dropdown ── */
.notification-bell-container {
  position: relative;
  display: inline-block;
}

.notification-bell-btn {
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid var(--together-border);
  border-radius: 12px;
  width: 42px;
  height: 42px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--together-text);
  cursor: pointer;
  transition: all 0.2s ease;
  position: relative;
}

.notification-bell-btn:hover {
  background: #f3faf5;
  border-color: rgba(165, 214, 63, 0.4);
  transform: translateY(-1px);
}

.notification-badge {
  position: absolute;
  top: 2px;
  right: 2px;
  background: #ef4444;
  color: #fff;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 800;
  min-width: 16px;
  height: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
  border: 2px solid #fff;
}

.notification-dropdown {
  position: absolute;
  top: 100%;
  left: 0;
  right: auto;
  width: 380px;
  margin-top: 8px;
  background: #ffffff;
  border: 1px solid var(--together-border);
  border-radius: 18px;
  box-shadow: 0 20px 48px rgba(0, 0, 0, 0.12);
  z-index: 50;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.notification-dropdown-header {
  padding: 14px 20px;
  border-bottom: 1px solid var(--together-border);
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #fafbfc;
}

.notification-dropdown-header h3 {
  margin: 0;
  font-size: 15px;
  color: var(--together-green);
  font-weight: 800;
}

.mark-all-read-btn {
  background: transparent;
  border: none;
  color: #16a34a;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  padding: 4px 8px;
  border-radius: 6px;
  transition: background 0.15s;
}

.mark-all-read-btn:hover {
  background: #f0fdf4;
}

.notification-list {
  max-height: 320px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
}

.notification-item {
  padding: 14px 20px;
  border-bottom: 1px solid var(--together-border);
  display: flex;
  flex-direction: column;
  gap: 4px;
  text-align: right;
  text-decoration: none;
  color: inherit;
  transition: background 0.15s;
}

.notification-item:hover {
  background: #f8fafc;
}

.notification-item.unread {
  background: #f0fdf4;
}

.notification-item.unread:hover {
  background: #ecfdf5;
}

.notification-item-title {
  font-size: 13px;
  font-weight: 800;
  color: #0f172a;
}

.notification-item-body {
  font-size: 11.5px;
  color: var(--together-muted);
  line-height: 1.6;
}

.notification-item-time {
  font-size: 9.5px;
  color: #94a3b8;
  margin-top: 4px;
}

.notification-empty-state {
  padding: 32px 20px;
  text-align: center;
  color: var(--together-muted);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.notification-empty-state svg {
  width: 40px;
  height: 40px;
  color: #cbd5e1;
}

.notification-dropdown-footer {
  padding: 12px 20px;
  border-top: 1px solid var(--together-border);
  background: #fafbfc;
  text-align: center;
}

.view-all-notifications-link {
  font-size: 12px;
  font-weight: 800;
  color: var(--together-green);
  text-decoration: none;
  transition: opacity 0.15s;
}

.view-all-notifications-link:hover {
  opacity: 0.8;
}


/*!*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************!*\
  !*** css ../../node_modules/next/dist/build/webpack/loaders/css-loader/src/index.js??ruleSet[1].rules[14].oneOf[2].use[1]!../../node_modules/next/dist/build/webpack/loaders/next-font-loader/index.js??ruleSet[1].rules[14].oneOf[2].use[2]!../../node_modules/next/font/google/target.css?{"path":"app/layout.tsx","import":"Cairo","arguments":[{"subsets":["arabic","latin"],"weight":["400","600","700","800","900"],"variable":"--font-cairo","display":"swap"}],"variableName":"cairo"} ***!
  \*************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************************/
/* arabic */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/350b852752f8489d-s.p.woff2) format('woff2');
  unicode-range: U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E, U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F, U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B, U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A, U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB, U+1EEF0-1EEF1;
}
/* latin-ext */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/5ec84f17416dda4d-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(/_next/static/media/01f0c602c274ea55-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* arabic */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/350b852752f8489d-s.p.woff2) format('woff2');
  unicode-range: U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E, U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F, U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B, U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A, U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB, U+1EEF0-1EEF1;
}
/* latin-ext */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/5ec84f17416dda4d-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url(/_next/static/media/01f0c602c274ea55-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* arabic */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/350b852752f8489d-s.p.woff2) format('woff2');
  unicode-range: U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E, U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F, U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B, U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A, U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB, U+1EEF0-1EEF1;
}
/* latin-ext */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/5ec84f17416dda4d-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(/_next/static/media/01f0c602c274ea55-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* arabic */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/350b852752f8489d-s.p.woff2) format('woff2');
  unicode-range: U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E, U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F, U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B, U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A, U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB, U+1EEF0-1EEF1;
}
/* latin-ext */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/5ec84f17416dda4d-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url(/_next/static/media/01f0c602c274ea55-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* arabic */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/350b852752f8489d-s.p.woff2) format('woff2');
  unicode-range: U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E, U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F, U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B, U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A, U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB, U+1EEF0-1EEF1;
}
/* latin-ext */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/5ec84f17416dda4d-s.woff2) format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Cairo';
  font-style: normal;
  font-weight: 900;
  font-display: swap;
  src: url(/_next/static/media/01f0c602c274ea55-s.p.woff2) format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}@font-face {font-family: 'Cairo Fallback';src: local("Arial");ascent-override: 137.65%;descent-override: 60.32%;line-gap-override: 0.00%;size-adjust: 94.66%
}.__className_b80265 {font-family: 'Cairo', 'Cairo Fallback';font-style: normal
}.__variable_b80265 {--font-cairo: 'Cairo', 'Cairo Fallback'
}

