:root{
  /* Sneat-like light palette */
  --bg: #f5f6fb;
  --surface: rgba(255,255,255,0.92);
  --surface-2: rgba(255,255,255,0.86);
  --text: #1b1e2b;
  --muted: #6b7280;
  --border: rgba(18, 24, 40, 0.08);

  --shadow-sm: 0 10px 20px rgba(18, 24, 40, 0.06);
  --shadow-md: 0 26px 60px rgba(18, 24, 40, 0.10);
  --shadow-lg: 0 40px 90px rgba(18, 24, 40, 0.14);

  --radius-lg: 24px;
  --radius-md: 18px;
  --radius-sm: 14px;
  --ring: 0 0 0 4px rgba(105, 108, 255, 0.22);

  --accent: #696cff;      /* Sneat-ish indigo */
  --accent-2: #03c3ec;    /* cyan accent */
  --accent-soft: rgba(105, 108, 255, 0.12);
  --accent-soft-2: rgba(3, 195, 236, 0.10);

  --g-1: 8px;
  --g-2: 16px;
  --g-3: 24px;
  --g-4: 32px;
  --g-5: 40px;

  /* Layout sizing */
  --sidebar-w: 296px;
  --sidebar-w-collapsed: 92px;

  /* Sidebar */
  --sidenav-pad: 16px;
  --sidenav-card-pad: 18px;
}

html, body{
  height: 100%;
}

body{
  font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  background:
    radial-gradient(1000px 520px at 12% 0%, rgba(105, 108, 255, 0.18), transparent 55%),
    radial-gradient(900px 520px at 88% 10%, rgba(3, 195, 236, 0.14), transparent 56%),
    radial-gradient(980px 560px at 50% 100%, rgba(168, 85, 247, 0.10), transparent 60%),
    var(--bg);
  color: var(--text);
}

/* Auth background image */
.auth-bg{
  background:
    radial-gradient(900px 520px at 10% 0%, rgba(105, 108, 255, 0.22), transparent 55%),
    radial-gradient(820px 520px at 90% 10%, rgba(3, 195, 236, 0.16), transparent 56%),
    linear-gradient(180deg, rgba(245,246,251,0.78), rgba(245,246,251,0.92)),
    url("/public/assets/img/login-bg.jpg") center/cover no-repeat,
    var(--bg);
}

.auth-bg .card-surface{
  background: linear-gradient(180deg, rgba(255,255,255,0.86), rgba(255,255,255,0.78));
  backdrop-filter: blur(16px);
  box-shadow: var(--shadow-lg);
}

/* Auth (login/setup) */
.auth-head{
  margin-bottom: 18px;
}
.auth-title{
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.03em;
  font-size: 1.6rem;
  margin: 0;
}
.auth-form .form-control{
  border-radius: 18px;
}
.auth-submit{
  height: 48px;
  font-weight: 700;
}
.auth-divider{
  position: relative;
  text-align: center;
  margin: 14px 0;
}
.auth-divider::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top: 50%;
  height:1px;
  background: rgba(18,24,40,0.10);
}
.auth-divider span{
  position: relative;
  display:inline-flex;
  padding: 0 12px;
  background: rgba(255,255,255,0.88);
  color: var(--muted);
  font-size: .85rem;
}

.h-title{
  font-family: Poppins, Inter, system-ui, sans-serif;
  letter-spacing: -0.02em;
}

.text-muted-2{ color: var(--muted) !important; }
.text-sm{ font-size: .875rem; }
.text-xs{ font-size: .75rem; }

.app{
  min-height: 100vh;
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
}

/* Collapsed sidebar (desktop) */
.sidebar-collapsed .app{
  grid-template-columns: var(--sidebar-w-collapsed) 1fr;
}
.sidebar-collapsed .sidenav{
  padding: 14px;
}
.sidebar-collapsed .sidenav__brandText,
.sidebar-collapsed .sidenav__section,
.sidebar-collapsed .sidenav__label,
.sidebar-collapsed .sidenav__userText{
  display:none;
}
.sidebar-collapsed .sidenav__brand{
  justify-content:center;
}
.sidebar-collapsed .sidenav__item{
  justify-content:center;
}
.sidebar-collapsed .sidenav__footer{
  justify-content:center;
}
.sidebar-collapsed .sidenav__actions{
  width: 100%;
  justify-content:center;
}

.sidebar{
  position: sticky;
  top: 0;
  height: 100vh;
  padding: var(--sidenav-pad);
  width: 100%;
}

/* New sidebar (built from scratch) */
.sidenav{
  height: 100%;
  width: 100%;
  border-radius: var(--radius-lg);
  background: linear-gradient(180deg, rgba(255,255,255,0.94), rgba(255,255,255,0.84));
  backdrop-filter: blur(14px);
  border: 1px solid var(--border);
  box-shadow: var(--shadow-lg);
  padding: var(--sidenav-card-pad);
  display:flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
}

.sidenav__header{
  padding: 2px 2px 6px;
}
.sidenav__brand{
  display:flex;
  align-items:center;
  gap: 12px;
  text-decoration:none;
  color: inherit;
  padding: 8px 10px;
  border-radius: 18px;
  border: 1px solid transparent;
  transition: background .18s ease, border-color .18s ease;
}
.sidenav__brand:hover{
  background: rgba(105,108,255,0.06);
  border-color: rgba(105,108,255,0.10);
}
.sidenav__logo{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--accent), var(--accent-2));
  box-shadow: 0 18px 32px rgba(105, 108, 255, 0.22);
  color: #fff;
  display:flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
}
.sidenav__brandText{
  display:flex;
  flex-direction: column;
  min-width: 0;
}
.sidenav__title{
  font-family: Poppins, Inter, system-ui, sans-serif;
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.sidenav__subtitle{
  color: var(--muted);
  font-size: .82rem;
  line-height: 1.15;
}

.sidenav__nav{
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 4px 2px 8px;
  display:flex;
  flex-direction: column;
  gap: 6px;
}
.sidenav__section{
  color: var(--muted);
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .10em;
  padding: 10px 10px 4px;
}
.sidenav__item{
  display:flex;
  align-items:center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 18px;
  text-decoration: none;
  color: var(--text);
  border: 1px solid transparent;
  transition: transform .18s ease, background .18s ease, box-shadow .18s ease, border-color .18s ease;
  position: relative;
}
.sidenav__item:hover{
  background: rgba(105, 108, 255, 0.06);
  transform: translateY(-1px);
}
.sidenav__icon{
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: rgba(105,108,255,0.06);
  color: rgba(27,30,43,0.70);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  flex: 0 0 auto;
  font-size: 20px;
}
.sidenav__label{
  font-weight: 600;
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sidenav__item.is-active{
  background: linear-gradient(180deg, rgba(105,108,255,0.16), rgba(105,108,255,0.10));
  border-color: rgba(105, 108, 255, 0.22);
  box-shadow: 0 16px 34px rgba(105, 108, 255, 0.12);
}
.sidenav__item.is-active .sidenav__icon{
  background: rgba(105,108,255,0.14);
  color: var(--accent);
}
.sidenav__item.is-active::before{
  content:"";
  position:absolute;
  left: 10px;
  top: 12px;
  bottom: 12px;
  width: 3px;
  border-radius: 999px;
  background: linear-gradient(180deg, var(--accent), var(--accent-2));
}

.sidenav__footer{
  border-top: 1px solid var(--border);
  padding-top: 12px;
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: 10px;
}
.sidenav__user{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
  padding: 8px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.74);
  backdrop-filter: blur(10px);
}
.sidenav__userIcon{
  font-size: 18px;
  color: var(--muted);
}
.sidenav__userText{
  display:flex;
  flex-direction: column;
  min-width: 0;
}
.sidenav__userName{
  font-size: .86rem;
  font-weight: 600;
  line-height: 1.1;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 150px;
}
.sidenav__userRole{
  font-size: .78rem;
  color: var(--muted);
  line-height: 1.1;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  max-width: 150px;
}
.sidenav__actions{
  display:flex;
  align-items:center;
  gap: 10px;
}

/* Scrollbar (sidebar) */
.sidenav__nav::-webkit-scrollbar{ width: 10px; }
.sidenav__nav::-webkit-scrollbar-track{ background: transparent; }
.sidenav__nav::-webkit-scrollbar-thumb{
  background: rgba(18, 24, 40, 0.12);
  border-radius: 999px;
  border: 3px solid transparent;
  background-clip: content-box;
}
.sidenav__nav:hover::-webkit-scrollbar-thumb{
  background: rgba(18, 24, 40, 0.18);
  border: 3px solid transparent;
  background-clip: content-box;
}

/* legacy sidebar styles removed */

/* legacy icon styles removed */
.nav a .nav-label{
  font-weight: 600;
  letter-spacing: -0.01em;
}

/* legacy nav hover/active moved to .sidenav__item */

.sidebar-footer{
  margin-top: auto;
  padding-top: var(--g-2);
  border-top: 1px solid var(--border);
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: var(--g-2);
}

/* old sidebar scrollbar removed (nav -> sidenav__nav) */

.pill{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  backdrop-filter: blur(10px);
}

.content{
  padding: var(--g-3) var(--g-5) var(--g-5);
}

.topbar{
  display:flex;
  align-items:center;
  justify-content: space-between;
  gap: var(--g-2);
  margin-bottom: var(--g-3);
  padding: 14px 16px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: linear-gradient(180deg, rgba(255,255,255,0.85), rgba(255,255,255,0.72));
  backdrop-filter: blur(14px);
  box-shadow: var(--shadow-md);
}

.search{
  flex: 1;
  max-width: 560px;
  position: relative;
}

.search .mi{
  position:absolute;
  top: 50%;
  left: 14px;
  transform: translateY(-50%);
  color: var(--muted);
  pointer-events:none;
}

.search input{
  width: 100%;
  padding: 12px 14px 12px 44px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.86);
  box-shadow: var(--shadow-sm);
  outline: none;
  transition: box-shadow .2s ease, border-color .2s ease;
}

.search input:focus{
  border-color: rgba(79, 70, 229, 0.35);
  box-shadow: var(--shadow-sm), var(--ring);
}

.top-actions{
  display:flex;
  align-items:center;
  gap: 10px;
}

.icon-btn{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.86);
  box-shadow: var(--shadow-sm);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color: var(--text);
  transition: transform .2s ease, box-shadow .2s ease;
}
.icon-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 22px 46px rgba(18, 24, 40, 0.12);
}

.card-surface{
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,0.82));
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(14px);
}

/* Bootstrap UI polish (global) */
.dropdown-menu{
  border-radius: 16px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.92);
  backdrop-filter: blur(10px);
}
.dropdown-item{
  border-radius: 12px;
}
.dropdown-item:active{
  background: var(--accent-soft);
  color: var(--text);
}

.card{
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(12px);
  box-shadow: var(--shadow-md);
}

.form-control, .form-select{
  border-radius: 16px;
  border-color: rgba(15, 23, 42, 0.10);
  background: rgba(255,255,255,0.85);
  box-shadow: var(--shadow-sm);
}
.form-control:focus, .form-select:focus{
  border-color: rgba(79, 70, 229, 0.35);
  box-shadow: var(--shadow-sm), var(--ring);
}
.form-floating > label{
  color: var(--muted);
}

.table{
  --bs-table-bg: transparent;
}
.table > :not(caption) > * > *{
  border-bottom-color: rgba(15, 23, 42, 0.08);
}

.btn-primary{
  border-radius: 14px;
  background: var(--accent);
  border-color: rgba(79,70,229,.25);
  box-shadow: 0 18px 34px rgba(105, 108, 255, 0.20);
}
.btn-primary:hover{
  background: #5a5cf4;
  border-color: rgba(105,108,255,.35);
}
.btn-outline-secondary, .btn-outline-primary, .btn-outline-danger{
  border-radius: 14px;
}

.alert{
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.75);
  backdrop-filter: blur(10px);
}

.stats-grid{
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--g-2);
  margin-bottom: var(--g-3);
}

.stat-card{
  padding: var(--g-3);
  position: relative;
  overflow:hidden;
  transition: transform .2s ease, box-shadow .2s ease;
}
.stat-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 30px 70px rgba(18, 24, 40, 0.12);
}
.stat-card::after{
  content:"";
  position:absolute;
  inset: -40% -20% auto auto;
  width: 220px;
  height: 220px;
  background: radial-gradient(circle at 30% 30%, rgba(105,108,255,0.22), transparent 60%),
              radial-gradient(circle at 70% 60%, rgba(3,195,236,0.16), transparent 62%);
  transform: rotate(18deg);
  pointer-events:none;
}
.stat-icon{
  width: 48px; height: 48px;
  border-radius: 16px;
  background: linear-gradient(180deg, rgba(105,108,255,0.14), rgba(105,108,255,0.10));
  color: var(--accent);
  display:flex; align-items:center; justify-content:center;
}
.stat-value{
  font-family: Poppins, Inter, sans-serif;
  font-weight: 700;
  font-size: 1.75rem;
  letter-spacing: -0.02em;
}
.stat-delta{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.55);
}

.grid-2{
  display:grid;
  grid-template-columns: 1.3fr 0.7fr;
  gap: var(--g-2);
  margin-bottom: var(--g-3);
}

.emp-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--g-2);
}

.emp-card{
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
}
.emp-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.emp-top{
  display:flex;
  align-items:center;
  gap: 12px;
}
.emp-avatar{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--accent);
  background: linear-gradient(180deg, rgba(105,108,255,0.14), rgba(105,108,255,0.08));
  border: 1px solid rgba(105,108,255,0.14);
}
.emp-meta{
  min-width: 0;
  flex: 1 1 auto;
}
.emp-name{
  display:block;
  text-decoration:none;
  color: var(--text);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.emp-name:hover{ color: var(--accent); }
.emp-sub{
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.emp-actions{
  display:flex;
  gap: 8px;
}
.emp-actions .icon-btn{
  width: 40px;
  height: 40px;
  border-radius: 14px;
}

.emp-info{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.emp-row{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}
.emp-ico{
  font-size: 18px;
  color: rgba(27,30,43,0.55);
}
.emp-val{
  color: rgba(27,30,43,0.84);
  font-size: .9rem;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.emp-footer{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  display:flex;
  justify-content:flex-end;
}

.dept-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--g-2);
}

.dept-card{
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
}
.dept-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.dept-top{
  display:flex;
  align-items:center;
  gap: 12px;
}
.dept-avatar{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: rgba(3,195,236,0.95);
  background: linear-gradient(180deg, rgba(3,195,236,0.14), rgba(3,195,236,0.08));
  border: 1px solid rgba(3,195,236,0.14);
}
.dept-meta{
  min-width: 0;
  flex: 1 1 auto;
}
.dept-name{
  display:block;
  text-decoration:none;
  color: var(--text);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.15;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dept-name:hover{ color: var(--accent); }
.dept-sub{
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.dept-actions{
  display:flex;
  gap: 8px;
}
.dept-actions .icon-btn{
  width: 40px;
  height: 40px;
  border-radius: 14px;
}

.dept-info{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.dept-row{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}
.dept-ico{
  font-size: 18px;
  color: rgba(27,30,43,0.55);
}
.dept-val{
  color: rgba(27,30,43,0.84);
  font-size: .9rem;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.dept-footer{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  display:flex;
  justify-content:flex-end;
}

.pos-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--g-2);
}

.pos-card{
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
}
.pos-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.pos-top{
  display:flex;
  align-items:center;
  gap: 12px;
}
.pos-avatar{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: rgba(105,108,255,0.95);
  background: linear-gradient(180deg, rgba(105,108,255,0.14), rgba(105,108,255,0.08));
  border: 1px solid rgba(105,108,255,0.14);
}
.pos-meta{
  min-width: 0;
  flex: 1 1 auto;
}
.pos-name{
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pos-sub{
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.pos-actions{
  display:flex;
  gap: 8px;
}
.pos-actions .icon-btn{
  width: 40px;
  height: 40px;
  border-radius: 14px;
}

.pos-info{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.pos-row{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}
.pos-ico{
  font-size: 18px;
  color: rgba(27,30,43,0.55);
}
.pos-val{
  color: rgba(27,30,43,0.84);
  font-size: .9rem;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.pos-footer{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  display:flex;
  justify-content:flex-end;
}

.rep-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--g-2);
}
.rep-card{
  padding: 16px;
}
.rep-title{
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.rep-desc{
  margin-top: 6px;
}
.rep-actions{
  margin-top: 14px;
  display:flex;
  gap: 10px;
}
.rep-actions .btn{
  flex: 1 1 auto;
}

.vac-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--g-2);
}

.vac-card{
  padding: 16px;
  transition: transform .18s ease, box-shadow .18s ease;
}
.vac-card:hover{
  transform: translateY(-2px);
  box-shadow: var(--shadow-lg);
}

.vac-top{
  display:flex;
  align-items:center;
  gap: 12px;
}
.vac-avatar{
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: rgba(105,108,255,0.95);
  background: linear-gradient(180deg, rgba(105,108,255,0.14), rgba(105,108,255,0.08));
  border: 1px solid rgba(105,108,255,0.14);
}
.vac-meta{
  min-width: 0;
  flex: 1 1 auto;
}
.vac-name{
  display:block;
  text-decoration:none;
  color: var(--text);
  font-weight: 800;
  letter-spacing: -0.02em;
  line-height: 1.15;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.vac-name:hover{ color: var(--accent); }
.vac-sub{
  display:flex;
  align-items:center;
  min-width: 0;
}
.vac-actions{
  display:flex;
  gap: 8px;
}
.vac-actions .icon-btn{
  width: 40px;
  height: 40px;
  border-radius: 14px;
}

.vac-pill{
  display:inline-flex;
  align-items:center;
  padding: 5px 10px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 700;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.68);
}
.vac-pill--ok{
  border-color: rgba(34,197,94,0.25);
  color: rgba(22,101,52,0.95);
  background: rgba(34,197,94,0.10);
}
.vac-pill--warn{
  border-color: rgba(245,158,11,0.25);
  color: rgba(120,53,15,0.95);
  background: rgba(245,158,11,0.10);
}
.vac-pill--bad{
  border-color: rgba(239,68,68,0.25);
  color: rgba(127,29,29,0.95);
  background: rgba(239,68,68,0.10);
}
.vac-pill--muted{
  border-color: rgba(27,30,43,0.10);
  color: rgba(27,30,43,0.70);
  background: rgba(27,30,43,0.05);
}

.vac-info{
  margin-top: 14px;
  display:grid;
  gap: 10px;
}
.vac-row{
  display:flex;
  align-items:center;
  gap: 10px;
  min-width: 0;
}
.vac-ico{
  font-size: 18px;
  color: rgba(27,30,43,0.55);
}
.vac-val{
  color: rgba(27,30,43,0.84);
  font-size: .9rem;
  overflow:hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.vac-footer{
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  display:flex;
  justify-content:flex-end;
}

.panel{
  padding: var(--g-3);
}

.panel-head{
  display:flex;
  align-items:flex-end;
  justify-content: space-between;
  gap: var(--g-2);
  margin-bottom: var(--g-2);
}

.table-wrap{
  overflow:auto;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.75);
}

table{
  margin: 0;
}

thead th{
  font-size: .75rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--muted);
  background: rgba(15, 23, 42, 0.02);
  border-bottom: 1px solid var(--border) !important;
  user-select: none;
}

tbody tr{
  transition: background .2s ease, transform .2s ease;
}
tbody tr:hover{
  background: rgba(79, 70, 229, 0.06);
}

.btn-soft{
  border-radius: 14px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,0.7);
  box-shadow: var(--shadow-sm);
}
.btn-soft:hover{
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.10);
}

.fade-in{
  animation: fadeInUp .55s ease both;
}
@keyframes fadeInUp{
  from{ opacity: 0; transform: translateY(10px); }
  to{ opacity: 1; transform: translateY(0); }
}

/* Responsive */
@media (max-width: 1200px){
  :root{ --sidebar-w: 272px; }
  .stats-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .grid-2{ grid-template-columns: 1fr; }
  .emp-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dept-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .pos-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .vac-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .rep-grid{ grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .content{ padding: var(--g-3); }
}

@media (max-width: 900px){
  .app{ grid-template-columns: 1fr; }
  .emp-grid{ grid-template-columns: 1fr; }
  .dept-grid{ grid-template-columns: 1fr; }
  .pos-grid{ grid-template-columns: 1fr; }
  .vac-grid{ grid-template-columns: 1fr; }
  .rep-grid{ grid-template-columns: 1fr; }
  .sidebar{
    position: fixed;
    inset: 0 auto 0 0;
    width: min(92vw, 340px);
    transform: translateX(-110%);
    transition: transform .25s ease;
    z-index: 1050;
  }
  .sidebar-collapsed .app{ grid-template-columns: 1fr; }
  .sidebar-collapsed .sidebar{ padding: 16px; }
  .sidebar.open{ transform: translateX(0); }
  .sidebar-backdrop{
    position: fixed;
    inset: 0;
    background: rgba(15, 23, 42, 0.35);
    backdrop-filter: blur(6px);
    z-index: 1040;
    opacity: 0;
    pointer-events: none;
    transition: opacity .25s ease;
  }
  .sidebar-backdrop.show{
    opacity: 1;
    pointer-events: auto;
  }
  .topbar{ gap: 10px; }
  .search{ max-width: none; }
}

